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

 
 
3 страниц V   1 2 3 >  
Reply to this topicStart new topic
> Keil Оптимизатор
vlad_new
сообщение Jan 16 2012, 16:45
Сообщение #1


Местный
***

Группа: Участник
Сообщений: 218
Регистрация: 24-06-10
Пользователь №: 58 127



Как использовать переменные типа volatile и одновременно пользоваться стандартными библиотеками, где все сплошником char*.
Приходится везде вписыать что то типа:
volatile char Buf1[100], Buf2[100];
.....
memcopy((char*)Buf1,(char*)Buf2,20);
.....
Если же Buf не будут volatile, то оптимизатор выбрасывает строки типа: Buf1[0]=7;
Может как то можно переопределить в билиотеках char на volatile char, ну или еще как то справится с этими неудобствами?

Сообщение отредактировал vlad_new - Jan 16 2012, 16:49
Go to the top of the page
 
+Quote Post
scifi
сообщение Jan 16 2012, 18:08
Сообщение #2


Гуру
******

Группа: Свой
Сообщений: 3 020
Регистрация: 7-02-07
Пользователь №: 25 136



Цитата(vlad_new @ Jan 16 2012, 20:45) *
Если же Buf не будут volatile, то оптимизатор выбрасывает строки типа: Buf1[0]=7;

А почему это проблема? Если выбрасывает, значит они не нужны.
Go to the top of the page
 
+Quote Post
vlad_new
сообщение Jan 16 2012, 18:43
Сообщение #3


Местный
***

Группа: Участник
Сообщений: 218
Регистрация: 24-06-10
Пользователь №: 58 127



Цитата(scifi @ Jan 16 2012, 22:08) *
А почему это проблема? Если выбрасывает, значит они не нужны.


Вот пример кода.
Заполняем массив Buf_RS485 и отправляем его в UART. Первый байт в массиве определяет его длинну.
Первые 2 строки после case00: копируют некие данные известной длинны. Поэтому в следующей строке эта длинна и записывается.
Далее, если есть Cnt_sob, то туда еще кучка всего вписывается и другая длинна перезаписывается.
Таким образом отправляется либо короткий, либо более длинный пакет.
Так вот 3 строку оптимизатор игнорирует и пакет отправляется с неверной длинной!

Код
vu8  Buf_RS485[256];  // Глобальная

