亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? level3.c

?? EM4094示例Firmware
?? C
?? 第 1 頁 / 共 2 頁
字號:
/*
*-------------------------------------------------------------------------------
*--  RCSId: $Id: level3.c,v 1.33 2004-06-30 12:47:41+02 mjg Exp mjg $
*--         $Name:  $
*-------------------------------------------------------------------------------
*-- level3.c - High level data transformations and main loop 
*-------------------------------------------------------------------------------
*-- $Log: level3.c,v $*-- Revision 1.33  2004-06-30 12:47:41+02  mjg*-- key selection extension*--
*-- Revision 1.32  2004-05-31 16:41:51+02  mjg
*-- single carrier too slow caused CRC errors, speeded up
*--
*-- Revision 1.31  2004-05-21 09:29:37+02  mjg
*-- startup inventory, to toggle EAS off for EM4034
*--
*-- Revision 1.30  2004-05-10 09:23:28+02  mjg
*-- to toggle EAS off
*--
*-- Revision 1.29  2004-05-07 08:10:25+02  mjg
*-- HW auth passed
*--
*-- Revision 1.28  2004-04-27 17:05:44+02  mjg
*-- to better test the design
*--
*-- Revision 1.27  2004-04-21 15:48:47+02  mjg
*-- FSK low data rate support
*--
*-- Revision 1.26  2004-04-21 13:05:21+02  mjg
*-- EOF ignored because of FSK and 4034 support
*--
*-- Revision 1.25  2004-04-13 11:21:39+02  mjg
*-- sync
*--
*-- Revision 1.24  2004-03-25 16:09:19+01  mjg
*-- to add delayed EOF feature
*--
*-- Revision 1.23  2004-03-25 15:13:23+01  mjg
*-- to add delayed EOF feature
*--
*-- Revision 1.22  2004-03-24 13:35:36+01  mjg
*-- error msg needs better handling
*--
*-- Revision 1.21  2004-03-15 16:59:06+01  mjg
*-- to check SPI
*--
*-- Revision 1.20  2004-02-16 08:04:11+01  mjg
*-- preliminary CD
*--
*-- Revision 1.18  2004-02-10 19:24:40+01  mjg
*-- FSK to add valid bits
*--
*-- Revision 1.17  2004-02-10 18:30:46+01  mjg
*-- dual carrier raw, decoded 1st try
*--
*-- Revision 1.16  2004-02-09 18:03:33+01  mjg
*-- raw dual carrier capture
*--
*-- Revision 1.15  2004-02-08 12:30:52+01  mjg
*-- Decode var removed, FSK polling added
*--
*-- Revision 1.14  2004-02-07 14:59:47+01  mjg
*-- Response parsing correction
*--
*-- Revision 1.13  2004-02-03 08:42:52+01  mjg
*-- hubneme II
*--
*-- Revision 1.12  2004-02-03 07:24:37+01  mjg
*-- fwd debug implemented and removed from being compiled
*--
*-- Revision 1.11  2004-01-19 14:08:05+01  mjg
*-- hubneme I
*--
*-- Revision 1.10  2004-01-14 14:57:35+01  mjg
*-- to Invenotry version 2
*--
*-- Revision 1.9  2003-12-11 17:37:20+01  mjg
*-- yes
*--
*-- Revision 1.8  2003-12-11 16:33:41+01  mjg
*-- 1TS gives too much responses, stayquiet ?
*--
*-- Revision 1.7  2003-12-10 08:15:48+01  mjg
*-- to add dbg code
*--
*-- Revision 1.6  2003-12-09 12:43:01+01  mjg
*-- to 1TS inventory
*--
*-- Revision 1.5  2003-12-09 12:42:44+01  mjg
*-- to 1TS inventory
*--
*-- Revision 1.3  2003-12-05 08:38:56+01  mjg
*-- write update
*--
*-- Revision 1.2  2003-12-04 15:58:08+01  mjg
*-- to write
*--
*-- Revision 1.1  2003-12-01 08:18:04+01  mjg
*-- single carrier low drate level1 ok
*--
*-- Revision 1.0  2003-11-26 09:01:02+01  mjg
*-- Initial revision
*--
*-------------------------------------------------------------------------------
*/


