From mboxrd@z Thu Jan 1 00:00:00 1970 From: Richard Knutsson Subject: Re: [KJ][RFC][PATCH] BIT macro cleanup Date: Fri, 23 Feb 2007 23:43:44 +0100 Message-ID: <45DF6E20.9060604@student.ltu.se> References: <3b44d3fb0702222056k1d2a9b57q69a3555a09a9058e@mail.gmail.com> <45DEAC45.7090105@student.ltu.se> <3b44d3fb0702230215o2fbd5a3y25729e481a447149@mail.gmail.com> <45DEF5EE.4030002@student.ltu.se> <45DF1165.2080003@student.ltu.se> <45DF2F57.2080309@student.ltu.se> <45DF3C53.4030100@student.ltu.se> Mime-Version: 1.0 Content-Type: text/plain; charset=ISO-8859-1; format=flowed Content-Transfer-Encoding: 7bit Return-path: In-Reply-To: Sender: owner-linux-input@atrey.karlin.mff.cuni.cz List-Help: List-Owner: List-Post: List-Unsubscribe: To: Dmitry Torokhov Cc: Milind Choudhary , kernel-janitors@lists.osdl.org, linux-kernel@vger.kernel.org, linux-input@atrey.karlin.mff.cuni.cz, linux-joystick@atrey.karlin.mff.cuni.cz List-Id: linux-input@vger.kernel.org Dmitry Torokhov wrote: > On 2/23/07, Richard Knutsson wrote: >> Dmitry Torokhov wrote: >> > >> > Hm, I thought as was clear, but apparently I messed up explaining my >> > position: >> > >> > 1. I don't like BITWRAP name at all and I don't want anything like >> > that near input code. I think BIT is just fine. >> Oh, I think I understand now. So the (in input.h): >> #undef BIT >> #define BIT(... >> business is what you want to do? Well, that I will not object to. > > No, #undefs may be barely tolerable in .c files but they are not > acceptable in core subsystem interfaces. If you do that you will never > know what version of BIT patricular module is using. Yes, kinda. But wouldn't the compiler complain if you included both input.h and bitops.h (multiply definitions of BIT)? >> Your >> patch with: >> +#define BIT(nr) (1UL << (nr)) >> +#define LLBIT(nr) (1ULL << (nr)) >> +#define BITWRAP(nr) (1UL << ((nr) % BITS_PER_LONG)) >> in bitops.h made me believe the #undef in input.h was just a temporarily >> thing. > > No. There is no "my patch". You are confusing me with Milind > Choudhary. Sorry about that. Am surprised I didn't notice it earlier... > I am saying that IMO input's BIT definition should be > adequate for 99% of potential users and that I would be OK with moving > said BIT definition from input.h to bitops.h and maybe supplementing > it with LLBIT. I am also saying that I do not want BITWRAP, BITSWAP > (what swap btw?) nor BIT(x % BITS_PER_LONG) in input drivers. Is the reason for the modulo to put a bitmask larger then the variable into an array? I did just a quick 'grep' for "BIT(" in drivers/input/ and from what I saw, most (or all?) of the values are defined constants and those in input.h were noway near the limits of a 'long'. The reason I don't like it with modulo is simply because it hides potential bugs (when x is to big). And what about the "1%"? IMHO BIT should be as simple as possible. Richard Knutsson