AWTK 在騰訊 TOS 上的移植筆記

AWTK 在騰訊 TOS 上的移植筆記

本文以 STM32f103ze 爲例,介紹了 AWTK 在 RTOS 上移植的經驗。與其說移植,倒不如說是集成。由於 RTOS 一般沒有提供標準的 LCD 驅動接口,顯示部分並不須要特別的改動。所作的事情不過是把 AWTK 放到 RTOS 的一個線程中執行而已。git

1. 加入 TOS 相關文件。

AWTK 已經移植到 STM32f103ze 裸系統上,爲了簡單起見,直接在 awtk-stm32f103ze-raw 基礎上加入 TOS 支持。github

  • 在 Keil 中增長下列文件:
TencentOS/kernel/core/tos_event.c
TencentOS/kernel/core/tos_fifo.c
TencentOS/kernel/core/tos_global.c
TencentOS/kernel/core/tos_mmblk.c
TencentOS/kernel/core/tos_mmheap.c
TencentOS/kernel/core/tos_msg.c
TencentOS/kernel/core/tos_mutex.c
TencentOS/kernel/core/tos_pend.c
TencentOS/kernel/core/tos_queue.c
TencentOS/kernel/core/tos_robin.c
TencentOS/kernel/core/tos_sched.c
TencentOS/kernel/core/tos_sem.c
TencentOS/kernel/core/tos_sys.c
TencentOS/kernel/core/tos_task.c
TencentOS/kernel/core/tos_tick.c
TencentOS/kernel/core/tos_time.c
TencentOS/kernel/core/tos_timer.c
TencentOS/kernel/pm/tos_pm.c
TencentOS/kernel/pm/tos_tickless.c
TencentOS/arch/arm/arm-v7m/common/tos_cpu.c
TencentOS/arch/arm/arm-v7m/common/tos_fault.c
TencentOS/arch/arm/arm-v7m/cortex-m3/armcc/port_c.c
TencentOS/arch/arm/arm-v7m/cortex-m3/armcc/port_s.S
  • 增長 include 的路徑
TencentOS/arch/arm/arm-v7m/common/include
TencentOS/arch/arm/arm-v7m/cortex-m3/armcc
TencentOS/kernel/core/include
TencentOS/kernel/hal/include
TencentOS/kernel/pm/include
TencentOS/TOS-CONFIG
  • 修改配置文件

根據本身的須要修改配置 TencentOS/TOS-CONFIG/tos_config.h:app

通常來講不須要修改,使用官方提供的便可。我用的是 TencentOS-Demo 項目中的。less

2. 加入針對 TOS 實現的線程和同步的函數。

src/platforms/tos/mutex.c
src/platforms/tos/semaphore.c
src/platforms/tos/thread.c
src/platforms/common/sys_tick.c

3. 實現 rtos.c

主要就是 SysTick 中斷的實現,從 TencentOS-Demo 中拷貝過來就好了。函數

ret_t rtos_init(void) {
  tos_knl_init();
  tos_robin_config(TOS_ROBIN_STATE_ENABLED, (k_timeslice_t)500u);

  return RET_OK;
}

ret_t rtos_start(void) {
  tos_knl_start();

  return RET_OK;
}

void rtos_tick(void) {
  if (tos_knl_is_running()) {
    tos_knl_irq_enter();
    tos_tick_handler();
    tos_knl_irq_leave();
  }
}

void rtos_delay(uint32_t ms) {
  tos_task_delay(ms);
}

4. 在線程中啓動 AWTK

void* awtk_thread(void* args) {
  gui_app_start(320, 480);

  return NULL;
}

static ret_t awtk_start_ui_thread(void) {
  tk_thread_t* ui_thread = tk_thread_create(awtk_thread, NULL);
  return_value_if_fail(ui_thread != NULL, RET_BAD_PARAMS);

  tk_thread_set_priority(ui_thread, 3);
  tk_thread_set_name(ui_thread, "awtk");
  tk_thread_set_stack_size(ui_thread, 2048);

  return tk_thread_start(ui_thread);
}

int main() {
  hardware_prepare();
  platform_prepare();

  rtos_init();
  awtk_start_ui_thread();
  rtos_start();
	
	return 0;
}

這裏與裸系統不一樣的地方,主要有兩個:ui

    1. 在線程中啓動 AWTK。
    1. 要提早調用 platform_prepare,platform_prepare 負責初始化內存,放在 tk_init 中就有些晚,須要單獨提出來調用。

爲此 platform_prepare 函數作了防重複調用的處理。線程

static bool_t s_inited = FALSE;
static uint32_t s_heam_mem[4096];

ret_t platform_prepare(void) {
	if(!s_inited) {
		s_inited = TRUE;
    tk_mem_init(s_heam_mem, sizeof(s_heam_mem));
	}
  return RET_OK;
}

AWTK 集成 RTOS 是很是簡單的,以上過程大概花了 2 個小時吧。只要 RTOS 自己好移植,集成 AWTK 和 RTOS 只是分分鐘的問題。code

相關文章
相關標籤/搜索