METHOD FOR DATA STORAGE MEANS AND A SYSTEM WITH DATA STORAGE MEANS

Abstract
A system and a method for data storage means includes a set of data storage sub-assemblies and connectable to storage control means adapted to retrieve, for a plurality of simultaneous user applications, data stored in the data storage means. The method divides a data composition into a plurality of payload data subsets, and stores the payload data subsets in the data storage sub-assemblies. The storage control means is adapted to retrieve, for a user application, the payload data subsets in a predetermined retrieving sequence, wherein a sequence of a number of payload data subsets, which number corresponds to the number of data storage sub-assemblies in the set of data storage sub-assemblies, and which payload data subsets follow sequentially one immediately upon the other in the retrieving sequence, are stored in separate ones of the data storage sub-assemblies in the set of data storage sub-assemblies.
Description
TECHNICAL FIELD

The present disclosure relates to a system comprising data storage means, and a method for data storage means comprising a set of data storage sub-assemblies and being connectable to storage control means adapted to retrieve, for a plurality of simultaneous user applications, data stored in the data storage means.


BACKGROUND OF THE INVENTION

In many data storage applications, a plurality of data retrieving tasks are undertaken simultaneously to retrieve data from data storage means. Often, these tasks are controlled by a processor or a memory controller serving a plurality of processors. The tasks can originate from one or more user applications.


Data streaming is one area where such data storage applications occur. Data streaming is conventionally performed on data with video, sound or multimedia content, and enables the playback of such data without the need to download the entire resource file in advance of playback. This means that such data has to be sent at a pace corresponding, at least on average, to the pace at which it is to be presented. In many streaming applications, users, e.g., video viewers, have display devices, e.g., television sets or personal computers, that are connectable, e.g., via an IP-network, to a server including data storage means in which media data is stored. In the case of videos, each user can request individually a streaming session, i.e., a video stored in the data storage means to be displayed, so that the video is displayed to the user immediately upon streaming from the server, i.e., without storage at the display device of the entire video.


Thus, there are in many cases, for example in data streaming, a plurality of simultaneous user applications, for example streaming sessions, and the data retrieved for each user application is in the form of a relatively large coherent set of data, herein referred to as a data composition, which can represent for example a multimedia sequence, e.g., a movie, a music file, an advertisement or a TV station transmission. Thereby, the data storage means might store a large amount of such data compositions, and the user applications can involve retrieving a large number of different data compositions simultaneously. A problem that has to be addressed in such cases is retrieving data with a sustained bandwidth in operations where many simultaneous user applications demand retrieval of separate individual data compositions, and also in operations where the retrieval of the same data composition is demanded by many simultaneous user applications.


One way of solving this problem is to use dynamic random access memory (DRAM) for the data storage means, as suggested in US2003/0095783A1. DRAM provides a very fast access of stored data. However, DRAM provides a relatively low storage capacity, and consumes high levels of power for its operations including cooling. It is also relatively expensive. The combination of low storage capacity and high power consumption necessitates for many applications large assemblies of DRAM units with elaborate cooling arrangements demanding very high levels of power.


It is also suggested in US2003/0095783A1 to use a solid state memory, such as flash memory, for storing data for video/audio streaming applications. However, due to flash memories providing a slow access of stored data, said problem of retrieving data with a sustained bandwidth remains to be solved.


OBJECTS AND SUMMARY OF THE INVENTION

It is an object of the invention to provide, in data storage applications involving, on one hand, data storage means storing a plurality of data compositions, and, on the other hand, a plurality of simultaneous user applications each involving retrieving a data composition from the data storage means, a sustained bandwidth during a variety of combinations of user applications.


It is also an object of the invention to provide, in data storage applications involving, on one hand, data storage means storing a plurality of data compositions, and, on the other hand, a plurality of simultaneous user applications each involving retrieving a data composition from the data storage means, a high storage capacity and a low power consumption.


These objects are reached with a method for data storage means comprising a set of data storage sub-assemblies and being connectable to storage control means adapted to retrieve, for a plurality of simultaneous user applications, data stored in the data storage means, the method comprising the steps of

    • dividing a data composition into a plurality of payload data subsets, and
    • storing the payload data subsets in the data storage sub-assemblies,
    • the storage control means being adapted to retrieve, for a user application, the payload data subsets in a predetermined retrieving sequence,
    • wherein a sequence of a number of payload data subsets, which number corresponds to the number of data storage sub-assemblies in the set of data storage sub-assemblies, and which payload data subsets follow sequentially one immediately upon the other in the retrieving sequence, are stored in separate ones of the data storage sub-assemblies in the set of data storage sub-assemblies.


It should be noted that, as exemplified below, the data storage sub-assemblies can be banks of dual inline memory modules, dual inline memory modules, individual flash memories, groups of dual inline memory modules, or any other suitable type of sub-assembly of the data storage means. It should also be noted that the set of data storage sub-assemblies can comprise all data storage sub-assemblies of the data storage means. Alternatively, the data storage means can comprise data storage sub-assemblies in addition to those included in the set of data storage sub-assemblies. Thus, the set of data storage sub-assemblies include at least some of the data storage sub-assemblies of the data storage means.


Preferably, the payload data subsets of a data composition are equal in size. Alternatively, the payload data subsets of a data composition can be of different sizes.


The invention provides for the payload data subsets being distributed, when stored, to all data storage sub-assemblies in the set of data storage sub-assemblies, and so that the payload data subsets are stored so that any pair of them, related to each other so that one follows immediately upon the other in the retrieving sequence, are stored in separate ones of the data storage sub-assemblies. Where the data composition represents media data, the payload data subsets will be distributed in a sequence representing a sequence of the presentation of the media data in a normal presentation mode. As exemplified below, there can be other presentation modes, providing other retrieving sequences, for example at trick play modes.


As a result of the invention, requests from the storage control means will be evenly distributed among all data storage sub-assemblies, regardless whether the operational situation of the data storage means is extreme to one end such that all simultaneous user application involve the retrieval of separate, individual data compositions, the operational situation of the data storage means is extreme to another end such that all simultaneous user application involve the retrieval of the same data composition, or the operational situation of the data storage means is a combination of such extremities. This will reduce risks of excessive data queuing and reduce latency considerably. As a result of the invention reducing latency, it is possible to use flash memories with sustained bandwidth, while enjoying the benefits of low power consumption and high storage capacity.


Preferably, further sequences following, in the retrieving sequence, said sequence of payload data subsets are stored in a cyclic manner so that the payload data subsets of each sequence are stored in separate ones of the data storage sub-assemblies in the set of data storage sub-assemblies. Thereby, the data compositions can be stored in a striping way so that sequences of payload data subsets are retrieved in a rotational manner in the data storage sub-assemblies.


Preferably, the data storage means comprise a plurality of dual inline memory modules, and the data storage sub-assemblies are provided as banks of the dual inline memory modules, the method further comprising sending requests to the banks of each dual inline memory module in an alternating, interleaving manner. As will be explained closer below, sending read requests in this alternating manner will allow full use of the capacity of a bus to which the banks of the dual inline memory module are connected.


The objects are also reached with a system comprising data storage means comprising a set of data storage sub-assemblies, the system further comprising storage control means connectable to the data storage means and adapted to retrieve, for a plurality of simultaneous user applications, data stored in the data storage means, the storage control means being adapted to receive a data composition and divide it into a plurality of payload data subsets before the data composition is stored in the data storage means, the storage control means being adapted to retrieve, for a user application, the payload data subsets in a predetermined retrieving sequence, the system being adapted to store the payload data subsets so that a number of payload data subsets, which number corresponds to the number of data storage sub-assemblies in the set of data storage sub-assemblies, and which payload data subsets follow sequentially one immediately upon the other in the retrieving sequence, are stored in separate ones of the data storage sub-assemblies in the set of data storage sub-assemblies. Preferably, the system is adapted to store in a cyclic manner further sequences following, in the retrieving sequence, said sequence of payload data subsets so that the payload data subsets of each sequence are stored in separate ones of the data storage sub-assemblies in the set of data storage sub-assemblies.


Preferably, the data storage means comprise a plurality of flash memories. This will provide low power consumption and high storage capacity, while, as mentioned above, providing a sustained bandwidth for access of the data storage means. As exemplified below, the data storage means can comprise a plurality of dual inline memory modules, and the data storage sub-assemblies are provided as banks of the dual inline memory modules, each bank comprising a plurality of the flash memories.


