Attribuutti (bitti) NX-Bit ( n e x ecute bit it AMD terminologiassa ) tai XD-Bit ( e x ecute d isable b it Intel terminologiassa ) on suorituksen estobitti , joka lisätään sivuille (katso .sivutaulukot ( englanniksi) ) toteuttaa kyky estää tietojen suorittaminen koodina. Käytetään estämään puskurin ylivuodon haavoittuvuus , joka sallii mielivaltaisen koodin suorittamisen paikallisesti tai etänä hyökkäyksissä olevassa järjestelmässä. Tekniikka vaatii ohjelmistotuen (katso DEP ) käyttöjärjestelmän ytimeltä .
NX-bittinen tekniikka voi toimia vain seuraavissa olosuhteissa:
Jotkut ohjelmistot eivät ole yhteensopivia NX-bit-tekniikan kanssa, joten BIOS tarjoaa mahdollisuuden poistaa tekniikan käytöstä.
NX ( XD ) on x86- ja x86-64-arkkitehtuurien muistisivun attribuutti (bitti), joka on lisätty suojaamaan järjestelmää ohjelmavirheiltä sekä viruksilta , troijalaisilta ja muilta niitä käyttäviltä haittaohjelmilta.
AMD kutsui bittiä "NX" englanniksi. n o e x ecute . Intel kutsui samaa bittiä englanniksi "XD". e x ecution d isable .
Koska nykyaikaiset tietokonejärjestelmät jakavat muistin sivuille, joilla on tietyt attribuutit, prosessorien suunnittelijat ovat lisänneet toisen: estävät koodin suorittamisen sivulla. Toisin sanoen tällaiselle sivulle voidaan tallentaa tietoja, mutta ei ohjelmakoodia. Jos yrität siirtää ohjauksen tällaiselle sivulle , tapahtuu keskeytys , käyttöjärjestelmä ottaa hallinnan ja lopettaa ohjelman. Suoritussuojausattribuutti on ollut pitkään läsnä muissa[ mitä? ] mikroprosessoriarkkitehtuurit; x86-järjestelmissä tällainen suojaus toteutettiin kuitenkin vain ohjelmasegmenttien tasolla, jonka mekanismia nykyaikaiset käyttöjärjestelmät eivät ole käyttäneet pitkään aikaan. Nyt se lisätään myös yksittäisten sivujen tasolla.
Nykyaikaiset ohjelmat on jaettu selkeästi koodisegmentteihin ("teksti"), dataan ("data"), alustamattomaan dataan ("bss") sekä dynaamisesti varattuun muistialueeseen, joka on jaettu kasaan ("keko") . ja ohjelmapino ("pino"). Jos ohjelma on kirjoitettu ilman virheitä, käskyosoitin ei koskaan ylitä koodisegmenttejä; Ohjelmistovirheiden seurauksena ohjaus voi kuitenkin siirtyä muille muistialueille. Tässä tapauksessa prosessori lopettaa ohjelmoitujen toimintojen suorittamisen, mutta suorittaa satunnaisen komentosarjan, jota varten se ottaa näille alueille tallennetut tiedot, kunnes se kohtaa virheellisen sekvenssin tai yrittää suorittaa toiminnon, joka rikkoo järjestelmän eheys, jotka laukaisevat suojausjärjestelmän. Molemmissa tapauksissa ohjelma kaatuu. Prosessori voi myös kohdata sekvenssin, joka tulkitaan hyppykäskyiksi jo kulkevaan osoitteeseen. Tässä tapauksessa prosessori siirtyy äärettömään silmukkaan, ja ohjelma "jumittuu" vie 100% prosessorin ajasta. Tällaisten tapausten estämiseksi otettiin käyttöön tämä lisäattribuutti: jos tiettyä muistialuetta ei ole tarkoitettu ohjelmakoodin tallentamiseen, niin kaikki sen sivut on merkittävä NX-bitillä, ja jos ohjaus yritetään siirtää sinne, prosessori luo poikkeuksen ja käyttöjärjestelmä kaataa ohjelman välittömästi ja signaloi segmentin rajojen ulkopuolelle (SIGSEGV).
Tämän ominaisuuden käyttöönoton päämotiivi ei ollut niinkään nopea vastaus tällaisiin virheisiin, vaan se, että hyökkääjät käyttivät hyvin usein tällaisia virheitä päästäkseen luvattomasti tietokoneisiin sekä kirjoittaakseen viruksia. On ilmestynyt valtava määrä sellaisia viruksia ja matoja, jotka käyttävät hyväkseen yleisten ohjelmien haavoittuvuuksia.
Yksi hyökkäysskenaarioista on, että käyttämällä puskurin ylivuotoa ohjelmassa (usein verkkopalvelua tarjoavassa demonissa ) , erityisesti kirjoitettu haittaohjelma ( exploit ) voi kirjoittaa koodia haavoittuvan ohjelman tietoalueelle esim. tavalla, että tämä koodi ottaa virheen seurauksena hallintaansa ja suorittaa hyökkääjän ohjelmoimia toimia (usein pyyntö suorittaa käyttöjärjestelmän kääreohjelma , jolla hyökkääjä ottaa haavoittuvan järjestelmän hallintaansa haavoittuvan ohjelman omistaja; usein tämä on root ).
Puskurin ylivuoto tapahtuu usein, kun ohjelman kehittäjä varaa tietyn data-alueen (puskurin), jonka pituus on kiinteä, uskoen tämän riittävän, mutta sitten ei tarkista dataa manipuloidessaan, onko se ylittänyt sen rajoja. Tämän seurauksena saapuvat tiedot vievät muistin alueita, joita ei ole tarkoitettu niille, mikä tuhoaa siellä saatavilla olevan tiedon. Hyvin usein proseduurien (alirutiinien) sisällä varataan väliaikaisia puskureita, joiden muisti on varattu ohjelmapinoon, joka myös tallentaa kutsuvan aliohjelman paluuosoitteet. Tutkittuaan huolellisesti ohjelmakoodin, hyökkääjä voi havaita tällaisen virheen , ja nyt riittää, että hän siirtää tällaisen tietosekvenssin ohjelmaan, jonka käsittelyn jälkeen ohjelma korvaa pinon paluuosoitteen vahingossa tarvittavalla osoitteella. hyökkääjä, joka myös siirsi osan ohjelmakoodista tietojen varjolla. Alirutiinin valmistumisen jälkeen proseduurin paluukomento (RET) ei siirrä hallintaa kutsuvaan toimintosarjaan, vaan hyökkääjän proseduuriin - tietokone saadaan hallintaan.
NX-attribuutin ansiosta tämä on mahdotonta. Pinoalue on merkitty NX-bitillä ja koodin suorittaminen siinä on kielletty. Nyt, jos siirrät ohjauksen pinoon, suojaus toimii. Vaikka ohjelma voidaan pakottaa kaatumaan, sen käyttäminen mielivaltaisen koodin suorittamiseen tulee erittäin vaikeaksi (tämä vaatisi ohjelman vahingossa poistamaan NX-suojauksen).
Jotkut ohjelmat käyttävät kuitenkin koodin suorittamista pinossa tai pinossa. Tällainen päätös voi johtua optimoinnista , dynaamisesta käännöksestä tai yksinkertaisesti alkuperäisestä teknisestä ratkaisusta. Normaalisti käyttöjärjestelmät tarjoavat järjestelmäkutsuja pyytääkseen muistia, jossa on käytössä suoritettava toiminto juuri tätä tarkoitusta varten, mutta monet vanhemmat ohjelmat pitävät koko muistia aina suoritettavana. Jotta voit suorittaa tällaisia ohjelmia Windowsissa, sinun on poistettava NX-toiminto käytöstä koko istunnon ajaksi, ja sen uudelleen ottaminen käyttöön edellyttää uudelleenkäynnistystä. Vaikka Windowsissa on mekanismi sellaisten ohjelmien lisäämiseksi sallittujen luetteloon , joiden DEP on poistettu käytöstä, tämä menetelmä ei kuitenkaan aina toimi oikein. . Iris on esimerkki tällaisesta ohjelmasta .
NX-bitti on merkinnän merkittävin bitti 64-bittisissä sivutaulukoissa , joita prosessori käyttää varaamaan muistia osoiteavaruudessa. 64-bittisiä sivutaulukoita käyttävät käyttöjärjestelmät, jotka toimivat 64-bittisessä tilassa tai joissa Physical Address Extension (PAE) on käytössä. Jos käyttöjärjestelmä käyttää 32-bittisiä taulukoita, sivun suoritussuojausta ei voi käyttää.
Kaikki Intelin ja AMD:n nykyaikaiset PC-prosessorit tukevat tätä tekniikkaa. Windows 10 :n asentaminen - sen läsnäolo on pakollista, muuten asennusohjelma ei salli sinun asentaa järjestelmää.