Перейти к содержанию

Неверные временные интервалы при использовании команд BSF BCF


luxor92

Рекомендуемые сообщения

Добрый вечер, уважаемые знатоки. Нужна Ваша помощь. Столкнулся с такой проблемой, что PIC16F627 не удерживает достаточное количество времени логические единицы. Подскажите, пожалуйста, почему. Чтобы было нагляднее, написал программу: на ногах мк должна последовательно появиться единица, затем в той же последовательности появиться ноль, теоретически на диаграмме с лог. анализатора должны быть прямоугольники, немного смещенные друг относительно друга, но фактически имеем то, что некоторые логические единицы сразу же сбрасываются в ноль. Почему? 

11.png

задержки реализованы с помощью nop. Используется внутренний генератор МК.

Изменено пользователем luxor92
Ссылка на комментарий
Поделиться на другие сайты

Цитата

ORG 0

bsf STATUS, 5 ; go bank 1
CLRF TRISA; set TRISA to out
bcf STATUS, 5 ; back to bank 0
CLRF PORTA

start
bsf PORTA, RS
nop
BSF PORTA, RW
nop
BSF PORTA, E
nop
BSF PORTA, DB7
nop
 bsf PORTA, DB6
 nop
 bsf PORTA, DB5
 nop
 bsf PORTA, DB4
 nop
 BCF PORTA, RS
 nop
 BCF PORTA, RW
 nop
 BCF PORTA, E
 nop
 bcf PORTA, DB7
 nop
 BCF PORTA, DB6
 nop
 bcf PORTA, DB5
 nop
 bcf PORTA, DB4
 nop
 nop
 nop
 nop
 nop
 nop
 nop
 
 goto start

 

Ссылка на комментарий
Поделиться на другие сайты

Сравнительное тестирование аккумуляторов EVE Energy и Samsung типоразмера 18650

Инженеры КОМПЭЛ провели сравнительное тестирование аккумуляторов EVE и Samsung популярного для бытовых и индустриальных применений типоразмера 18650. 

Для теста были выбраны аккумуляторы литий-никельмарганцевой системы: по два образца одного наименования каждого производителя – и протестированы на двух значениях тока разряда: 0,5 А и 2,5 А. Испытания проводились в нормальных условиях на электронной нагрузке EBD-USB от ZKEtech, а зарядка осуществлялась от лабораторного источника питания в режиме CC+CV в соответствии с рекомендациями в даташите на определенную модель. Подробнее>>

Реклама: АО КОМПЭЛ, ИНН: 7713005406, ОГРН: 1027700032161

Новый аккумулятор EVE серии PLM для GSM-трекеров, работающих в жёстких условиях (до -40°С)

Компания EVE выпустила новый аккумулятор серии PLM, сочетающий в себе высокую безопасность, длительный срок службы, широкий температурный диапазон и высокую токоотдачу даже при отрицательной температуре. 

Эти аккумуляторы поддерживают заряд при температуре от -40/-20°С (сниженным значением тока), безопасны (не воспламеняются и не взрываются) при механическом повреждении (протыкание и сдавливание), устойчивы к вибрации. Они могут применяться как для автотранспорта (трекеры, маячки, сигнализация), так и для промышленных устройств мониторинга, IoT-устройств. Подробнее параметры и результаты тестов новой серии PLM по ссылке.

Реклама: АО КОМПЭЛ, ИНН: 7713005406, ОГРН: 1027700032161

Литиевые батарейки и аккумуляторы от мирового лидера  EVE в Компэл

Компания Компэл, официальный дистрибьютор EVE Energy, бренда №1 по производству химических источников тока (ХИТ) в мире, предлагает продукцию EVE как со склада, так и под заказ. Компания EVE широко известна в странах Европы, Америки и Юго-Восточной Азии уже более 20 лет. Недавно EVE была объявлена поставщиком новых аккумуляторных элементов круглого формата для электрических моделей «нового класса» компании BMW.

Продукция EVE предназначена для самого широкого спектра применений – от бытового до промышленного. Подробнее>>

Реклама: АО КОМПЭЛ, ИНН: 7713005406, ОГРН: 1027700032161

 

