Rumah >pembangunan bahagian belakang >C++ >Adakah x86 Memuat dan Menyimpan Atom?

Adakah x86 Memuat dan Menyimpan Atom?

Mary-Kate Olsen
Mary-Kate Olsenasal
2024-11-28 10:55:12322semak imbas

Are x86 Loads and Stores Atomic?

Atomicity of Load and Store on x86

Walaupun tanggapan bahawa operasi memori dalam std::atomic bergantung semata-mata pada penguncian bas, operasi atom sebenarnya dilaksanakan dalam cache.

Cache Kepaduan

Kepaduan cache memastikan semua teras mempunyai pandangan ingatan yang konsisten. Garisan cache dipindahkan antara teras dan memori dalam ketulan atom. Ini membolehkan operasi atom berlaku dalam cache, tanpa bergantung pada penguncian bas luaran.

Operasi Sejajar

Pemuatan sejajar dan operasi stor sehingga 64 bit dijamin akan atom pada pemproses x86. Ini kerana akses sejajar boleh dipindahkan melalui laluan data yang cukup luas untuk menampung keseluruhan operasi.

Operasi Tidak Selaras

Beban dan stor tidak sejajar boleh menjadi bukan atom , kerana ia mungkin memerlukan berbilang akses untuk diselesaikan. Contohnya, beban atau stor yang melintasi sempadan talian cache mesti dilakukan dalam dua akses berasingan, menjadikannya bukan atom.

Kendalian Baca-Ubah Suai-Tulis Atom

Operasi baca-ubah suai-tulis atom, seperti tambah kunci [mem], eax, adalah lebih kompleks untuk dilaksanakan daripada beban mudah atau kedai. Operasi ini memerlukan teras untuk menahan talian cache yang terjejas dalam keadaan diubah suai dan menghalang sebarang pengubahsuaian luaran sehingga operasi selesai. Operasi baca-ubah suai-tulis tidak sejajar mungkin memerlukan penegasan isyarat LOCK# untuk mengunci bas dan menghalang teras lain daripada mengakses memori yang terjejas.

Pengoptimuman Pengkompil

Penyusun boleh mengoptimumkan beban seq_cst dengan meninggalkan arahan mfence, kerana pesanan memori x86 menghalang LoadLoad dan Penyusunan semula LoadStore. Walau bagaimanapun, pagar masih diperlukan untuk kedai seq_cst untuk menghalang penyusunan semula StoreLoad.

Ringkasnya, atomicity pada pemproses x86 dicapai melalui gabungan keselarasan cache, operasi sejajar dan penguncian bas untuk operasi baca-ubah suai-tulis tidak sejajar . Ini membolehkan operasi atom berlaku dengan cekap dan tanpa menjejaskan prestasi keseluruhan sistem.

Atas ialah kandungan terperinci Adakah x86 Memuat dan Menyimpan Atom?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn