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

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

?? main.c

?? rds解碼過程
?? C
?? 第 1 頁 / 共 3 頁
字號:
/*

Copyright (C) 2006 Marc Ketel

This program is free software; you can redistribute it and/or
modify it under the terms of the GNU General Public License
as published by the Free Software Foundation; either version 2
of the License, or (at your option) any later version.

This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
GNU General Public License for more details.

You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA.

*/

#define INFO "20060629-1 RDS Decoder by Marc Ketel alias DiNo, marc@atoomnet.net."
/*

Works with RDS clock signal and RDS data signal. During design a TDA7300B rds demodulator was used.

This source compiles correctly with WinAVR 20060421.

Use a Atmega168 to flash program into. low fuse: 0xF0, high fuse: 0xDD

Versions:
  20060629-1  Initial version

*/

/*

general word on ISR: it does not seem that ISR has global interrupts disabled.

*/

#include <avr/io.h>
#include <avr/interrupt.h>
#include <avr/pgmspace.h>
#include <avr/wdt.h>
#include <stdio.h>
#include <math.h>

#define RDS_PORT PIND
#define RDS_PIN  PD4

FILE* Uart;

//used for stdout
int uartSend(char data, FILE* stream) {
  //wait for completion of previous send
  loop_until_bit_is_set(UCSR0A, UDRE0);

  //send the data
  UDR0 = data;
  return 0;
}

//used for stdin
int uartRecv(FILE* stream) {
  loop_until_bit_is_set(UCSR0A, RXC0);
  return UDR0;
}

volatile unsigned char event = 0;
#define eventTimerOverflow      _BV(0)
#define eventUsart0RxDInterrupt _BV(1)
#define eventGroupComplete      _BV(2)
#define eventBitstreamSnapshot  _BV(3)
#define eventSyncLost           _BV(4)

volatile unsigned char timerOverflowCount = 0;
volatile unsigned char usart0RxDByte = 0;
volatile unsigned char bitCounter = 0;
volatile unsigned char bitCounterSnapshot = 0;

volatile unsigned char synchronized = 0;
volatile unsigned char syncQuality = 0; //0-31, 0=no useable signal, 15=medium quality, 31=perfect!
volatile unsigned char syncCounter = 0;

volatile unsigned char block = 0;
volatile unsigned long bitstream = 0;
volatile unsigned long bitstreamData = 0;
volatile unsigned int block1 = 0;
volatile unsigned int block2 = 0;
volatile unsigned int block3 = 0;
volatile unsigned int block4 = 0;

