📄 iccpdir.src
字号:
; .\out_sst89e564\iccpdir.SRC generated from: source\iccpdir.c
; COMPILER INVOKED BY:
; C:\Keil\C51\BIN\C51.EXE source\iccpdir.c LARGE BROWSE ORDER NOAREGS DEBUG OBJECTEXTEND PRINT(.\iccpdir.lst) SRC(.\out_sst89e564\iccpdir.SRC)
$NOMOD51
NAME ICCPDIR
P0 DATA 080H
SP DATA 081H
DPL DATA 082H
DPH DATA 083H
PCON DATA 087H
TCON DATA 088H
TMOD DATA 089H
TL0 DATA 08AH
TL1 DATA 08BH
TH0 DATA 08CH
TH1 DATA 08DH
P1 DATA 090H
SCON DATA 098H
SBUF DATA 099H
P2 DATA 0A0H
IE DATA 0A8H
P3 DATA 0B0H
IP DATA 0B8H
T2CON DATA 0C8H
T2MOD DATA 0C9H
RCAP2L DATA 0CAH
RCAP2H DATA 0CBH
TL2 DATA 0CCH
TH2 DATA 0CDH
PSW DATA 0D0H
ACC DATA 0E0H
B DATA 0F0H
P0_0 BIT 080H.0
P0_1 BIT 080H.1
P0_2 BIT 080H.2
P0_3 BIT 080H.3
P0_4 BIT 080H.4
P0_5 BIT 080H.5
P0_6 BIT 080H.6
P0_7 BIT 080H.7
IT0 BIT 088H.0
IE0 BIT 088H.1
IT1 BIT 088H.2
IE1 BIT 088H.3
TR0 BIT 088H.4
TF0 BIT 088H.5
TR1 BIT 088H.6
TF1 BIT 088H.7
P1_0 BIT 090H.0
P1_1 BIT 090H.1
P1_2 BIT 090H.2
P1_3 BIT 090H.3
P1_4 BIT 090H.4
P1_5 BIT 090H.5
P1_6 BIT 090H.6
P1_7 BIT 090H.7
T2 BIT 090H.0
T2EX BIT 090H.1
RI BIT 098H.0
TI BIT 098H.1
RB8 BIT 098H.2
TB8 BIT 098H.3
REN BIT 098H.4
SM2 BIT 098H.5
SM1 BIT 098H.6
SM0 BIT 098H.7
P2_0 BIT 0A0H.0
P2_1 BIT 0A0H.1
P2_2 BIT 0A0H.2
P2_3 BIT 0A0H.3
P2_4 BIT 0A0H.4
P2_5 BIT 0A0H.5
P2_6 BIT 0A0H.6
P2_7 BIT 0A0H.7
EX0 BIT 0A8H.0
ET0 BIT 0A8H.1
EX1 BIT 0A8H.2
ET1 BIT 0A8H.3
ES BIT 0A8H.4
ET2 BIT 0A8H.5
EA BIT 0A8H.7
P3_0 BIT 0B0H.0
P3_1 BIT 0B0H.1
P3_2 BIT 0B0H.2
P3_3 BIT 0B0H.3
P3_4 BIT 0B0H.4
P3_5 BIT 0B0H.5
P3_6 BIT 0B0H.6
P3_7 BIT 0B0H.7
RXD BIT 0B0H.0
TXD BIT 0B0H.1
INT0 BIT 0B0H.2
INT1 BIT 0B0H.3
T0 BIT 0B0H.4
T1 BIT 0B0H.5
WR BIT 0B0H.6
RD BIT 0B0H.7
PX0 BIT 0B8H.0
PT0 BIT 0B8H.1
PX1 BIT 0B8H.2
PT1 BIT 0B8H.3
PS BIT 0B8H.4
PT2 BIT 0B8H.5
CP_RL2 BIT 0C8H.0
C_T2 BIT 0C8H.1
TR2 BIT 0C8H.2
EXEN2 BIT 0C8H.3
TCLK BIT 0C8H.4
RCLK BIT 0C8H.5
EXF2 BIT 0C8H.6
TF2 BIT 0C8H.7
P BIT 0D0H.0
FL BIT 0D0H.1
OV BIT 0D0H.2
RS0 BIT 0D0H.3
RS1 BIT 0D0H.4
F0 BIT 0D0H.5
AC BIT 0D0H.6
CY BIT 0D0H.7
FST DATA 0B6H
WDTC DATA 0C0H
WDTD DATA 085H
AUXR DATA 08EH
AUXR1 DATA 0A2H
WDTRST DATA 0A6H
WDTPRG DATA 0A7H
SADDR DATA 0A9H
IPH DATA 0B7H
IPH0 DATA 0B7H
SADEN DATA 0B9H
IPL DATA 0B8H
IPL0 DATA 0B8H
CCON DATA 0D8H
CMOD DATA 0D9H
CCAPM0 DATA 0DAH
CCAPM1 DATA 0DBH
CCAPM2 DATA 0DCH
CCAPM3 DATA 0DDH
CCAPM4 DATA 0DEH
P5 DATA 0E8H
CL DATA 0E9H
CCAP0L DATA 0EAH
CCAP1L DATA 0EBH
CCAP2L DATA 0ECH
CCAP3L DATA 0EDH
CCAP4L DATA 0EEH
CH DATA 0F9H
CCAP0H DATA 0FAH
CCAP1H DATA 0FBH
CCAP2H DATA 0FCH
CCAP3H DATA 0FDH
CCAP4H DATA 0FEH
?PR?iccgetputonebit?ICCPDIR SEGMENT CODE
?BI?iccgetputonebit?ICCPDIR SEGMENT BIT OVERLAYABLE
?PR?TxRxdata?ICCPDIR SEGMENT CODE
?PR?_GetInputData?ICCPDIR SEGMENT CODE
?PR?_IccInitETU?ICCPDIR SEGMENT CODE
?PR?_IccSelect?ICCPDIR SEGMENT CODE
?PR?_IccRead?ICCPDIR SEGMENT CODE
?XD?_IccRead?ICCPDIR SEGMENT XDATA OVERLAYABLE
?PR?_IccWrite?ICCPDIR SEGMENT CODE
?XD?_IccWrite?ICCPDIR SEGMENT XDATA OVERLAYABLE
?PR?IccClear?ICCPDIR SEGMENT CODE
?PR?_IccSetTimeout?ICCPDIR SEGMENT CODE
?PR?_IccOpen?ICCPDIR SEGMENT CODE
?XD?_IccOpen?ICCPDIR SEGMENT XDATA OVERLAYABLE
?PR?IccInit?ICCPDIR SEGMENT CODE
?PR?IccUserPower?ICCPDIR SEGMENT CODE
?BI?IccUserPower?ICCPDIR SEGMENT BIT OVERLAYABLE
?PR?IccUserTest?ICCPDIR SEGMENT CODE
?PR?IccUserEject?ICCPDIR SEGMENT CODE
?XD?IccUserEject?ICCPDIR SEGMENT XDATA OVERLAYABLE
?PR?IccUserOverLoad?ICCPDIR SEGMENT CODE
?XD?ICCPDIR SEGMENT XDATA
?PR?_IccSyncWRWithACK?ICCPDIR SEGMENT CODE
?XD?_IccSyncWRWithACK?ICCPDIR SEGMENT XDATA OVERLAYABLE
?PR?IccSyncStart?ICCPDIR SEGMENT CODE
?PR?IccSyncStop?ICCPDIR SEGMENT CODE
?PR?_IccSyncPutCharWaitACK?ICCPDIR SEGMENT CODE
?XD?_IccSyncPutCharWaitACK?ICCPDIR SEGMENT XDATA OVERLAYABLE
?BI?_IccSyncPutCharWaitACK?ICCPDIR SEGMENT BIT OVERLAYABLE
?PR?IccSyncGetCharSendACK?ICCPDIR SEGMENT CODE
?XD?IccSyncGetCharSendACK?ICCPDIR SEGMENT XDATA OVERLAYABLE
?BI?IccSyncGetCharSendACK?ICCPDIR SEGMENT BIT OVERLAYABLE
?PR?_IccSyncPutChar?ICCPDIR SEGMENT CODE
?XD?_IccSyncPutChar?ICCPDIR SEGMENT XDATA OVERLAYABLE
?PR?IccSyncGetChar?ICCPDIR SEGMENT CODE
?PR?_IccSyncReset?ICCPDIR SEGMENT CODE
?XD?_IccSyncReset?ICCPDIR SEGMENT XDATA OVERLAYABLE
?PR?_IccSyncPollingIO?ICCPDIR SEGMENT CODE
?XD?_IccSyncPollingIO?ICCPDIR SEGMENT XDATA OVERLAYABLE
?PR?IccSyncClock?ICCPDIR SEGMENT CODE
?C_INITSEG SEGMENT CODE
?CO?ICCPDIR SEGMENT CODE
?DT?ICCPDIR SEGMENT DATA
?BI?ICCPDIR SEGMENT BIT
?ID?ICCPDIR SEGMENT IDATA
?DT?_IccRead?ICCPDIR SEGMENT DATA OVERLAYABLE
?DT?_IccWrite?ICCPDIR SEGMENT DATA OVERLAYABLE
?DT?_IccOpen?ICCPDIR SEGMENT DATA OVERLAYABLE
EXTRN CODE (_delay)
EXTRN CODE (dummy)
EXTRN CODE (GetTickCount)
EXTRN CODE (_InitUserTimer)
EXTRN CODE (_SoftDelayCyl)
EXTRN CODE (_StartCLKO)
EXTRN CODE (_SetIntPri)
EXTRN CODE (?C?CSTPTR)
EXTRN CODE (?C?CLDOPTR)
EXTRN CODE (?C?CLDPTR)
EXTRN CODE (?C?CSTOPTR)
PUBLIC IccSyncClock
PUBLIC _IccSyncPollingIO
PUBLIC _IccSyncReset
PUBLIC IccSyncGetChar
PUBLIC _IccSyncPutChar
PUBLIC ?IccSyncGetCharSendACK?BIT
PUBLIC IccSyncGetCharSendACK
PUBLIC _IccSyncPutCharWaitACK
PUBLIC IccSyncStop
PUBLIC IccSyncStart
PUBLIC ?_IccSyncWRWithACK?BYTE
PUBLIC _IccSyncWRWithACK
PUBLIC IccUserOverLoad
PUBLIC IccUserEject
PUBLIC IccUserTest
PUBLIC ?IccUserPower?BIT
PUBLIC IccUserPower
PUBLIC IccInit
PUBLIC _IccOpen
PUBLIC _IccSetTimeout
PUBLIC IccClear
PUBLIC _IccWrite
PUBLIC _IccRead
PUBLIC _IccSelect
PUBLIC TxRxdata
PUBLIC iccgetputonebit
RSEG ?XD?_IccRead?ICCPDIR
?_IccRead?BYTE:
buf?544: DS 3
ORG 3
len?545: DS 2
RSEG ?XD?_IccWrite?ICCPDIR
?_IccWrite?BYTE:
buf?648: DS 3
ORG 3
len?649: DS 2
RSEG ?XD?_IccOpen?ICCPDIR
?_IccOpen?BYTE:
buf?954: DS 3
RSEG ?XD?IccUserEject?ICCPDIR
?IccUserEject?BYTE:
i?1365: DS 1
RSEG ?BI?IccUserPower?ICCPDIR
?IccUserPower?BIT:
en?1164: DBIT 1
RSEG ?XD?_IccSyncWRWithACK?ICCPDIR
?_IccSyncWRWithACK?BYTE:
wbuf?1567: DS 3
ORG 3
wlen?1568: DS 2
ORG 5
rbuf?1569: DS 3
ORG 8
rlen?1570: DS 2
ORG 10
i?1571: DS 2
RSEG ?XD?_IccSyncPutCharWaitACK?ICCPDIR
?_IccSyncPutCharWaitACK?BYTE:
ch?1872: DS 1
ORG 1
ci?1873: DS 1
RSEG ?BI?_IccSyncPutCharWaitACK?ICCPDIR
?_IccSyncPutCharWaitACK?BIT:
fret?1874: DBIT 1
RSEG ?XD?IccSyncGetCharSendACK?ICCPDIR
?IccSyncGetCharSendACK?BYTE:
ch?1977: DS 1
RSEG ?BI?IccSyncGetCharSendACK?ICCPDIR
?IccSyncGetCharSendACK?BIT:
fack?1975: DBIT 1
RSEG ?XD?_IccSyncPutChar?ICCPDIR
?_IccSyncPutChar?BYTE:
ch?2078: DS 1
ORG 1
ci?2079: DS 1
RSEG ?XD?_IccSyncPollingIO?ICCPDIR
?_IccSyncPollingIO?BYTE:
tm?2386: DS 2
ORG 2
starttime?2387: DS 2
RSEG ?XD?_IccSyncReset?ICCPDIR
?_IccSyncReset?BYTE:
buf?2282: DS 3
ORG 3
ch?2285: DS 1
RSEG ?BI?iccgetputonebit?ICCPDIR
?iccgetputonebit?BIT:
bioport?040: DBIT 1
RSEG ?XD?ICCPDIR
ovtime?1466: DS 2
attr: DS 4
CardId: DS 1
RSEG ?DT?ICCPDIR
TIME_OUT_MS: DS 2
ETU: DS 2
RLD: DS 1
TxRLDStart: DS 1
RxRLDStart: DS 1
RxBits: DS 1
ibufputidx: DS 1
ibufgetidx: DS 1
mycharp: DS 1
parityerror: DS 1
parityerrorcnt: DS 1
bitcounter: DS 1
endflag: DS 1
RSEG ?BI?ICCPDIR
dir: DBIT 1
fReset: DBIT 1
TxNotRx: DBIT 1
RxWorking: DBIT 1
TxParity: DBIT 1
RSEG ?ID?ICCPDIR
IBUF: DS 64
RSEG ?DT?_IccRead?ICCPDIR
i?546: DS 2
RSEG ?DT?_IccRead?ICCPDIR
starttime?547: DS 2
RSEG ?DT?_IccWrite?ICCPDIR
i?650: DS 2
RSEG ?DT?_IccWrite?ICCPDIR
starttime?651: DS 2
RSEG ?DT?_IccWrite?ICCPDIR
trytimes?652: DS 1
RSEG ?DT?_IccOpen?ICCPDIR
i?955: DS 1
RSEG ?DT?_IccOpen?ICCPDIR
j?956: DS 1
RSEG ?DT?_IccOpen?ICCPDIR
format?957: DS 1
RSEG ?DT?_IccOpen?ICCPDIR
mylrc?958: DS 1
RSEG ?DT?_IccOpen?ICCPDIR
CWI?959: DS 1
RSEG ?DT?_IccOpen?ICCPDIR
BWI?960: DS 1
RSEG ?DT?_IccOpen?ICCPDIR
inchar?961: DS 1
RSEG ?DT?_IccOpen?ICCPDIR
oldtmo?962: DS 2
RSEG ?DT?_IccOpen?ICCPDIR
nhistory?963: DS 1
RSEG ?CO?ICCPDIR
IccEtu:
DB 0F8H
DB 03EH
DB 0C0H
DB 030H
RSEG ?C_INITSEG
DB 044H
DW attr
DB 00CH
DB 00CH
DB 00CH
DB 00CH
DB 002H
DB TIME_OUT_MS
DW 00032H
DB 002H
DB ETU
DW 0003EH
DB 001H
DB RLD
DB 0C2H
DB 001H
DB TxRLDStart
DB 0E0H
DB 001H
DB RxRLDStart
DB 0DFH
DB 001H
DB RxBits
DB 008H
DB 0C1H, dir + 080H ; bit-init
DB 0C1H, fReset + 000H ; bit-init
DB 001H
DB ibufputidx
DB 000H
DB 001H
DB ibufgetidx
DB 000H
DB 0C1H, TxNotRx + 000H ; bit-init
DB 0C1H, RxWorking + 000H ; bit-init
DB 0C1H, TxParity + 000H ; bit-init
DB 042H
DW ovtime?1466
DW 00000H
; /****************************
; * iccpdir.c *
; * Designe by 刘俐训 *
; * T = 0 for ic card *
; * Sync card *
; * last update: 04-13-2007 *
; ****************************/
; #include <reg52.h>
; #include "stimer.h"
; #include "string.h"
; #include "uart.h"
; #include "icc.h"
; #include <v51rx2.h>
; #include "intrsc.h"
; //#include <wdt.h>
;
; #define DEBUG_ICC 0
;
; #define ICCIO P3_3
; #define ICCRST P3_4
; #define USERRST P2_0
;
; #define ICCUSERCLKC P1_1
; #define ICCUSERCLS P2_5
; #define ICCUSEROVLD P2_6
; #define ICCUSEREJECT P1_4
; #define ICCUSERSCLK P1_2 // sync clk of user card
; #define ICCUSERVCCC P2_1
;
; #define ICCA0 P1_6
; #define ICCA1 P1_5
; #define ICCINH P1_7
;
;
; #define INFOLEN 176
;
; #ifndef enable
; #define disable() EA = 0
; #define enable() EA = 1
; #endif
;
; #define IccEnable(); IE1 = 0; EX1 = 1;
; #define IccDisable(); EX1 = 0;
;
; #define StartSend(); TxNotRx = 1;\
; ICCIO = 0;
;
; typedef struct _ICCATTR
; {
; unsigned char etu : 2; // baudrate, 00:9600, 01:38400, 10: onchip9600, 11: Onchip38400
; unsigned char autob : 1; // auto baudrate or not
; unsigned char dir : 1; // pdir or ndir
; }ICCATTR;
;
; static code unsigned char IccEtu[4] = {248, 62, 192, 48};
; static ICCATTR attr[4] = {{0,1,1}, {0,1,1}, {0,1,1}, {0,1,1}};
; static unsigned int data TIME_OUT_MS = 50; /* 默认超时时间是50毫秒 */
;
; // these parameters are calculated from ETU
; static unsigned int data ETU = 62; //248; // 372 * 4 / 12 = 124 (cycles)
; static unsigned char data RLD = 256 - 62; // bit period
; static unsigned char data TxRLDStart = 256 - 62 + 30; // the 1st bit period
; static unsigned char data RxRLDStart = 256 - 62 - 31 + 60; // the 1st bit period
; static unsigned char data RxBits = 8;
;
; // data direction
; static bit dir = 1; // pdir
;
; // flag of reseting card
; static bit fReset = 0;
;
; // current card id
; static unsigned char CardId;
;
; /*********************************************************************/
; void iccgetputonebit(void); // call in the user timer interrupt for every bit
;
; /*********************************************************************/
; #ifndef SSBUF_SIZE
; #define SSBUF_SIZE 64
; #endif
;
; static unsigned char idata IBUF[SSBUF_SIZE];
; static unsigned char data ibufputidx=0;
; static unsigned char data ibufgetidx=0;
; static bit TxNotRx = 0;
;
; static bit GetInputData( unsigned char *addr);
;
; // calculate ETU, RLD and so on.
; static void IccInitETU(unsigned int etu);
; /*********************************************************************/
;
; // these parameters are prepared for the bit interrupt functions
; static unsigned char data mycharp;
; static unsigned char data parityerror;
; static unsigned char data parityerrorcnt;
; static unsigned char data bitcounter;
; static unsigned char data endflag;
; static volatile bit RxWorking = 0;
; static volatile bit TxParity = 0;
;
; void iccgetputonebit(void)
RSEG ?PR?iccgetputonebit?ICCPDIR
iccgetputonebit:
USING 0
; SOURCE LINE # 103
; {
; SOURCE LINE # 104
; bit bioport;
;
; if(TxNotRx)
; SOURCE LINE # 107
JNB TxNotRx,?C0001
; {
; SOURCE LINE # 108
; if(endflag)
; SOURCE LINE # 109
MOV A,endflag
JZ ?C0002
; {
; SOURCE LINE # 110
; if(endflag == 1)
; SOURCE LINE # 111
CJNE A,#01H,?C0003
; {
; SOURCE LINE # 112
; ICCIO = 1; // stop parity bit
; SOURCE LINE # 113
SETB P3_3
; endflag ++;
; SOURCE LINE # 114
INC endflag
; }
; SOURCE LINE # 115
RET
?C0003:
; else
; {
; SOURCE LINE # 117
; parityerror = ~ICCIO;
; SOURCE LINE # 118
MOV C,P3_3
CPL C
CLR A
RLC A
MOV parityerror,A
; TxNotRx = 0;
; SOURCE LINE # 119
CLR TxNotRx
; DiUserTimer();
; SOURCE LINE # 120
CLR ET0
; IccEnable();
; SOURCE LINE # 121
CLR IE1
SETB EX1
; }
; SOURCE LINE # 122
; }
; SOURCE LINE # 123
RET
?C0002:
; else if(!bitcounter)
; SOURCE LINE # 124
MOV A,bitcounter
JNZ ?C0006
; {
; SOURCE LINE # 125
; ICCIO = TxParity;
; SOURCE LINE # 126
MOV C,TxParity
MOV P3_3,C
; endflag = 1;
; SOURCE LINE # 127
MOV endflag,#01H
; }
; SOURCE LINE # 128
RET
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -