# ODMB VME Baseline Firmware Guide

### UCSB ODMB Team

October 20, 2020

# **1** Test Instructions

This is document is a guide to using the ODMB7 baseline firmware for testing VME communication and copper (x)DCFEB communication on the ODMB7 version 1 prototype boards. This firmware will confirm if VME signals are properly received and sent to the VME back plane as well as if JTAG signals are properly received and sent to the PPIB/(x)DCFEBs.

Physically, the ODMB should be inserted into an ODMB-compatible slot in a VME crate. There should be a computer with appropriate optical drivers and capable of running some version of Emulib that is connected to and able to control the crate's VCC. This computer should be loaded with the vme\_cli software available at this repository. There should also be a computer equipped with the Vivado software and connected to the JTAG port of the ODMB via a Xilinx red box. This can be the same or separate from the computer handling VCC communication. Finally, the ODMB should be connected to the two skew-clear cables running to the PPIB. When testing communication with each (x)DCFEB, a powered (x)DCFEB will need to be plugged into the PPIB slot being tested. A diagram of this setup is shown in figure 1.



Figure 1: Test stand configuration for testing the ODMB7 VME baseline firmware.

| File Edit Flow Tools Window        | w Layout Yew Help Q+ Ouick Access                                                               | Bureing on                                                                                                            | t design Cancel |
|------------------------------------|-------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------|-----------------|
|                                    | P Φ Σ % Ø ¥ Dashboard -                                                                         |                                                                                                                       | afault Layout   |
|                                    |                                                                                                 |                                                                                                                       | 7 raun cayour   |
|                                    | HARDWARE MANAGER - localhost/sline_tcf/Diglent/2103                                             | JUSASUEDE                                                                                                             | 7               |
| PROJECT MANAGER                    | Hardware ? _ 🗆 🖾 ×                                                                              | odmb7_ucsb_dev.vhd × hw_ila_1 × hw_vios ×                                                                             | ? 🗆             |
| Settings                           | Q.≚.0.∅ ► ≫ ■ 0                                                                                 |                                                                                                                       |                 |
| Add Sources                        | Name Status                                                                                     | Waveform - hw_fa_1                                                                                                    | ? _ 🗆 ×         |
| Language Templates                 | V localhost (1) Connected                                                                       | Dpt to m                                                                                                              |                 |
| P Catalog                          | <ul> <li>silinx_tcf/Digilent/210308A Open</li> </ul>                                            | 8                                                                                                                     |                 |
|                                    | <ul> <li>         Ø xcku040_0 (3)         Programmec     </li> </ul>                            |                                                                                                                       |                 |
| IP INTEGRATOR                      | SysMon (System Monit                                                                            |                                                                                                                       |                 |
| Create Block Design                |                                                                                                 | Da                                                                                                                    |                 |
| Open Block Design                  | hw_ila_1 (hw_ila_1)<br>idle                                                                     |                                                                                                                       |                 |
| Generate Block Design              |                                                                                                 | No content                                                                                                            |                 |
| SIMULATION                         |                                                                                                 |                                                                                                                       |                 |
| Run Simulation                     | ( · · · · · · · · · · · · · · · · · · ·                                                         |                                                                                                                       |                 |
|                                    | Hardware Device Properties ? _                                                                  |                                                                                                                       |                 |
| <ul> <li>RTL ANALYSIS</li> </ul>   |                                                                                                 |                                                                                                                       |                 |
| > Open Elaborated Design           | ⊕ xcku040_0 ← ⇒ 🌣                                                                               |                                                                                                                       |                 |
|                                    | Name: xcku040 0                                                                                 |                                                                                                                       |                 |
| <ul> <li>SYNTHESIS</li> </ul>      | Part: xcku040                                                                                   |                                                                                                                       |                 |
| Run Synthesis                      | ID code: 13822093                                                                               | Settings - hw_ila_1 Status - hw_ia_1 × ? _ D Trigger Setup - hw_ia_1 × Capture Setup - hw_ila_1                       | ? _ 0           |
| > Open Synthesized Design          | IR length: 6                                                                                    | 8 <b>b x c c c c c c c c c c</b>                                                                                      |                 |
|                                    | Status: Programmed                                                                              |                                                                                                                       |                 |
| <ul> <li>IMPLEMENTATION</li> </ul> | Programming file:                                                                               | Core status                                                                                                           |                 |
| Run Implementation                 | Probes file:                                                                                    | Idle Waiting for Trigger Post-Trigger No probes exist for xcku040 0. Specify the probes file and refresh the device . |                 |
| > Open Implemented Design          | User chain count: 4                                                                             | Capture status                                                                                                        |                 |
|                                    | · · · · · · · · · · · · · · · · · · ·                                                           | Window 1 of 1 Window sample 0 of 1024 Total s                                                                         |                 |
| PROGRAM AND DEBUG                  | General Properties                                                                              |                                                                                                                       |                 |
| 👫 Generate Bitstream               |                                                                                                 |                                                                                                                       |                 |
| Open Hardware Manager              | Tcl Console × Messages Serial I/O Links !                                                       | Serial UO Scans                                                                                                       | ? _ 🗆           |
| Open Target                        | Q X 0 II E III II                                                                               |                                                                                                                       |                 |
| Program Device                     | set_property PARAM. FREQUENCY 15000000 [get_hw_t                                                | targets */wilinx_tcf/Digilent/210308480666)                                                                           |                 |
| Add Configural (8) xcku040         | <pre>© open hw_target</pre>                                                                     | xalhoot:3121/xilinx.tdf/Digilent/21030840066E                                                                         |                 |
| Add configural W xcku040           | current hv device [get hv devices xcku040 0]<br>refresh hv device -update hv probes false [linc |                                                                                                                       |                 |
|                                    | INFO: [Labtools 27-2382] Device xcku848 (JTAG o                                                 | device index = 0) is programmed with a design that has 1 ILA core(s).                                                 |                 |
|                                    | ☐ INPO: [Lebtools 27-2302] Device xcku040 (JTAG o                                               | <pre>sevice index = 0) is programmed with a design that has 1 VID core(s).</pre>                                      |                 |
|                                    | ·                                                                                               |                                                                                                                       | >               |
|                                    | Type a Tcl command here                                                                         |                                                                                                                       |                 |

Figure 2: Programming device with Vivado, pictured for KCU105 evaluation board.

| A                                  | baseline_project - [/net/top/homes/oshi                                                | v/odmb/firmware_projects/odmb7_baseline_vme/baseline_project/baseline_project.xpr] - Vivado 2017.2 (on higgs.physics.ucsb.edu) | _ 0 ×                      |
|------------------------------------|----------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------|----------------------------|
| Elle Edit Flow Tools Window        | Layout View Help Q- Ouick Access                                                       | Running pla                                                                                                                    | ace_design <u>Cancel</u> 🔾 |
|                                    | 🗈 🔕 ∑ 🚿 🖉 🖌 Dashboard -                                                                |                                                                                                                                | Default Layout 🔍 🗸         |
| Flow Navigator ± 0 ? _             | HARDWARE MANAGER - localhost/kilins_tcf/Digile                                         | /210308480666                                                                                                                  | ? ×                        |
| ✓ PROJECT MANAGER                  | Hardware 2 _ D B                                                                       | c odmb7 ucsb dev.vhd x hw lla 1 x hw vios x                                                                                    | 205                        |
| Settings                           | Q. ₹ . ♥ . ▶ . ▶                                                                       |                                                                                                                                |                            |
| Add Sources                        |                                                                                        | Waveform - bw_fa_1                                                                                                             | ? _ 🗆 ×                    |
| Language Templates                 | Name Status V localhost (1) Connect                                                    |                                                                                                                                |                            |
| Catalog                            | <ul> <li>Winx tcf/Diglent/210308A Open</li> </ul>                                      | 8                                                                                                                              |                            |
|                                    | <ul> <li></li></ul>                                                                    |                                                                                                                                |                            |
| IP INTEGRATOR                      | SysMon (System Monit                                                                   | Durtha a                                                                                                                       |                            |
| Create Block Design                | hw_vio_1 (hw_vio_1) OK                                                                 |                                                                                                                                |                            |
| Open Block Design                  | hw_fia_1 (hw_fia_1)                                                                    |                                                                                                                                |                            |
| Generate Block Design              |                                                                                        | A Program Device (on higgs.physics.ucsb.edu) x intert                                                                          |                            |
| <ul> <li>SIMULATION</li> </ul>     |                                                                                        | Select a bitstream programming file and download it to your hardware device. You can                                           |                            |
| Bun Simulation                     | <                                                                                      | optionally select a debug probes file that corresponds to the debug cores contained 🔥                                          |                            |
|                                    |                                                                                        |                                                                                                                                |                            |
| ✓ RTL ANALYSIS                     | Hardware Device Properties ? _ D                                                       |                                                                                                                                |                            |
| > Open Elaborated Design           | B xcku040_0 ← →                                                                        | Bitstream file: location_of_bit_file_here.bit                                                                                  |                            |
| , open closed besign               | Name: xcku040 0                                                                        | Debug probes file: location_of_tbc_file_here.tbj                                                                               |                            |
| ✓ SYNTHESIS                        | Part: xcku040                                                                          | ✓ Enable end of startup check                                                                                                  |                            |
| Bun Synthesis                      | ID code: 13822093                                                                      | Capture Setup - hw_ila_1                                                                                                       | ? _ □                      |
| > Open Synthesized Design          | B length: 6                                                                            |                                                                                                                                |                            |
| ) open synchesized besign          | Status: Programmed                                                                     |                                                                                                                                |                            |
| <ul> <li>IMPLEMENTATION</li> </ul> | Programming file:                                                                      | Program Cancel                                                                                                                 |                            |
| Bun implementation                 | Probes file:                                                                           | no stobes exist for xxku040 0. Specify the probes file and refresh the device .                                                |                            |
| > Open Implemented Design          | User chain count: 4                                                                    | Capture status                                                                                                                 |                            |
| ,                                  | Cost chair counce 4                                                                    | Window 1 of 1 Window samele 0 of 1024 Totals                                                                                   |                            |
| PROGRAM AND DEBUG                  | General Properties                                                                     | 3                                                                                                                              |                            |
| III Generate Bitstream             |                                                                                        |                                                                                                                                |                            |
| Open Hardware Manager              | Td Console × Messages Serial I/O Lin                                                   | s Serial UO Scans                                                                                                              | ? _ 🗆 🖾                    |
| Open Target                        | Q. ≚ ≑ Ⅱ 16 18 18                                                                      |                                                                                                                                |                            |
|                                    | set_property PARAM.FREQUENCY 15000000 (ge                                              | <pre>/w_targets */wilink_tcf/Digilent/210308480E0E)</pre>                                                                      | ^                          |
| Program Device                     | open hw_target     TNED: [[abtoolstr] 44.456] Opening hw_tar                           | et localhost:3121/x1lmv_tcf/Digilent/21030460866                                                                               |                            |
| Add Configuration Memory Dev       | current hy device [get hy devices xcku04]                                              |                                                                                                                                |                            |
|                                    | refresh hv device -update hv probes false<br>: INFO: [Labtools 27-2302] Device xcku040 | TAG device index = 0) is programmed with a design that has 1 ILA core(s).                                                      | 1-                         |
|                                    | ☐ INFO: [Labtools 27-2302] Device xcku040                                              | TAG device index = 0) is programmed with a design that has 1 VID core(s).                                                      |                            |
|                                    | <                                                                                      |                                                                                                                                | ×                          |
|                                    | Type a Tcl command here                                                                |                                                                                                                                |                            |
|                                    |                                                                                        |                                                                                                                                |                            |

Figure 3: After clicking program device, the bit and ltx files can be specified.

To begin testing the VME firmware, the prototype boards should be loaded with the provided firmware and the Vivado program equipped with the appropriate test probes. The provided .bit and .ltx files can be loaded as shown in figures 2 and 3.

Once the firmware is loaded, VME commands can be sent using the vme\_cli software. After compiling the software with make, a VME command can be issued to the ODMB in a format demonstrated by the following example.

The VCC MAC address, schar\_port, eth\_name, and VME slot should be adjusted based on the configuration of the host computer and VME crate. The arguments vme\_write\_read, vme\_command, and vme\_data indicate the actual content of the command issued to the ODMB. The vme\_write\_read argument takes on the value w or r to indicate a write or read command respectively. In the case of read commands, no vme\_data needs to be provided. The vme\_command and vme\_data take 16 bit values specified as 4 hex characters. vme\_data values with fewer than 4 characters are interpreted by padding to the left with 0's. Below, commands will be listed in the format <vme\_write\_read> <vme\_command> (<vme\_data>) (//comment on command). As a first test, the command R 4100 should be issued. The ODMB should respond with the return value OD3B, which will be displayed by the vme\_cli program.

If this is successful, a more complicated series of commands can be issued to read the User code from the (x)DCFEBs. This is given in listing 1 for DCFEBs and listing 1 for xDCFEBs. The two R 1014 commands will return the usercode, which should be DCFEB### where the #'s depend on the firmware version of the (x)DCFEB. Note that the lower 16 bits get returned first.

```
W 1018 0000 //reset DCFEBs
W 1020 #
            //Select DCFEBs, use #=01, 02, 04, 08, 10, 20, or 40 to select DCFEB 1, 2, 3, 4, 5, 6, or
    7 respectively
W 191C 3C8 //shift instruction "read usercode"
W 1F04 0000 //shift 16 upper data bits
R. 1014
            //read retrieved data bits
W 1F08 0000 //shift 16 lower data bits
R 1014
            //read retrieved data bits
W 1018 0000 //reset DCFEBs
W 1020 #
            //Select DCFEBs, use #=01, 02, 04, 08, 10, 20, or 40 to select DCFEB 1, 2, 3, 4, 5, 6, or
    7 respectively
W 1934 3C8 //shift instruction "read usercode"
W 1F30 FFFF //bypass instruction to other xDCFEB devices
W 1F30 FFFF //bypass instruction to other xDCFEB devices
W 1F30 FFFF //bypass instruction to other xDCFEB devices
W 1338 F
            //bypass instruction to other xDCFEB devices
W 1F04 0000 //shift 16 upper data bits
R. 1014
            //read retrieved data bits
W 1F08 0000 //shift 16 lower data bits
R. 1014
            //read retrieved data bits
```

If the returned values from R 4100 or R 1014 are not as expected, more information on debugging is given in the next section.

# 2 Debugging

#### 2.1 Check Clocks

The first check to perform if the R 4100 command fails is to check the ODMB clocks. If the CMS clock is not received from the CCB or if the clock manager is not functional, the ODMB firmware will not be able to handle VME communication. To diagnose these problems, one can first run the ILA un-triggered. If the ILA does not respond, this is indicative of no clock signal, which can be caused by either not receiving the CMS clock from the CCB or a malfunction of the clock manager in firmware.

If it is suspected that the CMS clock is not being received, an alternative firmware version with the ILA directly reading the CMS clock signal can be generated. Alternatively, the firmware can be replaced with an alternate version that uses the clock from the on-board clock synthesizer, which must be configured using appropriate software. Failure to see the CMS clock directly and success with the alternate firmware indicates a problem in receiving the clock from the CCB.

If the alternative firmware that reads the clock signal directly from the CCB demonstrates the clock is being received, then the clock manager module in the firmware is likely at fault and firmware debugging is required.

#### 2.2 Check VME Signals

If the clock signals look as expected, the next debugging step is to check that VME signals are being sent/received. To diagnose VME problems, the VME crate should be restarted and the ODMB ILA equipped with the VME signals listed in table 1. This table also lists the expected behavior of the signals and their response to a R 4100 command in simulation is shown in figure 4. Once the ILA is equipped with the appropriate signals, it should be triggered on vme\_as\_b=0. Once the ILA is armed, a R 4100 command should be issued from vme\_cli.

The first thing to check are the strobes and dtack. The VCC should pull vme\_as\_b low, then both bits of vme\_ds\_b. Shortly after vme\_ds\_b is pulled low, the strobe signal become 1. After some time, the ODMB should pull vme\_dtack\_v6\_b low, and the VCC should de-assert vme\_ds\_b, then vme\_as\_b. If vme\_as\_b or vme\_ds\_b is never pulled low, and vme\_dir is low, there may be some problem receiving the appropriate signal, which could be caused by ICs or traces on the ODMB. Further debugging may be performed with an oscilloscope on appropriate IC legs. If vme\_as\_b and vme\_ds\_b are pulled low but strobe never goes high, the other vme\_ signals listed in table 1 should be checked against their expected values. If these match their expected values, additional firmware will need to be generated to debug firmware issues.

If the correct sequence of strobes and dtack is observed, then the VME command is being received by the ODMB and the signals vme\_data\_out, vme\_tovme, and vme\_doe\_b should be checked against their expected values. If these signals match their expected values, external ICs and signal traces may need to be debugged.

If vme\_data\_out is incorrect or if strobe is asserted but vme\_dtack\_v6\_b never goes low, it is likely that the VME modules in the firmware are at fault. The dummy\_confregs module that handles the R 4100 command is very simple and thus not expected to fail. Information on debugging the cfebjtag module is given in the next section.

| Signal           | Long name                    | Expected behavior                                                                    |
|------------------|------------------------------|--------------------------------------------------------------------------------------|
| vme_data_in_buf  | Data in                      | Value passed by vme_cli for write commands.                                          |
| vme_data_out_buf | Data out                     | Value returned by ODMB.                                                              |
| vme_crate_addr   | Address                      | The slot number should match the bitwise inverse of vme_ga_b when vme_as_b goes low. |
| vme_cmd          | Command                      | Should match value passed by vme_cli.                                                |
| vme_am           | Address Modifier.            | When vme_as_b goes low, this should be 111X10 or 111X01.                             |
| vme_gap_b        | Geographical address parity. | Should be 1 if an odd number of bits in ga are $0$ and $0$ otherwise.                |
| vme_ga_b         | Geographical address.        | Should correspond to the VME slot used.                                              |
| vme_as_b         | Address strobe.              | Should go low to indicate address ready to read.                                     |
| vme_ds_b         | Data strobe.                 | Both bits should go low after vme_as_b to indicate data ready to read.               |
| vme_sysfail_b    | Sysfail.                     | Should be 1.                                                                         |
| vme_berr_b       | Bus Error.                   | Should be 1, but doesn't matter for ODMB.                                            |
| vme_iack_b       | Interrupt acknowledge.       | Should be 1.                                                                         |
| vme_lword_b      | Load word.                   | Should be 1 when vme_as_b goes low.                                                  |
| vme_write_b      | Write.                       | Should be 0 for write commands and 1 for read commands.                              |
| vme_dtack_v6_b   | Data acknowledge.            | Should be issued by ODMB some time after receiving vme_ds_b low.                     |
| vme_dir          | To VME                       | Should be go high when read commands are sent and low otherwise.                     |
| vme_doe_b        | Output Enable                | Should go low when read commands are sent.                                           |
| strobe           | Stobe                        | Should go high shortly after vme_ds_b goes low.                                      |

Table 1: Signals in VME interface

| Name                            | Value |      | 19, <b>500</b> ns | 20,000 ns | 20,500 ns | 21,000 ns | 21,500 ns | 22,000 ns | 22,500 ns | 23, <b>000</b> ns |
|---------------------------------|-------|------|-------------------|-----------|-----------|-----------|-----------|-----------|-----------|-------------------|
| > Vme_data_in_buf[15:0]         | 2ead  | 0000 | X                 |           | Od 3b     |           |           |           | 2eac      |                   |
| > strain vme_data_out_buf[15:0] | 0d3b  | 6000 | <b>)</b> X        |           |           |           |           | Dd3b      |           |                   |
| > vme_crate_addr                | 15    | 60   |                   |           |           |           |           | 15        |           |                   |
| > vme_cmd                       | 4100  | 0000 | X                 |           |           |           |           | 100       |           |                   |
| > 📲 VME_AM[5:0]                 | 3a    |      |                   |           |           |           | Sa        |           |           |                   |
| Te VME_GAP_B                    | 1     |      |                   |           |           |           |           |           |           |                   |
| > ME_GA_B[4:0]                  | 0a    |      |                   |           |           |           | 0a        |           |           |                   |
| 1 VME_AS_B                      | 1     |      |                   |           |           |           |           |           |           |                   |
| > ME_DS_B[1:0]                  | 3     |      | 3                 | X         | 0         |           |           |           | 3         |                   |
| VME_SYSFAIL_B                   | 1     |      |                   |           |           |           |           |           |           |                   |
| VME_BERR_B                      | 0     |      |                   |           |           |           |           |           |           |                   |
| UME_IACK_B                      | 0     |      |                   |           |           |           |           |           |           |                   |
| VME_LWORD_B                     | 1     |      |                   |           |           |           |           |           |           |                   |
| 1 VME_WRITE_B                   | 0     |      |                   |           |           |           |           |           |           |                   |
| VME_DTACK_KUS_B                 | 1     |      |                   |           |           |           |           |           |           |                   |
| ₩ vme_dir                       | 0     |      |                   |           |           |           |           |           |           |                   |
| US_VME_OE_B                     | 0     |      |                   |           |           |           |           |           |           |                   |
| 🖓 strobe                        | 0     |      |                   |           |           |           |           |           |           |                   |
|                                 |       |      |                   |           |           |           |           |           |           |                   |
|                                 |       |      |                   |           |           |           |           |           |           |                   |
|                                 |       |      |                   |           |           |           |           |           |           |                   |
|                                 |       |      |                   |           |           |           |           |           |           |                   |
|                                 |       |      |                   |           |           |           |           |           |           |                   |
|                                 |       |      |                   |           |           |           |           |           |           |                   |
|                                 |       |      |                   |           |           |           |           |           |           |                   |

