mirror of
https://github.com/felis/USB_Host_Shield_2.0.git
synced 2024-03-22 11:31:26 +01:00
PL2303 Xbee terminal added
This commit is contained in:
parent
915542ff59
commit
568f00b65b
2 changed files with 125 additions and 3 deletions
|
@ -84,9 +84,11 @@ void loop()
|
|||
delay(50);
|
||||
|
||||
/* reading the phone */
|
||||
/* buffer size must be equal to max.packet size */
|
||||
uint8_t buf[32];
|
||||
uint16_t rcvd = 32;
|
||||
/* buffer size must be greater or equal to max.packet size */
|
||||
/* it it set to 64 (largest possible max.packet size) here, can be tuned down
|
||||
for particular endpoint */
|
||||
uint8_t buf[64];
|
||||
uint16_t rcvd = 64;
|
||||
rcode = Acm.RcvData(&rcvd, buf);
|
||||
if (rcode && rcode != hrNAK)
|
||||
ErrorMessage<uint8_t>(PSTR("Ret"), rcode);
|
||||
|
|
120
examples/pl2303/pl2303_xbee_terminal/pl2303_xbee_terminal.pde
Normal file
120
examples/pl2303/pl2303_xbee_terminal/pl2303_xbee_terminal.pde
Normal file
|
@ -0,0 +1,120 @@
|
|||
/* Arduino terminal for PL2303 USB to serial converter and XBee radio. */
|
||||
/* Inserts linefeed after carriage return in data sent to and received from Xbee */
|
||||
/* USB support */
|
||||
#include <avrpins.h>
|
||||
#include <max3421e.h>
|
||||
#include <usbhost.h>
|
||||
#include <usb_ch9.h>
|
||||
#include <Usb.h>
|
||||
#include <usbhub.h>
|
||||
#include <avr/pgmspace.h>
|
||||
#include <address.h>
|
||||
/* CDC support */
|
||||
#include <cdcacm.h>
|
||||
#include <cdcprolific.h>
|
||||
/* Debug support */
|
||||
#include <printhex.h>
|
||||
#include <message.h>
|
||||
#include <hexdump.h>
|
||||
#include <parsetools.h>
|
||||
|
||||
class PLAsyncOper : public CDCAsyncOper
|
||||
{
|
||||
public:
|
||||
virtual uint8_t OnInit(ACM *pacm);
|
||||
};
|
||||
|
||||
uint8_t PLAsyncOper::OnInit(ACM *pacm)
|
||||
{
|
||||
uint8_t rcode;
|
||||
|
||||
// Set DTR = 1
|
||||
rcode = pacm->SetControlLineState(1);
|
||||
|
||||
if (rcode)
|
||||
{
|
||||
ErrorMessage<uint8_t>(PSTR("SetControlLineState"), rcode);
|
||||
return rcode;
|
||||
}
|
||||
|
||||
LINE_CODING lc;
|
||||
lc.dwDTERate = 115200;
|
||||
lc.bCharFormat = 0;
|
||||
lc.bParityType = 0;
|
||||
lc.bDataBits = 8;
|
||||
|
||||
rcode = pacm->SetLineCoding(&lc);
|
||||
|
||||
if (rcode)
|
||||
ErrorMessage<uint8_t>(PSTR("SetLineCoding"), rcode);
|
||||
|
||||
return rcode;
|
||||
}
|
||||
USB Usb;
|
||||
//USBHub Hub(&Usb);
|
||||
PLAsyncOper AsyncOper;
|
||||
PL Pl(&Usb, &AsyncOper);
|
||||
|
||||
void setup()
|
||||
{
|
||||
Serial.begin( 115200 );
|
||||
Serial.println("Start");
|
||||
|
||||
if (Usb.Init() == -1)
|
||||
Serial.println("OSCOKIRQ failed to assert");
|
||||
|
||||
delay( 200 );
|
||||
}
|
||||
|
||||
void loop()
|
||||
{
|
||||
Usb.Task();
|
||||
|
||||
if( Usb.getUsbTaskState() == USB_STATE_RUNNING )
|
||||
{
|
||||
uint8_t rcode;
|
||||
|
||||
/* reading the keyboard */
|
||||
if(Serial.available()) {
|
||||
uint8_t data= Serial.read();
|
||||
|
||||
if ( data == '\r' ) {
|
||||
Serial.print("\r\n"); //insert linefeed
|
||||
}
|
||||
else {
|
||||
Serial.print( data ); //echo back to the screen
|
||||
}
|
||||
|
||||
/* sending to the phone */
|
||||
rcode = Pl.SndData(1, &data);
|
||||
if (rcode)
|
||||
ErrorMessage<uint8_t>(PSTR("SndData"), rcode);
|
||||
}//if(Serial.available()...
|
||||
|
||||
delay(50);
|
||||
|
||||
/* reading the converter */
|
||||
/* buffer size must be greater or equal to max.packet size */
|
||||
/* it it set to 64 (largest possible max.packet size) here, can be tuned down
|
||||
for particular endpoint */
|
||||
uint8_t buf[64];
|
||||
uint16_t rcvd = 64;
|
||||
rcode = Pl.RcvData(&rcvd, buf);
|
||||
if (rcode && rcode != hrNAK)
|
||||
ErrorMessage<uint8_t>(PSTR("Ret"), rcode);
|
||||
|
||||
if( rcvd ) { //more than zero bytes received
|
||||
for(uint16_t i=0; i < rcvd; i++ ) {
|
||||
if( buf[i] =='\r' ) {
|
||||
Serial.print("\r\n"); //insert linefeed
|
||||
}
|
||||
else {
|
||||
Serial.print(buf[i]); //printing on the screen
|
||||
}
|
||||
}
|
||||
}
|
||||
delay(10);
|
||||
}//if( Usb.getUsbTaskState() == USB_STATE_RUNNING..
|
||||
}
|
||||
|
||||
|
Loading…
Reference in a new issue