Multimedia web services FPGA Quality of service VHDL
I. INTRODUCTION
The widespread of design on FPGA is attributed to several characteristics including parallelism, low-power consumption, ability to be reprogrammed, affordable cost, availability of design tools and invulnerability to software attacks. Parallelism and low-power consumption is compelling for embedded systems and distributed applications such as MWS. FPGAs offer numerous advantages to engineering domains such as prototyping for ASIC, academic research [1, 2, 3, 4, 5] spacecraft and high-energy physics [6] . Compared to FPGAs, ASICs offer low area on Silicon, better performance and low-power consumption. On the other hand, design on FPGA offers parallelism, short time-tomarket, affordable and flexible platform for prototyping and academic applications. For designs on FPGA, the maximum clock frequency is limited by the placement of modules and on the area they occupy within the FPGA chip. The parallelism aspect of FPGA is relevant in accelerating various intensive processing tasks, such as compression algorithms for multimedia manipulation, for regular expression matching [7] and real-time multi-face detection [8] for video surveillance applications. The flexible hardware aspect of FPGAs makes them appealing to the design of Web services for their inherent immunity against software viruses, for instance. These advantages have motivated our research work through the utilisation of FPGA in high-quality, secure and high-performance MWS. Several realisations of MWS focus on lightweight services with modest sizes of data, while others are based upon intermediary microprocessor module to accomplish Web services on FPGA employing a specific flavour of Linux kernel. Although the exploitation of already available libraries for communication is between the FPGA and the Web through the Ethernet port may facilitate the development on FPGA, this reduces significantly the performance and efficiency. However, different Web services were successfully designed on FPGAs without necessarily focusing on the QoS. In contrast to that, in this paper we demonstrate our design and realisation of high QoS MWS on FPGA through incorporating a Physical Layer module [9, 10, 11] and different Hardware Description Language (HDL) mod-ules targeting different layers of the Open Systems Interconnection (OSI) model. The Representational State Transfer (REST) style of Web service design is proven to be more efficient and of lighter weight compared to the Simple Object Access Protocol (SOAP) MWS . Previous research articles show the relevance of using REST style rather than the SOAP protocol for the design of MWS [12, 13, 14, 15] . Therefore, we have designed an image-retrieval RESTful MWS, which utilises FPGA development boards from Digilent [16, 17] , pure HDL code, opensource modules and free design tools. The rest of this paper is organised as follows: In section III, we present an overview of related works. In section IV, we present a VHDL design example of a UDP and ARP packet sender on FPGA, which can be integrated into a MWS on FPGA. Following the design example, a design of an imageretrieval MWS was accomplished utilising Xilinx Spartan 6 FPGA [18] on the Nexys3 board, which is briefly presented in V for the sake of brevity and further details are left for an upcoming paper. Section VI contains our conclusion and future work.
II. RELATED WORK
On Web services design on FPGA. The work in [19] aims at reducing implementation time and effort to create flexible and high performance Web services. The design is simplified through the utilisation of high level programming languages and on some intermediary modules on FPGA, namely the NIOS II micro-controller. This facilitates design by taking advantage of existing libraries. The work in [20] presents a MWS for interfacing some specialised laboratory equipment on campus with remote endusers who are equipped with PDA's in order to get visual feedback. The realisation includes a Web server and FPGA Spartan-3E board and a Web-cam. The design takes into consideration the low processing resources in PDA's. Unlike our work, the work in [20] focuses the attention on the usefulness of the features rather than the QoS and performance. The work in [21] presents an Internet communications service between PC and FPGA through a Web page, based upon the SOAP protocol. The service enables data transfer through the Ethernet port by utilising a custom transport protocol that is based upon raw sockets. The custom protocol utilised provides a simple solution for communications by avoiding the complexity of implementing a TCP/IP stack on FPGA. Unlike the work in [21] , our work is based upon a TCP/IP stack, which provides a RESTFul and compatible Web service. The works in [22, 23] describe the use of an FPGA-based system to attack a crypto-processor deployed in a banking infrastructure, based upon Data Encryption Standard (DES). The authors demonstrate the utilisation of pipelined solution and replication processing blocks on FPGA, as two valid and efficient schemes. The work in [24] proposes a security solution based upon FPGA for multimedia applications on wireless LAN, which reduces the processing delay. By moving the processing load of security to the end systems' CPUs and by disabling the default security schemes, the performance could be augmented considerably, by 3.7 folds. Our work can be essentially distinguished from other works by focusing on designing and implementing high QoS and high performance MWS, where the payload data are in binary format (images, voice and video) rather than text and eXtensible Markup Language (XML). We also cover up a wider range of data sizes, which are more realistic and common to MWS. In order to efficiently profit from the hardware resources on FPGA, our proposed architecture is completely realised with HDL without the addition of CPU modules on FPGA.
III. DESIGN EXAMPLE OF A UDP/ARP PACKET SENDER ON FPGA This section presents a design example of a User Datagram
Protocol (UDP) and Address Resolution Protocol (ARP) packet sender module at a rate of 10 Mbps, which can be utilised for test purposes or in a simple video on-demand MWS. This section aims at presenting a design example that leads to seamless creation of MWS on FPGAs. The design in this section concentrates on the lower layers of the OSI [9] model, i.e., the data link layer, including its Media Access Control (MAC) sub-layer, and the physical layer (Phy). We have opted for the Spartan 2E FPGA on the D2SB [17] board that does not have an integrated Ethernet port. Therefore have built a custom 10-Mbps Ethernet extension card in order to enable communications for MWS through the Ethernet port. The D2SB board and the designed Ethernet extension card are shown in Figure 1 . A complete MWS was accomplished on the Nexys3 board, which has an integrated Phy chip and one RJ-45 port that could not presented in this paper for the sake of brevity. The features of the D2SB platform, which is con-nected to our module (as shown in Figure 1 ) can be summarised as follows: • ROM used to store the generated programming files. [26] . Indeed, the availability of open-source HDL modules enhanced production for research and industry.
A. I/O Standards Phy Modes Supported by FPGA
Since FPGA is programmable hardware, it is essential to have some relevant knowledge about digital hardware and logic design. Though the syntax of HDL has much in common with software and computer languages, HDL has its own particular aspects and purpose [1] .
B. Designing and Building an Ethernet Extension Board
We have built several prototypes of an Ethernet extension board that enabled us to investigate the use of single-ended and differential signals into the FPGA as well as to evaluate several schematics and layouts using Computer Aided Design (CAD) software, such as geda schem, geda pcb, kicad, DipTrace and Eagle. The schematic diagram of the final prototype has been achieved with geda schem as depicted on Figure 2 . The following components are shown on both 
C. Overview of Software Tools for FPGA
The design on FPGA necessitates specific software tools in order to write HDL modules, simulate HDL, synthesize code, and program the FPGA. Software tools for FPGA are hardware-dependent, such as Xilinx Webpack with isim simulator. We limit our discussion to Xilinx-related tools since we utilised only FPGA chips from Xilinx, which is supported for Windows and Linux. We therefore opted for Xilinx on Debian Linux as our development platform, which proved to be user-friendlier and very productive. We utilised several testing tools including packet-sniffing and packet-generation tools, such as Wireshark and packeth. In addition, tools like wget, curl and SocketTest were used for checking TCP and HTTP packets. Wireshark software is used to capture different types of packets such as UDP and ARP. In addition, some packets are selected and viewed on the LCD (on a separate card attached to the D2SB card), for which we have utilised a FIFO memory and a dedicated state machine 
IV. REALISATION OF A HIGH QOS IMAGE-RETRIEVAL MWS ON FPGA
In this section, we provide details about the design and the implementation of a high QoS image-retrieval MWS on the Nexys3 FPGA board, as depicted on Figure 3 . We provide a complete design and realisation of a MWS on FPGA that concentrates mainly on the higher layers of the OSI model, whereas the previous design in section IV concentrates on the lower layers of the OSI. This section also concentrates on the service logic of the MWS as well as on several QoS parameters. The realisation of MWS on FPGA in this section is inspired by the design example presented in section IV. The Nexys3 board is equipped with Spartan 6 Xilinx XC6SLX16 FPGA and offers several peripherals, such as an RJ-45 port and Phy chip. Compared to the previous FPGA board used in section IV, the Nexys3 board is equipped with all necessary peripherals for the design of sophisticated Web services without the need for any additional hardware. We have investigated several open-source projects (cores), of which the Ethernet MAC 10/100 Mbps project has been adopted and tailored in order to suite our MWS on the Nexys3 board. This module was selected for two reasons: 1) It offers compatible MII standard with the Phy available on the Nexys3 board 2) It has multiple features such as: • Preamble generation and removal. • Automatic padding for short frames before transmission. • Detection of too long or too short packets. • Ability to transmit large packets. • Full duplex support. • Supported rates include 10 and 100 Mbps. The first step of adapting the Ethernet module was to connect the Phy (see section IV-A) input and output (I/O) signals to the FPGA through the user constraints file of the Nexys3 board. Setting up the operation mode of the Phy (i.e., 100 Mbps in full-duplex mode) on the Nexys3 board has been done through the addition of several I/O buffers. This has been achieved through a careful study of the datasheet of the Phy chip on the Nexys3 board. We have written a FSM module in VHDL to initialise the different configuration registers and provided input data for the Wishbone in order to activate the transmission module. Besides, we have added two RAM modules to save the received and transmitted packets. The Wishbone is a data communications standard for exchanging the frames to be sent and received between the memory and the Ethernet core. For test purposes, we have added new modules in order to generate fixed-width UDP and ARP packets that are transmitted periodically every one second. This phase has been successfully achieved throughout the FSM for the Wishbone interface module that we have developed using tools like StateCad [27] . Although the Ethernet MAC 10/100 Mbps project offers a rich set of options and features, its documentation lacks some critical information about the operation of the Wishbone interface, which has caused extra delays for the design of the receiver module. In order to avoid design-related delays, we opted for the adaptation of a second HDL project core, namely, the TCP/IP socket, of which the characteristics are compared to other technologies. The TCP/IP socket project is compelling since it offers a TCP/IP stack and a working example of a simple HTTP server, which offers an interface page in HTML. Several improvements have been done to meet our requirements. For example, we worked closely with the original author of the module in order to provide support for the MII Phy standard of the Nexys3 board. V. CONCLUSION Parallelism, programmable in-memory design, af-fordable cost, availability of design tools and low-power consumption make FPGA a highly compelling alternative for computers in several domains, including MWS. FPGAs provide ex-cellent platforms for ASIC prototyping and for secure multimedia Web services. The widespread of parallel processing and pipelined solutions on FPGAs have opened the way for time-consuming and processing-intensive applications. Our contributions in this article can be summarised as follows: 1) We present a design example of a UDP/ARP packet sender on FPGA, which is intended to inspire new designs of MWS on Spartan 2E FPGA and is focused mainly on the lower layers of the OSI model. 2) We elaborate on a more sophisticated design of high QoS MWS on Spartan 6 FPGA based upon pure HDL and opensource VHDL modules.
3) We elaborate on our design, implementation tools and environments. The second design represents a thorough approach to the realisation of a low-power, and secure RESTful image-retrieval MWS on FPGA, which concentrates on the upper layers of the OSI model. For the sake of brevity, some details about test cases and results could not be included in this article. For larger payloads, the MWS on FPGA is to out-perform their computer counterparts by several folds, since the lager image sizes mean longer processing times, i.e., the MWS threads would be served more frequently by the CPU.
A. Future Work
We plan to extend our approach to include more QoS parameters such as response time, download time, processing time, rapid compression, availability, throughput and security. Our future work would concentrate on rapid compression, availability, throughput and security. After discussing the use of text and image payloads, we would include more multimedia types, such as video and voice. The work in this paper can be extended to include specialised QoS management modules for Web service workflow interactions with minimum overhead cost in order to enhance the design and realisation of high performance and high fidelity MWS. The role of the QoS management module is to perform negotiation, agree-ment and to monitor different QoS parameters and service interactions. The Web service interactions workflow module is to prevent, detect and resolve Web service interactions that may occur during operation. We plan to add more features to our MWS, such as enabling the transfer of large files, by integrating new HDL modules to regulate data transfer with recovery and resume options utilising the chunked-transfer encoding of the HTTP/1.1 protocol.
VI. ACKNOWLEDGMENT
We thank Mr. Jonathan P. Dawson for his valuable support and collaboration regarding the adaptation of the MII inter-face of the TCP/IP socket to the Nexys3 board.
