Presentation is loading. Please wait.

Presentation is loading. Please wait.

EVG-to-EVR Data Transfer (Dayle Kotturi)

Similar presentations


Presentation on theme: "EVG-to-EVR Data Transfer (Dayle Kotturi)"— Presentation transcript:

1 EVG-to-EVR Data Transfer (Dayle Kotturi)

2 EVG Event Time Line – 4 Fiducials
360Hz Fiducial F0 (n=0) F1 (n=1) F2 (n=2) F3 (n=3) Time (msec) 1.0 2.8 5.6 8.3 9.3 HW starts sending event codes, starting with fiducial event code R0 R1 R2 R3 Receive Fn+3 PNET, determine and send Fn+3 LCLS pattern, advance pipeline (n-2->n-1->n), set event codes in alternate RAM for FN=1 P0 P1 P2 P3 120Hz BEAM B-3 B0 HW finishes sending event codes, switch RAMs R0 R1 R2 R3

3 EVR Event Time Line – 4 Fiducials
PATTERN n-3 PATTERN n-2 PATTERN n-1 PATTERN n P-1 P-2 P-3 P-4 P-1 P-2 P-3 P0 P-1 P-2 P-3 P0 P-1 P-2 P1 P0 P-1 P-2 P1 P0 P-1 P2 P1 P0 P-1 P2 P1 P0 P3 P2 P1 P0 360Hz Fiducial F0 (n=0) F1 (n=1) F2 (n=2) F3 (n=3) Time (msec) 2.8 5.6 8.3 9.3 HW starts receiving event codes, starting with fiducial event code R0 R1 R2 R3 Process Pn-3 pattern, advance pipeline (n-3->n-2->n-1->n), and prepare BSA based on the n records L0 L1 L2 L3 Receive Fn+3 LCLS pattern and copy into temporary storage P0 P1 P2 P3 120Hz BEAM B-3 B0 HW finishes receiving event codes R0 R1 R2 R3

4 Trigger Event Time Line – 1 Beam Pulse (B0)
Record processing (event, interrupt) Hardware Triggers Receive pattern for 3 pulses ahead Post-Beam Acq Event Timestamp, pattern records, and BSA ready Beam Kly Standby Acq Trigger Last Event (255) Received Laser Control Fiducial Event (1) Received Fiducial F3 B0 30 500 1023 Time (usec) 0.3 Event Codes 1-111,

5 EVG 360 Hz Data Flow Diagram
BSA Enable Records (2) Fiducial sub Record PULSEID Pattern n (120Hz) Record LNK1 LNK3 Advance Times Pattern (360Hz) Record first dbProcess BSA EDEF History/Snapshot Records LNK2 FLNK LCLS Time Stamps INP Pn – New Pattern Processing Pattern n-1 Record FLNK INP Sequence RAM Setup Records FLNK High Priority PNET Task Pattern n-2 Record INP FLNK FLNK second dbProcess Fanout Record En – Set Event Codes Write to Pipeline Pattern n-3 sub Record Event Event Task post_event BSA EDEF Check, Set, Init Records PNET Avail ISR FLNK FLNK Ln – Send Pattern Module720 Diagnostics Records Data Data Check sub Record INP VME PNET Data Space NTP Client System Time Stamp BSA EDEF Records Bunch Charge Determination Records

6 EVR 360 Hz Data Flow Diagram
BSA Enable Records (2) Ln - Fiducial Event Processing PULSEID Fiducial sub Record Pattern n (120Hz) Record LNK3 LNK1 Advance Times Pattern (360Hz) Record SLC-Aware EVR Check Records Event ISR LNK2 Event LNK4 second dbProcess FLNK INP VME, PCI Pattern n-1 Record LCLS Time Stamps Wakeup INP FLNK FLNK High Priority EVR Task Pattern n-2 Record INP Fanout Record Write to Pipeline Pn - New Pattern Processing first dbProcess FLNK Data Avail ISR EDEF Meas Severity Record Pattern n-3 sub Record Modulo 720 Diagnostics Records Data post_event VME, PCI Pattern Data Space dbProcess Event Task BSA Reset Sequence Records

7 Pattern Subroutine Record
C – Time slot (1 to 6) D,E,F,G,H – MODIFIER1 to 5: Beam Modifiers (4 for PNET, 1 for 20 EDEF active bits and 12 TBD bits) I – BUNCHCHARGE (in picoCoulombs, value normally between 200 to 1000) J – BEAMCODE decoded from MODIFIER1 by pattern sub record A, B – EDEF measurement severity masks used to create EDEF measurement severities K – EDEF average done mask L - PULSEID decoded from lower 17 bits in the LCLS timestamp by pattern sub record (0x1FFFF = invalid)

