TWI738737B - 使用伴隨記憶體預配置的緩衝器映射方案的電腦實施方法及控制資料傳遞的裝置 - Google Patents

使用伴隨記憶體預配置的緩衝器映射方案的電腦實施方法及控制資料傳遞的裝置 Download PDF

Info

Publication number
TWI738737B
TWI738737B TW106107679A TW106107679A TWI738737B TW I738737 B TWI738737 B TW I738737B TW 106107679 A TW106107679 A TW 106107679A TW 106107679 A TW106107679 A TW 106107679A TW I738737 B TWI738737 B TW I738737B
Authority
TW
Taiwan
Prior art keywords
application
application program
operating system
physical address
address
Prior art date
Application number
TW106107679A
Other languages
English (en)
Chinese (zh)
Other versions
TW201738756A (zh
Inventor
馬諾基 K 古素拉
文卡塔 巴努 普拉卡什 葛拉普迪
Original Assignee
南韓商三星電子股份有限公司
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 南韓商三星電子股份有限公司 filed Critical 南韓商三星電子股份有限公司
Publication of TW201738756A publication Critical patent/TW201738756A/zh
Application granted granted Critical
Publication of TWI738737B publication Critical patent/TWI738737B/zh

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING OR CALCULATING; 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/46Multiprogramming arrangements
    • G06F9/54Interprogram communication
    • G06F9/544Buffers; Shared memory; Pipes
    • GPHYSICS
    • G06COMPUTING OR CALCULATING; COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F12/00Accessing, addressing or allocating within memory systems or architectures
    • G06F12/02Addressing or allocation; Relocation
    • G06F12/0223User address space allocation, e.g. contiguous or non contiguous base addressing
    • G06F12/023Free address space management
    • GPHYSICS
    • G06COMPUTING OR CALCULATING; COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F12/00Accessing, addressing or allocating within memory systems or architectures
    • G06F12/02Addressing or allocation; Relocation
    • G06F12/0223User address space allocation, e.g. contiguous or non contiguous base addressing
    • G06F12/023Free address space management
    • G06F12/0238Memory management in non-volatile memory, e.g. resistive RAM or ferroelectric memory
    • G06F12/0246Memory management in non-volatile memory, e.g. resistive RAM or ferroelectric memory in block erasable memory, e.g. flash memory
    • GPHYSICS
    • G06COMPUTING OR CALCULATING; 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/10Address translation
    • G06F12/1081Address translation for peripheral access to main memory, e.g. direct memory access [DMA]
    • GPHYSICS
    • G06COMPUTING OR CALCULATING; COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F13/00Interconnection of, or transfer of information or other signals between, memories, input/output devices or central processing units
    • G06F13/14Handling requests for interconnection or transfer
    • G06F13/16Handling requests for interconnection or transfer for access to memory bus
    • G06F13/1668Details of memory controller
    • G06F13/1673Details of memory controller using buffers
    • GPHYSICS
    • G06COMPUTING OR CALCULATING; COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F13/00Interconnection of, or transfer of information or other signals between, memories, input/output devices or central processing units
    • G06F13/14Handling requests for interconnection or transfer
    • G06F13/20Handling requests for interconnection or transfer for access to input/output bus
    • G06F13/28Handling requests for interconnection or transfer for access to input/output bus using burst mode transfer, e.g. direct memory access DMA, cycle steal
    • GPHYSICS
    • G06COMPUTING OR CALCULATING; COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F2212/00Indexing scheme relating to accessing, addressing or allocation within memory systems or architectures
    • G06F2212/10Providing a specific technical effect
    • G06F2212/1041Resource optimization
    • G06F2212/1044Space efficiency improvement
    • GPHYSICS
    • G06COMPUTING OR CALCULATING; COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F2212/00Indexing scheme relating to accessing, addressing or allocation within memory systems or architectures
    • G06F2212/65Details of virtual memory and virtual address translation
    • G06F2212/656Address space sharing

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Software Systems (AREA)
  • Memory System Of A Hierarchy Structure (AREA)
  • Memory System (AREA)
  • Bus Control (AREA)
TW106107679A 2016-04-22 2017-03-09 使用伴隨記憶體預配置的緩衝器映射方案的電腦實施方法及控制資料傳遞的裝置 TWI738737B (zh)

Applications Claiming Priority (4)

Application Number Priority Date Filing Date Title
US201662326537P 2016-04-22 2016-04-22
US62/326,537 2016-04-22
US15/333,010 2016-10-24
US15/333,010 US10380012B2 (en) 2016-04-22 2016-10-24 Buffer mapping scheme involving pre-allocation of memory

Publications (2)

Publication Number Publication Date
TW201738756A TW201738756A (zh) 2017-11-01
TWI738737B true TWI738737B (zh) 2021-09-11

Family

ID=60090251

Family Applications (1)

Application Number Title Priority Date Filing Date
TW106107679A TWI738737B (zh) 2016-04-22 2017-03-09 使用伴隨記憶體預配置的緩衝器映射方案的電腦實施方法及控制資料傳遞的裝置

Country Status (5)

Country Link
US (1) US10380012B2 (enExample)
JP (1) JP6757289B2 (enExample)
KR (1) KR102814052B1 (enExample)
CN (1) CN107305509B (enExample)
TW (1) TWI738737B (enExample)

Families Citing this family (11)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN110119637B (zh) * 2018-02-07 2023-04-14 联发科技股份有限公司 硬件控制方法与硬件控制系统
US11792307B2 (en) 2018-03-28 2023-10-17 Apple Inc. Methods and apparatus for single entity buffer pool management
US11829303B2 (en) 2019-09-26 2023-11-28 Apple Inc. Methods and apparatus for device driver operation in non-kernel space
US11558348B2 (en) 2019-09-26 2023-01-17 Apple Inc. Methods and apparatus for emerging use case support in user space networking
US11606302B2 (en) 2020-06-12 2023-03-14 Apple Inc. Methods and apparatus for flow-based batching and processing
US11775359B2 (en) 2020-09-11 2023-10-03 Apple Inc. Methods and apparatuses for cross-layer processing
US11954540B2 (en) 2020-09-14 2024-04-09 Apple Inc. Methods and apparatus for thread-level execution in non-kernel space
US11799986B2 (en) 2020-09-22 2023-10-24 Apple Inc. Methods and apparatus for thread level execution in non-kernel space
US11876719B2 (en) 2021-07-26 2024-01-16 Apple Inc. Systems and methods for managing transmission control protocol (TCP) acknowledgements
US11882051B2 (en) 2021-07-26 2024-01-23 Apple Inc. Systems and methods for managing transmission control protocol (TCP) acknowledgements
EP4617883A1 (en) * 2022-12-14 2025-09-17 Samsung Electronics Co., Ltd. Electronic device and memory management method

Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US7979645B2 (en) * 2007-09-14 2011-07-12 Ricoh Company, Limited Multiprocessor system for memory mapping of processing nodes
US20150095610A1 (en) * 2013-10-01 2015-04-02 Applied Micro Circuits Corporation Multi-stage address translation for a computing device
US9092426B1 (en) * 2011-01-03 2015-07-28 Applied Micro Circuts Corporation Zero-copy direct memory access (DMA) network-attached storage (NAS) file system block writing
US9256474B2 (en) * 2011-03-16 2016-02-09 Tintri Inc. Automatically aligning virtual blocks to physical blocks

Family Cites Families (13)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
DE69524916T2 (de) 1994-10-11 2002-11-14 Sun Microsystems, Inc. Verfahren und Vorrichtung zur Datenübertragung im Bereich der Rechnersysteme
US7493465B2 (en) * 2004-05-17 2009-02-17 Oracle International Corporation Method and system for extended memory with user mode input/output operations
US20050273571A1 (en) * 2004-06-02 2005-12-08 Lyon Thomas L Distributed virtual multiprocessor
US7590777B2 (en) 2004-12-10 2009-09-15 International Business Machines Corporation Transferring data between system and storage in a shared buffer
US7739474B2 (en) * 2006-02-07 2010-06-15 International Business Machines Corporation Method and system for unifying memory access for CPU and IO operations
US20070255866A1 (en) 2006-05-01 2007-11-01 Eliezer Aloni Method and system for a user space TCP offload engine (TOE)
US8015388B1 (en) * 2006-08-04 2011-09-06 Vmware, Inc. Bypassing guest page table walk for shadow page table entries not present in guest page table
US8166194B2 (en) 2006-12-13 2012-04-24 Microsoft Corporation Lock-free shared audio buffer
US8521966B2 (en) * 2007-11-16 2013-08-27 Vmware, Inc. VM inter-process communications
US8504744B2 (en) 2010-10-28 2013-08-06 Alcatel Lucent Lock-less buffer management scheme for telecommunication network applications
US8909727B2 (en) 2010-11-24 2014-12-09 International Business Machines Corporation RDMA read destination buffers mapped onto a single representation
US8868867B2 (en) 2011-09-15 2014-10-21 The Regents Of The University Of California Method for reducing latency of accessing data stored in a file system on a computer storage device by caching file system permission information in the computer storage device
CN102402487B (zh) * 2011-11-15 2014-10-22 北京天融信科技股份有限公司 一种零拷贝接收报文的方法和系统

Patent Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US7979645B2 (en) * 2007-09-14 2011-07-12 Ricoh Company, Limited Multiprocessor system for memory mapping of processing nodes
US9092426B1 (en) * 2011-01-03 2015-07-28 Applied Micro Circuts Corporation Zero-copy direct memory access (DMA) network-attached storage (NAS) file system block writing
US9256474B2 (en) * 2011-03-16 2016-02-09 Tintri Inc. Automatically aligning virtual blocks to physical blocks
US20150095610A1 (en) * 2013-10-01 2015-04-02 Applied Micro Circuits Corporation Multi-stage address translation for a computing device

Also Published As

Publication number Publication date
CN107305509A (zh) 2017-10-31
CN107305509B (zh) 2023-07-04
US10380012B2 (en) 2019-08-13
JP2017194964A (ja) 2017-10-26
KR102814052B1 (ko) 2025-05-28
JP6757289B2 (ja) 2020-09-16
US20170308460A1 (en) 2017-10-26
TW201738756A (zh) 2017-11-01
KR20170121045A (ko) 2017-11-01

Similar Documents

Publication Publication Date Title
TWI738737B (zh) 使用伴隨記憶體預配置的緩衝器映射方案的電腦實施方法及控制資料傳遞的裝置
US8719464B2 (en) Efficient memory and resource management
US20130145055A1 (en) Peripheral Memory Management
CN112612574B (zh) 输入输出设备的内存访问管理单元、系统及地址转换方法
US8738890B2 (en) Coupled symbiotic operating system
US20130145051A1 (en) Direct Device Assignment
US10372336B2 (en) File access method, system, and host
US20050144422A1 (en) Virtual to physical address translation
CN105830059A (zh) 文件访问方法、装置及存储设备
US10467179B2 (en) Method and device for sharing PCIe I/O device, and interconnection system
US10671419B2 (en) Multiple input-output memory management units with fine grained device scopes for virtual machines
US10754679B2 (en) Method and apparatus for handling network I/O device virtualization
US20160275042A1 (en) Zero-copy data transmission system
US10140214B2 (en) Hypervisor translation bypass by host IOMMU with virtual machine migration support
US20160098367A1 (en) Logical-to-physical block mapping inside the disk controller: accessing data objects without operating system intervention
WO2017219250A1 (zh) 一种虚拟机内存的映射方法、装置及数据传输设备
CN104468307B (zh) 一种基于虚拟机的实时通信系统
JP2021536643A (ja) ハイブリッドメモリシステムインタフェース
WO2012058364A2 (en) Secure partitioning with shared input/output
US20190102321A1 (en) Techniques to provide access protection to shared virtual memory
JP7196858B2 (ja) 入出力実行装置、デバイス仮想化システム、入出力実行方法、および、プログラム
US20220335109A1 (en) On-demand paging support for confidential computing
CN101073062A (zh) 在共享缓冲区中在系统和存储器之间传送数据
US7900016B2 (en) Full virtualization of resources across an IP interconnect
CA2816441A1 (en) Secure partitioning with shared input/output