#### Smalltalk-80 : hardware and software

#### **Bernard Pottier**

<sup>1</sup>LESTER - Architecture & Système CNRS FRE 2734 - Université de Bretagne Occidentale pottier@univ-brest.fr

#### ESUG'05 16/8/05



3

◆□ ▶ ◆□ ▶ ◆ □ ▶ ◆ □ ▶ ・

### Outline

- Introduction
- 2 The electronic industry roadmap
- 3 Synthesis from Smalltalk
- 4 Virtual machines of the past
- **6** Example of a mixed-grain reconfigurable data path
- 6 Conclusion



イロト 不得 トイヨト イヨト 三日

 Introduction
 Outline
 The electronic industry roadmap
 Synthesis from Smalltalk
 Virtual machines of the past
 Example of a mixe

 ••••••
 •••••
 •••••
 •••••
 ••••
 ••••
 ••••

# Group presentation

Status:

- Architectures and Systems (AS) is a research group at Université de Bretagne Occidentale, Brest, France.
- AS participates in the LESTER, a laboratory distributed on two universities at Lorient and Brest,
- LESTER received a recognition from french CNRS for its research activities on software methods for integrated systems: synthesis, power consumption, reconfigurable devices, algorithms for communications.

AS is a small group (at most 10 persons) working in computer science, sometime in relation with people working in electronics (academy and industry).

・ コ ト ・ 雪 ト ・ 雪 ト ・ 日 ト

#### Previous projects

Summary of my researches at UBO:

- 80-86 : virtual machines and support for programming languages (Lisp, Smalltalk, ...)
- 87-89 : applications of concurrent architectures (Transputers, data-flow languages, mapping signal processing applications),
- 90-95 : parallel and reconfigurable architectures, dedicated language designs and synthesis techniques. Design of a parallel reconfigurable machine (ArMen),
- 96-2005 : tools for reconfigurable circuit ans systems (Madeo workbench).

In this last period, most of the work was achieved using Smalltalk-80 (Visualworks).



・ロト ・ 同ト ・ ヨト ・ ヨト ・ ヨ

# Motivations : software problems in the silicon industry

#### EETimes Aout 2005 :

#### EE Times:

Hardware, software design on collision course, panel finds

Dylan McGrath

Page 1 of 2

EE Times (08/04/2005 1:55 PM EDT) design are on a collision course,

SAN FRANCISCO — Hardware and software design are on a collision course, and time-to-market pressures and other factors are forcing the electronics industry to search for the "holy grail" of concurrent hardware-software codesign, concluded a panel of executives from across the EDA spectrum at the

Kalekos said the mistake mainstream IDA vendors are making is that that they no longer provide competitive differentiation. Time-to-market, he said, is no longer a competitive advantage, but a requirement to secure business. To be successful, he said, a tool vendor must provide value that cannot be obtained elsewhere, something he believes can be done with FSL.

Kalekos said the market for ESL tools will eventually be worth more than S1 billion annually — perhaps significantly more. In the future, he said, ESL and intellectual property would be the biggest growth areas for EDA.

Kalekos also warned that a potential crisis in software development is coming more rapidly than most people realize, with the advent of multiprocessor systems. 'People don't know how to write architectures for embedded software development on multiprocessor systems,' he said. Pressure on integrated application developments:

- Quick developments are mandatory,
- Part of the software is increasing,
- The frontier between software and hardware is less and less clear,
- Tools are inaccurate,
- Multiprocessing is a key point.

・ロット ( 雪 ) ・ ヨ )



Introduction Outline The electronic industry roadmap Synthesis from Smalltalk Virtual machines of the past Example of a mixed occorrection of the sector of

#### Motivations to use Smalltalk at low level

- Smalltalk-80 has powerful development environments and is ideal to build generic solutions,
- It is easy to extend the language because it is not bound to a small number of types (int, char..).
- An interest is appearing for evolutions on Smalltalk allowing to take benefits of the emerging technologies.



・ロット ( 雪 ) ・ ヨ )

Introduction Outline The electronic industry roadmap Synthesis from Smalltalk Virtual machines of the past Example of a mixe

#### Frustrations and dreams with current virtual machines



Long term desirable evolutions:

