RTEMS 闪灯程序

初始化生成一个user任务,然后运行user任务,init任务删除自己。
在user任务中,调用系统函数 rtems_task_wake_after 函数,该函数会将自己线程挂起,然后释放CPU资源,等待 N 个 tick 之后唤醒。
系统默认到 tick 是 10ms ,可以直接使用 rtems_task_wake_after( 50 ); 表示 50个 tick 也就是 500ms
也可以使用 rtems_clock_get_ticks_per_second() 函数得到1秒有多少个 tick

其他就没啥来,延时500ms开关LED,就是最基本的闪烁功能了。



#include <stdlib.h>
#include <stdio.h>
#include <bsp.h>

#define LED_ON()  GPBDAT &=~ (1<<5)
#define LED_OFF() GPBDAT |=  1<<5

static rtems_task user_task (rtems_task_argument ignored)
{
	printf("In User tASK\n");
	GPBCON = 1<<(5*2);

	while (1)
	{
	    //rtems_task_wake_after( 1 * rtems_clock_get_ticks_per_second() );
		rtems_task_wake_after( 50 );
	    LED_OFF();
	    //rtems_task_wake_after( 1 * rtems_clock_get_ticks_per_second() );
	    rtems_task_wake_after( 50 );
	    LED_ON();
	}
}

rtems_task Init(rtems_task_argument ignored)
{
  rtems_name Task_name;
  rtems_id   Task_id;
  rtems_status_code status;

  printf("RTEMS 4.10.2 Start\n");

  Task_name = rtems_build_name('U','S','E','R');

  status = rtems_task_create(
    Task_name, 1, RTEMS_MINIMUM_STACK_SIZE * 10,
    RTEMS_DEFAULT_MODES ,
    RTEMS_FLOATING_POINT | RTEMS_DEFAULT_ATTRIBUTES, &Task_id
  );

  status = rtems_task_start( Task_id, user_task, 1 );
  status = rtems_task_delete( RTEMS_SELF );
}

/* configuration information */
#define CONFIGURE_APPLICATION_NEEDS_CLOCK_DRIVER
#define CONFIGURE_APPLICATION_NEEDS_CONSOLE_DRIVER

#define CONFIGURE_RTEMS_INIT_TASKS_TABLE
#define CONFIGURE_MAXIMUM_TASKS 10

#define CONFIGURE_INIT

#include <rtems/confdefs.h>



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值