void vTaskSwitchContext(void)
{

    //my_printf( "uxSchedulerSuspended = %d\n", uxSchedulerSuspended );
/* 调度器处于挂起状态 */
if (uxSchedulerSuspended != (UBaseType_t)pdFALSE) {
/**
* The scheduler is currently suspended - do not allow a context
* switch.
*/
xYieldPending = pdTRUE;
} else {
xYieldPending = pdFALSE;
traceTASK_SWITCHED_OUT();


/* Check for stack overflow, if configured. */
taskCHECK_FOR_STACK_OVERFLOW();

        /* Before the currently running task is switched out, save its errno. */
#if (configUSE_POSIX_ERRNO == 1)
{bbb
pxCurrentTCB->iTaskErrno = FreeRTOS_errno;
}
#endif

        /**
* Select a new task to run using either the generic C or port
* optimised asm code.  debug_stamp
* 选择优先级最高的任务
*/
//taskSELECT_HIGHEST_PRIORITY_TASK();
UBaseType_t uxTopPriority;                                                                                                                                                        
/* Find the highest priority list that contains ready tasks. */                        
//portGET_HIGHEST_PRIORITY(uxTopPriority, uxTopReadyPriority);    
//#define portGET_HIGHEST_PRIORITY xxx( uxTopPriority, uxReadyPriorities ) 


//my_printf( "ccccuxTopReadyPriority = %#x\n", uxTopReadyPriority );
uxTopPriority = ( 31UL - ( uint32_t ) ucPortCountLeadingZeros( ( uxTopReadyPriority ) ) );
//configASSERT(listCURRENT_LIST_LENGTH(&(pxReadyTasksLists[uxTopPriority])) > 0);    



//listGET_OWNER_OF_NEXT_ENTRY(pxCurrentTCB, &(pxReadyTasksLists[uxTopPriority])); 


//|------->volatile UBaseType_t uxNumberOfItems = 1    //链表中元素的个数
//| |<-----ListItem_t *pxIndex;                           //总是指向xListEnd节点,在链表尾部插入的时候,方便找到位置    
//| |->|-->TickType_t xItemValue = portMAX_DELAY       [MiniListItem_t xListEnd]   
//|    |   struct xLIST_ITEM *pxNext;     ----->|      //后继节点
//|    |   struct xLIST_ITEM *pxPrevious; ----->|      //前驱节点    
//|    |                                        |
//|    |   TickType_t xItemValue; <-------------|      //链表节点的值
//|    |<--struct xLIST_ITEM *pxNext;                  //后继节点
//|    |<--struct xLIST_ITEM *pxPrevious;              //前驱节点
//|        void * pvOwner;                             //保存私有数据
//|<------ struct xLIST *pxContainer;                  //节点所在的链表


//|------->volatile UBaseType_t uxNumberOfItems = 1    //链表中元素的个数
//| |<-----ListItem_t *pxIndex;                           //总是指向xListEnd节点,在链表尾部插入的时候,方便找到位置    
//| |  |-->TickType_t xItemValue = portMAX_DELAY       [MiniListItem_t xListEnd]   
//| |  |   struct xLIST_ITEM *pxNext;     ----->|      //后继节点
//| |  |   struct xLIST_ITEM *pxPrevious; ----->|      //前驱节点    
//| |  |                                        |
//| |--|-->TickType_t xItemValue; <-------------|      //链表节点的值
//|    |<--struct xLIST_ITEM *pxNext;                  //后继节点
//|    |<--struct xLIST_ITEM *pxPrevious;              //前驱节点
//|        void * pvOwner;                             //保存私有数据
//|<------ struct xLIST *pxContainer;                  //节点所在的链表


        
my_printf( "\nuxTopPriority = %d\n", uxTopPriority );
my_printf( "pxCurrentTCB->pcTaskName1 = %s\n", pxCurrentTCB->pcTaskName );
List_t * const pxConstList = &pxReadyTasksLists[uxTopPriority];    
//my_printf( "pxConstList = %p\n", pxConstList );
my_printf( "pxConstList->pxIndex before = %p\n", pxConstList->pxIndex );

        
/* Increment the index to the next item and return the item, ensuring */           
/* we don't return the marker used at the end of the list.    */                       
pxConstList->pxIndex = pxConstList->pxIndex->pxNext;
//此处有指针的指向偏移 由 xListEnd -> xLIST_ITEM

        my_printf( "pxConstList->pxIndex hou = %p\n", pxConstList->pxIndex );
my_printf( " &pxConstList->xListEnd = %p\n",  &pxConstList->xListEnd );

if( (void *)pxConstList->pxIndex == (void *)&pxConstList->xListEnd ){                                                                                   
pxConstList->pxIndex = pxConstList->pxIndex->pxNext;    
my_printf( "pxConstList->pxIndexxx = %p\n", pxConstList->pxIndex );

            //空闲任务由于不能挂起,其指向内容有些不一样 pxIndex->pxNext 指向 &xListEnd, 而不是指向xLIST_ITEM
//而对于其他有挂起和恢复的任务 不一样
//空闲任务不会有链表xLIST_ITEM的删除和插入动作
//第一次进空闲任务不会走这里 后续由于没有删除和插入对pxIndex复位 
//pxConstList->pxIndex = pxConstList->pxIndex->pxNext; 指向了xLIST_ITEM 
//然后达到了循环的稳定点 
//总结下来:第一次指向 &xListEnd,后续运行指向 xLIST_ITEM 
//为啥后续不交错指向? 2次运行 pxConstList->pxIndex = pxConstList->pxIndex->pxNext; 回到原点.
//第一次运行:
//|------->volatile UBaseType_t uxNumberOfItems = 1    //链表中元素的个数
//| |<-----ListItem_t *pxIndex;                           //总是指向xListEnd节点,在链表尾部插入的时候,方便找到位置    
//| |->|-->TickType_t xItemValue = portMAX_DELAY       [MiniListItem_t xListEnd]   
//|    |   struct xLIST_ITEM *pxNext;     ----->|      //后继节点
//|    |   struct xLIST_ITEM *pxPrevious; ----->|      //前驱节点    
//|    |                                        |
//|    |   TickType_t xItemValue; <-------------|      //链表节点的值 xLIST_ITEM xLIST_ITEM
//|    |<--struct xLIST_ITEM *pxNext;                  //后继节点
//|    |<--struct xLIST_ITEM *pxPrevious;              //前驱节点
//|        void * pvOwner;                             //保存私有数据
//|<------ struct xLIST *pxContainer;                  //节点所在的链表

            //第2次运行:
//|------->volatile UBaseType_t uxNumberOfItems = 1    //链表中元素的个数
//| |<-----ListItem_t *pxIndex;                           //总是指向xListEnd节点,在链表尾部插入的时候,方便找到位置    
//| |  |-->TickType_t xItemValue = portMAX_DELAY       [MiniListItem_t xListEnd]   
//| |  |   struct xLIST_ITEM *pxNext;     ----->|      //后继节点
//| |  |   struct xLIST_ITEM *pxPrevious; ----->|      //前驱节点    
//| |  |                                        |
//| |--|-->TickType_t xItemValue; <-------------|      //链表节点的值 xLIST_ITEM xLIST_ITEM
//|    |<--struct xLIST_ITEM *pxNext;                  //后继节点
//|    |<--struct xLIST_ITEM *pxPrevious;              //前驱节点
//|        void * pvOwner;                             //保存私有数据
//|<------ struct xLIST *pxContainer;                  //节点所在的链表

            

            
}                                                                                   
pxCurrentTCB = pxConstList->pxIndex->pvOwner;        
my_printf( "pxCurrentTCB->pcTaskName2 = %s\n", pxCurrentTCB->pcTaskName );

    
traceTASK_SWITCHED_IN();

        /* After the new task is switched in, update the global errno. */
#if (configUSE_POSIX_ERRNO == 1)
{
FreeRTOS_errno = pxCurrentTCB->iTaskErrno;
}
#endif
}
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/pingmian/89947.shtml
繁体地址,请注明出处:http://hk.pswp.cn/pingmian/89947.shtml
英文地址,请注明出处:http://en.pswp.cn/pingmian/89947.shtml

如若内容造成侵权/违法违规/事实不符,请联系英文站点网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

CPU 密集型 和 I/O 密集型 任务

文章目录**CPU 密集型任务&#xff08;CPU-bound&#xff09;**定义&#xff1a;特点&#xff1a;常见场景&#xff1a;如何优化 CPU 密集型任务&#xff1a;**I/O 密集型任务&#xff08;I/O-bound&#xff09;**定义&#xff1a;特点&#xff1a;常见场景&#xff1a;如何优化…

[2025CVPR-小目标检测方向]基于特征信息驱动位置高斯分布估计微小目标检测模型

核心问题 ​小目标检测性能差&#xff1a;​​ 尽管通用目标检测器&#xff08;如 Faster R-CNN, YOLO, SSD&#xff09;在常规目标上表现出色&#xff0c;但在检测微小目标&#xff08;如 AI-TOD 基准定义的&#xff1a;非常小目标 2-8 像素&#xff0c;小目标 8-16 像素&…

三大工厂设计模式

1.简单工厂模式1.1需求入手从需求进行入手&#xff0c;可以更深入的理解什么是设计模式。有一个制作披萨的需求&#xff1a;需要便于扩展披萨的种类&#xff0c;便于维护。1.披萨的种类有很多&#xff1a;GreekPizz&#xff0c;CheesePizz等2.披萨的制作流程&#xff1a;prepar…

SpringBoot--Mapper XML 和 Mapper 接口在不同包

&#x1f9e9; 背景说明在 Spring Boot 中&#xff0c;MyBatis 默认要求 Mapper 接口和 XML 文件位于相同包路径。 但在实际项目中&#xff0c;为了模块化或结构清晰&#xff0c;常将 XML 放在 resources/mybatis/... 下&#xff0c;这种做法就必须进行额外配置。&#x1f4c1;…

公交车客流人数统计管理解决方案:智能化技术与高效运营实践

1. 引言公交车作为城市公共交通的核心组成部分&#xff0c;其客流数据的精准统计与管理直接影响运营效率、调度优化和乘客体验。传统的人工统计方式效率低、误差大&#xff0c;难以满足现代智慧交通的需求。随着人工智能&#xff08;AI&#xff09;、物联网&#xff08;IoT&…

正则表达式完全指南:从入门到实战

目录 一、什么是正则表达式&#xff1f; 二、基础语法速查表 三、进阶特性 1.分组与捕获 2.非捕获分组 3.前瞻与后顾 4.贪婪与懒惰匹配 四、实战案例 案例1&#xff1a;验证手机号 案例2&#xff1a;提取网页中所有链接 案例3&#xff1a;密码强度验证 一、什么是正…

SmartETL循环流程的设计与应用

1. 引言 **检索增强生成&#xff08;RAG&#xff09;**是指通过检索对大模型生成进行增强的技术&#xff0c;通过充分利用信息检索&#xff08;尤其是语义检索&#xff09;相关技术&#xff0c;实现大模型快速扩展最新知识、有效减少幻觉的能力。主流RAG框架包括问题理解、知识…

uni-app开发小程序,根据图片提取主题色值

需求&#xff0c;在页面根据传入的图片提取图片主色值并用来设置区块背景色<template><view class"icon-container"><view class"sport-icon" :style"{ backgroundColor: mainColor }"><image :src"/static/images/sp…

ESP32-Cam三脚架机器人:DIY你的智能移动监控平台

项目概述 在物联网与机器人技术融合发展的今天&#xff0c;基于ESP32的创意项目层出不穷。今天为大家介绍一款极具创新性的ESP32-Cam三脚架机器人&#xff08;Dodge&#xff09;&#xff0c;它将传统三脚架结构与智能监控功能完美结合&#xff0c;通过巧妙的机械设计和开源硬件…

Kotlin集合过滤

过滤操作 在处理集合时&#xff0c;根据特定条件过滤集合或检查集合中是否包含符合特定条件的元素是软件开发中的常见任务。为了解决这个问题&#xff0c;我们可以使用 Kotlin 中实现的函数式 API。 在本主题中&#xff0c;我们将介绍如何使用谓词过滤集合&#xff0c;并获得满…

14.8 LLaMA2-7B×Dolly-15K实战:从准确率63%到89%,如何用优质数据让大模型性能飙升42%?

LLaMA2-7BDolly-15K实战:从准确率63%到89%,如何用优质数据让大模型性能飙升42%? 在大模型微调中,“数据质量”往往比“数据数量”更能决定最终效果。Databricks发布的Dolly-15K数据集以“全人工标注+多维度校验”的特点,成为指令微调的“黄金样本”——用它微调后的LLaMA…

OpenCV中常用特征提取算法(SURF、ORB、SIFT和AKAZE)用法示例(C++和Python)

OpenCV 中提供了多种常用的特征提取算法&#xff0c;广泛应用于图像匹配、拼接、SLAM、物体识别等任务。以下是 OpenCV 中几个主流特征提取算法的 用法总结与代码示例&#xff0c;涵盖 C 和 Python 两个版本。常用特征提取算法列表算法特点是否需额外模块SIFT&#xff08;尺度不…

复杂度+包装类型+泛型

什么是集合框架什么是数据结构什么是算法时间复杂度与空间复杂度的概念时间复杂度的表达方式时间复杂度的大 O 的渐近表示法时间复杂度函数的大小排序包装类和泛型基本数据类型和对应的包装类型包装类型出现的原因什么叫做装箱&#xff08;装包&#xff09;和拆箱&#xff08;拆…

硬件设计学习DAY15——自举电容:MOSFET高端驱动的核心奥秘

每日更新教程&#xff0c;评论区答疑解惑&#xff0c;小白也能变大神&#xff01;" 目录 一.自举电容 1.自举电容的作用 2.自举电路原理 3.工作过程分析 4.实际应用中的问题 5.关键要点 二.自举电容实现MOSFET高端驱动 2.1MOSFET半桥高端驱动的基本原理 2.2自举电…

【SpringAI实战】实现仿DeepSeek页面对话机器人

一、实现效果 二、代码实现 2.1 后端代码 2.2 前端代码 一、实现效果 可以保存聊天记录与会话记录 二、代码实现 2.1 后端代码 pom.xml <!-- 继承Spring Boot父POM&#xff0c;提供默认依赖管理 --><parent><groupId>org.springframework.boot</grou…

RedisJSON 指令精讲JSON.STRLEN 高效统计字符串长度

1 场景与价值 在日志累加、指标采集、消息追踪等场景中&#xff0c;我们常需快速判断某个字符串字段“到底有多长”&#xff0c;以便&#xff1a; 阻止过大日志&#xff1a;若长度超限则截断或归档&#xff1b;动态分桶&#xff1a;按长度选择不同存储策略&#xff1b;性能监控…

大数据量查询计算引发数据库CPU告警问题复盘

大数据量查询计算引发数据库CPU告警问题复盘一、背景二、根因分析三、解决方案方案1&#xff1a;多线程缓存方案2&#xff1a;利用中间表缓存四、总结一、背景 2025年7月份某天&#xff0c;CDP系统每天不定时推送我们的Portal服务&#xff0c;生产环境运营看板会展示统计数据&…

2025最新版虚幻引擎5(UE5)C++入门教程:前言——你的随身教程和学习笔记

大家好&#xff0c;我是开发游戏的老王&#xff0c;一名高校教师&#xff0c;我主讲游戏开发已有十余年时间&#xff0c;通过我的博客大家应该可以了解我所涉猎的游戏技术范畴非常广泛&#xff0c;除了Unreal,Unity,Godot等主流游戏引擎&#xff0c;还包括Blender、Houdini、3D…

(3)重定向 | 时间相关指令 | 文件查找 | 打包与压缩

Ⅰ . 初始重定向01 输出重定向 >在上一节中我们为了方便讲解 head 和 tail 指令&#xff0c;我们用到了 > 去生成了一千行文本。通过 > 将生成的一千行文本写入到了 large.txt 中……我们现在来正式介绍一下&#xff1a;$ echo "内容" > [目标] 本来应…

DTH11测量温湿度学习(第十一天)

&#x1f468;‍&#x1f4bb;个人主页&#xff1a;开发者-削好皮的Pineapple! &#x1f468;‍&#x1f4bb; hello 欢迎 点赞&#x1f44d; 收藏⭐ 留言&#x1f4dd; 加关注✅! &#x1f468;‍&#x1f4bb; 本文由 削好皮的Pineapple! 原创 &#x1f468;‍&#x1f4…