Неадекватное поведение 16F630 при 259 слов в памяти программ

Поклонники продукции Microchip Technology Inc тусуются тут.
Ответить
Аватара пользователя
CaseBot
Открыл глаза
Сообщения: 45
Зарегистрирован: Пт июл 19, 2013 15:08:01
Откуда: Дальний Восток

Неадекватное поведение 16F630 при 259 слов в памяти программ

Сообщение CaseBot »

Доброго времени суток! Занялся написанием часов/будильника на PIC16F630..
Так вот, при занятых 258 словах памяти программ контроллера всё хорошо, ведет себя как и положено, но стоит только дабавить любую команду в начало исходника, то он начинает отображать не то что надо, в зависимости от места постановки лишнего слова..
Может есть какая-то особенность или секрет, которого я не знаю?

Пишу на ассемблере в MPLAB IDE v8.70
Прошиваю через PICkit 2 Programmer

Если нужно, могу выложить исходник..

P.S. Замена контроллера не помогла..
Реклама
otest
Друг Кота
Сообщения: 7853
Зарегистрирован: Ср фев 11, 2009 20:35:58

Re: Неадекватное поведение 16F630 при 259 слов в памяти прог

Сообщение otest »

Если нужно
тебе совет,то выкладывай. Форуму ни чего не нужно.
Реклама
Аватара пользователя
CaseBot
Открыл глаза
Сообщения: 45
Зарегистрирован: Пт июл 19, 2013 15:08:01
Откуда: Дальний Восток

Re: Неадекватное поведение 16F630 при 259 слов в памяти прог

Сообщение CaseBot »

Вот исходник с 259-й командой NOP в блоке инициализации
Собрано на макетной плате: PIC16F630, сдвиговый регистр 74HC595, 4-х разрядный 7-ми сегментный индикатор FYQ-2541AS
Схему соединения сейчас нарисую..
Аватара пользователя
uldemir
Друг Кота
Сообщения: 7359
Зарегистрирован: Пт авг 28, 2009 21:34:30
Откуда: 845-й км.

Re: Неадекватное поведение 16F630 при 259 слов в памяти прог

Сообщение uldemir »

И не мудрено. Вы очень вольно обращаетесь с таблицами. И не учитываете, что команда 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 раза.
Реклама
Эиком - электронные компоненты и радиодетали
otest
Друг Кота
Сообщения: 7853
Зарегистрирован: Ср фев 11, 2009 20:35:58

Re: Неадекватное поведение 16F630 при 259 слов в памяти прог

Сообщение otest »

Компилируй и пиши дальше. Объяснять лень. Читай про PCL и PCH
Реклама
Аватара пользователя
CaseBot
Открыл глаза
Сообщения: 45
Зарегистрирован: Пт июл 19, 2013 15:08:01
Откуда: Дальний Восток

Re: Неадекватное поведение 16F630 при 259 слов в памяти прог

Сообщение CaseBot »

uldemir писал(а):И не учитываете, что команда ADDWF PCL не выполняет перенос в старший байт адреса, при переполнении в младшем.
Да, в этом и была причина.. В источниках, откуда я черпал свои знания (интернет статьи, частично даташиты) такого нюанса не видел..

Благодарю за разъяснение! :beer:
Реклама
iGraphicsS
Нашел транзистор. Понюхал.
Сообщения: 193
Зарегистрирован: Ср фев 16, 2011 22:58:23

Re: Неадекватное поведение 16F630 при 259 слов в памяти прог

Сообщение iGraphicsS »

CaseBot писал(а):частично даташиты
В даташите этому 2-3 странице посвящено, и насколько помню даже со стрелочками куда какие биты переносятся показано. Даташиты надо изучать, а не хрень самописную всякую. Если программа не сильно объемная, то можно сделать так: в мплабе (если там пишете) ставим

Код: Выделить всё

TABLE1     ORG 0xXXXX ;где XXXX адрес начала страницы памяти команд, смотреть ДШ
     ADDWF PCL,1 ;
     RETLW ... ;изымаемые данные
      .....
     RETLW ... ;изымаемые данные
Таблица должны быть в самом конце программы.
Аватара пользователя
uldemir
Друг Кота
Сообщения: 7359
Зарегистрирован: Пт авг 28, 2009 21:34:30
Откуда: 845-й км.

Re: Неадекватное поведение 16F630 при 259 слов в памяти прог

Сообщение uldemir »

Не буду комментировать Ваш наезд на ТС - человек учится, но отмечу, что последнее Ваше утверждение - спорное.
Аватара пользователя
BOB51
Друг Кота
Сообщения: 15573
Зарегистрирован: Вт мар 16, 2010 22:02:27
Откуда: ДОНЕЦК

Re: Неадекватное поведение 16F630 при 259 слов в памяти прог

Сообщение BOB51 »

iGraphicsS писал(а): Таблица должны быть в самом конце программы.
Однако в случае с PICами это утверждение весьма спорно.
Сработает только в случае, если у применяемого МК только одна страница памяти программ.
Ежли мы имеем дело с МК имеющим более 1 страницы памяти программ, то повылазят дополнительные "подарки" от неучтенного содержимого PCLATH даже при обработке простейших подпрограмм (не говоря уже о таблицах). 8)
otest
Друг Кота
Сообщения: 7853
Зарегистрирован: Ср фев 11, 2009 20:35:58

