Embodiments described herein generally relate to system integrity verification methods and devices, including integrity verifications during start-up and/or runtime.
The accompanying drawings, which are incorporated herein and form a part of the specification, illustrate the embodiments of the present disclosure and, together with the description, further serve to explain the principles of the embodiments and to enable a person skilled in the pertinent art to make and use the embodiments.
The exemplary embodiments of the present disclosure will be described with reference to the accompanying drawings. The drawing in which an element first appears is typically indicated by the leftmost digit(s) in the corresponding reference number.
In the following description, numerous specific details are set forth in order to provide a thorough understanding of the embodiments of the present disclosure. However, it will be apparent to those skilled in the art that the embodiments, including structures, systems, and methods, may be practiced without these specific details. The description and representation herein are the common means used by those experienced or skilled in the art to most effectively convey the substance of their work to others skilled in the art. In other instances, well-known methods, procedures, components, and circuitry have not been described in detail to avoid unnecessarily obscuring embodiments of the disclosure.
As an overview, during start-up (also referred to as boot-up) of a system on chip (SOC), such as a microcontroller, and before application software execution, start-up software is executed. The start-up software is generally related to hardware of an associated system, such as one or more peripheral devices connected with the microcontroller. Due to changes with the microcontroller state during the execution of the start-up software, later executed application software can be negative impacted. The changes of the microcontroller state can include, for example, changes with control and status registers of the microcontroller.
The status of the microcontroller can be verified against direct impact flags or registers. In one or more exemplary embodiments, indirect impacts can be verified by checking one or more registers, such as special function registers (SFR), and in some or all embodiments, all SFRs are checked. For example, the SFRs can be checked to verify that the SFRs have been restored to their corresponding expected values to reduce and/or prevent application issues with later executed application software. In operation, the SFRs can be associated with one or more peripheral devices connected with (and controlled by) the SOC (e.g., microcontroller). The SFRs can be used to configure the associated peripheral devices. For example, a SFR can be configured to define the data rate for communications between the SOC and the corresponding peripheral device. The verification of the SFRs can be in addition to, or as an alternative to one or more memory built-in self-tests (MBIST) and/or logic built-in self-tests (LBIST). Further, the integrity of the SFRs can be used to support the verification of, for example, automotive safety integrity level (ASIL) applications.
In an exemplary embodiment, the one or more of the registers 120 is a special function register (SFR). One or more of the registers 120 can be associated with a corresponding one of the peripheral devices 130, and the registers 120 can be configured to define one or more parameters of the corresponding peripheral devices 130. For example, the register value of register 120.1 can define a data rate between the SOC 100 and the peripheral device 130. In another example, the register value of register 120.1 can define, for example, the peripheral name, serial number, hardware version, software version, firmware version, and/or one or more other parameters as would be understood by one of ordinary skill in the relevant arts. In an exemplary embodiment where the SOC 100 includes one or more internal peripherals, the SOC 100 can include one or more corresponding registers 120 associated with the internal peripherals.
In an exemplary embodiment, the controller 115 can be configured to perform one or more integrity verification operations to check the integrity of the SOC 100. In an exemplary embodiment, the controller 115 can include processor circuitry that is configured to perform the one or more integrity verification operations to check the integrity of the SOC 100.
The controller 115 can be configured to perform the integrity verification operation(s) during start-up and/or runtime of the SOC 100. For example, the controller 115 can check the integrity of the SOC 100 during start-up (also referred to as boot-up) of the SOC 100 and before application software execution. In an exemplary embodiment, the controller 115 can be configured to check the integrity of the SOC 110 after start-up software has been executed but before the execution of software applications. In operation, the controller 115 can be configured to determine state changes of the SOC 100 during (and resulting from) the execution of the start-up software. The changes of the state of the SOC 100 can include, for example, changes with control and status registers of the SOC 100. By determining state changes of the SOC 100, possible negative implications on later executed application software from the SOC 100 state changes can be reduced and/or negated.
In an exemplary embodiment, the controller 115 can be configured to obtain corresponding register values from one or more of the registers 120.1 to 120.N. The controller 115 can read the register values from the registers 120 and store the register values in one or more memories 135 of the SOC 100. In some embodiments, the controller 115 includes one or more internal memories and can be configured to store the register values in the one or more internal memories in addition to, or as an alternative to, the memory 135.
In an exemplary aspect, the controller 115 can obtain the register values before the execution of one or more start-up operations of the SOC 100, including one or more start-up applications. In this example, these register values can be referred to as pre-execution register values. In the present disclosure, applications can include a computer program having one or more instructions that, when executed by a corresponding controller 115, controls the controller 115 to perform one or more functions of the corresponding application.
In an exemplary embodiment, the controller 115 can be configured to generate one or more sets of register values based on one or more of the obtained register values. The set(s) of register values can be then stored in the memory 135 and/or an internal memory (or memories) of the controller 115.
Following the acquisition of the register values (or the generation of the set(s) of register values from the obtained values), the controller 115 can execute one or more processes of the SOC 100, which can include one or more start-up operations of the SOC 100 (e.g., execution of the start-up software). The controller 115 can be “hard-coded” with instructions to perform corresponding start-up functions, or can be configured to access an internal memory of the controller 114 and/or memory 135 to retrieve instructions stored therein, which when executed by the controller 115, perform the corresponding start-up functions.
The controller 115 can also be configured to again obtain corresponding register values from one or more of the registers 120.1 to 120.N. The controller 115 can read the register values from the registers 120 and store the register values in one or more memories 135 of the SOC 100 and/or an internal memory of the controller 115. In an exemplary aspect, the controller 115 can obtain the register values after the execution of one or more start-up operations of the SOC 100, including one or more start-up applications. In this example, these register values can be referred to as post-execution register values.
In an exemplary embodiment, the controller 115 can be configured to generate one or more additional sets of register values based on the post-execution register values. The set(s) of register values can be then stored in the memory 135 and/or an internal memory (or memories) of the controller 115. In this example, this set of register values can be referred to as post-execution register value set(s).
In an exemplary embodiment, the controller 115 can be configured to compare the pre-execution register values/sets with the post-execution register values/sets. For example, the controller 115 can be configured to compare the pre-execution register values/sets with the post-execution register values/sets. Based on the comparison, the controller 115 can be configured to determine differences between the pre-execution and post-execution register values/sets.
In an exemplary embodiment, the controller 115 can be configured to analyze the differences between the pre-execution and post-execution register values/sets and determine if the controller 115 should take one or more actions. The actions can include, for example, changing the operating mode of the SOC 100 (e.g., switch to a safe mode), perform a reset of the SOC 100 (e.g., power-on reset), restore one or more registers 120 to a predetermined value (e.g., a default value), generate a warning of the difference that may impact operation of the SOC 100, and/or one or more other actions as would be understood by one of ordinary skill in the art.
The controller 115 can be configured to generate, or control the SOC 100 to generate, one or more one or more databases based on the pre-execution and post-execution register values/sets and the determination of any differences between the values/sets. The database can include, for example, register names, register addresses (e.g., 0xf0000000), pre-execution register values, post-execution values, one or more indicators/flags indicating a difference between the pre-execution and post-execution values, analysis by the controller 115 and/or by one or more users of the SOC 100, the action(s) taken or to be taken by the controller 115 and/or by the user(s) of the SOC 100, and/or one or more other parameters and/or information as would be understood by one of ordinary skill in the relevant arts. The database can be stored in one or memory units, such as memory 135.
In an exemplary embodiment, the controller 115 can be configured to generate a report based on the comparison of the pre-execution and post-execution register values/sets. The report can include the analysis of the pre-execution and post-execution register values/sets and/or the action(s) taken or to be taken by the controller 115. The controller 115 can be configured to provide, or control the SOC 100 to provide the generated report to one or more components of the SOC 100, provide the report to one or more external devices (e.g., peripheral devices 130), transmit the report via one or more communication networks, control the SOC 100 to display the report on one or more displays, and/or take one or more other actions with the generated report as would be understood by one of ordinary skill in the relevant arts.
In an exemplary embodiment, the controller 115 can be configured to generate a notification, or control the SOC 100 and/or one or more external components to generate the notification, to indicate differences between the pre-execution and post-execution values. The notification can include a signal to one or more other components to notify the component(s) of the difference, an audible signal, a visual signal, or another notification as would be understood by one of ordinary skill in the relevant arts. In an exemplary embodiment, the controller 115 can be configured to notify (and/or control the SOC 100 and/or one or more external components to notify) application software of the SOC 100 and/or application software of one or more one or more external components based on one or more differences between the pre-execution and post-execution values.
In an exemplary embodiment, the SOC integrity verification system 200 includes the evaluator 205 that is connected (wireless and/or wired) to the SOC 100. The evaluator 205 can include a controller 210 and memory 220 that is connected to the controller 210. The memory 220 can be any well-known volatile and/or non-volatile memory that stores data and/or instructions, including, for example, read-only memory (ROM), random access memory (RAM), flash memory, a magnetic storage media, an optical disc, erasable programmable read only memory (EPROM), and programmable read only memory (PROM). The memory can be non-removable, removable, or a combination of both.
In an exemplary embodiment, the controller 210 can be configured to perform one or more integrity verification operations to check the integrity of the SOC 100. In an exemplary embodiment, the controller 210 can include processor circuitry that is configured to perform the one or more integrity verification operations to check the integrity of the SOC 100.
As discussed above with reference to
Following the acquisition of the register values (or the generation of the set(s) of register values from the obtained values), the controller 115 can execute one or more processes of the SOC 100, which can include one or more start-up operations of the SOC 100 (e.g., execution of the start-up software). The controller 115 can again obtain (and store) corresponding register values from one or more of the registers 120.1 to 120.N (e.g., post-execution register values). The controller 115 can be configured to generate (and store) one or more additional sets of register values based on one or more of the obtained register values (e.g., post-execution register value set(s)). In an exemplary embodiment, the controller 210 of the evaluator 205 is configured to control the controller 115 to obtain register values, and/or execute one or more processes of the SOC 100.
In an exemplary embodiment, the controller 115 can be configured to provide the pre-execution and post-execution register values and/or register value sets to the evaluator 205. In an exemplary embodiment, the evaluator 205 can obtain/read the values/value sets from the SOC 100. The evaluator 205 can store the values or value sets in memory 220 and/or in one or more internal memories of controller 210. In an exemplary embodiment, the connection between the SOC 100 and the evaluator 205 is a serial connection, a Universal Serial Bus (USB) connection, infrared connection, fiber optic connections, firewire (IEEE 1394), eSATA connection, wired and/or wireless network connection (e.g., WLAN, LAN, Ethernet), and/or another connection type as would be understood by one of ordinary skill in the relevant arts.
In an exemplary embodiment, the controller 210 can be configured to compare the pre-execution register values with the post-execution register values. For example, the controller 210 can be configured to compare the pre-execution register value set(s) with the post-execution register value set(s). Based on the comparison, the controller 210 can be configured to determine differences between the pre-execution and post-execution register values/sets.
In an exemplary embodiment, the controller 210 can be configured to analyze the differences between the pre-execution and post-execution register values/sets and determine if the controller 115 and/or the controller 210 should take one or more actions. The actions can include, for example, changing the operating mode of the SOC 100 (e.g., switch to a safe mode), perform a reset of the SOC 100 (e.g., power-on reset), restore one or more registers 120 to a predetermined value (e.g., a default value), generate a warning of the difference that may impact operation of the SOC 100, and/or one or more other actions as would be understood by one of ordinary skill in the art.
The controller 210 can be configured to generate, or control the SOC 100 (e.g., controller 115) to generate, one or more one or more databases based on the pre-execution and post-execution register values/sets and the determination of any differences between the values/sets. As discussed above, the database can include, for example, register names, register addresses (e.g., 0xf0000000), pre-execution register values, post-execution values, one or more indicators/flags indicating a difference between the pre-execution and post-execution values, analysis by the controller 210, controller 115, and/or by one or more users of the SOC 100, the action(s) taken or to be taken by the controller 210, the controller 115 and/or by the user(s) of the SOC 100, and/or one or more other parameters and/or information as would be understood by one of ordinary skill in the relevant arts. The database can be stored in one or memory units, such as memory 220 and/or memory 135.
In an exemplary embodiment, the controller 210 can be configured to generate a report based on the comparison of the pre-execution and post-execution register values/sets. The report can include the analysis of the pre-execution and post-execution register values/sets and/or the action(s) taken or to be taken by the controller 210 and/or controller 115. The controller 210 can be configured to provide, or control the SOC 100 to provide the generated report to one or more components of the SOC 100, provide the report to one or more external devices (e.g., peripheral devices 130), transmit the report via one or more communication networks, display the report on one or more displays, control the SOC 100 to display the report on one or more displays, and/or take one or more other actions with the generated report as would be understood by one of ordinary skill in the relevant arts.
In an exemplary embodiment, the controller 210 can be configured to generate a notification, or control the SOC 100 and/or one or more external components to generate the notification, to indicate differences between the pre-execution and post-execution values. The notification can include a signal to one or more other components to notify the component(s) of the difference, an audible signal, a visual signal, or another notification as would be understood by one of ordinary skill in the relevant arts.
In an exemplary embodiment, the controller 210 and the controller 115 can cooperatively operate to perform one or more integrity verification operations. In this example, any combination of the functions and operations performed by the controller 115 can be performed by the controller 210, and vice versa. For example, the controller 115 can perform a portion of the obtaining of values, storing of values, comparing values, analyzing values, database generation, notification, and/or reporting, while the controller 210 performs the remaining portion of the operations not performed by the controller 115.
In an exemplary embodiment, one or more registers (e.g., registers 120) can be identified (e.g., names, addresses, and/or other identification information). The identification information of the register(s) can be used with one or more software applications configured to read register values from the registers. For example, an application programming interface (API) can be used to create one or more software applications configured to obtain register values (e.g., “PrintRegs( )” instruction) from one or more registers. The reading operations (e.g., “PrintRegs( )” instruction) can be implemented in the SOC 100 and the controller 115 can be configured to execute the instruction to read the register values from the registers 120. In operation, the controller of the SOC 100 can be configured to obtain the register values before the execution of one or more start-up operations (e.g., “Start-up Exec( )” instruction) of the SOC 100.
Following the acquisition of the pre-execution register values/sets, the controller 115 can execute one or more start-up operations (e.g., “Start-up Exec( )” instruction). After the start-up operation(s) have been executed (and in some embodiments, after the operations have completed), the controller 115 can again read register values from the registers (e.g., “PrintRegs( )” instruction).
The pre-execution and post-execution register values/sets can then be compared and analyzed. In an exemplary embodiment, the controller 115 can be configured to compare the pre-execution register values with the post-execution register values. Based on the comparison, the controller 115 can be configured to determine differences between the pre-execution and post-execution register values/sets.
In an exemplary embodiment, the controller 115 can be configured to analyze the differences between the pre-execution and post-execution register values/sets and determine if the controller 115 should take one or more actions.
In an exemplary embodiment, a report can be generated based on the comparison of the pre-execution and post-execution register values/sets. For example, the controller 115 can be configured to generate a report based on the comparison of the pre-execution and post-execution register values/sets. The report can include the analysis of the pre-execution and post-execution register values/sets and/or action(s) taken or to be taken by the controller 115. The controller 115 can be configured to provide, or control the SOC 100 to provide the generated report to one or more components of the SOC 100, provide the report to one or more external devices (e.g., peripheral devices 130), transmit the report via one or more communication networks, control the SOC 100 to display the report on one or more displays, and/or take one or more other actions with the generated report as would be understood by one of ordinary skill in the relevant arts.
The pre-execution and post-execution register values/sets, corresponding analysis, determined differences and/or other information can be stored in the SOC 100 and/or in one or more external devices. For example, the controller 115 can be configured to store the pre-execution and post-execution register values/sets, corresponding analysis, and the determination of any differences between the values/sets in, for example, memory 135. The controller 115 can be configured to generate, or control the SOC 100 to generate, one or more one or more databases based on the pre-execution and post-execution register values/sets and the determination of any differences between the values/sets.
Additionally or alternatively, the comparison of the pre-execution and post-execution register values/sets, analysis, differences determination, report generation, notifications, and/or other operations can be performed by an external device such as evaluator 205 as illustrated in
For example, as discussed above, one or more registers (e.g., registers 120) can be identified, and the identification information can be used with one or more software applications configured to read register values from the registers. The reading operations (e.g., “PrintRegs( )” instruction) can be implemented in the SOC 100 and the controller 115 can be configured to execute the instruction to read the register values from the registers 120. In operation, the controller of the SOC 100 can be configured to obtain the register values before the execution of one or more start-up operations (e.g., “Start-up Exec( )” instruction) of the SOC 100.
Following the acquisition of the pre-execution register values/sets, the controller 115 can execute one or more start-up operations (e.g., “Start-up Exec( )” instruction). After the start-up operation(s) have been executed (and in some embodiments, after the operations have completed), the controller 115 can again read register values from the registers (e.g., “PrintRegs( )” instruction).
The pre-execution and post-execution register values/sets are then provided to the evaluator 205 or obtained from the SOC 100 by the evaluator 205.
In an exemplary embodiment, the evaluator 205 can receive and/or obtain/read the values/value sets from the SOC 100. The evaluator 205 can store the values or value sets in memory 220 and/or in one or more internal memories of controller 210.
The pre-execution and post-execution register values/sets are then compared. Based on the comparison, differences between the pre-execution and post-execution register values/sets can be determined. In an exemplary embodiment, the controller 210 of the evaluator 205 can be configured to compare the pre-execution register values with the post-execution register values. Based on the comparison, the controller 210 can be configured to determine differences between the pre-execution and post-execution register values/sets.
The pre-execution and post-execution register values/sets and/or any determined differences can be analyzed. Based on the analysis, the evaluator 205 can determine if one or more actions (e.g., adjust operating mode, reset SOC 100, etc.) are to be taken. In an exemplary embodiment, the controller 210 can be configured to analyze the differences between the pre-execution and post-execution register values/sets and determine if the controller 115 and/or the controller 210 should take one or more actions.
In an exemplary operation, one or more databases can be generated. For example, the controller 210 can be configured to generate, or control the SOC 100 (e.g., controller 115) to generate, one or more one or more databases based on the pre-execution and post-execution register values/sets and the determination of any differences between the values/sets. In a non-limiting example, the database can be a table of values, a spreadsheet (e.g., XLS document), or other data structure as would be understood by one of ordinary skill in the art.
As discussed above, the database can include, for example, register names, register addresses (e.g., 0xf0000000), pre-execution register values, post-execution values, one or more indicators/flags indicating a difference between the pre-execution and post-execution values, analysis by the controller 210, controller 115, and/or by one or more users of the SOC 100, the action(s) taken or to be taken by the controller 210, the controller 115 and/or by the user(s) of the SOC 100, and/or one or more other parameters and/or information as would be understood by one of ordinary skill in the relevant arts. The database can be stored in one or memory units, such as memory 220 and/or memory 135.
With continued reference to
In an exemplary embodiment, the controller 210 can be configured to generate the report. The controller 210 can be configured to provide the report to one or more components of the SOC 100, provide the report to one or more external devices (e.g., peripheral devices 130), transmit the report via one or more communication networks, display the report on one or more displays, control the SOC 100 to display the report on one or more displays, and/or take one or more other actions with the generated report as would be understood by one of ordinary skill in the relevant arts.
In an exemplary embodiment, the controller 210 can be configured to generate a notification, or control the SOC 100 and/or one or more external components to generate the notification, to indicate differences between the pre-execution and post-execution values. The notification can include a signal to one or more other components to notify the component(s) of the difference, an audible signal, a visual signal, or another notification as would be understood by one of ordinary skill in the relevant arts.
The method of flowchart 500 begins at step 505 and transitions to step 510, where one or more register values are obtained/read from the one or more registers to generate a first set of register values. In an exemplary embodiment, the SOC 100 (e.g., controller 115) is configured to obtain/read the register values from one or more of the registers 120. In an exemplary embodiment, the evaluator 205 is configured to control the SOC 100 to obtain/read the register values from the register(s) 120. In an exemplary embodiment, the SOC 100 can be configured generate a first register value set based on the obtained register values. The values and/or value sets can be stored in, for example, memory 135 and/or memory 220.
After step 510, the flowchart 500 transitions to step 515, where one or more processes, such as one or more start-up processes are executed. In an exemplary embodiment, the controller 115 of the SOC 100 is configured to execute, or control one or more other components of the SOC 100 to execute, one or more processes, which can include one or more start-up operations of the SOC 100.
After step 515, the flowchart 500 transitions to step 520, where one or more register values are again obtained/read from the one or more registers to generate a second set of register values. In an exemplary embodiment, the SOC 100 (e.g., controller 115) is configured to obtain/read the register values from one or more of the registers 120. In an exemplary embodiment, the evaluator 205 is configured to control the SOC 100 to obtain/read the register values from the register(s) 120. In an exemplary embodiment, the SOC 100 can be configured generate a second register value set based on the obtained register values. The values and/or value sets can be stored in, for example, memory 135 and/or memory 220.
After step 520, the flowchart 500 transitions to step 525, where the first set of register values and the second set of register values compared to determine if there is a difference between one or more of the register values between the first and the second sets of register values. In an exemplary embodiment, the controller 115 of the SOC 100 and/or the controller 210 of the evaluator 205 is configured to compare the first set of register values with the second set of register values.
If there is a difference with one or more values (YES at step 525), the flowchart 500 transitions to step 530. Otherwise (NO at step 525), the flowchart 500 transitions to step 540 where the flowchart ends.
At step 530, the differences between the first and the second sets of register values are analyzed. Based on the analysis, it is determined if one or more action should be performed in response to the differences. In an exemplary embodiment, the controller 115 of the SOC 100 and/or the controller 210 of the evaluator 205 is configured to analyze the differences between the first set of register values and the second set of register values. The controller 115 and/or controller 210 determine if one or more action should be taken based on the analysis. In an exemplary embodiment, the user of the SOC 100 can be configured to analyze the differences and determine if one or more actions should be taken. For example, the user can analyze a report generating based on the differences and determine if one or more actions should be taken.
If one or more action is to be performed (YES at step 530), the flowchart 500 transitions to step 535. Otherwise (NO at step 530), the flowchart 500 transitions to step 540 where the flowchart ends.
At step 535, one or more actions are performed in response to the analysis of the differences between the first and the second sets of register values. The actions can include, for example, changing/adjusting the operating mode of the SOC 100 (e.g., switch to a safe mode), perform a reset of the SOC 100 (e.g., power-on reset), restore one or more registers 120 to a predetermined value (e.g., a default value), generate a warning of the difference that may impact operation of the SOC 100, and/or one or more other actions as would be understood by one of ordinary skill in the art. In an exemplary embodiment, the controller 115 of the SOC 100 and/or the controller 210 of the evaluator 205 is configured to perform the action(s) or control the SOC 100 to perform the action(s).
After steps 535, the flowchart 500 transitions to step 540, where the flowchart 500 ends. The flowchart 500 may be repeated one or more times. For example, the flowchart 500 may be performed during the runtime of the SOC 100. As a non-limiting example, the integrity verification method can be performed during runtime: in response to a request from one or more external components; in response to an external component connecting with and/or disconnecting from, the SOC 100; in response to a user request; and/or at a specific time and/or periodically.
Various exemplary embodiments described herein can be implemented, for example, using one or more computer systems, such as computer system 600 shown in
Computer system 600 includes one or more processors (also called central processing units, or CPUs), such as a processor 604. Processor 604 is connected to a communication infrastructure or bus 606.
One or more processors 604 may each be a graphics processing unit (GPU). In an embodiment, a GPU is a processor that is a specialized electronic circuit designed to rapidly process mathematically intensive applications on electronic devices. The GPU may have a highly parallel structure that is efficient for parallel processing of large blocks of data, such as mathematically intensive data common to computer graphics applications, images and videos.
Computer system 600 can also include user input/output device(s) 603, such as monitors, keyboards, pointing devices, etc., which communicate with communication infrastructure 606 through user input/output interface(s) 602.
Computer system 600 can include a main or primary memory 608, such as random access memory (RAM). Main memory 608 may include one or more levels of cache. Main memory 608 has stored therein control logic (i.e., computer software) and/or data.
Computer system 600 may also include one or more secondary storage devices or memory 610. Secondary memory 610 may include, for example, a hard disk drive 612 and/or a removable storage device or drive 614. Removable storage drive 614 may be a floppy disk drive, a magnetic tape drive, a compact disk drive, an optical storage device, tape backup device, and/or any other storage device/drive.
Removable storage drive 614 may interact with a removable storage unit 618. Removable storage unit 618 includes a computer usable or readable storage device having stored thereon computer software (control logic) and/or data. Removable storage unit 618 may be a floppy disk, magnetic tape, compact disk, DVD, optical storage disk, and/ any other computer data storage device. Removable storage drive 614 reads from and/or writes to removable storage unit 618 in a well-known manner.
According to an exemplary embodiment, secondary memory 610 may include other instrumentalities or other approaches for allowing computer programs and/or other instructions and/or data to be accessed by computer system 600. Such instrumentalities or other approaches may include, for example, a removable storage unit 622 and an interface 620. Examples of the removable storage unit 622 and the interface 620 may include a program cartridge and cartridge interface (such as that found in video game devices), a removable memory chip (such as an EPROM or PROM) and associated socket, a memory stick and USB port, a memory card and associated memory card slot, and/or any other removable storage unit and associated interface.
Computer system 600 may further include a communication or network interface 624. Communication interface 624 enables computer system 600 to communicate and interact with any combination of remote devices, remote networks, remote entities, etc. (individually and collectively referenced by reference number 628). For example, communication interface 624 may allow computer system 600 to communicate with remote devices 628 over communications path 626, which may be wired and/or wireless, and which may include any combination of LANs, WANs, the Internet, etc. Control logic and/or data may be transmitted to and from computer system 600 via communication path 626.
In an exemplary embodiment, a tangible apparatus or article of manufacture comprising a tangible computer useable or readable medium having control logic (software) stored thereon is also referred to herein as a computer program product or program storage device. This includes, but is not limited to, computer system 600, main memory 608, secondary memory 610, and removable storage units 618 and 622, as well as tangible articles of manufacture embodying any combination of the foregoing. Such control logic, when executed by one or more data processing devices (such as computer system 600), causes such data processing devices to operate as described herein.
Based on the teachings contained in this disclosure, it will be apparent to persons skilled in the relevant art(s) how to make and use the invention using data processing devices, computer systems and/or computer architectures other than that shown in
The aforementioned description of the specific embodiments will so fully reveal the general nature of the disclosure that others can, by applying knowledge within the skill of the art, readily modify and/or adapt for various applications such specific embodiments, without undue experimentation, and without departing from the general concept of the present disclosure. Therefore, such adaptations and modifications are intended to be within the meaning and range of equivalents of the disclosed embodiments, based on the teaching and guidance presented herein. It is to be understood that the phraseology or terminology herein is for the purpose of description and not of limitation, such that the terminology or phraseology of the present specification is to be interpreted by the skilled artisan in light of the teachings and guidance.
References in the specification to “one embodiment,” “an embodiment,” “an exemplary embodiment,” etc., indicate that the embodiment described may include a particular feature, structure, or characteristic, but every embodiment may not necessarily include the particular feature, structure, or characteristic. Moreover, such phrases are not necessarily referring to the same embodiment. Further, when a particular feature, structure, or characteristic is described in connection with an embodiment, it is submitted that it is within the knowledge of one skilled in the art to affect such feature, structure, or characteristic in connection with other embodiments whether or not explicitly described.
The exemplary embodiments described herein are provided for illustrative purposes, and are not limiting. Other exemplary embodiments are possible, and modifications may be made to the exemplary embodiments. Therefore, the specification is not meant to limit the disclosure. Rather, the scope of the disclosure is defined only in accordance with the following claims and their equivalents.
Embodiments may be implemented in hardware (e.g., circuits), firmware, software, or any combination thereof. Embodiments may also be implemented as instructions stored on a machine-readable medium, which may be read and executed by one or more processors. A machine-readable medium may include any mechanism for storing or transmitting information in a form readable by a machine (e.g., a computing device). For example, a machine-readable medium may include read only memory (ROM); random access memory (RAM); magnetic disk storage media; optical storage media; flash memory devices; electrical, optical, acoustical or other forms of propagated signals (e.g., carrier waves, infrared signals, digital signals, etc.), and others. Further, firmware, software, routines, instructions may be described herein as performing certain actions. However, it should be appreciated that such descriptions are merely for convenience and that such actions in fact results from computing devices, processors, controllers, or other devices executing the firmware, software, routines, instructions, etc. Further, any of the implementation variations may be carried out by a general purpose computer.
For the purposes of this discussion, the term “processor circuitry” shall be understood to be circuit(s), processor(s), logic, or a combination thereof. For example, a circuit can include an analog circuit, a digital circuit, state machine logic, other structural electronic hardware, or a combination thereof. A processor can include a microprocessor, a digital signal processor (DSP), or other hardware processor. The processor can be “hard-coded” with instructions to perform corresponding function(s) according to embodiments described herein. Alternatively, the processor can access an internal and/or external memory to retrieve instructions stored in the memory, which when executed by the processor, perform the corresponding function(s) associated with the processor, and/or one or more functions and/or operations related to the operation of a component having the processor included therein.
In one or more of the exemplary embodiments described herein, processor circuitry can include memory that stores data and/or instructions. The memory can be any well-known volatile and/or non-volatile memory, including, for example, read-only memory (ROM), random access memory (RAM), flash memory, a magnetic storage media, an optical disc, erasable programmable read only memory (EPROM), and programmable read only memory (PROM). The memory can be non-removable, removable, or a combination of both.