#include <avr/io.h>
#include <inttypes.h>
#include <avr/interrupt.h>
#include <avr/signal.h>
#include <avr/wdt.h>
#include "level4.h"
#include "level3.h"
#include "level2.h"
#include "level1.h"

//--------------------------------------------------------------
//global variables

uint8_t maxCaptureTimeLow;           //lower part of current maximum capture time (used to initialise TCNT1)
uint8_t maxCaptureTimeHi;            //upper part of current maximum capture time (expected value 0xFF or 0xFE only)

//register uint8_t capture_cnt asm ("r8");        //store_bit current capture byte index (this is a mirror from main.c)

//--------------------------------------------------------------
//local declarations

#define STD_WAIT 145                  //~318us = (145+13)x32 @ 16MHz , 13x32 uC clocks is a setup reserve

uint8_t clean_data_cnt;               //clean response data length

//uint16_t maxTRead;                    //current datarate maximum response capture time
uint16_t maxTGeneral;                 //current datarate maximum response capture time
uint16_t maxTwa1ee;                   //

uint8_t signed_crc;                   //flag of signed response

void SendCaptureData( uint8_t cmd, uint8_t ack );
void Send(uint8_t len, uint16_t wait_time);
void Compute_Timeouts( uint8_t flags );

uint8_t Inventory(void);
uint8_t HW_Authentication(void);
uint8_t ToggleEAS(void);
uint8_t GeneralRead(void);

//--------------------------------------------------------------
// main loop routine
//--------------------------------------------------------------

