



# Status of the AWAKE run 2c photoinjector LLRF at CERN

Ben Woolley, Kristiaan Pelckmans, Steffen Doebert

06/12/2023

# **AWAKE: Proton driven plasma wakefield acceleration**

- Unique to CERN
  - Very successful: showed that a high energy (400 GeV) proton bunch reproducibly selfmodulates, driving strong wakefields.
  - Externally injected low-energy (16 MeV) electrons were accelerated to 2 GeV in under 10 m.
- Staged upgrades (Run 2):
  - Run 2a: demonstrate reproducible self-modulation via electron seeding. (Done 2022)
  - Run 2b: New vapour source with density step to stabilise microbunches. (Ongoing 2023-24)

06/12/2023





#### **Current Electron Injector RF System architecture**



06/12/2023 Micro TCA WS 2023: Status of the AWAKE run 2c photoinjector LLRF at CERN

CÉRN

AIVAKE





station 2

# **Second Electron injector**

- 160 MeV electron energy
- Emittance 2mm mrad
- S-band photo cathode gun
- X-band buncher
- X-band accelerating structures with 80 MV/m
  - Option for 3x, 55 MV/m structures also studied.
- 3 drive signals to be to be controlled.





# LLRF system specifications for run 2c

- 3GHz and 12GHz signals to be acquired and generated.
  - Arbitrary amplitude and phase control is required to operate the system in a closed loop fashion and to provide the necessary phase manipulation for the RF pulse compressors.
- Timing jitter between seed and witness ebunches to be below 50fs to achieve optimal placement of the witness e- bunch into the plasma wakefield.
  - LLRF modulator must have an additive phase jitter of less than 30 fs.
- Slow drifts must be compensated for by the LLRF system.

06/12/2023

• Temperature variations in signal cables, long waveguides, driver amplifiers, klystrons, pulse compressors.



|                       | S-band           | X-band           |  |  |  |  |  |
|-----------------------|------------------|------------------|--|--|--|--|--|
| Operating frequency   | 2.997899 GHz     | 11.9915962 GHz   |  |  |  |  |  |
| Pulse length          | 1-10 µs          | 100-1500 ns      |  |  |  |  |  |
| Bandwidth             | > 20 MHz         | > 20 MHz         |  |  |  |  |  |
| Pulse repetition rate | 9.97 Hz          | 9.97 Hz          |  |  |  |  |  |
| Number of signals to  | 14 + Reference   | 18 + Reference   |  |  |  |  |  |
| be acquired           |                  |                  |  |  |  |  |  |
| Number of signals to  | 2                | 2                |  |  |  |  |  |
| be generated          |                  |                  |  |  |  |  |  |
| Jitter                | <30 fs           | < 30 fs          |  |  |  |  |  |
| Amplitude stability   | 10 <sup>-4</sup> | 10 <sup>-4</sup> |  |  |  |  |  |

# LLRF architecture

- Use SIS8300KU and DWC8VM1 • AMC+RTM.
- Uppsala University as collaborator to develop the LLRF system for tests at **CERN's CLEAR (formerly CTF)** facility.
- Last year's WS we asked DESY and KVG to launch the development of the DeRTM-LOG 3GHz for REF, LO and CLK distribution on the RF backplane.
- For X-band stations use middleware (a la DESY<sup>1</sup>) to up/down convert between 3GHz and 12GHz.



1: https://indico.fnal.gov/event/21836/contributions/64954/attachments/40833/49435/PUBLIC\_VERSION - LLRF19\_MReukauff\_Talk.pdf



LO

# **DESY FWK BSP: an external perspective**

- The FWK/demo facilitated the developer to go from absolute beginner to modest expert in +/-1 year.
- The FWK/demo is now (fall 2023) in a stable phase with initial glitches ironed out.
- The appeal (for us) is that FWK/demo keeps the delay overhead (between ADC > DAC) down without too much tuning.
- Understanding the FWK/demo helped understanding other efforts as well.

06/12/2023

• The core of FWK/demo includes efficient memmap management.



