Introduction to Assembly Language and Computer Architecture
Posted on Sep 5, 2024 in Computers
Chapter 1: Introduction
Q&A
Questions
- How do assemblers and linkers work together?
- How will studying assembly language enhance your understanding of operating systems?
- What is meant by a one-to-many relationship when comparing a high-level language to machine language?
- Explain the concept of portability as it applies to programming languages.
- Is the assembly language for x86 processors the same as those for computer systems such as the Vax or Motorola 68×00?
- Give an example of an embedded systems application.
- What is a device driver?
- Do you suppose type checking on pointer variables is stronger (stricter) in assembly language or in C and C++?
- Name two types of applications that would be better suited to assembly language than a high-level language.
- Why would a high-level language not be an ideal tool for writing a program that directly accesses a particular brand of printer?
- Why is assembly language not usually used when writing large application programs?
- Challenge: Translate the following C++ expression to assembly language, using the example presented earlier in this chapter as a guide: X = (Y * 4) + 3.
Answers
- An assembler converts source-code programs from assembly language into machine language. A linker combines individual files created by an assembler into a single executable program.
- Assembly language is a good tool for learning how application programs communicate with the computer’s operating system via interrupt handlers, system calls, and common memory areas. Assembly language programming also helps when learning how the operating system loads and executes application programs.
- In a one-to-many relationship, a single statement expands into multiple assembly language or machine instructions.
- A language whose source programs can be compiled and run on a wide variety of computer systems is said to be portable.
- No. Each assembly language is based on either a processor family or a specific computer.
- Some examples of embedded systems applications are automobile fuel and ignition systems, air-conditioning control systems, security systems, flight control systems, hand-held computers, modems, printers, and other intelligent computer peripherals.
- Device drivers are programs that translate general operating system commands into specific references to hardware details that only the manufacturer knows.
- C++ does not allow a pointer of one type to be assigned to a pointer of another type. Assembly language has no such restriction regarding pointers.
- Applications suited to assembly language: hardware device driver and embedded systems and computer games requiring direct hardware access.
- A high-level language may not provide for direct hardware access. Even if it does, awkward coding techniques must often be used, resulting in possible maintenance problems.
- Assembly language has minimal formal structure, so structure must be imposed by programmers who have varying levels of experience. This leads to difficulties maintaining existing code.
Q&A
Questions
- In your own words, describe the virtual machine concept.
- Why don’t programmers write application programs in machine language?
- (True/False): When an interpreted program written in language L1 runs, each of its instructions is decoded and executed by a program written in language L0.
- Explain the technique of translation when dealing with languages at different virtual machine levels.
- At which level does assembly language appear in the virtual machine example shown in this section?
- What software permits compiled Java programs to run on almost any computer?
- Name the four virtual machine levels named in this section, from lowest to highest.
- Why don’t programmers write applications in machine language?
- Machine language is used at which level of the virtual machine shown in Figure 1-1?
- Statements at the assembly language level of a virtual machine are translated into statements at which other level?
Answers
- Virtual machine concept: Computers are constructed in layers, so that each layer represents a translation layer from a higher-level instruction set to a lower-level instruction set.
- Machine language: It is enormously detailed and consists purely of numbers. Hard for humans to understand.
- True.
- An entire L1 program is converted into an L0 program by an L0 program specifically designed for this purpose. Then the resulting L0 program is executed directly on the computer hardware.
- Assembly language appears at Level 3.
- The Java virtual machine (JVM) allows compiled Java programs to run on almost any computer.
- Digital logic, instruction set architecture, assembly language, high-level language.
- Machine language is difficult for humans to understand since it provides no visual clues relating to the instruction syntax.
- Instruction set architecture.
- Level 2 (Instruction Set Architecture).
Q&A
Questions
- The central processor unit (CPU) contains registers and what other basic elements?
- The central processor unit is connected to the rest of the computer system using what three buses?
- Why does memory access take more machine cycles than register access?
- What are the three basic steps in the instruction execution cycle?
- Which two additional steps are required in the instruction execution cycle when a memory operand is used?
- During which stage of the instruction execution cycle is the program counter incremented?
- When a program runs, what information does the OS read from the filename’s disk directory entry?
- After a program has been loaded into memory, how does it begin execution?
- Define multitasking.
- What is the function of the OS scheduler?
- When the processor switches from one task to another, what values in the first task’s state must be preserved?
- What is the duration of a single clock cycle in a 3-GHz processor?
Answers
- Control Unit, Arithmetic Logic Unit, and the clock.
- Data, Address, and Control buses.
- Conventional memory is outside the CPU, and it responds more slowly to access requests. Registers are hard-wired inside the CPU.
- Fetch, decode, execute.
- Fetch memory operands, store memory operands.
- During the fetch step.
- Section 2.1.4 mentions the filename, file size, and starting location on the disk. (Most directories also store the file’s last modification date and time.)
- The OS executes a branch (like a GOTO) to the first machine instruction in the program.
- The CPU executes multiple tasks (programs) by rapidly switching from one program to the next. This gives the impression that all programs are executing at the same time.
- The OS scheduler determines how much time to allot to each task, and it switches between tasks.
- The program counter, the task’s variables, and the CPU registers (including the status flags).
- 3.33 x 10-10, which is 1.0/3.0 x 10-9.
Q&A
Questions
- What are the x86 processor’s three basic modes of operation?
- Name all eight 32-bit general-purpose registers.
- Name all six segment registers.
- What special purpose does the ECX register serve?
- Besides the stack pointer (ESP), what other register points to variables on the stack?
- Name at least four CPU status flags.
- Which flag is set when the result of an unsigned arithmetic operation is too large to fit into the destination?
- Which flag is set when the result of a signed arithmetic operation is either too large or too small to fit into the destination?
- Which flag is set when an arithmetic or logical operation generates a negative result?
- Which part of the CPU performs floating-point arithmetic?
- How many bits long are the FPU data registers?
- Which Intel processor was the first member of the IA-32 family?
- Which Intel processor first introduced superscalar execution?
- Which Intel processor first used MMX technology?
- Describe the CISC design approach.
- Describe the RISC design approach.
Answers
- Real-address mode, Protected mode, and System Management mode.
- EAX, EBX, ECX, EDX, ESI, EDI, ESP, EBP.
- CS, DS, SS, ES, FS, GS.
- Loop counter.
- EBP.
- Most common: Carry, Sign, Zero, Overflow. Less common: Auxiliary Carry, Parity.
- Carry.
- Overflow.
- Sign.
- Floating-Point Unit.
- 80 bits.
- The Intel 80386.
- The Pentium.
- The Pentium II.
- CISC means complex instruction set: a large collection of instructions, some of which perform sophisticated operations that might be typical of a high-level language.
- The term RISC stands for reduced instruction set: a small set of simple (atomic) instructions that may be combined into more complex operations.
Q&A
Questions
- What is the range of addressable memory in protected mode?
- What is the range of addressable memory in real-address mode?
- The two ways of describing an address in real-address mode are segment-offset and ______________.
- In real-address mode, convert the following hexadecimal segment-offset address to a linear address: 0950:0100.
- In real-address mode, convert the following hexadecimal segment-offset address to a linear address: 0CD1:02E0.
- In MASM’s flat segmentation model, how many bits hold the address of an instruction or variable?
- In protected mode, which register references the descriptor for the stack segment?
- In protected mode, which table contains pointers to memory segments used by a single program?
- In the flat segmentation model, which table contains pointers to at least two segments?
- What is the main advantage to using the paging feature of x86 processors?
- Challenge: Can you think of a reason why MS-DOS was not designed to support protected-mode programming?
- Challenge: In real-address mode, demonstrate two segment-offset addresses that point to the same linear address.
Answers
- 4 GByte (0 to FFFFFFFFh).
- 1 MByte (0 to FFFFFh).
- Linear (absolute).
- 09600h.
- 0CFF0h.
- 32 bits.
- SS register.
- Local descriptor table.
- Global descriptor table.
- The total size of all programs loaded into memory can exceed the amount of physical memory installed in the computer.
- This is an open-ended question, of course. It is a fact that MS-DOS first had to run on the 8086/8088 processors, which only supported Real-address mode. When later processors came out that supported Protected mode, my guess is that Microsoft wanted MS-DOS to continue to run on the older processors. Otherwise, customers with older computers would refuse to upgrade to new versions of MS-DOS.
- The following segment-offset addresses point to the same linear address: 0640:0100 and 0630:0200.
Q&A
Questions
- Describe SRAM and its most common use.
- Describe VRAM.
- List at least two features found in the Intel P965 Express chipset.
- Name four types of RAM mentioned in this chapter.
- Which type of RAM is used for Level 2 cache memory?
- What advantages does a USB device offer over a standard serial or parallel device?
- What is the purpose of the 8259A PIC controller?
- What are the main differences between Wi-Fi and Bluetooth?
Answers
- SRAM is an acronym for Static RAM, used in CPU cache memory.
- VRAM (video ram) holds displayable video data. When CRT monitors are used, VRAM is dual ported, allowing one port to continuously refresh the display while another port writes data to the display.
- Intel Fast Memory Access uses an updated Memory Controller Hub (MCH).
- I/O Controller Hub (Intel ICH8/R/DH) that supports serial ATA devices (disk drives).
- Support for 10 USB ports, 6 PCI express slots, networking, and Intel Quiet System technology.
- High definition audio chip.
- Dynamic RAM, Static RAM, Video RAM, and CMOS RAM.
- Static RAM.
- The computer can query a device connected via USB to find out its name and device type and the type of driver it supports. The computer can also suspend power to individual devices. None of these capabilities is possible with serial and parallel ports.
- The 8259 is the interrupt controller chip, sometimes called PIC, that schedules hardware interrupts and interrupts the CPU.
- Bluetooth is a wireless communication protocol for exchanging small amounts of data over short distances. It is commonly used with mobile devices such as cell phones and PDAs. Wi-Fi devices operate at a greater speed and capacity than Bluetooth. Wi-Fi devices often communicate with each other when in the range of a wireless network.
Q&A
Questions
- Of the four levels of input/output in a computer system, which is the most universal and portable?
- What characteristics distinguish BIOS-level input/output?
- Why are device drivers necessary, given that the BIOS already has code that communicates with the computer’s hardware?
- In the example regarding displaying a string of characters, which level exists between the operating system and the video controller card?
- At which level(s) can an assembly language program manipulate input/output?
- Why do game programs often send their sound output directly to the sound card’s hardware ports?
- Challenge: Is it likely that the BIOS for a computer running MS-Windows would be different from that used by a computer running Linux?
Answers
- The application program level.
- BIOS functions communicate directly with the system hardware. They are independent of the operating system.
- New devices are invented all the time with capabilities that were often not anticipated when the BIOS was written.
- The BIOS level.
- The operating system, BIOS, and hardware levels.
- Game programs often try to take advantage of the latest features in specialized sound cards. It should be noted that MS-DOS game applications were more prone to do this than games running under MS-Windows. In fact, Windows-NT, 2000, and XP all prevent applications from directly accessing system hardware.
- No. The same BIOS would work for both operating systems. Many computer owners install two or three operating systems on the same computer. They would certainly not want to change the system BIOS every time they rebooted the computer!