skb_queue_head_init(&qp->req_pkts);
 
-       rxe_init_task(rxe, &qp->req.task, qp,
+       rxe_init_task(&qp->req.task, qp,
                      rxe_requester, "req");
-       rxe_init_task(rxe, &qp->comp.task, qp,
+       rxe_init_task(&qp->comp.task, qp,
                      rxe_completer, "comp");
 
        qp->qp_timeout_jiffies = 0; /* Can't be set for UD/UC in modify_qp */
 
        skb_queue_head_init(&qp->resp_pkts);
 
-       rxe_init_task(rxe, &qp->resp.task, qp,
+       rxe_init_task(&qp->resp.task, qp,
                      rxe_responder, "resp");
 
        qp->resp.opcode         = OPCODE_NONE;
 
        task->ret = ret;
 }
 
-int rxe_init_task(void *obj, struct rxe_task *task,
+int rxe_init_task(struct rxe_task *task,
                  void *arg, int (*func)(void *), char *name)
 {
-       task->obj       = obj;
        task->arg       = arg;
        task->func      = func;
        snprintf(task->name, sizeof(task->name), "%s", name);
 
  * called again.
  */
 struct rxe_task {
-       void                    *obj;
        struct tasklet_struct   tasklet;
        int                     state;
        spinlock_t              state_lock; /* spinlock for task state */
  *     arg  => parameter to pass to fcn
  *     func => function to call until it returns != 0
  */
-int rxe_init_task(void *obj, struct rxe_task *task,
+int rxe_init_task(struct rxe_task *task,
                  void *arg, int (*func)(void *), char *name);
 
 /* cleanup task */