This application claims the priority under 35 U.S.C. § 119 to Korean Patent Application No. 10-2015-0078668, filed on Jun. 3, 2015, the entire contents of which are incorporated herein by reference in their entirety.
The inventive concept relates to a mobile device and an operation method thereof, and more particularly, to a mobile device and an operation method thereof which are capable of reducing power consumption or improving operation performance.
With requests for downsizing and high-performance of mobile devices, such as smart phones, tablet personal computers, and wearable devices, power consumption and memory bandwidths have become an issue in mobile devices.
The inventive concept provides a mobile device and an operation method thereof capable of reducing power consumption or improving operation performance by controlling ineffective operations.
According to an aspect of the inventive concept, there is provided an operation method including in response to an initialization request with respect to a memory device of the mobile device, setting a first type area of the memory device, which is not initialized as a first value, and responding that the initializing request is completed with respect to the first type area without completing the initialization of the first type area.
According to another aspect of the inventive concept, there is provided a mobile device including a central processor configured to perform data processing for controlling the mobile device, a memory device configured to store data required for an operation of the central processor, and a zero data processor configured to generate a response for an operation command accompanied by an access to a first type area of the memory device without accessing the memory device and to transmit the generated response to the central processor, wherein the first type area is an area which is not initialized as zero data in response to an initialization request generated from the central processor.
According to another aspect of the inventive concept, there is provided a wearable device including a central processor, a memory device wherein all areas of the memory device, except a first type area, are initialized in response to an initialization request received from the central processor, and a zero data processor configured to generate a response for an operation command accompanied by an access to the first type area of the memory device without accessing the memory device and to transmit the generated response to the central processor.
Example embodiments of the inventive concept will be more clearly understood from the following detailed description taken in conjunction with the accompanying drawings in which:
Reference will now be made in detail to example embodiments, examples of which are illustrated in the accompanying drawings, wherein like reference numerals refer to like elements throughout. Expressions such as “at least one of,” when preceding a list of elements, modify the entire list of elements and do not modify the individual elements of the list.
It will be understood that, although the terms first, second, etc. may be used herein to describe various elements, these elements should not be limited by these terms. These terms are only used to distinguish one element from another. For example, a first signal could be termed a second signal, and, similarly, a second signal could be termed a first signal without departing from the teachings of the disclosure.
The terminology used herein is for the purpose of describing particular embodiments only and is not intended to be limiting of the invention. As used herein, the singular forms “a”, “an” and “the” are intended to include the plural forms as well, unless the context clearly indicates otherwise. It will be further understood that the terms “comprises” and/or “comprising,” or “includes” and/or “including” when used in this specification, specify the presence of stated features, regions, integers, steps, operations, elements, and/or components, but do not preclude the presence or addition of one or more other features, regions, integers, steps, operations, elements, components, and/or groups thereof.
As is traditional in the field of the inventive concepts, embodiments may be described and illustrated in terms of blocks which carry out a described function or functions. These blocks, which may be referred to herein as units or modules or the like, are physically implemented by analog and/or digital circuits such as logic gates, integrated circuits, microprocessors, microcontrollers, memory circuits, passive electronic components, active electronic components, optical components, hardwired circuits and the like, and may optionally be driven by firmware and/or software. The circuits may, for example, be embodied in one or more semiconductor chips, or on substrate supports such as printed circuit boards and the like. The circuits constituting a block may be implemented by dedicated hardware, or by a processor (e.g., one or more programmed microprocessors and associated circuitry), or by a combination of dedicated hardware to perform some functions of the block and a processor to perform other functions of the block. Each block of the embodiments may be physically separated into two or more interacting and discrete blocks without departing from the scope of the inventive concepts. Likewise, the blocks of the embodiments may be physically combined into more complex blocks without departing from the scope of the inventive concepts.
Unless otherwise defined, all terms (including technical and scientific terms) used herein have the same meaning as commonly understood by one of ordinary skill in the art to which this invention belongs. It will be further understood that terms, such as those defined in commonly used dictionaries, should be interpreted as having a meaning that is consistent with their meaning in the context of the relevant art and/or the present application, and will not be interpreted in an idealized or overly formal sense unless expressly so defined herein.
The operation method of
The memory device 240 may store data required for an operation of the central processing unit 220. For example, the data that is calculated or processed by the central processing unit 220 for executing an application may be loaded on the memory device 240. The memory device 240 may be, for example, dynamic random access memory (DRAM), magnetic RAM (MRAM), resistive RAM (RRAM), phase-change RAM (PRAM), and ferroelectric RAM (FRAM). However, hereinafter, for convenience of explanation, an example in which the memory device 240 is embodied as DRAM will be described. However, all or part of the operation method of the mobile device 200 according to the present example embodiment will be operated identically or similarly, even if the memory device 240 is embodied as MRAM, etc.
The memory device 240 may be provided in a single or a multiple number. For example, as illustrated in
Referring again to
For example, the zero data processing unit 260 may receive an initialization request with respect to the memory device 240 from the central processing unit 220, and may set a first type area of the memory device 240, which is not initialized as a first value, in operation S120. For example, the zero data processing unit 260 may set the first type area in a unit of the channels CH1 and CH2 or the rank RK of
The first value may be 0 indicating logic low. When one application is ended, the central processing unit 220 may initialize an area of the memory device 240, which is allocated for the application, as the first value, for example, the value of 0, for security, etc. The zero data processing unit 260 of the mobile device 200 may receive an initialization request of the central processing unit 220 with respect to a random area of the memory device 240, and may control the area not to be initialized. The zero data processing unit 260 may set the area of the memory device 240, which is not initialized, despite the initialization request, as the first type area.
The first type area may be set in the above initialization operation of the memory device 240, or, as it will be described later, may be set by a write command for writing zero data. The zero data may refer to data in which values of all bits are set as 0. In addition, the zero data processing unit 260 may receive a write command, a read command, and a refresh command for the first type area, and may generate a processing result of the command without accessing the memory device 240.
This aspect will be described in more detail later.
A response with respect to a processing result of a request for the memory device 240, etc. may be transmitted to the central processing unit 220 by the zero data processing unit 260, in operation S140. For example, the zero data processing unit 260 may transmit a response for the initialization request, which notifies that the initialization request with respect to the memory device 240 is received or processed, to the central processing unit 220. The zero data processing unit 260 may be embodied as a hardware module. Alternatively, the zero data processing unit 260 may be embodied as a software module.
The central processing unit 220, the memory device 240, and the zero data processing unit 260 may exchange signals and data with one another via the bus 280. Although not illustrated in
According to the mobile device 200 and the operation method thereof according to an example embodiment, a scheme for performing a normal operation without performing initialization of the memory device 240 is provided so that power consumption caused by the initialization of the memory device 240 may be reduced. Alternatively, according to the mobile device 200 and the operation method thereof according to an example embodiment, a refresh operation is not performed on an area of the memory device 240, which is processed as an initialized area or as an area storing zero data, and thus, power consumption may be reduced and an operation delay may be prevented. Alternatively, according to the mobile device 200 and the operation method thereof according to an example embodiment, a scheme for performing a normal operation without accessing the memory device 240 is provided so that delay problems due to a limit of a physical bandwidth of the memory device 240 may be solved. Alternatively, when the memory device 240 is initialized, cache miss which may occur when performing a next write operation may be prevented, and thus, the performance of the mobile device 200 may be improved.
Hereinafter, the operation method of the mobile device 200 will be described in more detail.
In response to the initialization request REQ_int, the zero data processing unit 260 may set the first type area, which is not initialized despite the initialization request REQ_int {circle around (2)}. The zero data processing unit 260 may set a plurality of first type areas in page units. In this case, the zero data processing unit 260 may store a value indicating that the page is the first type area, in a random entry of a look-up table with respect to each page. For example, when a first page, matching information of which is stored in a first index of the look-up table, is the first type area, the value of 1 may be stored in a random entry of the first index.
The zero data processing unit 260 may transmit a response RSP_int notifying that the initialization is performed, to the central processing unit 220, without accessing DRAM 240a, that is, without initializing an area of the DRAM 240a, which corresponds to a plurality of pages, for which the initialization is requested {circle around (3)}. Via this operation, power consumption caused by the initialization of the DRAM 240a may be reduced.
Then, when a write command CMD_wt for writing zero data in the first type area of the DRAM 240a is activated from the central processing unit 220 {circle around (4)}, the zero data processing unit 260 may not access the DRAM 240a, that is, may not perform a write operation, and may transmit a response RSP_wt indicating that the write command has succeeded to the central processing unit 220 {circle around (5)}. Here, the zero data processing unit 260 may determine whether a page corresponding to an address included in the write command is the first type area, by searching the look-up table. As shown above, the write operation by transmitting the zero data to the DRAM 240a is not performed, and thus, power consumption caused by the write operation may be reduced, and a delay which may be caused during a data exchange operation with the DRAM 240a, due to a limit of a bandwidth of the DRAM 240a, may be prevented.
Then, when a write command CMD_wt for writing the write data which is non-zero data in the first type area is activated from the central processing unit 220 {circle around (4)}, the zero data processing unit 260 may transmit a first control signal XCON1 for writing the write data in the DRAM 240a, to the DRAM 240a {circle around (5)}. However, the zero data processing unit 260 may transmit the write command CMD_wt to the DRAM 240a without additionally generating the first control signal XCON1.
The DRAM 240a may perform a write operation in response to the first control signal XCON1 {circle around (6)} and may output a response RSP_wt for the write command, which notifies that the write operation is completed {circle around (7)}. The zero data processing unit 260 changes the first type area of the DRAM 240a, in which the write data which is non-zero data is written, to a second type area {circle around (8)}. For example, the zero data processing unit 260 may update a value of a random entry, which indicates whether a page is the first type area, from 1 to 0, in a look-up table, in order to change the page of the first type area to a page of the second type area. The second type area indicates the area in which the write data which is non-zero data is written. The zero data processing unit 260 may transmit the response RSP_wt for the write command, which notifies that the write operation is completed, to the central processing unit 220 {circle around (9)}.
According to another example embodiment of the present inventive concepts, the zero data processing unit 260 may control the DRAM 240a to perform a write operation of the write data to the first type area of the DRAM 240a before output a response RST_wt for the write command {circle around (9)}, and update a loop-up table to indicate that the write data in response to an address of the write command is stored in the first type area of the DRAM 240a{circle around (8)}.
In
Also, in
According to another example embodiment of the present inventive concepts, the zero data processing unit 260 may update a loop-up table to indicate that the write data in response to an address of the write command is stored in the first type area of the DRAM 240a {circle around (5)}, and control the DRAM 240a to perform a write operation of the write data to the first type area of the DRAM 240a before output a response RST_wt for the write command {circle around (8)}.
Hereinafter, for convenience of explanation, the operation method of the mobile device 200 according to an example embodiment will be described according to the operation order of
To prevent the security problem, the mobile device 200 may be operated in a method of
Next, a write command CMD_wt for writing the write data which is non-zero data in the first type area of the DRMA 240a is activated from the central processing unit 220 {circle around (4)}. However, as illustrated in
The DRAM 240a may perform the initialization {circle around (6)} and the write operations {circle around (7)} with respect to the first type area, in response to the second control signal XCON2. The zero data processing unit 260 may receive a response RSP_wt for the write command from the DRAM 240a {circle around (8)}. The response RSP_wt for the write command notifies the zero data processing unit 260 that the write operation is completed. After changing the first type area of the DRAM 240a, to which the write data which is non-zero data has been written, to the second type area {circle around (9)}, the zero data processing unit 260 may transmit the response RSP_wt for the write command to the central processing unit 220 {circle around (10)}.
Through the above-described operations, a cache-hit ratio may be increased by performing the initialization when the security problem of
Next, when a read command CMD_rd for reading read data of the first type area is activated from the central processing unit 220 {circle around (4)}, the zero data processing unit 260 may not access the DRAM 240a, that is, may not perform the read operation, and may transmit zero data to the central processing unit 220, as a response RSP_rd for the read command {circle around (5)}. That is because the zero data processing unit 260 may identify that a result of the reading operation is the zero data, without accessing the DRAM 240a.
However, example embodiments are not limited thereto. As illustrated in
Next, when a refresh command CMD_rf for refreshing data of the first type area is activated from the central processing unit 220 {circle around (4)}, the zero data processing unit 260 may not transmit the refresh command CMD_rf to the DRAM 240a, and may transmit to the central processing unit 220 a response RSP_rf for the refresh command CMD_rf, which notifies that the refresh command CMD_rf is received {circle around (5)}. Thus, according to the mobile device and the operation method thereof according to an example embodiment, power consumption caused by the refresh operation may be reduced.
As shown above, the methods of processing the write command, the read command, and the refresh command, with respect to the memory area of the DRAM 240a, which is set as the first type area in response to the initialization request, are described. By writing the write data which is non-zero data, the first type area and the second type area may co-exist in the memory area of the DRAM 240a.
With respect to the memory area changed to the first type area, even if a read operation or the write operation of the zero data is requested, the value of the identifier is maintained as 1. However, when the write data which is non-zero data is requested to be written in the first type area, the first type area is changed to the second type area, and the identifier may have the value of 0.
Hereinafter, the operation method of the mobile device 200, described in
Next, when a write command CMD_wt for writing write data which is non-zero data in the first type area is activated from the central processing unit 220 {circle around (4)}, the zero data processing unit 260 may transmit the first control signal XCON1 for writing the write data in the DRAM 240a to the DRAM 240a {circle around (5)}. The DRAM 240a may perform a write operation in response to the first control signal XCON1 {circle around (63)}, and may output a response RSP_wt for the write command CMD_wt, which notifies that the write operation is completed {circle around (7)}. The zero data processing unit 260 may change the first type area of the DRAM 240a, in which the write data which is non-zero data is written, to the second type area {circle around (8)}. The zero data processing unit 260 may transmit the response RSP_wt for the write command, which notifies that the write operation is completed, to the central processing unit 220 {circle around (9)}.
Thereafter, the operation command for the second type area may be processed in operation S160. For example, the write command CMD_wt for writing zero data in the second type area may be activated {circle around (10)}. In response to the write command CMD_wt, the zero data processing unit 260 may not perform an access to the DRAM 240a, that is, may not perform the write operation, and may change the setting of the memory area, for which the write operation is requested, from the second type area to the first type area {circle around (11)}. Then, the zero data processing unit 260 may transmit the response RSP_wt for the write command CMD_wt, which notifies that the write operation is completed, to the central processing unit 220 {circle around (12)}.
Here, the write command CMD_wt for writing zero data in the second type area may be a bulk zero write command for writing plurality of pieces of zero data at once. If a total size of the zero data requested to be written by the bulk zero write command is n (n is a positive integer) times the size of a page, the page may be set as the first type area by using the look-up table as described above. When the total size of the zero data requested to be written by the bulk zero data write command is not n times the size of the page, the first type area may be set by using the reserved address bit described above.
Thereafter, the operation command for the second type area may be processed in operation S160. For example, the write command CMD_wt for writing the write data which is non-zero data in the second type area may be activated {circle around (10)}. The zero data processing unit 260 may transmit a first control signal XCON1 for writing the write data in the DRAM 240a to the DRAM 240a {circle around (11)}. The DRAM 240a may perform a write operation in response to the first control signal XCON1 {circle around (12)}, and may output a response RSP_wt for the write command, which notifies that the write operation is completed {circle around (13)}. The zero data processing unit 260 may maintain the setting of the second type area and may transmit the response RSP_wt for the write command CMD_wt to the central processing unit 220 {circle around (14)}.
Then, the operation command for the second type area may be processed in operation S160. For example, a read command CMD_rd for reading with respect to the second type area may be activated {circle around (10)}. The zero data processing unit 260 may transmit a third control signal XCON3 for reading to the DRAM 240a {circle around (11)}. The third control signal XCON3 may not be additionally generated, and the read command CMD_rd may be transmitted to the DRAM 240a. The DRAM 240a may perform a read operation in response to the third control signal XCON3 {circle around (12)}, and may output read data as a response RSP_rd for the read command CMD_rd {circle around (13)}. The zero data processing unit 260 may maintain the setting of the second type area and may transmit the response RSP_rd for the read command CMD_rd to the central processing unit 220 {circle around (14)}.
Thereafter, the operation command for the DRAM 240a in which the first type area and the second type area co-exist may be processed in operation S180. For example, a refresh command CMD_rf for refreshing the DRAM 240a may be activated {circle around (10)}. The zero data processing unit 260 may transmit a fourth control signal XCON4 for refreshing the DRAM 240a to the DRAM 240a {circle around (11)}. The fourth control signal XCON4 may not be additionally generated and the refresh command CMD_rf may be transmitted to the DRAM 240a. In response to the fourth control signal XCON4, the DRAM 240a may not perform the refresh operation on the first type area, and may perform the refresh operation only on the second type area {circle around (12)}. For example, the DRAM 240a may operate in a partial array self refresh (PASR) mode, and may refresh only the second type area. The PASR method is a method of performing a refresh operation only on some memory cells rather than the whole memory cells of the DRAM 240a. The PASR mode may be performed by a setting of a mode register set (MRS).
The zero data processing unit 260 may maintain the setting of the first type area and the second type area, and may transmit a response RSP_rf for the refresh command to the central processing unit 220 {circle around (13)}. Thus, according to the mobile device 200 and the operation method thereof according to the example embodiments, power consumption and the operation delay caused by the refresh operation may be prevented.
While the inventive concept has been particularly shown and described with reference to example embodiments thereof, it will be understood that various changes in form and details may be made therein without departing from the spirit and scope of the following claims.
Number | Date | Country | Kind |
---|---|---|---|
10-2015-0078668 | Jun 2015 | KR | national |
Number | Name | Date | Kind |
---|---|---|---|
4272985 | Rapson, Jr. et al. | Jun 1981 | A |
5920895 | Perazzoli, Jr. | Jul 1999 | A |
5935242 | Madany | Aug 1999 | A |
8456972 | Mehra et al. | Jun 2013 | B2 |
8719513 | Agesen | May 2014 | B2 |
8812817 | Fuller | Aug 2014 | B2 |
8942072 | Mehra et al. | Jan 2015 | B2 |
8947988 | Mehra et al. | Feb 2015 | B2 |
20030095459 | Derner | May 2003 | A1 |
20060087903 | Riho | Apr 2006 | A1 |
20070250283 | Barnum et al. | Oct 2007 | A1 |
20110088084 | Yasaki | Apr 2011 | A1 |
20110296087 | Kim | Dec 2011 | A1 |
20130198246 | Scales | Aug 2013 | A1 |
20140189704 | Narvaez et al. | Jul 2014 | A1 |
20140344513 | Lo et al. | Nov 2014 | A1 |
20150068181 | Horstmann | Mar 2015 | A1 |
20150095604 | Doi | Apr 2015 | A1 |
20150378615 | Ramanujan | Dec 2015 | A1 |
Number | Date | Country |
---|---|---|
20140060308 | May 2014 | KR |
Entry |
---|
Seshadri, Vivek et al., “RowClone: Fast and Energy-Efficient In-DRAM Bulk Data Copy and Initialization,” Carnegie Mellon University, Intel Pittsburgh, MICRO-46 Proceedings of the 46th Annual IEEE/ACM International Symposium on Microarchitecture, Dec. 7-11, 2013, 13 pages. |
Number | Date | Country | |
---|---|---|---|
20160358642 A1 | Dec 2016 | US |