summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorChristian Pointner <equinox@spreadspace.org>2015-06-22 02:30:18 +0200
committerChristian Pointner <equinox@spreadspace.org>2015-06-22 02:30:18 +0200
commit74aa7851308734d51d546ed683fc600d5271c16a (patch)
tree524b3066531762bc20093a50f67ad04727090916
parentimproved dual usbio - fully working now (diff)
improved handling for stdio portLUFA-120219
-rw-r--r--lib/dualusbio.c5
-rw-r--r--lib/dualusbio.h1
-rw-r--r--usb-led2/usb-led2.c21
3 files changed, 19 insertions, 8 deletions
diff --git a/lib/dualusbio.c b/lib/dualusbio.c
index 27d72ea..2a9bd3b 100644
--- a/lib/dualusbio.c
+++ b/lib/dualusbio.c
@@ -133,6 +133,11 @@ int16_t dualusbio_bytes_received(uint8_t port)
return 0;
}
+int16_t dualusbio_bytes_received_std(void)
+{
+ return dualusbio_bytes_received(stdio_port);
+}
+
void EVENT_CDC_Device_ControLineStateChanged(USB_ClassInfo_CDC_Device_t* const CDCInterfaceInfo)
{
uint8_t p;
diff --git a/lib/dualusbio.h b/lib/dualusbio.h
index a5a68a0..99c139e 100644
--- a/lib/dualusbio.h
+++ b/lib/dualusbio.h
@@ -32,5 +32,6 @@ void dualusbio_init(void);
void dualusbio_task(void);
void dualusbio_make_stdio(uint8_t port);
int16_t dualusbio_bytes_received(uint8_t port);
+int16_t dualusbio_bytes_received_std(void);
#endif
diff --git a/usb-led2/usb-led2.c b/usb-led2/usb-led2.c
index 74d5bf2..8640207 100644
--- a/usb-led2/usb-led2.c
+++ b/usb-led2/usb-led2.c
@@ -31,26 +31,30 @@
#include "led.h"
#include "dualusbio.h"
+uint8_t stdio_port = 0;
+
void handle_cmd(uint8_t cmd)
{
switch(cmd) {
case '0': led_off(); break;
case '1': led_on(); break;
case 't': led_toggle(); break;
+ case 's': printf("std: already stdio\r\n"); return;
default: printf("std: error\r\n"); return;
}
printf("std: ok\r\n");
}
-void handle_cmd2(uint8_t cmd)
+void handle_cmd2(uint8_t p, uint8_t cmd)
{
switch(cmd) {
case '0': led_on(); break;
case '1': led_off(); break;
case 't': led_toggle(); break;
- default: fprintf(usbio[1], "2: error\r\n"); return;
+ case 's': stdio_port = p; dualusbio_make_stdio(stdio_port); break;
+ default: fprintf(usbio[p], "%d: error\r\n", p); return;
}
- fprintf(usbio[1], "2: ok\r\n");
+ fprintf(usbio[p], "%d: ok\r\n", p);
}
int main(void)
@@ -63,10 +67,10 @@ int main(void)
dualusbio_init();
sei();
- dualusbio_make_stdio(0);
+ dualusbio_make_stdio(stdio_port);
for(;;) {
- int16_t BytesReceived = dualusbio_bytes_received(0);
+ int16_t BytesReceived = dualusbio_bytes_received_std();
while(BytesReceived > 0) {
int ReceivedByte = fgetc(stdin);
if(ReceivedByte != EOF) {
@@ -75,11 +79,12 @@ int main(void)
BytesReceived--;
}
- BytesReceived = dualusbio_bytes_received(1);
+ uint8_t p = (stdio_port) ? 0 : 1;
+ BytesReceived = dualusbio_bytes_received(p);
while(BytesReceived > 0) {
- int ReceivedByte = fgetc(usbio[1]);
+ int ReceivedByte = fgetc(usbio[p]);
if(ReceivedByte != EOF) {
- handle_cmd2(ReceivedByte);
+ handle_cmd2(p, ReceivedByte);
}
BytesReceived--;
}