void main_receiver(void) {
  uint8_t check_stat;
  uint8_t fwd_bit_count;
  uint8_t i;

  if (watchdog_reset != 0) {
    FormatResponse_Short( 0x00, ERR_ASIC_ANTENNA_FAULT );
  } else {
    decode_number = 2;
    forward_link_type = 0x01;            //default value = 1 from 4 forward link    
    counter1set = (1<<ICNC1) | (1<<CS10);
  }

  enable_capture = 0;

  while (21) {                              // infinite loop

    wdt_reset();                            // reset the watchdog

    if((check_stat = CheckIncommingMessage()) != UART_MESSAGE_OK)     // check any incoming message
      FormatResponse_Short( 0, check_stat );
    else {                                                            // no error, processing command

      forward_ptr = data_buffer;            // initialize fwd pointer
      fwd_bit_count = 0;
  
      switch (uart_command) {

//...............................................................................................

        case 0x83 :                               //1TS Inventory
          Inventory();
          Wait(512);
          FormatResponse_Short( uart_command, Inventory() );
          break;

//...............................................................................................

        case 0x85 :                               //Stay Quiet
          Send( cmd_message_len, 0 );

          FormatResponse_Short( uart_command, 0x00 );
          break;

//...............................................................................................

        case 0x88 :                               //general read command
          i = GeneralRead();

          if (debug_mode == 0) {

            if (clean_data_cnt == 0)
              SendCaptureData( uart_command, i );
            else
              FormatResponse_Data( uart_command, i, clean_data_cnt, (uint8_t*)data_buffer );

          } else 
          if (debug_mode == 2) 
            SendCaptureData( uart_command, ERR_EM4035_CAPT_DATA );
          else
            FormatResponse_Data( uart_command, ERR_EM4035_RAW_DATA, capture_cnt, (uint8_t*)capture.capture_data );

          break;

//...............................................................................................

        case 0x89 :                               //HW Authentication
          i = HW_Authentication();
      
          if (i == UART_MESSAGE_OK)
            FormatResponse_Data( uart_command, i, clean_data_cnt, (uint8_t*)data_buffer );
          else
            SendCaptureData( uart_command, i );
          break;

//...............................................................................................

        case 0x8A :                               //Toggle EAS

          i = ToggleEAS();

          if (i == UART_MESSAGE_OK)
            FormatResponse_Data( uart_command, i, clean_data_cnt, (uint8_t*)data_buffer );
          else
            SendCaptureData( uart_command, i );
          break;

//...............................................................................................

        case 0x8B :                               //Startup Invenotry

          //RF Reset
          WriteSPI( write_4094_low & 0xFFFE, write_4094_hi );
          Wait(32768);
          WriteSPI( write_4094_low | 1, write_4094_hi );
          Wait(1000);                            //wait for ~2ms

          i = GeneralRead();

          if (debug_mode == 0) {

            if (clean_data_cnt == 0)
              SendCaptureData( uart_command, i );
            else
              FormatResponse_Data( uart_command, i, clean_data_cnt, (uint8_t*)data_buffer );

          } else 
          if (debug_mode == 2) 
            SendCaptureData( uart_command, ERR_EM4035_CAPT_DATA );
          else
            FormatResponse_Data( uart_command, ERR_EM4035_RAW_DATA, capture_cnt, (uint8_t*)capture.capture_data );

          break;

//...............................................................................................

        case 0x90 :                               //general write command

          signed_crc = 0;

          if (cmd_message[1] == 0xE3) {                  //signed operation

            //sign the CRC
            HWSign( &cmd_message[cmd_message_len-2], &cmd_message[cmd_message_len-2], 16);

            if ((cmd_message[0] & 0x40) != 0) {
              signed_crc = 1;
            }
          }

          Send( cmd_message_len, 0 );

          if ((cmd_message[0] & 0x40) && ((cmd_message[1] == 0x21) ||
              (cmd_message[1] == 0x22) || (cmd_message[1] == 0x27))) {    //optionFlag = '1'

            Wait( write_tag_memory_delay );
            
            SendEOF();

            maxCaptureTimeLow = (uint8_t)maxTGeneral; 
            maxCaptureTimeHi = maxTGeneral >> 8; 

          } else {                              //optionFlag = '0'

            maxCaptureTimeLow = (uint8_t)maxTwa1ee; 
            maxCaptureTimeHi = maxTwa1ee >> 8; 
          }
   
          Capture(2);

          if (debug_mode == 0) {

            clean_data_cnt = 0;
            if (sof >= 1) {

              i = 248 - ExtractData( 248 );              //extract data, max effective size is 248/8 bytes
                            
              if ((i >= 33) && (data_buffer[0] != 0)) {  //error message found
                i = ERR_EM4035_ERROR_MSG;
                clean_data_cnt = 4;

                if (signed_crc != 0) {
                  //unsign
                  HWSign( (uint8_t*)&data_buffer[clean_data_cnt-2], (uint8_t*)&data_buffer[clean_data_cnt-2], 16);
                }

              } else if ((i-1) < expectedResponseLen) { //no good header found or not enough data
                clean_data_cnt = 0;

                i = ERR_EM4035_WRONG_LEN;
              } else {                                   //clamp data to bytes
                i = 0;
                clean_data_cnt = expectedResponseLen / 8;

                if (signed_crc != 0) {
                  //unsign
                  HWSign( (uint8_t*)&data_buffer[clean_data_cnt-2], (uint8_t*)&data_buffer[clean_data_cnt-2], 16);
                }

              }

              if (clean_data_cnt != 0) {
                FormatResponse_Data( uart_command, i, clean_data_cnt, (uint8_t*)data_buffer );
                break;
              }

            } else {
              i = ERR_EM4035_NO_SOF;
            }
            SendCaptureData( 0x90, i );
          }
          else
          if (debug_mode == 2) 
            SendCaptureData( uart_command, ERR_EM4035_CAPT_DATA );
          else
            FormatResponse_Data( uart_command, ERR_EM4035_RAW_DATA, capture_cnt, (uint8_t*)capture.capture_data );
          break;

//...............................................................................................

        case 0xF1 :                               //write SPI configuration word directly
          WriteSPI( write_4094_low, write_4094_hi );
          FormatResponse_Short( uart_command, 0x00 );
          break;

//...............................................................................................

        case 0xF0 :                               //RF reset using SPI configuration word
          WriteSPI( write_4094_low & 0xFFFE, write_4094_hi );
          FormatResponse_Short( uart_command, 0x00 );

          wdt_disable();

          i = write_tag_memory_delay;
          while (i-->0) {
            Wait(16384);
          }

          wdt_enable(0x7);

          WriteSPI( write_4094_low | 1, write_4094_hi );
          break;

//...............................................................................................

        case 0x00 :                               //no command
          continue;

//...............................................................................................

        default:
          FormatResponse_Short( 0, ERR_UART_UNKNOWN_CMD );
          break;
      }

      uart_command = 0;

    }

  }
}

