Information
-
Patent Application
-
20020080973
-
Publication Number
20020080973
-
Date Filed
December 22, 200024 years ago
-
Date Published
June 27, 200222 years ago
-
CPC
-
US Classifications
-
International Classifications
Abstract
A computer system and method are disclosed for generating a certificate that can be validated against a trusted hardware subsystem within a computer system. A security subsystem is established within the computer system. A master key pair including a master public key and master private key are established. The master private key is stored in protected storage within the security subsystem such that the master private key is inaccessible outside of the security subsystem. Generation of a self-verifying certificate is requested. A user of the computer system is then prompted to enter an authentication code in response to the request for generation of the certificate. A certificate is generated utilizing the master key pair only in response to a correct entry of the authentication code. The certificate is used only internally within the computer system.
Description
BACKGROUND OF THE INVENTION
[0001] 1. Field of the Invention
[0002] The present invention relates in general to data processing systems and, in particular, to a computer system and method for generating a self-verifying certificate. Still more particularly, the present invention relates to a computer system and method to generate a self-verifying certificate for use only within the computer system for authenticating internal operations, wherein only the system administrator can create the certificate.
[0003] 2. Description of the Related Art
[0004] Personal computer systems are well known in the art. They have attained widespread use for providing computer power to many segments of today's modern society. Personal computers (PCs) may be defined as a desktop, floor standing, or portable microcomputer that includes a system unit having a central processing unit (CPU) and associated volatile and non-volatile memory, including random access memory (RAM) and basic input/output system read only memory (BIOS ROM), a system monitor, a keyboard, one or more flexible diskette drives, a CD-ROM drive, a fixed disk storage drive (also known as a “hard drive”), a pointing device such as a mouse, and an optional network interface adapter. One of the distinguishing characteristics of these systems is the use a motherboard or system planar to electrically connect these components together. Examples of such personal computer systems are IBM's NetVista series, Aptiva series, and Intellistation series.
[0005] Encryption algorithms are known to ensure that only the intended recipient of a message may read and access the message. One known encryption algorithm is an asymmetric, or public key, algorithm. The public key algorithm is a method for encrypting messages sent from a first entity to a second entity. This algorithm provides for a key pair comprised of a private key and public key which are mathematically related such that if the private key is used to encrypt data then only the matched public key can be used to decrypt the data, and visa versa.
[0006] Inherent in a public key encryption algorithm is the need for strong trust relationships. Individual trust relationships are typically enabled through a Certificate Authority (CA). A Certificate Authority is a mutually trusted agent that vouches for the authenticity of a sender of a message, which may be either a group or an individual.
[0007] In Intranet, Internet, Virtual Private Networks, e-mail, and e-commerce applications, communication connections may traverse backbones and routers as well as machines at secured or non-secured sites. in certain circumstances, it is imperative that users of the above-referenced applications employ systems and methods which provide for secure transactions and communications.
[0008] A Public Key Infrastructure (PKI), a system for using public key methodologies, enables users of an essentially non-secured public network, such as the Internet, to securely and privately exchange information and authenticate identities using a public/private cryptographic key pair.
[0009] Certificate Authorities are entities that can issue digital certificates. Certificate Authorities are, in essence, a commonly trusted third party that is relied upon to verify the matching of public keys to identity, e-mail name, or other such information.
[0010] A digital certificate may be described as an attachment to an electronic message used for security purposes which establishes credentials when doing business or other transactions on the Web. Digital certificates link details about an individual, or an organization to a public key, and are able to identify individuals, or organizations. A common use of a digital certificate is to verify that a user sending a message is the person the user claims to be. The digital certificate may contain your name, a serial number, expiration dates, a copy of the certificate holder's public key, and the digital signature of a Certificate Authority. The digital certificate contains the digital signature of the CA so that anyone can verify that the certificate is real.
[0011] Certificates are beneficial when two entities both trust the same CA. This allows them to learn each other's public key by exchanging a certificate signed by that CA. A digital signature is an electronic signature, rather than a written signature, that can be used by someone to authenticate the identity of the sender of a message or of the signer of a document. It can also be used to ensure that the original content of a message or document that has been conveyed is unchanged. A digital signature can be used with any kind of message, whether it is encrypted or not, simply so that the receiver can be sure of the sender's identity and that the message has arrived in the manner intended by the sender. When a public key is known, it can be used to encrypt data, individuals can send it to one another, or it can be used to verify signatures on documents.
[0012] Directory services in the PKI include one or more directories where the certificates (with their public keys) are held. A registration authority is an authority in a network that acts as the verifier for the CA before a digital certificate is issued to a requestor. The registration authority tells the CA to issue the certificate if the verification process so dictates.
[0013] Individuals who desire to send an encrypted message can request a digital certificate from a CA. The CA can issue a signed digital certificate containing the applicant's public key and other identification information. The CA may make its own public key readily available through print materials, through the Internet, or via other means.
[0014] The recipient of an encrypted message uses the CA's public key to decode the digital certificate attached to the message, verifies it as issued by the CA and then obtains the sender's public key and identification information held within the certificate.
[0015] A certificate is typically requested by a user through an application such as a browser or email. The certificate request, and target Public Key utilized to create the certificate, is routed to the CA. After the identity of the requester is verified, the CA generates the certificate. The certificate is then returned to the requester and installed into their system.
[0016] The certificates and certificate authority of the prior art are utilized when information is transmitted from one computer system to another computer system that is separate from the transmitting computer system. Therefore, the certificates are transmitted externally from one computer system across some type of network and are received by another computer system.
[0017] Therefore a need exists for a method and system to build a trust relationship internally within a single computer system by generating a self-verifying certificate for use only within the computer system to establish trust for internal purposes.
SUMMARY OF THE INVENTION
[0018] A computer system and method are disclosed for generating a certificate that can be internally generated and verified for trust. A security subsystem is established within the computer system. A master key pair including a master public key and master private key are established. The master private key is stored in protected storage within the security subsystem such that the master private key is inaccessible outside of the security subsystem. Generation of a self-verifying certificate is requested. A user of the computer system is then prompted to enter an authentication code in response to the request for generation of the self-verifying certificate. A self-verifying certificate is generated utilizing the master key pair only in response to a correct entry of the authentication code. The validity of this certificate can be ascertained by checking the certificate against the master public key security subsystem.
[0019] The above as well as additional objectives, features, and advantages of the present invention will become apparent in the following detailed written description.
BRIEF DESCRIPTION OF THE DRAWINGS
[0020] The novel features are set forth in the appended claims. The present invention itself, however, as well as a preferred mode of use, further objectives, and advantages thereof, will best be understood by reference to the following detailed description of a preferred embodiment when read in conjunction with the accompanying drawings, wherein:
[0021]
FIG. 1 illustrates a pictorial representation of a data processing system including a first computer system coupled to a second computer system utilizing a network in accordance with the method and system of the present invention;
[0022]
FIG. 2 depicts a more detailed pictorial representation of either computer system of FIG. 1 in accordance with the method and system of the present invention;
[0023]
FIG. 3 illustrates a high level flow chart which depicts initializing a security subsystem included in a computer system in accordance with the method and system of the present invention;
[0024]
FIG. 4 depicts a high level flow chart which illustrates generating a self-verifying certificate in accordance with the method and system of the present invention; and
[0025]
FIG. 5 illustrates a high level flow chart which depicts an example of using a virtual certificate in accordance with the method and system of the present invention.
DETAILED DESCRIPTION OF A PREFERRED EMBODIMENT
[0026] A preferred embodiment of the present invention and its advantages are better understood by referring to FIGS. 1-5 of the drawings, like numerals being used for like and corresponding parts of the accompanying drawings.
[0027] Although the present invention may be implemented using any suitably configured computer system which includes the components described below, the preferred implementation uses a NetVista computer platform computer system and includes the components described below. A NetVista computer platform computer system is available from International Business Machines. The method of the present invention can be implemented on a variety of platforms such as defined by the Trusted Computing Platform Alliance specification.
[0028] The present invention is a method and system for permitting a computer system to create a virtual certificate to be used within the computer system. Only an authorized administrator is permitted to cause the creation of these certificates. The certificates may be used subsequently by applications internally to the computer system to authenticate the validity of a credential.
[0029] A security subsystem is established within the computer system. The security subsystem includes protected storage. A master key pair is established including a master private key and a master public key. The master private key is stored in non-readable, protected storage included within the computer system. The master public key is stored in protected read-only storage in this security subsystem. An authentication code is required in order to cause the generation of a self-verifying certificate. Only the system administrator possesses this authentication code. Therefore, only the system administrator can cause the computer system to generate a self-verifying certificate. Trust is thereby established in the certificates because only the administrator could have caused a certificate to be created.
[0030] A public key for the target virtual certificate is supplied to the security subsystem. The system administrator then needs to provide the authorization code for the hardware private key to sign the target public key. This signed target public key is then appended to the target public key data structure to form a virtual certificate.
[0031] Those skilled in the art will recognize that the certificate may also be used to allow exchange of data and information in a trusted manner among a group of computer systems which trust the source of the certificate. These computer systems trust the source of this certificate because the certificate was generated by an administrator having the authentication code who then generated the certificate using the hardware security subsystem.
[0032]
FIG. 1 illustrates a pictorial representation of a computer system 10 in accordance with the method and system of the present invention. Computer system 10 includes a computer 12, a monitor 14, a keyboard 16, a mouse 18, a printer or plotter 20, and a floppy disk drive 22. Computer system 10 may be implemented utilizing any commercially available computer system which has been suitably programmed and which has been modified as described below. Computer system 10 is capable of receiving a variety of different types of inputs from a variety of different types of input devices. Keyboard 16 and mouse 18 are two such types of input devices. Computer system 10 may be coupled to another computer system 24 utilizing a network 26.
[0033]
FIG. 2 depicts a more detailed pictorial representation of a computer system of FIG. 1 in accordance with the method and system of the present invention. A computer system includes a planar 28 (also commonly called a motherboard or system board) which is mounted within the computer and provides a means for mounting and electrically interconnecting various components of the computer including a central processing unit (CPU) 200, system memory 206, and accessory cards or boards as is well known in the art.
[0034] CPU 200 is connected by address, control, and data busses 202 to a memory controller and peripheral component interconnect (PCI) bus bridge 204 which is coupled to system memory 206. An integrated drive electronics (IDE) device controller 220, and a PCI bus to Industry Standard Architecture (ISA) bus bridge 212 are connected to PCI bus bridge 204 utilizing PCI bus 208. IDE controller 220 provides for the attachment of IDE compatible storage devices, such as a removable hard disk drive 222. PCI/ISA bridge 212 provides an interface between PCI bus 208 and an optional feature or expansion bus such as the ISA bus 214. PCI/ISA bridge 212 includes power management logic 212. A PCI standard expansion bus with connector slots 210 is coupled to PCI bridge 204. PCI connector slots 210 may receive PCI bus compatible peripheral cards. An ISA standard expansion bus with connector slots 216 is connected to PCI/ISA bridge 212. ISA connector slots 216 may receive ISA compatible adapter cards (not shown). It will be appreciated that other expansion bus types may be used to permit expansion of the system with added devices. It should also be appreciated that two expansion busses are not required to implement the present invention.
[0035] An I/O controller 218 is coupled to PCI-ISA bridge controller 212. I/O controller 218 controls communication between PCI-ISA bridge controller 212 and devices and peripherals such as floppy drive 22, keyboard 16, and mouse 18 so that these devices may communicate with CPU 200.
[0036] PCI-ISA bridge controller 212 includes an interface for a flash memory 242 which includes an interface for address, data, flash chip select, and read/write. Flash memory 242 is an electrically erasable programmable read only memory (EEPROM) module and includes BIOS that is used to interface between the I/O devices and operating system.
[0037] The computer system also includes a video controller 246 which may, for example, be plugged into one of PCI expansion slots 210. Video controller 246 is connected to video memory 248. The image in video memory 248 is read by controller 246 and displayed on monitor 14 which is connected to connector 250.
[0038] The computer system includes a network adapter 230 which may, for example, be plugged into one of the PCI connector slots 210 (as illustrated) or one of the ISA connector slots 216 in order to permit computer system 10 to communicate with a LAN via a connector 236.
[0039] Computer system 10 includes a special power supply 240 which supplies full normal system power 243, and has an auxiliary power main AUX 5 247 which supplies full time auxiliary power 247 to the power management logic 212 and to the network adapter 230. This enables computer system 10 to respond to a wakeup signal from network adapter 230. In response to a receipt of the wakeup signal, normal system power 243 from power supply 240 is turned on and then powers up computer system 10.
[0040] In accordance with the present invention, planar 28 includes an application specific integrated circuit (ASIC) security subsystem 261 which includes an encryption/decryption engine 260 which includes an encryption/decryption algorithm which may be utilized to encode and decode messages transmitted and received by planar 28 and protected storage 262. Engine 260 is preferably an RSA public key crypto-system. Engine 260 may access a protected storage device 262. Protected storage device 262 is accessible only through engine 260. Therefore, storage device 262 cannot be read or written to by planar 28, device 222, or any other device. Storage device 262 is utilized to store the master key pair for this planar, and to store the authentication code. Storage device 262 may also be utilized to store application keys.
[0041] Device 262 may be implemented utilizing an electronically erasable storage device, such as an EEPROM. Access may be gained to non-readable storage device 262 in order to initially store the master private key. The EEPROM storage locations can be initialized and then changed to “no access”, “read-only”, or “read-write”. After the master private key is stored, its storage location is changed to “no access”. The master public key is also stored in storage 262. Its location is “read-only” so that the master public key may be read.
[0042] Security subsystem 261 is coupled to PCI-ISA bridge 212 utilizing a system management (SM) bus 238. System management bus 238 is a two-wire, low speed, serial bus used to interconnect management and monitoring devices.
[0043]
FIG. 3 illustrates a high level flow chart which depicts initializing a security subsystem included in a computer system in accordance with the method and system of the present invention. The process starts as depicted by block 300 and thereafter passes to block 302 which illustrates the security subsystem 261 creating a master key pair and storing the master key pair in protected storage 262. Block 304, then, illustrates an administrator choosing an authentication code. Thereafter, block 306 depicts the security subsystem 261 securely storing the authentication code in protected storage 262. The authentication code can be changed only by the administrator. The process then terminates as illustrated by block 308.
[0044]
FIG. 4 illustrates a high level flow chart which depicts generating a self-verifying certificate in accordance with the method and system of the present invention. The process starts as depicted by block 400 and thereafter passes to block 402 which illustrates an administrator supplying a target public key to the security subsystem. Alternatively, the administrator may cause the security subsystem to create a target key pair which includes a public key to be used as a target public key. This target key pair is different from the master key pair. The target key pair is a second, completely separate, key pair. Thereafter, block 404 depicts security subsystem 261 prompting for an authentication code. Next, block 406 illustrates a determination of whether or not the correct authentication code was entered within the required number of attempts to correctly enter the code. If a determination is made that the correct authentication code was not correctly entered within the required number of tries, the process terminates as depicted by block 416.
[0045] Referring again to block 406, if a determination is made that the correct authentication code was correctly entered within the required number of tries, the process passes to block 408 which depicts the administrator entering a certificate identifier to identify this certificate which is to be created. Each certificate receives a certificate identifier so that the identifier can be used later within the computer system by an application. For example, an administrator could create multiple, different certificates. A certificate could be created to be used when, for example, an application is copying application keys. This certificate would be identified by a particular identifier. A different certificate could be created to be used when backing up application keys. This certificate would be identified by its own, unique identifier. An application could obtain a particular certificate by requesting a certificate identified by a particular identifier.
[0046] Next, block 410 illustrates the security subsystem forming security data. The security data includes a public key, the certificate identifier, and other fields known in the art to be included in a certificate. Thereafter, block 412 depicts the security subsystem creating a hash of the security data structure, and encrypting the resulting hash value with the master private key to create a signature. Block 414 depicts the security subsystem appending the signature to the security data structure to form a virtual certificate. The process then terminates as illustrated by block 416.
[0047]
FIG. 5 illustrates a high level flow chart which depicts an example of using a virtual certificate in accordance with the method and system of the present invention. The process starts as depicted by block 500 and thereafter passes to block 502 which illustrates an application requesting authentication of a signature included in a virtual certificate. For example, an application may attempt to restore applications keys which were previously stored in hard disk 222. These application keys had been stored on disk 222 along with a certificate. An application might later need to verify that the certificate stored along with these keys is authentic.
[0048] Next, block 504 depicts the security subsystem validating the signature by reading the master public key from protected storage 262. Thereafter, block 506 illustrates the security subsystem using the master public key to decrypt the signature and determining whether the signature is authentic. Block 508, then, depicts the security subsystem responding to the application regarding whether the signature is authentic. The process then terminates as illustrated by block 510.
[0049] While a preferred embodiment has been particularly shown and described, it will be understood by those skilled in the art that various changes in form and detail may be made therein without departing from the spirit and scope of the present invention.
Claims
- 1. A method in a computer system for generating a certificate for use only within said computer system to authenticate operations internal to said computer system, said method comprising the steps of:
establishing a security subsystem within said computer system; establishing a master key pair including a master private key and a master public key; storing said master private key in a protected storage within said security subsystem, wherein said master private key is inaccessible outside of said security subsystem; supplying a target public key; requesting generation of a self-verifying certificate; prompting a user for an authentication code in response to a request for generation of said certificate; and generating a self-verifying certificate utilizing said target public key and said master key pair only in response to a correct entry of said authentication code, said certificate used only internally within said computer system.
- 2. The method according to claim 1, further comprising the step of storing said authentication code in said security subsystem.
- 3. The method according to claim 2, further comprising the step of prohibiting an alteration of said authentication code after said authentication code is stored in said security subsystem.
- 4. The method according to claim 2, further comprising the step of prohibiting access to said authentication code to devices outside of said security subsystem after said authentication code is stored in said security subsystem.
- 5. The method according to claim 1, further comprising the step of determining a certificate identifier after a correct entry of said authentication code, said certificate identifier uniquely identifying said certificate.
- 6. The method according to claim 1, further comprising the steps of:
said security subsystem generating security data for said certificate after a correct entry of said authentication code; said security subsystem hashing said security data; said security subsystem encrypting said security data utilizing said master private key to create a signature; and said security subsystem appending said signature to said security data to create said certificate.
- 7. The method according to claim 1, further comprising the step of storing said certificate along with a certificate identifier in said computer system.
- 8. The method according to claim 1, further comprising the steps of
receiving information within an appended certificate; requesting authentication of a signature included within said appended certificate; said security subsystem reading said master public key from said protected storage; said security subsystem using said master public key to decrypt said signature; and said security subsystem determining whether said signature is authentic.
- 9. A computer system for generating a certificate for use only within said computer system to authenticate operations internal to said computer system, said method comprising the steps of:
a security subsystem within said computer system; a master key pair including a master private key and a master public key; a protected storage within said security subsystem for storing said master private key, wherein said master private key is inaccessible outside of said security subsystem; a target public key; said computer system including a CPU executing code for requesting generation of a self-verifying certificate; said computer system including a CPU executing code for prompting a user for an authentication code in response to a request for generation of said certificate; and a self-verifying certificate generated utilizing said target public key and said master key pair only in response to a correct entry of said authentication code, said certificate used only internally within said computer system.
- 10. The system according to claim 9, further comprising said security subsystem for storing said authentication code.
- 11. The system according to claim 10, further comprising said computer system including a CPU executing code for prohibiting an alteration of said authentication code after said authentication code is stored in said security subsystem.
- 12. The system according to claim 10, further comprising said computer system including a CPU executing code for prohibiting access to said authentication code to devices outside of said security subsystem after said authentication code is stored in said security subsystem.
- 13. The system according to claim 9, further comprising a certificate identifier being determined after a correct entry of said authentication code, said certificate identifier uniquely identifying said certificate.
- 14. The system according to claim 9, further comprising:
said security subsystem for generating security data for said certificate after a correct entry of said authentication code; said security subsystem for hashing said security data; said security subsystem for encrypting said security data utilizing said master private key to create a signature; and said security subsystem for appending said signature to said security data to create said certificate.
- 15. The system according to claim 9, further comprising said certificate being stored along with a certificate identifier in said computer system.
- 16. The system according to claim 9, further comprising:
said computer system including a CPU executing code for receiving information within an appended certificate; said computer system including a CPU executing code for requesting authentication of a signature included within said appended certificate; said security subsystem for reading said master public key from said protected storage; said security subsystem for using said master public key to decrypt said signature; and said security subsystem for determining whether said signature is authentic.