The data storage means can comprise a plurality of groups, each group comprising a plurality of dual inline memory modules. Thereby, the dual inline memory modules of each group are advantageously fully buffered.


Preferably, the data storage means of the system comprise a plurality of dual inline memory modules, the data storage sub-assemblies are provided as banks of the dual inline memory modules, and a local storage controller of each dual inline memory module is adapted to send requests to the banks of the respective dual inline memory module in an alternating, interleaving manner.





BRIEF DESCRIPTION OF THE DRAWINGS

Below, embodiments of the invention will be described with reference to the drawings, in which



FIG. 1 shows a schematic view of an apparatus adapted to stream media data to user devices.



FIG. 2 shows schematically parts of the apparatus in FIG. 1.



FIG. 3 illustrates allocation of data to data storage sub-assemblies of the apparatus in FIG. 1.



FIG. 4 illustrates allocation of data within a data storage sub-assembly of the apparatus in FIG. 1.



FIG. 5 shows parts of data storage means of the apparatus in FIG. 1.



FIG. 6 shows a diagram of events, as a function of time, in a part of data storage means of the apparatus in FIG. 1.



FIG. 7 illustrates allocation of data to data storage sub-assemblies according to an alternative embodiment of the invention.





DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENTS


FIG. 1 shows schematically a system 1, herein also referred to as a data handling system 1, in the form of a streaming apparatus 1, adapted to stream media data to user devices, for example in a manner described in the patent applications GB0700313.0, GB0700311.4, GB0700343.7, GB0708734.9, and SE0701995-3, incorporated herein by reference. The streaming apparatus 1 can provide simultaneous user applications, in this example in the form of simultaneous streaming sessions, for the user devices, each user application being individually adapted to the requests of the respective user device. The streaming apparatus comprises a streaming unit SU, for example embodied as an FPGA (Field Programmable Gate Array) hardware unit. The streaming unit SU is adapted to access a memory unit MU, for example embodied as a DRAM (Dynamic Random Access Memory), for queuing media data to be sent during streaming, via a network unit NU of the streaming apparatus 1, and a network NW, to the user devices.


The streaming apparatus 1 also comprises data storage means FS for storing media data and control data as described closer below. The streaming apparatus 1 further comprises storage control means SU, CU, in turn comprising a global storage controller SC comprising retrieving means adapted to access the data storage means FS via a suitable bus (not shown). In this embodiment, the global storage controller SC is included in the streaming unit SU.


The data storage means FS comprises a plurality of DIMMs (Dual Inline Memory Modules) 100-172. The DIMMs 100-172 are arranged in a plurality of groups 10-17, in this example eight groups 10-17. In general, the DIMMs 100-172 could be arranged in any number of groups 10-17. Also, each group 10-17 could comprise any suitable number of DIMMs 100-172.


Reference is made to FIG. 2, in which one of the DIMM groups 10 is shown as comprising three DIMMs 100-102. Each DIMM 100-102 comprises a local storage controller SCL, and a plurality of flash memories F0-F7, each accessible to the respective local storage controller SCL. In this embodiment, each flash memory F0-F7 is in the form of a NAND (Not AND)-flash memory. The flash memories F0-F7 of each DIMM 100-102 are distributed in two data storage sub-assemblies 1001-1022. The data storage sub-assemblies are in this example also referred to as a first bank 1001, 1011, 1021 or a second bank 1002, 1012, 1022. Each DIMM 100-102 comprises one first bank 1001, 1011, 1021 and one second bank 1002, 1012, 1022, and each bank 1001-1022 comprises a subset F0-F7 of eight flash memories F0-F7. In a practical embodiment, each DIMM 100-102 comprises a planar substrate serving as a carrier for the flash memories F0-F7, the flash memories F0-F7 of the first bank 1001, 1011, 1021 being located on one side of the substrate, and the flash memories F0-F7 of the second bank 1002, 1012, 1022 being located on the other side of the substrate.


