# SPECS: a Serial Protocol for the Experiment Control System of LHCb Institut National de Physique Nucléaire ET DE PHYSIQUE DES PARTICULES <u>D.Charlet, D. Breton, P.Robbe</u> LAL, IN2P3-CNRS, Université Paris-Sud, Bat. 200, 91400 Orsay Cedex, France Charlet@lal.in2p3.fr Cavern Front end chip ### **SPECS** protocole The SPECS is a single master, multi slave serial bus. It communicates between an unique master and up to 32 slaves (limit fixed by the address range), at a 10 MHz rate, thanks to 4 different unidirectional lines. These lines called MS SDA, MS SCL, SM SDA, and SM SCL are the data and clock lines, from master to slave, and from slave to master respectively. They can be implemented in differential mode (8 wires) or in unipolar mode (4 wires). Data transfer is organized in frames of variable length. The format is the same for transfers from the master to the slaves or in the other direction, except for the interrupt commands which have a specific frame. The frames start and stop with a specific transition of the data line when the clock line is at a high level ("1"). These transitions are called 'start condition' and 'stop condition', and are identical to the ones used in I2C. The clock lines are active only during a data transfer and remain quiet during an idle phase. A frame is composed of a variable number of words, the latter being separated from each other by a 'missing clock cycle'. This makes the debugging by oscilloscope very easy, since the packets are clearly identified. The words have a fixed length of 9 bits and, due to the missing clock cycle, a word needs 10 cycles to be transferred. Therefore, with the 10 MHz clock frequency, the data transfer rate is 1 MB/s. ### Mezzanine implementation **SPECS** implementation On the SPECS mezzanine, 2 SPECS interfaces are provided: one point to point for long distance interconnection and one for local bus connection. Thanks to this feature, we can handle several mezzanines on the same SPECS bus. Mezzanine can be chained using cable. We use Ethernet CAT6 ## Backplane implementation The SPECS protocol is mono-master multi-slave. This permits the implementation of many slaves on the same bus. For the Calorimeter electronics, the SPECS bus will actually be distributed on the remote crate backplane. Simulation with signal integrity tool have been performed to select specific logic (plot. result on fig 1 et fig 2) # The SPECS software # **Software Layers** # **Software Functionalities** The Software libraries give access to all SPECS functionalities: 1. I2C Accesses: 2. Parallel Bus Accesses: Read: automatic selection of DMA access when the size of data to send is larger than 1 (x Write. 3. JTAG Accesses: Irscan, Drscan. Reset, Read: with or without sub-address (ie first word after address word), with selection of I2C Write: with or without sub-address, or using general I2C calls. 5. Management Functions: • Error reports: when the I2C slave address does not exist (SPECS interrupt associated Initialization: initialization, termination, or reset of communications with Masters or Identification: of Master location and serial number. > • Control: selection of SPECS Master clock frequency, reset of Emitter and Receiver Error Report: when problem in data transfers (timeout, checksum error) Linux environment and are written in C language. In order to maintain low CPU occupancies, Read: to any Slave register (I/O pins, Clock Selection, ...) (Identification and User space), write to the User space board at the same time. 4. Register Accesses: 6. Combined Accesses: On-board DCU Functionalities: initialization, reset, selection of input mode, and On-board EEPROM Functionalities: read to all 65 kbits of the EEPROM Service box Mono master multi-saves bus Bi directional, serial, synchronous bus. On detector •10Mbits /s serial link. Service box •Point to point or muti-drop implementation. •Up to 32 slaves on a same link. \*System rad tolerant (40Krad) Top of detector 100mBarracks Master Board, # C de register Leds Cmd ### The SPECS slave ### SPECS slave chip The slave is designed as a portable VERILOG code and is physically integrated inside an ACTEL flash PGA. With this technology, the slave is SEL immune, and is also SEU immune, because the internal registers are appropriately protected by triple voting techniques, and state machines use one-hot state. Moreover, to ensure a high reliability of the decoding of the SPECS commands, there are no state machine in the SPECS receiver part. In addition, all commands (and in particular all resets) are generated without using any local clock but only the SPECS lines. This may for instance allow the user to reset the TTCrx through SPECS if necessary. The chip will also be reasonably radiation tolerant, up to 10 krad (with some safety margin, the ACTEL chip having been tested up to 40 krads) over the lifetime of the experiment. It can then be placed at most locations where we foresee to have electronics, except in or near the Vertex Locator tank. The chip is an ACTEL APA150. SPECS slave mezzanine general description A mezzanine daughter-board has been developed to house the SPECS slave, and to provide all the described functionalities of the SPECS Slave chip through 2 SMC connectors. The mezzanine board also provides most of the necessary service functions for the sub-detector front-end electronics. The goal is to avoid putting unnecessary electronics in the radiation sensitive area. The mezzanine can be configured in master mode or in slave mode. In master mode, the mezzanine can deal with 2 SPECS busses: One point to point long distance bus. This bus is implemented with RJ45 connectors on the mezzanine, which permits a direct connection, without any additional component, to the master through an Ethernet cable. List of the main features of the mezzanine board: •One long distance point to point differential SPECS interface (coming from the •One unipolar SPECS local interface for multi-load bus applications. •Three serial bus: 1) local I2C 2) long distance I2C 3) JTAG bus. •16 JTAG or 15 I2C chip-select control bits and direction control bits for external •One parallel bus offering 16 data bits and 8 address bits. •One decoder for the channel B of the TTCrx, decoding: A) L0 front-end reset, B) Calibration pulse type 0, which can be delayed with a programmable counter. •One 32-bit static register to control or read back the local environment. The bits [31..0] can be individually configured either in output or in input mode. •One reset signal. This output can be triggered without the need of any clock on the •One local 40MHz oscillator. It is also provided as an output of the mezzanine and can be enabled by the software. •One PROM which will allow the ECS system to obtain some information about the front-end element housing the mezzanine. It will be mounted on a socket. • One DCU chip with 6 ADC channels of 12-bit resolution. Radiation environment For radiation zones, hardness to the single event latch-ups (SEL), single event upsets (SEU), and single event transients (SET) are required. This point has to be considered carefully, and the design of the slave chip ensures that the registers and state machines are protected by appropriate redundancy. The single event latch-up sensitivity however depends on the technology used. For this reason we have tested and chosen some specific ones. All the components have thus been tested either by us or by other laboratories up to 30kRads ### The SPECS master Front end electronic The SPECS master board hosts 4 SPECS masters. The SPECS master is implemented on a standard 32-bit 33 MHz PCI board, which can be plugged into a PC. In order to offer an easy setup for the test benches, the board also includes an internal SPECS slave, which allows the user to benefit from both JTAG and I2C local output capability. The heart of the system is integrated within an ALTERA CYCLONE FPGA and the PCI interface is performed by a PLX9030 chip, each of them having its own configuration EEPROM. For the driver part, we use the DS92LV090 driver with the voltage RC pole-zero cancellation. For the receiver part, due to the long distance link, we use receivers with high common mode input voltage range (-2 to 4.4V), and low differential input thresholds ( < 50mv), SN-5LVDS032 from TI SPECS slave- The firmware have been developed in portable verilog code. This require specific logic like anti-metastability The loading of the FPGA via the PCI bus. To do this, the general purpose I/O of the PLX 9030 and the JTAG of the FPGA are used. The GPIO are configured and connected to the JTAG. The download file contains firmware which takes control of the active serial bus of the FPGA, this one is used to load the EEPROM and to configure the FPGA, and also transform the FPGA into a bridge between the 2 One of the main characteristic is the 3 different clock buses. After with the INIT command we download the firmware contains in the EEPROM which replaces the specific one. The JAMPLAYER software is delivered by ALTERA and allows, after modification, to control the GPIO, the GPIO emulate a JTAG bus. Calorimeter Front\_end board SPECS slave chip SPECS mezzanine HPD module control board LHCb RICH detector CROC Calorimeter control board