Неадекватное поведение 16F630 при 259 слов в памяти программ
Неадекватное поведение 16F630 при 259 слов в памяти программ
Доброго времени суток! Занялся написанием часов/будильника на PIC16F630..
Так вот, при занятых 258 словах памяти программ контроллера всё хорошо, ведет себя как и положено, но стоит только дабавить любую команду в начало исходника, то он начинает отображать не то что надо, в зависимости от места постановки лишнего слова..
Может есть какая-то особенность или секрет, которого я не знаю?
Пишу на ассемблере в MPLAB IDE v8.70
Прошиваю через PICkit 2 Programmer
Если нужно, могу выложить исходник..
P.S. Замена контроллера не помогла..
Так вот, при занятых 258 словах памяти программ контроллера всё хорошо, ведет себя как и положено, но стоит только дабавить любую команду в начало исходника, то он начинает отображать не то что надо, в зависимости от места постановки лишнего слова..
Может есть какая-то особенность или секрет, которого я не знаю?
Пишу на ассемблере в MPLAB IDE v8.70
Прошиваю через PICkit 2 Programmer
Если нужно, могу выложить исходник..
P.S. Замена контроллера не помогла..
- Реклама
Re: Неадекватное поведение 16F630 при 259 слов в памяти прог
тебе совет,то выкладывай. Форуму ни чего не нужно.Если нужно
Re: Неадекватное поведение 16F630 при 259 слов в памяти прог
Вот исходник с 259-й командой NOP в блоке инициализации
Собрано на макетной плате: PIC16F630, сдвиговый регистр 74HC595, 4-х разрядный 7-ми сегментный индикатор FYQ-2541AS
Схему соединения сейчас нарисую..
Собрано на макетной плате: PIC16F630, сдвиговый регистр 74HC595, 4-х разрядный 7-ми сегментный индикатор FYQ-2541AS
Схему соединения сейчас нарисую..
Re: Неадекватное поведение 16F630 при 259 слов в памяти прог
И не мудрено. Вы очень вольно обращаетесь с таблицами. И не учитываете, что команда ADDWF PCL не выполняет перенос в старший байт адреса, при переполнении в младшем.
У меня для контроля в таких случаях всегда стоял предохранитель:
У меня для контроля в таких случаях всегда стоял предохранитель:
Код: Выделить всё
decpartb:
andlw 0x0f
addwf pcl
DT 0, 1, 1, 2, 3, 3, 4, 4
DT 5, 6, 6, 7, 8, 8, 9, 9
;
IF high($-1)-high(decpartb)
ERROR "decpartb over page edge"
ENDIF
Последний раз редактировалось uldemir Вс мар 09, 2014 19:41:26, всего редактировалось 3 раза.
Re: Неадекватное поведение 16F630 при 259 слов в памяти прог
Компилируй и пиши дальше. Объяснять лень. Читай про PCL и PCH
- Реклама
Re: Неадекватное поведение 16F630 при 259 слов в памяти прог
Да, в этом и была причина.. В источниках, откуда я черпал свои знания (интернет статьи, частично даташиты) такого нюанса не видел..uldemir писал(а):И не учитываете, что команда ADDWF PCL не выполняет перенос в старший байт адреса, при переполнении в младшем.
Благодарю за разъяснение!
-
iGraphicsS
- Нашел транзистор. Понюхал.
- Сообщения: 193
- Зарегистрирован: Ср фев 16, 2011 22:58:23
Re: Неадекватное поведение 16F630 при 259 слов в памяти прог
В даташите этому 2-3 странице посвящено, и насколько помню даже со стрелочками куда какие биты переносятся показано. Даташиты надо изучать, а не хрень самописную всякую. Если программа не сильно объемная, то можно сделать так: в мплабе (если там пишете) ставимCaseBot писал(а):частично даташиты
Код: Выделить всё
TABLE1 ORG 0xXXXX ;где XXXX адрес начала страницы памяти команд, смотреть ДШ
ADDWF PCL,1 ;
RETLW ... ;изымаемые данные
.....
RETLW ... ;изымаемые данные
Re: Неадекватное поведение 16F630 при 259 слов в памяти прог
Не буду комментировать Ваш наезд на ТС - человек учится, но отмечу, что последнее Ваше утверждение - спорное.
Re: Неадекватное поведение 16F630 при 259 слов в памяти прог
Однако в случае с PICами это утверждение весьма спорно.iGraphicsS писал(а): Таблица должны быть в самом конце программы.
Сработает только в случае, если у применяемого МК только одна страница памяти программ.
Ежли мы имеем дело с МК имеющим более 1 страницы памяти программ, то повылазят дополнительные "подарки" от неучтенного содержимого PCLATH даже при обработке простейших подпрограмм (не говоря уже о таблицах).
Re: Неадекватное поведение 16F630 при 259 слов в памяти прог
Добавлю: вообще не правильное. И приложенный код тоже.последнее Ваше утверждение - спорное.
-
iGraphicsS
- Нашел транзистор. Понюхал.
- Сообщения: 193
- Зарегистрирован: Ср фев 16, 2011 22:58:23
Re: Неадекватное поведение 16F630 при 259 слов в памяти прог
Эм... прошу изъяснений.
- КРАМ
- Друг Кота
- Сообщения: 25263
- Зарегистрирован: Чт янв 10, 2008 22:01:02
- Откуда: Московская область, Фрязино
Re: Неадекватное поведение 16F630 при 259 слов в памяти прог
Таблица вообще может быть где угодно, хоть кусками в разных местах.
Весь это пустопорожний разговор от желания упростить расчет перехода через addwf PCL, f.
Универсальный расчет перехода включает в себя вычисление ЗНАЧЕНИЯ для PCL с переносом (переполнения) в PCLATH и лишь затем записью в сам PCL. Это слегка длиннее, но абсолютно универсально.
Весь это пустопорожний разговор от желания упростить расчет перехода через addwf PCL, f.
Универсальный расчет перехода включает в себя вычисление ЗНАЧЕНИЯ для PCL с переносом (переполнения) в PCLATH и лишь затем записью в сам PCL. Это слегка длиннее, но абсолютно универсально.
Re: Неадекватное поведение 16F630 при 259 слов в памяти прог
По выложенному тексту таблица должна находиться в первой странице т.е. в начале программы и заканчиваться не далее 0xFF.прошу изъяснений
Если хотите располагать таблицу в любом месте, то как описал КРАМ.
Поиграйте с текстом в MPLAB.
Код: Выделить всё
LIST P=16F630
#INCLUDE <P16F630.INC>
ERRORLEVEL -302
__CONFIG 3FF1H
;=========
REG EQU 0x20
;==========
ORG 0
CALL TABLE
NOP
;=================
ORG 220H ; РАСПОЛОЖЕНИЕ В ЛЮБОЙ СТРАНИЦЕ ПАМЯТИ ПРОГРАММ
TABLE MOVLW HIGH TABL ; СТАРШИЙ БАЙТ АДРЕСА ТАБЛИЦЫ
MOVWF PCLATH ; В PCLATH
MOVF REG,W ; ЗАБИРАЕМ ЧТО НУЖНО ПЕРЕКОДИРОВАТЬ
ADDLW LOW TABL ; СКЛАДЫВАЕМ С МЛАДШИМ БАЙТОМ АДРЕСА ТАБЛИЦЫ
BTFSC STATUS,C ; ПРОВЕРКА ПЕРЕПОЛНЕНИЯ
INCF PCLATH,F ; ЕСТЬ ПЕРЕНОС PCLATH+1
MOVF REG,W ; НЕТ ПЕРЕНОСА.ЗАБИРАЕМ ЧТО НУЖНО ПЕРЕКОДИРОВАТЬ
;==================
ADDWF PCL,F ;
TABL RETLW B'11000000' ;
RETLW B'10011111' ;
; ...
ENDRe: Неадекватное поведение 16F630 при 259 слов в памяти прог
МММ...
Поговорим о "среднемладших"... Исходим из следующего:
В большинстве случаев таблица нужна для быстрого преобазования данных и редко превышает 256 байт.
Общий объём памяти программ превышает 1 страницу...
Возможна работа активных аппаратных перрываний...
Поскольку при вызове подпрограммы преобразования по CALL TABLE содержимое PCLATH.4:PCLATH.3 уже автоматически сбрасывается в PCH, то загрузка старшего байта адреса указателя таблицы должна быть выполнена перед вызовом CALL TABLE, а не в самом теле обработчика.
Для удобства работы начальную точку желательно размещать на границе областей (0x0000/0xNN00).
Следует учесть, что ADDWF PCL,1 при W=0xFF даст "бесконечный цикл"...
(если не учитывать перенос в старший разряд при "примитиве" минимальной реализации алгоритма обращения к PCL)
Таким образом вводится еще одно ограничение на входные параметры при вызове обработчика.
В обработчике прерываний обязательным пунктом будет хранение в программном блоке временных регистров содержимого PCLATH и его последующее восстановление по завершению обработчика прерываний.
Пример с дополнительной предобработкой содержимого PCLATH в теле обработчика необходим лишь в случае произвольной точки вхождения в обработчик таблиц в любой точке адресного пространства памяти программ.
В большинстве практических применений достаточно предварительное указание старшего байта адреса таблицы, не забывая при том, что исходное (до CALL TABLE) содержимое PCLATH после выполнения RETLW X будет искажено (если не добавить еще один промежуточный регистр временного хранения).
Кстати PIC16F630 такие страсти-ужасти практически не угрожают - диапазон адресов не затрагивает PCLATH.4:PCLATH.3 (0x000-0x3FF) да еще при весьма "льготном" режиме доступа ко второму банку РПД.
Единственно надо следить за PCLATH.2:PCLATH.1:PCLATH.0, но и это не обязательно, если таблица на границе 256 байтовой области, либо значение в W не превышает 127.
Т.е. для 630-го это будет:
REG EQU 0x20
;==========
ORG 0
CALL TABLE
NOP
;=================
ORG 220H ; РАСПОЛОЖЕНИЕ В ЛЮБОм
; месте памяти программ при разрешенном
; диапазоне значений в W от 0 до 127 (0x00-0x7F)
TABLE
ADDWF PCL,F ;
TABL RETLW B'11000000' ;
RETLW B'10011111' ;
; ...
END
Если же необходимо использовать страничный механизм, то прийдется сделать такое:
movlw high TABLE
movwf PCLATH
CALL TABLE
_______
TABLE
movlw low TABLE
addwf reg,w
btfsc STATUS,C
incf PCLATH,f
movwf PCL
ну и далее кучка retlw
а вот как насчет 0xFF в REG... и дополнительного хранения/восстановления PCLATH - кому надобно - додумывайте.
Поговорим о "среднемладших"... Исходим из следующего:
В большинстве случаев таблица нужна для быстрого преобазования данных и редко превышает 256 байт.
Общий объём памяти программ превышает 1 страницу...
Возможна работа активных аппаратных перрываний...
Поскольку при вызове подпрограммы преобразования по CALL TABLE содержимое PCLATH.4:PCLATH.3 уже автоматически сбрасывается в PCH, то загрузка старшего байта адреса указателя таблицы должна быть выполнена перед вызовом CALL TABLE, а не в самом теле обработчика.
Для удобства работы начальную точку желательно размещать на границе областей (0x0000/0xNN00).
Следует учесть, что ADDWF PCL,1 при W=0xFF даст "бесконечный цикл"...
Таким образом вводится еще одно ограничение на входные параметры при вызове обработчика.
В обработчике прерываний обязательным пунктом будет хранение в программном блоке временных регистров содержимого PCLATH и его последующее восстановление по завершению обработчика прерываний.
Пример с дополнительной предобработкой содержимого PCLATH в теле обработчика необходим лишь в случае произвольной точки вхождения в обработчик таблиц в любой точке адресного пространства памяти программ.
В большинстве практических применений достаточно предварительное указание старшего байта адреса таблицы, не забывая при том, что исходное (до CALL TABLE) содержимое PCLATH после выполнения RETLW X будет искажено (если не добавить еще один промежуточный регистр временного хранения).
Кстати PIC16F630 такие страсти-ужасти практически не угрожают - диапазон адресов не затрагивает PCLATH.4:PCLATH.3 (0x000-0x3FF) да еще при весьма "льготном" режиме доступа ко второму банку РПД.
Единственно надо следить за PCLATH.2:PCLATH.1:PCLATH.0, но и это не обязательно, если таблица на границе 256 байтовой области, либо значение в W не превышает 127.
Т.е. для 630-го это будет:
REG EQU 0x20
;==========
ORG 0
CALL TABLE
NOP
;=================
ORG 220H ; РАСПОЛОЖЕНИЕ В ЛЮБОм
; месте памяти программ при разрешенном
; диапазоне значений в W от 0 до 127 (0x00-0x7F)
TABLE
ADDWF PCL,F ;
TABL RETLW B'11000000' ;
RETLW B'10011111' ;
; ...
END
Если же необходимо использовать страничный механизм, то прийдется сделать такое:
movlw high TABLE
movwf PCLATH
CALL TABLE
_______
TABLE
movlw low TABLE
addwf reg,w
btfsc STATUS,C
incf PCLATH,f
movwf PCL
ну и далее кучка retlw
а вот как насчет 0xFF в REG... и дополнительного хранения/восстановления PCLATH - кому надобно - додумывайте.
Re: Неадекватное поведение 16F630 при 259 слов в памяти прог
Код: Выделить всё
REG EQU 0x20
;==========
ORG 0
CALL TABLE
NOP
;=================
ORG 220H ; РАСПОЛОЖЕНИЕ В ЛЮБОм
; месте памяти программ при разрешенном
; диапазоне значений в W от 0 до 127 (0x00-0x7F)
TABLE
ADDWF PCL,F ;
TABL RETLW B'11000000' ;
RETLW B'10011111' ;
; ...
ENDRe: Неадекватное поведение 16F630 при 259 слов в памяти прог
Да у Микрочипа есть апнота по этому злодейству... поиском её...
"Я не даю готовых решений, я заставляю думать!"(С)
Re: Неадекватное поведение 16F630 при 259 слов в памяти прог
Верно...otest писал(а):BOB51 Не поленись в MPLAB прогнать этот код.Код: Выделить всё
REG EQU 0x20 ;========== ORG 0 CALL TABLE NOP ;================= ORG 220H ; РАСПОЛОЖЕНИЕ В ЛЮБОм ; месте памяти программ при разрешенном ; диапазоне значений в W от 0 до 127 (0x00-0x7F) TABLE ADDWF PCL,F ; TABL RETLW B'11000000' ; RETLW B'10011111' ; ; ... END
зато второй пример к месту
Re: Неадекватное поведение 16F630 при 259 слов в памяти прог
Импровизация не возбраняется. Главное не упускать из виду основную суть.зато второй пример к месту
Re: Неадекватное поведение 16F630 при 259 слов в памяти прог
Благодарю всех участников данного обсуждения, особо otest за помощь в разрушении "стереотипа ADDWF PCL,f"/подсказку решений относительно особенностей работы с PCL/PCLATH для режимов таблица данных/вычисляемый переход (таблица векторов)!



