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

 
 
> Непредусмотренное изменение регистра, Странное поведение похожее на баг компилятора
Didro
сообщение Jun 10 2012, 08:48
Сообщение #1


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

Группа: Участник
Сообщений: 94
Регистрация: 9-04-07
Пользователь №: 26 893



Добрый день,

работаю с AT90CAN32. В основной программе обнаружил странную ошибку и в процессе выяснения обстоятельств получил вот такой пример, её иллюстрирующий:

CODE
#define F_CPU 16000000UL
#include <avr/io.h>
#include <util/delay.h>
#include <avr/interrupt.h>
#include "twi_master.h"

unsigned char sendbuf[2] = {0b0011011<<1, 0xB4};

int main(void) {
CLKPR = 0x80;
CLKPR = 0x00;
DDRB = 0xFF;
DDRE |= (1<<PE2);
sei();

TWI_Master_Initialise();
TWI_Start_Transceiver_With_Data(sendbuf, 2);


unsigned char cntr=1;
while(1) {
if (fint) {fint = 0; TWI_Start_Transceiver_With_Data(sendbuf, 2); }

//_delay_us(30); если раскомментировать эту строку
//__asm__ __volatile__ ("ldir25, 0x61" :sm.gif;
//или если раскомментировать эту строку, то проблема себя не проявляет

volatile unsigned char tvar2876;
tvar2876 = 0x61;
if (tvar2876 != 0x61) {
PORTB = tvar2876;
PORTE|=1<<2;_delay_us(200);PORTE&=~(1<<2);_delay_us(200);
}

}
return 0;
}


Реализация функций работы с TWI взяты из AppNote315 (файлы TWI_Master.h и TWI_Master.c, приложены: Прикрепленный файл  TWI_Master.h.txt ( 5.98 килобайт ) Кол-во скачиваний: 365
Прикрепленный файл  TWI_Master.c.txt ( 11.93 килобайт ) Кол-во скачиваний: 310
).

Проблема заключается в том, что на PORTB выводится число 0х61 - т.е. срабатывает сравнение tvar2876 != 0x61, хотя очевидно, что такого быть не должно. Имя переменной tvar2876 выбрано случайным (специально, чтоб не думалось, что эта переменная где-то объявлена как external в других модулях).

Делаю следующий вывод по asm-листингу: Прикрепленный файл  AVR_Transmission.lss.txt ( 107.48 килобайт ) Кол-во скачиваний: 482
регистр r24, участвующий в операции сравнения меняется где-то в TWI-функциях (побочный эффект).

В чем может быть проблема ? Ранее с таким не сталкивался.

Компилировал AVR Studio 4 (Winavr2010aug), AVR Studio 6. Оптимизации выключены -O0
Спасибо

Сообщение отредактировал IgorKossak - Jun 10 2012, 14:01
Причина редактирования: [codebox] для длинного кода!!!
Go to the top of the page
 
+Quote Post



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

 


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


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