EEL pack02のメモリに関して

Former Member
Former Member

環境はCS+ for CC V8.01.00 [03 Dec 2018]  / CC-RL V1.08.00   /R5F100AE  /EEL pack02使用です。

セルフRAMリスト(R20UT2943JJ0302)を参照してFEF00H-FF07FHを空けてmapファイルは下記の状態です。

.monitor2   0000fe00 0000ffff 200 1
.dataR        000ff080 000ff160 e1 2
.bss           000ff162 000ffe05 ca4 2
.sdataR      000ffe20 000ffe20 0 2
.sbss          000ffe20 000ffe20 0 2
EEL_SDAT  000ffe20 000ffe20 1 2
FDL_SDAT  000ffe22 000ffe23 2 2

このときに関数の引数や関数内の変数がFF020HなどFEF00H-FF07FHの中に配置されることがあります。

EEL_ERR_INTERNALやRefreshの失敗などが起こっていて、これが原因だと思っています。

map上だと未使用に見えるのですが、セクション指定が足りないなどあるのでしょうか?

Parents
  • Former Member
    Former Member
    わわいさん
    ありがとうございます。
    cstart.asmの MOVW SP,#LOWW(__STACK_ADDR_START)で
    任意にアドレスに設定してSPがそのアドレスに対応するのが確認できました。
    __STACK_ADDR_STARTと__STACK_ADDR_ENDのアドレスはユーザが
    直接指定できるものではないという理解です。
    また、__STACK_ADDR_START~__STACK_ADDR_ENDに関しては
    スタックの初期化を行う際のみ必要で初期化を行わなければサイズは特に関係ないという理解です。
Reply
  • Former Member
    Former Member
    わわいさん
    ありがとうございます。
    cstart.asmの MOVW SP,#LOWW(__STACK_ADDR_START)で
    任意にアドレスに設定してSPがそのアドレスに対応するのが確認できました。
    __STACK_ADDR_STARTと__STACK_ADDR_ENDのアドレスはユーザが
    直接指定できるものではないという理解です。
    また、__STACK_ADDR_START~__STACK_ADDR_ENDに関しては
    スタックの初期化を行う際のみ必要で初期化を行わなければサイズは特に関係ないという理解です。
Children
  • わわいです
    RL78はあんまし使ったことないんでハズしてるところがあるかもですが、、
    スタックのエリアというのはサイズ制限ってのはできません。最初に設定すれば、使った分だけ消費します
    また、__STACK_ADDR_STARTと__STACK_ADDR_ENDですが、ツールチェインのマニュアルになんか記述はないでしょうか。普通はスタックのエリアをどっかで指定するかスタックセクションを定義して、その値が入るとかなんとかなってたと思います

    ややこしければ、そういう機能?は使わないで、自分でcstart.asmを修正して好きな値を設定すればいいです。
    注意すべきは、スタックポインタに設定する値はある程度制限があるのでCPUのマニュアルで確認することですね
    #4バイトアライメントにする必要があるとかなんとか