Figure 4: Simulated ODMB response to VME command R 4100. Note that in simulation 2EAD appears on the vme\_data\_in line while in the real ODMB, a value of 0000 is expected.

### 2.3 Check CFEBJTAG

If the user code can not be successfully read back from the (x)DCFEBs, the first thing to check are the JTAG communication lines. These signals are tms, tck, tdi(selected (x)DCFEB index), and tdo(selected (x)DCFEB index), and are listed along with the other signals relevant to cfebjtag in table 2. Note that the signals in the ILA are prefixed with dcfeb\_. Their expected behavior along with that of other cfebjtag signals is shown in figures 5 through 11.

As a first qualitative check, after each W 1X0Y, W 1X1Y, or W 1X3Y command, the tms signal and the tck only for the selected (x)DCFEB should respond with some pattern. This can be observed by again triggering on vme\_as\_b=0. If they do not respond, this indicates a bug in generating a busy signal or appropriate tms response and the appropriate paragraph below should be referenced. If other tck clocks are running, this indicates a problem in selecting the correct dcfeb and the selfeb signal should be monitored as discussed below.

If tms and tck seem to respond to appropriate commands, one should check that the correct tdo bits are being returned from the (x)DCFEBs. When the W 1F04 and W 1F08 commands are issued, one can check the value of tdo on rising edges of tck after tms has been 0 for two cycles up to and including the first tck edge for which tms is 1. The bits should be DCFEB### noting that the shifted bits on tdo appear in reverse order.

