collapse

* Posts Recentes

Transmissão de energia sem fios por dropes
[Hoje às 13:09]


MINI560 - corrente sem carga? por KammutierSpule
[14 de Maio de 2024, 15:09]


Arame de Estendal por SerraCabo
[11 de Maio de 2024, 14:15]


Meu novo robô por josecarlos
[11 de Maio de 2024, 10:52]


LLM Crawlers por TigPT
[04 de Maio de 2024, 21:40]


Emulador NES em ESP32 por dropes
[04 de Maio de 2024, 14:48]


Circuito Microfone que funcione por almamater
[27 de Abril de 2024, 17:14]


O que é isto ? por SerraCabo
[12 de Abril de 2024, 14:20]


Amplificador - Rockboard HA 1 In-Ear por almamater
[11 de Abril de 2024, 20:46]


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

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

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

Offline SerraCabo

  • Mini Robot
  • *
  • Mensagens: 1.054
    • 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.054
    • 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.