General protection fault (GPF) pada arsitekturIntelx86 dan AMDx86-64, dan arsitektur lainnya yang tidak berkaitan, adalah sebuah fault (sebuah jenis interupsi) yang dapat mencakup beberapa keadaan saat mekanisme proteksi di dalam arsitektur prosesor dilanggar oleh program apapun yang sedang berjalan, baik kernel maupun program user. Mekanisme ini pertama kali dijelaskan di bab 9.8.13 dalam manual referensi programmer Intel 80386 pada tahun 1986. General protection fault diimplementasikan sebagai interrupt (vektor interupsi nomor 13 dalam desimal) dalam kedua arsitektur x86 dan AMD64. Aplikasi dapat dikatakan mengalami crash.
Penyebab GPF yang paling umum adalah dua aplikasi yang mencoba menggunakan menggunakan blok memori yang sama, sehingga terjadi bentrok penggunaan memori.
Beberapa sebab GPF lainnya adalah penggunaan device driver (perangkat penggerak) yang tidak tepat dan sistem operasi Windows yang terkorupsi.
Perilaku dalam sistem operasi tertentu
Dalam Microsoft Windows, general protection fault disajikan dalam berbagai bahasa, bergantung pada versi produk:
Mencoba menjalankan / mengeksekusi bita dalam memori yang tidak dirancang sebagai instruksi
Mencoba membaca sebagai bita data dalam memori yang sebetulnya dirancang sebagai instruksi
Perbedaan / konflik lainnya antara perancangan bagian memori dengan penggunaannya
Meskipun begitu, banyak sistem operasi modern menerapkan skema pengendalian akses memori melalui paging, bukan segmentasi, jadi sering ada kasus referensi memori yang tidak valid dalam sistem operasi seperti Windows dilaporkan melalui page fault daripada general protection fault. Sistem operasi biasanya menyediakan lapisan abstraksi (seperti exception handling atau sinyal) yang menyembunyikan apapun mekanisme prosesor internal yang digunakan untuk mengirimkan memory access error dari program, dengan tujuan menyediakan antarmuka standar untuk menangani berbagai tipe berbeda dari kondisi error yang diciptakan prosesor.
Dalam kondisi arsitektur x86, general protection fault adalah khusus untuk proteksi berbasis segmentasi saat sampai pada akses memori. Namun, general protection fault masih digunakan untuk melaporkan pelanggaran proteksi lainnya (di samping pelanggaran terhadap akses memori) saat digunakan paging, seperti penggunaan instruksi yang tidak dapat diakses dari current privilege level.
Meskipun secara teoretis sistem operasi mungkin untuk menyediakan baik paging maupun segmentasi, dalam bagian besar, sistem operasi umum biasanya mengandalkan paging untuk kebutuhan memory access controlnya.
Lain-lain
Penyebab lain dari general protection fault adalah:
mencoba mengakses interupsi/exception handler dari mode v86 saat kode handler pendeskripsi segmen (DPL = descriptor privilege level) sedang lebih dari nol
mencoba menulis angka satu ke dalam bit yang telah dipesan (reserved) dari CR4
mencoba mengeksekusi instruksi yang memerlukan privilege saat current privileged level (CPL) tidak nol
menulis ke bit reserved dalam instruksi MSR
mengakses gerbang yang mengandung pemilih segmen null
mengeksekusi interupsi perangkat lunak saat set CPL lebih besar dari DPL untuk gerbang interupsi
pemilih segmen dalam sebuah pemanggilan, interupsi, atau gerbang trap tidak menunjuk ke segmen kode
melebihi panjang instruksi yaitu 15 bita
melanggar aturan hak akses (privilege)
mengaktifkan paging saat menonaktifkan proteksi
mereferensikan tabel pembaca interupsi yang menyertai sebuah interupsi atau exception yang sebenarnya bukan interupsi, trap, atau gerbang task
SSE kuno: Operand memori tidak merupakan 16-bita
Catatan dan referensi
Intel Architecture Software Developer's Manual–Volume 3: System Programming