📄 4442卡的底层操作程序.c
字号:
//4442卡的底层操作程序
#include <stdio.h>
#include <intrins.h>
#include <reg52.h>
typedef unsigned char uchar;
typedef unsigned int uint;
#define RMM_COMM 0x30 //读主存命令字
#define UMM_COMM 0x38 //写主存命令字
#define CVD_COMM 0x33 //校验密码
#define RSM_COMM 0x31 //读密码存储区
#define USM_COMM 0x39 //写密码存储区
#define RPM_COMM 0x34 //读保护存储区
#define WPM_COMM 0x3c //写保护存储区
#define Pow_On 0 //低电平供电
#define Pow_Off 1 //高电平断电
//******************************************
//定义IC卡接口
sbit CLK=P1^1; //时钟
sbit OUTDATA=P1^2; //输出(CPU侧)
sbit INDATA=P1^2; //输入(CPU侧)
sbit POWER=P1^4; //电源
sbit RST=P1^0; //复位
//******************************************
//************************************************************************
//4442卡底层程序的外部函数声明
extern void Rmm(uchar CardAdd,uchar idata *pt,uchar i); //读IC卡主存
extern void Umm(uchar CardAdd,uchar idata *pt); //写IC卡主存,每次写一
字节
extern void Rpm(uchar idata *pt); //读保护存储器
extern void P_Byte(uchar CardAdd,uchar idata *pt); //保护一字节,注意待保
护的字节是已经写入过的,地址只能在保护存储区内
extern void Power_On(uchar idata *pt); //卡上电,延时约80us,卡
复位,同时读入4个标示字节
extern void Power_Off(void); //卡下电,延时约80us
extern bit Verify(uchar idata *pt); //校验密码,成功返回1
//******************************************************************
//************************************************************
//功能演示,在实际用的时候把这段注释掉
void main(void)
{
uchar idata *pt;
uchar cc;
bit temp_flag;
uchar test[12]={1,2,3,4,5,6,7,8,9};
uchar test1[12];
pt=&test1[0];
Power_Off();
Power_On(pt); //上电同时读入标示字节
*pt=0xff; //第一个密码
pt++;
*pt=0xff; //第二个密码
pt++;
*pt=0xff; //第三个密码
pt=&test1[0];
temp_flag=Verify(pt); //校验密码
pt=&test1[0];
Rpm(pt); //读入保密区字节
pt=&test[0];
for (cc=0;cc<10;cc++,pt++)
Umm(0x40+cc,pt);
pt=&test1[0];
Umm(0x40+cc,pt);
Rmm(0x40,pt,12);
*pt=0xaa;
Umm(0x04,pt);
P_Byte(0x05,pt);
while (1);
}
//**********************************************
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -