[101] | 1 | /*-----------------------------------------------------------------------------
|
---|
| 2 | * TOPPERS/SSP Windows Debug Environment
|
---|
| 3 | * Copyright (C) 2014 Cores Co., Ltd. Japan
|
---|
| 4 | *-----------------------------------------------------------------------------
|
---|
| 5 | * $Id: target_support.c 108 2015-06-11 09:15:46Z coas-nagasima $
|
---|
| 6 | */
|
---|
| 7 |
|
---|
| 8 | /*
|
---|
| 9 | * ターゲットシステム依存モジュール(AP-RX62N-0A用)
|
---|
| 10 | */
|
---|
| 11 |
|
---|
| 12 | #include "kernel_impl.h"
|
---|
| 13 | #include <sil.h>
|
---|
| 14 |
|
---|
| 15 | void hardware_init_hook()
|
---|
| 16 | {
|
---|
| 17 | /*
|
---|
| 18 | * 動作モード設定
|
---|
| 19 | *
|
---|
| 20 | * 動作モードはボード上の端子によって決定されるため,
|
---|
| 21 | * ここでは特別設定しない.
|
---|
| 22 | * ただし, リトルエンディアン/シングルチップモード
|
---|
| 23 | * であることを前提とする.
|
---|
| 24 | *
|
---|
| 25 | * またリセット後, 内蔵ROM:有効, 内蔵RAM:有効, 外部バス:無効
|
---|
| 26 | * である.
|
---|
| 27 | */
|
---|
| 28 |
|
---|
| 29 | /*
|
---|
| 30 | * クロック設定
|
---|
| 31 | *
|
---|
| 32 | * 入力:12MHz
|
---|
| 33 | * PLL回路:12 x 8 = 96MHz
|
---|
| 34 | * システムクロック:96MHz
|
---|
| 35 | * 周辺モジュールクロック:48MHz
|
---|
| 36 | * 外部バスクロック:96MHz
|
---|
| 37 | * とする.
|
---|
| 38 | */
|
---|
| 39 | sil_wrb_mem(PORT3_PDR_ADDR,
|
---|
| 40 | sil_reb_mem(PORT3_PDR_ADDR) & ~PORT_PDR_B6_BIT);
|
---|
| 41 | sil_wrb_mem(PORT3_PDR_ADDR,
|
---|
| 42 | sil_reb_mem(PORT3_PDR_ADDR) & ~PORT_PDR_B7_BIT);
|
---|
| 43 | sil_wrb_mem(PORT3_PMR_ADDR,
|
---|
| 44 | sil_reb_mem(PORT3_PMR_ADDR) & ~PORT_PDR_B6_BIT);
|
---|
| 45 | sil_wrb_mem(PORT3_PMR_ADDR,
|
---|
| 46 | sil_reb_mem(PORT3_PMR_ADDR) & ~PORT_PDR_B7_BIT);
|
---|
| 47 |
|
---|
| 48 | sil_wrh_mem(SYSTEM_PRCR_ADDR, 0xa503);
|
---|
| 49 |
|
---|
| 50 | /* メインクロック発振器強制発振 */
|
---|
| 51 | while((sil_reb_mem(SYSTEM_MOFCR_ADDR) & SYSTEM_MOFCR_MOFXIN) == 0)
|
---|
| 52 | sil_wrb_mem(SYSTEM_MOFCR_ADDR,
|
---|
| 53 | sil_reb_mem(SYSTEM_MOFCR_ADDR) | SYSTEM_MOFCR_MOFXIN);
|
---|
| 54 |
|
---|
| 55 | /* メインクロック発振器動作 */
|
---|
| 56 | while((sil_reb_mem(SYSTEM_MOSCCR_ADDR) & SYSTEM_MOSCCR_MOSTP) != 0)
|
---|
| 57 | sil_wrb_mem(SYSTEM_MOSCCR_ADDR,
|
---|
| 58 | sil_reb_mem(SYSTEM_MOSCCR_ADDR) & ~SYSTEM_MOSCCR_MOSTP);
|
---|
| 59 |
|
---|
| 60 | sil_wrh_mem(SYSTEM_PLLCR_ADDR,
|
---|
| 61 | (sil_reh_mem(SYSTEM_PLLCR_ADDR) & ~SYSTEM_PLLCR_STC_MASK)
|
---|
| 62 | | (0x0f << SYSTEM_PLLCR_STC_OFFSET));
|
---|
| 63 |
|
---|
| 64 | sil_wrb_mem(SYSTEM_PLLCR2_ADDR,
|
---|
| 65 | sil_reb_mem(SYSTEM_PLLCR2_ADDR) & ~SYSTEM_PLLCR2_PLLEN);
|
---|
| 66 |
|
---|
| 67 | sil_wrw_mem(SYSTEM_SCKCR_ADDR, 0x21021211);
|
---|
| 68 |
|
---|
| 69 | /* PLL回路選択 */
|
---|
| 70 | sil_wrh_mem(SYSTEM_SCKCR3_ADDR,
|
---|
| 71 | (sil_reh_mem(SYSTEM_SCKCR3_ADDR) & ~SYSTEM_SCKCR3_CKSEL_MASK)
|
---|
| 72 | | (4 << SYSTEM_SCKCR3_CKSEL_OFFSET));
|
---|
| 73 |
|
---|
| 74 | /*
|
---|
| 75 | * モジュールストップ
|
---|
| 76 | *
|
---|
| 77 | * リセット後, 動作している内蔵周辺モジュールはDMAC, DTC,
|
---|
| 78 | * 内蔵RAMのみである.
|
---|
| 79 | * それ以外の内蔵周辺モジュールに関しては使用する側で
|
---|
| 80 | * 設定すること.
|
---|
| 81 | */
|
---|
| 82 | sil_wrh_mem(SYSTEM_PRCR_ADDR, 0xa500);
|
---|
| 83 | }
|
---|
| 84 |
|
---|
| 85 | void software_init_hook()
|
---|
| 86 | {
|
---|
| 87 | /*
|
---|
| 88 | * 本コンパイラではweak definitionの機能が無いため,
|
---|
| 89 | * 特に必要な処理はないが, 必ず呼び出すこととする.
|
---|
| 90 | */
|
---|
| 91 | }
|
---|