Lines Matching refs:ionic

273 	dev_dbg(lif->ionic->dev, "notifyq event:\n");  in ionic_notifyq_service()
282 if (lif->ionic->idev.fw_status_ready && in ionic_notifyq_service()
390 err = ionic_heartbeat_check(lif->ionic); in ionic_adminq_post()
443 ionic_heartbeat_check(lif->ionic); in ionic_adminq_wait()
445 !lif->ionic->idev.fw_status_ready) || in ionic_adminq_wait()
457 dev_dbg(lif->ionic->dev, "%s: elapsed %d msecs\n", in ionic_adminq_wait()
471 if (!ionic_is_fw_running(&lif->ionic->idev)) in __ionic_adminq_post_wait()
489 static void ionic_dev_cmd_clean(struct ionic *ionic) in ionic_dev_cmd_clean() argument
491 struct ionic_dev *idev = &ionic->idev; in ionic_dev_cmd_clean()
500 void ionic_dev_cmd_dev_err_print(struct ionic *ionic, u8 opcode, u8 status, in ionic_dev_cmd_dev_err_print() argument
508 dev_err(ionic->dev, "DEV_CMD %s (%d) error, %s (%d) failed\n", in ionic_dev_cmd_dev_err_print()
512 static int __ionic_dev_cmd_wait(struct ionic *ionic, unsigned long max_seconds, in __ionic_dev_cmd_wait() argument
515 struct ionic_dev *idev = &ionic->idev; in __ionic_dev_cmd_wait()
542 dev_dbg(ionic->dev, "DEVCMD %s (%d) done=%d took %ld secs (%ld jiffies)\n", in __ionic_dev_cmd_wait()
547 ionic_dev_cmd_clean(ionic); in __ionic_dev_cmd_wait()
548 dev_warn(ionic->dev, "DEVCMD %s (%d) interrupted - FW is down\n", in __ionic_dev_cmd_wait()
554 ionic_dev_cmd_clean(ionic); in __ionic_dev_cmd_wait()
555 dev_warn(ionic->dev, "DEVCMD %s (%d) timeout after %ld secs\n", in __ionic_dev_cmd_wait()
560 err = ionic_dev_cmd_status(&ionic->idev); in __ionic_dev_cmd_wait()
564 dev_dbg(ionic->dev, "DEV_CMD %s (%d), %s (%d) retrying...\n", in __ionic_dev_cmd_wait()
576 ionic_dev_cmd_dev_err_print(ionic, opcode, err, in __ionic_dev_cmd_wait()
582 ionic_dev_cmd_clean(ionic); in __ionic_dev_cmd_wait()
587 int ionic_dev_cmd_wait(struct ionic *ionic, unsigned long max_seconds) in ionic_dev_cmd_wait() argument
589 return __ionic_dev_cmd_wait(ionic, max_seconds, true); in ionic_dev_cmd_wait()
592 int ionic_dev_cmd_wait_nomsg(struct ionic *ionic, unsigned long max_seconds) in ionic_dev_cmd_wait_nomsg() argument
594 return __ionic_dev_cmd_wait(ionic, max_seconds, false); in ionic_dev_cmd_wait_nomsg()
597 int ionic_setup(struct ionic *ionic) in ionic_setup() argument
601 err = ionic_dev_setup(ionic); in ionic_setup()
604 ionic_reset(ionic); in ionic_setup()
609 int ionic_identify(struct ionic *ionic) in ionic_identify() argument
611 struct ionic_identity *ident = &ionic->ident; in ionic_identify()
612 struct ionic_dev *idev = &ionic->idev; in ionic_identify()
622 mutex_lock(&ionic->dev_cmd_lock); in ionic_identify()
628 err = ionic_dev_cmd_wait(ionic, DEVCMD_TIMEOUT); in ionic_identify()
633 mutex_unlock(&ionic->dev_cmd_lock); in ionic_identify()
636 dev_err(ionic->dev, "Cannot identify ionic: %d\n", err); in ionic_identify()
642 dev_info(ionic->dev, "FW: %.*s\n", in ionic_identify()
646 dev_info(ionic->dev, "FW: (invalid string) 0x%02x 0x%02x 0x%02x 0x%02x ...\n", in ionic_identify()
652 err = ionic_lif_identify(ionic, IONIC_LIF_TYPE_CLASSIC, in ionic_identify()
653 &ionic->ident.lif); in ionic_identify()
655 dev_err(ionic->dev, "Cannot identify LIFs: %d\n", err); in ionic_identify()
665 int ionic_init(struct ionic *ionic) in ionic_init() argument
667 struct ionic_dev *idev = &ionic->idev; in ionic_init()
670 mutex_lock(&ionic->dev_cmd_lock); in ionic_init()
672 err = ionic_dev_cmd_wait(ionic, DEVCMD_TIMEOUT); in ionic_init()
673 mutex_unlock(&ionic->dev_cmd_lock); in ionic_init()
678 int ionic_reset(struct ionic *ionic) in ionic_reset() argument
680 struct ionic_dev *idev = &ionic->idev; in ionic_reset()
686 mutex_lock(&ionic->dev_cmd_lock); in ionic_reset()
688 err = ionic_dev_cmd_wait(ionic, DEVCMD_TIMEOUT); in ionic_reset()
689 mutex_unlock(&ionic->dev_cmd_lock); in ionic_reset()
694 int ionic_port_identify(struct ionic *ionic) in ionic_port_identify() argument
696 struct ionic_identity *ident = &ionic->ident; in ionic_port_identify()
697 struct ionic_dev *idev = &ionic->idev; in ionic_port_identify()
701 mutex_lock(&ionic->dev_cmd_lock); in ionic_port_identify()
704 err = ionic_dev_cmd_wait(ionic, DEVCMD_TIMEOUT); in ionic_port_identify()
710 mutex_unlock(&ionic->dev_cmd_lock); in ionic_port_identify()
715 int ionic_port_init(struct ionic *ionic) in ionic_port_init() argument
717 struct ionic_identity *ident = &ionic->ident; in ionic_port_init()
718 struct ionic_dev *idev = &ionic->idev; in ionic_port_init()
724 idev->port_info = dma_alloc_coherent(ionic->dev, in ionic_port_init()
734 mutex_lock(&ionic->dev_cmd_lock); in ionic_port_init()
738 err = ionic_dev_cmd_wait(ionic, DEVCMD_TIMEOUT); in ionic_port_init()
740 ionic_dev_cmd_port_state(&ionic->idev, IONIC_PORT_ADMIN_STATE_UP); in ionic_port_init()
741 ionic_dev_cmd_wait(ionic, DEVCMD_TIMEOUT); in ionic_port_init()
743 mutex_unlock(&ionic->dev_cmd_lock); in ionic_port_init()
745 dev_err(ionic->dev, "Failed to init port\n"); in ionic_port_init()
746 dma_free_coherent(ionic->dev, idev->port_info_sz, in ionic_port_init()
755 int ionic_port_reset(struct ionic *ionic) in ionic_port_reset() argument
757 struct ionic_dev *idev = &ionic->idev; in ionic_port_reset()
764 mutex_lock(&ionic->dev_cmd_lock); in ionic_port_reset()
766 err = ionic_dev_cmd_wait(ionic, DEVCMD_TIMEOUT); in ionic_port_reset()
767 mutex_unlock(&ionic->dev_cmd_lock); in ionic_port_reset()
770 dma_free_coherent(ionic->dev, idev->port_info_sz, in ionic_port_reset()