diff options
author | Michael Chan <mchan@broadcom.com> | 2010-10-05 23:16:06 -0400 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2010-10-06 17:09:23 -0400 |
commit | 1420398db4d5e236583d3ab392637df255bd5c6b (patch) | |
tree | 5d2e287b142ea3b4a6167dc5d9af1ee5de699751 /drivers | |
parent | ceb7e1c7c5ab86ca686d523f99ca473a1f3a984d (diff) |
cnic: Use pfid for internal memory offsets.
The pfid (physical function ID) is the same as PCI function on production
devices. The pfid for future devices will be different and will be used
for internal memory offsets.
Signed-off-by: Michael Chan <mchan@broadcom.com>
Signed-off-by: Dmitry Kravkov <dmitry@broadcom.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'drivers')
-rw-r--r-- | drivers/net/cnic.c | 144 | ||||
-rw-r--r-- | drivers/net/cnic.h | 1 |
2 files changed, 75 insertions, 70 deletions
diff --git a/drivers/net/cnic.c b/drivers/net/cnic.c index 0e31d5aa1dd2..50cded7fff51 100644 --- a/drivers/net/cnic.c +++ b/drivers/net/cnic.c | |||
@@ -1246,8 +1246,8 @@ static int cnic_bnx2x_iscsi_init1(struct cnic_dev *dev, struct kwqe *kwqe) | |||
1246 | { | 1246 | { |
1247 | struct cnic_local *cp = dev->cnic_priv; | 1247 | struct cnic_local *cp = dev->cnic_priv; |
1248 | struct iscsi_kwqe_init1 *req1 = (struct iscsi_kwqe_init1 *) kwqe; | 1248 | struct iscsi_kwqe_init1 *req1 = (struct iscsi_kwqe_init1 *) kwqe; |
1249 | int func = cp->func, pages; | 1249 | int hq_bds, pages; |
1250 | int hq_bds; | 1250 | u32 pfid = cp->pfid; |
1251 | 1251 | ||
1252 | cp->num_iscsi_tasks = req1->num_tasks_per_conn; | 1252 | cp->num_iscsi_tasks = req1->num_tasks_per_conn; |
1253 | cp->num_ccells = req1->num_ccells_per_conn; | 1253 | cp->num_ccells = req1->num_ccells_per_conn; |
@@ -1264,60 +1264,60 @@ static int cnic_bnx2x_iscsi_init1(struct cnic_dev *dev, struct kwqe *kwqe) | |||
1264 | return 0; | 1264 | return 0; |
1265 | 1265 | ||
1266 | /* init Tstorm RAM */ | 1266 | /* init Tstorm RAM */ |
1267 | CNIC_WR16(dev, BAR_TSTRORM_INTMEM + TSTORM_ISCSI_RQ_SIZE_OFFSET(func), | 1267 | CNIC_WR16(dev, BAR_TSTRORM_INTMEM + TSTORM_ISCSI_RQ_SIZE_OFFSET(pfid), |
1268 | req1->rq_num_wqes); | 1268 | req1->rq_num_wqes); |
1269 | CNIC_WR16(dev, BAR_TSTRORM_INTMEM + TSTORM_ISCSI_PAGE_SIZE_OFFSET(func), | 1269 | CNIC_WR16(dev, BAR_TSTRORM_INTMEM + TSTORM_ISCSI_PAGE_SIZE_OFFSET(pfid), |
1270 | PAGE_SIZE); | 1270 | PAGE_SIZE); |
1271 | CNIC_WR8(dev, BAR_TSTRORM_INTMEM + | 1271 | CNIC_WR8(dev, BAR_TSTRORM_INTMEM + |
1272 | TSTORM_ISCSI_PAGE_SIZE_LOG_OFFSET(func), PAGE_SHIFT); | 1272 | TSTORM_ISCSI_PAGE_SIZE_LOG_OFFSET(pfid), PAGE_SHIFT); |
1273 | CNIC_WR16(dev, BAR_TSTRORM_INTMEM + | 1273 | CNIC_WR16(dev, BAR_TSTRORM_INTMEM + |
1274 | TSTORM_ISCSI_NUM_OF_TASKS_OFFSET(func), | 1274 | TSTORM_ISCSI_NUM_OF_TASKS_OFFSET(pfid), |
1275 | req1->num_tasks_per_conn); | 1275 | req1->num_tasks_per_conn); |
1276 | 1276 | ||
1277 | /* init Ustorm RAM */ | 1277 | /* init Ustorm RAM */ |
1278 | CNIC_WR16(dev, BAR_USTRORM_INTMEM + | 1278 | CNIC_WR16(dev, BAR_USTRORM_INTMEM + |
1279 | USTORM_ISCSI_RQ_BUFFER_SIZE_OFFSET(func), | 1279 | USTORM_ISCSI_RQ_BUFFER_SIZE_OFFSET(pfid), |
1280 | req1->rq_buffer_size); | 1280 | req1->rq_buffer_size); |
1281 | CNIC_WR16(dev, BAR_USTRORM_INTMEM + USTORM_ISCSI_PAGE_SIZE_OFFSET(func), | 1281 | CNIC_WR16(dev, BAR_USTRORM_INTMEM + USTORM_ISCSI_PAGE_SIZE_OFFSET(pfid), |
1282 | PAGE_SIZE); | 1282 | PAGE_SIZE); |
1283 | CNIC_WR8(dev, BAR_USTRORM_INTMEM + | 1283 | CNIC_WR8(dev, BAR_USTRORM_INTMEM + |
1284 | USTORM_ISCSI_PAGE_SIZE_LOG_OFFSET(func), PAGE_SHIFT); | 1284 | USTORM_ISCSI_PAGE_SIZE_LOG_OFFSET(pfid), PAGE_SHIFT); |
1285 | CNIC_WR16(dev, BAR_USTRORM_INTMEM + | 1285 | CNIC_WR16(dev, BAR_USTRORM_INTMEM + |
1286 | USTORM_ISCSI_NUM_OF_TASKS_OFFSET(func), | 1286 | USTORM_ISCSI_NUM_OF_TASKS_OFFSET(pfid), |
1287 | req1->num_tasks_per_conn); | 1287 | req1->num_tasks_per_conn); |
1288 | CNIC_WR16(dev, BAR_USTRORM_INTMEM + USTORM_ISCSI_RQ_SIZE_OFFSET(func), | 1288 | CNIC_WR16(dev, BAR_USTRORM_INTMEM + USTORM_ISCSI_RQ_SIZE_OFFSET(pfid), |
1289 | req1->rq_num_wqes); | 1289 | req1->rq_num_wqes); |
1290 | CNIC_WR16(dev, BAR_USTRORM_INTMEM + USTORM_ISCSI_CQ_SIZE_OFFSET(func), | 1290 | CNIC_WR16(dev, BAR_USTRORM_INTMEM + USTORM_ISCSI_CQ_SIZE_OFFSET(pfid), |
1291 | req1->cq_num_wqes); | 1291 | req1->cq_num_wqes); |
1292 | CNIC_WR16(dev, BAR_USTRORM_INTMEM + USTORM_ISCSI_R2TQ_SIZE_OFFSET(func), | 1292 | CNIC_WR16(dev, BAR_USTRORM_INTMEM + USTORM_ISCSI_R2TQ_SIZE_OFFSET(pfid), |
1293 | cp->num_iscsi_tasks * BNX2X_ISCSI_MAX_PENDING_R2TS); | 1293 | cp->num_iscsi_tasks * BNX2X_ISCSI_MAX_PENDING_R2TS); |
1294 | 1294 | ||
1295 | /* init Xstorm RAM */ | 1295 | /* init Xstorm RAM */ |
1296 | CNIC_WR16(dev, BAR_XSTRORM_INTMEM + XSTORM_ISCSI_PAGE_SIZE_OFFSET(func), | 1296 | CNIC_WR16(dev, BAR_XSTRORM_INTMEM + XSTORM_ISCSI_PAGE_SIZE_OFFSET(pfid), |
1297 | PAGE_SIZE); | 1297 | PAGE_SIZE); |
1298 | CNIC_WR8(dev, BAR_XSTRORM_INTMEM + | 1298 | CNIC_WR8(dev, BAR_XSTRORM_INTMEM + |
1299 | XSTORM_ISCSI_PAGE_SIZE_LOG_OFFSET(func), PAGE_SHIFT); | 1299 | XSTORM_ISCSI_PAGE_SIZE_LOG_OFFSET(pfid), PAGE_SHIFT); |
1300 | CNIC_WR16(dev, BAR_XSTRORM_INTMEM + | 1300 | CNIC_WR16(dev, BAR_XSTRORM_INTMEM + |
1301 | XSTORM_ISCSI_NUM_OF_TASKS_OFFSET(func), | 1301 | XSTORM_ISCSI_NUM_OF_TASKS_OFFSET(pfid), |
1302 | req1->num_tasks_per_conn); | 1302 | req1->num_tasks_per_conn); |
1303 | CNIC_WR16(dev, BAR_XSTRORM_INTMEM + XSTORM_ISCSI_HQ_SIZE_OFFSET(func), | 1303 | CNIC_WR16(dev, BAR_XSTRORM_INTMEM + XSTORM_ISCSI_HQ_SIZE_OFFSET(pfid), |
1304 | hq_bds); | 1304 | hq_bds); |
1305 | CNIC_WR16(dev, BAR_XSTRORM_INTMEM + XSTORM_ISCSI_SQ_SIZE_OFFSET(func), | 1305 | CNIC_WR16(dev, BAR_XSTRORM_INTMEM + XSTORM_ISCSI_SQ_SIZE_OFFSET(pfid), |
1306 | req1->num_tasks_per_conn); | 1306 | req1->num_tasks_per_conn); |
1307 | CNIC_WR16(dev, BAR_XSTRORM_INTMEM + XSTORM_ISCSI_R2TQ_SIZE_OFFSET(func), | 1307 | CNIC_WR16(dev, BAR_XSTRORM_INTMEM + XSTORM_ISCSI_R2TQ_SIZE_OFFSET(pfid), |
1308 | cp->num_iscsi_tasks * BNX2X_ISCSI_MAX_PENDING_R2TS); | 1308 | cp->num_iscsi_tasks * BNX2X_ISCSI_MAX_PENDING_R2TS); |
1309 | 1309 | ||
1310 | /* init Cstorm RAM */ | 1310 | /* init Cstorm RAM */ |
1311 | CNIC_WR16(dev, BAR_CSTRORM_INTMEM + CSTORM_ISCSI_PAGE_SIZE_OFFSET(func), | 1311 | CNIC_WR16(dev, BAR_CSTRORM_INTMEM + CSTORM_ISCSI_PAGE_SIZE_OFFSET(pfid), |
1312 | PAGE_SIZE); | 1312 | PAGE_SIZE); |
1313 | CNIC_WR8(dev, BAR_CSTRORM_INTMEM + | 1313 | CNIC_WR8(dev, BAR_CSTRORM_INTMEM + |
1314 | CSTORM_ISCSI_PAGE_SIZE_LOG_OFFSET(func), PAGE_SHIFT); | 1314 | CSTORM_ISCSI_PAGE_SIZE_LOG_OFFSET(pfid), PAGE_SHIFT); |
1315 | CNIC_WR16(dev, BAR_CSTRORM_INTMEM + | 1315 | CNIC_WR16(dev, BAR_CSTRORM_INTMEM + |
1316 | CSTORM_ISCSI_NUM_OF_TASKS_OFFSET(func), | 1316 | CSTORM_ISCSI_NUM_OF_TASKS_OFFSET(pfid), |
1317 | req1->num_tasks_per_conn); | 1317 | req1->num_tasks_per_conn); |
1318 | CNIC_WR16(dev, BAR_CSTRORM_INTMEM + CSTORM_ISCSI_CQ_SIZE_OFFSET(func), | 1318 | CNIC_WR16(dev, BAR_CSTRORM_INTMEM + CSTORM_ISCSI_CQ_SIZE_OFFSET(pfid), |
1319 | req1->cq_num_wqes); | 1319 | req1->cq_num_wqes); |
1320 | CNIC_WR16(dev, BAR_CSTRORM_INTMEM + CSTORM_ISCSI_HQ_SIZE_OFFSET(func), | 1320 | CNIC_WR16(dev, BAR_CSTRORM_INTMEM + CSTORM_ISCSI_HQ_SIZE_OFFSET(pfid), |
1321 | hq_bds); | 1321 | hq_bds); |
1322 | 1322 | ||
1323 | return 0; | 1323 | return 0; |
@@ -1327,7 +1327,7 @@ static int cnic_bnx2x_iscsi_init2(struct cnic_dev *dev, struct kwqe *kwqe) | |||
1327 | { | 1327 | { |
1328 | struct iscsi_kwqe_init2 *req2 = (struct iscsi_kwqe_init2 *) kwqe; | 1328 | struct iscsi_kwqe_init2 *req2 = (struct iscsi_kwqe_init2 *) kwqe; |
1329 | struct cnic_local *cp = dev->cnic_priv; | 1329 | struct cnic_local *cp = dev->cnic_priv; |
1330 | int func = cp->func; | 1330 | u32 pfid = cp->pfid; |
1331 | struct iscsi_kcqe kcqe; | 1331 | struct iscsi_kcqe kcqe; |
1332 | struct kcqe *cqes[1]; | 1332 | struct kcqe *cqes[1]; |
1333 | 1333 | ||
@@ -1339,21 +1339,21 @@ static int cnic_bnx2x_iscsi_init2(struct cnic_dev *dev, struct kwqe *kwqe) | |||
1339 | } | 1339 | } |
1340 | 1340 | ||
1341 | CNIC_WR(dev, BAR_TSTRORM_INTMEM + | 1341 | CNIC_WR(dev, BAR_TSTRORM_INTMEM + |
1342 | TSTORM_ISCSI_ERROR_BITMAP_OFFSET(func), req2->error_bit_map[0]); | 1342 | TSTORM_ISCSI_ERROR_BITMAP_OFFSET(pfid), req2->error_bit_map[0]); |
1343 | CNIC_WR(dev, BAR_TSTRORM_INTMEM + | 1343 | CNIC_WR(dev, BAR_TSTRORM_INTMEM + |
1344 | TSTORM_ISCSI_ERROR_BITMAP_OFFSET(func) + 4, | 1344 | TSTORM_ISCSI_ERROR_BITMAP_OFFSET(pfid) + 4, |
1345 | req2->error_bit_map[1]); | 1345 | req2->error_bit_map[1]); |
1346 | 1346 | ||
1347 | CNIC_WR16(dev, BAR_USTRORM_INTMEM + | 1347 | CNIC_WR16(dev, BAR_USTRORM_INTMEM + |
1348 | USTORM_ISCSI_CQ_SQN_SIZE_OFFSET(func), req2->max_cq_sqn); | 1348 | USTORM_ISCSI_CQ_SQN_SIZE_OFFSET(pfid), req2->max_cq_sqn); |
1349 | CNIC_WR(dev, BAR_USTRORM_INTMEM + | 1349 | CNIC_WR(dev, BAR_USTRORM_INTMEM + |
1350 | USTORM_ISCSI_ERROR_BITMAP_OFFSET(func), req2->error_bit_map[0]); | 1350 | USTORM_ISCSI_ERROR_BITMAP_OFFSET(pfid), req2->error_bit_map[0]); |
1351 | CNIC_WR(dev, BAR_USTRORM_INTMEM + | 1351 | CNIC_WR(dev, BAR_USTRORM_INTMEM + |
1352 | USTORM_ISCSI_ERROR_BITMAP_OFFSET(func) + 4, | 1352 | USTORM_ISCSI_ERROR_BITMAP_OFFSET(pfid) + 4, |
1353 | req2->error_bit_map[1]); | 1353 | req2->error_bit_map[1]); |
1354 | 1354 | ||
1355 | CNIC_WR16(dev, BAR_CSTRORM_INTMEM + | 1355 | CNIC_WR16(dev, BAR_CSTRORM_INTMEM + |
1356 | CSTORM_ISCSI_CQ_SQN_SIZE_OFFSET(func), req2->max_cq_sqn); | 1356 | CSTORM_ISCSI_CQ_SQN_SIZE_OFFSET(pfid), req2->max_cq_sqn); |
1357 | 1357 | ||
1358 | kcqe.completion_status = ISCSI_KCQE_COMPLETION_STATUS_SUCCESS; | 1358 | kcqe.completion_status = ISCSI_KCQE_COMPLETION_STATUS_SUCCESS; |
1359 | 1359 | ||
@@ -1804,37 +1804,37 @@ static void cnic_init_storm_conn_bufs(struct cnic_dev *dev, | |||
1804 | static void cnic_init_bnx2x_mac(struct cnic_dev *dev) | 1804 | static void cnic_init_bnx2x_mac(struct cnic_dev *dev) |
1805 | { | 1805 | { |
1806 | struct cnic_local *cp = dev->cnic_priv; | 1806 | struct cnic_local *cp = dev->cnic_priv; |
1807 | int func = CNIC_FUNC(cp); | 1807 | u32 pfid = cp->pfid; |
1808 | u8 *mac = dev->mac_addr; | 1808 | u8 *mac = dev->mac_addr; |
1809 | 1809 | ||
1810 | CNIC_WR8(dev, BAR_XSTRORM_INTMEM + | 1810 | CNIC_WR8(dev, BAR_XSTRORM_INTMEM + |
1811 | XSTORM_ISCSI_LOCAL_MAC_ADDR0_OFFSET(func), mac[0]); | 1811 | XSTORM_ISCSI_LOCAL_MAC_ADDR0_OFFSET(pfid), mac[0]); |
1812 | CNIC_WR8(dev, BAR_XSTRORM_INTMEM + | 1812 | CNIC_WR8(dev, BAR_XSTRORM_INTMEM + |
1813 | XSTORM_ISCSI_LOCAL_MAC_ADDR1_OFFSET(func), mac[1]); | 1813 | XSTORM_ISCSI_LOCAL_MAC_ADDR1_OFFSET(pfid), mac[1]); |
1814 | CNIC_WR8(dev, BAR_XSTRORM_INTMEM + | 1814 | CNIC_WR8(dev, BAR_XSTRORM_INTMEM + |
1815 | XSTORM_ISCSI_LOCAL_MAC_ADDR2_OFFSET(func), mac[2]); | 1815 | XSTORM_ISCSI_LOCAL_MAC_ADDR2_OFFSET(pfid), mac[2]); |
1816 | CNIC_WR8(dev, BAR_XSTRORM_INTMEM + | 1816 | CNIC_WR8(dev, BAR_XSTRORM_INTMEM + |
1817 | XSTORM_ISCSI_LOCAL_MAC_ADDR3_OFFSET(func), mac[3]); | 1817 | XSTORM_ISCSI_LOCAL_MAC_ADDR3_OFFSET(pfid), mac[3]); |
1818 | CNIC_WR8(dev, BAR_XSTRORM_INTMEM + | 1818 | CNIC_WR8(dev, BAR_XSTRORM_INTMEM + |
1819 | XSTORM_ISCSI_LOCAL_MAC_ADDR4_OFFSET(func), mac[4]); | 1819 | XSTORM_ISCSI_LOCAL_MAC_ADDR4_OFFSET(pfid), mac[4]); |
1820 | CNIC_WR8(dev, BAR_XSTRORM_INTMEM + | 1820 | CNIC_WR8(dev, BAR_XSTRORM_INTMEM + |
1821 | XSTORM_ISCSI_LOCAL_MAC_ADDR5_OFFSET(func), mac[5]); | 1821 | XSTORM_ISCSI_LOCAL_MAC_ADDR5_OFFSET(pfid), mac[5]); |
1822 | 1822 | ||
1823 | CNIC_WR8(dev, BAR_TSTRORM_INTMEM + | 1823 | CNIC_WR8(dev, BAR_TSTRORM_INTMEM + |
1824 | TSTORM_ISCSI_TCP_VARS_LSB_LOCAL_MAC_ADDR_OFFSET(func), mac[5]); | 1824 | TSTORM_ISCSI_TCP_VARS_LSB_LOCAL_MAC_ADDR_OFFSET(pfid), mac[5]); |
1825 | CNIC_WR8(dev, BAR_TSTRORM_INTMEM + | 1825 | CNIC_WR8(dev, BAR_TSTRORM_INTMEM + |
1826 | TSTORM_ISCSI_TCP_VARS_LSB_LOCAL_MAC_ADDR_OFFSET(func) + 1, | 1826 | TSTORM_ISCSI_TCP_VARS_LSB_LOCAL_MAC_ADDR_OFFSET(pfid) + 1, |
1827 | mac[4]); | 1827 | mac[4]); |
1828 | CNIC_WR8(dev, BAR_TSTRORM_INTMEM + | 1828 | CNIC_WR8(dev, BAR_TSTRORM_INTMEM + |
1829 | TSTORM_ISCSI_TCP_VARS_MSB_LOCAL_MAC_ADDR_OFFSET(func), mac[3]); | 1829 | TSTORM_ISCSI_TCP_VARS_MSB_LOCAL_MAC_ADDR_OFFSET(pfid), mac[3]); |
1830 | CNIC_WR8(dev, BAR_TSTRORM_INTMEM + | 1830 | CNIC_WR8(dev, BAR_TSTRORM_INTMEM + |
1831 | TSTORM_ISCSI_TCP_VARS_MSB_LOCAL_MAC_ADDR_OFFSET(func) + 1, | 1831 | TSTORM_ISCSI_TCP_VARS_MSB_LOCAL_MAC_ADDR_OFFSET(pfid) + 1, |
1832 | mac[2]); | 1832 | mac[2]); |
1833 | CNIC_WR8(dev, BAR_TSTRORM_INTMEM + | 1833 | CNIC_WR8(dev, BAR_TSTRORM_INTMEM + |
1834 | TSTORM_ISCSI_TCP_VARS_MSB_LOCAL_MAC_ADDR_OFFSET(func) + 2, | 1834 | TSTORM_ISCSI_TCP_VARS_MSB_LOCAL_MAC_ADDR_OFFSET(pfid) + 2, |
1835 | mac[1]); | 1835 | mac[1]); |
1836 | CNIC_WR8(dev, BAR_TSTRORM_INTMEM + | 1836 | CNIC_WR8(dev, BAR_TSTRORM_INTMEM + |
1837 | TSTORM_ISCSI_TCP_VARS_MSB_LOCAL_MAC_ADDR_OFFSET(func) + 3, | 1837 | TSTORM_ISCSI_TCP_VARS_MSB_LOCAL_MAC_ADDR_OFFSET(pfid) + 3, |
1838 | mac[0]); | 1838 | mac[0]); |
1839 | } | 1839 | } |
1840 | 1840 | ||
@@ -1850,10 +1850,10 @@ static void cnic_bnx2x_set_tcp_timestamp(struct cnic_dev *dev, int tcp_ts) | |||
1850 | } | 1850 | } |
1851 | 1851 | ||
1852 | CNIC_WR8(dev, BAR_XSTRORM_INTMEM + | 1852 | CNIC_WR8(dev, BAR_XSTRORM_INTMEM + |
1853 | XSTORM_ISCSI_TCP_VARS_FLAGS_OFFSET(cp->func), xstorm_flags); | 1853 | XSTORM_ISCSI_TCP_VARS_FLAGS_OFFSET(cp->pfid), xstorm_flags); |
1854 | 1854 | ||
1855 | CNIC_WR16(dev, BAR_TSTRORM_INTMEM + | 1855 | CNIC_WR16(dev, BAR_TSTRORM_INTMEM + |
1856 | TSTORM_ISCSI_TCP_VARS_FLAGS_OFFSET(cp->func), tstorm_flags); | 1856 | TSTORM_ISCSI_TCP_VARS_FLAGS_OFFSET(cp->pfid), tstorm_flags); |
1857 | } | 1857 | } |
1858 | 1858 | ||
1859 | static int cnic_bnx2x_connect(struct cnic_dev *dev, struct kwqe *wqes[], | 1859 | static int cnic_bnx2x_connect(struct cnic_dev *dev, struct kwqe *wqes[], |
@@ -1928,7 +1928,7 @@ static int cnic_bnx2x_connect(struct cnic_dev *dev, struct kwqe *wqes[], | |||
1928 | cnic_init_storm_conn_bufs(dev, kwqe1, kwqe3, conn_buf); | 1928 | cnic_init_storm_conn_bufs(dev, kwqe1, kwqe3, conn_buf); |
1929 | 1929 | ||
1930 | CNIC_WR16(dev, BAR_XSTRORM_INTMEM + | 1930 | CNIC_WR16(dev, BAR_XSTRORM_INTMEM + |
1931 | XSTORM_ISCSI_LOCAL_VLAN_OFFSET(cp->func), csk->vlan_id); | 1931 | XSTORM_ISCSI_LOCAL_VLAN_OFFSET(cp->pfid), csk->vlan_id); |
1932 | 1932 | ||
1933 | cnic_bnx2x_set_tcp_timestamp(dev, | 1933 | cnic_bnx2x_set_tcp_timestamp(dev, |
1934 | kwqe1->tcp_flags & L4_KWQ_CONNECT_REQ1_TIME_STAMP); | 1934 | kwqe1->tcp_flags & L4_KWQ_CONNECT_REQ1_TIME_STAMP); |
@@ -3283,30 +3283,30 @@ static void cnic_cm_stop_bnx2x_hw(struct cnic_dev *dev) | |||
3283 | static int cnic_cm_init_bnx2x_hw(struct cnic_dev *dev) | 3283 | static int cnic_cm_init_bnx2x_hw(struct cnic_dev *dev) |
3284 | { | 3284 | { |
3285 | struct cnic_local *cp = dev->cnic_priv; | 3285 | struct cnic_local *cp = dev->cnic_priv; |
3286 | int func = CNIC_FUNC(cp); | 3286 | u32 pfid = cp->pfid; |
3287 | 3287 | ||
3288 | cnic_init_bnx2x_mac(dev); | 3288 | cnic_init_bnx2x_mac(dev); |
3289 | cnic_bnx2x_set_tcp_timestamp(dev, 1); | 3289 | cnic_bnx2x_set_tcp_timestamp(dev, 1); |
3290 | 3290 | ||
3291 | CNIC_WR16(dev, BAR_XSTRORM_INTMEM + | 3291 | CNIC_WR16(dev, BAR_XSTRORM_INTMEM + |
3292 | XSTORM_ISCSI_LOCAL_VLAN_OFFSET(func), 0); | 3292 | XSTORM_ISCSI_LOCAL_VLAN_OFFSET(pfid), 0); |
3293 | 3293 | ||
3294 | CNIC_WR(dev, BAR_XSTRORM_INTMEM + | 3294 | CNIC_WR(dev, BAR_XSTRORM_INTMEM + |
3295 | XSTORM_TCP_GLOBAL_DEL_ACK_COUNTER_ENABLED_OFFSET(func), 1); | 3295 | XSTORM_TCP_GLOBAL_DEL_ACK_COUNTER_ENABLED_OFFSET(pfid), 1); |
3296 | CNIC_WR(dev, BAR_XSTRORM_INTMEM + | 3296 | CNIC_WR(dev, BAR_XSTRORM_INTMEM + |
3297 | XSTORM_TCP_GLOBAL_DEL_ACK_COUNTER_MAX_COUNT_OFFSET(func), | 3297 | XSTORM_TCP_GLOBAL_DEL_ACK_COUNTER_MAX_COUNT_OFFSET(pfid), |
3298 | DEF_MAX_DA_COUNT); | 3298 | DEF_MAX_DA_COUNT); |
3299 | 3299 | ||
3300 | CNIC_WR8(dev, BAR_XSTRORM_INTMEM + | 3300 | CNIC_WR8(dev, BAR_XSTRORM_INTMEM + |
3301 | XSTORM_ISCSI_TCP_VARS_TTL_OFFSET(func), DEF_TTL); | 3301 | XSTORM_ISCSI_TCP_VARS_TTL_OFFSET(pfid), DEF_TTL); |
3302 | CNIC_WR8(dev, BAR_XSTRORM_INTMEM + | 3302 | CNIC_WR8(dev, BAR_XSTRORM_INTMEM + |
3303 | XSTORM_ISCSI_TCP_VARS_TOS_OFFSET(func), DEF_TOS); | 3303 | XSTORM_ISCSI_TCP_VARS_TOS_OFFSET(pfid), DEF_TOS); |
3304 | CNIC_WR8(dev, BAR_XSTRORM_INTMEM + | 3304 | CNIC_WR8(dev, BAR_XSTRORM_INTMEM + |
3305 | XSTORM_ISCSI_TCP_VARS_ADV_WND_SCL_OFFSET(func), 2); | 3305 | XSTORM_ISCSI_TCP_VARS_ADV_WND_SCL_OFFSET(pfid), 2); |
3306 | CNIC_WR(dev, BAR_XSTRORM_INTMEM + | 3306 | CNIC_WR(dev, BAR_XSTRORM_INTMEM + |
3307 | XSTORM_TCP_TX_SWS_TIMER_VAL_OFFSET(func), DEF_SWS_TIMER); | 3307 | XSTORM_TCP_TX_SWS_TIMER_VAL_OFFSET(pfid), DEF_SWS_TIMER); |
3308 | 3308 | ||
3309 | CNIC_WR(dev, BAR_TSTRORM_INTMEM + TSTORM_TCP_MAX_CWND_OFFSET(func), | 3309 | CNIC_WR(dev, BAR_TSTRORM_INTMEM + TSTORM_TCP_MAX_CWND_OFFSET(pfid), |
3310 | DEF_MAX_CWND); | 3310 | DEF_MAX_CWND); |
3311 | return 0; | 3311 | return 0; |
3312 | } | 3312 | } |
@@ -4123,9 +4123,13 @@ static int cnic_start_bnx2x_hw(struct cnic_dev *dev) | |||
4123 | struct cnic_local *cp = dev->cnic_priv; | 4123 | struct cnic_local *cp = dev->cnic_priv; |
4124 | int func = CNIC_FUNC(cp), ret, i; | 4124 | int func = CNIC_FUNC(cp), ret, i; |
4125 | int port = CNIC_PORT(cp); | 4125 | int port = CNIC_PORT(cp); |
4126 | u32 pfid; | ||
4126 | u16 eq_idx; | 4127 | u16 eq_idx; |
4127 | u8 sb_id = cp->status_blk_num; | 4128 | u8 sb_id = cp->status_blk_num; |
4128 | 4129 | ||
4130 | cp->pfid = func; | ||
4131 | pfid = cp->pfid; | ||
4132 | |||
4129 | ret = cnic_init_id_tbl(&cp->cid_tbl, MAX_ISCSI_TBL_SZ, | 4133 | ret = cnic_init_id_tbl(&cp->cid_tbl, MAX_ISCSI_TBL_SZ, |
4130 | cp->iscsi_start_cid); | 4134 | cp->iscsi_start_cid); |
4131 | 4135 | ||
@@ -4133,7 +4137,7 @@ static int cnic_start_bnx2x_hw(struct cnic_dev *dev) | |||
4133 | return -ENOMEM; | 4137 | return -ENOMEM; |
4134 | 4138 | ||
4135 | cp->kcq1.io_addr = BAR_CSTRORM_INTMEM + | 4139 | cp->kcq1.io_addr = BAR_CSTRORM_INTMEM + |
4136 | CSTORM_ISCSI_EQ_PROD_OFFSET(func, 0); | 4140 | CSTORM_ISCSI_EQ_PROD_OFFSET(pfid, 0); |
4137 | cp->kcq1.sw_prod_idx = 0; | 4141 | cp->kcq1.sw_prod_idx = 0; |
4138 | 4142 | ||
4139 | cp->kcq1.hw_prod_idx_ptr = | 4143 | cp->kcq1.hw_prod_idx_ptr = |
@@ -4147,41 +4151,41 @@ static int cnic_start_bnx2x_hw(struct cnic_dev *dev) | |||
4147 | /* Only 1 EQ */ | 4151 | /* Only 1 EQ */ |
4148 | CNIC_WR16(dev, cp->kcq1.io_addr, MAX_KCQ_IDX); | 4152 | CNIC_WR16(dev, cp->kcq1.io_addr, MAX_KCQ_IDX); |
4149 | CNIC_WR(dev, BAR_CSTRORM_INTMEM + | 4153 | CNIC_WR(dev, BAR_CSTRORM_INTMEM + |
4150 | CSTORM_ISCSI_EQ_CONS_OFFSET(func, 0), 0); | 4154 | CSTORM_ISCSI_EQ_CONS_OFFSET(pfid, 0), 0); |
4151 | CNIC_WR(dev, BAR_CSTRORM_INTMEM + | 4155 | CNIC_WR(dev, BAR_CSTRORM_INTMEM + |
4152 | CSTORM_ISCSI_EQ_NEXT_PAGE_ADDR_OFFSET(func, 0), | 4156 | CSTORM_ISCSI_EQ_NEXT_PAGE_ADDR_OFFSET(pfid, 0), |
4153 | cp->kcq1.dma.pg_map_arr[1] & 0xffffffff); | 4157 | cp->kcq1.dma.pg_map_arr[1] & 0xffffffff); |
4154 | CNIC_WR(dev, BAR_CSTRORM_INTMEM + | 4158 | CNIC_WR(dev, BAR_CSTRORM_INTMEM + |
4155 | CSTORM_ISCSI_EQ_NEXT_PAGE_ADDR_OFFSET(func, 0) + 4, | 4159 | CSTORM_ISCSI_EQ_NEXT_PAGE_ADDR_OFFSET(pfid, 0) + 4, |
4156 | (u64) cp->kcq1.dma.pg_map_arr[1] >> 32); | 4160 | (u64) cp->kcq1.dma.pg_map_arr[1] >> 32); |
4157 | CNIC_WR(dev, BAR_CSTRORM_INTMEM + | 4161 | CNIC_WR(dev, BAR_CSTRORM_INTMEM + |
4158 | CSTORM_ISCSI_EQ_NEXT_EQE_ADDR_OFFSET(func, 0), | 4162 | CSTORM_ISCSI_EQ_NEXT_EQE_ADDR_OFFSET(pfid, 0), |
4159 | cp->kcq1.dma.pg_map_arr[0] & 0xffffffff); | 4163 | cp->kcq1.dma.pg_map_arr[0] & 0xffffffff); |
4160 | CNIC_WR(dev, BAR_CSTRORM_INTMEM + | 4164 | CNIC_WR(dev, BAR_CSTRORM_INTMEM + |
4161 | CSTORM_ISCSI_EQ_NEXT_EQE_ADDR_OFFSET(func, 0) + 4, | 4165 | CSTORM_ISCSI_EQ_NEXT_EQE_ADDR_OFFSET(pfid, 0) + 4, |
4162 | (u64) cp->kcq1.dma.pg_map_arr[0] >> 32); | 4166 | (u64) cp->kcq1.dma.pg_map_arr[0] >> 32); |
4163 | CNIC_WR8(dev, BAR_CSTRORM_INTMEM + | 4167 | CNIC_WR8(dev, BAR_CSTRORM_INTMEM + |
4164 | CSTORM_ISCSI_EQ_NEXT_PAGE_ADDR_VALID_OFFSET(func, 0), 1); | 4168 | CSTORM_ISCSI_EQ_NEXT_PAGE_ADDR_VALID_OFFSET(pfid, 0), 1); |
4165 | CNIC_WR16(dev, BAR_CSTRORM_INTMEM + | 4169 | CNIC_WR16(dev, BAR_CSTRORM_INTMEM + |
4166 | CSTORM_ISCSI_EQ_SB_NUM_OFFSET(func, 0), cp->status_blk_num); | 4170 | CSTORM_ISCSI_EQ_SB_NUM_OFFSET(pfid, 0), cp->status_blk_num); |
4167 | CNIC_WR8(dev, BAR_CSTRORM_INTMEM + | 4171 | CNIC_WR8(dev, BAR_CSTRORM_INTMEM + |
4168 | CSTORM_ISCSI_EQ_SB_INDEX_OFFSET(func, 0), | 4172 | CSTORM_ISCSI_EQ_SB_INDEX_OFFSET(pfid, 0), |
4169 | HC_INDEX_C_ISCSI_EQ_CONS); | 4173 | HC_INDEX_C_ISCSI_EQ_CONS); |
4170 | 4174 | ||
4171 | for (i = 0; i < cp->conn_buf_info.num_pages; i++) { | 4175 | for (i = 0; i < cp->conn_buf_info.num_pages; i++) { |
4172 | CNIC_WR(dev, BAR_TSTRORM_INTMEM + | 4176 | CNIC_WR(dev, BAR_TSTRORM_INTMEM + |
4173 | TSTORM_ISCSI_CONN_BUF_PBL_OFFSET(func, i), | 4177 | TSTORM_ISCSI_CONN_BUF_PBL_OFFSET(pfid, i), |
4174 | cp->conn_buf_info.pgtbl[2 * i]); | 4178 | cp->conn_buf_info.pgtbl[2 * i]); |
4175 | CNIC_WR(dev, BAR_TSTRORM_INTMEM + | 4179 | CNIC_WR(dev, BAR_TSTRORM_INTMEM + |
4176 | TSTORM_ISCSI_CONN_BUF_PBL_OFFSET(func, i) + 4, | 4180 | TSTORM_ISCSI_CONN_BUF_PBL_OFFSET(pfid, i) + 4, |
4177 | cp->conn_buf_info.pgtbl[(2 * i) + 1]); | 4181 | cp->conn_buf_info.pgtbl[(2 * i) + 1]); |
4178 | } | 4182 | } |
4179 | 4183 | ||
4180 | CNIC_WR(dev, BAR_USTRORM_INTMEM + | 4184 | CNIC_WR(dev, BAR_USTRORM_INTMEM + |
4181 | USTORM_ISCSI_GLOBAL_BUF_PHYS_ADDR_OFFSET(func), | 4185 | USTORM_ISCSI_GLOBAL_BUF_PHYS_ADDR_OFFSET(pfid), |
4182 | cp->gbl_buf_info.pg_map_arr[0] & 0xffffffff); | 4186 | cp->gbl_buf_info.pg_map_arr[0] & 0xffffffff); |
4183 | CNIC_WR(dev, BAR_USTRORM_INTMEM + | 4187 | CNIC_WR(dev, BAR_USTRORM_INTMEM + |
4184 | USTORM_ISCSI_GLOBAL_BUF_PHYS_ADDR_OFFSET(func) + 4, | 4188 | USTORM_ISCSI_GLOBAL_BUF_PHYS_ADDR_OFFSET(pfid) + 4, |
4185 | (u64) cp->gbl_buf_info.pg_map_arr[0] >> 32); | 4189 | (u64) cp->gbl_buf_info.pg_map_arr[0] >> 32); |
4186 | 4190 | ||
4187 | cnic_setup_bnx2x_context(dev); | 4191 | cnic_setup_bnx2x_context(dev); |
@@ -4386,7 +4390,7 @@ static void cnic_stop_bnx2x_hw(struct cnic_dev *dev) | |||
4386 | index_values[HC_INDEX_C_ISCSI_EQ_CONS]), | 4390 | index_values[HC_INDEX_C_ISCSI_EQ_CONS]), |
4387 | 0); | 4391 | 0); |
4388 | CNIC_WR(dev, BAR_CSTRORM_INTMEM + | 4392 | CNIC_WR(dev, BAR_CSTRORM_INTMEM + |
4389 | CSTORM_ISCSI_EQ_CONS_OFFSET(cp->func, 0), 0); | 4393 | CSTORM_ISCSI_EQ_CONS_OFFSET(cp->pfid, 0), 0); |
4390 | CNIC_WR16(dev, cp->kcq1.io_addr, 0); | 4394 | CNIC_WR16(dev, cp->kcq1.io_addr, 0); |
4391 | cnic_free_resc(dev); | 4395 | cnic_free_resc(dev); |
4392 | } | 4396 | } |
diff --git a/drivers/net/cnic.h b/drivers/net/cnic.h index 6c099811eee7..ef2c25e4962d 100644 --- a/drivers/net/cnic.h +++ b/drivers/net/cnic.h | |||
@@ -272,6 +272,7 @@ struct cnic_local { | |||
272 | 272 | ||
273 | u32 chip_id; | 273 | u32 chip_id; |
274 | int func; | 274 | int func; |
275 | u32 pfid; | ||
275 | u32 shmem_base; | 276 | u32 shmem_base; |
276 | 277 | ||
277 | u32 uio_dev; | 278 | u32 uio_dev; |