From 0f07803d84b5ac89500ee33a6818c50583e3ff7f Mon Sep 17 00:00:00 2001 From: Keith Packard Date: Sat, 25 Apr 2009 13:18:37 -0700 Subject: [PATCH] Allow the USB system to be disabled/enabled at run-time --- ao.h | 8 ++++++++ ao_usb.c | 26 +++++++++++++++++++++++++- 2 files changed, 33 insertions(+), 1 deletion(-) diff --git a/ao.h b/ao.h index e9761c18..d5669ae9 100644 --- a/ao.h +++ b/ao.h @@ -273,6 +273,14 @@ ao_usb_flush(void); void ao_usb_isr(void) interrupt 6; +/* Enable the USB controller */ +void +ao_usb_enable(void); + +/* Disable the USB controller */ +void +ao_usb_disable(void); + /* Initialize the USB system */ void ao_usb_init(void); diff --git a/ao_usb.c b/ao_usb.c index c1520d75..1868ec3c 100644 --- a/ao_usb.c +++ b/ao_usb.c @@ -514,7 +514,7 @@ ao_usb_getchar(void) __critical } void -ao_usb_init(void) +ao_usb_enable(void) { /* Turn on the USB controller */ SLEEP |= SLEEP_USB_EN; @@ -537,6 +537,30 @@ ao_usb_init(void) USBCIF = 0; USBOIF = 0; USBIIF = 0; +} + +void +ao_usb_disable(void) +{ + /* Disable USB interrupts */ + USBIIE = 0; + USBOIE = 0; + USBCIE = 0; + IEN2 &= ~IEN2_USBIE; + /* Clear any pending interrupts */ + USBCIF = 0; + USBOIF = 0; + USBIIF = 0; + + /* Turn off the USB controller */ + SLEEP &= ~SLEEP_USB_EN; +} + +void +ao_usb_init(void) +{ + ao_usb_enable(); + ao_add_task(&ao_usb_task, ao_usb_ep0, "usb"); } -- 2.30.2