TW202424763A - Abnormality detection module and method of direct memory access, and electronic system using the same - Google Patents
Abnormality detection module and method of direct memory access, and electronic system using the same Download PDFInfo
- Publication number
- TW202424763A TW202424763A TW111146381A TW111146381A TW202424763A TW 202424763 A TW202424763 A TW 202424763A TW 111146381 A TW111146381 A TW 111146381A TW 111146381 A TW111146381 A TW 111146381A TW 202424763 A TW202424763 A TW 202424763A
- Authority
- TW
- Taiwan
- Prior art keywords
- memory access
- direct memory
- abnormality detection
- signal
- detection device
- Prior art date
Links
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F11/00—Error detection; Error correction; Monitoring
- G06F11/22—Detection or location of defective computer hardware by testing during standby operation or during idle time, e.g. start-up testing
- G06F11/2205—Detection or location of defective computer hardware by testing during standby operation or during idle time, e.g. start-up testing using arrangements specific to the hardware being tested
- G06F11/221—Detection or location of defective computer hardware by testing during standby operation or during idle time, e.g. start-up testing using arrangements specific to the hardware being tested to test buses, lines or interfaces, e.g. stuck-at or open line faults
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F11/00—Error detection; Error correction; Monitoring
- G06F11/22—Detection or location of defective computer hardware by testing during standby operation or during idle time, e.g. start-up testing
- G06F11/2205—Detection or location of defective computer hardware by testing during standby operation or during idle time, e.g. start-up testing using arrangements specific to the hardware being tested
- G06F11/2221—Detection or location of defective computer hardware by testing during standby operation or during idle time, e.g. start-up testing using arrangements specific to the hardware being tested to test input/output devices or peripheral units
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F11/00—Error detection; Error correction; Monitoring
- G06F11/22—Detection or location of defective computer hardware by testing during standby operation or during idle time, e.g. start-up testing
- G06F11/2273—Test methods
Landscapes
- Engineering & Computer Science (AREA)
- General Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Computer Hardware Design (AREA)
- Quality & Reliability (AREA)
- Physics & Mathematics (AREA)
- General Physics & Mathematics (AREA)
- Debugging And Monitoring (AREA)
- Bus Control (AREA)
Abstract
Description
本發明是有關於一種偵測直接記憶體存取(Direct Memory Access,DMA)裝置異常的技術,且特別是一種可以防止直接記憶存取裝置異常導致系統中斷或崩潰並可以讓軟體程式介入對異常的直接記憶存取裝置進行處置的直接記憶體存取異常偵測模組、方法與使用其的電子系統。The present invention relates to a technology for detecting abnormalities of a direct memory access (DMA) device, and in particular to a DMA abnormality detection module, method and electronic system using the same, which can prevent the abnormality of the DMA device from causing system interruption or crash and allow a software program to intervene to handle the abnormal DMA device.
當遇到直接記憶體存取裝置異常時,輕者呈現直接記憶體存取陷阱(DMA trap),嚴重者甚至導致直接記憶體存取溢位(DMA overflow)而出現電子系統崩潰的現象。先前技術的解決方案是透過軟體強制限制直接記憶體存取裝置使用的緩存僅能配置在靜態隨機存取記憶體的最後頁面,且儲存有標記於靜態隨機存取記憶體的最後頁面。When a DMA device is abnormal, a DMA trap may occur at the least, and a DMA overflow may occur at the most serious, causing the electronic system to crash. The solution of the prior art is to restrict the cache used by the DMA device through software to be configured only at the last page of the static random access memory, and store the cache marked at the last page of the static random access memory.
透過先前技術的做法,於每次中斷程序時,電子系統會須使用處理器之算力要去檢查此標記是否被擦除,於判斷標記被擦除後,電子系統跳至直接記憶體存取溢位處理。然而,上述做法並無法同時防止多個直接記憶體存取裝置發生直接記憶體存取溢位,且上述做法是透過軟體額外使用處理器之算力,故可能會導致判斷直接記憶體存取裝置占用過久,使得電子系統直接跳至直接記憶體存取裝置逾時(DMA time out)處理。According to the previous technology, each time the program is interrupted, the electronic system will use the processor's computing power to check whether the mark is erased. After determining that the mark is erased, the electronic system jumps to the direct memory access overflow process. However, the above method cannot prevent multiple direct memory access devices from having direct memory access overflows at the same time, and the above method uses the processor's computing power through software, which may cause the direct memory access device to be judged to be occupied for too long, causing the electronic system to directly jump to the direct memory access device timeout (DMA time out) process.
由上述描述可以理解,本發明需要解決的技術問題是如何以監控直接記憶體存取裝置的線路之方式來解決直接記憶體存取裝置逾時與直接記憶體存取溢位的技術問題。進一步地,本發明的技術方案能夠同時防止多個直接記憶體存取裝置發生逾時與溢位。From the above description, it can be understood that the technical problem to be solved by the present invention is how to solve the technical problem of direct memory access device timeout and direct memory access overflow by monitoring the line of the direct memory access device. Furthermore, the technical solution of the present invention can prevent multiple direct memory access devices from timeout and overflow at the same time.
為了解決上述的習知問題,本發明的實施例提供一種直接記憶體存取異常偵測模組,此直接記憶體存取異常偵測模組包括一個或多個直接記憶體存取異常偵測裝置。直接記憶體存取異常偵測裝置用於偵測其電性連接的直接記憶體存取裝置是否異常。直接記憶體存取異常偵測裝置根據接收到的直接記憶體存取異常偵測致能信號與接收到的直接記憶體存取裝置的簇發信號(burst signal)產生直接記憶體存取裝置存取記憶體的上限位址(upper bound address),並且根據上限位址與接收的上限位址門限值產生直接記憶體存取停止信號給直接記憶體存取裝置與中斷旗標信號。To solve the above-mentioned known problems, an embodiment of the present invention provides a direct memory access abnormality detection module, which includes one or more direct memory access abnormality detection devices. The direct memory access abnormality detection device is used to detect whether the direct memory access device electrically connected to it is abnormal. The direct memory access abnormality detection device generates an upper bound address of the direct memory access device accessing the memory according to the received direct memory access abnormality detection enable signal and the received burst signal of the direct memory access device, and generates a direct memory access stop signal and an interrupt flag signal to the direct memory access device according to the upper bound address and the received upper bound address threshold.
為了解決上述的習知問題,本發明的實施例提供另一種直接記憶體存取異常偵測模組,此直接記憶體存取異常偵測模組包括一個或多個直接記憶體存取異常偵測裝置。直接記憶體存取異常偵測裝置用於偵測其電性連接的直接記憶體存取裝置是否異常。直接記憶體存取異常偵測裝置根據接收到的直接記憶體存取異常偵測致能信號被致能。在直接記憶體存取異常偵測裝置被致能時,基於其接收的時脈計數以產生計數值,若計數值到達計數值門限值,則直接記憶體存取異常偵測裝置將產生直接記憶體存取停止信號給直接記憶體存取裝置與中斷旗標信號。在直接記憶體存取異常偵測裝置被致能時,若直接記憶體存取異常偵測裝置接收到直接記憶體存取裝置的工作完成信號,則將計數值重置歸零。To solve the above-mentioned known problems, an embodiment of the present invention provides another direct memory access abnormality detection module, which includes one or more direct memory access abnormality detection devices. The direct memory access abnormality detection device is used to detect whether the direct memory access device electrically connected to it is abnormal. The direct memory access abnormality detection device is enabled according to the received direct memory access abnormality detection enable signal. When the direct memory access abnormality detection device is enabled, it counts based on the received clock to generate a count value. If the count value reaches the count value threshold, the direct memory access abnormality detection device will generate a direct memory access stop signal to the direct memory access device and an interrupt flag signal. When the direct memory access abnormality detection device is enabled, if the direct memory access abnormality detection device receives a work completion signal from the direct memory access device, the count value is reset to zero.
為了解決上述的習知問題,本發明的實施例還提供一種電子系統,此電子系統包括前述的直接記憶體存取異常偵測模組、一個或多個直接記憶體存取異常偵測裝置以及一個或多個資料處理電路。一個或多個資料處理電路電性連接一個或多個等直接記憶體存取裝置,並用於透過一個或多個等直接記憶體存取裝置存取記憶體的一筆或多筆資料。To solve the above-mentioned known problems, an embodiment of the present invention further provides an electronic system, which includes the above-mentioned direct memory access abnormality detection module, one or more direct memory access abnormality detection devices, and one or more data processing circuits. The one or more data processing circuits are electrically connected to one or more direct memory access devices and are used to access one or more data in the memory through the one or more direct memory access devices.
為了解決上述的習知問題,本發明的實施例更提供一種直接記憶體存取異常偵測方法,此直接記憶體存取異常偵測方法係由直接記憶體存取異常偵測裝置執行,且包括以下步驟。接收直接記憶體存取異常偵測致能信號以致能直接記憶體存取異常偵測裝置,以及接收與直接記憶體存取異常偵測裝置電性連接的直接記憶體存取測裝置的上限位址門限值。於觸發直接記憶體存取測裝置以使直接記憶體存取測裝置工作後,根據直接記憶體存取異常偵測致能信號與直接記憶體存取裝置的簇發信號產生直接記憶體存取裝置存取記憶體的上限位址。根據上限位址與上限位址門限值產生直接記憶體存取停止信號給直接記憶體存取裝置與中斷旗標信號。To solve the above-mentioned known problems, the embodiment of the present invention further provides a direct memory access abnormality detection method, which is performed by a direct memory access abnormality detection device and includes the following steps: receiving a direct memory access abnormality detection enable signal to enable the direct memory access abnormality detection device, and receiving an upper address threshold value of a direct memory access detection device electrically connected to the direct memory access abnormality detection device. After the direct memory access detection device is triggered to work, the upper limit address of the direct memory access device for accessing the memory is generated according to the direct memory access abnormal detection enable signal and the burst signal of the direct memory access device. According to the upper limit address and the upper limit address threshold value, a direct memory access stop signal is generated to the direct memory access device and an interrupt flag signal.
為了解決上述的習知問題,本發明的實施例甚至提供一種直接記憶體存取異常偵測方法,此直接記憶體存取異常偵測方法係由直接記憶體存取異常偵測裝置執行,且包括以下步驟。接收直接記憶體存取異常偵測致能信號以致能直接記憶體存取異常偵測裝置,以及接收與直接記憶體存取異常偵測裝置電性連接的直接記憶體存取測裝置的計數值門限值。於觸發直接記憶體存取測裝置以使直接記憶體存取測裝置工作後,根據直接記憶體存取異常偵測致能信號基於接收的時脈進行計數,以產生計數值。根據計數值與計數值門限值產生直接記憶體存取停止信號給直接記憶體存取裝置與中斷旗標信號。於觸發直接記憶體存取測裝置以使直接記憶體存取測裝置工作後,根據直接記憶體存取異常偵測致能信號與直接記憶體存取測裝置的工作完成信號,將計數值重置歸零。To solve the above-mentioned known problems, an embodiment of the present invention even provides a direct memory access abnormality detection method, which is performed by a direct memory access abnormality detection device and includes the following steps: receiving a direct memory access abnormality detection enable signal to enable the direct memory access abnormality detection device, and receiving a count value threshold value of a direct memory access detection device electrically connected to the direct memory access abnormality detection device. After the direct memory access test device is triggered to make the direct memory access test device work, counting is performed based on the received clock according to the direct memory access abnormal detection enable signal to generate a count value. A direct memory access stop signal and an interrupt flag signal are generated to the direct memory access device according to the count value and the count value threshold. After the direct memory access test device is triggered to make the direct memory access test device work, the count value is reset to zero according to the direct memory access abnormal detection enable signal and the work completion signal of the direct memory access test device.
承上所述,本發明提供之直接記憶體存取異常偵測技術可以再偵測到直接記憶體存取裝置異常時,產生停止信號自動地停止異常的直接記憶體存取裝置,以避免接記憶體存取溢位的技術問題,故不會發生記憶體被過度覆寫(overwrite)與系統崩潰,也不會使得直接記憶體存取裝置停駐(halt)。As mentioned above, the direct memory access abnormality detection technology provided by the present invention can generate a stop signal to automatically stop the abnormal direct memory access device when an abnormality is detected in the direct memory access device, so as to avoid the technical problem of memory access overflow, so that the memory will not be overwritten and the system will not crash, and the direct memory access device will not be stopped.
有鑑於上述待克服的技術問題,本發明實施例提供一種可以在電子系統運行時可以自動處理直接記憶體存取裝置異常的直接記憶體存取異常偵測模組、方法與電子系統。透過本發明提供的直接記憶體存取異常偵測模組、方法與電子系統,可以自動地停止異常的直接記憶體存取裝置,並且避免系統中斷與系統崩潰,且進一步地可以透過軟體程式針對異常進行處置,處置例如包括重置與直接記憶體存取裝置電性連接的資料處理電路、重置直接記憶體存取裝置、禁能直接記憶體存取裝置或通報處置人員進行處理。In view of the above technical problems to be overcome, the embodiments of the present invention provide a direct memory access abnormality detection module, method and electronic system that can automatically handle the abnormality of the direct memory access device when the electronic system is running. Through the direct memory access abnormality detection module, method and electronic system provided by the present invention, the abnormal direct memory access device can be automatically stopped, and system interruption and system crash can be avoided. Furthermore, the abnormality can be handled through a software program, and the handling includes, for example, resetting the data processing circuit electrically connected to the direct memory access device, resetting the direct memory access device, disabling the direct memory access device or notifying the handling personnel for handling.
接著,請參照圖1,圖1是本發明第一實施例之使用直接記憶體存取異常偵測模組的電子系統的方塊圖。電子系統1包括直接記憶體存取異常偵測模組11、一個或多個直接記憶體存取裝置12以及一個或多個資料處理電路(未繪示於圖式中)。直接記憶體存取異常偵測模組11包括一個或多個直接記憶體存取異常偵測裝置111,每一個直接記憶體存取異常偵測裝置111電性連接一個直接記憶體存取裝置12,以達到同時偵測多個直接記憶體存取裝置12是否異常的目的。每一個直接記憶體存取裝置12電性連接一個資料處理電路,資料處理電路用於透過其電性連接的直接記憶體存取裝置存取記憶體的一筆或多筆資料。Next, please refer to FIG. 1, which is a block diagram of an electronic system using a direct memory access abnormality detection module according to a first embodiment of the present invention. The electronic system 1 includes a direct memory access abnormality detection module 11, one or more direct memory access devices 12, and one or more data processing circuits (not shown in the figure). The direct memory access abnormality detection module 11 includes one or more direct memory access
在本發明實施例中,資料處理電路包括圖像資料處理電路、感測器資料處理電路、音訊資料處理電路、控制資料處理電路、封包資料處理電路或週邊裝置資料處理電路,且本發明不以資料處理電路的類型為限制。資料處理電路的類型是跟電子系統1的類型有關,例如電子系統1是伺服器,則多個資料處理電路包括圖像資料處理電路、音訊資料處理電路及封包資料處理電路。記憶體可以是隨機存取記憶體,例如靜態隨機存取記憶體,但本發明不以記憶體的類型為限制,舉例來說,記憶體也可以是快閃記憶體。In the embodiment of the present invention, the data processing circuit includes an image data processing circuit, a sensor data processing circuit, an audio data processing circuit, a control data processing circuit, a packet data processing circuit or a peripheral device data processing circuit, and the present invention is not limited by the type of the data processing circuit. The type of the data processing circuit is related to the type of the electronic system 1. For example, if the electronic system 1 is a server, the multiple data processing circuits include an image data processing circuit, an audio data processing circuit and a packet data processing circuit. The memory can be a random access memory, such as a static random access memory, but the present invention is not limited by the type of memory. For example, the memory can also be a flash memory.
每一個直接記憶體存取異常偵測裝置111用於偵測電性連接的直接記憶體存取裝置12是否異常。直接記憶體存取異常偵測裝置111根據接收到的直接記憶體存取異常偵測致能信號ENCH與接收到的直接記憶體存取裝置12的簇發信號BST產生直接記憶體存取裝置12存取記憶體的上限位址DADD,並且根據上限位址DADD與接收的上限位址門限值ADDTH產生直接記憶體存取停止信號STP給直接記憶體存取裝置12與中斷旗標信號INTFL。Each direct memory access
進一步,簇發信號BST具有直接記憶體存取裝置12存取記憶體的上限位址DADD,其中上限位址DADD是指直接記憶體存取裝置12在記憶體中存取資料之存取資料之多個位址中的最大一者。舉例來說,直接記憶體存取裝置12要在記憶體中連續存取了位址為0x5510、0x5520、0x5530的資料,則直接記憶體存取裝置12發出的簇發信號BST會包括上限位址DADD為0x5530。若上限位址門限值ADDTH為0x5550且上限位址DADD為0x5530,則直接記憶體存取異常偵測裝置111不產生直接記憶體存取停止信號STP與中斷旗標信號INTFL。若上限位址門限值ADDTH為0x5550且上限位址DADD為0x5560,則直接記憶體存取異常偵測裝置111產生直接記憶體存取停止信號STP與中斷旗標信號INTFL,以使直接記憶體存取異常偵測裝置111停止工作。Furthermore, the burst signal BST has an upper limit address DADD for the direct memory access device 12 to access the memory, wherein the upper limit address DADD refers to the largest one of multiple addresses of the access data of the direct memory access device 12 to access the data in the memory. For example, if the direct memory access device 12 wants to access the data of the addresses 0x5510, 0x5520, and 0x5530 in the memory continuously, the burst signal BST issued by the direct memory access device 12 will include the upper limit address DADD of 0x5530. If the upper address threshold value ADDTH is 0x5550 and the upper address DADD is 0x5530, the direct memory access
請接著參照圖1、圖2,圖2是本發明第一實施例之直接記憶體存取異常偵測裝置的方塊圖。圖1的直接記憶體存取異常偵測裝置111能夠以圖2的實現方式來實作,但本發明並不限制直接記憶體存取異常偵測裝置111僅能以圖2的方式來實現。直接記憶體存取異常偵測裝置111包括多個硬體電路,且此多個硬體電路包括邏輯和閘1111、比較器1112與中斷旗標產生器1113。邏輯和閘111電性連接直接記憶體存取裝置12,比較器1112電性連接邏輯和閘1111與直接記憶體存取裝置12,以及中斷旗標產生器1113電性連接比較器1112。Please refer to FIG. 1 and FIG. 2. FIG. 2 is a block diagram of the direct memory access abnormality detection device of the first embodiment of the present invention. The direct memory access
邏輯和閘1111用於接收簇發信號BST與直接記憶體存取異常偵測致能信號ENCH,並對簇發信號BST與直接記憶體存取異常偵測致能信號ENCH進行邏輯和運算,以產生直接記憶體存取裝置12存取記憶體的上限位址DADD。比較器1112用於接收及比較上限位址DADD與上限位址門限值ADDTH,並產生比較結果作為直接記憶體存取停止信號STP給直接記憶體存取裝置12。中斷旗標產生器1113用於根據直接記憶體存取停止信號STP產生中斷旗標信號INTFL。The logic and
進一步地,直接記憶體存取異常偵測裝置111除了包括多個硬體電路之外,更可以具有以軟體程式實現的處置模組。處置模組可用於根據中斷旗標信號對停止的直接記憶體存取裝置12進行處置,其中處置包括重置與直接記憶體存取裝置12電性連接的資料處理電路、重置直接記憶體存取裝置12、禁能直接記憶體存取裝置12或通報處置人員進行處理。Furthermore, in addition to including a plurality of hardware circuits, the direct memory access
請接著參照圖1~圖3,圖3是本發明第一實施例之直接記憶體存取異常偵測方法的流程圖。直接記憶體存取異常偵測方法是由電子系統1所執行。於步驟S301中,直接記憶體存取異常偵測裝置111接收直接記憶體存取異常偵測致能信號ENCH以使直接記憶體存取異常偵測裝置111致能。在步驟S302中,直接記憶體存取異常偵測裝置111接收直接記憶體存取裝置12的上限位址門限值ADDTH。接著,在步驟S303中,電子系統1的直接記憶體存取測裝置12被觸發。直接記憶體存取測裝置12被觸發後,在步驟S304中,直接記憶體存取測裝置12進行工作,以向記憶體存取資料。Please refer to FIG. 1 to FIG. 3 , FIG. 3 is a flow chart of the direct memory access abnormality detection method of the first embodiment of the present invention. The direct memory access abnormality detection method is executed by the electronic system 1. In step S301, the direct memory access
然後,在步驟S305中,直接記憶體存取異常偵測裝置111從接收到的簇發信號BST取得上限位址DADD,並且判斷上限位址DADD是否到達上限位址門限值ADDTH。若上限位址DADD未到達上限位址門限值ADDTH,則繼續執行步驟S306,否則,則執行步驟S307。在步驟S307中,直接記憶體存取異常偵測裝置111產生直接記憶體存取停止信號STP給直接記憶體存取裝置12與中斷旗標信號INTFL,以停止直接記憶體存取裝置12,並讓處置模組對異常的直接記憶體存取裝置12進行處置。在步驟S306中,電子系統1判斷直接記憶體存取裝置12是否結束工作,若是,則直接記憶體存取裝置12結束工作,否則,則執行步驟S304,即直接記憶體存取裝置12繼續進行工作。Then, in step S305, the direct memory access
接者,請參照圖4,圖4是本發明第二實施例之使用直接記憶體存取異常偵測模組的電子系統的方塊圖。電子系統2包包括直接記憶體存取異常偵測模組21、一個或多個直接記憶體存取裝置22以及一個或多個資料處理電路(未繪示於圖式中)。直接記憶體存取異常偵測模組21包括一個或多個直接記憶體存取異常偵測裝置211,每一個直接記憶體存取異常偵測裝置211電性連接一個直接記憶體存取裝置22,以達到同時偵測多個直接記憶體存取裝置22是否異常的目的。每一個直接記憶體存取裝置22電性連接一個資料處理電路,資料處理電路用於透過其電性連接的直接記憶體存取裝置存取記憶體的一筆或多筆資料。資料處理電路如前面所述,可以包括圖像資料處理電路、感測器資料處理電路、音訊資料處理電路、控制資料處理電路、封包資料處理電路或週邊裝置資料處理電路,但本發明不以此為限制。Next, please refer to FIG. 4, which is a block diagram of an electronic system using a direct memory access abnormality detection module according to a second embodiment of the present invention. The electronic system 2 includes a direct memory access abnormality detection module 21, one or more direct memory access devices 22, and one or more data processing circuits (not shown in the figure). The direct memory access abnormality detection module 21 includes one or more direct memory access
每一個直接記憶體存取異常偵測裝置211用於偵測其電性連接的直接記憶體存取裝置22是否異常。直接記憶體存取異常偵測裝置211根據接收到的直接記憶體存取異常偵測致能信號ENCH被致能。在直接記憶體存取異常偵測裝置211被致能時,基於其接收的時脈CLK計數以產生計數值CNT。若計數值CNT到達直接記憶體存取異常偵測裝置211接收的計數值門限值CNTTH,則直接記憶體存取異常偵測裝置211將產生直接記憶體存取停止信號STP給直接記憶體存取裝置22與中斷旗標信號INTFL;若在計數值CNT未到達直接記憶體存取異常偵測裝置211接收的計數值門限值CNTTH前,直接記憶體存取異常偵測裝置211接收到直接記憶體存取裝置22的工作完成信號CP,則直接記憶體存取異常偵測裝置211將計數值CNT重置歸零。簡單地說,圖1的做法是檢測直接記憶體存取裝置12存取記憶體的上限位址,而相較於圖1的做法,圖4的做法是檢測直接記憶體存取裝置22占用的時間是否逾時,以藉此判斷檢測直接記憶體存取裝置22是否有異常。Each direct memory access
之後,請參照圖4、圖5,圖5是本發明第二實施例之直接記憶體存取異常偵測裝置的方塊圖。圖4的直接記憶體存取異常偵測裝置211能夠以圖5的實現方式來實作,但本發明並不限制直接記憶體存取異常偵測裝置211僅能以圖5的方式來實現。直接記憶體存取異常偵測裝置211包括多個硬體電路,且多個硬體電路包括邏輯和閘2111、2112、計數器2113、比較器2114與中斷旗標產生器2115,其中邏輯和閘2111、2112電性連接計數器2113,邏輯和閘2112電性連接直接記憶體存取裝置22,比較器2114電性連接計數器2113、中斷旗標產生器2115與直接記憶體存取裝置22。Next, please refer to Figures 4 and 5. Figure 5 is a block diagram of the direct memory access abnormality detection device of the second embodiment of the present invention. The direct memory access
邏輯和閘2111用於接收直接記憶體存取異常偵測致能信號ENCH與時脈CLK),並對直接記憶體存取異常偵測致能信號ENCH與時脈CLK進行邏輯和運算,以產生計數觸發信號INC。邏輯和閘2112用於接收直接記憶體存取異常偵測致能信號ENCH與工作完成信號CP,並對直接記憶體存取異常偵測致能信號ENCH與工作完成信號CP進行邏輯和運算,以產生計數器重置信號RST。計數器2113用於接收計數觸發信號INC與計數器重置信號RST,根據計數觸發信號INC計數產生出計數值CNT,以及根據計數器重置信號RST將計數值CNT重置歸零。比較器2114用於接收及比較計數值CNT與計數值門限值CNTTH,並產生比較結果作為直接記憶體存取停止信號STP給直接記憶體存取裝置12。中斷旗標產生器2115用於根據直接記憶體存取停止信號STP產生中斷旗標信號INTFL。The logic and
進一步地,直接記憶體存取異常偵測裝置211除了包括多個硬體電路之外,更可以具有以軟體程式實現的處置模組。處置模組可用於根據中斷旗標信號對停止的直接記憶體存取裝置22進行處置,其中處置包括重置與直接記憶體存取裝置22電性連接的資料處理電路、重置直接記憶體存取裝置22、禁能直接記憶體存取裝置22或通報處置人員進行處理。Furthermore, in addition to including a plurality of hardware circuits, the direct memory access
請參照圖4~圖6,圖6是本發明第二實施例之直接記憶體存取異常偵測方法的流程圖。直接記憶體存取異常偵測方法是由電子系統2所執行。於步驟S401中,直接記憶體存取異常偵測裝置211接收直接記憶體存取異常偵測致能信號ENCH以使直接記憶體存取異常偵測裝置211致能。在步驟S402中,直接記憶體存取異常偵測裝置211接收直接記憶體存取裝置22的計數值門限值CNTTH。接著,在步驟S403中,電子系統2的直接記憶體存取測裝置22被觸發。直接記憶體存取測裝置22被觸發後,在步驟S304中,直接記憶體存取測裝置22進行工作,以向記憶體存取資料。Please refer to FIG. 4 to FIG. 6 , FIG. 6 is a flow chart of the direct memory access abnormality detection method of the second embodiment of the present invention. The direct memory access abnormality detection method is executed by the electronic system 2. In step S401, the direct memory access
然後,在步驟S405中,直接記憶體存取異常偵測裝置211基於時脈CLK進行計數,並判斷產生的計數值CNT是否到達計數值門限值CNTTH。若計數值CNT到達計數值門限值CNTTH,則繼續執行步驟S408,否則,則執行步驟S406。在步驟S408中,直接記憶體存取異常偵測裝置211產生直接記憶體存取停止信號STP給直接記憶體存取裝置22與中斷旗標信號INTFL,以停止直接記憶體存取裝置22,並讓處置模組對異常的直接記憶體存取裝置22進行處置。在步驟S406中,電子系統2判斷直接記憶體存取裝置22是否結束工作,若是,則直接記憶體存取裝置12結束工作,並執行步驟S407,否則,則執行步驟S404,即直接記憶體存取裝置22繼續進行工作。在步驟S407,直接記憶體存取異常偵測裝置211接收到直接記憶體存取裝置22的工作完成信號CP,並將計數值CNT重置歸零。Then, in step S405, the direct memory access
綜合以上所述,本發明實施例提供的直接記憶體存取異常偵測模組、方法與使用其的電子系統,可以在直接記憶體存取異常發生時,可讓硬體電路偵測並自動停止直接記憶體存取裝置,從而避免系統崩潰或系統停駐,並達到同時防止多個直接記憶體存取裝置的異常(例如,多個直接記憶體存取裝溢位。另外,上述避免系統崩潰或系統停駐,並達到同時防止多個直接記憶體存取裝置的異常的做法可以不使用軟體與額外處理器之算力介入。另外,在本發明實施例中,也可以選擇性地讓軟體程式介入,以進行錯誤報告,並且進行處置,例如重置與直接記憶體存取裝置22電性連接的資料處理電路或直接記憶體存取裝置22本身,以解除直接記憶體存取裝置22的異常狀態。In summary, the direct memory access abnormality detection module, method and electronic system using the same provided by the embodiments of the present invention can allow the hardware circuit to detect and automatically stop the direct memory access device when a direct memory access abnormality occurs, thereby avoiding system crash or system shutdown, and achieving the goal of preventing abnormalities of multiple direct memory access devices at the same time (for example, multiple direct memory access devices overflow). In addition, the above-mentioned method of avoiding system crash or system shutdown In addition, in the embodiment of the present invention, the software program can be selectively intervened to report errors and perform processing, such as resetting the data processing circuit electrically connected to the direct memory access device 22 or the direct memory access device 22 itself, to release the abnormal state of the direct memory access device 22.
本發明在本文中僅以較佳實施例揭露,然任何熟習本技術領域者應能理解的是,上述實施例僅用於描述本發明,並非用以限定本發明所主張之專利權利範圍。舉凡與上述實施例均等或等效之變化或置換,皆應解讀為涵蓋於本發明之精神或範疇內。因此,本發明之保護範圍應以下述之申請專利範圍所界定者為基準。The present invention is disclosed in this article only with preferred embodiments. However, anyone familiar with the technical field should understand that the above embodiments are only used to describe the present invention and are not used to limit the scope of the patent rights claimed by the present invention. Any changes or substitutions that are equal or equivalent to the above embodiments should be interpreted as being included in the spirit or scope of the present invention. Therefore, the scope of protection of the present invention should be based on the scope defined by the following patent application.
1、2:電子系統
11、21:直接記憶體存取異常偵測模組
111、211:直接記憶體存取異常偵測裝置
1111、2111、2112:邏輯和閘
1112、2114:比較器
1113、2115:中斷旗標產生器
12、22: 直接記憶體存取裝置
2113:計數器
STP:直接記憶體存取停止信號
BST:簇發信號
INTFL:中斷旗標信號
ENCH:直接記憶體存取異常偵測致能信號
DADD:上限位址
ADDTH:上限位址門限值
CLK:時脈
CP:工作完成信號
CNTTH:計數值上限值
CNT:計數值
INC:計數觸發信號
RST:計數器重置信號
S301~S307、S401~S408:步驟
1, 2: Electronic system
11, 21: Direct memory access
為讓本發明之上述和其他目的、特徵、優點與實施例能更明顯易懂,所附圖式之說明如下: 圖1是本發明第一實施例之使用直接記憶體存取異常偵測模組的電子系統的方塊圖; 圖2是本發明第一實施例之直接記憶體存取異常偵測裝置的方塊圖; 圖3是本發明第一實施例之直接記憶體存取異常偵測方法的流程圖; 圖4是本發明第二實施例之使用直接記憶體存取異常偵測模組的電子系統的方塊圖; 圖5是本發明第二實施例之直接記憶體存取異常偵測裝置的方塊圖; 圖6是本發明第二實施例之直接記憶體存取異常偵測方法的流程圖。 In order to make the above and other purposes, features, advantages and embodiments of the present invention more clearly understandable, the attached drawings are described as follows: Figure 1 is a block diagram of an electronic system using a direct memory access abnormality detection module of the first embodiment of the present invention; Figure 2 is a block diagram of a direct memory access abnormality detection device of the first embodiment of the present invention; Figure 3 is a flow chart of a direct memory access abnormality detection method of the first embodiment of the present invention; Figure 4 is a block diagram of an electronic system using a direct memory access abnormality detection module of the second embodiment of the present invention; Figure 5 is a block diagram of a direct memory access abnormality detection device of the second embodiment of the present invention; Figure 6 is a flow chart of the direct memory access abnormality detection method of the second embodiment of the present invention.
1:電子系統 1: Electronic system
11:直接記憶體存取異常偵測模組 11: Direct memory access anomaly detection module
111:直接記憶體存取異常偵測裝置 111: Direct memory access anomaly detection device
12:直接記憶體存取裝置 12: Direct memory access device
STP:直接記憶體存取停止信號 STP: Direct memory access stop signal
BST:簇發信號 BST: Burst Signaling
INTFL:中斷旗標信號 INTFL: Interrupt flag signal
ENCH:直接記憶體存取異常偵測致能信號 ENCH: Direct memory access abnormal detection enable signal
ADDTH:上限位址門限值 ADDTH: Upper address threshold
Claims (10)
Priority Applications (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
TW111146381A TWI856442B (en) | 2022-12-02 | 2022-12-02 | Abnormality detection module and method of direct memory access, and electronic system using the same |
CN202310216570.3A CN118132352A (en) | 2022-12-02 | 2023-03-08 | Direct memory access anomaly detection module, method and electronic system using the same |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
TW111146381A TWI856442B (en) | 2022-12-02 | 2022-12-02 | Abnormality detection module and method of direct memory access, and electronic system using the same |
Publications (2)
Publication Number | Publication Date |
---|---|
TW202424763A true TW202424763A (en) | 2024-06-16 |
TWI856442B TWI856442B (en) | 2024-09-21 |
Family
ID=91234832
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
TW111146381A TWI856442B (en) | 2022-12-02 | 2022-12-02 | Abnormality detection module and method of direct memory access, and electronic system using the same |
Country Status (2)
Country | Link |
---|---|
CN (1) | CN118132352A (en) |
TW (1) | TWI856442B (en) |
Family Cites Families (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US4471427A (en) * | 1981-12-01 | 1984-09-11 | Burroughs Corporation | Direct memory access logic system for a data transfer network |
JP2003050774A (en) * | 2001-08-08 | 2003-02-21 | Matsushita Electric Ind Co Ltd | Data processor and data transfer method |
JP4818793B2 (en) * | 2006-04-20 | 2011-11-16 | ルネサスエレクトロニクス株式会社 | Microcomputer and memory access control method |
MA41915A (en) * | 2015-04-07 | 2018-02-13 | Benjamin Gittins | PROGRAMMABLE MEMORY TRANSFER REQUEST UNITS |
US10235176B2 (en) * | 2015-12-17 | 2019-03-19 | The Charles Stark Draper Laboratory, Inc. | Techniques for metadata processing |
GB2551508B (en) * | 2016-06-20 | 2019-11-27 | Advanced Risc Mach Ltd | Transferring Data between memory system and buffer of a master device |
-
2022
- 2022-12-02 TW TW111146381A patent/TWI856442B/en active
-
2023
- 2023-03-08 CN CN202310216570.3A patent/CN118132352A/en active Pending
Also Published As
Publication number | Publication date |
---|---|
CN118132352A (en) | 2024-06-04 |
TWI856442B (en) | 2024-09-21 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN101989242B (en) | Bus monitor for improving safety of SOC (System on a Chip) as well as realizing method thereof | |
US8099636B2 (en) | System and method for protecting memory stacks using a debug unit | |
EP1708071A1 (en) | Method and system for detection and neutralization of buffer overflow attacks | |
KR101701014B1 (en) | Reporting malicious activity to an operating system | |
JP2006309760A (en) | Monitoring logic and monitoring method for detecting abnormal operation of data processor | |
CN107958164A (en) | Control device | |
EP4533457A1 (en) | Detecting and mitigating memory attacks | |
CN110716818B (en) | Exception handling method, device, hardware protection device and storage medium | |
CN117472623A (en) | Method, device, equipment and storage medium for processing memory fault | |
TWI856442B (en) | Abnormality detection module and method of direct memory access, and electronic system using the same | |
CN211236890U (en) | Detection apparatus for stack overflow and electronic equipment | |
US11914703B2 (en) | Method and data processing system for detecting a malicious component on an integrated circuit | |
US20250045229A1 (en) | Data processing method and system, and related components | |
US20230106636A1 (en) | Tracking memory transactions matching specified pattern | |
US8230286B1 (en) | Processor reliability improvement using automatic hardware disablement | |
US9013207B2 (en) | Method and apparatus for chip self deactivation | |
US20100127767A1 (en) | Integrated Circuit Device Including Noise Filter | |
US20230102435A1 (en) | Interrupt latency and interval tracking | |
TWI700583B (en) | Servo method, servo system, main board and computer readable storage medium | |
US10846162B2 (en) | Secure forking of error telemetry data to independent processing units | |
CN114448666A (en) | Monitoring and defense method, electronic device and system for cache attack | |
US20250068725A1 (en) | Electronic control unit and access control method | |
CN117472622A (en) | Method, device, equipment and storage medium for isolating fault memory | |
WO2021207874A1 (en) | Non-secure software detection apparatus and detection method, and storage medium | |
WO2021062798A1 (en) | Method and device for detecting stack overflow, electronic apparatus, and storage medium |