Question

In: Computer Science

Write an assembly program which will read the value of the switches on the board, parse...

Write an assembly program which will read the value of the switches on the board, parse this number by looking at the 4 least-significant bits, using the lookup table from the prelab to get the value necessary to display this hex number on a 7-segment display, using shift instructions to adjust registers as necessary to parse the next set of values. Repeat until all four displays are accounted for. Finally, when one register has a bit-stream necessary to display all four 7-segment displays for the value read from the switches, this value is written to the four rightmost 7-segment displays. This set of displays is addressed by a keyword in the given .s address file. 2/2All four 7-segement displays must display some character, using zeros if there would be nothing else to display.

Lookup lib:


.equ H_ZERO, 0x0000003F
.equ H_ONE, 0x00000006
.equ H_TWO, 0X0000005B
.equ H_THREE, 0x0000004F
.equ H_FOUR, 0x00000066
.equ H_FIVE, 0x0000006D
.equ H_SIX, 0x0000007D
.equ H_SEVEN 0x00000007
.equ H_EIGHT 0x0000007F
.equ H_NINE 0x0000006F
.equ H_TEN, 0x00000077
.equ H_ELEVEN 0x0000007C
.equ H_TWELVE 0x00000039
.equ H_THIRTEEN 0x0000005E
.equ H_FOURTEEN 0x00000079
.equ H_FIFTEEN 0x00000071

please write in arm assembly language thank you.


Solutions

Expert Solution

/* This files provides address values that exist in the system */

/* Memory */
.equ DDR_BASE, 0x00000000
.equ DDR_END, 0x3FFFFFFF
.equ A9_ONCHIP_BASE, 0xFFFF0000
.equ A9_ONCHIP_END, 0xFFFFFFFF
.equ SDRAM_BASE, 0xC0000000
.equ SDRAM_END, 0xC3FFFFFF
.equ FPGA_ONCHIP_BASE, 0xC8000000
.equ FPGA_ONCHIP_END, 0xC803FFFF
.equ FPGA_CHAR_BASE, 0xC9000000
.equ FPGA_CHAR_END, 0xC9001FFF

/* Cyclone V FPGA devices */
.equ LEDR_BASE, 0xFF200000
.equ HEX3_HEX0_BASE, 0xFF200020
.equ HEX5_HEX4_BASE, 0xFF200030
.equ SW_BASE, 0xFF200040
.equ KEY_BASE, 0xFF200050
.equ JP1_BASE, 0xFF200060
.equ JP2_BASE, 0xFF200070
.equ PS2_BASE, 0xFF200100
.equ PS2_DUAL_BASE, 0xFF200108
.equ JTAG_UART_BASE, 0xFF201000
.equ JTAG_UART_2_BASE, 0xFF201008
.equ IrDA_BASE, 0xFF201020
.equ TIMER_BASE, 0xFF202000
.equ TIMER_2_BASE, 0xFF202020
.equ AV_CONFIG_BASE, 0xFF203000
.equ PIXEL_BUF_CTRL_BASE, 0xFF203020
.equ CHAR_BUF_CTRL_BASE, 0xFF203030
.equ AUDIO_BASE, 0xFF203040
.equ VIDEO_IN_BASE, 0xFF203060
.equ ADC_BASE, 0xFF204000

/* Cyclone V HPS devices */
.equ HPS_GPIO1_BASE, 0xFF709000
.equ I2C0_BASE, 0xFFC04000
.equ I2C1_BASE, 0xFFC05000
.equ I2C2_BASE, 0xFFC06000
.equ I2C3_BASE, 0xFFC07000
.equ HPS_TIMER0_BASE, 0xFFC08000
.equ HPS_TIMER1_BASE, 0xFFC09000
.equ HPS_TIMER2_BASE, 0xFFD00000
.equ HPS_TIMER3_BASE, 0xFFD01000
.equ FPGA_BRIDGE, 0xFFD0501C

/* ARM A9 MPCORE devices */
.equ PERIPH_BASE, 0xFFFEC000 /* base address of peripheral devices */
.equ MPCORE_PRIV_TIMER, 0xFFFEC600 /* PERIPH_BASE + 0x0600 */

