DSM Work 1

Download as docx, pdf, or txt
Download as docx, pdf, or txt
You are on page 1of 8

Sure, here's a brief summary of the sequence of operations for each topic:

**Topic 1: ALU-Based Computing Network with ROM Contents**

1. Select operand OP0:


- Set P1=0, P0=0.
- Command ALU to copy OP0 to its output (F=B), setting F2=1, F1=1, F0=1.
- Update accumulator with OP0, setting S1=1, S0=1.
- Set END=0.

2. Select operand OP1 and add to accumulator:


- Set P1=0, P0=1.
- Command ALU to add accumulator contents to OP1, setting F2=0, F1=0, F0=0.
- Update accumulator with result, setting S1=1, S0=1.
- Set END=0.

3. Select operand OP2 and subtract from accumulator:


- Set P1=1, P0=0.
- Command ALU to subtract OP2 from accumulator contents, setting F2=0, F1=0, F0=1.
- Set END=1.

**Topic 2: Computing Example - Evaluating Sum of Operands**

1. Add operand OP0 to operand OP1:


- Set P1=0, P0=0.
- Command ALU to add OP0 and OP1, setting F2=0, F1=0, F0=0.
- Update accumulator with result, setting S1=1, S0=1.
- Set END=0.
2. Subtract operand OP2 from the previous result:
- Set P1=1, P0=0.
- Command ALU to subtract OP2 from accumulator contents, setting F2=0, F1=0, F0=1.
- Set END=1.

3. Evaluate flags:
- Determine CO and ZF based on the result:
- If (OP0 + OP1) = OP2, CO=0, ZF=1.
- If (OP0 + OP1) > OP2, CO=0, ZF=0.
- If (OP0 + OP1) < OP2, CO=1, ZF=0.

These sequences outline the steps involved in each topic's computing process using the ALU-
based network and ROM contents.
Evaluating both the carry out (CO) and zero flag (ZF) during the subtraction step provides
crucial information to accurately determine the relationship between the sum of operands (OP0 +
OP1) and operand OP2.

1.Carry Out (CO): CO indicates whether there was a borrow during the subtraction operation. If
CO is 1, it signifies a borrow, indicating that the result (OP0 + OP1) is less than OP2.

2. Zero Flag (ZF): ZF indicates whether the result of the subtraction is zero. If ZF is 1, it means
the result is zero, signifying that (OP0 + OP1) is equal to OP2.

By considering both CO and ZF, the computation can accurately determine whether (OP0 +
OP1) is greater than, equal to, or less than OP2. This enables precise control flow or decision-
making in subsequent steps of the algorithm.
Certainly! Here's the topic written in a similar style to the previous one, along with the
advancements made:

**1.2.5 The "Instructions"**


Since the machine executes operations stored in memory, we'll refer to these operations as
"instructions" from now on. Defining instructions in the ROM bit by bit can be tedious and error-
prone. To simplify this, we'll introduce mnemonic codes associated with each instruction. These
mnemonics can be easily translated into machine code later.

Advancements:
- Introduction of mnemonic codes for instructions, making it easier to define ROM contents.
- Use of mnemonic codes like "IN" for input and "ADD" for addition, similar to microprocessor
technical manuals.

Here are some examples of mnemonic codes and their corresponding machine code
representations:

1. **Input Operation:**
- Mnemonic: IN A,P
- Machine Code: p1 p0 0 1 1 1 1 1
- Description: A ← P (where P represents one of the four possible inputs)

2. **Addition Operation:**
- Mnemonic: ADD A,P
- Machine Code: p1 p0 0 0 0 0 1 1
- Description: A ← (A + P)

3. **Subtraction Operation:**
- Mnemonic: SUB A,P
- Machine Code: p1 p0 0 0 1 1 1 1
- Description: A ← (A - P)

4. **Logical AND Operation:**


- Mnemonic: AND A,P
- Machine Code: p1 p0 0 1 0 1 1 1
- Description: A ← (A AND P)

5. **Logical OR Operation:**
- Mnemonic: OR A,P
- Machine Code: p1 p0 0 1 1 1 1 1
- Description: A ← (A OR P)

Advancements:
- Introduction of mnemonic codes for various ALU operations like addition, subtraction, logical
AND, and logical OR.
- Implementation of mnemonic codes for shift operations, denoted by "SRL" for Shift Right
Logic and "SLL" for Shift Left Logic.

**1.2.6 "Program", "Programming", and Other Important Terms**

We'll now refer to a sequence of instructions describing an algorithm as a "program".


Programming the system involves two phases:
- In phase one, we write a text file with instructions in mnemonic code, describing the desired
algorithm.
- In phase two, we translate the mnemonic code into machine code and insert it into the ROM,
also known as Program Memory.