As can be seen in FIG. 2, the local storage controllers SCL are connected so as to form a serial data link to the global storage controller SC, i.e. they are fully buffered. Preferably, on each DIMM 100-102, four pins (not shown) are used for the serial data link. This provides a fast data connection between the DIMMs 100-102 and the global storage controller SC. Also, since a relative small amount of pins on each DIMM 100-102 are used for this connection, there is a relatively small possibility of a malfunctioning pin.


Reference is made to FIG. 3 and FIG. 4. As stated in said patent applications (GB0700313.0, GB0700311.4, GB0700343.7, GB0708734.9, and SE0701995-3), the media data stored by the streaming apparatus 1 comprises data compositions 20, herein also referred to as payload data sets or payload data flows. Each data composition 20 is a relatively large coherent set of data, for example data representing multimedia sequences, e.g. movies, music files, and/or advertisements. More generally, a data composition 20 can be any form of media data, whether audio, visual, text or code, provided separately or in any combination. Also, a data composition 20 can provide data for a time limited media display, or be received from a continuous flow of data, for example in the form of a transmission from a TV station. As also described in said patent applications, for storing, the storage control means SU, CU of the streaming apparatus 1 further comprises a control unit CU (FIG. 1) which is adapted to pre-process the data compositions 20, whereby they are divided into payload data subsets 200-295 (FIG. 3), and control data sets are created by the control unit CU, which control data sets are used for retrieving from the data storage means FS respective payload data subsets 200-295 during streaming.


The payload data subsets 200-295 are preferably of a predetermined size, as an example 16 kB. As illustrated in FIG. 4, the control data comprises control data subsets CSS, each stored in association with a respective payload data subset 200. More specifically, as described in said patent applications (GB0700313.0, GB0700311.4, GB0700343.7, GB0708734.9, and SE0701995-3), the storage address of each control data subset CSS is linked to the storage address of the respective payload data subset 200 such that the control data subset CSS is retrieved, during streaming, together with the payload data subset 200. The control data subset CSS includes data that is used by the global storage controller SC, (FIG. 1), during streaming, for retrieving the following payload data subset 201 and associated control data subset. (As an example, the size of each control data subset CSS is 64 bytes.) Thus the control data subsets CSS provides a retrieving sequence for each data composition 20 corresponding to at least one a user application mode, which retrieving sequence determines the order in which the payload data subsets 200-295 are retrieved from the storage means FS. The retrieving sequence corresponds to the sequence of the payload data subsets as provided in the data composition 20. As an alternative to control data subsets CSS stored with the payload data subsets 200-295, the retrieving sequence can be provided from a table accessible by the global storage controller SC.


It should be noted that there retrieving could be more than one retrieving sequence for a data composition 20. For example, in the case of data for an audio/visual presentation, e.g., a movie, there could be one retrieving sequence corresponding to a normal presentation mode, and one or more retrieving sequences corresponding to respective trick play modes, e.g., a fast forward mode or a reverse mode. Thereby the control data subsets can include information for linking the payload data subsets 200-295 in more than one alternative manner, as described in said patent application GB0700343.7. The control data sets can also be used for editing the data to be streamed as described in said patent application GB0700343.7.


As can be seen in FIG. 4, for storing, each payload data subset 200 is divided into eight payload data subset portions 2000-2007. When stored, the eight payload data subset portions 2000-2007 are distributed to the each of the flash memories F0-F7 of a bank 1001 of a DIMM 100, (see also FIG. 2). The respective control data subset CSS, which is relatively small is size compared to the payload data subset portions 2000-2007, is stored in one of the flash memories F0-F7 along with a payload data subset portion.


During the pre-processing, the control unit CU (FIG. 1) allocates storage space for the respective data composition. As illustrated with the vertical arrows in FIG. 3, forty-eight payload data subsets 200-247 of a first sequence of payload data subsets, which payload data subsets follow sequentially one immediately upon the other in the data composition 20, are stored in individual, separate ones of the forty-eight banks 1001-1722 of the storage means FS. For this presentation, the forty-eight banks 1001-1722 are also referred to as a set of data storage sub-assemblies. In a cyclic manner, forty-eight payload data subsets 248-295 of a second sequence which follows in the data composition 20 immediately upon the first sequence of payload data subsets 200-247, are stored in the individual, separate ones of the banks 1001-1722. In this cyclic manner, the entire data composition 20 is stored in the storage means FS, so that the payload data subsets are distributed evenly to all banks 1001-1722. As a result, each payload data subset 201 is retrieved from a bank 1002 different from the bank 1001 from which the immediately preceding payload data subset 200 was retrieved.