//--------------------------------------------------------------
//compute the timeouts according to the flag byte
//
void Compute_Timeouts(uint8_t flags) {

  register uint16_t pom;
  register uint16_t corr;

  pom = expectedResponseLen * 16;        //512RF/32 = 16 TCNT0 pulses per bit
  pom += 128;                            //reserve
  corr = expectedResponseLen / 2 + 2;    //correction for dual carrier

  if ((flags & 2) == 0)
    pom *= 4;
  else
    corr >>= 2;

  if ((flags & 1) == 1)
    pom -= corr;

  pom = (38 * (uint32_t)pom) / 32 + 1;

  decode_number = flags & 3;

  switch (decode_number) {
  case 0 :           //single carrier, low datarate
    halfDataRate    = 288 * 4;
    pulsesPerBit    = 32;
//    maxTRead        = 7904 + 1;     // = 4 * ((768 + 24 * 32 + 256 + 256) + 96 * 512 + (256 + 256 + 24 * 32 + 768)) * 38 / 32 / 32 + 1;
    break;

  case 1 :             //dual carrier, low_datarate
    halfDataRate    = 288*4;
    pulsesPerBit    = 32;
//    maxTRead        = 7842 + 1; //4 * ((27*28 + 24 * 32 + 508) + 96 * 508 + (508 + 24 * 32 + 27*28)) * 38 / 32 / 32 + 1;
    break;

  case 2 :             //single carrier, high datarate
    halfDataRate    = 288;
    pulsesPerBit    = 8;
//    maxTRead        = 1976 + 1; //((768 + 24 * 32 + 256 + 256) + 96 * 512 + (256 + 256 + 24 * 32 + 768)) * 38 / 32 / 32 + 1;
    break;

  case 3 :             //dual carrier, high datarate
    halfDataRate    = 288;
    pulsesPerBit    = 8;
//    maxTRead        = 1960 + 1; //((27*28 + 24 * 32 + 508) + 96 * 508 + (508 + 24 * 32 + 27*28)) * 38 / 32 / 32 + 1;
    break;

  default :
    decode_number = 0xFF;
  }

  maxTGeneral     = pom;
  maxTwa1ee       = write_tag_memory_delay + pom;

}


//--------------------------------------------------------------
//Output of default read
// 

void SendCaptureData(uint8_t cmd, uint8_t ack) {

  uint8_t check_stat;

  SendByte(0x02);
  SendByte(4 + 2 * capture_cnt);
  SendByte(cmd);
  SendByte(ack);

  check_stat = (4 + 2 * capture_cnt) ^ cmd ^ ack;

  check_stat ^= Block_Output (capture_cnt, capture.capture_data);

  check_stat ^= Block_Output (capture_cnt, capture.capture_valid);

  SendByte(check_stat);
  SendByte(0x03);
}

