Modes of Addressing (OCR A Level Computer Science)

Revision Note

Callum Davies

Written by: Callum Davies

Reviewed by: James Woodhouse

Updated on

Modes of Addressing

  • Immediate Addressing

    • Operand is part of the instruction itself

MOV AX, 1234h // Moves the immediate hex value 1234h to the AX register

  • Direct Addressing

    • The memory address of the operand is directly specified

MOV AX, [1234h] // Take the value stored in memory location 1234h and move to the AX register

  • Indirect Addressing

    • A register contains the memory address of the operand

    • If BX contains the value 2000h:

MOV AX, [BX] // Moves the value from memory location 2000h to the AX register

  • This does not mean "Move the value 2000h into AX"

  • Instead, it means, "Look in the memory address 2000h (the value currently stored in the BX register) and move whatever value you find into the AX register."

  • When brackets [ ] are around a register in assembly language (like [BX]), it's an instruction to treat the value inside that register as a memory address and to use the data at that memory address for the operation

  • Indexed Addressing

    • Combines a base address with an index to compute the effective address

    • If BX contains 0050h and SI has a base address 1000h:

MOV AX, [BX + SI] // Move the value at memory location 1050h to AX

  • Fetches data from the effective address (because 1000h + 0050h is 1050h) and moves it into the AX register

Worked Example

Consider a basic computer system with the following assembly language instructions and a memory layout starting at address 1000.

1000: MOV AX, 8
1002: ADD AX, [BX]
1004: MOV [0008], AX
1006: MOV CX, [BX+DI]
1008: HLT
 

Assume the registers have the following values before execution:

AX = 0000
BX = 0003
DI = 0002
CX = 0010

Memory contains:

0000: 0
0001: 0
0002: 0
0003: 5
0004: 0
0005: 7
0006: 7
0007: 9
0008: 0

a) For the instruction at 1002, identify the addressing mode used and explain what it does in the context of this instruction.

[2]

b) After the instruction at 1004 has executed, what will the value at memory address 0008 be? Justify your answer.

[2]

c) What value will be moved into the CX register after the instruction at 1006 executes? Explain the addressing mode used.

[2]

Answer:

Answer that gets full marks:

a) The instruction at 1002 uses Indirect Addressing. The instruction ADD AX, [BX] adds the value at the memory address contained in the BX register to the AX register. In this case, since BX is 3, it will add the value at memory address 3 to AX.

b) The value at memory address 0008 will be 13. Before the instruction, AX contains the value 8. After adding 5 (from memory address 3 due to the instruction at 1002), AX will have the value 13. The instruction at 1004 then moves this value to memory address 0008.

c) The value moved into the CX register will be 7. The instruction at 1006 uses Indexed Addressing. It accesses memory by combining the address in BX with the offset in DI. Given BX is 3 and DI is 2, the effective address is 3 + 2 = 5, so it fetches the value 7 from address 0005 into CX.

Acceptable responses:

a) Any answer identifying Indirect Addressing and explaining its use in the context of fetching a value from memory for the instruction should be awarded marks.

b) Any answer stating that the value at address 0008 will be 13 due to adding 8 and 5 should be awarded marks.

c) Any response indicating the use of Indexed Addressing and explaining the value fetch from address 5 should be awarded marks.

You've read 0 of your 5 free revision notes this week

Sign up now. It’s free!

Join the 100,000+ Students that ❤️ Save My Exams

the (exam) results speak for themselves:

Did this page help you?

Callum Davies

Author: Callum Davies

Expertise: Computer Science

Callum is an experienced teacher of GCSE and A-Level Computer Science. He has 4 years of teaching experience and has detailed knowledge of how to achieve exam success, having marked for OCR A-Level. Callum is now a software engineer and regularly mentors new engineers.

James Woodhouse

Author: James Woodhouse

Expertise: Computer Science

James graduated from the University of Sunderland with a degree in ICT and Computing education. He has over 14 years of experience both teaching and leading in Computer Science, specialising in teaching GCSE and A-level. James has held various leadership roles, including Head of Computer Science and coordinator positions for Key Stage 3 and Key Stage 4. James has a keen interest in networking security and technologies aimed at preventing security breaches.