- Numeric processing with new hardware primitives, (arbitrary floating and fixed points, Galois fields, etc ...),
- Automatic synthesis of these circuits from behavioural code,
- Concurrent execution for Collections (pipelined or data parallel), and Stream computations,



### Outline

#### Introduction

- 2 The electronic industry roadmap
- 3 Synthesis from Smalltalk
- 4 Virtual machines of the past
- **5** Example of a mixed-grain reconfigurable data path
- 6 Conclusion



э

ヘロト 人間 トイヨト イヨト

| Introduction | Outline | The electronic industry roadmap | Synthesis from Smalltalk | Virtual machines of the past | Example of a mixed |
|--------------|---------|---------------------------------|--------------------------|------------------------------|--------------------|
| 00000        |         | 0000000000                      | 000000000000000          | 0                            |                    |

#### THE ELECTRONIC INDUSTRY ROADMAP



# Technology progress: a scientific, economic and social fact

#### Exponential increase in transistors,



#### 40 YEARS OF EXPONENTIAL PROGRESS

IT IS IMPOSSIBLE TO OVERSTATE THE IMPACT OF 40 YEARS OF CONTINUOUS PROGRESS IN SEMICONDUCTOR TECHNOLOGY. AS THE COMPLEXITY OF INTEGRATED CIRCUITS HAS CONTINUED TO DOUBLE EVERY COUPLE OF YEARS—THIS ABILITY TO CRAM AN EVER-INCREASING NUMBER OF COMPONENTS ONTO A CHIP AT CONSTANTLY DECLINING COST HAS REVOLUTIONIZED VIRTUALLY EVERY ASPECT OF HUMAN ENDEAVOR.

#### (from the SIA Report 2005)

Effect of Moore's law,  $\times 10000$  transistors increase in 25 years.

1982: logic = 120K, ram = 64K

2005: logic = 1.7G , ram = 1G

Increase expected to continue until 2020.

In the meantime, nanotechnologies are preparing cheaper, smaller, more flexible integration solutions with a variety of applications.



Introduction Outline

The electronic industry roadmap

Synthesis from Smalltalk Vir

Virtual machines of the past Example of a mixed

#### Industry roadmaps

The semiconductor industry prepare roadmaps, listing potential difficulties, preparing objectives, research, and use of the technologies. This is the underlying activity behind Moore's law.

A number of reports are available on this roadmap:

- http://www.sia-online.org/
- http://public.itrs.net

The future is :

- massive parallelism
- software synthesis, or hard/soft synthesis

・ロット ( 雪 ) ・ ヨ )

..rather than hardware developments.



Introduction Outline The electronic industry roadmap Synthesis from Smalltalk Virtual machines of the past Example of a mixe

# Known Challenges through 2009

| Silicon complexity : devices and interconnects          | (SP) Technology and library<br>characterization<br>(SP) eDRAM, eFPGA                             |
|---------------------------------------------------------|--------------------------------------------------------------------------------------------------|
| System complexity : number of states, design, diversity | (SP) verifying systems with<br>exploding number of states<br>(SP) scalable algorithms            |
| Design Productivity                                     | <ul><li>(S) Integrating 3rd party components</li><li>(SP) Design tool interoperability</li></ul> |
| Time-to-market                                          | (S) Support for platform<br>based design<br>(SP) Exploiting Parallel<br>Processing               |

Introduction Outline The electronic industry roadmap 

Synthesis from Smalltalk Virtual machines of the past Example of a mixe

### Variety of hardwares

As Low Scale Integration (LSI) has disappeared, VLSI is also on the edge to be replaced by new technologies. Currently, the hardware available for application developments is:

- microprocessors: VLSI, does not scale.
- **2**  $\uparrow$  system on chips: VLSI-ULSI, scale, but is specific.
- 3 ↑ reconfigurable circuits: VLSI-ULSI, scale, general purpose.



・ロット 御マット ほう・

Introduction Outline The electronic industry roadmap Synthesis from Smalltalk Virtual machines of the past Example of a mixe

#### Processors evolve toward multi-processing

General purpose processors have internal instruction level parallelism and evolve toward task level parallelism:

- time-shared multi-tasking: several tasks are sequenced following time slices or race conditions on one processor,
- simultaneaous multi-threading (SMT): several tasks run concurrently sharing processor resources,
- Implemented in the same circuit and act in real concurrency.
- AMD and Intel are currently selling multi-core processors.



・ロット ( 雪 ) ・ ヨ )



Introduction Outline The electronic industry roadmap Synthesis from Smalltalk Virtual machines of the past Example of a mixed opposite opp

#### System-on-chips (SoC) are for the mass market

SoC are integrated systems optimized for an application.

- Personal assistants, mobile phones, cameras, set-top-box are implemented at low cost due to the capability of the industry to produce applications on a small number of circuits.
- 2 These circuits assemble specific components 'IPs', general purpose processors.



Introduction Outline The electronic industry roadmap 00000000000

Synthesis from Smalltalk

Virtual machines of the past Example of a mixe

# Field Programmable Gate Arrays

FPGAs allow to build a dedicated system by characterizing an off-the-shelf component.

- They are the shortest path from a need to an application because they only need 'software'.
- 2 They propose random logic integration, set of operators, multi-processors and high speed communications.

3 Xilinx FPGAs: maximum capacities. Configuration = 50MBits

|        | logic   | dsp                              | system          |
|--------|---------|----------------------------------|-----------------|
| logic  | 200K    | 55K                              | 150K            |
| cells  |         |                                  |                 |
| RAM    | 6K      | 6K                               | 10K             |
| (bits) |         |                                  |                 |
| oper-  | 100     | 500                              | 200             |
| ators  |         |                                  |                 |
| CPUs   | 0       | 0                                | 2 🚺             |
| serial | 0       | 0                                | 24              |
| ports  |         |                                  | L.E.S.T.E.      |
|        | < <>>>< | <ul> <li>&lt; Ξ &gt; </li> </ul> | ≣। <u>≣</u> १९९ |

Introduction Outline The electronic industry roadmap Synthesis from Smalltalk Virtual machines of the past Example of a mixe

#### Gigascale will not have a tiny impact

The semi-conductor industry says:

- Moore's law will continue its curve.
- 2 We are at a turn with a scale change in the architectures. Parallelism is a key point with several variants.



・ロット 御マット ほう・

Introduction Outline The electronic industry roadmap

#### Gigascale will not have a tiny impact

The semi-conductor industry says:

- 1 Moore's law will continue its curve.
- We are at a turn with a scale change in the architectures. Parallelism is a key point with several variants.

We would like to complement referencing two scientists.



・ロット ( 雪 ) ・ ヨ )

Introduction Outline

The electronic industry roadmap

Synthesis from Smalltalk

lk Virtual machines of the past Example of a mixed

#### From the academy: a Call to Arms

In 2002, David Patterson has published a position on present and future of computers. To summarize:

- importance of computer for science and technologies,
- obsession for performances, and ridiculous reliability for users,
- serious problems with scaling: GB of memory, hundred of processors are the future.

The 'new manifesto' for research in computer science is:

- more attention to human factors: interest of applications, security, privacy,
- start fresh researches on new architectures, new software systems, new programming systems, new applications.

・ロット ( 雪 ) ・ ヨ )

B

Sac

Introduction Outline The electronic industry roadmap Synthesis from Smalltalk Virtual machines of the past Example of a mixe

## Computers is a pop culture

Another interesting opinion is given in the Alan Kay interview to ACM Queue (Dec, 2004)

- computer systems reflect the understanding of the people (like TV),
- comparison of the software building with pyramides brick tiling, build by brute force,
- retrogression of systems due to personal computing,

On architecture support:

- Recall the B5000, and pseudo-codes approach as used by Wirth, and refused by the industry.
- Critics on current architecture efficiency.
- Insists on the interest of late binding.

"Just as an aside, to give you an interesting benchmark on roughly the same system, roughly optimized the same way, a benchmark from 1979 at Xerox PARC runs only 50 times faster today."



#### What to do?

- we must take into account the hypothesis of large amount of resources given from several sources,
- most of these resources will be used for intensive computations: signal processing, multimedia, security, scientific,
- it makes sense to define the whole translation and execution chain with transparency, using the same tools,
- it is mandatory to pay attention to these topics, this does not forbid to improve the quality of the language and its support for general purpose programming.