К сожалению проблема не ушла, она перестала проявлять себя только в первой тестовой программе. Написал программу, в которой в течение логического уровня "1" на одной из ног (PORTA,E = RA0), должны "подняться" другие ноги, и вот что имеем на анализаторе: RA7, RA6, RA1 поднимаются, остальные не реагируют на программу. В чем еще может быть проблема? :( Прикладываю график и код.

диаграмма.png

 

Цитата

LIST P=16F627A
; PIC16F627 Configuration Bit Settings
; Assembly source line config statements
#include "p16f627A.inc"

; CONFIG
; __config 0x3F18
 __CONFIG _FOSC_INTOSCIO & _WDTE_OFF & _PWRTE_OFF & _MCLRE_OFF & _BOREN_OFF & _LVP_OFF & _CPD_OFF & _CP_OFF

Reg_1 EQU 0x21 ;/////////////////
Reg_2 EQU 0x22 ; FOR TIMING   ///
Reg_3 EQU 0x23 ;/////////////////
RS EQU 7
RW EQU 6
DB7 EQU 4
DB6 EQU 3
DB5 EQU 2
DB4 EQU 1
E EQU 0

ORG 0
 CLRF PORTA      ;отключили компараторы
 movlw 0x07
 movwf CMCON      
 bsf STATUS, 5   ; TRISA & TRISB на выход
 CLRF TRISA
 CLRF TRISB
 bcf STATUS, 5

start            ; Выжидаем паузу
 nop
 nop
 nop
 
movlw b'11111111'  ; Делаем очередь из 0xFF и 0x00 на PORTA, чтобы легко
 movwf PORTA       ;  было найти начало на графиках
 nop
 CLRF PORTA
 nop
 movlw b'11111111'
 movwf PORTA
 nop
 CLRF PORTA
 nop
 movlw b'11111111'
 movwf PORTA
 nop
 CLRF PORTA
 nop
 movlw b'11111111'
 movwf PORTA
 nop
 CLRF PORTA
 nop
 movlw b'11111111'
 movwf PORTA
 nop
 CLRF PORTA
 nop                        ; делаем пузу в 10 "nop"
 nop
 nop
 nop
 nop
 nop
 nop
 nop
 nop
 nop

                 ; Здесь начинается часть программы,
               ; выполняющаяся с ошибкой
               
bcf PORTA, RS             ; Сбрасываем RS, RW
bcf PORTA, RW             ;
nop        
bsf PORTA, E              ; Устанавливаем строб Е
nop;      
bsf PORTA, DB4 
nop                                ; Устанавливаем  DB7:DB4 в '1'
bsf PORTA, DB5            ;
nop              ;
bsf PORTA, DB6            ;
nop              ;
bsf PORTA, DB7            ;
bsf PORTA, RS             ;
bsf PORTA, RW             ;
              ;        
nop        
bcf PORTA, E          ; Сбрасываем E
nop

 
 ;зацикливаем программу
 nopping
 nop
 nop
 nop
 nop
 goto nopping

end

Ra4 подтянут к земле через резистор 670 ом. 

Ссылка на комментарий
Поделиться на другие сайты

Это реальный объект. Как избежать то этого эффекта? Nop'ы везде расставил. Переключений ног с входов на выходы нет. Скорость низкая, должны напряжения успевать подниматься вроде как...

Ссылка на комментарий
Поделиться на другие сайты

влияние емкости монтажа.

 я решал этот вопрос через темповскую  переменную типа
 

 bsf tempPORTA,RA4
 movfw tempPORTA
 movwf PORTA 
;или если несколько битов 
  movlw (1<<4)|(1<<5)
  iorwf tempPORTA,w
  iorwf tempPORTA,f
  movwf PORTA  
 ;или
   movfw tempPORTA
    iorlw (1<<4)|(1<<5)
    movwf PORTA
   movwf tempPORTA 
   

на одну команду больше, но работает железобетонно...

Ссылка на комментарий
Поделиться на другие сайты

2 часа назад, IMXO сказал:

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

Сделал так же:

Цитата


bcf ADDITIONAL, RS
bcf ADDITIONAL, RW
               
bsf PORTA, E
bsf ADDITIONAL, E            ; Устанавливаем строб Е
      
 
bsf ADDITIONAL, DB4      ; Устанавливаем  DB7:DB4 в '1'
bsf ADDITIONAL, DB5            ;
bsf ADDITIONAL, DB6            ;
bsf ADDITIONAL, DB7            ;
bsf ADDITIONAL, RS              ;
bsf ADDITIONAL, RW             ;
movf ADDITIONAL, W            ;
movwf PORTA
nop        
bcf PORTA, E          ; Сбрасываем E
bcf ADDITIONAL, E
nop

Вот результат:

2.png

Теперь все работает как надо, радует синхронность установки данных DB7:DB4. Совет помог, уважуха! Надеюсь, инициализацию LCD допишу без казусов :)

Ссылка на комментарий
Поделиться на другие сайты

6 часов назад, luxor92 сказал:

Теперь все работает как надо

сомневаюсь, если используете темр, то обращение к порту только через темр, те это

nop        
bcf PORTA, E          ; Сбрасываем E
bcf ADDITIONAL, E
nop 

не правильно. тоже должно быть

nop       
bcf ADDITIONAL, E
movfw ADDITIONAL, E
movwf PORTA
nop

 

Ссылка на комментарий
Поделиться на другие сайты

