Ignore:
Timestamp:
Apr 17, 2019, 12:13:00 PM (5 years ago)
Author:
nmir-saito
Message:

modify svn:mimetype of files

File:
1 edited

Legend:

Unmodified
Added
Removed
  • ssp_rpi3/trunk/target/rpi_arm64_gcc/start.S

    • Property svn:mime-type set to text/plain; charset=utf-8
    r384 r386  
    1010 *             Nagoya Municipal Industrial Research Institute, JAPAN
    1111 *
    12  *  上記著作権è€
    13 ã¯ï¼Œä»¥ä¸‹ã®(1)〜(4)の条件を満たす場合に限り,本ソフトウェ
    14  *  ア(本ソフトウェアを改変したものを含む.以下同じ)を使用・複製・改
    15  *  変・再é
    16 å¸ƒï¼ˆä»¥ä¸‹ï¼Œåˆ©ç”¨ã¨å‘¼ã¶ï¼‰ã™ã‚‹ã“とを無償で許諾する.
    17  *  (1) 本ソフトウェアをソースコードの形で利用する場合には,上記の著作
    18  *      権表示,この利用条件および下記の無保証規定が,そのままの形でソー
    19  *      スコード中に含まれていること.
    20  *  (2) 本ソフトウェアを,ライブラリ形式など,他のソフトウェア開発に使
    21  *      用できる形で再é
    22 å¸ƒã™ã‚‹å ´åˆã«ã¯ï¼Œå†é
    23 å¸ƒã«ä¼´ã†ãƒ‰ã‚­ãƒ¥ãƒ¡ãƒ³ãƒˆï¼ˆåˆ©ç”¨
    24  *      è€
    25 ãƒžãƒ‹ãƒ¥ã‚¢ãƒ«ãªã©ï¼‰ã«ï¼Œä¸Šè¨˜ã®è‘—作権表示,この利用条件および下記
    26  *      の無保証規定を掲載すること.
    27  *  (3) 本ソフトウェアを,機器に組み込むなど,他のソフトウェア開発に使
    28  *      用できない形で再é
    29 å¸ƒã™ã‚‹å ´åˆã«ã¯ï¼Œæ¬¡ã®ã„ずれかの条件を満たすこ
    30  *      と.
    31  *    (a) 再é
    32 å¸ƒã«ä¼´ã†ãƒ‰ã‚­ãƒ¥ãƒ¡ãƒ³ãƒˆï¼ˆåˆ©ç”¨è€
    33 ãƒžãƒ‹ãƒ¥ã‚¢ãƒ«ãªã©ï¼‰ã«ï¼Œä¸Šè¨˜ã®è‘—
    34  *        作権表示,この利用条件および下記の無保証規定を掲載すること.
    35  *    (b) 再é
    36 å¸ƒã®å½¢æ
    37 ‹ã‚’,別に定める方法によって,TOPPERSプロジェクトに
    38  *        報告すること.
    39  *  (4) 本ソフトウェアの利用により直接的または間接的に生じるいかなる損
    40  *      害からも,上記著作権è€
    41 ãŠã‚ˆã³TOPPERSプロジェクトをå
    42 è²¬ã™ã‚‹ã“と.
    43  *      また,本ソフトウェアのユーザまたはエンドユーザからのいかなる理
    44  *      由に基づく請求からも,上記著作権è€
    45 ãŠã‚ˆã³TOPPERSプロジェクトを
    46  *      å
    47 è²¬ã™ã‚‹ã“と.
     12 *  上記著作権者は,以下の(1)〜(4)の条件を満たす場合に限り,本ソフトウェ
     13 *  ア(本ソフトウェアを改変したものを含む.以下同じ)を使用・複製・改
     14 *  変・再配布(以下,利用と呼ぶ)することを無償で許諾する.
     15 *  (1) 本ソフトウェアをソースコードの形で利用する場合には,上記の著作
     16 *      権表示,この利用条件および下記の無保証規定が,そのままの形でソー
     17 *      スコード中に含まれていること.
     18 *  (2) 本ソフトウェアを,ライブラリ形式など,他のソフトウェア開発に使
     19 *      用できる形で再配布する場合には,再配布に伴うドキュメント(利用
     20 *      者マニュアルなど)に,上記の著作権表示,この利用条件および下記
     21 *      の無保証規定を掲載すること.
     22 *  (3) 本ソフトウェアを,機器に組み込むなど,他のソフトウェア開発に使
     23 *      用できない形で再配布する場合には,次のいずれかの条件を満たすこ
     24 *      と.
     25 *    (a) 再配布に伴うドキュメント(利用者マニュアルなど)に,上記の著
     26 *        作権表示,この利用条件および下記の無保証規定を掲載すること.
     27 *    (b) 再配布の形態を,別に定める方法によって,TOPPERSプロジェクトに
     28 *        報告すること.
     29 *  (4) 本ソフトウェアの利用により直接的または間接的に生じるいかなる損
     30 *      害からも,上記著作権者およびTOPPERSプロジェクトを免責すること.
     31 *      また,本ソフトウェアのユーザまたはエンドユーザからのいかなる理
     32 *      由に基づく請求からも,上記著作権者およびTOPPERSプロジェクトを
     33 *      免責すること.
    4834 *
    49  *  本ソフトウェアは,無保証で提供されているものである.上記著作権è€
    50 ãŠ
    51  *  よびTOPPERSプロジェクトは,本ソフトウェアに関して,特定の使用目的
    52  *  に対する適合性も含めて,いかなる保証も行わない.また,本ソフトウェ
    53  *  アの利用により直接的または間接的に生じたいかなる損害に関しても,そ
    54  *  の責任を負わない.
     35 *  本ソフトウェアは,無保証で提供されているものである.上記著作権者お
     36 *  よびTOPPERSプロジェクトは,本ソフトウェアに関して,特定の使用目的
     37 *  に対する適合性も含めて,いかなる保証も行わない.また,本ソフトウェ
     38 *  アの利用により直接的または間接的に生じたいかなる損害に関しても,そ
     39 *  の責任を負わない.
    5540 *
    5641 *  $Id$
     
    5843
    5944#define TOPPERS_MACRO_ONLY
    60 #define UINT64_C(val)   (val)           /* uint64_t型の定数を作るマクロ */
     45#define UINT64_C(val)   (val)           /* uint64_t型の定数を作るマクロ */
    6146#include "kernel_impl.h"
    6247
     
    6651    .global vectors
    6752start:
    68     // コア0のみ利用
     53    // コア0のみ利用
    6954    mrs x0, mpidr_el1
    7055    and x0, x0, #3
    7156    cbz x0, 2f
    72571:
    73     // コア0以外
     58    // コア0以外
    7459    wfi
    7560    b   1b
    76612:
    77     // これ以降はコア0のみ
     62    // これ以降はコア0のみ
    7863    msr daifset, #(AARCH64_DAIF_IRQ | AARCH64_DAIF_FIQ)      // CPSR.{I,F}=1
    7964
    8065    /*
    81      * スタックå
    82 ˆé ­ç•ªåœ°ã‚’取り出しておく
     66     * スタック先頭番地を取り出しておく
    8367     */
    8468    adrp x1, _kernel_istkpt
     
    8771
    8872    /*
    89      *  EL毎の処理
     73     *  EL毎の処理
    9074     */
    9175    mrs x0, CurrentEL
     
    10690    msr CNTFRQ_EL0, x0
    10791
    108     // EL2へ移行
     92    // EL2へ移行
    10993    mov x2, #0x0c9    // I=F=1, MODE=1001 (EL2h)
    11094    msr spsr_el3, x2
     
    133117    isb
    134118
    135     // EL1へ移行
     119    // EL1へ移行
    136120    mov x2, #0x0c5         // I,F=1, mode=0101(EL1h)
    137121    msr spsr_el2, x2
     
    144128     */
    145129start_el1:
    146     // スタックポインタとフレームポインタの初期化
     130    // スタックポインタとフレームポインタの初期化
    147131    mov sp, x1
    148132    mov x29, xzr
    149133
    150134    /*
    151      *  例外ベクタテーブルのベースアドレス設定
     135     *  例外ベクタテーブルのベースアドレス設定
    152136     */
    153137    ldr x0, =vectors
     
    155139
    156140    /*
    157      *  bssセクションのクリア
     141     *  bssセクションのクリア
    158142     */
    159143    ldr   x1, =__start_bss
     
    1681524:
    169153    /*
    170      *  sta_ker呼び出し
     154     *  sta_ker呼び出し
    171155     */
    172156    bl sta_ker
Note: See TracChangeset for help on using the changeset viewer.