Received: by 2002:ac0:a679:0:0:0:0:0 with SMTP id p54csp284091imp; Thu, 21 Feb 2019 01:11:29 -0800 (PST) X-Google-Smtp-Source: AHgI3IbMxRELF49vrPwq4LEWmvovg2gTqCHh+6wGRJl5229pjR7QEZYX/89VBpld+zXyyShHHNv+ X-Received: by 2002:a17:902:8e82:: with SMTP id bg2mr3976459plb.217.1550740289433; Thu, 21 Feb 2019 01:11:29 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1550740289; cv=none; d=google.com; s=arc-20160816; b=CoLMeE9lSG5+Detfdlf1jZ+hb+Dh4PwOtXNiYA7VUil9YQ+b0ygSKqTsosJSe9+kUq N9aAxk/g1wNF6BURLcaPo/ONDmn/1seIIOmRTxq1rp/1EVnNQteak3+0jkK0rdeJJRTD K6HOmbBJTwQDUAuuQ+gNuoksn4L+S7YUyluQTY+z1w/30tr0hZ2u/zXANNm2NaIx3mBh lw/uEfuHjY9yDhS3hdIYKJwuSg0bjmZ3jb810h3irI+tEQ+DYCXt+HC6c8ddFuhnwzI1 wtyVgpFBN1ktdQ8Cn5W2Xqu/R7LjlhH5ZtGB8Io8+eeePNfAdkottkmpW9cdaB8IQMoE Fn+w== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:message-id:subject:cc :to:from:date; bh=rMYsCCa2Y0H7Cv2g3Jz/Q1W2appTnLlvAaHmlowRD5s=; b=mPNDQZZoZEZQMkq0nd4gKXieOu5E5A+A54mlMHOvC09Qs4AYw+1/35miNqH1lfcWNC 6PidVxHrVAEAtwC9WfxkexwZcyhtMP6wm4gfufjNN6e9R8OtlUfC+jCeXrtRD3CuGCmY MvAi+prx9wiZt1ZrK3WPJv6XFzg5wQ3TdlEwc23GcS3seaK9v37S4eBQS8YPA1aSy5gP jyfo/Q7FRaRvKpHq6Rt4Pe/mu0Ej9UNLWEssWcqFGaFEVxqBuhaJvGSY/2BlX8WQjI32 cXFWn6gEE1jVuWUr5G85SOL11V3tqJoMjYgrOfPkFyilfE/QOZ12FCfWpWiaiKja3SIA 44FQ== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id t1si2920797plo.371.2019.02.21.01.11.13; Thu, 21 Feb 2019 01:11:29 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727401AbfBUJIy (ORCPT + 99 others); Thu, 21 Feb 2019 04:08:54 -0500 Received: from mga04.intel.com ([192.55.52.120]:16991 "EHLO mga04.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726184AbfBUJIy (ORCPT ); Thu, 21 Feb 2019 04:08:54 -0500 X-Amp-Result: UNKNOWN X-Amp-Original-Verdict: FILE UNKNOWN X-Amp-File-Uploaded: False Received: from fmsmga001.fm.intel.com ([10.253.24.23]) by fmsmga104.fm.intel.com with ESMTP/TLS/DHE-RSA-AES256-GCM-SHA384; 21 Feb 2019 01:08:53 -0800 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.58,394,1544515200"; d="scan'208";a="148634708" Received: from kuha.fi.intel.com ([10.237.72.189]) by fmsmga001.fm.intel.com with SMTP; 21 Feb 2019 01:08:51 -0800 Received: by kuha.fi.intel.com (sSMTP sendmail emulation); Thu, 21 Feb 2019 11:08:50 +0200 Date: Thu, 21 Feb 2019 11:08:50 +0200 From: Heikki Krogerus To: Nikolaus Voss Cc: Greg Kroah-Hartman , Guenter Roeck , linux-usb@vger.kernel.org, linux-kernel@vger.kernel.org, Nikolaus Voss Subject: Re: [PATCHv3] usb: typec: tps6598x: handle block writes separately with plain-I2C adapters Message-ID: <20190221090850.GE5054@kuha.fi.intel.com> References: <20190220110017.BFA344CE86@mail.steuer-voss.de> <20190220151138.12332-1-nv@vosn.de> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20190220151138.12332-1-nv@vosn.de> User-Agent: Mutt/1.10.1 (2018-07-13) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Wed, Feb 20, 2019 at 04:11:38PM +0100, Nikolaus Voss wrote: > From: Nikolaus Voss > > Commit 1a2f474d328f handles block _reads_ separately with plain-I2C > adapters, but the problem described with regmap-i2c not handling > SMBus block transfers (i.e. read and writes) correctly also exists > with writes. > > As workaround, this patch adds a block write function the same way > 1a2f474d328f adds a block read function. > > Fixes: 1a2f474d328f ("usb: typec: tps6598x: handle block reads separately with plain-I2C adapters") > Fixes: 0a4c005bd171 ("usb: typec: driver for TI TPS6598x USB Power Delivery controllers") > Signed-off-by: Nikolaus Voss Acked-by: Heikki Krogerus > --- > v2: fix tps6598x_exec_cmd also > v3: use fixed length for stack buffer > --- > drivers/usb/typec/tps6598x.c | 26 ++++++++++++++++++++------ > 1 file changed, 20 insertions(+), 6 deletions(-) > > diff --git a/drivers/usb/typec/tps6598x.c b/drivers/usb/typec/tps6598x.c > index c84c8c189e90..eb8046f87a54 100644 > --- a/drivers/usb/typec/tps6598x.c > +++ b/drivers/usb/typec/tps6598x.c > @@ -110,6 +110,20 @@ tps6598x_block_read(struct tps6598x *tps, u8 reg, void *val, size_t len) > return 0; > } > > +static int tps6598x_block_write(struct tps6598x *tps, u8 reg, > + void *val, size_t len) > +{ > + u8 data[TPS_MAX_LEN + 1]; > + > + if (!tps->i2c_protocol) > + return regmap_raw_write(tps->regmap, reg, val, len); > + > + data[0] = len; > + memcpy(&data[1], val, len); > + > + return regmap_raw_write(tps->regmap, reg, data, sizeof(data)); > +} > + > static inline int tps6598x_read16(struct tps6598x *tps, u8 reg, u16 *val) > { > return tps6598x_block_read(tps, reg, val, sizeof(u16)); > @@ -127,23 +141,23 @@ static inline int tps6598x_read64(struct tps6598x *tps, u8 reg, u64 *val) > > static inline int tps6598x_write16(struct tps6598x *tps, u8 reg, u16 val) > { > - return regmap_raw_write(tps->regmap, reg, &val, sizeof(u16)); > + return tps6598x_block_write(tps, reg, &val, sizeof(u16)); > } > > static inline int tps6598x_write32(struct tps6598x *tps, u8 reg, u32 val) > { > - return regmap_raw_write(tps->regmap, reg, &val, sizeof(u32)); > + return tps6598x_block_write(tps, reg, &val, sizeof(u32)); > } > > static inline int tps6598x_write64(struct tps6598x *tps, u8 reg, u64 val) > { > - return regmap_raw_write(tps->regmap, reg, &val, sizeof(u64)); > + return tps6598x_block_write(tps, reg, &val, sizeof(u64)); > } > > static inline int > tps6598x_write_4cc(struct tps6598x *tps, u8 reg, const char *val) > { > - return regmap_raw_write(tps->regmap, reg, &val, sizeof(u32)); > + return tps6598x_block_write(tps, reg, &val, sizeof(u32)); > } > > static int tps6598x_read_partner_identity(struct tps6598x *tps) > @@ -229,8 +243,8 @@ static int tps6598x_exec_cmd(struct tps6598x *tps, const char *cmd, > return -EBUSY; > > if (in_len) { > - ret = regmap_raw_write(tps->regmap, TPS_REG_DATA1, > - in_data, in_len); > + ret = tps6598x_block_write(tps, TPS_REG_DATA1, > + in_data, in_len); > if (ret) > return ret; > } > -- > 2.17.1 thanks, -- heikki