SDCCでは、PDATA変数をアクセスするための_XPAGEの定義は必須と考えたほうが良いかもしれない。_XPAGEが未定義である場合はMCS51の伝統に従い_XPAGE = 0xA0と仮定することによる誤動作の可能性がある。
初期化指定子がないPDATA/XDATA変数が存在する場合、lib/src/mcs51/crtxclear.asmにて_XPAGE定義が参照され初期化(ゼロクリア)される。
_XPAGEが未定義である場合、アドレス(0xA0)のSFRレジスタが間違ってアクセスされることによる誤動作に加え、PDATA/XDATA変数が正しく初期化されないという不具合が発生する可能性がある。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 |
;-------------------------------------------------------------------------- ; crtxclear.asm - C run-time: clear XSEG ; ; Copyright (C) 2004, Erik Petrich ; ; This library is free software; you can redistribute it and/or modify it ; under the terms of the GNU General Public License as published by the ; Free Software Foundation; either version 2, or (at your option) any ; later version. ; ; This library is distributed in the hope that it will be useful, ; but WITHOUT ANY WARRANTY; without even the implied warranty of ; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the ; GNU General Public License for more details. ; ; You should have received a copy of the GNU General Public License ; along with this library; see the file COPYING. If not, write to the ; Free Software Foundation, 51 Franklin Street, Fifth Floor, Boston, ; MA 02110-1301, USA. ; ; As a special exception, if you link this library with other files, ; some of which are compiled with SDCC, to produce an executable, ; this library does not by itself cause the resulting executable to ; be covered by the GNU General Public License. This exception does ; not however invalidate any other reasons why the executable file ; might be covered by the GNU General Public License. ;-------------------------------------------------------------------------- .area CSEG (CODE) .area GSINIT0 (CODE) .area GSINIT1 (CODE) .area GSINIT2 (CODE) .area GSINIT3 (CODE) .area GSINIT4 (CODE) .area GSINIT5 (CODE) .area GSINIT (CODE) .area GSFINAL (CODE) .area GSINIT4 (CODE) __mcs51_genXRAMCLEAR:: mov r0,#l_PSEG mov a,r0 orl a,#(l_PSEG >> 8) jz 00006$ mov r1,#s_PSEG mov __XPAGE,#(s_PSEG >> 8) clr a 00005$: movx @r1,a inc r1 djnz r0,00005$ 00006$: mov r0,#l_XSEG mov a,r0 orl a,#(l_XSEG >> 8) jz 00008$ mov r1,#((l_XSEG + 255) >> 8) mov dptr,#s_XSEG clr a 00007$: movx @dptr,a inc dptr djnz r0,00007$ djnz r1,00007$ 00008$: |
初期化指定子があるPDATA/XDATA変数が存在する場合、lib/src/mcs51/crtxinit.asmにて_XPAGE定義を参照するコードが実行される。_XPAGEが未定義である場合、アドレス(0xA0)のSFRレジスタが間違ってアクセスされることによる誤動作に加え、初期化指定子があるPDATA/XDATA変数が正しく初期化されないという不具合が発生する可能性がある。
[nRF24LE1]
SDKではPAGEレジスタがMPAGEとして定義されているため_XPAGEをMPAGEと同じアドレスで追加定義する必要がある。これはPDATA変数を正しく処理するためにも必須である。
何も対処せずに初期化指定子があるPDATA/XDATA変数を使用した場合、誤ってP2ポート(QFN48のみ)がアクセスされることによる誤動作や初期化指定子があるPDATA/XDATA変数が初期化されないという不具合が発生する。
[nRF24LU1P]
SDCCのlib/src/mcs51/crtxinit.asmソース内のDUAL_DPTRの値を0から1に書き換えた後アセンブルしその.relをリンカーの最後のパラメタとして指定する必要がある。
何も対処せずに初期化指定子があるPDATA/XDATA変数を使用した場合、誤ってUSBCONレジスタがアクセスされることによる誤動作や初期化指定子があるPDATA/XDATA変数が初期化されないという不具合が発生する。
※PAGEレジスタが存在しないためPDATA変数が使えないことは当然であるが複数の不具合が同時発生するとデバッグが困難になるため想定外のHW誤動作だけは防ぐという意味で未使用のSFRアドレスを_XPAGEとして定義することは良いことかもしれない。
以上、SDCCでMCS51するさいの参考にでもなれば幸いです。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 |
;-------------------------------------------------------------------------- ; crtxinit.asm :- C run-time: copy XINIT to XISEG ; ; Copyright (C) 2004, Erik Petrich ; ; This library is free software; you can redistribute it and/or modify it ; under the terms of the GNU General Public License as published by the ; Free Software Foundation; either version 2, or (at your option) any ; later version. ; ; This library is distributed in the hope that it will be useful, ; but WITHOUT ANY WARRANTY; without even the implied warranty of ; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the ; GNU General Public License for more details. ; ; You should have received a copy of the GNU General Public License ; along with this library; see the file COPYING. If not, write to the ; Free Software Foundation, 51 Franklin Street, Fifth Floor, Boston, ; MA 02110-1301, USA. ; ; As a special exception, if you link this library with other files, ; some of which are compiled with SDCC, to produce an executable, ; this library does not by itself cause the resulting executable to ; be covered by the GNU General Public License. This exception does ; not however invalidate any other reasons why the executable file ; might be covered by the GNU General Public License. ;-------------------------------------------------------------------------- ; Set DUAL_DPTR to 1 and reassemble if your derivative has dual data pointers ; Especially useful if movx @Ri cannot go beyond the first 256 bytes of xdata ; due to lack of P2 or _XPAGE ; If the derivative has auto-toggle or auto-increment it can be further optimized DUAL_DPTR = 0 <<<==== Modify to DUAL_DPTR = 1 .area CSEG (CODE) .area GSINIT0 (CODE) .area GSINIT1 (CODE) .area GSINIT2 (CODE) .area GSINIT3 (CODE) .area GSINIT4 (CODE) .area GSINIT5 (CODE) .area GSINIT (CODE) .area GSFINAL (CODE) .area GSINIT3 (CODE) .if DUAL_DPTR .globl _DPS ; assume DPSEL is in DPS bit0 __mcs51_genXINIT:: mov r1,#l_XINIT mov a,r1 orl a,#(l_XINIT >> 8) jz 00003$ mov r2,#((l_XINIT+255) >> 8) orl _DPS,#0x01 ; set DPSEL, select DPTR1 mov dptr,#s_XINIT ; DPTR1 for code dec _DPS ; clear DPSEL, select DPTR0 mov dptr,#s_XISEG ; DPTR0 for xdata 00001$: clr a inc _DPS ; set DPSEL, select DPTR1 movc a,@a+dptr inc dptr dec _DPS ; clear DPSEL, select DPTR0 movx @dptr,a inc dptr djnz r1,00001$ djnz r2,00001$ 00003$: .else .globl __XPAGE __mcs51_genXINIT:: mov r1,#l_XINIT mov a,r1 orl a,#(l_XINIT >> 8) jz 00003$ mov r2,#((l_XINIT+255) >> 8) mov dptr,#s_XINIT mov r0,#s_XISEG mov __XPAGE,#(s_XISEG >> 8) 00001$: clr a movc a,@a+dptr movx @r0,a inc dptr inc r0 cjne r0,#0,00002$ inc __XPAGE 00002$: djnz r1,00001$ djnz r2,00001$ mov __XPAGE,#0xFF 00003$: .endif |