Re: [PATCH] net: via-rhine: Fix compiler warning re: pointer casting on 64bit
From: Alexey Charkov <alchark@gmail.com>
Date: 2014-05-01 11:33:57
Also in:
lkml
2014-05-01 13:30 GMT+04:00 David Laight [off-list ref]:
From: Alexey Charkov [mailto:alchark@gmail.com] ...quoted
This patch removes the cast altogether, and instead stores an actual pointer to u8 in match->data. All instances of 'revision' are also unified to u8 instead of an assortment of different integer types, in line with the definition of 'revision' in struct pci_dev....quoted
+static u8 vt8500_revision = 0x84; static struct of_device_id rhine_of_tbl[] = { - { .compatible = "via,vt8500-rhine", .data = (void *)0x84 }, + { .compatible = "via,vt8500-rhine", .data = &vt8500_revision }, { } /* terminate list */Actually the above looks strange. Why does the vt8500 have a revision number of 0x84 ? Surely it should be 0x85, or even 0x8500 (or decimal 85000).
David, vt8500 is the SoC version (the first one I know where it appeared, might have been used earlier though), not the version of the Rhine core itself (no clue what that is). Here's the source for 0x84 (see line 1031): https://github.com/wondermedia/wm8850/blob/master/ANDROID_3.0.8/arch/arm/common/pci_wmt.c Vendor kernel uses an emulated (shadow-only) PCI bus to bind some obscure PCI driver (not upstream) to the integrated Rhine core, and that emulated PCI bus has Rhine listed with revision 0x84 on it. Anyway, I've now submitted a new patch instead of this one where I got rid of the 0x84 altogether - see https://lkml.org/lkml/2014/4/30/500 Best, Alexey