Files
Jungfraujoch/FPGA_SETTINGS.html
T
2026-04-16 12:12:54 +00:00

1 line
38 KiB
HTML

<!DOCTYPE html> <html lang=en data-content_root="./"> <meta charset=utf-8 /> <meta name=viewport content="width=device-width, initial-scale=1.0" /><meta name=viewport content="width=device-width, initial-scale=1" /> <meta name=viewport content="width=device-width,initial-scale=1"> <meta http-equiv=x-ua-compatible content="ie=edge"> <meta name="lang:clipboard.copy" content="Copy to clipboard"> <meta name="lang:clipboard.copied" content="Copied to clipboard"> <meta name="lang:search.language" content=en > <meta name="lang:search.pipeline.stopwords" content=True > <meta name="lang:search.pipeline.trimmer" content=True > <meta name="lang:search.result.none" content="No matching documents"> <meta name="lang:search.result.one" content="1 matching document"> <meta name="lang:search.result.other" content="# matching documents"> <meta name="lang:search.tokenizer" content="[\s\-]+"> <link href="https://fonts.gstatic.com/" rel=preconnect crossorigin> <link href="https://fonts.googleapis.com/css?family=Roboto+Mono:400,500,700|Roboto:300,400,400i,700&display=fallback" rel=stylesheet > <style> body, input { font-family: "Roboto", "Helvetica Neue", Helvetica, Arial, sans-serif } code, kbd, pre { font-family: "Roboto Mono", "Courier New", Courier, monospace } </style> <link rel=stylesheet href="_static/stylesheets/application.css"/> <link rel=stylesheet href="_static/stylesheets/application-palette.css"/> <link rel=stylesheet href="_static/stylesheets/application-fixes.css"/> <link rel=stylesheet href="_static/fonts/material-icons.css"/> <meta name=theme-color content="#3f51b5"> <script src="_static/javascripts/modernizr.js"></script> <title>FPGA advanced reference &#8212; Jungfraujoch 1.0.0-rc.135 documentation</title> <link rel=stylesheet type="text/css" href="_static/pygments.css?v=83e35b93" /> <link rel=stylesheet type="text/css" href="_static/material.css?v=79c92029" /> <script src="_static/documentation_options.js?v=d1fa3868"></script> <script src="_static/doctools.js?v=9bcbadda"></script> <script src="_static/sphinx_highlight.js?v=dc90522c"></script> <link rel=icon href="_static/jfjoch.png"/> <link rel=index title=Index href=genindex.html /> <link rel=search title=Search href=search.html /> <link rel=next title="FPGA data analysis" href=FPGA_DATA_ANALYSIS.html /> <link rel=prev title="FPGA PCIe driver" href=FPGA_PCIE_DRIVER.html /> <body dir=ltr data-md-color-primary=indigo data-md-color-accent=lime> <svg class=md-svg > <defs data-children-count=0 > <svg xmlns="http://www.w3.org/2000/svg" width=500 height=500 viewBox="0 0 500 500" id=__gitlab ><path fill=currentColor d="M93.667 473.347l90.684-279.097H2.983l90.684 279.097z" transform="translate(156.198 1.16)"/><path fill=currentColor d="M221.333 473.345L130.649 194.25H3.557l217.776 279.095z" transform="translate(28.531 1.16)" opacity=.7 /><path fill=currentColor d="M32 195.155L4.441 279.97a18.773 18.773 0 0 0 6.821 20.99l238.514 173.29L32 195.155z" transform="translate(.089 .256)" opacity=.5 /><path fill=currentColor d="M2.667-84.844h127.092L75.14-252.942c-2.811-8.649-15.047-8.649-17.856 0L2.667-84.844z" transform="translate(29.422 280.256)"/><path fill=currentColor d="M2.667 473.345L93.351 194.25h127.092L2.667 473.345z" transform="translate(247.198 1.16)" opacity=.7 /><path fill=currentColor d="M221.334 195.155l27.559 84.815a18.772 18.772 0 0 1-6.821 20.99L3.557 474.25l217.777-279.095z" transform="translate(246.307 .256)" opacity=.5 /><path fill=currentColor d="M130.667-84.844H3.575l54.618-168.098c2.811-8.649 15.047-8.649 17.856 0l54.618 168.098z" transform="translate(336.974 280.256)"/></svg> </defs> </svg> <input class=md-toggle data-md-toggle=drawer type=checkbox id=__drawer > <input class=md-toggle data-md-toggle=search type=checkbox id=__search > <label class=md-overlay data-md-component=overlay for=__drawer ></label> <a href="#FPGA_SETTINGS" tabindex=1 class=md-skip > Skip to content </a> <header class=md-header data-md-component=header > <nav class="md-header-nav md-grid"> <div class="md-flex navheader"> <div class="md-flex__cell md-flex__cell--shrink"> <a href=index.html title="Jungfraujoch 1.0.0-rc.135 documentation" class="md-header-nav__button md-logo"> <i class=md-icon >&#xe30d</i> </a> </div> <div class="md-flex__cell md-flex__cell--shrink"> <label class="md-icon md-icon--menu md-header-nav__button" for=__drawer ></label> </div> <div class="md-flex__cell md-flex__cell--stretch"> <div class="md-flex__ellipsis md-header-nav__title" data-md-component=title > <span class=md-header-nav__topic >PSI Jungfraujoch</span> <span class=md-header-nav__topic > FPGA advanced reference </span> </div> </div> <div class="md-flex__cell md-flex__cell--shrink"> <label class="md-icon md-icon--search md-header-nav__button" for=__search ></label> <div class=md-search data-md-component=search role=dialog > <label class=md-search__overlay for=__search ></label> <div class=md-search__inner role=search > <form class=md-search__form action=search.html method=get name=search > <input type=text class=md-search__input name=q placeholder=""Search"" autocapitalize=off autocomplete=off spellcheck=false data-md-component=query data-md-state=active > <label class="md-icon md-search__icon" for=__search ></label> <button type=reset class="md-icon md-search__icon" data-md-component=reset tabindex=-1 > &#xE5CD; </button> </form> <div class=md-search__output > <div class=md-search__scrollwrap data-md-scrollfix> <div class=md-search-result data-md-component=result > <div class=md-search-result__meta > Type to start searching </div> <ol class=md-search-result__list ></ol> </div> </div> </div> </div> </div> </div> <div class="md-flex__cell md-flex__cell--shrink"> <div class=md-header-nav__source > <a href="https://gitea.psi.ch/mx/jungfraujoch" title="Go to repository" class=md-source data-md-source=github > <div class=md-source__icon > <svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" viewBox="0 0 24 24" width=28 height=28 > <use xlink:href="#__gitlab" width=24 height=24 ></use> </svg> </div> <div class=md-source__repository > Jungfraujoch </div> </a> </div> </div> <script src="_static/javascripts/version_dropdown.js"></script> <script> var json_loc = ""versions.json"", target_loc = "../", text = "Versions"; $( document ).ready( add_version_dropdown(json_loc, target_loc, text)); </script> </div> </nav> </header> <div class=md-container > <nav class=md-tabs data-md-component=tabs > <div class="md-tabs__inner md-grid"> <ul class=md-tabs__list > <li class=md-tabs__item ><a href=index.html class=md-tabs__link >Jungfraujoch 1.0.0-rc.135 documentation</a> </ul> </div> </nav> <main class=md-main > <div class="md-main__inner md-grid" data-md-component=container > <div class="md-sidebar md-sidebar--primary" data-md-component=navigation > <div class=md-sidebar__scrollwrap > <div class=md-sidebar__inner > <nav class="md-nav md-nav--primary" data-md-level=0 > <label class="md-nav__title md-nav__title--site" for=__drawer > <a href=index.html title="Jungfraujoch 1.0.0-rc.135 documentation" class="md-nav__button md-logo"> <i class=md-icon >&#xe30d</i> </a> <a href=index.html title="Jungfraujoch 1.0.0-rc.135 documentation">PSI Jungfraujoch</a> </label> <div class=md-nav__source > <a href="https://gitea.psi.ch/mx/jungfraujoch" title="Go to repository" class=md-source data-md-source=github > <div class=md-source__icon > <svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" viewBox="0 0 24 24" width=28 height=28 > <use xlink:href="#__gitlab" width=24 height=24 ></use> </svg> </div> <div class=md-source__repository > Jungfraujoch </div> </a> </div> <ul class=md-nav__list > <li class=md-nav__item > <span class="md-nav__link caption"><span class=caption-text >General</span></span> <li class=md-nav__item > <a href=ACKNOWLEDGEMENT.html class=md-nav__link >Acknowledgements</a> <li class=md-nav__item > <a href=LICENSE.html class=md-nav__link >License</a> <li class=md-nav__item > <a href=DETECTORS.html class=md-nav__link >Supported detectors</a> <li class=md-nav__item > <a href="DETECTORS.html#dectris-detectors" class=md-nav__link >DECTRIS detectors</a> <li class=md-nav__item > <a href=HARDWARE.html class=md-nav__link >Hardware requirements</a> <li class=md-nav__item > <a href=SOFTWARE.html class=md-nav__link >Software requirements</a> <li class=md-nav__item > <a href=VERSIONING.html class=md-nav__link >Semantic versioning</a> <li class=md-nav__item > <a href=DEPLOYMENT.html class=md-nav__link >Deployment</a> <li class=md-nav__item > <a href=CHANGELOG.html class=md-nav__link >Changelog</a> <li class=md-nav__item > <span class="md-nav__link caption"><span class=caption-text >Software</span></span> <li class=md-nav__item > <a href=JFJOCH_BROKER.html class=md-nav__link >jfjoch_broker</a> <li class=md-nav__item > <a href=JFJOCH_WRITER.html class=md-nav__link >jfjoch_writer</a> <li class=md-nav__item > <a href=SOFTWARE_INTEGRATION.html class=md-nav__link >Integration with MX data processing software</a> <li class=md-nav__item > <a href=TOOLS.html class=md-nav__link >Tools</a> <li class=md-nav__item > <span class="md-nav__link caption"><span class=caption-text >FPGA</span></span> <li class=md-nav__item > <a href=FPGA.html class=md-nav__link >FPGA smartNIC</a> <li class=md-nav__item > <a href=FPGA_LICENSE.html class=md-nav__link >FPGA license</a> <li class=md-nav__item > <a href=FPGA_DESIGN.html class=md-nav__link >FPGA data flow</a> <li class=md-nav__item > <a href=FPGA_NETWORK.html class=md-nav__link >FPGA network</a> <li class=md-nav__item > <a href=FPGA_PCIE_DRIVER.html class=md-nav__link >FPGA PCIe driver</a> <li class=md-nav__item > <input class="md-toggle md-nav__toggle" data-md-toggle=toc type=checkbox id=__toc > <label class="md-nav__link md-nav__link--active" for=__toc > FPGA advanced reference </label> <a href="#" class="md-nav__link md-nav__link--active">FPGA advanced reference</a> <nav class="md-nav md-nav--secondary"> <ul class=md-nav__list data-md-scrollfix=""> </ul> </nav> <ul class=md-nav__list > <li class=md-nav__item > <a href="#register-map" class=md-nav__link >Register map</a> <li class=md-nav__item > <a href="#axi-mailbox" class=md-nav__link >AXI Mailbox</a> <li class=md-nav__item > <a href="#hbm-memory" class=md-nav__link >HBM memory</a> </ul> <li class=md-nav__item > <a href=FPGA_DATA_ANALYSIS.html class=md-nav__link >FPGA data analysis</a> <li class=md-nav__item > <span class="md-nav__link caption"><span class=caption-text >Reference</span></span> <li class=md-nav__item > <a href=DETECTOR_GEOMETRY.html class=md-nav__link >Detector geometry</a> <li class=md-nav__item > <a href=CPU_DATA_ANALYSIS.html class=md-nav__link >CPU-side crystallographic data analysis (Jungfraujoch)</a> <li class=md-nav__item > <a href=OPENAPI.html class=md-nav__link >OpenAPI</a> <li class=md-nav__item > <a href=OPENAPI_SPECS.html class=md-nav__link >OpenAPI specification</a> <li class=md-nav__item > <a href=CBOR.html class=md-nav__link >CBOR messages</a> <li class=md-nav__item > <a href=IMAGE_STREAM.html class=md-nav__link >Data streams</a> <li class=md-nav__item > <a href=PIXEL_MASK.html class=md-nav__link >Pixel mask</a> <li class=md-nav__item > <a href=WEB_FRONTEND.html class=md-nav__link >Web frontend</a> <li class=md-nav__item > <a href=TESTS.html class=md-nav__link >Tests</a> <li class=md-nav__item > <span class="md-nav__link caption"><span class=caption-text >OpenAPI Python client</span></span> <li class=md-nav__item > <a href="python_client/README.html" class=md-nav__link >jfjoch-client</a> <li class=md-nav__item > <a href="python_client/README.html#license-clarification" class=md-nav__link >License Clarification</a> <li class=md-nav__item > <a href="python_client/docs/DefaultApi.html" class=md-nav__link >jfjoch_client.DefaultApi</a> <li class=md-nav__item > <a href="python_client/docs/DefaultApi.html#cancel-post" class=md-nav__link ><strong>cancel_post</strong></a> <li class=md-nav__item > <a href="python_client/docs/DefaultApi.html#config-azim-int-get" class=md-nav__link ><strong>config_azim_int_get</strong></a> <li class=md-nav__item > <a href="python_client/docs/DefaultApi.html#config-azim-int-put" class=md-nav__link ><strong>config_azim_int_put</strong></a> <li class=md-nav__item > <a href="python_client/docs/DefaultApi.html#config-dark-mask-get" class=md-nav__link ><strong>config_dark_mask_get</strong></a> <li class=md-nav__item > <a href="python_client/docs/DefaultApi.html#config-dark-mask-put" class=md-nav__link ><strong>config_dark_mask_put</strong></a> <li class=md-nav__item > <a href="python_client/docs/DefaultApi.html#config-detector-get" class=md-nav__link ><strong>config_detector_get</strong></a> <li class=md-nav__item > <a href="python_client/docs/DefaultApi.html#config-detector-put" class=md-nav__link ><strong>config_detector_put</strong></a> <li class=md-nav__item > <a href="python_client/docs/DefaultApi.html#config-file-writer-get" class=md-nav__link ><strong>config_file_writer_get</strong></a> <li class=md-nav__item > <a href="python_client/docs/DefaultApi.html#config-file-writer-put" class=md-nav__link ><strong>config_file_writer_put</strong></a> <li class=md-nav__item > <a href="python_client/docs/DefaultApi.html#config-image-format-conversion-post" class=md-nav__link ><strong>config_image_format_conversion_post</strong></a> <li class=md-nav__item > <a href="python_client/docs/DefaultApi.html#config-image-format-get" class=md-nav__link ><strong>config_image_format_get</strong></a> <li class=md-nav__item > <a href="python_client/docs/DefaultApi.html#config-image-format-put" class=md-nav__link ><strong>config_image_format_put</strong></a> <li class=md-nav__item > <a href="python_client/docs/DefaultApi.html#config-image-format-raw-post" class=md-nav__link ><strong>config_image_format_raw_post</strong></a> <li class=md-nav__item > <a href="python_client/docs/DefaultApi.html#config-indexing-get" class=md-nav__link ><strong>config_indexing_get</strong></a> <li class=md-nav__item > <a href="python_client/docs/DefaultApi.html#config-indexing-put" class=md-nav__link ><strong>config_indexing_put</strong></a> <li class=md-nav__item > <a href="python_client/docs/DefaultApi.html#config-instrument-get" class=md-nav__link ><strong>config_instrument_get</strong></a> <li class=md-nav__item > <a href="python_client/docs/DefaultApi.html#config-instrument-put" class=md-nav__link ><strong>config_instrument_put</strong></a> <li class=md-nav__item > <a href="python_client/docs/DefaultApi.html#config-internal-generator-image-put" class=md-nav__link ><strong>config_internal_generator_image_put</strong></a> <li class=md-nav__item > <a href="python_client/docs/DefaultApi.html#config-internal-generator-image-tiff-put" class=md-nav__link ><strong>config_internal_generator_image_tiff_put</strong></a> <li class=md-nav__item > <a href="python_client/docs/DefaultApi.html#config-mask-get" class=md-nav__link ><strong>config_mask_get</strong></a> <li class=md-nav__item > <a href="python_client/docs/DefaultApi.html#config-mask-tiff-get" class=md-nav__link ><strong>config_mask_tiff_get</strong></a> <li class=md-nav__item > <a href="python_client/docs/DefaultApi.html#config-roi-get" class=md-nav__link ><strong>config_roi_get</strong></a> <li class=md-nav__item > <a href="python_client/docs/DefaultApi.html#config-roi-put" class=md-nav__link ><strong>config_roi_put</strong></a> <li class=md-nav__item > <a href="python_client/docs/DefaultApi.html#config-select-detector-get" class=md-nav__link ><strong>config_select_detector_get</strong></a> <li class=md-nav__item > <a href="python_client/docs/DefaultApi.html#config-select-detector-put" class=md-nav__link ><strong>config_select_detector_put</strong></a> <li class=md-nav__item > <a href="python_client/docs/DefaultApi.html#config-spot-finding-get" class=md-nav__link ><strong>config_spot_finding_get</strong></a> <li class=md-nav__item > <a href="python_client/docs/DefaultApi.html#config-spot-finding-put" class=md-nav__link ><strong>config_spot_finding_put</strong></a> <li class=md-nav__item > <a href="python_client/docs/DefaultApi.html#config-user-mask-get" class=md-nav__link ><strong>config_user_mask_get</strong></a> <li class=md-nav__item > <a href="python_client/docs/DefaultApi.html#config-user-mask-put" class=md-nav__link ><strong>config_user_mask_put</strong></a> <li class=md-nav__item > <a href="python_client/docs/DefaultApi.html#config-user-mask-tiff-get" class=md-nav__link ><strong>config_user_mask_tiff_get</strong></a> <li class=md-nav__item > <a href="python_client/docs/DefaultApi.html#config-user-mask-tiff-put" class=md-nav__link ><strong>config_user_mask_tiff_put</strong></a> <li class=md-nav__item > <a href="python_client/docs/DefaultApi.html#config-zeromq-metadata-get" class=md-nav__link ><strong>config_zeromq_metadata_get</strong></a> <li class=md-nav__item > <a href="python_client/docs/DefaultApi.html#config-zeromq-metadata-put" class=md-nav__link ><strong>config_zeromq_metadata_put</strong></a> <li class=md-nav__item > <a href="python_client/docs/DefaultApi.html#config-zeromq-preview-get" class=md-nav__link ><strong>config_zeromq_preview_get</strong></a> <li class=md-nav__item > <a href="python_client/docs/DefaultApi.html#config-zeromq-preview-put" class=md-nav__link ><strong>config_zeromq_preview_put</strong></a> <li class=md-nav__item > <a href="python_client/docs/DefaultApi.html#deactivate-post" class=md-nav__link ><strong>deactivate_post</strong></a> <li class=md-nav__item > <a href="python_client/docs/DefaultApi.html#detector-status-get" class=md-nav__link ><strong>detector_status_get</strong></a> <li class=md-nav__item > <a href="python_client/docs/DefaultApi.html#fpga-status-get" class=md-nav__link ><strong>fpga_status_get</strong></a> <li class=md-nav__item > <a href="python_client/docs/DefaultApi.html#image-buffer-clear-post" class=md-nav__link ><strong>image_buffer_clear_post</strong></a> <li class=md-nav__item > <a href="python_client/docs/DefaultApi.html#image-buffer-image-cbor-get" class=md-nav__link ><strong>image_buffer_image_cbor_get</strong></a> <li class=md-nav__item > <a href="python_client/docs/DefaultApi.html#image-buffer-image-jpeg-get" class=md-nav__link ><strong>image_buffer_image_jpeg_get</strong></a> <li class=md-nav__item > <a href="python_client/docs/DefaultApi.html#image-buffer-image-tiff-get" class=md-nav__link ><strong>image_buffer_image_tiff_get</strong></a> <li class=md-nav__item > <a href="python_client/docs/DefaultApi.html#image-buffer-start-cbor-get" class=md-nav__link ><strong>image_buffer_start_cbor_get</strong></a> <li class=md-nav__item > <a href="python_client/docs/DefaultApi.html#image-buffer-status-get" class=md-nav__link ><strong>image_buffer_status_get</strong></a> <li class=md-nav__item > <a href="python_client/docs/DefaultApi.html#image-pusher-status-get" class=md-nav__link ><strong>image_pusher_status_get</strong></a> <li class=md-nav__item > <a href="python_client/docs/DefaultApi.html#initialize-post" class=md-nav__link ><strong>initialize_post</strong></a> <li class=md-nav__item > <a href="python_client/docs/DefaultApi.html#pedestal-post" class=md-nav__link ><strong>pedestal_post</strong></a> <li class=md-nav__item > <a href="python_client/docs/DefaultApi.html#preview-pedestal-tiff-get" class=md-nav__link ><strong>preview_pedestal_tiff_get</strong></a> <li class=md-nav__item > <a href="python_client/docs/DefaultApi.html#preview-plot-bin-get" class=md-nav__link ><strong>preview_plot_bin_get</strong></a> <li class=md-nav__item > <a href="python_client/docs/DefaultApi.html#preview-plot-get" class=md-nav__link ><strong>preview_plot_get</strong></a> <li class=md-nav__item > <a href="python_client/docs/DefaultApi.html#result-scan-get" class=md-nav__link ><strong>result_scan_get</strong></a> <li class=md-nav__item > <a href="python_client/docs/DefaultApi.html#start-post" class=md-nav__link ><strong>start_post</strong></a> <li class=md-nav__item > <a href="python_client/docs/DefaultApi.html#statistics-calibration-get" class=md-nav__link ><strong>statistics_calibration_get</strong></a> <li class=md-nav__item > <a href="python_client/docs/DefaultApi.html#statistics-data-collection-get" class=md-nav__link ><strong>statistics_data_collection_get</strong></a> <li class=md-nav__item > <a href="python_client/docs/DefaultApi.html#statistics-get" class=md-nav__link ><strong>statistics_get</strong></a> <li class=md-nav__item > <a href="python_client/docs/DefaultApi.html#status-get" class=md-nav__link ><strong>status_get</strong></a> <li class=md-nav__item > <a href="python_client/docs/DefaultApi.html#trigger-post" class=md-nav__link ><strong>trigger_post</strong></a> <li class=md-nav__item > <a href="python_client/docs/DefaultApi.html#version-get" class=md-nav__link ><strong>version_get</strong></a> <li class=md-nav__item > <a href="python_client/docs/DefaultApi.html#wait-till-done-post" class=md-nav__link ><strong>wait_till_done_post</strong></a> <li class=md-nav__item > <a href="python_client/docs/DefaultApi.html#xfel-event-code-get" class=md-nav__link ><strong>xfel_event_code_get</strong></a> <li class=md-nav__item > <a href="python_client/docs/DefaultApi.html#xfel-pulse-id-get" class=md-nav__link ><strong>xfel_pulse_id_get</strong></a> </ul> </nav> </div> </div> </div> <div class="md-sidebar md-sidebar--secondary" data-md-component=toc > <div class=md-sidebar__scrollwrap > <div class=md-sidebar__inner > <nav class="md-nav md-nav--secondary"> <ul class=md-nav__list data-md-scrollfix=""> </ul> </nav> </div> </div> </div> <div class=md-content > <article class="md-content__inner md-typeset" role=main > <section class="tex2jax_ignore mathjax_ignore" id=fpga-advanced-reference > <h1 id=fpga-settings--page-root >FPGA advanced reference<a class=headerlink href="#fpga-settings--page-root" title="Link to this heading"></a></h1> <section id=register-map > <h2 id=register-map >Register map<a class=headerlink href="#register-map" title="Link to this heading"></a></h2> <p>FPGA setup can be done via registers:</p> <table> <thead> <tr class=row-odd ><th class=head ><p>Address</p> <th class=head ><p>Bits</p> <th class=head ><p>Meaning</p> <th class="head text-left"><p>Mode</p> <th class=head ><p>Notes</p> <tr class=row-even ><td><p>0x000000 - 0x00FFFF</p> <td><p></p> <td><p>Reserved (in case using MicroBlaze in the future, this has to be reserved for internal memory)</p> <td class=text-left ><p></p> <td><p></p> <tr class=row-odd ><td><p>0x010000</p> <td><p>32</p> <td><p>Action Control Register</p> <td class=text-left ><p></p> <td><p></p> <tr class=row-even ><td><p></p> <td><p></p> <td><p>Bit 0 - Action start</p> <td class=text-left ><p>R/W</p> <td><p></p> <tr class=row-odd ><td><p></p> <td><p></p> <td><p>Bit 1 - Action idle</p> <td class=text-left ><p>R</p> <td><p></p> <tr class=row-even ><td><p></p> <td><p></p> <td><p>Bit 2 - Action cancel</p> <td class=text-left ><p>R/W</p> <td><p>cleared on reset or action start</p> <tr class=row-odd ><td><p></p> <td><p></p> <td><p>Bit 3 - Clear network counters</p> <td class=text-left ><p>R/W</p> <td><p>cleared on reset</p> <tr class=row-even ><td><p></p> <td><p></p> <td><p>Bit 12:4 - Debug signals (see action_config.v for details)</p> <td class=text-left ><p>R</p> <td><p></p> <tr class=row-odd ><td><p></p> <td><p></p> <td><p>Bit 16 - AXI Mailbox interrupt 0</p> <td class=text-left ><p>R</p> <td><p></p> <tr class=row-even ><td><p>0x010004</p> <td><p>32</p> <td><p>Reserved</p> <td class=text-left ><p>-</p> <td><p></p> <tr class=row-odd ><td><p>0x010008</p> <td><p>32</p> <td><p>Reserved</p> <td class=text-left ><p>-</p> <td><p></p> <tr class=row-even ><td><p>0x01000C</p> <td><p>32</p> <td><p>GIT SHA1</p> <td class=text-left ><p>R</p> <td><p></p> <tr class=row-odd ><td><p>0x010010</p> <td><p>32</p> <td><p>Reserved</p> <td class=text-left ><p>R</p> <td><p></p> <tr class=row-even ><td><p>0x010014</p> <td><p>32</p> <td><p>Reserved</p> <td class=text-left ><p>R</p> <td><p></p> <tr class=row-odd ><td><p>0x010018</p> <td><p>32</p> <td><p>Jungfraujoch FPGA variant</p> <td class=text-left ><p>R</p> <td><p></p> <tr class=row-even ><td><p>0x01001C</p> <td><p>32</p> <td><p>Reserved</p> <td class=text-left ><p>R</p> <td><p></p> <tr class=row-odd ><td><p>0x010020</p> <td><p>32</p> <td><p>Max. number supported detector modules</p> <td class=text-left ><p>R</p> <td><p>constant</p> <tr class=row-even ><td><p>0x010024</p> <td><p>32</p> <td><p>Reserved</p> <td class=text-left ><p>R</p> <td><p>constant</p> <tr class=row-odd ><td><p>0x010028</p> <td><p>64</p> <td><p>Pipeline stalls before writing to host memory</p> <td class=text-left ><p>R</p> <td><p>reset on action start</p> <tr class=row-even ><td><p>0x010030</p> <td><p>64</p> <td><p>Pipeline stalls before accessing HBM</p> <td class=text-left ><p>R</p> <td><p>reset on action start</p> <tr class=row-odd ><td><p>0x010038</p> <td><p>32</p> <td><p>FIFO status (see action_config.v for details)</p> <td class=text-left ><p>R</p> <td><p></p> <tr class=row-even ><td><p>0x01003C</p> <td><p>32</p> <td><p>Size of single HBM channel in bytes (default value for the particular card)</p> <td class=text-left ><p>R/W</p> <td><p>should not be altered for standard operation</p> <tr class=row-odd ><td><p>0x010040</p> <td><p>64</p> <td><p>Packets processed by the action</p> <td class=text-left ><p>R</p> <td><p>cleared on reset or action start</p> <tr class=row-even ><td><p>0x010048</p> <td><p>64</p> <td><p>Valid ethernet packets</p> <td class=text-left ><p>R</p> <td><p>cleared on reset</p> <tr class=row-odd ><td><p>0x010050</p> <td><p>64</p> <td><p>Valid ICMP packets</p> <td class=text-left ><p>R</p> <td><p>cleared on reset</p> <tr class=row-even ><td><p>0x010058</p> <td><p>64</p> <td><p>Valid UDP packets</p> <td class=text-left ><p>R</p> <td><p>cleared on reset</p> <tr class=row-odd ><td><p>0x010060</p> <td><p>64</p> <td><p>Valid detector packets processed by the card</p> <td class=text-left ><p>R</p> <td><p>cleared on reset</p> <tr class=row-even ><td><p>0x010068</p> <td><p>64</p> <td><p>Packets flagged as errors by CMAC</p> <td class=text-left ><p>R</p> <td><p>cleared on reset</p> <tr class=row-odd ><td><p>0x010070</p> <td><p>64</p> <td><p>Pipeline stalls before data processing</p> <td class=text-left ><p>R</p> <td><p>reset on action start</p> <tr class=row-even ><td><p>0x010078</p> <td><p>64</p> <td><p>AXI-beats before accessing HBM</p> <td class=text-left ><p>R</p> <td><p>reset on action start</p> <tr class=row-odd ><td><p>0x010080</p> <td><p>64</p> <td><p>AXI-beats before data processing</p> <td class=text-left ><p>R</p> <td><p>reset on action start</p> <tr class=row-even ><td><p>0x010088</p> <td><p>64</p> <td><p>AXI-beats before host writer</p> <td class=text-left ><p>R</p> <td><p>reset on action start</p> <tr class=row-odd ><td><p>0x010090</p> <td><p>64</p> <td><p>Last encountered SwissFEL pulse ID</p> <td class=text-left ><p>R</p> <td><p>cleared on reset</p> <tr class=row-even ><td><p>0x010100</p> <td><p>32</p> <td><p>Spot finder photon count threshold</p> <td class=text-left ><p>R/W</p> <td><p></p> <tr class=row-odd ><td><p>0x010104</p> <td><p>32</p> <td><p>Spot finder signal-to-noise ratio threshold (single-precision float)</p> <td class=text-left ><p>R/W</p> <td><p></p> <tr class=row-even ><td><p>0x010200</p> <td><p>64</p> <td><p>MAC address source for internal frame generator</p> <td class=text-left ><p>R/W</p> <td><p>network byte order</p> <tr class=row-odd ><td><p>0x010208</p> <td><p>32</p> <td><p>IPv4 address source for internal frame generator</p> <td class=text-left ><p>R/W</p> <td><p>network byte order</p> <tr class=row-even ><td><p>0x01020C</p> <td><p>32</p> <td><p>Number of detector modules (value minus one: 0 =&gt; 1 module, 1 =&gt; 2 modules, etc.)</p> <td class=text-left ><p>R/W</p> <td><p></p> <tr class=row-odd ><td><p>0x010210</p> <td><p>32</p> <td><p>Data collection mode</p> <td class=text-left ><p>R/W</p> <td><p></p> <tr class=row-even ><td><p></p> <td><p></p> <td><p>Bit 0 - Conversion to photons</p> <td class=text-left ><p></p> <td><p></p> <tr class=row-odd ><td><p></p> <td><p></p> <td><p>Bit 1 - Output extend to 32-bit</p> <td class=text-left ><p></p> <td><p></p> <tr class=row-even ><td><p></p> <td><p></p> <td><p>Bit 2 - Output is unsigned integer</p> <td class=text-left ><p></p> <td><p></p> <tr class=row-odd ><td><p></p> <td><p></p> <td><p>Bit 3 - Use sq. root lossy compression</p> <td class=text-left ><p></p> <td><p></p> <tr class=row-even ><td><p></p> <td><p></p> <td><p>Bit 7 - JUNGFRAU fixed G1 mode</p> <td class=text-left ><p></p> <td><p></p> <tr class=row-odd ><td><p></p> <td><p></p> <td><p>Bit 8 - Set to zero values below threshold</p> <td class=text-left ><p></p> <td><p></p> <tr class=row-even ><td><p></p> <td><p></p> <td><p>Bit 16:31 - Data collection ID (carried with completions)</p> <td class=text-left ><p></p> <td><p></p> <tr class=row-odd ><td><p>0x010214</p> <td><p>32</p> <td><p>Photon energy in keV (single-precision float)</p> <td class=text-left ><p>R/W</p> <td><p></p> <tr class=row-even ><td><p>0x010218</p> <td><p>32</p> <td><p>Number of frames expected in the data collection (defines termination condition)</p> <td class=text-left ><p>R/W</p> <td><p></p> <tr class=row-odd ><td><p>0x01021C</p> <td><p>32</p> <td><p>Number of storage cells</p> <td class=text-left ><p>R/W</p> <td><p></p> <tr class=row-even ><td><p>0x010220</p> <td><p>32</p> <td><p>Summation on card (value minus one: 0 =&gt; summation of 1, 1 =&gt; summation of 2, etc.)</p> <td class=text-left ><p>R/W</p> <td><p></p> <tr class=row-odd ><td><p>0x010224</p> <td><p>32</p> <td><p>Coefficient for sq. root compression (need to set bit in data collection mode to apply)</p> <td class=text-left ><p>R/W</p> <td><p></p> <tr class=row-even ><td><p>0x010225</p> <td><p>32</p> <td><p>Threshold; set values below set to zero (need to set bit in data collection mode to apply)</p> <td class=text-left ><p>R/W</p> <td><p></p> <tr class=row-odd ><td><p>0x030000 - 0x03FFFF</p> <td><p></p> <td><p>AXI Mailbox for Work Request / Work Completion</p> <td class=text-left ><p></p> <td><p>See Xilinx PG114 for register map</p> <tr class=row-even ><td><p>0x040000 - 0x04FFFF</p> <td><p></p> <td><p>QuadSPI flash</p> <td class=text-left ><p></p> <td><p>See Xilinx PG153 for register map</p> <tr class=row-odd ><td><p>0x050000 - 0x05FFFF</p> <td><p></p> <td><p>Interrupt controller</p> <td class=text-left ><p></p> <td><p>See Xilinx PG099 for register map</p> <tr class=row-even ><td><p>0x060000 - 0x06FFFF</p> <td><p></p> <td><p>Load calibration (HLS)</p> <td class=text-left ><p></p> <td><p></p> <tr class=row-odd ><td><p>0x070000 - 0x07FFFF</p> <td><p></p> <td><p>AXI Firewall</p> <td class=text-left ><p></p> <td><p>See Xilinx PG293 for register map</p> <tr class=row-even ><td><p>0x080000 - 0x08FFFF</p> <td><p></p> <td><p>Frame generator (HLS)</p> <td class=text-left ><p></p> <td><p></p> <tr class=row-odd ><td><p>0x090000 - 0x09FFFF</p> <td><p></p> <td><p>PCIe DMA control</p> <td class=text-left ><p></p> <td><p>See Xilinx PG195 for register map</p> <tr class=row-even ><td><p>0x0A0000 - 0x0AFFFF</p> <td><p></p> <td><p>I2C clock generator</p> <td class=text-left ><p></p> <td><p>See Xilinx PG195 for register map</p> <tr class=row-odd ><td><p>0x0C0000 - 0x0FFFFF</p> <td><p></p> <td><p>Xilinx Card Management Solution Subsystem management subsystem</p> <td class=text-left ><p></p> <td><p>See Xilinx PG348 for register map</p> <tr class=row-even ><td><p>0x100000 - 0x10FFFF</p> <td><p></p> <td><p>MAC 10G / CMAC 100G</p> <td class=text-left ><p></p> <td><p>See Xilinx PG210/PG203 for register map</p> <tr class=row-odd ><td><p>0x110000 - 0x11FFFF</p> <td><p></p> <td><p>MAC 10G</p> <td class=text-left ><p></p> <td><p>See Xilinx PG210 for register map</p> <tr class=row-even ><td><p>0x120000 - 0x12FFFF</p> <td><p></p> <td><p>MAC 10G</p> <td class=text-left ><p></p> <td><p>See Xilinx PG210 for register map</p> <tr class=row-odd ><td><p>0x130000 - 0x13FFFF</p> <td><p></p> <td><p>MAC 10G</p> <td class=text-left ><p></p> <td><p>See Xilinx PG210 for register map</p> <tr class=row-even ><td><p>0x140000 - 0x14FFFF</p> <td><p></p> <td><p>MAC 10G</p> <td class=text-left ><p></p> <td><p>See Xilinx PG210 for register map</p> <tr class=row-odd ><td><p>0x150000 - 0x15FFFF</p> <td><p></p> <td><p>MAC 10G</p> <td class=text-left ><p></p> <td><p>See Xilinx PG210 for register map</p> <tr class=row-even ><td><p>0x160000 - 0x16FFFF</p> <td><p></p> <td><p>MAC 10G</p> <td class=text-left ><p></p> <td><p>See Xilinx PG210 for register map</p> <tr class=row-odd ><td><p>0x170000 - 0x17FFFF</p> <td><p></p> <td><p>MAC 10G</p> <td class=text-left ><p></p> <td><p>See Xilinx PG210 for register map</p> <tr class=row-even ><td><p>0x200000 - 0x20FFFF</p> <td><p></p> <td><p>Eth/IPv4 network stack for interface #0</p> <td class=text-left ><p></p> <td><p></p> <tr class=row-odd ><td><p>0x210000 - 0x21FFFF</p> <td><p></p> <td><p>Eth/IPv4 network stack for interface #1</p> <td class=text-left ><p></p> <td><p></p> <tr class=row-even ><td><p>0x220000 - 0x22FFFF</p> <td><p></p> <td><p>Eth/IPv4 network stack for interface #2</p> <td class=text-left ><p></p> <td><p></p> <tr class=row-odd ><td><p>0x230000 - 0x23FFFF</p> <td><p></p> <td><p>Eth/IPv4 network stack for interface #3</p> <td class=text-left ><p></p> <td><p></p> <tr class=row-even ><td><p>0x240000 - 0x24FFFF</p> <td><p></p> <td><p>Eth/IPv4 network stack for interface #4</p> <td class=text-left ><p></p> <td><p></p> <tr class=row-odd ><td><p>0x250000 - 0x25FFFF</p> <td><p></p> <td><p>Eth/IPv4 network stack for interface #5</p> <td class=text-left ><p></p> <td><p></p> <tr class=row-even ><td><p>0x260000 - 0x26FFFF</p> <td><p></p> <td><p>Eth/IPv4 network stack for interface #6</p> <td class=text-left ><p></p> <td><p></p> <tr class=row-odd ><td><p>0x270000 - 0x27FFFF</p> <td><p></p> <td><p>Eth/IPv4 network stack for interface #7</p> <td class=text-left ><p></p> <td><p></p> <tr class=row-even ><td><p>0x400000 - 0x47FFFF</p> <td><p>64</p> <td><p>Address table: decodes handles used by load_calibration and host_writer to DMA addresses</p> <td class=text-left ><p></p> <td><p></p> </table> </section> <section id=axi-mailbox > <h2 id=axi-mailbox >AXI Mailbox<a class=headerlink href="#axi-mailbox" title="Link to this heading"></a></h2> <p>AXI mailbox is used to send work request from host to action, and receive work completions. Messages are exchanged through AXI Mailbox IP from Xilinx (see Xilinx PG114).</p> <p>Work request has the following structure:</p> <table> <thead> <tr class=row-odd ><th class=head ><p>Bit start</p> <th class=head ><p>Bit end</p> <th class=head ><p>Meaning</p> <tr class=row-even ><td><p>0</p> <td><p>15</p> <td><p>Work request ID (handle)</p> </table> <p>Work completion has the following structure:</p> <table> <thead> <tr class=row-odd ><th class=head ><p>Bit start</p> <th class=head ><p>Bit end</p> <th class=head ><p>Meaning</p> <tr class=row-even ><td><p>0</p> <td><p>15</p> <td><p>Work request ID (handle)</p> <tr class=row-odd ><td><p></p> <td><p></p> <td><p>Special values:</p> <tr class=row-even ><td><p></p> <td><p></p> <td><p>65534 - start of data collection</p> <tr class=row-odd ><td><p></p> <td><p></p> <td><p>65535 - end of data collection</p> <tr class=row-even ><td><p>15</p> <td><p>31</p> <td><p>Data collection ID</p> </table> </section> <section id=hbm-memory > <h2 id=hbm-memory >HBM memory<a class=headerlink href="#hbm-memory" title="Link to this heading"></a></h2> <table> <thead> <tr class=row-odd ><th class=head ><p>Interface number</p> <th class=head ><p>Core</p> <th class=head ><p>Meaning</p> <tr class=row-even ><td><p>0-1</p> <td><p>jf_conversion</p> <td><p>Gain factor G0</p> <tr class=row-odd ><td><p>2-3</p> <td><p>jf_conversion</p> <td><p>Gain factor G1</p> <tr class=row-even ><td><p>4-5</p> <td><p>jf_conversion</p> <td><p>Gain factor G2</p> <tr class=row-odd ><td><p>6-7</p> <td><p>jf_conversion</p> <td><p>Pedestal G0</p> <tr class=row-even ><td><p>8-9</p> <td><p>jf_conversion</p> <td><p>Pedestal G1</p> <tr class=row-odd ><td><p>10-11</p> <td><p>jf_conversion</p> <td><p>Pedestal G2</p> <tr class=row-even ><td><p>12-13</p> <td><p>integration</p> <td><p>Integration map</p> <tr class=row-odd ><td><p>14-15</p> <td><p>integration</p> <td><p>Integration weights</p> <tr class=row-even ><td><p>16-17</p> <td><p>spot_finder_mask</p> <td><p>Spot finder resolution</p> <tr class=row-odd ><td><p>18-19</p> <td><p>roi_calc</p> <td><p>ROI calculation</p> <tr class=row-even ><td><p>20-21</p> <td><p>frame_generator</p> <td><p>Frame generator</p> <tr class=row-odd ><td><p>22-27</p> <td><p>load_from_hbm</p> <td><p>Frame summation</p> </table> </section> </section> </article> </div> </div> </main> </div> <footer class=md-footer > <div class=md-footer-nav > <nav class="md-footer-nav__inner md-grid"> <a href=FPGA_PCIE_DRIVER.html title="FPGA PCIe driver" class="md-flex md-footer-nav__link md-footer-nav__link--prev" rel=prev > <div class="md-flex__cell md-flex__cell--shrink"> <i class="md-icon md-icon--arrow-back md-footer-nav__button"></i> </div> <div class="md-flex__cell md-flex__cell--stretch md-footer-nav__title"> <span class=md-flex__ellipsis > <span class=md-footer-nav__direction > "Previous" </span> FPGA PCIe driver </span> </div> </a> <a href=FPGA_DATA_ANALYSIS.html title="FPGA data analysis" class="md-flex md-footer-nav__link md-footer-nav__link--next" rel=next > <div class="md-flex__cell md-flex__cell--stretch md-footer-nav__title"><span class=md-flex__ellipsis > <span class=md-footer-nav__direction > "Next" </span> FPGA data analysis </span> </div> <div class="md-flex__cell md-flex__cell--shrink"><i class="md-icon md-icon--arrow-forward md-footer-nav__button"></i> </div> </a> </nav> </div> <div class="md-footer-meta md-typeset"> <div class="md-footer-meta__inner md-grid"> <div class=md-footer-copyright > <div class=md-footer-copyright__highlight > &#169; Copyright 2024, Paul Scherrer Institute. </div> Created using <a href="http://www.sphinx-doc.org/">Sphinx</a> 8.1.3. and <a href="https://github.com/bashtage/sphinx-material/">Material for Sphinx</a> </div> </div> </div> </footer> <script src="_static/javascripts/application.js"></script> <script>app.initialize({version: "1.0.4", url: {base: ".."}})</script>