The patent badge is an abbreviated version of the USPTO patent document. The patent badge does contain a link to the full patent document.

The patent badge is an abbreviated version of the USPTO patent document. The patent badge covers the following: Patent number, Date patent was issued, Date patent was filed, Title of the patent, Applicant, Inventor, Assignee, Attorney firm, Primary examiner, Assistant examiner, CPCs, and Abstract. The patent badge does contain a link to the full patent document (in Adobe Acrobat format, aka pdf). To download or print any patent click here.

Date of Patent:
Jan. 09, 2018

Filed:

Aug. 17, 2015
Applicant:

Teleputers, Llc, Princeton, NJ (US);

Inventors:

Ruby B. Lee, Princeton, NJ (US);

Zhenghong Wang, San Jose, CA (US);

Assignee:

Teleputers, LLC, Princeton, NJ (US);

Attorney:
Primary Examiner:
Int. Cl.
CPC ...
G06F 12/08 (2016.01); G06F 12/128 (2016.01); G06F 12/0802 (2016.01); G06F 12/0846 (2016.01); G06F 12/0891 (2016.01); G06F 12/0811 (2016.01); G06F 12/0864 (2016.01);
U.S. Cl.
CPC ...
G06F 12/128 (2013.01); G06F 12/0802 (2013.01); G06F 12/0846 (2013.01); G06F 12/0891 (2013.01); G06F 12/0811 (2013.01); G06F 12/0864 (2013.01); G06F 2212/1021 (2013.01); Y02B 60/1225 (2013.01);
Abstract

A cache memory having enhanced performance and security feature is provided. The cache memory includes a data array storing a plurality of data elements, a tag array storing a plurality of tags corresponding to the plurality of data elements, and an address decoder which permits dynamic memory-to-cache mapping to provide enhanced security of the data elements, as well as enhanced performance. The address decoder receives a context identifier and a plurality of index bits of an address passed to the cache memory, and determines whether a matching value in a line number register exists. The line number registers allow for dynamic memory-to-cache mapping, and their contents can be modified as desired. Methods for accessing and replacing data in a cache memory are also provided, wherein a plurality of index bits and a plurality of tag bits at the cache memory are received. The plurality of index bits are processed to determine whether a matching index exists in the cache memory and the plurality of tag bits are processed to determine whether a matching tag exists in the cache memory, and a data line is retrieved from the cache memory if both a matching tag and a matching index exist in the cache memory. A random line in the cache memory can be replaced with a data line from a main memory, or evicted without replacement, based on the combination of index and tag misses, security contexts and protection bits. User-defined and/or vendor-defined replacement procedures can be utilized to replace data lines in the cache memory.


Find Patent Forward Citations

Loading…