From 9d0d597c5fd4a1fd6d3c85fe177f7b36e39d5082 Mon Sep 17 00:00:00 2001 From: Jonathan Gray Date: Sat, 29 Apr 2006 02:58:16 +0000 Subject: Add a close method to send the shutdown command, which presumably put the adapter in a low power usage state. --- sys/dev/usb/uslcom.c | 22 ++++++++++++++++++++-- 1 file changed, 20 insertions(+), 2 deletions(-) (limited to 'sys') diff --git a/sys/dev/usb/uslcom.c b/sys/dev/usb/uslcom.c index c7e65679db6..b8622f69fb1 100644 --- a/sys/dev/usb/uslcom.c +++ b/sys/dev/usb/uslcom.c @@ -1,4 +1,4 @@ -/* $OpenBSD: uslcom.c,v 1.1 2006/04/29 02:15:06 jsg Exp $ */ +/* $OpenBSD: uslcom.c,v 1.2 2006/04/29 02:58:15 jsg Exp $ */ /* * Copyright (c) 2006 Jonathan Gray @@ -95,6 +95,7 @@ Static void uslcom_get_status(void *, int portno, u_char *lsr, u_char *msr); Static void uslcom_set(void *, int, int, int); Static int uslcom_param(void *, int, struct termios *); Static int uslcom_open(void *sc, int portno); +Static void uslcom_close(void *, int); Static void uslcom_break(void *sc, int portno, int onoff); struct ucom_methods uslcom_methods = { @@ -103,7 +104,7 @@ struct ucom_methods uslcom_methods = { uslcom_param, NULL, uslcom_open, - NULL, + uslcom_close, NULL, NULL, }; @@ -271,6 +272,23 @@ uslcom_open(void *vsc, int portno) return (0); } +Static void +uslcom_close(void *vsc, int portno) +{ + struct uslcom_softc *sc = vsc; + usb_device_request_t req; + + if (sc->sc_dying) + return; + + req.bmRequestType = USLCOM_WRITE; + req.bRequest = USLCOM_UART; + USETW(req.wValue, USLCOM_UART_DISABLE); + USETW(req.wIndex, portno); + USETW(req.wLength, 0); + usbd_do_request(sc->sc_udev, &req, NULL); +} + Static void uslcom_set(void *vsc, int portno, int reg, int onoff) { -- cgit v1.2.3