int
swi_scheduler_main (void *arg)
{
- int id = (long) arg;
+ int id = (int)(long_ptr_t) arg;
char name[16];
snprintf(name, sizeof(name), "swi_sd%03d", id);
spin_unlock(&swi_data.wi_lock);
if (nloops < SWI_RESCHED)
- wait_event_interruptible_exclusive(
+ cfs_wait_event_interruptible_exclusive(
swi_data.wi_waitq,
- !swi_sched_cansleep(&swi_data.wi_runq));
+ !swi_sched_cansleep(&swi_data.wi_runq), rc);
else
our_cond_resched();
int rc;
swi_workitem_t *wi;
- while (!list_empty(&swi_data.wi_serial_runq) &&
+ while (!list_empty(&swi_data.wi_serial_runq) &&
nloops < SWI_RESCHED) {
wi = list_entry(swi_data.wi_serial_runq.next,
swi_workitem_t, wi_list);
list_del_init(&wi->wi_list);
- LASSERT (!wi->wi_running);
- LASSERT (wi->wi_scheduled);
+ LASSERTF (!wi->wi_running && wi->wi_scheduled,
+ "wi %p running %d scheduled %d\n",
+ wi, wi->wi_running, wi->wi_scheduled);
nloops++;
wi->wi_running = 1;
spin_unlock(&swi_data.wi_lock);
if (nloops < SWI_RESCHED)
- wait_event_interruptible_exclusive(
- swi_data.wi_serial_waitq,
- !swi_sched_cansleep(&swi_data.wi_serial_runq));
+ cfs_wait_event_interruptible_exclusive(
+ swi_data.wi_serial_waitq,
+ !swi_sched_cansleep(&swi_data.wi_serial_runq), rc);
else
our_cond_resched();
}
for (i = 0; i < num_online_cpus(); i++) {
- rc = swi_start_thread(swi_scheduler_main, (void *) (long) i);
+ rc = swi_start_thread(swi_scheduler_main,
+ (void *) (long_ptr_t) i);
if (rc != 0) {
CERROR ("Can't spawn workitem scheduler: %d\n", rc);
swi_shutdown();