⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 reader.c

📁 很强的射频卡reader源代码
💻 C
📖 第 1 页 / 共 5 页
字号:
/****************************************************************************
*                                                                           
* File:         READER.C                                  
*                                                                           
* Created:      2002.12.25                                                    
*                                                                           
* Editor        
*                                                                           
* Compiler:     KEIL C51 V7.00                                              
*                                                                           
* Description:  sst89e554-Firmware for RC500 Serial Reader               
*                                                                           
*****************************************************************************
*                                                                           
* Version | Date     |  PCB  | Description                                          
* --------+----------+-------+------------------------------------------------ 
*3600v0.1 | 22/04/03 |       | weigand ,RS485, IAP 
* V140    | 08/04/04 |       | Adding 15693 funtions 
* V130    | 08/02/03 |       | Adding some funtions about SAM  
* V120    | 20/01/03 |       | Modify reader.h,adding rc500cmd.h   
* V110    | 15/01/03 |       | reset pin control by FIFO out pins.Adding two new command
*         |          |       | (READ EEPROM C6 and WRITE EEPROM C7).
*         |          |       | delay using a fixed time,not "for loop".
*         |          |       | New routine "funtions()" is generated in 	 funtion.          
* V100	  | 25/12/02 |       | Initial version,TypeA and TypeB	    
                                  
****************************************************************************/

//#pragma src(example11.a51)
#include "string.h"
#include "reader.h"
#include "rc632cmd.h"
#include "intrins.h"
#include "Rc632cv.h"
#include "Rc632Reg.h"
#include "632MfErrNo.h"
#include "iap.h"
#include "wiegand.h"
void make_xor(unsigned char *data_buffer,unsigned char len);
extern int des(unsigned char *source,unsigned char * dest,unsigned char * inkey, int flg);
extern unsigned char  write_byte_Flash(unsigned int byte_address,unsigned char a);
extern unsigned char get_desfire_uid(void);
extern unsigned char read(unsigned char app_no[3],
		                  unsigned char file_no,
		                  unsigned char file_offset[3],
		                  unsigned char read_length);
//For control I/O port used
typedef struct    //typedef??
{
  unsigned char TimeOut[4];
}IO_Struct;
IO_Struct Port;
void weigand_26(unsigned char *wei_data);
unsigned char Tiflag;
bit Output0Flag;
bit Output1Flag;
//bit Output2Flag;
//bit Output3Flag;
bit BuzFlag;
bit RD2IDLEFlag; 		//单片机掉电模式?bit Display_Flag;
bit C_ExtFlag;

unsigned char key_temp,key_i;

// led Flag
bit RedLED_Flag;
bit GreenLED_Flag;
unsigned char DlyforWiegand;
idata unsigned char NumPeriodLED_R;  //Number of ON/OFF period 
idata unsigned char NumPeriodLED_G;
idata unsigned char DutyTimeLED_R;   //ON LED time
idata unsigned char DutyTimeLED_G;   
idata unsigned char Buz_T1,Buz_T2,Buz_T3,Buz_T4,Buz_Period,Buz_Step,Buz_CNT;
data unsigned int SecondCNT_t1,C_ext_CNT;

//=======================================================================
//wiegand 控制
unsigned char weigandFlag;
						//bit0		=0不受IO口控制,=1受IO口控制
						//bit1		=0读卡成功后BEEP LED 不亮,=1 ,成功后亮
						//bit4		=0 wiegand 不输出,1 weigand输出

idata unsigned char wiegand_mode; 	   	//wiegand 格式选择
						//=0	wiegand 26
						//=1	wiegand 32
						//=2	wiegand 40
						//=3	wiegand 34
						//=4	wiegand 42
						//=5	wiegand 32e		//直接输出CARD序列号
						//=6	wiegand 56
						

idata unsigned char wiegand_block;  	//wiegand 数据存放块地址
					//=0   读卡序列号
					//=1~16 读块的值
