エンベデッド・ペリフェラルIPユーザーガイド

ID 683130
日付 9/21/2020
Public
ドキュメント目次
1. 概要 2. Avalon® -ST Multi-Channel Shared Memory FIFOコア 3. Avalon® -STシングルクロックFIFOコアおよびデュアルクロックFIFOコア 4. Avalon® -STシリアル・ペリフェラル・インターフェイス・コア 5. SPIコア 6. SPI Slave to Avalon® Master Bridgeコア/JTAG to Avalon® Master Bridgeコア 7. インテル eSPIスレーブコア 8. eSPI to LPCブリッジコア 9. イーサネットMDIOコア 10. インテルFPGA 16550互換UARTコア 11. UARTコア 12. JTAG UARTコア 13. インテル FPGA Avalon® Mailboxコア 14. インテル FPGA Avalon® ミューテックス・コア 15. インテル FPGA Avalon® I2C (Master) コア 16. インテル FPGA I2C Slave to Avalon® -MM Master Bridgeコア 17. インテルFPGA Avalon® コンパクト・フラッシュ・コア 18. EPCS/EPCQAシリアル・フラッシュ・コントローラー・コア 19. インテルFPGAシリアル・フラッシュ・コントローラー・コア 20. インテルFPGAシリアル・フラッシュ・コントローラーIIコア 21. インテルFPGA汎用クアッドSPIコントローラー・コア 22. インテルFPGA汎用クアッドSPIコントローラーIIコア 23. インターバル・タイマー・コア 24. インテルFPGA Avalon FIFOメモリーコア 25. オンチップメモリー (RAMおよびROM) コア 26. Optrex 16207 LCDコントローラー・コア 27. PIOコア 28. PLLコア 29. DMAコントローラー・コア 30. Modular Scatter-Gather DMAコア 31. Scatter-Gather DMAコントローラー・コア 32. SDRAMコントローラー・コア 33. トライステートSDRAMコア 34. Video Sync GeneratorコアとPixel Converterコア 35. インテル FPGA Interrupt Latency Counterコア 36. パフォーマンス・カウンター・ユニット・コア 37. ベクトル割り込みコントローラー・コア 38. Avalon® -STデータ・パターン・ジェネレーター・コアとデータ・パターン・チェッカー・コア 39. Avalon® -STテスト・パターン・ジェネレーター・コアとテスト・パターン・チェッカー・コア 40. システムIDペリフェラル・コア 41. Avalon® Packets to Transactions Converterコア 42. Avalon® -STマルチプレクサー・コアとデマルチプレクサー・コア 43. Avalon® -ST Bytes to Packets ConverterコアとPackets to Bytes Converterコア 44. Avalon® -ST Delayコア 45. Avalon® -STラウンド・ロビン・スケジューラー・コア 46. Avalon® -ST Splitterコア 47. Avalon® -MM DDR Memory Half Rate Bridgeコア 48. インテル FPGA GMII to RGMIIコンバーター・コア 49. インテル FPGA MII to RMIIコンバーター・コア 50. インテルFPGA HPS GMII to TSE 1000BASE-X/SGMII PCSブリッジコア 51. インテル FPGA HPS EMAC to Multi-rate PHY GMIIアダプターコア 52. インテル FPGA MSI to GICジェネレーター・コア

7.1.2. トランザクション・レイヤー

トランザクション・レイヤーのRXシフターブロックは、リンクレイヤーからパラレル・データ・バスを取得します。これにより、ヘッダー、データ、ステータスなどのeSPIトランザクションのフィールドを識別し、それをCommand Detectorブロックに送信してデコードを行います。送信側では、Response GeneratorブロックでeSPIトランザクションに関する情報を収集します。その後、TXシフターブロックはフィールド順序に従いトランザクションをリンクレイヤーに送信します。

また、トランザクション・レイヤーにはエラーの検出および処理ブロックが含まれています。エラー訂正機能やハードウェア回復メカニズムはeSPIバスに定義されていません。eSPIスレーブコアは、eSPIバスで検出されたエラーを次のように分類して処理します。
表 21.  エラーの検出と処理におけるカテゴリー
エラー状態 eSPIスレーブコアの応答と処理
無効なコマンドオペコード コマンドは破棄されます。eSPIスレーブコアは、NO_RESPONSEオペコードで応答します。
無効なサイクルタイプ コマンドは破棄されます。eSPIスレーブコアは、NO_RESPONSEオペコードで応答します。
コマンドフェーズのCRCエラー コマンドは破棄されます。eSPIスレーブコアは、NO_RESPONSEオペコードで応答します。
予期しないespi_cs_nのデアサート eSPIスレーブコアは、espi_cs_nがデアサートされた後にデータバスをトライステートにし、tSHQZの規則に従います。また、CRCチェックが有効になっている場合にのみ、応答フェーズでCRCエラーをトリガーします。
プロトコルエラー
  • FREEのないPUT
  • AVAILABLEのないGET
コマンドは破棄されます。eSPIスレーブコアはFATAL_ERRORオペコードで応答します。
コマンドフェーズ時の不正な形式のパケット
  • ペリフェラル・チャネル
    • ペイロード長 > 最大ペイロードサイズ
    • 読み出し要求サイズ > 最大読み出し要求サイズ
    • (アドレス + 長さ) > 4Kb
  • 仮想ワイヤーチャネル
    • カウント > 最大仮想ワイヤーカウント
コマンドは破棄されます。eSPIスレーブコアは、FATAL_ERRORオペコードで応答します。
ポート00hからポート100hPC_CHANNEL IO SHORTコマンドのみをサポートしている場合に、マスターがIO READ/WRITE SHORTコマンドを発行して00hから100h以外にアドレス指定している コマンドは破棄されます。eSPIスレーブコアは、NON_FATAL_ERRORオペコードで応答します。
エラー検出および処理ブロックのほかに、CRC-8ジェネレーター・ブロックにより、eSPIトランザクション・パケットを保護しています。コマンドフェーズと応答フェーズには、それぞれのCRCバイトが含まれます。コマンドフェーズの場合、CRC計算にはコマンドフェーズ中のすべてのバイトが含まれます (コマンドオペコード、ヘッダー、データなど)。応答フェーズの場合、CRC計算には応答フェーズ中のすべてのバイトが含まれます (WAIT_STATEを除く応答オペコード、ヘッダー、データ、ステータスなど)。CRCチェックはデフォルトで無効になっています。CRCチェックを有効にするには、SET_CONFIGURATIONコマンドを使用してCRC Checking Enableビットを有効にします。