Secure cryptographic multi-exponentiation method and coprocessor subsystem
First Claim
Patent Images
1. A system for use in connection with a host system for performing high-speed exponentiation, comprising:
- an interface for receiving and sending data to a host system;
a plurality of exponentiators provided to perform exponentiation on data received from the host system; and
logic circuitry coupled to receive data to be provided from the host system and adapted to query a status of one of the exponentiators and, in response to an indication of availability, to select said one of the plurality of exponentiators as an available exponentiator, and to use the available exponentiator from said plurality of exponentiators to process the received data.
6 Assignments
0 Petitions
Accused Products
Abstract
A system for performing high speed exponentiation in a secure environment. The system includes an interface for receiving encrypted data sent from a host system, a plurality of exponentiators capable of operating concurrently, an encyptor decrypting data received from a host system and encrypting data produced from the exponentiators, and logic circuitry for selecting an available and properly functioning exponentiator to perform exponentiation on the received data.
-
Citations
44 Claims
-
1. A system for use in connection with a host system for performing high-speed exponentiation, comprising:
-
an interface for receiving and sending data to a host system; a plurality of exponentiators provided to perform exponentiation on data received from the host system; and logic circuitry coupled to receive data to be provided from the host system and adapted to query a status of one of the exponentiators and, in response to an indication of availability, to select said one of the plurality of exponentiators as an available exponentiator, and to use the available exponentiator from said plurality of exponentiators to process the received data. - View Dependent Claims (2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14)
-
-
15. A method for performing high speed exponentiation of data transferred from a host system, comprising:
-
receiving data in encrypted form; decrypting said encrypted data; and performing exponentiation of the received data to produce resulting data using a plurality of concurrently-operating exponentiators provided to perform exponentiation on data received from the host system. - View Dependent Claims (16, 17, 22)
-
-
18. A method for performing high speed exponentiation of data transferred from a host system, comprising:
-
receiving data; performing exponentiation of said received data to produce resulting data using a plurality of exponentiators provided to perform exponentiation on data received from the host system, wherein the received data is in encrypted form; decrypting said encrypted data; encrypting said resulting data after performing exponentiation;
wherein said encrypted data has been encrypted at said host system using a second key;storing a first key in a non-volatile memory; receiving said second key in encrypted form, wherein said second key has been encrypted using said first key; decrypting said second key with said first key; decrypting said received data with said second key; and encrypting said resulting data with said second key after performing exponentiation. - View Dependent Claims (19, 20)
-
-
21. A method for performing high speed exponentiation of data transferred from a host system, comprising:
-
receiving data; performing exponentiation of said received data to produce resulting data using a plurality of exponentiators provided to perform exponentiation on data received from the host system wherein at least two exponentiators process data concurrently, wherein the received data is in encrypted form; decrypting said encrypted data; encrypting said resulting data after performing exponentiation; and testing whether said plurality of exponentiators function properly and disabling exponentiators in said plurality of exponentiators that are not functioning properly, wherein said received data cannot pass to an exponentiator in said plurality of exponentiators that has been disabled. - View Dependent Claims (24)
-
-
23. A method for performing high speed exponentiation of data transferred from a host system, comprising:
-
receiving data; performing exponentiation of said received data to produce resulting data using a plurality of exponentiators provided to perform exponentiation on data received from the host system wherein at least two exponentiators process data concurrently, wherein the received data is in encrypted form; decrypting said encrypted data; encrypting said resulting data after performing exponentiation; and monitoring the status of the exponentiators in said plurality of exponentiators to determine if any of the exponentiators in said plurality of exponentiators is in a busy status.
-
-
25. A method for performing high speed exponentiation of data, comprising:
-
transferring data from a host system to a subsystem; performing exponentiation of said transferred data at said subsystem to produce resulting data using a plurality of exponentiators provided to perform exponentiation on data received from the host system; encrypting said transferred data at said host system prior to transferring said transferred data to said subsystem; and decrypting said transferred data at said subsystem before performing exponentiation. - View Dependent Claims (26, 27, 29, 30, 31, 39)
-
-
28. A method for performing high speed exponentiation of data, comprising:
-
transferring data from a host system to a subsystem; performing exponentiation of said transferred data at said subsystem to produce resulting data using a plurality of concurrently-operating exponentiators provided to perform exponentiation on data received form the host system; and testing said plurality of said exponentiators and disabling each of said exponentiators in said plurality of exponentiators that does not function properly.
-
-
32. A method for performing high speed exponentiation of data, comprising:
-
transferring data from a host system to a subsystem; performing exponentiation of said transferred data at said subsystem to produce resulting data using a plurality of exponentiators provided to perform exponentiation on data received form the host system; wherein at least two exponentiators process data concurrently; storing a first key in said subsystem; encrypting said transferred data at said host system with said first key prior to transferring said transferred data to said subsystem; decrypting said transferred data at said subsystem using said first key; and encrypting said resulting data with said first key after performing exponentiation.
-
-
33. A method for performing high speed exponentiation of data, comprising:
-
transferring data from a host system to a subsystem; performing exponentiation of said transferred data at said subsystem to produce resulting data using a plurality of exponentiators provided to perform exponentiation on data received form the host system; wherein at least two exponentiators process data concurrently; storing a first key in said subsystem; randomly generating a second key at said host system; encrypting said transferred data at said host system with said second key prior to transferring said transferred data to said subsystem; encrypting said second key with said first key at said host system; transferring said encrypted second key and said encrypted data to said subsystem; decrypting said encrypted second key with said first key at said subsystem; and decrypting said transferred data received at said subsystem using said second key. - View Dependent Claims (34, 35, 36, 37)
-
-
38. A method for performing high speed exponentiation of data, comprising:
-
transferring data from a host system to a subsystem; performing exponentiation of said transferred data at said subsystem to produce resulting data using a plurality of exponentiators provided to perform exponentiation on data received form the host system; wherein at least two exponentiators process data concurrently; and wherein said subsystem includes a plurality of chips having at least one exponentiator in said plurality of exponentiators, each of said chips having a common base address and a unique offset address.
-
-
40. A system for performing high speed exponentiation of data, comprising:
-
a host system; a subsystem communicating with said host system, said subsystem having an interface for receiving data from said host system, a plurality of concurrently-operating exponentiators provided to perform exponentiation on the data received from the host system, and logic circuitry for selecting an available exponentiator from said plurality of exponentiators to receive said data, said logic circuitry connected between said interface and said plurality of exponentiators, the available exponentiator being selected based on a status indicating it is available for use in processing the received data. - View Dependent Claims (41, 42, 43, 44)
-
Specification