162306a36Sopenharmony_ci/* SPDX-License-Identifier: GPL-2.0+ */ 262306a36Sopenharmony_ci/* 362306a36Sopenharmony_ci * u_serial.h - interface to USB gadget "serial port"/TTY utilities 462306a36Sopenharmony_ci * 562306a36Sopenharmony_ci * Copyright (C) 2008 David Brownell 662306a36Sopenharmony_ci * Copyright (C) 2008 by Nokia Corporation 762306a36Sopenharmony_ci */ 862306a36Sopenharmony_ci 962306a36Sopenharmony_ci#ifndef __U_SERIAL_H 1062306a36Sopenharmony_ci#define __U_SERIAL_H 1162306a36Sopenharmony_ci 1262306a36Sopenharmony_ci#include <linux/usb/composite.h> 1362306a36Sopenharmony_ci#include <linux/usb/cdc.h> 1462306a36Sopenharmony_ci 1562306a36Sopenharmony_ci#define MAX_U_SERIAL_PORTS 8 1662306a36Sopenharmony_ci 1762306a36Sopenharmony_cistruct f_serial_opts { 1862306a36Sopenharmony_ci struct usb_function_instance func_inst; 1962306a36Sopenharmony_ci u8 port_num; 2062306a36Sopenharmony_ci}; 2162306a36Sopenharmony_ci 2262306a36Sopenharmony_ci/* 2362306a36Sopenharmony_ci * One non-multiplexed "serial" I/O port ... there can be several of these 2462306a36Sopenharmony_ci * on any given USB peripheral device, if it provides enough endpoints. 2562306a36Sopenharmony_ci * 2662306a36Sopenharmony_ci * The "u_serial" utility component exists to do one thing: manage TTY 2762306a36Sopenharmony_ci * style I/O using the USB peripheral endpoints listed here, including 2862306a36Sopenharmony_ci * hookups to sysfs and /dev for each logical "tty" device. 2962306a36Sopenharmony_ci * 3062306a36Sopenharmony_ci * REVISIT at least ACM could support tiocmget() if needed. 3162306a36Sopenharmony_ci * 3262306a36Sopenharmony_ci * REVISIT someday, allow multiplexing several TTYs over these endpoints. 3362306a36Sopenharmony_ci */ 3462306a36Sopenharmony_cistruct gserial { 3562306a36Sopenharmony_ci struct usb_function func; 3662306a36Sopenharmony_ci 3762306a36Sopenharmony_ci /* port is managed by gserial_{connect,disconnect} */ 3862306a36Sopenharmony_ci struct gs_port *ioport; 3962306a36Sopenharmony_ci 4062306a36Sopenharmony_ci struct usb_ep *in; 4162306a36Sopenharmony_ci struct usb_ep *out; 4262306a36Sopenharmony_ci 4362306a36Sopenharmony_ci /* REVISIT avoid this CDC-ACM support harder ... */ 4462306a36Sopenharmony_ci struct usb_cdc_line_coding port_line_coding; /* 9600-8-N-1 etc */ 4562306a36Sopenharmony_ci 4662306a36Sopenharmony_ci /* notification callbacks */ 4762306a36Sopenharmony_ci void (*connect)(struct gserial *p); 4862306a36Sopenharmony_ci void (*disconnect)(struct gserial *p); 4962306a36Sopenharmony_ci int (*send_break)(struct gserial *p, int duration); 5062306a36Sopenharmony_ci}; 5162306a36Sopenharmony_ci 5262306a36Sopenharmony_ci/* utilities to allocate/free request and buffer */ 5362306a36Sopenharmony_cistruct usb_request *gs_alloc_req(struct usb_ep *ep, unsigned len, gfp_t flags); 5462306a36Sopenharmony_civoid gs_free_req(struct usb_ep *, struct usb_request *req); 5562306a36Sopenharmony_ci 5662306a36Sopenharmony_ci/* management of individual TTY ports */ 5762306a36Sopenharmony_ciint gserial_alloc_line_no_console(unsigned char *port_line); 5862306a36Sopenharmony_ciint gserial_alloc_line(unsigned char *port_line); 5962306a36Sopenharmony_civoid gserial_free_line(unsigned char port_line); 6062306a36Sopenharmony_ci 6162306a36Sopenharmony_ci#ifdef CONFIG_U_SERIAL_CONSOLE 6262306a36Sopenharmony_ci 6362306a36Sopenharmony_cissize_t gserial_set_console(unsigned char port_num, const char *page, size_t count); 6462306a36Sopenharmony_cissize_t gserial_get_console(unsigned char port_num, char *page); 6562306a36Sopenharmony_ci 6662306a36Sopenharmony_ci#endif /* CONFIG_U_SERIAL_CONSOLE */ 6762306a36Sopenharmony_ci 6862306a36Sopenharmony_ci/* connect/disconnect is handled by individual functions */ 6962306a36Sopenharmony_ciint gserial_connect(struct gserial *, u8 port_num); 7062306a36Sopenharmony_civoid gserial_disconnect(struct gserial *); 7162306a36Sopenharmony_civoid gserial_suspend(struct gserial *p); 7262306a36Sopenharmony_civoid gserial_resume(struct gserial *p); 7362306a36Sopenharmony_ci 7462306a36Sopenharmony_ci#endif /* __U_SERIAL_H */ 75