Linux DMAインターフェースの知識ポイントの詳細な説明

Linux DMAインターフェースの知識ポイントの詳細な説明

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 編集部までご連絡ください。

以下もご興味があるかもしれません:
  • Linux システムで Centos7 を使って ElasticSearch ミドルウェアと共通インターフェースを構築するデモ
  • Linux で利用可能なネットワーク インターフェイスを表示する方法
  • LinuxシステムはPythonを使用してネットワークインターフェースを監視し、ネットワークの入出力を取得します。
  • Linux での BSD ソケット開発の基礎入門
  • Linux オペレーティングシステムでの BSD ソケット開発の基礎入門
  • Linux /etc/network/interfaces 設定インターフェース方法

<<:  mysql5.5.28 のインストール チュートリアルは非常に詳細です。

>>:  MySQL 文字列連結と null 値の設定のためのインスタンス メソッド

推薦する

フロートをクリアするための CSS メソッドの概要

フロートはWebページのレイアウトでよく使用されますが、フローティングブロックレベル要素は標準のドキ...

Windows で MySQL データベースを別のディスクに移動する

序文今日、MySQL をインストールしたところ、データベース ストレージがデフォルトで C ドライブ...

Dockerボリュームマウントの実装方法

最も単純な hello world 出力イメージを作成することは最も簡単なスタートですが、実行中のコ...

Mysqlのマージ結果と水平スプライシングフィールドの実装手順

序文最近、レポート機能に取り組んでいたのですが、ある月に各部署に入社した人と退職した人の数をカウント...

Centos7 で NIS を構成する詳細な手順

目次原理ネットワーク環境の準備インストール前の準備NIS サーバー操作NIS クライアント操作原理N...

Windows 10 Home EditionにDockerをインストールする方法を教えます

Redisの本やSpring Cloud Alibabaの本を執筆した際に、一部の分散コンポーネント...

MySQL はカスタムシーケンスを使用して row_number 関数を実装します (詳細な手順)

いくつかの記事を読んだ後、ようやく MySQL で row_number() ソートを実装する方法が...

40 CSS/JSスタイルと機能的な技術処理

1-ドロップダウン選択ボックスのスタイル設定 - ドロップダウン リストを変更します。 2- <...

Mysql の 2 つのテーブル間の結合クエリの 4 つの状況の概要

一般的に言えば、より完全な結果を得るためには、2 つ以上のテーブルから結果を取得する必要があります。...

MySQL sql_modeの適切な設定に関する詳細な説明

MySQL sql_modeの適切な設定sql_mode は見落とされやすい変数です。デフォルト値は...

丸い角や鋭い角の代わりに文字を使用することに関する研究経験の共有

1. フォントと文字表示の関係左側と右側の鋭角部分は Songti フォントで表示されます: &l...

MySQLの水平および垂直テーブルパーティションの説明

前回の記事で、MySQL ステートメントの最適化には限界があると述べました。MySQL ステートメン...

echartsマップカルーセルハイライトを解決するための記事

目次序文やることリストやるだけ地図を準備するインスタンスをバックアップ用に保存するタイマーカルーセル...

MySQL は information_schema オブジェクトの付与をバイパスし、ERROR 1044 (4200) エラーを報告します

この質問は、MySQL の権限に関する WeChat グループのネットユーザー間の議論です。次のよう...

動的な背景グラデーション効果を実現するCSS3

CSS3 を学ぶということは、新しい機能と基本的な理論に慣れることを意味します。この記事では、ケー...