idata unsigned char iso15693block;
					//=FF  读目录
idata unsigned char wiegand_requst;  	//Request 模式选择
					//=0,		
					//=1,		

//idata unsigned char wiegand_io_m; 		//I/O 报警模式选择
idata unsigned char key_outmode;		//键盘输出模式
idata unsigned char csn_outmode;		//卡序号输出方向
					//bit0 				=0正常输出,	=反向输出
					//bit1				=0 不输出到串口,=1 输出到串口
					//bit2				=0 key press beep on/off
//===========================================================================

extern unsigned char getkey();
xdata unsigned char KeyBuffer[10]=0;
unsigned char xdata cmd_buffer[64];
unsigned char xdata card_buffer[64];


unsigned char SlaveADR;
unsigned char SlaveADR_MSB; //High byte of address

unsigned char SEQ=0x80;
//Below buffer for PC UART used
unsigned char delay_times;
unsigned char CheckSum;                    //Receiver checksum of PC UART
unsigned char TxCheckSum;                  //Transmit checksum of PC UART 
unsigned char ReceivCNT;                   //Receiver count
unsigned char STX_Pointer;                 //Start of transmit data pointer 
unsigned char ETX_Pointer;                 //End of transmit data pointer
unsigned char Rec_Status;                  //for receiver selected to decode
unsigned char Regetrc500EEPROMTimeOut;	           //Received byte by byte times 
//xdata struct uart_Host Host;
bit ReceivFlag,DecodeFlag;
bit TxFlag;                       //In the transmit status set bit  
bit TxFlag1; 
//idata UART_Buffer[UART_MaxRxd];
unsigned char SecondCNT;


union union1 u_ram;





#if (MCTYPE==CV5100)
	static code unsigned char Version[]="CV5100DV415";  
	
#elif(MCTYPE==CV5500)
	static code unsigned char Version[]="CV5500DV415";  

#elif(MCTYPE==CV5600)
	static code unsigned char Version[]="CV5600DV415";  

#else
	static code unsigned char Version[]="CV5600SDV415";  
	 
#endif

//static 
xdata unsigned char display1[16]="  China Vision  ";  
static xdata unsigned char *ip=display1;
static code unsigned char display4[]="     Welcome    ";  
static code unsigned char cls[]="                  ";
static code unsigned char wgdisplay1[]="Weigand_26:       ";  
static code unsigned char weigandkey[6]={0xff,0xff,0xff,0xff,0xff,0xff};

extern unsigned char des_app_no[3];		//应用号
extern unsigned char des_file_no;			//文件号
//extern unsigned char des_file_type;
//extern unsigned char des_encrypt_mode;
extern unsigned char des_offset[3];
extern unsigned char des_read_len;
//extern unsigned char des_key_no;
extern unsigned char session_key[16];
extern unsigned char select_key[17];
extern unsigned char card_desuid[9];

void CBC_3Des_SendToPICC(unsigned char *Data,unsigned char *Key,unsigned char *aSessionKey,int Len8);
void CBC_3Des_DataEnciphering(unsigned char *Data,unsigned char *Key,unsigned char *aSessionKey,int Len8);
void CBC_3Des_ReceiveFromPICC(unsigned char *Data,unsigned char *Key,unsigned char *aSessionKey,int Len8);
void ComputeCrc(int CRCType, char *Data, int Length,unsigned char *TransmitFirst, unsigned char *TransmitSecond);

//*****************************125k define**************************************
#define	FALSE	1
#define	TRUE	0
#define	 WEIGENDBITS 42
#define	uchar	unsigned char

unsigned char  data int0bitptr=0;						//WEIGEND位指针
unsigned char wtimeoutw;
bit	TW_flag;
bit	WeiGendEM_flag=FALSE;

uchar xdata int0bit[WEIGENDBITS];			//WEIGEND位寄存器
	
