Elliotba ágyazva: Lin a hackerek

egy autó egy gördülő halom több száz microcontroller-ek ezekben a napokban – csak kérdezzen semmilyen Greybeard mechanikusnak, és elkezdi a “karburátor” rantot. Mindezek a rendszerek és alrendszerek kell beszélni egymással egy elektromosan ellenséges környezetben, és nem túlzás azt mondani, hogy a hibás kommunikáció, vagy akár késleltetett kommunikáció is jelentős következményekkel járhat. Az autós hálózatban a nagyobb üzlet. Mass production of automobiles makes numerous of the relevant transceiver ICs low-cost for the non-automotive hardware hacker. Tehát miért nem látunk sokkal több hacker projektet, amelyek kihasználják ezt a figyelemre méltó erőforrás-bázist?

Az autó hálózatának gerincét a vezérlőterület hálózat (CAN). Hackaday’s own [Eric Evenchick] is a car-hacker extraordinaire, and wrote up many everything you’d want to know about the CAN bus in a multipart series that you’ll certainly want to bookmark for reading later. A motor, a fékek, az ajtók és az összes műszeres adatérték (differenciál). Gyors és nagy megbízhatóság. Ez is bonyolult és egy kicsit drága megvalósítás.

In the late 1990, numerous producers had their own proprietary bus protocols running alongside CAN for the non-critical parts of the automotive network: how a door-mounted console talks to the door-lock chauffeur and window motors, for instance. Nem érdemes megragadni a legfontosabb buszokat, amelyek nem kritikus és helyi kommunikációval rendelkeznek, így az alhálózatok a fő lehet. These didn’t need the speed or reliability guarantees of the main network, and for cost reasons they had to be easy to implement. A legkisebb mikrokontrollernek elegendő ahhoz, hogy felfelé és lefelé gördüljön, ugye?

A 2000-es évek elején a helyi összekapcsolódási hálózat (LIN) specifikáció szabványosította az egyik módszert ezeknek az alhálózatoknak, amely az egy mester mikrokontroller és egy kis számú rabszolgák közötti kommunikáció alacsony költségének, közepes sebességének, újrakonfigurálhatóságának és kiszámítható viselkedésének koncentrációja klaszter. Olcsó, egyszerű, megvalósítható kis mikrokontrollerek, és csak a médiumi projektekhez? Hacker álma! Miért nem használja a Lin-t a többszörös mikrohi projektekben? Nézzük meg, és láthatjuk, hogy ez hasznos-e az Ön számára.

A LIN protokoll

A Lin “klaszter”, amely a helyi mini-hálózatot a zsargon hívja, egyetlen mester mikrokontrollerből és számos rabszolgából áll. LIN starts off as conventional 8N1 UART serial, typically at 19,200 Baud, and does away with one wire. Next, it adds a protocol that allows this single wire to be used as a bus, shared among multiple slaves. Ha megpróbálta a saját hálózati protokollját forgatni az egyszerű UART soros kommunikáció érdekében, akkor valami hasonló lin. Menjen el a specifikáció (PDF) másolatát, és olvassa el!

Every LIN transaction is fundamentally the same: the master sends a header that includes a protected identifier (PID), which specifies the task to be carried out. A feladatok lehetnek valami, mint a “Report Hőmérséklet-érzékelő 2” vagy “SET SERVO 3 pozíció”. A feladattól függően egy és nyolc bájt között követik, két byte checksummal. A rabszolgáknak tudniuk kell, hogy mely feladatokra válaszolnak, és hogyan kell válaszolni. Tehát ha “SET SERVO 3 POSITION” kerül elküldésre kerül, akkor a szervo 3 rabszolga meg kell hallgatnia a következő bájtokat, és ennek megfelelően reagál. All slaves that don’t respond to the command can disregard data until the next preamble.

