blob: 40e7c36eb6ff831a3c894ad5294b7b600cf99d12 [file] [log] [blame]
/* Teensyduino Core Library
* http://www.pjrc.com/teensy/
* Copyright (c) 2017 PJRC.COM, LLC.
*
* Permission is hereby granted, free of charge, to any person obtaining
* a copy of this software and associated documentation files (the
* "Software"), to deal in the Software without restriction, including
* without limitation the rights to use, copy, modify, merge, publish,
* distribute, sublicense, and/or sell copies of the Software, and to
* permit persons to whom the Software is furnished to do so, subject to
* the following conditions:
*
* 1. The above copyright notice and this permission notice shall be
* included in all copies or substantial portions of the Software.
*
* 2. If the Software is incorporated into a build system that allows
* selection among a list of target devices, then similar target
* devices manufactured by PJRC.COM must be included in the list of
* target devices and selectable in the same manner.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
* NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS
* BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
* ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
* CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
* SOFTWARE.
*/
#ifndef USBserial_h_
#define USBserial_h_
#include "motors/usb/usb_desc.h"
#include <inttypes.h>
// C language implementation
#ifdef __cplusplus
extern "C" {
#endif
void usb_serial_init(void);
// Reads the next character (if any) and returns it. Returns -1 if no characters
// are available.
int usb_serial_getchar(int port);
// Returns the next character (if any) or -1.
int usb_serial_peekchar(int port);
// Reads as many bytes (up to size) as are available now. Returns 0 immediately
// if no bytes are available. Returns the number of bytes read.
int usb_serial_read(int port, void *buffer, uint32_t size);
// Drops any unread input until the most recent packet sent.
void usb_serial_flush_input(int port);
// Writes data. Returns -1 if it times out or 0 if it succeeds.
//
// NOTE: This does not send immediately. The data is buffered
int usb_serial_write(int port, const void *buffer, uint32_t size);
// Writes a single character. Returns -1 if it times out or 1 if it succeeds.
static inline int usb_serial_putchar(int port, uint8_t c) {
return usb_serial_write(port, &c, 1);
}
// Immediately flushes all written data.
//
// TODO(Brian): What exactly are the semantics here?
void usb_serial_flush_output(int port);
#ifdef __cplusplus
}
#endif
#endif // USBserial_h_