E N D
Design Methodology for High-Level Model Based on an Eight Bit Entertainment SystemAlejandro Lizaola, Ricardo D. Castro, Gilberto Beltran.Dr. Manuel Salim and Mtro. Alejandro MorenoDepartment of Electronics, Systems and InformaticsInstitutoTecnológico y de EstudiosSuperiores de Occidente (ITESO)Guadalajara, Mexico, 45090 Intel & Iberchip XVII, February 2011
Outline • Introduction • Theory • Main Block Description • Design Methodology • Verification Strategies • Results • Conclusions • Future Work
Introduction • This presentation is about a design methodology for a high-level model based on an 8 bit entertainment system. • Verification strategy as the reference model is proposed for this project is based on reverse engineering. • Design and architecture of the group of reference models has been identified . • Coding and Verification development has been a challenge. • It’s been a merge between a Software and Hardware verification methodology for the reference model.
Theory Reverse Engineering: It has the goal to obtain information from a product to determine its structure, function and operation. Emulator: It is a software that allows certain computer programs to run on a different platform than the one they were originally written for.
…Theory • Reference Model: • It is a high level description of a system, chip, block, or component to obtain the expected values that will compare with the obtained values and declare a failed or passed test. • Verification: • It is the process to determine that an implementation behaves according to a given set of requirements for all possible scenarios.
Design • Comprehend and understand the functionality of the NES. • Comprehend and understand the operation of the NES. • Election of emulator. • Reference model design. • Implementation of reference model main blocks. • Verify the operation of each block of the reference model. • Integrate reference model modules. • Verify reference model integration.
Verification Strategies Reference Model Verification:
…Verification Strategies Verification Plan: The verification plan is defined base on the NES console. Through the specification of the console, all functional areas are described as well as monitors, checkers and coverage have been analyzed. This will be useful for all those who are working in the planning and execution of the console verification.
Results Comparison between output files using Soccer rom
Results Triangular channel outputs for crystali game. [crystali] is an audio rom, it uses mapper 4
…Results White noise channel outputs for crystali game
…Results Audio buffer outputs for crystali game
…Results Scroll results for crystali game • Sprites results for crystaligame
Conclusions • A Nintendo emulator for PC was selected. A reference model was implemented based on this emulator and implemented in SystemVerilog. The model was created in a modular way using reverse engineering and design tools for programming high-level languages. Model functionality was verified. • An automated comparison makes error detection easier on the output files. • SystemVerilogmakes easier the reference model implementation because it provides a high level modeling abstraction with a lot of capabilities to implement and verify a design developed in any hardware description language.
…Conclusions • The Methodology proposed was based in software debugging techniques by mapping the hardware validation to software validations process. • The performance of the model behaves as expected. • This is a oriented object model for verification environment not synthesizable. • The synthesis & Test of the reference model is possible.
Future Work • Mappers and more expansion chips can be implemented. • An interface between CPU and controllers can be designed. • The reference model can be done to be synthesized and to be downloaded into a FPGA. With this reference model a verification environment can be done to validate a RTL prototype . • The system must further refine the PPU module, especially a variable called "display" to have the optimal functioning of the entire system.
Question & Answers… • Any question ?
Slides Background Central Processing Unit: The CPU emulated by the NES is an 8-bit microprocessor produced by Ricoh based on MOS Technology 6502 core. The NTSC version (North America and Japan) of the console use the Ricoh 2A03 (or RP2A03), which operates at 1.78MHz, PAL version (Europe and Australia) use the Ricoh 2A07 (or RP2A07), this is identical to version NTSC with the difference that it works on 1.66MHz.
Slides Background Audio Processing Unit: The APU is responsible for generating the game sound. It is implemented in two chips, RP2A03 for NTSC and RP2A07 for PAL. The APU has 5 channels: • Square channel, frequency ranges 54 Hz – 28 KHz. • Square channel, frequency ranges 54 Hz – 28 KHz. • Triangle channel, frequency ranges 27 Hz – 56 KHz. • Noise channel, LFSR, two modes and sixteen programmable frequencies. • DPCM channel.
Slides Background MAPPERS: Mappers are chips designed for videogames developers to use them in NES cartridges. Mappers are used to access memory beyond the limits of the 64k memory, allowing special effects in the video and sound, such as forcing some interruptions and instructions among other things. The memory used by the NES is implemented in two blocks, Rom program (PRG-ROM) and Rom Character (CHR-ROM). This includes the memory area where the current code will be executed by the micro as well as the video memory data .
Slides Background Picture Processing Unit: The PPU used by the NES was designed by Ricoh. This unit is responsible for transforming the digital information received from the CPU into video signal to display the game on screen. This process is known as image rendering The PPU contains the following: • Background render unit. • Sprites render unit. • Records of entry and exit. • Internal RAM 32B. • External RAM 256B.