To be demonstrated.



・ロト ・ 同ト ・ ヨト ・ ヨト ・ ヨ

| Introduction | Outline | The electronic industry roadmap | Synthesis from Smalltalk | Virtual machines of the past | Example of a mixed |
|--------------|---------|---------------------------------|--------------------------|------------------------------|--------------------|
| 00000        |         | 0000000000                      | 000000000000000          | 0                            |                    |

#### SYNTHESIS FROM SMALLTALK



# Objectives

Madeo project was started a long term effort withe hope to *survive* in the evolving domain of reconfigurable architectures (FPGAs).

It came after ArMen that developped a parallel machine and ad-hoc compilers quickly lost due to the change in tools and architectures.

Several directions have been explored:

- technology modeling,
- portable physical tools,
- logic synthesis,

- structural design,
- · system synthesis.

・ロット 御マット ほう・



# Architecture modeling

Reconfigurable architectures are charaterized at run time by connecting signal lines or buses, by programming switches, logic cells, operators, by filling memories.

These circuits are replication of patterns that can be organized hierarchically.

This is very similar to the organization of nodes in a program tree, or window components. The common interface allows to:

. . .

- compute costs,
- route signals or buses

 draw components in an editor window.

・ロト ・ 一 マ ト ・ 日 ト ・



・ロト ・ 一 マ ト ・ 日 ト ・

# Physical synthesis

#### PLacing and routing.

Given an architecture, and given an abstract computation graph, this task consists of resource allocation, then route constitution, to obtain an implementation.

- Resource allocation is a selection of architecture components able to implement a primitive function node from the graph,
- Graph edges are implemented by path of routed components.



Introduction Outline The electronic industry roadmap Synthesis from Smalltalk Virtual machines of the past Example of a mixe

### Physical synthesis

Floor-planning,

Graphes are hierarchies of graphes. For each non-primitive node, an opertion of floor-planning is achieved on the underlying components to find the best arrangement minimizing the number of resources.



Floor planning of a level in a hierachical graph,



-



Directed acyclic graph,



# Equivalent graph placed and routed on an architecture.

イロト イポト イヨト イヨト



Introduction Outline The electronic industry roadmap Synthesis from Smalltalk October Control of the past Example of a mixe

# Physical synthesis applicability

- Physical tools for logic based FPGAs are mature and has been applied on several experimental or commercial architectures, including a practical workbench on the Virtex1.
- Applicability to data-path and heterogeneous reconfigurable circuits has been partially investigated on a design from STMicroelectronics,
- On-going work on nanofabric modeling in a joint work with a team at UMass,
- Investigations on a massive parallel micro-programmable architecture model in a franco-german project,
- Integrated Project Morpheus will start this fall with the obective to develop a SoC approach with heterogeneous reconfigurable units...



Introduction Outline The electronic industry roadmap Synthesis from Smalltalk Virtual machines of the past Example of a mixe

#### Logic synthesis: an evolving grain

We need data-flow graphs for the physical layer.

- The grain of "*fabrics*" is evolving from gate arrays to tiles grouping operators, registers, memories and buses.
- The semiconductor roadmap predicts a move to mesh of small processors, and reconfigurability will evolve to allow local control,
- The term *Logic Synthesis* match the requirement to produce logic graphs, from higl level programs, for physical synthesis.
- It must be though as *Numeric Synthesis* when data-path are involved, and *Graph Mapping* when processor meshes will be addressed.

ヘロト ヘ戸ト ヘヨト ヘヨト

Introduction Or

The electronic industry roadmap

Synthesis from Smalltalk

talk Virtual machines of the past Example of a mixed o o

# Algorithm+Data=Circuits

- Logic blocks are produced from Smalltalk methods *writen for this purpose*, but executable in the high level environment.
- As we are using a late-bound language, no type information is normally available.
- This need is filled by requiring a *compilation context* that holds the data that will be operated by the resulting circuit.

- The programming game is to avoid nodes of large complexity, to quickly converge to synthesizable nodes.
- The same code allows to synthesize from objects of different classes,
- Polymorphism survives in this technique,
- Fully automatic process,

・ロット ( 雪 ) ・ ヨ )



