1 /* 2 * Copyright (c) 2019 Nordic Semiconductor ASA 3 * 4 * SPDX-License-Identifier: Apache-2.0 5 */ 6 7 #ifndef ZEPHYR_INCLUDE_SHELL_TELNET_H_ 8 #define ZEPHYR_INCLUDE_SHELL_TELNET_H_ 9 10 #include <zephyr/net/socket.h> 11 #include <zephyr/shell/shell.h> 12 13 #ifdef __cplusplus 14 extern "C" { 15 #endif 16 17 extern const struct shell_transport_api shell_telnet_transport_api; 18 19 #define SHELL_TELNET_POLLFD_COUNT 3 20 #define SHELL_TELNET_MAX_CMD_SIZE 3 21 22 /** Line buffer structure. */ 23 struct shell_telnet_line_buf { 24 /** Line buffer. */ 25 char buf[CONFIG_SHELL_TELNET_LINE_BUF_SIZE]; 26 27 /** Current line length. */ 28 uint16_t len; 29 }; 30 31 /** TELNET-based shell transport. */ 32 struct shell_telnet { 33 /** Handler function registered by shell. */ 34 shell_transport_handler_t shell_handler; 35 36 /** Context registered by shell. */ 37 void *shell_context; 38 39 /** Buffer for outgoing line. */ 40 struct shell_telnet_line_buf line_out; 41 42 /** Array for sockets used by the telnet service. */ 43 struct zsock_pollfd fds[SHELL_TELNET_POLLFD_COUNT]; 44 45 /** Input buffer. */ 46 uint8_t rx_buf[CONFIG_SHELL_CMD_BUFF_SIZE]; 47 48 /** Number of data bytes within the input buffer. */ 49 size_t rx_len; 50 51 /** Mutex protecting the input buffer access. */ 52 struct k_mutex rx_lock; 53 uint8_t cmd_buf[SHELL_TELNET_MAX_CMD_SIZE]; 54 uint8_t cmd_len; 55 56 /** The delayed work is used to send non-lf terminated output that has 57 * been around for "too long". This will prove to be useful 58 * to send the shell prompt for instance. 59 */ 60 struct k_work_delayable send_work; 61 struct k_work_sync work_sync; 62 63 /** If set, no output is sent to the TELNET client. */ 64 bool output_lock; 65 }; 66 67 #define SHELL_TELNET_DEFINE(_name) \ 68 static struct shell_telnet _name##_shell_telnet; \ 69 struct shell_transport _name = { \ 70 .api = &shell_telnet_transport_api, \ 71 .ctx = (struct shell_telnet *)&_name##_shell_telnet \ 72 } 73 74 /** 75 * @brief This function provides pointer to shell telnet backend instance. 76 * 77 * Function returns pointer to the shell telnet instance. This instance can be 78 * next used with shell_execute_cmd function in order to test commands behavior. 79 * 80 * @returns Pointer to the shell instance. 81 */ 82 const struct shell *shell_backend_telnet_get_ptr(void); 83 84 #ifdef __cplusplus 85 } 86 #endif 87 88 #endif /* ZEPHYR_INCLUDE_SHELL_TELNET_H_ */ 89