Elliot:LINはハッカーのためのものです

最近のgreybeardメカニックであるgreybeardメカニックを尋ねるだけで、彼の「キャブレター」ラントを始めてください。これらのシステムとサブシステムの全ては、電気的に敵対的な環境で互いに話す必要があり、誤解、または遅延通信さえも大きな結果を得ることができるという誇張ではありません。車のネットワーキングは主要な事業です。自動車の大量生産は、非自動車用ハードウェアハッカーのための関連するトランシーバICS低コストを多数する。それでは、この驚くべきリソースベースを活用するより多くのハッカープロジェクトを見るのはなぜですか?

自動車のネットワークのバックボーンは、コントローラエリアネットワーク(CAN)です。 Hackaday自身の[Eric Imechick]は、カーハッカーの臨時調整業者で、あなたが後で読むためにブックマークしたいマルチパートシリーズのCANバスについて知っておくべき多くのすべてを書きました。エンジン、ブレーキ、ドア、およびすべての計装データレビュー(差動)レビュー速くて高い信頼性です。それはまた複雑で実装するのが少し高価です。

1990年後半に、多数の生産者は、自動車ネットワークの非臨界部品のために缶と走る独自の独自のバスプロトコルを持っていました。それはそのようなクリティカルでローカルコミュニケーションのメインのCANバスを散らす価値がないので、サブネットワークはメイン缶から減速されました。これらはメインネットワークのスピードまたは信頼性の保証を必要とせず、そして費用の理由から、それらが実装が容易でなければならなかった。最小のマイクロコントローラは、窓を上下に転がすのに十分であるべきですね。

2000年代初頭では、ローカルインターコネクトネットワーク(LIN)仕様はこれらのサブネットワークに1つの方法を標準化し、1つのマスターマイクロコントローラと少数のスレーブの間の通信のための低コスト、中速、再構成、および予測可能な動作に焦点を合わせて、クラスタ安く、シンプルで、小型のマイクロコントローラで実装可能、そして中規模のプロジェクトに最適ですか?ハッカーの夢!なぜあなたはあなたの複数マイクロプロジェクトでLinを使っていないのですか?掘り下げましょう。

LINプロトコル

LIN「クラスター」が、標準的なミニネットワークがJargonで呼び出されたもので、単一のマスターマイクロコントローラと数のスレーブで構成されています。 LINは通常19,200ボーで、従来の8N1 UARTシリアルとして始まり、1つのワイヤで離れています。次に、このシングルワイヤを複数のスレーブ間で共有するバスとして使用できるプロトコルを追加します。簡単なUARTシリアル通信のために独自のネットワークプロトコルをロールロールしようとした場合は、Linのようなものになりました。仕様書(PDF)のコピーを取得して読んでください。

すべてのLINトランザクションは基本的に同じです。マスターは、実行されるタスクを指定する保護された識別子(PID)を含むヘッダーを送信します。タスクは、「レポート温度センサ2」または「サーボ3位置の設定」のようなものにすることができます。タスクによっては、1バイトのチェックサムで、1~8バイトのデータが続きます。スレーブは、どのタスクが対応するか、およびどのように対応するかを知る必要があります。したがって、「サーボ3位置を設定する」が送信された場合、サーボ3スレーブは次のバイトを聴き、それに応じて反応する必要があります。コマンドに応答しないすべてのスレーブは、次のプリアンブルまでデータを無視できます。

「レポート温度センサ2」の場合、コマンドを受信した直後に温度センサを有するスレーブがそのデータを送信する。バイト長は事前に知られており、センサ2のみがこのタスクに応答することが許可されているため、マスターは正確に、つまり反応の4バイトを聞くことを知っており、それがどのくらいの時間を知っています。

マスター送信ヘッダーとスレーブ送信反応を持つこのポーリングシステムは、どのデバイスも同時にバスにアクセスしないことを保証します。プリアンブルには、スレーブがマスタークロックにロックするのに役立つ同期バイト(0x55)が含まれているため、スレーブはより安価なRCクロックソースで動作し、自動搭載が可能です。