void sw_get(void)
{
u32 i, j, k, u;

switch(GetSet)
  {

  case 0x00: Pool=1; RX_RS485=1;                                
             memcpy((char*)Buf_RS485+1,Mac_mas_bcd,4);  
             memcpy((char*)Buf_RS485+5,Mac_sl_bcd,4); u=9;
             Buf_RS485[0]=u-1;                                  

             if(Cnt_sob)                
               {
               j=EE_rd_byte(UK_WRS);      
               if(j>=Cnt_sob) k=j-Cnt_sob;
               else k=KOL_BUF-(Cnt_sob-j);
               k=k*LEN_SOB+BAZA_S; i=0;
               EE_rd_nbyte(k,Buf_tmp,64); Buf_tmp[64]=0;  
               k=strlen((char*)Buf_tmp); k=k-6; Buf_RS485[u++]=k|0x40;
               for(i=0; i<12; i=i+2,u++)
                 Buf_RS485[u]=((Buf_tmp[i]-0x30)<<4)|((Buf_tmp[i+1]-0x30)&0xF);
               for(i=0; i<(k-6); i++) Buf_RS485[u++]=Buf_tmp[i+12];
               Buf_RS485[0]=u-1;                                
               }

             SEND_RS485; return;
.........
   }


Сообщение отредактировал IgorKossak - Jan 17 2012, 08:12
Причина редактирования: [code]
Go to the top of the page
 
+Quote Post
Genadi Zawidowsk...
сообщение Jan 16 2012, 18:57
Сообщение #4


Профессионал
*****

Группа: Участник
Сообщений: 1 620
Регистрация: 22-06-07
Из: Санкт-Петербург, Россия
Пользователь №: 28 634



Несовсем понятно о какой строчке идёт речь. Можекте пометить её в исходнике?

Сообщение отредактировал Genadi Zawidowski - Jan 16 2012, 18:57
Go to the top of the page
 
+Quote Post
vlad_new
сообщение Jan 16 2012, 19:07
Сообщение #5


Местный
***

Группа: Участник
Сообщений: 218
Регистрация: 24-06-10
Пользователь №: 58 127



Цитата(Genadi Zawidowski @ Jan 16 2012, 22:57) *
Несовсем понятно о какой строчке идёт речь. Можекте пометить её в исходнике?

Угу. Пометил. Вот эта имелась ввиду:
Buf_RS485[0]=u-1;

Сообщение отредактировал vlad_new - Jan 16 2012, 19:09
Go to the top of the page
 
+Quote Post
scifi
сообщение Jan 16 2012, 19:34
Сообщение #6


Гуру
******

Группа: Свой
Сообщений: 3 020
Регистрация: 7-02-07
Пользователь №: 25 136



Этот код какой-то кривой. Например, переменная 'char Buf_RS485;' используется как массив. Что это? Неточно запостили? Будьте любезны постить реальный код. Кто знает, что Вы там ещё переиначили? И лучше с отступами, а также обрамлять тегами (code)(/code).
Вы подозреваете баг в компиляторе, а я подозреваю баг в программе. Чаще бывает второе.
Go to the top of the page
 
+Quote Post
vlad_new
сообщение Jan 16 2012, 19:51
Сообщение #7


Местный
***

Группа: Участник
Сообщений: 218
Регистрация: 24-06-10
Пользователь №: 58 127



Цитата(scifi @ Jan 16 2012, 23:34) *
Этот код какой-то кривой. Например, переменная 'char Buf_RS485;' используется как массив. Что это? Неточно запостили? Будьте любезны постить реальный код. Кто знает, что Вы там ещё переиначили? И лучше с отступами, а также обрамлять тегами (code)(/code).
Вы подозреваете баг в компиляторе, а я подозреваю баг в программе. Чаще бывает второе.

Уже подправил. Реальный код слишком длинный. К тому же похожие проблеммы с оптимизатором не редки. И как правило когда индекс =0, или он const.
Иногда помагало обозвать переменную индекса массива как static. Но вот в этом куске бубны с танцами не помогли.

Сообщение отредактировал vlad_new - Jan 16 2012, 19:52
Go to the top of the page
 
+Quote Post
scifi
сообщение Jan 16 2012, 20:03
Сообщение #8


Гуру
******

Группа: Свой
Сообщений: 3 020
Регистрация: 7-02-07
Пользователь №: 25 136



Цитата(vlad_new @ Jan 16 2012, 23:51) *
Уже подправил. Реальный код слишком длинный. К тому же похожие проблеммы с оптимизатором не редки. И как правило когда индекс =0, или он const.
Иногда помагало обозвать переменную индекса массива как static. Но вот в этом куске бубны с танцами не помогли.

Это глюки в программе с вероятностью 99%.
Поскольку реальный код видеть нет возможности, то больше сказать нечего. Даже если бы был реальный код, было бы слишком трудно в нём разобраться, так как написан он (если судить по показанному отрывку) не самым лучшим образом, мягко говоря.

Update:
Забыл добавить. О глюках судят по результатам выполнения программы. Например, если содержимое пакета данных на проводе отличается от ожидаемого. Если Вы смотрите на содержимое переменных в отладчике и видите неожиданные значения - не факт, что это глюк. На высоких уровнях оптимизации бывает так, что данные отладчика весьма слабо коррелируют с исходным кодом. И вообще отлаживать удобнее на самом низком уровне оптимизации.
Go to the top of the page
 
+Quote Post
vlad_new
сообщение Jan 16 2012, 20:12
Сообщение #9


Местный
***

Группа: Участник
Сообщений: 218
Регистрация: 24-06-10
Пользователь №: 58 127



Цитата(scifi @ Jan 17 2012, 00:03) *
Это глюки в программе с вероятностью 99%.
Поскольку реальный код видеть нет возможности, то больше сказать нечего. Даже если бы был реальный код, было бы слишком трудно в нём разобраться, так как написан он (если судить по показанному отрывку) не самым лучшим образом, мягко говоря.

Да отступы почему то здесь не выходят, хотя в режиме редактирования я их вижу. А на счет глюков в программе: ну так она же работает если без оптимизатора или
Buf_RS485 описать как vu8 ( volatile unsigned char ), но тогда в сотнях местах приходится вписывать явное преобразование типов. memcopy((char*)Buf_RS485,.... )

Updete: Да я в таких случиях смотрю код ассемблера. А о веревке: Так и есть другое устройство принимает пакет с ошибочной длинной.


Сообщение отредактировал vlad_new - Jan 16 2012, 20:18
Go to the top of the page
 
+Quote Post
aaarrr
сообщение Jan 16 2012, 20:13
Сообщение #10


Гуру
******

Группа: Свой
Сообщений: 10 713
Регистрация: 11-12-04
Пользователь №: 1 448



Цитата(vlad_new @ Jan 16 2012, 23:51) *
Реальный код слишком длинный. К тому же похожие проблеммы с оптимизатором не редки.

Если проблемы не редки, то почти наверняка оптимизатор ни при чем. Вам в любом случае надо локализовать проблему, и оформить её в виде изолированного фрагмента - или чтобы аргументированно обвинить оптимизатор, или чтобы разобраться с изъянами своего кода. И уж точно не стоит "лечить" программу, добавляя разнообразные квалификаторы там, где они объективно не нужны.
Go to the top of the page
 
+Quote Post
Allregia
сообщение Jan 16 2012, 20:17
Сообщение #11


Профессионал
*****

Группа: Свой
Сообщений: 1 047
Регистрация: 28-06-07
Из: Israel
Пользователь №: 28 763



Цитата(vlad_new @ Jan 16 2012, 22:12) *
Да отступы почему то здесь не выходят, хотя в режиме редактирования я их вижу.


Потому что Вы не оформили свой код в теги [сode] [/сode]

Если бы оформили - все бы отсупало:
Код
с начала
      с отступом 8 пробелов
Go to the top of the page
 
+Quote Post
scifi
сообщение Jan 16 2012, 20:20
Сообщение #12


Гуру
******

Группа: Свой
Сообщений: 3 020
Регистрация: 7-02-07
Пользователь №: 25 136



Цитата(vlad_new @ Jan 17 2012, 00:12) *
А на счет глюков в программе: ну так она же работает если без оптимизатора или Buf_RS485 описать как vu8 ( volatile unsigned char ), но тогда в сотнях местах приходится вписывать явное преобразование типов. memcopy((char*)Buf_RS485,.... )

В сотнях мест?!! О ужас! Вероятность глюка в программе приблизилась к 99,9%.
Зачем вообще включаете оптимизацию? Если работает - не трогайте. Не открывайте ящик Пандоры. Есть большой класс ошибок, чувствительных к уровню оптимизации. Они Вам нужны?
Go to the top of the page
 
+Quote Post
vlad_new
сообщение Jan 16 2012, 20:20
Сообщение #13


Местный
***

Группа: Участник
Сообщений: 218
Регистрация: 24-06-10
Пользователь №: 58 127



Цитата(Allregia @ Jan 17 2012, 00:17) *
Потому что Вы не оформили свой код в теги [сode] [/сode]

Если бы оформили - все бы отсупало:
Код
с начала
      с отступом 8 пробелов

Не знал что так надо. Век живи век учись. Ща попробую.
Go to the top of the page
 
+Quote Post
aaarrr
сообщение Jan 16 2012, 20:24
Сообщение #14


Гуру
******

Группа: Свой
Сообщений: 10 713
Регистрация: 11-12-04
Пользователь №: 1 448



Цитата(vlad_new @ Jan 17 2012, 00:12) *
А на счет глюков в программе: ну так она же работает если без оптимизатора или
Buf_RS485 описать как vu8 ( volatile unsigned char ), но тогда в сотнях местах приходится вписывать явное преобразование типов. memcopy((char*)Buf_RS485,.... )

Подобные симптомы свидетельствуют отнюдь не в пользу версии о правильности программы, а совсем даже наоборот.

Цитата(scifi @ Jan 17 2012, 00:20) *
Зачем вообще включаете оптимизацию? Если работает - не трогайте. Не открывайте ящик Пандоры. Есть большой класс ошибок, чувствительных к уровню оптимизации. Они Вам нужны?

Странный совет. Правильнее было бы не выключать оптимизацию, дабы по мере написания программы выгребать содержимое ящика.
Go to the top of the page
 
+Quote Post
vlad_new
сообщение Jan 16 2012, 20:30
Сообщение #15


Местный
***

Группа: Участник
Сообщений: 218
Регистрация: 24-06-10
Пользователь №: 58 127



Цитата(aaarrr @ Jan 17 2012, 00:20) *
Подобные симптомы свидетельствуют отнюдь не в пользу версии о правильности программы, а совсем даже наоборот.

Естественно. Внешний массив и обязан быть volatile, тем более что он используется в прерываниях. Ну так я и спрашивал как бы
сделать так, чтоб в стандартные библиотеки передовать тип volatile без явного преобразования типа повсеместно.
Может через какой нибудь typedef переопределить типы параметров в библиотеке. А может еще какие то другие есть решения.

Go to the top of the page
 
+Quote Post

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

 


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


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