If the tdo bits are not correct, it may be necessary to inspect each W 1XOY, W 1X1Y, and W 1X3Y command issued in detail. Figures 5 through 11 show the expected behavior for each command. To compare to the figures, check the value of tdi and tms against the values shown in the figures for each rising edge of tck. If the tdi or tms are incorrect, this indicates a bug in the logic that generates the tms patterns or transfers the input to tdi.

If the tms clock never begins running after a (x)DCFEB communication command is issued, this indicates either a problem in generating a busy signal or a failure to select any (x)DCFEBs. To diagnose the prior issue, check the strobe, load, busy, and tck\_global signals after issueing a command. The load should go high once after receiving strobe high. If this does not happen, check that vme\_cmd is correct. After load goes high, busy should go high until the communication is finished and while busy is running, tck\_global should be running. If this does not happen, more debugging will be required for the busy logic.

If multiple tms clocks are running or if tck\_global is running but no other tck signals, this indicates a problem with selecting (x)DCFEBs. One should check the selfebsignal after issuing a W 1020 to see if updates to reflect selected (x)DCFEBs. The command R 1024 can also be used to read back the currently selected (x)DCFEBs to check. After issuing a W 1020 command, one run the ILA untriggered or issue R 1024 to see if the selected (x)DCFEBs are still selected. If not, it is likely the ODMB received a spurious reset, and additional firmware should be made to investigate spurious reset signals.