//ISR is executed when there is a new rds bit to read
ISR(INT0_vect) {
  cli();
  unsigned int syndrome = 0;
  
  //Copy global vars to local vars for performance
  unsigned long bitstreamLocal = bitstream;
  unsigned char blockLocal = block;
  
  //shift rds bit in on right side
  bitstreamLocal *= 2; 
  if (RDS_PORT & _BV(RDS_PIN))
    bitstreamLocal++;
    
  bitCounter++;
  
  //collect data for raw bitstream snapshots
  bitCounterSnapshot++;
  if (bitCounterSnapshot == 26) {
    bitstreamData = (bitstreamLocal & 0x3FFFFFF);
    bitCounterSnapshot = 0;
    
    event |= eventBitstreamSnapshot;
  }
  
  //when we have 26 bits or are not synchronized to the stream
  //check the CRC and maybe store a rds block
  if (bitCounter == 26 || !synchronized) {
  
    bitstreamLocal &= 0x3FFFFFF; //we only need 26 bits
  
    syndrome = (bitstreamLocal / 0x10000); //bits 16-31 (2^16)
  
    if (bitstreamLocal & _BV(0))
      syndrome ^= 0x031b;
    
    if (bitstreamLocal & _BV(1))
      syndrome ^= 0x038f;
    
    if (bitstreamLocal & _BV(2))
      syndrome ^= 0x02a7;
      
    if (bitstreamLocal & _BV(3))
      syndrome ^= 0x00f7;
    
    if (bitstreamLocal & _BV(4))
      syndrome ^= 0x01ee;
    
    if (bitstreamLocal & _BV(5))
      syndrome ^= 0x03dc;
    
    if (bitstreamLocal & _BV(6))
      syndrome ^= 0x0201;
    
    if (bitstreamLocal & _BV(7))
      syndrome ^= 0x01bb;
    
    if (bitstreamLocal & _BV(8))
      syndrome ^= 0x0376;
    
    if (bitstreamLocal & _BV(9))
      syndrome ^= 0x0355;
  
    if (bitstreamLocal & _BV(10))
      syndrome ^= 0x0313;
    
    if (bitstreamLocal & _BV(11))
      syndrome ^= 0x039f;
  
    if (bitstreamLocal & _BV(12))
      syndrome ^= 0x0287;
      
    if (bitstreamLocal & _BV(13))
      syndrome ^= 0x00b7;
    
    if (bitstreamLocal & _BV(14))
      syndrome ^= 0x016e;

    if (bitstreamLocal & 0b1000000000000000) // _BV(15) does not work!!!
      syndrome ^= 0x02dc;

    //Block A?
    if (blockLocal == 0 && syndrome == 0x03d8) {
      block1 = bitstreamLocal / 0x400; //bits 10-25 (2^10)
      synchronized = 1;
      blockLocal++;
    } else 
    //Block B?
    if (blockLocal == 1 && syndrome == 0x03d4) {
      block2 = bitstreamLocal / 0x400; //bits 10-25 (2^10)
      synchronized = 1;
      blockLocal++;
    } else  
    //Block C type A?
    if (blockLocal == 2 && !(block2 & _BV(11)) && syndrome == 0x025c) {
      block3 = bitstreamLocal / 0x400; //bits 10-25 (2^10)
      synchronized = 1;
      blockLocal++;
    } else
    //Block C type B?
    if (blockLocal == 2 && (block2 & _BV(11)) && syndrome == 0x03cc) {
      block3 = bitstreamLocal / 0x400; //bits 10-25 (2^10)
      synchronized = 1;
      blockLocal++;
    } else
    //Block D?
    if (blockLocal == 3 && syndrome == 0x0258) {
      block4 = bitstreamLocal / 0x400; //bits 10-25 (2^10)
      synchronized = 1;
      blockLocal = 0;
      //we have a complete group!
      event |= eventGroupComplete;
    } else {
      //sync lost..
      synchronized = 0;
      blockLocal = 0;
      event |= eventSyncLost;
    }
    
    bitCounter = 0; 
  }
  
  if (event & eventGroupComplete) {
    PORTC |= _BV(PC1);
    
    if (syncQuality < 31)
      syncQuality++;
    
  } else if (!synchronized) {
    PORTC &= ~_BV(PC1);
    
    syncCounter++;
    if (syncQuality > 0 && syncCounter == 26) {
      syncQuality--;
      syncCounter = 0;
    }
      
  }
  
  if (syncQuality >= 15)
    PORTC |= _BV(PC2);
  else
    PORTC &= ~_BV(PC2);
  
  //Store local vars into global vars to remember state
  bitstream = bitstreamLocal;
  block = blockLocal;
  sei();
}

//timer0 overflowed
ISR(TIMER0_OVF_vect) {
  cli();
  timerOverflowCount++;
  if (timerOverflowCount > 4) {
    event |= eventTimerOverflow;
    timerOverflowCount = 0;
  }
  sei();
}

ISR(USART_RX_vect) {
  cli();
  usart0RxDByte = UDR0;
  event |= eventUsart0RxDInterrupt;
  sei();
}

void displayInfo(void) {
  printf_P(PSTR("INFO: 0x01, "));
  printf_P(PSTR(INFO));
  printf_P(PSTR("\r\n"));
}

