|
Несимметрия конечного результата vinavr компилятора |
|
|
|
Nov 16 2012, 21:46
|

Ambidexter
    
Группа: Свой
Сообщений: 1 589
Регистрация: 22-06-06
Из: Oxford, UK
Пользователь №: 18 282

|
Всем привет. Такой вопрос. Почему код Код while(pph!=&ph[8]) { *(pph++)=~(*(pph-4)); }, в котором берётся часть массива, инвертируется и записывается в другое место, компилируется в такой несимметричный код? Код while(pph!=&ph[8]) { *(pph++)=~(*(pph-4)); 94: fd 01 movw r30, r26 96: 34 97 sbiw r30, 0x04; 4 98: 80 81 ld r24, Z 9a: 80 95 com r24 9c: 8c 93 st X, r24 9e: 80 91 71 00 lds r24, 0x0071 a2: 80 95 com r24 a4: 11 96 adiw r26, 0x01; 1 a6: 8c 93 st X, r24 a8: 11 97 sbiw r26, 0x01; 1 aa: 90 91 72 00 lds r25, 0x0072 ae: 89 2f mov r24, r25 b0: 80 95 com r24 b2: 12 96 adiw r26, 0x02; 2 b4: 8c 93 st X, r24 b6: 12 97 sbiw r26, 0x02; 2 b8: 80 91 73 00 lds r24, 0x0073 bc: 80 95 com r24 be: 13 96 adiw r26, 0x03; 3 c0: 8c 93 st X, r24 } Казалось бы чего проще, для всех 4-х байт сделать одно и тоже действие: загрузить байт в регистр, а лучше бы воспользоваться регистровой парой Z, инвертировать и записать в новое место, указываемое парой Х. Дальше, почему бы не использовать постинкремент Х+ вместо двух команд adiw и st? Может, кто-то знает, как переделать си-код в нечто подобное?
--------------------
Делай сразу хорошо, плохо само получится
|
|
|
|
|
 |
Ответов
|
Nov 19 2012, 06:52
|

неотягощённый злом
     
Группа: Свой
Сообщений: 2 746
Регистрация: 31-01-08
Из: Санкт-Петербург
Пользователь №: 34 643

|
Мне вообще представленная ТС строка не нравится Цитата(=GM= @ Nov 17 2012, 01:46)  *(pph++)=~(*(pph-4)); приходится напрягать мозг чтобы понять что произойдёт тут и вспоминать точки следования  ИМХО так значительно прозрачнее Код pph[0] = ~pph[-4]; pph++; ну или даже так Код *pph++ = ~pph[-4] не, так плохо, прогнал, и на компиляции получил предупреждение о возможном неопределённом поведении. {дополнено позже} Цитата(Сергей Борщ @ Nov 17 2012, 21:42)  при грамотном использовании инлайн-асм gcc позволяет сделать практичеки чудеса Это наверно так, но у меня к примеру почему-то простейшая конструкция не выходит (правда я нашёл другой способ решить мою задачу) Код #define makeword16(b0,b1) \ (__extension__({ \ uint8_t __b0 = (uint8_t)(b0); \ uint8_t __b1 = (uint8_t)(b1); \ uint16_t __result; \ __asm__ __volatile__ \ ( \ "\n\t" \ "mov %A0,%A1" "\n\t" \ "mov %B0,%A2" "\n\t" \ : "=r" (__result) /* output operands */ \ : "r" (__b0), /* input operands */ \ "r" (__b1) \ ); \ __result; \ }))
uint8_t b[n]; uint16_t x = makeword16(b[1],b[0]); //read big-endian value ... получаем Код 582: 81 81 ldd r24, Z+1; 0x01 584: 90 81 ld r25, Z 586: 88 2f mov r24, r24 // я плакал:( 588: 99 2f mov r25, r25 // дважды:( Если вы сможете мне помочь буду очень благодарен за развитие кругозора. Спасибо!
--------------------
“Будьте внимательны к своим мыслям - они начало поступков” (Лао-Цзы)
|
|
|
|
|
Nov 20 2012, 07:40
|

неотягощённый злом
     
Группа: Свой
Сообщений: 2 746
Регистрация: 31-01-08
Из: Санкт-Петербург
Пользователь №: 34 643

|
Цитата(Сергей Борщ @ Nov 20 2012, 11:35)  Эта ваша задача решается через union. Будет так же непортируемо, как и с асм-вставкой. Так и сделано (с union наиоптимальнейший результат). Но хотелось бы понять как сие и на асме изобразить. Сейчас не до портируемости, ибо размер сильно важен, а со сдвигами сильно плохо оптимизирует... Код uint16_t x = b0<<8 | b1; никак не меньше 4 инструкций выходит
--------------------
“Будьте внимательны к своим мыслям - они начало поступков” (Лао-Цзы)
|
|
|
|
|
Nov 20 2012, 10:25
|

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

