/* * TOPPERS/ASP Kernel * Toyohashi Open Platform for Embedded Real-Time Systems/ * Advanced Standard Profile Kernel * * Copyright (C) 2000-2003 by Embedded and Real-Time Systems Laboratory * Toyohashi Univ. of Technology, JAPAN * Copyright (C) 2005-2007 by Embedded and Real-Time Systems Laboratory * Graduate School of Information Science, Nagoya Univ., JAPAN * * 上記著作権者は,以下の(1)〜(4)の条件を満たす場合に限り,本ソフトウェ * ア(本ソフトウェアを改変したものを含む.以下同じ)を使用・複製・改 * 変・再配布(以下,利用と呼ぶ)することを無償で許諾する. * (1) 本ソフトウェアをソースコードの形で利用する場合には,上記の著作 * 権表示,この利用条件および下記の無保証規定が,そのままの形でソー * スコード中に含まれていること. * (2) 本ソフトウェアを,ライブラリ形式など,他のソフトウェア開発に使 * 用できる形で再配布する場合には,再配布に伴うドキュメント(利用 * 者マニュアルなど)に,上記の著作権表示,この利用条件および下記 * の無保証規定を掲載すること. * (3) 本ソフトウェアを,機器に組み込むなど,他のソフトウェア開発に使 * 用できない形で再配布する場合には,次のいずれかの条件を満たすこ * と. * (a) 再配布に伴うドキュメント(利用者マニュアルなど)に,上記の著 * 作権表示,この利用条件および下記の無保証規定を掲載すること. * (b) 再配布の形態を,別に定める方法によって,TOPPERSプロジェクトに * 報告すること. * (4) 本ソフトウェアの利用により直接的または間接的に生じるいかなる損 * 害からも,上記著作権者およびTOPPERSプロジェクトを免責すること. * また,本ソフトウェアのユーザまたはエンドユーザからのいかなる理 * 由に基づく請求からも,上記著作権者およびTOPPERSプロジェクトを * 免責すること. * * 本ソフトウェアは,無保証で提供されているものである.上記著作権者お * よびTOPPERSプロジェクトは,本ソフトウェアに関して,特定の使用目的 * に対する適合性も含めて,いかなる保証も行わない.また,本ソフトウェ * アの利用により直接的または間接的に生じたいかなる損害に関しても,そ * の責任を負わない. * */ /* * ターゲット依存モジュール(STM32 DISCOVERY用) */ #include "kernel_impl.h" #include #include "stm32_discovery.h" #include "target_serial.h" #include "target_syssvc.h" STK_T _target_istk[DEFAULT_ISTKSZ]; /* * GPIOレジスタ操作関数 */ #pragma inline void set_cr_mode(uint32_t reg, uint_t p, int_t v) { if (p < 8) { sil_andw((void*)GPIO_CRL(reg), ~CR_MODE_MASK(p)); sil_orw((void*)GPIO_CRL(reg), CR_MODE(p, v)); } else if (8 <= p && p < 16) { sil_andw((void*)GPIO_CRH(reg), ~CR_MODE_MASK(p - 8)); sil_orw((void*)GPIO_CRH(reg), CR_MODE(p - 8, v)); } } #pragma inline void set_cr_cnf(uint32_t reg, uint_t p, int_t v) { if (p < 8) { sil_andw((void*)GPIO_CRL(reg), ~CR_CNF_MASK(p)); sil_orw((void*)GPIO_CRL(reg), CR_CNF(p, v)); } else if (8 <= p && p < 16) { sil_andw((void*)GPIO_CRH(reg), ~CR_CNF_MASK(p - 8)); sil_orw((void*)GPIO_CRH(reg), CR_CNF(p - 8, v)); } } #pragma inline void set_port_pull(uint32_t reg, uint_t p, bool_t up) { if (up) { sil_wrw_mem((void*)GPIO_BSRR(reg), 0x01 << p); } else { sil_wrw_mem((void*)GPIO_BRR(reg), 0x01 << p); } } /* * ターゲット依存部 初期化処理 */ void target_initialize(void) { /* * プロセッサクロック(RCC)の初期化 */ /* HSEの有効化 */ sil_orw((void*)RCC_CR, CR_HSE_ON); /* HSE有効待ち */ while ((sil_rew_mem((void*)RCC_CR) & CR_HSE_RDY) == 0) ; /* FLASH ROMは2wait待ち */ sil_andw((void*)FLASH_ACR, ~ACR_LATENCY_MASK); sil_orw((void*)FLASH_ACR, ACR_LATENCY_TWO); /* HCLK = SYSCLK, PCLK2 = HCLK, PCLK1 = HCLK/2 */ sil_orw((void*)RCC_CFGR, 0x00 | (0x01 << 17) | (0x00 << 11) | (0x04 << 8)); /* PLLCLK = 4MHz x 6 = 24, HSE as PLL clock */ sil_orw((void*)RCC_CFGR, 0x04 << 18); sil_orw((void*)RCC_CFGR, CFGR_PLL_SRC); /* PLLの有効化 */ sil_orw((void*)RCC_CR, CR_PLL_ON); /* PLL有効待ち */ while ((sil_rew_mem((void*)RCC_CR) & CR_PLL_RDY) == 0) ; /* PLLをシステムクロックに選択 */ sil_orw((void*)RCC_CFGR, CFGR_SW_PLL); /* PLLのシステムクロック選択待ち */ while ((sil_rew_mem((void*)RCC_CFGR) & CFGR_SWS_MASK) != (CFGR_SW_PLL << 2)) ; /* * プロセッサ依存部の初期化 */ core_initialize(); /* * ペリフェラルの有効化 */ sil_orw((void*)RCC_APB2ENR, APB2ENR_USART1_EN | APB2ENR_IOPA_EN | APB2ENR_IOPC_EN | APB2ENR_AFIO_EN); /* * I/Oポートの初期化 */ /* USART1(RX) プルアップ */ set_cr_mode(GPIOA_BASE, 10, MODE_INPUT); set_cr_cnf(GPIOA_BASE, 10, CNF_IN_FLOATING); /* USART1(TX) */ set_cr_mode(GPIOA_BASE, 9, MODE_OUTPUT_50MHZ); set_cr_cnf(GPIOA_BASE, 9, CNF_OUT_AF_PP); /* LEDポート */ set_cr_mode(GPIOC_BASE, 9, MODE_OUTPUT_50MHZ); set_cr_cnf(GPIOC_BASE, 9, CNF_OUT_GP_PP); /* * バーナー出力用のシリアル初期化 */ target_usart_init(SIO_PORTID); } /* * ターゲット依存部 終了処理 */ void target_exit(void) { /* プロセッサ依存部の終了処理 */ core_terminate(); } /* * システムログの低レベル出力のための文字出力 */ void target_fput_log(char_t c) { if (c == '\n') { sio_pol_snd_chr('\r', SIO_PORTID); } sio_pol_snd_chr(c, SIO_PORTID); }