int main(void) {

  wdt_reset(); //reset inmediately in case of a previous system reset
  //lets enable watchdog with 1 second timeout
  wdt_enable(WDTO_1S);

  unsigned int  programmeIdentificationCode = 0;
  unsigned char groupType = 0;
  unsigned char groupVersion = 0;
  unsigned char trafficProgrammeIdentificationCode = 0;
  unsigned char programmeTypeCode = 0;
  unsigned char trafficAnnouncementCode = 0;
  unsigned char musicSpeechSwitchScode = 0;
  unsigned char group0CodeBits = 0;
  unsigned char group0CodeBitsSteadyCount = 0;
  unsigned char programmeServiceName[8];
  unsigned char programmeServiceNameNew[8];
  unsigned char decoderIdentificationControlCode = 0;
  unsigned char decoderIdentificationControlCodeNew = 0;
  unsigned char alternativeFrequencyCodes[27];
  unsigned char syncMessage = 0;
  unsigned char displayRaw = 0;
  unsigned char displayBitstream = 0;
  unsigned char linkageActuator = 0;
  unsigned char extendedCountryCode = 0;
  unsigned char textSegmentAddress = 0;
  unsigned char textSegmentAddressPrevious = 0;
  unsigned char textVersion = 0;
  unsigned char textVersionPrevious = 0; 
  unsigned char radioText[64];
  unsigned char radioTextPrevious[64];
  unsigned char textSegmentAddress0Seen = 0;
  unsigned int  modifiedJulianDay = 0;
  unsigned int  utcYear = 0;
  unsigned char utcMonth = 0;
  unsigned char utcDay = 0;
  signed   char localHours = 0;
  unsigned char utcHours = 0;
  signed   char localMinutes = 0;
  unsigned char utcMinutes = 0;
  unsigned char utcMinutesPrevious = 0xFF;
  unsigned char localSign = 0;
  unsigned int  localTimeOffset = 0;
  
  //general purpose vars
  unsigned int  m;
  unsigned char h;
  unsigned char i;
  unsigned char j;
  
  //1.8mhz crystal
  //baudrate 115.2K
  //UBRR0 = 0;
  //baudrate 9600
  //UBRR0 = 11;
  
  //16mhz crystal
  //38.4k
  //UBRR0 = 25;
  
  //4.332Mhz crystal
  //baudrate 38K4
  UBRR0 = 6;
  
  //enable RxD interrupt, RxD, TxD
  UCSR0B |= _BV(RXCIE0) | _BV(RXEN0) | _BV(TXEN0);
  
  //8 bit
  //UCSR0C |= _BV(UCSZ00) | _BV(UCSZ01);
  
  //UART is stdout and stdin;
  Uart = fdevopen(uartSend, uartRecv);

  //enable int0
  EIMSK = _BV(INT0);
  
  //INT0 raising edge
  EICRA |= _BV(ISC01) | _BV(ISC00);
  
  //PC0, PC1, PC2 are outputs;
  DDRC |= _BV(PC0) | _BV(PC1) | _BV(PC2);

  //timer0 prescaler clk/1024
  TCCR0B |= _BV(CS02) | _BV(CS00);
  //enable overflow interrupt
  TIMSK0 |= _BV(TOIE0);
  
  displayInfo();
  
  sei(); //enable interrupts;
  
  for (;;) {
    
    do {} while (!event);
    wdt_reset(); //reset watchdog, we are still alive!
    
    cli();
    if (event & eventUsart0RxDInterrupt) {
      event &= ~eventUsart0RxDInterrupt;
      sei();
      
      //collect the command
      
      //switch group display on (G) or off (g)
      if (usart0RxDByte == 'G')
        displayRaw = 0;
      else if (usart0RxDByte == 'g')
        displayRaw = 1;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲精品一区在线观看| 欧美激情一区二区三区四区| 91天堂素人约啪| 色域天天综合网| 国产成人av影院| 在线观看不卡视频| 久久网这里都是精品| 人人爽香蕉精品| 欧美性猛交一区二区三区精品| 欧美xfplay| 精品在线播放免费| 日韩欧美国产三级电影视频| 肉色丝袜一区二区| 欧美电影在线免费观看| 午夜电影一区二区三区| 日韩精品专区在线影院观看| 色噜噜夜夜夜综合网| 日韩免费成人网| 艳妇臀荡乳欲伦亚洲一区| 国产一区二区剧情av在线| 在线精品视频一区二区三四| 欧美一区二区日韩| 亚洲色图丝袜美腿| 成人午夜精品一区二区三区| 日韩午夜av电影| 亚洲午夜精品久久久久久久久| 国产风韵犹存在线视精品| 91精品国产麻豆| 亚洲一区二区三区影院| www.成人网.com| 国产精品久久久久久久午夜片| 蜜臀av在线播放一区二区三区 | 欧美一区二区黄| 亚洲www啪成人一区二区麻豆| 99久久婷婷国产综合精品电影| 欧美国产一区视频在线观看| 青青草国产精品97视觉盛宴| 亚洲第一成年网| 香蕉av福利精品导航| 免费在线观看精品| 秋霞av亚洲一区二区三| 国产成人午夜视频| 91久久久免费一区二区| 精品久久人人做人人爽| 日韩电影一二三区| 精品国产一区二区三区av性色| 亚洲成人av一区二区| 欧美乱妇15p| 日本亚洲三级在线| 久久―日本道色综合久久| 国产精品99久久久久久久女警| 久久精品亚洲国产奇米99| 国产精品亚洲午夜一区二区三区| 国产亚洲欧美一级| 色菇凉天天综合网| 久久国产精品色婷婷| 国产视频亚洲色图| 色婷婷精品久久二区二区蜜臀av| 亚洲午夜在线视频| 国产亚洲人成网站| 欧美影片第一页| 久久99精品国产麻豆婷婷| 国产精品日日摸夜夜摸av| 在线免费观看日本欧美| 韩国精品一区二区| 一个色妞综合视频在线观看| 国产午夜久久久久| 日韩免费观看高清完整版| 国产福利电影一区二区三区| 一区二区三区国产豹纹内裤在线 | 日韩精品一区二区三区中文精品| 波多野结衣亚洲| 麻豆精品在线视频| 日韩激情在线观看| 亚洲一二三区视频在线观看| 国产欧美一区二区精品秋霞影院 | 亚洲一级片在线观看| 国产精品五月天| 精品处破学生在线二十三| 欧美一区二区三区视频免费播放| 色妞www精品视频| 色综合久久综合网| jlzzjlzz亚洲日本少妇| 成人av网站在线| 91亚洲精品久久久蜜桃| va亚洲va日韩不卡在线观看| 国产福利精品导航| 国产激情91久久精品导航| 国产电影一区二区三区| 国产成人aaa| 99re视频这里只有精品| 色婷婷久久久综合中文字幕| 欧美中文字幕亚洲一区二区va在线| 99精品国产一区二区三区不卡| 色综合久久久久| 欧美一区二区免费视频| 久久婷婷综合激情| 亚洲视频中文字幕| 午夜a成v人精品| 国产精品自拍毛片| 91欧美一区二区| 91精品国产综合久久久久久 | 蜜桃在线一区二区三区| 国产乱子伦视频一区二区三区 | 欧美mv日韩mv亚洲| 国产欧美一区二区在线观看| 亚洲精品五月天| 激情亚洲综合在线| 欧美日韩大陆在线| 国产亚洲人成网站| 欧美96一区二区免费视频| 不卡一区在线观看| 日韩精品一区二区三区中文精品| 国产精品久久二区二区| 日韩激情av在线| 色网站国产精品| 国产精品欧美极品| 精久久久久久久久久久| 欧美日韩中文国产| 亚洲激情图片一区| 99九九99九九九视频精品| 欧美精品一区男女天堂| 久久狠狠亚洲综合| 911精品国产一区二区在线| 一区二区在线电影| 日本伦理一区二区| 亚洲另类色综合网站| 99精品偷自拍| 中文字幕一区二| 九九在线精品视频| 国产精品不卡一区| 欧美性猛交xxxxxx富婆| 国产精品一区在线观看你懂的| 欧美日韩色一区| 精品国产乱码久久久久久影片| 成人av在线播放网址| 久久国产精品色| 亚洲老司机在线| 国产精品第五页| 久久久亚洲精品一区二区三区| 欧美调教femdomvk| 一本到不卡精品视频在线观看| 国产美女娇喘av呻吟久久| 午夜影院在线观看欧美| 亚洲欧美一区二区久久| 久久亚洲一级片| 欧美福利电影网| 99视频国产精品| 国产成人免费视频精品含羞草妖精| 一区二区在线免费| 综合色天天鬼久久鬼色| 2欧美一区二区三区在线观看视频| 色综合一区二区三区| eeuss鲁片一区二区三区在线观看 eeuss鲁片一区二区三区在线看 | 玖玖九九国产精品| 亚洲18色成人| 亚洲欧洲在线观看av| 日本一区二区三区久久久久久久久不 | 欧美日韩不卡在线| 91在线播放网址| 99久久精品免费看| 91在线一区二区| 欧美中文字幕久久| 91精品综合久久久久久| 免费不卡在线观看| 波多野结衣一区二区三区| 成人免费高清在线观看| www.爱久久.com| 欧美日韩国产经典色站一区二区三区| 91丨porny丨户外露出| 91麻豆国产自产在线观看| av不卡在线观看| 欧美午夜不卡视频| 日韩精品中文字幕一区| 日韩午夜av电影| 最新日韩av在线| 奇米色777欧美一区二区| 国产乱码精品一区二区三| 成人高清视频在线观看| 色婷婷综合久久久中文一区二区| 欧美四级电影在线观看| www国产亚洲精品久久麻豆| 国产精品国产三级国产aⅴ入口| 亚洲免费在线观看| 国产精品亚洲综合一区在线观看| 99re视频精品| 久久综合丝袜日本网| 最近中文字幕一区二区三区| 日韩高清不卡一区二区| 99久久免费国产| 欧美一区二区私人影院日本| 亚洲国产成人一区二区三区| 亚洲一区二区在线免费观看视频| 国产米奇在线777精品观看| 欧美视频自拍偷拍| 中文字幕国产一区| 国内精品视频666| 日韩一区二区精品在线观看| 久久在线观看免费| 久久精品国产77777蜜臀|