Claims
- 1. A controller circuit for switching between a user mode and a kernel mode in a processor comprising;a processor; a program counter electrically connected to the processor for monitoring program fetch addresses; a kernel program fetch supervisor circuit having a predetermined address value stored within, the kernel program fetch supervisor circuit being electrically connected to the program counter for comparing the address in the program counter to the predetermined address value stored within the kernel program fetch supervisor circuit; a program memory electrically connected to the program counter; a sequential circuit electrically connected to the kernel program fetch supervisor circuit for switching between setting a user mode bit and a kernel mode bit; a kernel data fetch supervisor circuit electrically connected to the processor for comparing a data fetch address to a memory address range; a data memory electrically connected to a processor data interface for storing data; a first AND circuit coupled to the sequential circuit and the kernel data fetch supervisor circuit for activating and deactivating a violation reset signal; and a second AND circuit coupled to the first AND circuit and the kernel program fetch supervisor circuit for activating and deactivating the violation reset signal.
- 2. A method of monitoring and controlling program fetch addresses and data fetch addresses in a processing circuit to control access to a protected memory comprising the steps of:fetching a program opcode; reading a program opcode address associated with the program opcode; determining whether the program opcode address is fetched from one of a protected program memory address and an unprotected program memory address; resetting the processing circuit when the program opcode is fetched from the protected program memory address; fetching a data operand when the program opcode address is fetched from the unprotected program memory address; reading a data operand address associated with the data operand; determining whether the data operand address is fetched from one of a protected data memory address and an unprotected data memory address; resetting the processing circuit when the data operand is fetched from the protected data memory address; calling a starting address of the protected program memory when the data operand address is fetched from the unprotected data memory; fetching a second program opcode; reading a second program opcode address associated with the second program opcode; determining whether the second program opcode address is fetched from one of the protected program memory address and the unprotected program memory address; fetching a third program opcode when the second program opcode address is fetched from the unprotected memory address; and fetching a second data operand when the second program opcode address is fetched from the protected memory address.
CROSS-REFERENCE TO RELATED APPLICATIONS
This application is a continuation of Application Ser. No. 09/154,357 filed on Sep. 16, 1998 now U.S. Pat. No. 6,282,657 and is based on Provisional Patent Application Serial Nos. 60/059,082 and 60/059,843, each of which was filed on Sep. 16, 1997, and relates to U.S. patent application Ser. No. 09/154,443 filed on Sep. 16, 1998, the disclosures of which are incorporated herein by reference.
US Referenced Citations (10)
Provisional Applications (2)
|
Number |
Date |
Country |
|
60/059082 |
Sep 1997 |
US |
|
60/059843 |
Sep 1997 |
US |
Continuations (1)
|
Number |
Date |
Country |
| Parent |
09/154357 |
Sep 1998 |
US |
| Child |
09/897670 |
|
US |