In the case of “report temperature sensor 2”, the slave with the temperature sensor sends its data right away after receiving the command. because the byte length is known in advance, and only sensor 2 is allowed to respond to this task, the master knows to listen for exactly, say, four bytes in reaction and knows how long that ought to take.

This polling system with the master sending headers and the slaves sending reactions guarantees that none of the devices will access the bus at the same time, so LIN gets by with just a single RX/TX line. The preamble includes a sync byte (0x55) that helps the slaves lock on to the master clock, so the slaves can run on less expensive RC clock sources and auto-bauding is possible.

Since the length of messages is known ahead of time, the timing for the master’s polling routine can be written down in a schedule. The master polls the network at defined intervals, and if the slave doesn’t respond within 1.4 times the required time for the transaction, it’s presumed to be missing in action. Either way, the master is on to the next item in its schedule, and won’t retry the potentially defective slave until its turn comes around again. This guarantees a known update rate for all of the devices, which makes life a lot simpler for programming the master.

Those are the basics. The master sends PIDs, and a series of data bytes follows. Everything’s comfy old UART, call and response, adapted as simply as possible to create a small network.

Extras

GUI LIN configuration app from an instructive video.
Keeping the network that easy requires that the master and slaves all agree on the command set and valid reaction lengths. That’s a lot of information needed for the LIN cluster to function, in principle. helping matters out somewhat, there’s a conventional format for notating all of this laid out in the LIN spec.

There’s also a conventional API for C that both the master and slave microcontrollers can use to make handling coding up behavior in a LIN cluster. Combined, this makes a conventional workflow for specifying and implementing LIN busses — very useful for the automakers, and not useless for the hacker either.

There is also a sleep state and behavior that’s defined for the bus, with associated sleep and wakeup signals. all of the slaves ought to respond to the sleep signal, and any of them ought to automatically go to sleep after a timeout of four seconds if they haven’t heard from the master. any node, slave or master, can send the wakeup command, and after that the master ought to go back to its normal polling schedule.

LIN version 2.0 included a number of optional frame types that make the network much more flexible. In particular, “sporadic frames” make the slave’s reaction optional if it hasn’t gotten any new data because the last update. “Event triggered frames” are like sporadic frames, except they can be additionally responded to by any slave node that has new data.

This introduces the possibility of a collision on the bus, in which case hopefully the checksum doesn’t add up and the master falls back to slave-specific frames as before. These two modes speed up the bus when data updates are infrequent, but add some indeterminacy to the schedule and conditional complexity to the code. use them only if you need them.

The master can also have multiple schedules, and switch among them. The slaves don’t care — they just listen for the tasks that are relevant to them anyway. There’s no reason for the master to send servo position data every period if it hasn’t changed, for instance, even if it makes things conceptually simpler. Hívásod.

There is even an optional carry layer spec that is compatible with CAN bus and makes it simpler to integrate the local LIN cluster with the bigger network. In short, LIN is a very thoroughly thought through UART bus protocol with good industry adoption. You’ll find good tutorials from every vendor of LIN transceiver hardware. (Here’s a terrific intro from national Instruments.)

Hardware — The Physical Layer

Topping all of this protocol niceness off is a broad variety of LIN transceiver chips ranging from $0.25 to $0.50 for plain transceivers, on up to around a buck or two for “system basis” chips with integrated voltage regulators. These are especially slick, because the transceiver can take care of the sleep/wake logic and turn the power supply to your microcontroller on and off. This makes integrating a slave node that operates at 3.3 V very simple.

Little chip purchases you a lot.
Since the LIN bus is developed for automotive, it’s typically specced for 12 V because that’s what courses through the veins of your car’s wiring harness. LIN transceiver hardware needs to be able to accommodate even higher voltages, because automobile electrical systems can be spiky environments. They also have to cope with bus contention, when the transceiver chip may be trying to pull the LIN line down while someone else is trying to pull it up, so there’s overheating protection built in as well. LIN transceivers are robust little beasties.

