US8850102B2 - Flash memory with small data programming capability - Google Patents
Flash memory with small data programming capability Download PDFInfo
- Publication number
- US8850102B2 US8850102B2 US11/895,611 US89561107A US8850102B2 US 8850102 B2 US8850102 B2 US 8850102B2 US 89561107 A US89561107 A US 89561107A US 8850102 B2 US8850102 B2 US 8850102B2
- Authority
- US
- United States
- Prior art keywords
- memory
- specific amount
- flash
- array
- data
- 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
- 230000015654 memory Effects 0.000 title claims abstract description 264
- 238000000034 method Methods 0.000 claims abstract description 34
- 238000005516 engineering process Methods 0.000 claims abstract description 9
- 238000004590 computer program Methods 0.000 claims description 6
- 238000013507 mapping Methods 0.000 claims description 5
- 239000000872 buffer Substances 0.000 description 4
- 238000010276 construction Methods 0.000 description 3
- 230000000694 effects Effects 0.000 description 2
- 238000004519 manufacturing process Methods 0.000 description 1
- 239000002699 waste material Substances 0.000 description 1
Images
Classifications
-
- G—PHYSICS
- G11—INFORMATION STORAGE
- G11C—STATIC STORES
- G11C16/00—Erasable programmable read-only memories
- G11C16/02—Erasable programmable read-only memories electrically programmable
- G11C16/06—Auxiliary circuits, e.g. for writing into memory
- G11C16/10—Programming or data input circuits
Definitions
- the present invention relates to flash memory; and more particularly to a method and apparatus for providing small programming capability in such flash memory.
- Non-volatile flash memories are widely used in different kinds of consumer products (and also other technical devices having embedded software (SW) and/or data storing capabilities). Because smaller packages are needed to make smaller mobile devices, and because going to smaller memory die processes offer component price benefits, non-volatile memory devices are shrunk to smaller lithographs (130 nm ⁇ 110 nm ⁇ 90 nm ⁇ 65 nm ⁇ ) which at some point will increase the need of having error correction in NOR flash. As the memory cell gets smaller, the probability of getting an erroneous read also increases. Error correction is commonly done for some specific amount of memory cells which limits the write size to this same amount of cells. (if error correction is done for 512 Bytes, usually each write is also limited to the same size as the error correction area).
- Multi Level Cell MLC
- Bits are commonly identified as different voltage levels (current levels) in the memory cell and thus MLC is more prone to have errors (e.g., if a cell can have voltages between 0-5 volts, 0 would be 0-1.5 volts and 1 would be 2-5 volts).
- MLC Multi Level Cell
- the difference between different states is smaller and thus reading/programming is more sensitive. If some data needs smaller writes than this error correction area, some devices support also other programming modes but commonly a part of a memory array is not accessible anymore after using that programming mode.
- flash file system becomes complex and guessing of different memory array areas is difficult/impossible if the memory array configuration is changed in a product, as the flash file system needs to have pre-defined information about how the memory needs to be accessed.
- Pre-generated production images for flash devices become different as error correction areas are not a standard size.
- Other reasons for limiting programming granularity is programming performance if programming buffers are used more parallelism can be implemented inside the memory device and/or more sophisticated programming algorithm for the memory cells can be implemented inside the memory device.
- Error correction NOR memory devices have different programming modes for the whole memory array. Flash file system knows (defined in source code) how memory needs to be accessed. This varies between flash memory generations.
- each error correction area (several inside each erase unit) whether it is used in a single level cell programming mode (which is bit manipulation capable and thus suitable for flash file system small control data), or in a multi level cell programming mode (which is not bit manipulation capable as error correction implementation prevents that). That is, the Intel M18 has two programming modes, a Control Mode and an Object mode, the first of them being suitable for Flash File System or Header information. Control Mode and Object Mode programming regions can be intermingled within the erase block, where a programming region is 1 kB, and thus a programming mode can be changed only at 1 kB intervals. However, the programming mode of any region within a block can be changed only after erasing the entire block.
- US 2007/0147116 discloses the use of blocks of flash memory outside of the main flash memory array for small parameter storage.
- the purpose of this solution is to keep the main flash memory array symmetrical by storing small data apart from it, i.e. to an extended flash array (EFA).
- EFA extended flash array
- EFA blocks need to be erased separately as they are not connected to blocks of main flash memory array. Further, EFA blocks are mapped on top of a “regular” address space by issuing an EFA command, and thus the main array block cannot be written or read.
- the present invention provides a new and unique method and apparatus that features receiving a request to access a memory array having one or more memory erase units with a data area of flash array and with a specific amount of memory which offers small data programming capability; and if the memory access request includes programming small data, then providing access to the specific amount of memory, or if the memory access request does not include programming small data, then providing access to the data area of flash array.
- the accessing may include memory programming capabilities such as reading, writing or erasing the programming data to or from the specific amount of memory.
- the size of that memory area is pre-defined.
- the memory area which allows this smaller data (bit manipulation/byte write/word write) programming and overwriting (changing more bits/bytes to 0 in same area) can be even a different technology but making it more cost effective from a product point of view.
- Implementation can be done differently based on a memory interface.
- the memory device must be implemented in that way that a small data area can be erased simultaneously or sequentially (with one command or sequential commands) with the main block (if the small data area is located in a different erase unit).
- Data units which create an erase unit can be in same erase unit as the small data area.
- the memory array doesn't have holes (areas which can not be accessed/or doesn't have valid data).
- a small data area may be located into the same memory erase unit as a main block or into a different memory erase unit as the main block.
- the memory array may form part of e.g. a MUX-NOR interface memory device, as well as a low power double data rate II (LP-DDR2) interface memory device.
- a MUX-NOR interface memory device as well as a low power double data rate II (LP-DDR2) interface memory device.
- LP-DDR2 low power double data rate II
- I/O input/output
- similar devices may be implemented for a standard NOR interface.
- the method may also comprise implementing the step of the method via a computer program running in a processor, controller or other suitable module in the user equipment, such as a mobile phone, terminal or device.
- the apparatus may take the form of a flash memory device featuring such a memory array having one or more memory erase units with such a data area of flash array and with such a specific amount of memory which offers small data programming capability, and such a memory controller, responsive to such a memory access request, and configured for providing access to the specific amount of memory if the memory access request includes programming small data, or for providing access to the data area of flash array if the memory access request does not include programming small data.
- the apparatus may take the form of a system featuring a device configured for providing such a memory access request; and such a flash memory device having such a memory array having one or more memory erase units with such a data area of flash array and with such a specific amount of memory which offers small data programming capability, and such a memory controller, responsive to the memory access request, and being configured for providing access to the specific amount of memory if the memory access request includes programming small data, or for providing access to the data area of flash array if the memory access request does not include programming small data.
- the apparatus may take the form of a computer program product with a program code, which program code is stored on a computer readable medium, for carrying out steps of a method comprising receiving such a request to access such a memory array having one or more memory erase units with such a data area of flash array and with such a specific amount of memory which offers small data programming capability; and if the memory access request includes programming small data, then providing access to the specific amount of memory, or if the memory access request does not include programming small data, then providing access to the data area of flash array, when the computer program is run in a module of user equipment, such as a mobile phone, terminal or device.
- a module of user equipment such as a mobile phone, terminal or device.
- the flash memory device may be implemented in conjunction with, or form part of, a flash file system, including where the flash file system data structures for a data unit can be located in the specific amount of memory.
- a flash file system including where the flash file system data structures for a data unit can be located in the specific amount of memory.
- FIG. 1 shows a flow chart of a method having basic steps of some embodiments of the present invention.
- FIG. 2 shows a flash memory device according to some embodiments of the present invention.
- FIG. 3 shows an example of a Mux-NOR interface device from a flash file system point of view according to some embodiments of the present invention.
- FIG. 4 shows an example a memory device in LP-DDR2 interface according to some embodiments of the present invention.
- FIG. 5 shows a system according to some embodiments of the present invention.
- FIGS. 1-5 show a new and unique technique for providing small programming capability in non-volatile flash memory, according to the present invention.
- FIG. 1 shows a flowchart generally indicated as 10 of a method according to the present invention having steps 10 a , 10 b , which include receiving a request to access a memory array having one or more memory erase units with a data area of flash array and with a specific amount of memory which offers small data programming capability; and if the memory access request includes programming small data, then providing access to the specific amount of memory, or if the memory access request does not include programming small data, then providing access to the data area of flash array.
- the accessing may include memory programming capabilities such as reading, writing or erasing the programming data to or from the specific amount of memory.
- the scope of the invention is also intended to include other memory programming capabilities either now known or later developed in the future.
- the small data may include validity information data; however, consistent with that shown and described herein, the scope of the invention is not intended to be limited to any particular type or kind of small data either now known or later developed in the future.
- small data e.g. validity or sector status information
- file system data blocks e.g. not for code
- It can be, for example, 8 bytes in size. If this data was written into the error correction area, it would waste huge amount of memory.
- small write areas according to the present invention, both programming modes need not to be supported by all memory cells.
- the size of the specific amount of memory may be pre-defined; the specific amount of memory may be a different memory technology; the specific amount of memory can be erased simultaneously or with sequentially with the main block of the memory array; the specific amount of memory may be located physically in the same location in the one or more memory erase units; the specific amount of memory may be located physically in a separate location in the one or more memory erase units; the specific amount of memory may be erased simultaneously, including by using one command or sequential commands; the specific amount of memory can be mapped inside an overlay window, where the overlay window can be mapped to any address, or where the specific amount of memory may not be visible until overlap mapping is changed again; or some combination of these features.
- embodiments are envisioned in which programming the device/small data can be implemented by using a programming buffer or single word programming, although the scope of the invention is not intended to include needing to use such a programming buffer.
- the buffer size can also be optimized to offer better performance of the device and cost for having integrated RAM in the memory device.
- FIGS. 2-3 shows a flash memory device generally indicated as 20 ( FIG. 2 ) having a memory array 20 a and a memory controller 20 b , according to some embodiments of the present invention.
- the memory array 20 a has one or more memory erase units 22 with a data area of flash array 22 a and with a specific amount of memory 22 b which offers small data programming capability, as shown in FIG. 3 .
- a small programming area 22 b can be located physically in the same location in a flash memory erase unit 22 or in a separate location, but erasing of those areas can be done simultaneously (with one command or sequential commands).
- the memory controller 20 b responds to a memory access request, for example, from a device (see FIG. 5 ), and is configured to provide access to the specific amount of memory 22 b if the request includes programming small data, or to provide access to the data area of flash array 22 a if the memory access request does not include programming small data.
- FIG. 3 shows, by way of example, how the memory array 20 a can be implemented from a file system point of view to a Mux-NOR interface.
- this embodiment allows the use of different memory cells in the flash memory device for different areas. Both areas are visible in the same memory array (addresses are sequential). There may be 126 kB of data area and 2 kB of small data area (which offers smaller data programming possibility).
- the scope of the invention is not intended to be limited to the size of the areas or combinations thereof; for example, embodiments are envisioned using other sizes such as 252 kB and 4 kB combination, or a 63 kB and 1 kB combination, as well as other sizes and combinations.
- all erase units are similar so memory device may read in similar way independently of location, this is needed for code execution.
- FIG. 4 shows an alternative embodiment having a combination generally indicated as 30 for use in relation to an LP-DDR2 interface.
- the combination 30 would form part of a flash memory device like 20 shown in FIG. 3 and have a memory controller like 20 b shown in FIG. 3 .
- the combination 30 provides an even more advanced method than that shown in FIG. 3 .
- the combination 30 includes a memory array 32 and one or more erase units 34 having small data programming area 36 that would be visible through an overlay window 36 which is mapped to some memory array location for the time when it needs to be accessed.
- each erase unit 34 can be mapped inside the overlay window 38 , and the overlay window 38 can be mapped to any address but as a side effect that the area in the memory device is not visible until overlay mapping is changed again.
- the main area of each erase unit 34 could be, for example, 64 kB, 128 kB, 256 kB or 512 kB (or any multiple of 8 kB) and small data area would be, for example, 1 kB for each 64 kB.
- This new and unique technique creates the possibility to simplify the memory device and flash file system.
- FIG. 5 shows a system generally indicated as 40 according to some embodiments of the present invention, having a device 42 and a flash memory device 44 .
- the device 42 is configured for providing the memory access request to the flash memory device 44 , and may take the form of an input/output (I/O) device, or other suitable device for providing such a request.
- I/O input/output
- the scope of the invention is not intended to be limited to any particular type or kind of device that provides the request.
- the flash memory device 44 includes a memory array 44 a and a memory controller 44 b .
- the memory array 44 a has one or more memory erase units such as 22 in FIG. 3 or 34 in FIG. 4 .
- the memory erase unit has a data area of flash array such as 22 a in FIG. 3 , and also has a specific amount of memory such as 22 b in FIG. 3 or 36 in FIG. 4 which offers small data programming capability.
- the flash memory device 44 responds to the memory access request, and the memory controller 44 b either provides access to the specific amount of memory in the memory array 44 a if the memory access request includes programming small data, or provides access to the data area of flash array 44 a if the memory access request does not include programming small data.
- the functionality of the memory controller 20 b may be implemented using hardware, software, firmware, or a combination thereof, although the scope of the invention is not intended to be limited to any particular embodiment thereof.
- the controller 20 b would be one or more microprocessor-based architectures having a microprocessor, a random access memory (RAM), a read only memory (ROM), input/output devices and control, data and address buses connecting the same.
- RAM random access memory
- ROM read only memory
- input/output devices control, data and address buses connecting the same.
- a person skilled in the art would be able to program such a microprocessor-based implementation to perform the functionality described herein without undue experimentation.
- the scope of the invention is not intended to be limited to any particular implementation using technology now known or later developed in the future.
- the scope of the invention is intended to include the controller 20 b forming part of the flash memory, being implemented as a stand alone module, being implemented in the combination with other circuitry for implementing another module, or being implemented in another way either now known or later developed in the future.
- the real-time part may be implemented in hardware, while non real-time part may be done in software.
- the invention comprises the features of construction, combination of elements, and arrangement of parts which will be exemplified in the construction hereinafter set forth.
Landscapes
- Read Only Memory (AREA)
Abstract
Description
- Byte=8 bits
- kB=kilobyte, 1024 bytes
- Mux-NOR=Address/Data multiplexed NOR interface
- NOR=non volatile flash memory which is byte/word accessible
- Word=16 bits
Claims (42)
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US11/895,611 US8850102B2 (en) | 2007-08-23 | 2007-08-23 | Flash memory with small data programming capability |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US11/895,611 US8850102B2 (en) | 2007-08-23 | 2007-08-23 | Flash memory with small data programming capability |
Publications (2)
Publication Number | Publication Date |
---|---|
US20090055575A1 US20090055575A1 (en) | 2009-02-26 |
US8850102B2 true US8850102B2 (en) | 2014-09-30 |
Family
ID=40383217
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US11/895,611 Expired - Fee Related US8850102B2 (en) | 2007-08-23 | 2007-08-23 | Flash memory with small data programming capability |
Country Status (1)
Country | Link |
---|---|
US (1) | US8850102B2 (en) |
Cited By (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20190066784A1 (en) * | 2013-11-22 | 2019-02-28 | Micron Technology, Inc. | Memory Systems and Memory Programming Methods |
US20190074060A1 (en) * | 2014-01-09 | 2019-03-07 | Micron Technology, Inc. | Memory Systems and Memory Programming Methods |
US11011229B2 (en) | 2013-12-16 | 2021-05-18 | Micron Technology, Inc. | Memory systems and memory programming methods |
Families Citing this family (10)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
TWI384488B (en) * | 2007-12-24 | 2013-02-01 | Skymedi Corp | Nonvolatile storage device and its data writing method |
US20110167197A1 (en) * | 2010-01-05 | 2011-07-07 | Mark Leinwander | Nonvolatile Storage with Disparate Memory Types |
CN102467522B (en) * | 2010-11-10 | 2013-09-11 | 中兴通讯股份有限公司 | Self-programming method and device of file system based on NAND flash |
US9081665B2 (en) * | 2012-02-02 | 2015-07-14 | OCZ Storage Solutions Inc. | Apparatus, methods and architecture to increase write performance and endurance of non-volatile solid state memory components |
US10430085B2 (en) | 2016-11-08 | 2019-10-01 | Micron Technology, Inc. | Memory operations on data |
US10261876B2 (en) | 2016-11-08 | 2019-04-16 | Micron Technology, Inc. | Memory management |
US10649665B2 (en) | 2016-11-08 | 2020-05-12 | Micron Technology, Inc. | Data relocation in hybrid memory |
US10083751B1 (en) | 2017-07-31 | 2018-09-25 | Micron Technology, Inc. | Data state synchronization |
US10916324B2 (en) | 2018-09-11 | 2021-02-09 | Micron Technology, Inc. | Data state synchronization involving memory cells having an inverted data state written thereto |
KR20210012329A (en) * | 2019-07-24 | 2021-02-03 | 에스케이하이닉스 주식회사 | Memory system and operating method of the memory system |
Citations (9)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
EP0704851A1 (en) * | 1994-09-27 | 1996-04-03 | STMicroelectronics S.r.l. | Byte erasable EEPROM fully compatible with a single power supply flash-EPROM process |
US6222775B1 (en) * | 1999-06-22 | 2001-04-24 | Stmicroelectronics S.R.L. | Flash compatible EEPROM |
CN1524227A (en) | 2002-04-03 | 2004-08-25 | 索尼株式会社 | Recording device and method, storage medium and program |
US20050251617A1 (en) * | 2004-05-07 | 2005-11-10 | Sinclair Alan W | Hybrid non-volatile memory system |
US20070083697A1 (en) | 2005-10-07 | 2007-04-12 | Microsoft Corporation | Flash memory management |
US20070147116A1 (en) | 2005-12-22 | 2007-06-28 | Shekoufeh Qawami | Use of flash memory blocks outside of the main flash memory array |
US20070283082A1 (en) * | 2006-04-13 | 2007-12-06 | Christophe Laurent | Optimized flash memory access method and device |
US20080068897A1 (en) * | 2006-09-19 | 2008-03-20 | Samsung Electronics Co., Ltd. | Semiconductor memory device and memory system including semiconductor memory device |
US20090027950A1 (en) * | 2007-07-26 | 2009-01-29 | Chung Hon Lam | Block Erase for Phase Change Memory |
-
2007
- 2007-08-23 US US11/895,611 patent/US8850102B2/en not_active Expired - Fee Related
Patent Citations (12)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
EP0704851A1 (en) * | 1994-09-27 | 1996-04-03 | STMicroelectronics S.r.l. | Byte erasable EEPROM fully compatible with a single power supply flash-EPROM process |
US6222775B1 (en) * | 1999-06-22 | 2001-04-24 | Stmicroelectronics S.R.L. | Flash compatible EEPROM |
CN1524227A (en) | 2002-04-03 | 2004-08-25 | 索尼株式会社 | Recording device and method, storage medium and program |
US20050251617A1 (en) * | 2004-05-07 | 2005-11-10 | Sinclair Alan W | Hybrid non-volatile memory system |
US20070083697A1 (en) | 2005-10-07 | 2007-04-12 | Microsoft Corporation | Flash memory management |
US20070147116A1 (en) | 2005-12-22 | 2007-06-28 | Shekoufeh Qawami | Use of flash memory blocks outside of the main flash memory array |
US20070283082A1 (en) * | 2006-04-13 | 2007-12-06 | Christophe Laurent | Optimized flash memory access method and device |
US20080068897A1 (en) * | 2006-09-19 | 2008-03-20 | Samsung Electronics Co., Ltd. | Semiconductor memory device and memory system including semiconductor memory device |
KR20080025927A (en) * | 2006-09-19 | 2008-03-24 | 삼성전자주식회사 | Semiconductor memory device and memory system including same |
KR100843142B1 (en) * | 2006-09-19 | 2008-07-02 | 삼성전자주식회사 | Semiconductor memory device and memory system including same |
US7580295B2 (en) * | 2006-09-19 | 2009-08-25 | Samsung Electronics Co., Ltd. | Semiconductor memory device and memory system including semiconductor memory device |
US20090027950A1 (en) * | 2007-07-26 | 2009-01-29 | Chung Hon Lam | Block Erase for Phase Change Memory |
Non-Patent Citations (3)
Title |
---|
Intel StrataFlash® Cellular Memory (M18), Order No. 309823, Revision 1, Oct. 24, 2005, 126 pages. |
Spansion. "S71NS-N MCP Products-MirrorBit 1.8 Volt-only Simultaneous Read/Write Burst-mode Multiplexed Flash Memory" Advance Information Data Sheet. Spansion Pub. No. S71NS-N-00 A3, published Oct. 10, 2006. * |
Spansion. "S71NS-N MCP Products—MirrorBit 1.8 Volt-only Simultaneous Read/Write Burst-mode Multiplexed Flash Memory" Advance Information Data Sheet. Spansion Pub. No. S71NS-N—00 A3, published Oct. 10, 2006. * |
Cited By (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20190066784A1 (en) * | 2013-11-22 | 2019-02-28 | Micron Technology, Inc. | Memory Systems and Memory Programming Methods |
US10937493B2 (en) * | 2013-11-22 | 2021-03-02 | Micron Technology, Inc. | Memory systems and memory programming methods |
US11011229B2 (en) | 2013-12-16 | 2021-05-18 | Micron Technology, Inc. | Memory systems and memory programming methods |
US20190074060A1 (en) * | 2014-01-09 | 2019-03-07 | Micron Technology, Inc. | Memory Systems and Memory Programming Methods |
US11024378B2 (en) * | 2014-01-09 | 2021-06-01 | Micron Technology , Inc. | Memory systems and memory programming methods |
Also Published As
Publication number | Publication date |
---|---|
US20090055575A1 (en) | 2009-02-26 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US8850102B2 (en) | Flash memory with small data programming capability | |
JP4834676B2 (en) | System and method using on-chip non-volatile memory write cache | |
US8180953B2 (en) | Data accessing method for flash memory, and storage system and controller system thereof | |
US10120615B2 (en) | Memory management method and storage controller using the same | |
US8037232B2 (en) | Data protection method for power failure and controller using the same | |
CN106598479B (en) | Method and apparatus for fail-safe erasure of flash memory | |
US8015370B2 (en) | Memory control method and memory system | |
US20080172521A1 (en) | Memory System Determining Storage Mode According to Host Provided Data Information | |
US20100017557A1 (en) | Memory controller, nonvolatile memory device,access device, and nonvolatile memory system | |
US9846643B2 (en) | Methods for maintaining a storage mapping table and apparatuses using the same | |
US20110004723A1 (en) | Data writing method for flash memory and control circuit and storage system using the same | |
US20090198875A1 (en) | Data writing method for flash memory, and controller and system using the same | |
US9619380B2 (en) | Data writing method, memory control circuit unit and memory storage apparatus | |
CN107402716B (en) | Data writing method, memory control circuit unit and memory storage device | |
US7193923B2 (en) | Semiconductor memory device and access method and memory control system for same | |
US20100057979A1 (en) | Data transmission method for flash memory and flash memory storage system and controller using the same | |
JP2006031696A (en) | Flash memory system including bad block management part | |
US11748011B2 (en) | Control method of flash memory controller and associated flash memory controller and storage device | |
US9122583B2 (en) | Memory controller and memory storage device and data writing method | |
US9383929B2 (en) | Data storing method and memory controller and memory storage device using the same | |
US20150234741A1 (en) | Command Execution Using Existing Address Information | |
TWI408692B (en) | Address translation between a memory controller and an external memory device | |
US9378130B2 (en) | Data writing method, and memory controller and memory storage apparatus using the same | |
US9507706B2 (en) | Memory system controller including a multi-resolution internal cache | |
US20190278703A1 (en) | Memory system, operating method thereof and electronic device |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
AS | Assignment |
Owner name: NOKIA CORPORATION, FINLAND Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:HANHIMAKI, PETTERI;JARVINEN, ILPO;REEL/FRAME:021033/0963;SIGNING DATES FROM 20050516 TO 20080506 Owner name: NOKIA CORPORATION, FINLAND Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:HANHIMAKI, PETTERI;JARVINEN, ILPO;SIGNING DATES FROM 20050516 TO 20080506;REEL/FRAME:021033/0963 |
|
FEPP | Fee payment procedure |
Free format text: PAYOR NUMBER ASSIGNED (ORIGINAL EVENT CODE: ASPN); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY Free format text: PAYER NUMBER DE-ASSIGNED (ORIGINAL EVENT CODE: RMPN); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY |
|
STCF | Information on status: patent grant |
Free format text: PATENTED CASE |
|
AS | Assignment |
Owner name: NOKIA TECHNOLOGIES OY, FINLAND Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:NOKIA CORPORATION;REEL/FRAME:035496/0763 Effective date: 20150116 |
|
AS | Assignment |
Owner name: PROVENANCE ASSET GROUP LLC, CONNECTICUT Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:NOKIA TECHNOLOGIES OY;NOKIA SOLUTIONS AND NETWORKS BV;ALCATEL LUCENT SAS;REEL/FRAME:043877/0001 Effective date: 20170912 Owner name: NOKIA USA INC., CALIFORNIA Free format text: SECURITY INTEREST;ASSIGNORS:PROVENANCE ASSET GROUP HOLDINGS, LLC;PROVENANCE ASSET GROUP LLC;REEL/FRAME:043879/0001 Effective date: 20170913 Owner name: CORTLAND CAPITAL MARKET SERVICES, LLC, ILLINOIS Free format text: SECURITY INTEREST;ASSIGNORS:PROVENANCE ASSET GROUP HOLDINGS, LLC;PROVENANCE ASSET GROUP, LLC;REEL/FRAME:043967/0001 Effective date: 20170913 |
|
MAFP | Maintenance fee payment |
Free format text: PAYMENT OF MAINTENANCE FEE, 4TH YEAR, LARGE ENTITY (ORIGINAL EVENT CODE: M1551) Year of fee payment: 4 |
|
AS | Assignment |
Owner name: NOKIA US HOLDINGS INC., NEW JERSEY Free format text: ASSIGNMENT AND ASSUMPTION AGREEMENT;ASSIGNOR:NOKIA USA INC.;REEL/FRAME:048370/0682 Effective date: 20181220 |
|
AS | Assignment |
Owner name: PROVENANCE ASSET GROUP LLC, CONNECTICUT Free format text: RELEASE BY SECURED PARTY;ASSIGNOR:CORTLAND CAPITAL MARKETS SERVICES LLC;REEL/FRAME:058983/0104 Effective date: 20211101 Owner name: PROVENANCE ASSET GROUP HOLDINGS LLC, CONNECTICUT Free format text: RELEASE BY SECURED PARTY;ASSIGNOR:CORTLAND CAPITAL MARKETS SERVICES LLC;REEL/FRAME:058983/0104 Effective date: 20211101 Owner name: PROVENANCE ASSET GROUP LLC, CONNECTICUT Free format text: RELEASE BY SECURED PARTY;ASSIGNOR:NOKIA US HOLDINGS INC.;REEL/FRAME:058363/0723 Effective date: 20211129 Owner name: PROVENANCE ASSET GROUP HOLDINGS LLC, CONNECTICUT Free format text: RELEASE BY SECURED PARTY;ASSIGNOR:NOKIA US HOLDINGS INC.;REEL/FRAME:058363/0723 Effective date: 20211129 |
|
AS | Assignment |
Owner name: RPX CORPORATION, CALIFORNIA Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:PROVENANCE ASSET GROUP LLC;REEL/FRAME:059352/0001 Effective date: 20211129 |
|
FEPP | Fee payment procedure |
Free format text: MAINTENANCE FEE REMINDER MAILED (ORIGINAL EVENT CODE: REM.); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY |
|
LAPS | Lapse for failure to pay maintenance fees |
Free format text: PATENT EXPIRED FOR FAILURE TO PAY MAINTENANCE FEES (ORIGINAL EVENT CODE: EXP.); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY |
|
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: 20220930 |