提交 8064135e 编写于 作者: K Kees Cook 提交者: Doug Ledford

IB/hfi1: 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. Switches test of .data field to
.function, since .data will be going away.

Cc: Mike Marciniszyn <mike.marciniszyn@intel.com>
Cc: Dennis Dalessandro <dennis.dalessandro@intel.com>
Cc: Doug Ledford <dledford@redhat.com>
Cc: Sean Hefty <sean.hefty@intel.com>
Cc: Hal Rosenstock <hal.rosenstock@gmail.com>
Cc: linux-rdma@vger.kernel.org
Signed-off-by: NKees Cook <keescook@chromium.org>
Signed-off-by: NDoug Ledford <dledford@redhat.com>
上级 a2930e5c
...@@ -218,9 +218,9 @@ static inline void aspm_ctx_disable(struct hfi1_ctxtdata *rcd) ...@@ -218,9 +218,9 @@ static inline void aspm_ctx_disable(struct hfi1_ctxtdata *rcd)
} }
/* Timer function for re-enabling ASPM in the absence of interrupt activity */ /* Timer function for re-enabling ASPM in the absence of interrupt activity */
static inline void aspm_ctx_timer_function(unsigned long data) static inline void aspm_ctx_timer_function(struct timer_list *t)
{ {
struct hfi1_ctxtdata *rcd = (struct hfi1_ctxtdata *)data; struct hfi1_ctxtdata *rcd = from_timer(rcd, t, aspm_timer);
unsigned long flags; unsigned long flags;
spin_lock_irqsave(&rcd->aspm_lock, flags); spin_lock_irqsave(&rcd->aspm_lock, flags);
...@@ -281,8 +281,7 @@ static inline void aspm_enable_all(struct hfi1_devdata *dd) ...@@ -281,8 +281,7 @@ static inline void aspm_enable_all(struct hfi1_devdata *dd)
static inline void aspm_ctx_init(struct hfi1_ctxtdata *rcd) static inline void aspm_ctx_init(struct hfi1_ctxtdata *rcd)
{ {
spin_lock_init(&rcd->aspm_lock); spin_lock_init(&rcd->aspm_lock);
setup_timer(&rcd->aspm_timer, aspm_ctx_timer_function, timer_setup(&rcd->aspm_timer, aspm_ctx_timer_function, 0);
(unsigned long)rcd);
rcd->aspm_intr_supported = rcd->dd->aspm_supported && rcd->aspm_intr_supported = rcd->dd->aspm_supported &&
aspm_mode == ASPM_MODE_DYNAMIC && aspm_mode == ASPM_MODE_DYNAMIC &&
rcd->ctxt < rcd->dd->first_dyn_alloc_ctxt; rcd->ctxt < rcd->dd->first_dyn_alloc_ctxt;
......
...@@ -5538,9 +5538,9 @@ static void handle_cce_err(struct hfi1_devdata *dd, u32 unused, u64 reg) ...@@ -5538,9 +5538,9 @@ static void handle_cce_err(struct hfi1_devdata *dd, u32 unused, u64 reg)
* associated with them. * associated with them.
*/ */
#define RCVERR_CHECK_TIME 10 #define RCVERR_CHECK_TIME 10
static void update_rcverr_timer(unsigned long opaque) static void update_rcverr_timer(struct timer_list *t)
{ {
struct hfi1_devdata *dd = (struct hfi1_devdata *)opaque; struct hfi1_devdata *dd = from_timer(dd, t, rcverr_timer);
struct hfi1_pportdata *ppd = dd->pport; struct hfi1_pportdata *ppd = dd->pport;
u32 cur_ovfl_cnt = read_dev_cntr(dd, C_RCV_OVF, CNTR_INVALID_VL); u32 cur_ovfl_cnt = read_dev_cntr(dd, C_RCV_OVF, CNTR_INVALID_VL);
...@@ -5559,7 +5559,7 @@ static void update_rcverr_timer(unsigned long opaque) ...@@ -5559,7 +5559,7 @@ static void update_rcverr_timer(unsigned long opaque)
static int init_rcverr(struct hfi1_devdata *dd) static int init_rcverr(struct hfi1_devdata *dd)
{ {
setup_timer(&dd->rcverr_timer, update_rcverr_timer, (unsigned long)dd); timer_setup(&dd->rcverr_timer, update_rcverr_timer, 0);
/* Assume the hardware counter has been reset */ /* Assume the hardware counter has been reset */
dd->rcv_ovfl_cnt = 0; dd->rcv_ovfl_cnt = 0;
return mod_timer(&dd->rcverr_timer, jiffies + HZ * RCVERR_CHECK_TIME); return mod_timer(&dd->rcverr_timer, jiffies + HZ * RCVERR_CHECK_TIME);
...@@ -5567,9 +5567,8 @@ static int init_rcverr(struct hfi1_devdata *dd) ...@@ -5567,9 +5567,8 @@ static int init_rcverr(struct hfi1_devdata *dd)
static void free_rcverr(struct hfi1_devdata *dd) static void free_rcverr(struct hfi1_devdata *dd)
{ {
if (dd->rcverr_timer.data) if (dd->rcverr_timer.function)
del_timer_sync(&dd->rcverr_timer); del_timer_sync(&dd->rcverr_timer);
dd->rcverr_timer.data = 0;
} }
static void handle_rxe_err(struct hfi1_devdata *dd, u32 unused, u64 reg) static void handle_rxe_err(struct hfi1_devdata *dd, u32 unused, u64 reg)
...@@ -12089,9 +12088,8 @@ static void free_cntrs(struct hfi1_devdata *dd) ...@@ -12089,9 +12088,8 @@ static void free_cntrs(struct hfi1_devdata *dd)
struct hfi1_pportdata *ppd; struct hfi1_pportdata *ppd;
int i; int i;
if (dd->synth_stats_timer.data) if (dd->synth_stats_timer.function)
del_timer_sync(&dd->synth_stats_timer); del_timer_sync(&dd->synth_stats_timer);
dd->synth_stats_timer.data = 0;
ppd = (struct hfi1_pportdata *)(dd + 1); ppd = (struct hfi1_pportdata *)(dd + 1);
for (i = 0; i < dd->num_pports; i++, ppd++) { for (i = 0; i < dd->num_pports; i++, ppd++) {
kfree(ppd->cntrs); kfree(ppd->cntrs);
...@@ -12367,9 +12365,9 @@ static void do_update_synth_timer(struct work_struct *work) ...@@ -12367,9 +12365,9 @@ static void do_update_synth_timer(struct work_struct *work)
} }
} }
static void update_synth_timer(unsigned long opaque) static void update_synth_timer(struct timer_list *t)
{ {
struct hfi1_devdata *dd = (struct hfi1_devdata *)opaque; struct hfi1_devdata *dd = from_timer(dd, t, synth_stats_timer);
queue_work(dd->update_cntr_wq, &dd->update_cntr_work); queue_work(dd->update_cntr_wq, &dd->update_cntr_work);
mod_timer(&dd->synth_stats_timer, jiffies + HZ * SYNTH_CNT_TIME); mod_timer(&dd->synth_stats_timer, jiffies + HZ * SYNTH_CNT_TIME);
...@@ -12387,8 +12385,7 @@ static int init_cntrs(struct hfi1_devdata *dd) ...@@ -12387,8 +12385,7 @@ static int init_cntrs(struct hfi1_devdata *dd)
const int bit_type_32_sz = strlen(bit_type_32); const int bit_type_32_sz = strlen(bit_type_32);
/* set up the stats timer; the add_timer is done at the end */ /* set up the stats timer; the add_timer is done at the end */
setup_timer(&dd->synth_stats_timer, update_synth_timer, timer_setup(&dd->synth_stats_timer, update_synth_timer, 0);
(unsigned long)dd);
/***********************/ /***********************/
/* per device counters */ /* per device counters */
......
...@@ -1252,9 +1252,9 @@ void shutdown_led_override(struct hfi1_pportdata *ppd) ...@@ -1252,9 +1252,9 @@ void shutdown_led_override(struct hfi1_pportdata *ppd)
write_csr(dd, DCC_CFG_LED_CNTRL, 0); write_csr(dd, DCC_CFG_LED_CNTRL, 0);
} }
static void run_led_override(unsigned long opaque) static void run_led_override(struct timer_list *t)
{ {
struct hfi1_pportdata *ppd = (struct hfi1_pportdata *)opaque; struct hfi1_pportdata *ppd = from_timer(ppd, t, led_override_timer);
struct hfi1_devdata *dd = ppd->dd; struct hfi1_devdata *dd = ppd->dd;
unsigned long timeout; unsigned long timeout;
int phase_idx; int phase_idx;
...@@ -1298,8 +1298,7 @@ void hfi1_start_led_override(struct hfi1_pportdata *ppd, unsigned int timeon, ...@@ -1298,8 +1298,7 @@ void hfi1_start_led_override(struct hfi1_pportdata *ppd, unsigned int timeon,
* timeout so the handler will be called soon to look at our request. * timeout so the handler will be called soon to look at our request.
*/ */
if (!timer_pending(&ppd->led_override_timer)) { if (!timer_pending(&ppd->led_override_timer)) {
setup_timer(&ppd->led_override_timer, run_led_override, timer_setup(&ppd->led_override_timer, run_led_override, 0);
(unsigned long)ppd);
ppd->led_override_timer.expires = jiffies + 1; ppd->led_override_timer.expires = jiffies + 1;
add_timer(&ppd->led_override_timer); add_timer(&ppd->led_override_timer);
atomic_set(&ppd->led_override_timer_active, 1); atomic_set(&ppd->led_override_timer_active, 1);
......
...@@ -1006,7 +1006,7 @@ static void stop_timers(struct hfi1_devdata *dd) ...@@ -1006,7 +1006,7 @@ static void stop_timers(struct hfi1_devdata *dd)
for (pidx = 0; pidx < dd->num_pports; ++pidx) { for (pidx = 0; pidx < dd->num_pports; ++pidx) {
ppd = dd->pport + pidx; ppd = dd->pport + pidx;
if (ppd->led_override_timer.data) { if (ppd->led_override_timer.function) {
del_timer_sync(&ppd->led_override_timer); del_timer_sync(&ppd->led_override_timer);
atomic_set(&ppd->led_override_timer_active, 0); atomic_set(&ppd->led_override_timer_active, 0);
} }
......
...@@ -399,9 +399,9 @@ static void send_trap(struct hfi1_ibport *ibp, struct trap_node *trap) ...@@ -399,9 +399,9 @@ static void send_trap(struct hfi1_ibport *ibp, struct trap_node *trap)
ib_free_send_mad(send_buf); ib_free_send_mad(send_buf);
} }
void hfi1_handle_trap_timer(unsigned long data) void hfi1_handle_trap_timer(struct timer_list *t)
{ {
struct hfi1_ibport *ibp = (struct hfi1_ibport *)data; struct hfi1_ibport *ibp = from_timer(ibp, t, rvp.trap_timer);
struct trap_node *trap = NULL; struct trap_node *trap = NULL;
unsigned long flags; unsigned long flags;
int i; int i;
......
...@@ -428,6 +428,6 @@ struct sc2vlnt { ...@@ -428,6 +428,6 @@ struct sc2vlnt {
COUNTER_MASK(1, 4)) COUNTER_MASK(1, 4))
void hfi1_event_pkey_change(struct hfi1_devdata *dd, u8 port); void hfi1_event_pkey_change(struct hfi1_devdata *dd, u8 port);
void hfi1_handle_trap_timer(unsigned long data); void hfi1_handle_trap_timer(struct timer_list *t);
#endif /* _HFI1_MAD_H */ #endif /* _HFI1_MAD_H */
...@@ -491,10 +491,10 @@ static void sdma_err_progress_check_schedule(struct sdma_engine *sde) ...@@ -491,10 +491,10 @@ static void sdma_err_progress_check_schedule(struct sdma_engine *sde)
} }
} }
static void sdma_err_progress_check(unsigned long data) static void sdma_err_progress_check(struct timer_list *t)
{ {
unsigned index; unsigned index;
struct sdma_engine *sde = (struct sdma_engine *)data; struct sdma_engine *sde = from_timer(sde, t, err_progress_check_timer);
dd_dev_err(sde->dd, "SDE progress check event\n"); dd_dev_err(sde->dd, "SDE progress check event\n");
for (index = 0; index < sde->dd->num_sdma; index++) { for (index = 0; index < sde->dd->num_sdma; index++) {
...@@ -1453,8 +1453,8 @@ int sdma_init(struct hfi1_devdata *dd, u8 port) ...@@ -1453,8 +1453,8 @@ int sdma_init(struct hfi1_devdata *dd, u8 port)
sde->progress_check_head = 0; sde->progress_check_head = 0;
setup_timer(&sde->err_progress_check_timer, timer_setup(&sde->err_progress_check_timer,
sdma_err_progress_check, (unsigned long)sde); sdma_err_progress_check, 0);
sde->descq = dma_zalloc_coherent( sde->descq = dma_zalloc_coherent(
&dd->pcidev->dev, &dd->pcidev->dev,
......
...@@ -667,9 +667,9 @@ void hfi1_16B_rcv(struct hfi1_packet *packet) ...@@ -667,9 +667,9 @@ void hfi1_16B_rcv(struct hfi1_packet *packet)
* This is called from a timer to check for QPs * This is called from a timer to check for QPs
* which need kernel memory in order to send a packet. * which need kernel memory in order to send a packet.
*/ */
static void mem_timer(unsigned long data) static void mem_timer(struct timer_list *t)
{ {
struct hfi1_ibdev *dev = (struct hfi1_ibdev *)data; struct hfi1_ibdev *dev = from_timer(dev, t, mem_timer);
struct list_head *list = &dev->memwait; struct list_head *list = &dev->memwait;
struct rvt_qp *qp = NULL; struct rvt_qp *qp = NULL;
struct iowait *wait; struct iowait *wait;
...@@ -1636,8 +1636,7 @@ static void init_ibport(struct hfi1_pportdata *ppd) ...@@ -1636,8 +1636,7 @@ static void init_ibport(struct hfi1_pportdata *ppd)
for (i = 0; i < RVT_MAX_TRAP_LISTS ; i++) for (i = 0; i < RVT_MAX_TRAP_LISTS ; i++)
INIT_LIST_HEAD(&ibp->rvp.trap_lists[i].list); INIT_LIST_HEAD(&ibp->rvp.trap_lists[i].list);
setup_timer(&ibp->rvp.trap_timer, hfi1_handle_trap_timer, timer_setup(&ibp->rvp.trap_timer, hfi1_handle_trap_timer, 0);
(unsigned long)ibp);
spin_lock_init(&ibp->rvp.lock); spin_lock_init(&ibp->rvp.lock);
/* Set the prefix to the default value (see ch. 4.1.1) */ /* Set the prefix to the default value (see ch. 4.1.1) */
...@@ -1844,7 +1843,7 @@ int hfi1_register_ib_device(struct hfi1_devdata *dd) ...@@ -1844,7 +1843,7 @@ int hfi1_register_ib_device(struct hfi1_devdata *dd)
/* Only need to initialize non-zero fields. */ /* Only need to initialize non-zero fields. */
setup_timer(&dev->mem_timer, mem_timer, (unsigned long)dev); timer_setup(&dev->mem_timer, mem_timer, 0);
seqlock_init(&dev->iowait_lock); seqlock_init(&dev->iowait_lock);
seqlock_init(&dev->txwait_lock); seqlock_init(&dev->txwait_lock);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册