久久久久久久999_99精品久久精品一区二区爱城_成人欧美一区二区三区在线播放_国产精品日本一区二区不卡视频_国产午夜视频_欧美精品在线观看免费

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 5266|回復: 0
收起左側

非接觸ID卡程序(AVR與em4095)

[復制鏈接]
ID:104287 發表于 2016-1-30 01:39 | 顯示全部樓層 |閱讀模式
/*
在提取出同步時鐘信號后,就可以通過檢測出兩個上升沿(或下降沿)的時間間隔來提取數據了。
兩個上升沿(或下降沿)的時間間隔總共有t=T’,t=1.5T’,t=2T’三種情況。
如果檢測到兩個上升沿之間的間隔t=T’時,則收到一個與前一個邏輯值相同的數據,
在b上升沿之后t=T’時間的的c處檢測到上升沿,得到與前一個邏輯值con_receive相同的數據1。
將此數據存放入存儲器中,并同時將當前邏輯值1賦給狀態位con_receive;
如果檢測到兩個上升沿之間的時間間隔t=1.5T’時,兩種情況:當前一個數據值con_receive為1時,
得到兩個數據00,并將邏輯值0賦給con_receive;當前一個數據為0時,得到一個數據1,
并將邏輯值1賦給con_receive。如圖3,在c上升沿之后t=1.5T’時間的d處檢測到上升沿,
由于在c上升沿得到的邏輯值為1,則得到數據00,con_receive的值也相應變為0;
又經過T’時間后到達e上升沿,得到與前一個邏輯值相同的數據0;
又經過t=1.5T’時間到達f上升沿,由于前一個數據的邏輯值為0,
則得到數據1,con_receive也相應變為1;如果檢測到兩個上升沿之間的時間間隔t=2T’時,
得到兩個數據01,并將邏輯值1賦給con_receive。如圖3,在f上升沿之后的t=2T’時間的g處檢測到上升沿,
得到兩個數據01;
但是這個程序是,在周期中間的下降沿才是1,上升沿是0.
*/
//采用外部晶振8.000Mhz
#include <mega16.h>

#define RXB8 1
#define TXB8 0
#define UPE 2
#define OVR 3
#define FE 4
#define UDRE 5
#define RXC 7
#define FRAMING_ERROR (1<<FE)
#define PARITY_ERROR (1<<UPE)
#define DATA_OVERRUN (1<<OVR)
#define DATA_REGISTER_EMPTY (1<<UDRE)
#define RX_COMPLETE (1<<RXC)
// USART Transmitter buffer
#define TX_BUFFER_SIZE 8
char tx_buffer[TX_BUFFER_SIZE];
#if TX_BUFFER_SIZE<256
unsigned char tx_wr_index,tx_rd_index,tx_counter;
#else
unsigned int tx_wr_index,tx_rd_index,tx_counter;
#endif
// USART Transmitter interrupt service routine
interrupt [USART_TXC] void usart_tx_isr(void)
{
if (tx_counter)
   {
   --tx_counter;
   UDR=tx_buffer[tx_rd_index];
   if (++tx_rd_index == TX_BUFFER_SIZE) tx_rd_index=0;
   };
}
#ifndef _DEBUG_TERMINAL_IO_
// Write a character to the USART Transmitter buffer
#define _ALTERNATE_PUTCHAR_
#pragma used+
void putchar(char c)
{
while (tx_counter == TX_BUFFER_SIZE);
#asm("cli")
if (tx_counter || ((UCSRA & DATA_REGISTER_EMPTY)==0))
   {
   tx_buffer[tx_wr_index]=c;
   if (++tx_wr_index == TX_BUFFER_SIZE) tx_wr_index=0;
   ++tx_counter;
   }
else
   UDR=c;
#asm("sei")
}
#pragma used-
#endif
// Standard Input/Output functions
#include <stdio.h>
/////////////////////////////////////////////////////////////////
unsigned char global_flag=0;
#define MAXCARDCHAR   10
#define _WHICH_EXT0 0   
#define _CARD_DATA 0
#define _set(c,b) (c)|=1<<(b)
#define _clr(c,b) (c)&=(~(1<<(b)))
#define _flag(c,b) ((c)&(1<<(b)))//==(1<<(b)))
#define _EXTFALL      MCUCR=0x02   
#define _EXTRIS       MCUCR=0x03   
#define _TCONT_OFF    TCCR0=0x00
#define _TCONT_ON     TCCR0=0x03  

