Compiler-directed dynamic memory disambiguation for loop structures

S Alli, C Bailey

Research output: Chapter in Book/Report/Conference proceedingConference contribution

Abstract

The increase in the latencies of memory operations can be attributed to the increasing disparity between the speeds of the processor and memory. This effect is compounded by the fact that superscalar processors may generate several memory operations in a clock cycle, whereas the memory system often only handles one memory operation at a time because caches should preferably be single parted. Thus, there may be several memory operations outstanding concurrently. Processors alleviate the effects of this restriction by issuing loads ahead of stores. However, the memory references must first be disambiguated in order to ensure correct execution of the program. This paper introduces a technique for disambiguating memory references dynamically. This technique enables the compiler to convey information about the program that is available at compile time but cannot be exploited fully due to practical limitations. The processor can then use this information to issue loads ahead of stores.

Original languageEnglish
Title of host publicationPROCEEDINGS OF THE EUROMICRO SYSTEMS ON DIGITAL SYSTEM DESIGN
EditorsH Selvaraj
Place of PublicationLOS ALAMITOS
PublisherIEEE Computer Society
Pages130-134
Number of pages5
ISBN (Print)0-7695-2203-3
DOIs
Publication statusPublished - 2004
EventDSD 2004 - Rennes, France
Duration: 31 Aug 20043 Sept 2004

Conference

ConferenceDSD 2004
Country/TerritoryFrance
CityRennes
Period31/08/043/09/04

Cite this