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

 
 
 
Reply to this topicStart new topic
> Не работает умножение на микроконтроллере, PIC18F4520
Marser
сообщение Dec 7 2010, 09:36
Сообщение #1


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

Группа: Участник
Сообщений: 162
Регистрация: 12-09-08
Из: Казань
Пользователь №: 40 143



Здравствуйте!
Микроконтроллер не выполняет умножение, если в качестве множителей стоят переменные. Вот код:
long x, y;
x=15;
y=x*2;
indicate(y); ///отображение числа y на семисегментном экране.
В результате отображаетс не 30, а 15, то есть вместо операции y=x*2 выполнилась операция x=y;
Если множители типа int, умножение так же не работает, вот код:
int x, y;
x=15;
y=x*2;
indicate(y); ///отображение числа y на семисегментном экране.
В результате отображается нуль.
Операция умножения работает, только если множители заданы числами:
long y;
y=15*2;
indicate(y); ///отображение числа y на семисегментном экране.
В этом случае отображается число 30, как и должно быть.
В чём может быть проблема?
Cпасибо.


Go to the top of the page
 
+Quote Post
MrYuran
сообщение Dec 7 2010, 09:46
Сообщение #2


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

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



Цитата(Marser @ Dec 7 2010, 12:36) *
Операция умножения работает, только если множители заданы числами:
long y;
y=15*2;

Это не умножение работает, а препроцессор. И забивает по месту заранее сосчитанную константу.


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


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

Группа: Участник
Сообщений: 162
Регистрация: 12-09-08
Из: Казань
Пользователь №: 40 143



Цитата(MrYuran @ Dec 7 2010, 12:46) *
Это не умножение работает, а препроцессор. И забивает по месту заранее сосчитанную константу.

А почему может не умножать микроконтроллер?
Go to the top of the page
 
+Quote Post
dimka76
сообщение Dec 7 2010, 10:55
Сообщение #4


developer
****

Группа: Свой
Сообщений: 902
Регистрация: 12-04-06
Из: Казань
Пользователь №: 16 032



Цитата(Marser @ Dec 7 2010, 13:07) *
А почему может не умножать микроконтроллер?


А с чего вы взяли, что контроллер не умножает?

А если так
Код
volatile int x, y, z;

x= 15;
z = 2;

y = x * z;
indicate(y); ///отображение числа y на семисегментном экране.



--------------------
Все может быть и быть все может, и лишь того не может быть-чего уж точно быть не может, хотя..и это может быть.
Go to the top of the page
 
+Quote Post
_Pasha
сообщение Dec 7 2010, 11:35
Сообщение #5


;
******

Группа: Участник
Сообщений: 5 646
Регистрация: 1-08-07
Пользователь №: 29 509



Цитата(Marser @ Dec 7 2010, 12:36) *
Вот код:

Не, лучше подробнее код, а то так ничего не понятно.
Go to the top of the page
 
+Quote Post
Marser
сообщение Dec 7 2010, 13:19
Сообщение #6


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

Группа: Участник
Сообщений: 162
Регистрация: 12-09-08
Из: Казань
Пользователь №: 40 143



Цитата(dimka76 @ Dec 7 2010, 13:55) *
А с чего вы взяли, что контроллер не умножает?

А если так
Код
volatile int x, y, z;

x= 15;
z = 2;

y = x * z;
indicate(y); ///отображение числа y на семисегментном экране.

Так то же не работает, в результате умножения получается нуль.

Цитата(_Pasha @ Dec 7 2010, 14:35) *
Не, лучше подробнее код, а то так ничего не понятно.

#include "pic18f4520.h"

int x, y, z;
void indicate(int value);

void main(void)
{
x=15;
z=3;
y=x*z;
indicate(y); ///индикация на ЖК экране.
}

void indicate(int value)
{
..... ////подпрограмма отображения символа на экране.
}
Go to the top of the page
 
