news 2025/12/23 11:20:12

openvela——动态管理日志输出通道及其实现原理

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
openvela——动态管理日志输出通道及其实现原理

在《Vela rpmsg log 实现原理》中提到 vela 日志输出支持多通道日志输出,它们是在系统运行前期配置好的,所以无法将它们动态删除。但是可以控制使能、禁用某通道,达到相应通道输出、不输出日志的目的。接下来篇章将讲述”动态管理日志输出通道方法“和”动态管理日志输出通道原理“。

动态管理日志输出通道方法

  • 列出当前已配置的所有输出通道及它们各自的状态
    在 nuttx shell 中执行setlogmask list命令,输出 ”通道“:”状态“ 格式的信息。如下结果显示:“default 通道”(物理串口)已打开、”ramlog 通道“ 已打开。

ap> setlogmask list Channels: default: enable ramlog: enable
  • 禁用(启用)日志输出通道

ap> setlogmask disable default ap> setlogmask enable default

动态管理日志输出通道原理

从代码角度来看禁止某(些)通道输出日志的方式是在写日志时候跳过禁用通道,如下代码片段:

ssize_t syslog_write_foreach(FAR const char *buffer, size_t buflen, bool force) { //... for (i = 0; i < CONFIG_SYSLOG_MAX_CHANNELS; i++) { FAR syslog_channel_t *channel = g_syslog_channel[i]; if (channel == NULL) break; #ifdef CONFIG_SYSLOG_IOCTL /// 根据“禁用”状态,忽略写相应通道 if (channel->sc_state & SYSLOG_CHANNEL_DISABLE) continue; #endif /// ... /// 调用通道的写函数 } }

命令 setlogmask enable(disable) out_channel_name 的本质是:修改对应通道变量的 sc_state。为了实现此目的:

  1. Vela 注册了一个虚拟设备,生成一个设备节点——"/dev/log";

  2. setlogmask 命令会打开此设备并通过ioctl调用传递命令参数;

  3. sys log 驱动的 syslog_chardev_ioctl 接收到命令参数后,进行名字匹配找到对应通道变量并更新sc_state。

int main(int argc, FAR char *argv[]) { if (argc < 2) { show_usage(argv[0], EXIT_FAILURE); } #ifdef CONFIG_SYSLOG_IOCTL if (strcmp(argv[1], "list") == 0) { print_channels(); return EXIT_SUCCESS; } else if (argc == 3) { if (strcmp(argv[1], "enable") == 0) { return disable_channel(argv[2], false); } else if (strcmp(argv[1], "disable") == 0) { return disable_channel(argv[2], true); } else { show_usage(argv[0], EXIT_FAILURE); } } #endif
static int disable_channel(FAR const char *name, bool disable) { fd = open("/dev/log", O_WRONLY); info.sc_disable = disable; strlcpy(info.sc_name, name, sizeof(info.sc_name)); ret = ioctl(fd, SYSLOGIOC_SETFILTER, (unsigned long)&info); close(fd); return ret; }
#ifdef CONFIG_SYSLOG_IOCTL static int syslog_chardev_ioctl(FAR struct file *filep, int cmd, unsigned long arg) { if (cmd == SYSLOGIOC_GETCHANNELS) { // ... } else if (cmd == SYSLOGIOC_SETFILTER) { info = (FAR struct syslog_channel_info_s *)arg; for (i = 0; i < CONFIG_SYSLOG_MAX_CHANNELS; i++) { if (strncmp(g_syslog_channel[i]->sc_name, info->sc_name, sizeof(info->sc_name)) == 0) { channel = g_syslog_channel[i]; break; } } // ... // 修改日志输出状态 channel->sc_state = info->sc_disable ? channel->sc_state | SYSLOG_CHANNEL_DISABLE : channel->sc_state & ~SYSLOG_CHANNEL_DISABLE; } return OK; } #endif
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2025/12/17 13:10:52

17、深入理解 Linux 文件系统机制与结构

深入理解 Linux 文件系统机制与结构 1. 理解长格式文件列表 在 Linux 中,使用 ls -la 命令可以查看详细的文件列表信息,示例输出如下: drwx------ 2 dee dee 4096 Jul 29 07:48 . drwxr-xr-x 5 root root 4096 Jul 27 11:57 .. -rw-r--r-- 1 dee dee 24 Jul 27 …

作者头像 李华
网站建设 2025/12/22 9:05:09

29、Linux 软件使用与故障排除指南

Linux 软件使用与故障排除指南 1. VMWare 和 Wine 软件介绍 VMWare : 缺点 :运行 VMWare 需要系统有额外的性能支持,使用前需查看其系统要求,并尽量让系统配置高于该要求。 优点 :它在独立窗口中运行,几乎等同于拥有另一台计算机。 Wine : 简介 :Wine(www.wi…

作者头像 李华
网站建设 2025/12/23 6:15:58

从入门到转行:网络安全自学与跳槽的终极建议

目录 为什么写这篇文章 为什么我更合适回答这个问题 先问自己3个问题 1.一定要明确自己是否是真喜欢&#xff0c;还是一时好奇。 2.自学的习惯 3.选择网安、攻防这行的目标是什么&#xff1f; 确认无误后&#xff0c;那如何进入这个行业&#xff1f; 1.选择渗透测试集中…

作者头像 李华
网站建设 2025/12/21 4:17:40

从系统运维到网络安全工程师,8个月转行真实经验分享!

从系统运维到安全工程师&#xff1a;我用 8 个月转行网络安全的真实经历 2023 年春天&#xff0c;我坐在公司的运维工位上&#xff0c;盯着屏幕上循环滚动的服务器日志&#xff0c;第 10 次手动重启了出问题的 OA 系统。那时我 32 岁&#xff0c;做系统运维已经 5 年&#xff0…

作者头像 李华
网站建设 2025/12/23 0:38:22

算法系列(Algorithm)- 快速排序

1. 基本思想与核心原理快速排序的核心思想是通过一趟排序将要排序的数据分割成独立的两部分&#xff0c;其中一部分的所有数据都比另一部分的所有数据都要小&#xff0c;然后再按此方法对这两部分数据分别进行快速排序&#xff0c;整个排序过程可以递归进行&#xff0c;以此达到…

作者头像 李华