Go to the source code of this file.
| Enumerations | |
| enum | { MAX_BUF = 1024 } | 
| Functions | |
| int | display_open (char *prog, int no_xterm, int flash_sz, int sram_sz, int sram_start, int eeprom_sz) | 
| void | display_close (void) | 
| void | display_send_msg (char *msg) | 
| void | display_clock (int clock) | 
| void | display_pc (int val) | 
| void | display_reg (int reg, uint8_t val) | 
| void | display_io_reg (int reg, uint8_t val) | 
| void | display_io_reg_name (int reg, char *name) | 
| void | display_flash (int addr, int len, uint16_t *vals) | 
| void | display_sram (int addr, int len, uint8_t *vals) | 
| void | display_eeprom (int addr, int len, uint8_t *vals) | 
Interface for using display coprocesses.
Simulavr has the ability to use a coprocess to display register and memory values in near real time.
Definition in file display.c.
| int display_open | ( | char * | prog, | 
| int | no_xterm, | ||
| int | flash_sz, | ||
| int | sram_sz, | ||
| int | sram_start, | ||
| int | eeprom_sz | ||
| ) | 
Open a display as a coprocess.
| prog | The program to use as a display coprocess. | 
| no_xterm | If non-zero, don't run the disply in an xterm. | 
| flash_sz | The size of the flash memory space in bytes. | 
| sram_sz | The size of the sram memory space in bytes. | 
| sram_start | The addr of the first byte of sram (usually 0x60 or 0x100). | 
| eeprom_sz | The size of the eeprom memory space in bytes. | 
Try to start up a helper program as a child process for displaying registers and memory. If the prog argument is NULL, don't start up a display.
Returns an open file descriptor of a pipe used to send data to the helper program.
Returns -1 if something failed.
Definition at line 85 of file display.c.
References avr_warning.
| void display_close | ( | void | ) | 
| void display_send_msg | ( | char * | msg | ) | 
Encode the message and send to display.
| msg | The message string to be sent to the display process. | 
Encoding is the same as that used by the gdb remote protocol: '$...#CC' where '...' is msg, CC is checksum. There is no newline termination for encoded messages.
FIXME: TRoth: This should be a private function. It is only public so that dtest.c can be kept simple. dtest.c should be changed to avoid direct use of this function. [dtest.c has served it's purpose and will be retired soon.]
Definition at line 220 of file display.c.
References avr_new0.
| void display_clock | ( | int | clock | ) | 
| void display_pc | ( | int | val | ) | 
| void display_reg | ( | int | reg, | 
| uint8_t | val | ||
| ) | 
| void display_io_reg | ( | int | reg, | 
| uint8_t | val | ||
| ) | 
| void display_io_reg_name | ( | int | reg, | 
| char * | name | ||
| ) | 
Specify a name for an IO register.
| reg | The IO register number. | 
| name | The symbolic name of the register. | 
Names of IO registers may be different from device to device.
Definition at line 316 of file display.c.
Referenced by avr_core_io_display_names().
| void display_flash | ( | int | addr, | 
| int | len, | ||
| uint16_t * | vals | ||
| ) | 
Update a block of flash addresses in the display.
| addr | Address of beginning of the block. | 
| len | Length of the block (number of words). | 
| vals | Pointer to an array of len words. | 
The display will update each addr of the block to the coresponding value in the vals array.
Each address in the flash references a single 16-bit wide word (or opcode or instruction). Therefore, flash addresses are aligned to 16-bit boundaries. It is simplest to consider the flash an array of 16-bit values indexed by the address.
Definition at line 340 of file display.c.
Referenced by flash_write().
| void display_sram | ( | int | addr, | 
| int | len, | ||
| uint8_t * | vals | ||
| ) | 
Update a block of sram addresses in the display.
| addr | Address of beginning of the block. | 
| len | Length of the block (number of bytes). | 
| vals | Pointer to an array of len bytes. | 
The display will update each addr of the block to the coresponding value in the vals array.
| void display_eeprom | ( | int | addr, | 
| int | len, | ||
| uint8_t * | vals | ||
| ) | 
Update a block of eeprom addresses in the display.
| addr | Address of beginning of the block. | 
| len | Length of the block (number of bytes). | 
| vals | Pointer to an array of len bytes. | 
The display will update each addr of the block to the coresponding value in the vals array.