SG11201703912VA - Apparatus and method for considering spatial locality in loading data elements for execution - Google Patents

Apparatus and method for considering spatial locality in loading data elements for execution

Info

Publication number
SG11201703912VA
SG11201703912VA SG11201703912VA SG11201703912VA SG11201703912VA SG 11201703912V A SG11201703912V A SG 11201703912VA SG 11201703912V A SG11201703912V A SG 11201703912VA SG 11201703912V A SG11201703912V A SG 11201703912VA SG 11201703912V A SG11201703912V A SG 11201703912VA
Authority
SG
Singapore
Prior art keywords
execution
data elements
loading data
spatial locality
considering spatial
Prior art date
Application number
SG11201703912VA
Inventor
Ruchira Sasanka
Elmoustapha Ould-Ahmed-Vall
Original Assignee
Intel Corp
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Intel Corp filed Critical Intel Corp
Publication of SG11201703912VA publication Critical patent/SG11201703912VA/en

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F12/00Accessing, addressing or allocating within memory systems or architectures
    • G06F12/02Addressing or allocation; Relocation
    • G06F12/08Addressing or allocation; Relocation in hierarchically structured memory systems, e.g. virtual memory systems
    • G06F12/0802Addressing of a memory level in which the access to the desired data or data block requires associative addressing means, e.g. caches
    • G06F12/0806Multiuser, multiprocessor or multiprocessing cache systems
    • G06F12/0811Multiuser, multiprocessor or multiprocessing cache systems with multilevel cache hierarchies
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F12/00Accessing, addressing or allocating within memory systems or architectures
    • G06F12/02Addressing or allocation; Relocation
    • G06F12/08Addressing or allocation; Relocation in hierarchically structured memory systems, e.g. virtual memory systems
    • G06F12/0802Addressing of a memory level in which the access to the desired data or data block requires associative addressing means, e.g. caches
    • G06F12/0804Addressing of a memory level in which the access to the desired data or data block requires associative addressing means, e.g. caches with main memory updating
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F12/00Accessing, addressing or allocating within memory systems or architectures
    • G06F12/02Addressing or allocation; Relocation
    • G06F12/08Addressing or allocation; Relocation in hierarchically structured memory systems, e.g. virtual memory systems
    • G06F12/0802Addressing of a memory level in which the access to the desired data or data block requires associative addressing means, e.g. caches
    • G06F12/0875Addressing of a memory level in which the access to the desired data or data block requires associative addressing means, e.g. caches with dedicated cache, e.g. instruction or stack
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F12/00Accessing, addressing or allocating within memory systems or architectures
    • G06F12/02Addressing or allocation; Relocation
    • G06F12/08Addressing or allocation; Relocation in hierarchically structured memory systems, e.g. virtual memory systems
    • G06F12/0802Addressing of a memory level in which the access to the desired data or data block requires associative addressing means, e.g. caches
    • G06F12/0877Cache access modes
    • G06F12/0886Variable-length word access
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/30Arrangements for executing machine instructions, e.g. instruction decode
    • G06F9/30003Arrangements for executing specific machine instructions
    • G06F9/3004Arrangements for executing specific machine instructions to perform operations on memory
    • G06F9/30043LOAD or STORE instructions; Clear instruction
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F2212/00Indexing scheme relating to accessing, addressing or allocation within memory systems or architectures
    • G06F2212/28Using a specific disk cache architecture
    • G06F2212/283Plural cache memories
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F2212/00Indexing scheme relating to accessing, addressing or allocation within memory systems or architectures
    • G06F2212/45Caching of specific data in cache memory
    • G06F2212/452Instruction code

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Software Systems (AREA)
  • Advance Control (AREA)
  • Executing Machine-Instructions (AREA)
  • Memory System Of A Hierarchy Structure (AREA)
SG11201703912VA 2014-12-11 2015-10-09 Apparatus and method for considering spatial locality in loading data elements for execution SG11201703912VA (en)

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US14/567,602 US9811464B2 (en) 2014-12-11 2014-12-11 Apparatus and method for considering spatial locality in loading data elements for execution
PCT/US2015/054963 WO2016093943A1 (en) 2014-12-11 2015-10-09 Apparatus and method for considering spatial locality in loading data elements for execution

Publications (1)

Publication Number Publication Date
SG11201703912VA true SG11201703912VA (en) 2017-06-29

Family

ID=56107894

Family Applications (1)

Application Number Title Priority Date Filing Date
SG11201703912VA SG11201703912VA (en) 2014-12-11 2015-10-09 Apparatus and method for considering spatial locality in loading data elements for execution

Country Status (9)

Country Link
US (1) US9811464B2 (en)
EP (1) EP3230852B1 (en)
JP (1) JP2018502364A (en)
KR (1) KR102585780B1 (en)
CN (1) CN107111554B (en)
BR (1) BR112017010005A2 (en)
SG (1) SG11201703912VA (en)
TW (1) TWI622879B (en)
WO (1) WO2016093943A1 (en)

