diff options
author | Dhananjay Phadke <dhananjay@netxen.com> | 2009-10-13 01:31:44 -0400 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2009-10-13 14:48:21 -0400 |
commit | f03b0ebd8e7132bd9adb41348070813feb280300 (patch) | |
tree | c7606724b4dcd84857980797c9d948f00cbeb185 /drivers/net/netxen/netxen_nic_hw.c | |
parent | 907fa1201c76f426a13bdff5be2747fb62c2353f (diff) |
netxen: separate register and memory access lock
Since register and onboard memory access has separate
window registers, they need not be kept under same lock.
Also, memory is always accessed from process context
(mostly for firmware init and diagnostic tools).
Signed-off-by: Dhananjay Phadke <dhananjay@netxen.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'drivers/net/netxen/netxen_nic_hw.c')
-rw-r--r-- | drivers/net/netxen/netxen_nic_hw.c | 63 |
1 files changed, 30 insertions, 33 deletions
diff --git a/drivers/net/netxen/netxen_nic_hw.c b/drivers/net/netxen/netxen_nic_hw.c index 37f47660dcdd..d067bee87cd5 100644 --- a/drivers/net/netxen/netxen_nic_hw.c +++ b/drivers/net/netxen/netxen_nic_hw.c | |||
@@ -41,6 +41,11 @@ | |||
41 | #define CRB_HI(off) ((crb_hub_agt[CRB_BLK(off)] << 20) | ((off) & 0xf0000)) | 41 | #define CRB_HI(off) ((crb_hub_agt[CRB_BLK(off)] << 20) | ((off) & 0xf0000)) |
42 | #define CRB_INDIRECT_2M (0x1e0000UL) | 42 | #define CRB_INDIRECT_2M (0x1e0000UL) |
43 | 43 | ||
44 | static void netxen_nic_io_write_128M(struct netxen_adapter *adapter, | ||
45 | void __iomem *addr, u32 data); | ||
46 | static u32 netxen_nic_io_read_128M(struct netxen_adapter *adapter, | ||
47 | void __iomem *addr); | ||
48 | |||
44 | #ifndef readq | 49 | #ifndef readq |
45 | static inline u64 readq(void __iomem *addr) | 50 | static inline u64 readq(void __iomem *addr) |
46 | { | 51 | { |
@@ -1164,17 +1169,15 @@ netxen_nic_hw_write_wx_128M(struct netxen_adapter *adapter, ulong off, u32 data) | |||
1164 | BUG_ON(!addr); | 1169 | BUG_ON(!addr); |
1165 | 1170 | ||
1166 | if (ADDR_IN_WINDOW1(off)) { /* Window 1 */ | 1171 | if (ADDR_IN_WINDOW1(off)) { /* Window 1 */ |
1167 | read_lock(&adapter->adapter_lock); | 1172 | netxen_nic_io_write_128M(adapter, addr, data); |
1168 | writel(data, addr); | ||
1169 | read_unlock(&adapter->adapter_lock); | ||
1170 | } else { /* Window 0 */ | 1173 | } else { /* Window 0 */ |
1171 | write_lock_irqsave(&adapter->adapter_lock, flags); | 1174 | write_lock_irqsave(&adapter->ahw.crb_lock, flags); |
1172 | addr = pci_base_offset(adapter, off); | 1175 | addr = pci_base_offset(adapter, off); |
1173 | netxen_nic_pci_set_crbwindow_128M(adapter, 0); | 1176 | netxen_nic_pci_set_crbwindow_128M(adapter, 0); |
1174 | writel(data, addr); | 1177 | writel(data, addr); |
1175 | netxen_nic_pci_set_crbwindow_128M(adapter, | 1178 | netxen_nic_pci_set_crbwindow_128M(adapter, |
1176 | NETXEN_WINDOW_ONE); | 1179 | NETXEN_WINDOW_ONE); |
1177 | write_unlock_irqrestore(&adapter->adapter_lock, flags); | 1180 | write_unlock_irqrestore(&adapter->ahw.crb_lock, flags); |
1178 | } | 1181 | } |
1179 | 1182 | ||
1180 | return 0; | 1183 | return 0; |
@@ -1195,16 +1198,14 @@ netxen_nic_hw_read_wx_128M(struct netxen_adapter *adapter, ulong off) | |||
1195 | BUG_ON(!addr); | 1198 | BUG_ON(!addr); |
1196 | 1199 | ||
1197 | if (ADDR_IN_WINDOW1(off)) { /* Window 1 */ | 1200 | if (ADDR_IN_WINDOW1(off)) { /* Window 1 */ |
1198 | read_lock(&adapter->adapter_lock); | 1201 | data = netxen_nic_io_read_128M(adapter, addr); |
1199 | data = readl(addr); | ||
1200 | read_unlock(&adapter->adapter_lock); | ||
1201 | } else { /* Window 0 */ | 1202 | } else { /* Window 0 */ |
1202 | write_lock_irqsave(&adapter->adapter_lock, flags); | 1203 | write_lock_irqsave(&adapter->ahw.crb_lock, flags); |
1203 | netxen_nic_pci_set_crbwindow_128M(adapter, 0); | 1204 | netxen_nic_pci_set_crbwindow_128M(adapter, 0); |
1204 | data = readl(addr); | 1205 | data = readl(addr); |
1205 | netxen_nic_pci_set_crbwindow_128M(adapter, | 1206 | netxen_nic_pci_set_crbwindow_128M(adapter, |
1206 | NETXEN_WINDOW_ONE); | 1207 | NETXEN_WINDOW_ONE); |
1207 | write_unlock_irqrestore(&adapter->adapter_lock, flags); | 1208 | write_unlock_irqrestore(&adapter->ahw.crb_lock, flags); |
1208 | } | 1209 | } |
1209 | 1210 | ||
1210 | return data; | 1211 | return data; |
@@ -1226,12 +1227,12 @@ netxen_nic_hw_write_wx_2M(struct netxen_adapter *adapter, ulong off, u32 data) | |||
1226 | } | 1227 | } |
1227 | 1228 | ||
1228 | if (rv == 1) { | 1229 | if (rv == 1) { |
1229 | write_lock_irqsave(&adapter->adapter_lock, flags); | 1230 | write_lock_irqsave(&adapter->ahw.crb_lock, flags); |
1230 | crb_win_lock(adapter); | 1231 | crb_win_lock(adapter); |
1231 | netxen_nic_pci_set_crbwindow_2M(adapter, &off); | 1232 | netxen_nic_pci_set_crbwindow_2M(adapter, &off); |
1232 | writel(data, (void __iomem *)off); | 1233 | writel(data, (void __iomem *)off); |
1233 | crb_win_unlock(adapter); | 1234 | crb_win_unlock(adapter); |
1234 | write_unlock_irqrestore(&adapter->adapter_lock, flags); | 1235 | write_unlock_irqrestore(&adapter->ahw.crb_lock, flags); |
1235 | } else | 1236 | } else |
1236 | writel(data, (void __iomem *)off); | 1237 | writel(data, (void __iomem *)off); |
1237 | 1238 | ||
@@ -1256,12 +1257,12 @@ netxen_nic_hw_read_wx_2M(struct netxen_adapter *adapter, ulong off) | |||
1256 | } | 1257 | } |
1257 | 1258 | ||
1258 | if (rv == 1) { | 1259 | if (rv == 1) { |
1259 | write_lock_irqsave(&adapter->adapter_lock, flags); | 1260 | write_lock_irqsave(&adapter->ahw.crb_lock, flags); |
1260 | crb_win_lock(adapter); | 1261 | crb_win_lock(adapter); |
1261 | netxen_nic_pci_set_crbwindow_2M(adapter, &off); | 1262 | netxen_nic_pci_set_crbwindow_2M(adapter, &off); |
1262 | data = readl((void __iomem *)off); | 1263 | data = readl((void __iomem *)off); |
1263 | crb_win_unlock(adapter); | 1264 | crb_win_unlock(adapter); |
1264 | write_unlock_irqrestore(&adapter->adapter_lock, flags); | 1265 | write_unlock_irqrestore(&adapter->ahw.crb_lock, flags); |
1265 | } else | 1266 | } else |
1266 | data = readl((void __iomem *)off); | 1267 | data = readl((void __iomem *)off); |
1267 | 1268 | ||
@@ -1272,9 +1273,9 @@ netxen_nic_hw_read_wx_2M(struct netxen_adapter *adapter, ulong off) | |||
1272 | static void netxen_nic_io_write_128M(struct netxen_adapter *adapter, | 1273 | static void netxen_nic_io_write_128M(struct netxen_adapter *adapter, |
1273 | void __iomem *addr, u32 data) | 1274 | void __iomem *addr, u32 data) |
1274 | { | 1275 | { |
1275 | read_lock(&adapter->adapter_lock); | 1276 | read_lock(&adapter->ahw.crb_lock); |
1276 | writel(data, addr); | 1277 | writel(data, addr); |
1277 | read_unlock(&adapter->adapter_lock); | 1278 | read_unlock(&adapter->ahw.crb_lock); |
1278 | } | 1279 | } |
1279 | 1280 | ||
1280 | static u32 netxen_nic_io_read_128M(struct netxen_adapter *adapter, | 1281 | static u32 netxen_nic_io_read_128M(struct netxen_adapter *adapter, |
@@ -1282,9 +1283,9 @@ static u32 netxen_nic_io_read_128M(struct netxen_adapter *adapter, | |||
1282 | { | 1283 | { |
1283 | u32 val; | 1284 | u32 val; |
1284 | 1285 | ||
1285 | read_lock(&adapter->adapter_lock); | 1286 | read_lock(&adapter->ahw.crb_lock); |
1286 | val = readl(addr); | 1287 | val = readl(addr); |
1287 | read_unlock(&adapter->adapter_lock); | 1288 | read_unlock(&adapter->ahw.crb_lock); |
1288 | 1289 | ||
1289 | return val; | 1290 | return val; |
1290 | } | 1291 | } |
@@ -1366,11 +1367,10 @@ netxen_nic_pci_mem_access_direct(struct netxen_adapter *adapter, u64 off, | |||
1366 | { | 1367 | { |
1367 | void __iomem *addr, *mem_ptr = NULL; | 1368 | void __iomem *addr, *mem_ptr = NULL; |
1368 | resource_size_t mem_base; | 1369 | resource_size_t mem_base; |
1369 | unsigned long flags; | ||
1370 | int ret = -EIO; | 1370 | int ret = -EIO; |
1371 | u32 start; | 1371 | u32 start; |
1372 | 1372 | ||
1373 | write_lock_irqsave(&adapter->adapter_lock, flags); | 1373 | spin_lock(&adapter->ahw.mem_lock); |
1374 | 1374 | ||
1375 | ret = adapter->pci_set_window(adapter, off, &start); | 1375 | ret = adapter->pci_set_window(adapter, off, &start); |
1376 | if (ret != 0) | 1376 | if (ret != 0) |
@@ -1397,7 +1397,8 @@ noremap: | |||
1397 | writeq(*data, addr); | 1397 | writeq(*data, addr); |
1398 | 1398 | ||
1399 | unlock: | 1399 | unlock: |
1400 | write_unlock_irqrestore(&adapter->adapter_lock, flags); | 1400 | spin_unlock(&adapter->ahw.mem_lock); |
1401 | |||
1401 | if (mem_ptr) | 1402 | if (mem_ptr) |
1402 | iounmap(mem_ptr); | 1403 | iounmap(mem_ptr); |
1403 | return ret; | 1404 | return ret; |
@@ -1409,7 +1410,6 @@ static int | |||
1409 | netxen_nic_pci_mem_write_128M(struct netxen_adapter *adapter, | 1410 | netxen_nic_pci_mem_write_128M(struct netxen_adapter *adapter, |
1410 | u64 off, u64 data) | 1411 | u64 off, u64 data) |
1411 | { | 1412 | { |
1412 | unsigned long flags; | ||
1413 | int j, ret; | 1413 | int j, ret; |
1414 | u32 temp, off_lo, off_hi, addr_hi, data_hi, data_lo; | 1414 | u32 temp, off_lo, off_hi, addr_hi, data_hi, data_lo; |
1415 | void __iomem *mem_crb; | 1415 | void __iomem *mem_crb; |
@@ -1453,7 +1453,7 @@ netxen_nic_pci_mem_write_128M(struct netxen_adapter *adapter, | |||
1453 | return -EIO; | 1453 | return -EIO; |
1454 | 1454 | ||
1455 | correct: | 1455 | correct: |
1456 | write_lock_irqsave(&adapter->adapter_lock, flags); | 1456 | spin_lock(&adapter->ahw.mem_lock); |
1457 | netxen_nic_pci_set_crbwindow_128M(adapter, 0); | 1457 | netxen_nic_pci_set_crbwindow_128M(adapter, 0); |
1458 | 1458 | ||
1459 | writel(off_lo, (mem_crb + MIU_TEST_AGT_ADDR_LO)); | 1459 | writel(off_lo, (mem_crb + MIU_TEST_AGT_ADDR_LO)); |
@@ -1479,7 +1479,7 @@ correct: | |||
1479 | ret = 0; | 1479 | ret = 0; |
1480 | 1480 | ||
1481 | netxen_nic_pci_set_crbwindow_128M(adapter, NETXEN_WINDOW_ONE); | 1481 | netxen_nic_pci_set_crbwindow_128M(adapter, NETXEN_WINDOW_ONE); |
1482 | write_unlock_irqrestore(&adapter->adapter_lock, flags); | 1482 | spin_unlock(&adapter->ahw.mem_lock); |
1483 | return ret; | 1483 | return ret; |
1484 | } | 1484 | } |
1485 | 1485 | ||
@@ -1487,7 +1487,6 @@ static int | |||
1487 | netxen_nic_pci_mem_read_128M(struct netxen_adapter *adapter, | 1487 | netxen_nic_pci_mem_read_128M(struct netxen_adapter *adapter, |
1488 | u64 off, u64 *data) | 1488 | u64 off, u64 *data) |
1489 | { | 1489 | { |
1490 | unsigned long flags; | ||
1491 | int j, ret; | 1490 | int j, ret; |
1492 | u32 temp, off_lo, off_hi, addr_hi, data_hi, data_lo; | 1491 | u32 temp, off_lo, off_hi, addr_hi, data_hi, data_lo; |
1493 | u64 val; | 1492 | u64 val; |
@@ -1532,7 +1531,7 @@ netxen_nic_pci_mem_read_128M(struct netxen_adapter *adapter, | |||
1532 | return -EIO; | 1531 | return -EIO; |
1533 | 1532 | ||
1534 | correct: | 1533 | correct: |
1535 | write_lock_irqsave(&adapter->adapter_lock, flags); | 1534 | spin_lock(&adapter->ahw.mem_lock); |
1536 | netxen_nic_pci_set_crbwindow_128M(adapter, 0); | 1535 | netxen_nic_pci_set_crbwindow_128M(adapter, 0); |
1537 | 1536 | ||
1538 | writel(off_lo, (mem_crb + MIU_TEST_AGT_ADDR_LO)); | 1537 | writel(off_lo, (mem_crb + MIU_TEST_AGT_ADDR_LO)); |
@@ -1561,7 +1560,7 @@ correct: | |||
1561 | } | 1560 | } |
1562 | 1561 | ||
1563 | netxen_nic_pci_set_crbwindow_128M(adapter, NETXEN_WINDOW_ONE); | 1562 | netxen_nic_pci_set_crbwindow_128M(adapter, NETXEN_WINDOW_ONE); |
1564 | write_unlock_irqrestore(&adapter->adapter_lock, flags); | 1563 | spin_unlock(&adapter->ahw.mem_lock); |
1565 | 1564 | ||
1566 | return ret; | 1565 | return ret; |
1567 | } | 1566 | } |
@@ -1570,7 +1569,6 @@ static int | |||
1570 | netxen_nic_pci_mem_write_2M(struct netxen_adapter *adapter, | 1569 | netxen_nic_pci_mem_write_2M(struct netxen_adapter *adapter, |
1571 | u64 off, u64 data) | 1570 | u64 off, u64 data) |
1572 | { | 1571 | { |
1573 | unsigned long flags; | ||
1574 | int j, ret; | 1572 | int j, ret; |
1575 | u32 temp, off8; | 1573 | u32 temp, off8; |
1576 | void __iomem *mem_crb; | 1574 | void __iomem *mem_crb; |
@@ -1601,7 +1599,7 @@ netxen_nic_pci_mem_write_2M(struct netxen_adapter *adapter, | |||
1601 | correct: | 1599 | correct: |
1602 | off8 = off & MIU_TEST_AGT_ADDR_MASK; | 1600 | off8 = off & MIU_TEST_AGT_ADDR_MASK; |
1603 | 1601 | ||
1604 | write_lock_irqsave(&adapter->adapter_lock, flags); | 1602 | spin_lock(&adapter->ahw.mem_lock); |
1605 | 1603 | ||
1606 | writel(off8, (mem_crb + MIU_TEST_AGT_ADDR_LO)); | 1604 | writel(off8, (mem_crb + MIU_TEST_AGT_ADDR_LO)); |
1607 | writel(0, (mem_crb + MIU_TEST_AGT_ADDR_HI)); | 1605 | writel(0, (mem_crb + MIU_TEST_AGT_ADDR_HI)); |
@@ -1625,7 +1623,7 @@ correct: | |||
1625 | } else | 1623 | } else |
1626 | ret = 0; | 1624 | ret = 0; |
1627 | 1625 | ||
1628 | write_unlock_irqrestore(&adapter->adapter_lock, flags); | 1626 | spin_unlock(&adapter->ahw.mem_lock); |
1629 | 1627 | ||
1630 | return ret; | 1628 | return ret; |
1631 | } | 1629 | } |
@@ -1634,7 +1632,6 @@ static int | |||
1634 | netxen_nic_pci_mem_read_2M(struct netxen_adapter *adapter, | 1632 | netxen_nic_pci_mem_read_2M(struct netxen_adapter *adapter, |
1635 | u64 off, u64 *data) | 1633 | u64 off, u64 *data) |
1636 | { | 1634 | { |
1637 | unsigned long flags; | ||
1638 | int j, ret; | 1635 | int j, ret; |
1639 | u32 temp, off8; | 1636 | u32 temp, off8; |
1640 | u64 val; | 1637 | u64 val; |
@@ -1668,7 +1665,7 @@ netxen_nic_pci_mem_read_2M(struct netxen_adapter *adapter, | |||
1668 | correct: | 1665 | correct: |
1669 | off8 = off & MIU_TEST_AGT_ADDR_MASK; | 1666 | off8 = off & MIU_TEST_AGT_ADDR_MASK; |
1670 | 1667 | ||
1671 | write_lock_irqsave(&adapter->adapter_lock, flags); | 1668 | spin_lock(&adapter->ahw.mem_lock); |
1672 | 1669 | ||
1673 | writel(off8, (mem_crb + MIU_TEST_AGT_ADDR_LO)); | 1670 | writel(off8, (mem_crb + MIU_TEST_AGT_ADDR_LO)); |
1674 | writel(0, (mem_crb + MIU_TEST_AGT_ADDR_HI)); | 1671 | writel(0, (mem_crb + MIU_TEST_AGT_ADDR_HI)); |
@@ -1694,7 +1691,7 @@ correct: | |||
1694 | ret = 0; | 1691 | ret = 0; |
1695 | } | 1692 | } |
1696 | 1693 | ||
1697 | write_unlock_irqrestore(&adapter->adapter_lock, flags); | 1694 | spin_unlock(&adapter->ahw.mem_lock); |
1698 | 1695 | ||
1699 | return ret; | 1696 | return ret; |
1700 | } | 1697 | } |