メッセージの長さが前もって知られているので、マスターのポーリングルーチンのタイミングをスケジュールで書き留めることができます。マスターはネットワークを定義された間隔でポーリングし、スレーブがトランザクションに必要な時間の1.4倍以内に応答しない場合は、アクションが欠落していると推定されます。どちらの方法でも、マスターはそのスケジュールの次の項目に進み、そのターンが再び歩き回るまで潜在的に欠陥のあるスレーブを再試行しません。これにより、すべてのデバイスのアップデートレートが保証されており、ライフはマスターをプログラミングするためにLOLが簡単になります。

それらは基本です。マスターはPIDSを送信し、一連のデータバイトが続きます。小さなネットワークを作成するためにできるだけ簡単に適応された、すべてのComfy Old UART、呼び出しと応答。

extr

Interalive ViからのGUI LIN設定アプリデオ。
簡単にネットワークを維持するには、マスターとスレーブがすべてコマンドセットと有効な反応長を同意することを要求しています。これは、原則としてLINクラスタが機能するのに必要な情報の多くです。やや問題を解決するのを助けてください。

C用の従来のAPIは、Masterマイクロコントローラとスレーブマイクロコントローラの両方がLINクラスタ内の符号化動作を処理するために使用できることもあります。組み合わされた、これは、LINバスを特定して実装するための従来のワークフローを作ります – 自動車メーカーにとって非常に有用であり、ハッカーのためには役に立たない。

関連するスリープ信号とウェイクアップ信号を使用して、バスに定義されている睡眠状態と動作もあります。すべてのスレーブはスリープ信号に応答する必要があり、それらがマスターから聞いたことがない場合は4秒のタイムアウト後に自動的にスリープ状態になる必要があります。ノード、スレーブまたはマスターは、wakeupコマンドを送信できます。その後、マスターが通常のポーリングスケジュールに戻るべきです。

LINバージョン2.0には、ネットワークをはるかに柔軟にするオプションのフレームタイプがいくつか含まれていました。特に、「散発的なフレーム」は、最後の更新で新しいデータを取得していない場合は、スレーブの反応をオプションにします。 「イベントトリガフレーム」は、新しいデータを持つ任意のスレーブノードによって追加的に応答できることを除いて、散発性フレームのようなものです。

これにより、バス上の衝突の可能性が紹介され、その場合、チェックサムが追加されず、マスターは以前と同じようにスレーブ固有のフレームに戻ります。これら2つのモードは、データの更新がまれであるときにバスを高速化しますが、コードにスケジュールと条件付きの複雑さにいくつかの不確定性を追加します。必要な場合にのみ使用してください。

マスターには複数のスケジュールを持ち、それらの間で切り替えることもできます。スレーブは気にしない – 彼らはとにかく彼らに関連するタスクを聞くだけです。たとえそれが物事を概念的により単純にする場合でも、それが変更されていない場合は、マスターが変更されていない場合はその期間ごとにサーボ位置データを送信する理由はありません。あなたの電話

CANバスと互換性のあるオプションのキャリーレイヤースペックさえも、ローカルLINクラスタをより大きなネットワークと統合するのが簡単になります。つまり、LINは、業界が優れているUARTバスプロトコルを介して非常に徹底的に考えられています。 LINトランシーバハードウェアのすべてのベンダーから良いチュートリアルがあります。 (これはナショナルインスツルメンツからの素晴らしいイントロです。)

ハードウェア – 物理層

このプロトコルのすべてを最上位にすると、普通のトランシーバの範囲で0.25ドルから0.50ドルの範囲の広範なLINトランシーバチップが、電圧レギュレータを内蔵した「システムベース」チップのための昇降圧または2つの範囲です。トランシーバはスリープ/ウェイクロジックの世話をすることができ、電源をマイクロコントローラのオン/オフにすることができるため、これらは特にスリックです。これにより、3.3 Vで動作するスレーブノードを非常に簡単に統合できます。

