Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 235283
b: refs/heads/master
c: 9abff15
h: refs/heads/master
i:
  235281: 52e9fc9
  235279: 41e7b99
v: v3
  • Loading branch information
Tejun Heo authored and Greg Kroah-Hartman committed Jan 23, 2011
1 parent 2e916fa commit 5a04e05
Show file tree
Hide file tree
Showing 2 changed files with 6 additions and 15 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: ef58d97a30af66b31f6400e49c87b4d64fc1f5bc
refs/heads/master: 9abff15dd69c6f4ed88ecc8ba089f55e9cf6655e
19 changes: 5 additions & 14 deletions trunk/drivers/usb/atm/ueagle-atm.c
Original file line number Diff line number Diff line change
Expand Up @@ -168,7 +168,6 @@ struct uea_softc {
union cmv_dsc cmv_dsc;

struct work_struct task;
struct workqueue_struct *work_q;
u16 pageno;
u16 ovl;

Expand Down Expand Up @@ -1879,7 +1878,7 @@ static int uea_start_reset(struct uea_softc *sc)
/* start loading DSP */
sc->pageno = 0;
sc->ovl = 0;
queue_work(sc->work_q, &sc->task);
schedule_work(&sc->task);

/* wait for modem ready CMV */
ret = wait_cmv_ack(sc);
Expand Down Expand Up @@ -2091,14 +2090,14 @@ static void uea_schedule_load_page_e1(struct uea_softc *sc,
{
sc->pageno = intr->e1_bSwapPageNo;
sc->ovl = intr->e1_bOvl >> 4 | intr->e1_bOvl << 4;
queue_work(sc->work_q, &sc->task);
schedule_work(&sc->task);
}

static void uea_schedule_load_page_e4(struct uea_softc *sc,
struct intr_pkt *intr)
{
sc->pageno = intr->e4_bSwapPageNo;
queue_work(sc->work_q, &sc->task);
schedule_work(&sc->task);
}

/*
Expand Down Expand Up @@ -2170,13 +2169,6 @@ static int uea_boot(struct uea_softc *sc)

init_waitqueue_head(&sc->sync_q);

sc->work_q = create_workqueue("ueagle-dsp");
if (!sc->work_q) {
uea_err(INS_TO_USBDEV(sc), "cannot allocate workqueue\n");
uea_leaves(INS_TO_USBDEV(sc));
return -ENOMEM;
}

if (UEA_CHIP_VERSION(sc) == ADI930)
load_XILINX_firmware(sc);

Expand Down Expand Up @@ -2225,7 +2217,6 @@ static int uea_boot(struct uea_softc *sc)
sc->urb_int = NULL;
kfree(intr);
err0:
destroy_workqueue(sc->work_q);
uea_leaves(INS_TO_USBDEV(sc));
return -ENOMEM;
}
Expand All @@ -2246,8 +2237,8 @@ static void uea_stop(struct uea_softc *sc)
kfree(sc->urb_int->transfer_buffer);
usb_free_urb(sc->urb_int);

/* stop any pending boot process, when no one can schedule work */
destroy_workqueue(sc->work_q);
/* flush the work item, when no one can schedule it */
flush_work_sync(&sc->task);

if (sc->dsp_firm)
release_firmware(sc->dsp_firm);
Expand Down

0 comments on commit 5a04e05

Please sign in to comment.