8 EVR Data Contents and Order
EVG: 4 PNET 32 bit unsigned integers (MODIFIER1 to 4). EVR: 2 16 bit unsigned integers – header consisting of waveform type (pattern or TBD) and version number 1 LCLS 32 bit unsigned integer (MODIFIER5) 4 LCLS 32 bit EDEF masks: Average done Don’t use minor severity data in average Don’t use major severity data in average Initialize – rearm compress records and reset averages 2 LCLS timestamp 32 bit unsigned integers 1 bunch charge 32 bit unsigned integer (BUNCHCHARGE)

9 LCLS Pipeline Timestamps
Table of 4 EPICS timestamps/status, protected by mutex. Each timestamp is 2 32bit integers and each status is 1 32bit integer: First timestamp integer: #secs since 1990 Second timestamp integer: #nsecs since last second but with the lower 17bits containing encoded pulse ID Status integer: 0 = OK, -1 = invalid Each timestamp/status is associated with an index: 0 = current pulse (Pn) 1 = next (upcoming) pulse (Pn-1) 2 = two pulses in the future (Pn-2) 3 = three pulses in the future (Pn-3) The table is initialized with system time and invalid status. The timestamp and status is updated at 360Hz during fiducial and pattern processing

10 LCLS Event Code Timestamps
Table of 256 EPICS timestamps/status, protected by mutex. Each timestamp is 2 32bit integers and each status is 1 32bit integer: First timestamp integer: #secs since 1990 Second timestamp integer: #nsecs since last second but with the lower 17bits containing encoded pulse ID Status integer: 0 = OK, -1 = invalid Each timestamp/status is associated with an event code from the EVR. Event code 0 has the current timestamp updated at 120hz (only on the 2 time slots served by the IOC). The table is initialized with system time and invalid status. The timestamp and status is updated whenever an event code, with an enabled IRQ, is received by the EVR. All records on the IOC uses a timestamp from this table depending on the record’s TSE field. The default TSE is zero - these records use the event code 0 timestamp. If the status is invalid, the record timestamp will be system time with an encoded invalid pulse ID.

11 Common EVG and EVR Software Error Conditions
Data/PNET Avail ISR: Overwrite message space – update counter No space available (space currently being readout by the task) – update counter Check sum error (EVR only for now) – update counter Task is busy (taking too much time) – update counter Data Processing (record set invalid): No data available (TIMEOUT) Other read error or version/type mismatch (INVALID_DATA) Error creating (EVG) or writing (EVR) LCLS timestamp (INVALID_TIME) Upstream MPG (EVG) or EVG (EVR) is unsynchronized (MPG_IPLING) Fiducial Subroutine Record Processing: Error advancing LCLS timestamps - set error flag. Pulse ID error (any invalid PULSEID or non-consecutive PULSEIDs) – set appropriate counters. Set error flag. If the upcoming 3 pulses are the same, set timestamp to invalid.

12 EVG-only Software Error Conditions
PNET Data Check Subroutine Processing: Set record invalid and reset pulse ID and base rate modulo counter if any of these conditions is true: MPG is IPLing Time slot not synchronized with MPG Time slot pattern (SEQCHK) not synchronized with MPG Time slot and time slot pattern mismatch Modulo720 not synchronized with MPG Pulse ID not synchronized with MPG Pattern Creation Subroutine Processing: Error getting system time – set record and timestamp to invalid and don’t send pattern to EVRs. Any of the above errors – set record invalid but send pattern on to EVR with the MPG_IPLING bit set.

13 EVR Hardware Error Conditions (John Dusatko)
Unplugged fiber: the EVR has a bit in its CSR called RX_VIO. This bit gets set when there is either a bit error or loss of signal. This toggles the CSR bit, lights up the red front panel "RX ERR" LED and also can be programmed to generate an interrupt. Binary input record is processed every 2 seconds to check this condition. The EVR also has a "heartbeat" mechanism which looks like it basically does a watchdog function: the EVG can send out a special heartbeat reset event code that resets the EVR's heartbeat counter. The counter seems to have a hard-wired timeout of 1.6 sec. The timeout condition sets a register bit as well as can be programmed to generate an interrupt. So it looks like they thought of some error checking mechanisms. Software ignores this condition since it detects missing fiducials within 0.06 sec instead and then sets records invalid (TIMEOUT error).

14 EVG Hardware Error Conditions
No errors when fiducial or clock is missing PNET SDLC and other errors Ignored by software – will result in TIMEOUT and unsynchronized data errors. Loss of PNET (MPG down, cable disconnected, etc) Software times out in 0.04 sec, sets records invalid, and sends data to EVR with an invalid pulse ID and the MPG_IPLING bit set.


Download ppt "EVG-to-EVR Data Transfer (Dayle Kotturi)"

Similar presentations


Ads by Google