简单OS(ucos超级精简版)——裸调度器【worldsing笔记】
简单原则少ROM,少RAM,任务完成就让出CPU,调度器描述:
1、按最大任务数轮番调度;
2、任务调用延时接口将让出CPU使用权,进入下一个任务调度;
3、用户任务都处于延时或是不使用CPU运行Idle任务;
4、最大任务数255;
5、任务用独立栈,栈大小由用户自定义;
6、调度器无需初始化,代码为单个C文件,结构简单,代码尺寸小;
7、调度器加3个任务代码尺寸:Code=1428 RO-data=268 RW-data=32 ZI-data=520
软件环境:Keil Mdk 4.7a 硬件:stm32f103vb

-------------------------------------------------------------------------------------------------
//调度器C文件 Switch.c
#include "stm32f10x.h"
#include "switch.h"
#include "string.h"
#include "stdbool.h"
TCB TaskTCB[MAX_TASK + 1] = {0};
TCB *TaskNew, *TaskRuning;
uint32_t IdleStack[20];
uint8_t TaskCnt = 0;
void TaskIdle() {
while(1){
}
}
__asm void TaskSwitch(void)
{
LDR R0, =0xE000ED22
LDR R1, =0xFF
STRB R1, [R0]
LDR R0, =0xE000ED04
LDR R1, =0x10000000
STR R1, [R0]
BX LR
ALIGN
}
__asm void PendSV_Handler(void)
{
IMPORT TaskRuning
IMPORT TaskNew
CPSID I
MRS R0, PSP
CBZ R0, NoSave
SUBS R0, R0, #0x20
STM R0, {R4-R11}
LDR R1, =TaskRuning
LDR R1, [R1]
STR R0, [R1]
NoSave
LDR R0, =TaskRuning
LDR R1, =TaskNew
LDR R2, [R1]
STR R2, [R0]
LDR R0, [R2]
LDM R0, {R4-R11}
ADDS R0, R0, #0x20
MSR PSP, R0
ORR LR, LR, #0x04
CPSIE I
BX LR
ALIGN
}
void SysTick_Handler (void)
{
uint8_t i;
bool bOneSwitch;
bOneSwitch = false;
for(i = 0; i < MAX_TASK; i++){
if(TaskTCB[i].Delay != 0){
TaskTCB[i].Delay--;
}
if(bOneSwitch == false){
TaskCnt %= MAX_TASK;
if(0 == TaskTCB[TaskCnt].Delay){
bOneSwitch = true;
TaskNew = &TaskTCB[TaskCnt++];
}else{
TaskCnt++;
}
}
}
if(bOneSwitch == false)
TaskNew = &TaskTCB[IDLE_TASK];
TaskSwitch();
}
void SwitchDelay(uint16_t nTick)
{
uint8_t i;
if(0 == nTick)
return;
TaskRuning->Delay = nTick;
for(i = 0; i < MAX_TASK; i++){
TaskCnt %= MAX_TASK;
if(0 == TaskTCB[TaskCnt].Delay){
TaskNew = &TaskTCB[TaskCnt++];
break;
}else TaskCnt++;
}
if(TaskRuning == TaskNew)
TaskNew = &TaskTCB[IDLE_TASK];
TaskSwitch();
}
void SwitchTaskInt(void (*task)(void), OS_STK *ptos)
{
if(MAX_TASK + 1 <= TaskCnt){
TaskCnt = 0;
return;
}
if(NULL == task)
return;
if(NULL == ptos)
return;
*(ptos) = (INT32U)0x01000000L;
*(--ptos) = (INT32U)task;
TaskTCB[TaskCnt]. pTaskStack = ptos -14;
TaskTCB[TaskCnt++]. Delay = 0;
}
void SwitchStart(void)
{
SystemInit();
__set_PSP(0);
SwitchTaskInt(TaskIdle, IdleStack+19);
SysTick_Config((SystemCoreClock / N_TICK_IN_SECOND) - 1);
}
-------------------------------------------------------------------------------------------------
//调度器头文件 SWitch.h
#ifndef __SWITCH_H__
#define __SWITCH_H__
#include "stdint.h"
#define MAX_TASK 2
#define N_TICK_IN_SECOND 1000
#define IDLE_TASK MAX_TASK
typedef uint32_t OS_STK;
typedef uint32_t INT32U;
typedef struct TCB
{
uint32_t *pTaskStack;
uint16_t Delay;
}TCB;
extern TCB *TaskRuning;
extern TCB *TaskNew;
extern TCB TCBTask[MAX_TASK];
void SwitchTaskInt(void (*task)(void), OS_STK *ptos);
void SwitchDelay(uint16_t Time);
void SwitchStart(void);
#endif
-------------------------------------------------------------------------------------------------
//应用Demo App.c
#include "stm32f10x.h"
#include "stm32f10x_rcc.h"
#include "stm32f10x_gpio.h"
#include "switch.h"
#include <stdio.h>
u32 TaskStack[2][40];
void Task0(void);
void Task1(void);
int main(void)
{
SwitchTaskInt(Task0, &TaskStack[0][39]);
SwitchTaskInt(Task1, &TaskStack[1][39]);
SwitchStart();
while(1);
}
void Task0(void)
{
u8 i;
for(;;)
{
i = i;
//SwitchDelay(200);
}
}
void Task1(void)
{
u8 i;
for(;;)
{
//SwitchDelay(300);
i = i;
}
}
调度器代码: 点击下载
简单OS(ucos超级精简版)——裸调度器【worldsing笔记】的更多相关文章
- 推荐《C Primer Plus(第五版)中文版》【worldsing笔记】
老外写的C书,看了你会有一种哇塞的感觉,这里提供PDF扫描版的下在,包含数内的例程,请大家支持原版!! C Primer Plus(第五版)中文版.pdf 下载地址:http://pan.bai ...
- k8s调度器介绍(调度框架版本)
从一个pod的创建开始 由kubectl解析创建pod的yaml,发送创建pod请求到APIServer. APIServer首先做权限认证,然后检查信息并把数据存储到ETCD里,创建deployme ...
- Linux 调度器发展简述
引言 进程调度是操作系统的核心功能.调度器只是是调度过程中的一部分,进程调度是非常复杂的过程,需要多个系统协同工作完成.本文所关注的仅为调度器,它的主要工作是在所有 RUNNING 进程中选择最合适的 ...
- Yarn 调度器Scheduler详解
理想情况下,我们应用对Yarn资源的请求应该立刻得到满足,但现实情况资源往往是有限的,特别是在一个很繁忙的集群,一个应用资源的请求经常需要等待一段时间才能的到相应的资源.在Yarn中,负责给应用分配资 ...
- 第1节 yarn:14、yarn集群当中的三种调度器
yarn当中的调度器介绍: 第一种调度器:FIFO Scheduler (队列调度器) 把应用按提交的顺序排成一个队列,这是一个先进先出队列,在进行资源分配的时候,先给队列中最头上的应用进行分配资源 ...
- Hadoop调度器
一.FIFO调度器(先进先出调度) 上图为FIFO调度器的执行过程示意图.FIFO Scheduler是最简单也是最容易理解的调度器,它缺点是不适用于共享集群.大的应用可能会占用所有集群资源,这就导致 ...
- YARN调度器(Scheduler)详解
理想情况下,我们应用对Yarn资源的请求应该立刻得到满足,但现实情况资源往往是有限的,特别是在一个很繁忙的集群,一个应用资源的请求经常需要等待一段时间才能的到相应的资源.在Yarn中,负责给应用分配资 ...
- [异常解决] ubuntu上安装虚拟机遇到的问题(vmware坑了,virtual-box简单安装,在virtual-box中安装精简版win7)
利用周末时间将整个电脑格式化,换成了ubuntu系统- 所谓:扫清屋子再请客! 但是有些软件只在win上有,于是还是考虑装个虚拟机来个——逐步过度策略,一点点地从win上转移到linux上 我的系统是 ...
- [原创]spring及springmvc精简版--AOP
接上一篇:[原创]spring及springmvc精简版--IOC 理解AOP.java是一种面向对象的语言.而AOP是面向切面,在我看来是面向逻辑或者业务编程,它是对一组逻辑的抽象和分配. 经典例子 ...
随机推荐
- mac 升级后 web 服务器起不来 问题
4. Apache 要本地调试代码的时候发现Apache也不能幸免地跪了.执行apachectl -v发现Apache已经更新到2.4.9版本了.一定又是因为版本更新出了什么差错. 4.1 修改htt ...
- ArcGIS Runtime for Android开发教程V2.0(2)开发环境配置
原文地址: ArcGIS Runtime for Android开发教程V2.0(2)开发环境配置 - ArcGIS_Mobile的专栏 - 博客频道 - CSDN.NET http://blog.c ...
- 编程之美:1.9高效率安排见面会 图的m着色问题 回溯法
原书问题,可以转换为图的m着色问题 ,下面该问题的代码 这里有参考ppt与code,免积分载 http://download.csdn.net/detail/u011467621/6341195 // ...
- poj 2109 Power of Cryptography (double 精度)
题目:http://poj.org/problem?id=2109 题意:求一个整数k,使得k满足kn=p. 思路:exp()用来计算以e为底的x次方值,即ex值,然后将结果返回.log是自然对数,就 ...
- POI2001 Gold mine(二叉排序树 黑书经典)
采矿(KOP) 金矿的老师傅年底要退休了.经理为了奖赏他的尽职尽责的工作,决定送他一块长方形地.长度为S,宽度为W.老师傅可以自己选择这块地.显然其中包含的采金点越多越好.你的任务就是计算最多能得到多 ...
- hdu 1166(树状数组 或 线段树)
线段树 (本题无需建树,少了很多) #include<cstdio> #include<cstring> int sum[5000005],rt,data,lb,rb,n,m; ...
- bzoj1029
贪心,比较明显了(很像USACO的风格); 按时间限制排序(升序) 顺次处理,如果当前时间能够修复就修复 否则就在之前修复的任务中找一个耗时最多(大于当前任务)的,改成修当前任务; 显然这样最优吧, ...
- 【转】android 最新 NDK r8 在window下开发环境搭建 安装配置与使用 详细图文讲解,完整实际配置过程记录(原创)
原文网址:http://www.cnblogs.com/zdz8207/archive/2012/11/27/android-ndk-install.html android 最新 NDK r8 在w ...
- MAC虚拟机NAT方式共享上网设置
有部分FY需要,我写一下我的方法吧,当初安装完MAC后,无法上网,网络搜索用的是HOST-only方法,试了几次都没有成功,后来尝试NAT方法,发现很简单. 我的主机系统:win7 64位,自动获取I ...
- activemq p2p方式
package ch02.chat; import java.io.Serializable; import javax.jms.Connection; import javax.jms.Connec ...