diff options
author | Jing Huang <huangj@Brocade.COM> | 2012-04-04 01:42:08 -0400 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2012-04-04 18:19:17 -0400 |
commit | e491c77ed37de43cc89cfb4930f80f9a36dff1b8 (patch) | |
tree | bdc74ac23f2c8d3f191c067acbfabc7eeaad9c1f /drivers/net | |
parent | 695e00789a2703e79da9adf3cd868fe54142885e (diff) |
bna: Serialize smem access during adapter initialization
Use init semaphore to serialize execution of the "unlock IOC semaphore"
code. Added bfa_ioc_fwver_clear() function to clear the firmware header if
last firmwar boot is not from driver.
Signed-off-by: Jing Huang <huangj@brocade.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'drivers/net')
-rw-r--r-- | drivers/net/ethernet/brocade/bna/bfa_ioc.c | 50 |
1 files changed, 42 insertions, 8 deletions
diff --git a/drivers/net/ethernet/brocade/bna/bfa_ioc.c b/drivers/net/ethernet/brocade/bna/bfa_ioc.c index 77977d735dd7..7a3e79c7834b 100644 --- a/drivers/net/ethernet/brocade/bna/bfa_ioc.c +++ b/drivers/net/ethernet/brocade/bna/bfa_ioc.c | |||
@@ -1207,27 +1207,62 @@ bfa_nw_ioc_sem_release(void __iomem *sem_reg) | |||
1207 | writel(1, sem_reg); | 1207 | writel(1, sem_reg); |
1208 | } | 1208 | } |
1209 | 1209 | ||
1210 | /* Clear fwver hdr */ | ||
1211 | static void | ||
1212 | bfa_ioc_fwver_clear(struct bfa_ioc *ioc) | ||
1213 | { | ||
1214 | u32 pgnum, pgoff, loff = 0; | ||
1215 | int i; | ||
1216 | |||
1217 | pgnum = PSS_SMEM_PGNUM(ioc->ioc_regs.smem_pg0, loff); | ||
1218 | pgoff = PSS_SMEM_PGOFF(loff); | ||
1219 | writel(pgnum, ioc->ioc_regs.host_page_num_fn); | ||
1220 | |||
1221 | for (i = 0; i < (sizeof(struct bfi_ioc_image_hdr) / sizeof(u32)); i++) { | ||
1222 | writel(0, ioc->ioc_regs.smem_page_start + loff); | ||
1223 | loff += sizeof(u32); | ||
1224 | } | ||
1225 | } | ||
1226 | |||
1227 | |||
1210 | static void | 1228 | static void |
1211 | bfa_ioc_hw_sem_init(struct bfa_ioc *ioc) | 1229 | bfa_ioc_hw_sem_init(struct bfa_ioc *ioc) |
1212 | { | 1230 | { |
1213 | struct bfi_ioc_image_hdr fwhdr; | 1231 | struct bfi_ioc_image_hdr fwhdr; |
1214 | u32 fwstate = readl(ioc->ioc_regs.ioc_fwstate); | 1232 | u32 fwstate, r32; |
1215 | 1233 | ||
1216 | if (fwstate == BFI_IOC_UNINIT) | 1234 | /* Spin on init semaphore to serialize. */ |
1235 | r32 = readl(ioc->ioc_regs.ioc_init_sem_reg); | ||
1236 | while (r32 & 0x1) { | ||
1237 | udelay(20); | ||
1238 | r32 = readl(ioc->ioc_regs.ioc_init_sem_reg); | ||
1239 | } | ||
1240 | |||
1241 | fwstate = readl(ioc->ioc_regs.ioc_fwstate); | ||
1242 | if (fwstate == BFI_IOC_UNINIT) { | ||
1243 | writel(1, ioc->ioc_regs.ioc_init_sem_reg); | ||
1217 | return; | 1244 | return; |
1245 | } | ||
1218 | 1246 | ||
1219 | bfa_nw_ioc_fwver_get(ioc, &fwhdr); | 1247 | bfa_nw_ioc_fwver_get(ioc, &fwhdr); |
1220 | 1248 | ||
1221 | if (swab32(fwhdr.exec) == BFI_FWBOOT_TYPE_NORMAL) | 1249 | if (swab32(fwhdr.exec) == BFI_FWBOOT_TYPE_NORMAL) { |
1250 | writel(1, ioc->ioc_regs.ioc_init_sem_reg); | ||
1222 | return; | 1251 | return; |
1252 | } | ||
1223 | 1253 | ||
1254 | bfa_ioc_fwver_clear(ioc); | ||
1224 | writel(BFI_IOC_UNINIT, ioc->ioc_regs.ioc_fwstate); | 1255 | writel(BFI_IOC_UNINIT, ioc->ioc_regs.ioc_fwstate); |
1256 | writel(BFI_IOC_UNINIT, ioc->ioc_regs.alt_ioc_fwstate); | ||
1225 | 1257 | ||
1226 | /* | 1258 | /* |
1227 | * Try to lock and then unlock the semaphore. | 1259 | * Try to lock and then unlock the semaphore. |
1228 | */ | 1260 | */ |
1229 | readl(ioc->ioc_regs.ioc_sem_reg); | 1261 | readl(ioc->ioc_regs.ioc_sem_reg); |
1230 | writel(1, ioc->ioc_regs.ioc_sem_reg); | 1262 | writel(1, ioc->ioc_regs.ioc_sem_reg); |
1263 | |||
1264 | /* Unlock init semaphore */ | ||
1265 | writel(1, ioc->ioc_regs.ioc_init_sem_reg); | ||
1231 | } | 1266 | } |
1232 | 1267 | ||
1233 | static void | 1268 | static void |
@@ -1585,11 +1620,6 @@ bfa_ioc_download_fw(struct bfa_ioc *ioc, u32 boot_type, | |||
1585 | u32 i; | 1620 | u32 i; |
1586 | u32 asicmode; | 1621 | u32 asicmode; |
1587 | 1622 | ||
1588 | /** | ||
1589 | * Initialize LMEM first before code download | ||
1590 | */ | ||
1591 | bfa_ioc_lmem_init(ioc); | ||
1592 | |||
1593 | fwimg = bfa_cb_image_get_chunk(bfa_ioc_asic_gen(ioc), chunkno); | 1623 | fwimg = bfa_cb_image_get_chunk(bfa_ioc_asic_gen(ioc), chunkno); |
1594 | 1624 | ||
1595 | pgnum = bfa_ioc_smem_pgnum(ioc, loff); | 1625 | pgnum = bfa_ioc_smem_pgnum(ioc, loff); |
@@ -1914,6 +1944,10 @@ bfa_ioc_pll_init(struct bfa_ioc *ioc) | |||
1914 | bfa_ioc_pll_init_asic(ioc); | 1944 | bfa_ioc_pll_init_asic(ioc); |
1915 | 1945 | ||
1916 | ioc->pllinit = true; | 1946 | ioc->pllinit = true; |
1947 | |||
1948 | /* Initialize LMEM */ | ||
1949 | bfa_ioc_lmem_init(ioc); | ||
1950 | |||
1917 | /* | 1951 | /* |
1918 | * release semaphore. | 1952 | * release semaphore. |
1919 | */ | 1953 | */ |