Bennett/General User Manual
If anything is unclear in this manual, please contact cadtools@manchester.ac.uk
Bennett
Bennett is a hardware monitor tool. It's puprpose is to make expose the controls to a processor and allow the Bennett user to operate on the memory of the system.
Bennett User Guide
Bennett has several backend modules, for example MU0 and RISC-V. The screenshots and examples in this guide use a variety of backends, so the exact interface / register banks may differ slightly depending on which course unit you are studying. Currently Benentt is used in COMP12111, COMP15111, COMP22111, COMP32211, COMP22711
Starting Bennnett
Please reference Bennett or your Lab manual on how to start bennett for your course unit.
GUI Overview
The figure below outlines the main elements of the Bennett GUI.
(A) Memory Window
The memory window displays the current values of the given memory for the underlying system.
In the top right corner of the memory panel, you can select to change the view of the memory.
- Source - Shows the source against the memory values
- Source (Expanded) - Shows empty white space and multiline comments
- Bytes - Shows the memory as bytes
- Halford - Shows the memory as halfwords
- Other modes are available. Not all modes are available for every backend module. (MU0 isn't byte addressable for example)
At the top of the memory panel, there is a box in which you can enter expressions. This expression will move the memory view around the whole memory. For example, if you put "PC", the memory pane will follow the value of the program counter as the processor executes instructions.
Breakpoints
Breakpoints are positions in the code where you would like execution to halt; this makes it much easier to debug code.
A breakpoint is set by double clicking the memory address in one of the memory windows – a green circle will appear. The row header (e.g 0x001) must be clicked, the part in light grey not the memory value cell itself.
Setting breakpoints is only possible when viewing in the Source or Disassembly formats in the memory view window.
When a breakpoint is set and the program run, the execution will automatically pause at the address with the breakpoint. To continue execution simply press the Play button. To remove a breakpoint simply click on the address where a breakpoint is currently set. It is possible to have more than one breakpoint in your code. Up to a maximum of 32.
(B) Registers / Breakpoints
From the register view window, you can see the contents of the system registers
For COMP12111, the acumulator, and the PC, as well as the status of the flags, Z and N. These values are fixed. A depressed button indicates that the bit representing that flag is 1.
For COMP15111/COMP22712 the full RISC-V registers are visible.
(C) File Menu
The file menu offers several more advanced options.
Comms
Gives options to control how many steps are step forward at a time, an ability to turn of communications with the underlying system and set the speed of the walk feature.
Assembly and Loading
Allows you to select a file to assemble, and a list of recently assembled files which can be reasembled quickly.
(D) Controls
Run
Bennett will tell the underlying processor to start running forward. The speed of this depends on the underlying system. Please consult your lab manual / lecture notes or ask a member of staff in labs about specifics for your module.
Stop
Bennett will ask the underlying system to stop.
Single Step
Bennett will request the underlying system exectues a single instruction. This is keybound to F5.
Walk
Reset
Bennett will request the processor resets. In most systems this will reset the program counter and internal state of the processor, but will not reset the memory or register values. Please consult your lab manual / lecture notes for details or ask a member of academic staff.
Load Program
Bennett will offer to load a program from disk. If an assembly file is given, bennett will attempt to assemble it first.
Other file formats supported include KMD, PNG, JPEG, HEX and Bin. See Bennett loading file formats for more details.
Reload Program
Bennett will attempt to reload the last progam that was loaded into the system memory.
(E) Status Message
The status message will let you know the current state of the system. This could be running, stopped, stopped due to a hardware issue etc.
Expression evaluation
Anywhere in Bennett that values can be entered, you may enter an expression. General mathematic expressions are valid, and Bennett will treat register names as variable holding the value of the register.
Some examples:
0xfff - 123
(Evaluates to a fixed number)PC -4
(Evaluating to the program counter - 4, good for following the PC)ACC * 2
(Evaluating to twice the accumulator)x0 * x12
(Another expressions that could be used in COMP15111)
If these expressions are entered in the memory window search bar, they will update continusly, allowing for live following of expressions.
Peripherals
Terminal
Bennett provides a terminal interface.