|
Эффективность кода WinAVR |
|
|
|
Apr 21 2008, 15:46
|
дятел
    
Группа: Свой
Сообщений: 1 681
Регистрация: 13-05-06
Из: Питер
Пользователь №: 17 065

|
Цитата(777777 @ Apr 21 2008, 19:42)  Тот же результат наблюдается если написать const int F0BIT = 8; И ничего затейливого в этом нет. Пользуйтесь define и проблем не будет: Код #define FOBIT 8 #define FOBIT_MASK (1<<FOBIT) ......
if (XXX & FOBIT_MASK) ............
|
|
|
|
|
Apr 21 2008, 16:44
|

Профессионал
    
Группа: Участник
Сообщений: 1 091
Регистрация: 25-07-07
Из: Саратов
Пользователь №: 29 357

|
Цитата(Палыч @ Apr 21 2008, 19:48)  Что, тоже сдвигает?  А, если так: #define F0BIT (1<<F0) То же самое. Впрочем, я уже скачал новую версию, 20080411 (4.3.0), там это место генерируется весьма эффективно, через SBRS, но там в другом месте глюк - часть кода не транслируется вообще, завтра буду разбираться.
|
|
|
|
|
Apr 21 2008, 17:11
|
Местный
  
Группа: Свой
Сообщений: 408
Регистрация: 21-10-06
Из: Санкт-Петербург
Пользователь №: 21 527

|
GCC 3.4.6 Код #define F0 5 const int F0BIT = (1<<F0); uint16_t v;
int main(void) { if(v & F0BIT) PORTD = 0; else PORTD = 0xFF;
while(1){}; } Код ---- main.c --------------------------------------------------------------------------------------- 23: if(v & F0BIT) PORTD = 0; else PORTD = 0xFF; +00000032: 91800062 LDS R24,0x0062 Load direct from data space +00000034: 91900063 LDS R25,0x0063 Load direct from data space +00000036: FF85 SBRS R24,5 Skip if bit in register set +00000037: C002 RJMP PC+0x0003 Relative jump +00000038: BA12 OUT 0x12,R1 Out to I/O location +00000039: C002 RJMP PC+0x0003 Relative jump +0000003A: EF8F SER R24 Set Register +0000003B: BB82 OUT 0x12,R24 Out to I/O location 33: while(1){}; +0000003C: CFFF RJMP PC-0x0000 Relative jump Никто ничего не вычисляет
|
|
|
|
|
Apr 21 2008, 17:50
|
Местный
  
Группа: Свой
Сообщений: 408
Регистрация: 21-10-06
Из: Санкт-Петербург
Пользователь №: 21 527

|
Цитата(Aesthete Animus @ Apr 21 2008, 21:36)  Вопрос конечно совсем не в тему... Но не скажите как вы генерите листинги, что в них вставляются комментарии (Load direct from data space, Out to I/O location и пр.)? Я запускаю отладку в студии, а потом view -> dissasembler -> ctrl+c -> ctrl+v...
|
|
|
|
|
Apr 22 2008, 04:31
|

Профессионал
    
Группа: Участник
Сообщений: 1 091
Регистрация: 25-07-07
Из: Саратов
Пользователь №: 29 357

|
Цитата(Qwertty @ Apr 21 2008, 21:11)  GCC 3.4.6 У меня была 3.4.5 Цитата(777777 @ Apr 21 2008, 20:44)  ... Впрочем, я уже скачал новую версию, 20080411 (4.3.0), там это место генерируется весьма эффективно, через SBRS, но там в другом месте глюк - часть кода не транслируется вообще, завтра буду разбираться. После уменьшения кода до минимально необходимого для повторения глюка, удалось понять его причину. Дело в том, что gcc - компилятор "настоящий" (в отличие от Keil, напимер), поэтому volatile нужно писать всегда, где это надо
|
|
|
|
|
Apr 22 2008, 07:05
|
Местный
  
Группа: Свой
Сообщений: 408
Регистрация: 21-10-06
Из: Санкт-Петербург
Пользователь №: 21 527

|
Цитата(777777 @ Apr 22 2008, 08:31)  У меня была 3.4.5 Попробовал в 4.2.2 - тоже нормально, почти оптимальный результат. Цитата(777777 @ Apr 22 2008, 08:31)  После уменьшения кода до минимально необходимого для повторения глюка, удалось понять его причину. Дело в том, что gcc - компилятор "настоящий" (в отличие от Keil, напимер), поэтому volatile нужно писать всегда, где это надо  Никогда не видел, что бы отсутствие волатила препятствовало компиляции. Обычно это совсем не мешает, просто программа работает не совсем так, как надо. Или совсем не так  Можно примерчик кода не собирающегося без волатила?
|
|
|
|
|
Apr 22 2008, 07:30
|

Профессионал
    
Группа: Участник
Сообщений: 1 091
Регистрация: 25-07-07
Из: Саратов
Пользователь №: 29 357

|
Цитата(Qwertty @ Apr 22 2008, 11:05)  Никогда не видел, что бы отсутствие волатила препятствовало компиляции. Обычно это совсем не мешает, просто программа работает не совсем так, как надо. Или совсем не так  Ну так программа работает не так именно потому, что компилятор постарался  Цитата(Qwertty @ Apr 22 2008, 11:05)  Можно примерчик кода не собирающегося без волатила? Код #include <avr/io.h>
#define CTRL0 0 // output bits #define CTRL1 1 //
#define F0 2 // input bits #define F1 3 //
/*volatile*/ int8_t Pulse;
int main() { // port B PORTB = 0xff; DDRB = (1<<CTRL0)|(1<<CTRL1);
uint8_t State = PINB; // previous B state Pulse = 0;
while(1) { // inc/dec Pulse if F1 changes if((PINB^State) & (1<<F1)) { State = PINB; // *** uint8_t v = -1; if(State & (1<<F0)) v = 1; if(State & (1<<F1)) v = -v; Pulse += v; } } } переменную Pulse предполагается использовать в прерывании. Но компилятор об этом не знает и потому считает ненужными все стоки после // *** так как он не видт использования Pulse. Правда, тогда непонятно почему он вообще не выкидывает while(1), ведь внутри него ничего не происходит - порты не записываются, а локальные переменные не должны никого интересовать.
Сообщение отредактировал 777777 - Apr 22 2008, 07:37
|
|
|
|
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0
|
|
|