From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752100AbbAUIeu (ORCPT ); Wed, 21 Jan 2015 03:34:50 -0500 Received: from mailgw01.mediatek.com ([210.61.82.183]:35202 "EHLO mailgw01.mediatek.com" rhost-flags-OK-FAIL-OK-FAIL) by vger.kernel.org with ESMTP id S1750812AbbAUIel (ORCPT ); Wed, 21 Jan 2015 03:34:41 -0500 X-Listener-Flag: 11101 Subject: Re: [PATCH v4 2/2] I2C: mediatek: Add driver for MediaTek I2C controller From: Eddie Huang To: Uwe =?ISO-8859-1?Q?Kleine-K=F6nig?= CC: Wolfram Sang , Matthias Brugger , , Rob Herring , Pawel Moll , Mark Rutland , Ian Campbell , Kumar Gala , Grant Likely , Jean Delvare , Arnd Bergmann , Doug Anderson , Andrew Bresticker , Max Schwarz , Boris BREZILLON , Anders Berg , Neelesh Gupta , Wei Yan , Lee Jones , Simon Glass , Jim Cromie , Bjorn Andersson , Beniamino Galvani , Xudong Chen , , , , , , , Sascha Hauer In-Reply-To: <20150121082022.GT22880@pengutronix.de> References: <1421404418-50718-1-git-send-email-eddie.huang@mediatek.com> <1421404418-50718-3-git-send-email-eddie.huang@mediatek.com> <20150118101816.GF22880@pengutronix.de> <1421810004.15468.825.camel@mtksdaap41> <20150121082022.GT22880@pengutronix.de> Content-Type: text/plain; charset="UTF-8" Date: Wed, 21 Jan 2015 16:34:35 +0800 Message-ID: <1421829275.6546.6.camel@mtksdaap41> MIME-Version: 1.0 X-Mailer: Evolution 2.28.3 Content-Transfer-Encoding: 8bit X-MTK: N Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Uwe, On Wed, 2015-01-21 at 09:20 +0100, Uwe Kleine-König wrote: > Hello, > > On Wed, Jan 21, 2015 at 11:13:24AM +0800, Eddie Huang wrote: > > > > + /* set when doing the transfer */ > > > > + u16 irq_stat; /* interrupt status */ > > > > + unsigned int speed_hz; /* The speed in transfer */ > > > > + bool trans_stop; /* i2c transfer stop */ > > > > + enum mtk_trans_op op; > > > > + u16 msg_len; > > > > + u8 *msg_buf; /* pointer to msg data */ > > > > + u16 msg_aux_len; /* WRRD mode to set AUX_LEN register*/ > > > > + u16 addr; /* 7bit slave address, without read/write bit */ > > > Wouldn't it be easier to maintain a pointer to the message to be > > > transferred? > > I think use mtk_i2c pointer is more flexible than maintain a pointer to > > message. > Not sure you understood what I intended to suggest. My idea was to drop > > u16 msg_len; > u8 *msg_buf; > u16 msg_aux_len; // maybe > u16 addr; > > from struct mtk_i2c and add a struct i2c_msg *msg instead. Up to you to > decide. > Because this driver pass mtk_i2c pointer between functions, it's flexible to use any member of struct mtk_i2c. The good thing is avoid passing one more struct i2c_msg parameter between functions, or another struct copy. The bad thing is make struct mtk_i2c larger. I prefer to keep as it is now. Best Regards Eddie