реклама на сайте
подробности

 
 
2 страниц V   1 2 >  
Reply to this topicStart new topic
> Из Atmega8 в Atmega16, TWI не хочет мигрировать
Basilkmv06
сообщение Jun 6 2006, 17:16
Сообщение #1





Группа: Участник
Сообщений: 13
Регистрация: 14-01-06
Пользователь №: 13 169



Очень внимательно прочитал ветку "Проблема с TWI", но вопросы остались.
Суть вопроса такова. До сихпор пользовался мегой8 и ее аппаратным TWI в слайве, но быстрый переход на мегу16 не удался. После долгих ковыряний всяких доков написал маленький софт на
LPT (что-то вроде мастера TWI). Пришел к выводу, что при таких равных условиях
1. Оба кристала подключены по одинаковой схеме;
2. Оба работают на внутреннем генераторе 8МГц;
3. Оба кристала выполняют одинаковый код
мега16 отказывается работать уже на частоте CLK ~150кГц, когда как м8 только на ~270кГц.
Обе проца 16мегагерцовые, единственное м8-PDIP, а м16- TQFP. В чем может быть пичина?
Go to the top of the page
 
+Quote Post
defunct
сообщение Jun 6 2006, 19:10
Сообщение #2


кекс
******

Группа: Свой
Сообщений: 3 825
Регистрация: 17-12-05
Из: Киев
Пользователь №: 12 326



Цитата(Basilkmv06 @ Jun 6 2006, 20:16) *
мега16 отказывается работать уже на частоте CLK ~150кГц, когда как м8 только на ~270кГц.
Обе проца 16мегагерцовые, единственное м8-PDIP, а м16- TQFP. В чем может быть пичина?

Возможно в емкости линии. Что если попробовать уменьшить сопротивление между Vcc и линиями данных?
Go to the top of the page
 
+Quote Post
GetSmart
сообщение Jun 6 2006, 23:29
Сообщение #3


.
******

Группа: Участник
Сообщений: 4 005
Регистрация: 3-05-06
Из: Россия
Пользователь №: 16 753



Ух ты. Не знал, что LPT можно использовать как TWI. А как оно будет читать данные (DTA) ? Что можно сделать только в одну сторону меня не удивляет, а вот как в обе стороны? Через диод што ли?
_____________
Может проблема в неправильных формах старт/стоп битов, формируемых LPT? В смысле временных их характеристиках.


--------------------
Заблуждаться - Ваше законное право :-)
Go to the top of the page
 
+Quote Post
Basilkmv06
сообщение Jun 7 2006, 10:41
Сообщение #4





Группа: Участник
Сообщений: 13
Регистрация: 14-01-06
Пользователь №: 13 169



Цитата(GetSmart @ Jun 7 2006, 03:29) *
Ух ты. Не знал, что LPT можно использовать как TWI. А как оно будет читать данные (DTA) ? Что можно сделать только в одну сторону меня не удивляет, а вот как в обе стороны? Через диод што ли?


Все просто. Два OUT бита LPT для передачи CLK и SDA, а один IN бит LPT для чтения SDA, SDA IN и SDA OUT развязаны LMкой.

Цитата(GetSmart @ Jun 7 2006, 03:29) *
Может проблема в неправильных формах старт/стоп битов, формируемых LPT? В смысле временных их характеристиках.


Уже года четыре пользуюсь програмкой для заливки всяких AT24CXXX, ни каких проблем не было.
Старты/стопы даже с метровым кабелем по временным характеристика довольно приличные.
А вот на счет емкости лини не знаю. А может входная емксть меги16 быть больше меги8?
Go to the top of the page
 
+Quote Post
Faradey
сообщение Jun 7 2006, 17:39
Сообщение #5


Частый гость
**

Группа: Свой
Сообщений: 127
Регистрация: 31-05-06
Из: Belarus, Minsk
Пользователь №: 17 638



