Al-Qadisiya Journal For Engineering Sciences Vol. 3 No. 1 Year 2010 - 79 - FPGA REALIZATION OF SPEECH SCRAMBLING USING SPARTAN-XL ELECTRONIC PLATFORMS Abstract: - The Field Programmable Gate Array (FPGA) approach is one of the most recent category, which takes the place in the implementation of most Digital Signal Processing (DSP) applications. It had proved its capability to handle such problems and supports all the necessary needs like scalability, speed, size, cost, and efficiency. In this paper a new circuit design is implemented for speech scrambling with an implemented example using FPGA is provided. In this implementation the speech coefficients are evaluated on both the scrambled and the De-scrambled sides. This implementation was achieved using an FPGA Kit after building the logical circuits on the specified kit that uses the Spartan-XL electronic library type implemented using the ISE-4.1 software which is one of the latest versions of the Xilinx Foundation Series 2.1I software. Key words: Security, Data hiding, Speech Scrambling, FPGA, Spartan XL. ومات الكالم في تنفيذ الية اخفاء المعل) برمجة مصفوفات البوابات المنطقية(استخدام تقنية االلكترونية) SPARTAN-XL(بتطبيقها على رقاقات محمد ناصر الطرفي. د قسم هندسة الحاسبات والبرمجيات كلية الهندسة–الجامعة المستنصرية -:الخالصة أن أتساع الحاجة الى الرقاقات الرقمية ذات السرع العالية و الحجم الصغير و التي تمتلك قابليات عاليـة فـي مجـال عالجة المعلومات أصبح من المسائل الملحة التي تتسايق الشركات العالمية ألثبات قابلياتها في هـذة المجـاالت و مـن هـذة م و التي أثبتت أنها الرائد في FPGAالشركات شركة زايلنكس و التي أثبتت حضور منقطع النظير خاصةة بعد تطويرها لرقاقة .قابليات و أقل الكلفمجال معالجة األشارة الرقمية بأعلى ال في هذا البحث تم تصميم دائرة بأستخدام هذة الرقاقة الغرض منها تغيير ماهية الكالم ليتسنى أخفاء المعلومات الحسية و اليمكن تحديدها أال من خالل الدائرة األخرى التي تقوم بعملية أعادة الكالم الى ما كان عليـة قبـل أجـراء عمليـة أخفـاء .المعلومات Dr. Mohammed N. Al-Turfi Department of Computer and Software Engineering University of Al-Mustansirya Al-Qadisiya Journal For Engineering Sciences Vol. 3 No. 1 Year 2010 - 80 - المنتج Xilinx Foundation 2.1 و هو أحد النسخ المتطورة من برنامج ISE4.1 تم تنفيذ التصميم ياستخدام برنامج الـ لقد SPARTAN – XLمن قبل شركة زايلنكس على الرقاقة األلكترونية نوع Introduction Hiding, Scrambling, Encrypting, Coding…etc are the most important processes now a days since the type of wars is changed from the classical ones with bolts and guns to more effective and higher technology ones that uses information's and bits [Hussain,2000]. These great changes lead to change the type of data securing that fits these changes by using highly secured, complicated, large speed processing systems in order to be able to have the best response for such purposes [Hussain,2000]. The Field Programmable Gate Array (FPGA) technology was the remedy that takes the place in the fast electronic devices society and it had proved its fitness for handling tasks specialized with very fast, accurate, complicated processes. Where these tasks implemented with an exceptional efforts and costs. This lead to make these electronic kits are the new lead for a brand new branch in the designing of all digital systems specially the ones used for security purposes. The last ten years, all the companies that deals with electronic device productions were in a race with each other’s and time to be the initiative in the FPGA production field, because of the new word needs for this type of technology. Recently, Field Programmable Gate Arrays have enjoyed widespread use due to several advantages related to relatively high gate density, short design cycle, and low cost. They can be used in all applications that currently use Small – Scale Integrated circuits (SSI), Medium– Scale Integrated circuits (MSI), Large Scale Integrated circuits (LSI), and Programmable Logic Devices (PLDs). They also replace Mask – Programmable Gate Array (MPGAs) in many applications that are limited to 10000 gates and they do not need a very high operational speed.[ Hussain,2000] Speech is the one of the most important type of data since nearly 90% of direct dealings and direct data exchange is represented by conversations and conferences which leads to secured them as possible specially secret and top – secret ones. Since the amount of data in the speech specially for long periods of time is relatively large, then the circuit must have large capabilities and hence more complicated designs for transmitting and receiving the scrambled speech [1,2]. In this paper a new design for a circuit that can perform the speech scrambling on the transmitting and De-scrambling on the receiving sides are dedicated. The circuit operates in a high speed (Operating frequency is 1GHz). Short processing time and high accuracy (32 bit for the data 4 bytes at a time and five for control bit). Receiving data in many ways whether its serial or parallel and produce data in serial or parallel which made the circuit can be used for general purposes easily on both the transmitting and receiving sides. An example and experimental results that has been obtained from the processor is given and shown in this paper with circuit block diagrams to show the data flow and results on the circuit. Al-Qadisiya Journal For Engineering Sciences Vol. 3 No. 1 Year 2010 - 81 - FPGA Developed Environments The reason beyond choosing the FPGA for the implementation of nearly all the modern digital systems is its fitness for handling the high computationally expensive problems and cover its intensive need for the parallel processing or pipelining [3,4]. Therefore among the advantages of FPGAs some are: - 1. The replacement of the small-scale integrated circuits (SSI) and medium-scale integrated circuits (MSI) chips. 2. The availability of parts of the shelf. 3. Rapid turn around. 4. Low risk. 5. Some FPGAs have the ability of reprogramming. 6. Relatively low cost and flexible design. But its relative long design cycle is a disadvantage because its design process generally requires nine steps as follow : - 1. Entering the design in the form of schematic, net list, logic expressions, or HDL (Hardware Descriptive Language). 2. Simulate the design for functional verification. 3. Mapping the design into the FPGA architecture. 4. Placing and routing the FPGA design. 5. Extracting the delay parameters of the routed design. 6. Re-simulating for time verification. 7. Generating the FPGA device configuration format. 8. Configuring or programming the device. 9. Testing the product for undesired functional behavior. This long design cycle force the production companies to face a challengeble problem and hence force them to find suitable solutions. [5, 6, 7] Solutions are divided into four categories. The first one is consist of using the schematic approach for designing, which is used if the design elements and the circuit branches are well defined and their functions are specified. The second one is consist of using the Very high-speed integrated circuits Hardware Descriptive Languages (VHDL), where this category is used with looping or iterative processes. The third one uses the Finite State Machine (FSM) which uses with the control circuits, which have small numbers of inputs and outputs. Any of the above categories can be merged together to form a new combination for handling new jobs. For example, we can implement a control circuit in an FSM part to control the process flow of a certain function implemented using the schematic approach. The fourth category uses the high level language which is called the SYSTEM C4 or SYSTEM C5 [8]. This branch is a wild force PCI plug in board with 5-15 Processing Elements (PEs) with a 1MByte imbedded memory attached to each PE, and other inter connectors like FIFO, Crossbars, Single Inline Modules Data (SIMD). Al-Qadisiya Journal For Engineering Sciences Vol. 3 No. 1 Year 2010 - 82 - This board is installed by its installation software after its placement in the motherboard of the personal computer, where this kind of kits operate on 1,3,5,10,20,33,66 MHz clock frequency with large number of inputs and outputs and wide range of function control and implementation [Chan,2000]. Speech Scrambling One of the most important strategies for data hiding that is used in data security category is speech scrambling. Speech scrambling that will be discussed in this paper will consider that 95% of the phone lines uses the 56KBit/Sec Fax-Modem where the speech sample consist of 8 bits and the maximum bit rate of the phone line is 64 KBit/Sec. (Assuming the last intelligent frequency component in the speech is 4KHz. Using Nyquest rate so we will have 8KSample/Sec. With 8Bit/sample will lead to have a bit rate of 64KBit/Sec.) [Gilbert,2003 and Shafer,1982]. Speech scrambling depends upon the implemented scrambling functions inside the processing circuit because as much as the scrambling function is complex it’s difficult to be broken. But at the same time it will be time consuming and in need for more operations to handle the task which leads to make the circuit in need for more processing power (this means that the design is in need for more electric power and high-speed components with more complex circuit design)[ Gilbert,2003 and Figueroa ,2003]. In this paper speech scrambling is first performed by reversing the order of the bits of each sample. Then the system proceeds to perform the scrambling process on the modified sample. At the end of the process, the data will be ready to be transmitted. On the other side, the data must be Re-scrambled in order to reverse the order of the bits of each sample and then retrieve the original sample where the speech data now are the same as the ones at the start of the process. FPGA Simulation of Speech Scrambling Systems This paper shows a new method for designing an FPGA digital circuit for the evaluation of the coefficients of speech scrambling implemented using the ISE-4.1 software produced by Xilinx Company for FPGA electronic kit productions which represents one of the most recent updates for the Xilinx Foundation Series 2.1i. Therefore the simulation process should pass through four stages as follow. The problem formulation and function establishment represents the first stage. In this stage the general features of the problem are identified in order to specify the needs for the problem solution. In the other hand; the function establishment is very important to specify the necessary equipments and devices for function implementation where the limitations and boundaries are defined. The second stage is represented by over coming the limitations and difficulties in a reasonable way keeping an eye to the over all cost. While the implementation of the function must be optimized as much as possible in order to specify the type of the FPGA kit, size, capabilities, frequency ranges, number of inputs and outputs, power consumption, scalability, and compatibility. Operating the optimized designed kit represents the third stage. Generally in this stage two important problems are appearing, the first one is represented by the timing problem, which is the Al-Qadisiya Journal For Engineering Sciences Vol. 3 No. 1 Year 2010 - 83 - most important. The second one is represented by the production of the undesired results and values through the operating process and the way to get rid of them where most of these values are produced due to the timing problem. The fourth stage is represented by connecting the designed kit to the operating environment and search for its compatibility and the best ways for operating in the presence of other system equipments. Therefore it’s preferred to choose the kit type, as near as possible to the type of other system equipment’s in order to reduce the compatibility problems. Or if it’s possible and not costly to change the whole system since the FPGA kits are relatively of low cost. For the first stage, specifying the scrambling function represents the problem formulation where this function specifies the type of speech processing and the way of dealing with each bit of the speech sample For the second stage, the FPGA kit for the implemented design is SPARTAN-XL .The SPARTAN- XL 1.8V FPGA gives high performance, abundant logic resources, rich features set, all at exceptional low price. This family contains seven members offers density range from 50000 to 600000 system gates with wide operating frequency range (500KHz – 2.5GhHz)[8,9], delivering more I/Os and other features per dollar than other FPGAs by combining advanced process technology with a streamlined architecture based on the proven Vertex-E. Features include Block RAM (288 K bit), Distributed RAM (221K bit), 19 selectable I/O standard, 4 DLL (Delay Locked Loop), Fast Predictable Interconnection means that successive design iteration continue to meet timing requirements [Chan,2000 and Gilbert,2003]. The third stage depending upon the type of application, its operating frequency, its operating speed, and its response time. For example if the system is dealing with speech signal then the highest possible frequency component does not accede 6KHz in any way. While in target identification the image verification must be real time and very accurate with a very high response speed for direction changing. Or if systems are not in need for high speed and have symmetry in their circuits architecture then these symmetric circuits can be combined in few ones and the operations may be performed in sequence, or else redundant circuits will be built to perform parallel processing or pipe lining to achieve the necessary operating speed The fourth stage is represented by implementing the whole system from its receiving point to its transmitting point since the used kit is more than enough to handle this task from size, speed, accuracy, cost. So; building the whole system on the same kit reduces the compatibility problems to the minimum. Demonstrated Example In this system we have 5 control bits control the flow of the process. These bits prepare each stage to receive the data from the stage before it whenever the data are ready and the stages are in the best situation to perform the data exchange. When the receiving Serial – In – Parallel – Out Shift register finish the reception process, the control circuit signal to the reversal latch to receive the data from the shift register in a reversed mode. Now when the data settle in the reversal latch the control circuit resets the shift register and enable the scrambling latch to receive the reversed data and scramble it. Al-Qadisiya Journal For Engineering Sciences Vol. 3 No. 1 Year 2010 - 84 - The data at the output may be received in a parallel form or in a serial manner according to te application it self. Figure (1) shows the circuit designs. Figure (2) shows the circuit-timing diagram and the system output for the input applied to the circuit. Table (1) shows the bit stream response of the system from the bit entrance to their outlet. Figure (3) shows part of the report prepared by the software gives full details about the kit resources and the amount used by the circuit design. At the De-scrambling side the circuit will De- scramble the bits in a parallel manner in the De-scrambling latch and they will enter the reversing latch in order to obtain the original speech samples. Figure (4) shows the De-scrambling circuit designs. Figure (5) shows the circuit-timing diagram and the system output for the input applied to the circuit. Table (2) shows the bit stream response of the system from the bit entrance until the circuit obtains the original speech samples. Therefore the forward and backward speech scrambling phases can be represented by the flow charts shown in Figure (6) & (7) respectively:- Conclusions This paper is to propose a new circuit design for the implementation and evaluation of speech scrambling systems using the FPGA platforms. In this type of designs we are not in need for the wide range of circuit design in which we reduce the cost. And because of the kit wide capabilities high speed, high accuracy, low cost, low power consumption, so the transmitting and receiving circuits may be implemented on the same platform. Other advantages is achieved by overcoming the disadvantage of the conventional speech scrambling systems that suffers from, where the data may appears byte by byte (serially) or they may appear in parallel form. This needs no large circuit to handle this task or it needs a global synchronization to keep system accuracy where any simple combinational circuit can handle the job properly. With all what had mentioned above, the high speed circuit can handle several tasks at a time because in many applications the speech bit rate is not in need for very high speed circuits to be 1GHz operating frequency which leads to implement Several – In – One tasks. These will reduce the time, place, cost, power, and complexity where the same circuit may occupy many speech channels at a time. References [1] Mohammad N.Hussain, “Speaker Recognition Based Upon Phonemes Using Wavelet Packet Transform” Msc. Thesis, University of Baghdad, department of electrical engineering, October 2000,. [2] N. Rex Dixon & Thomas B. Martin “Automatic speech and speaker recognition “ 1989.A volume in the IEEE press selected reprint series. [3] L.R.Rabiner & R.W. Shafer “Digital processing of speech signal” Book , 1982. [4] Lawrence Rabiner & Biing – Hwang Juang “Fundamentals of speech signals” Book, 1993. [5] Piyush Jamkhandi, Amar Mukherjee, Kunal Mukherjee, Robert Franceschini, school of electrical engineering and computer science, “ Parallel H/W- S/W architecture for computation of multi- wavelet transform using RMF algorithm”. Report , July 2003, Al-Qadisiya Journal For Engineering Sciences Vol. 3 No. 1 Year 2010 - 85 - [6] Sarin George Mathen, thesis, University of Kansas, “Wavelet Transform based adaptive image compression on FPGA”. Book , June 2000 [7] www.Xilinix.com, “Spartan-XL 1.8 V FPGA family: introduction and ordering information’s”. July 2003, Company Production Catalog. [8] Pak K. Chan, University of California, “Digital Design Using Field Programmable Gate Array”. Book , October 2000. [9] John E. Gilbert , “Coding: theory and applications on FPGA”. Book , September 2003, [10] Miguel Figueroa , Chris Diorio, University of Washington , ,”A 200 MHz , 3mW,16-Tap Mixed –signal FIR Filter”. Company Production Catalog , September 2003 Table (1) The Scrambling system bit flow table D at a In pu t Circuit Reversing and Scrambling D at a O ut pu t 10 01 10 01 10 01 10 01 99 01 00 00 00 4O 10 01 10 01 10 01 10 01 99 11 11 11 11 FF 10 01 10 01 10 01 10 01 99 10 11 11 11 B F 10 01 10 01 B it - R ev er si ng 10 01 10 01 99 B it - Sc ra m bl in g 00 00 00 00 O O Table (2):The De-Scrambling system bit flow table D at a in pu t Circuit Reversing and Scrambling D at a O ut pu t 01 00 00 00 4O 10 01 10 01 10 01 10 01 99 11 11 11 11 FF 10 01 10 01 10 01 10 01 99 10 11 11 11 B F 10 01 10 01 10 01 10 01 99 00 00 00 00 O O B it – D e- S cr am bl in g 10 01 10 01 B it – R ev er si ng 10 01 10 01 99 http://www.Xilinix.com Al-Qadisiya Journal For Engineering Sciences Vol. 3 No. 1 Year 2010 - 86 - Figure (1) The circuit design for speech scrambling Figure (2):- Timing Diagram for the i/p & o/p data of the circuit Al-Qadisiya Journal For Engineering Sciences Vol. 3 No. 1 Year 2010 - 87 - Figure (3) part of the report that pr epared by the software about the circuit Al-Qadisiya Journal For Engineering Sciences Vol. 3 No. 1 Year 2010 - 88 - Figure (4) The circuit design for speech De-scrambling Figure (5) Timing Diagram for the i/p & o/p data of the circuit at the De-scrambling side Al-Qadisiya Journal For Engineering Sciences Vol. 3 No. 1 Year 2010 - 89 - Data Receiver (MIC or File) Data Processing Sampling Frequency Precision & Accuracy Is Data Process finished NO Yes Pass the data to the input shift register 4 Byte ,32 bit , serial – in – parallel – out shift register Is Data input finished Yes NO Shift the data in order to be Scrambled Parallel bit Scrambling to reduce Scrambling Time Pass the data to the output shift register 4 Byte ,32 bit , parallel – in –serial – out shift register Is Data output finished Yes NO Scrambled Speech Data to the file or speaker End Start Figure (6) The forward phase of Speech scrambling process Al-Qadisiya Journal For Engineering Sciences Vol. 3 No. 1 Year 2010 - 90 - Data Receiver Data Preparing for processing Is Data preparatio n NO Yes Pass the data to the input shift register 4 Byte ,32 bit , serial – in – parallel – out shift register Is Data input finished Yes NO Shift the data in order to be De-Scrambled Parallel bit De-Scrambling to reduce De-Scrambling Time Pass the data to the output shift register 4 Byte ,32 bit , parallel – in –serial – out shift register Is Data output finished Yes NO Original Speech Data End Start Figure (7) The backward phase of Speech scrambling process