operations for operations?

Consider the following sequence of micro-operations.

  MBR ← PC
  MAR ← X  
  PC ← Y  
  Memory ← MBR

Which one of the following is a possible operation performed by this sequence?

  • Instruction fetch
  • Operand fetch
  • Conditional branch
  • Initiation of interrupt service

  • Answer is option (4).

    My attempt :

  • Instruction fetch : Fetch instruction: Read instruction code from address in PC and place in IR. ( IR ← Memory[PC] )
  • Operand fetch : Fetch operands from memory if necessary: If any operands are memory addresses, initiate memory read cycles to read them into CPU registers. If an operand is in memory, not a register, then the memory address of the operand is known as the effective address, or EA for short. The fetching of an operand can therefore be denoted as Register ← Memory[EA]. On today's computers, CPUs are much faster than memory, so operand fetching usually takes multiple CPU clock cycles to complete.
  • A conditional branch instruction causes the location counter in the PSW to be set to the address specified in the register or the register plus a 12-bit offset, if a condition is satisfied (and the register is not 0)
  • An interrupt service routine (ISR) is a software routine that hardware invokes in response to an interrupt. ISRs examine an interrupt and determine how to handle it. ISRs handle the interrupt, and then return a logical interrupt value.

  • Can you explain in sequence of micro-operations for operations given in option?


    This question uses notation from one of William Stalling's Computer Organization and Architecture textbooks. The question itself does not contain enough background material for someone unfamiliar with Stalling's textbook to answer it (I do not own Stalling's textbook, or know which version this question references).

    However, after seeing the comment that pointed to an answer at another site, I Googled for "rules for clock cycle grouping". That led to a bunch of links that pointed to various different sets of slides.

    The third link for me was to a powerpoint presentation which included a slide that I have copied below as an image. There was a slide that explained what MAR and MBR stand for:

    Memory Address Register (MAR)

  • Connected to address bus

  • Specifies address for read or write op

  • Memory Buffer Register (MBR)

  • Connected to data bus

  • Holds data to write or last data read

  • 截图

    So it appears that what is happening is that first the PC is placed in MBR . Next the address for where the PC will be saved is copied from X to MAR . In the same cycle the PC is set to the start of the interrupt service routine which is available in Y . Finally the data in MBR is transferred on the bus to memory.

    链接地址: http://www.djcxy.com/p/80360.html

    上一篇: x86汇编对同一目标的两个跳转指令

    下一篇: 操作?