Lines Matching full:ndev
70 static void write_to_ucd_unit(struct nitrox_device *ndev, u32 ucode_size, in write_to_ucd_unit() argument
94 nitrox_write_csr(ndev, offset, block_num); in write_to_ucd_unit()
101 nitrox_write_csr(ndev, offset, data); in write_to_ucd_unit()
109 static int nitrox_load_fw(struct nitrox_device *ndev) in nitrox_load_fw() argument
123 dev_info(DEV(ndev), "Loading firmware \"%s\"\n", fw_name); in nitrox_load_fw()
125 ret = request_firmware(&fw, fw_name, DEV(ndev)); in nitrox_load_fw()
127 dev_err(DEV(ndev), "failed to get firmware %s\n", fw_name); in nitrox_load_fw()
135 dev_err(DEV(ndev), "Invalid ucode size: %u for firmware %s\n", in nitrox_load_fw()
143 memcpy(&ndev->hw.fw_name[0][0], ucode->version, (VERSION_LEN - 2)); in nitrox_load_fw()
144 ndev->hw.fw_name[0][VERSION_LEN - 1] = '\0'; in nitrox_load_fw()
147 write_to_ucd_unit(ndev, ucode_size, ucode_data, 0); in nitrox_load_fw()
153 nitrox_write_csr(ndev, offset, (~0ULL)); in nitrox_load_fw()
167 for (i = 0; i < ndev->hw.se_cores; i++) { in nitrox_load_fw()
169 nitrox_write_csr(ndev, offset, core_2_eid_val.value); in nitrox_load_fw()
174 dev_info(DEV(ndev), "Loading firmware \"%s\"\n", fw_name); in nitrox_load_fw()
176 ret = request_firmware(&fw, fw_name, DEV(ndev)); in nitrox_load_fw()
178 dev_err(DEV(ndev), "failed to get firmware %s\n", fw_name); in nitrox_load_fw()
186 dev_err(DEV(ndev), "Invalid ucode size: %u for firmware %s\n", in nitrox_load_fw()
194 memcpy(&ndev->hw.fw_name[1][0], ucode->version, (VERSION_LEN - 2)); in nitrox_load_fw()
195 ndev->hw.fw_name[1][VERSION_LEN - 1] = '\0'; in nitrox_load_fw()
198 write_to_ucd_unit(ndev, ucode_size, ucode_data, 2); in nitrox_load_fw()
205 nitrox_write_csr(ndev, offset, aqm_grp_execmask_lo.value); in nitrox_load_fw()
208 nitrox_write_csr(ndev, offset, aqm_grp_execmask_hi.value); in nitrox_load_fw()
222 for (i = 0; i < ndev->hw.ae_cores; i++) { in nitrox_load_fw()
224 nitrox_write_csr(ndev, offset, core_2_eid_val.value); in nitrox_load_fw()
232 * @ndev: NITROX device
234 static int nitrox_add_to_devlist(struct nitrox_device *ndev) in nitrox_add_to_devlist() argument
239 INIT_LIST_HEAD(&ndev->list); in nitrox_add_to_devlist()
240 refcount_set(&ndev->refcnt, 1); in nitrox_add_to_devlist()
244 if (dev == ndev) { in nitrox_add_to_devlist()
249 ndev->idx = num_devices++; in nitrox_add_to_devlist()
250 list_add_tail(&ndev->list, &ndevlist); in nitrox_add_to_devlist()
259 * @ndev: NITROX device
261 static void nitrox_remove_from_devlist(struct nitrox_device *ndev) in nitrox_remove_from_devlist() argument
264 list_del(&ndev->list); in nitrox_remove_from_devlist()
271 struct nitrox_device *ndev = NULL, *iter; in nitrox_get_first_device() local
276 ndev = iter; in nitrox_get_first_device()
281 if (!ndev) in nitrox_get_first_device()
284 refcount_inc(&ndev->refcnt); in nitrox_get_first_device()
287 return ndev; in nitrox_get_first_device()
290 void nitrox_put_device(struct nitrox_device *ndev) in nitrox_put_device() argument
292 if (!ndev) in nitrox_put_device()
295 refcount_dec(&ndev->refcnt); in nitrox_put_device()
317 static int nitrox_pf_sw_init(struct nitrox_device *ndev) in nitrox_pf_sw_init() argument
321 err = nitrox_common_sw_init(ndev); in nitrox_pf_sw_init()
325 err = nitrox_register_interrupts(ndev); in nitrox_pf_sw_init()
327 nitrox_common_sw_cleanup(ndev); in nitrox_pf_sw_init()
332 static void nitrox_pf_sw_cleanup(struct nitrox_device *ndev) in nitrox_pf_sw_cleanup() argument
334 nitrox_unregister_interrupts(ndev); in nitrox_pf_sw_cleanup()
335 nitrox_common_sw_cleanup(ndev); in nitrox_pf_sw_cleanup()
340 * @ndev: NITROX device
342 static int nitrox_bist_check(struct nitrox_device *ndev) in nitrox_bist_check() argument
348 value += nitrox_read_csr(ndev, EMU_BIST_STATUSX(i)); in nitrox_bist_check()
349 value += nitrox_read_csr(ndev, EFL_CORE_BIST_REGX(i)); in nitrox_bist_check()
351 value += nitrox_read_csr(ndev, UCD_BIST_STATUS); in nitrox_bist_check()
352 value += nitrox_read_csr(ndev, NPS_CORE_BIST_REG); in nitrox_bist_check()
353 value += nitrox_read_csr(ndev, NPS_CORE_NPC_BIST_REG); in nitrox_bist_check()
354 value += nitrox_read_csr(ndev, NPS_PKT_SLC_BIST_REG); in nitrox_bist_check()
355 value += nitrox_read_csr(ndev, NPS_PKT_IN_BIST_REG); in nitrox_bist_check()
356 value += nitrox_read_csr(ndev, POM_BIST_REG); in nitrox_bist_check()
357 value += nitrox_read_csr(ndev, BMI_BIST_REG); in nitrox_bist_check()
358 value += nitrox_read_csr(ndev, EFL_TOP_BIST_STAT); in nitrox_bist_check()
359 value += nitrox_read_csr(ndev, BMO_BIST_REG); in nitrox_bist_check()
360 value += nitrox_read_csr(ndev, LBC_BIST_STATUS); in nitrox_bist_check()
361 value += nitrox_read_csr(ndev, PEM_BIST_STATUSX(0)); in nitrox_bist_check()
367 static int nitrox_pf_hw_init(struct nitrox_device *ndev) in nitrox_pf_hw_init() argument
371 err = nitrox_bist_check(ndev); in nitrox_pf_hw_init()
373 dev_err(&ndev->pdev->dev, "BIST check failed\n"); in nitrox_pf_hw_init()
377 nitrox_get_hwinfo(ndev); in nitrox_pf_hw_init()
379 nitrox_config_nps_core_unit(ndev); in nitrox_pf_hw_init()
380 nitrox_config_aqm_unit(ndev); in nitrox_pf_hw_init()
381 nitrox_config_nps_pkt_unit(ndev); in nitrox_pf_hw_init()
382 nitrox_config_pom_unit(ndev); in nitrox_pf_hw_init()
383 nitrox_config_efl_unit(ndev); in nitrox_pf_hw_init()
385 nitrox_config_bmi_unit(ndev); in nitrox_pf_hw_init()
386 nitrox_config_bmo_unit(ndev); in nitrox_pf_hw_init()
388 nitrox_config_lbc_unit(ndev); in nitrox_pf_hw_init()
389 nitrox_config_rand_unit(ndev); in nitrox_pf_hw_init()
392 err = nitrox_load_fw(ndev); in nitrox_pf_hw_init()
396 nitrox_config_emu_unit(ndev); in nitrox_pf_hw_init()
412 struct nitrox_device *ndev; in nitrox_probe() local
444 ndev = kzalloc(sizeof(*ndev), GFP_KERNEL); in nitrox_probe()
445 if (!ndev) { in nitrox_probe()
450 pci_set_drvdata(pdev, ndev); in nitrox_probe()
451 ndev->pdev = pdev; in nitrox_probe()
454 nitrox_add_to_devlist(ndev); in nitrox_probe()
456 ndev->hw.vendor_id = pdev->vendor; in nitrox_probe()
457 ndev->hw.device_id = pdev->device; in nitrox_probe()
458 ndev->hw.revision_id = pdev->revision; in nitrox_probe()
460 ndev->timeout = msecs_to_jiffies(CMD_TIMEOUT); in nitrox_probe()
461 ndev->node = dev_to_node(&pdev->dev); in nitrox_probe()
462 if (ndev->node == NUMA_NO_NODE) in nitrox_probe()
463 ndev->node = 0; in nitrox_probe()
465 ndev->bar_addr = ioremap(pci_resource_start(pdev, 0), in nitrox_probe()
467 if (!ndev->bar_addr) { in nitrox_probe()
472 ndev->nr_queues = min_t(u32, MAX_PF_QUEUES, num_online_cpus()); in nitrox_probe()
473 ndev->qlen = qlen; in nitrox_probe()
475 err = nitrox_pf_sw_init(ndev); in nitrox_probe()
479 err = nitrox_pf_hw_init(ndev); in nitrox_probe()
483 nitrox_debugfs_init(ndev); in nitrox_probe()
486 atomic64_set(&ndev->stats.posted, 0); in nitrox_probe()
487 atomic64_set(&ndev->stats.completed, 0); in nitrox_probe()
488 atomic64_set(&ndev->stats.dropped, 0); in nitrox_probe()
490 atomic_set(&ndev->state, __NDEV_READY); in nitrox_probe()
501 nitrox_debugfs_exit(ndev); in nitrox_probe()
502 atomic_set(&ndev->state, __NDEV_NOT_READY); in nitrox_probe()
506 nitrox_pf_sw_cleanup(ndev); in nitrox_probe()
508 iounmap(ndev->bar_addr); in nitrox_probe()
510 nitrox_remove_from_devlist(ndev); in nitrox_probe()
511 kfree(ndev); in nitrox_probe()
526 struct nitrox_device *ndev = pci_get_drvdata(pdev); in nitrox_remove() local
528 if (!ndev) in nitrox_remove()
531 if (!refcount_dec_and_test(&ndev->refcnt)) { in nitrox_remove()
532 dev_err(DEV(ndev), "Device refcnt not zero (%d)\n", in nitrox_remove()
533 refcount_read(&ndev->refcnt)); in nitrox_remove()
537 dev_info(DEV(ndev), "Removing Device %x:%x\n", in nitrox_remove()
538 ndev->hw.vendor_id, ndev->hw.device_id); in nitrox_remove()
540 atomic_set(&ndev->state, __NDEV_NOT_READY); in nitrox_remove()
544 nitrox_remove_from_devlist(ndev); in nitrox_remove()
549 nitrox_debugfs_exit(ndev); in nitrox_remove()
550 nitrox_pf_sw_cleanup(ndev); in nitrox_remove()
552 iounmap(ndev->bar_addr); in nitrox_remove()
553 kfree(ndev); in nitrox_remove()