リトルチップはあなたをたくさん購入します。
LINバスは自動車用に開発されているので、それは通常あなたの車のワイヤーハーネスの静脈を通っているのかという理由から、通常12 vに隠されています。自動車の電気システムはスパイキー環境である可能性があるため、LINトランシーバハードウェアはさらに高い電圧を収容できる必要があります。他の誰かがそれを引き上げようとしている間、トランシーバチップがLINラインを引き下げようとしている可能性がある場合、バスの競合に対処する必要があります。 LINトランシーバは堅牢な小さな獣です。

パンジー抵抗でプルアップされているI2Cラインとは対照的に、自動車のLINバスは1kΩの抵抗で12 Vまでプルアップされます。このラインを十分に速く引き下げるには、LINトランシーバは数ミリアンペアを実行できる必要があります。 LINバスは、i2cが運転手に頼ることなくあなたに与えるカップルメートルではなく、40メートルで良いです。距離やノイズの免疫が必要な場合は、LINはあなたのためにあります。

しかし、トランシーバのハードウェアでさえ、12 Vでバスを実行することは何もありません。私が見たマイクロチップトランシーバは5.5 Vまで、NXPとMelexisのものはArduino対応の5 Vで停止します。

そして、トランシーバハードウェアをまったく使用することはありません。 PNPトランジスタ(またはPチャネルMOSFET)をバスラインに接続し、UART TXを使用してRXラインでバスをサンプリングするだけで駆動することができます。これは地元のエコーの欠点を持っていますが、それはソフトウェアで処理される可能性があります。または、ほんの数部の部品だけで、私たちが前に見たサービスがあります。ただし、rinトランシーバを実装するハッカープロジェクトが見つかりませんでした。たぶんそれは産業のものがとても安いのでそうです。

強みと弱み

すべての機会にはバスは理想的であり、Linは例外ではありません。 Linは特に速くはありませんが、19,200のボーのUAR頃に開発されていますT.アップデートは、マイクロコントローラの視点から、かなりめったにかなり来ています。タイムアウトを伴うフルレングストランザクションは、約10ミリ秒かかります。マスターが16個のデバイスをポーリングした場合、それは7つのHertz最悪の場合の更新率です。もちろん、マスターは毎回すべてのデバイスを投与する必要はなく、メッセージがその長さの半分になるでしょうが、あなたは200 Hz以上になるつもりはありません。一方、フレークされたデバイスにタイトタイムアウトを実行する能力のために、更新率は一定であり、信頼性と単純さにとっては素晴らしいものであり、I2Cよりもはるかに遅くはありません。

野生、1.x、2.xで見ることができる林の2つの主なバージョンがあります。上記のオプションのフレームタイプに加えて、2つのバージョンは異なるチェックサム式を持ち、2.xの1つは本当に奇妙です – Webベースの電卓はそれを正しくしていることを確認します。追加MOD-256の代わりに、それらは256以上の任意の値から255を減算します。それは0の代わりに1に折り返す8ビットのオーバーフローのようです。これはあなたのために意味がありますか?

LINデバイスは、Long Shootによって、I2CまたはSPIのように自動車産業の外側に普及していないため、おそらくプロトコルに対処することは決して強制されませんでした。しかし、少数のマイクロコントローラベースのモジュールをできるだけ簡単にネットワークアップしたい場合は、1ワイヤ(プラスグラウンド)を使用して、何も簡単に考えるのは難しいです。 I2Cスレーブコードの書き込みは確かにピクニックではありません。 UARTラインで特定のバイトをリッスンするコードを書くと、反応することはできませんでした。

プレーンバニラUARTをバスに変えたいですか? Lin Bookからページまたは2つを取り出してください。あなたはもうすでにやったことがありますか?私たちに見せてください!

