Techniques are presented for sending an application instruction from a hosting digital appliance to a portable medium, where the instruction is structured as one or more units whose size is a first size, or number of bytes. After flushing the contents of a cache, the instruction is written to the cache, where the cache is structured as logical blocks having a size that is a second size that is larger (in terms of number of bytes) than the first size. In writing the instruction (having a command part and, possibly, a data part), the start of the instruction is aligned with one of the logical block boundaries in the cache and the instruction is padded out with dummy data so that it fills an integral number of the cache blocks. When a response from a portable device to an instruction is received at a hosting digital appliance, the cache is similarly flushed prior to receiving the response. The response is then stored to align with a logical block boundary of the cache.
|
13. A method of receiving at a hosting digital appliance a response to an application instruction issued by the digital appliance from a controller circuit of a detachable non-volatile memory system connected thereto, Where the non-volatile memory system includes one or more non-volatile memory circuits and the controller circuit and wherein the response is structured as one or more units whose size is a first number of bytes, the method comprising:
issuing the application instruction from the hosting digital appliance to the non-volatile memory system;
flushing the contents of a cache on the hosting digital appliance, where the cache on the hosting appliance is structured as a plurality of logical blocks whose size is a second number of bytes, the second number being greater than the first number;
subsequently receiving the response from the controller circuit to the application instruction on the hosting digital appliance; and
storing the response from the controller circuit in the cache on the hosting digital appliance, the storing including:
aligning the start of the response with a boundary of the logical blocks.
1. A method of sending an application instruction from a hosting digital appliance to a detachable non-volatile memory system connected thereto, the non-volatile memory system including one or more non-volatile memory circuits and a controller circuit by which the application instruction is to be executed, wherein the application instruction is structured as one or more units whose size is a first number of bytes, the method comprising:
flushing the contents of a cache on the hosting digital appliance;
subsequently writing the application instruction to the cache on the hosting digital appliance, where the cache on the hosting digital appliance is structured as a plurality of logical blocks whose size is a second number of bytes, the second number being greater than the first number, the writing including:
aligning the start of the application instruction with a boundary of the logical blocks; and
padding the application instruction with dummy data to have a size which is an integer multiple of the second number of bytes; and
subsequently sending the application instruction from the cache on the hosting digital appliance to the non-volatile memory system.
4. The method of
5. The method of
6. The method of
9. The method of
in response to the application instruction, returning data from the non-volatile memory system to the hosting digital appliance.
10. The method of
storing the returned data in the cache on the hosting digital appliance, including aligning the start of the data with a boundary of the logical blocks.
11. The method of
storing a response to the application instruction in the cache on the hosting digital appliance, wherein the response to the application instruction is structured as one or more units whose size is the first number of bytes and the storing includes aligning the start of the response with a boundary of the logical blocks.
12. The method of
closing by the hosting digital appliance of the non-volatile memory system; and
subsequently opening by the hosting digital appliance of the non-volatile memory system.
15. The method of
padding the response with dummy data to have a size Which is an integer multiple of the second number of bytes.
16. The method of
18. The method of
closing by the hosting digital appliance of the non-volatile memory system; and
subsequently opening by the hosting digital appliance of the non-volatile memory system.
|
This invention pertains generally to the field of using portable media, such as a secure memory card, with digital appliances, such as a telephone handset, and more particularly to techniques for transferring instructions between a digital appliance and a portable media in communication therewith.
Digital appliances, such as notebook or laptop computers, personal digital assistants (PDAs), or mobile phones, are commonly used with portable media, such as memory cards or USB drives. In some cases, secure data is stored on these portable media. The application responsible for securely transferring this data between the hosting appliance and the media often uses instructions that have a specific structure. As part of the transfer process, the host may cache the instruction; but as the host's operating system may unaware of the instruction's structure, and because the host's cache structure may not be compatible with the instruction's structure, the instruction, along with any associated data, may not be successfully transferred.
According to a one aspect, techniques are presented for sending an application instruction from a hosting digital appliance to a portable medium, where the instruction is structured as one or more units whose size is a first size, or number of bytes. After flushing the contents of a cache, the instruction is written to the cache, where the cache is structured as logical blocks having a size that is a second size that is larger (in terms of number of bytes) than the first size. In writing the instruction (having a command part and, possibly, a data part), the start of the instruction is aligned with one of the logical block boundaries in the cache and the instruction is padded out with dummy data so that it fills an integral number of the cache blocks.
According to another aspect, when a response from a portable device to an instruction is received at a hosting digital appliance, the cache is similarly flushed prior to receiving the response. The response is then stored to align with a logical block boundary of the cache.
Various aspects, advantages, features and embodiments of the present invention are included in the following description of exemplary examples thereof, which description should be taken in conjunction with the accompanying drawings. All patents, patent applications, articles, other publications, documents and things referenced herein are hereby incorporated herein by this reference in their entirety for all purposes. To the extent of any inconsistency or conflict in the definition or use of terms between any of the incorporated publications, documents or things and the present application, those of the present application shall prevail.
The various aspects and features of the present invention may be better understood by examining the following figures, in which:
When transferring content between a portable medium, such as a memory card, and a hosting digital appliance, such as mobile telephone handset, a host's operation system will often use a caching mechanism for the content. This cache will typically have a structure where it is logically broken up into a number of blocks of a particular size. The content being transferred, whether data or an instruction (a command and maybe some associated data), may also be structured in a specific way as one or more sections of a certain size. When the content is structure in units of one size (for example, as 512 Byte sectors) and the cache is structured in units of another size (for example, in 2 KB blocks), the caching mechanism may clash with the content's structural requirements.
This is particularly true with dealing with secure content and secure portable storage media, such as that marketed under the TrustedFlash name. In such cases, the more basic levels of a host's operating system that handle transfers between the host and the portable medium will see the instruction as just so much data, being unaware of any embedded commands in the instruction, and store it as such in cache. Examples of such instructions and their use are described in U.S. Pat. No. 7,237,046, U.S. patent application Ser. No. 10/899,260, and, particularly, U.S. patent application Ser. Nos. 11/298,349 and 11/299,186. Under such arrangements, the host's operating system may treat the instruction as data to be written to a particular address on the medium; but, when received on the medium, this instruction will be interpreted as, for example, a write command to store data at different address on the medium. If the host then tries to issue a read command for this data, the address as seen by the host's operating system will not correspond to the actual address as interpreted on the medium; and as the host may then rely what is thinks is cached copy of the data, it will incorrectly use this cached data.
The techniques described here are widely applicable, both for portable media, such as memory cards, that are primarily used with a hosting digital appliance, and also digital. appliances which themselves include non-volatile memory, such as embedded flash. Example of such digital appliances include desktop, notebook or laptop tablet computers, personal digital assistants (PDAS), mobile phone handsets, a variety of media players such as MP3 players, DVD players, gaming consoles, digital recording devices such as digital cameras, and others. Suitable portable media are available from SanDisk Corporation, the assignee hereof, which include those sold under trademarks TrustedFlash, CompactFlash (CF), Multi-Media Card (MMC), Secure Digital (SD), MicroSD and Memory Stick PRO. These memory cards are removably connectable with digital appliances through mating connectors that are different thr most cards. Flash drives, sold as those sold under the Cruzer trademark, contain a plug according to the Universal Serial Bus (USB) standard, so can be plugged directly into any digital appliance having a USB receptacle. TrustedHash cards and other secure cards (SIM, SMMC, SD, etc) allow secure storage of the both licenses and associated content. Also the following discussion will often refer to non-volatile memory as flash, the techniques given here are not so limited and more generally apply to other non-volatile memory structures (such as described in US patent application Ser. No. 10/841,379, published as US Patent Application Publication number 2005/0251617. for example), for both portable devices and embedded memories. Although the teachings given here are not so limited, when reference is made to a particular embodiment flit purposes of discussion, the following will often refer to the concrete example of a mobile telephone handset used with a memory card, such as that of the TrustedFlash variety, having instructions whose structure is based on a sector.
To circumvent such possible difficulties with the host caching, firmware associated with the secure transfer can be changed to be aware of the running time command size; the associated application toolkit needs to be integrated with the applications; instructions sent from the application to the platform operation system (OS), including write and read commands, start with a cache block size aligned sector; and that the write, read buffer size should be cache block size aligned.
Technically, to allow fast spread out of secure content media to users of digital appliances, integration for these platforms with the corresponding secure content toolkit is important. Due to the special requirements of most secure content technology and code size consideration, the corresponding application toolkit usually needs to be integrated into the operating system (OS) of a handset or other hosting device, so that the applications can call the application programming interfaces (APIs) provided by the toolkit to access the media. However, for certain standardized or open platforms, say Linux and WIPI, this solution can be complicated to implement since it is not easy to have the needed platform modifications to support secure content media.
To overcome this limitation, every platform will provide a way for applications to access generic IO device; in case of a TrustedFlash card, this is the SD IO device. With this assumption, the applications can use the provided IO access to communicate with the secure content media card by integrating the corresponding toolkit into the applications. This can be used for any platforms, especially being good for those unmodified platforms, as long as the IO device is accessible for applications. The major difficulty of this solution is to deal with the caching mechanism, which is used most likely for every platform. The following section describes the nature of this caching mechanism, and the conflicts between its buffered IO and the earlier versions of secure content transfer firmware.
Problem of Buffered IO with Current Secure Transfer Firmware
As noted, many command and data transfer processes rely upon a particular structure for instructions. For example, current TrustedFlash firmware is defined to communicate with the handset or other host through sector (512 Bytes) based instructions. The number of sectors for each instruction is predefined. This can cause a major IO problem for buffered IO only platforms. Due to the hosting platform's caching mechanism, the instructions sent to TrustedFlash firmware on the media may not be sector based, so that the TrustedFlash communication channel is broken. For example, a TrustedFlash CREATE ACR command is a one-sector write instruction. When an application sends a one-sector write to the platform OS, this write command may be changed to a write command with multiple sectors, and the starting write location may be changed as well, after this command reaches the secure transfer firmware on the media.
A common scenario for write command is the following:
In practice, some platforms support direct IO, while others only provide buffered IO. In addition, the caching algorithms may be different from platform to platform. Therefore, a generic solution is quite preferable for integration with secure transfer application's toolkit. The following discussion present such an integrated solution, based on the example for TrustedFlash, that works whether the host platform uses direct IO or buffered IO. This is presented below as including four components: the structure of system integration; the modification of firmware; and the methods of solving caching for write and for read.
Integrating Secure Transfer Toolkit into Applications
Since a platform remains the same, for the applications to access the secure content card, the corresponding toolkit will need to integrate into the host's applications so that they can call the toolkit APIs to send, say, TrustedFlash commands to the TrustedFlash cards. Briefly, the toolkit provides full package of APIs for applications to access the secure media. This package offers many functions related with secure system, such as system operation, account operation, storage operation, and digital rights management (DRM) operation.
The applications will directly call the toolkit's APIs, and then the toolkit will talk to the corresponding secure medium by using the device operation methods provided by the platform OS. For example, in Linux, this methods are open( ), read( ), write( ), and close( ). According to each individual platform, this glue layer between toolkit and the platform is implemented in the Platform I/O Device Operation.
The Modification of Secure Firmware
As discussed above, the instructions used in secure data protocols are often based on units of a particular number of bits. For example, the TrustedFlash instructions for communicating between a host and the TrustedFlash firmware on media are sector-based. The number of sectors for each instruction is predefined during the firmware loading.
As shown in
In order to make the media firmware understood the commands from platforms with buffered IO, the current firmware preferably knows the dynamical command size of each commands. To do so, one field can be introduced to add into the command block to specify the total size of current sending command. For example, in the table of
When a platform OS is using buffered IO, the behaviors for both read and write may be changed as described below. The following two sections describe the way to deal with the caching on write, when an instruction is sent to the medium, and read, when a response is returned. Briefly, this process is illustrated in
Method of Direct Write Command for Buffered IO
The secure transfer firmware is the agent inside the media (e.g., TrustedFlash) card to handle the commands. The secure transfer commands from the host are preferably sent to the card immediately. Therefore, if the platform OS does not send a write command to the card, but puts the data into the buffer instead, the medium will have no way to get the command and respond to it. In addition, for instructions structured with the command block required to be in a specific locations, as with the TrustedFlash command block that must be the first sector of the whole command, the sequence of the write command must follow the appropriate (e.g. TrustedFlash) protocol; any extra reads or writes in the command sequence before command completion, including get command status, will cause problems to firmware, so that the command will not succeed. Below is the method to solve these problems one by one.
The method of forcing the OS to flush write command is the following:
Generally, when a card is inserted to the host, the host will initialize and mount the media/card. To access the contents of the media, it will open the media. It is considered as “logical” open. Related data, table, cache, and so on are established. After that, you can browse the directories, or open “file” for read/write operation. By “closing” the media, all cache contents, tables or data are cleared or invalidated. For example, the Linux operating system includes an open( ) command and a close( ) command. The close( ) command closes a file descriptor of the media so that it no longer refers to any file and may be used. Any record locks held on the file descriptor it was associated with, and owned with the process are removed. To logically reopen the device, a call to open( ) will create a new open file description. (These are described further in the Linux programmers manual.)
The other problem is the potential change of write location, write buffer size, and command sequence. To avoid these, the toolkit will send to the medium a command in the following way:
The flow chart of
The instruction is then placed in the flushed cache at block 705. As shown in
Returning to
Methods to Deal with Caching for IO Read
After receiving an instruction form the host, the medium may need to respond to the host, such as with a status or with data in response to a read request. Because of caching, whenever the application send a read command, the OS may just go to the cache to read it back if the related location data is in the cache. Therefore, the actual firmware response is not returned back to the application.
To deal with this problem, cache bypass can be used in the following way:
At 803, the cache is flushed as at 703, with a close and then open or, if available, with a command to flush the cache. As the cache is now emptied, this prevents the operating system from just returning cached material instead of the actual response from the medium. At 805, the alignment is checked to see that when the received response is placed in the cache, it will be aligned with the logical block structure of the cache. Finally, the read command is sent to the platform's operating system.
Once these preparations have been made, the driver can then send the read instruction to the medium, which will then return the response. As noted, this may include actual secure user data (that, data as seen be the secure transfer system) or a non-data response, such as a status. The response is then cached aligned with the logical block boundaries of the cache. Padding, which secure transfer application would then ignore, may also be added to fill out an integral number of cache blocks.
Although the invention has been described with reference to particular embodiments, the description is only an example of the invention's application and should not be taken as a limitation. Consequently, various adaptations and combinations of features of the embodiments disclosed are within the scope of the invention as encompassed by the following claims.
Qawami, Bahman, Sabet-sharghi, Farshid, Yuan, Po, Liu, Xian Jun, Barzilai, Ron, Chang, Robert C., Wang, Junzhi
Patent | Priority | Assignee | Title |
Patent | Priority | Assignee | Title |
4634807, | Aug 23 1984 | British Technology Group Limited | Software protection device |
4992931, | Dec 26 1986 | Kabushiki Kaisha Toshiba | Data alignment correction apparatus for properly formatting data structures for different computer architectures |
5450489, | Oct 29 1993 | WARNER BROS HOME ENTERTAINMENT INC | System and method for authenticating software carriers |
5530235, | Feb 16 1995 | CONTENTGUARD HOLDINGS, INC | Interactive contents revealing storage device |
5581743, | Dec 27 1993 | International Business Machines Corporation | CKD to fixed block mapping for optimum performance and space utilization |
5689702, | Jun 07 1995 | Mentor Graphics Corporation | Flexible data structure layout for data structure including bit-field data members |
5715403, | Nov 23 1994 | CONTENTGUARD HOLDINGS, INC | System for controlling the distribution and use of digital works having attached usage rights where the usage rights are defined by a usage rights grammar |
5847698, | Sep 17 1996 | DataVentures, Inc. | Electronic book device |
5887269, | Apr 07 1995 | VALUE STREET CONSULTING GROUP LLC | Data product authorization control for GPS navigation system |
5897663, | Dec 24 1996 | HEWLETT-PACKARD DEVELOPMENT COMPANY, L P | Host I2 C controller for selectively executing current address reads to I2 C EEPROMs |
5956034, | Aug 13 1996 | Rovi Technologies Corporation | Method and apparatus for viewing electronic reading materials |
5982891, | Feb 13 1995 | Intertrust Technologies Corp. | Systems and methods for secure transaction management and electronic rights protection |
5991399, | Dec 18 1997 | HONEYMAN CIPHER SOLUTIONS LLC | Method for securely distributing a conditional use private key to a trusted entity on a remote system |
6009525, | Aug 29 1997 | SAFENET DATA SECURITY ISRAEL LTD | Multi-tier electronic software distribution |
6055314, | Mar 22 1996 | Rovi Technologies Corporation | System and method for secure purchase and delivery of video content programs |
6073226, | Mar 19 1997 | Microsoft Technology Licensing, LLC | System and method for minimizing page tables in virtual memory systems |
6191712, | Jun 28 1999 | International Business Machines Corporation | Circuit for aligning logical sectors with physical sectors in a disk storage system |
6226618, | Aug 13 1998 | Level 3 Communications, LLC | Electronic content delivery system |
6240506, | Oct 02 1998 | Advanced Micro Devices, Inc. | Expanding instructions with variable-length operands to a fixed length |
6247097, | Jan 22 1999 | International Business Machines Corporation | Aligned instruction cache handling of instruction fetches across multiple predicted branch instructions |
6314409, | Nov 05 1997 | HANGER SOLUTIONS, LLC | System for controlling access and distribution of digital property |
6317809, | Feb 19 1997 | MEDIATEK INC | Optical disk under-run protection using formatted padding sectors |
6317812, | Jul 26 1991 | SanDisk Technologies LLC | Device and method for controlling solid-state memory system |
6363437, | Jan 07 1999 | CLUSTER, LLC; Optis Wireless Technology, LLC | Plug and play I2C slave |
6385677, | Nov 26 1999 | A-DATA TECHNOLOGY CO , LTD ; ATECH TOTALSOLUTION CO , LTD | Dual interface memory card and adapter module for the same |
6418421, | Aug 13 1998 | Level 3 Communications, LLC | Multimedia player for an electronic content delivery system |
6438638, | Jul 06 2000 | MCM Portfolio LLC | Flashtoaster for reading several types of flash-memory cards with or without a PC |
6460116, | Sep 21 1998 | GLOBALFOUNDRIES Inc | Using separate caches for variable and generated fixed-length instructions |
6502146, | Mar 29 2000 | Intel Corporation | Apparatus and method for dedicated interconnection over a shared external bus |
6529949, | Feb 07 2000 | Rovi Technologies Corporation | System, method and article of manufacture for remote unlocking of local content located on a client device |
6546193, | Oct 28 1997 | LG Electronics Inc. | Reproduction apparatus for remote rental system and control method of said apparatus |
6550011, | Aug 05 1998 | HEWLETT-PACKARD DEVELOPMENT COMPANY, L P | Media content protection utilizing public key cryptography |
6611358, | Jun 17 1997 | Lucent Technologies Inc. | Document transcoding system and method for mobile stations and wireless infrastructure employing the same |
6697944, | Oct 01 1999 | Microsoft Technology Licensing, LLC | Digital content distribution, transmission and protection system and method, and portable device for use therewith |
6738614, | Jun 19 2000 | 1477.com Wireless, Inc. | Method and system for communicating data to a wireless device |
6738905, | Apr 15 1998 | GOOGLE LLC | Conditional access via secure logging with simplified key management |
6742109, | Nov 30 2000 | Oracle America, Inc | Method and apparatus for representing variable-size computer instructions |
6745267, | Aug 09 2002 | Carry Computer Eng. Co., Ltd. | Multi-functional mini-memory card suitable for SFMI and USB interfaces |
6757749, | Nov 01 1999 | Seiko Epson Corporation | Data-output-control apparatus and data-output-service providing method |
6813725, | Jan 26 2000 | HEWLETT-PACKARD DEVELOPMENT COMPANY L P | Method for restoring an operating system utilizing a storage device on a USB bus |
6824051, | Jun 07 2001 | CONTENTGUARD HOLDINGS, INC | Protected content distribution system |
6876984, | May 31 2001 | CONTENGUARD HOLDINGS, INC | Method and apparatus for establishing usage rights for digital content to be created in the future |
6886036, | Nov 02 1999 | WSOU Investments, LLC | System and method for enhanced data access efficiency using an electronic book over data networks |
6907585, | Apr 17 2002 | Renesas Electronics Corporation | Semiconductor integrated circuit and its design methodology |
6922725, | Sep 07 2001 | Xerox Corporation | Method and apparatus for processing document service requests originating from a mobile computing device |
6944600, | Nov 23 1994 | ContentGuard Holdings, Inc. | System for controlling the distribution and use of digital works using digital tickets |
6973445, | May 31 2001 | CONTENTGUARD HOLDINGS, INC | Demarcated digital content and method for creating and processing demarcated digital works |
6974076, | Feb 14 2000 | Sony Corporation; Sony Electronics Inc. | Portable music player with pay per play usage and method for purchase of credits for usage |
6983367, | Mar 14 2000 | Sony Corporation | Information providing apparatus and method, information processing apparatus and method, and program storage medium |
7023572, | Feb 02 2000 | TULI, RAJA SINGH, MR | Portable high speed internet access device |
7068381, | Feb 02 2000 | TULI, RAJA SINGH, MR | Portable high speed internet access device |
7068387, | Jul 05 2000 | CHINA CITIC BANK CORPORATION LIMITED, GUANGZHOU BRANCH, AS COLLATERAL AGENT | Quick edit and speed print capability for a stand-alone ink jet printer |
7237046, | Mar 27 2003 | Sandisk IL Ltd | Data storage device with full access by all users |
20010013021, | |||
20020099955, | |||
20020112172, | |||
20020152172, | |||
20020162009, | |||
20020184156, | |||
20020185533, | |||
20020196364, | |||
20030018582, | |||
20030093598, | |||
20030167236, | |||
20030225765, | |||
20030233501, | |||
20040035939, | |||
20040039932, | |||
20040064612, | |||
20040093509, | |||
20040137664, | |||
20040193744, | |||
20040205453, | |||
20040210433, | |||
20050004875, | |||
20050015549, | |||
20050042930, | |||
20050044330, | |||
20050061873, | |||
20050138551, | |||
20050149450, | |||
20050195635, | |||
20050230483, | |||
20050230484, | |||
20050251617, | |||
20050289072, | |||
20060010500, | |||
20060080535, | |||
20060084287, | |||
20060136656, | |||
20060294289, | |||
20070070842, | |||
20070186032, | |||
20070214326, | |||
20080065552, | |||
20080065911, | |||
20080209109, | |||
DE19820479, | |||
EP1209574, | |||
EP1304665, | |||
EP1376309, | |||
GB2367925, | |||
TW200715797, | |||
WO2004031935, | |||
WO2006057991, | |||
WO169354, | |||
WO193000, | |||
WO2004086363, | |||
WO2005116819, | |||
WO2006110213, | |||
WO2007076214, | |||
WO9842098, |
Executed on | Assignor | Assignee | Conveyance | Frame | Reel | Doc |
Dec 07 2007 | WANG, JUNZHI | SanDisk Corporation | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 020341 | /0433 | |
Dec 07 2007 | SABET-SHARGI, FARSHID | SanDisk Corporation | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 020341 | /0433 | |
Dec 07 2007 | LIU, XIAN JUN | SanDisk Corporation | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 020341 | /0433 | |
Dec 07 2007 | CHANG, ROBERT C | SanDisk Corporation | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 020341 | /0433 | |
Dec 07 2007 | YUAN, PO | SanDisk Corporation | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 020341 | /0433 | |
Dec 07 2007 | BARZILAI, RON | SanDisk Corporation | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 020341 | /0433 | |
Dec 10 2007 | QAWAMI, BAHMAN | SanDisk Corporation | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 020341 | /0433 | |
Dec 13 2007 | SanDisk Technologies Inc. | (assignment on the face of the patent) | / | |||
Apr 04 2011 | SanDisk Corporation | SanDisk Technologies Inc | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 026276 | /0703 | |
May 16 2016 | SanDisk Technologies Inc | SanDisk Technologies LLC | CHANGE OF NAME SEE DOCUMENT FOR DETAILS | 038809 | /0600 |
Date | Maintenance Fee Events |
Nov 01 2018 | M1551: Payment of Maintenance Fee, 4th Year, Large Entity. |
Jan 02 2023 | REM: Maintenance Fee Reminder Mailed. |
Jun 19 2023 | EXP: Patent Expired for Failure to Pay Maintenance Fees. |
Date | Maintenance Schedule |
May 12 2018 | 4 years fee payment window open |
Nov 12 2018 | 6 months grace period start (w surcharge) |
May 12 2019 | patent expiry (for year 4) |
May 12 2021 | 2 years to revive unintentionally abandoned end. (for year 4) |
May 12 2022 | 8 years fee payment window open |
Nov 12 2022 | 6 months grace period start (w surcharge) |
May 12 2023 | patent expiry (for year 8) |
May 12 2025 | 2 years to revive unintentionally abandoned end. (for year 8) |
May 12 2026 | 12 years fee payment window open |
Nov 12 2026 | 6 months grace period start (w surcharge) |
May 12 2027 | patent expiry (for year 12) |
May 12 2029 | 2 years to revive unintentionally abandoned end. (for year 12) |