Forskere bag gennembrud for sikre styresystemer

Et hold australske forskere har som de første bevist, at en styresystemkerne overholder alle specifikationer. På sigt kan det føre til mere pålidelige og sikre styresystemer.

Artikel top billede

Forskere fra det australske NICTA, Information and Communications Technology Research Centre of Excellence, har som de første i verden bevist korrektheden af en styresystemkerne.

Forskerne fra NICTA har beskrevet kravene til styresystemkernen i en formaliseret kravspecifikation.

Korrekthedsbeviset betyder, at man kan være sikker på, at selve koden for styresystemkernen overholder kravspecifikationen.

Beviset sikrer med andre ord, at programkoden ikke introducerer fejl eller sideeffekter, der strider imod den oprindelige kravspecifikation.

Når man går fra en kravspecifikation til programkode, kan der normalt i systemudvikling blive introduceret mange fejl i forhold til de oprindelige krav.

Som forskerne selv beskriver det:

"Ideen er, at det er nemmere og hurtigere at specificere hvad du ønsker i specifikationen, fordi sproget er mere udtryksfuldt, og fordi du kan udelade detaljer, som du ikke er interesseret i; specifikationen behøver kun at sige hvad softwaren skal gøre, ikke hvordan det skal gøres."

Stort skridt mod pålidelige styresystemer

En styresystemkerne er det centrale i en computer og korrekthedsbeviset er et stort skridt mod sikre og pålidelige styresystemer.

"Formelle beviser for specifikke egenskaber er blevet udført for mindre kerner, men det, vi har gjort, er et generelt, funktionelt korrekthedbevis, som ikke før er opnået for rigtige højt-performende software af den her kompleksitet og størrelse," forklarer Dr. Gerwin Klein, som leder NICTA's formelle verifikationsforskerhold.

Arbejdet vinder anerkendelse.
"Det er svært at kommentere denne bedrift uden at anvende klicheer. At bevise korrektheden af 7.500 linjers C-kode er en enestående præstation, som vil føre til software af hidtil utænkelig høje standarder for pålidelighed," siger professor i Computational Logic ved Cambridge University, Lawrence C Paulson.

NICTA-forskerne har brugt 20-25 mandeår på at bevise, at implementeringen af Secure Embedded L4 (seL4)-mikrokernen overholder alle specifikationer.

seL4-mikrokernen er en styresystemkerne som er tiltænkt anvendelse i mobiltelefoner, håndholdte computere og andre apparater med brug for et lille og pålideligt styresystem.

Korrekthedsbeviset markerer afslutningen på L4.verified-projektet, som startede for fire år siden.

Usårlig overfor klassiske angreb

Beviset for seL4-korrektheden viser også, at mange almindelige angrebsformer ikke virker på seL4 kernen. Eksempelvis vil kernen ikke kunne blive udsat for buffer- overflows, hvilket ellers er en ofte set angrebsform, hvor hackere forsøger at overtage kontrollen med computere.

"Vores seL4 kerne kan ikke blive ødelagt af den slags angreb," siger Dr. Klein.

"Arbejdet går videre end de sædvanlige check for specifikke fejl," bemærker professor Lawrence C Paulson.

"I stedet for verificerer det fuld overholdelse af systemspecifikationen. Projektet har ikke kun givet en verificeret mikrokerne, men et sæt teknikker som kan anvendes til at udvikle anden verificeret software."

Ikke fejlfri

Selvom det nu er bevist, at implementeringen af seL4 overholder alle specifikationerne, kan forskerne ikke udelukke eventuelle fejl.

Hvis man har glemt at specificere nogle krav i kravspecifikationen, så vil koden heller ikke indeholde funktionalitet, der honorerer de glemte krav, ligesom nogle forkerte krav vil blive afspejlet i koden.

"En kyniker vil nok sige: beviser som det her viser kun, at enhver fejl i specifikationen er blevet præcist implementeret i C. Det er sandt...Men på et tidspunkt må man sige hvad man ønsker (den "abstrakte specifikation") og det er hvad du får."

"Vores bevis viser, at hvis forudsætningerne for beviset holder, så afviger seL4-kernen ikke fra specifikationen. Der kan være uforudsete features i specifikationen og en eller flere af forudsætningerne er måske ikke gældende.

Specielt kan implementeringsdetaljerne under niveauet for C programmeringssproget indeholde ligeså mange eller få defekter som anden software," lyder det på projektets spørgsmål og svar-side

1.200 linjers assembler- og boot-kode er ikke verificeret i seL4. Der er en nærmere beskrivelse af korrekthedsbeviset og antagelserne på projektets website.

Hvornår i mainstream styresystemer?

Selvom NICTA-forskerne nu har vist, at det kan lade sig gøre at bevise korrektheden for styresystemet, den centrale del af en computers software, så vil der formentlig gå lang tid, inden vi ser formelt verificerede styresystemkerner i mainstream styresystemer som Windows, Linux og Mac OSX.

seL4 er nemlig en mikrokerne med kun 8.700 linjers kode, hvorimod Windows og Linux er såkaldte monolitiske kerner, der består af flere millioner linjers kode.
Det vil tage tid at bevise korrektheden for dem.

Læses lige nu

    Event: Computerworld Summit 2026 - Aarhus

    Digital transformation | Aarhus C

    Styrk din digitale strategi med konkret brug af AI og ny teknologi. Mød 200 it-professionelle, få indsigter, løsninger og netværk på én dag. Computerworld Summit i Aarhus viser hvordan teknologi skaber forretningsværdi – her og nu.

    21. april 2026 | Gratis deltagelse

    Udlændinge- og Integrationsministeriet

    Løsningsarkitekt til Kontoret Udviklingsprojekter i Udlændingestyrelsen

    Københavnsområdet

    TV2

    Android App Developer til TV 2

    Københavnsområdet

    Netcompany A/S

    Erfaren databasespecialist

    Københavnsområdet

    Navnenyt fra it-Danmark

    Industriens Pension har pr. 3. november 2025 ansat Morten Plannthin Lund, 55 år,  som it-driftschef. Han skal især beskæftige sig med it-drift, it-support og samarbejde med outsourcingleverandører. Han kommer fra en stilling som Head of Nordic Operations Center hos Nexi Group. Han er uddannet HD, Business Management på Copenhagen Business School. Han har tidligere beskæftiget sig med kritisk it-infrastruktur og strategiske it-projekter. Nyt job

    Morten Plannthin Lund

    Industriens Pension

    Norriq Danmark A/S har pr. 1. september 2025 ansat Hans Christian Thisen som AI Consultant. Han skal især beskæftige sig med at bidrage til udvikling og implementering af AI- og automatiseringsløsninger. Nyt job

    Hans Christian Thisen

    Norriq Danmark A/S

    Sentia har pr. 1. oktober 2025 ansat Morten Jørgensen som Chief Commercial Officer. Han skal især beskæftige sig med udbygning af Sentias markedsposition og forretningsområder med det overordnede ansvar for den kommercielle organisation. Han kommer fra en stilling som Forretningsdirektør hos Emagine. Nyt job
    Signifly har pr. 1. august 2025 ansat Morten Eskildsen som UX Lead. Han skal især beskæftige sig med styrke bureauets kompetencer inden for UX og digital strategi i konsulentteamet og arbejde på tværs af alle afdelinger. Han kommer fra en stilling som CDO, UX & Digital Strategy Consultant hos Zupa. Nyt job

    Morten Eskildsen

    Signifly