/* Interrupt controller (GIC) CPU interface(s) */
.equ MPCORE_GIC_CPUIF, 0xFFFEC100 /* PERIPH_BASE + 0x100 */
.equ ICCICR, 0x00 /* CPU interface control register */
.equ ICCPMR, 0x04 /* interrupt priority mask register */
.equ ICCIAR, 0x0C /* interrupt acknowledge register */
.equ ICCEOIR, 0x10 /* end of interrupt register */
/* Interrupt controller (GIC) distributor interface(s) */
.equ MPCORE_GIC_DIST, 0xFFFED000 /* PERIPH_BASE + 0x1000 */
.equ ICDDCR, 0x00 /* distributor control register */
.equ ICDISER, 0x100 /* interrupt set-enable registers */
.equ ICDICER, 0x180 /* interrupt clear-enable registers */
.equ ICDIPTR, 0x800 /* interrupt processor targets registers */
.equ ICDICFR, 0xC00 /* interrupt configuration registers */


Related Solutions

Create an assembly language program on the 9S12 CPU to read switches and drive LED's 1-Configure...
Create an assembly language program on the 9S12 CPU to read switches and drive LED's 1-Configure all bits of Port U for output using address DDRU. There are 8 LEDs connected to those pins. When you output a 1 to a bit, that bit will be enabled for output, so when you later write a 1 to a bit in port U (PTU) that LED will turn ON. 2. Switches are attached to Port T. They work by grounding the...
Write Arduino program to implement wiring three momentary switches to the Arduino board
Write Arduino program to implement wiring three momentary switches to the Arduino board
Parse string java code Write a recursive program that can calculate the value of a given...
Parse string java code Write a recursive program that can calculate the value of a given polynomial in a string, which is not more than the tenth order, for the given x. The polynomial will be given in the following format and should display the value of the polynomial for spaced-out x Using index of for -/+
arms64 assembly language Write a function to read a Sudoku board from an input string. The...
arms64 assembly language Write a function to read a Sudoku board from an input string. The input string must be exactly 81 characters long (plus the terminating null that marks the end of the string) and contains digits and dots (the `.` character represents an unmarked position). The input contains all 9 rows packed together. For example, a Sudoku board that looks like this: ``` ..7 ... ... 6.4 ... ..3 ... .54 ..2 ... .4. ... 9.. ... ..5...
Write an assembly program (Data and Code) that uses loop to read 10 numbers and output...
Write an assembly program (Data and Code) that uses loop to read 10 numbers and output the largest of those numbers, you can assume any length for those numbers. 80x86 assembly language
Write a MIPS assembly language program to read an arbitrary number of integer pairs from a...
Write a MIPS assembly language program to read an arbitrary number of integer pairs from a file. Each pair will then be multiplied together with the results being accumulated (added together) forming a sum-of-products operation. Submit your report and code here.
**IN AT&T ASSEMBLY LANG** Write an assembly language program which either hardcodes or reads in two...
**IN AT&T ASSEMBLY LANG** Write an assembly language program which either hardcodes or reads in two integers, A and B, and uses them to compute the following expressions. You must use the same values for A and B throughout all three expressions. A * 5 (A + B) - (A / B) (A - B) + (A * B)
Write an assembly language program for 8085 microprocessor to read consecutive memory locations from 2000 to...
Write an assembly language program for 8085 microprocessor to read consecutive memory locations from 2000 to 2FFF & transfer to 4000 to 4FFF
Write a MIPS Assembly Language program to perform the following operations: Request and read two integers...
Write a MIPS Assembly Language program to perform the following operations: Request and read two integers from the console (Dn and Up), Call a recursive function to compute the result int RecurseFunc( int Dn, int Up ) { if( Dn < 1 ) return 0; return Dn * Up + RecurseFunc( Dn - 1, Up + 1 ); } Print out the results
Write a simple MIPS Assembly program to average 3 integers. Make sure to read in three...
Write a simple MIPS Assembly program to average 3 integers. Make sure to read in three numbers from the user instead of hard coding them. To divide the sum by 3 you may use div $t0, $t0, 3 where register $t0 conatins the sum of the 3 integers. .data prompt1: .asciiz " Please enter an integer: " prompt2: .asciiz " Please enter an integer: " prompt3: .asciiz " Please enter an integer: " result: .asciiz "The average of three number...
ADVERTISEMENT
ADVERTISEMENT
ADVERTISEMENT