If tms is not generated properly for a particular command, signals involved in tms pattern generation should be investigated. In particular, for W 1Y1C and W 1Y34, the shihead signal should be asserted to shift the instruction header before shifting data. For the W 1Y04 command, the shdhead signal should be asserted to shift the data header. For all JTAG shift commands, the shdata signal should be asserted to shift the tdi/tdo data. Then, for W 1Y1C, W 1Y38, and W 1Y08 commands, the shtail signal should be asserted to shift the tailer at the end of the shifting. If any of these signals are not asserted, additional firmware should be generated to analyze the VHDL logic generating the signal in question. If the signals are generated, but the tms or tdi patterns are not correct, additional firmware should be generated to analyze the shifting logic.

| Signal     | Description               | Expected behavior                                                                           |
|------------|---------------------------|---------------------------------------------------------------------------------------------|
| dcfeb_tms  | JTAG Control              | While tck is running, this should various values depending on command issued. See figures 5 |
|            |                           | through 11 for expected behavior for DCFEB commands                                         |
| dcfeb_tck  | JTAG Clock                | After a W 1X0Y, W 1X1Y, or W 1X3Y command, the TCK for the selected                         |
|            |                           | (x)DCFEB should oscillate for several cycles                                                |
| dcfeb_tdi  | JTAG Input                | When tck is running, the bits matching the provided vme_data should be seen.                |
| dcfeb_tdo  | JTAG Output               | During the final W 1F04 and W 1F08 commands, the tdo signal for the                         |
|            |                           | selected (x)DCFEB should be the bits for its usercode.                                      |
| load       | Load                      | Should go high once for each (x)DCFEB communication command issued.                         |
| busy       | Busy                      | Should be asserted while JTAG shifts in progress.                                           |
| tck_global | Global JTAG clock.        | Should be sent to selected $(x)DCFEB(s)$ as tck.                                            |
| selfeb     | Selected (x)DCFEB         | Should match selected $(x)DCFEB(s)$ after issuing W 1020 command.                           |
| shihead    | Shift instruction header. | Should go high for W 1Y1C and W 1Y34 commands.                                              |
| shdhead    | Shift data header.        | Should go high for W 1Y04 commands.                                                         |
| shdata     | Shift data.               | Should go high for all JTAG shift commands commands.                                        |
| shtail     | Shift tailer.             | Should go high for W 1Y08, W 1Y1C, and W 1Y38 commands.                                     |

