Web-based HW/SW Codesign Automation of an 802.16 Channel Codec

Ching-Shun Chen*, Chi-Yang Liao#, Chih-Jen Hsiao#, Yuan-Wen Huang#, Hsing-Chi Fang#, Li-Shin Huang# and Hsi-Ju Chen#

Department of Electrical Engineering, Da-Yeh University, 168 University Rd, Dacun, Changhua, Taiwan 51591, ROC

Abstract: The intelligent web-based systems had been developed for various applications such as conceptual design, rapid prototyping manufacturing, and supply chain planning. On the other hand, hardware/software (HW/SW) codesign is commonly used methodology for digital-system design. Noteworthy, our previous work had carried out in order to develop a web-based HW/SW codesign framework with implementation of a JPEG encoder [1]. Design of an 802.16 codec with the web-based HW/SW codesign automation is further performed in this work. The 802.16 codec designed by C program language is compiled with MS Visual C++ 6 to verify its correctness at first. The ANSI C design of an 802.16 codec is further transferred into the developed web-based codesign framework, which utilize web servers, CGI programs (in C or PERL), GCC compiler, SPIM simulator, and Cadence EDA tools. In about seventy working minutes, the respective design of a MIPS-like processor (hardware) in TSMC 0.18 μm VLSI layout with machine code (software) is going to be automatically accomplished in the web-based codesign framework. The full detailed HW/SW design is capable to be automatically e-mailed return to remote user for further application. In the web-based codesign framework, the MIPS-like processor is designed by using algorithmic state machine and Verilog hardware description language. In addition, the HW/SW design of an 802.16 codec is verified with using a Xilinx FPGA development board for this study.

Keywords: 802.16, HW/SW codesign automation, MIPS, FPGA, EDA, VLSI.

1. INTRODUCTION

The intelligent web-based systems had been developed for conceptual design, rapid prototyping manufacturing and supply chain planning [2-4]. As inter-enterprise cooperation on the internet becomes more dynamic and changing, the concept of how internet-enabled designs may allow companies to create global design groups to complete complex system-on-chip designs [5]. The HW/SW codesign methodology is commonly used for digital-system design, especially it is aimed at the consumer market to execute a variety of high-performance real-time tasks, such as audio, images, video, radio channel access, TCP/IP protocol stack management and so on. Noteworthy, the internet-based collaborative HW/SW codesign framework has been developed in our previous study with very preliminary verification with the implementation of an JPEG encoder [1]. To validate the performance of developed framework, more advanced and complicated design is urgently required to be studied.

WiMAX, meaning Worldwide Interoperability for Microwave Access, is based on the IEEE 802.16 standard [6] (also called Broadband Wireless Access). WiMAX has been tipped to bring a revolution in the way we use broadband services. In this study, design of the 802.16 channel codec capable for the application of WiMAX is performed in association with the web-based HW/SW codesign automation. The web-based HW/SW codesign framework which utilizes web servers, CGI programs [7] (in C or PERL), GCC compiler, SPIM simulator, and various EDA tools such as Cadence BuildGates and SOC Encounter has been implemented for running in Windows XP and TopologiLinux. As the processor core for HW/SW codesign, the MIPS-like processor is designed by using algorithmic state machine [8] and Verilog hardware description language.

An 802.16 channel codec designed by C program language is compiled with MS Visual C++ 6 to verify its correctness at first. Furthermore, a remote user can input the ANSI C design of the 802.16 channel codec to the web-based HW/SW codesign framework. In about seventy minutes, the full detailed HW/SW designs including C original design, assembly code, machine code and a MIPS-like processor in TSMC 0.18 μm VLSI layout are going to be automatically accomplished and e-mailed return to the remote user for further application. The HW/SW design of an 802.16 channel codec is verified by using MS Visual C++ 6, PCSPIM, Modelsim and a Xilinx FPGA development board [9] in this work.

The objective of this work is to further validate our novel web-based HW/SW codesign framework [1] which can effectively integrate various EDA tools to complete an 802.16 HW/SW codesign in less than two working hours. Using the proposed codesign automation is anticipated to save dozens or hundreds times of labor efforts than those using the EDA tools separately without design automation.
The paper is organized as follows: Section 2 introduces an 802.16 channel codec; The development of a MIPS-like processor using ASM and Verilog is discussed in Section 3; Our approach to realize the web-based HW/SW codesign framework and various possibilities is described in Section 4; Finally, Section 5 presents the various verification results to show correctness of the design of an 802.16 channel codec with web-based HW/SW codesign automation.

