Received: by 2002:ac0:a679:0:0:0:0:0 with SMTP id p54csp509057imp; Wed, 20 Feb 2019 04:15:35 -0800 (PST) X-Google-Smtp-Source: AHgI3IZyX+/xH5NS8mI9E44NvC2fhBevKu28VimQSt84q9qLmtaAMCVh1QNGG99rMCXsWaCExeGG X-Received: by 2002:a62:12d5:: with SMTP id 82mr34740865pfs.255.1550664935665; Wed, 20 Feb 2019 04:15:35 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1550664935; cv=none; d=google.com; s=arc-20160816; b=WTRaiajSCMAHmmgUJ8w+TA9cQcPkR1sq6M3Py+8yinIXQSAw29V+sB3X1zv0GIwrn2 ul3TMSotR4IXl8d5ADNfZTPQ66b/mGe4EKAXGo/k0siLn7gJt+1udzb+37KKTdK+Xj+z 6E3jv3p94wNQfRf1DkJWcmj7xgu4zq64NuDeH5SvudNRSdi8qAjaJ2hgMCY5PGqrLBvU 2+baVJSXuqvu491w1qqIPentUSixQ62pHvcqHerS/8a44rWt4xMh0YZT4jkOEJ2TMNdh sa5bY8kaZZ3p/IjoI2tCJgF+kCTylT0isXmxKYeNkE/u1FGjerbULys76K/KCzvJZTb/ TpCA== 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=FQooaURzW7ZzOozM23lULPdqyChM7nIVl0MpBXFaLHg=; b=JSBTJREDN1jXiM+ZOcng//ni9CCjRziWJQx5rcOz3CNIN12QdTKZF6RH1G6SHNZ+vz HcfNSSyGh3a0VIynbcxoRl4VNs51lFIQQHZGOOfwaeSl3wm9/ELGFDd8ZgK57eSNbJOD 8uVSxF6513Ll6UGNkYGa1DdiM5/boSj8tSkNUvq9HPMTCUwPzd2pHElINO47OEUA3V+i 4+LKUjLrQWi7l6jaj6oD928LqQTB/eWKS8iOVbIqhw5DAKCUSldisnS94wA2FQXvvLdm bJL34yi83Z3oYiZXJGMaZEPG1GMsqYo35o4fRkGlDuQAJxX47sIwvePyt3MnBz2KB9Dd KSOg== 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 a1si10539912pfn.245.2019.02.20.04.15.19; Wed, 20 Feb 2019 04:15:35 -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 S1726612AbfBTMOq (ORCPT + 99 others); Wed, 20 Feb 2019 07:14:46 -0500 Received: from mga14.intel.com ([192.55.52.115]:57523 "EHLO mga14.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726197AbfBTMOp (ORCPT ); Wed, 20 Feb 2019 07:14:45 -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 fmsmga103.fm.intel.com with ESMTP/TLS/DHE-RSA-AES256-GCM-SHA384; 20 Feb 2019 04:14:45 -0800 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.58,390,1544515200"; d="scan'208";a="148351782" Received: from kuha.fi.intel.com ([10.237.72.189]) by fmsmga001.fm.intel.com with SMTP; 20 Feb 2019 04:14:42 -0800 Received: by kuha.fi.intel.com (sSMTP sendmail emulation); Wed, 20 Feb 2019 14:14:41 +0200 Date: Wed, 20 Feb 2019 14:14:41 +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@loewensteinmedical.de Subject: Re: [PATCH] usb: typec: tps6598x: handle block writes separately with plain-I2C adapters Message-ID: <20190220121441.GA5054@kuha.fi.intel.com> References: <20180425142209.30745-1-heikki.krogerus@linux.intel.com> <20190220110017.BFA344CE86@mail.steuer-voss.de> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20190220110017.BFA344CE86@mail.steuer-voss.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 Hi, On Mon, Sep 10, 2018 at 07:05:01AM +0200, Nikolaus Voss wrote: > 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 > --- > drivers/usb/typec/tps6598x.c | 22 ++++++++++++++++++---- > 1 file changed, 18 insertions(+), 4 deletions(-) > > diff --git a/drivers/usb/typec/tps6598x.c b/drivers/usb/typec/tps6598x.c > index c84c8c189e90..57a3e6c5c175 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[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) You need to fix tps6598x_exec_cmd() as well. Did you really send this last September? If you did, then the mail has been stuck somewhere for a long time. thanks, -- heikki