Поклонники продукции Microchip Technology Inc тусуются тут.
Ответить

Сложности с управлением gp1

Ср май 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.
Почему так происходит?
У меня кончились идеи. В даташите ничего подобного не нашел.

Re: Сложности с управлением gp1

Ср май 19, 2021 16:30:49

В даташите ничего подобного не нашел.

Этого не может быть.
Вот сразу перевод.
Чтение регистра GPIO возвращает состояние на выводах порта, а запись производится в защелку GPIO. Все
операции записи в порт выполняются по принципу «чтение – модификация - запись», т.е. сначала производится чтение состояния выводов порта, затем изменение и запись в защелку.

Re: Сложности с управлением gp1

Ср май 19, 2021 16:46:20

Не в полне понимаю почему gp1 сбрасывается.
Получается
1. Считали
000010
2. Модифицировали
000110
3. Записали в защелку

Re: Сложности с управлением gp1

Ср май 19, 2021 17:17:39

Этой "проблеме" столько-же, сколько самому PIC, я думал, что об этом "глюке" и не услышу уже. :-D
TC: nop поставьте между bsf/bcf

Re: Сложности с управлением gp1

Ср май 19, 2021 17:54:22

Не в полне понимаю почему gp1 сбрасывается.
Получается
1. Считали
000010
2. Модифицировали
000110
3. Записали в защелку

Проблема в нагрузке на проблемный пин и в скорости чтения/записи. Если на пин напрямую повесить светодиод, например, то с него будет читаться 0, а не выведенная в пин 1.
В современных ПИКах есть отдельный регистр защелки выхода LAT и запись в этот регистр отдельного бита не связана с чтением пинов. Читается защелка, а не пин.

Re: Сложности с управлением gp1

Ср май 19, 2021 19:31:54

Как решение буфер вывода - с ним проводятся изменения, а уже его содержимое затем выдается в порт.
8)

Re: Сложности с управлением gp1

Ср май 19, 2021 22:45:44

Проблема в нагрузке на проблемный пин и в скорости чтения/записи. Если на пин напрямую повесить светодиод, например, то с него будет читаться 0, а не выведенная в пин 1.

Времени предостаточно, аж 8uS до вызова bsf. Попробовал поставить пожтягивающий резастор по + питания. Не дало результата.

Добавлено after 2 minutes 39 seconds:
Использовать буфер не дает возможность по времени. Тайминги всего алгоритма сбиваются. nop ставить тоже пробовал. Странный глюк.

Добавлено after 12 minutes 24 seconds:
:facepalm: C GP5 таких проблем нет, все отлично вкл. когда нужно и выкл. когда нужно. Только мне нужен GP1 :(
А с GP0 тоже что и с GP1. С остальными таких проблем нет. Может это как-то связано с компаратором.

Re: Сложности с управлением gp1

Ср май 19, 2021 23:32:20

trojninalex писал(а):Попробовал поставить пожтягивающий резастор по + питания.
Зачем подтягивающий резистор ноге, которую настроили на выход ? :facepalm:
Вам нужно разгрузить эту ногу. В защёлку пишется значение, равное реальному уровню на ноге, а не то, которое вы записали когда-то там. И никакие тут НОПы не спасут ...

Re: Сложности с управлением gp1

Чт май 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

Re: Сложности с управлением gp1

Чт май 20, 2021 05:07:59

На ноге GP1 пропали....на ноге GP2 появились...

Приведите РЕАЛЬНУЮ схему. Без домыслов, как есть.

Re: Сложности с управлением gp1

Чт май 20, 2021 10:27:58

Возожно вопрос во взаимодействии с компаратором.
Стоит проверить режим отключения незадействованного аппаратного модуля.
8)
Я частенько вот такую вставку делаю:
Код:
; инициализация железа при первой подаче питания
;
hard_init
       clrwdt
       MOVLW 07h ; Set GP<2:0> to
       MOVWF CMCON ; digital IO

но именно в самом начале программы, а не в режиме "оперативного переназначения" выводов.
Да и без схемы и полного текста программы будет очередное "гадание"....
:roll:

Re: Сложности с управлением gp1

Чт май 20, 2021 16:55:51

trojninalex писал(а):контакты порта считываются уже на выходе пина, модифицируется и записывается в защелку

А Вам что написали :
Аlex писал(а):В защёлку пишется значение, равное реальному уровню на ноге, а не то, которое вы записали когда-то там.

Re: Сложности с управлением gp1

Вс май 23, 2021 14:47:29

В данный момент контроллер подключен к логическому анализатору.

Добавлено after 1 minute 54 seconds:
Alex
Я рад что мы смогли убедиться, что понимаем одинакого, как работает порт на 12f629. Теперь можем перейти к решению самого вопроса.

Re: Сложности с управлением gp1

Вс май 30, 2021 13:51:59

Эксперименты продолжаются.
Решил по ножкам сделать внутренюб подтяжку
Установки следующие
Trisio = 0x3f
nGPPU = 0
CmCON = 7
WPU (по умолчанию равен 3f)

Подтяжка появилась на всех ножках кооме gp0 и gp1.

Пробовал на нескольких чипах. Результат тот же.

И вопрос по выходу так же не решен.

Re: Сложности с управлением gp1

Вс май 30, 2021 21:33:18

Изображение

Re: Сложности с управлением gp1

Пн май 31, 2021 06:33:30

Screenshot_1.jpg
(81.07 KiB) Скачиваний: 128

У ТС PIC12F629, а CMCON он настраивает.

Re: Сложности с управлением gp1

Пн май 31, 2021 09:46:09

О-о-опс, недосмотрел, недочитал.

Извините.
Ответить