Using task description blocks to maintain information...

Error detection/correction and fault detection/recovery – Data processing system error or fault handling – Reliability and availability

Reexamination Certificate

Rate now

  [ 0.00 ] – not rated yet Voters 0   Comments 0

Details

Reexamination Certificate

active

06766480

ABSTRACT:

TECHNICAL FIELD
This invention relates to maintaining information regarding operations to be performed, and particularly to using task description blocks to maintain information regarding operations.
BACKGROUND OF THE INVENTION
Modem, high-capacity data storage systems often utilize a plurality of physical disk drives for redundant storage of data. This arrangement speeds data access as well as protecting against data loss that might result from the failure of any single disk.
There are two common methods of storing redundant data. According to the first or “mirror” method, data is duplicated and stored on two separate areas of the storage system. In a disk array, for example, identical data is stored on two separate disks. This method has the advantages of high performance and high data availability. However, the mirror method is also relatively expensive, effectively doubling the cost of storing data.
In the second or “parity” method, a portion of the storage area is used to store redundant data, but the size of the redundant storage area is less than the remaining storage space used to store the original data. For example, in a disk array having six disks, five disks might be used to store data, with the sixth disk being dedicated to storing redundant data, which is referred to as “parity” data. The parity data allows reconstruction of the data from one data disk, using the parity data in conjunction with the data from surviving disks. The parity method is advantageous because it is less costly than the mirror method, but it also has lower performance and availability characteristics in comparison to the mirror method.
Aspects of this invention involve storing redundant data according to parity techniques. In conventional disk arrays utilizing parity storage, the space on the storage disks are configured into multiple storage stripes, where each storage stripe extends across the storage disks. Each stripe consists of multiple segments of storage space, where each segment is that portion of the stripe that resides on a single storage disk of the disk array.
FIG. 1
illustrates a conventional disk array
12
having six storage disks
13
. In this simplified example, there are five storage stripes extending across the storage disks.
FIG. 1
highlights data and storage segments of a single one of these five stripes. Data segments of the indicated stripe are indicated by cross-hatching. The corresponding parity segment of this same stripe is illustrated in solid black. Generally, of the six segments comprising any given stripe, five of the segments are data segments and the sixth segment is a parity segment.
This type of parity storage is referred to as 5+1 parity storage, indicating that there are five data segments for every single parity segment. This scheme is more generally referred to as N+1 grouping, where N is the actual number of data segments in a data stripe.
N+1 redundancy grouping such as illustrated in
FIG. 1
protects against the loss of any single physical storage device. If the storage device fails, its data can be reconstructed from the surviving data. The calculations performed to recover the data are straightforward, and are well-known. Generally, a single parity segment P is calculated from data segments D
0
through D
N−1
in accordance with the following equation:
P+x
0
+x
1
+x
2
+x
N−1
where x
0
through x
N−1
correspond to the data from data segments D
0
through D
N−1
. After the loss of any single data segment, its data can be recovered through a straightforward variation of the same equation.
In many systems, however, it is becoming important to protect against the loss of more than a single storage device. Thus, it is becoming necessary to implement N+2 grouping in redundant storage systems.
While N+2 redundancy grouping enhances data protection, it also involves more complex calculations—both in initially calculating parity segments and in reconstructing any lost data segments.
A general form of the N+2 parity computation is as follows:
P+p
0
x
0
+p
1
x
1
+p
2
x
2
+p
N−1
x
N−1
Q+q
0
x
0
+q
1
x
1
+q
2
x
2
+q
N−1
x
N−1
where:
P is the value of a first parity segment;
Q is the value of a second parity segment;
x
0
through x
N−1
are the values of the data segments
p
0
through p
N−1
and q
0
through q
N−1
are constant coefficients that are particular to a given parity scheme.
These equations form a two-equation system that, by the rules of linear algebra, can potentially solve for any two unknowns x
a
through x
b
which represent the data from a single stripe of any two failed storage devices. One requirement is that the two sets of coefficients p
i
and q
i
be linearly independent. This requirement is met, for example, if p
0
=1, p
1
=1, p
2
=1; etc.; and q
0
=1, q
1
=2, q
2
=3; etc. Other examples are also possible.
The mathematics of N+2 parity are well-known and are not the primary subject of this description. However, it is apparent from the brief description given above that N+2 parity computations are significantly more complex than N+1 parity computations. In actual implementations of N+2 disk arrays, this complexity threatens to limit the data throughput of storage device controllers and, consequently, of the overall disk array.
A co-pending U.S. patent application Ser. No. 09/808,710, entitled “Efficient Parity Operations”, to inventor Michael B. Jacobson, describes a more efficient way to maintain adequate data throughput in spite of the added complexity resulting from N+2 parity calculations, and is hereby incorporated by reference. However, even with the more efficient methods and means described in this co-pending application, data throughput of storage device controllers can still be adversely affected by inefficient memory structures for storing the information necessary to perform the parity calculations. This invention includes methods and apparatus for using task description blocks to maintain information regarding parity (or other) operations and maintain adequate data throughput.
SUMMARY
Using task description blocks to maintain information regarding operations is described herein.
In accordance with one aspect of the invention, a task description block queue stores a pointer to each of multiple task description blocks, and each task description block stores information for one operation. The data for an operation is stored in memory. Each task description block stores information necessary for operation logic to perform a single operation, including pointers to the data stored in memory and a pointer to a result location in memory where results of the operation are to be stored by the operation logic. Once all of this information is stored in the task description block, a pointer to the task description block is stored in the task description block queue, allowing the operation logic to perform the operation whenever it desires.
In accordance with another aspect of the invention involving parity operations, a task description block queue stores a pointer to each of multiple task description blocks, and each task description block stores information for one parity operation. The data for a parity operation is stored in memory, as is a plurality of different coefficients that are used for different parity operations. Each task description block stores information used by parity operation logic to perform a single parity operation, including: a type of operation to be performed, a size of the task description block, an optional tag number (for consistency checking), an indication of a response queue into which status results of the operation to be performed are to be stored, pointers to the data stored in memory, a pointer to a subset of the plurality of coefficients, an indication of the number of coefficients in the subset, and a pointer to a result location in memory where results of the parity operatio

LandOfFree

Say what you really think

Search LandOfFree.com for the USA inventors and patents. Rate them and share your experience with other people.

Rating

Using task description blocks to maintain information... does not yet have a rating. At this time, there are no reviews or comments for this patent.

If you have personal experience with Using task description blocks to maintain information..., we encourage you to share that experience with our LandOfFree.com community. Your opinion is very important and Using task description blocks to maintain information... will most certainly appreciate the feedback.

Rate now

     

Profile ID: LFUS-PAI-O-3207156

  Search
All data on this website is collected from public sources. Our data reflects the most accurate information available at the time of publication.