/***************************************************/
/* Release Notes for RTX51 TINY Version 2 */
/* PK51 PROFESSIONAL DEVELOPERS KIT */
/***************************************************/
This file contains release notes and last minute changes relating to the
RTX51 TINY Real Time Operating System Version 2.
Information in this file, the accompanying manual, and software is
Copyright (c) 2002 Keil Software and Keil Elektronik. All rights reserved.
Contents
========
1. What's New in RTX51 TINY Version 2
1.1. Code Banking Support
1.2. Explicit Task Switch (Function: os_switch_task)
1.3. RUN Status Flag for Tasks
1.4. CPU IDLE Mode for Power-Reduction
1.5. Add User Code to the 8051 CPU Hardware Timer Routine
1.6. Handling for Interval Events (Function: os_reset_interval)
2. Reduced Code/Data Size and Improved Performance
3. Problems solved in RTX51 TINY Version 2.02
4. Example Programs
1. What's New in RTX51 TINY Version 2
RTX51 TINY Version 2 has been completly restructured to gain flexiblity,
accelarate performance, and reduce code/data space requirements. Also
several new features are added to this popular Real-Time Kernal.
The following section describes the new features in RTX51 TINY Version 2:
1.1. Code Banking Support
You can now use RTX51 TINY together with code banking application. Code
banking support is enabled in the file CONF_TNY.A51 with the CODE_BANKING
configuration variable. As with all other code banking applications you
need to configure the file L51_BANK.A51. Note: The banking configuration
file L51_BANK.A51 V2.12 or higher is required.
1.2. Explicit Task Switch (Function: os_switch_task)
The function os_switch_task lets a task give up the CPU and let another
task execute. If the task calling os_switch_task is the only task that is
ready for execution, it will resume running immediately.
Function prototype:
void os_switch_task (void);
Program Example:
void long_job (void) _task_ 1 {
float f1, f2;
f1 = 0;
while (1) {
f2 = log (f1);
f1 += 0.0001;
os_switch_task (); // execute other tasks
}
}
1.3. READY Status Flag
In addition to the signal flag, each task has also a READY status flag.
A new function allows you to set the READY status flag. If the READY
status flag of a tasks is set, the task will always stay in the Ready
state. The os_wait function will immidiatly continue to the execute
when the READY status flag is set. When a task becomes active, the status
of the READY status flag is cleared and the previous status is signaled as
retrun value of the os_wait and os_switch_task function.
The os_wait function requires no specific argument (like K_SIG for the
signal flag) to wait for the READY status flag.
Compared to the os_send_signal function, the os_set_ready function executes
faster. os_set_ready does not check for valid taskid arguments.
Function Prototypes
void os_set_ready (unsigned char taskid);
void isr_set_ready (unsigned char taskid);
Set the READY status flag of the task specified by taskid.
The value of the READY status flag is indicated by the return value RDY_EVENT of the
os_wait and os_switch_task function. When a task becomes ready, the READY status flag
of these task is automatically cleared.
1.4. CPU IDLE Mode for Power-Reduction
Many 8051 variants can be switched into an IDLE mode where the CPU is gated
off the clock signal. In IDLE mode, the CPU stops instruction execution.
However peripherals including the interrupt system still continue their
operation. RTX51 Tiny invokes the IDLE mode when no task is in the status
READY. Typcially the IDLE mode is terminated by an CPU interrupt, i.e. the
RTX51 Tiny System Clock Interrupt.
On most 8051 variants the IDLE mode is started by setting bit 0 (IDL) in
the PCON register. However, the configuration file CONF_TNY.A51 provides
the macro CPU_IDLE for the configuration of the IDLE mode activation code.
1.5. Add User Code to the 8051 CPU Hardware Timer Routine
In RTX51 Tiny Version 2 it is possible to add user code for the RTX51
System Timer Interrupt routine. In this way you may use the fixed clock
rate of the RTX51 System Timer Interrupt to execute own routines. The user
code can be configured with macro HW_TIMER_CODE in the configuration file
CONF_TNY.A51.
1.6. Handling for Interval Events (Function os_reset_interval)
RTX51 Tiny maintains a software timer for each task. This software timer is
used as interval timer when os_wait is called with a K_IVL event argument.
The interval time specified is substracted from the software timer on the
entry of the os_wait function.
When two event arguments are used (signal and interval might be combined with
K_SIG | K_IVL) with os_wait and the signal event occurs, the software timer might
not be elapsed and this may result in incorrect interval times on further os_wait
calls with the K_IVL event argument. The function os_reset_interval overcomes this
problem and resets the interval time.
Example:
void maintask (void) _task_ 0 {
os_create_task (1);
while (1) {
event = os_wait2 (K_SIG | K_IVL, 100);
switch (event) {
case TMO_EVENT:
a = event;
break;
case SIG_EVENT:
b = event;
os_reset_inverval (100); // correct interval time on a signal event
break;
}
}
}
2. Reduced Code/Data Size and Improved Performance
RTX51 Tiny Version 2 is fully scalable and shows significant code size
reductions when:
a) Round Robin Task Switching is disabled with the setting TIMESHARING
EQU 0 in the configuation file CONF_TNY.A51.
b) not all RTX51 Tiny system functions are used.
c) Stack Checking is disabled with the setting FREE_STACK EQU 0 in the
configuration file CONF_TNY.A51.
Compared to RTX51 Tiny Version 1 the code size requirements are reduced.
However also the overall system performance is improved. When you disable
Round Robin Task Switching even the data requirements are reduced.
3. Problems solved in RTX51 TINY Version 2.02
The following known problems of RTX51 Tiny are corrected in Version 2.02:
a) RTX51 Tiny V1.06: isr_send_signal function may destroy the READY status
when an interrupt occurs during os_wait, whereby the current task is
waiting for the signal from this interrupt.
b) RTX51 Tiny V1.06: K_IVL and K_SIG event cannot be combined in os_wait
since it is not possible to correct the interval timer. In RTX51 Tiny
V2.0 the function os_reset_interval allows you to correct the interval
timer.
c) RTX51 Tiny V1.06: TIMESHARING (round-robin time) cannot be set to 1.
In in this case it can happen (when the interrupt appears before the
robin-time is set) that the timeout is delayed 256 system clock ticks.
d) RTX51 Tiny V1.06: When user interrupts are longer than a RTX51 Tiny
System Clock Timer Tick, the RTX51 Tiny System Clock Timer is called
recursively. This overwrites the values SAVEPSW and SAVEACC with wrong
values and causes typically a system crash.
In RTX51 Tiny V2.0 it is recommended that you set LONG_USR_INTR EQU 1
in the configuration file CONF_TNY.A51 if your application contains an
interrupt function that may take longer for execution than the RTX51
Tiny System Clock Timer Interval time. It might be also required to
set this flag when your code executes most of the time interrupt code
with high interrupt priority.
e) RTX51 Tiny V2.00 BETA: os_wait did not reset the SIGNAL event, when
the signal was already set
没有合适的资源?快使用搜索试试~ 我知道了~
up51v708_Full.rar_full_serial monitor 64
共1526个文件
h:416个
c:186个
a51:161个
1.该资源内容由用户上传,如若侵权请联系客服进行举报
2.虚拟产品一经售出概不退款(资源遇到问题,请及时私信上传者)
2.虚拟产品一经售出概不退款(资源遇到问题,请及时私信上传者)
版权申诉
0 下载量 3 浏览量
2022-07-14
21:02:49
上传
评论
收藏 28.73MB RAR 举报
温馨提示
kerl 单片机使用开发安装程序 ,开发单片机时需要使用它先安装
资源推荐
资源详情
资源评论
收起资源包目录
up51v708_Full.rar_full_serial monitor 64 (1526个子文件)
L51_BANK.A51 42KB
L51_BANK.A51 42KB
L51_BANK.A51 42KB
L51_BANK.A51 42KB
L51_BANK.A51 42KB
L51_BANK.A51 42KB
L51_BANK.A51 42KB
L51_BANK.A51 42KB
L51_BANK.A51 42KB
L51_BANK.A51 42KB
INSTALL.A51 37KB
INSTALL.A51 37KB
ISD51.A51 27KB
ISD51.A51 27KB
ISD51.A51 27KB
ISD51.A51 27KB
ISD51.A51 27KB
ISD51.A51 27KB
ISD51.A51 27KB
ISD51.A51 27KB
ISD51.A51 27KB
ISD51.A51 27KB
ISD51.A51 27KB
ISD51.A51 27KB
ISD51.A51 27KB
ISD51.A51 27KB
ISD51.A51 27KB
ISD51.A51 27KB
INSTALL.A51 20KB
INSTALL.A51 20KB
RTX51TNY.A51 18KB
RTX51TNY.A51 18KB
L51IBank.a51 16KB
L51IBank.a51 16KB
Conf_tny.A51 16KB
Conf_tny_Banking.A51 16KB
Conf_tny.A51 16KB
Conf_tny.A51 16KB
CONF_TNY.A51 16KB
CONF_TNY.A51 16KB
INSTALL.A51 15KB
INSTALL.A51 15KB
INSTALL.A51 14KB
INSTALL.A51 14KB
XBANKING.A51 12KB
XBANKING.A51 12KB
INSTALL.A51 12KB
INSTALL.A51 12KB
INSTALL.A51 12KB
INSTALL.A51 12KB
START900.A51 11KB
START900.A51 11KB
START900.A51 11KB
START900.A51 11KB
START900.A51 11KB
START900.A51 11KB
START900.A51 11KB
START900.A51 11KB
START900.A51 11KB
START900.A51 11KB
XBANKING.A51 11KB
XBANKING.A51 11KB
TEMPLATE.A51 11KB
TEMPLATE.A51 11KB
XBANKING.A51 10KB
XBANKING.A51 10KB
XBanking4XRAM.A51 10KB
XBanking4XRAM.A51 10KB
INIT.A51 9KB
INIT.A51 9KB
INIT.A51 9KB
INIT.A51 9KB
START390.A51 9KB
START390.A51 9KB
START390.A51 9KB
START390.A51 9KB
INIT_MX.A51 9KB
INIT_MX.A51 9KB
MON_BANK.A51 8KB
MON_BANK.A51 8KB
XBANKING.A51 8KB
XBANKING.A51 8KB
XBANKING.A51 8KB
XBANKING.A51 8KB
startup400.a51 8KB
startup400.a51 8KB
START_MX.A51 7KB
START_MX.A51 7KB
START390.A51 7KB
START390.A51 7KB
START390.A51 7KB
START390.A51 7KB
START390.A51 7KB
START390.A51 7KB
START_MX.A51 7KB
START_MX.A51 7KB
START_MX.A51 7KB
START_MX.A51 7KB
INIT_TNY.A51 7KB
INIT_TNY.A51 7KB
共 1526 条
- 1
- 2
- 3
- 4
- 5
- 6
- 16
资源评论
寒泊
- 粉丝: 75
- 资源: 1万+
上传资源 快速赚钱
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助
最新资源
- html动态爱心代码一(附源码)
- c40539bc-071a-486c-9d52-9d0c18d62dac 4.html
- 基于物理的非视域成像(NLOS)算法,利用了nerf+python源码+文档说明
- yuluer知更鸟.7z(1).001
- python课程设计-基于tensorflow实现的图文生成程序,数据集flickr30k-images+源代码+文档说明+截图
- python作业-基于Flickr30k数据集实现图像文本跨模态搜索python源码+数据集+测试界面+项目说明(高分课程设计)
- 基于Qt实现医院信息管理系统c++源码+文档说明+数据库(期末大作业)
- 基于python实现的医院信息管理系统完整源码+sql数据库+详细注释(高分课程设计)
- 基于python的眼底图像视杯视盘分割项目源码+文档说明+截图演示+详细注释(高分课程设计)
- ImageBasedModellingEdu-贰壹贰叁零
资源上传下载、课程学习等过程中有任何疑问或建议,欢迎提出宝贵意见哦~我们会及时处理!
点击此处反馈
安全验证
文档复制为VIP权益,开通VIP直接复制
信息提交成功