может я не в тему а на какой частое узаете TWI?
я помнится на 400 с чемто заводил и все работало...


--------------------
Завтра пойму, что нужно было сделать вчера...
Go to the top of the page
 
+Quote Post
Basilkmv06
сообщение Jun 8 2006, 15:19
Сообщение #6





Группа: Участник
Сообщений: 13
Регистрация: 14-01-06
Пользователь №: 13 169



Цитата(Faradey @ Jun 7 2006, 21:39) *
может я не в тему а на какой частое узаете TWI?
я помнится на 400 с чемто заводил и все работало...


TWI используется на частоте 250. В этом то и проблема, мега16 не хочет работать на такой частоте.
Сегодня еще покопался и проверил регистр состояния он после первой посылки 0x00, т. е. ошибка на шине. Сую вместо м16 м8 с идентичными кодами все работает. Повесил на шины уже по 1кОм, все равно таже ерунда.
Не может же TWIный модуль меги16 отличаться от меги8?
Go to the top of the page
 
+Quote Post
GetSmart
сообщение Jun 9 2006, 00:09
Сообщение #7


.
******

Группа: Участник
Сообщений: 4 005
Регистрация: 3-05-06
Из: Россия
Пользователь №: 16 753



А может микруха глючная? Если есть вторая, то проверить бы.


--------------------
Заблуждаться - Ваше законное право :-)
Go to the top of the page
 
+Quote Post
GetSmart
сообщение Jun 9 2006, 02:25
Сообщение #8


.
******

Группа: Участник
Сообщений: 4 005
Регистрация: 3-05-06
Из: Россия
Пользователь №: 16 753



Я бы не полагался на PC-i2c и для проверки связал бы два процессора например мегу16 и старую мегу8. Выставил бы на них те же 250 и убедился, что всё работает. А потом бы жаловался на писюху.


--------------------
Заблуждаться - Ваше законное право :-)
Go to the top of the page
 
+Quote Post
Starick
сообщение Jun 9 2006, 14:43
Сообщение #9


Участник
*

Группа: Участник
Сообщений: 34
Регистрация: 4-09-05
Пользователь №: 8 211



Цитата(Basilkmv06 @ Jun 6 2006, 20:16) *
Очень внимательно прочитал ветку "Проблема с TWI", но вопросы остались.
Суть вопроса такова. До сихпор пользовался мегой8 и ее аппаратным TWI в слайве, но быстрый переход на мегу16 не удался. После долгих ковыряний всяких доков написал маленький софт на
LPT (что-то вроде мастера TWI). Пришел к выводу, что при таких равных условиях
1. Оба кристала подключены по одинаковой схеме;
2. Оба работают на внутреннем генераторе 8МГц;
3. Оба кристала выполняют одинаковый код
мега16 отказывается работать уже на частоте CLK ~150кГц, когда как м8 только на ~270кГц.
Обе проца 16мегагерцовые, единственное м8-PDIP, а м16- TQFP. В чем может быть пичина?


Может я не понял чего - то, но что значит на внутреннем генераторе 8 МГц??? Внутренний генератор у меги8 и 16 вообще - то 1МГц. Не путаете ли Вы чего - то?? smile.gif
Go to the top of the page
 
+Quote Post
bodja74
сообщение Jun 9 2006, 14:56
Сообщение #10


Знающий
****

Группа: Свой
Сообщений: 543
Регистрация: 22-10-05
Пользователь №: 9 984



Внутрений генератор у мег на 1,2,4 и 8Мгц.

Сообщение отредактировал bodja74 - Jun 9 2006, 14:57
Go to the top of the page
 
+Quote Post
bodja74
сообщение Jun 9 2006, 15:15
Сообщение #11


Знающий
****

Группа: Свой
Сообщений: 543
Регистрация: 22-10-05
Пользователь №: 9 984



