Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id ; Wed, 26 Feb 2003 10:27:37 -0500 Received: (majordomo@vger.kernel.org) by vger.kernel.org id ; Wed, 26 Feb 2003 10:27:37 -0500 Received: from mail2.sonytel.be ([195.0.45.172]:55700 "EHLO mail.sonytel.be") by vger.kernel.org with ESMTP id ; Wed, 26 Feb 2003 10:27:35 -0500 Date: Wed, 26 Feb 2003 16:37:34 +0100 (MET) From: Geert Uytterhoeven To: Jeff Garzik cc: Marcus Meissner , "David S. Miller" , Linux Kernel Development , engebret@us.ibm.com Subject: Re: [PATCH] fixed pcnet32 multicast listen on big endian In-Reply-To: <3E5CDB83.1070400@pobox.com> Message-ID: MIME-Version: 1.0 Content-Type: TEXT/PLAIN; charset=US-ASCII Sender: linux-kernel-owner@vger.kernel.org X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 2067 Lines: 62 On Wed, 26 Feb 2003, Jeff Garzik wrote: > Geert Uytterhoeven wrote: > > On Sun, 23 Feb 2003, Geert Uytterhoeven wrote: > >>On Wed, 5 Feb 2003, Marcus Meissner wrote: > >>>This fixes multicast listen for pcnet32 on at least powerpc and powerpc64 > >>>kernels. > >>> > >>>The mcast_table is in memory referenced by the card and so it needs > >>>to be accessed in little endian mode. > >>> > >>>Ciao, Marcus > >>> > >>>--- linux-2.4.19/drivers/net/pcnet32.c.be 2003-02-05 07:59:27.000000000 +0100 > >>>+++ linux-2.4.19/drivers/net/pcnet32.c 2003-02-05 08:00:22.000000000 +0100 > >>>@@ -1534,7 +1534,9 @@ > >>> > >>> crc = ether_crc_le(6, addrs); > >>> crc = crc >> 26; > >>>- mcast_table [crc >> 4] |= 1 << (crc & 0xf); > >>>+ mcast_table [crc >> 4] = le16_to_cpu( > >> > >> ^^^^^^^^^^^ > >> > >>>+ le16_to_cpu(mcast_table [crc >> 4]) | (1 << (crc & 0xf)) > >>>+ ); > >> > >>Shouldn't the first conversion be `cpu_to_le16'? > > > > > > Ugh, a quick grep shows that this driver _always_ uses `le*_to_cpu()' to > > convert from CPU to little endian. > > Cosmetically you are correct, and I prefer it to be changed eventually. > > However programatically, it has no effect, because those cpu_to_foo and > foo_to_cpu functions either swap, or they don't. Direction doesn't > matter terribly much :) That's true. BTW, you save one swap by changing the code to mcast_table [crc >> 4] |= cpu_to_le16(1 << (crc & 0xf)); Because the order of bitwise or and swap doesn't matter. Gr{oetje,eeting}s, Geert -- Geert Uytterhoeven -- There's lots of Linux beyond ia32 -- geert@linux-m68k.org In personal conversations with technical people, I call myself a hacker. But when I'm talking to journalists I just say "programmer" or something like that. -- Linus Torvalds - To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/