collapse

* Posts Recentes

Amplificador - Rockboard HA 1 In-Ear por almamater
[Ontem às 19:13]


O que é isto ? por KammutierSpule
[26 de Março de 2024, 19:35]


Bateria - Portátil por almamater
[25 de Março de 2024, 22:14]


Emulador NES em ESP32 por dropes
[13 de Março de 2024, 21:19]


Escolher Osciloscópio por jm_araujo
[06 de Fevereiro de 2024, 23:07]


TP4056 - Dúvida por dropes
[31 de Janeiro de 2024, 14:13]


Leitura de dados por Porta Serie por jm_araujo
[22 de Janeiro de 2024, 14:00]


Distancia Cabo por jm_araujo
[08 de Janeiro de 2024, 16:30]


Meu novo robô por josecarlos
[06 de Janeiro de 2024, 16:46]


Laser Engraver - Alguém tem? por almamater
[16 de Dezembro de 2023, 14:23]

Autor Tópico: Glitch em linha I2C  (Lida 4005 vezes)

0 Membros e 1 Visitante estão a ver este tópico.

Offline SerraCabo

  • Mini Robot
  • *
  • Mensagens: 1.051
    • Serra Cabo
Glitch em linha I2C
« em: 17 de Fevereiro de 2021, 01:43 »
... só por curiosidade...

Olá.

Estava aqui a vasculhar umas linhas de controlo para tentar perceber quanto a comunicação I2C atravanca o controlador (ATmega 2560 a 16MHz) e deparei com uma coisa curiosa.

Reparem (olhem em baixo) no último bit antes de ACK aparece um glitch na linhas D5. Não aparece sempre (ou não é 'agarrado') mas aparece pelo menos 50% das vezes. Quando aparece, aparece nesse local.



O clock D4 trabalha a 100KHz e a frequência de amostragem está a 8MHz.

Não estou preocupado com isto porque, de uma forma ou outra, o LCD está a funcionar bem.

Outra coisa curiosa: não estava à espera que ele enviasse um byte de cada vez. Estava à espera que houvesse um cabeçalho e despachasse uma molhada de caracteres. Eu suponho que esta comunicação seja unidireccional.

Já agora, este "Logic Analyzer" que trabalha (diz ele) até 24MHz, tem um preço muito acessível e é particularmente útil. O software é o PulseView.

Abraço
SC

Offline SerraCabo

  • Mini Robot
  • *
  • Mensagens: 1.051
    • Serra Cabo
Re: Glitch em linha I2C
« Responder #1 em: 17 de Fevereiro de 2021, 16:24 »
Já percebi por que aparece o glitch. Dá-se quando o master (controlador) larga a linha de dados (vai passar a receptor). A linha vai para HI (haverá um pull-up qualquer) para que o slave (o LCD), possa colocar a linha a LOW indicando ao master que os dados foram lidos.

Agora, há outra coisa que eu não esperava. Se não houver resposta do slave (desligando, por exemplo a linha de dados), o controlador fica pendurado.