Еще ,выкладывайте инициализацию TWI слейва,посмотрим.
Кроме того ,если обработка прерывания у слейва долгая,он будет "затягивать" ACK,
Если у вашей проги на компе такой проверки нет ,будет глючить.
Но мне больше здается такторая частота заложена разная,проверте внимательно.
Go to the top of the page
 
+Quote Post
Basilkmv06
сообщение Jun 9 2006, 15:32
Сообщение #12





Группа: Участник
Сообщений: 13
Регистрация: 14-01-06
Пользователь №: 13 169



Цитата(Starick @ Jun 9 2006, 18:43) *
Цитата(Basilkmv06 @ Jun 6 2006, 20:16) *

Очень внимательно прочитал ветку "Проблема с TWI", но вопросы остались.
Суть вопроса такова. До сихпор пользовался мегой8 и ее аппаратным TWI в слайве, но быстрый переход на мегу16 не удался. После долгих ковыряний всяких доков написал маленький софт на
LPT (что-то вроде мастера TWI). Пришел к выводу, что при таких равных условиях
1. Оба кристала подключены по одинаковой схеме;
2. Оба работают на внутреннем генераторе 8МГц;
3. Оба кристала выполняют одинаковый код
мега16 отказывается работать уже на частоте CLK ~150кГц, когда как м8 только на ~270кГц.
Обе проца 16мегагерцовые, единственное м8-PDIP, а м16- TQFP. В чем может быть пичина?


Может я не понял чего - то, но что значит на внутреннем генераторе 8 МГц??? Внутренний генератор у меги8 и 16 вообще - то 1МГц. Не путаете ли Вы чего - то?? smile.gif

Читайте док, учите аглицкий.

Note: 1. The device is shipped with this option selected.
When this Oscillator is selected, start-up times are determined by the SUT Fuses as
shown in Table 10. XTAL1 and XTAL2 should be left unconnected (NC).
Table 9. Internal Calibrated RC Oscillator Operating Modes
CKSEL3..0 Nominal Frequency (MHz)
0001 (1) 1.0
0010 2.0
0011 4.0
0100 8.0
Go to the top of the page
 
+Quote Post
Basilkmv06
сообщение Jun 9 2006, 15:51
Сообщение #13





Группа: Участник
Сообщений: 13
Регистрация: 14-01-06
Пользователь №: 13 169



Цитата(bodja74 @ Jun 9 2006, 19:15) *
Еще ,выкладывайте инициализацию TWI слейва,посмотрим.
Кроме того ,если обработка прерывания у слейва долгая,он будет "затягивать" ACK,
Если у вашей проги на компе такой проверки нет ,будет глючить.
Но мне больше здается такторая частота заложена разная,проверте внимательно.

Полный текст (почти)
/*****************************************************
This program was produced by the
CodeWizardAVR V1.24.2c Standard
Automatic Program Generator
© Copyright 1998-2004 Pavel Haiduc, HP InfoTech s.r.l.
http://www.hpinfotech.ro
e-mail:office@hpinfotech.ro

Project :
Version :
Date : 05.02.2006
Author : Basil
Company :
Comments:


Chip type : ATmega8
Program type : Application
Clock frequency : 8,000000 MHz
Memory model : Small
External SRAM size : 0
Data Stack size : 256
*****************************************************/

#include <mega8.h>


unsigned char i,j;

unsigned char rom_code[9];
unsigned char devices;




unsigned char adr,cmd;
unsigned char cmd_57=0xE8;
unsigned char cmd_50[8]={0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff};//{0x01,0x6e,0x7e,0x00,0x0a,0x00,0x0,0x85};
unsigned char ds_4[4,8];
eeprom unsigned char cmd_00[0x8a];



unsigned char cmd_52=0x00;


union ULI {
unsigned char b[8];
unsigned long int word[2];
unsigned int pword[4];
};
union ULI cmd_30;





unsigned char w=0;




void iter(void)
{
cmd_30=...
}




