Linux UWB Stack实现——MCPS调度接口(数据结构)
MCPS(MAC Common Part Sublayer,媒介访问控制(Medium Access Control)公共部分子层)调度接口,文件:include\net\mcps802154_schedule.h。
MCPS访问方法
// MCPS 802154 访问方法
enum mcps802154_access_method {MCPS802154_ACCESS_METHOD_NOTHING,MCPS802154_ACCESS_METHOD_IMMEDIATE_RX, //立即接收访问方法MCPS802154_ACCESS_METHOD_IMMEDIATE_TX, //立即发送访问方法MCPS802154_ACCESS_METHOD_MULTI, //多帧访问方法MCPS802154_ACCESS_METHOD_VENDOR, //供应商操作方法
};
mcps802154_access_vendor_ops
该结构体定义了一些函数指针,用于实现供应商特定的访问协议的回调函数,在访问方法为MCPS802154_ACCESS_METHOD_VENDOR时使用。
每个回调函数都可以返回0以继续访问,返回1以停止访问,或者返回错误。
- 如果访问被停止,则使用
mcps802154_access.timestamp_dtu和mcps802154_access.duration_dtu来计算下一次访问,除非duration为0,当在该情况下,将从驱动程序请求当前日期。 - 在发生错误的情况下,设备将转换到broken状态。
- 如果回调函数缺失,将视为错误,但
&mcps802154_access_vendor_ops.handle与.schedule_change缺失除外,被忽略。
struct mcps802154_access_vendor_ops {/** 匿名结构体,需要在所有访问操作之前声明,与mcps802154_access_ops之中情况相似,均为access_done函数指针*/struct {void (*access_done)(struct mcps802154_access *access);};int (*handle)(struct mcps802154_access *access);int (*rx_frame)(struct mcps802154_access *access);int (*rx_timeout)(struct mcps802154_access *access);int (*rx_error)(struct mcps802154_access *access,enum mcps802154_rx_error_type error);int (*tx_done)(struct mcps802154_access *access);int (*broken)(struct mcps802154_access *access);int (*schedule_change)(struct mcps802154_access *access);
};
- 匿名结构成员->access_done,该结构有一个匿名结构成员,在所有操作访问之前都需要声明。该成员定义了一个名为access_done的函数指针。无论访问操作是否成功,都会在访问操作完成后调用此函数。即,对于所有MCPS访问,都需要为访问操作设定一个访问完成回调函数。
其他函数指针: - handle,一旦访问开始即调用,为NULL时,忽略;
- rx_frame,当接收到帧时进行回调。为NULL时,报错。
- rx_timeout,当接收超时时回调,为NULL时,报错。
- rx_error,当接收错误时回调,为NULL时,报错。
- tx_done,当发送完成之后调用。
- broken,当发生不可修复的错误时调用,若为NULL,报错。
- schedule_change,当调度改变时调用,为NULL时,忽略。
mcps802154域
struct mcps802154_region {/*** @ops: 域回调函数*/const struct mcps802154_region_ops *ops;
};
struct mcps802154_region,用于表示一个开放域实例。域处理程序(region handlers)可以在它的后面添加私有数据(private data)。
当前的mcps802154域仅定义了一个指向域回调函数操作的指针。
通过域的定义,不同的域处理程序可以实现在同一统一接口下,实现不同区域处理程序,并且各自管理自己的数据。
struct mcps802154_region_ops {/*** @owner: 指向拥有此域的模块的指针,大多数情况下为THIS_MODULE。*/struct module *owner;/*** @name: 域名称*/const char *name;/*** @registered_entry: Entry in list of registered regions.*/struct list_head registered_entry;/*** @open: 打开域的一个实例,返回一个新的域实例。若发生错误返回NULL。*/struct mcps802154_region *(*open)(struct mcps802154_llhw *llhw);/*** @close: Close a region instance.*/void (*close)(struct mcps802154_region *region);/*** @set_parameters: Set region parameters, may be NULL.*/int (*set_parameters)(struct mcps802154_region *region,const struct nlattr *attrs,struct netlink_ext_ack *extack);/*** @call: Call region procedure, may be NULL.*/int (*call)(struct mcps802154_region *region, u32 call_id,const struct nlattr *attrs, const struct genl_info *info);/*** @get_access: Get access for a given region at the given timestamp.* Access is valid until &mcps802154_access_ops.access_done() callback* is called. Return NULL if access is not possible.*/struct mcps802154_access *(*get_access)(struct mcps802154_region *region, u32 next_timestamp_dtu,int next_in_region_dtu, int region_duration_dtu);
};
通过定义struct mcps802154_region_ops结构体类型,定义域对应的回调函数,该结构体类型包含以下成员:
- owner:指向拥有此域的模块的指针,通常为THIS_MODULE。
- name:域的名称,为const char类型指针。
- registered_entry:已注册域列表入口。
- open:打开该域的一个实例,返回一个新的域实例,如果出现错误,则返回NULL。
- close:关闭域实例。
- set_parameters:设置域参数,可能为NULL。
- call:调用域过程,可能为NULL。
- get_access:获取给定时间戳下给定域的访问权限。访问直到
mcps802154_access_ops.access_done()调用之前都是有效的。如果访问不可行,返回NULL。
调度相关定义
调度更新
当调度更新时,上下文环境有效。
struct mcps802154_schedule_update {/*** @expected_start_timestamp_dtu: 基于当前访问日期,以及新调度安排在已有调度计划之后,得到的期望开始时间戳。*/u32 expected_start_timestamp_dtu;/*** @start_timestamp_dtu: 调度开始日期,对于无限调度可能会太远*/u32 start_timestamp_dtu;/*** @duration_dtu: 调度持续时间,无限调度时为0。当调度为空时,也为0。*/int duration_dtu;/*** @n_regions: 调度中域的数量*/size_t n_regions;
};
调度器
一个开放的调度器实例。调度器可以在此结构之后附加私有数据。
struct mcps802154_scheduler {/*** @ops: 调度器回调函数指针*/const struct mcps802154_scheduler_ops *ops;
};
调度器操作(回调)
调度器回调函数。调度器向MCPS提供一个调度计划(schedule),并在特定帧接收或调度不再有效时更新该调度。
struct mcps802154_scheduler_ops {struct module *owner;const char *name;struct list_head registered_entry;/*** @open: 为设备附加一个调度器*/struct mcps802154_scheduler *(*open)(struct mcps802154_llhw *llhw);/*** @close: 实现与调度器分离并关闭调度器*/void (*close)(struct mcps802154_scheduler *scheduler);/*** @set_parameters: Configure the scheduler.*/int (*set_parameters)(struct mcps802154_scheduler *scheduler,const struct nlattr *attrs,struct netlink_ext_ack *extack);/*** @set_region_parameters: Configure the region inside the scheduler.*/int (*set_region_parameters)(struct mcps802154_scheduler *scheduler,u32 region_id, const char *region_name,const struct nlattr *attrs,struct netlink_ext_ack *extack);/*** @call: 调用调度器的特定处理流程的函数指针。*/int (*call)(struct mcps802154_scheduler *scheduler, u32 call_id,const struct nlattr *attrs, const struct genl_info *info);/*** @call_region: Call region specific procedure.*/int (*call_region)(struct mcps802154_scheduler *scheduler,u32 region_id, const char *region_name, u32 call_id,const struct nlattr *attrs,const struct genl_info *info);/*** @update_schedule: 该函数指针完成schedule初始化以及更新.*/int (*update_schedule)(struct mcps802154_scheduler *scheduler,const struct mcps802154_schedule_update *schedule_update,u32 next_timestamp_dtu);/*** @ranging_setup: 调用配置测距,为临时接口。*/int (*ranging_setup)(struct mcps802154_scheduler *scheduler,const struct mcps802154_nl_ranging_request *requests,unsigned int n_requests);
};
调度器回调函数结构体struct mcps802154_scheduler_ops,包括以下成员:
owner:指向拥有这个调度器的模块的指针。name:调度器的名称。registered_entry:注册的调度器列表入口。open:为设备附加一个调度器,通过open函数指针,底层设备返回指向调度器的指针。close:将调度器分离并关闭调度器。set_parameters:配置调度器的函数指针。set_region_parameters:配置调度器内部区域的函数指针。call:调用调度器的特定处理流程的函数指针。call_region:调用特定域的过程的函数指针。update_schedule: 该函数指针完成schedule初始化以及更新。ranging_setup: 调用配置测距,为临时接口。
此外,结构体成员中还包括一些参数,例如attrs和extack用于确定调度器的参数设置等。
补充知识
Linux内核模块——THIS_MODULE
THIS_MODULE 是一个宏,它用于在 Linux 内核模块中获取对当前模块的引用。定义在linux/module.h头文件中,用于获取当前正在执行的模块的指针。
#define THIS_MODULE (&__this_module)
__this_module是一个全局变量,其类型是struct module,表示当前模块的信息。
THIS_MODULE 可以用于获取模块的一些重要信息,例如模块的名称、模块的版本、模块的作者和许可证等。通过THIS_MODULE宏,可以获取执行代码的模块指针,进而可以获取或修改模块的各种功能属性。
在 Linux 内核模块编程中,THIS_MODULE 经常与其他内核函数和宏一起使用,例如 module_init() 和 module_exit() 函数。
相关文章:
Linux UWB Stack实现——MCPS调度接口(数据结构)
MCPS(MAC Common Part Sublayer,媒介访问控制(Medium Access Control)公共部分子层)调度接口,文件:include\net\mcps802154_schedule.h。 MCPS访问方法 // MCPS 802154 访问方法 enum mcps8021…...
2023Q3数据安全政策、法规、标准及报告汇总(附下载)
数据安全处罚事件逐年升高,2023年呈爆发式增长。 截至2023年8月31日,南都大数据研究院通过各地行政执法公示平台、媒体报道等公开渠道收集到146起依据《数据安全法》作出行政处罚决定的案例。2021年公示5起,2022年公示11起,2023年…...
Ceph入门到精通-iptables 限制多个ip 的多个端口段访问
要使用iptables限制多个IP的多个端口范围的访问,可以使用以下命令: iptables -A INPUT -p tcp -m multiport --dports 端口段 -m iprange --src-range 起始IP-结束IP -j DROP上面的命令将添加一条规则到INPUT链中,该规则将禁止指定IP范围访问…...
【C/C++】STL——深度剖析vector容器
👻内容专栏: C/C编程 🐨本文概括:vector的介绍与使用、深度剖析及模拟实现。 🐼本文作者: 阿四啊 🐸发布时间:2023.10.8 一、vector的介绍与使用 1. vector的介绍 像string的学习…...
如何在idea中隐藏文件或文件夹
例如我想要隐藏如下文件 只需要点击file->settings editor->file types->ignores Files and Folders-> 然后按照图片点击顺序操作即可 添加完毕点击apply->ok 隐藏成功后效果如下:...
Scala第二十章节
Scala第二十章节 scala总目录 文档资料下载 章节目标 理解Akka并发编程框架简介掌握Akka入门案例掌握Akka定时任务代码实现掌握两个进程间通信的案例掌握简易版spark通信框架案例 1. Akka并发编程框架简介 1.1 Akka概述 Akka是一个用于构建高并发、分布式和可扩展的基于事…...
redis的持久化消息队列
Redis Stream Redis Stream 是 Redis 5.0 版本新增加的数据结构。 Redis Stream 主要用于消息队列(MQ,Message Queue),Redis 本身是有一个 Redis 发布订阅 (pub/sub) 来实现消息队列的功能,但它有个缺点就是消息无法…...
分类预测 | MATLAB实现KOA-CNN开普勒算法优化卷积神经网络数据分类预测
分类预测 | MATLAB实现KOA-CNN开普勒算法优化卷积神经网络数据分类预测 目录 分类预测 | MATLAB实现KOA-CNN开普勒算法优化卷积神经网络数据分类预测分类效果基本描述程序设计参考资料 分类效果 基本描述 1.MATLAB实现KOA-CNN开普勒算法优化卷积神经网络数据分类预测࿰…...
用 Pytorch 自己构建一个Transformer
一、说明 用pytorch自己构建一个transformer并不是难事,本篇使用pytorch随机生成五千个32位数的词向量做为源语言词表,再生成五千个32位数的词向量做为目标语言词表,让它们模拟翻译过程,transformer全部用pytorch实现,具备一定实战意义。 二、论文和概要 …...
Docker安装ActiveMQ
ActiveMQ简介 官网地址:https://activemq.apache.org/ 简介: ActiveMQ 是Apache出品,最流行的,能力强劲的开源消息总线。ActiveMQ 是一个完全支持JMS1.1和J2EE 1.4规范的 JMS Provider实现,尽管JMS规范出台已经是很久的事情了,…...
【二】spring boot-设计思想
spring boot-设计思想 简介:现在越来越多的人开始分析spring boot源码,拿到项目之后就有点无从下手了,这里介绍一下springboot源码的项目结构 一、项目结构 从上图可以看到,源码分为两个模块: spring-boot-project&a…...
系统架构设计:7 论企业集成架构设计及应用
目录 一 企业集成 1 企业集成分类:按照集成点分 (1)界面集成(表示集成)...
【pytorch】多GPU同时训练模型
文章目录 1. 基本原理单机多卡训练教程——DP模式 2. Pytorch进行单机多卡训练步骤1. 指定GPU2. 更改模型训练方式3. 更改权重保存方式 摘要:多GPU同时训练,能够解决单张GPU显存不足问题,同时加快模型训练。 1. 基本原理 单机多卡训练教程—…...
Git 学习笔记 | Git 基本理论
Git 学习笔记 | Git 基本理论 Git 学习笔记 | Git 基本理论Git 工作区域Git 工作流程 Git 学习笔记 | Git 基本理论 在开始使用 Git 创建项目前,我们先学习一下 Git 的基础理论。 Git 工作区域 Git本地有三个工作区域:工作目录(Working Di…...
滚动表格封装
滚动表格封装 我们先设定接收的参数 需要表头内容columns,表格数据data,需要currentSlides来控制当前页展示几行 const props defineProps({// 表头内容columns: {type: Array,default: () > [],required: true,},// 表格数据data: {type: Array,d…...
【LeetCode高频SQL50题-基础版】打卡第3天:第16~20题
文章目录 【LeetCode高频SQL50题-基础版】打卡第3天:第16~20题⛅前言 平均售价🔒题目🔑题解 项目员工I🔒题目🔑题解 各赛事的用户注册率🔒题目🔑题解 查询结果的质量和占比🔒题目&am…...
系统压力测试:保障系统性能与稳定的重要措施
压力测试简介 在当今数字化时代,各种系统和应用程序扮演着重要角色,从企业的核心业务系统到在线服务平台,都需要具备高性能和稳定性,以满足用户的需求。然而,随着用户数量和业务负载的增加,系统可能会面临…...
常用数据结构和算法
提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 前言一、时间复杂度二、使用步骤 1.引入库2.读入数据总结 前言 提示:这里可以添加本文要记录的大概内容: 这里面有10个数据结构࿱…...
C++中使用引用避免内存复制
C中使用引用避免内存复制 引用让您能够访问相应变量所在的内存单元,这使得编写函数时引用很有用。典型的函数声明类似于下面这样: ReturnType DoSomething(Type parameter);调用函数 DoSomething() 的代码类似于下面这样: ReturnType Resu…...
计算机网络(第8版)-第4章 网络层
4.1 网络层的几个重要概念 4.1.1 网络层提供的两种服务 如果主机(即端系统)进程之间需要进行可靠的通信,那么就由主机中的运输层负责(包括差错处理、流量控制等)。 4.1.2 网络层的两个层面 4.2 网际协议 IP 图4-4 网…...
UE5 学习系列(二)用户操作界面及介绍
这篇博客是 UE5 学习系列博客的第二篇,在第一篇的基础上展开这篇内容。博客参考的 B 站视频资料和第一篇的链接如下: 【Note】:如果你已经完成安装等操作,可以只执行第一篇博客中 2. 新建一个空白游戏项目 章节操作,重…...
《Qt C++ 与 OpenCV:解锁视频播放程序设计的奥秘》
引言:探索视频播放程序设计之旅 在当今数字化时代,多媒体应用已渗透到我们生活的方方面面,从日常的视频娱乐到专业的视频监控、视频会议系统,视频播放程序作为多媒体应用的核心组成部分,扮演着至关重要的角色。无论是在个人电脑、移动设备还是智能电视等平台上,用户都期望…...
精益数据分析(97/126):邮件营销与用户参与度的关键指标优化指南
精益数据分析(97/126):邮件营销与用户参与度的关键指标优化指南 在数字化营销时代,邮件列表效度、用户参与度和网站性能等指标往往决定着创业公司的增长成败。今天,我们将深入解析邮件打开率、网站可用性、页面参与时…...
智能分布式爬虫的数据处理流水线优化:基于深度强化学习的数据质量控制
在数字化浪潮席卷全球的今天,数据已成为企业和研究机构的核心资产。智能分布式爬虫作为高效的数据采集工具,在大规模数据获取中发挥着关键作用。然而,传统的数据处理流水线在面对复杂多变的网络环境和海量异构数据时,常出现数据质…...
Linux --进程控制
本文从以下五个方面来初步认识进程控制: 目录 进程创建 进程终止 进程等待 进程替换 模拟实现一个微型shell 进程创建 在Linux系统中我们可以在一个进程使用系统调用fork()来创建子进程,创建出来的进程就是子进程,原来的进程为父进程。…...
云原生安全实战:API网关Kong的鉴权与限流详解
🔥「炎码工坊」技术弹药已装填! 点击关注 → 解锁工业级干货【工具实测|项目避坑|源码燃烧指南】 一、基础概念 1. API网关(API Gateway) API网关是微服务架构中的核心组件,负责统一管理所有API的流量入口。它像一座…...
Linux nano命令的基本使用
参考资料 GNU nanoを使いこなすnano基础 目录 一. 简介二. 文件打开2.1 普通方式打开文件2.2 只读方式打开文件 三. 文件查看3.1 打开文件时,显示行号3.2 翻页查看 四. 文件编辑4.1 Ctrl K 复制 和 Ctrl U 粘贴4.2 Alt/Esc U 撤回 五. 文件保存与退出5.1 Ctrl …...
大数据治理的常见方式
大数据治理的常见方式 大数据治理是确保数据质量、安全性和可用性的系统性方法,以下是几种常见的治理方式: 1. 数据质量管理 核心方法: 数据校验:建立数据校验规则(格式、范围、一致性等)数据清洗&…...
C++--string的模拟实现
一,引言 string的模拟实现是只对string对象中给的主要功能经行模拟实现,其目的是加强对string的底层了解,以便于在以后的学习或者工作中更加熟练的使用string。本文中的代码仅供参考并不唯一。 二,默认成员函数 string主要有三个成员变量,…...
如何通过git命令查看项目连接的仓库地址?
要通过 Git 命令查看项目连接的仓库地址,您可以使用以下几种方法: 1. 查看所有远程仓库地址 使用 git remote -v 命令,它会显示项目中配置的所有远程仓库及其对应的 URL: git remote -v输出示例: origin https://…...