Compiler flow for logic synthesis:

- **1** parser: Smalltalk parser, produces a program graph,
- **2 DAG**: Dependency analysis, removing temporaries, production of a Directed Acyclic Graph (DAG),
- **3 Type inference**: the compiler context is propagated in the DAG:
  - complex messsage sends are compiled recursively
  - 2 simple nodes are replaced by a table
- **Optimization**: removing useless tables and values,
- **6** Coding: codes are attributed to objects,
- 6 Logic production: tables are split for adaptation to a target technology (SIS)



・ロト ・ 同ト ・ ヨト ・ ヨト ・ ヨ

# Relations with a software environment

- Combinational circuits produced at high level, applicative style of programmation,
- Strong interest for operator production,
- Very efficient optimization, proof of concept on critical applications (Galois fields and error correction)
- 100% compatible with the needs of a high level software environment



Table network If used from a virtual machine an adaptation is needed between object in memory and computing circuit (at least indexes).

・ロト ・ 厚 ト ・ ヨ ト ・ ヨ ト



# Logic synthesis applicability

Finite state machines are synthesized by including the state values in the compiler context. The state set is progressively built by retrieving new values from an initial value.



- Limited for computation organization
- Currently: only logic synthesis is working. Numeric synthesis for data path, micro machines are not implemented.
- 3 The type system allows to preserve numeric sets as intervals

・ロット ( 雪 ) ・ ヨ )

Sac

Introduction Outline The electronic industry roadmap Synthesis from Smalltalk Virtual machines of the past Example of a mixe

・ロット 小田 マ イロマ

#### Structural representations

More complex circuits are produced by copying, replicating and binding components together on the top of logic synthesis and Physical synthesis.

These programs can be kept "architecture independents" due to the relative geometrical characteristics obtained from the synthesized modules.



The electronic industry roadmap Synthesis from Smalltalk Virtual machines of the past Example of a mixe

### Structural representations

#### Module component known by its geometry

| <b>1</b> | THOM            | Ed    | ter   |      |      |        |       | '   |       |      |      |                     |                 |          | _ | ( | 2.8 | × |
|----------|-----------------|-------|-------|------|------|--------|-------|-----|-------|------|------|---------------------|-----------------|----------|---|---|-----|---|
| File     | Modu            | les   | Synth | esis | Repr | resent | ation | Exp | ert k | fode | Help |                     |                 |          | _ |   |     |   |
|          | lection<br>2013 | 1 882 | e : 0 |      | -    | -      |       | 0%  | 4     | -    | •    | com<br>fireP<br>reg | posite<br>races | d<br>sor |   |   | ]   |   |
|          |                 |       |       |      |      |        |       |     |       |      |      |                     |                 |          |   |   |     | 0 |
|          |                 |       |       |      |      |        |       |     |       |      |      |                     |                 |          |   |   |     |   |
|          |                 |       |       |      |      |        |       |     |       |      |      |                     |                 |          |   |   |     |   |
|          |                 |       |       |      |      |        |       |     |       |      |      |                     |                 |          |   |   |     |   |
|          |                 |       |       |      |      |        |       |     |       |      |      |                     |                 |          |   |   |     |   |
|          |                 |       |       |      |      |        |       |     |       |      |      |                     |                 |          |   |   |     |   |
|          |                 |       |       |      |      |        |       |     |       |      |      |                     |                 |          |   |   |     |   |
|          |                 |       |       |      |      |        |       |     |       |      |      |                     |                 |          |   |   |     |   |
|          |                 |       |       |      |      |        |       |     |       |      |      |                     |                 |          |   |   |     |   |
|          |                 | 0     | .7    |      |      |        |       |     |       |      |      |                     |                 |          |   |   |     |   |
|          |                 |       |       |      |      |        |       |     |       |      |      |                     |                 |          |   |   |     |   |
|          |                 | *白    | -     |      |      |        |       |     |       |      |      |                     |                 |          |   |   |     |   |
|          |                 |       | -0    |      |      |        |       |     |       |      |      |                     |                 |          |   |   |     |   |
|          |                 | *0    | -0    |      |      |        |       |     |       |      |      |                     |                 |          |   |   |     |   |
|          |                 | **    | -0    |      |      |        |       |     |       |      |      |                     |                 |          |   |   |     |   |
|          |                 | i h   | -0    |      |      |        |       |     |       |      |      |                     |                 |          |   |   |     |   |
|          |                 | 10    | -0    |      |      |        |       |     |       |      |      |                     |                 |          |   |   |     |   |
|          |                 | -     |       |      |      |        |       |     |       |      |      |                     |                 |          |   |   |     |   |
|          |                 |       |       |      |      |        |       |     |       |      |      |                     |                 |          |   |   |     |   |