+Quote Post
Marser
сообщение Dec 8 2010, 12:44
Сообщение #7


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

Группа: Участник
Сообщений: 162
Регистрация: 12-09-08
Из: Казань
Пользователь №: 40 143



Коллеги, проблему удалось решить.
В начале программы, после строки include "pic18F4520.h" я написал настройку конфигурационного регистра:

#ifdef MPLAB_ICD
__CONFIG(4, STVREN & LVPDIS & XINSTDIS & DEBUGEN);
#else
__CONFIG(4, STVREN & LVPDIS & XINSTDIS & DEBUGDIS);
#endif

После добавления этой настройки умножение работает адекватно. Почему, мне точно не понятно. Возможно причина в следующем: такая настройка конфигурационного регистра запрещает расширенный набор команд, а по умолчанию он был разрешён и каким то образом создавал проблемы.
Всем спасибо за советы.
Go to the top of the page
 
+Quote Post
xemul
сообщение Dec 8 2010, 16:58
Сообщение #8



*****

Группа: Свой
Сообщений: 1 928
Регистрация: 11-07-06
Пользователь №: 18 731



Как разрешение или запрет поддержки ICD может повлиять на работу умножителя, боюсь, никому не понятно. Эта поддержка требует некоторых ресурсов контроллера - пара ног, 256 слов на верхушке программной памяти да чуток ОЗУ и стека.
Другие ограничения при отладке с ICD расписаны в документации, но не помню, чтобы там поминался какой-то "расширенный набор команд". (у PIC18F4520 набор команд точно такой же как у остальных PIC18, и все команды благополучно доступны с ICD)

ЗЫЖ симулятор МПЛаба прекрасно симулирует умножитель.
ЗЗЫЖ для y=x*2 компилятор наверняка не стал заморачиваться с умножителем и заменил умножение сдвигами.
ЗЗЗЫЖ скорее всего Ваша проблема связана с проказами компилятора (а ПРО - такой проказник), но тогда её можно решить медитацией над результатами компиляции, а не телепатическим сеансом.
Если у Вас действительно ПРО, и относительно старый, то
- сначала стОит сравнить сорцы с полученными ассемблерными листингами и заглянуть в мап-файл;
- не стОит это делать в присутствии людей, которые думают, что Вы не умеете ругаться.
Go to the top of the page
 
+Quote Post
Marser
сообщение Dec 9 2010, 06:24
Сообщение #9


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

Группа: Участник
Сообщений: 162
Регистрация: 12-09-08
Из: Казань
Пользователь №: 40 143



Цитата(xemul @ Dec 8 2010, 19:58) *
ЗЫЖ симулятор МПЛаба прекрасно симулирует умножитель.

Симулировал он действительно прекрасно, но при прошивке программы в контроллер умножение не работало.
Цитата(xemul @ Dec 8 2010, 19:58) *
ЗЗЫЖ для y=x*2 компилятор наверняка не стал заморачиваться с умножителем и заменил умножение сдвигами.

Умножение не работало с разными числами. Проверял сгенерированный ассемблерный код, там был код умножения, а не сдвига.
Цитата(xemul @ Dec 8 2010, 19:58) *
её можно решить медитацией над результатами компиляции

Ассемблерный код, сгенерированный компилятором, я могу только посмотреть, но не менять. Вы знаете способ изменить этот ассемблерный код перед созданием hex файла? (кроме использования ассемблерной вставки в С - коде)

Go to the top of the page
 
+Quote Post
dimka76
сообщение Dec 9 2010, 06:33
Сообщение #10


developer
****

Группа: Свой
Сообщений: 902
Регистрация: 12-04-06
Из: Казань
Пользователь №: 16 032



Цитата(xemul @ Dec 8 2010, 19:58) *
Как разрешение или запрет поддержки ICD может повлиять на работу умножителя, боюсь, никому не понятно. Эта поддержка требует некоторых ресурсов контроллера - пара ног, 256 слов на верхушке программной памяти да чуток ОЗУ и стека.


