Index Terms-Advanced telecommunications computing architecture, field programmable gate array, firmware upgrade, high-energy physics, micro telecommunications computing architecture, programmable devices.
I. INTRODUCTION
T HE modern control and data acquisition systems used in large-scale physics experiments are designed with programmable devices, like processors, Digital Signal Processors (DSPs) or Field Programmable Gate Arrays (FPGAs) [1] , [2] . The firmware for those system components is usually stored in non-volatile memories. During the firmware development dedicated programmers are used. The tools provided by manufactures allow downloading firmware to non-volatile PROMs (Programmable Read-Only Memories) and provide a useful debugging functionality. Programmers can be connected using standard JTAG or proprietary debug connectors. Since xTCA systems are composed of various Advanced Mezzanine Cards (AMCs) or Advanced Telecommunications Computing Architecture (ATCA) modules, which may include various programmable devices, a large number of different tools can be required. The or ATCA chassis may house, respectively, up to 12 or 16 cards. In the case of the laboratory development, the firmware upgrade is performed using only a few dedicated programmers, upgrading each programmable device one by one. The situation is more difficult when the xTCA hardware is used to control a complex machine. In this case, the devices cannot be easily accessed. For example, the Low Level Radio Frequency (LLRF) control system of the European X-ray Free Electron Laser (EuXFEL) will be installed inside the accelerator tunnel. The system will be composed of hundreds of programmable devices. Therefore, the firmware upgrade cannot be performed using only programmers. Along with the deployment of complex control or data acquisition systems, the need for the remote and automated firmware upgrade solution becomes more and more important. An universal framework and set of tools for upgrading firmware in xTCA systems has been developed and tested. The proposed framework uses a fat pipe region interface of backplane for firmware data transmission and the Intelligent Platform Management Interface (IPMI) standard for the PROM memory management and control of the upgrade procedure. The proposed Firmware Upgrade Framework (FUF) has been tested with the -based LLRF control system of the Free Electron Laser at Hamburg (FLASH).
II. FIRMWARE UPGRADE IN DATA ACQUISITION AND CONTROL SYSTEMS
The xTCA standards do not specify the firmware upgrade procedure for payload devices [3]- [6] . The firmware upgrade can be performed using different methods during debugging, work in laboratory or in-system development.
A. xTCA Standards Family
The and ATCA standards, collectively known as xTCA, provide a flexible and scalable infrastructure for designing complex control or data acquisition systems. Both were designed to provide developers with methods for achieving high Reliability, Accessibility and Serviceability (RAS) in high-throughput computing and telecommunications platforms [6] , [7] The ATCA chassis contains power entry modules, a fan tray, Shelf Managers, a backplane and a number of card slots. Almost every built-in system is doubled to ensure high reliability by means of redundancy. Another factor increasing the reliability is continuous monitoring.
The Micro Telecommunications Computing Architecture (MTCA, uTCA, ) may be considered as a smaller and cheaper variant of the ATCA [4] . A chassis hosts up to 12 Advanced Mezzanine Cards (AMCs) [8] . The 0018-9499 © 2013 IEEE TABLE I  A SUMMARY OF MEMORY SIZES IN CURRENTLY AVAILABLE PROGRAMMABLE  DEVICES standards offers similar thermal, power and link management capabilities as ATCA.
B. Programmable Devices in xTCA Systems
Programmable devices provide flexible resources that can be easily adapted to increasing demands of modern control and data acquisition systems. Because of high complexity and a wide range of functionality, these systems include various types of programmable devices. Depending on the needs, microcontrollers, DSP processors and FPGA devices are applied. The most important feature from the firmware upgrade procedure's point of view of those devices is the size of program memory. It explicitly influences the amount of data which has to be sent to the device and, in consequence, the programming time. Table I presents program memory sizes for programmable devices which are currently available on the market. In the case of the microcontrollers and DSP processors the size of the program memory usually ranges from several kilobytes up to a few megabytes, taking the solutions without operating systems into consideration. FPGAs are more demanding. In their case, sizes of memory for programming range from several to tens of megabytes [9] , [10] .
1) Firmware Upgrade in Laboratory:
Due to the size and write speed of currently available Flash memories, their programming time is in the range of few seconds to several minutes. When the system is in the initial development stage, programs or bitstreams (FPGA configuration files) are loaded directly to the SRAM memory of the device using dedicated programmers. Moreover, these devices often provide essential trace and debug capabilities. In such an environment the remote upgrade of Flash memories neither increases the comfort nor reduces the time of programming the device. Nevertheless, it is an optimal phase to evaluate the firmware upgrade feature, as consequences of an improper operation are negligible and the debugging is relatively easy.
2) In-System Firmware Upgrade: When the system is finally assembled and e.g. mounted in a dedicated shelf, it is no longer easily accessible. The use of debugging tools is usually limited or even impossible at all, which is the case with systems installed inside the accelerator tunnel. If the system is not proven to be free of bugs, some mechanisms for upgrading the firmware have to be implemented. On the other hand, when the system is known to work perfectly, it is still worth implementing this functionality to have the possibility of extending the set of its features.
C. Firmware Upgrade Methods

1) JTAG Interface:
The programming of programmable devices using JTAG is described by the IEEE 1532-2002 standard [11] . When the system is composed of several boards, making a large chain of all programmable devices is not practical. For VME systems the Module Test and Maintenance Bus [12] is a standard way of accessing JTAG chains of individual boards [13] .
The specification [4] defines the JTAG connections on the AMC modules and an appropriate backplane, that can be optionally connected to a JTAG Switch Module (JSM), providing independent access to chains of all the boards in the system. Systems equipped with this module are available commercially [14] - [16] , however the crates chosen for the EuXFEL control [17] do not support this type of connections.
The main advantage of the direct JTAG connection is a fast FPGA programming and firmware debugging capability. It is a fast way to reprogram FPGA device, however reprogramming of parallel or serial PROMs takes usually from a few to dozens of minutes.
2) Direct Bitstream Upload: If the FPGA firmware adheres to specific conventions, it is possible to configure the device via PCI Express. FPGA manufactures provides solutions for partial reconfiguration, e.g.: Altera's Configuration via Protocol [18] , [19] or Xilinx's partial reconfiguration [20] , [21] . Using this method allows the firmware to be seamlessly updated, without the need to reenumerate the PCIe bus. However, the PCIe configuration (e.g. number and size of BARs) has to be fixed and known in advance.
This method allows fast programming of FPGAs. However the firmware must be divided into partitions. This method is not suitable for upgrades of PROMs.
3) Indirect Programming: In this programming method, the boot memory (PROM) is configured indirectly via the device it configures, and then the device is programmed from this memory. This approach requires a re-enumeration of the PCIe bus, as the programming process breaks the communication with the device. To ensure a proper recovery when the system is inaccessible, it is important to have the possibility of restoring the programming capability if the upgrade process should fail. To obtain this functionality, the use of at least two Flash memories is recommended. One of them always contains the firmware with a working programmer module. The other may contain a user application with or without the programmer module. Another possibility is to use multiple revisions of the same Flash, although this approach is less reliable. The programmer can be also integrated with the application firmware. Xilinx XSVF player [22] can be used for PROM reprogramming or the solution described in [23] , requiring a slightly more complex module inside the FPGA. If this indirect method is used via Ethernet, typically an embedded processor is used (e.g. Xillinx Microblaze or Altera Nios) [24] . Using multiple memories or multiple revisions (one for the programmer, optionally integrated with the known working revision of the firmware) requires some means of choosing the memory to boot from. Preferably, this task is assigned to the IPM controller (MMC in case of or IPMC on ATCA-based systems).
The indirect programming allows upgrading FPGA PROMs using various media (e.g. PCIe, Ethernet, USB, etc.). The programming can performed even faster than using manufacturer's programmer.
4) Hardware Platform Management IPM Controller Firmware Upgrade:
For xTCA systems, the on-board CPU and other hardware is known as a payload. PICMG does not define the standard to configure the payload, leaving it to the system developer. It only defines the standard to upgrade the firmware of the IPM controller (MMC or IPMC), required on every board [25] . It can be used for our purposes if we treat the programmable device firmware (FPGA or DSP) as a part of IPMC. This method can be used for programming both: FPGAs and PROMs. The main drawback of this solution is the low throughput of the bus (100 kbit/s) and therefore the long programming time of the payload device or memory. This method is not suitable for the firmware upgrade in complex systems however it could be helpful in emergency situations for direct programming when the programmer firmware is not available, for example: both PROMs were incidentally erased.
III. LLRF CONTROL SYSTEM
The Low Level Radio Frequency (LLRF) system for the Freeelectron LAser in Hamburg (FLASH) controls the phase and amplitude of the electromagnetic field inside superconducting cavities of the linear accelerator. A field stability of the order of 0.01% for amplitude and up to 0.01 in phase at 1.3 GHz is needed to provide required possible electron beam quality [26] - [29] . The control loop latency must not be larger than a few .
The system first measures field intensity in up to 32 accelerating cavities powered by one klystron (high power RF amplifier) and then calculates the corresponding phases and amplitudes. These parameters are sent to a control board, where all the vectors are added and compared with a set point. The controller calculates a required field correction and actuates the vector modulator supplying the klystron with an RF signal.
The control over high-speed ADCs and DACs, data transfers over backplane or optical links and the calculation of the vector sum is implemented using FPGAs. These operations may be efficiently realized in parallel hardware blocks. The control algorithms may be implemented using an additional DSP chip, that can execute complex floating point operations, or also using the FPGA resources. New FPGA devices offer slices containing wide multipliers and accumulators that are well suited for DSP operations.
The prototype LLRF control system of the FLASH accelerator is based on the standard. The system uses all components required by the standard, such as CPU (Central Processing Unit), MCH (MicroTCA Carrier Hub) and dedicated AMC modules containing FPGA and DSP devices. These modules include:
• -the signal processing module, the main controller, • SIS8300-digitizer cards with 10 ADC channels, • -Vector Modulator, • DAMC2-the general purpose FMC-carrier module, • -the timing card. The chassis housing AMCs with available interfaces is presented in Fig. 1 .
The board, equipped with Xilinx Virtex 5 FPGA and TigerSHARC DSP programmable devices, is intended to cooperate with a vector modulator RTM [30] , [31] . Therefore, the JTAG chain of the includes the main FPGA and the devices available on the RTM: Spartan 6 FPGA and Platform Flash, see Fig. 2 .
The board is equipped with three non-volatile SPI PROMs. The size of a single PROM is 128 Mbits. The MMC (Module Management Controller) is used to select the active PROM using custom commands. The reconfiguration of the devices may be forced by the Payload Reset IPMI command. The completion status of this operation can be monitored via MMC. The FPGA may access SPI memories at run time, for both reading and writing. This enables storing of the DSP firmware in the Flash memory. As there are three SPI memories, one of them can store the emergency bootloader bitstream that can be used to program the remaining memories. The other two can store firmware for the FPGA and DSP. The RTM FPGA and Platform Flash can be programmed using the main FPGA on the as a JTAG programmer. All devices can be programmed using an additional JTAG connector and an external programmer.
The RTM is dedicated to operate with the AMC card. Both cards are connected via the zone 3 connector that provides data, management and JTAG signals. The uses a Spartan 6 FPGA with a single Platform Flash. The JTAG chain is connected to the main FPGA of and included in its chain when the RTM module is plugged into the chassis, see Fig. 2 . There is no control of Platform Flash firmware revision so only a single revision is provided. The FPGA is rebooted automatically after a successful upgrade of PROM.
The SIS8300 board has only a single Platform Flash PROM (32 Mbits) [32] . The PROM can be programmed only via JTAG. For that purpose, the entire JTAG chain, consisting of the Platform Flash and FPGA can be connected to the JTAG connector, on-board MMC or the FPGA pins as presented in Fig. 3 . Switching between the MMC and FPGA programmer is performed by the MMC controller via custom IPMI commands. During the normal operation the FPGA can be used as a programmer to update the firmware stored in PROM revisions.
The Platform Flash is capable of storing two firmware revisions. It is possible to switch between them via the MMC controller. The first revision should contain the emergency bootloader; the second one can be updated independently and should contain the actual user firmware. It is possible to force the reboot of the FPGA by the MMC controller, but it is not possible to read the boot completion status.
The DAMC 2 board has a single Platform Flash PROM connected in a serial mode (32 Mbits) [33] . The JTAG chain includes the PROM and the main FPGA. In addition, the FMC (FPGA Mezzanine Card) module can be included in the chain. The JTAG chain can be programmed using a JTAG connector, JTAG pins available on the AMC connector, MMC and the main FPGA (configuration is available via custom IPMI commands). The detailed description of JTAG configuration and programming possibility can be found in the datasheet [33] . The Platform Flash is capable of storing two firmware revisions as in case of SIS8300 card. It is possible to switch between them using the MMC controller.
A. Requirements for LLRF Firmware Upgrade
The firmware upgrade infrastructure should allow downloading firmware for programmable devices of the following LLRF system components installed in the shelf: • Digital signal processing controller module [31] , • Vector Modulator [30] , • Digitizer module (SIS8300) [32] , • General purpose FMC-carrier module (DAMC2) [31] , [34] 
B. Chosen Method for Firmware Upgrade
The framework is supposed to be used for in-system firmware upgrade therefore the programming time is not so important.
Two types of non-volatile PROMs are used in the LLRF system: SPI and Platform Flash. Therefore, the infrastructure should allow reprogramming the PROMs, changing the active revision (rollback after an unsuccessful upgrade) and rebooting the FPGA. The HPM.1 standard can be applied to firmware upgrades. However, the IPMI protocol of uses the protocol for data transmission. Therefore, the transmission of a few megabits firmware takes a significant amount of time (e.g. 15 minutes for a single revision of Xilinx XC5VLX50T). The PCIe protocol can be used to make the transfer faster [35] Finally, the indirect programming with PCIe interface was chosen for firmware upgrade. The HPMI.1 programming is planned to be use only in critical situations when both PROMs are erased and the FPGA cannot be booted.
IV. FIRMWARE UPGRADE INFRASTRUCTURE
Upgrading the firmware of programmable devices in xTCAbased systems requires the cooperation of several subsystems. Fig. 4 presents an infrastructure designed for the firmware upgrade in -based LLRF control system. It includes components from various layers of the system, from hardware (FPGA) and management (MMC) to software (firmware upgrade agent). The FPGA firmware implements a PCIe module for a data transmission and a programmer module which is responsible for the programming of Flash memory. Since various modules of LLRF systems use different PROMs, a XSVF player [22] has been used for Platform Flash and a custom programmer for SPI PROMs. The memory for programming or booting is selected by the MMC, which can also initiate and monitor the booting process of the FPGA. Both above mentioned components are supervised by the Firmware Upgrade Agent-the application running on the CPU module and ensuring the proper course of firmware upgrade procedure. The agent allows programming SPI PROMs and playing .xsvf files prepared for JTAG programming.
A. Firmware Upgrade Procedure
The firmware upgrade procedure consists of similar steps for all the supported types of boards (see Fig. 5 ). However, due to different types of memories used on particular boards the first part of the procedure-file preparation-is slightly different. In the case of the SIS8300 and DAMC2 boards, which use Platform Flash PROM memory, the firmware upgrade flow starts with the creation of the bitstream file. Then, it is converted to an mcs file with Xilinx iMPACT tools. Then, the .xsvf file containing JTAG operations is generated. The resulting file is utilized by the Firmware Upgrade Agent for reprogramming of the Platform Flash. Then, the appropriate revision of the bitstream is selected, the FPGA boot is forced and finally the PCIe hot-swap mechanism must be invoked so the operating system can recognize the board in PCIe space.
In the case of the board, which is equipped with SPI Flash memories, the first step is also the creation of the bitstream. Due to the fact that it can be directly used for memory programming, the next step is the selection of the memory bank. Then, the PROM is programmed and the FPGA is rebooted which causes the newly programmed bistream to be loaded. Finally, the PCIe hot-swap must be performed. The is also equipped with an Analog Devices TigerSharc DSP (ADSP TS-201) [36] . There are several ways to boot this device, such as booting from an external EEPROM chip, host booting and link booting. The last approach is used in the case of . ADSP TS-201 is equipped with four high-speed serial links which can be used for both booting and data transmission [37] . Firstly, the DSP firmware needs to be linked with an appropriate bootloader to form a file which can be transmitted via the link. The VisualDSP++ integrated development environment provides options to do so. When configured for link booting, after reset, the DSP is waiting for 256 words of the code to be received on any of the links. This kernel is then used to receive the rest of the firmware which ultimately overwrites the bootloader memory. The source of data is the Virtex-5 FPGA, which reads the firmware from an external SPI-PROM chip. The FPGA is able to reset the DSP and force a new firmware into it on demand.
B. Firmware Upgrade Agent
The key element of the system is the Firmware Upgrade Agent running on the CPU module. It implements algorithms ensuring an execution of the firmware upgrade procedure. The procedure depends on the board type which is one of the input parameters of the application. The software supports the programming of SPI Flash and Platform Flash (SIS8300 and DAMC2) memories which are used to configure the FPGAs. The SPI FLASH memories are programmed directly using bitstream files. However, for the programming of Platform Flash memories the application uses xsvf files prepared for JTAG programming. For this reason the conversion of bitstream file to xsvf file is necessary. The firmware upgrade agent also gives the possibility to reboot FPGA from the selected memory. Moreover, the software supports programming of the board and DSP processor on the board. The application provides a simple user interface which facilitates programming. Besides the type of the board, it requires information about the device type (FPGA or DSP), action which will be performed (memory programming or switching) and firmware file, if needed. A specific firmware upgrade procedure is selected according to this information. The program verifies input parameters and checks if the MCH is available. If the destination board is detected on the PCIe bus, the programming process starts. If not, a suitable message is displayed and the process is interrupted.
C. Support from MMC (IPMI)
A firmware upgrade requires support from the MMC of the programmed board. The MMC is responsible for selecting memory for FPGA booting, restarting FPGA and JTAG chain configuration. The FPGA rebooting can be realized using Cold Reset or Payload Reset defined in PICMG IPMI and AMC specifications. However, for the memory selection and JTAG chain configuration custom commands have to be implemented. Moreover, it is highly recommended that the MMC provides custom-defined commands for reading of the selected memory number as well as for checking the FPGA status (whether it is booted or not).
The commands provided by boards, supported by the firmware upgrade infrastructure are summarized in Table II . In the case of the SIS8300 board, there is only one command that allows the active revision of memory to be changed. It has an IPMI command code 0x03 to set two bits that control the firmware revision. In the case of the DAMC2 board, there are two commands that allow the active revision of the memory to be changed and JTAG chain to be configured. They have IPMI command codes 0x01 and 0x03, respectively. In the case of the board, there are three custom commands available for the firmware upgrade management. The first allows the memory for FPGA booting to be selected. The second one can be used for checking the number of the currently selected memory. And the third allows the status of FPGA booting to be checked. They have IPMI command codes 0x00, 0x01 and 0x05, respectively.
All commands listed above are vendor's specific commands and they belong to the Controller-specific OEM/Group defined in theIPMI standard. For this reason their Network Function code is 0x30.
The Firmware Upgrade Agent communicates with the MMC using functions selected from the ipmitool utility which supports communication with IPMI-compliant devices.
D. Data Transmission
The data transmission interface used in the presented firmware upgrade infrastructure is the PCI Express [35] . Firmware for FPGA devices, besides the application part, also include a PCIe and programmer cores. The PCIe core is responsible for receiving data from the firmware upgrade agent and its transmission to the memory programming module. The task of this module is the programming of the memory using SPI or JTAG interface, depending on the board type and installed memory.
The important element in the firmware upgrade procedure is the PCIe hot-plug mechanism. It enables the PCIe bus to be refreshed after FPGA rebooting without the need of the CPU module to be restarted. There are two methods that can be used for the refreshing the PCIe bus: hardware and software. The hardware method requires support from the PCIe switch. When the board is deactivated or activated, a signal is sent to the PCIe switch and forwarded to a Root Complex (RC) controller. The RC can refresh the bus when a hot-plug event is received. The software method uses a fakephp kernel module that allows it to emulate the extraction and insertion of events. Both a hardware and software PCIe hot-plug have been tested and finally the hardware one has been selected for the firmware upgrade procedure.
The situation is different in the case of control signals transmitted from the user application to the MMC of the board e.g. in the case of memory switching or FPGA rebooting. This information is sent in two steps. At first, the application sends data to the MCH module using a IPMI over Ethernet protocol. Then, the MCH transforms the received data and sends an appropriate command to the MMC via an IPMI bus based on the standard.
E. Automation
The process of memory programming has been automated with scripts which greatly facilitate the firmware upgrade process. The scripts are mainly responsible for the first step of the firmware upgrade procedure-preparing input files for the firmware upgrade agent (see Fig. 5 ). In the case of the board, it is limited to verifying if the file provided by the user is a correct bitstream file. However, in the cases of the SIS8300 and DAMC2 boards scripts realize the conversion from a .bit file to the .xsvf file as described in Section IV-A After preparing the correct file, the firmware upgrade agent performs the remaining steps of the firmware upgrade.
V. EXPERIMENTAL RESULTS
The developed firmware upgrade infrastructure has been tested in the digital laboratories at the Technical University of Lodz (TUL) and Deutsches Elektronen-Synchrotron (DESY). The tools were installed on a network drive; therefore the firmware upgrade tools have been available for various experiments and have been tested with the FLASH Cryomodule Test Bench Facility (CMTB). The native Linux PCIe hot-plug was used during the tests (Ubuntu 10.04, Kernel 2.6.32).
A. Tests in the Shelf
The 12-slot chassis from Elma, an Adlink AMC-1000 CPU and a N.A.T. MCH have been used during tests [17] , [38] , [39] . All AMCs and RTM, described in Section III-A, have been tested. The LLRF AMCs and RTM use Xilinx Virtex 5, Spartan 6 family FPGAs and TigerSharc DSP. The Xilinx ISE framework has been used to generate bit files for FPGA devices and the VisualDSP++ environment provided the DSP binary file.
1) FPGA Booting Speed Test:
Since the FUF assumes that the FPGA is loaded within 1 second, the default frequency of SPI memory used during the booting of FPGA should be changed to at least 36 MHz to decrease the booting time. During tests a 46 MHz clock has been applied (FPGA booting time 700 ms).
The total programming time of a single SPI PROM for the board is 105 seconds. This time includes switching to the programmer, memory erasing, programming and verification. The detailed information concerning those steps is summarized in Table III .
The total programming time of boards equipped with the Platform Flash was much longer than for the and was equal to 320 s for and 375 s in cases of SIS8300 and DAMC2 boards, see Table III . The generated XSVF file should include commands for the PROM verification after the programming and FPGA reloading.
2) DSP Booting Speed Test:
The ADSP TS-201 links consist of four differential pairs of data signals and one differential clock. Data are sent on every clock edge (double data rate). The transmission clock generated by the FPGA is 100 MHz, which translates to the 800 Mbps of the transmission speed. During the booting, only raw data are transmitted with no protocol overhead. However, the FPGA state machine responsible for the bootloader transmission introduces data fetching states which can be considered as 'empty states' in terms of the bandwidth utilization. This resulted in a measured throughput of 630 Mbps. For tests in the shelf a firmware file of 35 kB has been used with the booting time of around 54 . These results proved satisfactory although it could be possible to optimize the FPGA state machine in order to come closer to 100% bandwidth utilization.
3) Problems With PCIe Hot-Plug: The Linux PCIe hot-plug implementation imposes some restrictions on the upgrade process. When sizes of areas described by Base Address Registers (BARs) are larger that the areas previously allocated for a given device, or the device has not been detected at the boot-time, the address space for an upgraded evice is not correctly allocated, making it impossible to use the device. This happens, because the memory allocation for the entire PCIe tree under Linux is performed at the boot-time and no reserves for the run-time modifications are made. The simplest solution to make the card usable is to reboot the CPU. One can also try to re-enumerate the entire PCIe device tree using a fakephp driver, but this will enumerate also other devices connected to PCIe bus.
One of possible solutions is to standardize endpoint sizes (e.g. fix them at 64 M/64 M/64 k). This solution was applied during the tests.
VI. PLANS FOR THE FUTURE
A. Improvements of Firmware Upgrade
The firmware upgrade system has not been designed for frequent, interactive upgrades during the development, so upgrade times have not been optimized. It is particularly noticeable in the case of devices booted from Platform Flash, programmed by JTAG, when the simplest approach based on [22] has been applied. If necessary, the upgrade time can be shortened by a means of application of one of the following solutions:
1) A Parallel Transfer of Bitstream Data to the FPGA: The Xilinx in [23] presents a module allowing to program Platform Flash PROMs with the reported speed of 9 s per 8 Mbit. The data to be programmed into the Flash memory are provided to the module using an 8-bit bus, simplifying the transfer of data via the PCIe bus. There are still some problems to be investigated with this solution:
• The programming clock frequency may have to be reduced, depending on the quality of the interconnection to the Flash memory, causing a reduction in programming speed.
• The module does not support advanced revisioning features, making it harder to recover after an unsuccessful firmware update.
• The Flash PROM should be directly connected to the FPGA (the only single device in the JTAG chain).
Since JTAG chains of SIS8300, DAMC2, modules include more devices, this solution cannot be directly applied to this board and requires modifications in hardware.
2) An Application of the Partial Reconfiguration: The Dynamic Partial Reconfiguration (DPR) can be applied to reprogram the FPGA on-the-fly via the PCIe bus without the need for hot-plug or re-enumeration of the PCIe tree. The Xilinx PlanAhead software defines boundaries between the fragments of the FPGA fabric that can be configured independently without interrupting the operation of the remaining parts. Xilinx provides ICAP_VIRTEX5 and ICAP_VIRTEX6 primitives, that can be used to reprogram the FPGA from within. Thus, the external EPROM configuring the FPGA after the system boot can contain the configuration only for the PCIe endpoint block and the programmer. The rest of the FPGA can be configured from the CPU. According to [40] , the configuration speed achieved for Virtex5 amounts to 1.6 MB/s.
This approach imposes some restriction on the firmware. The configuration of PCIe block (including the BAR sizes) has to be predefined, the area available for user logic is slightly reduced (max 80% of packing density achievable) and 10% of the degradation in clock frequency is to be expected.
VII. CONCLUSIONS
The proposed firmware upgrade framework is a unique implementation allowing the firmware of FPGA and DSP programmable devices to be upgraded. The infrastructure has been tested with the -based LLRF control system. The framework uses components available in all systems: CPU and MCH and the PCIe interface available on its backplane. Currently, three AMC modules and one RTM are supported. The project takes advantage of the PCIe fatpipe interface available on the backplane for transmitting firmware. Since defines other interfaces in the fatpipe region, GbE, sRIO or a custom protocol can be also used for this purpose. All of the supported AMC modules use custom IPMI commands to select the active PROM revision and JTAG configuration. In the current solution IPMI commands are not compatible between boards. Since the firmware upgrade is becoming more and more popular in xTCA systems, the IPMI commands are proposed to be standardized by the PICMG organization. The firmware upgrade solution has been successfully tested in the digital laboratory and CMTB facility at DESY in Hamburg. The PCIe hotplug in Linux caused real problems when parameters of PCIe endpoint implemented in Xilinx FPGAs changed. The problem is solved by the standardization of used endpoints. The programming time of PlatformFlash-based devices is relatively long. It is not so critical in the case of regular firmware upgrade. However, the programming time could be crucial for 'in-system firmware upgrade' applications, e.g. software of hardware during debugging. In those cases, the optimization of the firmware upgrade time would be useful. The application of partial FPGA reconfiguration should decrease the time significantly. In this case, it is not necessary to reprogram the Flash memory; the FPGA can be directly updated. The proposed framework has been tested with the chassis, however it can be easily implemented in ATCA systems.
