/* ---------------------------------------------------------------------------- * Copyright (c) Huawei Technologies Co., Ltd. 2013-2020. All rights reserved. * Description: System Console HeadFile * Author: Huawei LiteOS Team * Create: 2013-01-01 * Redistribution and use in source and binary forms, with or without modification, * are permitted provided that the following conditions are met: * 1. Redistributions of source code must retain the above copyright notice, this list of * conditions and the following disclaimer. * 2. Redistributions in binary form must reproduce the above copyright notice, this list * of conditions and the following disclaimer in the documentation and/or other materials * provided with the distribution. * 3. Neither the name of the copyright holder nor the names of its contributors may be used * to endorse or promote products derived from this software without specific prior written * permission. * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. * --------------------------------------------------------------------------- */ //在LiteOS操作系统中,console头文件通常用于定义与控制台交互相关的函数和数据结构。 #ifndef _CONSOLE_H #define _CONSOLE_H //代码中,首先使用了条件编译防护,以确保头文件内容只被包含一次。接着定义了控制台输入输出缓冲区的大小,并声明了控制台初始化、打印和读取等函数。 #include "los_config.h"//引用了系统配置文件,用于获取操作系统的一些设置和属性。 #ifdef LOSCFG_FS_VFS//使用条件编译指令判断是否定义了宏LOSCFG_FS_VFS,如果已经定义,则编译下面的代码块,否则跳过。 #include "termios.h"//包含了 POSIX 终端控制定义的头文件,用于对终端进行控制。 #ifdef LOSCFG_NET_TELNET//使用条件编译指令判断是否定义了宏,如果已经定义,则编译下面的代码块,否则跳过。 #include "telnet_dev.h"//包含了 Telnet 设备驱动的头文件,用于实现 Telnet 连接。 #endif//结束条件编译指令。 #include "virtual_serial.h"//包含了虚拟串口的头文件,用于实现虚拟串口的功能。 #include "los_ringbuf.h"//包含了环形缓冲区的头文件,用于实现缓冲区的读写操作。 #endif #ifdef __cplusplus #if __cplusplus extern "C" { #endif /* __cplusplus */ #endif /* __cplusplus */ #ifdef LOSCFG_KERNEL_CONSOLE /* Define two fixed console id for Console ID. */ #define CONSOLE_SERIAL 1 #define CONSOLE_TELNET 2 #define STDIN 0 #define STDOUT 1 #define STDERR 2 #define CONSOLE "/dev/console" #define CONSOLE_NAMELEN 16 //这段代码定义了一些宏和常量,它们的含义如下: #define CONSOLE_CMD_RD_BLOCK_SERIAL 0x104//表示从串口读取数据的阻塞命令,其值为0x104。 #define CONSOLE_CMD_RD_BLOCK_TELNET 101//表示从Telnet连接读取数据的阻塞命令,其值为101。 #define CONSOLE_RD_BLOCK 1//表示阻塞模式,其值为1。 #define CONSOLE_RD_NONBLOCK 0//表示非阻塞模式,其值为0。 #define CONSOLE_SHELL_KEY_EVENT 0x112//表示shell键盘事件,其值为0x112。 #define CONSOLE_SHELL_EXITED 0x400//表示shell已退出,其值为0x400。 #define CONSOLE_CONTROL_RIGHTS_CAPTURE 201//表示控制权被捕获,其值为201。 #define CONSOLE_CONTROL_RIGHTS_RELEASE 202//表示控制权被释放,其值为202。 #define CONSOLE_CONTROL_CAPTURE_LINE 203//表示捕获行命令,其值为203。 #define CONSOLE_CONTROL_CAPTURE_CHAR 204//表示捕获字符命令,其值为204。 #define CONSOLE_FIFO_SIZE 1024//表示控制台FIFO(First In First Out)缓冲区大小,其值为1024。 #define CONSOLE_NUM 2//表示控制台数量,其值为2。 typedef struct { Ringbuf ringbuf; /* Ring buffer *///表示环形缓冲区,它可能是一个用于缓存数据的循环队列或者环形链表。 EVENT_CB_S sendEvent; /* Inform telnet send task *///表示向telnet发送任务发送事件的回调函数。 } RingbufSendCB; typedef struct { UINT32 consoleID;//表示控制台的ID。 UINT32 consoleType;//表示控制台的类型。 UINT32 consoleSem;//表示用于同步的控制台信号量。 UINT32 shellEntryId;//表示shell的入口ID。 UINT32 consoleMask;//表示控制台的掩码。 struct inode *devInode;//表示设备节点。 CHAR *name;//表示控制台的名称。 INT32 fd;//表示文件描述符。 UINT32 refCount;//表示引用计数。 BOOL isNonBlock;//表示是否为非阻塞模式。 #ifdef LOSCFG_SHELL VOID *shellHandle;//表示shell的句柄。 #endif UINT32 sendTaskID;//表示发送任务的ID。 RingbufSendCB *ringbufSendCB;//表示环形缓冲区发送回调。 UINT8 fifo[CONSOLE_FIFO_SIZE];//表示控制台的FIFO缓冲区。 UINT32 fifoOut;//表示FIFO缓冲区的输出位置。 UINT32 fifoIn;//表示FIFO缓冲区的输入位置。 UINT32 currentLen;//表示当前长度。 struct termios consoleTermios;//表示控制台的终端属性。 } CONSOLE_CB; extern INT32 system_console_init(const CHAR *deviceName);//控制台初始化函数用于初始化控制台相关的资源和状态 extern INT32 system_console_deinit(const CHAR *deviceName);//控制台反初始化函数,用于释放控制台相关的资源和状态。 extern BOOL SetSerialNonBlock(const CONSOLE_CB *consoleCB);//设置串口为非阻塞模式。 extern BOOL SetSerialBlock(const CONSOLE_CB *consoleCB);//设置串口为阻塞模式。 extern BOOL SetTelnetNonBlock(const CONSOLE_CB *consoleCB);//设置Telnet连接为非阻塞模式。 extern BOOL SetTelnetBlock(const CONSOLE_CB *consoleCB);//设置Telnet连接为阻塞模式。 extern CONSOLE_CB *OsGetConsoleByID(INT32 consoleId);//根据控制台ID获取控制台的控制块(Control Block)。 extern CONSOLE_CB *OsGetConsoleByTaskID(UINT32 taskId);//根据任务ID获取关联的控制台的控制块。 extern UINT32 ConsoleTaskReg(INT32 consoleId, UINT32 taskId);//将任务与指定的控制台进行关联。 extern INT32 ConsoleUpdateFd(VOID);//更新控制台的文件描述符(File Descriptor)。 extern BOOL ConsoleEnable(VOID);//使能控制台功能。 extern BOOL is_nonblock(const CONSOLE_CB *consoleCB);//判断控制台是否为非阻塞模式。 extern BOOL IsConsoleOccupied(const CONSOLE_CB *consoleCB);//判断控制台是否已经被占用。 extern INT32 FilepOpen(struct file *filep, const struct file_operations_vfs *fops);//打开文件。 extern INT32 FilepClose(struct file *filep, const struct file_operations_vfs *fops);//关闭文件。 extern INT32 FilepRead(struct file *filep, const struct file_operations_vfs *fops, CHAR *buffer, size_t bufLen);//从文件中读取数据。 extern INT32 FilepWrite(struct file *filep, const struct file_operations_vfs *fops, const CHAR *buffer, size_t bufLen);//向文件中写入数据。 extern INT32 FilepPoll(struct file *filep, const struct file_operations_vfs *fops, poll_table *fds);//对文件进行轮询操作。 extern INT32 FilepIoctl(struct file *filep, const struct file_operations_vfs *fops, INT32 cmd, unsigned long arg);//对文件进行IO控制操作。 extern INT32 GetFilepOps(const struct file *filep, struct file **privFilep, const struct file_operations_vfs **fops);//获取文件的操作函数。 #else STATIC INLINE INT32 ConsoleUpdateFd(VOID)//这是一个函数声明,声明了一个名为ConsoleUpdateFd的静态内联函数,返回类型为INT32(32位整数),参数为空。根据函数体的实现为return -1;,该函数的作用是更新控制台的文件描述符(File Descriptor),并返回-1。 { return -1; } #endif//这个宏表示结束了之前的条件编译指令#if。 #ifdef __cplusplus//这一组条件编译指令用于判断是否为C++编译环境。如果是C++编译环境,则将后面的代码块用extern "C"包裹起来,以保证C和C++之间的函数调用规则一致。 #if __cplusplus } #endif /* __cplusplus */ #endif /* __cplusplus */ #endif /* _CONSOLE_H */