Так вот, может стека как раз и не хватало?


--------------------
Все может быть и быть все может, и лишь того не может быть-чего уж точно быть не может, хотя..и это может быть.
Go to the top of the page
 
+Quote Post
_Pasha
сообщение Dec 9 2010, 07:07
Сообщение #11


;
******

Группа: Участник
Сообщений: 5 646
Регистрация: 1-08-07
Пользователь №: 29 509



Хайтек PICC фтопку, он буйный. Был и будет.
Go to the top of the page
 
+Quote Post
Herz
сообщение Dec 9 2010, 08:11
Сообщение #12


Гуру
******

Группа: Модераторы
Сообщений: 10 983
Регистрация: 23-11-05
Пользователь №: 11 287



Цитата(_Pasha @ Dec 9 2010, 09:07) *
Хайтек PICC фтопку, он буйный. Был и будет.

Расскажите это на форуме Микрочипа. Почему-то у всех, кто имел категоричность гнать пургу на компилятор, особенно по подобным поводам, обнаруживались кривые руки...

Цитата(Marser @ Dec 9 2010, 08:24) *
Ассемблерный код, сгенерированный компилятором, я могу только посмотреть, но не менять. Вы знаете способ изменить этот ассемблерный код перед созданием hex файла? (кроме использования ассемблерной вставки в С - коде)

Его не надо менять. Вы его приведите, посмотрим. Дебаггер Вы не используете?
Go to the top of the page
 
+Quote Post
_Pasha
сообщение Dec 9 2010, 09:59
Сообщение #13


;
******

Группа: Участник
Сообщений: 5 646
Регистрация: 1-08-07
Пользователь №: 29 509



Цитата(Herz @ Dec 9 2010, 11:11) *
Расскажите это на форуме Микрочипа. Почему-то у всех, кто имел категоричность гнать пургу на компилятор, особенно по подобным поводам, обнаруживались кривые руки...

Поглядим. sm.gif
Go to the top of the page
 
+Quote Post
xemul
сообщение Dec 9 2010, 13:13
Сообщение #14



*****

Группа: Свой
Сообщений: 1 928
Регистрация: 11-07-06
Пользователь №: 18 731



Цитата(Marser @ Dec 9 2010, 09:24) *
Симулировал он действительно прекрасно, но при прошивке программы в контроллер умножение не работало.

hex в контроллер заливался тот же самый или с поддержкой ICD?
Цитата
Умножение не работало с разными числами. Проверял сгенерированный ассемблерный код, там был код умножения, а не сдвига.

Я говорил про описанный Вами случай x*2. Здесь компилятор оставит умножение только при отключённой оптимизации.
Цитата
Ассемблерный код, сгенерированный компилятором, я могу только посмотреть, но не менять. Вы знаете способ изменить этот ассемблерный код перед созданием hex файла? (кроме использования ассемблерной вставки в С - коде)

Если очень хочется, то можно скомпилить в ассемблерные листинги, поковыряться, а потом из них собрать hex.
Касательно умножений (и остальной арифметики) - они живут в библиотеках, отлажены и вылизаны, сорцы функций доступны. Если есть подозрение, ничто не мешает включить эти сорцы в проект и убедиться, что они работают как задумано.
Цитата(dimka76 @ Dec 9 2010, 09:33) *
Так вот, может стека как раз и не хватало?

Вряд ли. Линкер использование стека отслеживает и при возможности переполнения ругается. Я бы в мап-файл заглянул, не накосячил ли линкер с расположением секций.
ТС не показал содержимое indicate(), но сомневаюсь, что там можно выбрать хотя бы хардварный стек. Если таки удалось, то это повод задуматься о замене контроллера на более разумный без таких ограничений - 31-уровневый стек - просто издевательство над полётом фантазии.sm.gif
Go to the top of the page
 
+Quote Post

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

 


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


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