aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net
diff options
context:
space:
mode:
authorAndrea Merello <andrea.merello@gmail.com>2014-03-28 13:14:28 -0400
committerJohn W. Linville <linville@tuxdriver.com>2014-03-31 13:47:41 -0400
commit6cea5f2173440d324b0172373a95408323f28911 (patch)
treee8f8e89facb8d0138862c10541420aa6a28810d5 /drivers/net
parent3f3aa2fb48bd637002c5742c6d1cd4dfa931b771 (diff)
rtl8180: don't use weird trick to access "far" registers
In rtl8180/rtl8185/rtl8187se the register space is represented using packed structure type. Register are thus accessed using a pointer of this type. All registers are packed toghether, and only small gaps are present. However Rtl8187se has also some "sparse" registers, very far from the "main register block". It could be possible to access them by simply declare huge reserved blocks inside the register struct (and this causes NO memory waste). However, for various reasons, access to those "far" registers is done with special dedicated macros, without declaring them in the register struct. This is done in an intricate manner, that makes code less readable and caused static analisys tool to produce warnings. This patch keeps the "macro" mechanism, but it changes its implementation in a simplier and more straightforward way. Signed-off-by: Andrea Merello <andrea.merello@gmail.com> Signed-off-by: John W. Linville <linville@tuxdriver.com>
Diffstat (limited to 'drivers/net')
-rw-r--r--drivers/net/wireless/rtl818x/rtl818x.h14
1 files changed, 4 insertions, 10 deletions
diff --git a/drivers/net/wireless/rtl818x/rtl818x.h b/drivers/net/wireless/rtl818x/rtl818x.h
index 99dbc123b753..45ea4e1c4abe 100644
--- a/drivers/net/wireless/rtl818x/rtl818x.h
+++ b/drivers/net/wireless/rtl818x/rtl818x.h
@@ -17,13 +17,7 @@
17 17
18struct rtl818x_csr { 18struct rtl818x_csr {
19 19
20 union { 20 u8 MAC[6];
21 u8 MAC[6];
22 u8 offset1[6]; /* upper page indexing helpers */
23 __le16 offset2[1];
24 __le32 offset4[1];
25 } __packed;
26
27 u8 reserved_0[2]; 21 u8 reserved_0[2];
28 22
29 union { 23 union {
@@ -340,9 +334,9 @@ struct rtl818x_csr {
340 * I don't like to introduce a ton of "reserved".. 334 * I don't like to introduce a ton of "reserved"..
341 * They are for RTL8187SE 335 * They are for RTL8187SE
342 */ 336 */
343#define REG_ADDR1(addr) ((u8 __iomem *)(&priv->map->offset1[(addr)])) 337#define REG_ADDR1(addr) ((u8 __iomem *)priv->map + addr)
344#define REG_ADDR2(addr) ((__le16 __iomem *)(&priv->map->offset2[((addr) >> 1)])) 338#define REG_ADDR2(addr) ((__le16 __iomem *)priv->map + (addr >> 1))
345#define REG_ADDR4(addr) ((__le32 __iomem *)(&priv->map->offset4[((addr) >> 2)])) 339#define REG_ADDR4(addr) ((__le32 __iomem *)priv->map + (addr >> 2))
346 340
347#define FEMR_SE REG_ADDR2(0x1D4) 341#define FEMR_SE REG_ADDR2(0x1D4)
348#define ARFR REG_ADDR2(0x1E0) 342#define ARFR REG_ADDR2(0x1E0)