Поклонники продукции Microchip Technology Inc тусуются тут.
Ср май 19, 2021 15:44:26
Всем привет! Использую MPASM pic12f629
Код:
bsf STATUS, RP0
clrf TRISIO
bcf STATUS, RP0
clrf GPIO
movlw 0x07
Movwf CMCON
bsf GPIO, GP1
На выходе устанавливается высокий уровень. Но как только вызову:
bsf GPIO, GP2
или
bcf GPIO, GP2
У меня сбрасывается пин GP1.
Почему так происходит?
У меня кончились идеи. В даташите ничего подобного не нашел.
Ср май 19, 2021 16:30:49
В даташите ничего подобного не нашел.
Этого не может быть.
Вот сразу перевод.
Чтение регистра GPIO возвращает состояние на выводах порта, а запись производится в защелку GPIO. Все
операции записи в порт выполняются по принципу «
чтение – модификация - запись», т.е. сначала производится чтение состояния выводов порта, затем изменение и запись в защелку.
Ср май 19, 2021 16:46:20
Не в полне понимаю почему gp1 сбрасывается.
Получается
1. Считали
000010
2. Модифицировали
000110
3. Записали в защелку
Ср май 19, 2021 17:17:39
Этой "проблеме" столько-же, сколько самому PIC, я думал, что об этом "глюке" и не услышу уже. :-D
TC: nop поставьте между bsf/bcf
Ср май 19, 2021 17:54:22
Не в полне понимаю почему gp1 сбрасывается.
Получается
1. Считали
000010
2. Модифицировали
000110
3. Записали в защелку
Проблема в нагрузке на проблемный пин и в скорости чтения/записи. Если на пин напрямую повесить светодиод, например, то с него будет читаться 0, а не выведенная в пин 1.
В современных ПИКах есть отдельный регистр защелки выхода LAT и запись в этот регистр отдельного бита не связана с чтением пинов. Читается защелка, а не пин.
Ср май 19, 2021 19:31:54
Как решение буфер вывода - с ним проводятся изменения, а уже его содержимое затем выдается в порт.
Ср май 19, 2021 22:45:44
Проблема в нагрузке на проблемный пин и в скорости чтения/записи. Если на пин напрямую повесить светодиод, например, то с него будет читаться 0, а не выведенная в пин 1.
Времени предостаточно, аж 8uS до вызова bsf. Попробовал поставить пожтягивающий резастор по + питания. Не дало результата.
Добавлено after 2 minutes 39 seconds:Использовать буфер не дает возможность по времени. Тайминги всего алгоритма сбиваются. nop ставить тоже пробовал. Странный глюк.
Добавлено after 12 minutes 24 seconds: C GP5 таких проблем нет, все отлично вкл. когда нужно и выкл. когда нужно. Только мне нужен GP1
А с GP0 тоже что и с GP1. С остальными таких проблем нет. Может это как-то связано с компаратором.
Ср май 19, 2021 23:32:20
trojninalex писал(а):Попробовал поставить пожтягивающий резастор по + питания.
Зачем подтягивающий резистор ноге, которую настроили на выход ?
Вам нужно разгрузить эту ногу. В защёлку пишется значение, равное реальному уровню на ноге, а не то, которое вы записали когда-то там. И никакие тут НОПы не спасут ...
Чт май 20, 2021 00:22:05
bsf GPIO, GP1
На ноге GP1 появились +5v (точнее +4.92v)
; ANOTHER CODE
bsf GPIO, GP2
На ноге GP1 пропали +5v, на ноге GP2 появились +5v
Второй абзац пункта 3.1 страница 19. На странице 22 блок диаграмма пинов GP0 и GP1.
Судя по описанию и диаграме, контакты порта считываются уже на выходе пина, модифицируется и записывается в защелку.
В симуляции проблеммы нет, и как я все это понимаю должно работать без проблем, но...
- Вложения
-
- Screenshot_2021-05-20_00-04-29.png
- (111.15 KiB) Скачиваний: 180
Чт май 20, 2021 05:07:59
На ноге GP1 пропали....на ноге GP2 появились...
Приведите РЕАЛЬНУЮ схему. Без домыслов, как есть.
Чт май 20, 2021 10:27:58
Возожно вопрос во взаимодействии с компаратором.
Стоит проверить режим отключения незадействованного аппаратного модуля.
Я частенько вот такую вставку делаю:
- Код:
; инициализация железа при первой подаче питания
;
hard_init
clrwdt
MOVLW 07h ; Set GP<2:0> to
MOVWF CMCON ; digital IO
но именно в самом начале программы, а не в режиме "оперативного переназначения" выводов.
Да и без схемы и полного текста программы будет очередное "гадание"....
Чт май 20, 2021 16:55:51
trojninalex писал(а):контакты порта считываются уже на выходе пина, модифицируется и записывается в защелку
А Вам что написали :
Аlex писал(а):В защёлку пишется значение, равное реальному уровню на ноге, а не то, которое вы записали когда-то там.
Вс май 23, 2021 14:47:29
В данный момент контроллер подключен к логическому анализатору.
Добавлено after 1 minute 54 seconds:
Alex
Я рад что мы смогли убедиться, что понимаем одинакого, как работает порт на 12f629. Теперь можем перейти к решению самого вопроса.
Вс май 30, 2021 13:51:59
Эксперименты продолжаются.
Решил по ножкам сделать внутренюб подтяжку
Установки следующие
Trisio = 0x3f
nGPPU = 0
CmCON = 7
WPU (по умолчанию равен 3f)
Подтяжка появилась на всех ножках кооме gp0 и gp1.
Пробовал на нескольких чипах. Результат тот же.
И вопрос по выходу так же не решен.
Пн май 31, 2021 06:33:30
У ТС PIC12F629, а CMCON он настраивает.
Пн май 31, 2021 09:46:09
О-о-опс, недосмотрел, недочитал.
Извините.
Powered by phpBB © phpBB Group.
phpBB Mobile / SEO by Artodia.