Версия для печати темы

Нажмите сюда для просмотра этой темы в обычном формате

Форум разработчиков электроники ELECTRONIX.ru _ MCS51, AVR, PIC, STM8, 8bit _ Помогите освоить MPLAB X IDE

Автор: Herz Jul 25 2018, 18:24

Пришлось мне, всё-таки, расстаться с MPLAB 8.xx. Однако, при освоении новой среды столкнулся с некоторыми странностями.
К примеру, выставляю Configuration bits, но каждый раз после компиляции или при новом открытии проекта они упорно возвращаются к установленным "по умолчанию". Очередная попытка изменить на нужные мне значения сопровождается предупреждением "Pending change must be programmed". Как это понимать?

Автор: =AK= Jul 26 2018, 06:27

Цитата(Herz @ Jul 26 2018, 03:24) *
выставляю Configuration bits, но каждый раз после компиляции или при новом открытии проекта они упорно возвращаются к установленным "по умолчанию".

А я в последнее время обленился и вообще их не трогаю. Мне их MCC генерит.

Автор: Herz Jul 26 2018, 09:55

Вы имеете в виду, что они прописаны в программе? Но в старой MPLAB был хотя бы такой чекбокс: "Configuration bits set in code". А здесь я даже такой возможности не вижу.

Автор: =AK= Jul 26 2018, 10:45

Цитата(Herz @ Jul 26 2018, 18:55) *
Вы имеете в виду, что они прописаны в программе?

MCC генерирует кучу исходников, вокруг которых строится мой проект. В том числе исходник MCC.c, где прописаны фьюзы.


Автор: Herz Jul 28 2018, 16:19

Не пойму, почему у меня не получается видеть значения переменных в окне Watches (или Variables) во время отладки.
Вот, к примеру, крутится пару строчек для теста:

Код
do
{
  U1 = ADC_5 (0, 0);
  
RB0 = ~RB0;  

} while (1);

Так вот, значение RB0 я могу видеть, а значение U1 - нет. Почему бы это?

Автор: Arlleex Jul 29 2018, 13:30

Цитата(Herz @ Jul 28 2018, 19:19) *
Не пойму, почему у меня не получается видеть значения переменных в окне Watches (или Variables) во время отладки.
Вот, к примеру, крутится пару строчек для теста:
Код
do
{
  U1 = ADC_5 (0, 0);
  
RB0 = ~RB0;  

} while (1);

Так вот, значение RB0 я могу видеть, а значение U1 - нет. Почему бы это?

В некоторых случаях отладчик не может увидеть значение локальной переменной.
Я так понял, U1 - локальная переменная в какой-то функции, а RB - порт ввода/вывода. RB объявлен как глобальная переменная по определенному MMIO-адресу, скорее всего. Поэтому и видится без проблем.
Объявите U1 глобально и посмотрите.
В Keil, для ARM, по крайней мере, это так. Хотя бывает такое, что и локальные переменные видны. Причины разные - оптимизация (при отладке у должна быть в O0), размещение переменной в регистре... Ваша ситуация видится похожей.

Автор: Herz Jul 30 2018, 10:02

Это очень странно. U1 у меня - переменная, объявленная в функции main, то есть, по сути, глобальная. Попытки объявить её как static, register или auto ничего не изменили. На extern ругается и, как бы, понятно почему.
В MPLAB 8.xx не было такой проблемы. Внутри функций виделись локальные переменные, в основной программе - глобальные, как и положено.
Сейчас же в каждой функции по-прежнему нет проблем с видимостью её локальных переменных, но вот в main я, почему-то, могу видеть только SFR или, вот, состояние портов.

Как ещё я могу объявить U1 глобальной?

Автор: ViKo Jul 30 2018, 10:11

Цитата(Herz @ Jul 30 2018, 13:02) *
Как ещё я могу объявить U1 глобальной?

Вне функции main.

Автор: Herz Jul 30 2018, 10:22

Цитата(ViKo @ Jul 30 2018, 13:11) *
Вне функции main.

Я пытался, это ничего не меняет. Или даже выдаёт ошибку. В зависимости от спецификатора, с которым я пытаюсь объявить переменную. Как бы Вы объявили её?

Автор: ViKo Jul 30 2018, 10:48

Цитата(Herz @ Jul 30 2018, 13:22) *
Я пытался, это ничего не меняет. Или даже выдаёт ошибку. В зависимости от спецификатора, с которым я пытаюсь объявить переменную. Как бы Вы объявили её?

volatile объявил бы, тогда она была бы всегда.

Автор: Herz Jul 30 2018, 11:23

Так действительно помогло, спасибо. Поскольку у меня прерывания не используются, то и о volatile не задумывался...

Русская версия Invision Power Board (http://www.invisionboard.com)
© Invision Power Services (http://www.invisionpower.com)