ホームページ バックエンド開発 C++ x86 のロードとストアはアトミックですか?

x86 のロードとストアはアトミックですか?

Nov 28, 2024 am 10:55 AM

Are x86 Loads and Stores Atomic?

x86 でのロードとストアのアトミック性

std::atomic のメモリ操作はバス ロックのみに依存しているという印象にもかかわらず、アトミック操作実際にはキャッシュ内で実行されます。

キャッシュコヒーレンス

キャッシュ コヒーレンスにより、すべてのコアがメモリの一貫したビューを持つことが保証されます。キャッシュ ラインは、アトミック チャンクでコアとメモリ間で転送されます。これにより、外部バス ロックに依存せずに、キャッシュ内でアトミック操作を実行できるようになります。

アラインされた操作

最大 64 ビットのアラインされたロードおよびストア操作が保証されます。 x86 プロセッサ上のアトミック。これは、整列されたアクセスが、操作全体に対応できる十分な幅のデータ パスを介して転送されるためです。

整列されていない操作

整列されていないロードとストアは非アトミックになる可能性があります。完了するまでに複数のアクセスが必要になる場合があるためです。たとえば、キャッシュライン境界を越えるロードまたはストアは 2 つの個別のアクセスで実行する必要があり、非アトミックになります。

アトミック読み取り、変更、書き込み操作

lock add [mem]、eax などのアトミックな読み取り、変更、書き込み操作は、単純なロードやストアよりも実装が複雑です。これらの操作では、コアが影響を受けるキャッシュ ラインを変更された状態に保持し、操作が完了するまで外部からの変更を防ぐ必要があります。非整列の読み取り、変更、書き込み操作では、バスをロックし、他のコアが影響を受けるメモリにアクセスできないようにするために、LOCK# 信号をアサートする必要がある場合があります。

コンパイラーの最適化

コンパイラーは、 x86 メモリの順序付けにより LoadLoad と LoadStore が妨げられるため、mfence 命令を省略して seq_cst ロードを最適化します。並べ替え中。ただし、StoreLoad の並べ替えを防ぐために、seq_cst ストアには依然としてフェンスが必要です。

要約すると、x86 プロセッサ上のアトミック性は、キャッシュ コヒーレンス、アライメントされた操作、およびアライメントされていない読み取り、変更、書き込み操作のバス ロックの組み合わせによって実現されます。 。これにより、システム全体のパフォーマンスに影響を与えることなく、アトミック操作を効率的に実行できます。

以上がx86 のロードとストアはアトミックですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

C言語関数によって返される値の種類は何ですか?返品値を決定するものは何ですか? C言語関数によって返される値の種類は何ですか?返品値を決定するものは何ですか? Mar 03, 2025 pm 05:52 PM

C言語関数によって返される値の種類は何ですか?返品値を決定するものは何ですか?

GULC:Cライブラリはゼロから構築されています GULC:Cライブラリはゼロから構築されています Mar 03, 2025 pm 05:46 PM

GULC:Cライブラリはゼロから構築されています

c言語関数形式文字ケース変換手順 c言語関数形式文字ケース変換手順 Mar 03, 2025 pm 05:53 PM

c言語関数形式文字ケース変換手順

C言語関数の定義と呼び出しルールは何ですか、そして C言語関数の定義と呼び出しルールは何ですか、そして Mar 03, 2025 pm 05:53 PM

C言語関数の定義と呼び出しルールは何ですか、そして

メモリに保存されているC言語関数の返品値はどこにありますか? メモリに保存されているC言語関数の返品値はどこにありますか? Mar 03, 2025 pm 05:51 PM

メモリに保存されているC言語関数の返品値はどこにありますか?

明確な使用法とフレーズ共有 明確な使用法とフレーズ共有 Mar 03, 2025 pm 05:51 PM

明確な使用法とフレーズ共有

STL(ソート、検索、変換など)のアルゴリズムを効率的に使用するにはどうすればよいですか? STL(ソート、検索、変換など)のアルゴリズムを効率的に使用するにはどうすればよいですか? Mar 12, 2025 pm 04:52 PM

STL(ソート、検索、変換など)のアルゴリズムを効率的に使用するにはどうすればよいですか?

C標準テンプレートライブラリ(STL)はどのように機能しますか? C標準テンプレートライブラリ(STL)はどのように機能しますか? Mar 12, 2025 pm 04:50 PM

C標準テンプレートライブラリ(STL)はどのように機能しますか?

See all articles