Lines Matching refs:winch
585 struct winch { struct
597 struct winch *winch = container_of(work, struct winch, work); in __free_winch() local
598 um_free_irq(WINCH_IRQ, winch); in __free_winch()
600 if (winch->pid != -1) in __free_winch()
601 os_kill_process(winch->pid, 1); in __free_winch()
602 if (winch->stack != 0) in __free_winch()
603 free_stack(winch->stack, 0); in __free_winch()
604 kfree(winch); in __free_winch()
607 static void free_winch(struct winch *winch) in free_winch() argument
609 int fd = winch->fd; in free_winch()
610 winch->fd = -1; in free_winch()
613 __free_winch(&winch->work); in free_winch()
618 struct winch *winch = data; in winch_interrupt() local
621 int fd = winch->fd; in winch_interrupt()
630 winch->fd = -1; in winch_interrupt()
631 list_del(&winch->list); in winch_interrupt()
636 "support\n", winch->tty_fd); in winch_interrupt()
637 INIT_WORK(&winch->work, __free_winch); in winch_interrupt()
638 schedule_work(&winch->work); in winch_interrupt()
644 tty = tty_port_tty_get(winch->port); in winch_interrupt()
664 struct winch *winch; in register_winch_irq() local
666 winch = kmalloc(sizeof(*winch), GFP_KERNEL); in register_winch_irq()
667 if (winch == NULL) { in register_winch_irq()
672 *winch = ((struct winch) { .list = LIST_HEAD_INIT(winch->list), in register_winch_irq()
680 IRQF_SHARED, "winch", winch) < 0) { in register_winch_irq()
687 list_add(&winch->list, &winch_handlers); in register_winch_irq()
693 kfree(winch); in register_winch_irq()
704 struct winch *winch; in unregister_winch() local
710 winch = list_entry(ele, struct winch, list); in unregister_winch()
711 wtty = tty_port_tty_get(winch->port); in unregister_winch()
713 list_del(&winch->list); in unregister_winch()
715 free_winch(winch); in unregister_winch()
725 struct winch *winch; in winch_cleanup() local
728 while ((winch = list_first_entry_or_null(&winch_handlers, in winch_cleanup()
729 struct winch, list))) { in winch_cleanup()
730 list_del(&winch->list); in winch_cleanup()
733 free_winch(winch); in winch_cleanup()