Re: Неадекватное поведение 16F630 при 259 слов в памяти прог

Сообщение otest »

последнее Ваше утверждение - спорное.
Добавлю: вообще не правильное. И приложенный код тоже.
iGraphicsS
Нашел транзистор. Понюхал.
Сообщения: 193
Зарегистрирован: Ср фев 16, 2011 22:58:23

Re: Неадекватное поведение 16F630 при 259 слов в памяти прог

Сообщение iGraphicsS »

Эм... прошу изъяснений.
Аватара пользователя
КРАМ
Друг Кота
Сообщения: 25263
Зарегистрирован: Чт янв 10, 2008 22:01:02
Откуда: Московская область, Фрязино

Re: Неадекватное поведение 16F630 при 259 слов в памяти прог

Сообщение КРАМ »

Таблица вообще может быть где угодно, хоть кусками в разных местах.
Весь это пустопорожний разговор от желания упростить расчет перехода через addwf PCL, f.
Универсальный расчет перехода включает в себя вычисление ЗНАЧЕНИЯ для PCL с переносом (переполнения) в PCLATH и лишь затем записью в сам PCL. Это слегка длиннее, но абсолютно универсально.
otest
Друг Кота
Сообщения: 7853
Зарегистрирован: Ср фев 11, 2009 20:35:58

Re: Неадекватное поведение 16F630 при 259 слов в памяти прог

Сообщение otest »

прошу изъяснений
По выложенному тексту таблица должна находиться в первой странице т.е. в начале программы и заканчиваться не далее 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' ; 
           ; ...
		END
Аватара пользователя
BOB51
Друг Кота
Сообщения: 15573
Зарегистрирован: Вт мар 16, 2010 22:02:27
Откуда: ДОНЕЦК

Re: Неадекватное поведение 16F630 при 259 слов в памяти прог

Сообщение BOB51 »

МММ...
Поговорим о "среднемладших"... Исходим из следующего:
В большинстве случаев таблица нужна для быстрого преобазования данных и редко превышает 256 байт.
Общий объём памяти программ превышает 1 страницу...
Возможна работа активных аппаратных перрываний...
Поскольку при вызове подпрограммы преобразования по CALL TABLE содержимое PCLATH.4:PCLATH.3 уже автоматически сбрасывается в PCH, то загрузка старшего байта адреса указателя таблицы должна быть выполнена перед вызовом CALL TABLE, а не в самом теле обработчика.
Для удобства работы начальную точку желательно размещать на границе областей (0x0000/0xNN00).
Следует учесть, что ADDWF PCL,1 при W=0xFF даст "бесконечный цикл"... :cry: (если не учитывать перенос в старший разряд при "примитиве" минимальной реализации алгоритма обращения к 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 - кому надобно - додумывайте. :)
otest
Друг Кота
Сообщения: 7853
Зарегистрирован: Ср фев 11, 2009 20:35:58

Re: Неадекватное поведение 16F630 при 259 слов в памяти прог

Сообщение otest »

Код: Выделить всё

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
BOB51 Не поленись в MPLAB прогнать этот код.
HHIMERA
Друг Кота
Сообщения: 4583
Зарегистрирован: Вс дек 05, 2010 06:10:34
Откуда: ЮВ

Re: Неадекватное поведение 16F630 при 259 слов в памяти прог

Сообщение HHIMERA »

Да у Микрочипа есть апнота по этому злодейству... поиском её...
"Я не даю готовых решений, я заставляю думать!"(С)
Аватара пользователя
BOB51
Друг Кота
Сообщения: 15573
Зарегистрирован: Вт мар 16, 2010 22:02:27
Откуда: ДОНЕЦК

Re: Неадекватное поведение 16F630 при 259 слов в памяти прог

Сообщение BOB51 »

otest писал(а):

Код: Выделить всё

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
BOB51 Не поленись в MPLAB прогнать этот код.
Верно... :oops: Зевнул :) - любая запись весь PCLATH загружает, а старшей двойки там не будет.
зато второй пример к месту :beer:
otest
Друг Кота
Сообщения: 7853
Зарегистрирован: Ср фев 11, 2009 20:35:58

Re: Неадекватное поведение 16F630 при 259 слов в памяти прог

Сообщение otest »

зато второй пример к месту
Импровизация не возбраняется. Главное не упускать из виду основную суть.
Аватара пользователя
BOB51
Друг Кота
Сообщения: 15573
Зарегистрирован: Вт мар 16, 2010 22:02:27
Откуда: ДОНЕЦК

Re: Неадекватное поведение 16F630 при 259 слов в памяти прог

Сообщение BOB51 »

Благодарю всех участников данного обсуждения, особо otest за помощь в разрушении "стереотипа ADDWF PCL,f"/подсказку решений относительно особенностей работы с PCL/PCLATH для режимов таблица данных/вычисляемый переход (таблица векторов)!
8)
Ответить

Вернуться в «PIC»