projects
/
oweals
/
u-boot.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
serial: sandbox: optimize puts
[oweals/u-boot.git]
/
drivers
/
serial
/
usbtty.c
diff --git
a/drivers/serial/usbtty.c
b/drivers/serial/usbtty.c
index cc2bdac479efad185d9169eabf931ac2c5abde1f..cffd5a2b25259d5018274b7144dec6ed40c34acc 100644
(file)
--- a/
drivers/serial/usbtty.c
+++ b/
drivers/serial/usbtty.c
@@
-22,18
+22,14
@@
*/
#include <common.h>
*/
#include <common.h>
-
-#ifdef CONFIG_USB_TTY
-
+#include <config.h>
#include <circbuf.h>
#include <circbuf.h>
-#include <
devices
.h>
+#include <
stdio_dev
.h>
#include "usbtty.h"
#include "usb_cdc_acm.h"
#include "usbdescriptors.h"
#include "usbtty.h"
#include "usb_cdc_acm.h"
#include "usbdescriptors.h"
-#include <config.h> /* If defined, override Linux identifiers with
- * vendor specific ones */
-#if
0
+#if
def DEBUG
#define TTYDBG(fmt,args...)\
serial_printf("[%s] %s %d: "fmt, __FILE__,__FUNCTION__,__LINE__,##args)
#else
#define TTYDBG(fmt,args...)\
serial_printf("[%s] %s %d: "fmt, __FILE__,__FUNCTION__,__LINE__,##args)
#else
@@
-74,7
+70,7
@@
static circbuf_t usbtty_output;
/*
* Instance variables
*/
/*
* Instance variables
*/
-static
device_t
usbttydev;
+static
struct stdio_dev
usbttydev;
static struct usb_device_instance device_instance[1];
static struct usb_bus_instance bus_instance[1];
static struct usb_configuration_instance config_instance[NUM_CONFIGS];
static struct usb_device_instance device_instance[1];
static struct usb_bus_instance bus_instance[1];
static struct usb_configuration_instance config_instance[NUM_CONFIGS];
@@
-98,7
+94,7
@@
static char serial_number[16];
* Descriptors, Strings, Local variables.
*/
* Descriptors, Strings, Local variables.
*/
-/* defined and used by
usbdcore_
ep0.c */
+/* defined and used by
gadget/
ep0.c */
extern struct usb_string_descriptor **usb_strings;
/* Indicies, References */
extern struct usb_string_descriptor **usb_strings;
/* Indicies, References */
@@
-154,8
+150,7
@@
struct acm_config_desc {
/* Slave Interface */
struct usb_interface_descriptor data_class_interface;
/* Slave Interface */
struct usb_interface_descriptor data_class_interface;
- struct usb_endpoint_descriptor
- data_endpoints[NUM_ENDPOINTS-1] __attribute__((packed));
+ struct usb_endpoint_descriptor data_endpoints[NUM_ENDPOINTS-1];
} __attribute__((packed));
static struct acm_config_desc acm_configuration_descriptors[NUM_CONFIGS] = {
} __attribute__((packed));
static struct acm_config_desc acm_configuration_descriptors[NUM_CONFIGS] = {
@@
-220,7
+215,7
@@
static struct acm_config_desc acm_configuration_descriptors[NUM_CONFIGS] = {
.bLength =
sizeof(struct usb_endpoint_descriptor),
.bDescriptorType = USB_DT_ENDPOINT,
.bLength =
sizeof(struct usb_endpoint_descriptor),
.bDescriptorType = USB_DT_ENDPOINT,
- .bEndpointAddress =
0x01
| USB_DIR_IN,
+ .bEndpointAddress =
UDC_INT_ENDPOINT
| USB_DIR_IN,
.bmAttributes = USB_ENDPOINT_XFER_INT,
.wMaxPacketSize
= cpu_to_le16(CONFIG_USBD_SERIAL_INT_PKTSIZE),
.bmAttributes = USB_ENDPOINT_XFER_INT,
.wMaxPacketSize
= cpu_to_le16(CONFIG_USBD_SERIAL_INT_PKTSIZE),
@@
-246,7
+241,7
@@
static struct acm_config_desc acm_configuration_descriptors[NUM_CONFIGS] = {
.bLength =
sizeof(struct usb_endpoint_descriptor),
.bDescriptorType = USB_DT_ENDPOINT,
.bLength =
sizeof(struct usb_endpoint_descriptor),
.bDescriptorType = USB_DT_ENDPOINT,
- .bEndpointAddress =
0x02
| USB_DIR_OUT,
+ .bEndpointAddress =
UDC_OUT_ENDPOINT
| USB_DIR_OUT,
.bmAttributes =
USB_ENDPOINT_XFER_BULK,
.wMaxPacketSize =
.bmAttributes =
USB_ENDPOINT_XFER_BULK,
.wMaxPacketSize =
@@
-257,7
+252,7
@@
static struct acm_config_desc acm_configuration_descriptors[NUM_CONFIGS] = {
.bLength =
sizeof(struct usb_endpoint_descriptor),
.bDescriptorType = USB_DT_ENDPOINT,
.bLength =
sizeof(struct usb_endpoint_descriptor),
.bDescriptorType = USB_DT_ENDPOINT,
- .bEndpointAddress =
0x03
| USB_DIR_IN,
+ .bEndpointAddress =
UDC_IN_ENDPOINT
| USB_DIR_IN,
.bmAttributes =
USB_ENDPOINT_XFER_BULK,
.wMaxPacketSize =
.bmAttributes =
USB_ENDPOINT_XFER_BULK,
.wMaxPacketSize =
@@
-284,10
+279,8
@@
static struct rs232_emu rs232_desc={
struct gserial_config_desc {
struct usb_configuration_descriptor configuration_desc;
struct gserial_config_desc {
struct usb_configuration_descriptor configuration_desc;
- struct usb_interface_descriptor
- interface_desc[NUM_GSERIAL_INTERFACES] __attribute__((packed));
- struct usb_endpoint_descriptor
- data_endpoints[NUM_ENDPOINTS] __attribute__((packed));
+ struct usb_interface_descriptor interface_desc[NUM_GSERIAL_INTERFACES];
+ struct usb_endpoint_descriptor data_endpoints[NUM_ENDPOINTS];
} __attribute__((packed));
} __attribute__((packed));
@@
-328,7
+321,7
@@
gserial_configuration_descriptors[NUM_CONFIGS] ={
.bLength =
sizeof(struct usb_endpoint_descriptor),
.bDescriptorType = USB_DT_ENDPOINT,
.bLength =
sizeof(struct usb_endpoint_descriptor),
.bDescriptorType = USB_DT_ENDPOINT,
- .bEndpointAddress =
0x01
| USB_DIR_OUT,
+ .bEndpointAddress =
UDC_OUT_ENDPOINT
| USB_DIR_OUT,
.bmAttributes = USB_ENDPOINT_XFER_BULK,
.wMaxPacketSize =
cpu_to_le16(CONFIG_USBD_SERIAL_OUT_PKTSIZE),
.bmAttributes = USB_ENDPOINT_XFER_BULK,
.wMaxPacketSize =
cpu_to_le16(CONFIG_USBD_SERIAL_OUT_PKTSIZE),
@@
-338,7
+331,7
@@
gserial_configuration_descriptors[NUM_CONFIGS] ={
.bLength =
sizeof(struct usb_endpoint_descriptor),
.bDescriptorType = USB_DT_ENDPOINT,
.bLength =
sizeof(struct usb_endpoint_descriptor),
.bDescriptorType = USB_DT_ENDPOINT,
- .bEndpointAddress =
0x02
| USB_DIR_IN,
+ .bEndpointAddress =
UDC_IN_ENDPOINT
| USB_DIR_IN,
.bmAttributes = USB_ENDPOINT_XFER_BULK,
.wMaxPacketSize =
cpu_to_le16(CONFIG_USBD_SERIAL_IN_PKTSIZE),
.bmAttributes = USB_ENDPOINT_XFER_BULK,
.wMaxPacketSize =
cpu_to_le16(CONFIG_USBD_SERIAL_IN_PKTSIZE),
@@
-348,7
+341,7
@@
gserial_configuration_descriptors[NUM_CONFIGS] ={
.bLength =
sizeof(struct usb_endpoint_descriptor),
.bDescriptorType = USB_DT_ENDPOINT,
.bLength =
sizeof(struct usb_endpoint_descriptor),
.bDescriptorType = USB_DT_ENDPOINT,
- .bEndpointAddress =
0x03
| USB_DIR_IN,
+ .bEndpointAddress =
UDC_INT_ENDPOINT
| USB_DIR_IN,
.bmAttributes = USB_ENDPOINT_XFER_INT,
.wMaxPacketSize =
cpu_to_le16(CONFIG_USBD_SERIAL_INT_PKTSIZE),
.bmAttributes = USB_ENDPOINT_XFER_INT,
.wMaxPacketSize =
cpu_to_le16(CONFIG_USBD_SERIAL_INT_PKTSIZE),
@@
-437,6
+430,9
@@
int usbtty_getc (void)
*/
void usbtty_putc (const char c)
{
*/
void usbtty_putc (const char c)
{
+ if (!usbtty_configured ())
+ return;
+
buf_push (&usbtty_output, &c, 1);
/* If \n, also do \r */
if (c == '\n')
buf_push (&usbtty_output, &c, 1);
/* If \n, also do \r */
if (c == '\n')
@@
-490,8
+486,12
@@
static void __usbtty_puts (const char *str, int len)
void usbtty_puts (const char *str)
{
int n;
void usbtty_puts (const char *str)
{
int n;
- int len = strlen (str);
+ int len;
+
+ if (!usbtty_configured ())
+ return;
+ len = strlen (str);
/* add '\r' for each '\n' */
while (len > 0) {
n = next_nl_pos (str);
/* add '\r' for each '\n' */
while (len > 0) {
n = next_nl_pos (str);
@@
-529,8
+529,8
@@
int drv_usbtty_init (void)
}
snlen = strlen(sn);
if (snlen > sizeof(serial_number) - 1) {
}
snlen = strlen(sn);
if (snlen > sizeof(serial_number) - 1) {
- printf ("Warning: serial number %s is too long (%d > %
d
)\n",
- sn, snlen,
sizeof(serial_number) - 1
);
+ printf ("Warning: serial number %s is too long (%d > %
lu
)\n",
+ sn, snlen,
(ulong)(sizeof(serial_number) - 1)
);
snlen = sizeof(serial_number) - 1;
}
memcpy (serial_number, sn, snlen);
snlen = sizeof(serial_number) - 1;
}
memcpy (serial_number, sn, snlen);
@@
-570,7
+570,7
@@
int drv_usbtty_init (void)
usbttydev.putc = usbtty_putc; /* 'putc' function */
usbttydev.puts = usbtty_puts; /* 'puts' function */
usbttydev.putc = usbtty_putc; /* 'putc' function */
usbttydev.puts = usbtty_puts; /* 'puts' function */
- rc =
device
_register (&usbttydev);
+ rc =
stdio
_register (&usbttydev);
return (rc == 0) ? 1 : rc;
}
return (rc == 0) ? 1 : rc;
}
@@
-1007,6
+1007,3
@@
void usbtty_poll (void)
udc_irq();
}
udc_irq();
}
-
-
-#endif