Rapidly Developing Embedded Systems Using Configurable Processors

Total Page:16

File Type:pdf, Size:1020Kb

Rapidly Developing Embedded Systems Using Configurable Processors Class 413 Rapidly Developing Embedded Systems Using Configurable Processors Steven Knapp ([email protected]) Triscend Corporation www.triscend.com (Booth 160) © Copyright 1998-99, Triscend Corporation. All rights reserved. Agenda • What is a Configurable Processor? • Configurable Processors architectures • Building custom peripherals • Hardware/software trade-offs, algorithmic acceleration • Comparing the alternatives • Configurable Processor technical challenges – Communication – Software development environment – Debugging • Summary Terminology Used in this Session • Configurable Processor – Embedded processor core – Programmable logic to build peripherals – Dedicated System Bus – On-chip memory • User-Definable Processor – Parameterized or changeable processor hardware description – Typically synthesizable from VHDL/Verilog – Usually targeted to ASIC or system-on-a-chip – Examples: ARC, Tensilica, etc. Trends Toward the Configurable Processor • Decreasing Time-to-Market – Fast iterations – Fast in-system, real-time debugging – Fast component availability • More Adaptability – During design and debug – In the field or in the application • Higher Performance – Match the architecture to the problem – Fast response to real-time events – Parallel operations • Increased Differentiation • Ever-improving Process Technology Toward a Configurable Processor "System on a Configurable Chip" Processors MCU ASIC Derivative Configurable FLASH Processor EPROM/ MCU Derivatives and Programmable Logic RAM Discrete Solutions MCU Derivative EPROM/ RAM MCU TTL FLASH "Roll-Your- CPLD/ Own" MCU in EPROM EPROM FPGA FPGA PAL Periph- TTL eral Periph- Periph- TTL eral eral Increasing Functionality, Density, and Performance Density, Increasing Functionality, 1980 1990 2000 Year What Is a Configurable Processor? • Industry-standard Programmable I/O Programmable I/O processor Dedicated RAM • Dedicated bus Processor • Programmable Dedicated Programmable Peripherals Logic Logic Bus System Soft User Programmable I/O Programmable – Soft peripherals I/O Programmable Hardware peripherals logic Breakpoint – User-defined functions Programmable I/O – Hardware acceleration • On-Chip Memory Configurable Processors Vendor/ Dedicated Programmable Embedded Bus Family Processor Status Resources Resources Structure 2-channel DMA Triscend Triscend/ 8032 8K-64K bytes RAM 8-bit Data Sampling Coarse-grained, E5 "Turbo" Hardware debug 32-bit Address bus oriented JTAG Triscend ARM In 32-bit Data Triscend Coarse-grained, 7TDMI Development 32-bit Address bus oriented 2-channel DMA Multiple busses Motorola/ 3K bytes RAM Motorola MPA ColdFire Cancelled Unknown CORE+ DRAM controller Fine-grained format Hardware debug 16K RAM National/ Compact- In 8x256 RAM Concurrent NAPA RISC Development Timer Fine-grained 1000 JTAG debugger Plans Gatefield Siemens TriCore Announced Fine-grained Plans Atmel AT40K Atmel ? Announced Coarse-grained None, SIDSA/ Programmable SIDSA 8031 Sampling? Memory- FIPSOC analog Coarse-grained mapped Motorola CORE+ Clock DRAM Controller JTAG Chip System Selects 8Kbyte Bus Interrupt Instruction Controller Cache Controller External 8Kbyte Bus SRAM Interface Shared Pins Debug Module FPGA I/O Motorola M H/W ColdFire A Divide CPU Core C DMA Master Bus Fine- Controller Interface Grained 1Kbyte FPGA Parallel Embedded Array Port RAM Timers Slave Bus DUART Interface External 2 3Kbyte I C Embedded Bus Controller RAM Interface National NAPA ToggleBus Transceiver System Port National Reconfigurable Adaptive CompactRISC Pipeline Logic CPU Controller Processor Bus Interface Pipeline (fine-grain Unit Memory Array FPGA architecture) I/O Configurable External Memory Peripheral Scratchpad Interface Devices Memory Array Triscend E5 Configurable Processor Memory Selector PIO Power Interface Control Unit Selector PIO Configurable PIO System Logic Clock and Selector (CSL) PIO Crystal 8032 Matrix Oscillator PIO "Turbo" Control Micro- controller PIO Power-On Reset CSI Socket Data Bus Address Mappers Byte-wide Bus Address Bus System Arbiter RAM Two- channel DMA Hardware Controller Breakpoint Unit JTAG Interface Configurable System Interconnect (CSI) bus Configurable Processor Applications • Custom Peripheral Set – Practically any digital function – Matched specifically to the application – Derivative on demand • Hardware Acceleration – Algorithms in hardware – Handling odd-size math – Faster real-time response – Multiple operations in parallel – Bit manipulation Custom Peripherals (Hardware/Software Trade-Offs) • Software Solution (µs to ms) – Slow peripherals (serial ports, etc.) – Limited by CPU performance (Scenix, Teragen) – Easy to modify – Cheap, re-use existing silicon • Hardware Solution (ns to µs) – Standard derivative (no differentiation) – CPU + ASIC/FPGA (difficult to modify) – Configurable Processor (easy to modify) – Additional silicon/cost Example: SPI Interface • Find a processor derivative that matches your requirements – It has SPI, but does it have everything else you need? – Availability? Software support? • Implement your peripheral in software (ex. Scenix) • Build your peripheral in an external ASIC or FPGA • Use a SPI soft peripheral in your configurable processor Design Techniques Peripherals in Software Peripherals in Hardware • ‘C’ language • Schematic capture • Assembly • VHDL/Verilog entry • Instruction-set • Digital logic simulator simulator • Soft macros available • Function library Software Hardware Hardware Acceleration Example • Calculate the instantaneous average of four 8-bit values ABCD( + + + ) Z = 4 • Issues – Concurrency (I/O, processing requirements) – Handling overflow (accumulator width) – Performance (processing time) Two Solutions • Processor Solution • Logic Solution Move PortA to Accumulator A Add PortB to Accumulator B Add PortC to Accumulator ÷4 Z Add PortD to Accumulator C Shift Accumulator Right Twice (divide by four) D Move Accumulator to RegZ More instances require More instances require additional time additional logic Comparing the Alternatives Device Development Solution Issues When to Use It Cost Time/Cost Availability, software Processor Quick/ Lowest cost, if your $1 - $15 support, Derivative Low application fits differentiation Acquiring cores, System-on-a- $5 - $50 Long/ Volume, complexity, + development verification, NRE, Chip High performance justify it. cost vendor selection Fast Moderate/ Creating ‘soft’ If it fits and it’s fast $5 - $50 Processor Low peripherals enough, use it! Multi-chip solution, For applications where inter-chip CPU + Moderate/ a configurable $10 - $100 communication, ASIC/FPGA Moderate processor does not yet debugging support, exist. multiple CAE tools Fast time to market, Configurable Moderate/ $8 - $80 New technology complete embedded Processor Moderate system Configurable Processor Technical Challenges • Communication between the processor and programmable logic functions • Maintaining a standard development flow • Debugging a system with both processor and programmable logic Communication between the Processor and Programmable Logic • Distributing the data and address bus to the programmable logic • Decoding/controlling bus transactions • Multi-master bus support • Register intimacy • Debugging support One Solution: CSI Bus Socket (Configurable System Interconnect) • Distributes address and Side-band Signals CSI Socket Interface data to CSL matrix – Full access to data and Data Write 8032 address bus "Turbo" Data Read Microcontroller – Dedicated address Address decoding – Predictable, synchronous timing ?Selectors 2-Channel Bus Clock – Forward compatible with DMA Controller DMA Request/ Acknowledge (CSL) Matrix future configurable Wait-State processors Control Configurable System Logic – Wait-state and Breakpoint Hardware Configurable Interconnect (CSI) Bus System Control breakpoint control Breakpoint Unit – Contention-free bussing Decoding Bus Transactions CSI Selector Style CSI Bus Address A2 A1 A0 An Fast address decoding • Any address range Match0 READ RDSEL Match1 • Access type Code WRITE WRSEL Data BCLK Exported Special Function Registers (SFR) • Three modes Selector Bus Clock Chip Select RdSel DMA Control Register Data Read [7:0] DATA • Up to 200 selectors in a single device Decode delay is constant (less than 5 ns after clock) Connecting the Two Development Worlds Hardware Development Software Development • Design and “soft” • Compiler/assembler module libraries support • Passing register • Function libraries addresses to • Instruction-set compiler/assembler simulator • Vendor place and • System-wide in- route software system debugging • Device programming support support • System-wide in- system debugging support Preserving Existing Tool Flow Header Configurable Processor Tools File MCU Development Tools 1 2 System Program Configuration Development Soft Module Object Source Library File Code 4 3 Library System Test Program and Debug Debug 5 Device Designer’s Programming standard tool flow System on a Chip Flow Configurable Processor MCU Development Tools Development Software 3rd Party EDA Tools Program System Development Configuration Capture or Synthesis Instruction Source Code Simulation Library System Test Netlist and Debug Functional In-System Simulation Debug Device Designer’s Programming standard tool flow Example System: FastChip Software “Soft” Module Library Dedicated Resources “Soft” peripherals dragged into CSL matrix Resources Used Indicators Real-Time, In-System Debugging • Difficult in most ASIC or system-on-a-chip designs – Must rely on simulation before completing
Recommended publications
  • Escuela Politécnica Superior De Jaén
    UNIVERSIDAD DE JAÉN ESCUELA POLITÉCNICA SUPERIOR DE JAÉN Trabajo Fin de Grado DATALOGGER CON ENLACE BLUETOOTH A SISTEMA ANDROID Alumno: Juan Miguel Bejarano Bueno Tutor: Prof. D. Luis Miguel Nieto Nieto Dpto: Ingeniería Electrónica y Automática Escuela Politécnica Superior Jaén de Area: Tecnología Electrónica Septiembre, 2015 Juan Miguel Bejarano Bueno Datalogger con enlace Bluetooth a aplicación Android. Universidad de Jaén Escuela Politécnica Superior de Jaén Departamento de Electrónica y Automática Don LUIS MIGUEL NIETO NIETO, tutor del Trabajo Fin de Grado titulado: DATALOGGER CON ENLACE BLUETOOTH A ANDROID, que presenta JUAN MIGUEL BEJARANO BUENO, autoriza su presentación para defensa y evaluación en la Escuela Politécnica Superior de Jaén. Jaén, SEPTIEMBRE de 2015 El alumno: El tutor: JUAN MIGUEL BEJARANO BUENO LUIS MIGUEL NIETO NIETO 1 Escuela Politécnica Superior de Jaén Juan Miguel Bejarano Bueno Datalogger con enlace Bluetooth a aplicación Android. RESUMEN Este Trabajo de Fin de Grado consiste en el desarrollo de dos sistemas. En primer lugar, se dispondrá de un sistema de registro de datos por eventos o datalogger. El sistema está basado en un microcontrolador Microchip y dispondrá de una interfaz de comunicaciones Bluetooth. Este dispositivo será capaz de realizar mediciones con una duración mínima configurable. En segundo lugar y de manera simultánea, se ha diseñado una aplicación Android capaz de gestionar la comunicación con el dispositivo de una manera gráfica. El sistema se ha diseñado siempre teniendo en cuenta el ahorro económico, dispondrá de una alimentación autónoma y el mantenimiento será prácticamente nulo. Se pretende así obtener un datalogger funcional, económico e intuitivo para el manejo del mismo por cualquier tipo de usuario.
    [Show full text]
  • Downloaded to the Test Chip Verified
    - -------------------------------------------------------------------------------- - -------------------------------------------------------------------------------- SECURITIES AND EXCHANGE COMMISSION WASHINGTON, D.C. 20549 ------------------------ FORM 10-K ANNUAL REPORT PURSUANT TO SECTION 13 OR 15(D) OF THE SECURITIES EXCHANGE ACT OF 1934 FOR THE FISCAL YEAR ENDED DECEMBER 31, 1997 COMMISSION FILE NUMBER 0-23006 ------------------------ DSP GROUP, INC. (Exact name of registrant as specified in its charter) DELAWARE 94-2683643 (State or other jurisdiction of (I.R.S. Employer Identification No.) incorporation and organization) 3120 SCOTT BOULEVARD, SANTA CLARA, CA 95054 (Address of principal executive offices, including zip code) (408) 986-4300 (Registrant's telephone number) Securities registered pursuant to Section 12(b) of the Act: NONE Securities registered pursuant to Section 12(g) of the Act: COMMON STOCK, $.001 PER SHARE (Title of class) Indicate by check mark whether the Registrant: (1) has filed all reports required to be filed by Section 13 or 15(d) of the Securities Exchange Act of 1934 during the preceding 12 months (or for such shorter period that the Registrant was required to file such reports), and (2) has been subject to such filing requirements for the past 90 days. Yes /X/ No / / Indicate by check mark if disclosure of delinquent filers pursuant to Item 405 of Regulation S-K is not contained herein, and will not be contained, to the best of Registrant's knowledge, in definitive proxy or information statements incorporated by reference in Part III of this Form 10-K or any amendment to this Form 10-K. [ ] The aggregate market value of the voting stock held by non-affiliates of the Registrant, based on the closing price of the Common Stock on March 2, 1998, as reported on the Nasdaq National Market, was approximately $231,228,988.
    [Show full text]
  • Nexus Based Multi-Core Debug
    Nexus Based Multi-Core Debug Dr. Neal Stollon MIPS Technologies / First Silicon Solutions [email protected] Rich Collins Freescale Semiconductor [email protected] Impact of Debug Strategy Copyright © 2003 Novas Software, Inc. Yes! but. half of what??? Copyright © 2003 Novas Software, Inc. Prototype silicon to production Debug cost can get even bigger for new sets release is 6-9 months. of debug problems for multi-core designs Much of cost of debug driven by architecture limitations and debug learning curve But what if SoC internals are more visible, accessible? Debug implementations become standardized ? SoC Debug Evolution ICE BDM JTAG Embedded Multi-Core Embedded (Scan, BIST Processor / System Debug Run Control) Logic Trace 50K Platform SoC (Multi-Core) 20K SoC Debug- (RISC+IP Nexus +RAM) Difficulty 8K ASICS System FPGA Domain (gates/pins) (PLD+RISC IP) Embedded 2.5K Systems Single FPGAs 1K processor 1980s 1990s 2000s The New Frontier Embedded Debug Complexity keeps increasing • Gates increase geometrically - Pins increase linearly • Significant debug difficulties for leading architectures • More complex debug needs better Instrumentation What is Nexus? • Nexus is a standard for industry level instrumentation with real time interface for embedded system debug • “Nexus” is synonymous with the IEEE-ISTO 5001 std. • Supported by over 20 Member Companies • Specification freely available at http://www.nexus5001.org • Nexus is a toolbox of defined ways for processor debug: • Defines JTAG and Auxiliary bus debug interfaces • Defines simple
    [Show full text]
  • Gnu Assembler
    Using as The gnu Assembler (Sourcery G++ Lite 2010q1-188) Version 2.19.51 The Free Software Foundation Inc. thanks The Nice Computer Company of Australia for loaning Dean Elsner to write the first (Vax) version of as for Project gnu. The proprietors, management and staff of TNCCA thank FSF for distracting the boss while they gotsome work done. Dean Elsner, Jay Fenlason & friends Using as Edited by Cygnus Support Copyright c 1991, 92, 93, 94, 95, 96, 97, 98, 99, 2000, 2001, 2002, 2006, 2007, 2008, 2009 Free Software Foundation, Inc. Permission is granted to copy, distribute and/or modify this document under the terms of the GNU Free Documentation License, Version 1.3 or any later version published by the Free Software Foundation; with no Invariant Sections, with no Front-Cover Texts, and with no Back-Cover Texts. A copy of the license is included in the section entitled \GNU Free Documentation License". i Table of Contents 1 Overview :::::::::::::::::::::::::::::::::::::::: 1 1.1 Structure of this Manual :::::::::::::::::::::::::::::::::::::: 14 1.2 The GNU Assembler :::::::::::::::::::::::::::::::::::::::::: 15 1.3 Object File Formats::::::::::::::::::::::::::::::::::::::::::: 15 1.4 Command Line ::::::::::::::::::::::::::::::::::::::::::::::: 15 1.5 Input Files :::::::::::::::::::::::::::::::::::::::::::::::::::: 16 1.6 Output (Object) File:::::::::::::::::::::::::::::::::::::::::: 16 1.7 Error and Warning Messages :::::::::::::::::::::::::::::::::: 16 2 Command-Line Options::::::::::::::::::::::: 19 2.1 Enable Listings: `-a[cdghlns]'
    [Show full text]
  • Gcc Installation Instruction Release 12.0.1 (Experimental 20210414)
    Gcc Installation Instruction Release 12.0.1 (experimental 20210414) GCC Developer Community Aug 27, 2021 CONTENTS 1 Copyright 3 2 Installing GCC 5 3 Prerequisites 7 3.1 Tools/packages necessary for building GCC ............................... 7 3.2 Tools/packages necessary for modifying GCC .............................. 9 4 Downloading GCC 11 5 Configuration 13 5.1 Distributor options ............................................ 14 5.2 Host, Build and Target specification ................................... 14 5.3 Options specification ........................................... 15 5.4 Cross-Compiler-Specific Options ..................................... 33 5.5 Objective-C-Specific Options ....................................... 35 5.6 D-Specific Options ............................................ 36 6 Building 37 6.1 Building a native compiler ........................................ 37 6.2 Building a cross compiler ......................................... 39 6.3 Building in parallel ............................................ 40 6.4 Building the Ada compiler ........................................ 40 6.5 Building with profile feedback ...................................... 41 7 Testing 43 7.1 How can you run the testsuite on selected tests? ............................. 43 7.2 Passing options and running multiple testsuites .............................. 44 7.3 How to interpret test results ........................................ 45 7.4 Submitting test results .......................................... 45 8 Final installation 47
    [Show full text]
  • Pwny Documentation Release 0.9.0
    pwny Documentation Release 0.9.0 Author Jan 29, 2018 Contents 1 pwny package 3 2 pwnypack package 5 2.1 asm – (Dis)assembler..........................................5 2.2 bytecode – Python bytecode manipulation..............................7 2.3 codec – Data transformation...................................... 11 2.4 elf – ELF file parsing.......................................... 16 2.5 flow – Communication......................................... 36 2.6 fmtstring – Format strings...................................... 41 2.7 marshal – Python marshal loader................................... 42 2.8 oracle – Padding oracle attacks.................................... 43 2.9 packing – Data (un)packing...................................... 44 2.10 php – PHP related functions....................................... 46 2.11 pickle – Pickle tools.......................................... 47 2.12 py_internals – Python internals.................................. 49 2.13 rop – ROP gadgets........................................... 50 2.14 shellcode – Shellcode generator................................... 50 2.15 target – Target definition....................................... 79 2.16 util – Utility functions......................................... 80 3 Indices and tables 83 Python Module Index 85 i ii pwny Documentation, Release 0.9.0 pwnypack is the official CTF toolkit of Certified Edible Dinosaurs. It aims to provide a set of command line utilities and a python library that are useful when playing hacking CTFs. The core functionality of pwnypack
    [Show full text]
  • Architectural Trade-Offs in Dynamically Reconfigurable Processors
    Research Collection Doctoral Thesis Architectural trade-offs in dynamically reconfigurable processors Author(s): Enzler, Rolf Publication Date: 2004 Permanent Link: https://doi.org/10.3929/ethz-a-004717340 Rights / License: In Copyright - Non-Commercial Use Permitted This page was generated automatically upon download from the ETH Zurich Research Collection. For more information please consult the Terms of use. ETH Library Diss. ETH No. Architectural Trade-offs in Dynamically Reconfigurable Processors A dissertation submitted to the Swiss Federal Institute of Technology Zurich for the degree of Doctor of Technical Sciences presented by Rolf Enzler Dipl. El.-Ing. ETH born September citizen of Walchwil ZG accepted on the recommendation of Prof. Dr. Gerhard Tr¨oster,examiner PD Dr. Marco Platzner, co-examiner To Susana iv Acknowledgments I am grateful to my advisor, Prof. Dr. Gerhard Tr¨oster, for his support and for providing me with extraordinary research facilities. Special thanks belong to Christian Plessl and Dr. Marco Platzner for the uncountable hours of fruitful discussions and joint work within the research project ZIPPY. Further, I want to thank Marco for co- examining this thesis and for providing his valuable input. I would like to thank Dr. Hubert Kaeslin and Francisco Camarero of the Microelectronics Design Center at ETH Zurich for their technological advice and the support with the Synopsys synthesis tools. I am very much obliged to the members of the Electronics Laboratory and the Computer Engineering and Networks Laboratory – way too many to name all of them personally – for the pleasant and inspiring research atmosphere. Special thanks go to Didier Cottet who always had an open ear for my diverse requests.
    [Show full text]
  • The CHI Family of Cryptographic Hash Algorithms
    Submission to the SHA-3 Competition: The CHI Family of Cryptographic Hash Algorithms Design Team: Cryptographic Hash Initiative, Qualcomm International Lead Designers: Phil Hawkes, Cameron McDonald [email protected], [email protected] Level 3, 230 Victoria Rd, Gladesville, NSW 2111, Australia October 30, 2008 Abstract This document specifies the CHI family of cryptographic hash algorithms for the SHA-3 hash function competition being sponsored by NIST. The CHI family improves on the SHA-2 family by utilizing a stronger bit-wise non-linear function and ensuring better diffusion. This reduces the number of steps required to make the hash function secure and reduces the number of addition operations required. The addition operations are the largest and most power-hungry operations of the SHA-2 family, so the CHI family offers significant reduction in both energy usage and (in the case of hardware implementations) speed /area metrics. The CHI family targets 64-bit architecture, but is efficiently implemented on smaller architectures. 1 1 Introduction This document introduces four cryptographic hash algorithms collectively known as the CHI al- gorithms. The algorithms are denoted CHI-224, CHI-256, CHI-384 and CHI-512 according to the length of the output hash. The algorithms for CHI-224 and CHI-384 are almost identical to CHI- 256 and CHI-512 respectively, differing only in the values of some constants. The basic parameters of the CHI algorithms are shown in Table 1. Features of the CHI algorithms Regarding padding and parsing messages into message blocks for submitting to the compression function, the CHI algorithm processing is identical to FIPS 180-2 [56].
    [Show full text]
  • Microcontrollers and Modern Control Methods
    2nd WSEAS Int. Conf on COMPUTER ENGINEERING and APPLICATIONS (CEA'08) Acapulco, Mexico, January 25-27, 2008 Microcontrollers and Modern Control Methods VLADIMÍR VAŠEK, PETR DOSTÁLEK, JAN DOLINAY, DAGMAR JANÁČOVÁ, KAREL KOLOMAZNÍK Department of Automatic Control Faculty of Applied Informatics, Tomas Bata University in Zlin Mostní 5139, 760 01 Zlín CZECH REPUBLIC [email protected], http://web.fai.utb.cz Abstract: - The aim of this paper is to present overview of the microcontrollers which are usable for the controllers based on the modern control algorithms. In this paper are described necessities of the self tuning controllers. In our applications, we are focused to the microcontrollers Motorola and National Semiconductor that are commonly used for process control. Microcontrollers were divided into two categories: 8-bit and 16-bit. In the part of the work dedicated to 8-bit microcontrollers, the properties of M68HC08 (Motorola) and COP8 (National Semiconductor) are described. The part, which deals with 16-bit microcontrollers, contains description of M68HC16 (Motorola) and CR16 (National Semiconductor). Finally has been evaluated CPU performance of selected microcontrollers in clock cycles needed for factorial computation. Key-Words: - Microcontroller, CPU performance, 68HC08, 68HC12, COP8, CR16, adaptive - self tuning control. 1 Introduction microcontrollers is their great flexibility in many Microcontrollers today assert in all regions of human applications. This universality is secured by possibility activities – beginning with applications in consumer to program inner or outer program memory according electronics to complicated decentralized control to requirements of given application. Software systems, where they form particular structural equipment for 8-bit microcomputers is in most cases members of the whole system.
    [Show full text]
  • Installing GCC
    Installing GCC For gcc version 4.7.3 (GNU Tools for ARM Embedded Processors) Copyright c 1988, 1989, 1992, 1993, 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002, 2003, 2004, 2005, 2006, 2007, 2008, 2009, 2010 Free Software Foundation, Inc. Permission is granted to copy, distribute and/or modify this document under the terms of the GNU Free Documentation License, Version 1.3 or any later version published by the Free Software Foundation; with no Invariant Sections, the Front-Cover texts being (a) (see below), and with the Back-Cover Texts being (b) (see below). A copy of the license is included in the section entitled \GNU Free Documentation License". (a) The FSF's Front-Cover Text is: A GNU Manual (b) The FSF's Back-Cover Text is: You have freedom to copy and modify this GNU Manual, like GNU software. Copies published by the Free Software Foundation raise funds for GNU development. i Table of Contents 1 Installing GCC:::::::::::::::::::::::::::::::::: 1 2 Prerequisites :::::::::::::::::::::::::::::::::::: 3 3 Downloading GCC:::::::::::::::::::::::::::::: 9 4 Installing GCC: Configuration ::::::::::::::: 11 5 Building :::::::::::::::::::::::::::::::::::::::: 37 5.1 Building a native compiler :::::::::::::::::::::::::::::::::::: 37 5.2 Building a cross compiler:::::::::::::::::::::::::::::::::::::: 40 5.3 Building in parallel:::::::::::::::::::::::::::::::::::::::::::: 41 5.4 Building the Ada compiler :::::::::::::::::::::::::::::::::::: 41 5.5 Building with profile feedback ::::::::::::::::::::::::::::::::: 41 6 Installing GCC: Testing:::::::::::::::::::::::
    [Show full text]
  • RISC-V • 1980S: RISC • Case for Open Isas • 1990S: VLIW • Tour of RISC-V ISA • 2000S: NUMA Vs
    Past and Future Trends in Architecture and Hardware David Paerson [email protected] SOSP History Day October 3, 2015 1 Outline Part I - Past Part II – Future 50 years of Computer HW Technology Architecture History: • End of Moore’s Law • 1960s: • Flash vs. Disks Computer Families / • Fast DRAM Microprogramming • Crosspoint NVRAM • 1970s: CISC Open ISA & RISC-V • 1980s: RISC • Case for Open ISAs • 1990s: VLIW • Tour of RISC-V ISA • 2000s: NUMA vs. • RISC-V Software Stack Clusters • RISC-V Chips 2 IBM Compatibility Problem in early 1960s By early 1960’s, IBM had 4 incompatible lines of computers! 701 → 7094 650 → 7074 702 → 7080 1401 → 7010 Each system had its own • Instruction set • I/O system and Secondary Storage: magnetic tapes, drums and disks • Assemblers, compilers, libraries,... • Market niche: business, scientific, real time, ... ⇒ IBM System/360 – one ISA to rule them all 3 IBM 360: A Computer Family Model 30 . Model 70 Storage 8K - 64 KB 256K - 512 KB Datapath 8-bit 64-bit Circuit Delay 30 nsec/level 5 nsec/level Registers Main Store Transistor Registers The IBM 360 is why bytes are 8-bits long today! IBM 360 instrucon set architecture (ISA) completely hid the underlying technological differences between various models. Milestone: The first true ISA designed as portable hardware- soKware interface! With minor modifica>ons it s>ll survives today! 4 IBM System/360 Reference Card (“Green card”) OR (cl OC m' FLOA~NEP~INTFEATURE 'INSTRUCTIONS' Sy~t8m/~~ PaGk PAW F2 I%- Dinn4b#) RDD 86 AddN~allted,ExtenddJc.x) . , AXR 36 , RR
    [Show full text]
  • Great Microprocessors of the Past and Present Editor's Note: John's Remote Copy May Be More Up-To-Date
    Great Microprocessors of the Past and Present Editor's Note: John's Remote Copy may be more up-to-date. Great Microprocessors of the Past and Present (V 11.7.0) last major update: February 2000 last minor update: February 2000 Feel free to send me comments at (new email address): [email protected] Laugh at my own amateur attempt at designing a processor architecture at: http://www.cs.uregina.ca/~bayko/design/design.html Introduction: What's a "Great CPU"? This list is not intended to be an exhaustive compilation of microprocessors, but rather a description of designs that are either unique (such as the RCA 1802, Acorn ARM, or INMOS Transputer), or representative designs typical of the period (such as the 6502 or 8080, 68000, and R2000). Not necessarily the first of their kind, or the best. A microprocessor generally means a CPU on a single silicon chip, but exceptions have been made (and are documented) when the CPU includes particularly interesting design ideas, and is generally the result of the microprocessor design philosophy. However, towards the more modern designs, design from other fields overlap, and this criterion becomes rather fuzzy. In addition, parts that used to be separate (FPU, MMU) are now usually considered part of the CPU design. Another note on terminology - because of the muddling of the term "RISC" by marketroids, I've avoided using those terms here to refer to architectures. And anyway, there are in fact four architecture families, not two. So I use "memory-data" and "load-store" to refer to CISC and RISC architectures.
    [Show full text]