// 2 Wire bus interrupt service routine
interrupt [TWI] void twi_isr(void)
{
switch (TWSR){

case 0xA0: //Áûë îáíàðóæåí START

TWCR=0x45;
TWCR|=0x80;


break;


case 0x60: //Áûë ïðèíÿò SLA+W ñ ñîáñòåííûì àäðåñîì è ïîñëàíî ïîäòâåðæäåíèå
// w=0;
// adr=0;
// cmd=0;
TWCR=0x45;
TWCR|=0x80;
break;

case 0x80: //Óñòðîéñòâî óæå àäðåñîâàíî, áûë ïðèíÿò áàò äàííûõ è ïîñëàíî ïîäòâåðæäåíèå

if (w==0)
{
adr=TWDR;
w=1;
TWCR=0x45;
TWCR|=0x80;
break;

}
else
{

if (w==1)
{
cmd=TWDR;
w=2;
TWCR=0x45;
TWCR|=0x80;
break;
};
};

if (w==2)
{
switch (cmd){
case 0x20:
cmd_30.b[adr]=TWDR;
cmd=0;
adr=0;
w=0;
TWCR=0x45;
TWCR|=0x80;
break;

case 0x00:
cmd_00[adr]=TWDR;
cmd=0;
adr=0;
w=0;
TWCR=0x45;
TWCR|=0x80;
break;

case 0x50:
///if ((adr==0x3A) & (TWDR==0xCE)) scan_ds();
// scan_ds();
cmd=0;
adr=0;
w=0;
TWCR=0x45;
TWCR|=0x80;
break;

};

};

// TWCR=0x45;
// TWCR|=0x80;
break;

case 0xA8: ////Áûë ïðèíÿò SLA+R ñ ñîáñòåííûì àäðåñîì è ïîñëàíî ïîäòâåðæäåíèå
switch (cmd){
case 0x57:
TWDR=cmd_57;
TWCR=0x45;//0x05;
TWCR|=0x80;
adr=0;
cmd=0;
w=0;
break;

case 0x20:
TWDR=cmd_30.b[adr];
TWCR=0x45;//0x05;
TWCR|=0x80;
adr=0;
cmd=0;
w=0;
break;

case 0x00:
TWDR=cmd_00[adr];
TWCR=0x45;//0x05;
TWCR|=0x80;
adr=0;
cmd=0;
w=0;
break;

case 0x30:
if (adr==0x00)
{
iter();
TWDR=cmd_30.b[0];
}
else
{
TWDR=cmd_30.b[1];
};

TWCR=0x45;//0x05;
TWCR|=0x80;
adr=0;
cmd=0;
w=0;
break;

case 0x50:
TWDR=cmd_50[adr];
TWCR=0x45;//0x05;
TWCR|=0x80;
adr=0;
cmd=0;
w=0;
break;

case 0x52:
TWDR=cmd_52;
TWCR=0x45;//0x05;
TWCR|=0x80;
adr=0;
cmd=0;
w=0;
break;

default:
};
break;

case 0xC0: ////Áûë ïåðåäàí áàéò äàííûõ è ïîëó÷åíî íå ïîäòâåðæäåíèå
TWCR=0x45;
TWCR|=0x80;
w=0;
break;

default:
w=0; // ëþáîå äðóãîå ñîáûòèå
TWCR|=0x40; //ðàçðåøèòü áèò ïîäòâåðæäåíèÿ
TWCR&=~0x20; //ÇÀÏÐÅÒÈÒÜ START
TWCR|=0x10; //Ïåðåçàãðóçêà TWI ôîðìèðîâàòü STOP
TWCR|=0x80;

break;

};


}

// Declare your global variables here

