mirror of https://github.com/ARMmbed/mbed-os.git
Merge pull request #4199 from adbridge/usb_prs
USB: bus reset for KL25Z fix, USBSerial updatepull/3886/merge
commit
49802765a9
|
|
@ -455,6 +455,9 @@ void USBHAL::usbisr(void) {
|
|||
USB0->ERREN = 0xFF; // enable error interrupt sources
|
||||
USB0->ADDR = 0x00; // set default address
|
||||
|
||||
// reset bus for USBDevice layer
|
||||
busReset();
|
||||
|
||||
return;
|
||||
}
|
||||
|
||||
|
|
|
|||
|
|
@ -38,6 +38,10 @@ USBCDC::USBCDC(uint16_t vendor_id, uint16_t product_id, uint16_t product_release
|
|||
USBDevice::connect(connect_blocking);
|
||||
}
|
||||
|
||||
void USBCDC::USBCallback_busReset(void) {
|
||||
terminal_connected = false;
|
||||
};
|
||||
|
||||
bool USBCDC::USBCallback_request(void) {
|
||||
/* Called in ISR context */
|
||||
|
||||
|
|
|
|||
|
|
@ -116,6 +116,7 @@ protected:
|
|||
virtual bool USBCallback_request();
|
||||
virtual void USBCallback_requestCompleted(uint8_t *buf, uint32_t length);
|
||||
virtual bool USBCallback_setConfiguration(uint8_t configuration);
|
||||
virtual void USBCallback_busReset(void);
|
||||
volatile bool terminal_connected;
|
||||
|
||||
};
|
||||
|
|
|
|||
|
|
@ -66,3 +66,7 @@ bool USBSerial::EPBULK_OUT_callback() {
|
|||
uint8_t USBSerial::available() {
|
||||
return buf.available();
|
||||
}
|
||||
|
||||
bool USBSerial::connected() {
|
||||
return terminal_connected;
|
||||
}
|
||||
|
|
|
|||
|
|
@ -83,6 +83,13 @@ public:
|
|||
*/
|
||||
uint8_t available();
|
||||
|
||||
/**
|
||||
* Check if the terminal is connected.
|
||||
*
|
||||
* @returns connection status
|
||||
*/
|
||||
bool connected();
|
||||
|
||||
/** Determine if there is a character available to read
|
||||
*
|
||||
* @returns
|
||||
|
|
|
|||
Loading…
Reference in New Issue