The storing strategy illustrated in FIG. 3 is followed for all data composition 20 in the storage means FS. As a result, requests from the global storage controller SC will be evenly distributed among all banks 1001-1722, regardless whether the operational situation of the storage means FS is extreme to one end such that all simultaneous user application involve the retrieval of separate, individual data compositions 20, the operational situation of the storage means FS is extreme to another end such that all simultaneous user application involve the retrieval of the same data composition 20, or the operational situation of the storage means is a combination of such extremities. Requests from the global storage controller SC can be, for example, any of the requests known in the art as write, read and erase. The distribution of the global storage controller SC requests between the banks 1001-1722 will minimise risks of excessive data queuing and reduce latency considerably.



FIG. 5 shows schematically one of the DIMMs 100. Each flash memory F0-F7 comprises a storage element FE and a buffer element BE, the latter in the form of a SRAM (Static Random Access) Buffer. Communication between the buffer elements BE of both banks 1001, 1002 and the local storage controller SCL is carried out by means of a DIMM bus BB.


Each flash memory F0-F7 is arranged to retrieve a set of stored data from the storage element FE by a copying step and a reading step. In the copying step, the set of data is copied from the storage element FE to the buffer element BE. Thereupon, the reading step is performed, whereby the set of data is read by the local storage controller SCL from the buffer element BE. In this example, the copying step takes 100 ms and the reading step takes 200 ms, which is typical for a flash memory F0-F7 of a NAND-flash memory type. When a payload data subset 200 (FIG. 4) is retrieved, the payload data subset portions 2000-2007 thereof are copied essentially simultaneously from the respective storage elements FE to the respective buffer elements BE in the flash memories F0-F7 of one of the banks 1001. Thereafter, the payload data subset portions 2000-2007 are read essentially simultaneously by the local storage controller SCL from the buffer elements BE of the flash memories F0-F7 of the bank 1001.


Reference is made to FIG. 6. While the copying step is carried out, the respective flash memory F0-F7 is busy. The local storage controller SCL is adapted to send read requests in an alternating manner to the first and second bank 1001, 1002. More specifically, the local storage controller SCL is adapted to send, (see FIG. 6 at the time t1), a read request AB1 for a payload data subset to the flash memories F0-F7 of the first bank 1001, whereupon the flash memories F0-F7 of the first bank 1001 will become busy. As indicated in FIG. 6, after having sent a read request AB1 to the flash memories F0-F7 of the first bank 1001, the local storage controller SCL reads DB2, (see FIG. 6 at the time t2), a payload data subset from the flash memories F0-F7 of the second bank 1002. The local storage controller SCL is further adapted to send, upon having read DB2 a payload data subset from the flash memories F0-F7 of the second bank 1002, a read request AB2, (see FIG. 6 at the time t4), for a further payload data subset to the flash memories F0-F7 of the second bank 1002, whereupon the flash memories F0-F7 of the second bank 1002 will become busy. After having sent a read request AB2 to the flash memories F0-F7 of the second bank 1002, the local storage controller SCL reads DB1, (see FIG. 6 at the time t5), a payload data subset from the flash memories F0-F7 of the second bank 1001. Sending read requests in this alternating manner will allow full use of the capacity of the DIMM bus BB. It should be noted that the interleaving manner of requests between the banks described here can be carried out also with other types of requests, such as write or erase requests.


Above, an embodiment of the invention has been described in a streaming apparatus. However, it should be noted that the invention is applicable to any type of system or apparatus, where data compositions stored in data means are to be retrieved according to a plurality of simultaneous user applications. For example, as an alternative the invention can be applied to a system in which the control unit CU is provided remote from the data storage means FS.