Table 2: Signals related to JTAG debugging



Figure 5: Simulated ODMB response to VME command W 1018 0000. Note that this JTAG reset commands causes tck for each (x)DCFEB to run.



Figure 6: Simulated ODMB response to VME command W 191C 03C8. In this example, DCFEB 2 is selected. The tdo signals are unimportant and may differ for real DCFEBs.

| VME Signals               |      |        |    |       |      |    |   |  |
|---------------------------|------|--------|----|-------|------|----|---|--|
| 🕼 strobe                  | 0    |        |    |       |      |    |   |  |
| > vme_cmd                 | 1014 |        |    |       | 1934 |    |   |  |
| > 💐 vme_data_in_buf[15:0] | 2ead |        |    |       | 03c8 |    |   |  |
| > Vme_data_out_buf[15:0]  | ZZZZ |        |    |       | ZZZZ |    |   |  |
| CFEBJTAG Signals          |      |        |    |       |      |    |   |  |
| > 📢 dcfeb_tck[7:1]        | 00   | CO X.X |    |       |      |    | X |  |
| > 📢 dcfeb_tdo[7:1]        | OX   | OX     | 00 | 02 00 |      | 02 |   |  |
| Uk dcfeb_tck[2]           | 0    |        |    |       |      |    |   |  |
| 🕼 dcfeb_tdo[2]            | Х    |        |    |       |      |    |   |  |
| Uk dcfeb_tms              | Z    |        |    |       |      |    |   |  |
| ₩ dcfeb_tdi               | 0    |        |    |       |      |    |   |  |
| > selfeb[7:1]             | 02   |        |    |       | 02   |    |   |  |
| 1% load                   | 0    |        |    |       |      |    |   |  |
| 🕼 busy                    | 0    |        |    |       |      |    |   |  |
| ™ tck_global              | 0    |        |    |       |      |    |   |  |
| 🕼 shihead                 | 0    |        |    |       |      |    |   |  |
| 🕼 shdhead                 | 0    |        |    |       |      |    |   |  |
| 🕼 shdata                  | 0    |        |    |       |      |    |   |  |
| 🖏 shtail                  | 0    |        |    |       |      |    |   |  |

