diff --git a/.gitlab-ci.yml b/.gitlab-ci.yml index 3eec78441255290a23c74d00c8305dc22868c791..b4e4f5a75e93b8eab50b50083b2a23f578f33c12 100644 --- a/.gitlab-ci.yml +++ b/.gitlab-ci.yml @@ -26,7 +26,6 @@ # . See https://support.astron.nl/confluence/display/L2M/L3+SDP+Decision%3A+Gitlab+pipeline+automation+to+test+SDPFW+with+OPC+UA stages: - - linting - simulation - synthesis - hardware @@ -52,7 +51,7 @@ lint-vhdl-lib-dsp: script: - cd libraries/dsp - find . -name "*.vhd" -exec vsg -c ../../vsg_config.yaml -f {} \; - + lint-vhdl-lib-io: tags: - hdl @@ -63,7 +62,7 @@ lint-vhdl-lib-io: script: - cd libraries/io - find . -name "*.vhd" -exec vsg -c ../../vsg_config.yaml -f {} \; - + lint-vhdl-lib-technology: tags: - hdl @@ -112,7 +111,7 @@ lint-vhdl-applications-lofar2: # HDL simulation stage ############################################################################### sim-compile: - tags: + tags: - fpga stage: simulation script: @@ -124,12 +123,12 @@ sim-compile: - build/ sim-run: - tags: + tags: - fpga stage: simulation script: - echo "Running simulations" -# - test -f "build/info.txt" # This fails despite having artifact (see +# - test -f "build/info.txt" # This fails despite having artifact (see # sim-compile code block where a folder and # file are generated and preserved by using # 'artifacts'). @@ -138,21 +137,21 @@ sim-run: # HDL synthesis stage ############################################################################### synth-compile: - tags: + tags: - fpga stage: synthesis script: - echo "Compiling for synthesis" synth-check-fmax: - tags: + tags: - fpga stage: synthesis script: - echo "Checking achieved fMax" synth-check-programming-files: - tags: + tags: - fpga stage: synthesis script: diff --git a/applications/lofar2/doc/prestudy/station2_sdp_transient_buffer.txt b/applications/lofar2/doc/prestudy/station2_sdp_transient_buffer.txt index c90a88688f9bf3c446042e7567287b4b5c63c4d8..9a54def39092dd7ed5021298802a2956d79552a0 100644 --- a/applications/lofar2/doc/prestudy/station2_sdp_transient_buffer.txt +++ b/applications/lofar2/doc/prestudy/station2_sdp_transient_buffer.txt @@ -7,8 +7,9 @@ Detailed design: Transient Buffer (TBuf) function for LIFT project 3) TBB (Transient Buffer Board) LOFAR1 4) TBuf (Transient Buffer) Design 5) TBuf ICD SC-SDP, SDPTR-SDPFW -6) TBuf ICD STAT/SDP-CEP -7) Crossbar +6) SC / dump tool operation +7) TBuf ICD STAT/SDP-CEP +8) Crossbar 10) Planning 11) Transient detection (TDet) Design @@ -253,107 +254,124 @@ The CP FPGA_beamlet_output_nof_beamlets_RW is not supported in SDPTR and SDPFW y * In LOFAR1 bepaald LCU welke si uitgelezen moet worden richting CEP. De TBB uP zorgt dan dat de nof pages verstuurd worden. * Only FPGA_TBuf CP and MP. No need for TR_tbuf CP or MP +* SDPTR translates between double float timestamp = integer RSN * T_adc - Control Points (CP) en Monitor Points (MP): * Raw data: . W_adc = 14b, always use all ADC bits, so no need for W_raw. . W_ant = N_pol * W_adc = 28b - . c_tbuf_raw_sample_period - = 5 ns at FPGA_sdp_info_f_adc_R = 200 MHz - = 6.25 ns at FPGA_sdp_info_f_adc_R = 160 MHz + . SDPTR: raw sample period T_adc from FPGA_sdp_info_f_adc_R: + T_adc = 5 ns at FPGA_sdp_info_f_adc_R = 200 MHz + T_adc = 6.25 ns at FPGA_sdp_info_f_adc_R = 160 MHz - * RSN source (dp_rsn_source with nof_clk_per_sync register) + * RSN source (= dp_rsn_source.vhd) FPGA_processing_enable_RW - . SDPTR: set tbuf_nof_clk_per_sync dependent on FPGA_sdp_info_f_adc_R - . SDPFW: start RSN source at BSN sync, RSN derived from BSN + . SDPTR: sets nof_clk_per_sync in mms_dp_bsn_source.vhd dependent on FPGA_sdp_info_f_adc_R + . SDPFW: no need for MM interface: + use nof_clk_per_sync from dp_bsn_source also for dp_rsn_source + start RSN source when dp_bsn_source is (re)started, derive RSN from BSN . c_tbuf_nof_samples_per_block = c_tbuf_nof_samples_per_page = c_tbuf_nof_samples_per_packet = 2000 - . tbuf_nof_block_per_sync = tbuf_nof_clk_per_sync / c_tbuf_nof_samples_per_packet + . nof_block_per_sync = nof_clk_per_sync / c_tbuf_nof_samples_per_packet = 100k for sync interval 1 s at FPGA_sdp_info_f_adc_R = 200 MHz = 80k for sync interval 1 s at FPGA_sdp_info_f_adc_R = 160 MHz * RSN monitor (dp_bsn_monitor) - . FPGA_tbuf_signal_input_timestamp_R = FPGA_tbuf_signal_input_rsn_R * raw_sample_period . FPGA_tbuf_signal_input_rsn_R = RSN at sync - FPGA_tbuf_signal_input_nof_blocks_R : expected value tbuf_nof_block_per_sync - FPGA_tbuf_signal_input_nof_samples_R : expected value tbuf_nof_clk_per_sync + FPGA_tbuf_signal_input_nof_blocks_R : expected value nof_block_per_sync = 100k or 80k + FPGA_tbuf_signal_input_nof_samples_R : expected value nof_clk_per_sync = 200M or 160M * Record: . FPGA_tbuf_record_all_RW[pn] True = record all antenna inputs, - False = record only half of the antenna inputs, the once that have even index. + False = record only half of the antenna inputs, the half that have even index. . FPGA_tbuf_record_enable_RW[pn] - True = start/continue, + FPGA_tbuf_record_enable_R[pn] + True = start/continue recording, all ai or half of ai (dependent on FPGA_tbuf_record_all_RW) False = stop/freeze recording immediately * Recording: - . FPGA_tbuf_recording_R[pn] - True = pn is recording, all ai or half of ai (dependent on FPGA_tbuf_record_all_RW) - False = pn is frozen - - . FPGA_tbuf_recorded_last_timestamp_R[pn] = recorded_last_rsn * raw_sample_period - . FPGA_tbuf_recorded_first_timestamp_R[pn] = recorded_first_rsn * raw_sample_period - . FPGA_tbuf_recorded_time_interval_R[pn] = FPGA_tbuf_recorded_last_timestamp_R - FPGA_tbuf_recorded_first_timestamp_R - While FPGA_tbuf_recording_R = True then the last and first timestamps will increment in time - After the circular buffer has filled, then the time_interval will remain fixed at maximum. + . FPGA_tbuf_recorded_last_timestamp_R[pn] = reg_recorded_last_rsn_R * T_adc + . FPGA_tbuf_recorded_first_timestamp_R[pn] = reg_recorded_first_rsn_R * T_adc + . FPGA_tbuf_recorded_time_interval_R[pn] = (reg_recorded_last_rsn_R - reg_recorded_first_rsn_R) * T_adc + While FPGA_tbuf_record_enable_R = True then the last timestamp will increment in time and + the first timestamp will remain constant until the circular buffer has filled once. + After that the first timestamp will also increment in time, and the time_interval + between first and last will remain fixed at maximum buffer time. * Dumping: - . FPGA_tbuf_dump_inter_packet_gap_RW --> wait time between packets send to CEP in raw_sample_period units - . FPGA_tbuf_dump_timestamp_range_RW[pn][start, end] - [0] = start timestamp, - [1] = end timestamp - SDPTR translates between float timestamp = integer RSN * raw_sample_period + . FPGA_tbuf_dump_inter_packet_time_RW + Wait time in seconds between packets send to CEP. SDPTR translates float time into + T_adc units. + + . FPGA_tbuf_dump_start_timestamp_RW[pn] + FPGA_tbuf_dump_start_timestamp_R[pn] = reg_dump_start_rsn_RW * T_adc + Timestamp of first packet that will be dumped. Equals FPGA_tbuf_dump_start_timestamp_RW + if it exists in the buffer. + . FPGA_tbuf_dump_end_timestamp_RW[pn] + FPGA_tbuf_dump_end_timestamp_R[pn] + Timestamp of last packet that will be dumped. Equals FPGA_tbuf_dump_end_timestamp_RW + if it exists in the buffer. + . FPGA_tbuf_dump_nof_packets_R[pn] = reg_dump_nof_pages_RW + Amount of packets that will be dumped for range that is requested via FPGA_tbuf_dump_start_timestamp_RW + and FPGA_tbuf_dump_end_timestamp_RW. Forced to 0 if requested tange is not in buffer. + Each packet contains c_tbuf_nof_samples_per_packet = 2000 raw samples. This corresponds + to c_tbuf_nof_samples_per_packet * T_adc = 2000 * 5 ns = 10 us or 2000 * 6.25 ns = 12.5 us + of raw sample data per packet. Hence it takes about 100 packets to transport 1 ms of + raw sample data for one antenna input, and about 100000 packets to transport 1 s. + . FPGA_tbuf_dump_enable_RW[pn][ai] - True = start / keep dumping packets for the requested ai, - False = stop dumping + FPGA_tbuf_dump_enable_R[pn][ai] = value of FPGA_tbuf_dump_enable_RW in SDPFW + True = start / keep dumping packets for the requested ai, dumping stops when all + packets have been dumped, it is not necessary to explicitely stop the dumping. + - when busy then FPGA_tbuf_memory_read_nof_packets_R increments until it reaches value of + FPGA_tbuf_dump_nof_packets_R + - when finished then FPGA_tbuf_memory_remaining_nof_packets_R = 0 + False = stop dumping packets immediately SDPFW: - loops over one or multiple ai SC / dump tool: - takes care that only one global pn is selected at a time to avoid 10GbE link overload - - loops global pn, ai via FPGA_tbuf_dump_enable_RW and FPGA_tbuf_dumping_R - - use FPGA_tbuf_dumping_R to see whether PN is busy dumping, - - use FPGA_tbuf_dump_remaining_nof_packets_R = 0 to see whether PN dumping has finished - if FPGA_tbuf_dump_enable_RW is made False before PN dumping has finished, then - FPGA_tbuf_dump_remaining_nof_packets_R can be > 0. - - . FPGA_tbuf_dumping_R[pn] - True when dump is busy, - False when dump has finished. - - when busy then FPGA_tbuf_read_nof_packets_R increments until it reaches initial value of - FPGA_tbuf_dump_remaining_nof_packets_R - - when finished then FPGA_tbuf_dump_remaining_nof_packets_R = 0 - - . FPGA_tbuf_dump_nof_packets_R[pn][ai] - amount of packets that will be dumped for FPGA_tbuf_dump_timestamp_range_RW, - forced to 0 if FPGA_tbuf_dump_timestamp_range_RW is not in buffer - - . FPGA_tbuf_dump_remaining_nof_packets_R[pn][ai] + - loops global pn, ai via FPGA_tbuf_dump_enable_RW + + . FPGA_tbuf_memory_remaining_nof_packets_R[pn][ai] amount of packets that still need to be dumped, - = 0, when FPGA_tbuf_dump_enable_RW is False, - = dump_last_page_index_RW - dump_first_page_index_RW + 1, when FPGA_tbuf_dump_enable_RW is True. + starting at reg_dump_nof_pages_RW and then decrementing down to 0, when + FPGA_tbuf_dump_enable_RW is True. If it does not reach 0 then there is something wrong in SDPFW. - FPGA_tbuf_read_nof_packets_R[pn][ai] + FPGA_tbuf_memory_read_nof_packets_R[pn][ai] amount of packets that have been read so far - FPGA_tbuf_read_nof_memory_errors_R[pn][ai] - amount of packets that have been read and had a CRC error, count per ai, because each ai has own CRC + FPGA_tbuf_memory_dropped_nof_packets_R[pn][ai] + amount of packets that have been read and had a CRC error, + count per ai, because each ai has own CRC - FPGA_tbuf_dumped_nof_packets_R[pn][ai] + FPGA_tbuf_memory_dumped_nof_packets_R[pn][ai] amount of packets that have been dumped, packets with a read error are not passed on for dump - = FPGA_tbuf_read_nof_packets_R - FPGA_tbuf_read_nof_memory_errors_R, + = FPGA_tbuf_memory_read_nof_packets_R - FPGA_tbuf_memory_dropped_nof_packets_R, Not: FPGA_tbuf_clear_total_counts_RW[pn] --> clear all TBuf total counts in pn, total count not needed if MP is read after every dump Not: FPGA_tbuf_dump_enable_RW[pn] -- antenna index Not: Fixed buffer sizes, so no need to allocate pages per ai. + * Ring transport: + * 10GbE output: . FPGA_tbuf_output_hdr_eth_destination_mac_RW . FPGA_tbuf_output_hdr_ip_destination_address_RW . FPGA_tbuf_output_hdr_udp_destination_port_RW - . FPGA_tbuf_output_enable_RW[pn] - True : pass on dumped packets to 10GbE output - False : stop 10GbE output + + . FPGA_tbuf_output_enable_RW[pn] = reg_output_enable_RW + Enable output on the pn at end of ring that has interface to CEP. + + * 10GbE output monitor: + . FPGA_tbuf_output_nof_packets_R[pn] + Number of dump packets that have been output while FPGA_tbuf_output_enable_RW = True, + reset to 0 when FPGA_tbuf_output_clear_counts_RW = True event + . FPGA_tbuf_output_clear_counts_RW[pn] + Use dp_strobe_total_count with MM clear register rather than in_clr = revt(reg_output_enable_RW) and + rather then dp_bsn_monitor with sync = revt(reg_output_enable_RW). * Memory DDR4: With streaming use of io_ddr then the dvr_wr_flush_en = '0' (so ctlr_wr_flush_en = 0 in MP), because @@ -391,65 +409,93 @@ The CP FPGA_beamlet_output_nof_beamlets_RW is not supported in SDPTR and SDPFW y * Memory buffer: REG_TBUF_RAW new in node_sdp_transient_buffer_raw.vhd - . record_all_RW + . reg_record_all_RW = FPGA_tbuf_reg_record_all_RW True = record all antenna inputs, False = record only half of the antenna inputs, the once that have even index. - . record_enable_RW - True = pn is recording, all ai or half of ai (dependent on record_all_RW) + . reg_record_enable_RW = FPGA_tbuf_record_enable_RW + True = pn is recording, all ai or half of ai (dependent on reg_record_all_RW) False = pn is frozen . c_tbuf_nof_samples_per_page = c_tbuf_nof_samples_per_packet = 2000 - . nof_ddr_words_per_page_R = 657 or 329, depends on FPGA_tbuf_record_all_RW - SDPTR: ddr_nof_pages = floor(ddr_gigabytes * 1024**3 / (nof_ddr_words_per_page_R * ctrl_nof_bytes_per_ddr_word) + . reg_nof_ddr_words_per_page_R = 657 or 329, depends on reg_record_enable_RW + SDPTR: ddr_nof_pages = floor(ddr_gigabytes * 1024**3 / (reg_nof_ddr_words_per_page_R * ctrl_nof_bytes_per_ddr_word) - . recorded_first_page_index_R - freezes when recording stops by record_enable_RW = False, - restarts at 0 when recording starts by record_enable_RW = True, + . reg_recorded_first_page_R + freezes when recording stops by reg_record_enable_RW = False, + restarts at 0 when recording starts by reg_record_enable_RW = True, first page that was recorded in ddr, remains 0 until recording has filled the circular buffer once, - equals recorded_last_page_index + 1 when recording continues - recorded_last_page_index_R - freezes when recording stops by record_enable_RW = False, - restarts at 0 when recording starts by record_enable_RW = True, + equals reg_recorded_last_page_R + 1 when recording continues + reg_recorded_last_page_R + freezes when recording stops by reg_record_enable_RW = False, + restarts at 0 when recording starts by reg_record_enable_RW = True, last page that was recorded in ddr, increments during recording - . recorded_first_rsn_R - RSN of block at recorded_first_page_index - recorded_last_rsn_R - RSN of block at recorded_last_page_index + . reg_recorded_first_rsn_R + RSN of block at reg_recorded_first_page_R + reg_recorded_last_rsn_R + RSN of block at reg_recorded_last_page_R + + . reg_dump_start_page_RW --> index of start page to dump, same for all ai in pn + reg_dump_start_rsn_RW --> RSN of reg_dump_start_page_RW + reg_dump_nof_pages_RW + Number of pages = packets to dump, starting at reg_dump_start_page_RW, + Use nof_pages instead of index of last_page, to be able to set 0 pages, same for all ai in pn - . dump_first_page_index_RW --> index of first page to dump, same for all ai in pn - dump_last_page_index_RW --> index of last page to dump, same for all ai in pn SDPTR: # Get RSN range from timestamp range - FPGA_tbuf_dump_timestamp_range_RW / raw_sample_period --> dump_start_rsn, dump_end_rsn + dump_start_rsn = FPGA_tbuf_dump_start_timestamp_RW / T_adc + dump_end_rsn = FPGA_tbuf_dump_end_timestamp_RW / T_adc # Determine start page that includes start RSN - offset_page = floor((dump_start_rsn - recorded_first_rsn_R) / c_tbuf_nof_samples_per_page) + offset_page = floor((dump_start_rsn - reg_recorded_first_rsn_R) / c_tbuf_nof_samples_per_page) if offset_page < 0: offset_page = 0 - dump_start_page = recorded_first_page_index + offset_page + dump_start_page = reg_recorded_first_page_R + offset_page # Determine end page that includes end RSN - offset_page = ceil((dump_end_rsn - recorded_last_rsn_R) / c_tbuf_nof_samples_per_page) + offset_page = ceil((dump_end_rsn - reg_recorded_last_rsn_R) / c_tbuf_nof_samples_per_page) if offset_page > 0: offset_page = 0 - dump_end_page = recorded_last_page_index + offset_page + dump_end_page = reg_recorded_last_page_R + offset_page dump_nof_pages = dump_end_page - dump_start_page + 1 - - # Report nof packts that will be dumped - FPGA_tbuf_dump_nof_packets_R = 0 if dump_nof_pages > 0: - FPGA_tbuf_dump_nof_packets_R = dump_nof_pages + dump_nof_pages = 0 + + # Set packets that will be dumped by SDPTR + reg_dump_start_page_RW = dump_start_page + reg_dump_nof_pages_RW = dump_nof_pages + + . reg_memory_read_nof_packets_R[ai] + amount of packets that have been read so far + reg_memory_read_nof_errors_R[ai] + amount of packets that have been read and were dropped because they had a CRC error, + count per ai, because each ai has own CRC + reg_memory_remaining_nof_packets_R[ai] + amount of packets that still need to be read, + = reg_dump_nof_pages_RW - reg_memory_read_nof_packets_R + reg_memory_dumped_nof_packets_R[ai] + amount of packets that have been read correctly and were passed on to ring + = reg_memory_read_nof_packets_R - reg_memory_read_nof_errors_R + + FPGA_tbuf_memory_read_nof_packets_R[pn][ai] = reg_memory_read_nof_packets_R + FPGA_tbuf_memory_dropped_nof_packets_R[pn][ai] = reg_memory_read_nof_errors_R + FPGA_tbuf_memory_remaining_nof_packets_R[pn][ai] = reg_memory_remaining_nof_packets_R + FPGA_tbuf_memory_dumped_nof_packets_R[pn][ai] = reg_memory_dumped_nof_packets_R + + FPGA_tbuf_memory_clear_counts[pn] + Use dp_strobe_total_count with MM clear register, rather than in_clr = revt(reg_dump_enable_RW) + to clear all reg_memory_* counters. + + . reg_dump_enable_RW[ai] + True = start / keep dumping packets for the requested ai, + False = stop dumping packets immediately + When True maintain reg_memory counters, when False clear reg_memory counters to 0. - SDPTR based on: - . FPGA_tbuf_dump_timestamp_range_RW[pn][rsn] (start_rsn, end_rsn) - . FPGA_tbuf_dump_enable_RW[pn][ai] - sets: - . dump_first_page_RW = page index of from_rsn - . dump_nof_pages_RW = nof pages in range from_rsn, to_rsn - . dump_antenna_input_RW = active ai in FPGA_tbuf_dump_enable_RW - . dump_enable_RW <-- enable to dump ai, + . reg_output_enable_RW + True : pass on dumped packets from ring to 10GbE output + False : stop 10GbE output immediately, any packets that still arrive from the ring will + be discarded. Not (no peek and poke): . FPGA_tbuf_memory_address_RW[pn] @@ -457,11 +503,84 @@ The CP FPGA_beamlet_output_nof_beamlets_RW is not supported in SDPTR and SDPFW y FPGA_tbuf_memory_read_data_R[pn] --> read data results from FPGA_tbuf_memory_read_nof_words_RW . FPGA_tbuf_memory_write_data_words_RW[pn] --> write data words (512b) to FPGA_tbuf_memory_address_RW - Not: FPGA_tbuf_page_period_R # = raw_sample_period * 23.36 us - - -6) TBuf ICD STAT/SDP-CEP +6) SC / dump tool operation + +* Initialize output: + . write FPGA_tbuf_output_hdr_eth_destination_mac_RW + . write FPGA_tbuf_output_hdr_ip_destination_address_RW + . write FPGA_tbuf_output_hdr_udp_destination_port_RW + +* Enable output: + . write FPGA_tbuf_output_enable_RW = True for pn that has the 10GbE interface to CEP + +* Prepare recording: + . write FPGA_tbuf_reg_record_all_RW + +* Monitor every 1 s: + . read FPGA_tbuf_signal_input_rsn_R = RSN at sync : expected increment by FPGA_tbuf_signal_input_nof_samples_R + every 1 s when FPGA_processing_enable_RW = True, else -1 + read FPGA_tbuf_signal_input_nof_blocks_R : expected value nof_block_per_sync = 100k or 80k + read FPGA_tbuf_signal_input_nof_samples_R : expected value nof_clk_per_sync = 200M or 160M + +* Loop: + * Start recording: + . write FPGA_tbuf_record_enable_RW = True to start recording, + . read FPGA_tbuf_record_enable_R to check that recording has started. + + * Wait until external trigger + + * Stop recording: + . write FPGA_tbuf_record_enable_RW = False to stop recording, + . read FPGA_tbuf_record_enable_R to check that recording has stopped, + . read FPGA_tbuf_recorded_last_timestamp_R[pn] and + read FPGA_tbuf_recorded_first_timestamp_R[pn] to know recorded time interval. + + * Clear counts: + . write FPGA_tbuf_output_clear_counts_RW = True to clear FPGA_tbuf_output_nof_packets_R + . write FPGA_tbuf_memory_clear_counts = True to clear FPGA_tbuf_memory_*_R counts + + * Prepare dump: + . write FPGA_tbuf_dump_start_timestamp_RW to request start time of dump interval + . write FPGA_tbuf_dump_end_timestamp_RW to request end time of dump interval + . read FPGA_tbuf_dump_start_timestamp_R to check actual start time of dump interval + . read FPGA_tbuf_dump_end_timestamp_R to check actual end time of dump interval + . read FPGA_tbuf_dump_nof_packets_R to know how many packets will be dumped per ai + + * Do dump: + for pn in range(N_pn): + . write FPGA_tbuf_dump_enable_RW = True to start dumping from pn + . read FPGA_tbuf_dump_enable_R to wait until dumping has started in pn, + for enabled ai in range(A_pn): + . read FPGA_tbuf_memory_read_nof_packets_R[ai] == FPGA_tbuf_dump_nof_packets_R and + read FPGA_tbuf_memory_remaining_nof_packets_R[ai] == 0 to wait until dumping has + finished for all ai. If it does not finish, then timeout break because there is + something wrong in SDPFW. + for enabled ai in range(A_pn): + . read FPGA_tbuf_memory_dropped_nof_packets_R[ai] to monitor nof dropped packets due to memory errors + . read FPGA_tbuf_memory_dumped_nof_packets_R[ai] to monitor nof packets that were put on ring + + In case of dump timeout: + . write FPGA_tbuf_dump_enable_RW = False to force stop dumping from pn + + * Monitor dump results: + . read packet counts: + N_remaining = sum(FPGA_tbuf_memory_remaining_nof_packets_R[pn][ai]) + N_read = sum(FPGA_tbuf_memory_read_nof_packets_R[pn][ai]) + N_dropped = sum(FPGA_tbuf_memory_dropped_nof_packets_R[pn][ai]) + N_dumped = sum(FPGA_tbuf_memory_dumped_nof_packets_R[pn][ai]) + N_lost = N_read - N_dropped - N_dumped + N_output = FPGA_tbuf_output_nof_packets_R + . Expected results: + . N_remaining == 0, else something went wrong in SDPFW + . N_dumped = N_read - N_dropped, else something went wrong in SDPFW + . N_dropped == 0, else packets got lost due to DDR4 memory access errors + . N_lost == 0, else packets got lost on the ring + . N_read == FPGA_tbuf_dump_nof_packets_R * nof active ai, else something went wrong in SDPFW + . N_output == N_read - N_dropped - N_lost, else something went wrong in SDPFW + + +7) TBuf ICD STAT/SDP-CEP - LOFAR1: - 16b preamble = 0xA55A --> 8b marker + 8b version_id (as in beamlet packet) @@ -488,20 +607,24 @@ The CP FPGA_beamlet_output_nof_beamlets_RW is not supported in SDPTR and SDPFW y . 8b version_id - 32b observation_id --> like for beamlets, may be useful for cosmic ray piggy back, not in LOFAR1 . 16b station_info - - 1b hba_antenna_field (HBA-0, HBA-1) - - 15b station_id + - 4b antenna_field_index (e.g. HBA-0, HBA-1) + - 12b station_id . 16b source_info (as in beamlet packet) - - 3b reserved - 1b antenna_band_index (LB, HB) - 2b nyquist_zone_index - 1b f_adc --> sample clock rate, period is 5 ns or 6.25 ns + - 3b reserved - 4b sample_width --> 14b, where 16b is represented by 0 - 5b gn_index --> purpose fault analysis . 32b reserved - . 8b signal_input_index --> 0..191 ==> antenna_input_index 0..95 + . 8b antenna_input_index --> 0..95 . 16b nof_samples_per_packet --> (8kB - 16) / 14b = 4672 (= 1022 words of 64b) --> log2() = 13b . 64b RSN = Sample Sequence Number --> is prefered over a BSN, because RSN can start at any sample, whereas a BSN has to fit start at 1970. +??? 4b antenna_field_index in station_info +??? 8b gn_index +??? 2 Byte antenne_input_index + - headers: 14 + 20 + 8 + 24 = 66 bytes crc: 4 bytes @@ -514,10 +637,12 @@ SigMF: Tammo Jan 25 nov 2022: -Hoi Eric, over het opslaan van complex voltage data, dat ik gisteren tijdens de group meeting even noemde: het metadataformaat heet SigMF. . Het is gewoon een json-bestandje dat je naast een databestand met alleen complex voltages opslaat. Een prima viewer hiervoor is inspectrum ( https://github.com/miek/inspectrum ). Als data formaat voor streaming complex voltages gebruiken we difi (een subset van vita49) over ZeroMQ. +Hoi Eric, over het opslaan van complex voltage data, dat ik gisteren tijdens de group meeting even noemde: het metadataformaat heet SigMF. +Het is gewoon een json-bestandje dat je naast een databestand met alleen complex voltages opslaat. Een prima viewer hiervoor is inspectrum +( https://github.com/miek/inspectrum ). Als data formaat voor streaming complex voltages gebruiken we difi (een subset van vita49) over ZeroMQ. -7) Crossbar +8) Crossbar * It is not possible to combine 3 * 12 * 14b = 3 * 168b = 514b into one controller word, because it must be possible to individually record and stop signal inputs. Therefore