Starting from:

$30

CSC230-Lab 3 Introduction to Assembly Language Solved

Introduction to Atmel Studio 7.0:

Launch Atmel Studio 7.0 and create a new project named “lab3”: click on the Start  button, then click on Atmel Studio 7.0:



Create a new project named lab3: on the menu, click on File - New - Project:



In the new dialog box, on the left pane, under Installed, select Assembler. Type the project Name lab3 and select a Location on drive “H:”. Click on the OK button. 



             

When the new dialog box appears, choose ATmega2560 for the Device Family. Click on the OK button.



             

The new project will look similar to this:

 

 

             

Remove:

 

 

      start:            inc r16           rjmp start

 
 

And replace it with the following code:

 

 

 

Save the code and build the program: on the menu, click on Build - Build Solution:



             

The screen looks like this:



If there are any errors or warnings, you must address them and rebuild your program.

 

             

When there are no errors or warnings, you are ready to run your program using the simulator. Set up the configuration of the simulator: from the Project menu - lab3 Properties…:



In the settings window, click on Tool and select Simulator:



Save the project by click on “File” menu - “Save All”.

 

             

Start the simulator: from the menu, click on Debug - Start Debugging and Break



The editor should show a yellow arrow indicating the instruction about to be fetched. The left panel shows the “Processor Status”, where you can examine the register and processor values. The “Program Counter” shows the memory address of the next instruction to be fetched.



 

Execute the first instruction by clicking Step Into (or press the F11 key).



You can also do it by clicking this icon on the menu bar:

                                                 

After executing the first instruction, the value in register 16 (R16) is changed from 0x00 to 0x01. Notice that whenever a value changes in the Processor Status, Memory, and I/O windows, they are highlighted in red. Also, the instruction to be executed NEXT is indicated by the yellow arrow on the side.



You can stop the debugging session anytime by clicking on the “Stop Debugging” under the “Debug” menu (or press Crtl+Shift+F5)

II.    Converting Assembly language instructions to binary machine code.

 

Let’s consider the LDI instruction, which can be found on page 94 in the AVR Instruction Set Manual.

 

 

 

The binary opcode (operation code) for the instruction “LDI Rd, K” is “1110” and together the opcode and the operands are arranged as “1110 KKKK dddd KKKK”. Here, and everywhere else in the manual, Rd stands for destination register, and the corresponding dd...d specifies which register will be used as Rd. Similarly, KK…K specifies a value in binary format.

 

For example, to load the value 0x82 into register 16, we would write an Assembly language instruction:

 

 

      LDI r16, 0x82

 
 

In this example:

-        K = 0x82, which is 0b10000010 in binary, which must be in range 0 ≤ K ≤ 255.

-        d = 16, is 0b10000 in binary, which must be in range 16 ≤ d ≤ 31 (thus only 4 LSB[1] are used).

 

Note that the manual specifies the minimum and maximum values for the operands. Since there are only 4 bits available to specify the destination register, we can only specify 16 out of 32 registers. Thus, 0b0000 corresponds to r16 and 0b1111 corresponds to r31.

 

The Assembly instruction above translates to 0b1110100000000010 16-bit binary machine code, which is 0xE802. However, in program memory, you see 0x02E8. Why? Because it is stored in the Little-Endian format such that, in each word (two bytes), the least significant byte is stored first.

 

In summary, the Assembly instruction “LDI r16, 0x82” corresponds to the binary machine code 0b1110100000000010, or 0xE802, which is stored as 0x02E8 in the AVR program memory.

 

III.  Exercises: 

 

1.     Write the following Assembly language instructions (mnemonics) and convert them into the binary machine code using the Assembly Instruction Set manual. Verify the results by reviewing the machine code (hexadecimal numbers) in the program memory using the debugging procedure described above. 

a.     ANDI r16, 0x3A

b.     LDI r17, -5

c.      MOV r17, r0

 

2.     Write a program that calculates the number of students in the hypothetical course CSC 999. There are two lab sections in this course, B01 and B02. The number of students registered in these sections are 23 in B01 and 21 in B02.

 

Given that the maximum enrollment for the course is 60, set register 0 to indicate whether there are more students in the course than allowed by the enrollment limit. So, set R0 to 1 if there are more than 60 students enrolled in the labs and 0 otherwise. You can assume that the total number of students will fewer than 256. Here is the pseudo code for the algorithm:

o   Initialize the output register (set it to 0): R0 <= 0x00 o Set R19 to the value of maximum enrollment

o   Set R16 to the value indicating the number of students enrolled in B01 o Set R17 to the value indicating the number of students enrolled in B02 o Add R16 and R17, store the result in R16 o If R16 R19, set R0 to 1

o   Done

 

3.     (Submit this part only.) Write a program that checks if an 8-bit unsigned number is an even number. If the input number is even, the program outputs 0x00, otherwise 0xFF. Let’s use R18 for input and R19 for output. To test the program, initially set the input to 0x09 and test it. Then change the input to 0x08 and manually check if the output is correct via the debugging procedure described in this lab. Here is the pseudo code for the algorithm:

o   Initialize the output register R19 (set it to 0): R19 <= 0x00 o Set R18 to 9 as input to test: R18 <= 0x09

o   Set all bits except the last (least significant bit) of R18 to 0 (hint: use ANDI with a mask) o If R18 = 0x01, set R19 to 0xFF (note that you could use the zero flag in SREG directly after masking, thus reducing the required number of instructions. In other words, you don’t need to compare R18 with 0x01 separately after the masking operation.) o Done



[1] LSB stands for Least Significant Bit.

More products