#### is replicated after computing a correct position.



Sac



#### Use status

This software was started as an open alternative to industrial tools for architecture and compiler design.

- **System synthesis**: as a quick complement to the FPGA framework, a synthesizer has been built to allow the automatic production of code from *Smalltalk models*: C code, communication code, micro-code for a camera and FPGA. Demonstration on an embedded camera.
- Language integration: use of the framework as a back end for C compilers and the synchronous language Signal.
- Architecture design: most of the interest received is actually for modeling, quick tool generation and performance evaluations for new architectures.



・ロト ・ 同ト ・ ヨト ・ ヨト ・ ヨ

Introduction Outline The electronic industry roadmap Synthesis from Smalltalk Occocococo

- Morpheus project: will include a system on chip and reconfigurable units of different grain to be addressed in a similar way, and used under compiler control.
- Next? dedicated support for virtual machines: it is attractive and natural to investigate how we could build powerful support for 'virtual' machines using the reconfigurable units and .



Units can implement dedicated functions, reconfigurable on the fly. This is still general purpose HW, considered as a credible alternative to IP for flexibility and time-to-market reasons. It scales.

・ロット ( 雪 ) ・ ヨ )



| Introduction | Outline | The electronic industry roadmap | Synthesis from Smalltalk | Virtual machines of the past | Example of a mixed |
|--------------|---------|---------------------------------|--------------------------|------------------------------|--------------------|
| 00000        |         | 0000000000                      | 000000000000000          | 0                            |                    |

#### VIRTUAL MACHINES OF THE PAST



Introduction Outline The electronic industry roadmap Synthesis from Smalltalk Virtual machines of the past Example of a mixe

# Virtual machines of the past

Past and present VM will not address new challenges due to the large change of scale. However they can be used to control larger processing elements coming from synthesis. For VM, three reference points are :

- Micro-coded approach, as used in the Dorado, provides flexibility in the definition of the instruction set and efficient micro-grain parallelism inside the processor. This model is a good match with current HW orientations.
- Software approach, using a processor, we can interpret a pseudo-code and implement all the required functionalities. Characteristics: sequential specification and few use of specific HW support. (multicores, SMT ?)
- Specific processor tuned for performances, as was Smalltalk-on-a-Risc (SOAR).
   Will not appear in SoC or FPGAs.



Introduction Outline

The electronic industry roadmap

Synthesis from Smalltalk

alk Virtual machines of the past Example of a mixed

# Dorado control path and organization

# Pipeline for instruction decoding and execution :

the Instruction Fetch Unit share accesses to the memory cache and produce adresses for the micro-machine (up to 6 bytes prepared in adavance). **Micro-machine**: has a RAM microstore with 4K words of 36 bits. The IFU is restarted for jumps, message sends

#### Instruction set switching:

Smalltalk was implemented with its own IS and micro-code, plus the Alto IS addressed from a B compiler. The IS is switched to execute some primitives.



・ロト ・ 厚 ト ・ ヨ ト ・ ヨ ト

Sac

Introduction Outline

The electronic industry roadmap

Synthesis from Smalltalk

Virtual machines of the past Example of a mixed

# Dorado processor characteristics

registers : 16 groups of 16 registers (3 were used) stacks : 4 stacks of 64 registers (used only in the micro-code) data-path : operated on 16 bits pipeline stages : 6, including 2 in the IFU. cycle time : 70ns process switching: support of multitasking and I/Os in the micro-code cache : 4K words access in 100ns, virtual memory not used.

・ロット ( 雪 ) ・ ヨ )

Sac

A number of resources were not used, and the implementation relied mostly on the speed of the cache. Cost: 100000\$. Introduction Outline

