Return-path: Received: from mail.academy.zt.ua ([82.207.120.245]:58847 "EHLO mail.academy.zt.ua" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1755846Ab1BIV3P (ORCPT ); Wed, 9 Feb 2011 16:29:15 -0500 Received: from [10.0.2.42] by mail.academy.zt.ua (Cipher SSLv3:RC4-MD5:128) (MDaemon PRO v11.0.3) with ESMTP id md50000020116.msg for ; Wed, 09 Feb 2011 23:28:38 +0200 Subject: Re: SSB AI support code ([RFC4/11] SSB core control and state device ops) From: George Kashperko To: =?UTF-8?Q?Rafa=C5=82_Mi=C5=82ecki?= Cc: linux-wireless In-Reply-To: References: <1297258590.17400.37.camel@dev.znau.edu.ua> <1297262089.18053.24.camel@dev.znau.edu.ua> Content-Type: text/plain; charset=UTF-8 Date: Wed, 09 Feb 2011 23:21:48 +0200 Message-Id: <1297286508.11978.10.camel@dev.znau.edu.ua> Mime-Version: 1.0 Sender: linux-wireless-owner@vger.kernel.org List-ID: В Срд, 09/02/2011 в 22:01 +0100, Rafał Miłecki пишет: > W dniu 9 lutego 2011 21:35 użytkownik Rafał Miłecki napisał: > > 2011/2/9 George Kashperko : > >> From: George Kashperko > >> > >> Introduce handlers for SB core control and state flags' management. SB-style > >> buses provide access to these flags at two high octets of TMSLOW and TMSHIGH > >> registers whereas AI-ones implement these flags in two low octets of IOCTRL > >> and IOSTAT registers. > >> Signed-off-by: George Kashperko > >> --- > >> drivers/ssb/main.c | 36 ++++++++++++++++++++++++++++++++++++ > >> include/linux/ssb/ssb.h | 14 +++++++++++++- > >> 2 files changed, 49 insertions(+), 1 deletion(-) > >> --- linux-next-20110203.orig/drivers/ssb/main.c 2011-02-07 16:58:50.000000000 +0200 > >> +++ linux-next-20110203/drivers/ssb/main.c 2011-02-07 17:07:11.000000000 +0200 > >> @@ -1350,6 +1350,40 @@ static u32 ssb_admatch_size_sb(struct ss > >> return size; > >> } > >> > >> +static void ssb_core_ctl_flags_sb(struct ssb_device *dev, u32 mask, > >> + u32 val, u32 *res) > >> +{ > >> + u32 tmp; > >> + > >> + if (mask || val) { > >> + tmp = (ssb_read32(dev, SSB_TMSLOW) & ~mask) | val; > >> + ssb_write32(dev, SSB_TMSLOW, tmp); > >> + } > > > > Are you going to use that function for just reading SSB_TMSLOW? Why > > won't you use separated function then? Do you need separated function > > for sth so simple as "ssb_read32(dev, SSB_TMSLOW);" at all? > > In b43 we used to implement mask other way: > > void b43_radio_maskset(struct b43_wldev *dev, u16 offset, u16 mask, u16 set) > { > b43_radio_write16(dev, offset, > (b43_radio_read16(dev, offset) & mask) | set); > } > > I don't vote for any option, but I think we should one method everywhere. > (mask vs. ~mask) > No doubt. Think this one should be changed.