//********************************125k函数**********************************
void Sysint0_Interrupt() interrupt 7 
{	
	if(	WeiGendEM_flag==TRUE) return;

	if(int0bitptr==0)
	{
		wtimeoutw=120;
		TW_flag=0;
	}
	if((P4&0x02)==0)
	{	
		int0bit[int0bitptr]=1	;
		P4=P4|0x02;
	}
	else
	{
		int0bit[int0bitptr]=0	;
	}


	int0bitptr++;
	if(int0bitptr==WEIGENDBITS)
	{
		wtimeoutw=0;
		TW_flag=0;
		WeiGendEM_flag=TRUE;
		int0bitptr=0;
	}
	else
	{
		if (TW_flag)	//超时,清标志
		{
			WeiGendEM_flag=FALSE;
			int0bitptr=0;
		}
	}
}


//组合34WEIGEND码,产生4个字节的ID号
//WEIGEND码组成
//校验(1bit )+32位ID号+奇校验(1bit)
//前17位1的个数是偶数个
//后17位1的个数是奇数个

unsigned char pro_weigen(unsigned char *outbuf)
{
		uchar data i,tmpa,j,ptr;
		uchar idata wbuf [5];
		
		tmpa=0;		LED_G=OFF;	
		for(i=0;i<21;i++)
		{
				if(int0bit[i]==1)
				{
					tmpa++;	
				}
		}
		if((tmpa&0x01)==1)		//偶校验,偶数个1
		{	
			return FALSE;
		}
		//
		tmpa=0;
		for(i=0;i<21;i++)
		{
				if(int0bit[i+21]==1)
				{
					tmpa++;	
				}
		}
		if((tmpa&0x01)==0)	//奇校验,奇数个一
		{
			return FALSE;
		}
	
		//校验正确,开始组合
		ptr=1;//+1,去掉第一个奇数校验

		for(i=0;i<5;i++)
		{
			tmpa=0;			
			for(j=0;j<8;j++)
			{
				if(int0bit[ptr++]==0)	
				{
					tmpa=tmpa<<1;	
				}
				else
				{
					tmpa=tmpa<<1;	
					tmpa=tmpa|1;
				}
			}
			wbuf[i]=tmpa;
		}
		outbuf[4]=wbuf[4];
		outbuf[3]=wbuf[3];
		outbuf[2]=wbuf[2];
		outbuf[1]=wbuf[1];
		outbuf[0]=wbuf[0];
		return TRUE;
}
//---------------------------------------------------------------------
//======================================================================