Families Citing this family (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20170269935A1 (en) * 2011-09-26 2017-09-21 Elmoustapha Ould-Ahmed-Vall Instruction and logic to provide vector loads and stores with strides and masking functionality
US10685290B2 (en) * 2015-12-29 2020-06-16 International Business Machines Corporation Parameter management through RDMA atomic operations
US10262721B2 (en) 2016-03-10 2019-04-16 Micron Technology, Inc. Apparatuses and methods for cache invalidate
US10964869B2 (en) 2017-07-28 2021-03-30 Lg Chem, Ltd. Transparent light emitting element display
US20230089349A1 (en) * 2021-09-21 2023-03-23 Wisconsin Alumni Research Foundation Computer Architecture with Register Name Addressing and Dynamic Load Size Adjustment
CN114356414A (en) * 2021-12-17 2022-04-15 龙芯中科技术股份有限公司 Data loading method and device, electronic equipment and storage medium

Family Cites Families (20)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPH0512114A (en) * 1991-07-04 1993-01-22 Nec Corp Cache memory
US7441110B1 (en) * 1999-12-10 2008-10-21 International Business Machines Corporation Prefetching using future branch path information derived from branch prediction
US7137111B2 (en) 2001-11-28 2006-11-14 Sun Microsystems, Inc. Aggressive prefetch of address chains
US6981099B2 (en) * 2002-12-16 2005-12-27 Sun Microsystems, Inc. Smart-prefetch
US7099999B2 (en) * 2003-09-30 2006-08-29 International Business Machines Corporation Apparatus and method for pre-fetching data to cached memory using persistent historical page table data
EP1622009A1 (en) * 2004-07-27 2006-02-01 Texas Instruments Incorporated JSM architecture and systems
US7200717B2 (en) 2004-10-14 2007-04-03 International Business Machines Corporation Processor, data processing system and method for synchronizing access to data in shared memory
WO2007113757A2 (en) 2006-04-04 2007-10-11 Koninklijke Philips Electronics N.V. System and method for supporting a hot-word-first request policy for a multi-heirarchical memory system
US7529889B2 (en) * 2006-08-14 2009-05-05 Arm Limited Data processing apparatus and method for performing a cache lookup in an energy efficient manner
US8285941B2 (en) * 2008-02-25 2012-10-09 International Business Machines Corporation Enhancing timeliness of cache prefetching
US8171258B2 (en) * 2009-07-21 2012-05-01 Apple Inc. Address generation unit with pseudo sum to accelerate load/store operations
US8825982B2 (en) 2010-06-10 2014-09-02 Global Supercomputing Corporation Storage unsharing
US20120254592A1 (en) 2011-04-01 2012-10-04 Jesus Corbal San Adrian Systems, apparatuses, and methods for expanding a memory source into a destination register and compressing a source register into a destination memory location
US20120254591A1 (en) * 2011-04-01 2012-10-04 Hughes Christopher J Systems, apparatuses, and methods for stride pattern gathering of data elements and stride pattern scattering of data elements
US20130232304A1 (en) * 2012-03-05 2013-09-05 Qualcomm Incorporated Accelerated interleaved memory data transfers in microprocessor-based systems, and related devices, methods, and computer-readable media
US9311247B1 (en) * 2012-03-20 2016-04-12 Marvell International Ltd. Method and apparatus for detecting patterns of memory accesses in a computing system with out-of-order program execution
US8972697B2 (en) * 2012-06-02 2015-03-03 Intel Corporation Gather using index array and finite state machine
US10049061B2 (en) * 2012-11-12 2018-08-14 International Business Machines Corporation Active memory device gather, scatter, and filter
US9367466B2 (en) 2013-02-13 2016-06-14 Advanced Micro Devices, Inc. Conditional prefetching
US9244684B2 (en) * 2013-03-15 2016-01-26 Intel Corporation Limited range vector memory access instructions, processors, methods, and systems

Also Published As

Publication number Publication date
BR112017010005A2 (en) 2018-01-02
CN107111554A (en) 2017-08-29
EP3230852A4 (en) 2018-07-25
TW201636851A (en) 2016-10-16
US20160170883A1 (en) 2016-06-16
EP3230852A1 (en) 2017-10-18
EP3230852B1 (en) 2022-12-21
CN107111554B (en) 2021-01-22
JP2018502364A (en) 2018-01-25
KR102585780B1 (en) 2023-10-10
KR20170096101A (en) 2017-08-23
US9811464B2 (en) 2017-11-07
TWI622879B (en) 2018-05-01
WO2016093943A1 (en) 2016-06-16

Similar Documents

Publication Publication Date Title
HK1211095A1 (en) Method and platform for processing big data
SG11201705180VA (en) Data reading method and apparatus
GB2546906B (en) Data processing apparatus and method using programmable significance data
HK1211354A1 (en) Data processing method and device
EP2991268A4 (en) Data processing method and apparatus
GB2520571B (en) A data processing apparatus and method for performing vector processing
HK1211102A1 (en) Method for processing data and processor
HK1207722A1 (en) Method for sharing data and device thereof
HK1208924A1 (en) Method and device for processing user behavior data
SG11201703912VA (en) Apparatus and method for considering spatial locality in loading data elements for execution
EP2937782A4 (en) Data processing method and device
SG11201707803PA (en) Data handling method and apparatus
EP3082303A4 (en) Method and device for data processing
GB2523823B (en) Data processing apparatus and method for processing vector operands
HK1224042A1 (en) Method and device for reorganizing data
TWI563837B (en) Data processing method and device
EP3026573A4 (en) Data storage method and apparatus
GB201414750D0 (en) Data processing apparatus and method
HK1211098A1 (en) Method and device for processing data
EP3079054A4 (en) Method and apparatus for data access
HK1224045A1 (en) Method and device for loading page
EP3002701A4 (en) Program data updating method and device
PT3110210T (en) Data processing apparatus and method
GB2553969B (en) Methods and data processing apparatus for deblending seismic data
HK1224484A1 (en) Method and apparatus for acquiring positioning data