1. 2種類のDMAマッピング 1.1. 一貫性のあるDMAマッピング 主に長期間使用されるエリアをマッピングするために使用されます。 CPU と DMA コントローラはキャッシュの影響を考慮する必要はありません。 ここでの一貫性は、実際にはコヒーレントの概念であり、保証することはできません。言い換えると、メモリの順序を保証するためにメモリバリアが必要です。 1.2 ストリーミングDMAマッピング 主に 1 回限りの DMA 転送に使用され、転送が完了すると解放されます。 2. DMAデバイスのアドレス範囲を指定する include/linux/dma-mapping.h // 一貫性のあるメモリマッピングのマッピング範囲 static inline int dma_set_coherent_mask(struct device *dev, u64 mask) // ストリーミング メモリ マッピングのマッピング範囲 static inline int dma_set_mask(struct device *dev, u64 mask); 3.DMAマッピングインターフェース 3.1 コヒーレントDMAインターフェース より大きなDMAバッファを割り当てる // dev DMA コントローラー デバイス // size 割り当てられる DMA バッファー サイズ // dma_handle は DMA バッファーの物理アドレスを返します // flag 割り当てフラグ // 戻り値 DMA バッファーの仮想アドレス void *dma_alloc_coherent(struct device *dev, size_t size, dma_addr_t *dma_handle, gfp_t flag) // dev DMAコントローラデバイス // size 解放されたDMAバッファのサイズ // cpu_addr DMAバッファの仮想アドレス // dma_handle DMAバッファの物理アドレス void dma_free_coherent(struct device *dev, size_t size, void *cpu_addr、dma_addr_t dma_handle) より小さい DMA バッファを割り当て、それを dma ポールから適用します。 /** * dma_pool_alloc - DMA ポーリングから一貫性のあるメモリのブロックを取得します * @pool: メモリ ブロックを生成する DMA プール * @mem_flags: GFP_* ビットマスク * @handle: メモリブロックのDMAアドレスを返します */ void *dma_pool_alloc(構造体dma_pool *pool, gfp_t mem_flags, dma_addr_t *ハンドル) /** * dma_pool_free - メモリを解放して DMA プールに戻す * @pool: メモリブロックを生成するDMAプール * @vaddr: メモリブロックの仮想アドレス* @dma: メモリブロックの物理アドレス*/ void dma_pool_free(構造体 dma_pool *pool、void *vaddr、dma_addr_t dma) 3.2 ストリーミング DMA インターフェイス // dev メモリをマップする必要があるデバイス // ptr マップされたバッファの仮想アドレス // size マップされたサイズ // dir 転送方向 // attr 属性 // 戻り値 dma 物理アドレス dma_addr_t dma_map_single_attrs(struct device *dev, void *ptr, size_t サイズ、 列挙型 dma_data_direction ディレクトリ、 符号なしロング属性) // dev メモリをマップする必要があるデバイス // addr DMA領域の物理アドレス // size マッピングのサイズ // dir 転送方向 // attr 属性 void dma_unmap_single_attrs(struct device *dev, dma_addr_t addr, size_t サイズ、 列挙型 dma_data_direction ディレクトリ、 符号なしロング属性) ページマッピング dma_addr_t dma_map_page(構造体デバイス*dev、構造体ページ*ページ、 size_t オフセット、size_t サイズ、 列挙型 dma_data_direction dir) void dma_unmap_page(構造体デバイス*dev、dma_addr_t addr、 size_t サイズ、列挙型 dma_data_direction dir) DMAマッピングエラーを返します // DMAマッピングエラーを返す int dma_mapping_error(struct device *dev, dma_addr_t dma_addr) マッピング散布リスト int dma_map_sg_attrs(構造体デバイス*dev、構造体スキャッターリスト*sg、 int nents、enum dma_data_direction dir、 符号なしロング属性) void dma_unmap_sg_attrs(構造体デバイス*dev、構造体スキャッターリスト*sg、 int nents、enum dma_data_direction dir、 符号なしロング属性) // マップ後の DMA アドレスと長さを返します sg_dma_address(struct scatterlist *sg) sg_dma_len(構造体スキャッターリスト *sg) 同期操作 void dma_sync_single_for_cpu(構造体デバイス*dev、dma_addr_t addr、 size_t サイズ、 列挙型 dma_data_direction dir) void dma_sync_single_for_device(構造体デバイス*dev, dma_addr_t アドレス、size_t サイズ、 列挙型 dma_data_direction dir) 空所 dma_sync_sg_for_cpu(構造体デバイス*dev、構造体スキャッターリスト*sg、 int nelems、enum dma_data_direction dir) 空所 dma_sync_sg_for_device(構造体デバイス*dev、構造体スキャッターリスト*sg、 int nelems、enum dma_data_direction dir) 以上が今回ご紹介した関連知識の全てです。追加事項がありましたら、123WORDPRESS.COM 編集部までご連絡ください。 以下もご興味があるかもしれません:
|
<<: mysql5.5.28 のインストール チュートリアルは非常に詳細です。
>>: MySQL 文字列連結と null 値の設定のためのインスタンス メソッド
フロートはWebページのレイアウトでよく使用されますが、フローティングブロックレベル要素は標準のドキ...
序文今日、MySQL をインストールしたところ、データベース ストレージがデフォルトで C ドライブ...
最も単純な hello world 出力イメージを作成することは最も簡単なスタートですが、実行中のコ...
序文最近、レポート機能に取り組んでいたのですが、ある月に各部署に入社した人と退職した人の数をカウント...
目次原理ネットワーク環境の準備インストール前の準備NIS サーバー操作NIS クライアント操作原理N...
Redisの本やSpring Cloud Alibabaの本を執筆した際に、一部の分散コンポーネント...
いくつかの記事を読んだ後、ようやく MySQL で row_number() ソートを実装する方法が...
1-ドロップダウン選択ボックスのスタイル設定 - ドロップダウン リストを変更します。 2- <...
一般的に言えば、より完全な結果を得るためには、2 つ以上のテーブルから結果を取得する必要があります。...
MySQL sql_modeの適切な設定sql_mode は見落とされやすい変数です。デフォルト値は...
1. フォントと文字表示の関係左側と右側の鋭角部分は Songti フォントで表示されます: &l...
前回の記事で、MySQL ステートメントの最適化には限界があると述べました。MySQL ステートメン...
目次序文やることリストやるだけ地図を準備するインスタンスをバックアップ用に保存するタイマーカルーセル...
この質問は、MySQL の権限に関する WeChat グループのネットユーザー間の議論です。次のよう...
CSS3 を学ぶということは、新しい機能と基本的な理論に慣れることを意味します。この記事では、ケー...