Да, то что есть ошибка - понятно.Но даже если ее устранить, появилась дополнительная проблема. Есть два вывода PORTA (Ra2 и Ra3), они по какой-то причине влияют друг на друга: если один из них имеет низкий логический уровень, то на другом отдельно нельзя поставить высокий уровень, они либо оба равны нулям, либо оба равны единицам. Причина неизвестна, запись провожу через дополнительный регистр. О такой ошибке ничего не известно, или все из той же оперы чмз? 

Ссылка на комментарий
Поделиться на другие сайты

а почему такое не эффекивное назначение выводов порта

RS EQU 7
RW EQU 6
DB7 EQU 4
DB6 EQU 3
DB5 EQU 2
DB4 EQU 1
E EQU 0 

это ж какой геморой для ввода данных...

логичней было бы

RS EQU 7
RW EQU 6
E EQU 4 
DB7 EQU 3
DB6 EQU 2
DB5 EQU 1
DB4 EQU 0

 

Ссылка на комментарий
Поделиться на другие сайты

Физически сначала соединил pic и LCD, а потом уже писал, поэтому так... Особого дискомфорта не принесло это при вводе данных. , т.к отвёл отдельный регистр для байта данных, а подпрограмма уже распределяла по ногам porta данные по 4 бита как надо :) забуксовал ещё немного с инициализацией, там же команда отключения на дисплей идёт , а включить сразу не догадался.. но сейчас результат получен, lcd1602 повержен :)

Изменено пользователем luxor92
Ссылка на комментарий
Поделиться на другие сайты

Присоединяйтесь к обсуждению

Вы можете написать сейчас и зарегистрироваться позже. Если у вас есть аккаунт, авторизуйтесь, чтобы опубликовать от имени своего аккаунта.
Примечание: Ваш пост будет проверен модератором, прежде чем станет видимым.

Гость
Unfortunately, your content contains terms that we do not allow. Please edit your content to remove the highlighted words below.
Ответить в этой теме...

×   Вставлено с форматированием.   Восстановить форматирование

  Разрешено использовать не более 75 эмодзи.

×   Ваша ссылка была автоматически встроена.   Отображать как обычную ссылку

×   Ваш предыдущий контент был восстановлен.   Очистить редактор

×   Вы не можете вставлять изображения напрямую. Загружайте или вставляйте изображения по ссылке.

Загрузка...
  • Последние посетители   0 пользователей онлайн

    • Ни одного зарегистрированного пользователя не просматривает данную страницу
  • Сообщения

    • Здесь все индивидуально, точного ответа нет. Тип фоторезиста, качество фотошаблона, расстояние и время засветки, длина волны св.диодов, "полоскание" в химии ... Надо все пробовать самому, ручками, опыт придет со временем, ничего сложного там нет. На форуме есть ветка, почитайте.
    • Привет.  Хочу попробовать поработать с фоторезистом. Есть пару десятков ультрафиолетовых светодиодов, общей мощностью 4 вата. Хватит ли этой мощности для обработки платок размером 10 на 10 см или надо искать что-то дополнительно? 
    • Чтобы меньше было излучения, нужно мотать тороидальную. Возможно для повышения добротности по омическому сопротивлению лучше этот ТОР мотать в пару слоев. Если ее намотать на шило, то она вряд ли будет вообще работать как катушка.   Индуктивность прямо пропорциональна площади сечения, которая в свою очередь прямо пропорциональна квадрату диаметра. К тому же индуктивность в обратной пропорции с длиной намотки.
    • Я в ходе отладки выяснил, что сбоит в функции:  void w25qWritingByUSB(uint32_t dpagenum, uint8_t *bufByUSB) При чем поведение очень странное. Отладочные сообщения даже не выводятся в начале функции. В ходе экспериментов понял что связано это с объявлением массивов и решил объявить большие буферы которые на 4КБ и 0.25КБ: uint8_t current_sector_buf[4096]; uint8_t buf[256]; глобально. В оригинале, буферы объявлялись локально в функции. После изменения буквально двух строчек кода, все заработало. Также, в оригинальном проекте было сильно напутано из функциями. Я решил функции выкинуть из main.c и вставить в w25q.c Эти функции: void w25qEraseSector(uint16_t sector) void w25qWritingByUSB(uint32_t dpagenum, uint8_t *bufByUSB) Поиск данной проблемы реально отобрало кучу времени. На будущее буду знать что и такое бывает...
    • есть готовый  драйвер BTS7960 до 43А (долговременно до 10) с шим и все, что нужно и стоит недорого. И не надо изобретать  велосипед. Даже с учетом завышения параметров  уж 5А свободно.
    • А есть внятное описание этого M18? По моему он не очень "интегирируется" с микроконтроллером, да и нужно ли? По схеме выше - подключить его к U1C, выход U1C кинуть на +С12, U1D вообще выкинуть вместе с D1,D2 и R13.
×
×
  • Создать...