From 7fd9003f59ad6a1de8d8b70fae74ba16df666c09 Mon Sep 17 00:00:00 2001 From: tmk Date: Thu, 23 Sep 2010 20:23:50 +0900 Subject: divide usb_keyboard_debug.[c|h] into usb_device, usb_keyboard, usb_debug. --- usb_debug.c | 80 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 80 insertions(+) create mode 100644 usb_debug.c (limited to 'usb_debug.c') diff --git a/usb_debug.c b/usb_debug.c new file mode 100644 index 0000000000..97590184a5 --- /dev/null +++ b/usb_debug.c @@ -0,0 +1,80 @@ +#include +#include "usb_debug.h" + + +// the time remaining before we transmit any partially full +// packet, or send a zero length packet. +volatile uint8_t debug_flush_timer=0; + + +// transmit a character. 0 returned on success, -1 on error +int8_t usb_debug_putchar(uint8_t c) +{ + static uint8_t previous_timeout=0; + uint8_t timeout, intr_state; + + // if we're not online (enumerated and configured), error + if (!usb_configured()) return -1; + // interrupts are disabled so these functions can be + // used from the main program or interrupt context, + // even both in the same program! + intr_state = SREG; + cli(); + UENUM = DEBUG_TX_ENDPOINT; + // if we gave up due to timeout before, don't wait again + if (previous_timeout) { + if (!(UEINTX & (1<