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

 
 
> Не работает корректно операция << в (*указатель |= (1<<pin)) IAR AVR, в железе не работает
SZ0
сообщение Nov 26 2008, 12:46
Сообщение #1


Местный
***

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



На портах висят датчики температуры DS18S20 у ATmega640. Код в IAR AVR.
Если работать с битами портов по варианту 1, где операция сдвига
осуществляется при выполнении операции, то с выводов мы всегда считываем 0xFF.
Если работать по варианту 2, где переменной pin сразу присваивается сдвинутый
номер вывода, и внутри подпрограмм сдвига в операциях над портами нет, то
всё замечательно работает со всеми датчиками температуры. Ещё одна особенность
в варианте 1, если на любом порте работаем с датчиком на PIN0, то они нормально
опрашиваются. В симуляторе багов не заметил, и он показывает что нормально управляет
ножками портов как в варианте 1 так и 2.

Вариант 1:
Код
ptr_dport = (uchar*)&DDRD;
ptr_pin = (uchar*)&PIND;
pin = PD1;

*ptr_dport |= (1<<pin);    //0 на линии
*ptr_dport &= ~(1<<pin);//1 на линии


Вариант 2:
Код
ptr_dport = (uchar*)&DDRD;
ptr_pin = (uchar*)&PIND;
pin = 1<<PD1;

*ptr_dport |= pin;        //0 на линии
*ptr_dport &= ~pin;        //1 на линии
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов
MrYuran
сообщение Nov 26 2008, 13:23
Сообщение #2


Беспросветный оптимист
******

Группа: Свой
Сообщений: 4 640
Регистрация: 26-12-07
Из: Н.Новгород
Пользователь №: 33 646



Второй вариант лучше. Меньше операций. Нет бестолковых сдвигов, так как 1<<pin будет вычисляться, а 1<<DP1 подставит препроцессор (я так понимаю DP1 объявлено через #define)


--------------------
Программирование делится на системное и бессистемное. ©Моё :)
— а для кого-то БГ — это Bill Gilbert =)
Go to the top of the page
 
+Quote Post
SZ0
сообщение Nov 26 2008, 13:30
Сообщение #3


Местный
***

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



Цитата(MrYuran @ Nov 26 2008, 18:23) *
Второй вариант лучше. Меньше операций. Нет бестолковых сдвигов, так как 1<<pin будет вычисляться, а 1<<DP1 подставит препроцессор (я так понимаю DP1 объявлено через #define)


То что лучше я уже понял smile.gif и поменяю, но, я хочу понять и разобраться, почему не работает 1й вариант.
Go to the top of the page
 
+Quote Post
meister
сообщение Nov 26 2008, 14:17
Сообщение #4


Местный
***

Группа: Участник
Сообщений: 219
Регистрация: 20-11-07
Пользователь №: 32 484



Цитата(SZ0 @ Nov 26 2008, 17:30) *
То что лучше я уже понял smile.gif и поменяю, но, я хочу понять и разобраться, почему не работает 1й вариант.


Оптимизатор решил, что это dead assignment. Правильно так:

Код
unsigned char volatile * ptr_dport;
Go to the top of the page
 
+Quote Post
Сергей Борщ
сообщение Nov 26 2008, 14:36
Сообщение #5


Гуру
******

Группа: Модераторы
Сообщений: 8 455
Регистрация: 15-05-06
Из: Рига, Латвия
Пользователь №: 17 095



Цитата(meister @ Nov 26 2008, 16:17) *
Оптимизатор решил, что это dead assignment. Правильно так:
Совершенно верно. И не понадобятся лишние приведения типа ptr_dport = (uchar*). Причем без volatile при другом положении звезд на небе не будет работать и второй вариант.


--------------------
На любой вопрос даю любой ответ
"Write code that is guaranteed to work, not code that doesn’t seem to break" (C++ FAQ)
Go to the top of the page
 
+Quote Post
SZ0
сообщение Nov 26 2008, 15:09
Сообщение #6


Местный
***

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



Цитата(Сергей Борщ @ Nov 26 2008, 19:36) *
Совершенно верно. И не понадобятся лишние приведения типа ptr_dport = (uchar*). Причем без volatile при другом положении звезд на небе не будет работать и второй вариант.


Спасибо!
1й вариант так и не заработал с изменениями. Поэтому ввёл изменения во 2м добавив volatile.

А как было определено
Цитата
Оптимизатор решил, что это dead assignment.
?
Go to the top of the page
 
+Quote Post



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

 


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


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