US6813687B1 - Raid volume for sequential use that needs no redundancy pre-initialization - Google Patents
Raid volume for sequential use that needs no redundancy pre-initialization Download PDFInfo
- Publication number
- US6813687B1 US6813687B1 US09/645,949 US64594900A US6813687B1 US 6813687 B1 US6813687 B1 US 6813687B1 US 64594900 A US64594900 A US 64594900A US 6813687 B1 US6813687 B1 US 6813687B1
- Authority
- US
- United States
- Prior art keywords
- data
- volume
- boundary
- redundancy
- location
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Expired - Fee Related, expires
Links
- 238000000034 method Methods 0.000 claims abstract description 37
- 230000004044 response Effects 0.000 claims description 2
- 238000010586 diagram Methods 0.000 description 7
- 238000013459 approach Methods 0.000 description 6
- 230000008569 process Effects 0.000 description 4
- 230000006870 function Effects 0.000 description 3
- 230000003287 optical effect Effects 0.000 description 2
- 238000005192 partition Methods 0.000 description 2
- 230000002411 adverse Effects 0.000 description 1
- 230000001010 compromised effect Effects 0.000 description 1
- 238000007796 conventional method Methods 0.000 description 1
- 230000000593 degrading effect Effects 0.000 description 1
- 230000001419 dependent effect Effects 0.000 description 1
- 238000012986 modification Methods 0.000 description 1
- 230000004048 modification Effects 0.000 description 1
- 238000005457 optimization Methods 0.000 description 1
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F11/00—Error detection; Error correction; Monitoring
- G06F11/07—Responding to the occurrence of a fault, e.g. fault tolerance
- G06F11/08—Error detection or correction by redundancy in data representation, e.g. by using checking codes
- G06F11/10—Adding special bits or symbols to the coded information, e.g. parity check, casting out 9's or 11's
- G06F11/1076—Parity data used in redundant arrays of independent storages, e.g. in RAID systems
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F2211/00—Indexing scheme relating to details of data-processing equipment not covered by groups G06F3/00 - G06F13/00
- G06F2211/10—Indexing scheme relating to G06F11/10
- G06F2211/1002—Indexing scheme relating to G06F11/1076
- G06F2211/1035—Keeping track, i.e. keeping track of data and parity changes
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F2211/00—Indexing scheme relating to details of data-processing equipment not covered by groups G06F3/00 - G06F13/00
- G06F2211/10—Indexing scheme relating to G06F11/10
- G06F2211/1002—Indexing scheme relating to G06F11/1076
- G06F2211/1052—RAID padding, i.e. completing a redundancy group with dummy data
Definitions
- the present invention relates to a method and/or architecture for configuring a redundant array of inexpensive disks (RAID) volume generally and, more particularly, to a RAID volume that does not require redundancy pre-initialization.
- RAID redundant array of inexpensive disks
- volume redundancy When implementing volume redundancy, such as RAID 1 or RAID 5, the volume redundancy must be initialized.
- Two conventional approaches are used for initializing volume redundancy. However, both the conventional approaches (i) are performed when a volume is created and (ii) reduce host or array controller bandwidth during the initialization process.
- a first conventional approach writes blocks of zeros to both a primary data block and a redundancy data block. The blocks of zeros are written to every sector in a volume for both the primary data block and the redundancy data block (i.e., the parity partition or the mirror partition, depending on the redundancy level). The entire volume is unavailable for use until the initialization is complete.
- a second conventional approach is dependent on a particular RAID level.
- the second conventional approach requires existing blocks of data to be read from drives and new redundancy information to be created and written back to the drives.
- Such an approach allows the existing data volume to be used during initialization, with special handling for write operations to the area of the volume that has not yet been initialized. However, performance is compromised while the initialization runs in the background.
- the second conventional method allows a host to perform read and write operations on the existing data volume.
- an array controller of the host is required to know what area of the volume has been initialized and what area of the volume has not been initialized.
- the array controller is required to perform a specialized read and/or write that can require additional complex logic.
- the present invention concerns a method for providing sequential initialization of redundancy data in a volume comprising the steps of: (A) defining a boundary; (B) determining a location of the data with respect to the boundary; and (C) initializing a redundancy location of the volume and writing the data and a redundancy of the data to the volume.
- the objects, features and advantages of the present invention include providing a method and/or architecture for implementing a redundant array of inexpensive disks (RAID) volume that may (i) allow for sequential operation, (ii) operate without redundancy pre-initialization and/or (iii) eliminate an initializing volume redundancy process by implementing volume that is written sequentially.
- RAID redundant array of inexpensive disks
- FIG. 1 is a block diagram of a preferred embodiment of the present invention
- FIGS. 2 ( a-c ) are block diagrams of an operation of the present invention.
- FIG. 3 is a flow diagram illustrating an operation of the present invention.
- the circuit 100 may implement a sequential redundancy initialization process.
- the circuit 100 generally comprises a controller 102 and an array 104 .
- the controller 102 generally controls the level of redundancy of the array 104 .
- the array 104 generally comprises a number of drives 106 a - 106 n.
- the array 104 and the drives 106 a - 106 n may implement one or more volumes.
- One volume may be used to store data and one volume may be used to store redundant data.
- a volume may be divided into a number of portions configured to read and write data.
- the particular format of the volumes may vary according to the particular redundancy protocol (e.g., RAID 1, RAID 5, etc.).
- the system 100 may initially write to a volume sequentially (e.g., starting at logical block address (LBA) zero and ascend to a highest LBA), so that redundancy information may be initialized as data is written (to be discussed further in connection with FIGS. 2 and 3 ).
- LBA logical block address
- the system 100 may initially write to a volume sequentially (e.g., starting at logical block address (LBA) zero and ascend to a highest LBA), so that redundancy information may be initialized as data is written (to be discussed further in connection with FIGS. 2 and 3 ).
- LBA logical block address
- a predetermined attribute e.g., host sequential use initialization
- the predetermined attribute may be implemented when a primary data volume is initially created in a redundant environment.
- the predetermined attribute may be a user selectable attribute.
- other appropriate predetermined attributes and/or configurations of the predetermined attribute(s) may be implemented in order to meet the criteria of a particular implementation.
- FIGS. 2 ( a-c ) a detailed diagram of the operation of the present invention is shown.
- a volume 110 in various stages of initialization is shown.
- the volume 110 may be implemented as a redundant volume in a redundant drive system.
- the FIGS. 2 ( a-c ) may illustrate initialization of the volume 110 in accordance with the present invention.
- the volume 110 may illustrate an unwritten data and uninitialized redundancy configuration.
- An “Initialization Boundary” 116 may be at a LBA of zero of the volume 110 .
- the volume 110 may illustrate an area of (i) written data and initialized redundancy 112 and (ii) unwritten data and uninitialized redundancy 114 .
- the volume 110 may track the highest sequential LBA written.
- the highest sequential LBA written may be implemented as the initialization boundary 116 .
- a write to an LBA less than the initialization boundary 116 may be performed normally (e.g., performed using optimal RAID methods such as the RAID 5 read-modify-write method).
- the volume 110 may illustrate when a write to the same LBA that includes the initialization boundary 116 occurs.
- the volume 110 may create a valid redundancy location and update the initialization boundary 116 in response to a location conflict. Additionally, a write with an LBA greater than the initialization boundary 116 may be (i) returned with an error or (ii) performed in such a way as to create a valid redundancy without updating the initialization boundary 116 .
- a write outside the initialize boundary 116 may occur at a next block of data. Initialization of redundancy may occur at the next block of data at that point and time.
- the initialization boundary 116 may also be used to alert redundancy parity scans of a known end of valid redundancy volume 110 in order to avoid reporting false errors.
- the method 200 generally comprises a state 202 , a state 204 , a decision state 206 , a state 208 , a state 210 , a decision state 212 , a state 214 , a finish state 216 , a state 218 and an error state 220 .
- the state 202 may receive a write command.
- the state 204 may determine a location of data to be written.
- the state 206 may determine where a location to be written to is located with respect to a boundary (e.g., the initialization boundary 116 ).
- the method 200 may move to the state 208 .
- the state 208 may indicate no apparent conflicts.
- the state 208 may continue to the state 214 .
- the state 214 may write data utilizing an appropriate redundancy method.
- the state 214 may then continue to the finish state 216 .
- the method 200 may move to the state 210 .
- the state 210 may move the boundary and initialize a redundancy location to write the redundant data.
- the state 208 may then continue to the state 218 , where the data is written to both the primary and redundancy data locations via a sequential initialization of the redundancy location.
- the state 218 may control writing data to a primary and redundancy volume simultaneously.
- the step 210 and the step 218 may occur simultaneously. Data is generally written only after no conflicts of data locations occur.
- the method 200 may move to the decision state 212 .
- the decision state 212 may enforce a sequential write. If the sequential write is enforced, the method 200 may continue to the error state 220 . If the sequential write is not enforced the method 200 may continue to the state 218 , where the data is to be written and sequential initialization of redundancy data is to occur.
- an application that predominantly writes in a sequential fashion may initialize a redundant volume as primary data is written.
- the first time data is written to the primary area of the volume 110 e.g., as data is written in a sequential fashion
- data may be stored in adjacent blocks (e.g., from zero to the capacity of the volume).
- the sequential data may be written to block 0 , block 1 , block 2 , etc.
- data may be written in groups of blocks.
- the circuit 100 may be allowed to skip conventional redundancy initialization, by allowing the redundancy volume 110 to be initialized on an as needed basis. For example, the circuit 100 may only initialize the redundancy volume 110 as data is written outside of the primary data area (illustrated in FIG. 2 c ).
- a parity scan may occur to verify if there is parity consistency in the redundancy area of the volume 110 . If the redundancy volume 110 is correct, then a request to write data past what is already initialized may be ignored. Such a request may be ignored, since a requested location has not yet been written to. A request up to an end block (e.g., the last valid data) that has been written may be checked for valid parity. The circuit 100 may be only required to check validity to the last valid data block.
- Snapshot type copies may create an immediate copy of a volume without really copying all the data of the original volume.
- the snapshot copy may implement an instantaneous copy of the original volume.
- To access the snapshot copy another additional volume is required.
- the additional volume may be implemented as a snapshot volume.
- the snapshot volume is generally identical to the original volume at the point and time of origination of the snapshot copy.
- the snapshot copy/volume may allow the original volume to be modified normally.
- the snapshot volume may be then implemented to back up a tape or other similar function.
- the snapshot volume may be implemented to save data that is to be modified. For example, if a write to the original volume occurs the system 100 (or 200 ) may first check to see if a copy of the data is saved in a predetermined location (e.g., a repository). If the data is not saved, the system 100 may read the original data from the original volume, save a copy of the original data and then allow the write to complete to the original volume. The snapshot volume may then only be required to store a sub-set of the original data. The snapshot volume may read the repository to check if new data has been saved. If the new data is saved, the circuit 100 may return to the snapshot volume because the prior data block of the snapshot copy still exists in the snapshot volume. If the data is not stored within the snapshot volume then the block of data has not been changed and the data of the original volume may be read.
- a predetermined location e.g., a repository
- the implementation of the repository is sequential in nature.
- the repository may be implemented as an additional volume.
- the repository may be implemented as an internal volume.
- the repository may need to be created from an existing volume. However, the repository may not be required to initialize redundancy on the volume since the repository may be written to sequentially.
- the circuit 100 may write copies of data from the primary volume as they are being changed to the repository.
- the circuit 100 may also be configured to track where data is written.
- the circuit 100 generally provides essentially sequential implementation of a volume. Moreover, the sequential implementation may be internally implemented.
- a host application may define a new volume and write to the volume sequentially.
- the host application may not be required to devote considerable amounts of time to initialization of redundancy volume.
- volume that may be written to sequentially may also be checked for validity.
- the volume may be presented to the user as a specialized configuration. The specialized configuration may not be required to devote significant time to initializing redundancy volume initially.
- the circuit 100 may implement immediate availability initialization. Since initialization is on a write, the circuit 100 may allow for optimization depending on how the data is received. If the data is received in large enough blocks, a parity is generated and the write is completed. If the data is received in small blocks another method may ensure a validity of the parity block that may not be initialized.
- the present invention may initialize a repository comprising everything between the last block that was initialized and the last block written. Implementation of the repository may not guarantee absolutely sequential writes. However, the repository may ensure predetermined tolerances and may make adjustments for the tolerances allowing the system 100 to go back and initialize the parity for the few blocks between where the last known parity redundancy had been generated and the current block that is being written.
- the initial write is generally implemented at a same time as initialization of the redundancy volume. Every time a write is to be completed, an initialization for the written block of data is to occur.
- the present invention may allow writing of a block of data and initializing a redundancy volume at the same time.
- the function performed by the flow diagram 200 may be implemented using a conventional general purpose digital computer programmed according to the teachings of the present specification, as will be apparent to those skilled in the relevant art(s) Appropriate software coding can readily be prepared by skilled programmers based on the teachings of the present disclosure, as will also be apparent to those skilled in the relevant art(s).
- the functions of the flow diagram 200 may be implemented along with conventional routines (e.g., be in the drive controller 102 ).
- the present invention may also be implemented by the preparation of ASICs, FPGAs, or by interconnecting an appropriate network of conventional component circuits, as is described herein, modifications of which will be readily apparent to those skilled in the art(s).
- the present invention thus may also include a computer product which may be a storage medium including instructions which can be used to program a computer to perform a process in accordance with the present invention.
- the storage medium can include, but is not limited to, any type of disk including floppy disk, optical disk, CD-ROM, and magneto-optical disks, ROMs, RAMs, EPROMs, EEPROMs, Flash memory, magnetic or optical cards, or any type of media suitable for storing electronic instructions.
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Quality & Reliability (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Techniques For Improving Reliability Of Storages (AREA)
Abstract
Description
Claims (23)
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US09/645,949 US6813687B1 (en) | 2000-08-25 | 2000-08-25 | Raid volume for sequential use that needs no redundancy pre-initialization |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US09/645,949 US6813687B1 (en) | 2000-08-25 | 2000-08-25 | Raid volume for sequential use that needs no redundancy pre-initialization |
Publications (1)
Publication Number | Publication Date |
---|---|
US6813687B1 true US6813687B1 (en) | 2004-11-02 |
Family
ID=33300244
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US09/645,949 Expired - Fee Related US6813687B1 (en) | 2000-08-25 | 2000-08-25 | Raid volume for sequential use that needs no redundancy pre-initialization |
Country Status (1)
Country | Link |
---|---|
US (1) | US6813687B1 (en) |
Cited By (7)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20030120674A1 (en) * | 2001-12-25 | 2003-06-26 | Hitachi, Ltd. | Control method of control device conducting data input and output to storage devices, and control device used therefor |
US20040024977A1 (en) * | 2002-08-01 | 2004-02-05 | Delaney William P. | Method and apparatus for copying data between storage volumes of storage systems |
US20040215877A1 (en) * | 2003-04-28 | 2004-10-28 | Paresh Chatterjee | Methods and structure for rapid background initialization of a RAID logical unit |
US20040221102A1 (en) * | 2003-05-02 | 2004-11-04 | Hitachi, Ltd. | Method and apparatus for initialization of storage systems |
US7711897B1 (en) * | 2005-06-10 | 2010-05-04 | American Megatrends, Inc. | Method, system, apparatus, and computer-readable medium for improving disk array performance |
US20150370648A1 (en) * | 2014-06-20 | 2015-12-24 | Fujitsu Limited | Redundant system and redundancy method |
US10564903B2 (en) * | 2016-05-13 | 2020-02-18 | Seagate Technology Llc | Method and apparatus for rapid volume reformatting |
Citations (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5822782A (en) * | 1995-10-27 | 1998-10-13 | Symbios, Inc. | Methods and structure to maintain raid configuration information on disks of the array |
US6098119A (en) * | 1998-01-21 | 2000-08-01 | Mylex Corporation | Apparatus and method that automatically scans for and configures previously non-configured disk drives in accordance with a particular raid level based on the needed raid level |
US6334195B1 (en) * | 1995-12-29 | 2001-12-25 | Lsi Logic Corporation | Use of hot spare drives to boost performance during nominal raid operation |
US6467023B1 (en) * | 1999-03-23 | 2002-10-15 | Lsi Logic Corporation | Method for logical unit creation with immediate availability in a raid storage environment |
US6510491B1 (en) * | 1999-12-16 | 2003-01-21 | Adaptec, Inc. | System and method for accomplishing data storage migration between raid levels |
-
2000
- 2000-08-25 US US09/645,949 patent/US6813687B1/en not_active Expired - Fee Related
Patent Citations (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5822782A (en) * | 1995-10-27 | 1998-10-13 | Symbios, Inc. | Methods and structure to maintain raid configuration information on disks of the array |
US6334195B1 (en) * | 1995-12-29 | 2001-12-25 | Lsi Logic Corporation | Use of hot spare drives to boost performance during nominal raid operation |
US6098119A (en) * | 1998-01-21 | 2000-08-01 | Mylex Corporation | Apparatus and method that automatically scans for and configures previously non-configured disk drives in accordance with a particular raid level based on the needed raid level |
US6467023B1 (en) * | 1999-03-23 | 2002-10-15 | Lsi Logic Corporation | Method for logical unit creation with immediate availability in a raid storage environment |
US6510491B1 (en) * | 1999-12-16 | 2003-01-21 | Adaptec, Inc. | System and method for accomplishing data storage migration between raid levels |
Cited By (15)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20030120674A1 (en) * | 2001-12-25 | 2003-06-26 | Hitachi, Ltd. | Control method of control device conducting data input and output to storage devices, and control device used therefor |
US6976124B2 (en) * | 2001-12-25 | 2005-12-13 | Hitachi, Ltd. | Control method of control device conducting data input and output to storage devices, and control device used therefor |
US20040024977A1 (en) * | 2002-08-01 | 2004-02-05 | Delaney William P. | Method and apparatus for copying data between storage volumes of storage systems |
US6931499B2 (en) * | 2002-08-01 | 2005-08-16 | Lsi Logic Corporation | Method and apparatus for copying data between storage volumes of storage systems |
US7062605B2 (en) * | 2003-04-28 | 2006-06-13 | Lsi Logic Corporation | Methods and structure for rapid background initialization of a RAID logical unit |
US20040215877A1 (en) * | 2003-04-28 | 2004-10-28 | Paresh Chatterjee | Methods and structure for rapid background initialization of a RAID logical unit |
US20040221102A1 (en) * | 2003-05-02 | 2004-11-04 | Hitachi, Ltd. | Method and apparatus for initialization of storage systems |
US7461176B2 (en) * | 2003-05-02 | 2008-12-02 | Hitachi, Ltd. | Method for initialization of storage systems |
US7711897B1 (en) * | 2005-06-10 | 2010-05-04 | American Megatrends, Inc. | Method, system, apparatus, and computer-readable medium for improving disk array performance |
US7802063B1 (en) | 2005-06-10 | 2010-09-21 | American Megatrends, Inc. | Method, system, apparatus, and computer-readable medium for improving disk array performance |
US7991969B1 (en) | 2005-06-10 | 2011-08-02 | American Megatrends, Inc. | Method, system, apparatus, and computer-readable medium for improving disk array performance |
US20150370648A1 (en) * | 2014-06-20 | 2015-12-24 | Fujitsu Limited | Redundant system and redundancy method |
US10049021B2 (en) * | 2014-06-20 | 2018-08-14 | Fujitsu Limited | Redundant system and redundancy method |
US10564903B2 (en) * | 2016-05-13 | 2020-02-18 | Seagate Technology Llc | Method and apparatus for rapid volume reformatting |
US11321023B2 (en) | 2016-05-13 | 2022-05-03 | Seagate Technology Llc | Method and apparatus for rapid volume reformatting |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US6260156B1 (en) | Method and system for managing bad areas in flash memory | |
US4750106A (en) | Disk volume data storage and recovery method | |
US5166936A (en) | Automatic hard disk bad sector remapping | |
EP0405926B1 (en) | Method and apparatus for managing a shadow set of storage media | |
US5619690A (en) | Computer system including a computer which requests an access to a logical address in a secondary storage system with specification of a local address in the secondary storage system | |
US6643667B1 (en) | System and method for replicating data | |
US7237057B2 (en) | Window-based flash memory storage system and management and access methods thereof | |
US6785791B2 (en) | Method for accessing data being copied between data regions before the copying is completed | |
US5630054A (en) | Method and apparatus for storing and retrieving error check information | |
US4620295A (en) | Method for accessing a data set in a word processing system | |
JPH0317141B2 (en) | ||
US6167485A (en) | On-line data verification and repair in redundant storage systems | |
US20050163014A1 (en) | Duplicate data storing system, duplicate data storing method, and duplicate data storing program for storage device | |
US6728830B1 (en) | Method and apparatus for modifying the reserve area of a disk drive | |
US7133987B2 (en) | Storage system and snapshot management method thereof | |
US6813687B1 (en) | Raid volume for sequential use that needs no redundancy pre-initialization | |
US5337197A (en) | Method and system for maintaining directory consistency in magneto-optic media | |
US10114699B2 (en) | RAID consistency initialization method | |
CN114924923A (en) | Method, system, equipment and medium for verifying correctness of hard disk write-in point | |
US20050102482A1 (en) | Method and system for configuring RAID subsystems with block I/O commands and block I/O path | |
US7293193B2 (en) | Array controller for disk array, and method for rebuilding disk array | |
US6591264B1 (en) | Method that allows I/O requests to run concurrently with a rollback from a snapshot in a drive array | |
US7020770B2 (en) | Method and apparatus for configuration of RAID controllers | |
US7200771B2 (en) | Relocation batch processing for disk drives | |
US8601230B2 (en) | Volume migration program, method and system |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
AS | Assignment |
Owner name: LSI LOGIC CORPORATION, CALIFORNIA Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:HUMLICEK, DONALD R.;REEL/FRAME:011042/0904 Effective date: 20000824 |
|
FEPP | Fee payment procedure |
Free format text: PAYOR NUMBER ASSIGNED (ORIGINAL EVENT CODE: ASPN); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY |
|
FPAY | Fee payment |
Year of fee payment: 4 |
|
FPAY | Fee payment |
Year of fee payment: 8 |
|
AS | Assignment |
Owner name: DEUTSCHE BANK AG NEW YORK BRANCH, AS COLLATERAL AG Free format text: PATENT SECURITY AGREEMENT;ASSIGNORS:LSI CORPORATION;AGERE SYSTEMS LLC;REEL/FRAME:032856/0031 Effective date: 20140506 |
|
AS | Assignment |
Owner name: LSI CORPORATION, CALIFORNIA Free format text: CHANGE OF NAME;ASSIGNOR:LSI LOGIC CORPORATION;REEL/FRAME:033102/0270 Effective date: 20070406 |
|
AS | Assignment |
Owner name: AVAGO TECHNOLOGIES GENERAL IP (SINGAPORE) PTE. LTD Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:LSI CORPORATION;REEL/FRAME:035390/0388 Effective date: 20140814 |
|
AS | Assignment |
Owner name: LSI CORPORATION, CALIFORNIA Free format text: TERMINATION AND RELEASE OF SECURITY INTEREST IN PATENT RIGHTS (RELEASES RF 032856-0031);ASSIGNOR:DEUTSCHE BANK AG NEW YORK BRANCH, AS COLLATERAL AGENT;REEL/FRAME:037684/0039 Effective date: 20160201 Owner name: AGERE SYSTEMS LLC, PENNSYLVANIA Free format text: TERMINATION AND RELEASE OF SECURITY INTEREST IN PATENT RIGHTS (RELEASES RF 032856-0031);ASSIGNOR:DEUTSCHE BANK AG NEW YORK BRANCH, AS COLLATERAL AGENT;REEL/FRAME:037684/0039 Effective date: 20160201 |
|
AS | Assignment |
Owner name: BANK OF AMERICA, N.A., AS COLLATERAL AGENT, NORTH CAROLINA Free format text: PATENT SECURITY AGREEMENT;ASSIGNOR:AVAGO TECHNOLOGIES GENERAL IP (SINGAPORE) PTE. LTD.;REEL/FRAME:037808/0001 Effective date: 20160201 Owner name: BANK OF AMERICA, N.A., AS COLLATERAL AGENT, NORTH Free format text: PATENT SECURITY AGREEMENT;ASSIGNOR:AVAGO TECHNOLOGIES GENERAL IP (SINGAPORE) PTE. LTD.;REEL/FRAME:037808/0001 Effective date: 20160201 |
|
REMI | Maintenance fee reminder mailed | ||
LAPS | Lapse for failure to pay maintenance fees | ||
STCH | Information on status: patent discontinuation |
Free format text: PATENT EXPIRED DUE TO NONPAYMENT OF MAINTENANCE FEES UNDER 37 CFR 1.362 |
|
FP | Lapsed due to failure to pay maintenance fee |
Effective date: 20161102 |
|
AS | Assignment |
Owner name: AVAGO TECHNOLOGIES GENERAL IP (SINGAPORE) PTE. LTD., SINGAPORE Free format text: TERMINATION AND RELEASE OF SECURITY INTEREST IN PATENTS;ASSIGNOR:BANK OF AMERICA, N.A., AS COLLATERAL AGENT;REEL/FRAME:041710/0001 Effective date: 20170119 Owner name: AVAGO TECHNOLOGIES GENERAL IP (SINGAPORE) PTE. LTD Free format text: TERMINATION AND RELEASE OF SECURITY INTEREST IN PATENTS;ASSIGNOR:BANK OF AMERICA, N.A., AS COLLATERAL AGENT;REEL/FRAME:041710/0001 Effective date: 20170119 |