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

 
 
> Как обойти баг (cosmic, stm8), компилятор космик самовольно устанавливает биты
skef
сообщение Mar 3 2013, 08:44
Сообщение #1


Частый гость
**

Группа: Участник
Сообщений: 85
Регистрация: 29-10-09
Из: брежнев
Пользователь №: 53 292



Hi all!
Проблема заключается в том, что компилятор космик устанавливает бит который не нужно устанавлитвать.
Пример программы:
#include <STM8S105C6.h>
#define TEST 2
main()
{
PB_DDR = 255;//здесь порт настраивается на выход
PB_CR1 = 255;
PB_ODR = (TEST<<1);// Мы устанавливает "1" на вывод 2 порта В
//И она уставливается
PB_ODR = (TEST<<0);//Мы устанавливает "0" на вывод 2 порта В
//И он устанавливается. А вот тут самое интересное. Которое заключеется в том, что на выводе 1, который в
//этой программе не задействован, устанавливается "1"
while (1)
{
_asm("nop");//А тут просто брейкпойнт
}
}

На что отладчик в окне дизассемблер заявляет:
0x80ce <main> 0x35FF5007 MOV 0x5007,#0xff MOV _PB_DDR,#0xff
main.c:6 PB_CR1 = 255;
0x80d2 <main+4> 0x35FF5008 MOV 0x5008,#0xff MOV _PB_CR1,#0xff
main.c:7 PB_ODR = (TEST<<1);
0x80d6 <main+8> 0x35045005 MOV 0x5005,#0x04 MOV _PB_ODR,#0x04
main.c:8 PB_ODR = (TEST<<0);
0x80da <main+12> 0x35025005 MOV 0x5005,#0x02 MOV _PB_ODR,#0x02
main.c:12 _asm("nop");
0x80de <main+16> 0x9D NOP NOP
0x80df <main+17> 0x20FD JRT 0x80de JRT 0x80de
rupt_vector.c:17 return;

То есть компилятор самовольно устанавил бит (номер 2) в регистре периферии (PB_ODR).
Это баг компилятора? Или я неправильно понял ситуацию и что-то не так сделал?
И можно ли какими-то путями (например, опциями компилятора) гарантировано исключить подобные ситуации?


--------------------
на любой элемент найдется мощность, которая его сожжет.
Go to the top of the page
 
+Quote Post



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

 


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


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