Figure 7: Simulated ODMB response to VME command W 1934 03C8. In this example, xDCFEB 2 is selected. The tdo signals are unimportant and may differ for real xDCFEBs.



Figure 8: Simulated ODMB response to VME command W 1F30 FFFF. In this example, xDCFEB 2 is selected. The tdo signals are unimportant and may differ for real xDCFEBs.

| VME Signals               |      |    |    |     |      |   |    |  |
|---------------------------|------|----|----|-----|------|---|----|--|
| 🕼 strobe                  | 0    |    |    |     |      |   |    |  |
| > vme_cmd                 | 1014 |    |    |     | 1338 |   |    |  |
| > 💐 vme_data_in_buf[15:0] | 2ead |    |    |     | 000f |   |    |  |
| > vme_data_out_buf[15:0]  | ZZZZ |    |    |     | ZZ   | Z |    |  |
| CFEBJTAG Signals          |      |    |    |     |      |   |    |  |
| > 📢 dcfeb_tck[7:1]        | 00   | 00 |    | X•X |      |   | 00 |  |
| > 💐 dcfeb_tdo[7:1]        | OX   |    | 02 |     |      |   | OX |  |
| 🗤 dcfeb_tck[2]            | 0    |    |    |     |      |   |    |  |
| 🛯 🕼 dcfeb_tdo[2]          | Х    |    |    |     |      |   |    |  |
| 🖗 dcfeb_tms               | Z    |    |    |     |      |   |    |  |
| 🖓 dcfeb_tdi               | 0    |    |    |     |      |   |    |  |
| > 🔣 selfeb[7:1]           | 02   |    |    |     | 0    | 2 |    |  |
| 🖫 load                    | 0    |    |    |     |      |   |    |  |
| 🖫 busy                    | 0    |    |    |     |      |   |    |  |
| ৸ tck_global              | 0    |    |    |     |      |   |    |  |
| 🖫 shihead                 | 0    |    |    |     |      |   |    |  |
| 🖫 shdhead                 | 0    |    |    |     |      |   |    |  |
| 🖫 shdata                  | 0    |    |    |     |      |   |    |  |
| 🖞 shtail                  | 0    |    |    |     |      |   |    |  |
|                           |      |    |    |     |      |   |    |  |