In the embodiment described above, the data storage sub-assemblies 1001-1722, among which the payload data subsets are distributed, are provided in the form of banks 1001-1722, two of which are arranged in each DIMM 100-172 and each comprising a subset of the flash memories F0-F7. Alternatively, the data storage sub-assemblies, among which the payload data subsets are distributed, could be provided in the form of DIMMs, groups of DIMMs, or as individual flash memories F0-F7. FIG. 7 shows an example of data storage means comprising eight flash memories F0-F7, into which a data composition is allocated in a manner similar to what was described above with reference to FIG. 3. It should also be noted that as an alternative to NAND-flash memories, NOR (Not OR)-flash memories could be used.


Although the present invention has been described in connection with preferred embodiments thereof, it will be appreciated by those skilled in the art that additions, deletions, modifications, and substitutions not specifically described may be made without department from the spirit and scope of the invention as defined in the appended claims.

Claims
  • 1. A method for data storage means comprising a set of data storage sub-assemblies and being connectable to storage control means adapted to retrieve, for a plurality of simultaneous user applications, data stored in the data storage means, the method comprising the steps of: dividing a data composition into a plurality of payload data subsets; andstoring the payload data subsets in the data storage sub-assemblies,wherein the storage control means is adapted to retrieve, for a user application, the payload data subsets in a predetermined retrieving sequence,wherein a sequence of a number of payload data subsets, which number corresponds to the number of data storage sub-assemblies in the set of data storage sub-assemblies, and which payload data subsets follow sequentially one immediately upon the other in the retrieving sequence, are stored in separate ones of the data storage sub-assemblies in the set of data storage sub-assemblies, andwherein further sequences following, in the retrieving sequence, said sequence of payload data subsets are stored in a cyclic manner so that the payload data subsets of each sequence are stored in separate ones of the data storage sub-assemblies in the set of data storage sub-assemblies.
  • 2. The method according to claim 1, wherein the data storage means comprise a plurality of dual inline memory modules, and the data storage sub-assemblies are provided as banks of the dual inline memory modules, the method further comprising sending requests to the banks of each dual inline memory module in an alternating, interleaving manner.
  • 3. A system comprising: data storage means including a set of data storage sub-assemblies; andstorage control means connectable to the data storage means and adapted to retrieve, for a plurality of simultaneous user applications, data stored in the data storage means,wherein the storage control means is adapted to receive a data composition and divide it into a plurality of payload data subsets before the data composition is stored in the data storage means,wherein the storage control means is adapted to retrieve, for a user application, the payload data subsets in a predetermined retrieving sequence,wherein the system is adapted to store the payload data subsets so that a number of payload data subsets, which number corresponds to the number of data storage sub-assemblies in the set of data storage sub-assemblies, and which payload data subsets follow sequentially one immediately upon the other in the retrieving sequence, are stored in separate ones of the data storage sub-assemblies in the set of data storage sub-assemblies, andwherein the system is adapted to store in a cyclic manner further sequences following, in the retrieving sequence, said sequence of payload data subsets so that the payload data subsets of each sequence are stored in separate ones of the data storage sub-assemblies in the set of data storage sub-assemblies.
  • 4. The system according to claim 3, wherein the data storage means comprises a plurality of flash memories.
  • 5. The system according to claim 4, wherein the data storage means comprises a plurality of dual inline memory modules, and the data storage sub-assemblies are provided as banks of the dual inline memory modules, each bank comprising a plurality of the flash memories.
  • 6. The system according to claim 5, wherein the data storage means comprises a plurality of groups, each group comprising a plurality of dual inline memory modules.
  • 7. The system according to claim 6, wherein the dual inline memory modules of each group are fully buffered.
  • 8. The system according to claim 3, wherein the data storage means comprises a plurality of dual inline memory modules, the data storage sub-assemblies are provided as banks of the dual inline memory modules, and a local storage controller of each dual inline memory module is adapted to send requests to the banks of the respective dual inline memory module in an alternating, interleaving manner.
Priority Claims (1)
Number Date Country Kind
0850006-8 Jan 2008 SE national
CROSS-REFERENCE TO PRIOR APPLICATION

This application claims priority under 35 U.S.C. §119(e) to U.S. Provisional Application No. 61/006,658 filed Jan. 25, 2008, and claims priority under 35 U.S.C. §119 and/or §365 to Swedish Patent Application No. 0850006-8 filed Jan. 17, 2008, the contents of each of these applications are incorporated by reference herein.

Provisional Applications (1)
Number Date Country
61006658 Jan 2008 US