Leave a Reply

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

Related Post

Ghetto Electronics RepairGhetto Electronics Repair

彼のビデオカードがそれをリフローするためにそれを加熱することによって修理可能であるかもしれないことを聞いた後、このユーザーはそれだけでした。 彼はそれを剥がして彼のオーブンに投げました。 このタイプのハッキングの修理がどのように機能するかは驚くべきことです。 私たちはiBooks上のキャンドルを使って、オーブンのビデオカードを投げ、Xbox 360をタオルで包み、30分間走っているのを聞いたことがあります。 制御された温度と正確な測定でさえ邪魔されたのはなぜですか? 他にどんなクレイジーな修正を採用しなければなりませんか? 私たちは逆さまにしか働くプレイステーションをしました。 [介してEngadget]

2017 iPad Pro Designs機能4GBのRAM2017 iPad Pro Designs機能4GBのRAM

は、10.5インチiPad Pro vs 2017 12.9インチiPad Pro vs 9.7インチiPad Pro vs 2015 12.9インチiPad Pro RAM比較です。 Appleの新しい10.5インチiPad Proと改良された12.9インチiPad Proは、世界中の店舗に現れ始めました。クパチーノから。より大きな画面がありますが、非常に大きな割合で、新しい10.5インチiPad Proは多くの人々のために多くのボックスをチェックします。また、同様に多くのRAMがあることが判明しました。 Geekbenchテストによって作成されたスコアによると、デバイスで実行される新しい10.5インチiPad Proは、4GBのメモリをパックします。 同様に、最新の12.9インチiPad Proには4GBの完全なRAMが含まれていますが、以前の設計では3GBを使用する必要がありました。 9.7インチのiPad Proについて信じられているAをspareしみます。なぜなら、たった2GBのメモリを持っている人が電話をかけるために、自分で電話をかけることができるからです。予想通り、A10x CPUと4GBのRAMがこのものが詰め込まれていることを提供すると、ベンチマークスコアに関しては前かがみではありません。シングルコアでは3915のオタクベンチスコア、およびマルチコアテストの9387は印象的であり、新しいiPad Proを持ち込む人がタスクで解約する能力に喜んでいるという少しの質問があります。 iOS 11のマルチタスクに新たに焦点を当て、その周りに追加の能力が発生したため、Appleは、バターのような滑らかな体験を可能にするために、ハイエンドのiPadに提供されるメモリの量を増やしたようです。 Appleは以前、ガジェットにRAM部門で必要なうなり声を提供することに関してスキップしたと非難されていたため、この動きは間違いなく歓迎されています。 10.5インチiPad

Veronica 6502コンピュータがHi World StageVeronica 6502コンピュータがHi World Stage

最高のショーのスクリーンショット[Quinn Dunki’s]コンピュータプロジェクトは、こんにちは世界プログラムを表示しています。さて、それは今ここで最高の言葉を示すだけですが、その概念は同じです。これは、ネイティブ6502コードがプロセッサ上で実行されていること、およびそのVGAハードウェアを介してデータを確実に出力していることが証明されています。それは、このプロジェクトに多くの仕事を見た後の歓迎の達成です。 しかし、この複雑なものでは、バグを見つけることなく進歩することは期待できません。そして旅のこのステップは[Quinn]のために店でかなり大きいものを持っていました。アセンブリコードを書いてそれをそれを装置にロードした後、彼女は却下されました。今、彼女はスクリーンショットを見せて、それはレース状態として簡単に認識可能です – 彼女は私たちよりも大きな脳を持っていることを証明します。 問題は、同じAVRチップ(彼女が構築されたGPUの一部)で実行されている一対の無停電プロセスです。それらはプロセッササイクルの制御のために互いに闘っていて、彼女は上の画像の中で娘基板を見てそれを固定しています。 IDT7200L FIFO SRAMチップを使用して、その単一のAVRチップからタイムクリティカルプロセスの1つを移動します。