Пятница, 19.04.2024, 00:26
Микроконтроллерная техника AVR
Главная Регистрация Вход
Приветствую Вас, Гость · RSS
[ Новые сообщения · Участники · Правила форума · Поиск · RSS ]
  • Страница 1 из 1
  • 1
Форум » Микроконтроллеры » Вопросы по статьям » Приёмник кодировки Keeloq (Помогите переписать код под 1602 идикатор)
Приёмник кодировки Keeloq
IROBOTДата: Суббота, 31.01.2009, 10:47 | Сообщение # 1
Рядовой
Группа: Пользователи
Сообщений: 8
Репутация: 1
Статус: Offline
Вообщем в мк я по минимуму разбираюсь на уровне прошить и чуть программить,заинтересовался проблемой приёма и анализа кодировки KEELOQ ,нашёл в инете исходник приёмника с выводом наrs232,попогите советом как переделать исходник под 1602 индикатор?Прикладываю исходник выше описываемый и исходник от микрочипа с которого видимо писаля приёмник
#include <mega8.h>

#include <stdio.h>
#include <delay.h>
#include <String.h>

#define TRFreset 0
#define TRFSYNC 1
#define TRFUNO 2
#define TRFZERO 3

#define NBIT 65

#define HIGH_TO -10
#define LOW_TO 10
#define SHORT_HEAD 20
#define LONG_HEAD 45

#define RfIn PIND.4

typedef unsigned char byte;

bit RFFull;
bit RFBit;
int RFcount;
byte Bptr,BitCount,RFstate,Buf[9];
/////////////// receive /////////////////////////////////
interrupt [TIM0_OVF] void timer0_ovf_isr(void)
{
TCNT0=135;
RFBit=RfIn;

if (RFFull)
return;
/////////////////////////////////////////////////////////
switch(RFstate)
{
case TRFUNO:
if ( RFBit == 0)
{
RFstate= TRFZERO;
}
else
{
RFcount--;
if (RFcount < HIGH_TO) RFstate = TRFreset;
}
break;
//////////////////////////////////////////////////////////
case TRFZERO:
if (RFBit)
{
RFstate= TRFUNO;
Buf[Bptr] >>= 1;
if ( RFcount >= 0)
{
Buf[Bptr]+=0x80;
}
RFcount = 0;
if ((++BitCount & 7) == 0) Bptr++;

if (BitCount == NBIT)
{
printf("Reseive signal:");
printf("%02X%02X%02X%02X%02X%02X%02X%02X",
Buf[0],Buf[1],Buf[2],Buf[3],Buf[4],Buf[5],Buf[6],Buf[7]);
printf("\n\r");

RFstate = TRFreset;
RFFull = 1;
}
}
else
{
RFcount++;
if ( RFcount >= LOW_TO)
{
RFstate = TRFSYNC;
Bptr = 0;
BitCount = 0;
}
}
break;
///////////////////////////////////////////////////////////
case TRFSYNC:
if ( RFBit)
{
if ((RFcount < SHORT_HEAD)||(RFcount >= LONG_HEAD))
{
RFstate = TRFreset;break;
}
else
{
RFcount =0;RFstate= TRFUNO;
}
}
else
{
RFcount++;
}
break;
/////////////////////////////////////////////////////////////
case TRFreset:
default:
RFstate = TRFSYNC;
RFcount = 0;
Bptr = 0;
BitCount = 0;
break;
} // switch
//////////////////////////////////////////////////////////////
if(RFFull)
{
RFstate = TRFreset;
RFFull=0;
}
/////////////////////////////////////////////////////////////
} // receive
////////////////// main ////////////////////////////////////
void main(void)
{
PORTD=0x10;
DDRD=0x00;

TCCR0=0x02;
TCNT0=0x00;

TIMSK=0x01;

UCSRA=0x00;
UCSRB=0x08;
UCSRC=0x86;
UBRRH=0x00;
UBRRL=0x33;

////////////////////////////////////////////////////////////
printf(" WAIT SIGNAL!\n\r");
printf("\n\r");
////////////////////////////////////////////////////////////
#asm("sei")
}// main

Добавлено (31.01.2009, 10:47)
---------------------------------------------
а вот от микрочипа исходник
// Filename: RXI.c
//*********************************************************************
// Author: Lucio Di Jasio
// Company: Microchip Technology
// Revision: Rev 1.00
// Date: 08/07/00
//
// Interrupt based receive routine
//
// Compiled using HiTech PIC C compiler v.7.93
// Compiled using CCS PIC C compiler v.2.535
//********************************************************************
#define CLOCK 4 // MHz
#define TE 400 // us
#define OVERSAMPLING 3
#define PERIOD TE/OVERSAMPLING*4/CLOCK

#define NBIT 65 // number of bit to receive -1

byte B[9]; // receive buffer

static byte RFstate; // receiver state
static sbyte RFcount; // timer counter
static byte Bptr; // receive buffer pointer
static byte BitCount; // received bits counter
word XTMR; // 16 bit extended timer

volatile bit RFFull; // buffer full
volatile bit RFBit; // sampled RF signal

#define TRFreset 0
#define TRFSYNC 1
#define TRFUNO 2
#define TRFZERO 3

#define HIGH_TO -10 // longest high Te
#define LOW_TO 10 // longest low Te
#define SHORT_HEAD 20 // shortest Thead accepted 2,7ms
#define LONG_HEAD 45 // longest Thead accepted 6,2ms

