{"id":"https://openalex.org/W2790235418","doi":"https://doi.org/10.1145/3168809","title":"AutoPA: automatically generating active driver from original passive driver code","display_name":"AutoPA: automatically generating active driver from original passive driver code","publication_year":2018,"publication_date":"2018-02-24","ids":{"openalex":"https://openalex.org/W2790235418","doi":"https://doi.org/10.1145/3168809","mag":"2790235418"},"language":"en","primary_location":{"is_oa":false,"landing_page_url":"https://doi.org/10.1145/3168809","pdf_url":null,"source":null,"license":null,"license_id":null,"version":null,"is_accepted":false,"is_published":false},"type":"article","type_crossref":"proceedings-article","indexed_in":["crossref"],"open_access":{"is_oa":false,"oa_status":"closed","oa_url":null,"any_repository_has_fulltext":false},"authorships":[{"author_position":"first","author":{"id":"https://openalex.org/A5017174482","display_name":"Jia-Ju Bai","orcid":"https://orcid.org/0000-0002-9500-6100"},"institutions":[{"id":"https://openalex.org/I99065089","display_name":"Tsinghua University","ror":"https://ror.org/03cve4549","country_code":"CN","type":"education","lineage":["https://openalex.org/I99065089"]}],"countries":["CN"],"is_corresponding":false,"raw_author_name":"Jia-Ju Bai","raw_affiliation_strings":["Tsinghua University, China"],"affiliations":[{"raw_affiliation_string":"Tsinghua University, China","institution_ids":["https://openalex.org/I99065089"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5100339128","display_name":"Yu-Ping Wang","orcid":"https://orcid.org/0000-0003-4129-7704"},"institutions":[{"id":"https://openalex.org/I99065089","display_name":"Tsinghua University","ror":"https://ror.org/03cve4549","country_code":"CN","type":"education","lineage":["https://openalex.org/I99065089"]}],"countries":["CN"],"is_corresponding":false,"raw_author_name":"Yu-Ping Wang","raw_affiliation_strings":["Tsinghua University, China"],"affiliations":[{"raw_affiliation_string":"Tsinghua University, China","institution_ids":["https://openalex.org/I99065089"]}]},{"author_position":"last","author":{"id":"https://openalex.org/A5037233582","display_name":"Shi\u2010Min Hu","orcid":"https://orcid.org/0000-0001-7507-6542"},"institutions":[{"id":"https://openalex.org/I99065089","display_name":"Tsinghua University","ror":"https://ror.org/03cve4549","country_code":"CN","type":"education","lineage":["https://openalex.org/I99065089"]}],"countries":["CN"],"is_corresponding":false,"raw_author_name":"Shi-Min Hu","raw_affiliation_strings":["Tsinghua University, China"],"affiliations":[{"raw_affiliation_string":"Tsinghua University, China","institution_ids":["https://openalex.org/I99065089"]}]}],"institution_assertions":[],"countries_distinct_count":1,"institutions_distinct_count":1,"corresponding_author_ids":[],"corresponding_institution_ids":[],"apc_list":null,"apc_paid":null,"fwci":0.0,"has_fulltext":true,"fulltext_origin":"ngrams","cited_by_count":0,"citation_normalized_percentile":{"value":0.0,"is_in_top_1_percent":false,"is_in_top_10_percent":false},"cited_by_percentile_year":{"min":0,"max":62},"biblio":{"volume":null,"issue":null,"first_page":"288","last_page":"299"},"is_retracted":false,"is_paratext":false,"primary_topic":{"id":"https://openalex.org/T10054","display_name":"Parallel Computing and Optimization Techniques","score":0.9996,"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"}},"topics":[{"id":"https://openalex.org/T10054","display_name":"Parallel Computing and Optimization Techniques","score":0.9996,"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/T10933","display_name":"Real-Time Systems Scheduling","score":0.999,"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/T12127","display_name":"Software System Performance and Reliability","score":0.9988,"subfield":{"id":"https://openalex.org/subfields/1705","display_name":"Computer Networks and Communications"},"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/usable","display_name":"USable","score":0.68169904},{"id":"https://openalex.org/keywords/code","display_name":"Code (set theory)","score":0.5094829}],"concepts":[{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.80370694},{"id":"https://openalex.org/C193702766","wikidata":"https://www.wikidata.org/wiki/Q1414548","display_name":"Concurrency","level":2,"score":0.69312173},{"id":"https://openalex.org/C2780615836","wikidata":"https://www.wikidata.org/wiki/Q2471869","display_name":"USable","level":2,"score":0.68169904},{"id":"https://openalex.org/C138101251","wikidata":"https://www.wikidata.org/wiki/Q213092","display_name":"Thread (computing)","level":2,"score":0.6465757},{"id":"https://openalex.org/C2778562939","wikidata":"https://www.wikidata.org/wiki/Q1298791","display_name":"Synchronization (alternating current)","level":3,"score":0.5950031},{"id":"https://openalex.org/C2776760102","wikidata":"https://www.wikidata.org/wiki/Q5139990","display_name":"Code (set theory)","level":3,"score":0.5094829},{"id":"https://openalex.org/C149635348","wikidata":"https://www.wikidata.org/wiki/Q193040","display_name":"Embedded system","level":1,"score":0.50202346},{"id":"https://openalex.org/C79403827","wikidata":"https://www.wikidata.org/wiki/Q3988","display_name":"Real-time computing","level":1,"score":0.35714638},{"id":"https://openalex.org/C120314980","wikidata":"https://www.wikidata.org/wiki/Q180634","display_name":"Distributed computing","level":1,"score":0.20859522},{"id":"https://openalex.org/C111919701","wikidata":"https://www.wikidata.org/wiki/Q9135","display_name":"Operating system","level":1,"score":0.14304206},{"id":"https://openalex.org/C31258907","wikidata":"https://www.wikidata.org/wiki/Q1301371","display_name":"Computer network","level":1,"score":0.09614766},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.09456059},{"id":"https://openalex.org/C127162648","wikidata":"https://www.wikidata.org/wiki/Q16858953","display_name":"Channel (broadcasting)","level":2,"score":0.0},{"id":"https://openalex.org/C177264268","wikidata":"https://www.wikidata.org/wiki/Q1514741","display_name":"Set (abstract data type)","level":2,"score":0.0},{"id":"https://openalex.org/C136764020","wikidata":"https://www.wikidata.org/wiki/Q466","display_name":"World Wide Web","level":1,"score":0.0}],"mesh":[],"locations_count":1,"locations":[{"is_oa":false,"landing_page_url":"https://doi.org/10.1145/3168809","pdf_url":null,"source":null,"license":null,"license_id":null,"version":null,"is_accepted":false,"is_published":false}],"best_oa_location":null,"sustainable_development_goals":[],"grants":[],"datasets":[],"versions":[],"referenced_works_count":31,"referenced_works":["https://openalex.org/W1521891776","https://openalex.org/W1873898332","https://openalex.org/W1967959506","https://openalex.org/W2013560272","https://openalex.org/W2027179699","https://openalex.org/W2037431929","https://openalex.org/W20534961","https://openalex.org/W2056674090","https://openalex.org/W2058144256","https://openalex.org/W2059204570","https://openalex.org/W2078197548","https://openalex.org/W2081461908","https://openalex.org/W2082000355","https://openalex.org/W2091543666","https://openalex.org/W2100627043","https://openalex.org/W2101161997","https://openalex.org/W2102192199","https://openalex.org/W2109156518","https://openalex.org/W2117475792","https://openalex.org/W2119436055","https://openalex.org/W2128453996","https://openalex.org/W2132800423","https://openalex.org/W2134309469","https://openalex.org/W2143999355","https://openalex.org/W2167744164","https://openalex.org/W2170761533","https://openalex.org/W2243109068","https://openalex.org/W2508576555","https://openalex.org/W2546468634","https://openalex.org/W2547616304","https://openalex.org/W4210712189"],"related_works":["https://openalex.org/W4389422031","https://openalex.org/W4388292429","https://openalex.org/W2982321410","https://openalex.org/W2940029036","https://openalex.org/W2756595502","https://openalex.org/W2392004567","https://openalex.org/W2219281195","https://openalex.org/W2187233292","https://openalex.org/W2046296964","https://openalex.org/W2010789764"],"abstract_inverted_index":{"Original":[0],"device":[1],"drivers":[2,30,161,169,214,224],"are":[3,209],"often":[4],"passive":[5,46,89,114,232],"in":[6,29,179],"common":[7],"operating":[8],"systems,":[9],"and":[10,55,121,129,156,202,212],"they":[11],"should":[12],"correctly":[13],"handle":[14,60],"synchronization":[15,177],"when":[16],"concurrently":[17],"invoked":[18],"by":[19],"multiple":[20],"external":[21],"threads.":[22],"However,":[23],"many":[24,67],"concurrency":[25,37,68,207],"bugs":[26,69],"have":[27,80,142],"occurred":[28],"due":[31],"to":[32,43,59,93,106,124,137,230],"incautious":[33],"synchronization.":[34],"To":[35,183],"solve":[36],"problems,":[38],"active":[39,49,78,110,134,160,168,200,223],"driver":[40,50,79,90,111,115,127,135,164,181,190],"is":[41,86,225],"proposed":[42],"replace":[44],"original":[45,88,113,163,180,231],"driver.":[47],"An":[48],"has":[51],"its":[52],"own":[53],"thread":[54],"does":[56],"not":[57,226],"need":[58],"synchronization,":[61],"thus":[62],"the":[63,176,185,198,213,219],"occurrence":[64],"probability":[65],"of":[66,77,187,221],"can":[70,154,170,215],"be":[71,94],"effectively":[72],"reduced.":[73],"But":[74],"previous":[75],"approaches":[76],"some":[81],"limitations.":[82],"The":[83,149],"biggest":[84],"limitation":[85],"that":[87,152,204],"code":[91,122],"needs":[92],"manually":[95],"rewritten.":[96],"In":[97],"this":[98],"paper,":[99],"we":[100,192],"propose":[101],"a":[102],"practical":[103],"approach,":[104],"AutoPA,":[105],"automatically":[107,155],"generate":[108,158],"efficient":[109],"from":[112,162],"code.":[116,165,182],"AutoPA":[117,144,153,188],"uses":[118,131],"function":[119],"analysis":[120],"instrumentation":[123],"perform":[125,193],"automated":[126],"generation,":[128],"it":[130],"an":[132],"improved":[133],"architecture":[136],"reduce":[138],"performance":[139,220],"degradation.":[140],"We":[141],"evaluated":[143],"on":[145,189,197],"20":[146],"Linux":[147],"drivers.":[148,233],"results":[150],"show":[151],"successfully":[157],"usable":[159],"And":[166,218],"generated":[167,199,222],"work":[171,216],"normally":[172],"with":[173],"or":[174],"without":[175],"primitives":[178],"check":[184],"effect":[186],"reliability,":[191],"fault":[194],"injection":[195],"testing":[196],"drivers,":[201],"find":[203],"all":[205],"injected":[206],"faults":[208],"well":[210],"tolerated":[211],"normally.":[217],"obviously":[227],"degraded":[228],"compared":[229]},"cited_by_api_url":"https://api.openalex.org/works?filter=cites:W2790235418","counts_by_year":[],"updated_date":"2024-12-09T11:10:23.743602","created_date":"2018-03-29"}