bit f_cyc=0; //0表示下降沿空跳,1表示周期中間;
bit f_pr=1; //這個是記錄前一次的狀態值。
unsigned int t_value=0,header_data=0,Lcardbytein[10];
unsigned char data_head=0,header_data_count=0,cyc=0,c_count=0,data=0;   
unsigned char rbit=0,one_cyc=0,cardbytein[15],parity=0;
unsigned char TH1=0,TL1=0;
void all_parameter_init(void);
void all_parameter_init(void){
            header_data_count=0;   
            TCCR1B=0x00;
            rbit=0;
            cyc=0;
            data=0;
            header_data=0;
            t_value=0;
            GICR|=0x40;
               
}                             
// External Interrupt 0 service routine
interrupt [EXT_INT0] void ext_int0_isr(void)
{
/*
GICR&=0xbf;
TCCR1B=0x02;
   t_value=TCNT1;
   TCNT1H=0x00;TCNT1L=0x00;    //定時值清零;     
Lcardbytein[data++]=t_value;
if(data>=150){
while(1);
}
   
t_value=0;
GICR|=0x40;   
*/
GICR&=0xbf;
if(TCCR1B==0x00){
        TCNT1H=0x00;TCNT1L=0x00;
        TCCR1B=0x02;
        t_value=0;
        GICR|=0x40;
        header_data=0;
        data=0;
        header_data|=0x0001;
        f_pr=1;
        header_data_count=1;   
        parity=0;
        return;
}   
else{   
t_value=TCNT1;
TCNT1H=0x00;TCNT1L=0x00;
header_data<<=1;                  //這里先移,數據是0x03fe            
     
     if(header_data_count<9){      //處理數據頭
        if(t_value>999){           //表示數據為三個:101
            header_data_count=1;
            header_data=0;
            header_data|=0x0001;   
            f_pr=1;
            goto end;
        }   
        else if(t_value>730){
            if(f_pr==1){             //數據0
               header_data_count=0;
               header_data=0;
               f_pr=0;
            }
            else{                   //數據1
               header_data_count=1;
               header_data=0;
               header_data|=0x0001;   
               f_pr=1;
            }
            goto end;
        }         
        else if(t_value>480){
           if(f_pr==1){           //數據1
              header_data|=0x0001;
              header_data_count++;
              f_pr=1;
              f_cyc=1;      
           }
           else{                   //數據0
               header_data_count=0;
               header_data=0;
               f_pr=0;           
           }
            goto end;
        }
        else{
            header_data_count=0;   
            TCCR1B=0x00;
            goto end;
        }
     }
     else{                       //數據頭處理過了,這里是數據        
        rbit<<=1;   
        if(t_value>1180){
            all_parameter_init();
            return;
        }
        if(t_value<480){
            all_parameter_init();
            return;
        }
        if(t_value>999){
           if(f_pr){
                rbit&=0xfe;
                rbit<<=1;
                rbit|=0x01;
                cyc+=2;   
                f_pr=1;
                f_cyc=1;
                goto data_dw;
           }
           else{
                all_parameter_init();
                return;           
           }
                 
        }   
        else if(t_value>730){
           if(f_pr){
              rbit&=0xfe;
              f_pr=0;
              cyc++;
           }
           else{
              rbit&=0xfe;
              rbit<<=1;
              rbit|=0x01;
              cyc+=2;   
              f_pr=1;           
           }   
           goto data_dw;
        }
        else if(t_value>480){
           if(f_pr){
              rbit|=0x01;
              cyc++;
           }
           else{
              rbit&=0xfe;
              cyc++;         
           }
        }   
data_dw:

        if(cyc>=5){   
           if(cyc==6){//cyc有可能在之前增加的時候超過5; 這里是取校驗位
             cardbytein[data]=(rbit>>1);
           }
           else{
             cardbytein[data]=rbit;
           }
           parity=(((cardbytein[data]&0x10)>>4)+((cardbytein[data]&0x08)>>3)+((cardbytein[data]&0x04)>>2)+((cardbytein[data]&0x02)>>1));   
           if((parity&0x01)==(cardbytein[data]&0x01)){//cyc有可能在之前增加的時候超過5; 不取校驗位
                if(cyc==6){
                        cyc=1;
                        cardbytein[data]=(rbit>>2);
                        if(rbit&0x01){rbit=0x01;}
                        else rbit=0x00;
                }
                else{
                        cardbytein[data]=rbit>>1;
                        rbit=0x00;   
                        cyc=0;
                }               
               data++;
           }
           else{
                all_parameter_init();
                return;
           }   
                    
           if(data>9){//測試   
                _set(global_flag,_CARD_DATA);
                return;
           }
        }
        
     }
end:     
t_value=0;
GICR|=0x40;
}

}
// Timer 1 overflow interrupt service routine
interrupt [TIM1_OVF] void timer1_ovf_isr(void)
{
if(_flag(global_flag,_CARD_DATA)){
PORTA^=0X01;                     
}   
TCNT1H=0x00;
TCNT1L=0x00;
TCCR1B=0X00;
// Place your code here
}
// Declare your global variables here
void main(void)
{
// Declare your local variables here
// Input/Output Ports initialization
// Port A initialization
// Func7=In Func6=In Func5=In Func4=In Func3=In Func2=In Func1=In Func0=In
// State7=T State6=T State5=T State4=T State3=T State2=T State1=T State0=T
PORTA=0x00;
DDRA=0xff;
// Port B initialization
// Func7=In Func6=In Func5=In Func4=In Func3=In Func2=In Func1=In Func0=In
// State7=T State6=T State5=T State4=T State3=T State2=T State1=T State0=T
PORTB=0x00;
DDRB=0x00;
// Port C initialization
// Func7=In Func6=In Func5=In Func4=In Func3=In Func2=In Func1=In Func0=In
// State7=T State6=T State5=T State4=T State3=T State2=T State1=T State0=T
PORTC=0x00;
DDRC=0x00;
// Port D initialization
// Func7=In Func6=In Func5=In Func4=In Func3=In Func2=In Func1=In Func0=In
// State7=T State6=T State5=T State4=T State3=T State2=T State1=T State0=T
PORTD=0x04;
DDRD=0x00;
// Timer/Counter 0 initialization
// Clock source: System Clock
// Clock value: Timer 0 Stopped
// Mode: Normal top=FFh
// OC0 output: Disconnected
TCCR0=0x00;
TCNT0=0x00;
OCR0=0x00;
// Timer/Counter 1 initialization
// Clock source: System Clock
// Clock value: 1000.000 kHz
// Mode: Normal top=FFFFh
// OC1A output: Discon.
// OC1B output: Discon.
// Noise Canceler: Off
// Input Capture on Falling Edge
// Timer 1 Overflow Interrupt: On
// Input Capture Interrupt: Off
// Compare A Match Interrupt: Off
// Compare B Match Interrupt: Off
TCCR1A=0x00;
TCCR1B=0x00;//TCCR1B=0x02;
TCNT1H=0x00;
TCNT1L=0x00;
ICR1H=0x00;
ICR1L=0x00;
OCR1AH=0x00;
OCR1AL=0x00;
OCR1BH=0x00;
OCR1BL=0x00;
// Timer/Counter 2 initialization
// Clock source: System Clock
// Clock value: Timer 2 Stopped
// Mode: Normal top=FFh
// OC2 output: Disconnected
ASSR=0x00;
TCCR2=0x00;
TCNT2=0x00;
OCR2=0x00;
/*
// External Interrupt(s) initialization
// INT0: On
// INT0 Mode: Any change
// INT1: Off
// INT2: Off
GICR|=0x40;
MCUCR=0x01;
MCUCSR=0x00;
GIFR=0x40;
*/
// External Interrupt(s) initialization
// INT0: On
// INT0 Mode: Falling Edge
// INT1: Off
// INT2: Off
GICR|=0x40;
MCUCR=0x02;
MCUCSR=0x00;
GIFR=0x40;
// Timer(s)/Counter(s) Interrupt(s) initialization
TIMSK=0x04;
// USART initialization
// Communication Parameters: 8 Data, 1 Stop, No Parity
// USART Receiver: Off
// USART Transmitter: On
// USART Mode: Asynchronous
// USART Baud rate: 9600
UCSRA=0x00;
UCSRB=0x48;
UCSRC=0x86;
UBRRH=0x00;
UBRRL=0x33;
// Analog Comparator initialization
// Analog Comparator: Off
// Analog Comparator Input Capture by Timer/Counter 1: Off
ACSR=0x80;
SFIOR=0x00;
// Global enable interrupts
#asm("sei")
putchar('d');
while (1)
      {
      // Place your code here
         if(_flag(global_flag,_CARD_DATA)){
                UCSRA=0x00;
                UCSRB=0x48;
                UCSRC=0x86;
                UBRRH=0x00;
                UBRRL=0x33;         
             for(data=0;data<10;data++){     
                 putchar(cardbytein[data]);
             }
             _clr(global_flag,_CARD_DATA);
             all_parameter_init();
         }
      };
}