#pragma int_rtcc // install as interrupt handler (comment for HiTech!)
interrupt
rxi()
{
// this routine gets called every time TMR0 overflows
RFBit = RFIn; // sampling RF pin verify!!!
TMR0 -= PERIOD; // reload
T0IF = 0;

XTMR++; // extended 16 long timer update

if (RFFull) // avoid overrun
return;

switch( RFstate) // state machine main switch
{

case TRFUNO:
if ( RFBit == 0)
{ // falling edge detected ----+
// |
// +----
RFstate= TRFZERO;
}
else
{ // while high
RFcount--;
if ( RFcount < HIGH_TO)
RFstate = TRFreset; // reset if too long
}
break;

case TRFZERO:
if ( RFBit)
{ // rising edge detected +----
// |
// ----+
RFstate= TRFUNO;
B[Bptr] >>= 1; // rotate
if ( RFcount >= 0)
{
B[Bptr]+=0x80; // shift in bit
}
RFcount = 0; // reset length counter

if ( ( ++BitCount & 7) == 0)
Bptr++; // advance one byte
if (BitCount == NBIT)
{
RFstate = TRFreset; // finished receiving
RFFull = TRUE;
}
}
else
{ // still low
RFcount++;
if ( RFcount >= LOW_TO) // too long low
{
RFstate = TRFSYNC; // fall back into RFSYNC state
Bptr = 0; // reset pointers, while keep counting on
BitCount = 0;
}
}
break;

case TRFSYNC:
if ( RFBit)
{ // rising edge detected +---+ +---..
// | | <-Theader-> |
// +----------------+
if ( ( RFcount < SHORT_HEAD) || ( RFcount >= LONG_HEAD))
{
RFstate = TRFreset;
break; // too short/long, no header
}
else
{
RFcount =0; // restart counter
RFstate= TRFUNO;
}
}
else
{ // still low
RFcount++;
}
break;

case TRFreset:
default:
RFstate = TRFSYNC; // reset state machine in all other cases
RFcount = 0;
Bptr = 0;
BitCount = 0;
break;

} // switch


} // rxi

void InitReceiver()
{
T0IF = 0;
T0IE = 1; // TMR0 overflow interrupt
GIE = 1; // enable interrupts
RFstate = TRFreset; // reset state machine in all other cases
RFFull = 0; // start with buffer empty
XTMR = 0; // start extended timer
}


Не надо мне 15 раз объяснять-я с 9-го понимаю
 
my-avrДата: Вторник, 03.02.2009, 13:40 | Сообщение # 2
Admin
Группа: Администраторы
Сообщений: 79
Репутация: 10
Статус: Offline
А можно немного теории поличить, что такое Keelog и почему Вы хотите переделать его под LCD дисплей?
 
IROBOTДата: Вторник, 03.02.2009, 18:37 | Сообщение # 3
Рядовой
Группа: Пользователи
Сообщений: 8
Репутация: 1
Статус: Offline
MICROCHIP в России и в мире. Продукция фирмы MICROCHIP, ставшая популярной в России несколько лет назад благодаря высокому качеству изделий, хорошим бесплатным программным средствам поддержки разработки и простоты освоения, продолжает пополняться новыми изделиями. Сейчас на безграничном рынке охранных систем одно из ведущих мест заняло семейство кодеров/декодеров HCS*** MICROCHIP под торговой маркой "Keeloq". Название "Keeloq" созвучно английским словам key (ключ) и lock (замок). Разработанные для систем контроля доступа, эти микросхемы завоевали признание исключительно высокой защищенностью и функциональной законченностью у таких серьезных производителей, как Chrysler, Daewoo, Fiat, GM, Honda, Toyota, Volvo, VW, Clifford, Shurlok и многих других.

История Keeloq. Keeloq - это система алгоритмов, разработанная и запатентованная Южно-Африканской компанией Nanoteq в середине 80-х. Nanoteq была основана экспертами по кодированию и электронике из университета Претории и занималась вопросами информационной безопасности.

В настоящее время алгоритм Keeloq принят во всем мире и положен в основу тестовых критериев для систем безопасности в Великобритании, адаптирован рядом европейских производителей и использован в собственных системах, разработанных "Форд" (для Escort) и "Ягуар" (для XJS).

В догонку более точное описание здесь http://www.microchip.ru/lit/keeloq/keeloq_1.htm
http://www.microchip.ru/lit/keeloq/keeloq_2.htm
А на 1602 хочу переделать чтоб можно было носить с собой прибор


Не надо мне 15 раз объяснять-я с 9-го понимаю
 
extremistДата: Среда, 04.02.2009, 14:53 | Сообщение # 4
Рядовой
Группа: Пользователи
Сообщений: 15
Репутация: 2
Статус: Offline
Шо за хрень....
 
IROBOTДата: Среда, 04.02.2009, 15:59 | Сообщение # 5
Рядовой
Группа: Пользователи
Сообщений: 8
Репутация: 1
Статус: Offline
этот формат используется в сигналках-дистанционках автомобильных

Не надо мне 15 раз объяснять-я с 9-го понимаю
 
extremistДата: Вторник, 10.03.2009, 12:55 | Сообщение # 6
Рядовой
Группа: Пользователи
Сообщений: 15
Репутация: 2
Статус: Offline
Я слышал что дядьки работающие на заводе Мерседес у которых доступ есть к алгоритмам шифрования сигналок пару раз воровали инфу и продавали за не малые деньги, в следствии чего потом много Мерсов уезжало от хозяев. Я думаю там оч серъезно все... и ключи шифрования 128-ми битные как минимум...
 
Форум » Микроконтроллеры » Вопросы по статьям » Приёмник кодировки Keeloq (Помогите переписать код под 1602 идикатор)
  • Страница 1 из 1
  • 1
Поиск:

Хостинг от uCoz