|
QUOTE (demiurg_spb @ Nov 20 2012, 09:40)  Но хотелось бы понять как сие и на асме изобразить. Знаю, как убрать один из mov: CODE __asm__ __volatile__ \ ( \ "\n\t" \ "mov %B0,%2" "\n\t" \ : "=r" (__result) /* output operands */ \ : "0" (__b0), /* input operands */ \ "r" (__b1) \ ); \ Как объяснить насчет второго - пока не придумал. QUOTE (demiurg_spb @ Nov 20 2012, 09:40)  а со сдвигами сильно плохо оптимизирует... Увы, пока да.
--------------------
На любой вопрос даю любой ответ"Write code that is guaranteed to work, not code that doesn’t seem to break" ( C++ FAQ)
|
|
|
|
Сообщений в этой теме
=GM= Несимметрия конечного результата vinavr компилятора Nov 16 2012, 21:46 Genadi Zawidowski -Os, gcc 4.7.2
Код000066a2 <testfn>:
... Nov 16 2012, 23:19 zombi Писать на CИ и надеятся что какие то "дяди... Nov 16 2012, 23:44 С_Ч Цитата(zombi @ Nov 17 2012, 02:44) Писать... Nov 17 2012, 06:57  =GM= Да, слова золотые, целиком и полностью поддерживаю... Nov 17 2012, 07:30 _Pasha Текст, взятый у Геннадия, дает
CODEstatic unsigned... Nov 17 2012, 06:14 _Pasha Возьмите Клёновскую сборку, не обязательно крайнюю... Nov 17 2012, 07:57 ReAl Цитата(_Pasha @ Nov 17 2012, 09:57) Возьм... Nov 17 2012, 09:02  demiurg_spb Цитата(ReAl @ Nov 17 2012, 13:02) Или её,... Nov 17 2012, 12:47 polyname ЦитатаНа ассемблере писать!не, лучше прямо в б... Nov 17 2012, 12:31 С_Ч Цитата(polyname @ Nov 17 2012, 15:31) не,... Nov 17 2012, 13:27  =GM= Это я всё могу сделать на асме и сделаю, здесь про... Nov 17 2012, 15:28   _Pasha Цитата(=GM= @ Nov 17 2012, 18:28) Ну, над... Nov 17 2012, 15:43   Сергей Борщ QUOTE (=GM= @ Nov 17 2012, 17:28) могу сд... Nov 17 2012, 17:42    =GM= Борщ, уймитесь. Мне этот топик был полезен, уже ск... Nov 17 2012, 19:42 ILYAUL Код*(pph++)=~(*(pph-4));
... Nov 17 2012, 12:51 ILYAUL ЦитатаА то я чего-то отстал от жизни. нет , прост... Nov 17 2012, 14:11 ReAl А нельзя ли уточнить, какая именно версия avr-gcc/... Nov 17 2012, 20:37 =GM= WinAVR-20100110 (AVR-Studio, vers.4.18, build 684,... Nov 17 2012, 21:58 ReAl Да студия по барабану, если ключ оптимизации извес... Nov 18 2012, 09:35 Petka Цитата(ReAl @ Nov 18 2012, 13:35) ....
Во... Nov 18 2012, 10:33    demiurg_spb Цитата(Сергей Борщ @ Nov 20 2012, 14:25) ... Nov 20 2012, 12:39 =GM= Цитата(demiurg_spb @ Nov 19 2012, 06:52) ... Nov 20 2012, 15:37  _Pasha Цитата(=GM= @ Nov 20 2012, 19:37) Умереть... Nov 20 2012, 16:31  ReAl Цитата(=GM= @ Nov 20 2012, 17:37) И снача... Nov 20 2012, 20:51   =GM= Не понимаю разницы, оба варианта псевдокода привед... Nov 21 2012, 07:22    HHIMERA 2 =GM=
А вопрос применения МК с хадварной поддержк... Nov 21 2012, 20:44     =GM= Цитата(HHIMERA @ Nov 21 2012, 20:44) 2 =G... Nov 22 2012, 04:15      HHIMERA Цитата(=GM= @ Nov 22 2012, 08:15) Не знаю... Nov 22 2012, 05:38      ReAl Цитата(=GM= @ Nov 22 2012, 06:15) Извинит... Nov 22 2012, 06:58       demiurg_spb В продолжение темы:КодPORTA=PORTB=PORTC=0;может бы... Nov 22 2012, 09:38       ReAl Цитата(ReAl @ Nov 22 2012, 08:58) но поря... Nov 22 2012, 20:01    ReAl Цитата(=GM= @ Nov 21 2012, 09:22) Эта стр... Nov 21 2012, 21:32 Genadi Zawidowski Цитатапонять что произойдёт тут и вспоминать точки... Nov 20 2012, 01:29
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0
|
|
|