In contrast to I2C lines, which are pulled up with puny resistors, an automotive LIN bus is pulled up to 12 V with a 1 kΩ resistor. To pull this line down fast enough, LIN transceivers need to be able to conduct tens of milliamps, so they have slightly beefy (for ICs) transistors built in. The combination of a high voltage and relatively high line current implies that an automotive-spec LIN bus is good for 40 meters, rather than the couple meters that I2C gives you without resorting to drivers. If you need the distance or the noise immunity, LIN is there for you.

But nothing forces you to run your bus at 12 V, even the transceiver hardware. The Microchip transceivers that I’ve seen run down to 5.5 V, while the ones from NXP and Melexis run down at an Arduino-compatible 5 V.

And nothing forces you to use transceiver hardware at all! You could simply connect a PNP transistor (or P-channel MOSFET) to the bus line and drive that with the UART TX, sampling the bus with the RX line. This has the drawback of local echo, but that could be handled in software. Or, with only a few much more parts, there’s this service that we’ve seen before. I couldn’t find any hacker projects implementing LIN transceivers from scratch, though. maybe that’s because the industrial ones are just so cheap.

Erősségeit és gyengeségeit

No bus is ideal for all occasions, and LIN is no exception. LIN is not particularly fast, being developed around 19,200 baud UART. A frissítések meglehetősen ritkán vannak, a mikrokontroller perspektívájából. Teljes hosszúságú tranzakció, időtúllépéssel, tíz milliszekundumot vesz igénybe. Ha a mester szavazon tizenhat eszköz, ez egy frissítési sebessége körülbelül hét hertz legrosszabb esetben. Természetesen a mester minden alkalommal nem szavazott minden eszközre, és számos alkalommal az üzenetek fél hosszúak, de nem fog több, mint 200 Hz. Másrészt a frissítési ráta állandó, mivel a pelyhességi eszközök feszes időtúllépésének végrehajtása, amely rémülten a megbízhatóság és az egyszerűség, és ez nem olyan sokkal lassabb, mint az I2C.

A Vadon, 1.x és 2.x-ben két fő változat van. In addition to the optional frame types discussed above, the two versions have different checksum formulas — and the one in 2.x is really bizarre — necessitating a web-based calculator to make sure you’re doing it right. A kiegészítő mod-256 helyett 255-et kivonnak a 256 vagy annál nagyobb értéktől. Olyan, mint egy 8 bites túlcsordulás, amely a 0 helyett 1-re van kötve.

LIN devices aren’t as prevalent outside the automotive industry as I2C or SPI, by a long shot, so you’ve probably never been forced to deal with the protocol. De ha egy kis számú mikrokontroller-alapú modulot szeretnél, olyan könnyen és olcsón, csak egy vezetékes (plusz földön), nehéz könnyebb gondolkodni. Az I2C slave kód írása biztosan nem piknik. írási kódot hallgatni egy adott bájt egy UART vonalon, majd reagálhat, nem lehet egyszerűbb.

Szeretné fordítani a sima-vanília uart egy buszra? Vegyünk egy oldalt vagy kettőt a Lin könyvből! már csináltál már? Mutasd meg nekünk!

Leave a Reply

Your email address will not be published. Required fields are marked *

Related Post

Technikai ajánlatok: 45% kedvezmény a Samsung 4K TV -nek, Bluetooth fejhallgatónak, WWE 2K16 a PS4/Xbox One -hoz, még többTechnikai ajánlatok: 45% kedvezmény a Samsung 4K TV -nek, Bluetooth fejhallgatónak, WWE 2K16 a PS4/Xbox One -hoz, még több

A hétvége, valamint ez azt jelenti A pihenési idő távol a munkától vagy az irodától, valamint talán egy kicsit elrontja magunkat azáltal, hogy néhány ínycsiklandó technológiai terméknél diszkontrátákat használ fel.