void main(void)
{
// Declare your local variables here

// Input/Output Ports initialization
// 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
// Func6=In Func5=In Func4=In Func3=In Func2=In Func1=In Func0=In
// 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=0x00;
DDRD=0x00;

// Timer/Counter 0 initialization
// Clock source: System Clock
// Clock value: Timer 0 Stopped
TCCR0=0x00;
TCNT0=0x00;

// Timer/Counter 1 initialization
// Clock source: System Clock
// Clock value: Timer 1 Stopped
// Mode: Normal top=FFFFh
// OC1A output: Discon.
// OC1B output: Discon.
// Noise Canceler: Off
// Input Capture on Falling Edge
TCCR1A=0x00;
TCCR1B=0x00;
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: Off
// INT1: Off
MCUCR=0x00;

// Timer(s)/Counter(s) Interrupt(s) initialization
TIMSK=0x00;

// Analog Comparator initialization
// Analog Comparator: Off
// Analog Comparator Input Capture by Timer/Counter 1: Off
// Analog Comparator Output: Off
ACSR=0x80;
SFIOR=0x00;

// 2 Wire Bus initialization
// Generate Acknowledge Pulse: On
// 2 Wire Bus Slave Address: 58h
// General Call Recognition: Off
// Bit Rate: 250,000 kHz
TWBR=0x08;
TWAR=0xB0;
TWCR=0x45;


#asm("sei")
TWCR|=0x40; //ðàçðåøèòü áèò ïîäòâåðæäåíèÿ
TWCR&=~0x20; //ÇÀÏÐÅÒÈÒÜ START
TWCR|=0x10; //Ïåðåçàãðóçêà TWI ôîðìèðîâàòü STOP
TWCR|=0x80;





while (1)

{
};



}

В 8меге рботает на 250, тот же текст в меге16 не работает на 250!
Go to the top of the page
 
+Quote Post
bodja74
сообщение Jun 9 2006, 16:19
Сообщение #14


Знающий
****

Группа: Свой
Сообщений: 543
Регистрация: 22-10-05
Пользователь №: 9 984



А с чего Вы взяли что TWBR=0x08 это Bit Rate: 250,000 kHz ?
TWBR=0x08 это 166.666 Кгц ,что мы и имеем smile.gif

Вообщето по идее слейву должно быть все равно значение TWBR,но вполне возможно мегу 16 решили доработать и использовать TWBR для формирования длительности ACK.

PS Тяжко мне в Си разобраться sad.gif
Go to the top of the page
 
+Quote Post
Basilkmv06
сообщение Jun 9 2006, 17:13
Сообщение #15





Группа: Участник
Сообщений: 13
Регистрация: 14-01-06
Пользователь №: 13 169



Цитата(bodja74 @ Jun 9 2006, 20:19) *
А с чего Вы взяли что TWBR=0x08 это Bit Rate: 250,000 kHz ?
TWBR=0x08 это 166.666 Кгц ,что мы и имеем smile.gif

Вообщето по идее слейву должно быть все равно значение TWBR,но вполне возможно мегу 16 решили доработать и использовать TWBR для формирования длительности ACK.

PS Тяжко мне в Си разобраться sad.gif

Последняя документация на мегу16 (doc2466.pdf) гласит:
This unit controls the period of SCL when operating in a Master mode. The SCL period
is controlled by settings in the TWI Bit Rate Register (TWBR) and the Prescaler bits in
the TWI Status Register (TWSR). Slave operation does not depend on Bit Rate or Pres-caler
settings
, but the CPU clock frequency in the slave must be at least 16 times higher
than the SCL frequency. Note that slaves may prolong the SCL low period, thereby
reducing the average TWI bus clock period.

Т.е. TWBR для формирования длительности ACK не используется.
Что на счет кода? Может есть какие-то косяки?
Go to the top of the page
 
+Quote Post

2 страниц V   1 2 >
Reply to this topicStart new topic
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0

 


RSS Текстовая версия Сейчас: 18th July 2025 - 21:08
Рейтинг@Mail.ru


Страница сгенерированна за 0.01503 секунд с 7
ELECTRONIX ©2004-2016