{"id":"https://openalex.org/W2900135310","doi":"https://doi.org/10.1145/3290375","title":"An abstract stack based approach to verified compositional compilation to machine code","display_name":"An abstract stack based approach to verified compositional compilation to machine code","publication_year":2019,"publication_date":"2019-01-02","ids":{"openalex":"https://openalex.org/W2900135310","doi":"https://doi.org/10.1145/3290375","mag":"2900135310"},"language":"en","primary_location":{"id":"doi:10.1145/3290375","is_oa":true,"landing_page_url":"https://doi.org/10.1145/3290375","pdf_url":null,"source":{"id":"https://openalex.org/S4210216081","display_name":"Proceedings of the ACM on Programming Languages","issn_l":"2475-1421","issn":["2475-1421"],"is_oa":true,"is_in_doaj":false,"is_core":true,"host_organization":"https://openalex.org/P4310319798","host_organization_name":"Association for Computing Machinery","host_organization_lineage":["https://openalex.org/P4310319798"],"host_organization_lineage_names":["Association for Computing Machinery"],"type":"journal"},"license":"cc-by","license_id":"https://openalex.org/licenses/cc-by","version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the ACM on Programming Languages","raw_type":"journal-article"},"type":"article","indexed_in":["crossref"],"open_access":{"is_oa":true,"oa_status":"diamond","oa_url":"https://doi.org/10.1145/3290375","any_repository_has_fulltext":true},"authorships":[{"author_position":"first","author":{"id":"https://openalex.org/A5100384219","display_name":"Yuting Wang","orcid":"https://orcid.org/0000-0003-3990-2418"},"institutions":[{"id":"https://openalex.org/I32971472","display_name":"Yale University","ror":"https://ror.org/03v76x132","country_code":"US","type":"education","lineage":["https://openalex.org/I32971472"]}],"countries":["US"],"is_corresponding":true,"raw_author_name":"Yuting Wang","raw_affiliation_strings":["Yale University, USA","Yale University [New Haven] (157 Church Street, New Haven, CT 06510-2100 - United States)"],"affiliations":[{"raw_affiliation_string":"Yale University, USA","institution_ids":["https://openalex.org/I32971472"]},{"raw_affiliation_string":"Yale University [New Haven] (157 Church Street, New Haven, CT 06510-2100 - United States)","institution_ids":["https://openalex.org/I32971472"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5034073212","display_name":"Pierre Wilke","orcid":"https://orcid.org/0000-0001-9681-644X"},"institutions":[{"id":"https://openalex.org/I32971472","display_name":"Yale University","ror":"https://ror.org/03v76x132","country_code":"US","type":"education","lineage":["https://openalex.org/I32971472"]},{"id":"https://openalex.org/I4210107720","display_name":"CentraleSup\u00e9lec","ror":"https://ror.org/019tcpt25","country_code":"FR","type":"facility","lineage":["https://openalex.org/I277688954","https://openalex.org/I4210107720"]}],"countries":["FR","US"],"is_corresponding":false,"raw_author_name":"Pierre Wilke","raw_affiliation_strings":["Yale University, USA / CentraleSup\u00e9lec, France","CentraleSup\u00e9lec (3, rue Joliot Curie,\r\nPlateau de Moulon,\r\n91192 GIF-SUR-YVETTE Cedex - France)","Yale University [New Haven] (157 Church Street, New Haven, CT 06510-2100 - United States)"],"affiliations":[{"raw_affiliation_string":"Yale University, USA / CentraleSup\u00e9lec, France","institution_ids":["https://openalex.org/I4210107720"]},{"raw_affiliation_string":"CentraleSup\u00e9lec (3, rue Joliot Curie,\r\nPlateau de Moulon,\r\n91192 GIF-SUR-YVETTE Cedex - France)","institution_ids":["https://openalex.org/I4210107720"]},{"raw_affiliation_string":"Yale University [New Haven] (157 Church Street, New Haven, CT 06510-2100 - United States)","institution_ids":["https://openalex.org/I32971472"]}]},{"author_position":"last","author":{"id":"https://openalex.org/A5070627140","display_name":"Zhong Shao","orcid":"https://orcid.org/0000-0001-8184-7649"},"institutions":[{"id":"https://openalex.org/I32971472","display_name":"Yale University","ror":"https://ror.org/03v76x132","country_code":"US","type":"education","lineage":["https://openalex.org/I32971472"]}],"countries":["US"],"is_corresponding":false,"raw_author_name":"Zhong Shao","raw_affiliation_strings":["Yale University, USA","Yale University [New Haven] (157 Church Street, New Haven, CT 06510-2100 - United States)"],"affiliations":[{"raw_affiliation_string":"Yale University, USA","institution_ids":["https://openalex.org/I32971472"]},{"raw_affiliation_string":"Yale University [New Haven] (157 Church Street, New Haven, CT 06510-2100 - United States)","institution_ids":["https://openalex.org/I32971472"]}]}],"institutions":[],"countries_distinct_count":2,"institutions_distinct_count":3,"corresponding_author_ids":["https://openalex.org/A5100384219"],"corresponding_institution_ids":["https://openalex.org/I32971472"],"apc_list":null,"apc_paid":null,"fwci":2.8901,"has_fulltext":false,"cited_by_count":47,"citation_normalized_percentile":{"value":0.92780566,"is_in_top_1_percent":false,"is_in_top_10_percent":true},"cited_by_percentile_year":{"min":94,"max":100},"biblio":{"volume":"3","issue":"POPL","first_page":"1","last_page":"30"},"is_retracted":false,"is_paratext":false,"is_xpac":false,"primary_topic":{"id":"https://openalex.org/T11424","display_name":"Security and Verification in Computing","score":0.9994000196456909,"subfield":{"id":"https://openalex.org/subfields/1702","display_name":"Artificial Intelligence"},"field":{"id":"https://openalex.org/fields/17","display_name":"Computer Science"},"domain":{"id":"https://openalex.org/domains/3","display_name":"Physical Sciences"}},"topics":[{"id":"https://openalex.org/T11424","display_name":"Security and Verification in Computing","score":0.9994000196456909,"subfield":{"id":"https://openalex.org/subfields/1702","display_name":"Artificial Intelligence"},"field":{"id":"https://openalex.org/fields/17","display_name":"Computer Science"},"domain":{"id":"https://openalex.org/domains/3","display_name":"Physical Sciences"}},{"id":"https://openalex.org/T10054","display_name":"Parallel Computing and Optimization Techniques","score":0.9986000061035156,"subfield":{"id":"https://openalex.org/subfields/1708","display_name":"Hardware and Architecture"},"field":{"id":"https://openalex.org/fields/17","display_name":"Computer Science"},"domain":{"id":"https://openalex.org/domains/3","display_name":"Physical Sciences"}},{"id":"https://openalex.org/T10126","display_name":"Logic, programming, and type systems","score":0.9980000257492065,"subfield":{"id":"https://openalex.org/subfields/1702","display_name":"Artificial Intelligence"},"field":{"id":"https://openalex.org/fields/17","display_name":"Computer Science"},"domain":{"id":"https://openalex.org/domains/3","display_name":"Physical Sciences"}}],"keywords":[{"id":"https://openalex.org/keywords/call-stack","display_name":"Call stack","score":0.9051728248596191},{"id":"https://openalex.org/keywords/computer-science","display_name":"Computer science","score":0.8361663818359375},{"id":"https://openalex.org/keywords/stack","display_name":"Stack (abstract data type)","score":0.7828517556190491},{"id":"https://openalex.org/keywords/correctness","display_name":"Correctness","score":0.670247495174408},{"id":"https://openalex.org/keywords/merge","display_name":"Merge (version control)","score":0.6130849719047546},{"id":"https://openalex.org/keywords/compiler","display_name":"Compiler","score":0.5377087593078613},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.49562251567840576},{"id":"https://openalex.org/keywords/parallel-computing","display_name":"Parallel computing","score":0.4903147518634796},{"id":"https://openalex.org/keywords/source-code","display_name":"Source code","score":0.4261187016963959}],"concepts":[{"id":"https://openalex.org/C119024030","wikidata":"https://www.wikidata.org/wiki/Q759899","display_name":"Call stack","level":3,"score":0.9051728248596191},{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.8361663818359375},{"id":"https://openalex.org/C9395851","wikidata":"https://www.wikidata.org/wiki/Q177929","display_name":"Stack (abstract data type)","level":2,"score":0.7828517556190491},{"id":"https://openalex.org/C55439883","wikidata":"https://www.wikidata.org/wiki/Q360812","display_name":"Correctness","level":2,"score":0.670247495174408},{"id":"https://openalex.org/C197129107","wikidata":"https://www.wikidata.org/wiki/Q1921621","display_name":"Merge (version control)","level":2,"score":0.6130849719047546},{"id":"https://openalex.org/C169590947","wikidata":"https://www.wikidata.org/wiki/Q47506","display_name":"Compiler","level":2,"score":0.5377087593078613},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.49562251567840576},{"id":"https://openalex.org/C173608175","wikidata":"https://www.wikidata.org/wiki/Q232661","display_name":"Parallel computing","level":1,"score":0.4903147518634796},{"id":"https://openalex.org/C43126263","wikidata":"https://www.wikidata.org/wiki/Q128751","display_name":"Source code","level":2,"score":0.4261187016963959}],"mesh":[],"locations_count":2,"locations":[{"id":"doi:10.1145/3290375","is_oa":true,"landing_page_url":"https://doi.org/10.1145/3290375","pdf_url":null,"source":{"id":"https://openalex.org/S4210216081","display_name":"Proceedings of the ACM on Programming Languages","issn_l":"2475-1421","issn":["2475-1421"],"is_oa":true,"is_in_doaj":false,"is_core":true,"host_organization":"https://openalex.org/P4310319798","host_organization_name":"Association for Computing Machinery","host_organization_lineage":["https://openalex.org/P4310319798"],"host_organization_lineage_names":["Association for Computing Machinery"],"type":"journal"},"license":"cc-by","license_id":"https://openalex.org/licenses/cc-by","version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the ACM on Programming Languages","raw_type":"journal-article"},{"id":"pmh:oai:HAL:hal-02018168v1","is_oa":true,"landing_page_url":"https://hal.science/hal-02018168","pdf_url":null,"source":{"id":"https://openalex.org/S4306402512","display_name":"HAL (Le Centre pour la Communication Scientifique Directe)","issn_l":null,"issn":null,"is_oa":false,"is_in_doaj":false,"is_core":false,"host_organization":"https://openalex.org/I1294671590","host_organization_name":"Centre National de la Recherche Scientifique","host_organization_lineage":["https://openalex.org/I1294671590"],"host_organization_lineage_names":[],"type":"repository"},"license":"other-oa","license_id":"https://openalex.org/licenses/other-oa","version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"Proceedings of the ACM on Programming Languages, 2019, 3 (62), pp.30. &#x27E8;10.1145/3290375&#x27E9;","raw_type":"Journal articles"}],"best_oa_location":{"id":"doi:10.1145/3290375","is_oa":true,"landing_page_url":"https://doi.org/10.1145/3290375","pdf_url":null,"source":{"id":"https://openalex.org/S4210216081","display_name":"Proceedings of the ACM on Programming Languages","issn_l":"2475-1421","issn":["2475-1421"],"is_oa":true,"is_in_doaj":false,"is_core":true,"host_organization":"https://openalex.org/P4310319798","host_organization_name":"Association for Computing Machinery","host_organization_lineage":["https://openalex.org/P4310319798"],"host_organization_lineage_names":["Association for Computing Machinery"],"type":"journal"},"license":"cc-by","license_id":"https://openalex.org/licenses/cc-by","version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the ACM on Programming Languages","raw_type":"journal-article"},"sustainable_development_goals":[{"score":0.5,"display_name":"Peace, Justice and strong institutions","id":"https://metadata.un.org/sdg/16"}],"awards":[{"id":"https://openalex.org/G1981839175","display_name":null,"funder_award_id":"1715154","funder_id":"https://openalex.org/F4320306076","funder_display_name":"National Science Foundation"},{"id":"https://openalex.org/G2144793629","display_name":null,"funder_award_id":"1521523, 1715154","funder_id":"https://openalex.org/F4320306076","funder_display_name":"National Science Foundation"},{"id":"https://openalex.org/G4577670171","display_name":null,"funder_award_id":"FA8750-15-C-0082","funder_id":"https://openalex.org/F4320332180","funder_display_name":"Defense Advanced Research Projects Agency"},{"id":"https://openalex.org/G4613586726","display_name":null,"funder_award_id":"1521523,1715154,1763399","funder_id":"https://openalex.org/F4320306076","funder_display_name":"National Science Foundation"},{"id":"https://openalex.org/G4713059963","display_name":null,"funder_award_id":"FA8750","funder_id":"https://openalex.org/F4320332180","funder_display_name":"Defense Advanced Research Projects Agency"},{"id":"https://openalex.org/G536862562","display_name":"SHF: Medium: DeepSEA: A Language for Programming and Synthesizing Certified Software","funder_award_id":"1763399","funder_id":"https://openalex.org/F4320306076","funder_display_name":"National Science Foundation"},{"id":"https://openalex.org/G6080364906","display_name":null,"funder_award_id":"1521523","funder_id":"https://openalex.org/F4320306076","funder_display_name":"National Science Foundation"}],"funders":[{"id":"https://openalex.org/F4320306076","display_name":"National Science Foundation","ror":"https://ror.org/021nxhr62"},{"id":"https://openalex.org/F4320332180","display_name":"Defense Advanced Research Projects Agency","ror":"https://ror.org/02caytj08"}],"has_content":{"grobid_xml":false,"pdf":false},"content_urls":null,"referenced_works_count":22,"referenced_works":["https://openalex.org/W563467911","https://openalex.org/W1552921094","https://openalex.org/W1963833875","https://openalex.org/W2006731094","https://openalex.org/W2009248821","https://openalex.org/W2023035194","https://openalex.org/W2064390891","https://openalex.org/W2095770127","https://openalex.org/W2148662736","https://openalex.org/W2154942048","https://openalex.org/W2162627428","https://openalex.org/W2166662837","https://openalex.org/W2172426415","https://openalex.org/W2294599249","https://openalex.org/W2295752850","https://openalex.org/W2578546025","https://openalex.org/W2746152268","https://openalex.org/W2756121931","https://openalex.org/W2798365728","https://openalex.org/W2901282687","https://openalex.org/W4247648759","https://openalex.org/W4285719527"],"related_works":["https://openalex.org/W2087972928","https://openalex.org/W3015514077","https://openalex.org/W2779721357","https://openalex.org/W1527172253","https://openalex.org/W1968278738","https://openalex.org/W3125263037","https://openalex.org/W2377497513","https://openalex.org/W1536721933","https://openalex.org/W2374908835","https://openalex.org/W394712460"],"abstract_inverted_index":{"A":[0],"key":[1],"ingredient":[2],"contributing":[3],"to":[4,75,106,161,188,205,222],"the":[5,9,48,107,115,129,139,162,169,183,190,215,224,227,235,239,252,255,268,309,316],"success":[6],"of":[7,26,41,55,61,88,96,171,182,185,217,226,231,248,254,271,293,299],"CompCert,":[8,218,232,244,264],"state-of-the-art":[10],"verified":[11,31,89],"compiler":[12],"for":[13,24,98,213],"C,":[14],"is":[15,21,72,112,166],"its":[16,27],"block-based":[17],"memory":[18,35,56,173,211,281],"model,":[19],"which":[20,111],"used":[22],"uniformly":[23],"all":[25,214,234],"languages":[28,216],"and":[29,82,103,149,158,193,257],"their":[30],"compilation.":[32],"However,":[33],"CompCert's":[34,172],"model":[36,174,212],"lacks":[37],"an":[38,52,176],"explicit":[39],"notion":[40,298],"stack.":[42,84,318],"Its":[43],"target":[44],"assembly":[45,63],"language":[46,278],"represents":[47],"runtime":[49],"stack":[50,101,141,178,186,191,198,206,256,259,311],"as":[51,146],"unbounded":[53],"list":[54],"blocks,":[57],"making":[58],"further":[59],"compilation":[60,91,229,301,306],"CompCert":[62,249,272,294],"into":[64,79,275],"more":[65],"realistic":[66],"machine":[67],"code":[68],"difficult":[69],"since":[70],"it":[71],"not":[73,124],"possible":[74],"merge":[76],"these":[77],"blocks":[78,142],"a":[80,156,196,245,276,290,297],"finite":[81],"continuous":[83],"Furthermore,":[85],"various":[86],"notions":[87],"compositional":[90,300],"rely":[92],"on":[93,168,262,284],"some":[94,132],"kind":[95],"mechanism":[97],"protecting":[99],"private":[100],"data":[102],"enabling":[104],"modification":[105],"public":[108],"stack-allocated":[109],"data,":[110],"lacking":[113],"in":[114,128],"original":[116],"CompCert.":[117],"These":[118],"problems":[119],"have":[120],"been":[121],"investigated":[122],"but":[123],"fully":[125],"addressed":[126],"before,":[127],"sense":[130],"that":[131,136,179,194,250,273,295,302],"advanced":[133],"optimization":[134,236],"passes":[135],"significantly":[137],"change":[138],"ways":[140],"are":[143,151,220],"(de-)allocated,":[144],"such":[145],"tailcall":[147],"recognition":[148],"inlining,":[150],"often":[152],"omitted.":[153],"We":[154],"propose":[155],"lightweight":[157],"complete":[159,246,291],"solution":[160],"above":[163],"problems.":[164],"It":[165],"based":[167],"enrichment":[170],"with":[175,279],"abstract":[177,317],"keeps":[180],"track":[181],"history":[184],"frames":[187],"bound":[189],"consumption":[192],"enforces":[195,251],"uniform":[197,310],"access":[199,312],"policy":[200,313],"by":[201,307,315],"assigning":[202],"fine-grained":[203,258],"permissions":[204],"memory.":[207],"Using":[208],"this":[209],"enriched":[210],"we":[219,241,265,286,303],"able":[221],"reprove":[223],"correctness":[225],"full":[228],"chain":[230],"including":[233],"passes.":[237],"In":[238],"end,":[240],"get":[242],"Stack-Aware":[243,263,288],"extension":[247,270,292],"finiteness":[253],"permissions.":[260],"Based":[261,283],"develop":[266,287],"CompCertMC,":[267,285],"first":[269],"compiles":[274],"low-level":[277],"flat":[280],"spaces.":[282],"CompCertX,":[289],"supports":[296],"call":[304],"contextual":[305],"exploiting":[308],"provided":[314]},"counts_by_year":[{"year":2026,"cited_by_count":1},{"year":2025,"cited_by_count":19},{"year":2024,"cited_by_count":2},{"year":2023,"cited_by_count":5},{"year":2022,"cited_by_count":5},{"year":2021,"cited_by_count":7},{"year":2020,"cited_by_count":5},{"year":2019,"cited_by_count":3}],"updated_date":"2026-04-10T15:06:20.359241","created_date":"2025-10-10T00:00:00"}