Figure 9: Simulated ODMB response to VME command W 1338 000F. In this example, xDCFEB 2 is selected. The tdo signals are unimportant and may differ for real xDCFEBs.



Figure 10: Simulated ODMB response to VME command W 1F04 0000. In this example, xDCFEB 2 is selected. The tdo signal in simulation is A093 rather than B### expected for a real (x)DCFEB.

| VME Signals              |      |    |    |       |    |               |    |  |  |
|--------------------------|------|----|----|-------|----|---------------|----|--|--|
| 🕼 strobe                 | 0    |    |    |       |    |               |    |  |  |
| > vme_cmd                | 191c |    |    |       |    | 1f <b>0</b> 8 |    |  |  |
| > Vme_data_in_buf[15:0]  | 03c9 |    |    |       |    | 0000          |    |  |  |
| > Vme_data_out_buf[15:0] | ZZZZ |    |    |       |    | ZZ            | zz |  |  |
| CFEBJTAG Signals         |      |    |    |       |    |               |    |  |  |
| > 📢 dcfeb_tck[7:1]       | 02   | 00 |    |       |    |               |    |  |  |
| > 📢 dcfeb_tdo[7:1]       | 0X   | 00 | 02 | 00 02 | 00 | 02            | G  |  |  |
| Umdcfeb_tck[2]           | 1    |    |    |       |    |               |    |  |  |
| 🐚 dcfeb_tdo[2]           | Х    |    |    |       |    |               |    |  |  |
| 🖓 dcfeb_tms              | 0    |    |    |       |    |               |    |  |  |
| ₩ dcfeb_tdi              | 1    |    |    |       |    |               |    |  |  |
| > selfeb[7:1]            | 02   |    |    |       |    | 0             | 2  |  |  |
| 😼 load                   | 0    |    |    |       |    |               |    |  |  |
| 🖫 busy                   | 1    |    |    |       |    |               |    |  |  |
| 🖫 tck_global             | 1    |    |    |       |    |               |    |  |  |
| 🖫 shihead                | 1    |    |    |       |    |               |    |  |  |
| 🕼 shdhead                | 0    |    |    |       |    |               |    |  |  |
| 🕼 shdata                 | 0    |    |    |       |    |               |    |  |  |
| 😼 shtail                 | 0    |    |    |       |    |               |    |  |  |
|                          |      |    |    |       |    |               |    |  |  |

Figure 11: Simulated ODMB response to VME command W 1F08 0000. In this example, xDCFEB 2 is selected. The tdo signal in simulation is 0424 rather than DCFE expected for a real (x)DCFEB.