Автор: 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 не задумывался...