1 / 14

Illustrating CPU Operations in Computer Literacy Course

This work explores teaching non-experts about the internals of a computer's CPU using an Excel-based simulation program. Concepts of processor cycles and program sequence are demonstrated.

mparrott
Download Presentation

Illustrating CPU Operations in Computer Literacy Course

An Image/Link below is provided (as is) to download presentation Download Policy: Content on the Website is provided to you AS IS for your information and personal use and may not be sold / licensed / shared on other websites without getting consent from its author. Content is provided to you AS IS for your information and personal use only. Download presentation by click this link. While downloading, if for some reason you are not able to download a presentation, the publisher may have deleted the file from their server. During download, if you can't get a presentation, the file might be deleted by the publisher.

E N D

Presentation Transcript


  1. Extending the Spreadsheet to Illustrate Basic CPU Operations in a Computer Literacy Course Richard E. Smith, Ph.D.Department of Quantitative Methods and Computer ScienceUniversity of St. Thomas This work is licensed under the Creative Commons Attribution-NonCommercial-ShareAlike License. To view a copy of this license, visit http://creativecommons.org/licenses/by-nc-sa/2.0/ R. Smith - University of St Thomas - Minnesota

  2. The Problem • How do we teach non-experts about the internals of the computer’s central processing unit (CPU)? • Option: Don’t bother • Option: Use a software simulation program • Option: use the Excel-based Simple CPU R. Smith - University of St Thomas - Minnesota

  3. The Simple CPU Display R. Smith - University of St Thomas - Minnesota

  4. Operating Features • RAM appears in Column A on the left • One-address instruction set • Some instructions refer to a single memory location • Calculations use a single “accumulator” register • Each instruction requires two cycles • Fetch cycle – get the instruction that’s to be executed • Execute cycle – perform the calculation or other action • This cycle may fetch or store data in RAM • Very Simple Instruction set • Three instructions refer to memory locations: Add, Store, Jump • Based on the TX-0 computer built in the 1950s R. Smith - University of St Thomas - Minnesota

  5. Not your grandfather’s laptop. “Transistor Experiment” computer, version 0 Built in 1955-56 by MIT’s Lincoln Laboratory Absurdly simple instruction set Focus on testing the transistorized computer circuits Easier to build, easier to test, easier to fix The TX-0 R. Smith - University of St Thomas - Minnesota

  6. In “Assembly Language” (text) format: Clear Add 5 Store 5 Jump 2 1 (data) In “Machine Language” (numeric) format: 2 105 205 302 1 A “Simple CPU” program R. Smith - University of St Thomas - Minnesota

  7. Concepts to Convey • A program as a sequence of instructions • Instructions in a highly coded form • Processor cycles • CPU is separate from its RAM R. Smith - University of St Thomas - Minnesota

  8. Use in Class • Demonstrate on a projection display. • Explain the notion of the processor cycle. • Demonstrate a simple program. • Explain how to translate simple add-and-subtract calculations into the right sequence of add-invert-add, etc. • Assignment to write their own programs in numeric form. R. Smith - University of St Thomas - Minnesota

  9. Final Points • Integration into the spreadsheet • Relies on concepts the students learned in Excel training • Seems like a follow-on to Excel, not a major topic change • Easy to modify and extend for other classes, like computer architecture • Simulator conveys concepts more effectively • Pre-simulator training relied on rote learning of concepts with discussion but no hands-on work or live demonstrations • Simulator lets students demonstrate an understanding of machine level instructions by doing homework assignments • Success on CPU-oriented exam questions went from (estimate) 1 out of 3 to 7 out of 8. R. Smith - University of St Thomas - Minnesota

  10. Thank You! Questions? • My contact information: • Dr. Rick Smith • University of St. Thomas • resmith@stthomas.edu • Getting the SimpleCPU Simulator: • Go to Google • Search for “smith simple cpu demo” http://www.cs.stthomas.edu/faculty/resmith /c/qmcs110/m/cpudemo1.html R. Smith - University of St Thomas - Minnesota

  11. The Simple CPU Display R. Smith - University of St Thomas - Minnesota

  12. Future Work • Extensions to simplify programming • Add conditional jumps • Add an index register • Make easier to modify and maintain • Rearrange calculations to minimize reliance on memorized cell identities • Move critical functions into VBasic modules to improve readability • Try using to teach computer architecture • Extension to multiple cycles, multiple address modes • Modifications by students to prototype their own processors, instruction sets R. Smith - University of St Thomas - Minnesota

  13. Executing a Program • First, reset the CPU • Program address (PC) starts at 1 • AC register starts at 0 • Next, perform the Fetch cycle • Calculate new values for the AC, PC, and IR in locations E3-E5, based on the contents of D5-E5 and data fetched from memory • At the end of the cycle, copy the new values of the AC, PC, and IR from cells E3-E5 to D3-D5. • Finally, perform the Execute cycle • Use the IR, Instruction, and Address cells (D5, D10, D11) to identify and execute the instruction • At the end of the cycle, copy the new values of the AC, PC, and IR from cells E3-E5 to D3-D5. • If storing a result in memory, do that, too. • Start next instruction at the Fetch Cycle above R. Smith - University of St Thomas - Minnesota

  14. Calculates the contents of the AC at the end of the Execute cycle (D4): =IF(D2,D3, IF(D10=1,D3+D9, IF(D5=1,-D3, IF(D5=2,0, D3)))) If it’s the Fetch cycle (D2 is TRUE), leave the AC (D3) unchanged. Else if it’s an ADD instruction (D10=1) Add the data from memory to the AC Else if it’s a Negate instruction (D5=1) Negate the data in the AC Else if it a Clear instruction (D5=2) Clear the data in the AC Example: part of the ADD calculation R. Smith - University of St Thomas - Minnesota

More Related