//--------------------------------------------------------------
//send command and wait
//
void Send(uint8_t len, uint16_t wait_time) {

  uint8_t fwd_bit_count;
  int i;

  forward_ptr = data_buffer;
  fwd_bit_count = 0;

  for(i=0; i < len; i++) 
    fwd_bit_count += Prepare_Data( cmd_message[i] );

  Compute_Timeouts(cmd_message[0]);
  ClearCaptureBuffers();

  maxCaptureTimeLow = (uint8_t)maxTGeneral; 
  maxCaptureTimeHi = maxTGeneral >> 8; 

  SendForward(fwd_bit_count);

  if (wait_time != 0) Wait( wait_time );
}

//--------------------------------------------------------------
// general read function
//
uint8_t GeneralRead(void) {

  uint8_t i = UART_MESSAGE_OK;
  signed_crc = 0;

  if (cmd_message[1] == 0xE2) {                  //signed operation

    //sign the CRC
    HWSign( &cmd_message[cmd_message_len-2], &cmd_message[cmd_message_len-2], 16);

    if ((cmd_message[0] & 0x40) != 0) {
      signed_crc = 1;
    }
  }

  Send( cmd_message_len, STD_WAIT );

  maxCaptureTimeLow = (uint8_t)maxTGeneral; 
  maxCaptureTimeHi = maxTGeneral >> 8; 
   
  Capture(2);

  if (debug_mode == 0) {

    int i;
    clean_data_cnt = 0;
    if (sof >= 1) {

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
91在线观看下载| 欧美精品一区二区三区蜜桃| 精品国产91乱码一区二区三区| 色婷婷综合久久久久中文一区二区| 一二三四社区欧美黄| 欧美性猛片aaaaaaa做受| 亚洲成年人网站在线观看| 欧美日韩国产一二三| 免费一区二区视频| 国产三级精品视频| 色综合久久99| 91国产精品成人| 成人中文字幕在线| 日本色综合中文字幕| 国产精品你懂的在线| 欧美亚洲禁片免费| 欧美伦理影视网| 成人性生交大合| 波多野结衣亚洲一区| 久久成人综合网| 亚洲自拍偷拍麻豆| 国产精品久久久久久久久搜平片| 欧美一区二区三区啪啪| 国产成人高清视频| 免费人成网站在线观看欧美高清| 另类小说图片综合网| 国产成人午夜99999| 色播五月激情综合网| 91精品国产综合久久久久久| 色综合久久九月婷婷色综合| 欧美日韩一区二区三区四区| 一本一道久久a久久精品| 欧美日韩另类一区| 久久久久久一二三区| 精品三级在线看| 欧美一区二视频| 国产精品无遮挡| 天天综合日日夜夜精品| 亚洲va欧美va天堂v国产综合| 老司机午夜精品99久久| a亚洲天堂av| 日韩女优电影在线观看| 69久久夜色精品国产69蝌蚪网 | 久久久久久久久免费| 亚洲精品少妇30p| 亚洲欧美精品午睡沙发| 国产午夜一区二区三区| 久久精品夜色噜噜亚洲a∨| 一区二区成人在线观看| 国产一区二区伦理片| 日韩1区2区3区| 99久久国产综合精品女不卡| 日韩欧美一级在线播放| 亚洲一区影音先锋| 99久久er热在这里只有精品66| 日韩欧美一区二区三区在线| 亚洲自拍偷拍av| 91在线观看免费视频| 久久久久久亚洲综合影院红桃| 亚洲成人福利片| 不卡一区中文字幕| 91传媒视频在线播放| 中日韩av电影| 国产成人免费视频一区| 精品卡一卡二卡三卡四在线| 丝袜美腿亚洲一区| 国产一区福利在线| 欧美一级一区二区| 性做久久久久久免费观看欧美| 91在线云播放| 亚洲欧洲制服丝袜| 99麻豆久久久国产精品免费优播| 久久久精品影视| 激情综合色丁香一区二区| 视频一区视频二区中文| 欧美三级三级三级| 亚洲成av人**亚洲成av**| 欧美色窝79yyyycom| 亚洲一区二区三区四区的| 欧美亚洲免费在线一区| 亚洲v精品v日韩v欧美v专区| 欧美嫩在线观看| 日本美女视频一区二区| 在线播放中文字幕一区| 日韩电影一区二区三区四区| 欧美疯狂做受xxxx富婆| 日产精品久久久久久久性色| 精品捆绑美女sm三区| 国产精品一区免费视频| 欧美人成免费网站| 日韩国产精品久久久久久亚洲| 欧美精品亚洲一区二区在线播放| 日韩中文字幕麻豆| 精品日韩一区二区三区 | 亚洲视频网在线直播| 美女一区二区三区在线观看| 99精品桃花视频在线观看| 亚洲手机成人高清视频| 欧洲av在线精品| 国产精品毛片高清在线完整版| 国产精品91xxx| 依依成人精品视频| 日韩视频一区二区| 亚洲已满18点击进入久久| 欧美一区二区三区啪啪| 国产成人在线视频免费播放| 有坂深雪av一区二区精品| 欧美成人欧美edvon| 99国产精品久| 免费高清在线一区| 自拍偷拍亚洲综合| 日韩免费观看高清完整版在线观看| 国产精品18久久久久久久久久久久| 亚洲视频在线观看一区| 欧美精品777| av资源网一区| 免费成人你懂的| 亚洲精品一卡二卡| 久久众筹精品私拍模特| 国内精品伊人久久久久av一坑 | 久久精品亚洲乱码伦伦中文| 91福利资源站| 国产精品一区二区91| 亚洲午夜激情网页| 欧美日韩激情一区二区| 国产精品1024久久| 麻豆91免费看| 亚洲国产cao| 亚洲国产精品99久久久久久久久 | 亚洲欧洲www| 99热这里都是精品| 狠狠色综合日日| 视频一区二区中文字幕| 日韩一区有码在线| 久久亚洲私人国产精品va媚药| 欧美色图天堂网| 色婷婷综合视频在线观看| 国内成人精品2018免费看| 日韩国产在线一| 亚洲国产精品尤物yw在线观看| 国产精品人人做人人爽人人添 | 中文字幕一区二区三区精华液| 日韩精品影音先锋| 欧美浪妇xxxx高跟鞋交| 在线精品视频一区二区| 91美女福利视频| 成人av网站在线| 成人av在线网| 99在线精品免费| 97精品久久久午夜一区二区三区| 国产a区久久久| 亚洲美女区一区| 一区精品在线播放| 日韩毛片在线免费观看| 中文字幕日本不卡| 亚洲裸体在线观看| 一区二区三区蜜桃网| 一区二区高清免费观看影视大全| 亚洲精品国产成人久久av盗摄 | 欧美日韩国产高清一区二区 | 日韩欧美一级二级三级| 欧美成人一级视频| 久久久五月婷婷| 国产精品视频一二三区| 中文字幕一区在线观看| 一区二区久久久| 午夜精品久久久久久久99水蜜桃| 日韩中文字幕区一区有砖一区 | 欧美日韩中文字幕精品| 欧美色欧美亚洲另类二区| 欧美日韩免费观看一区二区三区| 欧美高清视频不卡网| 日韩视频在线观看一区二区| 26uuu国产一区二区三区| 国产精品乱码一区二三区小蝌蚪| 18欧美亚洲精品| 日韩**一区毛片| 懂色一区二区三区免费观看 | 国产精品99久久久久| 99精品欧美一区| 欧美午夜在线一二页| 久久综合九色综合欧美就去吻| 欧美高清在线一区二区| 亚洲一区二区欧美日韩 | 欧美激情一区在线观看| 一区二区三区在线高清| 久久精品国内一区二区三区| 成人精品在线视频观看| 69久久夜色精品国产69蝌蚪网| 国产亚洲综合性久久久影院| 一区二区三区毛片| 国产在线日韩欧美| 欧美三级欧美一级| 欧美激情一区二区三区全黄 | 国内欧美视频一区二区| 在线观看网站黄不卡| 国产亚洲综合在线| 日本三级亚洲精品| 在线免费av一区| 中文字幕乱码一区二区免费|