9781119801962
ISBN :Возрастное ограничение : 0
Дата обновления : 21.12.2020
Microprocessor 4
Philippe Darche
Table of Contents
1В Cover (#u68b151fc-8775-55b8-ad52-a87e36ba0774)
2В Title page (#ub9b50c45-c37e-5813-b8ac-eb6eaf5af8b8)
3В Copyright (#ub0c7c9d1-fd1a-5da7-a270-62bf7e748785)
4В Quotation (#u6813e6be-d2a6-5728-b6d2-d8abc959198b)
5В Preface (#u52413621-c3c9-5e42-94bc-4aaf12fb39a3)
6В Introduction (#ud268c57a-05f4-5843-85de-b2436e4080ba)
7В 1 Coding and Addressing Modes (#uaf622636-9ee7-5939-935a-0596e82428a6)1.1. Encoding and formatting an instruction (#ulink_2731dd8d-3a84-5d7e-8a6c-05a0a59a50c4)1.2. Addressing modes (#ulink_6c634395-5bf8-59ea-8b68-0995f6904c5f)1.3. Conclusion (#ulink_6ed48271-4749-541e-9551-d907d77a2541)
8В 2 Instruction Set and Class (#ud6d44f92-6a6a-555e-9f28-1b50c4c9828d)2.1. Definitions (#ulink_4c61a3e9-b637-5f66-a7b6-bc42a49c56d4)2.2. Transfer instructions (#ulink_1f21853f-6c16-580b-a3db-a6dc477261d0)2.3. Data processing instructions (#ulink_21237ed4-e72b-51e2-97e9-4c97681a046b)2.4. Control transfer instructions (#ulink_d35957a6-4f29-54fb-b944-edf15c5a4ce1)2.5. Environmental instructions (#ulink_02550ae2-0b81-5096-8703-a9fa1703dad5)2.6. Parallelism instructions (#ulink_068bdb74-9a2c-5cb7-9d6a-592af00dfb15)2.7. Extensions to instruction sets (#ulink_18d8ed3b-b0dc-5148-a96c-a105aae560d1)2.8. Various instructions (#ulink_0215e875-16d4-5e31-8386-cdacadef2ee1)2.9. Conclusion (#ulink_2815af15-47cd-5099-bfc6-d394d85d9baa)
9В 3 Additional Concepts (#u7c2b72c8-9f58-5cf8-89c8-95a6d038d61e)3.1. Concepts associated with the instruction set and programming (#ulink_e57738be-b9f1-5272-a39e-dc4814480226)3.2. Concepts linked to execution (#ulink_f8adb369-37af-59dc-b8b2-8b876ab084cf)3.3. Hardware and software compatibilities (#ulink_c7dea119-aecd-55c3-9afe-9a1a111813eb)3.4. Measuring processor performances (#ulink_23fe22ad-33dc-5161-b380-15358d58a77e)3.5. Criteria for choosing (#ulink_77876b1e-3088-5ae0-a739-04b21e175465)3.6. Conclusion (#ulink_e0eb6116-e4c2-5757-8896-440c6164c7e4)
10В 4 Subroutine (#u8b72c7c5-ad8c-5406-a1d9-5cc4987bda0c)4.1. Stack memory (#ulink_f8f751ca-d406-5374-9b60-402fe4caa91f)4.2. Subroutine (#ulink_382ac43b-db67-57c8-87ca-3163064a9bd7)4.3. Conclusion (#ulink_9b9e19b1-28ed-560a-81cb-3f4ffd43fa22)
11В 5 Interrupt Mechanism (#u5f78735e-811e-5ad6-a5c2-c018f246a2e3)5.1. Origin, definition and classification (#ulink_cdecb561-a547-5305-b846-053c8c45a004)5.2. External causes (#ulink_d4142f05-dfbe-55cf-b9b8-cf2fe41a908c)5.3. Nested interrupts (#ulink_ba552226-a96a-55ac-b904-2fb1f8dd765e)5.4. Internal causes (#ulink_20fad1e6-b453-5141-bb9b-f1b4cf76f449)5.5. Debugging (#ulink_d2d868ba-a53c-5f66-ac65-4e701c4829d1)5.6. Priority between internal and external interrupts (#ulink_b574dd5a-aaa7-554c-9d82-1038077bfee6)5.7. Identification of the source and vectorization (#ulink_57e74183-a961-57fb-834d-0b66cd39d0dc)5.8. Nested and queued interrupts (#ulink_2088716d-5544-5a8f-82ad-2fe6bebad249)5.9. Uses (#ulink_33ab54ee-f7a9-5b33-9d94-d35aa6a997b4)5.10. Interrupts and execution modes (#ulink_04fdd834-07a9-52b4-baeb-939bda595857)5.11. Interrupts and advanced architectures (#ulink_6d56b69d-f57f-5589-8526-b8ee81a4e5d2)5.12. Conclusion (#ulink_2f5aca1f-15e3-5b41-87b2-e6abc79a3364)
12В Conclusion of Volume 4 (#u6a7669b0-910c-5c62-bbeb-8b8f7ee187cf)
13В Exercises (#udf3e29e2-174f-5f93-b9be-da5e9cecbab4)
14В Appendix (#u61747d8a-4b22-507a-a748-7f89c5711c46)
15В Acronyms (#ue44230bb-1edf-5cac-84a3-68f16ffa3b5e)
16В References (#udac2250f-d5c5-5b39-a306-17e3c31d3b30)
17В Index (#u5581ac43-b53e-5dc8-b465-2afe990f08e5)
18В End User License Agreement (#u206f449f-0835-4009-884a-e8d22c6798f4)
List of Illustrations
1В Chapter 1Figure 1.1. Breakdown of an instructionFigure 1.2. An example of the structure of an operation codeFigure 1.3. Format of an instruction with two operandsFigure 1.4. An instruction with several operandsFigure 1.5. Three fixed formats for MIPS instructionsFigure 1.6. Typical instruction format from 8086/88Figure 1.7. Variable instruction format Intel IA-32 and Intel 64 (Intel 2016) ar...Figure 1.8. Instruction with an operand fieldFigure 1.9. Execution of an instruction using register addressing from one regis...Figure 1.10. Instruction with direct addressingFigure 1.11. Instruction with an address at page 0Figure 1.12. Execution of an instruction in relative addressingFigure 1.13. Seeking an operand in relative addressingFigure 1.14. Instruction with indirect register addressingFigure 1.15. Instruction with indirect memory addressingFigure 1.16. Execution of an instruction in indexed addressing with displacement...Figure 1.17. Execution of an instruction in indexed addressing with displacement...Figure 1.18. Execution of an instruction in base addressing with displacementFigure 1.19. Indirect indexed addressing or pre-indexingFigure 1.20. Indirect indexed addressing or post-indexingFigure 1.21. Indirect indexed zero-page addressing of MCS6502Figure 1.22. Execution of an instruction in bit addressingFigure 1.23. Window of five samplesFigure 1.24. Circular bufferFigure 1.25. Comparison between linear and circular addressings (from Rao (2001)...Figure 1.26. Flow diagram of the algorithm of an 8-point FFT DIT in base 2
2В Chapter 2Figure 2.1a. Instruction classification in modern MPUsFigure 2.1b. Classifying instructions in modern MPUs (continuation and end)Figure 2.2a. Classification of the main bit manipulation operationsFigure 2.2b. Classification of the main bit manipulation operations (continuatio...Figure 2.3. Logical left and right shiftsFigure 2.4. Shift arithmetic rightFigure 2.5. Left and right rotationsFigure 2.6. Left and right rotations through carryFigure 2.7. Generic examples of multiple shifts and rotationFigure 2.8. Double shift with a 386Figure 2.9. Field extract and field deposit operationsFigure 2.10. Left shuffle operation (interleaving)Figure 2.11. Right shuffle operation (interleaving)Figure 2.12. Reverse instructions from the ArmВ® and ThumbВ® family (n = 64)Figure 2.13. Classifying advanced bit manipulationsFigure 2.14. Field extract and field deposit operations of parallel bitsFigure 2.15. Normal butterfly circuit in n = 8 bits format (a) and associated sw...Figure 2.16. Reverse butterfly circuit in n = 8 bits formatFigure 2.17. Branching instructionsFigure 2.18. Execution paths for a jumpFigure 2.19. Execution steps for a conditional jumpFigure 2.20. Execution paths for a conditional jumpFigure 2.21. Left: result state check; right: direct checkFigure 2.22. Schema for evaluating a calculationFigure 2.23. Condition field from MPU ArmВ® VL86C010Figure 2.24. Instruction bufferFigure 2.25. Hardware management of a loopFigure 2.26. Functional block diagram showing a hardware loop manager (from Tsao...Figure 2.27. Distribution of operations in a vector instruction in a SIMD struct...
3 Chapter 3Figure 3.1. Instruction alignment in 32-bit format (from Darche (2012) modified)Figure 3.2. Levels of programming languageFigure 3.3. Hierarchy of protected execution modes from the x86 family from Inte...Figure 3.4. Operating modes of an MPU from IA-323 architecture from Intel® (Inte...Figure 3.5. Virtualization in an applicationFigure 3.6. Hypervision of virtual machinesFigure 3.7. Differences between container (a) and serverless (b) (from Wong (201...Figure 3.8. Hierarchization of the instruction set from x86 architectureFigure 3.9. Backward compatibility of the instruction set architecture by enrich...Figure 3.10. Types of compatibility of a digital systemFigure 3.11. Evolution of the calculating performance (MIPS) of the first MPUs f...Figure 3.12. Development of MPU systems’ performance over time (SPECint)Figure 3.13. Comparison of uniprocessor performances between supercomputers and ...Figure 3.14. Comparing (single-core) MPU performances with DRAM8 performances (f...Figure 3.15. Comparison of performances between computer classes (from Hennessy ...
4В Chapter 4Figure 4.1. Suggested visual representation of a stack SFigure 4.2. Pseudo-code for stacking (a) and unstacking (b) in the format n = 16...Figure 4.3. Operations of stacking and unstacking for TMS320C31Figure 4.4. Managing an ascending stackFigure 4.5. Classical structure of an execution stack (x86 family from Intel)Figure 4.6. Classic main memory mappingFigure 4.7. Stack register of a mathematical coprocessor in floating point from ...Figure 4.8. Stack in shift-register versionFigure 4.9. Unfolding execution of a program with a call to sub-programFigure 4.10. Subroutine call and return and stack content (x86 architecture)Figure 4.11. Recursive calls and returns from a subroutine (nested calls)Figure 4.12. Recursive calls and returns from a subroutine (nested calls)Figure 4.13. Windowing registers (from Scott (2016))
5В Chapter 5Figure 5.1. Origins of an interrupt request (Darche 2003)Figure 5.2. Ideal forms of external interrupt requestFigure 5.3. Call and return of a non-nested hardware interruptFigure 5.4. Execution flow of a program during a hardware interrupt requestFigure 5.5. Stages in handling an interruptFigure 5.6. Different sources of external interruptsFigure 5.7. Example of management logic for IT requests (Meinadier 1971, 1988)Figure 5.8. Processing chain for several sources of interrupt sharing a single i...Figure 5.9. Simplified decision organigram for considering a hardware interruptFigure 5.10. Execution organigram of a simple MPU: the MC6802 (Motorola 1984)Figure 5.11. Pre-emptive execution in a system of hierarchized interruptsFigure 5.12. Simplified processing logigram of an interrupt from the IT 8259A co...Figure 5.13. Mechanism of nested hardware interruptsFigure 5.14. Call and return of a non-nested software interrupt (example with MC...Figure 5.15. Call and return of nested software interrupts (example with MC6809)Figure 5.16. Call and return of nested software interrupts (example with MC6809)Figure 5.17. Decision process from MC6809 (simplified organigram without HALT an...Figure 5.18. Processing sequence for interrupt requests from 8086 (Intel 1989)Figure 5.19. Step-by-step execution modes with NMI and normal (Intel 1989)Figure 5.20. Simultaneous software exception and maskable external interrupt int...Figure 5.21. Simultaneous NMI, INTR and division by zero in interaction with ste...Figure 5.22. Processing organigram for interrupts from MC6809 (Motorola 1981, 19...Figure 5.23. Vectorization of the interruptFigure 5.24. External vectorizationFigure 5.25. Two typical implantations of different memory areas of an IT systemFigure 5.26. Proposal for processing flow for many IT requests (Intel 1980)Figure 5.27. Organization of different APICs
6В ExercisesFigure E2.28. Generation of address signals corresponding to an execution of a s...
List of Tables
1В Chapter 1Table 1.1. Possible address combinations in family IA-32Table 1.2. Combined MC6809 addressing modes
2В Chapter 2Table 2.1. Logical instructions from DEC System-10Table 2.2. Conditional jump instructions for 8086 for whole numbersTable 2.3. Condition codes from the ArmВ® architecture
3В Chapter 3Table 3.1. Additional cost in the number of cycles and memory clutter for the MC...Table 3.2. Effective address calculation time (8086)Table 3.3. ArmВ® architecture execution modesTable 3.4. List of iCOMP benchmarks
4В Chapter 4Table 4.1. Solutions for managing a stack in main memory
5В Chapter 5Table 5.1. Maskable and non-maskable interruptsTable 5.2. Categories of interrupt to qualify a double fault in 80386 (Intel 198...Table 5.3. Decision criteria for qualifying a double fault in 80386 (Intel 1986)Table 5.4. Priorities of different interrupts from 8086Table 5.5. Table of 256 interrupt vectors from IA-32 architectureTable 5.6. List of exception codes (ExcCode) for MIPS architecture (Kane 1988; K...Table 5.7. Management options in the case of multiple IT processingTable 5.8. Table summarizing interruptsTable 5.9. Interrupt recovery points for the 80286Table 5.10. Recovery point for ITs for the 80286 (real mode)Table 5.11. Recovery point for ITs for the 80286 (protected mode)Table 5.12a. Suggestion for classification criteria according to Hennessy and Pa...Table 5.12b. Suggestion of classification criteria according to Hennessy and Pat...
6В AppendixTable A.1a. Hexadecimal values of machine codesTable A.1b. Hexadecimal values of machine codesTable A.2a. Programming aidTable A.2b. Programming aidTable A.2c. Programming aid
Guide
1В Cover (#u68b151fc-8775-55b8-ad52-a87e36ba0774)
2В Table of Contents (#u0d194d7c-aa38-5973-a463-3b72df6436b3)
3В Title page (#ub9b50c45-c37e-5813-b8ac-eb6eaf5af8b8)
4В Copyright (#ub0c7c9d1-fd1a-5da7-a270-62bf7e748785)
5В Quotation (#u6813e6be-d2a6-5728-b6d2-d8abc959198b)
6В Preface (#u52413621-c3c9-5e42-94bc-4aaf12fb39a3)
7В Introduction (#ud268c57a-05f4-5843-85de-b2436e4080ba)
8В Begin Reading (#uaf622636-9ee7-5939-935a-0596e82428a6)
9В Conclusion of Volume 4 (#u6a7669b0-910c-5c62-bbeb-8b8f7ee187cf)
10В Exercises (#udf3e29e2-174f-5f93-b9be-da5e9cecbab4)
11В Appendix (#u61747d8a-4b22-507a-a748-7f89c5711c46)
12В Acronyms (#ue44230bb-1edf-5cac-84a3-68f16ffa3b5e)
13В References (#udac2250f-d5c5-5b39-a306-17e3c31d3b30)
14В Index (#u5581ac43-b53e-5dc8-b465-2afe990f08e5)
15В End User License Agreement (#u206f449f-0835-4009-884a-e8d22c6798f4)
Pages
1В v (#ulink_56f3807c-25a0-5f1f-ad75-3e6a3c472e80)
2В iii (#ulink_ced10cfd-a0c6-58fc-bdef-cd50beea6a7d)
3В iv (#ulink_5fcdb6e9-5ac0-5757-a11c-d6539b171c42)
4В xi (#ulink_992eb435-b859-5f32-a74e-b2252206ece9)
5В xi (#ulink_4473e09a-acce-5187-b243-6f853a1110ec)
6В xii (#ulink_44f97149-9fa2-5491-ba5f-b8f112f5d7f1)
7В xiii (#ulink_81b9cdd5-af11-59dd-829e-18f8c0771d42)
8В xv (#ulink_8ff8b9e4-0539-5a0d-82f4-104f5f38fff1)
9В 1 (#ulink_6c297e99-cb1e-58c7-a57b-85e50820a814)
10В 2 (#ulink_93d6899e-b2fd-526f-b717-be5d256c07ae)
11В 3 (#ulink_ef8b7d1b-3c6b-5a1f-9ab2-b87b649a5367)
12В 4 (#ulink_0cbdbe65-9883-50b6-90cc-82a2b11943f2)
13В 5 (#ulink_1ddca681-6fbe-5944-a5dc-52de2c331df9)
14В 6 (#ulink_8a9cce25-c472-5f64-a38a-e6e858b6623f)
15В 7 (#ulink_2fefbbc1-20ba-59ca-a842-26fd088d511a)
16В 8 (#ulink_0b52ea54-afcd-551a-95cc-df576b06d393)
17В 9 (#ulink_8ef499a1-59ff-5565-b7d1-5f41835684a0)
18В 10 (#ulink_ae181968-a6d8-567c-974e-52c2928519f2)
Все книги на сайте предоставены для ознакомления и защищены авторским правом