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

 
 
> Глюки с char-ами в MSPGCC, то ли руки кривые...
MrYuran
сообщение Oct 23 2008, 06:15
Сообщение #1


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

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



Столкнулся (уже не первый раз) с неприятной особенностью MSPGCC в части работы с переменными типа char. при подсчёте контрольной суммы пакета иногда возникают сбои.
Код
static char volatile Uart0Buffer[8];
static unsigned char Csumm;
...
Csumm=1;    
for (i=0;i<6;i++)    
{        
  Csumm += ~Uart0Buffer[i];           // вычисление контр. суммы    
}    
if(!((Uart0Buffer[6]-Csumm) & 0xff))           // контр. сумма верна и вообще

Последнее условие раньше выглядело if(Uart0Buffer[6] == Csumm) и работало через раз, пока не наложил байтовую маску. Такие вот дела.


--------------------
Программирование делится на системное и бессистемное. ©Моё :)
— а для кого-то БГ — это Bill Gilbert =)
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов
MrYuran
сообщение Oct 24 2008, 09:23
Сообщение #2


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

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



В продолжение темы об особенностях сравнения:

Есть у меня счётчик системных тиков Time, и есть Timer, который защёлкивает текущее значение в определённый момент.
Затем происходит сравнение
if(Time-Timer>(RegDelay+10))
{DoSomething()}
То есть отсчитывается задержка и выполняется определённое действие.
Timer и Time - unsigned int.
Как мне кажется (и вроде бы так и работает), при переполнении Time всё будет продолжать работать как надо. Нет ли тут подводных граблей? (имеется в виду "проблема 2000 года")
И что произойдёт, если в Timer загонять время для будущего запуска действия (Timer=Time+Delay), а потом сравнивать
if(Time>Timer)
(Это я сейчас так сделал, а потом озаботился)
Time и Timer теперь unsigned long, но и он когда-то переполнится...


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


Гуру
******

Группа: Свой
Сообщений: 10 920
Регистрация: 5-04-05
Пользователь №: 3 882



Цитата(MrYuran @ Oct 24 2008, 15:23) *
В продолжение темы об особенностях сравнения:

Есть у меня счётчик системных тиков Time, и есть Timer, который защёлкивает текущее значение в определённый момент.
Затем происходит сравнение
if(Time-Timer>(RegDelay+10))
{DoSomething()}
То есть отсчитывается задержка и выполняется определённое действие.
Timer и Time - unsigned int.
Как мне кажется (и вроде бы так и работает), при переполнении Time всё будет продолжать работать как надо. Нет ли тут подводных граблей? (имеется в виду "проблема 2000 года")
И что произойдёт, если в Timer загонять время для будущего запуска действия (Timer=Time+Delay), а потом сравнивать
if(Time>Timer)
(Это я сейчас так сделал, а потом озаботился)
Time и Timer теперь unsigned long, но и он когда-то переполнится...

Это вполне нормальный способ отсчета задержек и периодов времени. Я везде его применяю. Но у него есть два недостатка:
1) величина измеряемого периода ограничена разрядностью переменной. Например, у меня везде отсчеты идут в миллисекундах. Даже если период прерывания в котором переменная инкрементируется отличается от 1мс, то все равно она увеличивается на значение равное периоду, выраженному в миллисекундах. Поэтому 16-и разрядный unsigned int дает промежуток времени всего лишь 65,5с, а 32-х разрядный unsigned long немногим более 1,5 месяцев.
2) на архитектурах с разрядностью меньшей, чем используемая переменная, нужно предпринимать дополнительные действия по обеспечению атомарности доступа к такой переменной. Т.е. приходится перед считыванием ее значения запрещать прерывание, в котором эта переменная инкрементируется.
Go to the top of the page
 
+Quote Post

Сообщений в этой теме
- MrYuran   Глюки с char-ами в MSPGCC   Oct 23 2008, 06:15
- - Сергей Борщ   Цитата(MrYuran @ Oct 23 2008, 09:15) Посл...   Oct 23 2008, 06:58
- - MrYuran   Попробовал сделать листинг objdump-ом, херь какая-...   Oct 23 2008, 08:30
|- - Сергей Борщ   Цитата(MrYuran @ Oct 23 2008, 11:30) А ве...   Oct 23 2008, 08:53
|- - MrYuran   Цитата(Сергей Борщ @ Oct 23 2008, 12:53) ...   Oct 23 2008, 09:42
|- - gotty   Цитата(MrYuran @ Oct 23 2008, 12:42) Да, ...   Oct 23 2008, 11:18
||- - diper   Цитата(gotty @ Oct 23 2008, 15:18) Возмож...   Oct 23 2008, 18:46
||- - Сергей Борщ   Цитата(diper @ Oct 23 2008, 21:46) Вычита...   Oct 23 2008, 19:04
||- - diper   Цитата(Сергей Борщ @ Oct 23 2008, 23:04) ...   Oct 23 2008, 21:47
||- - gotty   Цитата(diper @ Oct 24 2008, 00:47) Хм. До...   Oct 24 2008, 05:59
||- - diper   Цитата(gotty @ Oct 24 2008, 09:59) В ANSI...   Oct 24 2008, 10:36
|- - Сергей Борщ   Цитата(MrYuran @ Oct 23 2008, 12:42) Не с...   Oct 23 2008, 11:47
- - demiurg_spb   Цитата(MrYuran @ Oct 23 2008, 10:15) stat...   Oct 23 2008, 09:07
- - MrYuran   Цитата(rezident @ Oct 24 2008, 14:15) 2) ...   Oct 24 2008, 10:38


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

 


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


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