回復

使用道具 舉報

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規則

手機版|小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術交流QQ群281945664

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 色综合久久天天综合网 | 国产探花在线观看视频 | 日本不卡一区 | 亚洲欧美日韩精品久久亚洲区 | 日韩欧美一级精品久久 | 四虎影院在线观看免费视频 | 一级片免费在线观看 | 亚洲国产一区在线 | 伊人一二三 | www.色午夜.com | 精品国产一二三区 | 521av网站| 成人精品一区 | 欧美一区二区三区大片 | 日韩免费在线 | 日韩免费高清视频 | 精品成人69xx.xyz| 欧美一级视频免费看 | 天天弄 | 红桃视频一区二区三区免费 | 在线免费国产视频 | 亚洲精品一区二区三区中文字幕 | 午夜精品视频在线观看 | 羞羞的视频在线 | 中国一级特黄视频 | 久久国产精品一区二区三区 | 中文字幕一区二区三区日韩精品 | 日本久久视频 | 丝袜 亚洲 欧美 日韩 综合 | 涩涩视频在线观看免费 | 精品欧美乱码久久久久久1区2区 | 亚洲成人精品久久久 | 成人午夜免费在线视频 | 久久久久久免费精品一区二区三区 | 国产久 | 国产午夜精品久久 | 中文字幕免费视频 | 欧美精品91 | 亚洲最大成人综合 | 国产精品精品 | 99re在线|