The electronic industry roadmap

Synthesis from Smalltalk Virtual machines of the past Example of a mixe

# Code distribution

IFU + microcode : interpreter microcode :

- process switch and kernel operations
- most of the memory management: allocation, recursive freeing, garbage collectors, compactor loops,
- access to the objects,
- block context management,
- simple operations and bitblt.

### macrocode (Alto) :

- more or less C
- large integers, floating point

・ロット ( 雪 ) ・ ヨ )

- I/Os
- snapshot,
- other storage management.



The electronic industry roadmap Synthesis from Smalltalk Virtual machines of the past Example of a mixe

・ロト ・ 一 マ ト ・ 日 ト ・

# Micro-code interesting features

- Compared with a software interpreter : the time spent in the fetch, dispatch loop, process switch is removed by the IFU Primitives call is reduced.
- ILP: micro-code allows 'by hand' instruction level parallelism that could be difficult to produce frm a compiler.
- most of the code is located in a surprisingly small micro-code memory.
- cache architecture remains critical.



| Introduction | Outline | The electronic industry roadmap | Synthesis from Smalltalk | Virtual machines of the past | Example of a mixed |
|--------------|---------|---------------------------------|--------------------------|------------------------------|--------------------|
| 00000        |         | 0000000000                      | 000000000000000          | 0                            |                    |

#### EXAMPLE OF A MIXED-GRAIN RECONFIGURABLE DATA PATH





### A data path slice

Data path slice showing 4 RAMs of  $256 \times 8$  bits connected to an arithmetic part with 2 multipliers (16 bits), and 4 8 bits ALU slices.





・ロト ・ 厚 ト ・ ヨ ト ・ ヨ ト

Synthesis from Smalltalk Virtual machines o

Virtual machines of the past Example of a mixed

Sac

# A reconfigurable unit

This unit has 8 similar slices organized as a data path, connected to a fine grain unit (M2000). A reconfigurable loader allows to program connectivities, fine grain from outside. Micro-code is emitted to/from the data-path. (J.Cambonie, V.George, STMicro)



Introduction Outline The electronic industry roadmap Synthesis from Smalltalk Virtual machines of the past Example of a mixe

# Being a little bit speculative...

Mapping of a Dorado-like architecture on this ST Data-path is nearly possible!



U 13 0

Sac

| Introduction ( | Outline | The electronic industry roadmap | Synthesis from Smalltalk | Virtual machines of the past | Example of a mixed |
|----------------|---------|---------------------------------|--------------------------|------------------------------|--------------------|
| 00000          |         | 0000000000                      | 000000000000000          | 0                            |                    |

### CONCLUSION



Introduction Outline The electronic industry roadmap Synthesis from Smalltalk Virtual machines of the past Example of a mixed opposite opp

### As a conclusion

- feed back to the industry efforts: given the future huge amount of hardware resources available, we can imagine methods and tools to produce applications quickly.
- it is best to build models and tools for future architectures now, rather than wait for the C compiler that will produce parallelism and ensure portability,
- **3** concurrency is the way to go, at the circuit level, distributed processing level, and machine level,
- several mechanisms are lacking in current Smalltalk, especially for spatial parallelism description, time constraint, type systems, processor descriptions.



・ロット 御マット ほう・

Introduction Outline The electronic industry roadmap Synthesis from Smalltalk Virtual machines of the past Example of a mixe

# Bibliography

Dorado (Lampson/Pier), (Deutsch), Soar (Patterson/Ungar), Self (Ungar/Chambers), Instruction path (DeBaer/Campenhout), Process networks(Lee), ...

### David Patterson.

A call to arms: A new manifesto for systems.

In *CRA Conference on "Grand Research Challenges" in Computer Science and Engineering*, Warrenton, Virginia, May 2002.

...we must broaden our research agenda beyond performance so that our legacy does not remain as fast as flaky... How should we design and program computers when the basic block is a processor rather than a transistor ?

Architecture of SOAR: Smalltalk on a RISC.D. ungar and r. blau and p. foley and d. samples and d. patterson.

In ISCA, 1984.



・ コ ト ・ 雪 ト ・ 雪 ト ・ 日 ト