CS252 Midterm Elma
CS252 Midterm Elma
CS252 Midterm Elma
Abstract-This paper presents two instruction set architectures, Relatively few instructions and addressing modes
particularly the CISC and the RISC, which have been developed makes it easy for the control unit to interpret
as computer architects aimed for a fast, cost-effective design. instructions
Included in this paper are the arguments made for each
architecture, and of some performance comparisons on RISC and Fixed instruction format makes decoding of
CISC processors. These data are collected from various papers instructions fast and easy
published concerning the RISC versus CISC discussion. More compile-time effort offers opportunity to
explicitly move static run-time complexity into
compiler
I. INTRODUCTION
And what exactly is CISC?
During the 1980’s, a new technology emerged in the The CISC design uses complex instructions intended for
computer industry – the Reduced Instruction Set Computer direct implementation of high-level language operations [2].
(RISC). This instruction set architecture surfaced as an These complex instructions that take time to be executed are
alternative to the older, established technology already in the made up of smaller, simpler instructions.
field – the Complex Instruction Set Computer (CISC). CISC microprocessors can be described as the opposite of
RISC was presented as a solution to derive more instruction RISC having these characteristics [3]:
set power out of a computer. It is not just a means to reduce
the instruction set, but it is a way of significantly enhancing
Multi-cycle operation due to variable execution
the performance of a system while having minimal costs
time of instructions
compared to that of a CISC implementation [1].
Not a load/store machine
In 1980, the paper published by Patterson and Ditzel laid
down the arguments in favor of RISC over CISC which started Relies on micro-coded control engine
the RISC versus CISC debate that lasted for years. More instructions and addressing modes like that
Before we delve into the arguments for and against these of a high-level programming language
architectures, we must first understand the differences between Variable-length instruction format dependent on
them. The definitions of RISC and of CISC are given in the the number of operands and addressing modes used
next few subsections. Difficult targets for optimizing compilers because
of complex instructions
What’s the RISC?
RISC is a microprocessor design approach using simple II. ARGUMENTS AND COUNTER-ARGUMENTS
instructions. Though it may seem less effective for a
computational task to be executed with many simple Having seen the difference between the two architectures,
instructions rather than a few complex instructions, the simple this section now presents the arguments made for each in
instructions take fairly the same amount of time to be different aspects of computer design.
performed, making them ideal for pipelining [2]. Table I shows the summarized list of arguments for RISC
The other elements that define a RISC processor, according and against CISC from [4]. Notice that the arguments for
to [3], are the following: RISC revolve around the central idea of it being a simple
design. From this simple design spawns advantages that the
Single-cycle operation aids in fast execution of CISC architecture would not be able to obtain due to its
simple functions complexity.
Load/Store architecture implemented due to the The arguments for CISC, however, I find they lack
desired single-cycle operation documentation. What I found instead are published papers
Hardwired control provides for the fastest possible with counter-arguments for RISC. The summary for the
single-cycle operation counter-arguments is given in the next subsection.
TABLE I
ARGUMENTS FOR RISC
Factor RISC CISC
Simple architecture makes RISC being realizable at Complex architecture make it difficult to implement
Implementation Feasibility
earlier date on a single chip with the design rules at that time
Lengthened design time may lead to problems such
Design that can be easier to design and debug can
as having a machine with an old technology, or
Design Time use much superior technology than design that takes
trying to predict future technology and have a go at
a long time to implement
attempting to build that technology
Gains in speed from better use of chip area and from
simple design – with less instructions and More instructions and addressing modes result to
Speed
addressing modes, these would lead to a less complicated control structure
complicated control structure
Area left on chip due to simple design may be used Complex design leaves no room on chip for
Use of Chip Area
to make RISC improve performance even more enhancements
The Counter-arguments According to these rebuttals, some arguments for RISC are
These are counter-arguments made against the RISC misleading – for example the design time and chip usage – and
architecture. therefore cannot be used as basis for comparison of the two
False Dichotomy. Complexity of a machine cannot be architectures. Also, other areas of interest must be properly
measured by instruction count alone, and cannot be the investigated to make an accurate comparison between the two,
only decisive factor for categorizing a machine as RISC or like that of the operating system of a machine. Reference [5]
CISC [3, 5]. stated that with just a paper design and lack of metrics to back
Lengthy Design Time. Designing products for a high- the arguments, the claim that the RISC architecture can be
volume manufacturing company has time-consuming superior over CISC will be difficult to prove.
processes that do not exist in a small company [5]. There
are differences in the design environments for academic
III. PERFORMANCE COMPARISON
research and from companies that produce commercial
products [3].
Bhandarkar and Clark published a paper [6] in 1991 that
Language Multiplicity. An instruction set that supports
did performance comparisons on implementations from the
only a particular language can make the implementation of
RISC and CISC architectures. They chose the MIPS M/2000
a different language difficult [5]. Designing a machine for
from the RISC architecture and Digital VAX 8700 from CISC
a particular language is different from designing one that
since these machines possess organizational similarity. Nine
accepts a wide range of languages [3].
out of ten SPEC89 benchmarks were run on both machines,
Instruction Execution Time. Frequency of execution of
and the results were noted down and analyzed.
instruction must not be the focus of attention, but also to
The results show that the MIPS M/2000 had more
the length of time an instruction is executed [3, 5].
instructions than that of VAX 8700, but achieved much less
Microbenchmarks. Small programs (e.g. Towers of
average CPI on all benchmarks. Also, analysis of results
Hanoi, Fibonacci) that have been used to measure
reveals that MIPS M/2000 has a net advantage, and this
performance on RISC machines have a narrow scope on
advantage are attributed to architectural factors like filled
functions, although they execute millions of instructions.
delay slots and the number of registers.
These benchmarks do not represent actual applications used
Based on the results, they concluded that the MIPS has an
in the industry [3].
advantage in processor performance over VAX with a
Specialized Hardware. Higher-level hardware-software
comparable architecture.
interface has the advantage of possible use of specialized
In 1994, another paper [7] was published by Bhandarkar
hardware for better performance [5].
comparing various design aspects of two machines from each
Chip Usage. Chip area left by RISC’s simple design can
architecture – the Alpha 21164 from RISC, and the Intel
indeed be used by adding enhancements for better
Pentium® Pro processor. Results show that the Alpha 21164
performance. But these enhancements are not inherent in
had better performance, performing over two times faster in
RISC architectures [3].
floating point benchmarks, and a little better in performance in
Ignored Operating System. The system is not only made
integer and transaction processing workloads than the
of software, hardware, and application code. The operating
Pentium® Pro.
system overhead and needs have been given too little
The performed experiments for comparison did not only
attention in RISC research [3].
demonstrate that RISC machines can be at par with CISC, but
More Instructions. Breaking up complex instructions of
may even outdo them in performance.
CISC results to more instructions per program [6].
III. INDUSTRY REACTION REFERENCES
While the RISC versus CISC debate continued over the [1] A. Molina, “Current trends, issues and strategies in
years, many companies have adopted the RISC design and the development of the microprocessor industry,”
produced a number of successful processors based on RISC Edinburgh PICT working paper no. 42, 1992.
designs. These include the ARM family of RISC processors, [2] C. Hamacher, Z. Vranesic, and S. Zaky, Computer
the IBM PowerPC family of RISC processors, Sun’s SPARC Organization fifth edition. Boston: McGraw-Hill
and UltraSparc, MIPS, and HP’s PA-RISC. Publishing, 2002.
The CISC-based design was also continued to be supported [3] R.P. Colwell, C.Y. Hitchcock III, E.D. Jensen, H.M.
and processors under the said architecture are the Motorola Brinkley Sprung, and C.P. Kollar, “Instruction sets and
68000 family, Intel processors, and the VAX family. beyond: computers, complexity, and controversy,”
Processors with characteristics from both architectures IEEE Computer, 1986.
have also materialized, as “Crisp” processors like Intel 80x86 [4] D. Patterson and D. Ditzel, “The case for the reduced
processors and the Motorola 80486 and 68040 were designed instruction set computer,” ACM SIGARCH Computer
to have RISC features [1]. Also, advancements in technology Architecture News, 1980.
such as simultaneous multi-threading and value prediction are [5] C. Douglas and W. Strecker, “Comments on ‘The
used by machines under both architectures, and because the case for the reduced instruction set computer’ by
architectures have adopted the strategies of the other that the Patterson and Ditzel,” 1980.
architecture classification becomes blurred [8]. [6] D. Bhandarkar and D. Clark, “Performance from
architecture: comparing a RISC and a CISC with
similar hardware organization,” Proceeding of APLOS-
IV. CONCLUSION
IV, 1991.
[7] D. Bhandarkar, “RISC versus CISC: a tale of two
The RISC design had advantages that result to a machine’s
chips,” Computer Architecture News, 1994.
excellent performance that it has been adopted for commercial
[8] C. Chen, G. Novick, and K. Shimano, RISC
products, as we can see from the industry’s response of
Architecure, http://cse.stanford.edu
designing RISC-based processors. The long RISC versus
CISC debate was most certainly a good thing as it allowed the
industry to explore and come up with solutions that have
significantly raised the machine’s performance we use today.
Due to this exploration, both architectures have continuously
developed and processors today have a little bit of something
from each architecture.