{"id":"https://openalex.org/W2004881145","doi":"https://doi.org/10.1145/1583991.1584050","title":"A lightweight in-place implementation for software thread-level speculation","display_name":"A lightweight in-place implementation for software thread-level speculation","publication_year":2009,"publication_date":"2009-08-11","ids":{"openalex":"https://openalex.org/W2004881145","doi":"https://doi.org/10.1145/1583991.1584050","mag":"2004881145"},"language":"en","primary_location":{"id":"doi:10.1145/1583991.1584050","is_oa":false,"landing_page_url":"https://doi.org/10.1145/1583991.1584050","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the twenty-first annual symposium on Parallelism in algorithms and architectures","raw_type":"proceedings-article"},"type":"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/A5080735312","display_name":"Cosmin E. Oancea","orcid":"https://orcid.org/0000-0001-5421-6876"},"institutions":[{"id":"https://openalex.org/I241749","display_name":"University of Cambridge","ror":"https://ror.org/013meh722","country_code":"GB","type":"education","lineage":["https://openalex.org/I241749"]}],"countries":["GB"],"is_corresponding":false,"raw_author_name":"Cosmin E. Oancea","raw_affiliation_strings":["The University of Cambridge, Cambridge, United Kingdom"],"raw_orcid":null,"affiliations":[{"raw_affiliation_string":"The University of Cambridge, Cambridge, United Kingdom","institution_ids":["https://openalex.org/I241749"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5004222850","display_name":"Alan Mycroft","orcid":"https://orcid.org/0000-0001-7013-8572"},"institutions":[{"id":"https://openalex.org/I241749","display_name":"University of Cambridge","ror":"https://ror.org/013meh722","country_code":"GB","type":"education","lineage":["https://openalex.org/I241749"]}],"countries":["GB"],"is_corresponding":false,"raw_author_name":"Alan Mycroft","raw_affiliation_strings":["The University of Cambridge, Cambridge, United Kingdom"],"raw_orcid":null,"affiliations":[{"raw_affiliation_string":"The University of Cambridge, Cambridge, United Kingdom","institution_ids":["https://openalex.org/I241749"]}]},{"author_position":"last","author":{"id":"https://openalex.org/A5018504427","display_name":"Tim Harris","orcid":"https://orcid.org/0000-0001-9628-130X"},"institutions":[{"id":"https://openalex.org/I1290206253","display_name":"Microsoft (United States)","ror":"https://ror.org/00d0nc645","country_code":"US","type":"company","lineage":["https://openalex.org/I1290206253"]},{"id":"https://openalex.org/I4210164937","display_name":"Microsoft Research (United Kingdom)","ror":"https://ror.org/05k87vq12","country_code":"GB","type":"company","lineage":["https://openalex.org/I1290206253","https://openalex.org/I4210164937"]}],"countries":["GB","US"],"is_corresponding":false,"raw_author_name":"Tim Harris","raw_affiliation_strings":["Microsoft Research, Cambridge, United Kingdom","Microsoft Research, Cambridge, United Kingdom ("],"raw_orcid":null,"affiliations":[{"raw_affiliation_string":"Microsoft Research, Cambridge, United Kingdom","institution_ids":["https://openalex.org/I4210164937"]},{"raw_affiliation_string":"Microsoft Research, Cambridge, United Kingdom (","institution_ids":["https://openalex.org/I1290206253"]}]}],"institutions":[],"countries_distinct_count":2,"institutions_distinct_count":3,"corresponding_author_ids":[],"corresponding_institution_ids":[],"apc_list":null,"apc_paid":null,"fwci":6.7021,"has_fulltext":false,"cited_by_count":69,"citation_normalized_percentile":{"value":0.97142316,"is_in_top_1_percent":false,"is_in_top_10_percent":true},"cited_by_percentile_year":{"min":90,"max":100},"biblio":{"volume":null,"issue":null,"first_page":"223","last_page":"232"},"is_retracted":false,"is_paratext":false,"is_xpac":false,"primary_topic":{"id":"https://openalex.org/T10054","display_name":"Parallel Computing and Optimization Techniques","score":1.0,"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":1.0,"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/T10772","display_name":"Distributed systems and fault tolerance","score":0.9998999834060669,"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"}},{"id":"https://openalex.org/T10101","display_name":"Cloud Computing and Resource Management","score":0.9983000159263611,"subfield":{"id":"https://openalex.org/subfields/1710","display_name":"Information Systems"},"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/speculation","display_name":"Speculation","score":0.8142744302749634},{"id":"https://openalex.org/keywords/computer-science","display_name":"Computer science","score":0.7324994802474976},{"id":"https://openalex.org/keywords/thread","display_name":"Thread (computing)","score":0.6589357256889343},{"id":"https://openalex.org/keywords/speculative-multithreading","display_name":"Speculative multithreading","score":0.6335736513137817},{"id":"https://openalex.org/keywords/software","display_name":"Software","score":0.46064192056655884},{"id":"https://openalex.org/keywords/operating-system","display_name":"Operating system","score":0.3952064514160156},{"id":"https://openalex.org/keywords/parallel-computing","display_name":"Parallel computing","score":0.3518630862236023},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.3350684344768524},{"id":"https://openalex.org/keywords/multithreading","display_name":"Multithreading","score":0.20630067586898804},{"id":"https://openalex.org/keywords/business","display_name":"Business","score":0.11062926054000854}],"concepts":[{"id":"https://openalex.org/C47941915","wikidata":"https://www.wikidata.org/wiki/Q107885","display_name":"Speculation","level":2,"score":0.8142744302749634},{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.7324994802474976},{"id":"https://openalex.org/C138101251","wikidata":"https://www.wikidata.org/wiki/Q213092","display_name":"Thread (computing)","level":2,"score":0.6589357256889343},{"id":"https://openalex.org/C15296174","wikidata":"https://www.wikidata.org/wiki/Q7575343","display_name":"Speculative multithreading","level":4,"score":0.6335736513137817},{"id":"https://openalex.org/C2777904410","wikidata":"https://www.wikidata.org/wiki/Q7397","display_name":"Software","level":2,"score":0.46064192056655884},{"id":"https://openalex.org/C111919701","wikidata":"https://www.wikidata.org/wiki/Q9135","display_name":"Operating system","level":1,"score":0.3952064514160156},{"id":"https://openalex.org/C173608175","wikidata":"https://www.wikidata.org/wiki/Q232661","display_name":"Parallel computing","level":1,"score":0.3518630862236023},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.3350684344768524},{"id":"https://openalex.org/C201410400","wikidata":"https://www.wikidata.org/wiki/Q1064412","display_name":"Multithreading","level":3,"score":0.20630067586898804},{"id":"https://openalex.org/C144133560","wikidata":"https://www.wikidata.org/wiki/Q4830453","display_name":"Business","level":0,"score":0.11062926054000854},{"id":"https://openalex.org/C10138342","wikidata":"https://www.wikidata.org/wiki/Q43015","display_name":"Finance","level":1,"score":0.0}],"mesh":[],"locations_count":2,"locations":[{"id":"doi:10.1145/1583991.1584050","is_oa":false,"landing_page_url":"https://doi.org/10.1145/1583991.1584050","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the twenty-first annual symposium on Parallelism in algorithms and architectures","raw_type":"proceedings-article"},{"id":"pmh:oai:CiteSeerX.psu:10.1.1.157.4670","is_oa":false,"landing_page_url":"http://citeseerx.ist.psu.edu/viewdoc/summary?doi=10.1.1.157.4670","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"http://research.microsoft.com/~tharris/papers/2009-spaa.pdf","raw_type":"text"}],"best_oa_location":null,"sustainable_development_goals":[],"awards":[],"funders":[],"has_content":{"pdf":false,"grobid_xml":false},"content_urls":null,"referenced_works_count":30,"referenced_works":["https://openalex.org/W16598917","https://openalex.org/W1510727076","https://openalex.org/W1517933564","https://openalex.org/W1598901422","https://openalex.org/W1988777345","https://openalex.org/W1995825057","https://openalex.org/W2014860543","https://openalex.org/W2042008201","https://openalex.org/W2051533028","https://openalex.org/W2080457852","https://openalex.org/W2091722458","https://openalex.org/W2094222793","https://openalex.org/W2095703459","https://openalex.org/W2100184706","https://openalex.org/W2106018697","https://openalex.org/W2111678563","https://openalex.org/W2111946621","https://openalex.org/W2117559535","https://openalex.org/W2121118021","https://openalex.org/W2126501440","https://openalex.org/W2133734540","https://openalex.org/W2136798749","https://openalex.org/W2136958529","https://openalex.org/W2143535196","https://openalex.org/W2148255965","https://openalex.org/W2214214281","https://openalex.org/W2296006986","https://openalex.org/W3145483441","https://openalex.org/W4238982306","https://openalex.org/W4285719527"],"related_works":["https://openalex.org/W2023832055","https://openalex.org/W2179235191","https://openalex.org/W2127642645","https://openalex.org/W2759759","https://openalex.org/W4254495365","https://openalex.org/W1964490256","https://openalex.org/W2036922283","https://openalex.org/W4312332351","https://openalex.org/W2754302417","https://openalex.org/W2527311517"],"abstract_inverted_index":{"Thread-level":[0],"speculation":[1],"(TLS)":[2],"is":[3],"a":[4,10,38,60,133,170,239,242],"technique":[5],"that":[6,140,161],"allows":[7],"parts":[8],"of":[9,37,62,191,224,227,230,241],"sequential":[11,30],"program":[12],"to":[13,26,40,90,108,142,150,187,196],"be":[14,99,151],"executed":[15],"in":[16,42,153,182],"parallel.":[17],"TLS":[18,64,76,96],"ensures":[19],"the":[20,27,91,175,189,225,231],"parallel":[21,43,235],"program\u2019s":[22],"behaviour":[23],"remains":[24],"true":[25],"language\u2019s":[28],"original":[29],"semantics;":[31],"for":[32,137,177,233],"example,":[33],"allowing":[34],"multiple":[35],"iterations":[36],"loop":[39],"run":[41],"if":[44,82],"there":[45],"are":[46],"no":[47],"conflicts":[48,55],"between":[49],"them.":[50],"Conventional":[51],"software-TLS":[52,135],"algorithms":[53],"detect":[54],"dynamically.":[56],"They":[57],"suffer":[58],"from":[59,213],"number":[61],"problems.":[63,145],"implementations":[65,77,97],"can":[66,78,84,98],"impose":[67],"large":[68],"storage":[69],"overheads":[70],"caused":[71],"by":[72],"buffering":[73],"speculative":[74,87,102,111,115,148],"work.":[75],"offer":[79],"disappointing":[80],"scalability,":[81],"threads":[83],"only":[85],"commit":[86],"work":[88,149],"back":[89],"\u201creal":[92],"\u201d":[93],"heap":[94],"sequentially.":[95],"slow":[100],"because":[101,114],"reads":[103,119,162],"must":[104],"consult":[105],"look-aside":[106],"tables":[107],"see":[109,164],"earlier":[110,165],"writes,":[112],"or":[113,128,179],"operations":[116],"replace":[117],"normal":[118],"and":[120,159,195,216],"writes":[121],"with":[122,199],"expensive":[123],"synchronisation":[124],"primitives":[125],"(e.g.":[126],"CAS":[127,178],"memory":[129,180],"fences).":[130],"We":[131,146,167,173,185,203,218,237],"present":[132],"streamlined":[134],"algorithm":[136],"mostlyparallel":[138],"loops":[139],"aims":[141],"avoid":[143,157,168,174],"these":[144],"allow":[147],"performed":[152],"place,":[154],"so":[155,160],"we":[156],"buffering,":[158],"naturally":[163],"writes.":[166],"needing":[169],"serialcommit":[171],"protocol.":[172],"need":[176],"fences":[181],"common":[183],"operations.":[184],"strive":[186],"reduce":[188],"size":[190],"TLS-related":[192],"conflict-detection":[193],"state,":[194],"interact":[197],"well":[198],"typical":[200],"data-cache":[201],"implementations.":[202],"evaluate":[204],"our":[205],"implementation":[206],"on":[207,245],"off-the-shelf":[208],"hardware":[209],"using":[210],"seven":[211],"applications":[212],"SciMark2,":[214],"BYTEmark":[215],"JOlden.":[217],"achieve":[219,238],"an":[220,246],"average":[221],"77":[222],"%":[223],"speed-up":[226,244],"manuallyparallelized":[228],"versions":[229],"benchmarks":[232],"fully":[234],"loops.":[236],"maximum":[240],"5.8x":[243],"8-core":[247],"machine.":[248]},"counts_by_year":[{"year":2024,"cited_by_count":1},{"year":2022,"cited_by_count":1},{"year":2020,"cited_by_count":2},{"year":2019,"cited_by_count":1},{"year":2018,"cited_by_count":1},{"year":2017,"cited_by_count":1},{"year":2016,"cited_by_count":8},{"year":2015,"cited_by_count":13},{"year":2014,"cited_by_count":4},{"year":2013,"cited_by_count":12},{"year":2012,"cited_by_count":9}],"updated_date":"2026-06-11T09:08:48.828518","created_date":"2025-10-10T00:00:00"}