2. 802.16 CHANNEL CODEC

Fig. (1) presents the flowchart of an 802.16 channel codec [6] and indicates that symbols, (A)-(P), are assigned to be referred to the following verification results. Randomizer is the first process after receiving the input signals. The Forward Error Correction (FEC) encoding is performed by passing the data in block format through the Reed-Solomon (RS) encoder and then passing it through a convolutional encoder. After interleaving, the signals are entered serially to modulate. The inverse fast Fourier transform (iFFT) is subsequently to convert the frequency domain signals into time domain. The time domain signals are transmitted through the channel. After channel transmission, the received signal is processed by using the fast Fourier transform (FFT) and demodulator. Furthermore, the signals are restored back into the original form by deinterleaver, FEC decoding and derandomizer. In general, the original data signal will be recovered in the final output.

In IEEE 802.16 standard, interleaving defined by a two-step process is used against long sequences of consecutive errors. The first step ensures that adjacent coded bits are mapped onto non-adjacent subcarriers. The second step ensures that adjacent coded bits are mapped alternately onto less or more significant bits of the constellation, thus avoiding long runs of unreliable bits. The specified modulation scheme can be BPSK, QPSK, 16-QAM and 64-QAM in the 802.16 channel codec. The BPSK and QPSK modulations are used for communication over longer distances or in impaired conditions. On the other hand, the disadvantage of BPSK and QPSK lies in the low signal rate. In this work, the QPSK modulation is performed.

3. MIPS-LIKE PROCESSOR

As well known in open literatures, MIPS processor was originally invented as part of a Stanford research project and later brought to market by newly-started MIPS Corporation in 1985, releasing the MIPS R2000 [10] running at 8 MHz on 2.0 micron process. MIPS, a family of 32-bit and 64-bit computer processors, is currently primarily used in many embedded applications such as the Windows CE devices, network routers, and video game consoles like the Nintendo 64, PlayStation 2, and PlayStation Portable handheld system. Until late 2006 they were also used in many of SGI's computer products. In this work, the MIPS-like processor architecture, which can be generated automatically by web-based HW/SW codesign framework, includes thirty-two general-purpose 32-bit registers, forty-seven instructions, and an external floating-point unit (FPU) for computation of real numbers.

For the design of MIPS-like processor, Algorithmic State Machine (ASM) notation [8], which builds on the foundation of state transition diagrams by providing a mean to express the state trajectory as a conditional flow, is applied in this work. It is accomplished by incorporating conditions, deci-
Web-based HW/SW Codesign Automation of an 802.16 Channel Codec

The Open Electrical & Electronic Engineering Journal, 2014, Volume 8 21

Fig. (2). A simplified ASM chart for MIPS-like processor.

Verilog is a hardware description language (HDL) utilized to model electronic systems in VLSI design industry. Based upon the designed ASM chart, the MIPS-like processor can be behaviorally modeled with Verilog very efficiently. The behavioral Verilog model of MIPS-like processor could be simulated and synthesized for further verification. In addition, EDA tools such as Cadence BuildGates and SOC Encounter are applied to accomplish VLSI layout of MIPS-like processor.

4. WEB-BASED HW/SW CODESIGN

Fig. (3a) presents the realized architecture for the web-based codesign framework. In the developed web-based HW/SW codesign framework, Windows XP and Topologicalinux operating systems are installed in one computer (CPU 2.0 GHz, RAM 752 MB, HD 30 GB) in association with Abyss web server, CGI programs, GCC compiler, SPIM simulator, and Cadence BuildGates and SOC Encounter.

In this work, web server provides access of the user to the codesign framework, as well as processes all design requests received from users who use their web browsers for communication with the server. Another function of the web server is to provide information about the current design status and results of the framework (i.e. the status and results of actions requested by the user). As the matter of fact, the web server is a connecting link between the hardware of the internet network and the user's browser. The CGI programs designed by using C or Perl language are utilized to make dynamic template pages (written in HTML language), to grant or deny user access by checking user’s IP address, and to drive GCC compiler, SPIM simulator, Cadence BuildGates, and SOC Encounter doing their jobs, respectively. Another function implemented in CGI programs is the organization of the files with result of simulation task and with VLSI layout of the designed MIPS-like processor. The processed design results including C original design, assembly code, machine code, and VLSI layout with timing report, area report, and power report may be sent to client via e-mail when the full design task is accomplished. Fig. (3b) illustrates a basic demonstration for the web-based HW/SW codesign.