Advancements:
- Introduction of the concept of a "program" to describe a sequence of instructions.
- Explanation of programming phases and the use of a mnemonic code-machine code translator
(assembler).
- Introduction of the term "Program Counter" (PC) to refer to the instruction address generated
by the sequencer, which indexes individual program instructions for execution.
- Mention of alternative terms like "Instruction Pointer" (IP) used in technical literature to refer
to the Program Counter.
Certainly! Here's the sequence of operation for each topic along with advancements:

**1.3 Sequencing, Microinstructions, and Microprograms**

**1.3.1 A More Compact Sequencer:**

1. **Identification of Limitations:** Recognize the limitations of the current network structure


in executing complex tasks due to fixed-length instruction codes and memory size constraints.

2. **Introduction of Microcode Memory (MCM):** Separate the sequencer from the network
and introduce a new ROM memory, MCM, to store microcodes representing sets of control
signals required for executing instructions.

3. **Microcode Addressing:** Use machine codes to represent addresses in the MCM, enabling
compact instruction codes independent of the number of control lines.

**Advancements:**
- Introduction of MCM to store microcodes, allowing for a more compact instruction format.
- Utilization of machine codes as addresses in MCM, enabling compact instruction codes even
with increased control lines.

**1.3.2 The Microprogrammed Sequencer:**

1. **Identification of Timing Limitations:** Acknowledge the limitations of executing


instructions with multiple clock cycles due to the structure of the MCM.

2. **Introduction of Microinstructions and Microprograms:** Recognize the need to treat each


instruction as a small program composed of multiple microinstructions to overcome timing
limitations.
3. **Introduction of Microprogram Memory (MPM):** Add a new counter, Microprogram
Counter (MPC), and a ROM memory, MPM, to store microprograms containing sequences of
microinstructions.

4. **Sequential Execution:** Implement sequential addressing by the MPC to execute


microinstructions within a microprogram, allowing for instructions with multiple clock cycles.

**Advancements:**
- Introduction of microinstructions and microprograms to execute instructions with multiple
clock cycles.
- Implementation of MPC and MPM to sequentially execute microinstructions within
microprograms, overcoming timing limitations.
- Separation of instruction execution into two phases: instruction retrieval from PM and
execution of microprograms stored in MPM.
- Enhancement of control signal generation through sequential decoding of instructions by MPC
and MPM.
**1.3.3 The Microprogrammed Sequencer and the Computing Network**

**Advancements:**

1. **Enhanced Control by Microinstructions:** Introduce lines LDPC, ENPC, and LDMC to be


controlled by microinstructions, enabling the sequencer to manage its functions internally.

2. **Integration of Microprogram Memory (MPM):** Connect MPM outputs to control lines for
incrementing or loading the Program Counter (PC), loading the Microprogram Counter (MPC),
and advancing the MPC.

3. **Sequencer Adaptation:** Adapt the computing network by replacing the sequencer with a
microprogrammed one, allowing for more intricate control and management of instruction
execution.

**1.3.4 How it Works:**


1. **Microinstruction Configuration:** Write microinstructions tailored for each instruction in
MPM, dictating specific signal configurations for execution.

2. **Sequencer Operation:** Execute instructions by loading microprograms containing


sequences of microinstructions from MPM, with each microinstruction activating specific
control signals.

**Advancements:**
- Utilization of microinstructions to control signal configurations, enabling precise instruction
execution.
- Integration of MPM to store microprograms, facilitating the execution of complex instructions
by sequential activation of microinstructions.

**1.3.5 Executing a Sequence of Instructions:**

1. **Instruction Cycle:** Implement a cyclical instruction cycle comprising Fetch, Decode, and
Execute phases, with microinstructions executed sequentially over multiple clock cycles.

2. **Instruction Sequencing:** Coordinate the execution of consecutive instructions by


activating control lines ENPC and LDMC in the last microinstruction of each instruction.

**Advancements:**
- Establishment of a continuous instruction execution cycle through coordinated activation of
control lines in microinstructions.
- Optimization of instruction sequencing to ensure smooth execution of consecutive instructions.

**1.3.6 Executing the First Instruction During Startup:**

1. **Initialization Process:** Define the execution of the first instruction after system reset by
targeting microprogram memory location zero.
2. **Configuration of Microinstruction at Location Zero:** Configure the microinstruction at
location zero to load the current instruction into the MPC, enabling PC increment and
preparation for executing the next instruction.

**Advancements:**
- Seamless execution of the first instruction post-reset by setting up microinstruction at location
zero to initialize the instruction cycle.
- Utilization of NOP instruction at location zero to facilitate startup initialization without
executing any operation.

These advancements signify the evolution of the computing network towards more efficient and
controlled instruction execution through microprogrammed sequencing.

You might also like