void main(void)
{	
int deskey_address;
//unsigned char i;
//  unsigned char i;
/*
unsigned char array1[24];
unsigned char select[16];
unsigned char i;


  	select[0]=0;
	select[1]=0x11;
	select[2]=0x22;
	select[3]=0x33;
	select[4]=0x44;
	select[5]=0x55;
	select[6]=0x66;
	select[7]=0x77;
	select[8]=0x88;
	select[9]=0x99;
	select[10]=0xaa;
	select[11]=0xbb;
	select[12]=0xcc;
	select[13]=0xdd;
	select[14]=0xee;
	select[15]=0xff;
	
 for (i=0;i<16;i++)
 	select[i]=0;



	array1[0]=0x2a;
	array1[1]=0xc8;
	array1[2]=0x6f;
	array1[3]=0x37;
	array1[4]=0xd6;
	array1[5]=0x31;
	array1[6]=0xe1;
	array1[7]=0x31;
	array1[8]=0xc4;
	array1[9]=0xba;
	array1[10]=0x6c;
	array1[11]=0xb2;
	array1[12]=0x16;
	array1[13]=0x32;
	array1[14]=0x72;
	array1[15]=0xa9;
	array1[16]=0x4d;
	array1[17]=0xd2;
	array1[18]=0xaa;
	array1[19]=0x46;
	array1[20]=0x23;
	array1[21]=0x8e;
	array1[22]=0xdd;
	array1[23]=0x10;
  
	session_key[0]=0x7c;
	session_key[1]=0xae;
	session_key[2]=0x65;
	session_key[3]=0xd6;
	session_key[4]=0x6e;
	session_key[5]=0x86;
	session_key[6]=0xf4;
	session_key[7]=0x21;
	session_key[8]=0xa2;
	session_key[9]=0xe4;
	session_key[10]=0xec;
	session_key[11]=0xea;
	session_key[12]=0xac;
	session_key[13]=0x25;
	session_key[14]=0x9f;
	session_key[15]=0xf7;

 //  23 71 F4 B8 FE 4A 8D D6
CBC_3Des_ReceiveFromPICC(array1,select,session_key,3);	*/
//CBC_3Des_SendToPICC(array1,select,NULL,2); 	   	 
//	 40 82 3D B1 DA C2 B3 CA					
//CBC_3Des_DataEnciphering(array1,select,session_key,1);
//unsigned char CRC1=0,CRC2=0;
//unsigned char DataRead[24];

//memset(DataRead,0,24);
//DataRead[0]=0x12;
//DataRead[1]=0x34;
//ComputeCrc(1,DataRead,16,&CRC1,&CRC2);

	 
	if ((u_ram.host.TxBuffer[0]==0x55) && (u_ram.host.TxBuffer[1]==0xAA) && (u_ram.host.TxBuffer[2]!=0))  //how run to this state
	{
		Buzzer = 0;
		delay_1ms(250); //Additional delay ~=800ms, let RC500 Stable
		Buzzer = 1;
		delay_1ms(250); //Additional delay ~=800ms, let RC500 Stable
		delay_1ms(250); //Additional delay ~=800ms, let RC500 Stable
		delay_1ms(250); //Additional delay ~=800ms, let RC500 Stable
		u_ram.host.TxBuffer[2]--;
		//gotoisp();
	}

	Initial();







	InitLcd();
	delay_1ms(100);					//Extra stable time for 8051
	RST=1;delay_1ms(100);RST=0;	//Reset RC500 and return to normal operation	
	delay_1ms(800); //Additional delay ~=800ms, let RC500 Stable
	SecondCNT=0;	//Reset Pulse ~=100ms
	MCRReset_1();
	Mf500PcdConfig();
	SecondCNT=0;
	while(SecondCNT < 15){} 
	Buzzer=OFF;
	LED_R = ON;
	LED_G = OFF;
	
	
	read_Flash(BCCA,&u_ram.host.RxBuffer[0],10);
	if (u_ram.host.RxBuffer[0] != 0x55 ||u_ram.host.RxBuffer[1] != 0xAA || u_ram.host.RxBuffer[3] > 0x05 ||u_ram.host.RxBuffer[4] > 0x05) //Check BCC; reader and SAM card bauderate
	{
		InitialUART(5);  //for 22.1184MHz   115200
		SlaveADR=0;	     //Default address is 0x00
		weigandFlag=0;	
		write_Flash(s_Manufacturer, ip,16);
		InitialSetup();  //Save  //initialsetup for the cpu work at the first time.
	} 
	else 
	{
		InitialUART(u_ram.host.RxBuffer[3]);  //for 22.1184MHz    	 
	  	SlaveADR=u_ram.host.RxBuffer[2];     //for address
		weigandFlag=u_ram.host.RxBuffer[5];
	}
 	read_Flash(s_Manufacturer,display1,16);
	DisplayLcd(cls,16,0x00);	
	DisplayLcd(display1,16,0x00);	
	DisplayLcd(cls,16,0x40);
	DisplayLcd(display4,16,0x40);

//=======================================================================
	read_Flash(des_read_parameter,cmd_buffer,9);
			des_app_no[0]=cmd_buffer[0];
			des_app_no[1]=cmd_buffer[1];
			des_app_no[2]=cmd_buffer[2];
			des_file_no=cmd_buffer[3];			
			des_offset[0]=cmd_buffer[4];

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -