EtherCAT: A pure Elixir fieldbus protocol
Disclaimer: this is pre 1.0 and should therefore not be used in production yet
So what is EtherCAT?
It is just a fieldbus protocol (like Siemens Profinet, Modbus, etc.) with some interesting characteristics:
- runs on Ethernet
- allows all kinds of topology
- is “open”
- widely used in the industry
(If you want to learn more, this is a great introduction)
Since a quick demo tells more than a thousand words (and I forced myself to write this post without the help of AI
) here we go:
There are three Beckhoff IO modules:
- EK1100 which is a Bus Coupler (the device with the two LAN ports)
- EL1809 which is a 16-channel digital input terminal
- EL2809 which is a 16-channel digital output terminal
As you can see in the video, each output is directly connected to the corresponding input. So when I set output 1 high, input 1 should also get high.
As you can see the master discovers all slaves, configures them and it just works.
Really fascinating if you ask me, since there is happening quite a bit behind the scenes ![]()
Why I wrote this library (and with “I”, I mean Claude + Codex)
There are mainly two reasons:
- I would like to bring Nerves to the automation sector and make Nerves able to talk to reliable hardware.
- I wanted to go with the hype and test some vibe coding

And I have to say the tools are insane. I would have never been able to write this library without the help of AI. I took so many different approaches:
I started with ethercat_ex, a Nif implementation of IgH EtherCAT, figured out that writing a Nif is not so easy in bare C, and switched to a Zigler implementation igh_ethercat. At one point I wanted to test an Erlang port driver ( GitHub - jannikbecher/igh_ethercat_port · GitHub ).
It is crazy how fast I can test different ideas. But I was actually already quite happy with my Zigler igh_ethercat implementation and thinking on how to publish it. But something still stopped me. I wasn’t really confident that the “glueing” of C, Zig, and Elixir would work reliably enough. There were so many moving pieces and two weeks ago I was sitting on the couch and thinking:
“All my problems I want to solve with this are actually quite slow compared to what the IgH EtherCAT implementation is solving. Why don’t I just try to implement this in pure Elixir? It would definitely make me more relaxed not to use a Nif.”
So I just asked Claude what it thinks and it pretty much one-shotted me a working library. I still can’t believe it and yet we are here…
But I’m still ambivalent. On the one hand, these tools are great and are helping dumb people like me to try different ideas. On the other hand, I’m shipping code which is not written by me. Much of the code is not even reviewed yet and there will definitely be bugs. And I don’t like this trend of releasing “barely working software”, but here is my reasoning why I did it nonetheless:
- First of all, I created this library for an actual private use case and it seems to work really well. I don’t have problems with 10ms cycle times on a Rpi4 and I can even go down to 1ms. This is real-time servo control territory

- I would like to reach out to the community, because I think there is great value to pursue this idea in a more professional manner. I’m currently at the end of my apprenticeship as an automation technician and I would like to explore in which way soft-real-time devices have their place in the automation world. Since I would like to continue my electrical engineering studies, which I stopped a few years ago, I think this could be a great topic for a bachelor’s thesis. So if you know someone, feel free to reach out to me

I hope there are people here similarly excited as I am! Thank you all for building these great tools I can depend on ![]()