A website developed for internal use and organized as aforementioned discussing offers the following possibilities:

I. Users can develop their designs in various fields such as wireless communication, digital signal processing, and
Fig. (3). (a) Block diagram of the web-based design framework. (b) Demonstrator operation, and layout example.

Fig. (4). (a) Main page of web-based design framework. (b) The example of user permission and C/C++ design input. (c) The example of assembly code generated by GCC compiler. (d) The example of simulation completed by SPIM simulator.
The performance simulation of the studied 802.16 channel codec is shown in Fig. (5) with comparison to that of previous study by Shafik et al. [11]. It is found that performance trends of this work and previous study are similar, but a little difference in BER performance is due to Shafik et al. using convolutional code only without RS code in their simulation.

The input signals of an 802.16 channel codec are given by \{0, 1, 0, 0, 0, 1, 0, 0, \ldots\} to verify the correctness of whole design. For the design verification, (A)-(P), are applied to illustrate the outputs from each component of an 802.16 channel codec as shown in Fig. (6a) with respect to Fig. (1).

The 802.16 channel codec designed by C program language is compiled with MS Visual C++ 6 to verify its correctness. Partial result data is extracted for further verification as shown in Fig. (6b). The two red frames of Fig. (6b) show that the original input data, subsection (A), is the same as the restored output data, subsection (P).
The C design of the 802.16 channel codec is further compiled by using GCC compiler toolchain and assembled by using SPIM to generate the MIPS-architecture assembly program and to complete MIPS-machine simulation, respectively, within the web-based HW/SW codesign framework. Partial coding data extracted from PCSPIM is shown in Fig. (7). It is found that data contents from using MS VC++6 and PCSPIM are the same as those from MS VC++6 (Fig. 6b) and Modelsim (Fig. 7). The whole 802.16 channel codec data is extracted from flash memory and is found to be correct in this work.

![Fig. (7). Partial results extracted from PCSPIM.](image)

Partial memory contents extracted from Modelsim as shown in Fig. (8) are the same as those in Fig. (6b) and (7). For example, the data 0x3ecf876f corresponding to address 0x10014048 in subsection (H) of Fig. (7) is the same as reverse ordered data 6f 87 cf 3e corresponding to address 4048 in subsection (H) of Fig. (8).

The Virtex-II PRO(V2-Pro) FPGA development system interfacing with flash memory is applied to verify the aforementioned Verilog model again. The behavioral Verilog model is synthesized and programmed into the FPGA board by using ISE design suite. The original data and the 802.16 channel codec program are programmed into flash memory, and the synthesized Verilog model of the MIPS-like processor is programmed into FPGA chip, respectively.

When the 802.16 channel coding and decoding are accomplished, the coded and decoded data of an 802.16 channel codec will be appeared in flash memory finally. The partial coding and decoding results in flash memory are the same as those by using MS VC++6 (Fig. 6b), PCSPIM (Fig. 7), and Modelsim (Fig. 8). The whole 802.16 channel codec data is extracted from flash memory and is found to be correct in this work.
In addition, the Verilog structural model of a MIPS-like processor can be automatically generated by using Cadence BuildGates in web-based HW/SW codesign framework. The synthesized netlist from BuildGates is further imported to Cadence SOC Encounter for VLSI layout with using TSMC 0.18 μm standard cell library as shown in Fig. (9). The VLSI layout could be passed for Design Rules Check (DRC) to complete all verification tasks.

CONCLUSION

Verification results reveal that the design of an 802.16 channel codec by using the web-based HW/SW codesign
automation is correct. The main contribution of this work is to design an 802.16 channel codec to successfully verify a web-based HW/SW framework [1] which can design a MIPS-like processor core and integrate various EDA tools to achieve web-based compilation, assembly, simulation, synthesis, and VLSI layout. In general, a HW/SW codesign for the 802.16 channel codec is able to be accomplished by using the developed framework in less than two working hours. In addition, users can develop their design in C/C++ to make their research very efficiently. Noteworthy, more complicated algorithms need to be studied for the robustness of proposed web-based HW/SW codesign framework.

CONFLICT OF INTEREST

The authors confirm that this article content has no conflict of interest.

ACKNOWLEDGEMENTS

The supports from Chip Implementation Center (CIC) and various EDA vendors such as Cadence, Mentor Graphic, and Xilinx are sincerely acknowledged for this work.

REFERENCES