| << Devices:                              |                                           | Modules/Registers:                           |              | Register properties                          |                                                                |                        | Options             |  |  |
|------------------------------------------|-------------------------------------------|----------------------------------------------|--------------|----------------------------------------------|----------------------------------------------------------------|------------------------|---------------------|--|--|
| ADC_BOARD<br>ADC_LOGICAL                 |                                           | BSP     ID     VERSION     PRJ_ID     PRJ_ID |              | Register path<br>/BSP/SCRATCH<br>Dimension   | <ul> <li>Read after write</li> <li>Show plot window</li> </ul> |                        |                     |  |  |
|                                          | PRJ_VERSION<br>PRJ_SHASUM                 | Scalar                                       | Operations   |                                              |                                                                |                        |                     |  |  |
|                                          |                                           | PRJ_TIMESTAMP                                |              |                                              |                                                                | Data Type              |                     |  |  |
|                                          |                                           | RESET_N<br>CLK_MUX                           |              | Unsigned integer                             |                                                                |                        |                     |  |  |
|                                          |                                           |                                              |              | Numerical Address                            | Write                                                          |                        |                     |  |  |
|                                          | CLK_SEL<br>CLK_RST                        | Bar Register widt                            |              |                                              | Write to file                                                  |                        |                     |  |  |
|                                          | CLK_FREQ                                  | 0 3<br>Address Fractional bi                 |              |                                              | Read from file                                                 |                        |                     |  |  |
|                                          | SPI_DIV_SEL                               |                                              |              |                                              | Continuous Poll                                                |                        |                     |  |  |
|                                          | SPI_DIV_BUSY                              | 24                                           | f            | 0                                            | Continuous Poli                                                |                        |                     |  |  |
|                                          | ADC_IDELAY_CNT                            | Total size (bytes) Signed Flag               |              |                                              | enabled                                                        |                        |                     |  |  |
|                                          | ADC_REVERT_CLK                            | 4                                            |              | 0                                            | Poll Freugency                                                 |                        |                     |  |  |
|                                          | SPI_ADC_BUSY<br>DAC_ENA<br>DAC_IDELAY_INC |                                              | Values       | <ul> <li>● 1 Hz</li> <li>○ 100 Hz</li> </ul> |                                                                |                        |                     |  |  |
|                                          |                                           | DAC_IDELAY_CNT<br>DDR_CALIB_DONE             |              | Value                                        | Last call time                                                 |                        |                     |  |  |
| Device status BOOT STATUS                |                                           |                                              | 0 42 42      | 0x3                                          | 2a                                                             | 2023-07-03T10-53-20 06 |                     |  |  |
| Device is open.                          | Close                                     | PCIE_IRQ_ENA<br>PCIE_IRQ_ACK_TIMEOUT<br>BSP  |              |                                              |                                                                |                        | Avg. update inteval |  |  |
| Device properties                        |                                           | AREA_SPI_DIV                                 |              |                                              |                                                                |                        |                     |  |  |
| Device name                              |                                           | AREA_SPI_ADC  ch0 top                        |              |                                              |                                                                |                        |                     |  |  |
| ADC_BOARD                                |                                           | FCM                                          |              |                                              |                                                                |                        |                     |  |  |
| Device identifier                        |                                           | TIMING                                       |              |                                              |                                                                |                        |                     |  |  |
| (sharedMemoryDummy?map=examp Find Module |                                           |                                              |              |                                              |                                                                |                        |                     |  |  |
| Map file                                 |                                           |                                              |              |                                              |                                                                |                        |                     |  |  |
|                                          |                                           | Autoselect previous register                 | Collapse All |                                              |                                                                |                        | Chimeral            |  |  |
| Load Decede                              |                                           | Sort Modules/Registers                       | Expand All   |                                              |                                                                |                        | -0                  |  |  |

#### -Kristiaan Pelckmans

# **Progress so far...**

- System shipped to CERN from Uppsala, installed in the form CLIC test facility.
- RF signal acquisition, generation and feedback/forward loops tested.
- Use of DESY BSP and python GUI.
- External trigger injection through RJ45 connector on SIS8300KU AMC, distributed to mLVDS lines.
  - Currently under test/development (still some bugs to iron out)
- Work progressing well on a DESYRDL to CERN/Cheby convertor script.





#### **Next steps**

- Fully validate the external trigger injection and synchronise to the CLEAR accelerator complex.
- Replace DESY RDL register map with CERN Cheby based one.
- Develop FESA class for acquisition and control.
- Install CTRA (CERN timing infrastructure card), to fully integrate into the CERN controls infrastructure.
  - AMC FMC carrier (AFC) and CERN developed timing receiver FMC.
- Connect the VM to the RF power plant and close the loops.
- 3GHz DeRTM-LOG still under development at DESY and KVG. We would like to use this for the final system with 5+ cards.





AFC FMC carrier: https://ohwr.org/project/afc DeRTM-LOG



AWAKE Run 2c photocathode gun installed in former CLIC Test Facility



#### **Advertisement: Cheby + Reksio**

Register map tool now open source:

Cheby:

- File format to describe the HW/SW interface (the memory map)
- A set of tools to generate HDL, drivers, documentation... from these files

https://gitlab.cern.ch/be-cem-edl/common/cheby

**Reksio: GUI to interface with Cheby.** 

06/12/2023

https://gitlab.cern.ch/Cheburashka/gui

| Eile Edit Search View Act          | reksio build 2020.02.14.13.51 /opt/jbetz/work/sps_newStd/sps_co       | ontainer/ | MemMap/SPS200C                    | avityLoops      | .cheby (on cwe-513-\ | ol992.cer | n.ch) | _      | _      | <b>†</b> | - □  |
|------------------------------------|-----------------------------------------------------------------------|-----------|-----------------------------------|-----------------|----------------------|-----------|-------|--------|--------|----------|------|
| + - × 🗅 ^ v                        | ✓ 品                                                                   |           |                                   |                 |                      |           |       |        |        |          |      |
| Nodes tree                         |                                                                       | ØX        | Attributes                        |                 |                      |           |       |        |        |          | 6    |
| Type                               | Name                                                                  |           | Attribute                         | Value           | 2                    |           |       |        |        |          |      |
| T T momoriu-man                    | sps200CavityControl                                                   |           | name                              | hwin            | fo                   |           |       |        |        |          |      |
| - @ driven edge                    | spszoocavitycontrol                                                   | -         | bus                               | cern-           | be-vme-err-32        |           |       |        |        |          |      |
| • 🗇 x-ariver-eage                  |                                                                       |           | <ul> <li>schema-versio</li> </ul> | n               |                      |           |       |        |        |          |      |
| pci-bars                           |                                                                       |           | core                              | 2.0.0           | 1                    |           |       |        |        |          |      |
| Ip-core-description                | ns                                                                    |           | x-gena                            | 1.0.0           |                      |           |       |        |        |          |      |
| 👻 🗂 submap                         | hwinfo                                                                |           | x-hdl                             | 1.0.0           | 1                    |           |       |        |        |          |      |
| 🕨 🗂 memory-map                     | hwinfo                                                                |           | x-fesa                            | 2.0.0           |                      |           |       |        |        |          |      |
| 🕨 🗇 submap                         | cavityLoops                                                           |           | x-driver-edg                      | <b>je</b> 1.0.0 |                      |           |       |        |        |          | _    |
| ▶ 🗇 submap                         | modulation                                                            |           | x-conversio                       | ns 1.0.0        |                      |           |       |        |        |          |      |
| ⊢                                  | timingGen                                                             |           | x-wbgen                           | 1.0.0           |                      |           |       |        |        |          |      |
| ) 🗇 subman                         | fac                                                                   |           | x-map-into                        | 1.0.0           |                      |           |       |        |        |          |      |
| > C subman                         | ageCoreEvt                                                            |           | - x-unver-euge                    | a REH           | WINEO                |           |       |        |        |          |      |
| , submap                           | acqcoleExt                                                            | _         | × x-man-info                      |                 | WINT O               |           |       |        |        |          |      |
| submap                             | acquoreint                                                            |           | memmap-ve                         | rsion 0.0.1     |                      |           |       |        |        |          |      |
| 🕨 🗂 submap                         | rfnco                                                                 | *         | <ul> <li>computed</li> </ul>      |                 |                      |           |       |        |        |          |      |
| Available attributes               |                                                                       | ର ହ       | address                           | 0x0             |                      |           |       |        |        |          |      |
| hus                                |                                                                       |           | size                              | 24              |                      |           |       |        |        |          |      |
| size                               |                                                                       | _         | align                             | 0x4             |                      |           |       |        |        |          |      |
| word-endian                        |                                                                       |           | offset_addr                       | ess 0x0         |                      |           |       |        |        |          |      |
| name                               |                                                                       |           |                                   |                 |                      |           |       |        |        |          |      |
| description                        |                                                                       | _         |                                   |                 |                      |           |       |        |        |          |      |
| comment                            |                                                                       |           |                                   |                 |                      |           |       |        |        |          |      |
| version                            |                                                                       |           |                                   |                 |                      |           |       |        |        |          |      |
| <ul> <li>schema-version</li> </ul> |                                                                       |           |                                   |                 |                      |           |       |        |        |          |      |
| core                               |                                                                       |           |                                   |                 |                      |           |       |        |        |          |      |
| x-hdl                              |                                                                       |           |                                   |                 |                      |           |       |        |        |          |      |
| x-wbgen                            |                                                                       |           |                                   |                 |                      |           |       |        |        |          |      |
| x-fesa                             |                                                                       |           |                                   |                 |                      |           |       |        |        |          |      |
| x-ariver-eage                      |                                                                       |           |                                   |                 |                      |           |       |        |        |          |      |
| x-gena<br>x-conversions            |                                                                       |           |                                   |                 |                      |           |       |        |        |          |      |
| x-man_info                         |                                                                       | -         |                                   |                 |                      |           |       |        |        |          |      |
| <ul> <li>computed</li> </ul>       |                                                                       |           |                                   |                 |                      |           |       |        |        |          |      |
| compared                           | 1.1.1                                                                 | •         |                                   |                 |                      |           |       |        |        |          |      |
| Available attributes Availabl      | e children                                                            |           |                                   |                 |                      |           |       |        |        |          |      |
| Cancela                            |                                                                       |           |                                   |                 |                      |           |       |        |        |          |      |
| Lonsole                            |                                                                       | 0 a       |                                   |                 |                      |           |       |        |        |          |      |
| Info: Submap fgc_ddr saved in /o   | pt/jbetz/work/sps_newStd/sps_container/IPCores/fgc_ddr/fgc_ddr.cheby. |           |                                   |                 |                      |           |       |        |        |          |      |
| nfo: "Memory map saved in /opt     | jbetz/work/sps_newStd/sps_container/MemMap/JDB_SPS_FGC.cheby"         |           |                                   |                 |                      |           |       |        |        |          |      |
| nfo: "Memory map /opt/jbetz/wo     | rk/sps_newStd/sps_container/MemMap/SPS200CavityLoops.cheby loaded."   |           |                                   |                 |                      |           |       |        |        |          |      |
| Info: Memory map is valid!         |                                                                       |           | Children overview                 |                 |                      |           |       |        |        |          | 1    |
| no: Memory map is valid!           |                                                                       |           |                                   |                 |                      |           |       |        |        |          |      |
|                                    |                                                                       |           |                                   |                 |                      |           |       |        |        |          |      |
|                                    |                                                                       |           | rea                               |                 |                      |           |       |        |        |          |      |
|                                    |                                                                       |           |                                   |                 | 1. 1.1               | 1.04      |       |        |        |          |      |
|                                    |                                                                       |           | name 🔺                            | address         | description          | width     | type  | access | preset | constant | com  |
|                                    |                                                                       |           | stdVersion                        | 0x0             |                      | 32        |       | ro     |        |          | 0x0  |
|                                    |                                                                       |           | serialNumber                      | 0x4             | HW serial number     | 64        |       | ro     |        |          | 0x4  |
|                                    |                                                                       |           | firmwareVersion                   | 0xc             | Firmware Version     | 32        |       | ro     |        |          | 0xC  |
|                                    |                                                                       |           | memManVersion                     | 0x10            | Memory Man Version   | 32        |       | ro     |        |          | 0x10 |
|                                    |                                                                       |           | ache                              | 0x10            | Echo register        | 32        |       | 10     |        |          | 0+14 |
|                                    |                                                                       |           | echo                              | UX14            | Ecno register        | 32        |       | rw     |        |          | 0X14 |
|                                    |                                                                       |           |                                   |                 |                      |           |       |        |        |          |      |
| Python interpreter                 |                                                                       | o x       |                                   |                 |                      |           |       |        |        |          |      |
|                                    |                                                                       |           |                                   |                 |                      |           |       |        |        |          |      |
|                                    |                                                                       |           | 4                                 |                 |                      |           |       |        |        |          |      |
|                                    |                                                                       |           |                                   |                 |                      |           |       |        |        |          |      |



#### **Thank You!**



#### **Questions?**





home.cern

#### **Extra Slides**



### **AWAKE run 2c upgrade**

- Two RF photocathode guns with S-band and X-band structures.
- Requires pulse to pulse stability of 30 fs  $\rightarrow$  active stabilisation with LLRF loops.
- Prototype microTCA LLRF system, currently undergoing tests at CERN through collaboration with Uppsala University.





AWAKE