On 07/04/2012 05:52 PM, Geert Uytterhoeven wrote:
On Wed, Jul 4, 2012 at 8:39 AM, Joe Perches <joe@xxxxxxxxxxx> wrote:
+static int mcf8390_init(struct net_device *dev)
+{
+ static u32 offsets[] = {
+ 0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07,
+ 0x08, 0x09, 0x0a, 0x0b, 0x0c, 0x0d, 0x0e, 0x0f,
+ };
const? u8?
That is assigned to the "reg_offset" field of "struct ei_device"
(defined in the existing 8390.h) and that is:
u32 *reg_offset; /* Register mapping table */
So I can't change this.
Sure you can, you can assign a u8 to a u32 just fine.
It's not the value that's assigned, but a pointer to the table, so
for now it must be non-const u32 *.
The value fits in a u8. Might as well make it take
less data space. static const makes it read-only and
makes the compiler assign it just once instead of at
function invocation.
That needs changes to drivers/net/ethernet/8390/8390.h, and
also probably to some drivers that assign values to the array.
Yes, that is right, some drivers as well.
Just making that local offsets array const generates compiler
warnings (as you would expect):
CC drivers/net/ethernet/8390/mcf8390.o
drivers/net/ethernet/8390/mcf8390.c: In function ‘mcf8390_init’:
drivers/net/ethernet/8390/mcf8390.c:393:23: warning: assignment discards
qualifiers from pointer target type
Regards
Greg
------------------------------------------------------------------------
Greg Ungerer -- Principal Engineer EMAIL: gerg@xxxxxxxxxxxx
SnapGear Group, McAfee PHONE: +61 7 3435 2888
8 Gardner Close, FAX: +61 7 3891 3630
Milton, QLD, 4064, Australia WEB: http://www.SnapGear.com
--
To unsubscribe from this list: send the line "unsubscribe linux-m68k" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html