提交 b386eec6 编写于 作者: K Kees Cook

scsi: be2iscsi: Convert timers to use timer_setup()

In preparation for unconditionally passing the struct timer_list pointer to
all timer callbacks, switch to using the new timer_setup() and from_timer()
to pass the timer pointer explicitly.

Cc: Subbu Seetharaman <subbu.seetharaman@broadcom.com>
Cc: Ketan Mukadam <ketan.mukadam@broadcom.com>
Cc: Jitendra Bhivare <jitendra.bhivare@broadcom.com>
Cc: "James E.J. Bottomley" <jejb@linux.vnet.ibm.com>
Cc: "Martin K. Petersen" <martin.petersen@oracle.com>
Cc: linux-scsi@vger.kernel.org
Signed-off-by: NKees Cook <keescook@chromium.org>
Reviewed-by: NMartin K. Petersen <martin.petersen@oracle.com>
上级 30199bee
...@@ -5230,12 +5230,11 @@ static void beiscsi_eqd_update_work(struct work_struct *work) ...@@ -5230,12 +5230,11 @@ static void beiscsi_eqd_update_work(struct work_struct *work)
msecs_to_jiffies(BEISCSI_EQD_UPDATE_INTERVAL)); msecs_to_jiffies(BEISCSI_EQD_UPDATE_INTERVAL));
} }
static void beiscsi_hw_tpe_check(unsigned long ptr) static void beiscsi_hw_tpe_check(struct timer_list *t)
{ {
struct beiscsi_hba *phba; struct beiscsi_hba *phba = from_timer(phba, t, hw_check);
u32 wait; u32 wait;
phba = (struct beiscsi_hba *)ptr;
/* if not TPE, do nothing */ /* if not TPE, do nothing */
if (!beiscsi_detect_tpe(phba)) if (!beiscsi_detect_tpe(phba))
return; return;
...@@ -5248,11 +5247,10 @@ static void beiscsi_hw_tpe_check(unsigned long ptr) ...@@ -5248,11 +5247,10 @@ static void beiscsi_hw_tpe_check(unsigned long ptr)
msecs_to_jiffies(wait)); msecs_to_jiffies(wait));
} }
static void beiscsi_hw_health_check(unsigned long ptr) static void beiscsi_hw_health_check(struct timer_list *t)
{ {
struct beiscsi_hba *phba; struct beiscsi_hba *phba = from_timer(phba, t, hw_check);
phba = (struct beiscsi_hba *)ptr;
beiscsi_detect_ue(phba); beiscsi_detect_ue(phba);
if (beiscsi_detect_ue(phba)) { if (beiscsi_detect_ue(phba)) {
__beiscsi_log(phba, KERN_ERR, __beiscsi_log(phba, KERN_ERR,
...@@ -5264,7 +5262,7 @@ static void beiscsi_hw_health_check(unsigned long ptr) ...@@ -5264,7 +5262,7 @@ static void beiscsi_hw_health_check(unsigned long ptr)
if (!test_bit(BEISCSI_HBA_UER_SUPP, &phba->state)) if (!test_bit(BEISCSI_HBA_UER_SUPP, &phba->state))
return; return;
/* modify this timer to check TPE */ /* modify this timer to check TPE */
phba->hw_check.function = beiscsi_hw_tpe_check; phba->hw_check.function = (TIMER_FUNC_TYPE)beiscsi_hw_tpe_check;
} }
mod_timer(&phba->hw_check, mod_timer(&phba->hw_check,
...@@ -5351,7 +5349,7 @@ static int beiscsi_enable_port(struct beiscsi_hba *phba) ...@@ -5351,7 +5349,7 @@ static int beiscsi_enable_port(struct beiscsi_hba *phba)
* Timer function gets modified for TPE detection. * Timer function gets modified for TPE detection.
* Always reinit to do health check first. * Always reinit to do health check first.
*/ */
phba->hw_check.function = beiscsi_hw_health_check; phba->hw_check.function = (TIMER_FUNC_TYPE)beiscsi_hw_health_check;
mod_timer(&phba->hw_check, mod_timer(&phba->hw_check,
jiffies + msecs_to_jiffies(BEISCSI_UE_DETECT_INTERVAL)); jiffies + msecs_to_jiffies(BEISCSI_UE_DETECT_INTERVAL));
return 0; return 0;
...@@ -5708,9 +5706,7 @@ static int beiscsi_dev_probe(struct pci_dev *pcidev, ...@@ -5708,9 +5706,7 @@ static int beiscsi_dev_probe(struct pci_dev *pcidev,
* Start UE detection here. UE before this will cause stall in probe * Start UE detection here. UE before this will cause stall in probe
* and eventually fail the probe. * and eventually fail the probe.
*/ */
init_timer(&phba->hw_check); timer_setup(&phba->hw_check, beiscsi_hw_health_check, 0);
phba->hw_check.function = beiscsi_hw_health_check;
phba->hw_check.data = (unsigned long)phba;
mod_timer(&phba->hw_check, mod_timer(&phba->hw_check,
jiffies + msecs_to_jiffies(BEISCSI_UE_DETECT_INTERVAL)); jiffies + msecs_to_jiffies(BEISCSI_UE_DETECT_INTERVAL));
beiscsi_log(phba, KERN_INFO, BEISCSI_LOG_INIT, beiscsi_log(phba, KERN_INFO, BEISCSI_LOG_INIT,
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册
新手
引导
客服 返回
顶部