CN110941578A - LIO design method and device with DMA function - Google Patents

LIO design method and device with DMA function Download PDF

Info

Publication number
CN110941578A
CN110941578A CN201911175718.3A CN201911175718A CN110941578A CN 110941578 A CN110941578 A CN 110941578A CN 201911175718 A CN201911175718 A CN 201911175718A CN 110941578 A CN110941578 A CN 110941578A
Authority
CN
China
Prior art keywords
control module
dma
lio
data
receiving
Prior art date
Legal status (The legal status 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 status listed.)
Granted
Application number
CN201911175718.3A
Other languages
Chinese (zh)
Other versions
CN110941578B (en
Inventor
不公告发明人
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Chengdu Tianyuxing Technology Co Ltd
Original Assignee
Chengdu Tianyuxing Technology Co Ltd
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 Chengdu Tianyuxing Technology Co Ltd filed Critical Chengdu Tianyuxing Technology Co Ltd
Priority to CN201911175718.3A priority Critical patent/CN110941578B/en
Publication of CN110941578A publication Critical patent/CN110941578A/en
Application granted granted Critical
Publication of CN110941578B publication Critical patent/CN110941578B/en
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR 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
    • G06F13/282Cycle stealing DMA

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Memory System Of A Hierarchy Structure (AREA)

Abstract

The invention discloses a design method and a device of LIO with DMA function, wherein a command analysis and control module is used for analyzing a command sent by a bus and carrying out corresponding processing and control according to the command; the address mapping module is used for converting the FLASH address received from the command analysis and control module into an external equipment address and sending the external equipment address to the receiving and sending control module; the receiving and transmitting control module is used for writing data into the transmitting cache and reading data from the receiving cache; the receiving and transmitting cache is used for matching the transmission speed of a transmission line and an LIO bus between the controller and the FLASH simulator, and the data stored in the receiving and transmitting cache consists of addresses and data; the LIO control module is used for realizing an LIO read-write time sequence; the DMA control module is used for providing an external control interface for DMA transmission; when the LIO is used for communicating with the external equipment, the external equipment can directly exchange data with the system memory without passing through the processor, so that the LIO transmission speed is improved, and the running load of the processor is also reduced.

Description

LIO design method and device with DMA function
Technical Field
The invention relates to the field of data transmission, in particular to a design method and a device of LIO with a DMA function.
Background
Interpretation of terms:
LIO bus: english is called LocalIO, a transmission bus.
DMA: the English full name Direct Memory Access is an interface technology for directly exchanging data with a system Memory without a CPU (central processing unit) by an external device.
In the prior art: some processors, such as Loongson 2F and Loongson 2K1000, are designed with LIO, also known as LocalBus interface, which can be used to connect memory for system boot. In practice, LIO is also often used as a parallel interface for communicating with external devices, but unfortunately none of these processors has designed a DMA controller for LIO, i.e. it is impossible to use DMA to transfer data with external devices when LIO communication is used. No solution to this problem has been seen at present.
Disclosure of Invention
The invention provides a design method and a device of an LIO with a DMA function, and aims to solve the problem that LIO integrated by some processors cannot perform DMA transmission without DMA.
In order to achieve the above object, the present invention provides a method for designing an LIO having a DMA function, the method comprising:
designing a FLASH simulator, wherein the FLASH simulator comprises: the command analysis and control module is used for analyzing the command sent by the bus and performing corresponding processing and control according to the command; the address mapping module is used for converting the FLASH address received from the command analysis and control module into an external equipment address and sending the external equipment address to the receiving and sending control module; the receiving and transmitting control module is used for writing data into the transmitting cache and reading data from the receiving cache;
designing a receiving cache and a sending cache, wherein the receiving cache and the sending cache are used for matching transmission lines between a controller and a FLASH simulator and the transmission speed of an LIO bus, and data stored in the receiving cache and the sending cache are composed of addresses and data;
designing an LIO control module, wherein the LIO control module is used for realizing an LIO read-write time sequence;
the DMA control module is designed and used for providing an external control interface for DMA transmission.
The principle of the invention is as follows: because the LIO has no DMA function, the processor needs to complete the data transmission each time when the processor communicates with the external equipment, thereby greatly increasing the load of the processor and reducing the data transmission speed. The invention provides a design method and a device of LIO with DMA function, when LIO is used for communicating with external equipment, the external equipment can directly exchange data with a system memory without a processor, so that the LIO transmission speed is improved, and the operation load of the processor is also reduced.
Preferably, the command analysis and control module is used for analyzing the command sent by the bus, and if the command analysis and control module analyzes that the command is a write data command, the address is sent to the address mapping module, and the data is sent to the transceiving control module; if the analyzed data is the data reading command, the address is sent to the address mapping module, and the data is read from the transceiving control module.
Preferably, the address and data of the cache are written in by the transceiving control module and read out by the LIO control module; the address of the receiving buffer is written in by the receiving and sending control module and read out by the LIO control module, and the data is written in by the LIO control module and then read out by the receiving and sending control module.
Preferably, the LIO control module is configured to implement an LIO read-write timing sequence, and includes: sending the address and data read from the send cache onto the LIO bus; the LIO bus transmits the address read from the receive buffer and writes the read data to the receive buffer.
Preferably, the external control interface for providing DMA transfer by the DMA control module comprises: a DMA _ REQ interface, a DMA _ ACK interface and a DMA _ DONE interface; the DMA _ REQ is a request signal of an external device, and the DMA control module sends an interrupt signal to the processor after receiving the request signal and informs the processor to start DMA transmission; DMA _ ACK is a reply indication to the request signal indicating that DMA transfer has started; DMA _ DONE indicates DMA transfer completion.
Preferably, the processor is a NAND controller or a PCIE controller, and the LIO interface is extended through a NAND bus or a PCIE bus.
In another aspect, the present invention further provides an LIO interface apparatus with DMA function, where the apparatus includes:
the FLASH simulator comprises: the command analysis and control module is used for analyzing the command sent by the bus and performing corresponding processing and control according to the command; the address mapping module is used for converting the FLASH address received from the command analysis and control module into an external equipment address and sending the external equipment address to the receiving and sending control module; the receiving and transmitting control module is used for writing data into the transmitting cache and reading data from the receiving cache;
the receiving and sending caches are used for matching transmission speed of a transmission line and an LIO bus between the controller and the FLASH simulator, and data stored in the receiving and sending caches consist of addresses and data;
the LIO control module is used for realizing an LIO read-write time sequence;
and the DMA control module is used for providing an external control interface for DMA transmission.
Further, the command analysis and control module is used for analyzing the command sent by the bus, and if the command analysis and control module analyzes that the command is a write data command, the address is sent to the address mapping module, and the data is sent to the transceiving control module; if the analyzed data is the data reading command, the address is sent to the address mapping module, and the data is read from the transceiving control module.
Furthermore, the address and data of the sending buffer are written in by the transceiving control module and read out by the LIO control module; the address of the receiving buffer is written in by the receiving and sending control module and read out by the LIO control module, and the data is written in by the LIO control module and then read out by the receiving and sending control module.
Further, the external control interface for providing DMA transfer by the DMA control module includes: a DMA _ REQ interface, a DMA _ ACK interface and a DMA _ DONE interface; the DMA _ REQ is a request signal of an external device, and the DMA control module sends an interrupt signal to the processor after receiving the request signal and informs the processor to start DMA transmission; DMA _ ACK is a reply indication to the request signal indicating that DMA transfer has started; DMA _ DONE indicates DMA transfer completion.
One or more technical schemes provided by the invention at least have the following technical effects or advantages:
the invention provides a design method and a device of LIO with DMA function, when LIO is used for communicating with external equipment, the external equipment can directly exchange data with a system memory without a processor, so that the LIO transmission speed is improved, and the operation load of the processor is also reduced.
Drawings
The accompanying drawings, which are included to provide a further understanding of the embodiments of the invention and are incorporated in and constitute a part of this application, illustrate embodiments of the invention and together with the description serve to explain the principles of the invention;
FIG. 1 is a hardware block diagram of the present invention;
fig. 2 is a schematic diagram of the NAND FLASH simulator.
Detailed Description
In order that the above objects, features and advantages of the present invention can be more clearly understood, a more particular description of the invention will be rendered by reference to the appended drawings. It should be noted that the embodiments and features of the embodiments of the present application may be combined with each other without conflicting with each other.
In the following description, numerous specific details are set forth in order to provide a thorough understanding of the present invention, however, the present invention may be practiced in other ways than those specifically described and thus the scope of the present invention is not limited by the specific embodiments disclosed below.
It will be understood by those skilled in the art that in the present disclosure, the terms "longitudinal," "lateral," "upper," "lower," "front," "rear," "left," "right," "vertical," "horizontal," "top," "bottom," "inner," "outer," and the like are used in an orientation or positional relationship indicated in the drawings for ease of description and simplicity of description, and do not indicate or imply that the referenced devices or components must be constructed and operated in a particular orientation and thus are not to be considered limiting.
It is understood that the terms "a" and "an" should be interpreted as meaning that a number of one element or element is one in one embodiment, while a number of other elements is one in another embodiment, and the terms "a" and "an" should not be interpreted as limiting the number.
The hardware block diagram of the present invention is shown in fig. 1, and the design idea of the present invention is to extend an LIO interface with a DMA function through a NAND bus by using a processor-integrated NAND controller or a PCIE controller (only the case of a NAND controller is described in the present invention). The parts participating in realizing the function are a NAND controller, a DMA controller, an interrupt controller in the processor, an NAND FLASH simulator designed by FPGA, a transceiving cache, an LIO control module and a DMA control module.
NAND FLASH simulator: the NAND FLASH simulator shown in fig. 2 is composed of function blocks such as a command parsing and control module, an address mapping module, a transceiving control module, etc. The command analysis and control module is responsible for analyzing the command sent by the NAND bus and performing corresponding processing and control according to the command. If the command analysis and control module analyzes that the command is a write data command, the address is sent to the address mapping module, and the data is sent to the transceiving control module; if the command is a read data command, the address is sent to the address mapping module, and the data is read from the transceiving control module. The address mapping module is responsible for converting the NAND FLASH address received from the command parsing and control module into an external device address and transmitting the external device address to the transceiving control module. The receiving and transmitting control module is responsible for writing data into the transmitting cache and reading data from the receiving cache.
Receiving and caching, sending and caching: the receiving and transmitting buffer is used for matching the transmission speed of the NAND BUS and the LIO BUS, and the data stored in the receiving and transmitting buffer consists of addresses and data. The address and data of the sending and caching are written in by the receiving and sending control module and read out by the LIO control module; the address of the receiving buffer is written in by the receiving and sending control module and read out by the LIO control module, and the data is written in by the LIO control module and then read out by the receiving and sending control module.
An LIO control module: the functions comprise the realization of LIO read-write time sequence; sending the address and data read from the issue cache onto the LIO bus; the LIO bus transmits the address read from the receive buffer and writes the read data to the receive buffer.
A DMA control module: an external control interface for DMA transmission is provided, the DMA _ REQ is a request signal of an external device, and the DMA control module sends an interrupt signal to the processor after receiving the request signal and informs the processor to start the DMA transmission; DMA _ ACK is a reply to the request signal indicating that DMA transfer has started; DMA _ DONE indicates DMA transfer completion.
The design idea of the LIO interface with the DMA function is expanded by utilizing a NAND controller or a PCIE controller integrated by a processor through a NAND bus or a PCIE bus.
The invention uses FPGA to expand a design method of LIO interface with DMA function through NAND bus.
The LIO DMA transmission design method provided by the invention solves the problem that the LIO integrated by the processor cannot carry out DMA transmission, not only improves the speed of the processor and external equipment for transmitting data, but also reduces the load of the processor when the data is transmitted.
While preferred embodiments of the present invention have been described, additional variations and modifications in those embodiments may occur to those skilled in the art once they learn of the basic inventive concepts. Therefore, it is intended that the appended claims be interpreted as including preferred embodiments and all such alterations and modifications as fall within the scope of the invention.
It will be apparent to those skilled in the art that various changes and modifications may be made in the present invention without departing from the spirit and scope of the invention. Thus, if such modifications and variations of the present invention fall within the scope of the claims of the present invention and their equivalents, the present invention is also intended to include such modifications and variations.

Claims (10)

1. A method for designing an LIO with DMA function, the method comprising:
designing a FLASH simulator, wherein the FLASH simulator comprises: the command analysis and control module is used for analyzing the command sent by the bus and performing corresponding processing and control according to the command; the address mapping module is used for converting the FLASH address received from the command analysis and control module into an external equipment address and sending the external equipment address to the receiving and sending control module; the receiving and transmitting control module is used for writing data into the transmitting cache and reading data from the receiving cache;
designing a receiving cache and a sending cache, wherein the receiving cache and the sending cache are used for matching transmission lines between a controller and a FLASH simulator and the transmission speed of an LIO bus, and data stored in the receiving cache and the sending cache are composed of addresses and data;
designing an LIO control module, wherein the LIO control module is used for realizing an LIO read-write time sequence;
the DMA control module is designed and used for providing an external control interface for DMA transmission.
2. The method of claim 1, wherein the command parsing and control module is configured to parse a command sent from the bus, and if the command parsing and control module parses the command as a write data command, send the address to the address mapping module and send the data to the transceiving control module; if the analyzed data is the data reading command, the address is sent to the address mapping module, and the data is read from the transceiving control module.
3. The method of claim 1, wherein the address and data of the cache are written by the transceiving control module and read by the LIO control module; the address of the receiving buffer is written in by the receiving and sending control module and read out by the LIO control module, and the data is written in by the LIO control module and then read out by the receiving and sending control module.
4. The method as claimed in claim 1, wherein the LIO control module is configured to implement an LIO read/write sequence, and comprises: sending the address and data read from the send cache onto the LIO bus; the LIO bus transmits the address read from the receive buffer and writes the read data to the receive buffer.
5. The method of claim 1, wherein the DMA control module provides an external control interface for DMA transfer, comprising: a DMA _ REQ interface, a DMA _ ACK interface and a DMA _ DONE interface; the DMA _ REQ is a request signal of an external device, and the DMA control module sends an interrupt signal to the processor after receiving the request signal and informs the processor to start DMA transmission; DMA _ ACK is a reply indication to the request signal indicating that DMA transfer has started; DMA _ DONE indicates DMA transfer completion.
6. The design method of an LIO with DMA function as claimed in claim 1, wherein the processor is a NAND controller or a PCIE controller, and the LIO interface is extended through a NAND bus or a PCIE bus.
7. An LIO interface device with DMA functionality, the device comprising:
the FLASH simulator comprises: the command analysis and control module is used for analyzing the command sent by the bus and performing corresponding processing and control according to the command; the address mapping module is used for converting the FLASH address received from the command analysis and control module into an external equipment address and sending the external equipment address to the receiving and sending control module; the receiving and transmitting control module is used for writing data into the transmitting cache and reading data from the receiving cache;
the receiving and sending caches are used for matching transmission speed of a transmission line and an LIO bus between the controller and the FLASH simulator, and data stored in the receiving and sending caches consist of addresses and data;
the LIO control module is used for realizing an LIO read-write time sequence;
and the DMA control module is used for providing an external control interface for DMA transmission.
8. The LIO interface apparatus having DMA capability of claim 7, wherein the command parsing and control module is configured to parse a command sent from the bus, and if the command parsing and control module parses the command as a write data command, send the address to the address mapping module and send the data to the transceiving control module; if the analyzed data is the data reading command, the address is sent to the address mapping module, and the data is read from the transceiving control module.
9. The LIO interface apparatus with DMA capability of claim 7, wherein the cached address and data are written by the transceiving control module and read by the LIO control module; the address of the receiving buffer is written in by the receiving and sending control module and read out by the LIO control module, and the data is written in by the LIO control module and then read out by the receiving and sending control module.
10. The LIO interface device with DMA function of claim 7, wherein the external control interface for providing DMA transfer by the DMA control module comprises: a DMA _ REQ interface, a DMA _ ACK interface and a DMA _ DONE interface; the DMA _ REQ is a request signal of an external device, and the DMA control module sends an interrupt signal to the processor after receiving the request signal and informs the processor to start DMA transmission; DMA _ ACK is a reply indication to the request signal indicating that DMA transfer has started; DMA _ DONE indicates DMA transfer completion.
CN201911175718.3A 2019-11-26 2019-11-26 LIO design method and device with DMA function Active CN110941578B (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201911175718.3A CN110941578B (en) 2019-11-26 2019-11-26 LIO design method and device with DMA function

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201911175718.3A CN110941578B (en) 2019-11-26 2019-11-26 LIO design method and device with DMA function

Publications (2)

Publication Number Publication Date
CN110941578A true CN110941578A (en) 2020-03-31
CN110941578B CN110941578B (en) 2021-05-04

Family

ID=69908929

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201911175718.3A Active CN110941578B (en) 2019-11-26 2019-11-26 LIO design method and device with DMA function

Country Status (1)

Country Link
CN (1) CN110941578B (en)

Cited By (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN111581136A (en) * 2020-05-08 2020-08-25 上海琪埔维半导体有限公司 DMA controller and implementation method thereof
CN111666237A (en) * 2020-06-08 2020-09-15 王斌 DMA controller with cache management function
CN114267404A (en) * 2022-03-03 2022-04-01 深圳佰维存储科技股份有限公司 eMMC test method, device, readable storage medium and electronic equipment
CN114595171A (en) * 2022-02-21 2022-06-07 杭州加速科技有限公司 PCIE-to-GPIB interface conversion device and use method thereof

Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN101114259A (en) * 2006-07-27 2008-01-30 杭州晟元芯片技术有限公司 Program code memory bank in processor piece based on FLASH structure and method for realizing execution in code piece
CN102207916A (en) * 2011-05-30 2011-10-05 西安电子科技大学 Instruction prefetch-based multi-core shared memory control equipment
CN102609222B (en) * 2012-02-13 2015-03-25 山东华芯半导体有限公司 Flash memory control method based on command descriptors
CN106612141A (en) * 2016-12-20 2017-05-03 北京旋极信息技术股份有限公司 Optical fiber channel protocol general simulation testing card and data interaction method thereof

Patent Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN101114259A (en) * 2006-07-27 2008-01-30 杭州晟元芯片技术有限公司 Program code memory bank in processor piece based on FLASH structure and method for realizing execution in code piece
CN102207916A (en) * 2011-05-30 2011-10-05 西安电子科技大学 Instruction prefetch-based multi-core shared memory control equipment
CN102609222B (en) * 2012-02-13 2015-03-25 山东华芯半导体有限公司 Flash memory control method based on command descriptors
CN106612141A (en) * 2016-12-20 2017-05-03 北京旋极信息技术股份有限公司 Optical fiber channel protocol general simulation testing card and data interaction method thereof

Cited By (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN111581136A (en) * 2020-05-08 2020-08-25 上海琪埔维半导体有限公司 DMA controller and implementation method thereof
CN111666237A (en) * 2020-06-08 2020-09-15 王斌 DMA controller with cache management function
CN111666237B (en) * 2020-06-08 2022-06-28 王斌 DMA controller with cache management function
CN114595171A (en) * 2022-02-21 2022-06-07 杭州加速科技有限公司 PCIE-to-GPIB interface conversion device and use method thereof
CN114267404A (en) * 2022-03-03 2022-04-01 深圳佰维存储科技股份有限公司 eMMC test method, device, readable storage medium and electronic equipment

Also Published As

Publication number Publication date
CN110941578B (en) 2021-05-04

Similar Documents

Publication Publication Date Title
CN110941578B (en) LIO design method and device with DMA function
CN105900076B (en) Data processing system and method for processing multiple transactions
EP3214550B1 (en) Control of persistent memory via a computer bus
US9189441B2 (en) Dual casting PCIE inbound writes to memory and peer devices
US5594882A (en) PCI split transactions utilizing dual address cycle
US8904045B2 (en) Opportunistic improvement of MMIO request handling based on target reporting of space requirements
US20180005670A1 (en) Hybrid lpddr4-dram with cached nvm and flash-nand in multi-chip packages for mobile devices
EP2506150A1 (en) Method and system for entirety mutual access in multi-processor
US11899612B2 (en) Online upgrading method and system for multi-core embedded system
US20030009432A1 (en) Access assurance for remote memory access over network
US20100281201A1 (en) Protocol translation in a data storage system
CN103885908B (en) Data transmission system and method based on external device and accessible registers
CN101963947B (en) Universal serial bus transmission transaction translator and transmission method in large amount
CN113742269B (en) Data transmission method, processing device and medium for EPA device
US9304925B2 (en) Distributed data return buffer for coherence system with speculative address support
US6425071B1 (en) Subsystem bridge of AMBA's ASB bus to peripheral component interconnect (PCI) bus
CN115811509A (en) Bus communication method and related equipment
US6629213B1 (en) Apparatus and method using sub-cacheline transactions to improve system performance
CN100349142C (en) Remote page access method for use in shared virtual memory system and network interface card
CN101976230B (en) Transaction translator of universal serial bus and input request isochronous transaction method
CN112559434B (en) Multi-core processor and inter-core data forwarding method
US6412033B1 (en) Method and apparatus for data and address transmission over a bus
KR20090128605A (en) Inter-processor communication device having burst transfer function, system including the inter-processor communication device, and device driver for operating the inter-processor communication device
KR20080109591A (en) Electric apparatus and data sending/receiving method thereof and slave apparatus and communication method between the plural number of apparatuses
US20050144331A1 (en) On-chip serialized peripheral bus system and operating method thereof

Legal Events

Date Code Title Description
PB01 Publication
PB01 Publication
SE01 Entry into force of request for substantive examination
SE01 Entry into force of request for substantive examination
GR01 Patent grant
GR01 Patent grant