From 711db6d1521bfe57c399b285aeaf4194903ee021 Mon Sep 17 00:00:00 2001 From: GHA Date: Thu, 25 Jul 2024 20:02:22 +0000 Subject: [PATCH] update 74b0d5cf07a5ba39b60032338078cc4fb044f342 --- .nojekyll | 0 img/SPI_timing_diagram2.wikimedia.png | Bin 0 -> 60978 bytes img/address_space.png | Bin 0 -> 172761 bytes img/bus_interface.png | Bin 0 -> 54222 bytes img/bus_interface_atomic.png | Bin 0 -> 57747 bytes img/cfu_r3type_instruction.png | Bin 0 -> 3781 bytes img/cfu_r4type_instruction.png | Bin 0 -> 3960 bytes img/cfu_r5type_instruction_a.png | Bin 0 -> 4116 bytes img/cfu_r5type_instruction_b.png | Bin 0 -> 4106 bytes img/eclipse.png | Bin 0 -> 132828 bytes img/icon.png | Bin 0 -> 1809 bytes img/license.md | 20 + img/neopixel_timing.png | Bin 0 -> 4852 bytes img/neorv32_boot_configurations.png | Bin 0 -> 87702 bytes img/neorv32_bus.png | Bin 0 -> 67443 bytes img/neorv32_cpu.png | Bin 0 -> 69153 bytes img/neorv32_logo.png | Bin 0 -> 11461 bytes img/neorv32_logo_riscv.png | Bin 0 -> 20451 bytes img/neorv32_logo_riscv_small.png | Bin 0 -> 7084 bytes img/neorv32_logo_small.png | Bin 0 -> 4604 bytes img/neorv32_logo_smcard.jpg | Bin 0 -> 152056 bytes img/neorv32_ocd_complex.png | Bin 0 -> 31378 bytes img/neorv32_processor.png | Bin 0 -> 138331 bytes img/neorv32_test_setup.png | Bin 0 -> 39522 bytes img/onewire_data.png | Bin 0 -> 4576 bytes img/onewire_reset.png | Bin 0 -> 3817 bytes img/oshw_logo.png | Bin 0 -> 11099 bytes img/ram_layout.png | Bin 0 -> 13837 bytes img/riscv_logo.png | Bin 0 -> 15859 bytes img/riscv_logo_small.png | Bin 0 -> 3484 bytes img/stream_link_interface.png | Bin 0 -> 7801 bytes img/vivado_ip_gui.png | Bin 0 -> 67843 bytes img/vivado_ip_soc.png | Bin 0 -> 69772 bytes img/xbus_read.png | Bin 0 -> 21832 bytes img/xbus_write.png | Bin 0 -> 23425 bytes index.html | 20959 ++++++++++++++++ sw/annotated.html | 129 + sw/atomic__test_2main_8c.html | 308 + sw/bc_s.png | Bin 0 -> 676 bytes sw/bc_sd.png | Bin 0 -> 635 bytes sw/bootloader_8c.html | 1184 + sw/bus__explorer_2main_8c.html | 299 + sw/classes.html | 120 + sw/clipboard.js | 61 + sw/closed.png | Bin 0 -> 132 bytes sw/cookie.js | 58 + sw/demo__blink__led_2main_8c.html | 139 + sw/demo__cfs_2main_8c.html | 178 + sw/demo__cfu_2main_8c.html | 483 + sw/demo__crc_2main_8c.html | 168 + sw/demo__dma_2main_8c.html | 212 + sw/demo__emulate__unaligned_2main_8c.html | 216 + sw/demo__gptmr_2main_8c.html | 182 + sw/demo__hpm_2main_8c.html | 161 + sw/demo__mtime_2main_8c.html | 174 + sw/demo__neopixel_2main_8c.html | 228 + sw/demo__newlib_2main_8c.html | 196 + sw/demo__onewire_2main_8c.html | 270 + sw/demo__pwm_2main_8c.html | 178 + sw/demo__sdi_2main_8c.html | 202 + sw/demo__slink_2main_8c.html | 182 + sw/demo__spi_2main_8c.html | 261 + sw/demo__spi__irq_2main_8c.html | 192 + sw/demo__trng_2main_8c.html | 261 + sw/demo__twi_2main_8c.html | 248 + sw/demo__wdt_2main_8c.html | 178 + sw/demo__xip_2main_8c.html | 479 + sw/demo__xirq_2main_8c.html | 241 + sw/dhry_8h_source.html | 557 + sw/dir_01cde3d98944a579dc3b5e43a5311a79.html | 110 + sw/dir_01fcd3835fb4e7d9331b722d86291b65.html | 109 + sw/dir_09a89dfa1596b6613cf2c29528a32844.html | 110 + sw/dir_0c6ac14e2254a316d41123f98feeb67b.html | 176 + sw/dir_0d2921e55a1172a4726516961ee96ab5.html | 110 + sw/dir_0f35fd52d2216117815d19d974239550.html | 113 + sw/dir_23212395b5ee0866d2fdd629e0ddeae8.html | 112 + sw/dir_23717ebbabf7a51c0558262947e0fe3b.html | 110 + sw/dir_237db5b95db643499d4c20f0bc5f6a7d.html | 110 + sw/dir_2ba96d3140b089dada6fb9f817b7975f.html | 110 + sw/dir_3b3bafc48b460f797485cc75b94aa81c.html | 112 + sw/dir_4316bb0e553b51b8b65560981547ce0f.html | 110 + sw/dir_449d8ba5f8b78dc90092f20d15a2386a.html | 110 + sw/dir_46981071cfd8ec44311b09fdcf6c06a8.html | 110 + sw/dir_4bd1267d34feeec0f679c16f884588e7.html | 103 + sw/dir_4c113257314015688a865e1bb8429184.html | 110 + sw/dir_5534fa9035f54ab438a41c43d6f7fc7a.html | 110 + sw/dir_6a888d76b0f727dc821f77838927e542.html | 103 + sw/dir_752b1e5d3973bf735fa78bf6b4727df9.html | 190 + sw/dir_78d7bfa405ff3a31fa7539cfd8bc8262.html | 110 + sw/dir_7a2c74f70a4cdf2e836a07048e2f71dd.html | 110 + sw/dir_7d04193005ada6f9450f847f4adb6b5b.html | 111 + sw/dir_8c514361e1f16692c783b23503f30f16.html | 110 + sw/dir_8d341cbe0581f44e1ae95d82d74e8bc8.html | 110 + sw/dir_8f848e36ac87ced1c361afcc0549ca32.html | 115 + sw/dir_93967190e0d2e549ceca77007097849b.html | 110 + sw/dir_9a1c128d67c35790e92af404beb936aa.html | 110 + sw/dir_9d04cdc586d6978be343bda7adcdc371.html | 113 + sw/dir_b5eb9f7d151d147efb5dbda58439e4e7.html | 109 + sw/dir_b683da3a5fc966bff32ebf7cda721811.html | 110 + sw/dir_b68ac2efc0c6ed3018151f7bb6c45670.html | 110 + sw/dir_b6b50782b8271d07dffbc5f0cb9ff3f4.html | 110 + sw/dir_bf935196a1ea0ca9cb42aae56d70946a.html | 110 + sw/dir_c2d46947bdd73c33f53326fc5ee3a272.html | 110 + sw/dir_c413aba6cb5da07a571465ba333950af.html | 110 + sw/dir_d4640980cbf1943e4a4aee6e8b810c7a.html | 110 + sw/dir_d68bb921df3f2482fe9ace49b286ab86.html | 110 + sw/dir_e9ffd83269fb7f0c372f5ffbe8545008.html | 113 + sw/dir_ebeff77b922fbb914a1494857a82a38e.html | 110 + sw/dir_eea6eb9fd693422884580f70321908d2.html | 103 + sw/dir_f05036e2ccd24a7119a5bbccebab20b2.html | 103 + sw/dir_f0f9b27afba2e8cc2da6e5fddcc1a8c9.html | 169 + sw/doc.svg | 12 + sw/docd.svg | 12 + sw/doxygen.css | 2244 ++ sw/doxygen.svg | 28 + sw/doxygen_crawl.html | 2128 ++ sw/dynsections.js | 198 + sw/files.html | 227 + sw/float__corner__test_2main_8c.html | 448 + ...finx__extension__intrinsics_8h_source.html | 945 + sw/floating__point__test_2main_8c.html | 492 + ...rv32__zfinx__extension__intrinsics_8h.html | 1744 ++ ...finx__extension__intrinsics_8h_source.html | 985 + sw/folderclosed.svg | 11 + sw/folderclosedd.svg | 11 + sw/folderopen.svg | 17 + sw/folderopend.svg | 12 + sw/functions.html | 213 + sw/functions_vars.html | 213 + sw/game__of__life_2main_8c.html | 460 + sw/globals.html | 110 + sw/globals_a.html | 104 + sw/globals_b.html | 104 + sw/globals_c.html | 357 + sw/globals_d.html | 139 + sw/globals_defs.html | 101 + sw/globals_defs_b.html | 103 + sw/globals_defs_c.html | 106 + sw/globals_defs_d.html | 115 + sw/globals_defs_e.html | 102 + sw/globals_defs_f.html | 102 + sw/globals_defs_g.html | 105 + sw/globals_defs_i.html | 101 + sw/globals_defs_m.html | 101 + sw/globals_defs_n.html | 153 + sw/globals_defs_o.html | 104 + sw/globals_defs_p.html | 105 + sw/globals_defs_r.html | 111 + sw/globals_defs_s.html | 126 + sw/globals_defs_t.html | 109 + sw/globals_defs_u.html | 119 + sw/globals_defs_w.html | 102 + sw/globals_defs_x.html | 113 + sw/globals_e.html | 116 + sw/globals_enum.html | 152 + sw/globals_eval.html | 346 + sw/globals_eval_d.html | 121 + sw/globals_eval_e.html | 110 + sw/globals_eval_f.html | 102 + sw/globals_eval_g.html | 107 + sw/globals_eval_h.html | 112 + sw/globals_eval_n.html | 130 + sw/globals_eval_o.html | 119 + sw/globals_eval_p.html | 114 + sw/globals_eval_r.html | 129 + sw/globals_eval_s.html | 179 + sw/globals_eval_t.html | 157 + sw/globals_eval_u.html | 137 + sw/globals_eval_w.html | 112 + sw/globals_eval_x.html | 122 + sw/globals_f.html | 104 + sw/globals_func.html | 107 + sw/globals_func_a.html | 102 + sw/globals_func_b.html | 101 + sw/globals_func_c.html | 103 + sw/globals_func_d.html | 102 + sw/globals_func_g.html | 109 + sw/globals_func_h.html | 103 + sw/globals_func_m.html | 102 + sw/globals_func_n.html | 328 + sw/globals_func_p.html | 108 + sw/globals_func_r.html | 148 + sw/globals_func_s.html | 131 + sw/globals_func_t.html | 105 + sw/globals_func_u.html | 102 + sw/globals_func_v.html | 104 + sw/globals_func_w.html | 102 + sw/globals_func_x.html | 111 + sw/globals_g.html | 122 + sw/globals_h.html | 115 + sw/globals_i.html | 102 + sw/globals_k.html | 101 + sw/globals_m.html | 103 + sw/globals_n.html | 449 + sw/globals_o.html | 123 + sw/globals_p.html | 129 + sw/globals_r.html | 189 + sw/globals_s.html | 240 + sw/globals_t.html | 175 + sw/globals_u.html | 159 + sw/globals_v.html | 104 + sw/globals_vars.html | 119 + sw/globals_w.html | 116 + sw/globals_x.html | 147 + sw/hello__world_2main_8c.html | 161 + sw/index.html | 100 + sw/jquery.js | 34 + sw/md_README.html | 336 + sw/menu.js | 134 + sw/menudata.js | 149 + sw/minus.svg | 8 + sw/minusd.svg | 8 + sw/nav_f.png | Bin 0 -> 153 bytes sw/nav_fd.png | Bin 0 -> 169 bytes sw/nav_g.png | Bin 0 -> 95 bytes sw/nav_h.png | Bin 0 -> 98 bytes sw/nav_hd.png | Bin 0 -> 114 bytes sw/navtree.css | 149 + sw/neorv32_8h.html | 1720 ++ sw/neorv32_8h_source.html | 348 + sw/neorv32__aux_8c.html | 230 + sw/neorv32__aux_8h.html | 248 + sw/neorv32__aux_8h_source.html | 152 + sw/neorv32__cfs_8c.html | 142 + sw/neorv32__cfs_8h.html | 175 + sw/neorv32__cfs_8h_source.html | 130 + sw/neorv32__cpu_8c.html | 413 + sw/neorv32__cpu_8h.html | 894 + sw/neorv32__cpu_8h_source.html | 299 + sw/neorv32__cpu__amo_8c.html | 414 + sw/neorv32__cpu__amo_8h.html | 496 + sw/neorv32__cpu__amo_8h_source.html | 181 + sw/neorv32__cpu__cfu_8c.html | 138 + sw/neorv32__cpu__cfu_8h.html | 281 + sw/neorv32__cpu__cfu_8h_source.html | 128 + sw/neorv32__cpu__csr_8h.html | 1297 + sw/neorv32__cpu__csr_8h_source.html | 802 + sw/neorv32__crc_8c.html | 255 + sw/neorv32__crc_8h.html | 312 + sw/neorv32__crc_8h_source.html | 157 + sw/neorv32__dma_8h.html | 676 + sw/neorv32__dma_8h_source.html | 228 + sw/neorv32__gpio_8c.html | 296 + sw/neorv32__gpio_8h.html | 326 + sw/neorv32__gpio_8h_source.html | 143 + sw/neorv32__gptmr_8c.html | 236 + sw/neorv32__gptmr_8h.html | 308 + sw/neorv32__gptmr_8h_source.html | 163 + sw/neorv32__intrinsics_8h.html | 451 + sw/neorv32__intrinsics_8h_source.html | 389 + sw/neorv32__legacy_8h.html | 137 + sw/neorv32__legacy_8h_source.html | 126 + sw/neorv32__mtime_8c.html | 285 + sw/neorv32__mtime_8h.html | 315 + sw/neorv32__mtime_8h_source.html | 149 + sw/neorv32__neoled_8c.html | 371 + sw/neorv32__neoled_8h.html | 554 + sw/neorv32__neoled_8h_source.html | 227 + sw/neorv32__onewire_8c.html | 552 + sw/neorv32__onewire_8h.html | 682 + sw/neorv32__onewire_8h_source.html | 221 + sw/neorv32__pwm_8c.html | 284 + sw/neorv32__pwm_8h.html | 344 + sw/neorv32__pwm_8h_source.html | 158 + sw/neorv32__rte_8c.html | 468 + sw/neorv32__rte_8h.html | 520 + sw/neorv32__rte_8h_source.html | 212 + sw/neorv32__sdi_8c.html | 301 + sw/neorv32__sdi_8h.html | 399 + sw/neorv32__sdi_8h_source.html | 183 + sw/neorv32__slink_8c.html | 485 + sw/neorv32__slink_8h.html | 657 + sw/neorv32__slink_8h_source.html | 235 + sw/neorv32__spi_8c.html | 526 + sw/neorv32__spi_8h.html | 681 + sw/neorv32__spi_8h_source.html | 231 + sw/neorv32__spi__irq_8c.html | 257 + sw/neorv32__spi__irq_8h.html | 301 + sw/neorv32__spi__irq_8h_source.html | 183 + sw/neorv32__sysinfo_8h_source.html | 189 + sw/neorv32__trng_8c.html | 275 + sw/neorv32__trng_8h.html | 354 + sw/neorv32__trng_8h_source.html | 167 + sw/neorv32__twi_8c.html | 434 + sw/neorv32__twi_8h.html | 582 + sw/neorv32__twi_8h_source.html | 215 + sw/neorv32__uart_8c.html | 860 + sw/neorv32__uart_8h.html | 1012 + sw/neorv32__uart_8h_source.html | 296 + sw/neorv32__wdt_8c.html | 254 + sw/neorv32__wdt_8h.html | 383 + sw/neorv32__wdt_8h_source.html | 183 + sw/neorv32__xip_8c.html | 312 + sw/neorv32__xip_8h.html | 433 + sw/neorv32__xip_8h_source.html | 199 + sw/neorv32__xirq_8c.html | 479 + sw/neorv32__xirq_8h.html | 491 + sw/neorv32__xirq_8h_source.html | 170 + sw/neorv32_logo_small.png | Bin 0 -> 4604 bytes sw/onewire__aux_8h_source.html | 401 + sw/open.png | Bin 0 -> 123 bytes sw/pages.html | 104 + sw/plus.svg | 9 + sw/plusd.svg | 9 + sw/processor__check_2main_8c.html | 460 + sw/resize.js | 145 + sw/search/all_0.js | 4 + sw/search/all_1.js | 4 + sw/search/all_10.js | 5 + sw/search/all_11.js | 4 + sw/search/all_12.js | 11 + sw/search/all_13.js | 432 + sw/search/all_14.js | 28 + sw/search/all_15.js | 39 + sw/search/all_16.js | 103 + sw/search/all_17.js | 161 + sw/search/all_18.js | 91 + sw/search/all_19.js | 70 + sw/search/all_1a.js | 8 + sw/search/all_1b.js | 20 + sw/search/all_1c.js | 50 + sw/search/all_1d.js | 4 + sw/search/all_2.js | 4 + sw/search/all_3.js | 4 + sw/search/all_4.js | 4 + sw/search/all_5.js | 10 + sw/search/all_6.js | 17 + sw/search/all_7.js | 18 + sw/search/all_8.js | 9 + sw/search/all_9.js | 267 + sw/search/all_a.js | 51 + sw/search/all_b.js | 23 + sw/search/all_c.js | 12 + sw/search/all_d.js | 32 + sw/search/all_e.js | 29 + sw/search/all_f.js | 13 + sw/search/classes_0.js | 4 + sw/search/classes_1.js | 4 + sw/search/classes_2.js | 22 + sw/search/classes_3.js | 4 + sw/search/classes_4.js | 6 + sw/search/classes_5.js | 4 + sw/search/close.svg | 18 + sw/search/defines_0.js | 4 + sw/search/defines_1.js | 6 + sw/search/defines_10.js | 5 + sw/search/defines_11.js | 16 + sw/search/defines_2.js | 9 + sw/search/defines_3.js | 18 + sw/search/defines_4.js | 5 + sw/search/defines_5.js | 5 + sw/search/defines_6.js | 8 + sw/search/defines_7.js | 4 + sw/search/defines_8.js | 4 + sw/search/defines_9.js | 56 + sw/search/defines_a.js | 7 + sw/search/defines_b.js | 8 + sw/search/defines_c.js | 14 + sw/search/defines_d.js | 29 + sw/search/defines_e.js | 12 + sw/search/defines_f.js | 22 + sw/search/enums_0.js | 5 + sw/search/enums_1.js | 41 + sw/search/enums_2.js | 7 + sw/search/enumvalues_0.js | 249 + sw/search/enumvalues_1.js | 24 + sw/search/enumvalues_2.js | 13 + sw/search/enumvalues_3.js | 5 + sw/search/enumvalues_4.js | 10 + sw/search/enumvalues_5.js | 15 + sw/search/enumvalues_6.js | 33 + sw/search/enumvalues_7.js | 22 + sw/search/enumvalues_8.js | 17 + sw/search/enumvalues_9.js | 32 + sw/search/enumvalues_a.js | 82 + sw/search/enumvalues_b.js | 60 + sw/search/enumvalues_c.js | 40 + sw/search/enumvalues_d.js | 15 + sw/search/enumvalues_e.js | 25 + sw/search/files_0.js | 4 + sw/search/files_1.js | 4 + sw/search/files_2.js | 55 + sw/search/files_3.js | 4 + sw/search/functions_0.js | 10 + sw/search/functions_1.js | 5 + sw/search/functions_10.js | 14 + sw/search/functions_2.js | 4 + sw/search/functions_3.js | 6 + sw/search/functions_4.js | 5 + sw/search/functions_5.js | 12 + sw/search/functions_6.js | 6 + sw/search/functions_7.js | 5 + sw/search/functions_8.js | 231 + sw/search/functions_9.js | 11 + sw/search/functions_a.js | 51 + sw/search/functions_b.js | 34 + sw/search/functions_c.js | 8 + sw/search/functions_d.js | 5 + sw/search/functions_e.js | 7 + sw/search/functions_f.js | 5 + sw/search/mag.svg | 24 + sw/search/mag_d.svg | 24 + sw/search/mag_sel.svg | 31 + sw/search/mag_seld.svg | 31 + sw/search/pages_0.js | 4 + sw/search/search.css | 291 + sw/search/search.js | 694 + sw/search/searchdata.js | 39 + sw/search/variables_0.js | 6 + sw/search/variables_1.js | 4 + sw/search/variables_10.js | 15 + sw/search/variables_11.js | 10 + sw/search/variables_12.js | 4 + sw/search/variables_13.js | 4 + sw/search/variables_14.js | 4 + sw/search/variables_2.js | 4 + sw/search/variables_3.js | 9 + sw/search/variables_4.js | 12 + sw/search/variables_5.js | 8 + sw/search/variables_6.js | 4 + sw/search/variables_7.js | 4 + sw/search/variables_8.js | 4 + sw/search/variables_9.js | 5 + sw/search/variables_a.js | 4 + sw/search/variables_b.js | 7 + sw/search/variables_c.js | 4 + sw/search/variables_d.js | 7 + sw/search/variables_e.js | 11 + sw/search/variables_f.js | 7 + sw/splitbar.png | Bin 0 -> 314 bytes sw/splitbard.png | Bin 0 -> 282 bytes sw/structdate__t.html | 228 + sw/structneorv32__cfs__t.html | 130 + sw/structneorv32__crc__t.html | 181 + sw/structneorv32__dma__t.html | 181 + sw/structneorv32__gpio__t.html | 147 + sw/structneorv32__gptmr__t.html | 164 + sw/structneorv32__mtime__t.html | 181 + sw/structneorv32__neoled__t.html | 147 + sw/structneorv32__onewire__t.html | 147 + sw/structneorv32__pwm__t.html | 147 + sw/structneorv32__sdi__t.html | 147 + sw/structneorv32__slink__t.html | 181 + sw/structneorv32__spi__t.html | 147 + sw/structneorv32__sysinfo__t.html | 181 + sw/structneorv32__trng__t.html | 130 + sw/structneorv32__twi__t.html | 147 + sw/structneorv32__uart__t.html | 147 + sw/structneorv32__wdt__t.html | 147 + sw/structneorv32__xip__t.html | 181 + sw/structneorv32__xirq__t.html | 249 + sw/structrecord.html | 155 + sw/structt__neorv32__spi.html | 228 + sw/sync_off.png | Bin 0 -> 853 bytes sw/sync_on.png | Bin 0 -> 845 bytes sw/syscalls_8c.html | 180 + sw/tab_a.png | Bin 0 -> 142 bytes sw/tab_ad.png | Bin 0 -> 135 bytes sw/tab_b.png | Bin 0 -> 169 bytes sw/tab_bd.png | Bin 0 -> 173 bytes sw/tab_h.png | Bin 0 -> 177 bytes sw/tab_hd.png | Bin 0 -> 180 bytes sw/tab_s.png | Bin 0 -> 184 bytes sw/tab_sd.png | Bin 0 -> 188 bytes sw/tabs.css | 1 + sw/unionfloat__conv__t.html | 148 + sw/unionsubwords16__t.html | 114 + sw/unionsubwords32__t.html | 117 + sw/unionsubwords64__t.html | 120 + ug/index.html | 4828 ++++ 470 files changed, 99205 insertions(+) create mode 100644 .nojekyll create mode 100644 img/SPI_timing_diagram2.wikimedia.png create mode 100644 img/address_space.png create mode 100644 img/bus_interface.png create mode 100644 img/bus_interface_atomic.png create mode 100644 img/cfu_r3type_instruction.png create mode 100644 img/cfu_r4type_instruction.png create mode 100644 img/cfu_r5type_instruction_a.png create mode 100644 img/cfu_r5type_instruction_b.png create mode 100644 img/eclipse.png create mode 100644 img/icon.png create mode 100644 img/license.md create mode 100644 img/neopixel_timing.png create mode 100644 img/neorv32_boot_configurations.png create mode 100644 img/neorv32_bus.png create mode 100644 img/neorv32_cpu.png create mode 100644 img/neorv32_logo.png create mode 100644 img/neorv32_logo_riscv.png create mode 100644 img/neorv32_logo_riscv_small.png create mode 100644 img/neorv32_logo_small.png create mode 100644 img/neorv32_logo_smcard.jpg create mode 100644 img/neorv32_ocd_complex.png create mode 100644 img/neorv32_processor.png create mode 100644 img/neorv32_test_setup.png create mode 100644 img/onewire_data.png create mode 100644 img/onewire_reset.png create mode 100644 img/oshw_logo.png create mode 100644 img/ram_layout.png create mode 100644 img/riscv_logo.png create mode 100644 img/riscv_logo_small.png create mode 100644 img/stream_link_interface.png create mode 100644 img/vivado_ip_gui.png create mode 100644 img/vivado_ip_soc.png create mode 100644 img/xbus_read.png create mode 100644 img/xbus_write.png create mode 100644 index.html create mode 100644 sw/annotated.html create mode 100644 sw/atomic__test_2main_8c.html create mode 100644 sw/bc_s.png create mode 100644 sw/bc_sd.png create mode 100644 sw/bootloader_8c.html create mode 100644 sw/bus__explorer_2main_8c.html create mode 100644 sw/classes.html create mode 100644 sw/clipboard.js create mode 100644 sw/closed.png create mode 100644 sw/cookie.js create mode 100644 sw/demo__blink__led_2main_8c.html create mode 100644 sw/demo__cfs_2main_8c.html create mode 100644 sw/demo__cfu_2main_8c.html create mode 100644 sw/demo__crc_2main_8c.html create mode 100644 sw/demo__dma_2main_8c.html create mode 100644 sw/demo__emulate__unaligned_2main_8c.html create mode 100644 sw/demo__gptmr_2main_8c.html create mode 100644 sw/demo__hpm_2main_8c.html create mode 100644 sw/demo__mtime_2main_8c.html create mode 100644 sw/demo__neopixel_2main_8c.html create mode 100644 sw/demo__newlib_2main_8c.html create mode 100644 sw/demo__onewire_2main_8c.html create mode 100644 sw/demo__pwm_2main_8c.html create mode 100644 sw/demo__sdi_2main_8c.html create mode 100644 sw/demo__slink_2main_8c.html create mode 100644 sw/demo__spi_2main_8c.html create mode 100644 sw/demo__spi__irq_2main_8c.html create mode 100644 sw/demo__trng_2main_8c.html create mode 100644 sw/demo__twi_2main_8c.html create mode 100644 sw/demo__wdt_2main_8c.html create mode 100644 sw/demo__xip_2main_8c.html create mode 100644 sw/demo__xirq_2main_8c.html create mode 100644 sw/dhry_8h_source.html create mode 100644 sw/dir_01cde3d98944a579dc3b5e43a5311a79.html create mode 100644 sw/dir_01fcd3835fb4e7d9331b722d86291b65.html create mode 100644 sw/dir_09a89dfa1596b6613cf2c29528a32844.html create mode 100644 sw/dir_0c6ac14e2254a316d41123f98feeb67b.html create mode 100644 sw/dir_0d2921e55a1172a4726516961ee96ab5.html create mode 100644 sw/dir_0f35fd52d2216117815d19d974239550.html create mode 100644 sw/dir_23212395b5ee0866d2fdd629e0ddeae8.html create mode 100644 sw/dir_23717ebbabf7a51c0558262947e0fe3b.html create mode 100644 sw/dir_237db5b95db643499d4c20f0bc5f6a7d.html create mode 100644 sw/dir_2ba96d3140b089dada6fb9f817b7975f.html create mode 100644 sw/dir_3b3bafc48b460f797485cc75b94aa81c.html create mode 100644 sw/dir_4316bb0e553b51b8b65560981547ce0f.html create mode 100644 sw/dir_449d8ba5f8b78dc90092f20d15a2386a.html create mode 100644 sw/dir_46981071cfd8ec44311b09fdcf6c06a8.html create mode 100644 sw/dir_4bd1267d34feeec0f679c16f884588e7.html create mode 100644 sw/dir_4c113257314015688a865e1bb8429184.html create mode 100644 sw/dir_5534fa9035f54ab438a41c43d6f7fc7a.html create mode 100644 sw/dir_6a888d76b0f727dc821f77838927e542.html create mode 100644 sw/dir_752b1e5d3973bf735fa78bf6b4727df9.html create mode 100644 sw/dir_78d7bfa405ff3a31fa7539cfd8bc8262.html create mode 100644 sw/dir_7a2c74f70a4cdf2e836a07048e2f71dd.html create mode 100644 sw/dir_7d04193005ada6f9450f847f4adb6b5b.html create mode 100644 sw/dir_8c514361e1f16692c783b23503f30f16.html create mode 100644 sw/dir_8d341cbe0581f44e1ae95d82d74e8bc8.html create mode 100644 sw/dir_8f848e36ac87ced1c361afcc0549ca32.html create mode 100644 sw/dir_93967190e0d2e549ceca77007097849b.html create mode 100644 sw/dir_9a1c128d67c35790e92af404beb936aa.html create mode 100644 sw/dir_9d04cdc586d6978be343bda7adcdc371.html create mode 100644 sw/dir_b5eb9f7d151d147efb5dbda58439e4e7.html create mode 100644 sw/dir_b683da3a5fc966bff32ebf7cda721811.html create mode 100644 sw/dir_b68ac2efc0c6ed3018151f7bb6c45670.html create mode 100644 sw/dir_b6b50782b8271d07dffbc5f0cb9ff3f4.html create mode 100644 sw/dir_bf935196a1ea0ca9cb42aae56d70946a.html create mode 100644 sw/dir_c2d46947bdd73c33f53326fc5ee3a272.html create mode 100644 sw/dir_c413aba6cb5da07a571465ba333950af.html create mode 100644 sw/dir_d4640980cbf1943e4a4aee6e8b810c7a.html create mode 100644 sw/dir_d68bb921df3f2482fe9ace49b286ab86.html create mode 100644 sw/dir_e9ffd83269fb7f0c372f5ffbe8545008.html create mode 100644 sw/dir_ebeff77b922fbb914a1494857a82a38e.html create mode 100644 sw/dir_eea6eb9fd693422884580f70321908d2.html create mode 100644 sw/dir_f05036e2ccd24a7119a5bbccebab20b2.html create mode 100644 sw/dir_f0f9b27afba2e8cc2da6e5fddcc1a8c9.html create mode 100644 sw/doc.svg create mode 100644 sw/docd.svg create mode 100644 sw/doxygen.css create mode 100644 sw/doxygen.svg create mode 100644 sw/doxygen_crawl.html create mode 100644 sw/dynsections.js create mode 100644 sw/files.html create mode 100644 sw/float__corner__test_2main_8c.html create mode 100644 sw/float__corner__test_2neorv32__zfinx__extension__intrinsics_8h_source.html create mode 100644 sw/floating__point__test_2main_8c.html create mode 100644 sw/floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html create mode 100644 sw/floating__point__test_2neorv32__zfinx__extension__intrinsics_8h_source.html create mode 100644 sw/folderclosed.svg create mode 100644 sw/folderclosedd.svg create mode 100644 sw/folderopen.svg create mode 100644 sw/folderopend.svg create mode 100644 sw/functions.html create mode 100644 sw/functions_vars.html create mode 100644 sw/game__of__life_2main_8c.html create mode 100644 sw/globals.html create mode 100644 sw/globals_a.html create mode 100644 sw/globals_b.html create mode 100644 sw/globals_c.html create mode 100644 sw/globals_d.html create mode 100644 sw/globals_defs.html create mode 100644 sw/globals_defs_b.html create mode 100644 sw/globals_defs_c.html create mode 100644 sw/globals_defs_d.html create mode 100644 sw/globals_defs_e.html create mode 100644 sw/globals_defs_f.html create mode 100644 sw/globals_defs_g.html create mode 100644 sw/globals_defs_i.html create mode 100644 sw/globals_defs_m.html create mode 100644 sw/globals_defs_n.html create mode 100644 sw/globals_defs_o.html create mode 100644 sw/globals_defs_p.html create mode 100644 sw/globals_defs_r.html create mode 100644 sw/globals_defs_s.html create mode 100644 sw/globals_defs_t.html create mode 100644 sw/globals_defs_u.html create mode 100644 sw/globals_defs_w.html create mode 100644 sw/globals_defs_x.html create mode 100644 sw/globals_e.html create mode 100644 sw/globals_enum.html create mode 100644 sw/globals_eval.html create mode 100644 sw/globals_eval_d.html create mode 100644 sw/globals_eval_e.html create mode 100644 sw/globals_eval_f.html create mode 100644 sw/globals_eval_g.html create mode 100644 sw/globals_eval_h.html create mode 100644 sw/globals_eval_n.html create mode 100644 sw/globals_eval_o.html create mode 100644 sw/globals_eval_p.html create mode 100644 sw/globals_eval_r.html create mode 100644 sw/globals_eval_s.html create mode 100644 sw/globals_eval_t.html create mode 100644 sw/globals_eval_u.html create mode 100644 sw/globals_eval_w.html create mode 100644 sw/globals_eval_x.html create mode 100644 sw/globals_f.html create mode 100644 sw/globals_func.html create mode 100644 sw/globals_func_a.html create mode 100644 sw/globals_func_b.html create mode 100644 sw/globals_func_c.html create mode 100644 sw/globals_func_d.html create mode 100644 sw/globals_func_g.html create mode 100644 sw/globals_func_h.html create mode 100644 sw/globals_func_m.html create mode 100644 sw/globals_func_n.html create mode 100644 sw/globals_func_p.html create mode 100644 sw/globals_func_r.html create mode 100644 sw/globals_func_s.html create mode 100644 sw/globals_func_t.html create mode 100644 sw/globals_func_u.html create mode 100644 sw/globals_func_v.html create mode 100644 sw/globals_func_w.html create mode 100644 sw/globals_func_x.html create mode 100644 sw/globals_g.html create mode 100644 sw/globals_h.html create mode 100644 sw/globals_i.html create mode 100644 sw/globals_k.html create mode 100644 sw/globals_m.html create mode 100644 sw/globals_n.html create mode 100644 sw/globals_o.html create mode 100644 sw/globals_p.html create mode 100644 sw/globals_r.html create mode 100644 sw/globals_s.html create mode 100644 sw/globals_t.html create mode 100644 sw/globals_u.html create mode 100644 sw/globals_v.html create mode 100644 sw/globals_vars.html create mode 100644 sw/globals_w.html create mode 100644 sw/globals_x.html create mode 100644 sw/hello__world_2main_8c.html create mode 100644 sw/index.html create mode 100644 sw/jquery.js create mode 100644 sw/md_README.html create mode 100644 sw/menu.js create mode 100644 sw/menudata.js create mode 100644 sw/minus.svg create mode 100644 sw/minusd.svg create mode 100644 sw/nav_f.png create mode 100644 sw/nav_fd.png create mode 100644 sw/nav_g.png create mode 100644 sw/nav_h.png create mode 100644 sw/nav_hd.png create mode 100644 sw/navtree.css create mode 100644 sw/neorv32_8h.html create mode 100644 sw/neorv32_8h_source.html create mode 100644 sw/neorv32__aux_8c.html create mode 100644 sw/neorv32__aux_8h.html create mode 100644 sw/neorv32__aux_8h_source.html create mode 100644 sw/neorv32__cfs_8c.html create mode 100644 sw/neorv32__cfs_8h.html create mode 100644 sw/neorv32__cfs_8h_source.html create mode 100644 sw/neorv32__cpu_8c.html create mode 100644 sw/neorv32__cpu_8h.html create mode 100644 sw/neorv32__cpu_8h_source.html create mode 100644 sw/neorv32__cpu__amo_8c.html create mode 100644 sw/neorv32__cpu__amo_8h.html create mode 100644 sw/neorv32__cpu__amo_8h_source.html create mode 100644 sw/neorv32__cpu__cfu_8c.html create mode 100644 sw/neorv32__cpu__cfu_8h.html create mode 100644 sw/neorv32__cpu__cfu_8h_source.html create mode 100644 sw/neorv32__cpu__csr_8h.html create mode 100644 sw/neorv32__cpu__csr_8h_source.html create mode 100644 sw/neorv32__crc_8c.html create mode 100644 sw/neorv32__crc_8h.html create mode 100644 sw/neorv32__crc_8h_source.html create mode 100644 sw/neorv32__dma_8h.html create mode 100644 sw/neorv32__dma_8h_source.html create mode 100644 sw/neorv32__gpio_8c.html create mode 100644 sw/neorv32__gpio_8h.html create mode 100644 sw/neorv32__gpio_8h_source.html create mode 100644 sw/neorv32__gptmr_8c.html create mode 100644 sw/neorv32__gptmr_8h.html create mode 100644 sw/neorv32__gptmr_8h_source.html create mode 100644 sw/neorv32__intrinsics_8h.html create mode 100644 sw/neorv32__intrinsics_8h_source.html create mode 100644 sw/neorv32__legacy_8h.html create mode 100644 sw/neorv32__legacy_8h_source.html create mode 100644 sw/neorv32__mtime_8c.html create mode 100644 sw/neorv32__mtime_8h.html create mode 100644 sw/neorv32__mtime_8h_source.html create mode 100644 sw/neorv32__neoled_8c.html create mode 100644 sw/neorv32__neoled_8h.html create mode 100644 sw/neorv32__neoled_8h_source.html create mode 100644 sw/neorv32__onewire_8c.html create mode 100644 sw/neorv32__onewire_8h.html create mode 100644 sw/neorv32__onewire_8h_source.html create mode 100644 sw/neorv32__pwm_8c.html create mode 100644 sw/neorv32__pwm_8h.html create mode 100644 sw/neorv32__pwm_8h_source.html create mode 100644 sw/neorv32__rte_8c.html create mode 100644 sw/neorv32__rte_8h.html create mode 100644 sw/neorv32__rte_8h_source.html create mode 100644 sw/neorv32__sdi_8c.html create mode 100644 sw/neorv32__sdi_8h.html create mode 100644 sw/neorv32__sdi_8h_source.html create mode 100644 sw/neorv32__slink_8c.html create mode 100644 sw/neorv32__slink_8h.html create mode 100644 sw/neorv32__slink_8h_source.html create mode 100644 sw/neorv32__spi_8c.html create mode 100644 sw/neorv32__spi_8h.html create mode 100644 sw/neorv32__spi_8h_source.html create mode 100644 sw/neorv32__spi__irq_8c.html create mode 100644 sw/neorv32__spi__irq_8h.html create mode 100644 sw/neorv32__spi__irq_8h_source.html create mode 100644 sw/neorv32__sysinfo_8h_source.html create mode 100644 sw/neorv32__trng_8c.html create mode 100644 sw/neorv32__trng_8h.html create mode 100644 sw/neorv32__trng_8h_source.html create mode 100644 sw/neorv32__twi_8c.html create mode 100644 sw/neorv32__twi_8h.html create mode 100644 sw/neorv32__twi_8h_source.html create mode 100644 sw/neorv32__uart_8c.html create mode 100644 sw/neorv32__uart_8h.html create mode 100644 sw/neorv32__uart_8h_source.html create mode 100644 sw/neorv32__wdt_8c.html create mode 100644 sw/neorv32__wdt_8h.html create mode 100644 sw/neorv32__wdt_8h_source.html create mode 100644 sw/neorv32__xip_8c.html create mode 100644 sw/neorv32__xip_8h.html create mode 100644 sw/neorv32__xip_8h_source.html create mode 100644 sw/neorv32__xirq_8c.html create mode 100644 sw/neorv32__xirq_8h.html create mode 100644 sw/neorv32__xirq_8h_source.html create mode 100644 sw/neorv32_logo_small.png create mode 100644 sw/onewire__aux_8h_source.html create mode 100644 sw/open.png create mode 100644 sw/pages.html create mode 100644 sw/plus.svg create mode 100644 sw/plusd.svg create mode 100644 sw/processor__check_2main_8c.html create mode 100644 sw/resize.js create mode 100644 sw/search/all_0.js create mode 100644 sw/search/all_1.js create mode 100644 sw/search/all_10.js create mode 100644 sw/search/all_11.js create mode 100644 sw/search/all_12.js create mode 100644 sw/search/all_13.js create mode 100644 sw/search/all_14.js create mode 100644 sw/search/all_15.js create mode 100644 sw/search/all_16.js create mode 100644 sw/search/all_17.js create mode 100644 sw/search/all_18.js create mode 100644 sw/search/all_19.js create mode 100644 sw/search/all_1a.js create mode 100644 sw/search/all_1b.js create mode 100644 sw/search/all_1c.js create mode 100644 sw/search/all_1d.js create mode 100644 sw/search/all_2.js create mode 100644 sw/search/all_3.js create mode 100644 sw/search/all_4.js create mode 100644 sw/search/all_5.js create mode 100644 sw/search/all_6.js create mode 100644 sw/search/all_7.js create mode 100644 sw/search/all_8.js create mode 100644 sw/search/all_9.js create mode 100644 sw/search/all_a.js create mode 100644 sw/search/all_b.js create mode 100644 sw/search/all_c.js create mode 100644 sw/search/all_d.js create mode 100644 sw/search/all_e.js create mode 100644 sw/search/all_f.js create mode 100644 sw/search/classes_0.js create mode 100644 sw/search/classes_1.js create mode 100644 sw/search/classes_2.js create mode 100644 sw/search/classes_3.js create mode 100644 sw/search/classes_4.js create mode 100644 sw/search/classes_5.js create mode 100644 sw/search/close.svg create mode 100644 sw/search/defines_0.js create mode 100644 sw/search/defines_1.js create mode 100644 sw/search/defines_10.js create mode 100644 sw/search/defines_11.js create mode 100644 sw/search/defines_2.js create mode 100644 sw/search/defines_3.js create mode 100644 sw/search/defines_4.js create mode 100644 sw/search/defines_5.js create mode 100644 sw/search/defines_6.js create mode 100644 sw/search/defines_7.js create mode 100644 sw/search/defines_8.js create mode 100644 sw/search/defines_9.js create mode 100644 sw/search/defines_a.js create mode 100644 sw/search/defines_b.js create mode 100644 sw/search/defines_c.js create mode 100644 sw/search/defines_d.js create mode 100644 sw/search/defines_e.js create mode 100644 sw/search/defines_f.js create mode 100644 sw/search/enums_0.js create mode 100644 sw/search/enums_1.js create mode 100644 sw/search/enums_2.js create mode 100644 sw/search/enumvalues_0.js create mode 100644 sw/search/enumvalues_1.js create mode 100644 sw/search/enumvalues_2.js create mode 100644 sw/search/enumvalues_3.js create mode 100644 sw/search/enumvalues_4.js create mode 100644 sw/search/enumvalues_5.js create mode 100644 sw/search/enumvalues_6.js create mode 100644 sw/search/enumvalues_7.js create mode 100644 sw/search/enumvalues_8.js create mode 100644 sw/search/enumvalues_9.js create mode 100644 sw/search/enumvalues_a.js create mode 100644 sw/search/enumvalues_b.js create mode 100644 sw/search/enumvalues_c.js create mode 100644 sw/search/enumvalues_d.js create mode 100644 sw/search/enumvalues_e.js create mode 100644 sw/search/files_0.js create mode 100644 sw/search/files_1.js create mode 100644 sw/search/files_2.js create mode 100644 sw/search/files_3.js create mode 100644 sw/search/functions_0.js create mode 100644 sw/search/functions_1.js create mode 100644 sw/search/functions_10.js create mode 100644 sw/search/functions_2.js create mode 100644 sw/search/functions_3.js create mode 100644 sw/search/functions_4.js create mode 100644 sw/search/functions_5.js create mode 100644 sw/search/functions_6.js create mode 100644 sw/search/functions_7.js create mode 100644 sw/search/functions_8.js create mode 100644 sw/search/functions_9.js create mode 100644 sw/search/functions_a.js create mode 100644 sw/search/functions_b.js create mode 100644 sw/search/functions_c.js create mode 100644 sw/search/functions_d.js create mode 100644 sw/search/functions_e.js create mode 100644 sw/search/functions_f.js create mode 100644 sw/search/mag.svg create mode 100644 sw/search/mag_d.svg create mode 100644 sw/search/mag_sel.svg create mode 100644 sw/search/mag_seld.svg create mode 100644 sw/search/pages_0.js create mode 100644 sw/search/search.css create mode 100644 sw/search/search.js create mode 100644 sw/search/searchdata.js create mode 100644 sw/search/variables_0.js create mode 100644 sw/search/variables_1.js create mode 100644 sw/search/variables_10.js create mode 100644 sw/search/variables_11.js create mode 100644 sw/search/variables_12.js create mode 100644 sw/search/variables_13.js create mode 100644 sw/search/variables_14.js create mode 100644 sw/search/variables_2.js create mode 100644 sw/search/variables_3.js create mode 100644 sw/search/variables_4.js create mode 100644 sw/search/variables_5.js create mode 100644 sw/search/variables_6.js create mode 100644 sw/search/variables_7.js create mode 100644 sw/search/variables_8.js create mode 100644 sw/search/variables_9.js create mode 100644 sw/search/variables_a.js create mode 100644 sw/search/variables_b.js create mode 100644 sw/search/variables_c.js create mode 100644 sw/search/variables_d.js create mode 100644 sw/search/variables_e.js create mode 100644 sw/search/variables_f.js create mode 100644 sw/splitbar.png create mode 100644 sw/splitbard.png create mode 100644 sw/structdate__t.html create mode 100644 sw/structneorv32__cfs__t.html create mode 100644 sw/structneorv32__crc__t.html create mode 100644 sw/structneorv32__dma__t.html create mode 100644 sw/structneorv32__gpio__t.html create mode 100644 sw/structneorv32__gptmr__t.html create mode 100644 sw/structneorv32__mtime__t.html create mode 100644 sw/structneorv32__neoled__t.html create mode 100644 sw/structneorv32__onewire__t.html create mode 100644 sw/structneorv32__pwm__t.html create mode 100644 sw/structneorv32__sdi__t.html create mode 100644 sw/structneorv32__slink__t.html create mode 100644 sw/structneorv32__spi__t.html create mode 100644 sw/structneorv32__sysinfo__t.html create mode 100644 sw/structneorv32__trng__t.html create mode 100644 sw/structneorv32__twi__t.html create mode 100644 sw/structneorv32__uart__t.html create mode 100644 sw/structneorv32__wdt__t.html create mode 100644 sw/structneorv32__xip__t.html create mode 100644 sw/structneorv32__xirq__t.html create mode 100644 sw/structrecord.html create mode 100644 sw/structt__neorv32__spi.html create mode 100644 sw/sync_off.png create mode 100644 sw/sync_on.png create mode 100644 sw/syscalls_8c.html create mode 100644 sw/tab_a.png create mode 100644 sw/tab_ad.png create mode 100644 sw/tab_b.png create mode 100644 sw/tab_bd.png create mode 100644 sw/tab_h.png create mode 100644 sw/tab_hd.png create mode 100644 sw/tab_s.png create mode 100644 sw/tab_sd.png create mode 100644 sw/tabs.css create mode 100644 sw/unionfloat__conv__t.html create mode 100644 sw/unionsubwords16__t.html create mode 100644 sw/unionsubwords32__t.html create mode 100644 sw/unionsubwords64__t.html create mode 100644 ug/index.html diff --git a/.nojekyll b/.nojekyll new file mode 100644 index 0000000000..e69de29bb2 diff --git a/img/SPI_timing_diagram2.wikimedia.png b/img/SPI_timing_diagram2.wikimedia.png new file mode 100644 index 0000000000000000000000000000000000000000..0e441147e5bc4213ead50a4ccbf1dda1dd80a057 GIT binary patch literal 60978 zcmdqI1y@^L)GZvm6lsycW!HOA_(*fq$vAV+b?r}!Pie~>*o06=zEJ0Z3s^D|_^lc!25GIh2cPsi9ivk@B^wC#`WcP+Kl;6P zBKch58CTtLwFUQ5BomEyVK;ye^Bv-Rc_#CO{{QGx1Yi8*B-#^t*>~Z#!w-o?duyOl z6pCvnV8NSIel9?;U|pF;0yCHCxBm_ahFA(!++IaPHqyAV7Q|{&8Qr|#V`L4EDD%49 zXB)XNLgV)nzfU&OrF7og5$J)8dG(^%i9!PXypSFR&NOKfcdRB;t{a=R>k8tz96Uicm@~v4o88rL@oSUiQffVdM!~wUVcz; zR(FQVRkj(pU|xzdqH!bHHn#o(nf_VJ34WkSn%uU%qB*Kg<&3xdJHxfD_??hb{paUG z3tq5MA5(oTGLzz|Ak5sZJOu^0L0%HQ9V6G)kbZ#|uU3*k5b(Pu7j(N8hGjsAExE8I-sH2U6GN(;>DfF(Z z8@(3XK0FOk-HWUQ&l)-wm563=AP(b{!-I-C#|}&+stV$KMpTSI@S<3p+uXh8fjTV{ zqdnIv?{+*9a40%f=dHtwyw16QWXLdb_CsDL` z4tD&Eei(GrIx3C5%O`hrc`f7u&)ssa-O{Ha%kVkG#}Y*QDxK8O_vqZaO*_?o{(SVL zl_Q=YHF}qY?c@?6Rm_NKdOO{ZFR{hDSMaGgv;?8XfHUlW<33jvd}r&(;IQ=??M20o zDU#0m*PSi1MohpGBYIG%V+i%K$E&hP!BXhs*e^7b(2m3Yio>;Fr&VEsYlh=D%R4tB zPxloVe`?LAglppNPW3)S7Y|g042OV_M^-o^1gU7o*z<%fGd80JDpTHV2F+x}{S!I2 zQ^Qp5h}XuV)8!Irk3I{c)SOeVkash4h4e39{&GA^KmGE9C%G5KE|kKcqk}6=u-kfA zK~J?6tZVL#uD|B?>+X1^8rqI}hN1ep{N`2)t>Qa~b7+VbBx~s;s_oa&n-s|iei{+8 zXK!z8R%JpJeH&AYHnB(xfpWXb9@aF;4#OA58VP?S&1gtegLy`j4UBXqd@oXtV7lnS z7#C@Fud5oS7XrR^GfKEllYf#wwbIOOh9d|AYtWw##}N#3EoOpC<%`z&1z zv^CbaHArauy>zCOQ(H$#m-HAjowIh9dXG*cma7L zje;D>UKnD7)ImgORTz$;-p(ZXFpuacVM7zut>fc9LTZsycqmgP_CqtXucd+Uhp3;` z)(4BRIq}0+Fv31LY(gR<8g|MBgqZw}co~^Puj5R}(e{3_Cs5?AOPQ_sXBqc~8$q zy%z}Yu_xw^D((o$4+3s}KS+G>jjUzo4DauGU{J^p@zrQ8THM9mpN3n|TiV|D)--}9 z*SCDJeK0=9P}996tM=TB`g*d)p#~y%njsERO6Ka2CIY+3BH6xD=`Cp)8HAd-xt-zE zX&C5`LPxWUHJKk4Dc3wi^fs;8KaL=Gl6xi=XMix_E}#B3==6%;jgUL%cAW^RaVP}M zo9Pef;&7Ua+^uLHM0vh0^)1gcKr%zrL3)}w_o0+7**G!2W^)>?wvik$E85@}6P`b! zZ;3DP4fF~ExVQ3%*O=#C!*#!9{~W?%Vq)Uto$d~lUV?k%mH0#Y*u=deXmE&#SC3rz zD;W^!Edt8yQa7eQlH|62{bG+{gn-VXeUF}02?zfE`|JJi-_9a?Z)tc3(2knF8nT^Y`;DmM9Nun82XaG~SMZ z0UClHKif|Ja=*FTK(9aUB5aCGU}tOIScCae-mG6BH1GL(g;E21(Rk?VkWL4|WtOW0 zujNPBaw=D7PD@~RQ;2Pn?j!b<;0mUW|FzYt~Gw~Cz{lqHWaohq^W(i zO_Dt6SzJTu=;Qvy zUuz;sST7fMgfkhl;m*uVu3C)VOQ+5m$8O<;-NsolMbOuYUUbxaLrxc>+W{|oX*}^N z5HI@?bew&6ne;Nlbu#_7VDn8!Bv@li^HH77+-ol!33s3-oU5rYO5=6QohjNRcQW44 z(p$TDQA(mTJj6sVn(j*HZ`B-WL)Mt7=2KoE##_M8TMsaY_2LY52)cF~el;`y=3hTSAGn3q{qp8)EelVw~`2G#|_|Weiy{$PXA7zsC^Ky2$f?QHQSvdvq zViQ>PKKHx+4Xx1+Z>Ols`9z6Ik)Xc98VH#1=iQ}#4Suk?BCgTZ0R~AVi}dQWHqEbd z-^oQq^f%>XM{SFrLr<|d%yBs73Bo_I${jD@X1D+R8sJGaf9S$0%80pbaqMwFU^o2D zg@AQb?7PL4H}ly_L&Z&oP~Y|JfeIye?hQ`PJaKbXjy2u3vZrU4^56cngiNRUlG*Hc zeZu7`b!67oJS;4@bQy!%y==nt3$V3zDU*ZW&CC`K(vn92Rz>e9-2dAs93 zDK-mb0BMq}e?wW*EX6B%NOVQh8DnONm!Gt+!TdvpoY!0A%EZB#k-y7Gf&7p^Tn@pGBUXjl# zy^EW=PIF{@Ew<`1=;#B2Iy08bZs9tLUGsw(1GN(pcgy#%gQRxXnRt(a?%~bhckmnT`KcPq6+I7~mt=@$g_Q z8Bn)l(H&X9tkuZ!`EOUasydxPQi=jlm1rd-6fV;Wej*gu>huN=5DjZ9H-^e?X=8Vo%{$d;87=RitIna(S8c zTFdZi2E^;k{pRkPJE;4~JFHr&C}lPJH{~S$Wyz^(Aib@P8@iHmDr;t*<%BLc_9D8GhkZll=Z*)}O=b%%oaDGrX}aZ^@<6e;Kztez4@R663N>?ioVN|sbh za4%T9f}J5HBhHbnxZ|LW*{|&x@^1aQFDGsc9d%D#aC=@|SWSzeApEIQ)L^tgAa7`= z&LC-E`4H=mQIeXse_ER9v!w$Z!q-5;+wE_<-F_bYaL%E{)wz2xM?#Wcu(Qxq%jkYV zD@jWy1@S4ro6)vDiq|WDi8jet>(z5GBF~P@r-@akYlFM@l?paAq8<5OJuIk7$9C+x%AWA_u~s z>5)!C12<`lorMPGC=Wi|Fi=F5&P$osL@zC$Z8f_}xz*sndq7jou8%}8^=gB+(5u|< z{U^)}P0;RV%d%jvpZUSVgvf`##kF-ECnw>7PLqNB_C6DM7H`po2bcQ#M3_e5hAV)% zJ?pMPbPM3GX|xriFv9S59f?<AVI4=U+myp4?3)s?#M#<=!T*g_=e7kT%OAKNmH=QI+4lot+>y zlJQ@um9l+T?zwHl_(t{Kj>UzI!lL0{1s<2ll&G_!D)-i|H$JuS4W*@muyX^h#GBu3 zBY2UMRz&$vNghdbxW~o^7w4^z*$5A9k1hXwdgNj`7w9pZwf7F=!m}P54iOX``WCS} zcpA8N4>At%j%G8A#`7Bp0zVx|Sb%ZKk@D1kO1!NI`9Re@_5!kup-pTSIScE4s>_M) zp1)|D>my|E@G#zbxaW_o!j`1z!B8Z*y^^xCF8JpZHN_!BhuIV3vV68gG4Wiu$FNG3 zLR*3Lhl9Bfs{DyI8CpdVgVX1aDcHSl?-*mdlX@MZ5q2trY z)vNHf4y6zmlb-qGOOb)E%dS6%{SCB>YoCQ9Ynnwk^#|rS!=FCco~!>}^A=Hi;x4a? z7LV81Q_w~hFzFVkImB{epDgL?zjU#-cqBad-opZ;#P~M0wXQGTy zdI)HQJW#`~EF6F6*c0TSK|Gg&@nQXa{FIM*;UMxn2c@7;Sl8?$mJI+qtm|h2t|MKC zakeb1CrC}B{xnvd(Wq=0Mkq@2E;&HW7Zqx&(e;LN`9v^sNOT-DL?w!x#T-Fx7&lrk zLJFFN6p%IMD55E_Z5CH_29-`Ykg(wm|kQg zAhN^&AZ^5(s<$`=zuZ%lBcp$3^rt%U1AX2`>h>sWRcSiEI|8&%b`cEjW+qySkLtJU zvc`~-AWl(l=0Y7Q=N|-^ zmuio>kL&L|{&Pjo_6_FTCE5Y3TB`Y{4-z_+j#rP{rK$Mc_QT^H6lGR1=eUi$me{>I ze^L6QUj#}!Wr4ioOt@WHVMmIqvMofVr`$Yqa9uWllC~*mm~Ch0O%gBLAbq@;JtZ&R zRWtKG{Z$lVXxXfJM*)cnfS6&w$S0fql9$llY*p$_FI>3)ip0CY6V}%mbiS1=ZP<*8O5hL=M#K^;Rri_|>7w!Pc6kePl^D zPoks75-!o0AHAt^)}CcUGmwOB?R)pvw&IKI9lcH36M8f7>&TN3kaD|i6=jgXF7sbH zIRaEV&x?tEoYH4Uq;-KwcBBq^IIfGCYavG^RdQFNyU{3Z*J7Kb6wS!vL1=BsYwcCN z@Lgx4uSyPWeYco;3Itc}pLZ9O-w|x|dMcf=`Iv+BI|4ppst}G5e(3e zMUv3RzCa{Drt2kw`b+xJG%achn_jnlrOVQSMeLXFn+vS&Rvqzb2&7*b(|b?qh1UX| zC37^Wkbts|AR5dTfKNeSC%Szlc(+XQa=!JB7^xU#4dl|c2efcU)_yIXX}p))TY4|a zDeM=7%Z!Q}zr1U%6+G{{1`pIE{UIPoKP^Lfng$G<`P=8!XK)6^0Wl>;n|5~Mo*}z|gtdEq|I@G$qH;e{VL#xA%(26wx?rf>MBxv!#m#3tDV=9~QnuTS{O zV{j2uQXywJ^)0i#`JFyl;R z-5-6zgiF>Dn!iICrE6E=qlz27^Vj?F-l~t`-G8$aPXm@hUR6TQGAh*Z_pJDNdX}c9 zYPi0Hg`pfKvw_9*9q&<4J^!dU*tq6>I8jARlJpF_uTQVZYY#`~zN?cOIdyP8dqKif zw^^#CHBNpX7-;DDqO|-bJX7D!+`LRB_I8bqTxT$|1a^g$Qj`@LEiLKfcIUk;ha5?3 zP;Lv*Xs>eOU^aVW(Tk6~=Tkqu0wvtz0z7s;X;vie@)@+rIyWo?5^nh9!>4qv3wDPK zd(Sd8sv(n^$aD-lnDDZtwmlJz&gNQ=t{?3``a8lB2=u?6>OcD-3VwH(xDMnoTH+jM8dkMt;BvE93#V`EJdpg_)C zkmgd^C)3e2uy>8Un$GgQ+?GMrm0uQ73!BTmvvok<)(k5xxN5uGGS{xC$J2ma$sfN->4Hck{u2*7TYIhvehN3~2z%;wc-U6jB z2B>#^ZO|sD0yf+awxLVPXbz-HZ2V@vRph1k12a$#&^ygYU%}G*fp+_c{wb3FDJV&l z76+wHug#Y`-ptz%Z%_Ol86~20^|9=~FV)ExR4w^&dQa%!sq&8+XT5(X2|lI0+;HJ1 z(esycJ}~=)x@V8ZeFfez4h}%g*bdg6Jk(ep%?AyM=zhfv8Q1KKuX@;FREaT_I6djh zX^=<1u9_=0lUw`y+|=KFC{qI9K8L_-RY5!k>%j+cG|dW^f|+xIB}J>yFv=U=Opqk% zVhU?`DBapb!zG;X!0;_f9{*qvqKRj$`mbhR)5%S!@X`()7iq-%obPjHmkK&`c5B8d zt&?*cz!-Q-pvon~sI<1=o)ur64?7rag)YHtzh)%fT8u!9*zqQ8Gf>a;TX& z0@&21`PGK*6_09C>4=6=r-Tyf(q2LH-6IdwbcF@c1zkUPTzl-%^~EiH)ubah5}0%XDuTgaZyx-@mFSL@Q(0jyqhwavUGy%`;uAPFd1fn4(BshW^mW5 z>ROKd-}#a!CCAn9zmfKBf{JElk$m3%m>cTQ%u2h5t=X4{4-SpyHk+pjCli%SLx zYDdkoyk0_`y+U>psjoJWOw^9iz*4PVY~m^Byk}y?HICRlNc+Ni52i03zI0XfM}w78 zASGeLdG%&zugB=2x8Ya0ZP($){g`f?vEYS$=u&^X2Bh#&j-Z)3$EhXk7J+e%ne@fQ z<8lA9(nGc!BfDAd5Oj8pP7G=~?1dy>6xAknwrPXfzSVZ*9zRq^$f>35*=Bs5`?yhI ziZ9(>J-#?C{^-a66Mq-lPv$f;wlkmiE+fcInTB)r&q}KpE@Av_WKv;EGeOi?IGyb#iZ-8P?#Taun_JIFzCtB=q zX-l9n=p9>M4aEf8S_y*y=>*$^=@vb|E%wEqrEzFe?3w+1v|$`;aFCz_xHcJi>5(7I z)zAcqlbz6XvLgd7B7w>bWl-KXV_eL}{iB-c<|8@$9_o*ISU;j9N(VF_{?G-_rW47c zTD%?gYva#l7I(e!!RITx_InK|QGn=iWzgP6By@6a1gW%^>R_Dq^#Ml1gl_tqU zTkKpS-EGcB+w*1ZX$KTrbZ^-9YK|gc8O7@rhAJAe>$)++iP=QIgvI9IxgpMFW25}4 zeb=}nE@sUV5Y5Sxt@cf7_JM-a_lnOp)dn^z*xo#WmI~AscX9!g>}I@ZwSZy2Yuot7 zSn|fEA^D44m~1TBgOh#Nfrf%QDDUJbceN1${@HQh7#hkn=Ne~gH&nZO?WBG514a^P zm_q==;f6{bCp*18XDr2m{@nZ^RnoK~nc%amcy+)?;3D*s@&Zo#mOxW#x91FRZxH7^ zN6@*3ebi$@=W! zq!;+CpDOoW$13wBf`%~o*+?pOPkDW8E0}A*M+8jie~6CH<{Z8AlNwmFehn=Uj`$rm z>d9cBCv)@<{v5J5ab6Qo8jxNa!gn34@)oWmol{X|a9Vd8Ra3g$KkhKLfb;$y9vs=3R2!-e%mGm?&RxS+EiHFB``_qBg?b=NTRN05LO@Sm?Bpl(H<@DoVo~`94;= z^_*?(^gP%xePN)pe7qMpH&@DEFqt6!YzeF7o>bDCjh*L58$r$N(_>h9g9Ml#7H%+v z@;5I~*p_UWyc%qw5?$2ent!%-cx}heDmJArK=omsPzXW2VB=CPS0RQ#aSh`pyy`Qz zrs=A1JJuyd%eq$tYr_5aoa2sRS|ggW;eGO)P+C(22a z>%HcX4Oq^eC(@EB!`ZDAk0DnlC+?SM|7D-MlOyc z9#_h6P2=!n*;)JMxt;NBHx-+`G2tdL@;@xc6#9C?VX^@5ui)p=G>xgZNj{7~rJ*&v zFs6efVE*nUL~7FdOxvE0A!Tx&q^>o?Y|Cp_cf*KpkjM3cc;v4jfi#lEl7!^!GATL1$VwHrr$uMyoK`YB zWLZPYvamrdt!A>wUS9ye#aTxbIGhw_g40&gBSGY`lsb|C(_9Ybn9|ZRP+Oh;V?!d% z#K@@QGSixY`uVe{9paS|-7*oqBVm!bQ%bo-K;iKcQPbY9v-3sXd$R*)>!ks^&#VXu z3BnpVOb{*2sM)SiaedF`M#o*#v8I<7Q0|jeI2ec=SuI0ySwx`O8OW^QRJgDTV7eXvN#>%ML$h6t*c>RbKU1c2NmmS1$|UXWL@6DMdtMKS`*!t( zt}e6J0ywKEX%q9`?1q(eS*F6HSyPidNy+;+LLMjoGX zmmA2mz0kSr9?uZK^Gmrz&H6uO3)dgfeN`IbiC*ekMK+CoPosl(jDwfmykc2lQvaq! zCkc_IPaeoixnUgv^1`7I7t3Rux7=9A75_&RKX* z&DHdebt`I4@}+VUM>yF)z0MBMXp`3{e#78RO+_(Nrl;y<_XcQ{7L|SYS3B6$jzZ?O zm3Md5)RazJ`c#6LY1!xHXFC4tH|-yP3s(DYU^+Z~8bZR2Jz=yJ&RRme)^HC>(g*2rq&jC|Lj6Sf`daWA#T^;ochX9#c9v;sb7Fra~`oUUt5v; zk^U3blRFMpG^tU~zP!zIm~59$cTt%87k|sU3$e!PU*A?e#%X@rKfI+6h^L=Kq9h>O zBcDOa1I&hNdk&@i0IC4zAZ3?JYrrW823= z3qZz)oDsQvG@kJG4s3HsDq*49Ykw?^KlCu*`9XvL8ca_J@PV#lzc#v`n_lp8C5L16 zF09U;G7%f!++8j12GdPP)Pw|wn3}@!kMF-N9k%^ia$o`^7e`P~U-}VB(j>D4H`mTc zd48%*dY2{GW%!hr4*4ul+0Um3+C6=UuG&PGv`^JEZv_PCpPo2GlG|h6?D{hSKErvI z)Pl_dj>Wy_2S$?u;`342_596Mbgkj>4gaxAGx95YctG8o2ArlvYwAnKrvB1?191Ph ztnB7aUCLi8YsGJNXwWhLE=I7`;x?5hG7|Iprkb0tR_`ocvYKX3_nhGHg=)jYXO77J zJ{!xx_FyZgC0fU#tQf9EMGq00%0QRlr=M`tE~Oh@E(cs4JbrYV zD=WgxyA&7nsIDwW+1q(|c-R*&o7eUPtc8RI$*b4zUUXxtcn}FC>1wC?s~3CI3D2)k znJ@HbrvH#t^cSfb%&;v=^-s5{-68u?Bw{1e9t^Y|*@p&cZ1U6SCpN5ub(#3k+S)Rc zQvVUx**3E??GkL&!x6Z4WQWFy>6rsg> zlISrwps=96cdVPAiT}rXqp+4cTHD+ddu_SigBLwuMFLLbLtL)UuWL`dxTY7vQ=hhc z@-IQy6L;6sk#tc~4w|Z%rB_GxK)3uIS?J4k$J!l$h!zs72D3^pRcooL54gS&V2KP; zh~qv>vyHj5lSA(!QBbYnul%E^IL#mHpCMG7YRAOE+IIClM5Ao-?c4X#AclY|o4!yC z8)5`M|6syb7J`3PX{f8ibGVIr9#j^W>|Ntvny>I#w*RZLP+iB9+tUT&h?Fv`rl{_fIDe)Vr>|-K;Wg(l4Pck@AULQl>Y2|cSWTNdKXd~P!uE3 zYH{vYqNqq+3Ed7qA-%N!UM&%4SZx8%!;YNf|E!uxFj=1J0);rSfA8o>dZ}KwTGrnW zhsnE60%bv|CbM1`*|2sBU0N!)7r$h15jlwvul2IDhUa~(O|q?#HrIKb2mA#YS#j}F z0hx~YSJo{L!ctBPp50b*MbxnynYqng$=ZTaP*9)2VgK_h#;{wy9)RD~ra#`yj88A{ z16QM)9W=l<##CU|ra(rkYPrQWtb@ob1hzJ`UW1=wtQP#)1Oe8_{s)5r}0{Y{qW za~evelhFd8u|a%P@g$c$`1pN4xjR8bwB@^xE9S`6H?HIjH)z2@3hE-VC{D@b_o`}} zGp=pb1-s6aGqs$O!N(C2&?zME=e0E;Tkh><4hd;6M=eG@#V6p3jEIe|JdCI}tqT=TmY7gs?&MbGdBzdJU}(KWzFrq4fir8d}Wsk!^#D8&p~PvEGCPMuO5 zGXz}x$NTzqabZg!19m@qY^tQ=GqRj{yYzo8eh*!z1vuX4vd8djDTb$w^M4!vwIsZ@ zHnYUeG!$#6nDG`8!x_B}B@j_800xcVi#)nz(E>3VcF%x=Qt9Sc^XgaiaxZg-b1a zh*rh79Mt>hWSmsh+MJxn3Yk)RAHb{!rEb5_Hn6{HFe9MqJPGXt>(%n~yVGA4ct{g8EdlEUi^&rNpn7eV+?0-9ty$xPp&w!biOONe~KL zZGLlSOTl-J1$|2wi=PZ~jj}<#U%obJ6i|nW3kq=!9hMnngWzcaG+~*Z2H|CGuRKBj zizXC(321fx@rD1d{E|~oxQx$-+lc)V?;Io(O1b>%8&Nq{G6*lERM1ZSNyvNi#>h1j zgiN%>bD0P}1O9IotA04&TvXr0Dx%xPzFC%7)>FMVdiHI(O$F-#w2!r__7N<@{{wx1 zZ$_Rg7ZLbI=83y}Gp%1o_sLIb=4cChSz_rkbbyC^w;;8L7)B^9gO+i+^8<|K^Mbb? zihoJa$2Fh{&n;JLBKo8$x#wykzC2qU_84CXA};2K(00p1z6PD&|2;daw0FCk$`m%h5XNsI z$b>wdBk6QF3$+hvt-t_Q=Ho=|pk1}V2ziB@Yd|?N6?FIJS9unUS=KQ%em6+4_M7Yz z`XMjd0y4Y${v!`X(BRoUA%^DJ*{l&*M&B82S$5F*xy+N%I({Ve!)`rcAxi=%y#T}i za842dJ1Cc+H+;uZiurx?>uX>;ilWiNM%BV0ZvnAH;Pmq49wHh_ZsN#%fICXLiLn;C zTu%txZ8nbuO5N}Dr$UzjH`jj{qintb6|$5^=HjPoD2Zn*+rM|MzmWZ`;-lm)N+j=p z7P0MwEFz$q75zr?9do3GRlDd>Tw`YW;R#adPk2aGC<;LiU2M^s0p7J@n~P3?O(qjj zlu5uYbC8MT{AW(q<+s|Qn|q%TYXmdRB(0X4@Hddj`%*^07- zp+^iwP=zjb3(@?O*JvMslOSm`ou$IyUUMPAEJ>%*S!jp!)c-8xx%$^HP0o~Ze6P`* zOh}=snRJ-Mp&JAb2g3)s67&P9;f9&~u>V=Wx|6nCd}lr3y47nmac?C}F|Z##IviGT z`Q><$$()WCpZ&`-T1n`4xR1m=9?rm7@#wZ<@NkXj*J*8oX=TY9p?Tfe+_wcdJ$>qE`sqm* zGqatYfd$S4?Z>Bq?4=h~147U}4S0)(f2G zm)QcG$qvT1l1B#kL@}cBA&->XrK5EQxx@rS(6cp077- z4TTWf#){NmzeXH;VC@6W)&VhR%np*=`$GAa^FP+ z5g4B=+&lEw7nds*7DfAi?qy?n z4a?34o)v_x8ETzAgFlqtDn9Np6y(zZBLycJu09Qpvz#EBhw+`w49LPf4|5D#ffdwC6P4g|fnked)P*?@tHx|U97 zzT1?EZz@p?8B_V&th`So_AP zo+up5yT5=L`qCVWIQU&zdE%A3sQ;T8$$t*`b2X9QaFBic!N2C43^jxI|6954|H9O5 zXDFJBA=Kbb{m)n%K;Cj@#P)ls586j74J|W31n;N3i!1j?LRnuCUXvx|8s-D+TM$4||5v)V zJ8h`_V{h!j}Dn`+_VyOPxNefU}4?f>0Rwja-hHRy*iww3@;Gn=5~v3IGC82 z5Ro?ycz1Y?lbwxryhG<|2KW9$G`d)?rKLr(;U(G?7#Qe)-P;$Au})4pp^HQcqhny; zwK@;4xCw&`W0pMDq#k@p5%)q5@PLWFs;>caY9=Noe!!y;P}eI;1YFC@AbQ`f}}k0z%!w0^pb_5-pI4!m}jhf{UmgN7L=(+zsUaE8MAdO^xu$kky0 zKo*bW)$m@vAlJje#N4l*ae^(@0lRCesad^}7PHERc2}Q-=YN--w)ghxl5Y@a!auJ- zl&k!lu!4J*K_X;T`+sH-j`d06S#a9i%{Z}G)m7~dCWVpOu|Ek8@zCYbZ~W5k(FQU_ zJb(AbQfb9tYMGd*s;Lno{LCe}(cUX6DwYrs5WrsJp2Ox){Hg`{H3>f|O~BYVIN*iD zm9B7Sqk5+kv(pEu(&6?abtjYRkkY6qo~|$g23FS6o`XhX&U&YrPhBgyo`K?;nwr|W zy2P5A&!3TykUXQKTbjveR8msXZ*ZYemb_NDxVbVU(F>H3k=E9J;qC4HB`N8qr@Pzh zQm}G%)-ajfptD6NdjY)H-d40P{T%1%S>NT+Qch!|uxt8%Y;4iHyABqXmKgaKmS|7d zI4M43NxihQh-qq8WD1@y-C%*@#1(r_l=DWOWm=V8$R93(KE5%*?NNv@l@$k+R)zmIav$Di| zJ+?>aJ3Bkk^8+r>bGuiL&#KDLfm4-TLW4VpK}~m3yUj_p*-$#y627FLyN5`T7wrWgr>iYn z9f}(pQ#(6loCK-dQMYIswZ2@>)oi6deE5)qKuA~3&cPhXo0^*bkSY+0eeM#g-ajA* z1x+JDG0IwRq(rmSoVSLu+R}?gYi)-^O|jgG(~AI6>`WybE?Sl@E>A4&UOF98Jl`-L z`Z)E;vdzg&jPMQSJ~aE6Dzk7A)vs|><3~go_9GzDC7tk`#7Z(glplN-xb@mu(3;gv zjP-3a8f!=_Vh$=211ERR8j!v6?#f$q58=WNhg7wk{%uL)v!#66yW+;}xv2u2c{hy# zDo|HiTG~WjKCC@ny(}>Eno0y(SxE?iKqSC3>TO#~SIoR^_aN2rR6bk6>chf9j>fhB zz&rn5nG0S;KR!G2B-?O_Lf1cOp8^WEAoA@aW2n6D1_u)C#T}*iu)&|9*GW-mbbPx|QjfD&%Tvev(ZCu>EU)Oan?(*WhPEVz4PQ$U-*k8l1pvh8PVJ3mO(X5^uX+jTVe`+!_0+lFlDV z`UoCR_UZq;KQJTf=EeX$EK1l9E^kt=2l)teEn=EfR984{gr$eR|oK4WYWH^l7K_!Sg#MVox zroV4dF5)Q)^H-3ureO$&yX7+SQ+b&a^(>ZLzOI8k&^$+5#c~~Q{gn`}Zfs&2`g?|RTUFT z80bA3wyEFB*N#CN&;Rx&D=Y!*yk=susGVs%?!@DW_S{95_!M__0F1siwd8M+txQX3 z*3}Xu2amHcWO`cv)923={C3X(VuF`5rTV#R+3M|SKUbQt`+q=GV0!f`#I!ZQeJSY5 z{rdRhy8{!S8S6IC-ezF;%7R#`s5h%m^MZyEZHAC5ld$kh)$!>D*PJ}T%JzqVq>;cI z$>!Qg9CHl$5iP zcSNIQdR+G?RAhAYTHDG~#-_z)0IGVX)y)8%b! zilz<-DEXh5nVD@3sh0h@J`DoB!_DpASe>!Wu||ZTVPav8{!}LCY+5I-sfno|JwG}5 zxIL05fK$Kq>%miC0Ss(Y*sSP6UDddcJ5#i;+0k1LT5bzkheabgZS}?GKGa>4G&<|Y z+wLGUB5fi%gfjx%N3(|6=DKp$hfV}{HN&_ckqs0ANugh1Kzi;9_u<$L#RZ!(!B6IQ z+PGf8-n% zNm(tnXLs&+Q64(`9kpJ)lnCH&SPB*clFvYvSPJ0kISC2G*@35j1f%e1F-dpM6}?=xcJ zRc|r6z+*I0QqtJNX4K_eNqM=|vb3ev{O!e_UPf9PMQTd*m&1i-s$F~V%2#r~`;$KZ zou4VGg3gpUgw)F&ICNICb@l*_3*?|J?~D`^ABr-)Dx0oO5xaCI+}vkmXDT&<@O%;^ z_ZAhDe%~s?yIs)YTDz}w!`&4)!q&c ztdf$FFE(5{TpFl$vC#B?nZGT_>5Hcuo~$ssxn7GWU<@fKDVgSo*jtU}aydT(Hhmh% zZo}ed`0z?_R*cu-eA@Cijj7NB5kc-rvGEZCp?Sp3R*t%oQdG&m!4ihz7)9BE`TfhePC9fl)O9FGFA&;q1|i? zx)Z!@%FPXliNQAo9|&~052o^TN%8R|7T`puy068C&FWWMU==9DZyq)uVZUNwiR_~V z$3%0rr5e@f=>Bglz^6~>?-Vz_lACTn9(NIWnjg9R$G~uMCB%PmUB~bav8v7DX$FR{ z&Q6O#^XA>9yT(TpA)!uMj+L9NthczohZ)S=MzGg}nF zbl-pJMc)$=EHDBnP#z*W0nAJQUv0hq`+HcxTeU(sJpC7U6?q)(c$qKV!e3xYkU1?a zE%0U|#n@|9E-WA)^dXGM7fwwG_d2+Z#zasJOFfD=1H+C@TiJZ`^6vnEZ^PrNs<=p) zRJiBWfSUeaOnd$M%g3&;lg$iQO4`3TjRBK7eejH!%P)}Ionn$ zo&IHGVLykX5AZZB`DAcGb&$G)%7F*4sV4*k8?%m80`t8lz6;hE0x^#KAKL&gny#}a z+1c6IhO4=|^8jv3`x%F*$k(;13Tk-s&qqls5?k>J->Em2x7 z!@dGLh={A8MtnHkQpks`4FdzkL!7UVSHi%LYF`yen0^T`_l=q6xVGJd{d-ikKg{|W zlQ4g45SU761UwpAQ6V?w{Vym!oaH>eblICVsNI+1GEn)DFg2kNXHa8>J1lWUO+i5s z7Pgk|u_WO;w-j{8u?qKPeubDu?+23I2>?J|AbLAEIs)TVM~#46{}~$E>>)SfM{ZU$ z%;!tEJ)*vR{pxSR*~h@e6@Rfem6)8|3#3_jYimX#iSuWGi#W~Hd|fs_dh9Mz&A?6% zTd=W2LN&uy9iRXL8WsbhsazU6G{k9nczC9R0^QQ}Q$5yVg+7>?4grRa?%(JH$}yjP z{mtQ=__Q9og*EUm0ikfuVTlG{29X{(u@*-aTSam?!1g1lfgwb8E~m+7_Rb8Uwg zh2p^F#ald`-Dm#P-e&EpC<~G@Obk^HXME8P)Ed=%{p#Z;Y4JF&w6n7_&8~oRin!Sm zZ^B~6gP^Mg-+^?2XmYc_QRF95An^>AHcnQWD0_PgWC%L1K0X{hHm*jo;S)7sheNr1 zFKPmgfFjlyP#+FtOJrnAfGHgcShDFw6tcS9s1lh}EyfBJ`+~E9Sf^H;sAm?G#GDg2 zrlDSL`#mPjR5qnw&fNS}4iN9F*IDW5LmyCgXB#PIl!xwT=V)M~swx(`;A{GDB09NVdpXzr>LXGJ{K>uc)puV4Krr9dqp~H6+%|Y;SG~3 zR3hd4)(w;2Zew5esUZzew2Nwp`5w-XX`$x-Kg!-Rs>&~V7u__{igbg7(%m5lC~eVf zy1Toiq(KCv8&tY;(MGzj&VPnkFv}CzH80-%qP}fRIgFkORu$A z5E{3JftIgr-$l@LK5H4QX6C^HHPF#ULc=lY{Q7j>Z8h@o?_M{1wZU`VH?WH|h*s?e zsgTcjzT$HN0(-F8S65d9qN8#77jlQ<8(a^D&Zcy2e=ev&?+WnsmYQh+GEVk%3y&n@ zj{-x$`Tm0C)+GQqODGlurK6vR%FD}7K~H% z4=jt1^mkJMuXS2>0_}4B7I0XgZJX*PEN;uN(XhPWnIB z>Sk?>o=KjOCLiTB7T>piW|*@Wdhz$c_{{#|HQB*~mYUk;Y?FH>juDugxQawGI5%w; z!hls}Foo}fhPl_rB(P}`g!k(LqQ$Oz?VgRR-1Awk2&FR$ItWCZeJ}3sEdwcF910OL zrYiw>QRQ@#J2x4hm4M3;%Xf`3Jp^UZvrpWtJbNKjzJEt~$Z^n^)k=8&%6wEUQuha! zccH+E_LUvPXv(OL^pbltZV9++d z_u~$H0mk}kti!+8Zdla@E~JsJp6Cc{lB^DwU#{I1FUp*PLG{6}?Zeg(+) zDL;+M|Hb5CSC?he_vzCdHr<@h{Y?JS6U`r(?LoiPR%at&`{{V9tkID6cht&pK9105 z;3xnUt{P!!a&q$8)X0d~rVvbQ>e(t#sFH@pOnF8m11BZ83b`dU2|v>B?1a*KJdj{# zH%kxckB!hY-8~rWQ_67L)$YhaDzEIioq--_fQ63$5-GEq;YwiD>K4C0!rgCxvw``Q znA0F|YA^o#cNLf1zk~#(HFUy0XO8l2J1_W}+%~#Fd^`gzM9&3=){=I_jKi%GzoWp% z&bzVTx@0_4Va%dg^%afM&F^vZgWKG3D47~b#&>y%7L++-HIT&JGa_(!cd?|bqeC&J z<4QrsZv%3o1lpc^)nI|A$g|bwUZEzJ>D?n*xd=BS_~&o@{-T*TpCgMaZ{g%~I@-ev z$%^H?Jzb3+6m5FPZ8EUDSG%;a^l;CwRco`pnc=%J)pE}p8yg#p8R!ePV>RR<19pNF z{acRg@<8bwqdy*cR`5t3{x1yL&j?RdB~*|1*N$h6U8fS`C;7uS-g#X7PRpJJS!UME0pOcd)%U_1lpf zoZ&J{&E7L*`bZhR_x1aP=1-nHF*3>}W1g~=oH_hmq**ODb;a}QRhX{tUA%lE+h~oo z*7f_1|9PIwYuQZ~Eh72$ExP4Y$%KxK>CsA8a^F<6 zOj=$W%wpn|j>EkL6OzjNXI>El+1?cD(LA?*Xt1kt-X1`0GoMs!Kwm4c>j|^-870`c z8l}{HGIIZ6mpgj?bnGWHj*HQ`wPo)6B)?szF~p?aa!Qg_b?pEy@niTy%90_yq?cC{ z2Qk*1KW6KYaeu-#w4+G3MNIOmmu#L~yvUd%D7-EKqiA{ z+h-~zP}uASHthcHz_-%(!Dno2?5(2W`f^*qRGQ2nXg*jIf8ODLd{Hnc40WuV0k~qzy|HvgMn-mfv%D_*^L^aI zA~|zqNn$#b4y3N`KQvkA;!;xwsC;j;lb{o}}Qw^*=Q&Wk) z0G5%9d0lpIo`FX6xIT3}G>TOLG#!k$m>^=k>DO+@CJUP*-YJdbf)LPm(Hn)=DD~oy zHTSMBdGy*4i_>D)w*OqNQB=!}7dv$_`wI}Tns*C&F3IJO1*IY7a;eoli zxzDdPYsm^HCn&oaJpurDuc)l7hc~AqhXk!s z5qFjw_TWiQ%Xv^!;M8J$MwK~IGs#_b!Qt=u^Ah79=qX6l8pL7Q5-Kn|G&?^1%pqhKfk z0z!Mwd)1BEGkC)(V(-uppK3k4#3<9Cuvu!RLJ##~(X({Himx$G4Nx3y7S$F$K0fWk zQ));vgi4UtuV33t!2q|-86W;L0SB2E&go}-(DI7XbC=W0+k3$y8gKx~T?U+hGMPrY zy~Bq5GB+z6EtLSCso0Ec(%}9&o^5$l4zPLUSTpY-oRU2C23;90KTuy0~C;*Sbi?98H~Gr<#MoY^6;fUQn;dP2~bJ&L9lTU zz_(?U9&|+u?|K%1m2vzkJ)uj5NiK}-Ep8G)J+kNTH`P~`@5AS7+&%Dm)!#B#jMQwx zrPxF!OBR-11qc4^8|u^FKWG^qDpP0Mjz8P@-7$<392`&JB7ETV>rCIpA}sy;I)g-g z`e5?s68xv{MTHqdlHgMZRkK!8vE{iQr=(AbNeO9pT^6^WgQt7^wt;C*l@wPOe=Oi_ zZHgqrWh}^}-jICufDCwVm;ds$(vFAz6}wVF`dak-**DHIokk@{%kHB0akS$m z8zhCvqwAmYsn^j$nI{$56;JEzHomVmzoo-#``)1UPks_@!BdVE3X~Qgd=z4-Whb4X z$kYk*H3?n$)(-`D9uJ0N#C~<_OZPQf06dpSl{)k;O`mNFx!UX zy5vV442Md!cw;>=aW@sq&f#KGo;!V;S1Sa1FTqT0X%>R>ejO31Fr(2U9)(Nv7Cm#5 z-&2r*&z)AU$?X{Zfy8b2MdQN$K1wm}2%)>zsmsqH842B4CmPUEj?}UdK}o`@U`;_t zioc2e_DSxaPRVfcS%6;%!Y-fI%*bYXV~Luog4HoWYSLPB_lUjXpPhYlNAJlZW6AD( zgOd}?m*Q?^`_2cU<$Y>FIexA+eJcBV8|zL}ADj3rCz%B*#<5*)q}qnX3fX_+eGP>j zBYh1);CYiVr5U`fL<8e<+^{s$jQHLaK+_Qdm%l+aFo;t_6onvb4o_(X-{-2S{vpz> zs>b{`kQ@C{*y|GBa5n31%p$4q{i5?`RTJ3Y)KrfLl0HW!yAVpWPOS&y`byS9%hgc* zFDLC?@9PrQsm7TxmuHJKdSZy8O#5-DO4tRSy1DkRzmlm;fcVL*)HU|Q5cvhop-cn&^Aw*;TAz)UxZn+q-PvfBMvuZhoA_h~`p^_tS(B3o>eka*^ zwfTeWx@DsxL)bZuuzoi&G-qgvA`D^1!I~fj-3Yv`FRRfydXw3t1``ImUVX&P|@A=oi81EhL*6^vHz-c!2ut~XP0;9WKu{eAg8 zto7M)x=6H|b3}TtSS^yDaA9BJ|Nak0ALSzuKee$m_y)FYX zAVsJeB}w}C-`n9G+U3_yRc}B1ca7{fS6Goakk!Mj2#{g|wT142ZvhU~<2Xbev*RJ8 zy&*k(jWCRj(ENtYv_{GUp~YU=x%4P^^<2n7!x=I{`V;r|y`<23Pxuw7*<}RD8L4WajD;#;2Ed8v?xRkhqM>|5Fb3C>ljnMq zg;O0L^N|;Pr*zbdRGa6^{#j>6Lt!PlLYw#>vYtVfBB|`DjxX2Qu>H%@;}}C+tmldS zw&9a^nC=5h1+t~#jQ5A7#Ppvvg#L9+N*GcYSRj2Sg>=l z^u9r=k5DJSjYZYY5s7ZZZ{!~|-v5BRR<~kEwCmbw7qF1rj6#Lx47f4aiPBD{Wa-@lD3Dr{pTWj6l0he zhsZ&m0=A3`y}Vut%MKH9AxLl8se22@U24@!=OU>b`kFb?SyryH&A#4}Gtx=ngKw=< zU!n#$H>(+vZGDaHU+6S%VQykZBbl%1OQry_coA5Z`0m<}9YPefduBaVq7w>#B-#;w ztf+YvAdpAjrOj4bR+UH5J{1k93uR~I>Q^5GK4FiW@i!Ar1?1GcjF7jHwCmC_q!E$t*j$? zxpv*jVxN0cae9rjzN~x*Z;v>|P?aK`L5f}6M_)V0!m^{{BD?>9z?F}%N>M>b&0h7z ze<$j$5#gwJEr-7MFl6pER~g#YO5M_WN#nj8yVm)ToLlLqU(W#ctHJESAw`I?euyk9 z<4ESS_K@9jzQ-Bw*W*yBcUVvTyC#p|(wOFLnW)c|RJT+QP00r{CeTX@{a>4^0tzGnE#hCVg)i?{W z>xb2KD9eUG^|IboodaA;ot8Fs81=ADyG~6hkpO&h6hG-R=GYc~)LyC123BJl2EiA& zgQ3+^N7v_NOS);SZ%Z|KMsocGm4$6g;a-tSy>4_dX#ObkW&mO$NMcG&1wtjBran)P1fs+16#!Dawj&%6~6cN zas)e5Q~1eSI_W;w=GfFOGa@**HO~NhybtD(Z>r%>>DICgmm1bP?*yp)Y!>7e(MD@+ zb$Jx=dt9vadcM`8)9j-M2y$^fzQl5j%CqV+gHW$_&U~?{-lpI?pz$I}dE50kcx1X^ z7OirnFL$Lycp-&!Fmh^TJ82Sv+Ap%&H5ZAka9qck^vw!bh_>xk$MaH#W%Ol5_6Yqo zWu3&mFA2UUp3OG?mG{X4*p0Ud?g9Qj60gcs3T~Nttoh332E8L&Tgc~H8m%^E36CL; z6zIrM*OTg0p6uo6xZ8+_>R#hhQ-lma>+Fa{b@ud(m+FdJOqE2o>1C>wLOrDKLj94@ zEFj{($9#f>;rnrefbWuyrW6Iv0%{J97@0`YqoW=w!&7pZ1Tz^-1_xyNk~(e-jMA3^@`N~2#-7WEJ5lNO_09R-(aFg;Ju@q7B$yXJ zRGKJ)sp8j%JPhz*qx8(Qv|s%EAnnc$N^#08H)c4kQrd+3k(SXmL4h`%D+_aCIJbM zT2%GirC8f<#w!0^90R3JY_-`aA^^!~Sgs;Gti#V;qw8ytl`H+28?7>4rytrdO2snL zFot6!X@zSaq}KlQJB54^8Qr{78$e>9v82U86l0cLd_XvB%A9gBS~iEK%9sg_VSXk~ zJefK04J!4!i0K{|k2xYyLPbRAHKG)qF{0+4dhK(dSU2OT_T0MnY)vtLYiU>7sAdMU zHK)~a{?;d~17Yn$5I#QFyS!%=fghoKw7%lrz*pt~Dq#U*0D<4>sguQI(Yp*W?;l*o zVNlL1E~8#Nz&Evx?zJFn@l|aMrO6kn76XzLdA&c;6!29|r(^Qk^$tP4cZD1`x05@@ z9K?^3?=Q7dN^p&Kms&FHSG(wV*wPmJYQYldHS-63HpdcrQad&-|18yRV zZnJi6>hiLlW zjvJ@j;{pk~3oBq!$kUyIZJ*Nd;H}3u z%W9ADo6TgHCrMH$oP0ILSbwE%#$vHMBaRgV&h%may*lCHL;ZlKV8&))Op0P7jQHRN zmwgL<%W`aB=YH=XHoO@!!P)X6VGanzTK&A@%r4l{aan717u3c9h|q084VBIPg>BZ z>2v^9$qXDSbj`QN@(5oYH;1+pCaQ0c1bcVo?C)>gb+}B1QeOh5#2Fq#l_T>Y+HQxCS1biO@BIGXN3#+%7I;D4>2nZw0s^~4s~dPpY*P!w?k^2> zxIh=81FO?@+z`-m_GcDqh>sk7kke&U(5M(3Fa$8)FED z@JIMPI5*qPH!uY7yqUBSLAE-RI5%FirNh_QJeJQb*nh#LzxvsTDCO2J_|pqSk}fY; z2ix3!>Dl}MyccU5`ka!XjN%af_t(chv`~U}(Y;y3FXzyxLEzM&6;M}3p?o*TXMLCt z2_U0mnTAm0Yt2Tpzs^YKm?smG zkZfziUcUPNv#v+Gbane#nI*h>u3CX9W-AuiZoWf;~pDX!w7Xc?fCN(v6=2|5Y zMjOe^^XF?YF3tW#cGIilbr!7}h1v+xi9++mvHsy<-0-e1cwfZ4uMdGRNd)_d;8b@3 zU421Kt>OzE2FP$I_g&oA$jFIm@=M z>_Dv(yFHXz;6m`ayR{+a+jrQV=5*Pcl}=>SQLi$43V7uR3gLt(3gHSsa6b}?3EP{S zA^GM%6c{8WMcAWa(4Qn%dgZ}z)YwkU)#VLPFNRR<2rF?Ery;v0( zX*wQvK!X`)(%Lqgz_f7Jn*o!`lWDh_81sE{M_5z=W$TN?y`8nChpCTIj+L(cej@KC zWhbX^o*eX?6NKoq%>_}|6UD*%NEG@ek)68pQ5+m^U;6~ES1vs~Q#E4Ad`cp3A#uC5~roQ?3%E&4zviT|acm$_{3$ z;bB8ljjX$Kj3;GLl;Zyg+?iF2^Z-2fy8IVHNnf-(TdC$IUkW_4z$%+0>d6OW=UiW3 zZ%$pv65Hh>#@4x*PLo?Kz!_YYlPtil;tY>XOsX__;&-yizLhYVC50vvMg9)-{B2OF zsk~30g8N_qEMU2L+l}2il`;wPii+=OxGR5_?c9Rv1<1=vARX-2Z&Eh6?EL|Vujkjt z0`&$STibw@*dIT>;(bX?B?oXgPd=C#EP7S|bYSnfq}g2>DN-iF@V;2j9fyBsWCS*xe_#j|Ly{JZ}#x# zSjwD)UP8_X_>cN4`80W(xy1Ib5+11-zuWkOS9-z-x;4NlztL2$QIo!$z9pE<9^xhZ z7geOchGIe|TA@s9KUO z$H2414e)*R=`4&HdXfMg^1B7y8u*E~78?1Fj*c1 z^^TivYq9eqnlx*}1%N*nxxZW;NYhG{S|4P&^ohmhFgD6{1bc#%hl%M+yC_($Jp~y) zavwg7VcVt)djYx`qY|1}C+saF&EB51#!Y9FT394pfke<=*4NsF zs;t@B+3HPhoWMEZM&r3TTw^^~)^D)Y+0``)^SsD*eH9o^#IDJ%(_kc7(zH&r`EQ@| zB4Ig_xRsY}uA_R^YoeI z?e>>G_a$@fhJFB?tRepE?LeSmbTjhKD3a1|#;Za9Me;9FGcW}A_V$upZ}ZMKEW%OiM4HKpnVTa^sO{P71)W!_AAWqPQ)g-=BUVO29nMoF;OF z9oEoil9Dv5Wn2w;k~GQ%Jgx;^e!NE3<&J8>thYXG>fV}#9Nl# zPwDb1Kl`sWfgKO~kmER4V~rXY%?<>jZhxekdY^^6ukpb5#p!u&Wis%i4SeXM(L`C~ z2stY&3pg6<%@D52JkBf%O*m8z7Hxn)Xm@*g)c#B^{DqhpWk8#rtZLYZAB}r{o#y~7 zN8^nRNf^?+HdPr1Amu(mb4IIgyE$=B$C!IG!suGKIR5p<6-h88Jg-HaeNL2=t}D0Q zflD&X7-O^X<--u!H?3v{|CV(BbSn4$R)Hsyq;;0D@`oi`tVkb8NK7?|+j<9ZEH%|0~yZuxz-&D@aWIFJ3&inLCJ%kDId zkjpL;a7jzMxz!PK==lkFUsu^^_?bR_%V|Ffi0YX~o2#iBQ6DX`uV!7Jrb6 zxVK1y0J9dI$V&t|Nl8iMW69>;pm2^xL$*lasu;gTt#?r0;bSJ<9sv|Wb_ z&p^Cp*6Xt|gd4}^ja$BL{a9JUCKBa4*(@5x=*^xS5*$8mdHotyPk)OSf=0)VBlf07 z!7=iHgLYNIRp7juMt*qB7_czDm^?#tIhEm9jjO!2XeLJ4e+r^*GHz~eOt(ct7v%tC z5iPTF_XOnV&)LkRN41iUE+=>58DLLc7-Z8Um#4@JZ?1>=Qz^&5bR zSj>_yFD4yVnzPu^C9Gzvet{Q(S*-?PWrAv@)6Z25-|x}T`>v2a7?+9-a@4t2+WFvJ zs{t`MUhAVTPPhaY4~4oxL|FCK(=i)(77R|eM#10J>+G^1Z~B|1b^+(w-ZQ0KWi|7m z7GXMYH|pku6z=W_?aQ4KS=nvJf){KGT8 zHQPJso-$fXq}kYvVs8BTFQ-BqYA-R~V3@G9|rxc~HXIr277yP~23K+}euy}W{gxVX3+>4gavG>)mpTCyi0 zF5F5pcvV)}9rT*#+!b*r*0r+>` zHm;qk_ql5jtg;w{OT4W_yK&UJ!$|ks7ySLXP<8FTBvruvOK0aBKo%*2W)1;uq!k=A z1R7GU5dyim&-|J$!;3ki<0I<{SEd%{)O&H;eBwc`u(Wtda({feNl+#$=09wG~a03{JWS&^-@w6pt zfF7CDhG1{=&bb7F)t1N&Gs>793@^;-qxDzr<{-I`95GS(i zHmmK*9x1e~mr!e1rRf_-V=QBK)BY&O@;Ad9f$Nlcc>D=z#THNR5FI|noNF8$ChTv; zzKK&xCr%af4z0AIzNPkOAj@0r=}|ZAkqqI}KhkJRG+KGyuWfw0v+eHgs@8`oR8zSU z5!?fuvt#YQU(m9Lr3UL_jFG`8-TefV{{5Al#Mu23@exZBYDXd2%{V8aNtaMo41p6FL_ z1Fwri^N2sX7{*}z$bh~)&=t;yK$zxXzVIM+ZxGU!qXqEk;vRXtS*1}Ug@{SDX8#kK zTSQ6>T%Q&oS0S4e6?C+)4wzouR{58{iYy?D2n26iiUB- zrWTD1JGkh#zW!?nQHf4}Uxhjkcv&BK**Z0dKL)B6CmoJu?^z>kz_>1_V+Sp7own9Z zYv=mSlTCh+lkOODkt(W5sjXhQdI=Db`4J-;eKk72 z)XKc@vpWdeHK~c!dboI)0uHY># z{c`iVNJAXmjkwjOG9KG|UvPnl2Gm3~I|iLAQmG!^m!1xqKMxV?I#;>maF+djyU{+w@x(s zITj{LN(WP~NRtWajF0qs5C64nO)T*#5_Jmbed)ie=|x>ad5`ag zvlX^`rHxvLNRH@(XabQwi(*}k86}&M5=O4W(MFC!B=ehSy%)I=T$g~UfBZ619e)wxc>q9~n}C5{#%0vbE2;YxED^@rusV9zJHNp{@O9d}pG3X3wkA-O+G46$;x`4L9LP zLJ(+nG!&$k3;9tYk(4Lws%k??@}xD9jE~1<%js9l9mWer?hd_kT*&f3`m|n}2MS`= zDiM1W>1?woWGS105l{!j+Za7 zwjeLIM&T<-IS2%WQ>fId78M!=P?OAOF^;G0D3vpM%PVJaF<{SdDRps0vAJ^5)Vs;b zf%NwM`RlY}{D!inN-8w;{$5Nh*U0$a2poulQYOKU9Tt5i(`6Nde$*5WspKf%fH2;> zTF`y$$xqk~7NqfGYWF-SNSTQnGk#Kb?!Sb-0MkDzydO{?K=&-*;)-qjWfrKqt^YRJBlvrMf@SfST3)gwJ+s=?cmJSx}4kK!}@t374^I1g*kJi(+|Q)UKZ zx0yc^Zf16sJ-Qi01Vw>aPYEqEs(-%y2Wo_!6}yB7_Jz=XirTO%-%&tzArM)wZu@X_-d@@9rSpfo@nW7FS@U9I5*``#MLgu^>| zc`5YQK#7}Qya2;w)AdfFm5xAvfoeaFl`a=i%AkqIW}2(nNaoMdQxh;ZOUcNfK8ib% zK^P#~R&Ki_2Hxn+U^1`scC~Sv!qU&iInU3ffb0QI&|mWG;a%;(Dmrs_l1-YH?vX?{ zHyM`{OL=(F@{o3pW2<2==(L3gHZv# z@PRFjac_1)E&vrf+jgnhrccm*1(}FVJJX;m?CLbEf&_RZfG~~pjGUaY+@?b+AgfN+0?03%N5KM2+6$AGAW~Js3<6k}oH`;E zr4HeQtZpF2H2=+UdyF2?i82xrt&ziM%}xAfchuKLe;Fb!ET+YG=2B>ZKnBnJ~A?L9lb4J(;iL5 z1j_r17KJlKtf2EeMv1{Uah8vY127LzDXOS$$m-}Kp*$<7Sxe!Gd5+>ilCMh=tq2c8 z3>)7eIBp81yTTm$hmiz&*RPI(nrf&VwpAhK5_=-UuCB4;MO(GUjPqv@k3S^KT0Q6O za`CV7!iDkT`iw9!iuJ<53ZEdA!36AfY*LcOn8g$DKnwmE1`bXQ@u1k`<4jN|PlfRH zV}Vk9l_u@0SAVk2lih6LD5KlkYRJ@lR?{kD7NIy4LemgVmn)m2=|Fa5>Si$beN&Ye zxmt@u#On})QbTWj3L$S46coUuz@V7?0y27c#oyJ!M~@yi!vgfL_uxIiio%fK@yyKd zZjb73H{uHid5Fh9?vMgsc9mr^gC7+|PcQlMuC)+fV~`x;`|mO)!ZsNLoAr8`R54*q z9?a-;hwR{-0JgcS*r3x}9ocRgSo)^BDY*h)StFjHD+WBKJjx`~5y+?m^hL_ee@k^U zstOaa6N<3dGKAViFXjU>GIZY+N&~u}EA6LRqstyv4SD!cduT`MA}kUxYaaoI1^P2U z&dEV|yE>KMrO13~K>U}_8Y8T?&ihe`g_K$Mk+1k_`sJI0_;p_H#ACP?1-N`{r<>R0 zAq$Hvw#Nh9!w@^YJ2{uTCOk`}A&M+D5ZC7<#yZD8N~t!Sn=%~i%aRT!lq_v>SpQ=V zMq`Qbsu~H|HMtQ~+ikcaaH26qdId!kl11S-f z$2=h`DTOP@9OdbiuBCNqQe)LeXqR|i>^ESyUS7I^%_R$nBJiQ7I}`nua$=_=QmBE; z7xfu2N$J0D)@~=%bU{uP7bL^cv9NOA=g4>g)p2_7TGbH{Ho(DPzSJyAz^vLiJRA*V z5iXMf;u7dYV&ZWpzA`aFjgNQ$fUZpr4vV$6RQ~?{;8Z%GH6OD)CUhZFlSEC~f1scVpfX@9MDB3y|z)MRk?83rpIoSy; z-=N%ZfKSw^00ezNpHW4|EG&{vYw~@Gwjj`LO5~M%G7|I6$p!3Mt=)k^o}TGv#Cm(E z)UHl7azL9zfl}Ihf?@64V}2VX?HIugJUp}mLRbeNd=?Vcb3q}R`IR_SX*e?lsWKaF z&j}0%Of8Qhvoi2oC@8Njy!!7Jq{^CX1k-Ta=(zu}zma~*mFoXqb$QC5dEcVP8p7q? z-bd;XIcVIAhx;V*sxrJ{Y1W@7h5M@^6tw9LOwdsgbMdN08E2 zVjCv*2Q)wfOaMs)93|gD^1c!fMU?JqPoW;$^ou?>d(S3-3*`_*XCLWyumM}a4<0}A zm+q&dvf+z@R3Kwat-KFc1MzkdKFG%pAGW4SGkT!qfTdi4!x@zh7X0a%$LU~z7?}b4 zOEJgwpee*}<=^I}teKhF(E4~!uR^^Xh^0C8m8-LWRU8BuI1Zp!K7JNBJ;ZEML7C@k zuF0q3RIq*Oz_0Y`G&r^C**$y`w_R)!_f{>|s?7(gG!Li^iO}M?s+vtB(^xx>bRZLd ztg+IlHGZs(k0f#grD!tHCz>DbJ%J`E3w8ncKxxe0kPs@LX<78PqrH~*Fb`)iLoZ<3 z4M;gTRoQ7%yGXGiY@R_HJO@5AJ*QkIMM57t#BY^L6vU>87G$UIU=lz*Y>DbouFsOP zCUU`A>2cnp zqI^H|+dP?rG;#%)E-1IhfFp$ytkEOD_F_l?ua;76Q9f(7t&!ZpQj2b41fV9vfD2(i%TFE?(NgSGxd0%Rf769+&?5~y^Q25~;8o(I96Kk>}PGC8AH z&=W_+9l;F`igkof-&K7iJrEn?wD5D>r|N0k)3pMN2+p2z;S*Co zOS%$%;*NLqBy!or6pSlGf+!!ZT-cdbPdv&feT6@H~Zu3C@;Sj z6|sOb6T;KgA%n@DYQT*KXi+rv2B()m50Dw>(Q(*sX^F#=RH=oE>MW8lf?N>;$ZG;y z$9BTMKYl*Z#0Y>vbMnl9aB*}0QZJ_khAbZNBT3+*?Lhyax$V!GdO;#&a^_~nlmG+K z3j$xmj{@S?ubE))id=8yqypVzD-Ba`0F!q`ks&drMvR)LS|rydU0b7&XPV zi{C9tS-~t>22kM6eQw8nj7c2&hzpIb zJv}`kz&Zzx9Z_#|VP%NB|KsA*%=NTTX`!LPxb6d}1Dl_x*`*a&_kpDV*sJem2I#guA(_c?~syDKZb-{n2QJ$_98_^N+*Yj{+TB_t>O%47eS_z;KdDMQKE zdIE@2hFDq#jc3oYf=Hd+do`pmabRb}0CaOFC?s3&+vN;Cd^=2l0%{4+Zd`zr2f*~* z!~LCe|7?YG3ifh)(8?{!J>W-(NCfPtfzO0?Y!s!Ftmx)U4Z-d#`M#T(LdZ!Ez{4ur zrF2lKPDW*^IDstlC{Al8ixu<(WQmZ}nKcz>Ry%jp8lz(VKVE=~3)8kQDDxm^4eWsN z2hBH807#VsYl03~+1yVh^{O?2T5!^`1$sdLM4_7d{Z;nPCQ;;qi4-V*t3A$p;-*97 z-BA?%YkhIxun$9kvLS#&4Jcx{TR&z=u!2NU3T6XA6fn}x9uO)Pqhw)V4#>fhkT&1o zC?olaDNq}JDJCereSP}iEuYN=zLa(O^AKq{2ko}r)^0cT$mwXMeFpLN?nL;_KzpEY&iiD3(kK* zN#-$^1TKNg^EuncYY7s24MyP9bN#*q)Xc?)C}v>)m;|$dfT$k|iQj+9G6;<2Q53Wh zg`VCPv$*XjS|Oz-ma!8V`k<_R;O>3K?Q#8CC=soxvLr#?+6b`^Yi;u%X=q`cQ)@k!;C*vm4p1D~s_w%#dakKrtsc(&UET2&TD4ZAr*26%XYiig znaW3jRW^!T|72rOW|U zIDu6XgkF%26Z~J|1jYN?bB!Ah)xI76flqfF-O_Q?M4{m(;pWW+En+FK~0MzWw| zH0?L(e%`WByxjc8Ltath7++Z=HoNfr3*O2|mJ|w~#6_;vS3JpiK;|RL7P1A5G67F- zY2l)ro10tnHA$q5j)(K^^yoe|Y|-mPakNZd>M1cX6FBSR4VdRU$!wcwzQx5kZ=e1B zs62yk)cL(M$W|f-Sf7H_cE;T_QB8og4G~XAHUi(cqc99)j^V%UPrw;W;X=+k=-?Ew zr_Y|z0%vqr1POQGgvCUjnhj?8efEwHYv7C(@J*3480}4$OM#a59@tdE0o>=*YlYZf zpPK7b05=#iHEl}u)5v|_w~!Sug)|tYiTgr<3i0&`KEu}R5<$u!1CL^5h-&C_iVzqR zq}+a0rgj~8QbJu9-DSbAPh50wg4)ggl!~fUi~n)5X3>ITC3DC_R;s6@~Q=T9Wq;b3G1+3QN) zfHq3}6c!6UTShF97I4|q1VcAqAJUM%@=uXJW%a;*<|hD*DB!QCIOJw%ot4}^&lhB2 z^pJAkq5@<4EjZ@nxu4rsJTd1forbF|V0<1WyDGC-$eY3zY=TwQeWK+2P|%$ct27M& zXh+1u7823(wY{MSW_Xbulv@BvHuq4hUQ_lT2%K&zFh9qL37$%MTRQD1L1ZMNk8DS< zU9S}yamK_%VJqgKaq)T?YBaiOmwRy_WQV05eag2ZpVpWZ*6J;Efh}z!CX7_h2hO6X zUwSmQfQWNbrY0LmZGzebR>kUhGZ>=)4@L5uw|NfZhed5e^j>(&;~_}ELEK0W2fO6O zix(=u!wRaQtcwdDkd6R!0TQ)m+6}n}iER)_NCKWEU!I)?8Tg7eT1Uc?B*3pS!366q zF@f(XcFy^N4cgQTzHn$*Si@2J%F0UF+#ZlD$5=HWfFjoJ zHa7;!Z0(wMi%%Lj-3BOF1i#fvaR3v9_Nci5B@bwByuRwy7V$dV#8t_Ib0qDSyn1I< zu2%qEJ#JYohq3YTnHFDh00#?PtV!5hPPg8(={75X!gYAzTKadR$^FF2kF#OQ@Ddr> zfP=IPAc(^H#sTYc_327eTwo^U_dzO9&R_s176Bwwr^EP|7JlwG*>Irpg;_@L{DcU& za`J&ZZ`0K@v*!ZteNdZT-RR0b7$sA|w2{B04J1o>jq_^vXar!FH+!ug54bNh5ZX`D za!7p~Y4EuSkH~tYdSVHvDWyvgxAk9k;VOd!SQz5=n>OpOVZyW&6`KFCsov0(Z-ih~ zb`LD6uQbf(PSw5KcFl&eQhMyZ1+ui8X$J}5?i}R+SNe0V=A!}l+gGr_8K^S8Khmjx zJ{Q~1|58(_KURBu${{=cx8=Wu27?WWkN+IO3YJ%bkvh3?*ly;0BTqW8Zq$3EZuiil zk8iy#G==JMYHFJ@msq!P9Ofz%pJQ}U1c=u!D4$ZtSno(suKo5bip5M>^zrnFDYYd^ zSs2=?chs^42l!P$HSlY6=6{hyu0xvddqzyqCQIK=&@enl*XFjFzr<*3yO`T`x%Ry_ zAI9Gt)|GOJv)3)%BU%80ofz#Jh4%Bhz-NdRHcC2q~158bZz zh$??C{B&mRx7Hb#;We_k|FAXEkNa~3rcs%BLFMg)(i(fR=}UQ-@z4~FgXi}j|F$fb=ZpY0-{Z0L92 z|Ha;02UXd&?W1b}0wNLu0!oKSNJy8Uf=Eb7ONo?7ce79sq(MTZL8Mzcr9(hkq@}w% z+~<0~@7pnZ&u{j>duB89zRx_5fNQP$y081Zjy&A(Fzo7zX;_O{xJ_#5U_EL*e3`=n zvX+Vl?e#Ew`baW1rU$$Z-!>n)EimMm%tol!%YBvkmun*vnq%SUsn5@*_7vN3O})xF zeWZ7*Sm8wOCgHvahBAwo7!F;@qbtEI?vqFJ@`5@)kFl|@!XFX*N|B2Jom- zmZz`w>EqgIY{d?zZ}dM!F9e_0LsvCaZqys zO|DyuT;+Fsq)w-bMe-#&kTe6gLz?&@@sIauno?Zl!6?-7#XN(Nq?8m9@fEC$r`Hnc z_~}z0qdrAETD|jP@ocW*cI>B!pO$p4iAQdW@Bsc?YPOajOy)`@gv7@%VwY?e{m_fT z40IlMZrF1^+t8GG3}17FVWtR+32Reip~$Ep1}}JZ@@6W=Xtk5|fZ<@Q7vuqTWJ?ieQV< z>jed7u7*sk31^a!^OzyG)=$$tvW#6kJUq)c-v7k+Qb+QUS!X|aB~DLHhLzb^xVQ>q zIl9}lFJ4eyyk&b;s#E2;+Cm2ZmFi<>be@{NH#iO7SgxNIxJ+M{{M~SQkd&M}jbG;8 zv+N=0tNw8@(eKzH)!UcVHf8ITF`axfY ze5w$rxAJ4j{G$Ee#dJ^xS3PcHN1w#j>e5o?@jqsGBSDkaM?MX2ykrjCQxQyw;wL5g zg+5c`<7a8AZW_76Bkq4&Vq{DM!>xB+rumNL8<*+4o7&LrCLSnaMX-|hT_0F+ zbOQ+8ET*e;%+fiyb@$`iA7@1k6G6xsj zJUk4dnL58oC2@4yD=PLXj$Y_py$bU#)!>R_P}&#BD;0%TC_>kByZ;&2isQVlJj=mu ztEG+27Q1`hRGJixq_guOYfAE-wTB_iUkv?wdMI7OFfQUA#871-{$llxAen3KC$AFU z;a(HEisj&cTrY=pq5kq2m&xYOmoJjr>7^< zq=V&x{E!mo+nC9hr)#u?W!60z`;PXzyVdZU!Nys1zdOR@^IUuQb7f`89=3;|gYrK= z_p~p>{sM8`KOq`5D^DtOVnP>2p;jD;%TLn>n>E6A3wTRWAIE_QczcV#%R0V#O}*v` zKZvp3a&#LrU!i~>Wn&-ip0(W`w`th%fh?-f)ju&4Z!r{^nZ?mlC&0m(QfR#rq}nLw z>yTLls3GaLEF#9t`M!WSHRsr20s_rynK?N-oP3^Ju6xD2ed`D?&vT|F7+t?+W^=l02gI&LG$}Dj^{R z5*Y$nwcpvc*p8$cRd{j0{sM(LoM z8J(VIKe03Ci?~){ePt&3-#H5eRm(}|v_eE73$27b6E2-a_f5o<$CfyNZ7)*YDerG->RNa+iVspjlm0Ym_+vnJSkSqEKTi%uBSy~-=8j|7(Woq>_-SP6LxyT5u!M9B zT75{p+S=NAr3WWi+OcGA&-CClv@pqrsmzYiU#aKESitnq&nxEE(>N4=?*WhC*w$;m zor<`%wq%;XM-=Xlec2?%Y=^T4y8~-mN>U#CDG6deM$t*l23=pqmi|$ai5*x3WKDYK?1$v^a(-y^$c`^!OGE#Awi0bebHTR(kC z>?xE9qm#V>uydAqnfdRc)P$Hga&rfv-?whd!xCqoIL0&wBJqkq{EDj1ty}`CMsq%U zkORhf&)h>#YS@&H4K%_{f2o_YFB>rl)rvH>!8y2!xM?-rn`Si*nbT5Fo@jj6L7P}_ zH2&Qfzwi;Z#|mz>msvgl&=tA8m-<+p>)W@e$QUrk4?{K-_<>AjkaUPFNILYA&EIj! z?ME*`Y4WA~>$6C;ckDJBc8xWk+MRGQiDn!sHU<;M_k77whJNJ5SJQ|xxQg;aL~4V# z&oeL?iG_pj`C3RSNfnGs1`*oC`FknqmD7i4q25@Jm(#O-d+3S?9>0vs0OaXD?v}yC zLbqDB>JqWSR^qlfX2Opu}=3%lVE>;Lan_&>=+Q|n6B0Pw-ued zO$c)5@Cs%}@mNm?U7d+f6#Wnu zo(Z%&nz<`Z0Az|u_H;09gmwIXuUkUa_)|b{xIZg^{vsHT z$GK4e&k8z&P42+?fk3$^(j9A9_bcdy~(rso$xIHNt2%h3MY*U7~5l1NGs2ba;&i{~^H z%NuzIL7O&l*TIEdJfy>4Hwc#nag6yISLtPIjat`dKn6P@O=;lIJDko6ot5lercWO~ zK8E)Q>Tv`b3TSr+#+1Ou#-@I-J#$`v;6%^#fVu%)uRCZwJ4>eh%hVA?I}p*fSY8Im52s7PuQLXw-rW z=FjF;cnMwId%wG5KY#9owE_vt#=uhMEPS^Z#si1Iw8Luj196rBm3P?Lu?rg;J>Vs` z{;dI)IrS27fa7i-^@Z0tc77dPSsuv0Ew}d<0drAcNC*=@e+C6Q5stv z0(2;^s%&T9_H91T1Zh7dpjnz6b8CeScUV}K-djN&D6^oTW?6eRtmQ-C!sp-vx{8aN z0z#FXd33@nI9c|91Q-O#0N{9T7YCy&{pmPMP;hrH3|66*BJT@#@!qHE5ZkvAcz1|8 z06i0OVkA_I(R4%*C)H6l@}7ejzRm57e>7MIn_+jMm%gbqiJOR1n1PaH7NoOyI)bZ?^csj-?`bi4b? zf%~6|H!LzTGV%z3+trxON_my~q#@xHq&VoEJqI7HynZF{nW~taYn4e>)d~S+6aU_y zfti;U9Li`YsiP#MDNQNl31iH=cll=jj+?tlwnBoz*D(N37~mWiB9XYivR*cygSLW} zQfxpzbFe>0oju&qjzx^2Y4d*h@U5Rfq|n1vCSg&8m~T~1cYwD0wgD=N`V!MhQs z)ekQB+ndS2m|UD4@w#m44!eg^2@g;K(egQ(lxB03uueZQw9Mnk`cH*T-!-mUL?a|C zx4y8clLj(N*kzOI*%v-m>84P$ro%*&|6pe)^4+_4TTkZ*zY`U;Z7>eH<>uwB_IZB5 zU2sNBa8bXpty3xSIIhUpb0$wBH?6$fs3UGOlMP;TQP&#Ij7mb09rswpul-D!xVJ~1 zYBgRCW4B{e3*;WE_OFuO-;R_i5~W%`aCgrZBfc5XY6M!ClznRX6t}&_LyVflU%!6Y z3$KiCIET?n^upGJ)*%?p^-0GmCaybcw}FrYo^YCF4}fxE0#z0zFR4ofYb6u#FSOXc2X=h;H1s{$Y-B){L4!AXpv>=8wuhv0 z1Fr)z@WV6l@u?Np0J!5hlf)m90Je*{!m6I#pBp9a6^N}gU#EX-;*$jO0J2pXrxKvzm!^*b8U zmd*JDG{g>M>61`Wc0y#ZlC?D_Ea9(U=%NyJ#y2pS9`Gkk1-ZwvqlmHglh^Svf58#K zp;d%}yCY|y-M`bg$(XMz_T00RL}@ciB^?6%pk14`W!BcPbPSh}&++*Aku-FM{8iydaiYKhR<<>QR=-EUzE(7>k>Dme?^S$XnmoAZ|&;uCK_b z!+wf$-o04XZT1?ei`&NYro%AnwS}EOn-nFb(y^#@U%>^9ltW|X8}O1%fVYNd>G5<1 zvh@DDNUdvlVk4|~?qGvP5niq<%wm-HjRRLBa>p!V5tbUcIdkCZIBA!-dsVn7V)pNdNgm&#tM!~F8#^l6 zD}NWzcXjj(%ei(%e^to$S6>;2z4g}L@}7gOi-(b3!|kJ+l12nH(TH7+n|W-Z0WW@V zt&Mggz?(wje=3>a_#U6K3GN$pP4nvGod8-(RE|Yg8d`+`SowV*zagul8>C-CuG=YW z+Ix$=Jvc%xm$f-ZYmfwrPOO0Y7$9ActcYEFuiVVhs}X%1EV+Cel6?s-y@GdG$~Qf3Zb1K35?@52!fBIN6Sl#YCrC4sHitdETb3nTE`D15Zq zu^)iFyFjTPZ~6R_hwRtC6V++IEd@AEPHv!BymrAo{1d!buF#Btd+i$I{rgd1W`$Eu zGjIUvonlU_(MUsJE?n|-gmaQ#hyCr{7)AFh1ksd1<4dfUl2@S;A2YQmG(~%m@e>N7g9@ zOj<8hOuvc=`u#sz0B`mS)D85Q14+qqa9C8gYN>Qs-hP?*uyASOWRHo3J?W1I!^w$} zNP5pVb2&|VI5G9FFnxe6kO20qQ=~KqTxLL-K_%jtWot*)1)ko|5TlzydbPFG@?;l- zD5?Bj@3*OiAK*&`Wgke(o)7N;GsvzGtn%FL`meG#n!QQlFdbjmY=h1h7E@N28RqeN zX&+t#q9N~y$rcmXjK45!i2bWwqGX?jaP-s)$50$r(h`n;ouw_V>ZtkQ;Ujzn?(FAtskb4IT2i-=|RwlVRnQ{K-*U*p^}^M72IuDwAVS#)bgJs9O3> zwDk#UL~gA8W^$lI>)*Q%=1B zSM4?i=!U_a_yry$+vwbXw0b|%~TwW3$;1d08Ijpp1%rUw@4?$17PBO!Cp;=dnCOC~ zq$@Lsb7v$1AH^yWzg&78NOZ(XhpF}Bz(S9|Qp{`fo^cM{qC8DYsfLIP9~@EJEy{M4 z;{}c>LIKQ>8UC;h|M+e_`32fPpct$fq(^vL26gW0#ZZ4u7!@DiojyBD;V1&&Mvhz| z=niLWg)yN0Wj+mI5S0 z5R(j8*1eo-oPe>I6|8UB*o>zjS(Fl0H%u-e_EoFOo*9PddvOdopnzLdz=1U5@!QRyiGh1D&6*^NrcbH5@;B_sy7=CFVTx*08J_-b6g#?p^Dr`6kk2en# zIl;Xiw7~af1YbKgSkGc8D^)9rz1>`Gw16*5BlPQ6CRQ#bH+l~Ub}tsmzFvw>mqu>8 zW-1Qha0psJpEICjCvFxkCUk{#8nxR31y>pBAVGob z=KEHomoNn97{gN~3~s%M_;`6$)f=z`G$&Ks;dlmKH@%u)ziLxwXW_{Cr&||EiAZ&vp(J zBTOiz{pPvUR6m=oq}t<8_JV`gr}be;GoDd|j#yk?N&&dW(G4k2wfmShJP?N-mE0L^ zB0#Y`kw@usz7r4~5utqQTk#22c?Wjg)Sn`ECmM^%Td@1Uf@Rma2e+fym3iNdKRcBU zU*!82C&+$)WRMD>1XU8t){_xTvSkmSC&5&QK(&jy^xpbiFYcbW8TPAtc%sfs>-X>- zev26^zMMnvI2J$%Af)(d;QpO!+wCB!W7jQ=s!V5BV$K|qocu5Iy%qMmAKymT6{At z-NSy_Ol2+`+Oh62jXUgnw@^lPXj$q3|GT$0UYYggdGWIcw~^d2y#Luay+3Q$fv@|{ zM|1X%i7_9VXO+){S3}&rc4_w()#FS)=e%kcadfXU7KkTXQHMtw2s_tmL!OL{kIP_m z^mN8r3B=E@t-aCw!^tcv`XYeCEYoYpUqZ6Op-*p|L`Go^|Q}Sse4OgJ}gjv0m!erY}7U((Y;ss zBN)5(4m_U~2;faV1x4?jg~i2HqA-8PK(Rw#(8iYh8F>KrU0w;O)A-bJ;@*znD9;tj zG5w-di4o0w>vSSt3~JW{R5ku-$xbF^t48iY^sq&pTI{=jq83ASlHqg`5^p`dSTdI8 zv9db?a&U%hCU$%Uew3}=My55KZ0QH|+%YpXwSLZqZ+Ket@(8K71*RV#+T?8Qsw#KQ zj694@>>Po*2Ag}KVV$S6rpABvl)GS`yyzS9bCsG#ThvBq3 zMWQeG^|jVB)TiVI@dPh^VWo|wW2yGACEuzjCZ5Y5I6jx=lhwa57Q{*4AVc4-@$K9E z+3{UO?1%~`%8EFN!G-l86ufB@^TA_vSRQc`p#ZXdy+Tgy5}DScdc0o~g%*Lr>%PAE zh+f)14m%UGb#b5>^Imc{P-AYvu)*{^9D1IOY1VgnpZ9q&g+xkzZ@0P4u#c1sYAD#u zKK!D5@u|MPzOKH0(wCMddAOqC2+z~`kB;tJb%g563s)Q?Ovb#G8fK}PWLZoyGl)t} zSM*^bY%?m>RZi99g#6|@3?|aVcX@uG;mwt(B;_MaX*2kc6Nqumr$tMEI*skF%5`P~V5qVla#_5`Q_e#FPfW^s){FF-C` z212J5#*-~D_Yv3ouy50Nsa3zqb?HXK1Us5de%qYFL>qcHk7iEj`t{HT1~_W$ zXfhD@yvc_ckkr&!9v!lx_y6_PHjNML86YO;ujBYs7}5Uw%ZHZ_QyI;q!q=QlTRtD+ z4U!9)OZ=R8z!zhN(2&cBN-OS0SUyGvGY3IS?XcDidy8vf6dvZpLV{|_*=_4~)_ZIJ zrZ#?yCFIj=a^nXIu%#0-4jB<8hstmDlVyJS?-!82sG){D!~BQc#_-3PG~yH&vi((^SG;oxqYqRw$DzWcD`V|>}zBi5%#!lOkWiRE>4^97U8$Q z_>HlWZwMwFl~Jf=^;i z1p1P9s2S3>Yi{ZFGO@(pR?EHP2TdyJfzgB+-w|wu=QCu@Sb8LB@xnpd@d`j`+|#3WM9$*to5Nknovfq3$< zj`J3d!9wL5+su9cD_kRrRa59)%uyufqEakrDQn#>|=eXT*CBG4>;6_WbPEV%$#;X% ze_C0QI^Vop*>#=E*1o{e#BYyGZ#B_i?9k4>R=l8^iS5DUB;1^JNBUlQiOj4P}+P=d8gUSu>h*%UXt;%tt< zznfpM>LlD{H9CTrjM+>|y3@2&I40^^ll9ttfVO$zNxD0HvS*U0XqId4r7Pc8RMZ3i z%^o^NO8UFI_4`jNV>J#|sqMYOyzA@T$nwMAWY5nz{Lauk=!)TG*P$K#n=zPZw=yim zG#_>{g~zia4*5|latPrH^jZCm+7u8T zdSPYunYCgluBv<=Oe%Hy$5xyACFAZXa+FC%2pX3H1FUlT2elc2A03}b^|zkl^(&^| zHI=FdEpT7D^{$q-?Lzs8-INPmeeV5VSSpP}ggbgGIzM-AG(A7NGqW%e>z|e8ve4-K zST{v1l>2VC-2I|QKQ1@<9;0>k}qoz=t5O%@>&&USVp2sBZnr2r-b=V80; z6~E#~5}@G(qpLJ<1iE&ULz#(JLLwR93WYl)Q&Uq27y}KtDIme;Iny;d4i1H>mpq4wP*SwV43wO;b#*XYz#qV91ypp?=%{8SM?mvKP_!;UC$J8}v&Mnt zibk$A0QURq*?DcbS^9KST>S1xXu)fy@mY{#BuaketQh77Q?VGxh=b-ykAzK4O@WyP zL^bHZVxqE`|K7a~PSno{UDZOpJz5EGF?6I4gD?P22?+_er;>rw0=uxUZPA9Lts(@KxYyNhUv&2LWI%Z&IJuZ)$C!E`BB={% zk@9Z1oY-&b@xQTO{wwVO%{5?w$!8EQ;ecu$7&_TJeRQXVVPxHRH@S=i*V7JU!^PjU znbvnQj^jLc-@jXCF|2w%jfs|>8*6j^=i4F67)V|@@|iYZ1>K0d*#AZo;4nV2tdE>tCrQPO1?ZT zNr6-F?gAh^h`fmkLU3(D3YQwCjP%ZYSs4g#iAhN2;v+vcV=OKGE;MKWq8;E9YiR29 zcbxf2>3oL?ux0d(#HL#aI3&8WvZ+GUMYT|l%zkh8E96jSMQMYQ*nV&g2$)y_>xqt~ zctM=YQX7MT(vq)G=bIfxNkx^X6P|{4!=r2LIHv1r+DH;b?1UNLu_U=ZiqT)#8LL5? zQb9?8SHf|GIW+|hIV-+6G~4sS>k~~)BfH#)HT%hK6;$BTv?6v@er}gKE6$VZe4mYS zZ;ILLR#*3B{HS@Y8O%5sEH_v`G^W`{>@{?7O1akGBWiO>?@G)}thna;nJp<@l)>ey zA;LDRW6mwGX#4O+7;T%=+?L)<9YgpyQGU2HUCuPE-vl-}78>$?q-~4~ z+nwA8;|at(ssk;5G~s}53#C2WNDtcE^O*6)krQ4WLFXa?*nh_+IP@TUeJOyW+ofd- zMD=Zu)G}V&(t=7hGP-;BZYAUX{m%-3Vl6=lk3cT)#-k8OI7#dtBjtAfderen1FA!% zT2Jh1h+WOUi)V*cPsipq2T7Ne$!3vQc4-p&^LB9$%^xNFwrT4QqzOvmd=-p0Qt9j8 zJN~z+7Kyv1adWl#YijSf=cVO&%zGNw>8kokt2!YL+`ei4Msi}#dg}Eje*FefCfcJA zuM{rs!wEznW+RaFx^nW2z_Zx>#)FpGcW4&}5XY&5E3O@%_X}eIeN7)+IR*%DKYzI%1|~* z!9FH47zOEN2a;n!Ad)@64u7vr>6rU+(-r4rG1zaOWvR2m>XVGN3EqLrxK~gsOT?YQyj28z05{*PNAUXe5u0TYG9> zSY)?^`cp*h3D?j!8E_t|9ujG}?Fx-Le2*pFJ64s-QViH8^>+3c8mPP)>`O@0Hn3!BI?TJ{D(T9+~%|qCgxH=_(i>fUx-Uf9`c4dH$~~|H;|e;8(j>Zhf5} zZ!`kmnI_l!zoPj~%e{BNZ2)FSLu0u9=#=i)f4;MVJ`Z@Z5ct%Ifn9@TPuiUe z6$8l2%kpM&P6{vig(TL6M3<>l`0&A&68Xus^gWdz3z$wSz-o9SDr$MK zf(!edNa^fY)^O|2_(Y3Ut{L*uYx_cYf{c4&a>70H)0>SA=V{ch8tgP*4;62z`HUg>P?M;@Zq#Z2+S%fBe?`razT4np z4+=LlI~C%!9XC0qy0Wse>{ZrN>%A7VOU>jF=`y+O(bMamdYq6U`1H{u41jl^n;=4L<*FZ%#wptuCbL0#{7mUBbp?SyOJc5no}=A00q$44@{u zd=j2$Zk7o6ABn{I^PAsgos{Z)>uKJfJ!C^x_NTR)Sd-9rYFw5nV#koqTWenuhQ}jOlKk20HLsrw~@hAOy9d9ghff z?dFvG8oFVj529pAGu;6zza|?+1x>V5;_my$gROQz5p{NVv)95Nu{_-%0TxV%#xOWo zQ-18GTUHZpP($rtVh6hM(E7xq*Gcg#Gj9@_w0{9BGDg$baLa!;wBrr)L! zK@F&vQq`TX7aTV+FoqoW>{f>hlaVt?Mcl(vlrAvE0ry}A!{h$is8Y-h4)<<$W-S7; z_g7R>yMe8hRZuVnl}(OG<=(*Y&K*SQ*m@)qz%Ut@ykKBW2dLK*awu~ipCBOfV*vRy zN(urI)H=~!;K1}i-2o*iQk63msoxV&cb)7lsjtBX8P*C)`?S z7x81+en^M)vbHAV$8MJKKbromL*^Oc6q+WAyzs2cMBgktpPMfgs%*6}S}FCJXX^_y z^CPCDzIRm7s{GKs5$Ee(@i*uo$)kloW=w73?oQAgy8m36>PGc{`sCr^f4=`Qit~Zs zK#S^>`WdPb51M4l1 zQd5RsMgsBuD?=xe{|hlfsd^`0e9zM;Ke#xnkCOgZS_Fjyv((YG$PMRP0vyS)jyHq- zp<9yMe*S5AJ?)cpVtH@xS)1qA;c_wn7lA|TNfglR+hfWoCYAu}D!V@AeteGz3bwQ9 z@1jj${?`T>0?3Ne;Q_I#kHU!#K)NDToOEvU;8akj%^m*}(GMia2rf*Jf9*#X66Vw@ zCP1U2_Lr5M)uZxkE9iP;_n}DIr)9>Os}&myKZK=9m#zj*w~Ghzp=5~MT>hw5XWnwNzK|t9g66SbE)K&jrD=Q{BJsAa_<7_0KfDboDbeCKT>brjZSrgN_keVy z6tJX#HFB8sbfH~6mkPCcUgbcuMoL2RuGMH3xOX&X0g@{zr;dYe|7#m4P_af~Fbc8= z3xD=GpQDAzAm)v^C2-KF4)&jL+plwF`9Z+rFQ8SM&R|Dqw5|XV0u@@krk<1l6Bm8= zeUONNtXQ?C+}^CddA4zUJRWRm&plb=5D8X22DydaHkfs*S_qAmri zc+be;wCDJ=afR2cqgUgv&?RqAykI80N_2oRY_}y)e*{|3EV+?glWy-aBm4i+0$8GT z76~F5wW9r?I|0KV9*7LVWC!PE*VEViso5}dq2rTs_D_MH-<710mkt&ZgX1Lui88C363Fp+u58vjd#MD(yXe^cw1Qqr5xTm(cW=>8FO__3B21r!@|K#|O+PZSyjy4uw!22c{eEY=DENO{+$;X=bQ zU=4j2gZcwXSO2+Aq&AXtbtBFtDh_6|;-$6qt0y?&e8VN_swnqD_r0`4%6U{E-_VWl zPvc`)pB5&{i{>Z0W0Wc%yebVIKcwz`fti+UsBLRvx};jYR3LPV9#3?UQNLl#ij~t- zg?85I=K~OzD8??>%bNjgUHoQA(KBJTo~!;iEt=7qw!!*$O76T^F$^RIWeFgZ1y7z( z{l(#n;U^*2ph{+eT@yd%;vD2TKoE{;xaq>QehL$BHD&{6l=JP$K% z$KeIA-o2}w*jH}&w|n)vCN7Yp z+ehw-?WE@OiN!BE#(cN_{VsbGH-Ac9CFHb9iiwSH2=;X}oZ(NR0%fB)OM8C1_p1r) z>Y@g)JljJrkT&lHn^3B}cByGuVYt)2xRare`PT1QowT`ye7N1*&iRF2u`-D>>1_Gm zgG&7RQ(Vl8rSanlkZv8#e-jU^)kJA_)1|X9_+9_&lKK4#e&CioQ4`5$O=H$gquyaN zdk=km8pw#}s1P27sACbY#gL);myemy4tP})-NmIP@>|z|H#Igjy*Z`%>KA$hf=Xbb zu@dGerX6_4xu==lkfDa|eE9@57@(ly8d}+&ZO)+8#pm2om=>^#VEO=tKIs^JIDIUk z$5S{r!9IZY=_mPIx`DPbgH6ooZ_Cx)Yj}$<@~f$$Y7Do%JV27ee&+_d}9}Kg{nj=xza6B*P!hGZm8s0KrVL zj$yN$`Yx+(a^ZKCq(~<}go5WSdK3ncB}5u4LRc?c1m%oT$oz7=!^KslUgu8rz`o@b z*B+?nAPu^pJ*g1nUF0wzgvZ{4(P#Qf5dPfUFL84K4QI*V6H338W(T|GRei?UV%mai_XIC)^JEa0ZSwdHE+U|kVb z2>dl}C$;NUrEz1*=)Hruk7}pvsCc@&u^Zdh)Gu2^R%!x_f39acxJ*2KCUxyoJTXE_ zXq054e4O~D5fSg(>FN*oBxy~xH=51_)w9zSW0iMXrR)ZsXdbB%G$67Fh;Oz-j0rP5 zyl)Xd97Z9~5gX4P7{ojdInaSlFoHm~0!UcGn$9!}V@J4W`YOe=lqP*7=zVR|5>_`JMadS#-IoDa&3O^SaW85zd H_yVme8`eQXZV8)8)WQnK}etqifPCK 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 literal 0 HcmV?d00001 diff --git a/img/address_space.png b/img/address_space.png new file mode 100644 index 0000000000000000000000000000000000000000..10744c5b24a300a4d13b7a12ef2edb58b82e4fa9 GIT binary patch literal 172761 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 %N*6r^c|)3@E35E&bgX`r4GIGWjv_!T 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 Dv1As4 literal 0 HcmV?d00001 diff --git a/img/bus_interface.png b/img/bus_interface.png new file mode 100644 index 0000000000000000000000000000000000000000..2f9248122bef9facf93a9cb66f0cb19034082629 GIT binary patch literal 54222 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 Umm-Jz4y1|k_EE9HqZ(1kVXt|* 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 Vwr1|+rsE7i;OXk;vd$@?2>|HwCV>C| literal 0 HcmV?d00001 diff --git a/img/bus_interface_atomic.png b/img/bus_interface_atomic.png new file mode 100644 index 0000000000000000000000000000000000000000..370be223af21537ce69235221b47b70ec0858d37 GIT binary patch literal 57747 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 literal 0 HcmV?d00001 diff --git a/img/cfu_r3type_instruction.png b/img/cfu_r3type_instruction.png new file mode 100644 index 0000000000000000000000000000000000000000..8d0cd9d9647d6c63b0b78accfcb22d222265625e GIT binary patch literal 3781 zcmb7Hc{mhY-<}zyC>ln}lBuYX*<6n)h|-|C^md^##=0w!cw*3h*qV;7qfT_~paE zQt~Z_L8B}C8IqiSr7$P}xE}!k9mWB8e>c5OF81dIzTEepz~6m!N@yUvHrkfF*Y{mp z-8aoBi;3hcKacAx4)V+GT|zm^%z1PL-?g{tshhn!={)< zwMcpRHehx_it`Owm9DN2aBX8lEn4ShwJN<$1u6HYO3;KoQqBB)8C*Id6pkEP4pC<& zTEB{&R&G45-NshMleF&p1AUc*__2egbUkbb@#cm(CT831UVR$t%wC&7u-!^VVd35S ztQ&p>Xsw#`8-fZ-atxSv(ek^yn2Fm2%a#qA@=X;d-FefDMA1)nkzG_nCl4VC1ZwP> zE;AJ;0y+YE;o4mdbU@zuUgY>3d-K%McQv${l_pAy@B!}g=Y{qH&SqUG~ZP2xpE;^r{=~?^2oxr=j;?(p2A={=Za$rU1 zphCDjUj(e-sar;n0$-DK>*Zgg`*d&RnU}x3dK&^wDKy8qr)9WPPF5t+(y2S2GDTS# z=9&#@p68N_()|tO7EJ_ScP;TI0E)^z@LpmvD*Rbv^^$0mXjy^iYPgNM3 z(K%51Hk~(#({ttUkO$09|Gy065)QxL9LFmnYWct1Tnqq_K)GuckrhKl@<7Cp*(_i=Sat1nOMO-}09{AGB*0m24bH{w{@L)p97dK{??>V#@?qo%yhVa; zqmV$HU-`wB>+viLUkoRE%hrH_R^*GwJEUwr1|f;@U4h7Tlsp2BOOazs6UKuRxJ%=2 zHU(x!njY-cH1se8iWoNg&1C_!jAnDr$#IU$Y4A1a`Moke-n%q;9Ia0V7^DIFMM zAB7sewOY1?{6$}$Y+Z9`gyuDVB8Ff)9VK;lmUat|AP<tnX6Z)v%h<7{eNd$5`hl}tD0Gwy~g^+09J8<5EKg(ppiGdk2Wu<^0$8?q}js1%M5>}1_<(3r+U_ME3Uq!2g;b7eE6tlM#5SQifm*%(9HvT2Mwd~m1NIr z(MM%G&jp2*ol<((@e>}lYu((6&Hiy~!T{JkM1I1gr51H7?B0*2J*)xctcTQ9AGSYv zn$g`JK*a|Gv(~o@e;JjdFS8VKG8kyKaK$(XH@A<9HI_l_k5`hTbaZ zm$Vb|8qP)`DS*ngrd7X_f&y_r>{ogi3biohFajSnU>IHQ`|Feq&kRkZ5#GBRbARzNwKKNSy%DT7fwj9KZA#FYh}8?)wOM5B~(>w0Rw zOP~ZpY0LVDKS4}+-{h7xA(FWMwdto4;e*SUz=fTF+wcsC+LBLA@t(i{J)2 zBkQP=P$#V`YT)FRsY;0DMVEsA<|&vb2NoD34S_PiY81kY<%;Aoj&W_h|IsKNj)dj!+#0fex9gfd9`>1Tb6} z;iQP474+bA^sm|8{n}5fweDJT2d_{ShnHMi(g*)Ymchp}9LvbjVwHODR*)SfI|X`r zY{{_^I7U$ z0;&RBll@#XHJEo)C$p?85ZBnL;$se~NsV;)<7McA&sLYo zMSW62TU4%wwn=;sED%l8Nh5qK8&o7uWO>>ryUt~pf~9l0nK^x`9nZs$Z_$@C)ZsdJ zXm2+B$p8zbte`N49X7U|&4fT(i5H-}yC=-G)7C)abIaF(*W(RFwmcD+*D_--jOfis zMruqGXb($_vnCWsLyIB9+lWL~>h`DyJR*;ue1Bn(ng&N0F?8TtZk%?hIr1)zy_AtY zqm98*Hr4ndB=GM1!2MTv-5!;Zux|hs&k2d4a)0Pc+ODu+h)$gXmzt(?CP3$}C_MfAxz) zss5S_$YSNZT#)Kh#B!^2hNuu@A@>?4u@B;PN^a1?fPx#(Wi=N7WF=)M-#_3+2EcQXWWbd+0j<*Ie z2VaOTdOg9(nT>m+mfoz69G2PkxFICEPFG>3frgRqU`? zzG2c|HF|~V8H%sU)9<*m9O%1u7LF9&t8}DH&WcI3JbCTh5rCEb;brvw@qaV`Dhr%I yNOj+fE(K=+N|v(K{;LCsR{*~K87IISdQ!}y$H&kU6Ws49;HsgS!Mi`5!v6&|5H@K5 literal 0 HcmV?d00001 diff --git a/img/cfu_r4type_instruction.png b/img/cfu_r4type_instruction.png new file mode 100644 index 0000000000000000000000000000000000000000..a20fcf5109f585aa1edd05e5236dcb25db50bf53 GIT binary patch literal 3960 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 literal 0 HcmV?d00001 diff --git a/img/cfu_r5type_instruction_a.png b/img/cfu_r5type_instruction_a.png new file mode 100644 index 0000000000000000000000000000000000000000..d741aa11833223399fb11492d46aa52aa03670f1 GIT binary patch literal 4116 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 literal 0 HcmV?d00001 diff --git a/img/cfu_r5type_instruction_b.png b/img/cfu_r5type_instruction_b.png new file mode 100644 index 0000000000000000000000000000000000000000..464df16520e56400b8acc8485380bf8d7dd5b88d GIT binary patch literal 4106 zcmb7{c{CJk`^Rlrs<9Tb3wdl65fWL3K}=DPWy+Sa44Sgf5K3Xvm<&Z@EE(d-ZpM;r zBsBJB>_a0&_9=$3dp*DRJ?Hm4&-wlSc+dHs``mwg@9Vzq>pu7ATsQJM7z8*fag>dX z4Pa#nv}a@Elsla3@p2!IN2GC_Y-|D)E1=2EaM$Hb3Px1r__OsrSwsyaQCNsiZ4?(d|yQJ;O!f^}Q{U@k8R z(X)-F+l-K%5n!hwV?o=Fnw1Ml9BC*K z>g;H-oMIj^f-O!rHVqr1mi%V2EOz^6WjOAK70${nN?*rcA-F2CENewo-nVs5OE}}J zD7Wv39zdXEi8gN)Ra;vhRuG{v@0oU~hc1;G1n7ynU!6JlYPLaK6SyE+0l$Tx!@Uar zmbn+oz3V!GKSQ&0Sed_2_&}^c@Ij-Q4qD^x@a3>n zf#kq%!vbbe0=!S*i9&&VW%u(~?!Z-c7u{78$i|mI%n*@0t))xVRq)fy4a=i6{?(0+L z{82s%+K|)d4H_EwtLdNiMuRiW)coXwgd}?kObA|gtpvfMd~!>U%&bh?dqKOE26kt} zIB$Xm_~A|pTQkBqyoh2{s~0g}n)Os6spxjeoa$G27K{0N?)i~u-g0&i`(1P6OSO3q zxsDktr^*QEJ!8F_ckOG zkN})({PlZ)j;;3qgh83^tmm!GD#4Q2DeB!^6Dj<{-o8?!GfOGoFGi~`n(t&AhJ$|j zEpT{PW?bP4o$KNLUi`w0!QZt->EHgf)<#RZFPOWR{VHT)6s5yR=B3cgA}MiPx7V!J zzEIVroUhwFp5PK}Pw073u+c&-E%;To?lMK~?jO+-Sm)A4;Ps7YM*>~#V2yFFPf;Lp zmrh@NJ#zVn4>qW)j((OI9&%$V_lgi+`h~w9e0)uE37IETazAG=a<}&5u zr1k4P0no>TGWs64bi((iBF*X-2Iy*<ds}=KT8{qwtkM$@*pgy^ z{hfFqy_I_J&t*prmxT@-scI(5DZjWu!`p{^R?)e63+O(sR zyQ+EN3GO`DVBrbG9r9A7T_vEmX)xy7i0>&|_s{ap;<G|n~5Gblb;V_=4 z+CrvzN5s^oviE4rxWfK#)Z;wPapLJnJ@y3@VY^PLs{MrGUwrPIf#{(Jd8ha*k83tR zp*-jk@Rpmsz*}CeDNW{^PHlUR@U~mc(i@2x$LmP>#>J|e9WQs+zRMYC$A9Rl==iTa zzY(L{2T8dHE<$ZXw{7tPS{(-qo1A8=lSh}_y}L(a+xW&Iv%6O`FZy1ih67a_D!hPF zGDa|W4Rzi~5k;qhP#cN*fWx>l*ZKVi1V^O1mT*|CaR z_SvP=&1f(Px`cnbN89kNLj8>L?1L4O(hjDHAM)EGNEM>PPZ>w!RP@U4gwJ> zH%Zm(DvxWvEZir8Ycr9R5N6R@eymMb=~6*fytbT#1}!~b+~HKCrdwC0{!W~Alpl1x zRQAWIHIgA{*Ydy@`emmX@osQ!VUK|r57#pICwFufddVT`As%mHm-4HTt_rm1?|YSt>gC#hKr%IO zrT2|#*D_xM&+@p=a@tP0t4J)~`>H188~xg}{KVLbzUYd-acI%^8v1j(C2DgyxU3*y zM7_Ag8+%XV*d#Cb^&?=fi8H;^^bRTZ>YoQtm=N*Vx4x7+O(`bskH% ze@32a{7+ z>+2Dh74Bb}l=}7P2y9VmUHnV=>)rwxg?Y{scOPl&@MhBtfn#{c_~9P^$sXT}OP(Ny zpMG>puY#RjQjnRGa&-ULv^~apI)GE_Ih<*Xaq=5F;D80Ahia4Ib28wnE^!565lO-9 z7X#%{{*Jxc^O0-FxrS`f*^`dTJok`uk`<&(BMnW+tdHmO!{U=>JWyJuYhvrlqviza zwl}A}%1}#TG|9j&5BOXv4a4i9xmK~@hLwf80|V0{Z`CRk=Y^2YXK8{H>E=Z*E}!lEu|8>fsr@+D9&Uz>D^7+dGoF(TpSP=9QJn{R}*Q~J(NMpW4gn>-ix&qPF z!|)Q!%NBGiLnzFOOZgn2aW|*#YxkXY1W($WPVOFvq#TMnqGtR4okJDm_E?Nh4&AHB zHdkcpZo(w6v|t5^$bSFgps7%&J@t@O&c%gcqDl;8EP!kX`IPLXN7ia(J7)1|dOyV9 zS{M{lg{n~c|KalzKsMKJrnR@8`7b?s@7R%NvwRM&bv^(TKOiG<=Q(PB4+fj>{MdS! zG~`Tl@6AfNF~HIPKQQerbR^F0X(u^ee6q;q?3LgFqAokdLX1_q;zU0&yHqa~~}6sBycDf#Kav()QGKggtgf8*+5cfr=MO3XpQ7ykb{(|VayL}uMecLx9+SB zX>Ic}>1D0zmt=hRCO13M0N5o$FPOuvJrUi4-x$@R24kq(UX!BAUhZQT;q{4i$|l^U z1+zDkkcKCGeo>WZ~b)$H`R$ERF_TE?-qvL3>h%gqmic*JR)Um5?IgvPD zR+Ydb7cS5HJ5ell+M#RaDKM-aL<6B&E&H?@PMt-cQI3G&Fh2;o3;q)&eU59(i2$$k5x-sOiGlh959yJtN{dO{^ z%_pUzfQyaE;ow2xQG-CQp57d3R-3Ok&605nrV=+=>*XIx@~IkHajqK!mxwGj<4Te z4leT2d?k`^C~q$BGK7sYgnHSVdeS~;VxFzdGV;W+QqCA70<#yR2Vx30O!2-prx8Nf+ zepk0HPRq3+R|pL{W4eAj+{=5ehynyo#0RIQuh45QE1!!;aTg&=-%P~K$YbNtzl}>= zq{^$K%E||~lct_+?;RaJX?tB%cf^hnbaVf?sGCv0*N?c3ri}S~ialbkL|fObzY{N^ zB&|d1j*)Y28_!~g4G-);*|ldM43WN^a~uBou*&cQ`zfUsXs+LEnGref z&cl;8CYKid$4t!yzw?j(toc&zWPpsZBR}4p*6eowP^ww=8XV|tAfU?1~__W{} z=w}@UM+Ylyf%|Jw-n8l!rpLL8v<;QEdd%?92U>bw92dN%G!Ua_I$fh9H}i5h@)PD= zdDH30)_aW^8Z8p493Z^ZMip92? zL~Y_+FeEbg6GIKF?Rz)qTK4;>RY?60`Xy?;Fw#3B$tr{1B!AZOFIf9&#ZeF`zG)S% v8-N9nZJ`$&{ObSr#JK(%iIhXRsuAb@PAD_+291JWqb${|N19t*a literal 0 HcmV?d00001 diff --git a/img/eclipse.png b/img/eclipse.png new file mode 100644 index 0000000000000000000000000000000000000000..ded06dff153d18014933e7b5098cd2a9c7edec3f GIT binary patch literal 132828 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 literal 0 HcmV?d00001 diff --git a/img/license.md b/img/license.md new file mode 100644 index 0000000000..6879d9dbe1 --- /dev/null +++ b/img/license.md @@ -0,0 +1,20 @@ +## :copyright: Image License and Copyright Notifications + +Figures are own work if not otherwise stated; see the [project's license](https://github.com/stnolting/neorv32/blob/main/LICENSE). +No copyright infringement intended. + +- `SPI_timing_diagram2.wikimedia.png` + - source: https://en.wikipedia.org/wiki/File:SPI_timing_diagram2.svg + - license: Creative Commons: https://en.wikipedia.org/wiki/Creative_Commons, Attribution-Share Alike 3.0 Unported: https://creativecommons.org/licenses/by-sa/3.0/deed.en + +- `riscv_logo.png` and `riscv_logo_small.png` + - source: https://riscv.org/risc-v-logo/ + - license: https://riscv.org/about/risc-v-branding-guidelines/ + +- `oshw_logo.png` + - source: https://www.oshwa.org/open-source-hardware-logo/ + - license: Creative Commons Attribution-ShareAlike 4.0 International License + +- `neorv32_logo_smcard.jpg` + - source: background image by https://pixabay.com + - license: Pixabay license diff --git a/img/neopixel_timing.png b/img/neopixel_timing.png new file mode 100644 index 0000000000000000000000000000000000000000..f7c62b91662e9c08086b128a83330851def2953f GIT binary patch literal 4852 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 BxzYdt literal 0 HcmV?d00001 diff --git a/img/neorv32_boot_configurations.png b/img/neorv32_boot_configurations.png new file mode 100644 index 0000000000000000000000000000000000000000..abb6180adad574f71568110f5ce64a3f307e1725 GIT binary patch literal 87702 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 literal 0 HcmV?d00001 diff --git a/img/neorv32_cpu.png b/img/neorv32_cpu.png new file mode 100644 index 0000000000000000000000000000000000000000..458ebfd8982bde031871094ef623e0c185e1a85d GIT binary patch literal 69153 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 W%@jt8z?v}t0000<MNUMnLSTZjF=A-| literal 0 HcmV?d00001 diff --git a/img/neorv32_logo_small.png b/img/neorv32_logo_small.png new file mode 100644 index 0000000000000000000000000000000000000000..457f55e5a767e4c258bc32345c58944c90506a98 GIT binary patch literal 4604 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 literal 0 HcmV?d00001 diff --git a/img/neorv32_logo_smcard.jpg b/img/neorv32_logo_smcard.jpg new file mode 100644 index 0000000000000000000000000000000000000000..30872195b5ee0a8a40bf4d4ce9578a2eba6a8c1d GIT binary patch literal 152056 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%0Ajag_s*b^vI`)x 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%0A^DMrh0~F}! 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 literal 0 HcmV?d00001 diff --git a/img/neorv32_ocd_complex.png b/img/neorv32_ocd_complex.png new file mode 100644 index 0000000000000000000000000000000000000000..2d8a08ffe7f66f23ef77a0268149460770407514 GIT binary patch literal 31378 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 literal 0 HcmV?d00001 diff --git a/img/neorv32_processor.png b/img/neorv32_processor.png new file mode 100644 index 0000000000000000000000000000000000000000..cb34b5f3b329cc88268898ed5e2b0471a3f3e783 GIT binary patch literal 138331 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%0Dv@!FFrus>Iz2XMeCYMI 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%0Ai`Ov&fO8ORS>#^2@>qe)~}t=k&W^?YOW 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%0Aqnlp!?%@882b<Gv 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 literal 0 HcmV?d00001 diff --git a/img/neorv32_test_setup.png b/img/neorv32_test_setup.png new file mode 100644 index 0000000000000000000000000000000000000000..1ce72dc7f1790a4efa088b581c49c69a262ade71 GIT binary patch literal 39522 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%0A2N;yqSPg6(wCB?96UfVJ8wkGz#{nHM}ph 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 Kv}-jTp8p@bOtb$0 literal 0 HcmV?d00001 diff --git a/img/onewire_data.png b/img/onewire_data.png new file mode 100644 index 0000000000000000000000000000000000000000..64646b18f7445a1862222e35b6c5f76fe9dbc782 GIT binary patch literal 4576 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 S6L@n2I%8^$d1i9?)_(!p5Qm8X literal 0 HcmV?d00001 diff --git a/img/onewire_reset.png b/img/onewire_reset.png new file mode 100644 index 0000000000000000000000000000000000000000..bb7ac5ad5e013be912f97d33e5ce3a39b1784ad0 GIT binary patch literal 3817 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 I^_i>x1NM0vBme*a literal 0 HcmV?d00001 diff --git a/img/oshw_logo.png b/img/oshw_logo.png new file mode 100644 index 0000000000000000000000000000000000000000..da7028f0dd30ec1105e9beee6545c70be5b37b76 GIT binary patch literal 11099 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 OH08G%Z|dc(!u}6NLzg%J literal 0 HcmV?d00001 diff --git a/img/ram_layout.png b/img/ram_layout.png new file mode 100644 index 0000000000000000000000000000000000000000..bac9c63d45207d6599f0f444bf17223caeb430ab GIT binary patch literal 13837 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 Rz)!dyC@ZMLisjx1{12^UXc_<j literal 0 HcmV?d00001 diff --git a/img/riscv_logo.png b/img/riscv_logo.png new file mode 100644 index 0000000000000000000000000000000000000000..27d8a41f056f65d755fc8eb04d52de90cd7debba GIT binary patch literal 15859 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 Vp$DOfeCL<clpjCH{|oN-{{RCnRfPZm literal 0 HcmV?d00001 diff --git a/img/riscv_logo_small.png b/img/riscv_logo_small.png new file mode 100644 index 0000000000000000000000000000000000000000..aec54fc11cc6511e3003dc452e6444e919fc6f0a GIT binary patch literal 3484 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 KMNUMnLSTXv2h_Cy literal 0 HcmV?d00001 diff --git a/img/stream_link_interface.png b/img/stream_link_interface.png new file mode 100644 index 0000000000000000000000000000000000000000..0206f93ab12f9d12d0b19ce9d74fd4bf00498744 GIT binary patch literal 7801 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 literal 0 HcmV?d00001 diff --git a/img/vivado_ip_gui.png b/img/vivado_ip_gui.png new file mode 100644 index 0000000000000000000000000000000000000000..09af8060f45962b90c05d7e8e07eee340b2306c9 GIT binary patch literal 67843 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 PK2SNMemeEk)qnmED3wc2 literal 0 HcmV?d00001 diff --git a/img/vivado_ip_soc.png b/img/vivado_ip_soc.png new file mode 100644 index 0000000000000000000000000000000000000000..0d12507deec3ba74f8c7a553a5829f55bd37e375 GIT binary patch literal 69772 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 literal 0 HcmV?d00001 diff --git a/img/xbus_read.png b/img/xbus_read.png new file mode 100644 index 0000000000000000000000000000000000000000..7018fe3e93f65fc550d2c6d4e7e66db33d99658f GIT binary patch literal 21832 zcmdqJWn5HizdyWYXe6Yh8|g+uS{i9VL^`BXr6dQX8zrO>q`OfBMp{5RMLMLUn_=cz z?7i=O?{ohD`<&<P^St22@PV~vt~KlW=5Ix4YbxX8QsDvsfUl~e@CX1Pi{KA8HYWHR zYNWX#05AZm3J>(WO@C+l8$6!M+zV9C#3bOu{B&I0iM7mQ8dN|?cobcod)}T|s7mIG zCNS-2=VBBrNoy$Bt@N7bahP5><w|hkCP{o<>W{jIXrFY-PEVI5?mf@iA1;vN`h=Nf z`DHElOD41Dj(4_)B-@<JkhE`QOTg7m{SY!UF!AN&W%<HoS<0R%pKm!uPMjWkRv_|% zR#;fL`QwX+OL!M-`huNt=MhA=qcl#mcmo71ceS0Ip!oRs5{{0JUY4_6HOk0{1eSnK zt!S8mQ%T^917^q_F2YC+^l*TP0jdBeg%F$TPO}q(FLV?bhE@*l`L@ijaBI=h(jGNB z&D6Yj_Kbxs@=)bzLOg&|^(;ir@t!4y93q^aE$F<dsj2ql<Rq%mWsd6CiO+|eoW<_m z-rm83g99Z^BiWO<l<CZ+x$Zc0gR<6~9!*u%Pxqvy17vcS-T_sZ{d5;>N^j3qd-j(5 zlDK|lihFQ|yqf&^6K_cB%y=(}>&fAF?}uxSp+C%)dj|=9@iT9ZVnB3t2QW{*HABL6 zcbU8kVQFRM>fzz>z{28#OiF(WU-s|K&8Jwv9BZw{Nf%3#?7f+bh&4?z>e@VIkAbf4 zXO*zkY=bqHfWv*Y?*jvfm98lAYr2@2n6IPxYGJ%4pX*fMikxN;Z-7BUrut_Bkat+y z{(grn9znw8vCKx;Rue`aaIP$ax){2qqZM-lN=iy%wKO!OxEGm{DgntE3<}?vG$puY zQdi{kIIOFPSZ3KaT=vC_7q(VbE6hnrNyz>D{QUXT)6+soPFH-;a8MBv2ma0kW{+=B z=2jlnvcAJ3R=s?R7ITO~a6Cd=w=IZ%fC$fKgjQEq>%MvOCW4ZZ61lIcs#-fXHue<Y zcj^Uj_?Z_QPFb~ucVizin{#Kdz-?4NmqT;|zE3939#oyL73Ak<($UgtSSnpzU0Hlj z6Q(z9_T<qRkh+I@?P9)`vV(J{jBG>|R$cTKNWZH}8~yY})9cj+g3n*->W=f@U=eoL zMmN^ie{FD{6|XRDxhyhx9uFuB$rz&D;WqiOq5do>dofYyN>d9Kqowwa0f&s(17>;t z^DCdUG;(6D*()&r^XDINrMbDwT32U#ftWyAI6XP!$;p#C%z?+Ex6#6gwRuJ!hY9nx zzSnhfp&ro=cwW-XB|iS?<u3v{DIfRe0m$D+BH$txU}0iT@BX5D5M8lYXujHjz}1hF z$QvWA)5-8*a?p!D8GC6IQh?Z+ig05Lr<Z999vB!nyS%&<Bqk;{x3R%IJUk2y3k{_M zV3Ywby*hIaZ=<o_T<2oTcK~&ly%OwXIat%^6judFSuUj4S~Iw@YHMpt-|V&|$MmwQ zun=pq!sM#?+c(t)G{a;0-}2Ep;|RN(3-`Tel0^3e`+a`rWcbPQ-0y^OvfIze9r%AG znjO_Y(ht&ISLr@1pa1ge=vH}oIlXPHh_LY2)8Dg!izhy9ocg55X~Fd;r-yFQfpwVC z!*c4W!z80_=~c(e^P9JY&2=%3by${_5$(k9MP28qeNT5dIQaO^!e*PE=ba6Ikk_jI zK5V(60yBXVGDZaoJkT9hdOpg^O;t@*&b8Drg7%t1*&^WEw{Iz08Dau5qM}oK-(F+f zVpUdFeo{RZ)Md;J@r1|(bAuQEjY=is2x<DKw3YW9BIN2HY*<)X2{bh{x@zPo>F7es z%E~rpW}c#gXt3#*u+WnTpJ|n8YhR3z))`ocF^V{ZJbw^Y!mGQ?rr)2JX|@)MPi^Yt z>Uu^G9~m8mf_s*$rn)+5l*JXhXWh|D4_{`8lEYo%^beTa`eNWFW>2j0@S!-k10b}Y zK24Pw_$7mSCFZ#^oic5$VmS?dymms4^v3VQRQ#Npq*g2pmJ|{62V*Q%ZcFV^u5H(z zHVzIYG6T7aQRa4b8zej8<^oPEaNeb`L=9qdz4-8M71>U6@O~^*%;A@jY1{t!=_T@H zVRzTXpwWePU~tfqK%oe!`20GL!>+nLN&3`Q`Y4s8?c%%ZB!jpQ6wtStQBzgDF!%HG zV@#GhZMb*Artt2Zvh(blRzS_K*#+cjO-Tu7VD#fs{g`ZN|4UA4Z0dU-sH1;`@#a=R zp8YyY9r9aeu|Y*&tg<O(S&~4QWYM{q;@`eKbn@}J92Bx0{7FJjPw0ELn^|63O8q6^ z`Vtq|H%#PCy$iL#i3fBs7@-ObKX86N)Y77#ZggGPeEaq-mw<qPge09-<<KuH`K4C7 zA;~o@Qz#4kZ4&+|6`JR1uZ%!$=g^&im%w5Hll94hr6z}^?nUGWcWN18^XkjjbhFN6 zx2YKpNSGgjn+ye{dfKHlkOgje67uI81TlhN5r#fZDiW#i7huRngD^lLb3E;m{`xDX z3ZgR{TvIkBS?-3}Eqa_P1OEqczZ-DF@#8^I^5AHbjO!WOIq``T^7$vAgryXyT^v}B z;_Zn9u)ysehv5-Hm=<NB2hX2Bx82^}CU>3tEIhb<BKP3I*O-Kagv^zdl^B8n!cRL4 z;HNtzyCcyz$dL`A2m#=S8zvQX=R4|mR}}sHUZQ$@_AYCc(~RK8=H`LCor_B-t%N81 z{M=hl?rF=VklW#^E8>+=9sBP$QRIAqhI0Wk9GO7XJx<8tGh7YP5xk|<sIsC0bL1_+ z2@0EnES^Ec8v>r_=p>B(_;DEn<0}Lft%38@+*Oe>;|tmCV%?ZCDsBzdWjkeS)8^Ac z!nf~aVmXkj*<W9eW3vjkVbT8-pO`-9Qw<3T2{@Z7dy3=XK`3uwQBiCxQH(4%JlW~o z9NT+bG|LD0kpNj$c|$rUd<h%d(*hsksDE2MMy8f9_o=YJ+p(YHOQH}*5)KXyo)B3U zPI@n@AsG}R@X7hvP>>aZ?$)FCqI^q>6((^h0oU8xF|QLozrh3!hwM~C3D|hrs;gDm zdFQ=Wc4m&w_@{chyL0O5ur)KzV>f9eRAFsrEgk!rdx-PldPgB@GD??Q83d<N5_IQ} zucId35b_>aGnMZTxzjR2lpfd?6S-K_t=N+RgHU)JU>*>!<cE+VxxQXVzbe-9KTe`! zA19zP;{TRqda#M)b-thzbA!%%uPkRvNT7c881NF%hyk>;m9ok`wVzXQNo0Q@F#V9d zZD$Lp+b>?WNpGIaYY*!CV*@*WJ7?Ck=nN+wKbK2Yo_q}WNtB`lw__i{yRYc?W^8#6 z3Z%c4#sd0<gnoIMe3=$cc@t_S&K)Zma_iv*8Cpd5o|@UEEjzn69w!&qHJ$&aT6#_n z0|qA-{hfo`-(~8}BgOK=eZvBy?mSi}!1wPxeSSXcYOcEJnrrN*cxmv_vdOvI5MuiB z^iGC>g)>!=*fdjoi!?boIjX9*_NC~kE?udeBV>_1x#g}}^1V!%z*a+xy(<7-;eIul zasMS%)~f>V+1)wRN~KsNMt#SNQBnphX7>ki5gf0L8e@N2i}q@5dyz=18MPJ{o4pRa zYLo`4)4na2urLPl_W}|}P*B=}DZMdItQ_gQfcz2oWnb=BR=TL`Boyw2Mj04mwHGmQ z9TjendluN$)io<2A<^da`E?PKAy=$OR4Rvx$W@sEn$2#MzVxwhVq|3GD-e0qVQ-KV z0NfU`IQH#Z#9rHp{#>AG_3P~uReK3LE+vK<_hA?EMI=&fzl*OG9Sx2Ay6fk{0-+hg zQUDLHN-AVsrY5mcpI{uBDd7c~tgJ-IOjT$E;sVo7led7X>5T%G9XG~H@?&ZBPTQow zb*_gDtT<IvAHGA&+?2%+@O7W3hD!(RwPZ0*RnQ)~O+M6v6bKtx9d|^#U9T~2V^fs+ z&Hf006l$SlynolzUj@~JtYdQwYpH%JOAu3AB5`Hw<%<`^u9odj(1Eb&bOR>nT5ePB zNhiITI;_5v^StG7A*Z>IV^jNJVxhV%iGH5Lx#hfXA=TOX(g77yP@Yl{FmhkjZ)RJ^ z>DRN-0*z7`)Czr|kg1HXSFoFLSXZiyhnw1AKf3OPjuszRplw?*hRDyouT@|9AIwVH z3of)@kZyV553(a#PwV&OJx_n-e7-z=HaOLK%JR&%N7kc$Y3|B!0_c(ndEWn93VAN` z{R{H)TQ-_36hNR&z98$l*PxeYj7CWG+5~Qv8->GPOY)HajT{*%6VJ#5iFwPy3I9gd z6!DcCGOD1Mqzz<DYm<}up181kdq__Ik^MdDm+OcLufW51X`T4g)6xVLgbr9MbsVz1 zk3OJfM@MiN(mwo|C|8V-N{q)0v_-6c=Q?OpF27?~kN?I#K(F=T2%&Jhh~QQ?=fYjJ zRvf;Tam<U0i+~cf<khcgd{P7#7c+8-uh+64LuvZjvafe&oPN~(`q75E%ARqlTa>tN zz=J;9LsiA~k&>I|V~3Hfn8)A>x9jP@YFP+L3)>0`dXf|KvD{X-ClpQ8qB`_5C6INo zLT?r}KF-3Nm}sE_dlfN9Da|57SFIb0UysvYWZ>|zc$;49Q~=$@#^z3B<S9IX8AbgU zU5kuFa?#wc!6zoReD(7a7k6kNXI^q+Ty-_ac_-U61L^c`t-xRlTOE#CPWK|VTTwz) z!d`Uv<074VuA%h>!6&1lwRB~+?}ogLvgGblGdO-)3A~=7pFO$Uo_+h94q{bKWGD=+ z9+fHQu#kd0z7Ck8s?tYjKfeD{#fa8aidb~|UNA;+p)HW*v(@8<^vjk}^~77#)p8C! z`Za@OUW%&<)W>xzx-6uEpu{5!W2>)pm-?96050Xh9hB0PMbZI(A^aqM1&80$x_Xpu z7ALdGer&704zujZ12?TnT+gBplkW8eIjLb5O1+^NV&jhLj4$@GnQRvvLw=E3S_C;d zh~uH5H7;H)1a|GY=<1T-;US={sO!qjJ6S<MJ5tdQhUN(Gfo>x8C)fB$(9pP24)F9a zt{KFjW%KU&cLTO`swu0NDU-HlM30*3bfwb856~R(%9d3=2|Va%>#x~)?YT^vW12L2 zk?D&smH|YmKX5#!e1R{fH?2|*kvZs8t8$o7Vh6cq^Fb#`Tt~@c6i#2i44VPzpfBNj zYlG@rY2_&1+Lt8B@|SIy?PPb&WsPA1q87!4=@?zytC#|7>_2*0xkrc^FF(i^u0C4` zzTMsyr#bZD40e*9PezEnrD3on@)V=%$$h5Bm5{I>!DKESkNKy39O07NqlPR3=hn7? zXaSdFn!Vp!{FmfBJy{XQg(%?Dr&}ktwAs)@1NCEJ_+PLF8bWHBZOStQ#=aORog%d= zGz<*$bWXwzK4F&Lxp(4fm`hQXWP`3lDVpJ5J{9kso<EsZD<I+YIW~s9+C@fgj)iFX zS^47T{YM$W)@xLy)yre}*563;dmWV?>JZ@8W*L;Muw$5T^gg5#{1SRk5}|xP+jh+w z9W&SJ;^ys5fjo6RGIxrmwU0fl{^+M8+3dVZfO;l@bL(nV`qoZ921PDu#5p!a7rtQb z19)<w_F$ozXV%h_4Q{&*k7*s+x+P<KtVGT>9-f}Xfm9Th%;ks{g08Wy4xTFXdq0o9 zddf^k`q7%GLhSM2YZnO2(-2Ff4xQZ?yq`jdmZ`MWpQ~`Rf|5Vo!O?Ms3j3&%vr0dc z>ZAFYvx;UqRG~<!h&G_^$oF_eiJdoqxUa7du@M!8n$4#7cOU8L>ziaC4XK@k3A@N! z>Z0xVw3}hV6zb?7o$!tRexq|9_Q))Q3%+G<Doik6?7%F>9A6+W!iX*!QLRS4iw2u* zehR>L(Fn{Ea!nSGm5i0ro;LC4A|}f&l*QaPus;^e2iO=_TYiff9OOCsSa4{(nE(4j zQDDNV?V|KzcqE^Z=Svk7+X(n2xubY6fzD*QiIL@wq6ADIXJmD#I~#mD44Tv}q)PIN z4&|~QC(1CIf)S<bj3+C5dC81V(Z3;K)4Y1_;pNp)JA}L*m)P4`la^w|bM4tTs^6N4 z7%N;T)owHc&K(w29&Re-g!@_ztm9V~M`U5dY~fPgy4`fN<M^q%YA|%}?v`%T=F>Vm zq${5(VmL5^(LWr<jsED-BlD>W6Ya-c`kL@SJZo3iO7307&bWzE88kL6WOw#tuA)7? z@fYulv8~fvfXR+rY`EC!fWoj%EXY&d<@uSGRxl?HJ~-4WQwh(OLV(B1($Lacc(p!| z>btzMVzD>hQVSXwZ>B2E%picNKqZnmz3)l%$Jz4)AZmjAczSv-)j~oA89{V6pkco` zDJx65%5|Z2?C#yWPb@7hJ-sEfOtXi2LfadM@)Rz$FCv5f;`VaY5dcwqHk<}%Dt6Po zZbaN?Ak2FU;JE4C;j)gzzI~%Vp0UY7xu4>Ea>hremia$L0ESe<?4)cJg!o29{An`% zZn#v2a_gJ1i`<w;Fz_(C=qfM`i#!$Zg#uB~zvzCgq=&ovz(S36e;-KSGuZo>trg{N zgb7*XY=L>z0SS0W-c@pXa&oVR*4BW7$#SEWFQ$B?q@+J7C@E*|OH0r9s*Qypyoo~a z|Ii3U6IfmE-)XkXedDKOgnAMiG&oTnA0MBa{F~zc-p0j{8O<cM-DfFt0Sq|bpV`I6 z7NpyS=B75pym~qMY1rV5JY6a;$zaAkLj2cB(xarxo|RXt`%4|4Kzfd}$;!?StZi&e zG2uO|4D#fARH+Gp_t#`4(XDfDxI*D1#2L-p?elg&6@mSxZ`<S{`9bIg6d$ZHqxBhZ zmD@Ww87I&JFnelhYJPw|#T|Z_m6g^0;u}JO!2PdSUtbO=rq=X7oEAul!|=svcD<!* zs&Ba{^3ksHNkb&x8#Sm?YCxLMPW*P$>nWm|z<jC;VwvhgH_A4wsdA&Uz654v$+CKo zOT$dY-TWLJwk&E1?{NlzOimf#mzk#SbvJA1_J`Bg7*RnM{cG_QYzUYPQ0ftUr&Pi? zRrfRNxb+nkyZS*6=mdEv{@f~+6@^fA^?9a%SY1lV$oM%kJ$<fXZJobRJUaTw)z|lG zEJ!D}xcKn)+7&P0hXxEn;D-YP7bfI<4Tr|k(LOC7E?busqc~Z^LZzRHrd?d$Qcp$2 zsL+x}aQR+^6F_XpXR{3$Q_hVxNwS?i@u#gj6V?m?v4^MXGQ+oJ09{Mcjqv<6a%yS` zAu%zE?1Y3R^2LuIKhA7!ZVq8pEDK!$WrKTXkVQ_w&v7v0KK_uT?ic5?UDUx78m)ac zE6Ygzh0h+r%nzq?ys$4%e^*}j+~RZJ{q*X{h6nHyy?rFiZ@NC3T&Z}%$FmO$eMEN} z&XCRU;hEkPcAS=^g$D@%HT+mbZIvT&IWlH6Je&F4pOJ^>_u|He9rsZ~TN}N8rKyyN zfWQG?Z>^Rvu>TY|cYpC>`O3BB@mcnhvPGYk_i8ZkUC1hz?cH8{`HL5Rd2)jK^`m}M z3j$D=w*f#@0%f=){2R@aGOtEwe6bf$8=BiUr;hPmBrF!Y_4wg|Kl0)i%2z|<JMUA) zP=t`w=$V&0@A6r@Rh-nRR~P~9VI`^o<iBHDGE)4)!YARqP6?PYtUhrIzLmdv>m3`% zR?c&9t9)?NE)p_~x6<G5lR@B&r>x1D%iB4ZJvzZZ9+Xo;9C7saeb?F^EF|iVepoJT zvkK&r`J(%y@0`0r=gMYu?e-3~iyZ&m{Z)GB7sN#DBTWV;pa(2DJUqN_=iyP`Mm__Y zR@t*Zeoz59yu;<@4RInO9W5Y_8A6@+EJPD}8hst%yh`zZ%{;ZZ5VW^TY`(T<co6MJ zf4p+ggR);gnbJbi0K~u|y+VI4G+^K(_?0@it7rVH3=&3Mm!pEIsIKOIf^M+q)nZG+ zQ~mg|@Q%AR4Z(wx=5}(^$jDHW=ijp4yOGEk2fX|>=)b)&k{5M!baZV8>VPk3XlU7J zfF~1{CpDrw<9^`DTsGn(>+=rGhM~<<Wu7lz_Y!q`KXg8o>MG0d)Yp0t_Wo_F+Hl}$ z?aM0ru`EXvaxc)Pc_cu|gU88aOqaZ30bDOE6YV(fi3Ki`2@<iEg;zDsN^r%|UnJ%~ zg020~REka*8=Y}KAP%Qe`cqR=_dxU8nuUc0J}`i{y0(T-h>tG?08Z~>dOuqg9Zur` zLx_X8N_hu|QCcXCraBtLqcEof$1U9DfY;Z`N_Rg(tBSjWZF+k+gOC9<UI=D`t@U<} z(KTJi9YO#{4bdYU&M9mI;jW--7G9^y++3#o`ue06{jbvPr&Uwwy)ujk)2qY*7c(<6 zZB1@VuLH&3)5?GH{QYA=LsK*0fwo`$c?{~rEYN9cyV6xnKMwXC*R9EZLp!~yuDupf zsswMlW6dyHK&y}P)?<5S;HV7eRxL$0xSwW&`t=k|Wcl4Z>1R71D#gOv=9`@{!eybM zp&FnfldvW=JJeG5GwG~s{qp6DCklB@Z}q*ZxEKfI9}D{zetQw&$`k=kZ0^gT!kP*- zMAP@gP%4P-&=3myfl-c#b#6}+ty~SrSHYTu#bF@M%h}Nqgr8xZ@U<^*o4t^&&b96= z;n>jLJcxdHf<8U4w<LRb&brw<I;g}kn!`~sU9n-env$4!ydK5Z`rgEJFxKys9=_!0 z>WaFX&f37<w$p-a_I$7%VO_*w*CJ*!2_tLHnYr8(jG|DvZ)H<sCjU-j8{NPay_l{( zH2t-{>yJ?q6)8!dv6(MzM+M~4UlN(k91>Zcu}W}lZXLCp&0n3dX=SN@|Ni}?vGZ!T zd9Qn|KSd3)SS~x(d3=#KmOs7+*^Vd<3?{V<yEnvIuKjvo2h%y&oAAB!En8(fOF@Q% ziH)OjBJ*;hY#)U(V=MgnZLy7eLymGjmPJ{g38b;@B3z0VIxcv`#QAu6kruYLzg!f) z%FnS>Kl}E!;ON&-tx}{1=Dmxsw#}YnRwnYqy>FeJo!MaSa6!08@rN(Vy|=T&?Tevo zz%I9cD~s1-O4YzH%x3>fXlJlq3l7&bMu<=O=GH{4L_v<V1diJ2<r8D$FD<pTNBv6H zN_-i@(6SWH>k3tvh($!XmADg0n0p=``Myz$MMo(4?Ck6{b(Nu^VNOB8`uB*42+L?4 zGwgsJyl<6a8{8Xr0J}!Vh7OApErV}2gw)VR_VeIOg_7!Kq*UVVwzhq>f4I7BOLxe~ zE<S($oP`ea;-0=XBCATJ+PS;aim&>L_CvR`$_~@}7yv%m8DfjhZSLUXi8Vu>7%Ov$ zZg9O7Pen4cYt0;9t{T^wGMQ6!R4WVYwxN)O^RIqoMvsrrroGS1ybk;N^?|1uU-RqX z9Sl6fTsW^u6CvQTcM1i<=CIVSwKoEK!v!gDN&KNs?6ZfMZ?DC954D{1WD!nlXPqEl z`QhW^v(C@=xw+Zm`tsyjI(tup``~fXo(vkiG;%E8poUt%!Y}7!ytvyJ|5Ps7M7haf zqL!pktL@2$Q$nDXO6;xRa-PP_Y}m`#+<OMi?9(RbyOJwu0BCT+<QVSW#Q^V5jK`0i zY$#x~@-wruQI<v>*d$t>Qx#eV&9)=C7i}%x2OU@C>IVI%TNBwq@7MxYP_IUE>j-&G zzaZ@E1A$?(rne&m<eBlTKj38F<4KAV;z07%^iKBS!@gP&KP84h`$@~sPjUy$UK%PY zT=p+dwz&ZKwkBtyV>4(a&ze9Jr9u9tPtx?C`J}%-o91Z*><$<Ye%r$QFK)8a_p|?h zxyhNqcg<4cm37q3XKJj6$HrEMEMC48+L^9K>+YG!L_cPPGUDWHvZgU|veQ7_X+KPV zmmz2#RR7$uJJ)@KmM_ltmwvXl%LSqh4h^+|7qy>P>wHQ!YMqn0@t{LoUc#H~BR=8| z1iqql^x;seX^ahWM=9J<mJx1@zhH+!j6XFzTvgoA;K|lKSDf1l!1pFHSuWT-^Wyr? zY5V*79Ox-14B%TM)6*1^=ZkMT=>7H|>}S~Qifjl5OgAdG&{+f+FZW+^g#@zG%HZ(h zD!DWN#Ft5=81b^SR6yirExg&DEcadOO<<;*d`(Cr2IqAUlNJ{4s$l&nLNSNe)b(V9 zKF8x6bmBpGRi`6vH&knlOZ9@4jm=9$L`3@0)2ExRU;dR_qNPkKBRHjr{R0Jh=cR|m zeQbJtK)N@XZD8RqE@|-Wm}4>U`SSxp(2(?Ej%@|)N*!)rwPbF4@j#@XaIzG@fReSF zOFvIt{U`f#_5Ul=%qBGMvUTuD`VsaX);Cz$)a308?uRL_R#}Y=wnKE3s#gvo*tq42 zhgrE91%5p1U?r$v^E}i_JG_=NH2m>(WMsr((&;AWJlUGCA|W9`G1Z6$^*u>DTyscK z>i_vFy^4w3JoH|C4_j7MD6uF_?_1nwb-6lX)v>|nszZArJ#@Z1djz!Nt7a%?N5?mX z*#SQ04sEd=4gcx_IBXGh&d{cHi`<u3N-nlLAgW51#b|qiq#mbROLQ+f-`bmA=p)=q zY!H-=avX1+asS?ZrADXfw`O)LSMY@!<txc7EGjB0y7CH}QVsw#bdfKOjEvBLaf~#^ zq{=t_Q_EQ99eM06ux04LBka3&4-)Vq6OuQ!aH{6_eD04E8|4Q&Jb2Q*L<_lfX{4ib z@WRoNO9BHvPDN^f=u|~UIFm94yx32d@Y*#}j-xZl$j;vLVrOIPk>KawzYmzRy?B4e zjMMCX-&Dy{yq!G3=ja9;?Mt0v?8!dR!n5YA4bDJO=5VIXbXBb-KIeA9g^TJ~-BS&k z)oju=-}^#BM=h<bt<k~3=<icggFyIS`tacc7Qmpf%9z~uB=Yca79s4js?M&4fl`;U z7U&3+>tk0<);$kahL@D31`w0KiY#oh)H>+Y^7)&%$Vnb0{*$;U_;FOcKNpXuk0TDj zixPzr2$MOlO629z)^#D*Kw@HP=88)zA!XI2w9Lg%rozPDf-Q*kyJY2LZEdX{Oqfv= zFG1<@Hyio(`Phn?tGQ3*)IH{8S^UF3x<Sh(=eT=qDo8RY7eRXrrz&-!<H1C2p)Ny^ zFlGaiYmMOH;oj~F->b>=@a$^@n6%CN9dwb`_V>>u3?b3P{C@xb-G&ac_3jfKPTaeV z%V~DiKh@W&J1A`4LiEvRoXQ2)u*F_Yd-$H0q$9Y9Z(Bp4>gi&gN-m&|4k1=r^E#XN z-CM|(d?hFh=CP;~|Fb!-mBY3Ed|*G>)VPI6aH4IaBJdEWYSK<mib=nsI`oGJ4XJR} zRB*H=v}kP7(278sy@>vHVk@PpuA|h9iZN^gaC>^JYCMvV<01!_{uH@`qt)@~;_&;O zOm%g2#Krh{A_|CITC(Wv>pL7A9ApiTbTv<V-}k0ca@^IocQDR*RKmWDYl<*L6r()* zPRJq~!<9Jph3$ekYqe-kz{$VDTvxb*y?szxTAC;uD{G{E=3}ShEx7=M)MrjioGN}f zW3-$7@oI>ubuiip{hN$$zbFUCroqdXNAlLz*2qvJJ-yZKtt}s7VE(It#K*(>M!y6b zfqQ2Q!yds8TXeNfO6ucn&uWNhV`P2mB09*@#q8c?ej3@{Q=IL&1~a0s5_@0XC8VWo zxgLPDH;{sc#t#peCJSy4TL{0jJz;-~kl!?$_TONqr-I~}D+sqsmB<<MCBOJpKcQ9M zsb%a<^GHdH+o++eys*%g;Ha^=nR>F)Y+>){V!rdXSr~r~vTL=2-hq#vUkU1j@mL_; zE6bP1Ch8^*z0Clowa{kI-><=-7bUtw(KkPDx-5_G{U<ie(`cU$qgOS4vU<six=BTS z&+|WiluXacYCRfA6*}we>FJnn@wEj%J!Yj@TPqa!VrhDPS0t&DLbdUxl~c;MQ9Y** zss6)n(dpaM2XkR~tN)cI$aRfD+BLIu;O*ltO;3$`7D3c3<e7Nbp+GvBeB%@;mpSOj zfh1sB0aku7ulKPWIm_C}{<M*V0pjV4pM&@#Z4QU=fL@LB*NV)dzde}$X6p=FHJ3vz z(O3d36~Jtrgqh*atn<kq^&M>|&@cL<GE{&a52Uv%C4eu&nV_%e;tFTBPv~r4ZEbA4 zZ?o=CPGV+ezOR$0+!q-Pp6)IeX`{wh^A$GmkS4u+(!9L8PX7Ma%jHIm-LG0q+1c5f z1Ox?ZUi$fcNk}QUb#cIiOFi$5P=V=`5=IIXW(IdvtXuxtn3w(5l0(!eZ2rL5OVNw5 ztpw}`?TUMB>EXT^`7f2Bsu*Yho##U~fLr)oU`pqMF^zljyb$_LC-J49lb*miD}bm} z>G*IQ4r7OSGW0BUgvl5g7;K2v`&}H)WMyS}K!}Ki_d3t1p}#M1QZf=+u>m^KS9hA+ zF5UvSnCk{$B%LWH^YDtKPq=_basoq#0-Oq3{PgM5Jpw#DZu508S~cGs&6iK%HL=XB zF_Li(8vEKx4lE`H^bTm~gHF$i8fdu*y<GILpak}v0fW0}eeCa{b!2({=SkqA>?ScQ z$5z=t5p!Dvnv0gs$Hz&H9toU8Km+KZfCT-Oe`%!>-raqoof~h*6MR$Y4mOjDB}GNv zpX%#9ey%2luW6MsBAT%P8wi7bsE7Fu=4+GD)ocnK^_vPvCfId~)6>_#%;e<ZIcaEY zl)(phY+5>xhsp?-mN(BEX#i79SX;HcU+O~5S>W^<H6@7cGuZ}2sdZ&V^$GQ#r~qE( zincNgSl*r4JdefRNur1NL9$LxJL8Ls=9WsB>75X;#*vnpl{E;3S)d<j-aD9sja5Qm zBh6o#N7^V(?&^s-p+*6iv!vpMf)c4J?E9VMHD<$)Y$l+sZPZRW#0&joZ*N}+)>GcS zN4vhhuCn=_Mp$Xm+%0a<7%-0kBL~c@%Y@uiu9H$vmbLw>-J}@*q*DT2jQQsx_wG5B zl$XyHJ7ABNp;>7WEhX~;VAG5=!R(d2{iYfgAzidB-A%CgcbzFbEF2lp^np?|Ixrgw zGpiP@-XS%ML9U$z;mypmaU$e7=xHF6R7;pQDDQ4`|1K?O>!rkL<Dr%N!`X0Wn<tcm zPKFOq=*!A(B(ID6%9gV4ZNmw60UfHkBBI9qsJOU5kF(u5v*L=1Q|8j5qVqB2^;I?m z#!3`QuznT?XrlvW3dR-7S>m25s2)rPcJOrix85h`*hf@kscc=-5h$`V+6GWuOY6;h zkFLZJnm?qt>n-=u!#t5yRf*|=`R>n8Z~nykz^gAY85tRyK|zp)t50min`-Ydsjrb@ zRX9<fevJo&8y(-j(j3q2ATiG$wu?v~^*9OFmCBvC%EXdqH!?g`>@-z#x|oD#HsM6g zW33m*kxsfmasH#zA>=7xD}U)km9-`T0ls7`N40!Y_4Iw~+Ahdx?gK3q#&CAudaAVp zS{_Ar%<q}xT};_omvC@zX324Jay~LNGHN4QF4l?kFvrq@{21Pw&-|!%zV>(HiWy|$ zXpU1A*K@0@EVB@v<LB%$o|h9(Ah3w+a(~VDNJa2JlLF;DLKM4cAxF``D-5ys6N{H6 zIuGs%3Qiq`U<qXbvp;UviC6~DurPLsSIJArW>MML8>H-){=19CpPrUxes%g=X5Xhp zJvdmJV2xbzdW)Q<lK!dSgj#x)LP@sISkj|=uL|Fv6gZy*5DG&@YIggrL`k_GKnMhC z5|_UXEe@&}V%@QqAr)mpU;mzd)}1Bg`>?OS|9aE;XVZx9#_)&2X`793F$OcHou3fT zQy~e+t!*+|4y@ZM)C0p0Z@Z$?xXg);7YY9?(xs)7AFm5e@@g?8Y-y_0tY|uxt}?yO zS#V~H&&cq*=!_sadinC@bt|_)mH7*I_e9$KAFj<W6TD!V0bQC%OTr<R)=NBXHEd<r zNvFnrL4wcp4hm%m4M%(fu2#A`QuGtdHfsx#V{_c5`;hkFO0YX1v$M1FGv@eXcPEX9 zZpYiZYH5SnGDGuo*usL1{<PB{bYVXAqLyvVFf%1f%jHFIOOg;L3k?fn<l=Jl@${Sw zWC+{n2|~0I0@;|b@2poDDyMulHfTE6T)e#V^D{FS)+0W|(Q(XhgZX&clLz>tF`*tJ zs?)6mJ8%N+62m=cKoYfxlXrDX%UmF!tfqEre0==NeE|WTXr0>xt33+8C4l`gS)}vt zmv$s~lz3REDbSsqv7uu+bp+8mm(Mzgp`do?NlQ<s2b&&8vwWPKhhU^4^^I4)hULMh zn3}Olu&Uxm+4&@AsQQ`w`@v}7;WzO>^s=no$5u<3(gb0`FYNC>_S^I~Pqa~0Dr5Rb zql|O50*L>Yt8g{+{;~Z-r?YJ!9t&_1O?wA^(n^y&vf?8Q3j7e7&}VJ2{jk7>3N#5f zT<zFM@_nYh3$pcJzr4V<#9$k8c5V)Td#VzZH1x|T^f5NUN{@@GFBuTve73Fpb)+B& z*)<@}{{x${*$=E@8q#HDN(_DJu2oA8hn3=h);PSvq&cUgq;Dwb58q(hfi>}!F8Z)L z$@lnTCvBD+c$P)S2LJFsQjWoSf9oE;(J*X<3@``kOwfG|QU-<h@NzIn3G%->&E)0a z_(V)XQrod|aD3?}Eke2*RmGP`Lv$W~Q~gbX_{Kmad~dL1+4ff3eZWmOq2|(6ppdk> z*sn|bbIgCQf8G77b=)}dN89X=MCy;!=slAx)Crebk?GF}iHSi8hHel|@8fhs75;DR zBd5pH2&40lw%O-Iv#g#K`%|Bm9?F*3*w_oB2B)X@1qI)BsEy?#yant-y>7~FbtUql zAVYCu_@7(KSnFZNp0`1d;{rEIv;A$QdT$>4-}SLyRi8dlf(1kf*gn(Au<A==fZUr? z5Mp`H7)i&FllD4c7v>&jLau}mBb@Ovy6}<AQYN66&bZ+du0de0Le$sScV-P8MP>Ka z*rV4OQRT{C6STktc>lDM)<fcK-}#d;<3iRQ&Xu_0?VA2JSX-n*5NIFLEsVSO4D|K& zui$VvbTSg;7K>l8=xLB(sI)7}+*;=RDLPx*<d(;rS@6a4h{_T_9q|BSbJFMyrH`a$ znO6eeYzIdQHac!6g-v&00+LNGbDy8Y(%fIR;5ml}q3z^`uITFO682xhRIPc9*T2pt zf=<9!y7CS-h?0DSO?Ys0aP(u=60AEyDw>+RPEJmKA8Tqx7rfQf)LK9Rq=g1oeOmD= z&u5X3D)k4{P<aSXQ3*Dqc*>@)z{;a139%wNZfj~f56jHVY$nQfpMnC-XC!NM-~ZK@ zqUxsu;sXJuvm|1fcQ;jTTTCph6(PZCvPs}yZU7c+!p4@Z$Ui(He+Lm671ikF=@~$& zX2ZlBNkq!e&F?iGk%IyoAS%%!GgT39wl^~n?+X0d;**m--Q3;pCD)%IkpTuRJ}1+l zW!m<h%uK|g;4rDc@6(U`5kaqY)-r6|_hT3aOKo?_dhHbR+$?Ev4&G%g+yXP0=>=MG z_g?V6ot(tflDR&HgWD2wc&!AJ5H;!4>VQ&kL7C1+Ok4D_yH#KJl2Dj)`kJa?k(J2U z>vF`tru}vo;hDr9TCl0%rK0jO*VJdiB;~}UFfeh<`S4+BWXqu;4O;c;Xk7-ZRtp2N zCONMjr7Ay7WtJx0K3l|;U&Q8D<4!ckR1{=aG0ZJxgZs2?TkG?+rY_Wvj@Ra|IQ|vq z?T`Y;JV*+y)79+hg4@e%SZ!c!y4B-&W2Eb*+7kxWrvDB~!t4+750moz1TH^op8!`y z>XH!sNH;M70^E4P=q$T~SlJ1tLUMW`e<>qzP_I@Ecm<Sw?QM;CgLs$g$7gF}(>gUZ zm68x24+sef#iyi*O5VG73;-V^c3|M5=K3X3YwCz{^tFM-9^e4mP5b9e+ZWxThhL{6 zE3*Xkwcc&xG(FObSvPYX54iFg(^@7?IUmt0Ssz3pKm;-~ZgOMH60q#i1~<A>uXpd> zncXHbi`@Q<>@(n_V<p|i78}>AOW5;P;2L)qA;fIi+}Cc{Au=a6^8r4D@jKEfZ1?x~ zJD%+=pag8dPTfECzdYgisFe0mQLK%DF+|_>Gp_KQlMSw+9_h*QHcr|6UO4k2oC?hd zmGpuf^xaOSg%4`8%^p1(P3LPpxAc5<U*d2k5D2SmX}L}T_M<m`fJV*rnxpjs#~u~` zIxF`Hdy;K%8C!!59l*p6uZxi1QB64~l4&VE^WAGX+tbRDOa;+to6u(g)cH+*7cV$~ zFZtw8T!Yn5_&#rEXF$vDYHtx$zbJp)l3a@9NzCEuO7h|{Xc?sD^-qqScYL(O%5Xf2 zEA#5B=F%tbOO}ca6>U*Q^K4_q)8MJ^MSd4HQJSo*tVl2y?h6EZ_V@XpSzEsXi4=)K zmngr6`r6kgbX$#5&wllYY*yzz)RAt|9cJfEAi{tcVikCp>(ds|EeaU?2eW^fTg1nM zQO2U0=?|6-t6(PeMcr?oN_~Ed`NG!qg7xlQT1OX`fTFUpfd#jy$VfjE6B8{cT!O+e zOt1AcnQxRkbR9{pc#-Rl7$i3@e-i%M+q<yjRYCHE1<`1(22I6u=Y#Ye^;o<AL*lpm zFB1RPEq+|g;%K+HlG{^J`9EJdpXl-&kdV`bC618vC-XRNZ*Hb`Ab#)ehMsIson860 ziVAd2G2#^k3S8{lhCGZ1j2=85SkJUIjhe{?r8D*)@cA#CMd3??)_`q*^V<+psNH99 zKNQ6xmA(hrao(NI`1VJ!nl6BYgJY<muy9ZE<@$gWIQCNIwKqQl#v5Njpsxgg%J)wK zBQ(~yltynPZP(T<5aJ%oI>Eqc9J|EB|Dny{Z`rvUO`DJ4Ckm-wyXi<1l^Q1A20eQb zB6G)9Q8N2dRKqu(hm*fSi9KhE#*PBtJy_{5zXd{>QI#XxRs#ox69PO9`vG%+C3>f2 zb2;*_LWxT$Y#NBT0dZwSCw6$3r_uEv<^yT^pQVs+7zbF?D5%o8p%l5{vj0Ncr&;3S z;_I%UL%!DAtD;G|mQcgQc#{s`b~)?vPoLi$lKe0#E-FgG$jq$G8?>CCn^uzJ;^MkQ zM@R3_(9^rF=5NXcd<k#=6Qakrm|eJWIdiap&j8G%)b1?Igt`GNbbCq=tIOc_P3b4z z*)KKx^kS_-w@@>`DjIakI$jP*P5G|%CHV<a*286lT<p3TQJrp<M}H1A`HKeO1N#$j zsW#7}`?x?Q6h5@$89bWu4v>gn0c#%FJlx#J65tJZBlYP{hbMUodsZLcBVvHW7K|n` z^MPVLq?Ij5!VC*039zTY$zME>{)f1)_%DM((oeqS*|FRdXo@Yho}1ea!2)k2y4jik zPF>8j?!_4gAa)Blis_6|pg=<~En#Zt%(H4Y{Dr~o$r_9Q#^4<XIbC{AGu>(F$km&x zZFvHAZ#uXZUjW{e01}fn`oSB<^Ojq{0swo7sbN4hu(amLLCxGPaB=q^9=+D*y1Mb% z`FZ3$ppF6z*(uaf1DCgXZ|1DX(z8#XU%=ra*`^{>JZfd9!i)ZddTjJ-7ls&DMFyTc z)!vPFItv^bA?P3u7lJrUA|xn?C}z2P_q(Q+mMsKc74q$^J<~oBc*W}%-vUwh2t|IB z5vX59PJfMdyegs*5_)zkM%D%N;5R`Jp2embEKy9BJv~~gcbpm>e#9WJARBhWBB9Yz zT|slu_H(u_pVH946i5!d!o%L0Qmo0Zy7VoFZ#be4<QHb*-uvc~FF%%-<AXAN@;PYc zD{I`p6CS*g9ZsG09K8L?rV*VO29BK+2-6E!{=Gj+zw!~eZ>jeZMQX`81B&)e5W<fF z3^ysmqfFqKZ&z`NyJa{$X&lelz7INKrSLtGs^;Xs({_G-{sg>fuamYML@dy>K|{Up z`sz#u4bWg}wYp$imTzhT8Shi40ML#<Byl07BxU|rSJ!(B?CScqgrS$apNx(jO?_(X zM+}y$@3BfW2Iuu2{ipGzEcQNDYsD8(u%$_A!L0kakKgC@-OsG0<k?eZEzpVnI8#4c z<Y2*p4Zr}ZYGRuQo+uWDI}^NjpZ(tfST=`F*<+pK<>75O$)Yy11@i(WQJHq09bM?s zvKlLVT9-!heRS}|zE&EM4Mo7C=wVvJR;3apg?5I6{-MD^Y0sth5QTMjEiJ;bzkt^X zt8N(Un+zj;yCP_14qG0*3<a=KpE7o`z>S4RzdDu)R_eS=3Q7v9mY{GlOF;ZXO(VfE zpMOm@%@CEy(X*g}{TLt(c=YBed|5!Ls0oLnZi{`SEv`7JT8q846mn@)RFH|#*6dzu z*4_&w?|0r6e(#Ud`8>7<pZZHde$-NJJCybI@Nkwb(dFM_+RiH>=jRU%K>3fpsq&}X z*9GL+V0u0IfUU)rYsI%O7r`OT7PPv$+Rvt$@je@b-?&faUtfO%znqVEJj^w9Ni(pq ziEe{{G*aZFKtrm(?oveboS%9}lt)J|bm?1zptHxNLtA2iQ9@Si!e5Jszm%=Vrm?wS zJNE=DxiZ0lsG1)eAqYw)tipl<%ha)sj*j@GBw;BDiEWv9`QtZ>*+sW3R^A0#dRJdW z+^RANU~h;7JRw$S1WVcP1`Qkh>vrLXT@`Y2r?<}^yG&Otb)BAiq98OpJUrUEx<~7s zoeI_QRzbbkNQ<Tq_HPg*9Z}zJ>{!X4bh8oLB@OeFtEaeDUdVTE-^PO5qYUWmt$XDc z74=R{Oq{SZ<9%~kVD~>Ga%%ue3zH|-dVDRDO)r$irKAFPP$rR?T^SS~?~_H1x#Gsk znuFg0@`Zq_-vi_0dTsR}A(O!)AgGyb?!G<n4u=V@2%mutBt5o8@6K9=57zg|aLkuK zULOHuj251XEYf=>JfDerfx-pLIn9Ha62Ht)f59%Q@7EE}%4<?qx5T54_K)^GH%Q1+ z`RFIk&sQ$OUdQ1|VmQDy04E>O>k^msyzn6h%96Wm519r3UA}z0rWOB(=%r5W<Vdn( zg8k9zi{M=g!M+`|@xKgFsm5u=R6uin27`OGI@ufWKkV4txTK`~%@<nz3&C<i1*i;m z_Pr%rq_gAjL#}eAjuK^Ffibz7zKDwv+ShI^aK=fA;}5<2K<T=X;-2CT`&wAH@=*MZ z^}an3j*Z#{C!S(bz=@~-FG*f3vSfMV{C5R3kF;0UouMFMdIO>&3YDIoZqXA<%P%dx zizzvp`Ro_wMxW$ca5<KB_%Y;ddBTcyb+lU>8Yr9sc4T8a!UzK!s;Y*wE5TOG(CP7U z)ym`M@6SkQWrU=Iqew7pKUpy^)r6U}f_uk#IbpO3e437We`s<x6z@DNCK#Lo?g`nh zfcGLE)z;L^)7}K##8lMOZ}Qbr2uwb^+b2BbOSl%=4z-a?3LKrYS?3REUz3M&N5|t8 zVGsK^>)p+e%W<0f>`_T`|3xrQI*6%Q(~9^#;Qa{30GR04?#ur3ub(D!iQ`lmuPwQ| zCZoao0r>8dd_to5w0}<K2FU!aYh|OxV^_q_{wzK&rQLN@!Zu)r?<`-EaFta%vpgXn zSlQ=zzlS*-*k8fqCMMHd<)2uQe%{sHt%*-Sz-sgC+4)g+V&XjsDXB~hpu^@?dl16O zwf5m8!K!UT$@$7t=C>fjy4AHr7B8jo1P%Ul3_xcV&&W34?aFHoH~SkzmCFAKq6+Nd z@!5K{`UI<Nk4(U(&4$jiyAVUI+{;B4=o*;L^U+Fr^Jm?k1Lf*$gY$Ni&&gJvW*_?7 zN)TfKU|zXK*#?i8UljVcldbS?C%Z!;znsi$$Sb+vu{||6X&B}^7v+5U`)_B77;e+k zqqcVEn%f?kd}nn6I5|0yb%7|PEs(<j{nnoxT<*%-i^=>J`JQAkN5wwEK^xwFU2#V* zpP!0o!!5DBYl_62YfMDDh9K+pUz`l@*;ow&!MZIa30;TFlBn12&#!sPalBx6;%o)X zC{pPtD9oF)U9)>F4p+1T8d{qx6@F_6usTL<P*wSKQoGA*bq*i~-zl~TZ)oTJUPKEr zHI|Y&J}e+v_&^q~vGN@N$8Ee%Za=+fmcMu!5!~OPcK$zL=SzVoDCEPbV^wGMY}f@+ zl}<H2*<iRz2$dpr@M^Xkfv7c4H9-A6_u10NSFe+!Z`G}9mH+_h+0AnSJ~6We-Dp=U za$aMVXS>x_>|j~^uL<EF<@6jjRX;J!Od<NXqE|9QR8?7kkgsH(SC*m0>eB0;ETQ&M zs<%RY5nsM&<oFz|f9I=fXb8x-9vL4;pKWwS1x;;VmqbBE=m@BB!TF|F3hM4LQ{hFS z)JdgFhv$R3{I74g)Yp~I2~|``)!L}h4~XcTI28)feXvyU?=fMaxqpla=f=|xXhk+s z&<qUeO$hM8ea4!$bR5MX`dXs5A`N;u?05n@*4`)&cZ95Yd%Kxqd_2RxpO%HzpTg`l ziPg0THiiG~Koju&=|H=a`O+HP!=gY&fMl~ZHt?9Pjlgf`P?!y_<VB1X@|dT4$MwYZ zL$Ef^8(UmMXBoZAulyf&IQ_>WsVj06R*Yt#2hM69ZwUfUdo2@*dR5fbX)@B%BCRi| z{>#WQFG|}e)(wN74Nl}aTC*yqRFHhJ=-1(%Tz1qytZ~2SXO%@q6lhC<@%%r#YN8K@ zdrS3dpSrLU5}VH_)OXcGeIwCkO_Bm1l~HpXZSV(7cQHHh{kQ-d^?&QwAuv$;7lx`* z&;be%86#JrC}@E3MDHtTS=Rhx+o|xJH2*FfX6MZ1=LQ&wF26o@oIe+yR6&pR47f$k z`{n#}*44J4py2Ykjjb)p!p$vyZeBR_t0?aI%%ze%>HbQI(jbX>#g2}76wYw-n>%Q% zM@8uW0Y2q5x@NjJGLhKH^f+$l7S!rngF;pKN;MqQs(=9&Ae}y1_$&fu0nJ9NviY`N z|90goEh#zdd0Ou<alScL=mp5uS}>2$52FDlK$ZAqt%G>jjiBvy*Jod*MgJ*+@y6sv zE85i^f+NnaL_lo(l`3Sr8xa>5*5Z3MI5{zaZ`u~%kFkDGJkqCCrcW97`$na7Z!0Ot zeFg(#`MY4co0quoKN!g*%$~M4uo=N##&eT)#~MuJ27?A|Rm2|?3Mxj|jT$aGH7?*p z!p<p`>;>DO*02#6HqX8`k<j@&ME-BN^go>8|2BvG;YQJenphTH9Ta#XAu&u~1@E>Z z`XM+kT|2ccHF!8aG9nNN!XB5hlG2M@_P9hcoIhZn{bscJ57_@4Z{}xg{Bs6;hCr85 zqf5+@Pm8v;wwu+nXU~3tGsVn&8svv7ilic6ZkRxxK0T?GrZ`TN_4~}w6Mo?5|Le?J z7#^pYCWxkAA$D_FRCuLzR=x*9U>d-_IDn9j=bCAC#Dakn2&hP^twf@!+vZp=Xr%ql zYj36&B>Bu*{Td1j!)PmiI1{0#4jM{h04Q>xmFGFi(gW3alV8vD;65QDHn#{)ri|CH ztEYlC>#uVH<4=`d<B>odu|L{aTepDqpek4@{lAen!lO^$->Jn}C5gi`eTEb8Rv!(! zD!OCVoq;}GVq-JvVvZXX<6U0iSAZ@Z97q|&W;Yq{jG_Ru><Q&VEj$^)wi=J^$(9$Z zy+k5Bcvu89Fz{g+H-@v5YS(xVEKqQ+vGmK(tX?3D=jTnF9pi_e$oHg$5whNH?Y{^P ztfqjqs2&Z?2!r`>xpOZ<U;y-wm%pF>8EG&7Z;|%+f$M$X3m&k8v@nupMEH^er+{oS zo`3AlHNDMs)DHH06PrNGke3){oq?@QJ5*Ku;f{ii5ZK&oRDCE-A6+@x>}ckrT&92M z;b|5ES<n>RIX=Eel50WKY_S|5x<A{<UE|u#eG~yXSAOTOz;a2RFe3{F+)!$*?^Uf_ znycsuTEW_aVGf;iC?5I|D4;|I##V+iy$0ymtA9V4!~W##tRqd>QTmJLZ>nwc^2@3b z8(|=$o)bdiIg$4w8Y#Q3k;i0N5$gy&%hXYU#V|$316&1SADyuO8vODq2{uXt*M@^B zZ=%Ca>~M&^czEgdMN&#~a;y9P;#cqFM@B}}PO}Z=D_aw#agp8>-7;%Fr7Fa7&xH|I zLM|A<zCiO?mfbO*L9JK&a_PQS5zXs_19StmoYxCnDExwojJE`2X4kY=Mi)z&qmxne zyI#yldor9b@0-}0BWMZ~m>%Yx1XTG!#WC@LmIl@5T|GT*pTQ>@RO&scg>cA%j&=4a zXwTvS_abgi->@P^2=poLM0HQ>$Ne6l!+@cxd}*f{uj#2_Iez=-??2s4$1+ipiry%0 zu#SJ?w$b(LI#XV6Z<%=hiEcXuzrC%oA=YH+o8#tt=<A^F@cz^HZXBBJ{hLVma=&={ zyTcny+H4a1iE4M|o}KcdNLZ(WLX?vU9zF>^GI{<S<IfV@MyMcOC17bjtY(&qsbx^_ zDrt$o*r{Pq1{oFSSIT6ePGE?SPffirH8V3)l9Pji&liz3HJ#rF$0g7Jeybofr?m7L z4bb<)I91drxn6k{-!s3;(kzAL)ILh0D+Hw>^*ZI-8?QA~Nebjr-dNfxDI9%OA{hph z7KD3K$tnCJ7`N=?=@RFkB)zM3a2R|S<!v`ddndvyz|-@z8iW^?8d9*QZ2tR4eOr1) z#xseW5NVJDyu5r&5%87hvhuev7QtAXN;N^*p;l2vRqr{o`5L={Bf7mlEa_kXyLz7V zQx<?Vwt8Eyt)FIz_A^eDFagJ8P=dJKQfR(43_&6v)miy(O7d##pOoai7ho}Ia0M*- z=AJ69Y?tZOcDM&P{u1YRZYSokC{M_pFEZFW10UjoZKOi9nyN1%m|xKq+cPvP^6~%a z<IMk|-v226A!SXbY{`&iLX<7rh_MfK(Q+**jU`>egqY-Z8FjN{xz?g?O@^9mnZel7 zn2SrHTPQLLap#(>LzHFay6<VZ&A0FO+x!Ldczk|%o%cD<bG9ujgyd99>M&w8X-xj4 z{Pb)hgHNW&B9vYRaA@}L^t&p(8M6@GK)Ae}@!Zvq{ceyB7nn@bdtTTVCU|$KI>6yp zOB(&$G};9}UGlyB8}OaHdev>+VIZ=iogZyYUaqgN|65&F$5YP?iR^HQ<H{BVt-kS4 zJa>pjO6^v*8(XC-nl4@(1*n~-tA(nh7{M!bV0dEKCi$j;Yh&<ls_*QTAX5kWzd8Am z^yP+P-$z*p=kX_mA7-&Xdu3C8g3AY8KGej_ld%3fUq~(~fv&5juOA+E>eOZU4Y99W zfi2CbVwa|#*K!MsM(I%_ys*44{_C(@gYKzR|1$leiLVnyGWDtTQLlBt^lB90>@*2^ z!S?&{$NPZhyK+VLZgKIsGk$(V&#tOLitSRnLvBd#sF}nn(KvF6(v371zP<}FU=VZL z*^`L)ZjK^i8YPz07f(3_4OnYr<m5z_)z>c<R8|@^O@n#~#>1mOd&)q4p%p4J<z6<# ze4z2!omP8E?`++hWSWzWBH1i?0d3M1TW0pzl54`{MnUHFJ-tXhS8f3rhTu=mOYcCR z?E4e7Thfk<BuSGn;eYKvhoNMzs%WFxzdBMcq7$LQ*W}@hss8Y-;7u6i^Rw2z{n`S{ z8VMd57~j~~*nVK5aVDEyy?R9kgD9Bg^OiMl<(P%@t_{5v5^Ql=6=##;Bt5Xuc^x+; zKgws%ngkG5Xz<jmQ{BAu$J=}0p@py!A`$=_FE+)Xih~ox$q#5h00x-6^5;Gdh`8@) z_8-LKqoG^kSi(az;pvA^T`E@^*zI;!?t<U+_%jxw9giH$!XyDB9_E{+1>{DN`Zw%_ z0Z})Alh;TAOKkmp9C5>)q>#lt;On?@LSCB)L)e{%+}C#fm7~hT0{8tl7Wfsf_djcx zA2d%Z5Kbv`wqT0|1OdFf;Tu7~)%ni1(R&{suXt}-*w3$tqJtW8ly!GJW@E?Df~oFN z4|xfMq`K6%YMU%NC!<pm1pGP}U$bd-9US9H3lwH+ne!(M_7rh|8o})FCb`_$=c@vI zhS&AuHzyxNF!#~0T`UQ@OY_7A{O#_1i=1NxJlsAfBonq6b+QMZpfuW`SBynP3`)!5 zvctEb_|QFc{U<*kcV2yq%8aWt+y4jaI54JS)tLQ~eWc6y7`l!pf?~MD4%Ey_K|1(r zsZ#xTqQHI)T3Oa-UQ86SUMp(gYKkGPUW)x5^f-XekkI2Z{#%g&hY6Y^q{fZO`bmK( zX<{5@-d%0?oZDjDoe5z8-y3(P*;V(5TfSk$tY$J1)}nTX@n4kCv=~rAK5|BiglpIQ z_V2`U&wpGxQQJkkz?GWa<pjn~*qh3+PetT6BCe@uB<q$gyocyI5LtUD5H4S?kfBm4 zs?KlvmwYk(J#W+$y}SC+;6UTNP}0TS$Wz?|+Vm-d)h*gnivlvF1pV~$vY$6hMteuR zAfNYH^Oh<JA^6XXKDFZ};MaiHBcH5LoS(q&Yml83@t<0nI*`2aQ4z`U_phvIn6Wx> z)6LwJ*G7Lz1=rvGTSiXqG$<r-DhF0n`la_I>iGtE;>=4n=)5|7w{3@LP+vTJNPuzN z!n;-11hg&}K<jez#UU^>5)69dYz8$rNcGZ4SnRAI{ohp)<B;aj3ID?2EwZ9vbv1vu z>65n!k}Lpp^@gf-4=(g2GuYqApBYStIb7I-S`Rh(o%Rc_`6(ygC>>V&Fi_rb_rA;{ z=G@Xx(S23ne~24NIn1<j6@0?{0dXYmX;{`$50ZR*xp%e)mh^??<I(#vGBR<Drnogj z=&AaRs?2bfvcN47h?Yb>#<V(U#F!=KCQ${uUP>VHcoaY3GsT~`FdDqvJ~c05kqCKw z|9#_21_QZ!@^GO1T9KzPZV5~>q)|C%Yd=8zBi)5)x$*H~%hPHa8b8GN_~55wXJGMD zKCvMSt7G&XItlc<@&yUm57t_CV<tc87|+RE-&7IxU!+QoUfH^;=(ln(LNQzsoO$PI zAPQ1nS=k}S4)9VGq9bRsfuZ3r*j(y#bace$=Wl)3*||+gK_Lc$PTK9Yn|E!!MCK{P zUbfD#C^W*9#yoR&QMkU>{!aQq?wOe#Iu;Z|HM({9I6QM_ub7*6u399OekQ4StAKm` z#g)iM1LSCJi}H0x`$DsPPY5o9lhD5VSY5`$DPR@S!KaQhF*AFFv${Xm;?lIT6VjtZ z93uF?U#SZ7PVN%%G!t`gDAVYOX(|n!6QkVBn=ewnr@7E03hxiv7(XN|i%mbV-A1Sc z_#GUZ;NZ#jBQeg-&SbzcDMvpzzQYE~5pr!>v6rqG^m|XzTvRvU4P(fhst(2pm9^2; za5282QX_O}n0aj4Ss{f?k~MrS1S5=NNpIih-=;UZAr`nYKl(qpX@LOMg4h$=Ot1?| z$Viq}%~r3R0^4P8$zQo$F7(QI7TOyY3E0i_QTt_2U3%Vi^0VtiyY+{3X+yIPDORp5 z85|hDxHU$Y24Ltkl-8%-*-{^miHMkIf&qiBC!kvR_88gcw?A1d*3NfGvZjylygvzC z%BB}BRpq0dFFJ?Te6Lne0VuF{0v3M2)7Dv~G)^4B>TqwlueCo2bAz@~Py#9yz*}Vc zr3D@|Q4#7(u6F4oM)`Cr{W^NodHes9BQ2K*v+L+20iUWzmKs^$h+4u1QMd!*_b<pW z{mY@kI@T$*hQr1J$jYA!qkKF(JkTd-5iJQDbpboPx@jbkuL}TwZ9&Wa?ip<zgvu?` z^__XxQxUYRdQ9QtdX*^~X|q_JTRsT_DZ9Gc;uEVkDUZbmQ*g2T@Lm<L7eB*$n-hf7 zwK0JBJObtErYt!uA#Jen9!rS_y|>4#_q3pvwf%1HR(@%l89Xt>Mx@rMt1oIKP);hx zUAfJ%`t4EBi2c2GIM&?IDA(;U{@*+!u1)U+GIh9LVEZQM1$GZs-@q&YjyqFqyMhu9 zZEn8%e5O*x-c~AF6@U?EpL=L9Yra~GYl`JooVOe{&<GIh_Nci!<_0ZM%T9ZXEZCmx zOG#@ycOglc7%h}~S&P^<vv&|lbUN&3w>^fR;3I$?8L%XAdf{YV#7P-}>U{q_w(iVl zp*XnlC4~2!6pEsn?EX!(pz17UU@k?I5XejvY{$cRI>GpWmg?44Fz0q1AP{N_w>j9` zB+{m-!P?nKC#Ofbd3kwofa>>;zois}5#%Z6{%9@KcXqy^^#I!oYb}vQfPpu>v(R4< z-PxWo(G(hyk`-kR!rt0`r~}1QLZDq>GqSc$>6eOIuDxO=5coOSyV%{c@wxC1Z~0{p literal 0 HcmV?d00001 diff --git a/img/xbus_write.png b/img/xbus_write.png new file mode 100644 index 0000000000000000000000000000000000000000..9d67458faaabfe65efb536516e0f20d14fb2a126 GIT binary patch literal 23425 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 W&kAtzpw2+xPhZ<atKhI>_<sP!GeD65 literal 0 HcmV?d00001 diff --git a/index.html b/index.html new file mode 100644 index 0000000000..b11025fd67 --- /dev/null +++ b/index.html @@ -0,0 +1,20959 @@ +<!DOCTYPE html> +<html lang="en"> +<head> +<meta charset="UTF-8"> +<meta http-equiv="X-UA-Compatible" content="IE=edge"> +<meta name="viewport" content="width=device-width, initial-scale=1.0"> +<meta name="generator" content="Asciidoctor 2.0.20"> +<meta name="description" content="A size-optimized, customizable and highly extensible MCU-class 32-bit RISC-V soft-core CPU and microcontroller-like SoC written in platform-independent VHDL."> +<meta name="keywords" content="neorv32, risc-v, riscv, rv32, fpga, soft-core, vhdl, microcontroller, cpu, soc, processor, gcc, openocd, gdb, verilog, rtl, asip, asic, safety"> +<link rel="icon" type="image/png" href="img/icon.png"> +<title>[Datasheet] The NEORV32 RISC-V Processor</title> +<link rel="stylesheet" href="https://fonts.googleapis.com/css?family=Open+Sans:300,300italic,400,400italic,600,600italic%7CNoto+Serif:400,400italic,700,700italic%7CDroid+Sans+Mono:400,700"> +<style> +/*! Asciidoctor default stylesheet | MIT License | https://asciidoctor.org */ +/* Uncomment the following line when using as a custom stylesheet */ +/* @import "https://fonts.googleapis.com/css?family=Open+Sans:300,300italic,400,400italic,600,600italic%7CNoto+Serif:400,400italic,700,700italic%7CDroid+Sans+Mono:400,700"; */ +html{font-family:sans-serif;-webkit-text-size-adjust:100%} +a{background:none} +a:focus{outline:thin dotted} +a:active,a:hover{outline:0} +h1{font-size:2em;margin:.67em 0} +b,strong{font-weight:bold} +abbr{font-size:.9em} +abbr[title]{cursor:help;border-bottom:1px dotted #dddddf;text-decoration:none} +dfn{font-style:italic} +hr{height:0} +mark{background:#ff0;color:#000} +code,kbd,pre,samp{font-family:monospace;font-size:1em} +pre{white-space:pre-wrap} +q{quotes:"\201C" "\201D" "\2018" "\2019"} +small{font-size:80%} +sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline} +sup{top:-.5em} +sub{bottom:-.25em} +img{border:0} +svg:not(:root){overflow:hidden} +figure{margin:0} +audio,video{display:inline-block} +audio:not([controls]){display:none;height:0} +fieldset{border:1px solid silver;margin:0 2px;padding:.35em .625em .75em} +legend{border:0;padding:0} +button,input,select,textarea{font-family:inherit;font-size:100%;margin:0} +button,input{line-height:normal} +button,select{text-transform:none} +button,html input[type=button],input[type=reset],input[type=submit]{-webkit-appearance:button;cursor:pointer} +button[disabled],html input[disabled]{cursor:default} +input[type=checkbox],input[type=radio]{padding:0} +button::-moz-focus-inner,input::-moz-focus-inner{border:0;padding:0} +textarea{overflow:auto;vertical-align:top} +table{border-collapse:collapse;border-spacing:0} +*,::before,::after{box-sizing:border-box} +html,body{font-size:100%} +body{background:#fff;color:rgba(0,0,0,.8);padding:0;margin:0;font-family:"Noto Serif","DejaVu Serif",serif;line-height:1;position:relative;cursor:auto;-moz-tab-size:4;-o-tab-size:4;tab-size:4;word-wrap:anywhere;-moz-osx-font-smoothing:grayscale;-webkit-font-smoothing:antialiased} +a:hover{cursor:pointer} +img,object,embed{max-width:100%;height:auto} +object,embed{height:100%} +img{-ms-interpolation-mode:bicubic} +.left{float:left!important} +.right{float:right!important} +.text-left{text-align:left!important} +.text-right{text-align:right!important} +.text-center{text-align:center!important} +.text-justify{text-align:justify!important} +.hide{display:none} +img,object,svg{display:inline-block;vertical-align:middle} +textarea{height:auto;min-height:50px} +select{width:100%} +.subheader,.admonitionblock td.content>.title,.audioblock>.title,.exampleblock>.title,.imageblock>.title,.listingblock>.title,.literalblock>.title,.stemblock>.title,.openblock>.title,.paragraph>.title,.quoteblock>.title,table.tableblock>.title,.verseblock>.title,.videoblock>.title,.dlist>.title,.olist>.title,.ulist>.title,.qlist>.title,.hdlist>.title{line-height:1.45;color:#7a2518;font-weight:400;margin-top:0;margin-bottom:.25em} +div,dl,dt,dd,ul,ol,li,h1,h2,h3,#toctitle,.sidebarblock>.content>.title,h4,h5,h6,pre,form,p,blockquote,th,td{margin:0;padding:0} +a{color:#2156a5;text-decoration:underline;line-height:inherit} +a:hover,a:focus{color:#1d4b8f} +a img{border:0} +p{line-height:1.6;margin-bottom:1.25em;text-rendering:optimizeLegibility} +p aside{font-size:.875em;line-height:1.35;font-style:italic} +h1,h2,h3,#toctitle,.sidebarblock>.content>.title,h4,h5,h6{font-family:"Open Sans","DejaVu Sans",sans-serif;font-weight:300;font-style:normal;color:#ba3925;text-rendering:optimizeLegibility;margin-top:1em;margin-bottom:.5em;line-height:1.0125em} +h1 small,h2 small,h3 small,#toctitle small,.sidebarblock>.content>.title small,h4 small,h5 small,h6 small{font-size:60%;color:#e99b8f;line-height:0} +h1{font-size:2.125em} +h2{font-size:1.6875em} +h3,#toctitle,.sidebarblock>.content>.title{font-size:1.375em} +h4,h5{font-size:1.125em} +h6{font-size:1em} +hr{border:solid #dddddf;border-width:1px 0 0;clear:both;margin:1.25em 0 1.1875em} +em,i{font-style:italic;line-height:inherit} +strong,b{font-weight:bold;line-height:inherit} +small{font-size:60%;line-height:inherit} +code{font-family:"Droid Sans Mono","DejaVu Sans Mono",monospace;font-weight:400;color:rgba(0,0,0,.9)} +ul,ol,dl{line-height:1.6;margin-bottom:1.25em;list-style-position:outside;font-family:inherit} +ul,ol{margin-left:1.5em} +ul li ul,ul li ol{margin-left:1.25em;margin-bottom:0} +ul.circle{list-style-type:circle} +ul.disc{list-style-type:disc} +ul.square{list-style-type:square} +ul.circle ul:not([class]),ul.disc ul:not([class]),ul.square ul:not([class]){list-style:inherit} +ol li ul,ol li ol{margin-left:1.25em;margin-bottom:0} +dl dt{margin-bottom:.3125em;font-weight:bold} +dl dd{margin-bottom:1.25em} +blockquote{margin:0 0 1.25em;padding:.5625em 1.25em 0 1.1875em;border-left:1px solid #ddd} +blockquote,blockquote p{line-height:1.6;color:rgba(0,0,0,.85)} +@media screen and (min-width:768px){h1,h2,h3,#toctitle,.sidebarblock>.content>.title,h4,h5,h6{line-height:1.2} +h1{font-size:2.75em} +h2{font-size:2.3125em} +h3,#toctitle,.sidebarblock>.content>.title{font-size:1.6875em} +h4{font-size:1.4375em}} +table{background:#fff;margin-bottom:1.25em;border:1px solid #dedede;word-wrap:normal} +table thead,table tfoot{background:#f7f8f7} +table thead tr th,table thead tr td,table tfoot tr th,table tfoot tr td{padding:.5em .625em .625em;font-size:inherit;color:rgba(0,0,0,.8);text-align:left} +table tr th,table tr td{padding:.5625em .625em;font-size:inherit;color:rgba(0,0,0,.8)} +table tr.even,table tr.alt{background:#f8f8f7} +table thead tr th,table tfoot tr th,table tbody tr td,table tr td,table tfoot tr td{line-height:1.6} +h1,h2,h3,#toctitle,.sidebarblock>.content>.title,h4,h5,h6{line-height:1.2;word-spacing:-.05em} +h1 strong,h2 strong,h3 strong,#toctitle strong,.sidebarblock>.content>.title strong,h4 strong,h5 strong,h6 strong{font-weight:400} +.center{margin-left:auto;margin-right:auto} +.stretch{width:100%} +.clearfix::before,.clearfix::after,.float-group::before,.float-group::after{content:" ";display:table} +.clearfix::after,.float-group::after{clear:both} +:not(pre).nobreak{word-wrap:normal} +:not(pre).nowrap{white-space:nowrap} +:not(pre).pre-wrap{white-space:pre-wrap} +:not(pre):not([class^=L])>code{font-size:.9375em;font-style:normal!important;letter-spacing:0;padding:.1em .5ex;word-spacing:-.15em;background:#f7f7f8;border-radius:4px;line-height:1.45;text-rendering:optimizeSpeed} +pre{color:rgba(0,0,0,.9);font-family:"Droid Sans Mono","DejaVu Sans Mono",monospace;line-height:1.45;text-rendering:optimizeSpeed} +pre code,pre pre{color:inherit;font-size:inherit;line-height:inherit} +pre>code{display:block} +pre.nowrap,pre.nowrap pre{white-space:pre;word-wrap:normal} +em em{font-style:normal} +strong strong{font-weight:400} +.keyseq{color:rgba(51,51,51,.8)} +kbd{font-family:"Droid Sans Mono","DejaVu Sans Mono",monospace;display:inline-block;color:rgba(0,0,0,.8);font-size:.65em;line-height:1.45;background:#f7f7f7;border:1px solid #ccc;border-radius:3px;box-shadow:0 1px 0 rgba(0,0,0,.2),inset 0 0 0 .1em #fff;margin:0 .15em;padding:.2em .5em;vertical-align:middle;position:relative;top:-.1em;white-space:nowrap} +.keyseq kbd:first-child{margin-left:0} +.keyseq kbd:last-child{margin-right:0} +.menuseq,.menuref{color:#000} +.menuseq b:not(.caret),.menuref{font-weight:inherit} +.menuseq{word-spacing:-.02em} +.menuseq b.caret{font-size:1.25em;line-height:.8} +.menuseq i.caret{font-weight:bold;text-align:center;width:.45em} +b.button::before,b.button::after{position:relative;top:-1px;font-weight:400} +b.button::before{content:"[";padding:0 3px 0 2px} +b.button::after{content:"]";padding:0 2px 0 3px} +p a>code:hover{color:rgba(0,0,0,.9)} +#header,#content,#footnotes,#footer{width:100%;margin:0 auto;max-width:62.5em;*zoom:1;position:relative;padding-left:.9375em;padding-right:.9375em} +#header::before,#header::after,#content::before,#content::after,#footnotes::before,#footnotes::after,#footer::before,#footer::after{content:" ";display:table} +#header::after,#content::after,#footnotes::after,#footer::after{clear:both} +#content{margin-top:1.25em} +#content::before{content:none} +#header>h1:first-child{color:rgba(0,0,0,.85);margin-top:2.25rem;margin-bottom:0} +#header>h1:first-child+#toc{margin-top:8px;border-top:1px solid #dddddf} +#header>h1:only-child,body.toc2 #header>h1:nth-last-child(2){border-bottom:1px solid #dddddf;padding-bottom:8px} +#header .details{border-bottom:1px solid #dddddf;line-height:1.45;padding-top:.25em;padding-bottom:.25em;padding-left:.25em;color:rgba(0,0,0,.6);display:flex;flex-flow:row wrap} +#header .details span:first-child{margin-left:-.125em} +#header .details span.email a{color:rgba(0,0,0,.85)} +#header .details br{display:none} +#header .details br+span::before{content:"\00a0\2013\00a0"} +#header .details br+span.author::before{content:"\00a0\22c5\00a0";color:rgba(0,0,0,.85)} +#header .details br+span#revremark::before{content:"\00a0|\00a0"} +#header #revnumber{text-transform:capitalize} +#header #revnumber::after{content:"\00a0"} +#content>h1:first-child:not([class]){color:rgba(0,0,0,.85);border-bottom:1px solid #dddddf;padding-bottom:8px;margin-top:0;padding-top:1rem;margin-bottom:1.25rem} +#toc{border-bottom:1px solid #e7e7e9;padding-bottom:.5em} +#toc>ul{margin-left:.125em} +#toc ul.sectlevel0>li>a{font-style:italic} +#toc ul.sectlevel0 ul.sectlevel1{margin:.5em 0} +#toc ul{font-family:"Open Sans","DejaVu Sans",sans-serif;list-style-type:none} +#toc li{line-height:1.3334;margin-top:.3334em} +#toc a{text-decoration:none} +#toc a:active{text-decoration:underline} +#toctitle{color:#7a2518;font-size:1.2em} +@media screen and (min-width:768px){#toctitle{font-size:1.375em} +body.toc2{padding-left:15em;padding-right:0} +#toc.toc2{margin-top:0!important;background:#f8f8f7;position:fixed;width:15em;left:0;top:0;border-right:1px solid #e7e7e9;border-top-width:0!important;border-bottom-width:0!important;z-index:1000;padding:1.25em 1em;height:100%;overflow:auto} +#toc.toc2 #toctitle{margin-top:0;margin-bottom:.8rem;font-size:1.2em} +#toc.toc2>ul{font-size:.9em;margin-bottom:0} +#toc.toc2 ul ul{margin-left:0;padding-left:1em} +#toc.toc2 ul.sectlevel0 ul.sectlevel1{padding-left:0;margin-top:.5em;margin-bottom:.5em} +body.toc2.toc-right{padding-left:0;padding-right:15em} +body.toc2.toc-right #toc.toc2{border-right-width:0;border-left:1px solid #e7e7e9;left:auto;right:0}} +@media screen and (min-width:1280px){body.toc2{padding-left:20em;padding-right:0} +#toc.toc2{width:20em} +#toc.toc2 #toctitle{font-size:1.375em} +#toc.toc2>ul{font-size:.95em} +#toc.toc2 ul ul{padding-left:1.25em} +body.toc2.toc-right{padding-left:0;padding-right:20em}} +#content #toc{border:1px solid #e0e0dc;margin-bottom:1.25em;padding:1.25em;background:#f8f8f7;border-radius:4px} +#content #toc>:first-child{margin-top:0} +#content #toc>:last-child{margin-bottom:0} +#footer{max-width:none;background:rgba(0,0,0,.8);padding:1.25em} +#footer-text{color:hsla(0,0%,100%,.8);line-height:1.44} +#content{margin-bottom:.625em} +.sect1{padding-bottom:.625em} +@media screen and (min-width:768px){#content{margin-bottom:1.25em} +.sect1{padding-bottom:1.25em}} +.sect1:last-child{padding-bottom:0} +.sect1+.sect1{border-top:1px solid #e7e7e9} +#content h1>a.anchor,h2>a.anchor,h3>a.anchor,#toctitle>a.anchor,.sidebarblock>.content>.title>a.anchor,h4>a.anchor,h5>a.anchor,h6>a.anchor{position:absolute;z-index:1001;width:1.5ex;margin-left:-1.5ex;display:block;text-decoration:none!important;visibility:hidden;text-align:center;font-weight:400} +#content h1>a.anchor::before,h2>a.anchor::before,h3>a.anchor::before,#toctitle>a.anchor::before,.sidebarblock>.content>.title>a.anchor::before,h4>a.anchor::before,h5>a.anchor::before,h6>a.anchor::before{content:"\00A7";font-size:.85em;display:block;padding-top:.1em} +#content h1:hover>a.anchor,#content h1>a.anchor:hover,h2:hover>a.anchor,h2>a.anchor:hover,h3:hover>a.anchor,#toctitle:hover>a.anchor,.sidebarblock>.content>.title:hover>a.anchor,h3>a.anchor:hover,#toctitle>a.anchor:hover,.sidebarblock>.content>.title>a.anchor:hover,h4:hover>a.anchor,h4>a.anchor:hover,h5:hover>a.anchor,h5>a.anchor:hover,h6:hover>a.anchor,h6>a.anchor:hover{visibility:visible} +#content h1>a.link,h2>a.link,h3>a.link,#toctitle>a.link,.sidebarblock>.content>.title>a.link,h4>a.link,h5>a.link,h6>a.link{color:#ba3925;text-decoration:none} +#content h1>a.link:hover,h2>a.link:hover,h3>a.link:hover,#toctitle>a.link:hover,.sidebarblock>.content>.title>a.link:hover,h4>a.link:hover,h5>a.link:hover,h6>a.link:hover{color:#a53221} +details,.audioblock,.imageblock,.literalblock,.listingblock,.stemblock,.videoblock{margin-bottom:1.25em} +details{margin-left:1.25rem} +details>summary{cursor:pointer;display:block;position:relative;line-height:1.6;margin-bottom:.625rem;outline:none;-webkit-tap-highlight-color:transparent} +details>summary::-webkit-details-marker{display:none} +details>summary::before{content:"";border:solid transparent;border-left:solid;border-width:.3em 0 .3em .5em;position:absolute;top:.5em;left:-1.25rem;transform:translateX(15%)} +details[open]>summary::before{border:solid transparent;border-top:solid;border-width:.5em .3em 0;transform:translateY(15%)} +details>summary::after{content:"";width:1.25rem;height:1em;position:absolute;top:.3em;left:-1.25rem} +.admonitionblock td.content>.title,.audioblock>.title,.exampleblock>.title,.imageblock>.title,.listingblock>.title,.literalblock>.title,.stemblock>.title,.openblock>.title,.paragraph>.title,.quoteblock>.title,table.tableblock>.title,.verseblock>.title,.videoblock>.title,.dlist>.title,.olist>.title,.ulist>.title,.qlist>.title,.hdlist>.title{text-rendering:optimizeLegibility;text-align:left;font-family:"Noto Serif","DejaVu Serif",serif;font-size:1rem;font-style:italic} +table.tableblock.fit-content>caption.title{white-space:nowrap;width:0} +.paragraph.lead>p,#preamble>.sectionbody>[class=paragraph]:first-of-type p{font-size:1.21875em;line-height:1.6;color:rgba(0,0,0,.85)} +.admonitionblock>table{border-collapse:separate;border:0;background:none;width:100%} +.admonitionblock>table td.icon{text-align:center;width:80px} +.admonitionblock>table td.icon img{max-width:none} +.admonitionblock>table td.icon .title{font-weight:bold;font-family:"Open Sans","DejaVu Sans",sans-serif;text-transform:uppercase} +.admonitionblock>table td.content{padding-left:1.125em;padding-right:1.25em;border-left:1px solid #dddddf;color:rgba(0,0,0,.6);word-wrap:anywhere} +.admonitionblock>table td.content>:last-child>:last-child{margin-bottom:0} +.exampleblock>.content{border:1px solid #e6e6e6;margin-bottom:1.25em;padding:1.25em;background:#fff;border-radius:4px} +.sidebarblock{border:1px solid #dbdbd6;margin-bottom:1.25em;padding:1.25em;background:#f3f3f2;border-radius:4px} +.sidebarblock>.content>.title{color:#7a2518;margin-top:0;text-align:center} +.exampleblock>.content>:first-child,.sidebarblock>.content>:first-child{margin-top:0} +.exampleblock>.content>:last-child,.exampleblock>.content>:last-child>:last-child,.exampleblock>.content .olist>ol>li:last-child>:last-child,.exampleblock>.content .ulist>ul>li:last-child>:last-child,.exampleblock>.content .qlist>ol>li:last-child>:last-child,.sidebarblock>.content>:last-child,.sidebarblock>.content>:last-child>:last-child,.sidebarblock>.content .olist>ol>li:last-child>:last-child,.sidebarblock>.content .ulist>ul>li:last-child>:last-child,.sidebarblock>.content .qlist>ol>li:last-child>:last-child{margin-bottom:0} +.literalblock pre,.listingblock>.content>pre{border-radius:4px;overflow-x:auto;padding:1em;font-size:.8125em} +@media screen and (min-width:768px){.literalblock pre,.listingblock>.content>pre{font-size:.90625em}} +@media screen and (min-width:1280px){.literalblock pre,.listingblock>.content>pre{font-size:1em}} +.literalblock pre,.listingblock>.content>pre:not(.highlight),.listingblock>.content>pre[class=highlight],.listingblock>.content>pre[class^="highlight "]{background:#f7f7f8} +.literalblock.output pre{color:#f7f7f8;background:rgba(0,0,0,.9)} +.listingblock>.content{position:relative} +.listingblock code[data-lang]::before{display:none;content:attr(data-lang);position:absolute;font-size:.75em;top:.425rem;right:.5rem;line-height:1;text-transform:uppercase;color:inherit;opacity:.5} +.listingblock:hover code[data-lang]::before{display:block} +.listingblock.terminal pre .command::before{content:attr(data-prompt);padding-right:.5em;color:inherit;opacity:.5} +.listingblock.terminal pre .command:not([data-prompt])::before{content:"$"} +.listingblock pre.highlightjs{padding:0} +.listingblock pre.highlightjs>code{padding:1em;border-radius:4px} +.listingblock pre.prettyprint{border-width:0} +.prettyprint{background:#f7f7f8} +pre.prettyprint .linenums{line-height:1.45;margin-left:2em} +pre.prettyprint li{background:none;list-style-type:inherit;padding-left:0} +pre.prettyprint li code[data-lang]::before{opacity:1} +pre.prettyprint li:not(:first-child) code[data-lang]::before{display:none} +table.linenotable{border-collapse:separate;border:0;margin-bottom:0;background:none} +table.linenotable td[class]{color:inherit;vertical-align:top;padding:0;line-height:inherit;white-space:normal} +table.linenotable td.code{padding-left:.75em} +table.linenotable td.linenos,pre.pygments .linenos{border-right:1px solid;opacity:.35;padding-right:.5em;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none} +pre.pygments span.linenos{display:inline-block;margin-right:.75em} +.quoteblock{margin:0 1em 1.25em 1.5em;display:table} +.quoteblock:not(.excerpt)>.title{margin-left:-1.5em;margin-bottom:.75em} +.quoteblock blockquote,.quoteblock p{color:rgba(0,0,0,.85);font-size:1.15rem;line-height:1.75;word-spacing:.1em;letter-spacing:0;font-style:italic;text-align:justify} +.quoteblock blockquote{margin:0;padding:0;border:0} +.quoteblock blockquote::before{content:"\201c";float:left;font-size:2.75em;font-weight:bold;line-height:.6em;margin-left:-.6em;color:#7a2518;text-shadow:0 1px 2px rgba(0,0,0,.1)} +.quoteblock blockquote>.paragraph:last-child p{margin-bottom:0} +.quoteblock .attribution{margin-top:.75em;margin-right:.5ex;text-align:right} +.verseblock{margin:0 1em 1.25em} +.verseblock pre{font-family:"Open Sans","DejaVu Sans",sans-serif;font-size:1.15rem;color:rgba(0,0,0,.85);font-weight:300;text-rendering:optimizeLegibility} +.verseblock pre strong{font-weight:400} +.verseblock .attribution{margin-top:1.25rem;margin-left:.5ex} +.quoteblock .attribution,.verseblock .attribution{font-size:.9375em;line-height:1.45;font-style:italic} +.quoteblock .attribution br,.verseblock .attribution br{display:none} +.quoteblock .attribution cite,.verseblock .attribution cite{display:block;letter-spacing:-.025em;color:rgba(0,0,0,.6)} +.quoteblock.abstract blockquote::before,.quoteblock.excerpt blockquote::before,.quoteblock .quoteblock blockquote::before{display:none} +.quoteblock.abstract blockquote,.quoteblock.abstract p,.quoteblock.excerpt blockquote,.quoteblock.excerpt p,.quoteblock .quoteblock blockquote,.quoteblock .quoteblock p{line-height:1.6;word-spacing:0} +.quoteblock.abstract{margin:0 1em 1.25em;display:block} +.quoteblock.abstract>.title{margin:0 0 .375em;font-size:1.15em;text-align:center} +.quoteblock.excerpt>blockquote,.quoteblock .quoteblock{padding:0 0 .25em 1em;border-left:.25em solid #dddddf} +.quoteblock.excerpt,.quoteblock .quoteblock{margin-left:0} +.quoteblock.excerpt blockquote,.quoteblock.excerpt p,.quoteblock .quoteblock blockquote,.quoteblock .quoteblock p{color:inherit;font-size:1.0625rem} +.quoteblock.excerpt .attribution,.quoteblock .quoteblock .attribution{color:inherit;font-size:.85rem;text-align:left;margin-right:0} +p.tableblock:last-child{margin-bottom:0} +td.tableblock>.content{margin-bottom:1.25em;word-wrap:anywhere} +td.tableblock>.content>:last-child{margin-bottom:-1.25em} +table.tableblock,th.tableblock,td.tableblock{border:0 solid #dedede} +table.grid-all>*>tr>*{border-width:1px} +table.grid-cols>*>tr>*{border-width:0 1px} +table.grid-rows>*>tr>*{border-width:1px 0} +table.frame-all{border-width:1px} +table.frame-ends{border-width:1px 0} +table.frame-sides{border-width:0 1px} +table.frame-none>colgroup+*>:first-child>*,table.frame-sides>colgroup+*>:first-child>*{border-top-width:0} +table.frame-none>:last-child>:last-child>*,table.frame-sides>:last-child>:last-child>*{border-bottom-width:0} +table.frame-none>*>tr>:first-child,table.frame-ends>*>tr>:first-child{border-left-width:0} +table.frame-none>*>tr>:last-child,table.frame-ends>*>tr>:last-child{border-right-width:0} +table.stripes-all>*>tr,table.stripes-odd>*>tr:nth-of-type(odd),table.stripes-even>*>tr:nth-of-type(even),table.stripes-hover>*>tr:hover{background:#f8f8f7} +th.halign-left,td.halign-left{text-align:left} +th.halign-right,td.halign-right{text-align:right} +th.halign-center,td.halign-center{text-align:center} +th.valign-top,td.valign-top{vertical-align:top} +th.valign-bottom,td.valign-bottom{vertical-align:bottom} +th.valign-middle,td.valign-middle{vertical-align:middle} +table thead th,table tfoot th{font-weight:bold} +tbody tr th{background:#f7f8f7} +tbody tr th,tbody tr th p,tfoot tr th,tfoot tr th p{color:rgba(0,0,0,.8);font-weight:bold} +p.tableblock>code:only-child{background:none;padding:0} +p.tableblock{font-size:1em} +ol{margin-left:1.75em} +ul li ol{margin-left:1.5em} +dl dd{margin-left:1.125em} +dl dd:last-child,dl dd:last-child>:last-child{margin-bottom:0} +li p,ul dd,ol dd,.olist .olist,.ulist .ulist,.ulist .olist,.olist .ulist{margin-bottom:.625em} +ul.checklist,ul.none,ol.none,ul.no-bullet,ol.no-bullet,ol.unnumbered,ul.unstyled,ol.unstyled{list-style-type:none} +ul.no-bullet,ol.no-bullet,ol.unnumbered{margin-left:.625em} +ul.unstyled,ol.unstyled{margin-left:0} +li>p:empty:only-child::before{content:"";display:inline-block} +ul.checklist>li>p:first-child{margin-left:-1em} +ul.checklist>li>p:first-child>.fa-square-o:first-child,ul.checklist>li>p:first-child>.fa-check-square-o:first-child{width:1.25em;font-size:.8em;position:relative;bottom:.125em} +ul.checklist>li>p:first-child>input[type=checkbox]:first-child{margin-right:.25em} +ul.inline{display:flex;flex-flow:row wrap;list-style:none;margin:0 0 .625em -1.25em} +ul.inline>li{margin-left:1.25em} +.unstyled dl dt{font-weight:400;font-style:normal} +ol.arabic{list-style-type:decimal} +ol.decimal{list-style-type:decimal-leading-zero} +ol.loweralpha{list-style-type:lower-alpha} +ol.upperalpha{list-style-type:upper-alpha} +ol.lowerroman{list-style-type:lower-roman} +ol.upperroman{list-style-type:upper-roman} +ol.lowergreek{list-style-type:lower-greek} +.hdlist>table,.colist>table{border:0;background:none} +.hdlist>table>tbody>tr,.colist>table>tbody>tr{background:none} +td.hdlist1,td.hdlist2{vertical-align:top;padding:0 .625em} +td.hdlist1{font-weight:bold;padding-bottom:1.25em} +td.hdlist2{word-wrap:anywhere} +.literalblock+.colist,.listingblock+.colist{margin-top:-.5em} +.colist td:not([class]):first-child{padding:.4em .75em 0;line-height:1;vertical-align:top} +.colist td:not([class]):first-child img{max-width:none} +.colist td:not([class]):last-child{padding:.25em 0} +.thumb,.th{line-height:0;display:inline-block;border:4px solid #fff;box-shadow:0 0 0 1px #ddd} +.imageblock.left{margin:.25em .625em 1.25em 0} +.imageblock.right{margin:.25em 0 1.25em .625em} +.imageblock>.title{margin-bottom:0} +.imageblock.thumb,.imageblock.th{border-width:6px} +.imageblock.thumb>.title,.imageblock.th>.title{padding:0 .125em} +.image.left,.image.right{margin-top:.25em;margin-bottom:.25em;display:inline-block;line-height:0} +.image.left{margin-right:.625em} +.image.right{margin-left:.625em} +a.image{text-decoration:none;display:inline-block} +a.image object{pointer-events:none} +sup.footnote,sup.footnoteref{font-size:.875em;position:static;vertical-align:super} +sup.footnote a,sup.footnoteref a{text-decoration:none} +sup.footnote a:active,sup.footnoteref a:active{text-decoration:underline} +#footnotes{padding-top:.75em;padding-bottom:.75em;margin-bottom:.625em} +#footnotes hr{width:20%;min-width:6.25em;margin:-.25em 0 .75em;border-width:1px 0 0} +#footnotes .footnote{padding:0 .375em 0 .225em;line-height:1.3334;font-size:.875em;margin-left:1.2em;margin-bottom:.2em} +#footnotes .footnote a:first-of-type{font-weight:bold;text-decoration:none;margin-left:-1.05em} +#footnotes .footnote:last-of-type{margin-bottom:0} +#content #footnotes{margin-top:-.625em;margin-bottom:0;padding:.75em 0} +div.unbreakable{page-break-inside:avoid} +.big{font-size:larger} +.small{font-size:smaller} +.underline{text-decoration:underline} +.overline{text-decoration:overline} +.line-through{text-decoration:line-through} +.aqua{color:#00bfbf} +.aqua-background{background:#00fafa} +.black{color:#000} +.black-background{background:#000} +.blue{color:#0000bf} +.blue-background{background:#0000fa} +.fuchsia{color:#bf00bf} +.fuchsia-background{background:#fa00fa} +.gray{color:#606060} +.gray-background{background:#7d7d7d} +.green{color:#006000} +.green-background{background:#007d00} +.lime{color:#00bf00} +.lime-background{background:#00fa00} +.maroon{color:#600000} +.maroon-background{background:#7d0000} +.navy{color:#000060} +.navy-background{background:#00007d} +.olive{color:#606000} +.olive-background{background:#7d7d00} +.purple{color:#600060} +.purple-background{background:#7d007d} +.red{color:#bf0000} +.red-background{background:#fa0000} +.silver{color:#909090} +.silver-background{background:#bcbcbc} +.teal{color:#006060} +.teal-background{background:#007d7d} +.white{color:#bfbfbf} +.white-background{background:#fafafa} +.yellow{color:#bfbf00} +.yellow-background{background:#fafa00} +span.icon>.fa{cursor:default} +a span.icon>.fa{cursor:inherit} +.admonitionblock td.icon [class^="fa icon-"]{font-size:2.5em;text-shadow:1px 1px 2px rgba(0,0,0,.5);cursor:default} +.admonitionblock td.icon .icon-note::before{content:"\f05a";color:#19407c} +.admonitionblock td.icon .icon-tip::before{content:"\f0eb";text-shadow:1px 1px 2px rgba(155,155,0,.8);color:#111} +.admonitionblock td.icon .icon-warning::before{content:"\f071";color:#bf6900} +.admonitionblock td.icon .icon-caution::before{content:"\f06d";color:#bf3400} +.admonitionblock td.icon .icon-important::before{content:"\f06a";color:#bf0000} +.conum[data-value]{display:inline-block;color:#fff!important;background:rgba(0,0,0,.8);border-radius:50%;text-align:center;font-size:.75em;width:1.67em;height:1.67em;line-height:1.67em;font-family:"Open Sans","DejaVu Sans",sans-serif;font-style:normal;font-weight:bold} +.conum[data-value] *{color:#fff!important} +.conum[data-value]+b{display:none} +.conum[data-value]::after{content:attr(data-value)} +pre .conum[data-value]{position:relative;top:-.125em} +b.conum *{color:inherit!important} +.conum:not([data-value]):empty{display:none} +dt,th.tableblock,td.content,div.footnote{text-rendering:optimizeLegibility} +h1,h2,p,td.content,span.alt,summary{letter-spacing:-.01em} +p strong,td.content strong,div.footnote strong{letter-spacing:-.005em} +p,blockquote,dt,td.content,td.hdlist1,span.alt,summary{font-size:1.0625rem} +p{margin-bottom:1.25rem} +.sidebarblock p,.sidebarblock dt,.sidebarblock td.content,p.tableblock{font-size:1em} +.exampleblock>.content{background:#fffef7;border-color:#e0e0dc;box-shadow:0 1px 4px #e0e0dc} +.print-only{display:none!important} +@page{margin:1.25cm .75cm} +@media print{*{box-shadow:none!important;text-shadow:none!important} +html{font-size:80%} +a{color:inherit!important;text-decoration:underline!important} +a.bare,a[href^="#"],a[href^="mailto:"]{text-decoration:none!important} +a[href^="http:"]:not(.bare)::after,a[href^="https:"]:not(.bare)::after{content:"(" attr(href) ")";display:inline-block;font-size:.875em;padding-left:.25em} +abbr[title]{border-bottom:1px dotted} +abbr[title]::after{content:" (" attr(title) ")"} +pre,blockquote,tr,img,object,svg{page-break-inside:avoid} +thead{display:table-header-group} +svg{max-width:100%} +p,blockquote,dt,td.content{font-size:1em;orphans:3;widows:3} +h2,h3,#toctitle,.sidebarblock>.content>.title{page-break-after:avoid} +#header,#content,#footnotes,#footer{max-width:none} +#toc,.sidebarblock,.exampleblock>.content{background:none!important} +#toc{border-bottom:1px solid #dddddf!important;padding-bottom:0!important} +body.book #header{text-align:center} +body.book #header>h1:first-child{border:0!important;margin:2.5em 0 1em} +body.book #header .details{border:0!important;display:block;padding:0!important} +body.book #header .details span:first-child{margin-left:0!important} +body.book #header .details br{display:block} +body.book #header .details br+span::before{content:none!important} +body.book #toc{border:0!important;text-align:left!important;padding:0!important;margin:0!important} +body.book #toc,body.book #preamble,body.book h1.sect0,body.book .sect1>h2{page-break-before:always} +.listingblock code[data-lang]::before{display:block} +#footer{padding:0 .9375em} +.hide-on-print{display:none!important} +.print-only{display:block!important} +.hide-for-print{display:none!important} +.show-for-print{display:inherit!important}} +@media amzn-kf8,print{#header>h1:first-child{margin-top:1.25rem} +.sect1{padding:0!important} +.sect1+.sect1{border:0} +#footer{background:none} +#footer-text{color:rgba(0,0,0,.6);font-size:.9em}} +@media amzn-kf8{#header,#content,#footnotes,#footer{padding:0}} +</style> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/4.7.0/css/font-awesome.min.css"> +</head> +<body class="book toc2 toc-left"> +<div id="header"> +<h1>The NEORV32 RISC-V Processor - Datasheet</h1> +<div class="details"> +<span id="revnumber">version v1.10.1-r126-g74b0d5cf</span> +</div> +<div id="toc" class="toc2"> +<div id="toctitle">Table of Contents</div> +<ul class="sectlevel1"> +<li><a href="#_overview">1. Overview</a> +<ul class="sectlevel2"> +<li><a href="#_rationale">1.1. Rationale</a></li> +<li><a href="#_project_key_features">1.2. Project Key Features</a></li> +<li><a href="#_project_folder_structure">1.3. Project Folder Structure</a></li> +<li><a href="#_vhdl_file_hierarchy">1.4. VHDL File Hierarchy</a></li> +<li><a href="#_vhdl_coding_style">1.5. VHDL Coding Style</a></li> +<li><a href="#_fpga_implementation_results">1.6. FPGA Implementation Results</a></li> +<li><a href="#_cpu_performance">1.7. CPU Performance</a></li> +</ul> +</li> +<li><a href="#_neorv32_processor_soc">2. NEORV32 Processor (SoC)</a> +<ul class="sectlevel2"> +<li><a href="#_processor_top_entity_signals">2.1. Processor Top Entity - Signals</a></li> +<li><a href="#_processor_top_entity_generics">2.2. Processor Top Entity - Generics</a></li> +<li><a href="#_processor_clocking">2.3. Processor Clocking</a> +<ul class="sectlevel3"> +<li><a href="#_clock_gating">2.3.1. Clock Gating</a></li> +<li><a href="#_peripheral_clocks">2.3.2. Peripheral Clocks</a></li> +</ul> +</li> +<li><a href="#_processor_reset">2.4. Processor Reset</a></li> +<li><a href="#_processor_interrupts">2.5. Processor Interrupts</a> +<ul class="sectlevel3"> +<li><a href="#_risc_v_standard_interrupts">2.5.1. RISC-V Standard Interrupts</a></li> +<li><a href="#_neorv32_specific_fast_interrupt_requests">2.5.2. NEORV32-Specific Fast Interrupt Requests</a></li> +</ul> +</li> +<li><a href="#_address_space">2.6. Address Space</a> +<ul class="sectlevel3"> +<li><a href="#_bus_system">2.6.1. Bus System</a></li> +<li><a href="#_bus_gateway">2.6.2. Bus Gateway</a></li> +<li><a href="#_reservation_set_controller">2.6.3. Reservation Set Controller</a></li> +<li><a href="#_io_switch">2.6.4. IO Switch</a></li> +<li><a href="#_boot_configuration">2.6.5. Boot Configuration</a></li> +</ul> +</li> +<li><a href="#_processor_internal_modules">2.7. Processor-Internal Modules</a> +<ul class="sectlevel3"> +<li><a href="#_instruction_memory_imem">2.7.1. Instruction Memory (IMEM)</a></li> +<li><a href="#_data_memory_dmem">2.7.2. Data Memory (DMEM)</a></li> +<li><a href="#_bootloader_rom_bootrom">2.7.3. Bootloader ROM (BOOTROM)</a></li> +<li><a href="#_processor_internal_instruction_cache_icache">2.7.4. Processor-Internal Instruction Cache (iCACHE)</a></li> +<li><a href="#_processor_internal_data_cache_dcache">2.7.5. Processor-Internal Data Cache (dCACHE)</a></li> +<li><a href="#_direct_memory_access_controller_dma">2.7.6. Direct Memory Access Controller (DMA)</a></li> +<li><a href="#_processor_external_bus_interface_xbus">2.7.7. Processor-External Bus Interface (XBUS)</a></li> +<li><a href="#_stream_link_interface_slink">2.7.8. Stream Link Interface (SLINK)</a></li> +<li><a href="#_general_purpose_input_and_output_port_gpio">2.7.9. General Purpose Input and Output Port (GPIO)</a></li> +<li><a href="#_cyclic_redundancy_check_crc">2.7.10. Cyclic Redundancy Check (CRC)</a></li> +<li><a href="#_watchdog_timer_wdt">2.7.11. Watchdog Timer (WDT)</a></li> +<li><a href="#_machine_system_timer_mtime">2.7.12. Machine System Timer (MTIME)</a></li> +<li><a href="#_primary_universal_asynchronous_receiver_and_transmitter_uart0">2.7.13. Primary Universal Asynchronous Receiver and Transmitter (UART0)</a></li> +<li><a href="#_secondary_universal_asynchronous_receiver_and_transmitter_uart1">2.7.14. Secondary Universal Asynchronous Receiver and Transmitter (UART1)</a></li> +<li><a href="#_serial_peripheral_interface_controller_spi">2.7.15. Serial Peripheral Interface Controller (SPI)</a></li> +<li><a href="#_serial_data_interface_controller_sdi">2.7.16. Serial Data Interface Controller (SDI)</a></li> +<li><a href="#_two_wire_serial_interface_controller_twi">2.7.17. Two-Wire Serial Interface Controller (TWI)</a></li> +<li><a href="#_one_wire_serial_interface_controller_onewire">2.7.18. One-Wire Serial Interface Controller (ONEWIRE)</a></li> +<li><a href="#_pulse_width_modulation_controller_pwm">2.7.19. Pulse-Width Modulation Controller (PWM)</a></li> +<li><a href="#_true_random_number_generator_trng">2.7.20. True Random-Number Generator (TRNG)</a></li> +<li><a href="#_custom_functions_subsystem_cfs">2.7.21. Custom Functions Subsystem (CFS)</a></li> +<li><a href="#_smart_led_interface_neoled">2.7.22. Smart LED Interface (NEOLED)</a></li> +<li><a href="#_external_interrupt_controller_xirq">2.7.23. External Interrupt Controller (XIRQ)</a></li> +<li><a href="#_general_purpose_timer_gptmr">2.7.24. General Purpose Timer (GPTMR)</a></li> +<li><a href="#_execute_in_place_module_xip">2.7.25. Execute In Place Module (XIP)</a></li> +<li><a href="#_system_configuration_information_memory_sysinfo">2.7.26. System Configuration Information Memory (SYSINFO)</a></li> +</ul> +</li> +</ul> +</li> +<li><a href="#_neorv32_central_processing_unit_cpu">3. NEORV32 Central Processing Unit (CPU)</a> +<ul class="sectlevel2"> +<li><a href="#_risc_v_compatibility">3.1. RISC-V Compatibility</a></li> +<li><a href="#_cpu_top_entity_signals">3.2. CPU Top Entity - Signals</a></li> +<li><a href="#_cpu_top_entity_generics">3.3. CPU Top Entity - Generics</a></li> +<li><a href="#_architecture">3.4. Architecture</a> +<ul class="sectlevel3"> +<li><a href="#_cpu_register_file">3.4.1. CPU Register File</a></li> +<li><a href="#_cpu_arithmetic_logic_unit">3.4.2. CPU Arithmetic Logic Unit</a></li> +<li><a href="#_cpu_bus_unit">3.4.3. CPU Bus Unit</a></li> +<li><a href="#_cpu_control_unit">3.4.4. CPU Control Unit</a></li> +<li><a href="#_sleep_mode">3.4.5. Sleep Mode</a></li> +<li><a href="#_full_virtualization">3.4.6. Full Virtualization</a></li> +</ul> +</li> +<li><a href="#_bus_interface">3.5. Bus Interface</a> +<ul class="sectlevel3"> +<li><a href="#_bus_interface_protocol">3.5.1. Bus Interface Protocol</a></li> +<li><a href="#_atomic_accesses">3.5.2. Atomic Accesses</a></li> +</ul> +</li> +<li><a href="#_instruction_sets_and_extensions">3.6. Instruction Sets and Extensions</a> +<ul class="sectlevel3"> +<li><a href="#_a_isa_extension">3.6.1. <code>A</code> ISA Extension</a></li> +<li><a href="#_b_isa_extension">3.6.2. <code>B</code> ISA Extension</a></li> +<li><a href="#_c_isa_extension">3.6.3. <code>C</code> ISA Extension</a></li> +<li><a href="#_e_isa_extension">3.6.4. <code>E</code> ISA Extension</a></li> +<li><a href="#_i_isa_extension">3.6.5. <code>I</code> ISA Extension</a></li> +<li><a href="#_m_isa_extension">3.6.6. <code>M</code> ISA Extension</a></li> +<li><a href="#_u_isa_extension">3.6.7. <code>U</code> ISA Extension</a></li> +<li><a href="#_x_isa_extension">3.6.8. <code>X</code> ISA Extension</a></li> +<li><a href="#_zifencei_isa_extension">3.6.9. <code>Zifencei</code> ISA Extension</a></li> +<li><a href="#_zfinx_isa_extension">3.6.10. <code>Zfinx</code> ISA Extension</a></li> +<li><a href="#_zicntr_isa_extension">3.6.11. <code>Zicntr</code> ISA Extension</a></li> +<li><a href="#_zicond_isa_extension">3.6.12. <code>Zicond</code> ISA Extension</a></li> +<li><a href="#_zicsr_isa_extension">3.6.13. <code>Zicsr</code> ISA Extension</a></li> +<li><a href="#_zihpm_isa_extension">3.6.14. <code>Zihpm</code> ISA Extension</a></li> +<li><a href="#_zmmul_isa_extension">3.6.15. <code>Zmmul</code> - ISA Extension</a></li> +<li><a href="#_zxcfu_isa_extension">3.6.16. <code>Zxcfu</code> ISA Extension</a></li> +<li><a href="#_smpmp_isa_extension">3.6.17. <code>Smpmp</code> ISA Extension</a></li> +<li><a href="#_sdext_isa_extension">3.6.18. <code>Sdext</code> ISA Extension</a></li> +<li><a href="#_sdtrig_isa_extension">3.6.19. <code>Sdtrig</code> ISA Extension</a></li> +</ul> +</li> +<li><a href="#_custom_functions_unit_cfu">3.7. Custom Functions Unit (CFU)</a> +<ul class="sectlevel3"> +<li><a href="#_cfu_instruction_formats">3.7.1. CFU Instruction Formats</a></li> +<li><a href="#_using_custom_instructions_in_software">3.7.2. Using Custom Instructions in Software</a></li> +<li><a href="#_cfu_control_and_status_registers_cfu_csrs">3.7.3. CFU Control and Status Registers (CFU-CSRs)</a></li> +<li><a href="#_custom_instructions_hardware">3.7.4. Custom Instructions Hardware</a></li> +</ul> +</li> +<li><a href="#_control_and_status_registers_csrs">3.8. Control and Status Registers (CSRs)</a> +<ul class="sectlevel3"> +<li><a href="#_floating_point_csrs">3.8.1. Floating-Point CSRs</a></li> +<li><a href="#_machine_trap_setup_csrs">3.8.2. Machine Trap Setup CSRs</a></li> +<li><a href="#_machine_trap_handling_csrs">3.8.3. Machine Trap Handling CSRs</a></li> +<li><a href="#_machine_configuration_csrs">3.8.4. Machine Configuration CSRs</a></li> +<li><a href="#_machine_physical_memory_protection_csrs">3.8.5. Machine Physical Memory Protection CSRs</a></li> +<li><a href="#_custom_functions_unit_cfu_csrs">3.8.6. Custom Functions Unit (CFU) CSRs</a></li> +<li><a href="#_machine_counter_and_timer_csrs">3.8.7. (Machine) Counter and Timer CSRs</a></li> +<li><a href="#_hardware_performance_monitors_hpm_csrs">3.8.8. Hardware Performance Monitors (HPM) CSRs</a></li> +<li><a href="#_machine_counter_setup_csrs">3.8.9. Machine Counter Setup CSRs</a></li> +<li><a href="#_machine_information_csrs">3.8.10. Machine Information CSRs</a></li> +<li><a href="#_neorv32_specific_csrs">3.8.11. NEORV32-Specific CSRs</a></li> +<li><a href="#_traps_exceptions_and_interrupts">3.8.12. Traps, Exceptions and Interrupts</a></li> +</ul> +</li> +</ul> +</li> +<li><a href="#_software_framework">4. Software Framework</a> +<ul class="sectlevel2"> +<li><a href="#_compiler_toolchain">4.1. Compiler Toolchain</a></li> +<li><a href="#_core_libraries">4.2. Core Libraries</a></li> +<li><a href="#_application_makefile">4.3. Application Makefile</a> +<ul class="sectlevel3"> +<li><a href="#_makefile_targets">4.3.1. Makefile Targets</a></li> +<li><a href="#_makefile_configuration">4.3.2. Makefile Configuration</a></li> +<li><a href="#_default_compiler_flags">4.3.3. Default Compiler Flags</a></li> +<li><a href="#_custom_compiler_flags">4.3.4. Custom (Compiler) Flags</a></li> +</ul> +</li> +<li><a href="#_executable_image_format">4.4. Executable Image Format</a> +<ul class="sectlevel3"> +<li><a href="#_linker_script">4.4.1. Linker Script</a></li> +<li><a href="#_ram_layout">4.4.2. RAM Layout</a></li> +<li><a href="#_c_standard_library">4.4.3. C Standard Library</a></li> +<li><a href="#_executable_image_generator">4.4.4. Executable Image Generator</a></li> +<li><a href="#_start_up_code_crt0">4.4.5. Start-Up Code (crt0)</a></li> +</ul> +</li> +<li><a href="#_bootloader">4.5. Bootloader</a> +<ul class="sectlevel3"> +<li><a href="#_bootloader_soccpu_requirements">4.5.1. Bootloader SoC/CPU Requirements</a></li> +<li><a href="#_bootloader_flash_requirements">4.5.2. Bootloader Flash Requirements</a></li> +<li><a href="#_bootloader_console">4.5.3. Bootloader Console</a></li> +<li><a href="#_auto_boot_sequence">4.5.4. Auto Boot Sequence</a></li> +<li><a href="#_bootloader_error_codes">4.5.5. Bootloader Error Codes</a></li> +</ul> +</li> +<li><a href="#_neorv32_runtime_environment">4.6. NEORV32 Runtime Environment</a> +<ul class="sectlevel3"> +<li><a href="#_rte_operation">4.6.1. RTE Operation</a></li> +<li><a href="#_using_the_rte">4.6.2. Using the RTE</a></li> +<li><a href="#_default_rte_trap_handlers">4.6.3. Default RTE Trap Handlers</a></li> +<li><a href="#_application_context_handling">4.6.4. Application Context Handling</a></li> +</ul> +</li> +</ul> +</li> +<li><a href="#_on_chip_debugger_ocd">5. On-Chip Debugger (OCD)</a> +<ul class="sectlevel2"> +<li><a href="#_debug_transport_module_dtm">5.1. Debug Transport Module (DTM)</a></li> +<li><a href="#_debug_module_dm">5.2. Debug Module (DM)</a> +<ul class="sectlevel3"> +<li><a href="#_dm_registers">5.2.1. DM Registers</a></li> +<li><a href="#_dm_cpu_access">5.2.2. DM CPU Access</a></li> +</ul> +</li> +<li><a href="#_cpu_debug_mode">5.3. CPU Debug Mode</a> +<ul class="sectlevel3"> +<li><a href="#_cpu_debug_mode_csrs">5.3.1. CPU Debug Mode CSRs</a></li> +</ul> +</li> +<li><a href="#_trigger_module">5.4. Trigger Module</a> +<ul class="sectlevel3"> +<li><a href="#_trigger_module_csrs">5.4.1. Trigger Module CSRs</a></li> +</ul> +</li> +</ul> +</li> +<li><a href="#_legal">6. Legal</a> +<ul class="sectlevel2"> +<li><a href="#_about">About</a></li> +<li><a href="#_license">License</a></li> +<li><a href="#_proprietary_notice">Proprietary Notice</a></li> +<li><a href="#_disclaimer">Disclaimer</a></li> +<li><a href="#_limitation_of_liability_for_external_links">Limitation of Liability for External Links</a></li> +<li><a href="#_citing">Citing</a></li> +<li><a href="#_acknowledgments">Acknowledgments</a></li> +</ul> +</li> +</ul> +</div> +</div> +<div id="content"> +<div id="preamble"> +<div class="sectionbody"> +<div class="imageblock text-center"> +<div class="content"> +<a class="image" href="https://github.com/stnolting/neorv32"><img src="img/neorv32_logo.png" alt="neorv32 logo"></a> +</div> +</div> +<div class="imageblock text-center"> +<div class="content"> +<a class="image" href="https://riscv.org/"><img src="img/riscv_logo.png" alt="riscv logo" width="350"></a> +</div> +</div> +<div class="paragraph text-center"> +<p><a href="https://github.com/stnolting/neorv32"><span class="image"><img src="https://img.shields.io/badge/GitHub-stnolting%2Fneorv32-ffbd00?style=flat-square&amp;logo=github&amp;" alt="GitHub stnolting%2Fneorv32 ffbd00?style=flat square&amp;logo=github&amp;" title="homepage"></span></a> +<a href="https://github.com/stnolting/neorv32/blob/main/LICENSE"><span class="image"><img src="https://img.shields.io/github/license/stnolting/neorv32?longCache=true&amp;style=flat-square" alt="neorv32?longCache=true&amp;style=flat square" title="license"></span></a> +<a href="https://github.com/stnolting/neorv32/releases/tag/nightly"><span class="image"><img src="https://img.shields.io/badge/data%20sheet-PDF-ffbd00?longCache=true&amp;style=flat-square&amp;logo=asciidoctor" alt="data%20sheet PDF ffbd00?longCache=true&amp;style=flat square&amp;logo=asciidoctor" title="datasheet (pdf)"></span></a> +<a href="https://github.com/stnolting/neorv32/releases/tag/nightly"><span class="image"><img src="https://img.shields.io/badge/user%20guide-PDF-ffbd00?longCache=true&amp;style=flat-square&amp;logo=asciidoctor" alt="user%20guide PDF ffbd00?longCache=true&amp;style=flat square&amp;logo=asciidoctor" title="userguide (pdf)"></span></a> +<a href="https://stnolting.github.io/neorv32/ug"><span class="image"><img src="https://img.shields.io/badge/-HTML-ffbd00?longCache=true&amp;style=flat-square" alt=" HTML ffbd00?longCache=true&amp;style=flat square" title="userguide (html)"></span></a> +<a href="https://stnolting.github.io/neorv32/sw/files.html"><span class="image"><img src="https://img.shields.io/badge/doxygen-HTML-ffbd00?longCache=true&amp;style=flat-square&amp;logo=Doxygen" alt="doxygen HTML ffbd00?longCache=true&amp;style=flat square&amp;logo=Doxygen" title="doxygen"></span></a><br> +<a href="https://github.com/stnolting/neorv32/releases"><span class="image"><img src="https://img.shields.io/github/v/release/stnolting/neorv32?longCache=true&amp;style=flat-square&amp;logo=GitHub" alt="neorv32?longCache=true&amp;style=flat square&amp;logo=GitHub" title="release"></span></a> +<a href="https://github.com/stnolting/neorv32/releases"><span class="image"><img src="https://img.shields.io/github/commits-since/stnolting/neorv32/latest?longCache=true&amp;style=flat-square&amp;logo=GitHub" alt="latest?longCache=true&amp;style=flat square&amp;logo=GitHub" title="release-commits"></span></a></p> +</div> +<div style="page-break-after: always;"></div> +</div> +</div> +<div class="sect1"> +<h2 id="_overview">1. Overview</h2> +<div class="sectionbody"> +<div class="paragraph"> +<p>The NEORV32 RISC-V Processor is an open-source RISC-V compatible processor system that is intended as +<strong>ready-to-go</strong> auxiliary processor within a larger SoC designs or as stand-alone custom / customizable +microcontroller.</p> +</div> +<div class="paragraph"> +<p>The system is highly configurable and provides optional common peripherals like embedded memories, +timers, serial interfaces, general purpose IO ports and an external bus interface to connect custom IP like +memories, NoCs and other peripherals. On-line and in-system debugging is supported by an OpenOCD/gdb +compatible on-chip debugger accessible via JTAG.</p> +</div> +<div class="paragraph"> +<p>Special focus is paid on <strong>execution safety</strong> to provide defined and predictable behavior at any time. +Therefore, the CPU ensures that all memory access are acknowledged and no invalid/malformed instructions +are executed. Whenever an unexpected situation occurs, the application code is informed via hardware exceptions.</p> +</div> +<div class="paragraph"> +<p>The software framework of the processor comes with application makefiles, software libraries for all CPU +and processor features, a bootloader, a runtime environment and several example programs - including a port +of the CoreMark MCU benchmark and the official RISC-V architecture test suite. RISC-V GCC is used as +default toolchain (<a href="https://github.com/stnolting/riscv-gcc-prebuilt">prebuilt toolchains are also provided</a>).</p> +</div> +<div class="paragraph"> +<p>Check out the processor&#8217;s <strong><a href="https://stnolting.github.io/neorv32/ug">online User Guide</a></strong> +that provides hands-on tutorials to get you started.</p> +</div> +<div class="paragraph"> +<p><strong>Structure</strong></p> +</div> +<div class="olist arabic"> +<ol class="arabic" start="2"> +<li> +<p><a href="#_neorv32_processor_soc">NEORV32 Processor (SoC)</a></p> +</li> +<li> +<p><a href="#_neorv32_central_processing_unit_cpu">NEORV32 Central Processing Unit (CPU)</a></p> +</li> +<li> +<p><a href="#_software_framework">Software Framework</a></p> +</li> +<li> +<p><a href="#_on_chip_debugger_ocd">On-Chip Debugger (OCD)</a></p> +</li> +<li> +<p><a href="#_legal">Legal</a></p> +</li> +</ol> +</div> +<div class="paragraph"> +<p><strong>Annotations</strong></p> +</div> +<div class="admonitionblock warning"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-warning" title="Warning"></i> +</td> +<td class="content"> +Warning +</td> +</tr> +</table> +</div> +<div class="admonitionblock important"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-important" title="Important"></i> +</td> +<td class="content"> +Important +</td> +</tr> +</table> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +Note +</td> +</tr> +</table> +</div> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +Tip +</td> +</tr> +</table> +</div> +<div style="page-break-after: always;"></div> +<div class="sect2"> +<h3 id="_rationale">1.1. Rationale</h3> +<h4 id="_why_did_you_make_this" class="discrete">Why did you make this?</h4> +<div class="paragraph"> +<p>Processor and CPU architecture designs are fascinating things: they are the magic frontier where software meets hardware. +This project started as something like a <em>journey</em> into this magic realm to understand how things actually work +down on this very low level and evolved over time to a capable system on chip.</p> +</div> +<div class="paragraph"> +<p>But there is more: when I started to dive into the emerging RISC-V ecosystem I felt overwhelmed by the complexity. +As a beginner it is hard to get an overview - especially when you want to setup a minimal platform to tinker with&#8230;&#8203; +Which core to use? How to get the right toolchain? What features do I need? How does booting work? How do I +create an actual executable? How to get that into the hardware? How to customize things? <strong><em>Where to start???</em></strong></p> +</div> +<div class="paragraph"> +<p>This project aims to provide a <em>simple to understand</em> and <em>easy to use</em> yet <em>powerful</em> and <em>flexible</em> platform +that targets FPGA and RISC-V beginners as well as advanced users.</p> +</div> +<h4 id="_why_a_soft_core_processor" class="discrete">Why a <em>soft-core</em> processor?</h4> +<div class="paragraph"> +<p>As a matter of fact soft-core processors <em>cannot</em> compete with discrete (like FPGA hard-macro) processors in terms +of performance, energy efficiency and size. But they do fill a niche in FPGA design space: for example, soft-core +processors allow to implement the <em>control flow part</em> of certain applications (e.g. communication protocol handling) +using software like plain C. This provides high flexibility as software can be easily changed, re-compiled and +re-uploaded again.</p> +</div> +<div class="paragraph"> +<p>Furthermore, the concept of flexibility applies to all aspects of a soft-core processor. The user can add +<em>exactly</em> the features that are required by the application: additional memories, custom interfaces, specialized +co-processors and even user-defined instructions.</p> +</div> +<h4 id="_why_risc_v" class="discrete">Why RISC-V?</h4> +<div class="imageblock text-left"> +<div class="content"> +<img src="img/riscv_logo.png" alt="riscv logo" width="250"> +</div> +</div> +<div class="quoteblock"> +<blockquote> +<div class="paragraph"> +<p>RISC-V is a free and open ISA enabling a new era of processor innovation through open standard collaboration.</p> +</div> +</blockquote> +<div class="attribution"> +&#8212; RISC-V International<br> +<cite>https://riscv.org/about/</cite> +</div> +</div> +<div class="paragraph"> +<p>Open-source is a great thing! +While open-source has already become quite popular in <em>software</em>, hardware-focused projects still need to catch up. +Admittedly, there has been quite a development, but mainly in terms of <em>platforms</em> and <em>applications</em> (so +schematics, PCBs, etc.). Although processors and CPUs are the heart of almost every digital system, having a true +open-source silicon is still a rarity. RISC-V aims to change that - and even it is <em>just one approach</em>, it helps paving +the road for future development.</p> +</div> +<div class="paragraph"> +<p>Furthermore, I highly appreciate the community aspect of RISC-V. The ISA and everything beyond is developed in direct +contact with the community: this includes businesses and professionals but also hobbyist, amateurs and people +that are just curious. Everyone can join discussions and contribute to RISC-V in their very own way.</p> +</div> +<div class="paragraph"> +<p>Finally, I really like the RISC-V ISA itself. It aims to be a clean, orthogonal and "intuitive" ISA that +resembles with the basic concepts of <em>RISC</em>: simple yet effective.</p> +</div> +<h4 id="_yet_another_risc_v_core_what_makes_it_special" class="discrete">Yet another RISC-V core? What makes it special?</h4> +<div class="paragraph"> +<p>The NEORV32 is not based on another RISC-V core. It was build entirely from ground up (just following the official +ISA specs). The project does not intend to replace certain RISC-V cores or +just beat existing ones like <a href="https://github.com/SpinalHDL/VexRiscv">VexRISC</a> in terms of performance or +<a href="https://github.com/olofk/serv">SERV</a> in terms of size. It was build having a different design goal in mind.</p> +</div> +<div class="paragraph"> +<p>The project aims to provide <em>another option</em> in the RISC-V / soft-core design space with a different performance +vs. size trade-off and a different focus: <em>embrace</em> concepts like documentation, platform-independence / portability, +RISC-V compatibility, <em>extensibility &amp; customization</em> and <em>ease of use</em> (see the <a href="#_project_key_features">Project Key Features</a> below).</p> +</div> +<div class="paragraph"> +<p>Furthermore, the NEORV32 pays special focus on <em>execution safety</em> using <a href="#_full_virtualization">Full Virtualization</a>. The CPU aims to +provide fall-backs for <em>everything that could go wrong</em>. This includes malformed instruction words, privilege escalations +and even memory accesses that are checked for address space holes and deterministic response times of memory-mapped +devices. Precise exceptions allow a defined and fully-synchronized state of the CPU at every time an in every situation.</p> +</div> +<h4 id="_a_multi_cycle_architecture" class="discrete">A multi-cycle architecture?!?!</h4> +<div class="paragraph"> +<p>Most mainstream CPUs out there are pipelined architectures to increase throughput. In contrast, most CPUs used for +teaching are single-cycle designs since they are probably the most easiest to understand. But what about the +multi-cycle architectures?</p> +</div> +<div class="paragraph"> +<p>In terms of energy, throughput, area and maximal clock frequency multi-cycle architectures are somewhere in between +single-cycle and fully-pipelined designs: they provide higher throughput and clock speed when compared to their +single-cycle counterparts while having less hardware complexity (= area) then a fully-pipelined designs. I decided to +use the multi-cycle approach because of the following reasons:</p> +</div> +<div class="ulist"> +<ul> +<li> +<p>Multi-cycle architecture are quite small! There is no need for pipeline hazard detection and resolution logic +(e.g. forwarding). Furthermore, you can "re-use" parts of the core to do several tasks (e.g. the ALU is used for the +actual data processing, but also for address generation, branch condition check and branch target computation).</p> +</li> +<li> +<p>Single-cycle architectures require memories that can be read asynchronously - a thing that is not feasible to implement +in real world applications (i.e. FPGA block RAM is entirely synchronous). Furthermore, such design usually have a very +long critical path tremendously reducing maximal operating frequency.</p> +</li> +<li> +<p>Pipelined designs increase performance by having several instruction "in fly" at the same time. But this also means +there is some kind of "out-of-order" behavior: if an instruction at the end of the pipeline causes an exception +all the instructions in earlier stages have to be invalidated. Potential architecture state changes have to be made <em>undone</em> +requiring additional (exception-handling) logic. In a multi-cycle architecture this situation cannot occur because only a +single instruction is "in fly" at a time.</p> +</li> +<li> +<p>Having only a single instruction in fly does not only reduce hardware costs, it also simplifies +simulation/verification/debugging, state preservation/restoring during exceptions and extensibility (no need to care +about pipeline hazards) - but of course at the cost of reduced throughput.</p> +</li> +</ul> +</div> +<div class="paragraph"> +<p>To counteract the loss of performance implied by a <em>pure</em> multi-cycle architecture, the NEORV32 CPU uses a <em>mixed</em> +approach: instruction fetch (front-end) and instruction execution (back-end) are de-coupled to operate independently +of each other. Data is interchanged via a queue building a simple 2-stage pipeline. Each "pipeline" stage in terms is +implemented as multi-cycle architecture to simplify the hardware and to provide <em>precise</em> state control (e.g. during +exceptions).</p> +</div> +</div> +<div class="sect2"> +<h3 id="_project_key_features">1.2. Project Key Features</h3> +<div class="paragraph"> +<p><strong>Project</strong></p> +</div> +<div class="ulist"> +<ul> +<li> +<p>all-in-one package: <strong>CPU</strong> + <strong>SoC</strong> + <strong>Software Framework &amp; Tooling</strong></p> +</li> +<li> +<p>completely described in behavioral, platform-independent VHDL - no vendor- or technology-specific primitives, attributes, macros, libraries, etc. are used at all</p> +</li> +<li> +<p>all-Verilog "version" available (auto-generated netlist)</p> +</li> +<li> +<p>extensive configuration options for adapting the processor to the requirements of the application</p> +</li> +<li> +<p>highly extensible hardware - on CPU, SoC and system level</p> +</li> +<li> +<p>aims to be as small as possible while being as RISC-V-compliant as possible - with a reasonable area-vs-performance trade-off</p> +</li> +<li> +<p>FPGA friendly (e.g. all internal memories can be mapped to block RAM - including the register file)</p> +</li> +<li> +<p>optimized for high clock frequencies to ease timing closure and integration</p> +</li> +<li> +<p>from zero to <em>"hello world!"</em> - completely open source and documented</p> +</li> +<li> +<p>easy to use even for FPGA/RISC-V starters – intended to <em>work out of the box</em></p> +</li> +</ul> +</div> +<div class="paragraph"> +<p><strong>NEORV32 CPU (the core)</strong></p> +</div> +<div class="ulist"> +<ul> +<li> +<p>32-bit RISC-V CPU</p> +</li> +<li> +<p>fully compatible to the RISC-V ISA specs. - checked by the <a href="https://github.com/stnolting/neorv32-riscof">official RISCOF architecture tests</a></p> +</li> +<li> +<p>base ISA + privileged ISA + several optional standard and custom ISA extensions</p> +</li> +<li> +<p>option to add user-defined RISC-V instructions as custom ISA extension</p> +</li> +<li> +<p>rich set of customization options (ISA extensions, design goal: performance / area / energy, tuning options, &#8230;&#8203;)</p> +</li> +<li> +<p><a href="#_full_virtualization">Full Virtualization</a> capabilities to increase execution safety</p> +</li> +<li> +<p>official RISC-V open source architecture ID</p> +</li> +</ul> +</div> +<div class="paragraph"> +<p><strong>NEORV32 Processor (the SoC)</strong></p> +</div> +<div class="ulist"> +<ul> +<li> +<p>highly-configurable full-scale microcontroller-like processor system</p> +</li> +<li> +<p>based on the NEORV32 CPU</p> +</li> +<li> +<p>optional standard serial interfaces (UART, TWI, SPI (host and device), 1-Wire)</p> +</li> +<li> +<p>optional timers and counters (watchdog, system timer)</p> +</li> +<li> +<p>optional general purpose IO and PWM; a native NeoPixel(c)-compatible smart LED interface</p> +</li> +<li> +<p>optional embedded memories and caches for data, instructions and bootloader</p> +</li> +<li> +<p>optional external memory interface for custom connectivity</p> +</li> +<li> +<p>optional execute in-place (XIP) module to execute code directly form an external SPI flash</p> +</li> +<li> +<p>optional DMA controller for CPU-independent data transfers</p> +</li> +<li> +<p>optional CRC module to check data integrity</p> +</li> +<li> +<p>on-chip debugger compatible with OpenOCD and gdb including hardware trigger module</p> +</li> +</ul> +</div> +<div class="paragraph"> +<p><strong>Software framework</strong></p> +</div> +<div class="ulist"> +<ul> +<li> +<p>GCC-based toolchain - <a href="https://github.com/stnolting/riscv-gcc-prebuilt">prebuilt toolchains available</a>; application compilation based on GNU makefiles</p> +</li> +<li> +<p>internal bootloader with serial user interface (via UART)</p> +</li> +<li> +<p>core libraries and HAL for high-level usage of the provided functions and peripherals</p> +</li> +<li> +<p>processor-specific runtime environment and several example programs</p> +</li> +<li> +<p>doxygen-based documentation of the software framework; a deployed version is available at <a href="https://stnolting.github.io/neorv32/sw/files.html" class="bare">https://stnolting.github.io/neorv32/sw/files.html</a></p> +</li> +<li> +<p>FreeRTOS port + demos available</p> +</li> +</ul> +</div> +<div class="paragraph"> +<p><strong>Extensibility and Customization</strong></p> +</div> +<div class="paragraph"> +<p>The NEORV32 processor is designed to ease customization and extensibility and provides several options for adding +application-specific custom hardware modules and accelerators. The three most common options for adding custom +on-chip modules are listed below.</p> +</div> +<div class="ulist"> +<ul> +<li> +<p><a href="#_processor_external_bus_interface_xbus">Processor-External Bus Interface (XBUS)</a> to attach processor-external IP modules (memories and peripherals)</p> +</li> +<li> +<p><a href="#_custom_functions_subsystem_cfs">Custom Functions Subsystem (CFS)</a> for tightly-coupled processor-internal co-processors</p> +</li> +<li> +<p><a href="#_custom_functions_unit_cfu">Custom Functions Unit (CFU)</a> for custom RISC-V instructions</p> +</li> +</ul> +</div> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +A more detailed comparison of the extension/customization options can be found in section +<a href="https://stnolting.github.io/neorv32/ug/#_adding_custom_hardware_modules">Adding Custom Hardware Modules</a> +of the user guide. +</td> +</tr> +</table> +</div> +<div style="page-break-after: always;"></div> +</div> +<div class="sect2"> +<h3 id="_project_folder_structure">1.3. Project Folder Structure</h3> +<div class="literalblock"> +<div class="content"> +<pre>neorv32 - Project home folder +│ +├docs - Project documentation +│├datasheet - AsciiDoc sources for the NEORV32 data sheet +│├figures - Figures and logos +│├references - Data sheets and RISC-V specs +│├sources - Sources for the images in 'figures/' +│└userguide - AsciiDoc sources for the NEORV32 user guide +│ +├rtl - VHDL sources +│├core - Core sources of the CPU &amp; SoC +││└mem - SoC-internal memories (default architectures) +│├processor_templates - Pre-configured SoC wrappers +│├system_integration - System wrappers and bridges for advanced connectivity +│└test_setups - Minimal test setup "SoCs" used in the User Guide +│ +├sim - Simulation files +│ +└-sw - Software framework + ├bootloader - Sources of the processor-internal bootloader + ├common - Linker script, crt0.S start-up code and central makefile + ├example - Example programs for the core and the SoC modules + │├eclipse - Pre-configured Eclipse IDE project + │└... - Several example programs + ├lib - Processor core library + │├include - NEORV32 core library header files (*.h) + │└source - NEORV32 core library source files (*.c) + ├image_gen - Helper program to generate executables &amp; memory images + ├ocd_firmware - Firmware for the on-chip debugger's "park loop" + ├openocd - OpenOCD configuration files + └svd - Processor system view description file (CMSIS-SVD)</pre> +</div> +</div> +<div style="page-break-after: always;"></div> +</div> +<div class="sect2"> +<h3 id="_vhdl_file_hierarchy">1.4. VHDL File Hierarchy</h3> +<div class="paragraph"> +<p>All necessary VHDL hardware description files are located in the project&#8217;s <code>rtl/core</code> folder. The top entity +of the entire processor including all the required configuration generics is <code>neorv32_top.vhd</code>.</p> +</div> +<div class="admonitionblock important"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-important" title="Important"></i> +</td> +<td class="content"> +<div class="title">Compile Order / File-List Files</div> +Most of the RTL sources use <strong>entity instantiation</strong>. Hence, the RTL compile order might be relevant. +Therefore, two file list files (<code>*.f</code>) are provided in the <code>rtl</code> folder that list all required rtl files +for the CPU core and for the entire processor and also represent their recommended compile order. +</td> +</tr> +</table> +</div> +<div class="admonitionblock important"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-important" title="Important"></i> +</td> +<td class="content"> +<div class="title">VHDL Library</div> +All core VHDL files from the list below have to be assigned to a <strong>new library</strong> named <code>neorv32</code>. +</td> +</tr> +</table> +</div> +<div class="literalblock"> +<div class="content"> +<pre>neorv32_top.vhd - NEORV32 PROCESSOR TOP ENTITY +│ +├neorv32_cpu.vhd - NEORV32 CPU TOP ENTIT +│├neorv32_cpu_alu.vhd - Arithmetic/logic unit +││├neorv32_cpu_cp_bitmanip.vhd - Bit-manipulation co-processor (B ext.) +││├neorv32_cpu_cp_cfu.vhd - Custom instructions co-processor (Zxcfu ext.) +││├neorv32_cpu_cp_cond.vhd - Integer conditional operations (Zicond ext.) +││├neorv32_cpu_cp_fpu.vhd - Floating-point co-processor (Zfinx ext.) +││├neorv32_cpu_cp_shifter.vhd - Bit-shift co-processor (base ISA) +││├neorv32_cpu_cp_muldiv.vhd - Mul/Div co-processor (M ext.) +│├neorv32_cpu_control.vhd - CPU control, exception system and CSRs +││└neorv32_cpu_decompressor.vhd - Compressed instructions decoder (C ext.) +│├neorv32_cpu_lsu.vhd - Load/store unit +│├neorv32_cpu_pmp.vhd - Physical memory protection unit (Smpmp ext.) +│└neorv32_cpu_regfile.vhd - Data register file +│ +├neorv32_boot_rom.vhd - Bootloader ROM +│└neorv32_bootloader_image.vhd - Bootloader ROM memory image +├neorv32_cfs.vhd - Custom functions subsystem +├neorv32_clockgate.vhd - Generic clock gating switch +├neorv32_crc.vhd - Cyclic redundancy check unit +├neorv32_cache.vhd - Generic cache module +├neorv32_debug_dm.vhd - on-chip debugger: debug module +├neorv32_debug_dtm.vhd - on-chip debugger: debug transfer module +├neorv32_dma.vhd - Direct memory access controller +├neorv32_dmem.entity.vhd - Processor-internal data memory (entity-only!) +├neorv32_fifo.vhd - Generic FIFO component +├neorv32_gpio.vhd - General purpose input/output port unit +├neorv32_gptmr.vhd - General purpose 32-bit timer +├neorv32_imem.entity.vhd - Processor-internal instruction memory (entity-only!) +│└neor32_application_image.vhd - IMEM application initialization image +├neorv32_intercon.vhd - SoC bus infrastructure +├neorv32_mtime.vhd - Machine system timer +├neorv32_neoled.vhd - NeoPixel (TM) compatible smart LED interface +├neorv32_onewire.vhd - One-Wire serial interface controller +├neorv32_package.vhd - Main VHDL package file +├neorv32_pwm.vhd - Pulse-width modulation controller +├neorv32_sdi.vhd - Serial data interface controller (SPI device) +├neorv32_slink.vhd - Stream link interface +├neorv32_spi.vhd - Serial peripheral interface controller (SPI host) +├neorv32_sysinfo.vhd - System configuration information memory +├neorv32_trng.vhd - True random number generator +├neorv32_twi.vhd - Two wire serial interface controller +├neorv32_uart.vhd - Universal async. receiver/transmitter +├neorv32_wdt.vhd - Watchdog timer +├neorv32_xbus.vhd - External (Wishbone) bus interface gateways +├neorv32_xip.vhd - Execute in place module +├neorv32_xirq.vhd - External interrupt controller +│ +├mem/neorv32_dmem.default.vhd - *Default* data memory (architecture-only!) +└mem/neorv32_imem.default.vhd - *Default* instruction memory (architecture-only!)</pre> +</div> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">Processor-Internal Memories</div> +The processor-internal instruction and data memories (IMEM and DMEM) are split into two design files each: +a plain entity definition (<code>neorv32_*mem.entity.vhd</code>) and the actual architecture definition +(<code>mem/neorv32_*mem.default.vhd</code>). The <code>*.default.vhd</code> architecture definitions from <code>rtl/core/mem</code> provide a <em>generic</em> and +<em>platform independent</em> memory design (inferring embedded memory blocks). You can replace/modify the architecture +source file in order to use platform-specific features (like advanced memory resources) or to improve technology mapping +and/or timing. +</td> +</tr> +</table> +</div> +<div style="page-break-after: always;"></div> +</div> +<div class="sect2"> +<h3 id="_vhdl_coding_style">1.5. VHDL Coding Style</h3> +<div class="ulist"> +<ul> +<li> +<p>The entire processor including the CPU core is written in platform-/technology-independent VHDL. +The code makes minimal use of VHDL 2008 features to provide compatibility even for older EDA tools.</p> +</li> +<li> +<p>A single package / library file (<code>neorv32_package.vhd</code>) is used to provide global defines and helper +functions. The specific user-defined configuration is done entirely by the generics of the top entity.</p> +</li> +<li> +<p>Internally, the generics are checked to ensure a correct configuration. Asserts and "sanity checks" are used +to inform the user about the actual processor configuration and potential illegal setting.</p> +</li> +<li> +<p>The code uses <em>entity instation</em> for all internal modules. However, if several "submodules" are specified +within the same file <em>component instantiation</em> is used for those.</p> +</li> +<li> +<p>When instantiating the processor top module (<code>neorv32_top.vhd</code>) in a custom design either entity instantiation or +component instantiation can be used as the NEORV32 package file / library already provides an according component declaration.</p> +</li> +</ul> +</div> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +<div class="title">Verilog Version</div> +A GHDL-generated all-Verilog version of the processor is available at <a href="https://github.com/stnolting/neorv32-verilog" class="bare">https://github.com/stnolting/neorv32-verilog</a>. +The provided setup generates a synthesizable Verilog netlist for a custom processor configuration. +</td> +</tr> +</table> +</div> +<div style="page-break-after: always;"></div> +</div> +<div class="sect2"> +<h3 id="_fpga_implementation_results">1.6. FPGA Implementation Results</h3> +<div class="paragraph"> +<p>This section shows <strong>exemplary</strong> FPGA implementation results for the NEORV32 CPU and NEORV32 Processor modules.</p> +</div> +<div class="admonitionblock important"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-important" title="Important"></i> +</td> +<td class="content"> +The results are generated by manual synthesis runs. Hence, they might not represent the latest version of the processor. +</td> +</tr> +</table> +</div> +<h4 id="_cpu" class="discrete">CPU</h4> +<table class="tableblock frame-all grid-topbot stretch"> +<colgroup> +<col style="width: 20%;"> +<col style="width: 80%;"> +</colgroup> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">HW version:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>1.7.8.5</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Top entity:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>rtl/core/neorv32_cpu.vhd</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">FPGA:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Intel Cyclone IV E <code>EP4CE22F17C6</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Toolchain:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Quartus Prime Lite 21.1</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Constraints:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><strong>no timing constraints</strong>, "balanced optimization", f<sub>max</sub> from "<em>Slow 1200mV 0C Model</em>"</p></td> +</tr> +</tbody> +</table> +<table class="tableblock frame-all grid-rows stretch"> +<colgroup> +<col style="width: 54.5454%;"> +<col style="width: 9.0909%;"> +<col style="width: 9.0909%;"> +<col style="width: 9.0909%;"> +<col style="width: 9.0909%;"> +<col style="width: 9.091%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-left valign-top">CPU ISA Configuration</th> +<th class="tableblock halign-right valign-top">LEs</th> +<th class="tableblock halign-right valign-top">FFs</th> +<th class="tableblock halign-right valign-top">MEM bits</th> +<th class="tableblock halign-right valign-top">DSPs</th> +<th class="tableblock halign-right valign-top"><em>f<sub>max</sub></em></th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>rv32i_Zicsr</code></p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">1223</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">607</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">1024</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">0</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">130 MHz</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>rv32i_Zicsr_Zicntr</code></p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">1578</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">773</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">1024</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">0</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">130 MHz</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>rv32im_Zicsr_Zicntr</code></p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">2087</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">983</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">1024</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">0</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">130 MHz</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>rv32imc_Zicsr_Zicntr</code></p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">2338</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">992</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">1024</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">0</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">130 MHz</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>rv32imcb_Zicsr_Zicntr</code></p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">3175</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">1247</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">1024</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">0</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">130 MHz</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>rv32imcbu_Zicsr_Zicntr</code></p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">3186</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">1254</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">1024</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">0</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">130 MHz</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>rv32imcbu_Zicsr_Zicntr_Zifencei</code></p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">3187</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">1254</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">1024</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">0</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">130 MHz</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>rv32imcbu_Zicsr_Zicntr_Zifencei_Zfinx</code></p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">4450</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">1906</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">1024</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">7</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">123 MHz</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>rv32imcbu_Zicsr_Zicntr_Zifencei_Zfinx_DebugMode</code></p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">4825</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">2018</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">1024</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">7</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">123 MHz</p></td> +</tr> +</tbody> +</table> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +<div class="title">Goal-Driven Optimization</div> +The CPU provides further options to reduce the area footprint or to increase performance. +See section <a href="#_processor_top_entity_generics">Processor Top Entity - Generics</a> for more information. Also, take a look at the User Guide section +<a href="https://stnolting.github.io/neorv32/ug/#_application_specific_processor_configuration">Application-Specific Processor Configuration</a>. +</td> +</tr> +</table> +</div> +<h4 id="_processor_modules" class="discrete">Processor - Modules</h4> +<table class="tableblock frame-all grid-topbot stretch"> +<colgroup> +<col style="width: 20%;"> +<col style="width: 80%;"> +</colgroup> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">HW version:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>1.8.6.7</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Top entity:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>rtl/core/neorv32_top.vhd</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">FPGA:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Intel Cyclone IV E <code>EP4CE22F17C6</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Toolchain:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Quartus Prime Lite 21.1</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Constraints:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><strong>no timing constraints</strong>, "balanced optimization"</p></td> +</tr> +</tbody> +</table> +<table class="tableblock frame-all grid-rows stretch"> +<caption class="title">Table 1. Hardware utilization by processor module</caption> +<colgroup> +<col style="width: 13.3333%;"> +<col style="width: 53.3333%;"> +<col style="width: 6.6666%;"> +<col style="width: 6.6666%;"> +<col style="width: 13.3333%;"> +<col style="width: 6.6669%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-left valign-top">Module</th> +<th class="tableblock halign-left valign-top">Description</th> +<th class="tableblock halign-right valign-top">LEs</th> +<th class="tableblock halign-right valign-top">FFs</th> +<th class="tableblock halign-right valign-top">MEM bits</th> +<th class="tableblock halign-right valign-top">DSPs</th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">BOOT ROM</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Bootloader ROM (4kB)</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">2</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">2</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">32768</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">0</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Bus switch (core)</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><em>SoC bus infrastructure</em></p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">28</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">15</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">0</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">0</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Bus switch (DMA)</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><em>SoC bus infrastructure</em></p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">159</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">9</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">0</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">0</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">CFS</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Custom functions subsystem (depends on custom design logic)</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">-</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">-</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">-</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">-</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">CRC</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Cyclic redundancy check unit</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">130</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">117</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">0</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">0</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">dCACHE</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Data cache (4 blocks, 64 bytes per block)</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">300</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">167</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">2112</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">0</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">DM</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">On-chip debugger - debug module</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">377</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">241</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">0</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">0</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">DTM</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">On-chip debugger - debug transfer module (JTAG)</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">262</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">220</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">0</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">0</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">DMA</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Direct memory access controller</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">365</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">291</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">0</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">0</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">DMEM</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Processor-internal data memory (8kB)</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">6</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">2</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">65536</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">0</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Gateway</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><em>SoC bus infrastructure</em></p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">215</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">91</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">0</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">0</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">GPIO</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">General purpose input/output ports</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">102</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">98</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">0</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">0</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">GPTMR</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">General Purpose Timer</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">150</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">105</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">0</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">0</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">IO Switch</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><em>SoC bus infrastructure</em></p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">217</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">0</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">0</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">0</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">iCACHE</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Instruction cache (2x4 blocks, 64 bytes per block)</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">458</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">296</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">4096</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">0</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">IMEM</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Processor-internal instruction memory (16kB)</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">7</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">2</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">131072</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">0</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">MTIME</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Machine system timer</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">307</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">166</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">0</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">0</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">NEOLED</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Smart LED Interface (NeoPixel/WS28128) (FIFO_depth=1)</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">171</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">129</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">0</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">0</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">ONEWIRE</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">1-wire interface</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">105</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">77</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">0</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">0</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">PWM</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Pulse_width modulation controller (4 channels)</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">91</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">81</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">0</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">0</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Reservation Set</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Reservation set controller for LR/SC instructions</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">52</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">33</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">0</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">0</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">SDI</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Serial data interface</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">103</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">77</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">512</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">0</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">SLINK</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Stream link interface (RX/TX FIFO depth=32)</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">96</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">73</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">2048</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">0</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">SPI</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Serial peripheral interface</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">137</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">97</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">1024</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">0</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">SYSINFO</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">System configuration information memory</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">11</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">11</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">0</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">0</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">TRNG</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">True random number generator</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">140</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">108</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">512</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">0</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">TWI</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Two-wire interface</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">93</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">64</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">0</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">0</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">UART0, UART1</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Universal asynchronous receiver/transmitter 0/1 (FIFO_depth=1)</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">222</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">142</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">1024</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">0</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">WDT</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Watchdog timer</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">107</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">89</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">0</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">0</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">WISHBONE</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">External memory interface</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">122</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">112</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">0</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">0</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">XIP</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Execute in place module</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">369</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">276</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">0</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">0</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">XIRQ</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">External interrupt controller (4 channels)</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">35</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">29</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">0</p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">0</p></td> +</tr> +</tbody> +</table> +<div style="page-break-after: always;"></div> +</div> +<div class="sect2"> +<h3 id="_cpu_performance">1.7. CPU Performance</h3> +<div class="paragraph"> +<p>The performance of the NEORV32 was tested and evaluated using the <a href="https://www.eembc.org/coremark/">Core Mark CPU benchmark</a>. +The according sources can be found in the <code>sw/example/coremark</code> folder. +The resulting CoreMark score is defined as CoreMark iterations per second per MHz.</p> +</div> +<table class="tableblock frame-all grid-topbot stretch"> +<caption class="title">Table 2. Configuration</caption> +<colgroup> +<col style="width: 20%;"> +<col style="width: 80%;"> +</colgroup> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">HW version:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>1.5.7.10</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Hardware:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">32kB int. IMEM, 16kB int. DMEM, no caches, 100MHz clock</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">CoreMark:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">2000 iterations, MEM_METHOD is MEM_STACK</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Compiler:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">RISCV32-GCC 10.2.0 (compiled with <code>march=rv32i mabi=ilp32</code>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Compiler flags:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">default but with <code>-O3</code>, see makefile</p></td> +</tr> +</tbody> +</table> +<table class="tableblock frame-all grid-rows stretch"> +<caption class="title">Table 3. CoreMark results</caption> +<colgroup> +<col style="width: 62.5%;"> +<col style="width: 12.5%;"> +<col style="width: 12.5%;"> +<col style="width: 12.5%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-left valign-top">CPU</th> +<th class="tableblock halign-center valign-top">CoreMark Score</th> +<th class="tableblock halign-center valign-top">CoreMarks/MHz</th> +<th class="tableblock halign-center valign-top">Average CPI</th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><em>small</em> (<code>rv32i_Zicsr_Zifencei</code>)</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">33.89</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><strong>0.3389</strong></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><strong>4.04</strong></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><em>medium</em> (<code>rv32imc_Zicsr_Zifencei</code>)</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">62.50</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><strong>0.6250</strong></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><strong>5.34</strong></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><em>performance</em> (<code>rv32imc_Zicsr_Zifencei</code> + perf. options)</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">95.23</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><strong>0.9523</strong></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><strong>3.54</strong></p></td> +</tr> +</tbody> +</table> +<div class="paragraph"> +<p>The NEORV32 CPU is based on a multi-cycle architecture. Each instruction is executed in a sequence of +several consecutive micro operations. The average CPI (cycles per instruction) depends on the instruction +mix of a specific applications and also on the available CPU extensions. More information regarding the execution +time of each implemented instruction can be found in section <a href="#_instruction_sets_and_extensions">Instruction Sets and Extensions</a>.</p> +</div> +</div> +</div> +</div> +<div class="sect1"> +<h2 id="_neorv32_processor_soc">2. NEORV32 Processor (SoC)</h2> +<div class="sectionbody"> +<div class="paragraph"> +<p>The NEORV32 Processor is based on the NEORV32 CPU. Together with common peripheral +interfaces and embedded memories it provides a RISC-V-based full-scale microcontroller-like SoC platform.</p> +</div> +<div class="imageblock text-center"> +<div class="content"> +<img src="img/neorv32_processor.png" alt="neorv32 processor"> +</div> +<div class="title">Figure 1. The NEORV32 Processor (Block Diagram)</div> +</div> +<div class="paragraph"> +<p><strong>Section Structure</strong></p> +</div> +<div class="ulist"> +<ul> +<li> +<p><a href="#_processor_top_entity_signals">Processor Top Entity - Signals</a> and <a href="#_processor_top_entity_generics">Processor Top Entity - Generics</a></p> +</li> +<li> +<p><a href="#_processor_clocking">Processor Clocking</a> and <a href="#_processor_reset">Processor Reset</a></p> +</li> +<li> +<p><a href="#_processor_interrupts">Processor Interrupts</a></p> +</li> +<li> +<p><a href="#_address_space">Address Space</a> and <a href="#_boot_configuration">Boot Configuration</a></p> +</li> +<li> +<p><a href="#_processor_internal_modules">Processor-Internal Modules</a></p> +</li> +</ul> +</div> +<div class="paragraph"> +<p><strong>Key Features</strong></p> +</div> +<div class="ulist"> +<ul> +<li> +<p><em>optional</em> processor-internal data and instruction memories (<a href="#_data_memory_dmem"><strong>DMEM</strong></a>/<a href="#_instruction_memory_imem"><strong>IMEM</strong></a>)</p> +</li> +<li> +<p><em>optional</em> caches (<a href="#_processor_internal_instruction_cache_icache"><strong>iCACHE</strong></a>, <a href="#_processor_internal_data_cache_dcache"><strong>dCACHE</strong>&gt;, &lt;&lt;_execute_in_place_module_xip,<strong>xipCACHE</strong>&gt;, &lt;&lt;_processor_external_bus_interface_xbus,<strong>xCACHE</strong></a>)</p> +</li> +<li> +<p><em>optional</em> internal bootloader (<a href="#_bootloader_rom_bootrom"><strong>BOOTROM</strong></a>) with UART console &amp; SPI flash boot option</p> +</li> +<li> +<p><em>optional</em> machine system timer (<a href="#_machine_system_timer_mtime"><strong>MTIME</strong></a>), RISC-V-compatible</p> +</li> +<li> +<p><em>optional</em> two independent universal asynchronous receivers and transmitters (<a href="#_primary_universal_asynchronous_receiver_and_transmitter_uart0"><strong>UART0</strong></a>, +<a href="#_secondary_universal_asynchronous_receiver_and_transmitter_uart1"><strong>UART1</strong></a>) with optional hardware flow control (RTS/CTS)</p> +</li> +<li> +<p><em>optional</em> serial peripheral interface host controller (<a href="#_serial_peripheral_interface_controller_spi"><strong>SPI</strong></a>) with 8 dedicated CS lines</p> +</li> +<li> +<p><em>optional</em> 8-bit serial data device interface (<a href="#_serial_data_interface_controller_spi"><strong>SDI</strong></a>)</p> +</li> +<li> +<p><em>optional</em> two wire serial interface controller (<a href="#_two_wire_serial_interface_controller_twi"><strong>TWI</strong></a>), compatible to the I²C standard</p> +</li> +<li> +<p><em>optional</em> general purpose parallel IO port (<a href="#_general_purpose_input_and_output_port_gpio"><strong>GPIO</strong></a>), 64xOut, 64xIn</p> +</li> +<li> +<p><em>optional</em> 32-bit external bus interface, Wishbone b4 / AXI4-Lite compatible (<a href="#_processor_external_bus_interface_xbus"><strong>XBUS</strong></a>)</p> +</li> +<li> +<p><em>optional</em> watchdog timer (<a href="#_watchdog_timer_wdt"><strong>WDT</strong></a>)</p> +</li> +<li> +<p><em>optional</em> PWM controller with up to 12 channels &amp; 8-bit duty cycle resolution (<a href="#_pulse_width_modulation_controller_pwm"><strong>PWM</strong></a>)</p> +</li> +<li> +<p><em>optional</em> ring-oscillator-based true random number generator (<a href="#_true_random_number_generator_trng"><strong>TRNG</strong></a>)</p> +</li> +<li> +<p><em>optional</em> custom functions subsystem for custom co-processor extensions (<a href="#_custom_functions_subsystem_cfs"><strong>CFS</strong></a>)</p> +</li> +<li> +<p><em>optional</em> NeoPixel&#8482;/WS2812-compatible smart LED interface (<a href="#_smart_led_interface_neoled"><strong>NEOLED</strong></a>)</p> +</li> +<li> +<p><em>optional</em> external interrupt controller with up to 32 channels (<a href="#_external_interrupt_controller_xirq"><strong>XIRQ</strong></a>)</p> +</li> +<li> +<p><em>optional</em> general purpose 32-bit timer (<a href="#_general_purpose_timer_gptmr"><strong>GPTMR</strong></a>)</p> +</li> +<li> +<p><em>optional</em> execute in-place module (<a href="#_execute_in_place_module_xip"><strong>XIP</strong></a>)</p> +</li> +<li> +<p><em>optional</em> 1-wire serial interface controller (<a href="#_one_wire_serial_interface_controller_onewire"><strong>ONEWIRE</strong></a>), compatible to the 1-wire standard</p> +</li> +<li> +<p><em>optional</em> autonomous direct memory access controller (<a href="#_direct_memory_access_controller_dma"><strong>DMA</strong></a>)</p> +</li> +<li> +<p><em>optional</em> stream link interface (<a href="#_stream_link_interface_slink"><strong>SLINK</strong></a>), AXI4-Stream compatible</p> +</li> +<li> +<p><em>optional</em> cyclic redundancy check unit (<a href="#_cyclic_redundancy_check_crc"><strong>CRC</strong></a>)</p> +</li> +<li> +<p><em>optional</em> on-chip debugger with JTAG TAP (<a href="#_on_chip_debugger_ocd"><strong>OCD</strong></a>)</p> +</li> +<li> +<p>system configuration information memory to check HW configuration via software (<a href="#_system_configuration_information_memory_sysinfo"><strong>SYSINFO</strong></a>)</p> +</li> +</ul> +</div> +<div style="page-break-after: always;"></div> +<div class="sect2"> +<h3 id="_processor_top_entity_signals">2.1. Processor Top Entity - Signals</h3> +<div class="paragraph"> +<p>The following table shows all interface signals of the processor top entity (<code>rtl/core/neorv32_top.vhd</code>). +All signals are of type <code>std_ulogic</code> or <code>std_ulogic_vector</code>, respectively.</p> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">Default Values of Inputs</div> +All <em>optional</em> input signals provide default values in case they are not explicitly assigned during instantiation. +The weak driver strengths of VHDL (<code>'L'</code> and <code>'H'</code>) are used to model a pull-down or pull-up resistor. +</td> +</tr> +</table> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">Variable-Sized Ports</div> +Some peripherals allow to configure the number of channels to-be-implemented by a generic (for example the number +of PWM channels). The according input/output signals have a fixed sized regardless of the actually configured +amount of channels. If less than the maximum number of channels is configured, only the LSB-aligned channels are used: +in case of an <em>input port</em> the remaining bits/channels are left unconnected; in case of an <em>output port</em> the remaining +bits/channels are hardwired to zero. +</td> +</tr> +</table> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">Tri-State Interfaces</div> +Some interfaces (like the TWI and the 1-Wire bus) require tri-state drivers in the designs top module. +</td> +</tr> +</table> +</div> +<table class="tableblock frame-all grid-rows stretch"> +<caption class="title">Table 4. NEORV32 Processor Signal List</caption> +<colgroup> +<col style="width: 21.4285%;"> +<col style="width: 7.1428%;"> +<col style="width: 7.1428%;"> +<col style="width: 7.1428%;"> +<col style="width: 57.1431%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-left valign-top">Name</th> +<th class="tableblock halign-center valign-top">Width</th> +<th class="tableblock halign-center valign-top">Direction</th> +<th class="tableblock halign-center valign-top">Default</th> +<th class="tableblock halign-left valign-top">Description</th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-center valign-top" colspan="5"><p class="tableblock"><strong>Global Control (<a href="#_processor_clocking">Processor Clocking</a> and <a href="#_processor_reset">Processor Reset</a>)</strong></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>clk_i</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">1</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">in</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">none</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">global clock line, all registers triggering on rising edge</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>rstn_i</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">1</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">in</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">none</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">global reset, asynchronous, <strong>low-active</strong></p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top" colspan="5"><p class="tableblock"><strong>JTAG Access Port for <a href="#_on_chip_debugger_ocd">On-Chip Debugger (OCD)</a></strong></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>jtag_tck_i</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">1</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">in</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>'L'</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">serial clock</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>jtag_tdi_i</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">1</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">in</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>'L'</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">serial data input</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>jtag_tdo_o</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">1</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">out</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">serial data output</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>jtag_tms_i</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">1</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">in</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>'L'</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">mode select</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top" colspan="5"><p class="tableblock"><strong><a href="#_processor_external_bus_interface_xbus">Processor-External Bus Interface (XBUS)</a></strong></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>xbus_adr_o</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">32</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">out</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">destination address</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>xbus_dat_o</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">32</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">out</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">read data</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>xbus_tag_o</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">3</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">out</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">access tag</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>xbus_we_o</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">1</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">out</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">write enable ('0' = read transfer)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>xbus_sel_o</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">4</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">out</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">byte enable</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>xbus_stb_o</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">1</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">out</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">strobe</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>xbus_cyc_o</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">1</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">out</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">valid cycle</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>xbus_dat_i</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">32</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">in</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>'L'</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">write data</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>xbus_ack_i</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">1</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">in</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>'L'</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">transfer acknowledge</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>xbus_err_i</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">1</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">in</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>'L'</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">transfer error</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top" colspan="5"><p class="tableblock"><strong><a href="#_stream_link_interface_slink">Stream Link Interface (SLINK)</a></strong></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>slink_rx_dat_i</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">32</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">in</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>'L'</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">RX data</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>slink_rx_src_i</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">4</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">in</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>'L'</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">RX source routing information</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>slink_rx_val_i</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">1</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">in</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>'L'</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">RX data valid</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>slink_rx_lst_i</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">1</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">in</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>'L'</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">RX last element of stream</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>slink_rx_rdy_o</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">1</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">out</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">RX ready to receive</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>slink_tx_dat_o</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">32</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">out</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">TX data</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>slink_tx_dst_o</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">4</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">out</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">TX destination routing information</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>slink_tx_val_o</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">1</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">out</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">TX data valid</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>slink_tx_lst_o</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">1</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">out</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">TX last element of stream</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>slink_tx_rdy_i</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">1</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">in</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>'L'</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">TX allowed to send</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top" colspan="5"><p class="tableblock"><strong><a href="#_execute_in_place_module_xip">Execute In Place Module (XIP)</a></strong></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>xip_csn_o</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">1</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">out</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">chip select, low-active</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>xip_clk_o</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">1</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">out</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">serial clock</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>xip_dat_i</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">1</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">in</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>'L'</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">serial data input</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>xip_dat_o</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">1</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">out</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">serial data output</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top" colspan="5"><p class="tableblock"><strong><a href="#_general_purpose_input_and_output_port_gpio">General Purpose Input and Output Port (GPIO)</a></strong></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>gpio_o</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">64</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">out</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">general purpose parallel output</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>gpio_i</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">64</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">in</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>'L'</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">general purpose parallel input</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top" colspan="5"><p class="tableblock"><strong><a href="#_primary_universal_asynchronous_receiver_and_transmitter_uart0">Primary Universal Asynchronous Receiver and Transmitter (UART0)</a></strong></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>uart0_txd_o</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">1</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">out</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">serial transmitter</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>uart0_rxd_i</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">1</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">in</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>'L'</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">serial receiver</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>uart0_rts_o</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">1</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">out</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">RX ready to receive new char</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>uart0_cts_i</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">1</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">in</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>'L'</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">TX allowed to start sending, low-active</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top" colspan="5"><p class="tableblock"><strong><a href="#_secondary_universal_asynchronous_receiver_and_transmitter_uart1">Secondary Universal Asynchronous Receiver and Transmitter (UART1)</a></strong></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>uart1_txd_o</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">1</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">out</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">serial transmitter</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>uart1_rxd_i</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">1</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">in</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>'L'</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">serial receiver</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>uart1_rts_o</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">1</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">out</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">RX ready to receive new char</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>uart1_cts_i</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">1</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">in</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>'L'</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">TX allowed to start sending, low-active</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top" colspan="5"><p class="tableblock"><strong><a href="#_serial_peripheral_interface_controller_spi">Serial Peripheral Interface Controller (SPI)</a></strong></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>spi_clk_o</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">1</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">out</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">controller clock line</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>spi_dat_o</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">1</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">out</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">serial data output</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>spi_dat_i</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">1</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">in</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>'L'</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">serial data input</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>spi_csn_o</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">8</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">out</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">select (low-active)</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top" colspan="5"><p class="tableblock"><strong><a href="#_serial_data_interface_controller_sdi">Serial Data Interface Controller (SDI)</a></strong></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>sdi_clk_i</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">1</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">in</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>'L'</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">controller clock line</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>sdi_dat_o</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">1</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">out</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">serial data output</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>sdi_dat_i</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">1</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">in</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>'L'</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">serial data input</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>sdi_csn_i</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">1</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">in</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>'H'</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">chip select, low-active</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top" colspan="5"><p class="tableblock"><strong><a href="#_two_wire_serial_interface_controller_twi">Two-Wire Serial Interface Controller (TWI)</a></strong></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>twi_sda_i</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">1</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">in</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>'H'</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">serial data line sense input</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>twi_sda_o</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">1</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">out</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">serial data line output (pull low only)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>twi_scl_i</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">1</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">in</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>'H'</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">serial clock line sense input</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>twi_scl_o</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">1</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">out</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">serial clock line output (pull low only)</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top" colspan="5"><p class="tableblock"><strong><a href="#_one_wire_serial_interface_controller_onewire">One-Wire Serial Interface Controller (ONEWIRE)</a></strong></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>onewire_i</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">1</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">in</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>'H'</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">1-wire bus sense input</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>onewire_o</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">1</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">out</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">1-wire bus output (pull low only)</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top" colspan="5"><p class="tableblock"><strong><a href="#_pulse_width_modulation_controller_pwm">Pulse-Width Modulation Controller (PWM)</a></strong></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>pwm_o</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">12</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">out</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">pulse-width modulated channels</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top" colspan="5"><p class="tableblock"><strong><a href="#_custom_functions_subsystem_cfs">Custom Functions Subsystem (CFS)</a></strong></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>cfs_in_i</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">32</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">in</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>'L'</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">custom CFS input signal conduit</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>cfs_out_o</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">32</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">out</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">custom CFS output signal conduit</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top" colspan="5"><p class="tableblock"><strong><a href="#_smart_led_interface_neoled">Smart LED Interface (NEOLED)</a></strong></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>neoled_o</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">1</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">out</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">asynchronous serial data output</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top" colspan="5"><p class="tableblock"><strong><a href="#_machine_system_timer_mtime">Machine System Timer (MTIME)</a></strong></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>mtime_time_o</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">64</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">out</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">MTIME system time output</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top" colspan="5"><p class="tableblock"><strong><a href="#_external_interrupt_controller_xirq">External Interrupt Controller (XIRQ)</a></strong></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>xirq_i</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">32</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">in</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>'L'</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">external interrupt requests</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top" colspan="5"><p class="tableblock"><strong>RISC-V Machine-Mode <a href="#_processor_interrupts">Processor Interrupts</a></strong></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>mtime_irq_i</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">1</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">in</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>'L'</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">machine timer interrupt (RISC-V), high-level-active</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>msw_irq_i</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">1</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">in</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>'L'</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">machine software interrupt (RISC-V), high-level-active</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>mext_irq_i</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">1</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">in</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>'L'</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">machine external interrupt (RISC-V), high-level-active</p></td> +</tr> +</tbody> +</table> +<div style="page-break-after: always;"></div> +</div> +<div class="sect2"> +<h3 id="_processor_top_entity_generics">2.2. Processor Top Entity - Generics</h3> +<div class="paragraph"> +<p>This section lists all configuration generics of the NEORV32 processor top entity (<code>rtl/neorv32_top.vhd</code>). +These generics allow to configure the system according to your needs. The generics are +used to control implementation of certain CPU extensions and peripheral modules and even allow to +optimize the system for certain design goals like minimal area or maximum performance.</p> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">Default Values</div> +All <em>optional</em> configuration generics provide default values in case they are not explicitly assigned during instantiation. +</td> +</tr> +</table> +</div> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +<div class="title">Software Discovery of Configuration</div> +Software can determine the actual CPU configuration via the <a href="#_misa"><strong><code>misa</code></strong></a> and <a href="#_mxisa"><strong><code>mxisa</code></strong></a> CSRs. The Soc/Processor +and can be determined via the <a href="#_system_configuration_information_memory_sysinfo">SYSINFO</a> memory-mapped registers. +</td> +</tr> +</table> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">Excluded Modules and Extensions</div> +If optional modules (like CPU extensions or peripheral devices) are not enabled the according hardware +will not be synthesized at all. Hence, the disabled modules do not increase area and power requirements +and do not impact timing. +</td> +</tr> +</table> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">Table Abbreviations</div> +The generic type &#8220;suv(x:y)&#8221; is an abbreviation for &#8220;std_ulogic_vector(x downto y)&#8221;. +</td> +</tr> +</table> +</div> +<table class="tableblock frame-all grid-rows stretch"> +<caption class="title">Table 5. NEORV32 Processor Generic List</caption> +<colgroup> +<col style="width: 20%;"> +<col style="width: 13.3333%;"> +<col style="width: 13.3333%;"> +<col style="width: 53.3334%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-left valign-top">Name</th> +<th class="tableblock halign-center valign-top">Type</th> +<th class="tableblock halign-center valign-top">Default</th> +<th class="tableblock halign-left valign-top">Description</th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-center valign-top" colspan="4"><p class="tableblock"><strong>General</strong></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>CLOCK_FREQUENCY</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">natural</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">The clock frequency of the processor&#8217;s <code>clk_i</code> input port in Hertz (Hz).</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>CLOCK_GATING_EN</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">boolean</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">false</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Enable clock gating when CPU is in sleep mode (see sections <a href="#_sleep_mode">Sleep Mode</a> and <a href="#_processor_clocking">Processor Clocking</a>).</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>INT_BOOTLOADER_EN</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">boolean</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">false</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Implement the processor-internal <a href="#_bootloader_rom_bootrom">Bootloader ROM (BOOTROM)</a>, pre-initialized with the default <a href="#_bootloader">Bootloader</a> image.</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>HART_ID</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">suv(31:0)</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">0x00000000</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">The hart thread ID of the CPU (passed to <a href="#_mhartid"><strong><code>mhartid</code></strong></a> CSR).</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>JEDEC_ID</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">suv(10:0)</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">00000000000</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">JEDEC ID; continuation codes plus vendor ID (passed to <a href="#_mvendorid"><strong><code>mvendorid</code></strong></a> CSR and to the <a href="#_debug_transport_module_dtm">Debug Transport Module (DTM)</a>).</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top" colspan="4"><p class="tableblock"><strong><a href="#_on_chip_debugger_ocd">On-Chip Debugger (OCD)</a></strong></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>ON_CHIP_DEBUGGER_EN</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">boolean</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">false</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Implement the on-chip debugger and the CPU debug mode.</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>DM_LEGACY_MODE</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">boolean</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">false</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Debug module spec. version: <code>false</code> = v1.0, <code>true</code> = v0.13 (legacy mode).</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top" colspan="4"><p class="tableblock"><strong>CPU <a href="#_instruction_sets_and_extensions">Instruction Sets and Extensions</a></strong></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>CPU_EXTENSION_RISCV_A</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">boolean</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">false</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Enable <a href="#_a_isa_extension"><code>A</code> ISA Extension</a> (atomic memory accesses).</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>CPU_EXTENSION_RISCV_B</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">boolean</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">false</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Enable <a href="#_b_isa_extension"><code>B</code> ISA Extension</a> (bit-manipulation).</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>CPU_EXTENSION_RISCV_C</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">boolean</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">false</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Enable <a href="#_c_isa_extension"><code>C</code> ISA Extension</a> (compressed instructions).</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>CPU_EXTENSION_RISCV_E</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">boolean</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">false</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Enable <a href="#_e_isa_extension"><code>E</code> ISA Extension</a> (reduced register file size).</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>CPU_EXTENSION_RISCV_M</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">boolean</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">false</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Enable <a href="#_m_isa_extension"><code>M</code> ISA Extension</a> (hardware-based integer multiplication and division).</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>CPU_EXTENSION_RISCV_U</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">boolean</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">false</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Enable <a href="#_u_isa_extension"><code>U</code> ISA Extension</a> (less-privileged user mode).</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>CPU_EXTENSION_RISCV_Zfinx</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">boolean</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">false</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Enable <a href="#_zfinx_isa_extension"><code>Zfinx</code> ISA Extension</a> (single-precision floating-point unit).</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>CPU_EXTENSION_RISCV_Zicntr</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">boolean</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">true</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Enable <a href="#_zicntr_isa_extension"><code>Zicntr</code> ISA Extension</a> (CPU base counters).</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>CPU_EXTENSION_RISCV_Zicond</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">boolean</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">false</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Enable <a href="#_zicond_isa_extension"><code>Zicond</code> ISA Extension</a> (integer conditional operations).</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>CPU_EXTENSION_RISCV_Zihpm</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">boolean</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">false</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Enable <a href="#_zihpm_isa_extension"><code>Zihpm</code> ISA Extension</a> (hardware performance monitors).</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>CPU_EXTENSION_RISCV_Zmmul</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">boolean</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">false</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Enable <a href="#_zmmul_isa_extension"><code>Zmmul</code> - ISA Extension</a> (hardware-based integer multiplication).</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>CPU_EXTENSION_RISCV_Zxcfu</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">boolean</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">false</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Enable NEORV32-specific <a href="#_zxcfu_isa_extension"><code>Zxcfu</code> ISA Extension</a> (custom RISC-V instructions).</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top" colspan="4"><p class="tableblock"><strong>CPU <a href="#_architecture">Architecture</a> Tuning Options</strong></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>FAST_MUL_EN</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">boolean</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">false</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Implement fast but large full-parallel multipliers (trying to infer DSP blocks); see section <a href="#_cpu_arithmetic_logic_unit">CPU Arithmetic Logic Unit</a>.</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>FAST_SHIFT_EN</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">boolean</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">false</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Implement fast but large full-parallel barrel shifters; see section <a href="#_cpu_arithmetic_logic_unit">CPU Arithmetic Logic Unit</a>.</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>REGFILE_HW_RST</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">boolean</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">false</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Implement full hardware reset for register file (prevent inferring of BRAM); see section <a href="#_cpu_register_file">CPU Register File</a>.</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top" colspan="4"><p class="tableblock"><strong>Physical Memory Protection (<a href="#_smpmp_isa_extension"><code>Smpmp</code> ISA Extension</a>)</strong></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>PMP_NUM_REGIONS</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">natural</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">0</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Number of implemented PMP regions (0..16).</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>PMP_MIN_GRANULARITY</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">natural</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">4</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Minimal region granularity in bytes. Has to be a power of two, min 4.</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>PMP_TOR_MODE_EN</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">boolean</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">true</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Implement support for top-of-region (TOR) mode.</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>PMP_NAP_MODE_EN</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">boolean</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">true</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Implement support for naturally-aligned power-of-two (NAPOT &amp; NA4) modes.</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top" colspan="4"><p class="tableblock"><strong>Hardware Performance Monitors (<a href="#_zihpm_isa_extension"><code>Zihpm</code> ISA Extension</a>)</strong></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>HPM_NUM_CNTS</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">natural</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">0</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Number of implemented hardware performance monitor counters (0..13).</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>HPM_CNT_WIDTH</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">natural</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">40</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Total LSB-aligned size of each HPM counter. Min 0, max 64.</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top" colspan="4"><p class="tableblock"><strong>Internal <a href="#_instruction_memory_imem">Instruction Memory (IMEM)</a></strong></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>MEM_INT_IMEM_EN</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">boolean</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">false</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Implement the processor-internal instruction memory.</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>MEM_INT_IMEM_SIZE</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">natural</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">16*1024</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Size in bytes of the processor internal instruction memory (use a power of 2).</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top" colspan="4"><p class="tableblock"><strong>Internal <a href="#_data_memory_dmem">Data Memory (DMEM)</a></strong></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>MEM_INT_DMEM_EN</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">boolean</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">false</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Implement the processor-internal data memory.</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>MEM_INT_DMEM_SIZE</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">natural</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">8*1024</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Size in bytes of the processor-internal data memory (use a power of 2).</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top" colspan="4"><p class="tableblock"><strong><a href="#_processor_internal_instruction_cache_icache">Processor-Internal Instruction Cache (iCACHE)</a></strong></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>ICACHE_EN</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">boolean</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">false</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Implement the instruction cache.</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>ICACHE_NUM_BLOCKS</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">natural</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">4</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Number of blocks ("lines") Has to be a power of two.</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>ICACHE_BLOCK_SIZE</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">natural</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">64</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Size in bytes of each block. Has to be a power of two.</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top" colspan="4"><p class="tableblock"><strong><a href="#_processor_internal_data_cache_dcache">Processor-Internal Data Cache (dCACHE)</a></strong></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>DCACHE_EN</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">boolean</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">false</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Implement the data cache.</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>DCACHE_NUM_BLOCKS</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">natural</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">4</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Number of blocks ("lines"). Has to be a power of two.</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>DCACHE_BLOCK_SIZE</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">natural</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">64</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Size in bytes of each block. Has to be a power of two.</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top" colspan="4"><p class="tableblock"><strong><a href="#_processor_external_bus_interface_xbus">Processor-External Bus Interface (XBUS)</a> (Wishbone b4 protocol)</strong></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>XBUS_EN</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">boolean</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">false</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Implement the external bus interface.</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>XBUS_TIMEOUT</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">natural</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">255</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Clock cycles after which a pending external bus access will auto-terminate and raise a bus fault exception.</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>XBUS_REGSTAGE_EN</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">boolean</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">false</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Implement XBUS register stages to ease timing closure.</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>XBUS_CACHE_EN</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">boolean</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">false</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Implement the external bus cache.</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>XBUS_CACHE_NUM_BLOCKS</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">natural</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">64</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Number of blocks ("lines"). Has to be a power of two.</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>XBUS_CACHE_BLOCK_SIZE</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">natural</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">32</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Size in bytes of each block. Has to be a power of two.</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top" colspan="4"><p class="tableblock"><strong><a href="#_execute_in_place_module_xip">Execute In Place Module (XIP)</a></strong></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>XIP_EN</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">boolean</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">false</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Implement the execute in-place module.</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>XIP_CACHE_EN</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">boolean</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">false</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Implement XIP cache.</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>XIP_CACHE_NUM_BLOCKS</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">natural</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">8</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Number of blocks in XIP cache. Has to be a power of two.</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>XIP_CACHE_BLOCK_SIZE</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">natural</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">256</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Number of bytes per XIP cache block. Has to be a power of two, min 4.</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top" colspan="4"><p class="tableblock"><strong><a href="#_external_interrupt_controller_xirq">External Interrupt Controller (XIRQ)</a></strong></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>XIRQ_NUM_CH</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">natural</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">0</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Number of channels of the external interrupt controller. Valid values are 0..32.</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top" colspan="4"><p class="tableblock"><strong>Peripheral/IO Modules</strong></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>IO_DISABLE_SYSINFO</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">boolean</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">false</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Disable <a href="#_system_configuration_information_memory_sysinfo">System Configuration Information Memory (SYSINFO)</a> module; ⚠️ not recommended - for advanced users only!</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>IO_GPIO_NUM</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">natural</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">0</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Number of general purpose input/output pairs of the <a href="#_general_purpose_input_and_output_port_gpio">General Purpose Input and Output Port (GPIO)</a>.</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>IO_MTIME_EN</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">boolean</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">false</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Implement the <a href="#_machine_system_timer_mtime">Machine System Timer (MTIME)</a>.</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>IO_UART0_EN</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">boolean</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">false</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Implement the <a href="#_primary_universal_asynchronous_receiver_and_transmitter_uart0">Primary Universal Asynchronous Receiver and Transmitter (UART0)</a>.</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>IO_UART0_RX_FIFO</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">natural</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">1</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">UART0 RX FIFO depth, has to be a power of two, minimum value is 1, max 32768.</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>IO_UART0_TX_FIFO</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">natural</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">1</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">UART0 TX FIFO depth, has to be a power of two, minimum value is 1, max 32768.</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>IO_UART1_EN</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">boolean</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">false</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Implement the <a href="#_secondary_universal_asynchronous_receiver_and_transmitter_uart1">Secondary Universal Asynchronous Receiver and Transmitter (UART1)</a>.</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>IO_UART1_RX_FIFO</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">natural</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">1</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">UART1 RX FIFO depth, has to be a power of two, minimum value is 1, max 32768.</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>IO_UART1_TX_FIFO</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">natural</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">1</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">UART1 TX FIFO depth, has to be a power of two, minimum value is 1, max 32768.</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>IO_SPI_EN</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">boolean</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">false</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Implement the <a href="#_serial_peripheral_interface_controller_spi">Serial Peripheral Interface Controller (SPI)</a>.</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>IO_SPI_FIFO</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">natural</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">1</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Depth of the <a href="#_serial_peripheral_interface_controller_spi">Serial Peripheral Interface Controller (SPI)</a> FIFO. Has to be a power of two, min 1, max 32768.</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>IO_SDI_EN</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">boolean</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">false</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Implement the <a href="#_serial_data_interface_controller_sdi">Serial Data Interface Controller (SDI)</a>.</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>IO_SDI_FIFO</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">natural</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">1</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Depth of the <a href="#_serial_data_interface_controller_sdi">Serial Data Interface Controller (SDI)</a> FIFO. Has to be a power of two, min 1, max 32768.</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>IO_TWI_EN</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">boolean</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">false</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Implement the <a href="#_two_wire_serial_interface_controller_twi">Two-Wire Serial Interface Controller (TWI)</a>.</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>IO_TWI_FIFO</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">natural</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">1</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Depth of the <a href="#_two_wire_serial_interface_controller_twi">Two-Wire Serial Interface Controller (TWI)</a> FIFO. Has to be a power of two, min 1, max 32768.</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>IO_PWM_NUM_CH</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">natural</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">0</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Number of channels of the <a href="#_pulse_width_modulation_controller_pwm">Pulse-Width Modulation Controller (PWM)</a> to implement (0..12).</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>IO_WDT_EN</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">boolean</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">false</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Implement the <a href="#_watchdog_timer_wdt">Watchdog Timer (WDT)</a>.</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>IO_TRNG_EN</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">boolean</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">false</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Implement the <a href="#_true_random_number_generator_trng">True Random-Number Generator (TRNG)</a>.</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>IO_TRNG_FIFO</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">natural</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">1</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Depth of the TRNG data FIFO. Has to be a power of two, min 1, max 32768.</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>IO_CFS_EN</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">boolean</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">false</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Implement the <a href="#_custom_functions_subsystem_cfs">Custom Functions Subsystem (CFS)</a>.</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>IO_CFS_CONFIG</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">suv(31:0)</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">0x00000000</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">"Conduit" generic to pass user-defined flags to the <a href="#_custom_functions_subsystem_cfs">Custom Functions Subsystem (CFS)</a>.</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>IO_CFS_IN_SIZE</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">natural</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">32</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Size of the <a href="#_custom_functions_subsystem_cfs">Custom Functions Subsystem (CFS)</a> input signal conduit (<code>cfs_in_i</code>).</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>IO_CFS_OUT_SIZE</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">natural</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">32</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Size of the <a href="#_custom_functions_subsystem_cfs">Custom Functions Subsystem (CFS)</a> output signal conduit (<code>cfs_out_o</code>).</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>IO_NEOLED_EN</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">boolean</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">false</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Implement the <a href="#_smart_led_interface_neoled">Smart LED Interface (NEOLED)</a>.</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>IO_NEOLED_TX_FIFO</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">natural</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">1</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">TX FIFO depth of the the <a href="#_smart_led_interface_neoled">Smart LED Interface (NEOLED)</a>. Has to be a power of two, min 1, max 32768.</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>IO_GPTMR_EN</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">boolean</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">false</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Implement the <a href="#_general_purpose_timer_gptmr">General Purpose Timer (GPTMR)</a>.</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>IO_ONEWIRE_EN</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">boolean</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">false</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Implement the <a href="#_one_wire_serial_interface_controller_onewire">One-Wire Serial Interface Controller (ONEWIRE)</a>.</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>IO_DMA_EN</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">boolean</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">false</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Implement the <a href="#_direct_memory_access_controller_dma">Direct Memory Access Controller (DMA)</a>.</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>IO_SLINK_EN</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">boolean</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">false</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Implement the <a href="#_stream_link_interface_slink">Stream Link Interface (SLINK)</a>.</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>IO_SLINK_RX_FIFO</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">natural</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">1</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">SLINK RX FIFO depth, has to be a power of two, minimum value is 1, max 32768.</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>IO_SLINK_TX_FIFO</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">natural</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">1</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">SLINK TX FIFO depth, has to be a power of two, minimum value is 1, max 32768.</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>IO_CRC_EN</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">boolean</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">false</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Implement the <a href="#_cyclic_redundancy_check_crc">Cyclic Redundancy Check (CRC)</a> unit.</p></td> +</tr> +</tbody> +</table> +<div style="page-break-after: always;"></div> +</div> +<div class="sect2"> +<h3 id="_processor_clocking">2.3. Processor Clocking</h3> +<div class="paragraph"> +<p>The processor is implemented as fully-synchronous logic design using a single clock domain that is driven entirely by the +top&#8217;s <code>clk_i</code> signal. This clock signal is used by all internal registers and memories, which trigger on the rising edge of +this clock signal - except for the <a href="#_processor_reset">Processor Reset</a> and the clock switching gate that trigger on a falling edge. +External "clocks" like the OCD&#8217;s JTAG clock or the SDI&#8217;s serial clock are synchronized into the processor&#8217;s clock domain +before being further processed.</p> +</div> +<div class="sect3"> +<h4 id="_clock_gating">2.3.1. Clock Gating</h4> +<div class="paragraph"> +<p>The single clock domain of the processor can be split into an always-on clock domain and a switchable clock domain. +The switchable clock domain is used to clock the CPU core, the CPU&#8217;s bus switch and - if implemented - the caches. +This domain can be deactivated to reduce power consumption. The always-on clock domain is used to clock all other +processor modules like peripherals, memories and IO devices. Hence, these modules can continue operation (e.g. a +timer keeps running) even if the CPU is shut down.</p> +</div> +<div class="paragraph"> +<p>The splitting into two clock domain is enabled by the <code>CLOCK_GATING_EN</code> generic (<a href="#_processor_top_entity_generics">Processor Top Entity - Generics</a>). +When enabled, a generic clock switching gate is added to decouple the switchable clock from the always-on clock domain +(VHDL file <code>neorv32_clockgate.vhd</code>). Whenever the CPU enters <a href="#_sleep_mode">Sleep Mode</a> the CPU clock domain ist shut down.</p> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">Clock Switch Hardware</div> +By default, a generic clock gate is used (<code>rtl/core/neorv32_clockgate.vhd</code>) to shut down the CPU clock. +Especially for FPGA setups it is highly recommended to replace this default version by a technology-specific primitive +or macro wrapper to improve efficiency (clock skew, global clock tree usage, etc.). +</td> +</tr> +</table> +</div> +</div> +<div class="sect3"> +<h4 id="_peripheral_clocks">2.3.2. Peripheral Clocks</h4> +<div class="paragraph"> +<p>Many processor modules like the UARTs or the timers provide a programmable time base for operations. In order to simplify +the hardware, the processor implements a global "clock generator" that provides <em>clock enables</em> for certain frequencies that +are derived from the man clock. Hence, these clock enable signals are synchronous to the system&#8217;s main clock and will be high +for only a single cycle. The processor modules can use these enables for sub-main-clock operations while still providing a single +clock domain only.</p> +</div> +<div class="paragraph"> +<p>In total, 8 sub-main-clock signals are available. All processor modules, which feature a time-based configuration, provide a +programmable three-bit prescaler select in their control register to select one of the 8 available clocks. The +mapping of the prescaler select bits to the according clock source is shown in the table below. Here, <em>f</em> represents the +processor main clock from the top entity&#8217;s <code>clk_i</code> signal.</p> +</div> +<table class="tableblock frame-all grid-rows stretch"> +<colgroup> +<col style="width: 27.2727%;"> +<col style="width: 9.0909%;"> +<col style="width: 9.0909%;"> +<col style="width: 9.0909%;"> +<col style="width: 9.0909%;"> +<col style="width: 9.0909%;"> +<col style="width: 9.0909%;"> +<col style="width: 9.0909%;"> +<col style="width: 9.091%;"> +</colgroup> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Prescaler bits:</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>0b000</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>0b001</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>0b010</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>0b011</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>0b100</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>0b101</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>0b110</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>0b111</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Resulting clock:</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><em>f/2</em></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><em>f/4</em></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><em>f/8</em></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><em>f/64</em></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><em>f/128</em></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><em>f/1024</em></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><em>f/2048</em></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><em>f/4096</em></p></td> +</tr> +</tbody> +</table> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +<div class="title">Power Saving</div> +If no peripheral modules requires a clock signal from the internal clock generator (all according modules are disabled by +clearing the enable bit in the according module&#8217;s control register) the generator is automatically deactivated to reduce +dynamic power consumption. +</td> +</tr> +</table> +</div> +<div style="page-break-after: always;"></div> +</div> +</div> +<div class="sect2"> +<h3 id="_processor_reset">2.4. Processor Reset</h3> +<div class="admonitionblock important"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-important" title="Important"></i> +</td> +<td class="content"> +<div class="title">Processor Reset Signal</div> +Always make sure to connect the processor&#8217;s reset signal <code>rstn_i</code> to a valid reset source (a button, the "locked" +signal of a PLL, a dedicated reset controller, etc.). +</td> +</tr> +</table> +</div> +<div class="paragraph"> +<p>The processor-wide reset can be triggered by any of the following sources:</p> +</div> +<div class="ulist"> +<ul> +<li> +<p>the asynchronous low-active <code>rstn_i</code> top entity input signal</p> +</li> +<li> +<p>the <a href="#_on_chip_debugger_ocd">On-Chip Debugger (OCD)</a></p> +</li> +<li> +<p>the <a href="#_watchdog_timer_wdt">Watchdog Timer (WDT)</a></p> +</li> +</ul> +</div> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +<div class="title">Reset Cause</div> +The actual reset cause can be determined via the <a href="#_watchdog_timer_wdt">Watchdog Timer (WDT)</a>. +</td> +</tr> +</table> +</div> +<div class="paragraph"> +<p>If any of these sources trigger a reset, the internal reset will be triggered for at least 4 clock cycles ensuring +a valid reset of the entire processor. The internal global reset is asserted <em>aysynchronoulsy</em> if triggered by the external +<code>rstn_i</code> signal. For internal reset sources, the global reset is asserted <em>synchronously</em>. If the reset cause gets inactive +the internal reset is de-asserted <em>synchronously</em> at a falling clock edge.</p> +</div> +<div class="paragraph"> +<p>Internally, <strong>all registers</strong> that are not meant for mapping to blockRAM (like the register file) do provide a dedicated and +low-active <strong>asynchronous hardware reset</strong>. This asynchronous reset ensures that the entire processor logic is reset to a +defined state even if the main clock is not operational yet.</p> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +The system reset will only reset the control registers of each implemented IO/peripheral module. This control register +reset will also reset the according "module enable flag" to zero, which - in turn - will cause a <em>synchronous</em> +module-internal reset of the remaining logic. +</td> +</tr> +</table> +</div> +<div style="page-break-after: always;"></div> +</div> +<div class="sect2"> +<h3 id="_processor_interrupts">2.5. Processor Interrupts</h3> +<div class="paragraph"> +<p>The NEORV32 Processor provides several interrupt request signals (IRQs) for custom platform use.</p> +</div> +<div class="admonitionblock important"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-important" title="Important"></i> +</td> +<td class="content"> +<div class="title">Trigger Type</div> +All interrupt request lines are <strong>level-triggered and high-active</strong>. Once set, the signal should remain high until +the interrupt request is explicitly acknowledged (e.g. writing to a memory-mapped register). +</td> +</tr> +</table> +</div> +<div class="sect3"> +<h4 id="_risc_v_standard_interrupts">2.5.1. RISC-V Standard Interrupts</h4> +<div class="paragraph"> +<p>The processor setup features the standard machine-level RISC-V interrupt lines for "machine timer interrupt", "machine +software interrupt" and "machine external interrupt". Their usage is defined by the RISC-V privileged architecture +specifications. However, bare-metal system can also repurpose these interrupts. See CPU section +<a href="#_traps_exceptions_and_interrupts">Traps, Exceptions and Interrupts</a> for more information.</p> +</div> +<table class="tableblock frame-all grid-rows stretch"> +<colgroup> +<col style="width: 28.5714%;"> +<col style="width: 71.4286%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-left valign-top">Top signal</th> +<th class="tableblock halign-left valign-top">Description</th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>mtime_irq_i</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Machine timer interrupt from <em>processor-external</em> MTIME unit (<code>MTI</code>). This IRQ is only available if the processor-internal <a href="#_machine_system_timer_mtime">Machine System Timer (MTIME)</a> unit is not implemented.</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>msw_irq_i</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Machine software interrupt (<code>MSI</code>). This interrupt is used for inter-processor interrupts in multi-core systems. However, it can also be used for any custom purpose.</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>mext_irq_i</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Machine external interrupt (<code>MEI</code>). This interrupt is used for any processor-external interrupt source (like a platform interrupt controller).</p></td> +</tr> +</tbody> +</table> +</div> +<div class="sect3"> +<h4 id="_neorv32_specific_fast_interrupt_requests">2.5.2. NEORV32-Specific Fast Interrupt Requests</h4> +<div class="paragraph"> +<p>As part of the NEORV32-specific CPU extensions, the processor core features 16 fast interrupt request signals +(<code>FIRQ0</code> to <code>FIRQ15</code>) providing dedicated bits in the <a href="#_mip"><strong><code>mip</code></strong></a> and <a href="#_mie"><strong><code>mie</code></strong></a> CSRs and custom <a href="#_mcause"><strong><code>mcause</code></strong></a> trap codes. +The FIRQ signals are reserved for <em>processor-internal</em> modules only (for example for the communication +interfaces to signal "available incoming data" or "ready to send new data").</p> +</div> +<div class="paragraph"> +<p>The mapping of the 16 FIRQ channels to the according processor-internal modules is shown in the following +table (the channel number also corresponds to the according FIRQ priority: 0 = highest, 15 = lowest):</p> +</div> +<table class="tableblock frame-all grid-rows stretch"> +<caption class="title">Table 6. NEORV32 Fast Interrupt Request (FIRQ) Mapping</caption> +<colgroup> +<col style="width: 20%;"> +<col style="width: 20%;"> +<col style="width: 60%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-center valign-top">Channel</th> +<th class="tableblock halign-left valign-top">Source</th> +<th class="tableblock halign-left valign-top">Description</th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">0</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_true_random_number_generator_trng">TRNG</a></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">TRNG data available interrupt</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">1</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_custom_functions_subsystem_cfs">CFS</a></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Custom functions subsystem (CFS) interrupt (user-defined)</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">2</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_primary_universal_asynchronous_receiver_and_transmitter_uart0">UART0</a></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">UART0 RX FIFO level interrupt</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">3</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_primary_universal_asynchronous_receiver_and_transmitter_uart0">UART0</a></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">UART0 TX FIFO level interrupt</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">4</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_secondary_universal_asynchronous_receiver_and_transmitter_uart1">UART1</a></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">UART1 RX FIFO level interrupt</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">5</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_secondary_universal_asynchronous_receiver_and_transmitter_uart1">UART1</a></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">UART1 TX FIFO level interrupt</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">6</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_serial_peripheral_interface_controller_spi">SPI</a></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">SPI FIFO level interrupt</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">7</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_two_wire_serial_interface_controller_twi">TWI</a></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">TWI FIFO level interrupt</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">8</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_external_interrupt_controller_xirq">XIRQ</a></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">External interrupt controller interrupt</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">9</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_smart_led_interface_neoled">NEOLED</a></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">NEOLED TX FIFO level interrupt</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">10</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_direct_memory_access_controller_dma">DMA</a></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">DMA transfer done interrupt</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">11</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_serial_data_interface_controller_sdi">SDI</a></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">SDI FIFO level interrupt</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">12</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_general_purpose_timer_gptmr">GPTMR</a></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">General purpose timer interrupt</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">13</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_one_wire_serial_interface_controller_onewire">ONEWIRE</a></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">1-wire idle interrupt</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">14</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_stream_link_interface_slink">SLINK</a></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">SLINK RX FIFO level interrupt</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">15</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_stream_link_interface_slink">SLINK</a></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">SLINK TX FIFO level interrupt</p></td> +</tr> +</tbody> +</table> +<div style="page-break-after: always;"></div> +</div> +</div> +<div class="sect2"> +<h3 id="_address_space">2.6. Address Space</h3> +<div class="paragraph"> +<p>As a 32-bit architecture the NEORV32 can access a 4GB physical address space. By default, this address space is +split into six main regions. Each region provides specific <em>physical memory attributes</em> ("PMAs") that define +the access capabilities (<code>rwxac</code>; <code>r</code> = read permission, <code>w</code> = write permission, <code>x</code> - execute permission, +<code>a</code> = atomic access support, <code>c</code> = cached CPU access, <code>p</code> = privileged access only).</p> +</div> +<div class="imageblock"> +<div class="content"> +<img src="img/address_space.png" alt="900"> +</div> +<div class="title">Figure 2. NEORV32 Processor Address Space (Default Configuration)</div> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">The "Void" (Unmapped Addresses)</div> +All accesses to "unmapped" addresses (= "void") are redirected to the <a href="#_processor_external_bus_interface_xbus">Processor-External Bus Interface (XBUS)</a>. +For example, if the internal IMEM is disabled, the accesses to the <em>entire</em> address space between <code>0x00000000</code> and +<code>0x7FFFFFFF</code> are converted into XBUS requests. If the XBUS interface is not enabled any access to the void will +raise a bus error exception. +</td> +</tr> +</table> +</div> +<table class="tableblock frame-all grid-rows stretch"> +<caption class="title">Table 7. Main Address Regions</caption> +<colgroup> +<col style="width: 7.1428%;"> +<col style="width: 28.5714%;"> +<col style="width: 14.2857%;"> +<col style="width: 50.0001%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-left valign-top">#</th> +<th class="tableblock halign-center valign-top">Region</th> +<th class="tableblock halign-center valign-top">PMAs</th> +<th class="tableblock halign-left valign-top">Description</th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">1</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">Internal IMEM address space</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>rwxac-</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">For instructions (=code) and constants; mapped to the internal <a href="#_instruction_memory_imem">Instruction Memory (IMEM)</a>.</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">2</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">Internal DMEM address space</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>rwxac-</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">For application runtime data (heap, stack, etc.); mapped to the internal <a href="#_data_memory_dmem">Data Memory (DMEM)</a>).</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">3</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">Memory-mapped XIP flash</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>r-xac-</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Memory-mapped access to the <a href="#_execute_in_place_module_xip">Execute In Place Module (XIP)</a> SPI flash.</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">4</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">Bootloader address space</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>r-xa-p</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Read-only memory for the internal <a href="#_bootloader_rom_bootrom">Bootloader ROM (BOOTROM)</a> containing the default <a href="#_bootloader">Bootloader</a>.</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">5</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">IO/peripheral address space</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>rwxa-p</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Processor-internal peripherals / IO devices.</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">6</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">The "<strong>void</strong>"</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>rwxac-</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Unmapped address space. All accesses to this region(s) are redirected to the <a href="#_processor_external_bus_interface_xbus">Processor-External Bus Interface (XBUS)</a> (if implemented).</p></td> +</tr> +</tbody> +</table> +<div class="admonitionblock important"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-important" title="Important"></i> +</td> +<td class="content"> +<div class="title">Privileged IO and BOOTROM Access Only</div> +Only privileged accesses (M-mode) to the IO/peripheral and bootloader address spaces are allowed. +If an unprivileged application tries to access this address space a bus access error exception is raised. +</td> +</tr> +</table> +</div> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +<div class="title">Custom PMAs</div> +Custom physical memory attributes enforced by the CPU&#8217;s <em>physcial memory protection</em> (<a href="#_smpmp_isa_extension"><code>Smpmp</code> ISA Extension</a>) +can be used to further constrain the physical memory attributes. +</td> +</tr> +</table> +</div> +<div class="sect3"> +<h4 id="_bus_system">2.6.1. Bus System</h4> +<div class="paragraph"> +<p>The CPU can access all of the 32-bit address space from the instruction fetch interface and also from the data access +interface. Both CPU interfaces can be equipped with optional caches (<a href="#_processor_internal_data_cache_dcache">Processor-Internal Data Cache (dCACHE)</a> and +<a href="#_processor_internal_instruction_cache_icache">Processor-Internal Instruction Cache (iCACHE)</a>). The two CPU interfaces are multiplexed by a simple bus switch into +a <em>single processor-internal bus</em>. Optionally, this bus is further switched by another instance of the bus switch so the +<a href="#_direct_memory_access_controller_dma">Direct Memory Access Controller (DMA)</a> controller can also access the entire address space. Accesses via the +resulting SoC bus are split by the <a href="#_bus_gateway">Bus Gateway</a> that redirects accesses to the according main address regions +(see table above). Accesses to the processor-internal IO/peripheral devices are further redirected via a +dedicated <a href="#_io_switch">IO Switch</a>.</p> +</div> +<div class="imageblock"> +<div class="content"> +<img src="img/neorv32_bus.png" alt="1300"> +</div> +<div class="title">Figure 3. Processor-Internal Bus Architecture</div> +</div> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +<div class="title">Bus Interface</div> +See sections CPU <a href="#_architecture">Architecture</a> and <a href="#_bus_interface">Bus Interface</a> for more information regarding the CPU bus accesses. +</td> +</tr> +</table> +</div> +</div> +<div class="sect3"> +<h4 id="_bus_gateway">2.6.2. Bus Gateway</h4> +<div class="paragraph"> +<p>The central bus gateway serves two purposes: <strong>redirect</strong> core accesses to the according modules (e.g. memory accesses +vs. memory-mapped IO accesses) and <strong>monitor</strong> all bus transactions. The redirection of access request is based on a +customizable memory map implemented via VHDL constants in the main package file (<code>rtl/core/neorv323_package.vhd</code>):</p> +</div> +<div class="listingblock"> +<div class="title">Listing 1. Main Address Regions Configuration in the VHDL Package File</div> +<div class="content"> +<pre class="highlight"><code class="language-vhdl" data-lang="vhdl">-- Main Address Regions --- +constant mem_imem_base_c : std_ulogic_vector(31 downto 0) := x"00000000"; +constant mem_dmem_base_c : std_ulogic_vector(31 downto 0) := x"80000000"; +constant mem_xip_base_c : std_ulogic_vector(31 downto 0) := x"e0000000"; +constant mem_xip_size_c : natural := 256*1024*1024; +constant mem_boot_base_c : std_ulogic_vector(31 downto 0) := x"ffffc000"; +constant mem_boot_size_c : natural := 8*1024; +constant mem_io_base_c : std_ulogic_vector(31 downto 0) := x"ffffe000"; +constant mem_io_size_c : natural := 8*1024;</code></pre> +</div> +</div> +<div class="paragraph"> +<p>Besides the delegation of bus requests the gateway also implements a bus monitor (aka "the bus keeper") that tracks all +active bus transactions to ensure <em>safe</em> and <em>deterministic</em> operations.</p> +</div> +<div class="paragraph"> +<p>Whenever a memory-mapped device is accessed (a real memory, a memory-mapped IO or some processor-external module) the bus +monitor starts an internal timer. The accessed module has to respond ("ACK") to the bus request within a specific +<strong>time window</strong>. This time window is defined by a global constant in the processor&#8217;s VHDL package file +(<code>rtl/core/neorv323_package.vhd</code>).</p> +</div> +<div class="listingblock"> +<div class="title">Listing 2. Internal Bus Timeout Configuration</div> +<div class="content"> +<pre class="highlight"><code class="language-vhdl" data-lang="vhdl"> constant bus_timeout_c : natural := 15;</code></pre> +</div> +</div> +<div class="paragraph"> +<p>This constant defines the <em>maximum</em> number of cycles after which a non-responding bus request (i.e. no <code>ack</code> +and no <code>err</code> signal) will time out raising a bus access fault exception. For example this can happen when accessing +"address space holes" - addresses that are not mapped to any physical module. The resulting exception type corresponds +to the according access type, i.e. instruction fetch access exception, load access exception or store access exception.</p> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">XIP Timeout</div> +Accesses to the memory-mapped XIP flash (via the <a href="#_execute_in_place_module_xip">Execute In Place Module (XIP)</a>) will <em>never</em> time out. +</td> +</tr> +</table> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">External Bus Interface Timeout</div> +Accesses that are delegated to the external bus interface have a different maximum timeout value that is defined by an +explicit specific processor generic. See section <a href="#_processor_external_bus_interface_xbus">Processor-External Bus Interface (XBUS)</a> for more information. +</td> +</tr> +</table> +</div> +</div> +<div class="sect3"> +<h4 id="_reservation_set_controller">2.6.3. Reservation Set Controller</h4> +<div class="paragraph"> +<p>The reservation set controller is responsible for handling the load-reservate and store-conditional bus transaction that +are triggered by the <code>lr.w</code> (LR) and <code>sc.w</code> (SC) instructions from the CPU&#8217;s <a href="#_a_isa_extension"><code>A</code> ISA Extension</a>.</p> +</div> +<div class="paragraph"> +<p>A "reservation" defines an address or address range that provides a guarding mechanism to support atomic accesses. A new +reservation is registered by the LR instruction. The address provided by this instruction defines the memory location +that is now monitored for atomic accesses. The according SC instruction evaluates the state of this reservation. If +the reservation is still valid the write access triggered by the SC instruction is finally executed and the instruction +return a "success" state (<code>rd</code> = 0). If the reservation has been invalidated the SC instruction will not write to memory +and will return a "failed" state (<code>rd</code> = 1).</p> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">Reservation Set(s) and Granule</div> +The reservation set controller supports only <strong>a single</strong> global reservation set with a <strong>word-aligned 4-byte granule</strong>. +</td> +</tr> +</table> +</div> +<div class="paragraph"> +<p>The reservation is invalidated if&#8230;&#8203;</p> +</div> +<div class="ulist"> +<ul> +<li> +<p>an SC instruction is executed that accesses an address <strong>outside</strong> of the reservation set of the previous LR instruction. +This SC instruction will <strong>fail</strong> (not writing to memory).</p> +</li> +<li> +<p>an SC instruction is executed that accesses an address <strong>inside</strong> of the reservation set of the previous LR instruction. +This SC instruction will <strong>succeed</strong> (finally writing to memory).</p> +</li> +<li> +<p>a normal store operation accesses an address <strong>inside</strong> of the current reservation set (by the CPU or by the DMA).</p> +</li> +<li> +<p>a hardware reset is triggered.</p> +</li> +</ul> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">Consecutive LR Instructions</div> +If an LR instruction is followed by another LR instruction the reservation set of the former one is overridden +by the reservation set of the latter one. +</td> +</tr> +</table> +</div> +<div class="admonitionblock important"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-important" title="Important"></i> +</td> +<td class="content"> +<div class="title">Bus Access Errors</div> +If the LR operation causes a bus access error (raising a load access exception) the reservation <strong>is registered anyway</strong>. +If the SC operation causes a bus access error (raising a store access exception) an already registered reservation set +<strong>is invalidated anyway</strong>. +</td> +</tr> +</table> +</div> +<div class="admonitionblock important"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-important" title="Important"></i> +</td> +<td class="content"> +<div class="title">Strong Semantic</div> +The LR/SC mechanism follows the <em>strong semantic</em> approach: the LR/SC instruction pair fails only if there is a write +access to the referenced memory location between the LR and SC instructions (by the CPU itself or by the DMA). +Context changes, interrupts, traps, etc. do not effect nor invalidate the reservation state at all. +</td> +</tr> +</table> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">Physical Memory Attributes</div> +The reservation set can be set for <em>any</em> address (only constrained by the configured granularity). This also +includes cached memory, memory-mapped IO devices and processor-external address spaces. +</td> +</tr> +</table> +</div> +<div class="paragraph"> +<p>Bus transactions triggered by the LR instruction register a new reservation set and are delegated to the adressed +memory/device. Bus transactions triggered by the SC remove a reservation set and are forwarded to the adressed +memory/device only if the SC operations succeeds. Otherwise, the access request is not forwarded and a local ACK is +generated to terminate the bus transaction.</p> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">LR/SC Bus Protocol</div> +More information regarding the LR/SC bus transactions and the the according protocol can be found in section +<a href="#_bus_interface">Bus Interface</a> / <a href="#_atomic_accesses">Atomic Accesses</a>. +</td> +</tr> +</table> +</div> +<div class="admonitionblock important"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-important" title="Important"></i> +</td> +<td class="content"> +<div class="title">Cache Coherency</div> +Atomic operations <strong>always bypass</strong> the cache using direct/uncached accesses. Care must be taken +to maintain data cache coherency (e.g. by using the <code>fence</code> instruction). +</td> +</tr> +</table> +</div> +</div> +<div class="sect3"> +<h4 id="_io_switch">2.6.4. IO Switch</h4> +<div class="paragraph"> +<p>The IO switch further decodes the address when accessing the processor-internal IO/peripheral devices and forwards +the access request to the according module. Note that a total address space size of 256 bytes is assigned to each +IO module in order to simplify address decoding. The IO-specific address map is also defined in the main VHDL +package file (<code>rtl/core/neorv323_package.vhd</code>).</p> +</div> +<div class="listingblock"> +<div class="title">Listing 3. Exemplary Cut-Out from the IO Address Map</div> +<div class="content"> +<pre class="highlight"><code class="language-vhdl" data-lang="vhdl"> -- IO Address Map -- + constant iodev_size_c : natural := 256; -- size of a single IO device (bytes) + constant base_io_cfs_c : std_ulogic_vector(31 downto 0) := x"ffffeb00"; + constant base_io_slink_c : std_ulogic_vector(31 downto 0) := x"ffffec00"; + constant base_io_dma_c : std_ulogic_vector(31 downto 0) := x"ffffed00";</code></pre> +</div> +</div> +</div> +<div class="sect3"> +<h4 id="_boot_configuration">2.6.5. Boot Configuration</h4> +<div class="paragraph"> +<p>Due to the flexible memory configuration, the NEORV32 Processor provides several different boot scenarios. +The following section illustrates the two most common boot scenarios.</p> +</div> +<div class="imageblock"> +<div class="content"> +<img src="img/neorv32_boot_configurations.png" alt="800"> +</div> +<div class="title">Figure 4. NEORV32 Boot Configurations</div> +</div> +<div class="paragraph"> +<p>There are two general boot scenarios: <em>Indirect Boot</em> (1a and 1b) and <em>Direct Boot</em> (2a and 2b) configured via the +<code>INT_BOOTLOADER_EN</code> generic. If this generic is <code>true</code> the <em>indirect boot scenario</em> is used. This is also the +default boot configuration of the processor. If <code>INT_BOOTLOADER_EN</code> is <code>*false</code> the <em>direct boot scenario</em> is used.</p> +</div> +<div class="sect4"> +<h5 id="_indirect_boot">Indirect Boot</h5> +<div class="paragraph"> +<p>The indirect_boot scenarios <strong>1a</strong> and <strong>1b</strong> are based on the processor-internal <a href="#_bootloader">Bootloader</a>. This boot setup is enabled +by setting the <code>INT_BOOTLOADER_EN</code> generic to <code>true</code>, which will implement the processor-internal <a href="#_bootloader_rom_bootrom">Bootloader ROM (BOOTROM)</a>. +This read-only memory is pre-initialized during synthesis with the default bootloader firmware. The bootloader provides several +options to upload an executable copying it to the beginning of the <em>instruction address space</em> so the CPU can execute it.</p> +</div> +<div class="paragraph"> +<p>Boot scenario <strong>1a</strong> uses the processor-internal IMEM. This scenario implements the internal <a href="#_instruction_memory_imem">Instruction Memory (IMEM)</a> +as non-initialized RAM so the bootloader can copy the actual executable to it.</p> +</div> +<div class="paragraph"> +<p>Boot scenario <strong>1b</strong> uses a processor-external IMEM that is connected via the processor&#8217;s bus interface. In this scenario +the internal <a href="#_instruction_memory_imem">Instruction Memory (IMEM)</a> is not implemented at all and the bootloader will copy the executable to the +processor-external memory. Hence, the external memory has to be implemented as RAM.</p> +</div> +</div> +<div class="sect4"> +<h5 id="_direct_boot">Direct Boot</h5> +<div class="paragraph"> +<p>The direct boot scenarios <strong>2a</strong> and <strong>2b</strong> do not use the processor-internal bootloader since the <code>INT_BOOTLOADER_EN</code> +generic is set <code>false</code>. In this configuration the <a href="#_bootloader_rom_bootrom">Bootloader ROM (BOOTROM)</a> is not implemented at all and the CPU will +directly begin executing code from the beginning of the instruction address space after reset. An application-specific +"pre-initialization" mechanism is required in order to provide an executable inside the memory.</p> +</div> +<div class="paragraph"> +<p>Boot scenario <strong>2a</strong> uses the processor-internal IMEM implemented as <em>read-only memory</em> in this scenario. +It is pre-initialized (by the bitstream) with the actual application executable during synthesis.</p> +</div> +<div class="paragraph"> +<p>In contrast, boot scenario <strong>2b</strong> uses a processor-external IMEM. In this scenario the system designer is responsible for +providing an initialized external memory that contains the actual application to be executed.</p> +</div> +<div style="page-break-after: always;"></div> +</div> +</div> +</div> +<div class="sect2"> +<h3 id="_processor_internal_modules">2.7. Processor-Internal Modules</h3> +<div class="admonitionblock important"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-important" title="Important"></i> +</td> +<td class="content"> +<div class="title">Privileged IO Access Only</div> +Only privileged accesses (M-mode) to the IO/peripheral modules are allowed. If an unprivileged application +tries to access this address space a bus access error exception is raised. +</td> +</tr> +</table> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">Full-Word Write Accesses Only</div> +All peripheral/IO devices should only be written in full-word mode (i.e. 32-bit). Byte or half-word (8/16-bit) write accesses +might cause undefined behavior. +</td> +</tr> +</table> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">Writing to Read-Only Registers</div> +Unless otherwise specified, writing to registers that are listed as read-only does not trigger an exception. +The write access is simply ignored by the corresponding hardware module. +</td> +</tr> +</table> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">IO Module&#8217;s Address Space</div> +Each peripheral/IO module occupies an address space of 256 bytes (64 words). Most devices do not fully utilize this address +space and will simply <em>mirror</em> the available interface registers across the entire 256 bytes of address space. +</td> +</tr> +</table> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">Unimplemented Modules / Address Holes</div> +When accessing an IO device that hast not been implemented (disabled via the according generic) +or when accessing an address that is actually unused, a load/store access fault exception is raised. +</td> +</tr> +</table> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">Module Interrupts</div> +Several peripheral/IO devices provide some kind of interrupt. These interrupts are mapped to the CPU&#8217;s +<a href="#_custom_fast_interrupt_request_lines">Custom Fast Interrupt Request Lines</a>. See section <a href="#_processor_interrupts">Processor Interrupts</a> for more information. +</td> +</tr> +</table> +</div> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +<div class="title">CMSIS System Description View (SVD)</div> +A CMSIS-compatible <strong>System View Description (SVD)</strong> file including all peripherals is available in <code>sw/svd</code>. +</td> +</tr> +</table> +</div> +<div style="page-break-after: always;"></div> +<div class="sect3"> +<h4 id="_instruction_memory_imem">2.7.1. Instruction Memory (IMEM)</h4> +<table class="tableblock frame-ends grid-none stretch"> +<colgroup> +<col style="width: 30%;"> +<col style="width: 30%;"> +<col style="width: 40%;"> +</colgroup> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Hardware source files:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">neorv32_imem.entity.vhd</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">entity-only definition</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">mem/neorv32_imem.default.vhd</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">default <em>platform-agnostic</em> memory architecture</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">mem/neorv32_imem.legacy.vhd</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">alternative legacy-style memory architecture</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Software driver files:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">none</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><em>implicitly used</em></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Top entity ports:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">none</p></td> +<td class="tableblock halign-left valign-top"></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Configuration generics:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>MEM_INT_IMEM_EN</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">implement processor-internal IMEM when <code>true</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>MEM_INT_IMEM_SIZE</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">IMEM size in bytes (use a power of 2)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>INT_BOOTLOADER_EN</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">use internal bootloader when <code>true</code> (implements IMEM as <em>uninitialized</em> RAM, otherwise the IMEM is implemented an <em>pre-intialized</em> ROM)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">CPU interrupts:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">none</p></td> +<td class="tableblock halign-left valign-top"></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Access restrictions:</p></td> +<td class="tableblock halign-left valign-top" colspan="2"><p class="tableblock">none / read-only if <code>INT_BOOTLOADER_EN = true</code></p></td> +</tr> +</tbody> +</table> +<div class="paragraph"> +<p><strong>Overview</strong></p> +</div> +<div class="paragraph"> +<p>Implementation of the processor-internal instruction memory is enabled by the processor&#8217;s +<code>MEM_INT_IMEM_EN</code> generic. The total memory size in bytes is defined via the <code>MEM_INT_IMEM_SIZE</code> generic. +Note that this size should be a power of two to optimize physical implementation. If the IMEM is implemented, +it is mapped to base address <code>0x00000000</code> by default (see section <a href="#_address_space">Address Space</a>).</p> +</div> +<div class="paragraph"> +<p>By default the IMEM is implemented as true RAM so the content can be modified during run time. This is +required when using the bootloader (or the on-chip debugger) so it can update the content of the IMEM at +any time. If this feature is not required the IMEM can be implemented as <em>pre-intialized</em> ROM so that the +application code permanently resides in memory. This is automatically implemented when the +processor-internal bootloader is disabled (<code>INT_BOOTLOADER_EN</code> = <code>false</code>).</p> +</div> +<div class="paragraph"> +<p>When the IMEM is implemented as ROM, it will be initialized during synthesis with the actual application program +image. The compiler toolchain provides an option to generate and override the default VHDL initialization file +<code>rtl/core/neorv32_application_image.vhd</code>, which is automatically inserted into the IMEM. If the IMEM is implemented +as RAM (default), the memory block will <strong>not be initialized at all</strong>.</p> +</div> +<div class="admonitionblock important"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-important" title="Important"></i> +</td> +<td class="content"> +<div class="title">Memory Size</div> +If the configured memory size (via the <code>MEM_INT_IMEM_SIZE</code> generic) is <strong>not</strong> a power of two the actual memory +size will be auto-adjusted to the next power of two (e.g. configuring a memory size of 60kB will result in a +physical memory size of 64kB). +</td> +</tr> +</table> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">VHDL Source File</div> +The actual IMEM is split into two design files: a plain entity definition (<code>neorv32_imem.entity.vhd</code>) and the actual +architecture definition <code>mem/neorv32_imem.default.vhd</code>. This <strong>default architecture</strong> provides a <em>generic</em> and +<em>platform independent</em> memory design that infers embedded memory blocks (blockRAM). The default architecture can +be replaced by platform-specific modules in order to use platform-specific features or to improve technology mapping +and/or timing. A "legacy-style" memory architecture is provided in <code>rtl/mem</code> that can be used if the synthesis does +not correctly infer blockRAMs. +</td> +</tr> +</table> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">Read-Only Access</div> +If the IMEM is implemented as true ROM any write attempt to it will raise a <em>store access fault</em> exception. +</td> +</tr> +</table> +</div> +<div style="page-break-after: always;"></div> +</div> +<div class="sect3"> +<h4 id="_data_memory_dmem">2.7.2. Data Memory (DMEM)</h4> +<table class="tableblock frame-ends grid-none stretch"> +<colgroup> +<col style="width: 30%;"> +<col style="width: 30%;"> +<col style="width: 40%;"> +</colgroup> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Hardware source files:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">neorv32_dmem.entity.vhd</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">entity-only definition</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">mem/neorv32_dmem.default.vhd</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">default <em>platform-agnostic</em> memory architecture</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">mem/neorv32_dmem.legacy.vhd</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">alternative legacy-style memory architecture</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Software driver files:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">none</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><em>implicitly used</em></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Top entity ports:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">none</p></td> +<td class="tableblock halign-left valign-top"></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Configuration generics:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>MEM_INT_DMEM_EN</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">implement processor-internal DMEM when <code>true</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>MEM_INT_DMEM_SIZE</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">DMEM size in bytes (use a power of 2)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">CPU interrupts:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">none</p></td> +<td class="tableblock halign-left valign-top"></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Access restrictions:</p></td> +<td class="tableblock halign-left valign-top" colspan="2"><p class="tableblock">none</p></td> +</tr> +</tbody> +</table> +<div class="paragraph"> +<p><strong>Overview</strong></p> +</div> +<div class="paragraph"> +<p>Implementation of the processor-internal data memory is enabled by the processor&#8217;s <code>MEM_INT_DMEM_EN</code> +generic. The total memory size in bytes is defined via the <code>MEM_INT_DMEM_SIZE</code> generic. Note that this +size should be a power of two to optimize physical implementation. If the DMEM is implemented, +it is mapped to base address <code>0x80000000</code> by default (see section <a href="#_address_space">Address Space</a>). +The DMEM is always implemented as true RAM.</p> +</div> +<div class="admonitionblock important"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-important" title="Important"></i> +</td> +<td class="content"> +<div class="title">Memory Size</div> +If the configured memory size (via the <code>MEM_INT_IMEM_SIZE</code> generic) is <strong>not</strong> a power of two the actual memory +size will be auto-adjusted to the next power of two (e.g. configuring a memory size of 60kB will result in a +physical memory size of 64kB). +</td> +</tr> +</table> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">VHDL Source File</div> +The actual DMEM is split into two design files: a plain entity definition <code>neorv32_dmem.entity.vhd</code> and the actual +architecture definition <code>mem/neorv32_dmem.default.vhd</code>. This <strong>default architecture</strong> provides a <em>generic</em> and +<em>platform independent</em> memory design that infers embedded memory blocks (blockRAM). The default architecture can +be replaced by platform-specific modules in order to use platform-specific features or to improve technology mapping +and/or timing. A "legacy-style" memory architecture is provided in <code>rtl/mem</code> that can be used if the synthesis does +not correctly infer blockRAMs. +</td> +</tr> +</table> +</div> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +<div class="title">Execute from RAM</div> +The CPU is capable of executing code also from arbitrary data memory. +</td> +</tr> +</table> +</div> +<div style="page-break-after: always;"></div> +</div> +<div class="sect3"> +<h4 id="_bootloader_rom_bootrom">2.7.3. Bootloader ROM (BOOTROM)</h4> +<table class="tableblock frame-ends grid-none stretch"> +<colgroup> +<col style="width: 30%;"> +<col style="width: 30%;"> +<col style="width: 40%;"> +</colgroup> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Hardware source files:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">neorv32_boot_rom.vhd</p></td> +<td class="tableblock halign-left valign-top"></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Software driver files:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">none</p></td> +<td class="tableblock halign-left valign-top"></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Top entity ports:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">none</p></td> +<td class="tableblock halign-left valign-top"></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Configuration generics:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>INT_BOOTLOADER_EN</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">implement processor-internal bootloader when <code>true</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">CPU interrupts:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">none</p></td> +<td class="tableblock halign-left valign-top"></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Access restrictions:</p></td> +<td class="tableblock halign-left valign-top" colspan="2"><p class="tableblock">privileged access only, read-only</p></td> +</tr> +</tbody> +</table> +<div class="paragraph"> +<p><strong>Overview</strong></p> +</div> +<div class="paragraph"> +<p>This boot ROM module provides a read-only memory that contain the executable image of the default NEORV32 +<a href="#_bootloader">Bootloader</a>. If the internal bootloader is enabled via the <code>INT_BOOTLOADER_EN</code> generic the CPU&#8217;s boot address +is automatically set to the beginning of the bootloader ROM. See sections <a href="#_address_space">Address Space</a> and +<a href="#_boot_configuration">Boot Configuration</a> for more information regarding the processor&#8217;s different boot scenarios.</p> +</div> +<div class="admonitionblock important"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-important" title="Important"></i> +</td> +<td class="content"> +<div class="title">Memory Size</div> +If the configured boot ROM size is <strong>not</strong> a power of two the actual memory size will be auto-adjusted to +the next power of two (e.g. configuring a memory size of 6kB will result in a physical memory size of 8kB). +</td> +</tr> +</table> +</div> +<div class="admonitionblock important"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-important" title="Important"></i> +</td> +<td class="content"> +<div class="title">Bootloader Image</div> +The boot ROM is initialized during synthesis with the default bootloader image +(<code>rtl/core/neorv32_bootloader_image.vhd</code>). +</td> +</tr> +</table> +</div> +<div style="page-break-after: always;"></div> +</div> +<div class="sect3"> +<h4 id="_processor_internal_instruction_cache_icache">2.7.4. Processor-Internal Instruction Cache (iCACHE)</h4> +<table class="tableblock frame-ends grid-none stretch"> +<colgroup> +<col style="width: 30%;"> +<col style="width: 30%;"> +<col style="width: 40%;"> +</colgroup> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Hardware source files:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">neorv32_cache.vhd</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Generic cache module</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Software driver files:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">none</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><em>implicitly used</em></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Top entity ports:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">none</p></td> +<td class="tableblock halign-left valign-top"></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Configuration generics:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>ICACHE_EN</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">implement processor-internal instruction cache when <code>true</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>ICACHE_NUM_BLOCKS</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">number of cache blocks (pages/lines)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>ICACHE_BLOCK_SIZE</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">size of a cache block in bytes</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">CPU interrupts:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">none</p></td> +<td class="tableblock halign-left valign-top"></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Access restrictions:</p></td> +<td class="tableblock halign-left valign-top" colspan="2"><p class="tableblock">none</p></td> +</tr> +</tbody> +</table> +<div class="paragraph"> +<p><strong>Overview</strong></p> +</div> +<div class="paragraph"> +<p>The processor features an optional instruction cache to improve performance when using memories with high +access latencies. The cache is connected directly to the CPU&#8217;s instruction fetch interface and provides +full-transparent accesses. The cache is direct-mapped and read-only.</p> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">Cached/Uncached Accesses</div> +The data cache provides direct accesses (= uncached) to memory in order to access memory-mapped IO (like the +processor-internal IO/peripheral modules). All accesses that target the address range from <code>0xF0000000</code> to <code>0xFFFFFFFF</code> +will not be cached at all (see section <a href="#_address_space">Address Space</a>). Direct/uncached accesses have <strong>lower</strong> priority than +cache block operations to allow continuous burst transfer and also to maintain logical instruction forward +progress / data coherency. Furthermore, atomic load-reservate and store-conditional instructions (<a href="#_a_isa_extension"><code>A</code> ISA Extension</a>) +will always <strong>bypass</strong> the cache. +</td> +</tr> +</table> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">Caching Internal Memories</div> +The data cache is intended to accelerate data access to <strong>processor-external</strong> memories. +The CPU cache(s) should not be implemented when using only processor-internal data and instruction memories. +</td> +</tr> +</table> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">Manual Cache Clear/Reload</div> +By executing the <code>fence(.i)</code> instruction the cache is cleared and a reload from main memory is triggered. +</td> +</tr> +</table> +</div> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +<div class="title">Retrieve Cache Configuration from Software</div> +Software can retrieve the cache configuration/layout from the <a href="#_sysinfo_cache_configuration">SYSINFO - Cache Configuration</a> register. +</td> +</tr> +</table> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">Bus Access Fault Handling</div> +The cache always loads a complete cache block (aligned to the block size) every time a +cache miss is detected. Each cached word from this block provides a single status bit that indicates if the +according bus access was successful or caused a bus error. Hence, the whole cache block remains valid even +if certain addresses inside caused a bus error. If the CPU accesses any of the faulty cache words, an +instruction bus error exception is raised. +</td> +</tr> +</table> +</div> +<div style="page-break-after: always;"></div> +</div> +<div class="sect3"> +<h4 id="_processor_internal_data_cache_dcache">2.7.5. Processor-Internal Data Cache (dCACHE)</h4> +<table class="tableblock frame-ends grid-none stretch"> +<colgroup> +<col style="width: 30%;"> +<col style="width: 30%;"> +<col style="width: 40%;"> +</colgroup> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Hardware source files:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">neorv32_cache.vhd</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Generic cache module</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Software driver files:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">none</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><em>implicitly used</em></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Top entity ports:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">none</p></td> +<td class="tableblock halign-left valign-top"></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Configuration generics:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>DCACHE_EN</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">implement processor-internal data cache when <code>true</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>DCACHE_NUM_BLOCKS</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">number of cache blocks (pages/lines)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>DCACHE_BLOCK_SIZE</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">size of a cache block in bytes</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">CPU interrupts:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">none</p></td> +<td class="tableblock halign-left valign-top"></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Access restrictions:</p></td> +<td class="tableblock halign-left valign-top" colspan="2"><p class="tableblock">none</p></td> +</tr> +</tbody> +</table> +<div class="paragraph"> +<p><strong>Overview</strong></p> +</div> +<div class="paragraph"> +<p>The processor features an optional data cache to improve performance when using memories with high +access latencies. The cache is connected directly to the CPU&#8217;s data access interface and provides +full-transparent accesses. The cache is direct-mapped and uses "write-allocate" and "write-back" strategies.</p> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">Cached/Uncached Accesses</div> +The data cache provides direct accesses (= uncached) to memory in order to access memory-mapped IO (like the +processor-internal IO/peripheral modules). All accesses that target the address range from <code>0xF0000000</code> to <code>0xFFFFFFFF</code> +will not be cached at all (see section <a href="#_address_space">Address Space</a>). Direct/uncached accesses have <strong>lower</strong> priority than +cache block operations to allow continuous burst transfer and also to maintain logical instruction forward +progress / data coherency. Furthermore, atomic load-reservate and store-conditional instructions (<a href="#_a_isa_extension"><code>A</code> ISA Extension</a>) +will always <strong>bypass</strong> the cache. +</td> +</tr> +</table> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">Caching Internal Memories</div> +The data cache is intended to accelerate data access to <strong>processor-external</strong> memories. +The CPU cache(s) should not be implemented when using only processor-internal data and instruction memories. +</td> +</tr> +</table> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">Manual Cache Flush/Clear/Reload</div> +By executing the <code>fence(.i)</code> instruction the cache is flushed, cleared and a reload from main memory is triggered. +</td> +</tr> +</table> +</div> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +<div class="title">Retrieve Cache Configuration from Software</div> +Software can retrieve the cache configuration/layout from the <a href="#_sysinfo_cache_configuration">SYSINFO - Cache Configuration</a> register. +</td> +</tr> +</table> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">Bus Access Fault Handling</div> +The cache always loads a complete cache block (aligned to the block size) every time a +cache miss is detected. Each cached word from this block provides a single status bit that indicates if the +according bus access was successful or caused a bus error. Hence, the whole cache block remains valid even +if certain addresses inside caused a bus error. If the CPU accesses any of the faulty cache words, a +data bus error exception is raised. +</td> +</tr> +</table> +</div> +<div style="page-break-after: always;"></div> +</div> +<div class="sect3"> +<h4 id="_direct_memory_access_controller_dma">2.7.6. Direct Memory Access Controller (DMA)</h4> +<table class="tableblock frame-ends grid-none stretch"> +<colgroup> +<col style="width: 30%;"> +<col style="width: 30%;"> +<col style="width: 40%;"> +</colgroup> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Hardware source files:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">neorv32_dma.vhd</p></td> +<td class="tableblock halign-left valign-top"></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Software driver files:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">neorv32_dma.c</p></td> +<td class="tableblock halign-left valign-top"></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">neorv32_dma.h</p></td> +<td class="tableblock halign-left valign-top"></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Top entity ports:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">none</p></td> +<td class="tableblock halign-left valign-top"></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Configuration generics:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>IO_DMA_EN</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">implement DMA when <code>true</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">CPU interrupts:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">fast IRQ channel 10</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">DMA transfer done (see <a href="#_processor_interrupts">Processor Interrupts</a>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Access restrictions:</p></td> +<td class="tableblock halign-left valign-top" colspan="2"><p class="tableblock">privileged access only, non-32-bit write accesses are ignored</p></td> +</tr> +</tbody> +</table> +<div class="paragraph"> +<p><strong>Overview</strong></p> +</div> +<div class="paragraph"> +<p>The NEORV32 DMA provides a small-scale scatter/gather direct memory access controller that allows to transfer and +modify data independently of the CPU. A single read/write transfer channel is implemented that is configured via +memory-mapped registers. a configured transfer can either be triggered manually or by a programmable CPU FIRQ interrupt +(see <a href="#_neorv32_specific_fast_interrupt_requests">NEORV32-Specific Fast Interrupt Requests</a>).</p> +</div> +<div class="paragraph"> +<p>The DMA is connected to the central processor-internal bus system (see section <a href="#_address_space">Address Space</a>) and can access the same +address space as the CPU core. It uses <em>interleaving mode</em> accessing the central processor bus only if the CPU does not +currently request and bus access.</p> +</div> +<div class="paragraph"> +<p>The controller can handle different data quantities (e.g. read bytes and write them back as sign-extend words) and can +also change the Endianness of data while transferring.</p> +</div> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +<div class="title">DMA Demo Program</div> +A DMA example program can be found in <code>sw/example/demo_dma</code>. +</td> +</tr> +</table> +</div> +<div class="paragraph"> +<p><strong>Theory of Operation</strong></p> +</div> +<div class="paragraph"> +<p>The DMA provides four memory-mapped interface registers: A status and control register <code>CTRL</code> and three registers for +configuring the actual DMA transfer. The base address of the source data is programmed via the <code>SRC_BASE</code> register. +Vice versa, the base address of the destination data is programmed via the <code>DST_BASE</code>. The third configuration register +<code>TTYPE</code> is use to configure the actual transfer type and the number of elements to transfer.</p> +</div> +<div class="paragraph"> +<p>The DMA is enabled by setting the <code>DMA_CTRL_EN</code> bit of the control register. Manual trigger mode (i.e. the DMA transfer is +triggered by writing to the <code>TTYPE</code> register) is selected if <code>DMA_CTRL_AUTO</code> is cleared. Alternatively, the DMA transfer can +be triggered by a processor internal FIRQ signal if <code>DMA_CTRL_AUTO</code> is set (see section below).</p> +</div> +<div class="paragraph"> +<p>The DMA uses a load-modify-write data transfer process. Data is read from the bus system, internally modified and then written +back to the bus system. This combination is implemented as an atomic progress, so canceling the current transfer by clearing the +<code>DMA_CTRL_EN</code> bit will stop the DMA right after the current load-modify-write operation.</p> +</div> +<div class="paragraph"> +<p>If the DMA controller detects a bus error during operation, it will set either the <code>DMA_CTRL_ERROR_RD</code> (error during +last read access) or <code>DMA_CTRL_ERROR_WR</code> (error during last write access) and will terminate the current transfer. +Software can read the <code>SRC_BASE</code> or <code>DST_BASE</code> register to retrieve the address that caused the according error. +Alternatively, software can read back the <code>NUM</code> bits of the control register to determine the index of the element +that caused the error. The error bits are automatically cleared when starting a new transfer.</p> +</div> +<div class="paragraph"> +<p>When the <code>DMA_CTRL_DONE</code> flag is set the DMA has actually executed a transfer. However, the <code>DMA_CTRL_ERROR_*</code> flags +should also be checked to verify that the executed transfer completed without errors. The <code>DMA_CTRL_DONE</code> flag is +automatically cleared when writing the <code>CTRL</code> register.</p> +</div> +<div class="admonitionblock warning"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-warning" title="Warning"></i> +</td> +<td class="content"> +<div class="title">DMA Access Privilege Level</div> +Transactions performed by the DMA are executed as bus transactions with elevated <strong>machine-mode</strong> privilege level. +Note that any physical memory protection rules (<a href="#_smpmp_isa_extension"><code>Smpmp</code> ISA Extension</a>) are not applied to DMA transfers. +</td> +</tr> +</table> +</div> +<div class="paragraph"> +<p><strong>Transfer Configuration</strong></p> +</div> +<div class="paragraph"> +<p>If the DMA is set to <strong>manual trigger mode</strong> (<code>DMA_CTRL_AUTO</code> = 0) writing the <code>TTRIG</code> register will start the +programmed DMA transfer. Once started, the DMA will read one data quantity from the source address, processes it internally +and then will write it back to the destination address. The <code>DMA_TTYPE_NUM</code> bits of the <code>TTYPE</code> register define how many +times this process is repeated by specifying the number of elements to transfer.</p> +</div> +<div class="paragraph"> +<p>Optionally, the source and/or destination addresses can be increments according to the data quantities +automatically by setting the according <code>DMA_TTYPE_SRC_INC</code> and/or <code>DMA_TTYPE_DST_INC</code> bit.</p> +</div> +<div class="paragraph"> +<p>Four different transfer quantities are available, which are configured via the <code>DMA_TTYPE_QSEL</code> bits:</p> +</div> +<div class="ulist"> +<ul> +<li> +<p><code>00</code>: Read source data as byte, write destination data as byte</p> +</li> +<li> +<p><code>01</code>: Read source data as byte, write destination data as zero-extended word</p> +</li> +<li> +<p><code>10</code>: Read source data as byte, write destination data as sign-extended word</p> +</li> +<li> +<p><code>11</code>: Read source data as word, write destination data as word</p> +</li> +</ul> +</div> +<div class="paragraph"> +<p>Optionally, the DMA controller can automatically convert Endianness of the transferred data if the <code>DMA_TTYPE_ENDIAN</code> +bit is set.</p> +</div> +<div class="admonitionblock important"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-important" title="Important"></i> +</td> +<td class="content"> +<div class="title">Address Alignment</div> +Make sure to align the source and destination base addresses to the according transfer data quantities. For instance, +word-to-word transfers require that the two LSB of <code>SRC_BASE</code> and <code>DST_BASE</code> are cleared. +</td> +</tr> +</table> +</div> +<div class="admonitionblock important"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-important" title="Important"></i> +</td> +<td class="content"> +<div class="title">Writing to IO Device</div> +When writing data to IO / peripheral devices (for example to the <a href="#_cyclic_redundancy_check_crc">Cyclic Redundancy Check (CRC)</a>) the destination +data quantity has to be set to <strong>word</strong> (32-bit) since all IO registers can only be written in full 32-bit word mode. +</td> +</tr> +</table> +</div> +<div class="paragraph"> +<p><strong>Automatic Trigger</strong></p> +</div> +<div class="paragraph"> +<p>As an alternative to the manual trigger mode, the DMA can be set to <strong>automatic trigger mode</strong> starting a pre-configured +transfer if a specific processor-internal peripheral issues a FIRQ interrupt request. The automatic trigger mode is enabled by +setting the <code>CTRL</code> register&#8217;s <code>DMA_CTRL_AUTO</code> bit. In this configuration <em>no</em> transfer is started when writing to the DMA&#8217;s +<code>TTYPE</code> register.</p> +</div> +<div class="paragraph"> +<p>The actually triggering FIRQ channel is configured via the control register&#8217;s <code>DMA_CTRL_FIRQ_SEL</code> bits. Writing a 0 will +select FIRQ channel 0, writing a 1 will select FIRQ channel 1, and so on. See section <a href="#_processor_interrupts">Processor Interrupts</a> +for a list of all FIRQ channels and their according sources.</p> +</div> +<div class="paragraph"> +<p>The FIRQ trigger can operate in two trigger mode configured via the <code>DMA_CTRL_FIRQ_TYPE</code> flag:</p> +</div> +<div class="ulist"> +<ul> +<li> +<p><code>DMA_CTRL_FIRQ_TYPE = 0</code>: trigger the automatic DMA transfer on a rising-edge of the selected FIRQ channel (e.g. trigger +DMA transfer only once)</p> +</li> +<li> +<p><code>DMA_CTRL_FIRQ_TYPE = 1</code>: trigger the automatic DMA transfer when the selected FIRQ channel is active (e.g. trigger +DMA transfer again and again)</p> +</li> +</ul> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">FIRQ Trigger</div> +The DMA transfer will start if a <strong>rising edge</strong> is detected on the configured FIRQ channel. Hence, the DMA is triggered only +once even if the selected FIRQ channel keeps pending. +</td> +</tr> +</table> +</div> +<div class="paragraph"> +<p><strong>Memory Barrier / Fence Operation</strong></p> +</div> +<div class="paragraph"> +<p>Optionally, the DMA can issue a FENCE request to the downstream memory system when a transfer has been completed +without errors. This can be used to re-sync caches (flush and reload) and buffers to maintain data coherency. +This automatic fencing is enabled by the setting the control register&#8217;s <code>DMA_CTRL_FENCE</code> bit.</p> +</div> +<div class="paragraph"> +<p><strong>DMA Interrupt</strong></p> +</div> +<div class="paragraph"> +<p>The DMA features a single CPU interrupt that is triggered when the programmed transfer has completed. This +interrupt is also triggered if the DMA encounters a bus error during operation. The interrupt will remain pending +until the control register&#8217;s <code>DMA_CTRL_DONE</code> is cleared (this will happen upon any write access to the control +register).</p> +</div> +<div class="paragraph"> +<p><strong>Register Map</strong></p> +</div> +<table class="tableblock frame-all grid-all stretch"> +<caption class="title">Table 8. DMA Register Map (<code>struct NEORV32_DMA</code>)</caption> +<colgroup> +<col style="width: 13.3333%;"> +<col style="width: 6.6666%;"> +<col style="width: 26.6666%;"> +<col style="width: 6.6666%;"> +<col style="width: 46.6669%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-left valign-top">Address</th> +<th class="tableblock halign-left valign-top">Name [C]</th> +<th class="tableblock halign-left valign-top">Bit(s), Name [C]</th> +<th class="tableblock halign-center valign-top">R/W</th> +<th class="tableblock halign-left valign-top">Function</th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-left valign-top" rowspan="12"><p class="tableblock"><code>0xffffed00</code></p></td> +<td class="tableblock halign-left valign-top" rowspan="12"><p class="tableblock"><code>CTRL</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0</code> <code>DMA_CTRL_EN</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">DMA module enable</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>1</code> <code>DMA_CTRL_AUTO</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Enable automatic mode (FIRQ-triggered)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>2</code> <code>DMA_CTRL_FENCE</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Issue a downstream FENCE operation when DMA transfer completes (without errors)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>7:3</code> <em>reserved</em></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">reserved, read as zero</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>8</code> <code>DMA_CTRL_ERROR_RD</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Error during read access, clears when starting a new transfer</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>9</code> <code>DMA_CTRL_ERROR_WR</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Error during write access, clears when starting a new transfer</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>10</code> <code>DMA_CTRL_BUSY</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">DMA transfer in progress</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>11</code> <code>DMA_CTRL_DONE</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/c</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Set if a transfer was executed; auto-clears on write-access</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>14:12</code> <em>reserved</em></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">reserved, read as zero</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>15</code> <code>DMA_CTRL_FIRQ_TYPE</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Trigger on rising-edge (<code>0</code>) or high-level (<code>1</code>) or selected FIRQ channel</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>19:16</code> <code>DMA_CTRL_FIRQ_SEL_MSB : DMA_CTRL_FIRQ_SEL_LSB</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">FIRQ trigger select (FIRQ0=0 &#8230;&#8203; FIRQ15=15)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>31:20</code> <em>reserved</em></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">reserved, read as zero</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0xffffed04</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>SRC_BASE</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>31:0</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Source base address (shows the last-accessed source address when read)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0xffffed08</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>DST_BASE</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>31:0</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Destination base address (shows the last-accessed destination address when read)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top" rowspan="6"><p class="tableblock"><code>0xffffed0c</code></p></td> +<td class="tableblock halign-left valign-top" rowspan="6"><p class="tableblock"><code>TTYPE</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>23:0</code> <code>DMA_TTYPE_NUM_MSB : DMA_TTYPE_NUM_LSB</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Number of elements to transfer (shows the last-transferred element index when read)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>26:24</code> <em>reserved</em></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">reserved, read as zero</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>28:27</code> <code>DMA_TTYPE_QSEL_MSB : DMA_TTYPE_QSEL_LSB</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Source data quantity select (<code>00</code> = byte, <code>01</code> = half-word, <code>10</code> = word)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>29</code> <code>DMA_TTYPE_SRC_INC</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Constant (<code>0</code>) or incrementing (<code>1</code>) source address</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>30</code> <code>DMA_TTYPE_DST_INC</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Constant (<code>0</code>) or incrementing (<code>1</code>) destination address</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>31</code> <code>DMA_TTYPE_ENDIAN</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Swap Endianness when set</p></td> +</tr> +</tbody> +</table> +<div style="page-break-after: always;"></div> +</div> +<div class="sect3"> +<h4 id="_processor_external_bus_interface_xbus">2.7.7. Processor-External Bus Interface (XBUS)</h4> +<table class="tableblock frame-ends grid-none stretch"> +<colgroup> +<col style="width: 30%;"> +<col style="width: 30%;"> +<col style="width: 40%;"> +</colgroup> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Hardware source files:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">neorv32_xbus.vhd</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">External bus gateway</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">neorv32_cache.vhd</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Generic cache module</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Software driver files:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">none</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><em>implicitly used</em></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Top entity ports:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>xbus_adr_o</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">address output (32-bit)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>xbus_dat_o</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">data output (32-bit)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>xbus_tag_o</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">access tag (3-bit)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>xbus_we_o</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">write enable (1-bit)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>xbus_sel_o</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">byte enable (4-bit)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>xbus_stb_o</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">bus strobe (1-bit)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>xbus_cyc_o</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">valid cycle (1-bit)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>xbus_dat_i</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">data input (32-bit)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>xbus_ack_i</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">acknowledge (1-bit)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>xbus_err_i</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">bus error (1-bit)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Configuration generics:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>XBUS_EN</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">enable external bus interface when <code>true</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>XBUS_TIMEOUT</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">number of clock cycles after which an unacknowledged external bus access will auto-terminate (0 = disabled)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>XBUS_REGSTAGE_EN</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">implement XBUS register stages</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>XBUS_CACHE_EN</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">implement the external bus cache</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>XBUS_CACHE_NUM_BLOCKS</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">number of blocks ("lines"), has to be a power of two.</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>XBUS_CACHE_BLOCK_SIZE</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">size in bytes of each block, has to be a power of two.</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">CPU interrupts:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">none</p></td> +<td class="tableblock halign-left valign-top"></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Access restrictions:</p></td> +<td class="tableblock halign-left valign-top" colspan="2"><p class="tableblock">none</p></td> +</tr> +</tbody> +</table> +<div class="paragraph"> +<p><strong>Overview</strong></p> +</div> +<div class="paragraph"> +<p>The external bus interface provides a <strong>Wishbone b4</strong>-compatible on-chip bus interface that is +implemented if the <code>XBUS_EN</code> generic is <code>true</code>. This bus interface can be used to attach processor-external +modules like memories, custom hardware accelerators or additional peripheral devices. +An optional cache module ("XCACHE") can be enabled to improve memory access latency.</p> +</div> +<div class="admonitionblock important"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-important" title="Important"></i> +</td> +<td class="content"> +<div class="title">Address Mapping</div> +The external interface is <strong>not</strong> mapped to a specific address space. Instead, all CPU memory accesses that +do not target a specific (and actually implemented) processor-internal address region (hence, accessing the "void"; +see section <a href="#_address_space">Address Space</a>) are <strong>redirected</strong> to the external bus interface. +</td> +</tr> +</table> +</div> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +<div class="title">AXI4-Lite Interface Bridge</div> +A processor top entity with an AXI4-Lite-compatible bus interface can be found in <code>rtl/system_inegration</code>. +More information regarding this alternate top entity can be found in in the user guide: +<a href="https://stnolting.github.io/neorv32/ug/#_packaging_the_processor_as_vivado_ip_block" class="bare">https://stnolting.github.io/neorv32/ug/#_packaging_the_processor_as_vivado_ip_block</a> +</td> +</tr> +</table> +</div> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +<div class="title">AHB3-Lite Interface Bridge</div> +A simple bridge that converts the processor&#8217;s XBUS into an AHB3-lite-compatible host interface can +be found in in <code>rtl/system_inegration</code> (<code>xbus2ahblite_bridge.vhd</code>). +</td> +</tr> +</table> +</div> +<div class="paragraph"> +<p><strong>Wishbone Bus Protocol</strong></p> +</div> +<div class="paragraph"> +<p>The external bus interface complies to the <strong>pipelined Wishbone b4</strong> protocol. Even though this protocol +was explicitly designed to support pipelined transfers, only a single transfer will be "in fly" at once. +Hence, just two types of bus transactions are generated by the XBUS controller (see images below).</p> +</div> +<div class="imageblock"> +<div class="content"> +<img src="img/xbus_write.png" alt="700"> +</div> +<div class="title">Figure 5. XBUS/Wishbone Write Transaction</div> +</div> +<div class="imageblock"> +<div class="content"> +<img src="img/xbus_read.png" alt="700"> +</div> +<div class="title">Figure 6. XBUS/Wishbone Read Transaction</div> +</div> +<div class="admonitionblock important"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-important" title="Important"></i> +</td> +<td class="content"> +<div class="title">Wishbone "Classic" Protocol</div> +Native support for the "classic" Wishbone protocol has been deprecated. +However, classic mode can still be <em>emulated</em> by connecting the processor&#8217;s <code>xbus_cyc_o</code> directly to the +device&#8217;s / bus system&#8217;s <code>cyc</code> and <code>stb</code> signals (omitting the processor&#8217;s <code>xbus_stb_o</code> signal). +</td> +</tr> +</table> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">Endianness</div> +Just like the processor itself the XBUS interface uses <strong>little-endian</strong> byte order. +</td> +</tr> +</table> +</div> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +<div class="title">Wishbone Specs.</div> +A detailed description of the implemented Wishbone bus protocol and the according interface signals +can be found in the data sheet "Wishbone B4 - WISHBONE System-on-Chip (SoC) Interconnection +Architecture for Portable IP Cores". A copy of this document can be found in the <code>docs</code> folder of this +project. +</td> +</tr> +</table> +</div> +<div class="paragraph"> +<p>An accessed XBUS/Wishbone device does not have to respond immediately to a bus request by sending an <code>ACK</code>. +Instead, there is a <strong>time window</strong> where the device has to acknowledge the transfer. This time window +is configured by the <code>XBUS_TIMEOUT</code> generic and it defines the maximum time (in clock cycles) a bus access can +be pending before it is automatically terminated raising an bus fault exception. If <code>XBUS_TIMEOUT</code> is set to zero, +the timeout is disabled and a bus access can take an arbitrary number of cycles to complete. Note that this is not +recommended as a missing ACK will permanently stall the entire processor!</p> +</div> +<div class="paragraph"> +<p>Furthermore, an accesses XBUS/Wishbone device can signal an error condition at any time by setting the <code>ERR</code> signal +high for one cycle. This will also terminate the current bus transaction before raising a CPU bus fault exception.</p> +</div> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +<div class="title">Register Stage</div> +An optional register stage can be added to the XBUS gateway to break up the critical path easing timing closure. +When <code>XBUS_REGSTAGE_EN</code> is <em>true</em> all outgoing and incoming XBUS signals are registered increasing access latency +by two cycles. Furthermore, all outgoing signals (like the address) will be kept stable if there is no bus access +being initiated. +</td> +</tr> +</table> +</div> +<div class="paragraph"> +<p><strong>Access Tag</strong></p> +</div> +<div class="paragraph"> +<p>The XBUS tag signal <code>xbus_tag_o(0)</code> provides additional information about the current access cycle. +It compatible to the the AXI4 <code>ARPROT</code> and <code>AWPROT</code> signals.</p> +</div> +<div class="ulist"> +<ul> +<li> +<p><code>xbus_tag_o(0)</code> <strong>P</strong>: access is performed from <strong>privileged</strong> mode (machine-mode) when set</p> +</li> +<li> +<p><code>xbus_tag_o(1)</code> <strong>NS</strong>: this bit is hardwired to <code>0</code> indicating a <strong>secure</strong> access</p> +</li> +<li> +<p><code>xbus_tag_o(2)</code> <strong>I</strong>: access is an <strong>instruction</strong> fetch when set; access is a data access when cleared</p> +</li> +</ul> +</div> +<div class="paragraph"> +<p><strong>External Bus Cache (X-CACHE)</strong></p> +</div> +<div class="paragraph"> +<p>The XBUS interface provides an optional internal cache that can be used to buffer processor-external accesses. +The x-cache is enabled via the <code>XBUS_CACHE_EN</code> generic. The total size of the cache is split into the number of +cache lines or cache blocks (<code>XBUS_CACHE_NUM_BLOCKS</code> generic) and the line or block size in bytes +(<code>XBUS_CACHE_BLOCK_SIZE</code> generic).</p> +</div> +<div class="listingblock"> +<div class="title">Listing 4. Simplified X-Cache Architecture</div> +<div class="content"> +<pre class="highlight"><code class="language-asciiart" data-lang="asciiart"> Direct Access +----------+ + /|-------------------------&gt;| Register |------------------------&gt;|\ + | | +----------+ | | +Core ---&gt;| | | |---&gt; XBUS + | | +--------------+ +--------------+ +-------------+ | | + \|---&gt;| Host Arbiter |---&gt;| Cache Memory |&lt;---| Bus Arbiter |---&gt;|/ + +--------------+ +--------------+ +-------------+</code></pre> +</div> +</div> +<div class="paragraph"> +<p>The cache uses a direct-mapped architecture that implements "write-allocate" and "write-back" strategies. +The <strong>write-allocate</strong> strategy will fetch the entire referenced block from main memory when encountering +a cache write-miss. The <strong>write-back</strong> strategy will gather all writes locally inside the cache until the according +cache block is about to be replaced. In this case, the entire modified cache block is written back to main memory.</p> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">Cached/Uncached Accesses</div> +The data cache provides direct accesses (= uncached) to memory in order to access memory-mapped IO. +All accesses that target the address range from <code>0xF0000000</code> to <code>0xFFFFFFFF</code> +will not be cached at all (see section <a href="#_address_space">Address Space</a>). Direct/uncached accesses have <strong>lower</strong> priority than +cache block operations to allow continuous burst transfer and also to maintain logical instruction forward +progress / data coherency. Furthermore, atomic load-reservate and store-conditional instructions (<a href="#_a_isa_extension"><code>A</code> ISA Extension</a>) +will always <strong>bypass</strong> the cache. +</td> +</tr> +</table> +</div> +<div style="page-break-after: always;"></div> +</div> +<div class="sect3"> +<h4 id="_stream_link_interface_slink">2.7.8. Stream Link Interface (SLINK)</h4> +<table class="tableblock frame-ends grid-none stretch"> +<colgroup> +<col style="width: 30%;"> +<col style="width: 30%;"> +<col style="width: 40%;"> +</colgroup> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Hardware source files:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">neorv32_slink.vhd</p></td> +<td class="tableblock halign-left valign-top"></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Software driver files:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">neorv32_slink.c</p></td> +<td class="tableblock halign-left valign-top"></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">neorv32_slink.h</p></td> +<td class="tableblock halign-left valign-top"></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Top entity ports:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>slink_rx_dat_i</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">RX link data (32-bit)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>slink_rx_src_i</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">RX routing information (4-bit)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>slink_rx_val_i</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">RX link data valid (1-bit)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>slink_rx_lst_i</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">RX link last element of stream (1-bit)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>slink_rx_rdy_o</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">RX link ready to receive (1-bit)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>slink_tx_dat_o</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">TX link data (32-bit)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>slink_tx_dst_o</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">TX routing information (4-bit)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>slink_tx_val_o</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">TX link data valid (1-bit)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>slink_tx_lst_o</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">TX link last element of stream (1-bit)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>slink_tx_rdy_i</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">TX link allowed to send (1-bit)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Configuration generics:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>IO_SLINK_EN</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">implement SLINK when <em>true</em></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>IO_SLINK_RX_FIFO</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">RX FIFO depth (1..32k), has to be a power of two, min 1</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>IO_SLINK_TX_FIFO</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">TX FIFO depth (1..32k), has to be a power of two, min 1</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">CPU interrupts:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">fast IRQ channel 14</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">RX SLINK IRQ (see <a href="#_processor_interrupts">Processor Interrupts</a>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">fast IRQ channel 15</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">TX SLINK IRQ (see <a href="#_processor_interrupts">Processor Interrupts</a>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Access restrictions:</p></td> +<td class="tableblock halign-left valign-top" colspan="2"><p class="tableblock">privileged access only, non-32-bit write accesses are ignored</p></td> +</tr> +</tbody> +</table> +<div class="paragraph"> +<p><strong>Overview</strong></p> +</div> +<div class="paragraph"> +<p>The stream link interface provides independent RX and TX channels for sending and receiving +stream data. Each channel features a configurable internal FIFO to buffer stream data +(<code>IO_SLINK_RX_FIFO</code> for the RX FIFO, <code>IO_SLINK_TX_FIFO</code> for the TX FIFO). The SLINK interface provides higher +bandwidth and less latency than the external bus interface making it ideally suited for coupling custom +stream processors or streaming peripherals.</p> +</div> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +<div class="title">Example Program</div> +An example program for the SLINK module is available in <code>sw/example/demo_slink</code>. +</td> +</tr> +</table> +</div> +<div class="paragraph"> +<p><strong>Interface &amp; Protocol</strong></p> +</div> +<div class="paragraph"> +<p>The SLINK interface consists of four signals for each channel:</p> +</div> +<div class="ulist"> +<ul> +<li> +<p><code>dat</code> contains the actual data word</p> +</li> +<li> +<p><code>val</code> marks the current transmission cycle as valid</p> +</li> +<li> +<p><code>lst</code> marks the current transmission cycle as the last element of a stream</p> +</li> +<li> +<p><code>rdy</code> indicates that the receiver is ready to receive</p> +</li> +<li> +<p><code>src</code> and <code>dst</code> provide source/destination routing information (optional)</p> +</li> +</ul> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">AXI4-Stream Compatibility</div> +The interface names (except for <code>src</code> and <code>dst</code>) and the underlying protocol is compatible to the AXI4-Stream protocol standard. +A processor top entity with a AXI4-Stream-compatible interfaces can be found in <code>rtl/system_inegration</code>. +More information regarding this alternate top entity can be found in in the user guide: +<a href="https://stnolting.github.io/neorv32/ug/#_packaging_the_processor_as_vivado_ip_block" class="bare">https://stnolting.github.io/neorv32/ug/#_packaging_the_processor_as_vivado_ip_block</a> +</td> +</tr> +</table> +</div> +<div class="paragraph"> +<p><strong>Theory of Operation</strong></p> +</div> +<div class="paragraph"> +<p>The SLINK provides four interface registers. The control register (<code>CTRL</code>) is used to configure +the module and to check its status. Two individual data registers (<code>DATA</code> and <code>DATA_LAST</code>) +are used to send and receive the link&#8217;s actual data stream.</p> +</div> +<div class="paragraph"> +<p>The <code>DATA</code> register provides direct access to the RX/TX FIFO buffers. Read accesses return data from the RX FIFO. +After reading data from this register the control register&#8217;s <code>SLINK_CTRL_RX_LAST</code> flag can be checked to determine +if the according data word has been marked as "end of stream" via the <code>slink_rx_lst_i</code> signal (this signal is also +buffered by the link&#8217;s FIFO). +Writing to the <code>DATA</code> register will immediately write to the TX link FIFO. +When writing to the <code>TX_DATA_LAST</code> the according data word will also be marked as "end of stream" via the +<code>slink_tx_lst_o</code> signal (this signal is also buffered by the link&#8217;s FIFO).</p> +</div> +<div class="paragraph"> +<p>The configured FIFO sizes can be retrieved by software via the control register&#8217;s <code>SLINK_CTRL_RX_FIFO_*</code> and +<code>SLINK_CTRL_TX_FIFO_*</code> bits.</p> +</div> +<div class="paragraph"> +<p>The SLINK is globally activated by setting the control register&#8217;s enable bit <code>SLINK_CTRL_EN</code>. Clearing this bit will +reset all internal logic and will also clear both FIFOs. The FIFOs can also be cleared manually at any time by +setting the <code>SLINK_CTRL_RX_CLR</code> and/or <code>SLINK_CTRL_TX_CLR</code> bits (these bits will auto-clear).</p> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">FIFO Overflow</div> +Writing to the TX channel&#8217;s FIFO while it is <em>full</em> will have no effect. Reading from the RX channel&#8217;s FIFO while it +is <em>empty</em> will also have no effect and will return the last received data word. There is no overflow indicator +implemented yet. +</td> +</tr> +</table> +</div> +<div class="paragraph"> +<p>The current status of the RX and TX FIFOs can be determined via the control register&#8217;s <code>SLINK_CTRL_RX_*</code> and +<code>SLINK_CTRL_TX_*</code> flags.</p> +</div> +<div class="paragraph"> +<p><strong>Stream Routing Information</strong></p> +</div> +<div class="paragraph"> +<p>Both stream link interface provide an optional port for routing information: <code>slink_tx_dst_o</code> (AXI stream&#8217;s <code>TDEST</code>) +can be used to set a destination address when using a switch/interconnect to access several stream sinks. <code>slink_rx_src_i</code> +(AXI stream&#8217;s <code>TID</code>) can be used to determine the source when several sources can send data via a switch/interconnect. +The routing information can be set/read via the <code>ROUTE</code> interface registers. Note that all routing information is also +fully buffered by the internal RX/TX FIFOs. RX routing information has to be read <strong>after</strong> reading the according RX +data. Vice versa, TX routing information has to be set <strong>before</strong> writing the according TX data.</p> +</div> +<div class="paragraph"> +<p><strong>Interrupts</strong></p> +</div> +<div class="paragraph"> +<p>The SLINK module provides two independent interrupt channels: one for RX events and one for TX events. +The interrupt conditions are based on the according link&#8217;s FIFO status flags and are configured via the control +register&#8217;s <code>SLINK_CTRL_IRQ_*</code> flags. The according interrupt will fire when the module is enabled (<code>SLINK_CTRL_EN</code>) +and the selected interrupt conditions are met. Note that all enabled interrupt conditions are logically OR-ed per +channel. If any enable interrupt conditions becomes active the interrupt will become pending until the +interrupt-causing condition is resolved (e.g. by reading from the RX FIFO).</p> +</div> +<div class="paragraph"> +<p><strong>Register Map</strong></p> +</div> +<table class="tableblock frame-all grid-all stretch"> +<caption class="title">Table 9. SLINK register map (<code>struct NEORV32_SLINK</code>)</caption> +<colgroup> +<col style="width: 15.3846%;"> +<col style="width: 15.3846%;"> +<col style="width: 30.7692%;"> +<col style="width: 7.6923%;"> +<col style="width: 30.7693%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-left valign-top">Address</th> +<th class="tableblock halign-left valign-top">Name [C]</th> +<th class="tableblock halign-left valign-top">Bit(s)</th> +<th class="tableblock halign-center valign-top">R/W</th> +<th class="tableblock halign-left valign-top">Function</th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-left valign-top" rowspan="22"><p class="tableblock"><code>0xffffec00</code></p></td> +<td class="tableblock halign-left valign-top" rowspan="22"><p class="tableblock"><code>NEORV32_SLINK.CTRL</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0</code> <code>SLINK_CTRL_EN</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">SLINK global enable</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>1</code> <code>SLINK_CTRL_RX_CLR</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">-/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Clear RX FIFO when set (bit auto-clears)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>2</code> <code>SLINK_CTRL_TX_CLR</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">-/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Clear TX FIFO when set (bit auto-clears)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>3</code> <em>reserved</em></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><em>reserved</em>, read as zero</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>4</code> <code>SLINK_CTRL_RX_LAST</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Last word read from <code>RX_DATA</code> is marked as "end of stream"</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>7:5</code> <em>reserved</em></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><em>reserved</em>, read as zero</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>8</code> <code>SLINK_CTRL_RX_EMPTY</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">RX FIFO empty</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>9</code> <code>SLINK_CTRL_RX_HALF</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">RX FIFO at least half full</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>10</code> <code>SLINK_CTRL_RX_FULL</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">RX FIFO full</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>11</code> <code>SLINK_CTRL_TX_EMPTY</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">TX FIFO empty</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>12</code> <code>SLINK_CTRL_TX_HALF</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">TX FIFO at least half full</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>13</code> <code>SLINK_CTRL_TX_FULL</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">TX FIFO full</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>15:14</code> <em>reserved</em></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><em>reserved</em>, read as zero</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>16</code> <code>SLINK_CTRL_IRQ_RX_NEMPTY</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">RX interrupt if RX FIFO not empty</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>17</code> <code>SLINK_CTRL_IRQ_RX_HALF</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">RX interrupt if RX FIFO at least half full</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>18</code> <code>SLINK_CTRL_IRQ_RX_FULL</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">RX interrupt if RX FIFO full</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>19</code> <code>SLINK_CTRL_IRQ_TX_EMPTY</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">TX interrupt if TX FIFO empty</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>20</code> <code>SLINK_CTRL_IRQ_TX_NHALF</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">TX interrupt if TX FIFO not at least half full</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>21</code> <code>SLINK_CTRL_IRQ_TX_NFULL</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">TX interrupt if TX FIFO not full</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>23:22</code> <em>reserved</em></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><em>reserved</em>, read as zero</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>27:24</code> <code>SLINK_CTRL_RX_FIFO_MSB : SLINK_CTRL_RX_FIFO_LSB</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">log2(RX FIFO size)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>31:28</code> <code>SLINK_CTRL_TX_FIFO_MSB : SLINK_CTRL_TX_FIFO_LSB</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">log2(TX FIFO size)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top" rowspan="3"><p class="tableblock"><code>0xffffec04</code></p></td> +<td class="tableblock halign-left valign-top" rowspan="3"><p class="tableblock"><code>NEORV32_SLINK.ROUTE</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>3:0</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">TX destination routing information (<code>slink_tx_dst_o</code>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>7:4</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">RX source routing information (<code>slink_rx_src_i</code>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>31:8</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">-/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><em>reserved</em></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0xffffec08</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>NEORV32_SLINK.DATA</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>31:0</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Write data to TX FIFO; read data from RX FIFO</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0xffffec0c</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>NEORV32_SLINK.DATA_LAST</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>31:0</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Write data to TX FIFO (and also set "last" signal); read data from RX FIFO</p></td> +</tr> +</tbody> +</table> +<div style="page-break-after: always;"></div> +</div> +<div class="sect3"> +<h4 id="_general_purpose_input_and_output_port_gpio">2.7.9. General Purpose Input and Output Port (GPIO)</h4> +<table class="tableblock frame-ends grid-none stretch"> +<colgroup> +<col style="width: 30%;"> +<col style="width: 30%;"> +<col style="width: 40%;"> +</colgroup> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Hardware source files:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">neorv32_gpio.vhd</p></td> +<td class="tableblock halign-left valign-top"></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Software driver files:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">neorv32_gpio.c</p></td> +<td class="tableblock halign-left valign-top"></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">neorv32_gpio.h</p></td> +<td class="tableblock halign-left valign-top"></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Top entity ports:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>gpio_o</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">64-bit parallel output port</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>gpio_i</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">64-bit parallel input port</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Configuration generics:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>IO_GPIO_NUM</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">number of input/output pairs to implement (0..64)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">CPU interrupts:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">none</p></td> +<td class="tableblock halign-left valign-top"></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Access restrictions:</p></td> +<td class="tableblock halign-left valign-top" colspan="2"><p class="tableblock">privileged access only, non-32-bit write accesses are ignored</p></td> +</tr> +</tbody> +</table> +<div class="paragraph"> +<p><strong>Overview</strong></p> +</div> +<div class="paragraph"> +<p>The general purpose parallel IO unit provides a simple parallel input and output port. These ports can be used +chip-externally (for example to drive status LEDs, connect buttons, etc.) or chip-internally to provide control +signals for other IP modules.</p> +</div> +<div class="paragraph"> +<p>The actual number of input/output pairs is defined by the <code>IO_GPIO_NUM</code> generic. When set to zero, the GPIO module +is excluded from synthesis and the output port <code>gpio_o</code> is tied to all-zero. If <code>IO_GPIO_NUM</code> is less than the +maximum value of 64, only the LSB-aligned bits in <code>gpio_o</code> and <code>gpio_i</code> are actually connected while the remaining +bits are tied to zero or are left unconnected, respectively.</p> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">Access Atomicity</div> +The GPIO modules uses two memory-mapped registers (each 32-bit) each for accessing the input and +output signals. Since the CPU can only process 32-bit "at once" updating the entire output cannot +be performed within a single clock cycle. +</td> +</tr> +</table> +</div> +<div class="paragraph"> +<p><strong>Register Map</strong></p> +</div> +<table class="tableblock frame-all grid-rows stretch"> +<caption class="title">Table 10. GPIO unit register map (<code>struct NEORV32_GPIO</code>)</caption> +<colgroup> +<col style="width: 16.6666%;"> +<col style="width: 16.6666%;"> +<col style="width: 8.3333%;"> +<col style="width: 8.3333%;"> +<col style="width: 50.0002%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-left valign-top">Address</th> +<th class="tableblock halign-left valign-top">Name [C]</th> +<th class="tableblock halign-center valign-top">Bit(s)</th> +<th class="tableblock halign-center valign-top">R/W</th> +<th class="tableblock halign-left valign-top">Function</th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0xfffffc00</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>INPUT[0]</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">31:0</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">parallel input port pins 31:0</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0xfffffc04</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>INPUT[1]</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">31:0</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">parallel input port pins 63:32</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0xfffffc08</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>OUTPUT[0]</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">31:0</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">parallel output port pins 31:0</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0xfffffc0c</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>OUTPUT[1]</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">31:0</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">parallel output port pins 63:32</p></td> +</tr> +</tbody> +</table> +<div style="page-break-after: always;"></div> +</div> +<div class="sect3"> +<h4 id="_cyclic_redundancy_check_crc">2.7.10. Cyclic Redundancy Check (CRC)</h4> +<table class="tableblock frame-ends grid-none stretch"> +<colgroup> +<col style="width: 30%;"> +<col style="width: 30%;"> +<col style="width: 40%;"> +</colgroup> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Hardware source files:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">neorv32_crc.vhd</p></td> +<td class="tableblock halign-left valign-top"></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Software driver files:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">neorv32_crc.c</p></td> +<td class="tableblock halign-left valign-top"></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">neorv32_crc.h</p></td> +<td class="tableblock halign-left valign-top"></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Top entity ports:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">none</p></td> +<td class="tableblock halign-left valign-top"></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Configuration generics:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>IO_CRC_EN</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">implement CRC module when <code>true</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">CPU interrupts:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">none</p></td> +<td class="tableblock halign-left valign-top"></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Access restrictions:</p></td> +<td class="tableblock halign-left valign-top" colspan="2"><p class="tableblock">privileged access only, non-32-bit write accesses are ignored</p></td> +</tr> +</tbody> +</table> +<div class="paragraph"> +<p><strong>Overview</strong></p> +</div> +<div class="paragraph"> +<p>The cyclic redundancy check unit provides a programmable checksum computation module. The unit operates on +single bytes and can either compute CRC8, CRC16 or CRC32 checksums based on an arbitrary polynomial and +start value.</p> +</div> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +<div class="title">CRC Demo Program</div> +A CRC example program (also using CPU-independent DMA transfers) can be found in <code>sw/example/crc_dma</code>. +</td> +</tr> +</table> +</div> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +<div class="title">CPU-Independent Operation</div> +The CRC unit can compute a checksum for an arbitrary memory array without any CPU overhead +by using the processor&#8217;s <a href="#_direct_memory_access_controller_dma">Direct Memory Access Controller (DMA)</a>. +</td> +</tr> +</table> +</div> +<div class="paragraph"> +<p><strong>Theory of Operation</strong></p> +</div> +<div class="paragraph"> +<p>The module provides four interface registers:</p> +</div> +<div class="ulist"> +<ul> +<li> +<p><code>MODE</code>: selects either CRC8-, CRC16- or CRC32-mode</p> +</li> +<li> +<p><code>POLY</code>: programmable polynomial</p> +</li> +<li> +<p><code>DATA</code>: data input register (single bytes only)</p> +</li> +<li> +<p><code>SREG</code>: the CRC shift register; this register is used to define the start value and to obtain +the final processing result</p> +</li> +</ul> +</div> +<div class="paragraph"> +<p>The <code>MODE</code>, <code>POLY</code> and <code>SREG</code> registers need to be programmed before the actual processing can be started. +Writing a byte to <code>DATA</code> will update the current checksum in <code>SREG</code>.</p> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">Access Latency</div> +Write access to the CRC module have an increased latency of 8 clock cycles. This additional latency +ensures that the internal bit-serial processing of the current data byte has also been completed when the +transfer is completed. +</td> +</tr> +</table> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">Data Size</div> +For CRC8-mode only bits <code>7:0</code> of <code>POLY</code> and <code>SREG</code> are relevant; for CRC16-mode only bits <code>15:0</code> are used +and for CRC32-mode the entire 32-bit of <code>POLY</code> and <code>SREG</code> are used. +</td> +</tr> +</table> +</div> +<div class="paragraph"> +<p><strong>Register Map</strong></p> +</div> +<table class="tableblock frame-all grid-all stretch"> +<caption class="title">Table 11. CRC Register Map (<code>struct NEORV32_CRC</code>)</caption> +<colgroup> +<col style="width: 13.3333%;"> +<col style="width: 6.6666%;"> +<col style="width: 26.6666%;"> +<col style="width: 6.6666%;"> +<col style="width: 46.6669%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-left valign-top">Address</th> +<th class="tableblock halign-left valign-top">Name [C]</th> +<th class="tableblock halign-left valign-top">Bit(s), Name [C]</th> +<th class="tableblock halign-center valign-top">R/W</th> +<th class="tableblock halign-left valign-top">Function</th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-left valign-top" rowspan="2"><p class="tableblock"><code>0xffffee00</code></p></td> +<td class="tableblock halign-left valign-top" rowspan="2"><p class="tableblock"><code>CTRL</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>1:0</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">CRC mode select (<code>00</code> CRC8, <code>01</code>: CRC16, <code>10</code>: CRC32)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>31:2</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><em>reserved</em>, read as zero</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0xffffee04</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>POLY</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>31:0</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">CRC polynomial</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top" rowspan="2"><p class="tableblock"><code>0xffffee08</code></p></td> +<td class="tableblock halign-left valign-top" rowspan="2"><p class="tableblock"><code>DATA</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>7:0</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">data input (single byte)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>31:8</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><em>reserved</em>, read as zero, writes are ignored</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0xffffee0c</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>SREG</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>32:0</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">current CRC shift register value (set start value on write)</p></td> +</tr> +</tbody> +</table> +<div style="page-break-after: always;"></div> +</div> +<div class="sect3"> +<h4 id="_watchdog_timer_wdt">2.7.11. Watchdog Timer (WDT)</h4> +<table class="tableblock frame-ends grid-none stretch"> +<colgroup> +<col style="width: 30%;"> +<col style="width: 30%;"> +<col style="width: 40%;"> +</colgroup> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Hardware source files:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">neorv32_wdt.vhd</p></td> +<td class="tableblock halign-left valign-top"></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Software driver files:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">neorv32_wdt.c</p></td> +<td class="tableblock halign-left valign-top"></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">neorv32_wdt.h</p></td> +<td class="tableblock halign-left valign-top"></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Top entity ports:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">none</p></td> +<td class="tableblock halign-left valign-top"></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Configuration generics:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>IO_WDT_EN</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">implement watchdog when <code>true</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">CPU interrupts:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">none</p></td> +<td class="tableblock halign-left valign-top"></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Access restrictions:</p></td> +<td class="tableblock halign-left valign-top" colspan="2"><p class="tableblock">privileged access only, non-32-bit write accesses are ignored</p></td> +</tr> +</tbody> +</table> +<div class="paragraph"> +<p><strong>Overview</strong></p> +</div> +<div class="paragraph"> +<p>The watchdog (WDT) provides a last resort for safety-critical applications. When a pre-programmed timeout value is reached +a system-wide hardware reset is generated. The internal counter has to be reset explicitly by the application +program every now and then to prevent a timeout.</p> +</div> +<div class="paragraph"> +<p><strong>Theory of Operation</strong></p> +</div> +<div class="paragraph"> +<p>The watchdog is enabled by setting the control register&#8217;s <code>WDT_CTRL_EN</code> bit. When this bit is cleared, the internal +timeout counter is reset to zero and no system reset can be triggered by this module.</p> +</div> +<div class="paragraph"> +<p>The internal 32-bit timeout counter is clocked at 1/4096th of the processor&#8217;s main clock (f<sub>WDT</sub>[Hz] = f<sub>main</sub>[Hz] / 4096). +Whenever this counter reaches the programmed timeout value (<code>WDT_CTRL_TIMEOUT</code> bits in the control register) a +hardware reset is triggered.</p> +</div> +<div class="paragraph"> +<p>The watchdog&#8217;s timeout counter is reset ("feeding the watchdog") by writing the reset <strong>PASSWORD</strong> to the <code>RESET</code> register. +The password is hardwired to hexadecimal <code>0x709D1AB3</code>.</p> +</div> +<div class="admonitionblock important"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-important" title="Important"></i> +</td> +<td class="content"> +<div class="title">Watchdog Operation during Debugging</div> +By default, the watchdog stops operation when the CPU enters debug mode and will resume normal operation after +the CPU has left debug mode again. This will prevent an unintended watchdog timeout during a debug session. However, +the watchdog can also be configured to keep operating even when the CPU is in debug mode by setting the control +register&#8217;s <code>WDT_CTRL_DBEN</code> bit. +</td> +</tr> +</table> +</div> +<div class="admonitionblock important"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-important" title="Important"></i> +</td> +<td class="content"> +<div class="title">Watchdog Operation during CPU Sleep</div> +By default, the watchdog stops operating when the CPU enters sleep mode. However, the watchdog can also be configured +to keep operating even when the CPU is in sleep mode by setting the control register&#8217;s <code>WDT_CTRL_SEN</code> bit. +</td> +</tr> +</table> +</div> +<div class="paragraph"> +<p><strong>Configuration Lock</strong></p> +</div> +<div class="paragraph"> +<p>The watchdog control register can be <em>locked</em> to protect the current configuration from being modified. The lock is +activated by setting the <code>WDT_CTRL_LOCK</code> bit. In the locked state any write access to the control register is entirely +ignored (see table below, "writable if locked"). However, read accesses to the control register as well as watchdog resets +are further possible.</p> +</div> +<div class="paragraph"> +<p>The lock bit can only be set if the WDT is already enabled (<code>WDT_CTRL_EN</code> is set). Furthermore, the lock bit can +only be cleared again by a system-wide hardware reset.</p> +</div> +<div class="paragraph"> +<p><strong>Strict Mode</strong></p> +</div> +<div class="paragraph"> +<p>The <em>strict operation mode</em> provides additional safety functions. If the strict mode is enabled by the <code>WDT_CTRL_STRICT</code> +control register bit an <strong>immediate hardware</strong> reset if enforced if</p> +</div> +<div class="ulist"> +<ul> +<li> +<p>the <code>RESET</code> register is written with an incorrect password or</p> +</li> +<li> +<p>the <code>CTRL</code> register is written and the <code>WDT_CTRL_LOCK</code> bit is set.</p> +</li> +</ul> +</div> +<div class="paragraph"> +<p><strong>Cause of last Hardware Reset</strong></p> +</div> +<div class="paragraph"> +<p>The cause of the last system hardware reset can be determined via the <code>WDT_CTRL_RCAUSE_*</code> bits:</p> +</div> +<div class="ulist"> +<ul> +<li> +<p><code>0b00</code>: Reset caused by external reset signal/pin</p> +</li> +<li> +<p><code>0b01</code>: Reset caused by on-chip debugger</p> +</li> +<li> +<p><code>0b10</code>: Reset caused by watchdog</p> +</li> +</ul> +</div> +<div class="paragraph"> +<p><strong>Register Map</strong></p> +</div> +<table class="tableblock frame-all grid-all stretch"> +<caption class="title">Table 12. WDT register map (<code>struct NEORV32_WDT</code>)</caption> +<colgroup> +<col style="width: 13.3333%;"> +<col style="width: 6.6666%;"> +<col style="width: 26.6666%;"> +<col style="width: 6.6666%;"> +<col style="width: 6.6666%;"> +<col style="width: 13.3333%;"> +<col style="width: 26.667%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-left valign-top">Address</th> +<th class="tableblock halign-left valign-top">Name [C]</th> +<th class="tableblock halign-left valign-top">Bit(s), Name [C]</th> +<th class="tableblock halign-center valign-top">R/W</th> +<th class="tableblock halign-center valign-top">Reset value</th> +<th class="tableblock halign-center valign-top">Writable if locked</th> +<th class="tableblock halign-left valign-top">Function</th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-left valign-top" rowspan="8"><p class="tableblock"><code>0xfffffb00</code></p></td> +<td class="tableblock halign-left valign-top" rowspan="8"><p class="tableblock"><code>CTRL</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0</code> <code>WDT_CTRL_EN</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>0</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">no</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">watchdog enable</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>1</code> <code>WDT_CTRL_LOCK</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>0</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">no</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">lock configuration when set, clears only on system reset, can only be set if enable bit is set already</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>2</code> <code>WDT_CTRL_DBEN</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>0</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">no</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">set to allow WDT to continue operation even when CPU is in debug mode</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>3</code> <code>WDT_CTRL_SEN</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>0</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">no</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">set to allow WDT to continue operation even when CPU is in sleep mode</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>4</code> <code>WDT_CTRL_STRICT</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>0</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">no</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">set to enable strict mode (force hardware reset if reset password is incorrect or if write access to locked CTRL register)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>6:5</code> <code>WDT_CTRL_RCAUSE_HI : WDT_CTRL_RCAUSE_LO</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>0</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">cause of last system reset; 0=external reset, 1=ocd-reset, 2=watchdog reset</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>7</code> -</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">-</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><em>reserved</em>, reads as zero</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>31:8</code> <code>WDT_CTRL_TIMEOUT_MSB : WDT_CTRL_TIMEOUT_LSB</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">0</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">no</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">24-bit watchdog timeout value</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0xfffffb04</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>RESET</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>31:0</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">-/w</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">-</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">yes</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Write <em>PASSWORD</em> to reset WDT timeout counter</p></td> +</tr> +</tbody> +</table> +<div style="page-break-after: always;"></div> +</div> +<div class="sect3"> +<h4 id="_machine_system_timer_mtime">2.7.12. Machine System Timer (MTIME)</h4> +<table class="tableblock frame-ends grid-none stretch"> +<colgroup> +<col style="width: 30%;"> +<col style="width: 30%;"> +<col style="width: 40%;"> +</colgroup> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Hardware source files:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">neorv32_mtime.vhd</p></td> +<td class="tableblock halign-left valign-top"></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Software driver files:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">neorv32_mtime.c</p></td> +<td class="tableblock halign-left valign-top"></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">neorv32_mtime.h</p></td> +<td class="tableblock halign-left valign-top"></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Top entity ports:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>mtime_irq_i</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">RISC-V machine timer IRQ if internal one is <strong>not</strong> implemented</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>mtime_time_o</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Current system time (<code>TIME</code> register)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Configuration generics:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>IO_MTIME_EN</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">implement machine timer when <code>true</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">CPU interrupts:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>MTI</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">machine timer interrupt (see <a href="#_processor_interrupts">Processor Interrupts</a>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Access restrictions:</p></td> +<td class="tableblock halign-left valign-top" colspan="2"><p class="tableblock">privileged access only, non-32-bit write accesses are ignored</p></td> +</tr> +</tbody> +</table> +<div class="paragraph"> +<p><strong>Overview</strong></p> +</div> +<div class="paragraph"> +<p>The MTIME module implements a memory-mapped machine system timer that is compatible to the RISC-V +privileged specifications. The 64-bit system time is accessed via individual <code>TIME_LO</code> and +<code>TIME_HI</code> registers. A 64-bit time compare register, which is accessible via individual <code>TIMECMP_LO</code> +and <code>TIMECMP_HI</code> registers, can be used to configure the CPU&#8217;s machine timer interrupt (<code>MTI</code>)).</p> +</div> +<div class="paragraph"> +<p>The interrupt is triggered whenever <code>TIME</code> (high &amp; low part) is greater than or equal to <code>TIMECMP</code> (high &amp; low part). +The interrupt remains active (=pending) until <code>TIME</code> becomes less than <code>TIMECMP</code> again (either by modifying +<code>TIME</code> or <code>TIMECMP</code>). The current system time is available for other SoC modules via the top&#8217;s <code>mtime_time_o</code> signal.</p> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">Hardware Reset</div> +After a hardware reset the <code>TIME</code> and <code>TIMECMP</code> register are reset to all-zero. +</td> +</tr> +</table> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">External MTIME Interrupt</div> +If the internal MTIME module is disabled (<code>IO_MTIME_EN</code> = <code>false</code>) the machine timer interrupt becomes available +as external signal. The <code>mtime_irq_i</code> signal is level-triggered and high-active. Once set the signal has to stay +high until the interrupt request is explicitly acknowledged (e.g. writing to a user-defined memory-mapped register). +</td> +</tr> +</table> +</div> +<div class="paragraph"> +<p><strong>Register Map</strong></p> +</div> +<table class="tableblock frame-all grid-all stretch"> +<caption class="title">Table 13. MTIME register map (<code>struct NEORV32_MTIME</code>)</caption> +<colgroup> +<col style="width: 21.4285%;"> +<col style="width: 21.4285%;"> +<col style="width: 7.1428%;"> +<col style="width: 7.1428%;"> +<col style="width: 42.8574%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-left valign-top">Address</th> +<th class="tableblock halign-left valign-top">Name [C]</th> +<th class="tableblock halign-center valign-top">Bits</th> +<th class="tableblock halign-center valign-top">R/W</th> +<th class="tableblock halign-left valign-top">Function</th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0xfffff400</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>TIME_LO</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">31:0</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">system time, low word</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0xfffff404</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>TIME_HI</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">31:0</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">system time, high word</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0xfffff408</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>TIMECMP_LO</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">31:0</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">time compare, low word</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0xfffff40c</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>TIMECMP_HI</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">31:0</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">time compare, high word</p></td> +</tr> +</tbody> +</table> +<div style="page-break-after: always;"></div> +</div> +<div class="sect3"> +<h4 id="_primary_universal_asynchronous_receiver_and_transmitter_uart0">2.7.13. Primary Universal Asynchronous Receiver and Transmitter (UART0)</h4> +<table class="tableblock frame-ends grid-none stretch"> +<colgroup> +<col style="width: 30%;"> +<col style="width: 30%;"> +<col style="width: 40%;"> +</colgroup> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Hardware source files:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">neorv32_uart.vhd</p></td> +<td class="tableblock halign-left valign-top"></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Software driver files:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">neorv32_uart.c</p></td> +<td class="tableblock halign-left valign-top"></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">neorv32_uart.h</p></td> +<td class="tableblock halign-left valign-top"></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Top entity ports:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>uart0_txd_o</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">serial transmitter output</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>uart0_rxd_i</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">serial receiver input</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>uart0_rts_o</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">flow control: RX ready to receive, low-active</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>uart0_cts_i</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">flow control: RX ready to receive, low-active</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Configuration generics:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>IO_UART0_EN</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">implement UART0 when <code>true</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>UART0_RX_FIFO</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">RX FIFO depth (power of 2, min 1)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>UART0_TX_FIFO</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">TX FIFO depth (power of 2, min 1)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">CPU interrupts:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">fast IRQ channel 2</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">RX interrupt</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">fast IRQ channel 3</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">TX interrupt (see <a href="#_processor_interrupts">Processor Interrupts</a>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Access restrictions:</p></td> +<td class="tableblock halign-left valign-top" colspan="2"><p class="tableblock">privileged access only, non-32-bit write accesses are ignored</p></td> +</tr> +</tbody> +</table> +<div class="paragraph"> +<p><strong>Overview</strong></p> +</div> +<div class="paragraph"> +<p>The NEORV32 UART provides a standard serial interface with independent transmitter and receiver channels, each +equipped with a configurable FIFO. The transmission frame is fixed to <strong>8N1</strong>: 8 data bits, no parity bit, 1 stop +bit. The actual transmission rate (Baud rate) is programmable via software. The module features two memory-mapped +registers: <code>CTRL</code> and <code>DATA</code>. These are used for configuration, status check and data transfer.</p> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">Standard Console</div> +All default example programs and software libraries of the NEORV32 software framework (including the bootloader +and the runtime environment) use the primary UART (<em>UART0</em>) as default user console interface. Furthermore, UART0 +is used to implement the "standard consoles" (<code>STDIN</code>, <code>STDOUT</code> and <code>STDERR</code>). +</td> +</tr> +</table> +</div> +<div class="paragraph"> +<p><strong>RX and TX FIFOs</strong></p> +</div> +<div class="paragraph"> +<p>The UART provides individual data FIFOs for RX and TX to allow data transmission without CPU intervention. +The sizes of these FIFOs can be configured via the according configuration generics (<code>UART0_RX_FIFO</code> and <code>UART0_TX_FIFO</code>). +Both FIFOs a re automatically cleared when disabling the module via the <code>UART_CTRL_EN</code> flag. However, the FIFOs can +also be cleared individually by setting the <code>UART_CTRL_RX_CLR</code> / <code>UART_CTRL_TX_CLR</code> flags.</p> +</div> +<div class="paragraph"> +<p><strong>Theory of Operation</strong></p> +</div> +<div class="paragraph"> +<p>The module is enabled by setting the <code>UART_CTRL_EN</code> bit in the UART0 control register <code>CTRL</code>. The Baud rate +is configured via a 10-bit <code>UART_CTRL_BAUDx</code> baud divisor (<code>baud_div</code>) and a 3-bit <code>UART_CTRL_PRSCx</code> +clock prescaler (<code>clock_prescaler</code>).</p> +</div> +<table class="tableblock frame-all grid-rows stretch"> +<caption class="title">Table 14. UART0 Clock Configuration</caption> +<colgroup> +<col style="width: 33.3333%;"> +<col style="width: 8.3333%;"> +<col style="width: 8.3333%;"> +<col style="width: 8.3333%;"> +<col style="width: 8.3333%;"> +<col style="width: 8.3333%;"> +<col style="width: 8.3333%;"> +<col style="width: 8.3333%;"> +<col style="width: 8.3336%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-left valign-top"><strong><code>UART_CTRL_PRSCx</code></strong></th> +<th class="tableblock halign-center valign-top"><code>0b000</code></th> +<th class="tableblock halign-center valign-top"><code>0b001</code></th> +<th class="tableblock halign-center valign-top"><code>0b010</code></th> +<th class="tableblock halign-center valign-top"><code>0b011</code></th> +<th class="tableblock halign-center valign-top"><code>0b100</code></th> +<th class="tableblock halign-center valign-top"><code>0b101</code></th> +<th class="tableblock halign-center valign-top"><code>0b110</code></th> +<th class="tableblock halign-center valign-top"><code>0b111</code></th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Resulting <code>clock_prescaler</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">2</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">4</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">8</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">64</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">128</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">1024</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">2048</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">4096</p></td> +</tr> +</tbody> +</table> +<div class="paragraph"> +<p><em><strong>Baud rate</strong></em> = (<em>f<sub>main</sub>[Hz]</em> / <code>clock_prescaler</code>) / (<code>baud_div</code> + 1)</p> +</div> +<div class="paragraph"> +<p>The control register&#8217;s <code>UART_CTRL_RX_*</code> and <code>UART_CTRL_TX_*</code> flags provide information about the RX and TX FIFO fill level. +Disabling the module via the <code>UART_CTRL_EN</code> bit will also clear these FIFOs.</p> +</div> +<div class="paragraph"> +<p>A new TX transmission is started by writing to the <code>DATA</code> register. The +transfer is completed when the <code>UART_CTRL_TX_BUSY</code> control register flag returns to zero. RX data is available when +the <code>UART_CTRL_RX_NEMPTY</code> flag becomes set. The <code>UART_CTRL_RX_OVER</code> will be set if the RX FIFO overflows. This flag +is cleared only by disabling the module via <code>UART_CTRL_EN</code>.</p> +</div> +<div class="paragraph"> +<p><strong>UART Interrupts</strong></p> +</div> +<div class="paragraph"> +<p>The UART module provides independent interrupt channels for RX and TX. These interrupts are triggered by certain RX and TX +FIFO levels. The actual configuration is programmed independently for the RX and TX interrupt channel via the control register&#8217;s +<code>UART_CTRL_IRQ_RX_*</code> and <code>UART_CTRL_IRQ_TX_*</code> bits:</p> +</div> +<div class="olist arabic"> +<ol class="arabic"> +<li> +<p><strong>RX IRQ</strong> The RX interrupt can be triggered by three different RX FIFO level states: If <code>UART_CTRL_IRQ_RX_NEMPTY</code> is set the +interrupt fires if the RX FIFO is <em>not</em> empty (e.g. when incoming data is available). If <code>UART_CTRL_IRQ_RX_HALF</code> is set the RX IRQ +fires if the RX FIFO is at least half-full. If <code>UART_CTRL_IRQ_RX_FULL</code> the interrupt fires if the RX FIFO is full. Note that all +these programmable conditions are logically OR-ed (interrupt fires if any enabled conditions is true).</p> +</li> +<li> +<p><strong>TX IRQ</strong> The TX interrupt can be triggered by two different TX FIFO level states: If <code>UART_CTRL_IRQ_TX_EMPTY</code> is set the +interrupt fires if the TX FIFO is empty. If <code>UART_CTRL_IRQ_TX_NHALF</code> is set the interrupt fires if the TX FIFO is <em>not</em> at least +half full. Note that all these programmable conditions are logically OR-ed (interrupt fires if any enabled conditions is true).</p> +</li> +</ol> +</div> +<div class="paragraph"> +<p>Once an UART interrupt has fired it remains pending until the actual cause of the interrupt is resolved; for +example if just the <code>UART_CTRL_IRQ_RX_NEMPTY</code> bit is set, the RX interrupt will keep firing until the RX FIFO is empty again.</p> +</div> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +<div class="title">RX/TX FIFO Size</div> +Software can retrieve the configured sizes of the RX and TX FIFO via the according <code>UART_DATA_RX_FIFO_SIZE</code> and +<code>UART_DATA_TX_FIFO_SIZE</code> bits from the <code>DATA</code> register. +</td> +</tr> +</table> +</div> +<div class="paragraph"> +<p><strong>RTS/CTS Hardware Flow Control</strong></p> +</div> +<div class="paragraph"> +<p>The NEORV32 UART supports optional hardware flow control using the standard CTS <code>uart0_cts_i</code> ("clear to send") and RTS +<code>uart0_rts_o</code> ("ready to send" / "ready to receive (RTR)") signals. Both signals are low-active. +Hardware flow control is enabled by setting the <code>UART_CTRL_HWFC_EN</code> bit in the modules control register <code>CTRL</code>.</p> +</div> +<div class="paragraph"> +<p>When hardware flow control is enabled:</p> +</div> +<div class="olist arabic"> +<ol class="arabic"> +<li> +<p>The UART&#8217;s transmitter will not start a new transmission until the <code>uart0_cts_i</code> signal goes low. +During this time, the UART busy flag <code>UART_CTRL_TX_BUSY</code> remains set.</p> +</li> +<li> +<p>The UART will set <code>uart0_rts_o</code> signal low if the RX FIFO is <strong>less than half full</strong> (to have a wide safety margin). +As long as this signal is low, the connected device can send new data. <code>uart0_rts_o</code> is always low if the hardware flow-control +is disabled. Disabling the UART (setting <code>UART_CTRL_EN</code> low) while having hardware flow-control enabled, will set <code>uart0_rts_o</code> +high to signal that the UARt is not capable of receiving new data.</p> +</li> +</ol> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +Note that RTS and CTS signaling can only be activated together. If the RTS handshake is not required the signal can be left +unconnected. If the CTS handshake is not required it has to be tied to zero. +</td> +</tr> +</table> +</div> +<div class="paragraph"> +<p><strong>Simulation Mode</strong></p> +</div> +<div class="paragraph"> +<p>The UART provides a <em>simulation-only</em> mode to dump console data as well as raw data directly to a file. When the simulation +mode is enabled (by setting the <code>UART_CTRL_SIM_MODE</code> bit) there will be <strong>no</strong> physical transaction on the <code>uart0_txd_o</code> signal. +Instead, all data written to the <code>DATA</code> register is immediately dumped to a file. Data written to <code>DATA[7:0]</code> will be dumped as +ASCII chars to a file named <code>neorv32.uart0.sim_mode.text.out</code>. Additionally, the ASCII data is printed to the simulator console.</p> +</div> +<div class="paragraph"> +<p>Both file are created in the simulation&#8217;s home folder.</p> +</div> +<div class="paragraph"> +<p><strong>Register Map</strong></p> +</div> +<table class="tableblock frame-all grid-all stretch"> +<caption class="title">Table 15. UART0 register map (<code>struct NEORV32_UART0</code>)</caption> +<colgroup> +<col style="width: 22.2222%;"> +<col style="width: 11.1111%;"> +<col style="width: 27.7777%;"> +<col style="width: 11.1111%;"> +<col style="width: 27.7779%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-left valign-top">Address</th> +<th class="tableblock halign-left valign-top">Name [C]</th> +<th class="tableblock halign-left valign-top">Bit(s), Name [C]</th> +<th class="tableblock halign-center valign-top">R/W</th> +<th class="tableblock halign-left valign-top">Function</th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-left valign-top" rowspan="20"><p class="tableblock"><code>0xfffff500</code></p></td> +<td class="tableblock halign-left valign-top" rowspan="20"><p class="tableblock"><code>CTRL</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0</code> <code>UART_CTRL_EN</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">UART enable</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>1</code> <code>UART_CTRL_SIM_MODE</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">enable <strong>simulation mode</strong></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>2</code> <code>UART_CTRL_HWFC_EN</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">enable RTS/CTS hardware flow-control</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>5:3</code> <code>UART_CTRL_PRSC2 : UART_CTRL_PRSC0</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Baud rate clock prescaler select</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>15:6</code> <code>UART_CTRL_BAUD9 : UART_CTRL_BAUD0</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">12-bit Baud value configuration value</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>16</code> <code>UART_CTRL_RX_NEMPTY</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">RX FIFO not empty</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>17</code> <code>UART_CTRL_RX_HALF</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">RX FIFO at least half-full</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>18</code> <code>UART_CTRL_RX_FULL</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">RX FIFO full</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>19</code> <code>UART_CTRL_TX_EMPTY</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">TX FIFO empty</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>20</code> <code>UART_CTRL_TX_NHALF</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">TX FIFO not at least half-full</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>21</code> <code>UART_CTRL_TX_FULL</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">TX FIFO full</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>22</code> <code>UART_CTRL_IRQ_RX_NEMPTY</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">fire IRQ if RX FIFO not empty</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>23</code> <code>UART_CTRL_IRQ_RX_HALF</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">fire IRQ if RX FIFO at least half-full</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>24</code> <code>UART_CTRL_IRQ_RX_FULL</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">fire IRQ if RX FIFO full</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>25</code> <code>UART_CTRL_IRQ_TX_EMPTY</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">fire IRQ if TX FIFO empty</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>26</code> <code>UART_CTRL_IRQ_TX_NHALF</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">fire IRQ if TX not at least half full</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>27</code> -</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><em>reserved</em> read as zero</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>28</code> <code>UART_CTRL_RX_CLR</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Clear RX FIFO, flag auto-clears</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>29</code> <code>UART_CTRL_TX_CLR</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Clear TX FIFO, flag auto-clears</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>30</code> <code>UART_CTRL_RX_OVER</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">RX FIFO overflow; cleared by disabling the module</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>31</code> <code>UART_CTRL_TX_BUSY</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">TX busy or TX FIFO not empty</p></td> +<td class="tableblock halign-left valign-top" rowspan="4"><p class="tableblock"><code>0xfffff504</code></p></td> +<td class="tableblock halign-left valign-top" rowspan="4"><p class="tableblock"><code>DATA</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>7:0</code> <code>UART_DATA_RTX_MSB : UART_DATA_RTX_LSB</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">receive/transmit data</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>11:8</code> <code>UART_DATA_RX_FIFO_SIZE_MSB : UART_DATA_RX_FIFO_SIZE_LSB</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">log2(RX FIFO size)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>15:12</code> <code>UART_DATA_TX_FIFO_SIZE_MSB : UART_DATA_TX_FIFO_SIZE_LSB</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">log2(RX FIFO size)</p></td> +</tr> +</tbody> +</table> +<div style="page-break-after: always;"></div> +</div> +<div class="sect3"> +<h4 id="_secondary_universal_asynchronous_receiver_and_transmitter_uart1">2.7.14. Secondary Universal Asynchronous Receiver and Transmitter (UART1)</h4> +<table class="tableblock frame-ends grid-none stretch"> +<colgroup> +<col style="width: 30%;"> +<col style="width: 30%;"> +<col style="width: 40%;"> +</colgroup> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Hardware source files:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">neorv32_uart.vhd</p></td> +<td class="tableblock halign-left valign-top"></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Software driver files:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">neorv32_uart.c</p></td> +<td class="tableblock halign-left valign-top"></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">neorv32_uart.h</p></td> +<td class="tableblock halign-left valign-top"></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Top entity ports:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>uart1_txd_o</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">serial transmitter output</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>uart1_rxd_i</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">serial receiver input</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>uart1_rts_o</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">flow control: RX ready to receive, low-active</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>uart1_cts_i</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">flow control: RX ready to receive, low-active</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Configuration generics:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>IO_UART1_EN</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">implement UART1 when <code>true</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>UART1_RX_FIFO</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">RX FIFO depth (power of 2, min 1)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>UART1_TX_FIFO</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">TX FIFO depth (power of 2, min 1)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">CPU interrupts:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">fast IRQ channel 4</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">RX interrupt</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">fast IRQ channel 5</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">TX interrupt (see <a href="#_processor_interrupts">Processor Interrupts</a>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Access restrictions:</p></td> +<td class="tableblock halign-left valign-top" colspan="2"><p class="tableblock">privileged access only, non-32-bit write accesses are ignored</p></td> +</tr> +</tbody> +</table> +<div class="paragraph"> +<p><strong>Overview</strong></p> +</div> +<div class="paragraph"> +<p>The secondary UART (UART1) is functionally identical to the primary UART +(<a href="#_primary_universal_asynchronous_receiver_and_transmitter_uart0">Primary Universal Asynchronous Receiver and Transmitter (UART0)</a>). Obviously, UART1 uses different addresses for the +control register (<code>CTRL</code>) and the data register (<code>DATA</code>). The register&#8217;s bits/flags use the same bit positions and naming +as for the primary UART. The RX and TX interrupts of UART1 are mapped to different CPU fast interrupt (FIRQ) channels.</p> +</div> +<div class="paragraph"> +<p><strong>Simulation Mode</strong></p> +</div> +<div class="paragraph"> +<p>The secondary UART (UART1) provides the same simulation options as the primary UART (UART0). However, output data is +written to UART1-specific file <code>neorv32.uart1.sim_mode.text.out</code>. This data is also printed to the simulator console.</p> +</div> +<div class="paragraph"> +<p><strong>Register Map</strong></p> +</div> +<table class="tableblock frame-all grid-all stretch"> +<caption class="title">Table 16. UART1 register map (<code>struct NEORV32_UART1</code>)</caption> +<colgroup> +<col style="width: 28.5714%;"> +<col style="width: 14.2857%;"> +<col style="width: 14.2857%;"> +<col style="width: 14.2857%;"> +<col style="width: 28.5715%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-left valign-top">Address</th> +<th class="tableblock halign-left valign-top">Name [C]</th> +<th class="tableblock halign-left valign-top">Bit(s), Name [C]</th> +<th class="tableblock halign-center valign-top">R/W</th> +<th class="tableblock halign-left valign-top">Function</th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0xfffff600</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>CTRL</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">&#8230;&#8203;</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">&#8230;&#8203;</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Same as UART0</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0xfffff604</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>DATA</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">&#8230;&#8203;</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">&#8230;&#8203;</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Same as UART0</p></td> +</tr> +</tbody> +</table> +<div style="page-break-after: always;"></div> +</div> +<div class="sect3"> +<h4 id="_serial_peripheral_interface_controller_spi">2.7.15. Serial Peripheral Interface Controller (SPI)</h4> +<table class="tableblock frame-ends grid-none stretch"> +<colgroup> +<col style="width: 30%;"> +<col style="width: 30%;"> +<col style="width: 40%;"> +</colgroup> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Hardware source files:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">neorv32_spi.vhd</p></td> +<td class="tableblock halign-left valign-top"></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Software driver files:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">neorv32_spi.c</p></td> +<td class="tableblock halign-left valign-top"></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">neorv32_spi.h</p></td> +<td class="tableblock halign-left valign-top"></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Top entity ports:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>spi_clk_o</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">1-bit serial clock output</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>spi_dat_o</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">1-bit serial data output</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>spi_dat_i</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">1-bit serial data input</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>spi_csn_o</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">8-bit dedicated chip select output (low-active)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Configuration generics:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>IO_SPI_EN</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">implement SPI controller when <code>true</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>IO_SPI_FIFO</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">FIFO depth, has to be a power of two, min 1</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">CPU interrupts:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">fast IRQ channel 6</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">configurable SPI interrupt (see <a href="#_processor_interrupts">Processor Interrupts</a>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Access restrictions:</p></td> +<td class="tableblock halign-left valign-top" colspan="2"><p class="tableblock">privileged access only, non-32-bit write accesses are ignored</p></td> +</tr> +</tbody> +</table> +<div class="paragraph"> +<p><strong>Overview</strong></p> +</div> +<div class="paragraph"> +<p>The NEORV32 SPI module is a <strong>host</strong> transceiver. Hence, it is responsible for generating transmission. +The module operates on a byte.wide data granularity, supports all 4 standard clock modes, a fine-tunable +SPI clock generator and provides up to 8 dedicated chip select signals via the top entity&#8217;s <code>spi_csn_o</code> signal. +An optional receive/transmit ring-buffer/FIFO can be configured via the <code>IO_SPI_FIFO</code> generic to support block-based +transmissions without CPU interaction.</p> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">Host-Mode Only</div> +The NEORV32 SPI module only supports <em>host mode</em>. Transmission are initiated only by the processor&#8217;s SPI module +and not by an external SPI module. If you are looking for a <em>device-mode</em> serial peripheral interface (transactions +initiated by an external host) check out the <a href="#_serial_data_interface_controller_sdi">Serial Data Interface Controller (SDI)</a>. +</td> +</tr> +</table> +</div> +<div class="paragraph"> +<p>The SPI module provides a single control register <code>CTRL</code> to configure the module and to check it&#8217;s status +and a single data register <code>DATA</code> for receiving/transmitting data.</p> +</div> +<div class="paragraph"> +<p><strong>Theory of Operation</strong></p> +</div> +<div class="paragraph"> +<p>The SPI module is enabled by setting the <code>SPI_CTRL_EN</code> bit in the <code>CTRL</code> control register. No transfer can be initiated +and no interrupt request will be triggered if this bit is cleared. Clearing this bit will reset the entire module, clear +the FIFO and terminate any transfer being in process.</p> +</div> +<div class="paragraph"> +<p>The actual SPI transfer (receiving one byte while sending one byte) as well as control of the chip-select lines is handled +via the module&#8217;s <code>DATA</code> register. Note that this register will access the TX FIFO of the ring-buffer when writing and will +access the RX FIFO of the ring-buffer when reading.</p> +</div> +<div class="paragraph"> +<p>The most significant bit of the <code>DATA</code> register (<code>SPI_DATA_CMD</code>) is used to select the purpose of the data being written. +When the <code>SPI_DATA_CMD</code> is cleared, the lowest 8-bit represent the actual SPI TX data. This data will be transmitted by the +SPI bus engine. After completion, the received data is stored to the RX FIFO.</p> +</div> +<div class="paragraph"> +<p>If <code>SPI_DATA_CMD</code> is cleared, the lowest 4-bit control the chip-select lines. In this case, bis <code>2:0</code> select one of the eight +chip-select lines. The selected line will become enabled when bit <code>3</code> is also set. If bit <code>3</code> is cleared, all chip-select +lines will be disabled.</p> +</div> +<div class="paragraph"> +<p>Examples: +. Enable chip-select line 3: <code>NEORV32_SPI&#8594;DATA = (1 &lt;&lt; SPI_DATA_CMD) | (1 &lt;&lt; 3) | 3;</code> +. Enable chip-select line 7: <code>NEORV32_SPI&#8594;DATA = (1 &lt;&lt; SPI_DATA_CMD) | (1 &lt;&lt; 3) | 7;</code> +. Disable all chip-select lines: <code>NEORV32_SPI&#8594;DATA = (1 &lt;&lt; SPI_DATA_CMD) | (0 &lt;&lt; 3);</code> +. Send data byte <code>0xAB</code>: <code>NEORV32_SPI&#8594;DATA = (0 &lt;&lt; SPI_DATA_CMD) | 0xAB;</code></p> +</div> +<div class="paragraph"> +<p>Since all SPI operations are controlled via the FIFO, entire SPI sequences (chip-enable, data transmissions, chip-disable) +can be "programmed". Thus, SPI operations can be executed without any CPU interaction at all.</p> +</div> +<div class="paragraph"> +<p>Application software can check if any chip-select is enabled by reading the control register&#8217;s <code>SPI_CS_ACTIVE</code> flag.</p> +</div> +<div class="paragraph"> +<p><strong>SPI Clock Configuration</strong></p> +</div> +<div class="paragraph"> +<p>The SPI module supports all standard SPI clock modes (0, 1, 2, 3), which are configured via the two control register bits +<code>SPI_CTRL_CPHA</code> and <code>SPI_CTRL_CPOL</code>. The <code>SPI_CTRL_CPHA</code> bit defines the <em>clock phase</em> and the <code>SPI_CTRL_CPOL</code> +bit defines the <em>clock polarity</em>.</p> +</div> +<div class="imageblock"> +<div class="content"> +<img src="img/SPI_timing_diagram2.wikimedia.png" alt="SPI timing diagram2.wikimedia"> +</div> +<div class="title">Figure 7. SPI clock modes; image from <a href="https://en.wikipedia.org/wiki/File:SPI_timing_diagram2.svg" class="bare">https://en.wikipedia.org/wiki/File:SPI_timing_diagram2.svg</a> (license: (Wikimedia) <a href="https://en.wikipedia.org/wiki/Creative_Commons">Creative Commons</a> <a href="https://creativecommons.org/licenses/by-sa/3.0/deed.en">Attribution-Share Alike 3.0 Unported</a>)</div> +</div> +<div class="paragraph"> +<p>The SPI clock frequency (<code>spi_clk_o</code>) is programmed by the 3-bit <code>SPI_CTRL_PRSCx</code> clock prescaler for a coarse clock selection +and a 4-bit clock divider <code>SPI_CTRL_CDIVx</code> for a fine clock configuration. +The following clock prescalers (<code>SPI_CTRL_PRSCx</code>) are available:</p> +</div> +<table class="tableblock frame-all grid-rows stretch"> +<caption class="title">Table 17. SPI prescaler configuration</caption> +<colgroup> +<col style="width: 33.3333%;"> +<col style="width: 8.3333%;"> +<col style="width: 8.3333%;"> +<col style="width: 8.3333%;"> +<col style="width: 8.3333%;"> +<col style="width: 8.3333%;"> +<col style="width: 8.3333%;"> +<col style="width: 8.3333%;"> +<col style="width: 8.3336%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-left valign-top"><strong><code>SPI_CTRL_PRSCx</code></strong></th> +<th class="tableblock halign-center valign-top"><code>0b000</code></th> +<th class="tableblock halign-center valign-top"><code>0b001</code></th> +<th class="tableblock halign-center valign-top"><code>0b010</code></th> +<th class="tableblock halign-center valign-top"><code>0b011</code></th> +<th class="tableblock halign-center valign-top"><code>0b100</code></th> +<th class="tableblock halign-center valign-top"><code>0b101</code></th> +<th class="tableblock halign-center valign-top"><code>0b110</code></th> +<th class="tableblock halign-center valign-top"><code>0b111</code></th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Resulting <code>clock_prescaler</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">2</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">4</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">8</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">64</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">128</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">1024</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">2048</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">4096</p></td> +</tr> +</tbody> +</table> +<div class="paragraph"> +<p>Based on the programmed clock configuration, the actual SPI clock frequency f<sub>SPI</sub> is derived +from the processor&#8217;s main clock f<sub>main</sub> according to the following equation:</p> +</div> +<div class="paragraph"> +<p><em><strong>f<sub>SPI</sub></strong></em> = <em>f<sub>main</sub>[Hz]</em> / (2 * <code>clock_prescaler</code> * (1 + <code>SPI_CTRL_CDIVx</code>))</p> +</div> +<div class="paragraph"> +<p>Hence, the maximum SPI clock is f<sub>main</sub> / 4 and the lowest SPI clock is f<sub>main</sub> / 131072. The SPI clock is always +symmetric having a duty cycle of exactly 50%.</p> +</div> +<div class="paragraph"> +<p><strong>High-Speed Mode</strong></p> +</div> +<div class="paragraph"> +<p>The SPI provides a high-speed mode to further boost the maximum SPI clock frequency. When enabled via the control +register&#8217;s <code>SPI_CTRL_HIGHSPEED</code> bit the clock prescaler configuration (<code>SPI_CTRL_PRSCx</code> bits) is overridden setting it +to a minimal factor of 1. However, the clock speed can still be fine-tuned using the <code>SPI_CTRL_CDIVx</code> bits.</p> +</div> +<div class="paragraph"> +<p><em><strong>f<sub>SPI</sub></strong></em> = <em>f<sub>main</sub>[Hz]</em> / (2 * 1 * (1 + <code>SPI_CTRL_CDIVx</code>))</p> +</div> +<div class="paragraph"> +<p>Hence, the maximum SPI clock is f<sub>main</sub> / 2 when in high-speed mode.</p> +</div> +<div class="paragraph"> +<p><strong>SPI Interrupt</strong></p> +</div> +<div class="paragraph"> +<p>The SPI module provides a set of programmable interrupt conditions based on the level of the RX/TX FIFO. The different +interrupt sources are enabled by setting the according control register&#8217;s <code>SPI_CTRL_IRQ_*</code> bits. All enabled interrupt +conditions are logically OR-ed, so any enabled interrupt source will trigger the module&#8217;s interrupt signal.</p> +</div> +<div class="paragraph"> +<p>Once the SPI interrupt has fired it remains pending until the actual cause of the interrupt is resolved; for +example if just the <code>SPI_CTRL_IRQ_RX_AVAIL</code> bit is set, the interrupt will keep firing until the RX FIFO is empty again.</p> +</div> +<div class="paragraph"> +<p><strong>Register Map</strong></p> +</div> +<table class="tableblock frame-all grid-all stretch"> +<caption class="title">Table 18. SPI register map (<code>struct NEORV32_SPI</code>)</caption> +<colgroup> +<col style="width: 13.3333%;"> +<col style="width: 6.6666%;"> +<col style="width: 26.6666%;"> +<col style="width: 6.6666%;"> +<col style="width: 46.6669%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-left valign-top">Address</th> +<th class="tableblock halign-left valign-top">Name [C]</th> +<th class="tableblock halign-left valign-top">Bit(s), Name [C]</th> +<th class="tableblock halign-center valign-top">R/W</th> +<th class="tableblock halign-left valign-top">Function</th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-left valign-top" rowspan="19"><p class="tableblock"><code>0xfffff800</code></p></td> +<td class="tableblock halign-left valign-top" rowspan="19"><p class="tableblock"><code>CTRL</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0</code> <code>SPI_CTRL_EN</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">SPI module enable</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>1</code> <code>SPI_CTRL_CPHA</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">clock phase</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>2</code> <code>SPI_CTRL_CPOL</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">clock polarity</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>5:3</code> <code>SPI_CTRL_PRSC2 : SPI_CTRL_PRSC0</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">3-bit clock prescaler select</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>9:6</code> <code>SPI_CTRL_CDIV2 : SPI_CTRL_CDIV0</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">4-bit clock divider for fine-tuning</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>10</code> <code>SPI_CTRL_HIGHSPEED</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">high-speed mode enable (overriding <code>SPI_CTRL_PRSC*</code>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>15:11</code> <em>reserved</em></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">reserved, read as zero</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>16</code> <code>SPI_CTRL_RX_AVAIL</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">RX FIFO data available (RX FIFO not empty)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>17</code> <code>SPI_CTRL_TX_EMPTY</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">TX FIFO empty</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>18</code> <code>SPI_CTRL_TX_NHALF</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">TX FIFO <em>not</em> at least half full</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>19</code> <code>SPI_CTRL_TX_FULL</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">TX FIFO full</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>20</code> <code>SPI_CTRL_IRQ_RX_AVAIL</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Trigger IRQ if RX FIFO not empty</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>21</code> <code>SPI_CTRL_IRQ_TX_EMPTY</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Trigger IRQ if TX FIFO empty</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>22</code> <code>SPI_CTRL_IRQ_TX_NHALF</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Trigger IRQ if TX FIFO <em>not</em> at least half full</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>23</code> <code>SPI_CTRL_IRQ_IDLE</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Trigger IRQ if TX FIFO is empty and SPI bus engine is idle</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>27:24</code> <code>SPI_CTRL_FIFO_MSB : SPI_CTRL_FIFO_LSB</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">FIFO depth; log2(<code>IO_SPI_FIFO</code>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>30:28</code> <em>reserved</em></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">reserved, read as zero</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>30</code> <code>SPI_CS_ACTIVE</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Set if any chip-select line is active</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>31</code> <code>SPI_CTRL_BUSY</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">SPI module busy when set (serial engine operation in progress and TX FIFO not empty yet)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top" rowspan="3"><p class="tableblock"><code>0xfffff804</code></p></td> +<td class="tableblock halign-left valign-top" rowspan="3"><p class="tableblock"><code>DATA</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>7:0</code> <code>SPI_DATA_MSB : SPI_DATA_LSB</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">receive/transmit data (FIFO)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>30:8</code> <em>reserved</em></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">reserved, read as zero</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>31</code> <code>SPI_DATA_CMD</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">-/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">data (<code>0</code>) / chip-select-command (<code>1</code>) select</p></td> +</tr> +</tbody> +</table> +<div style="page-break-after: always;"></div> +</div> +<div class="sect3"> +<h4 id="_serial_data_interface_controller_sdi">2.7.16. Serial Data Interface Controller (SDI)</h4> +<table class="tableblock frame-ends grid-none stretch"> +<colgroup> +<col style="width: 30%;"> +<col style="width: 30%;"> +<col style="width: 40%;"> +</colgroup> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Hardware source files:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">neorv32_sdi.vhd</p></td> +<td class="tableblock halign-left valign-top"></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Software driver files:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">neorv32_sdi.c</p></td> +<td class="tableblock halign-left valign-top"></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">neorv32_sdi.h</p></td> +<td class="tableblock halign-left valign-top"></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Top entity ports:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>sdi_clk_i</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">1-bit serial clock input</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>sdi_dat_o</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">1-bit serial data output</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>sdi_dat_i</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">1-bit serial data input</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>sdi_csn_i</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">1-bit chip-select input (low-active)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Configuration generics:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>IO_SDI_EN</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">implement SDI controller when <code>true</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>IO_SDI_FIFO</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">data FIFO size, has to a power of two, min 1</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">CPU interrupts:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">fast IRQ channel 11</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">configurable SDI interrupt (see <a href="#_processor_interrupts">Processor Interrupts</a>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Access restrictions:</p></td> +<td class="tableblock halign-left valign-top" colspan="2"><p class="tableblock">privileged access only, non-32-bit write accesses are ignored</p></td> +</tr> +</tbody> +</table> +<div class="paragraph"> +<p><strong>Overview</strong></p> +</div> +<div class="paragraph"> +<p>The serial data interface module provides a <strong>device-class</strong> SPI interface and allows to connect the processor +to an <strong>external SPI host</strong>, which is responsible of performing the actual transmission - the SDI is entirely +passive. An optional receive/transmit ring buffer (FIFOs) can be configured via the <code>IO_SDI_FIFO</code> generic to +support block-based transmissions without CPU interaction.</p> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">Device-Mode Only</div> +The NEORV32 SDI module only supports <em>device mode</em>. Transmission are initiated by an external host and not by the +the processor itself. If you are looking for a <em>host-mode</em> serial peripheral interface (transactions +performed by the NEORV32) check out the <a href="#_serial_peripheral_interface_controller_spi">Serial Peripheral Interface Controller (SPI)</a>. +</td> +</tr> +</table> +</div> +<div class="paragraph"> +<p>The SDI module provides a single control register <code>CTRL</code> to configure the module and to check it&#8217;s status +and a single data register <code>DATA</code> for receiving/transmitting data. Any access to the <code>DATA</code> register +actually accesses the internal ring buffer.</p> +</div> +<div class="paragraph"> +<p><strong>Theory of Operation</strong></p> +</div> +<div class="paragraph"> +<p>The SDI module is enabled by setting the <code>SDI_CTRL_EN</code> bit in the <code>CTRL</code> control register. Clearing this bit +resets the entire module and will also clear the entire RX/TX ring buffer.</p> +</div> +<div class="paragraph"> +<p>The SDI operates on byte-level only. Data written to the <code>DATA</code> register will be pushed to the TX FIFO. Received +data can be retrieved by reading the RX FIFO via the <code>DATA</code> register. The current state of these FIFOs is available +via the control register&#8217;s <code>SDI_CTRL_RX_*</code> and <code>SDI_CTRL_TX_*</code> flags. If no data is available in the TX FIFO while +an external device performs a transmission the external device will read all-zero from the SDI controller.</p> +</div> +<div class="paragraph"> +<p>Application software can check the current state of the SDI chip-select input via the control register&#8217;s +<code>SDI_CTRL_CS_ACTIVE</code> flag (the flag is set when the chip-select line is active (pulled low)).</p> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">MSB-first Only</div> +The NEORV32 SDI module only supports MSB-first mode. +</td> +</tr> +</table> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">In-Transmission Abort</div> +If the external SPI controller aborts the transmission by setting the chip-select signal high again <em>before</em> +8 data bits have been transferred, no data is written to the RX FIFO. +</td> +</tr> +</table> +</div> +<div class="paragraph"> +<p><strong>SDI Clocking</strong></p> +</div> +<div class="paragraph"> +<p>The SDI module supports both SPI clock polarity modes ("CPOL") but only "CPHA=0"-clock-phase is <em>officially</em> supported +yet. However, experiments have shown that the SDI module can also deal with both clock phase modes (for slow SDI clock speeds).</p> +</div> +<div class="paragraph"> +<p>All SDI operations are clocked by the external <code>sdi_clk_i</code> signal. This signal is synchronized to the processor&#8217;s +clock domain to simplify timing behavior. This clock synchronization requires the external SDI clock +(<code>sdi_clk_i</code>) does <strong>not exceed 1/4 of the processor&#8217;s main clock</strong>.</p> +</div> +<div class="paragraph"> +<p><strong>SDI Interrupt</strong></p> +</div> +<div class="paragraph"> +<p>The SDI module provides a set of programmable interrupt conditions based on the level of the RX &amp; TX FIFOs. The different +interrupt sources are enabled by setting the according control register&#8217;s <code>SDI_CTRL_IRQ_*</code> bits. All enabled interrupt +conditions are logically OR-ed so any enabled interrupt source will trigger the module&#8217;s interrupt signal.</p> +</div> +<div class="paragraph"> +<p>Once the SDI interrupt has fired it will remain active until the actual cause of the interrupt is resolved; for +example if just the <code>SDI_CTRL_IRQ_RX_AVAIL</code> bit is set, the interrupt will keep firing until the RX FIFO is empty again.</p> +</div> +<div class="paragraph"> +<p><strong>Register Map</strong></p> +</div> +<table class="tableblock frame-all grid-all stretch"> +<caption class="title">Table 19. SDI register map (<code>struct NEORV32_SDI</code>)</caption> +<colgroup> +<col style="width: 13.3333%;"> +<col style="width: 6.6666%;"> +<col style="width: 26.6666%;"> +<col style="width: 6.6666%;"> +<col style="width: 46.6669%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-left valign-top">Address</th> +<th class="tableblock halign-left valign-top">Name [C]</th> +<th class="tableblock halign-left valign-top">Bit(s), Name [C]</th> +<th class="tableblock halign-center valign-top">R/W</th> +<th class="tableblock halign-left valign-top">Function</th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-left valign-top" rowspan="18"><p class="tableblock"><code>0xfffff700</code></p></td> +<td class="tableblock halign-left valign-top" rowspan="18"><p class="tableblock"><code>CTRL</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0</code> <code>SDI_CTRL_EN</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">SDI module enable</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>3:1</code> <em>reserved</em></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">reserved, read as zero</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>7:4</code> <code>SDI_CTRL_FIFO_MSB : SDI_CTRL_FIFO_LSB</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">FIFO depth; log2(<em>IO_SDI_FIFO</em>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>14:8</code> <em>reserved</em></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">reserved, read as zero</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>15</code> <code>SDI_CTRL_IRQ_RX_AVAIL</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">fire interrupt if RX FIFO is not empty</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>16</code> <code>SDI_CTRL_IRQ_RX_HALF</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">fire interrupt if RX FIFO is at least half full</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>17</code> <code>SDI_CTRL_IRQ_RX_FULL</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">fire interrupt if if RX FIFO is full</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>18</code> <code>SDI_CTRL_IRQ_TX_EMPTY</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">fire interrupt if TX FIFO is empty</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>19</code> <code>SDI_CTRL_IRQ_TX_NHALF</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">fire interrupt if TX FIFO is not at least half full</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>22:20</code> <em>reserved</em></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">reserved, read as zero</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>23</code> <code>SDI_CTRL_RX_AVAIL</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">RX FIFO data available (RX FIFO not empty)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>24</code> <code>SDI_CTRL_RX_HALF</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">RX FIFO at least half full</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>25</code> <code>SDI_CTRL_RX_FULL</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">RX FIFO full</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>26</code> <code>SDI_CTRL_TX_EMPTY</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">TX FIFO empty</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>27</code> <code>SDI_CTRL_TX_NHALF</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">TX FIFO not at least half full</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>28</code> <code>SDI_CTRL_TX_FULL</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">TX FIFO full</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>30:29</code> <em>reserved</em></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">reserved, read as zero</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>31</code> <code>SDI_CTRL_CS_ACTIVE</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Chip-select is active when set</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top" rowspan="2"><p class="tableblock"><code>0xfffff704</code></p></td> +<td class="tableblock halign-left valign-top" rowspan="2"><p class="tableblock"><code>DATA</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>7:0</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">receive/transmit data (FIFO)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>31:8</code> <em>reserved</em></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">reserved, read as zero</p></td> +</tr> +</tbody> +</table> +<div style="page-break-after: always;"></div> +</div> +<div class="sect3"> +<h4 id="_two_wire_serial_interface_controller_twi">2.7.17. Two-Wire Serial Interface Controller (TWI)</h4> +<table class="tableblock frame-ends grid-none stretch"> +<colgroup> +<col style="width: 30%;"> +<col style="width: 30%;"> +<col style="width: 40%;"> +</colgroup> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Hardware source files:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">neorv32_twi.vhd</p></td> +<td class="tableblock halign-left valign-top"></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Software driver files:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">neorv32_twi.c</p></td> +<td class="tableblock halign-left valign-top"></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">neorv32_twi.h</p></td> +<td class="tableblock halign-left valign-top"></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Top entity ports:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>twi_sda_i</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">1-bit serial data line sense input</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>twi_sda_o</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">1-bit serial data line output (pull low only)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>twi_scl_i</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">1-bit serial clock line sense input</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>twi_scl_o</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">1-bit serial clock line output (pull low only)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Configuration generics:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>IO_TWI_EN</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">implement TWI controller when <code>true</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>IO_TWI_FIFO</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">FIFO depth, has to be a power of two, min 1</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">CPU interrupts:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">fast IRQ channel 7</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">FIFO empty and module idle interrupt (see <a href="#_processor_interrupts">Processor Interrupts</a>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Access restrictions:</p></td> +<td class="tableblock halign-left valign-top" colspan="2"><p class="tableblock">privileged access only, non-32-bit write accesses are ignored</p></td> +</tr> +</tbody> +</table> +<div class="paragraph"> +<p><strong>Overview</strong></p> +</div> +<div class="paragraph"> +<p>The NEORV32 TWI implements an I2C-compatible host controller to communicate with arbitrary I2C-devices. +Note that peripheral-mode (controller acts as a device) and multi-controller mode are not supported yet.</p> +</div> +<div class="paragraph"> +<p>The TWI controller provides two memory-mapped registers that are used for configuring the module and +for triggering operation: <code>CTRL</code> is the control and status register, <code>DCMD</code> is the command and data register.</p> +</div> +<div class="paragraph"> +<p>Key features:</p> +</div> +<div class="ulist"> +<ul> +<li> +<p>Programmable clock speed</p> +</li> +<li> +<p>Optional clock stretching</p> +</li> +<li> +<p>Generate START / repeated-START and STOP conditions</p> +</li> +<li> +<p>Sending &amp; receiving 8 data bits including ACK/NACK</p> +</li> +<li> +<p>Generating a host-ACK (ACK send by the TWI controller)</p> +</li> +<li> +<p>Configurable data/command FIFO to "program" large TWI sequences without further involvement of the CPU</p> +</li> +</ul> +</div> +<div class="paragraph"> +<p><strong>Tristate Drivers</strong></p> +</div> +<div class="paragraph"> +<p>The TWI module requires two tristate drivers (actually: open-drain drivers; signals can only be actively driven low) for +the SDA and SCL lines, which have to be implemented by the user in the setup&#8217;s top module / IO ring. A generic VHDL example +is shown below (here, <code>sda_io</code> and <code>scl_io</code> are the actual TWI bus lines, which are of type <code>std_logic</code>).</p> +</div> +<div class="listingblock"> +<div class="title">Listing 5. TWI VHDL Tristate Driver Example</div> +<div class="content"> +<pre class="highlight"><code class="language-VHDL" data-lang="VHDL">sda_io &lt;= '0' when (twi_sda_o = '0') else 'Z'; -- drive +scl_io &lt;= '0' when (twi_scl_o = '0') else 'Z'; -- drive +twi_sda_i &lt;= std_ulogic(sda_io); -- sense +twi_scl_i &lt;= std_ulogic(scl_io); -- sense</code></pre> +</div> +</div> +<div class="paragraph"> +<p><strong>TWI Clock Speed</strong></p> +</div> +<div class="paragraph"> +<p>The TWI clock frequency is programmed by two bit-fields in the device&#8217;s control register <code>CTRL</code>: a 3-bit <code>TWI_CTRL_PRSCx</code> +clock prescaler is sued for a coarse clock configuration and a 4-bit clock divider <code>TWI_CTRL_CDIVx</code> is used for a fine +clock configuration.</p> +</div> +<table class="tableblock frame-all grid-rows stretch"> +<caption class="title">Table 20. TWI prescaler configuration</caption> +<colgroup> +<col style="width: 33.3333%;"> +<col style="width: 8.3333%;"> +<col style="width: 8.3333%;"> +<col style="width: 8.3333%;"> +<col style="width: 8.3333%;"> +<col style="width: 8.3333%;"> +<col style="width: 8.3333%;"> +<col style="width: 8.3333%;"> +<col style="width: 8.3336%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-left valign-top"><strong><code>TWI_CTRL_PRSCx</code></strong></th> +<th class="tableblock halign-center valign-top"><code>0b000</code></th> +<th class="tableblock halign-center valign-top"><code>0b001</code></th> +<th class="tableblock halign-center valign-top"><code>0b010</code></th> +<th class="tableblock halign-center valign-top"><code>0b011</code></th> +<th class="tableblock halign-center valign-top"><code>0b100</code></th> +<th class="tableblock halign-center valign-top"><code>0b101</code></th> +<th class="tableblock halign-center valign-top"><code>0b110</code></th> +<th class="tableblock halign-center valign-top"><code>0b111</code></th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Resulting <code>clock_prescaler</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">2</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">4</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">8</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">64</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">128</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">1024</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">2048</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">4096</p></td> +</tr> +</tbody> +</table> +<div class="paragraph"> +<p>Based on the clock configuration, the actual TWI clock frequency f<sub>SCL</sub> is derived +from the processor&#8217;s main clock f<sub>main</sub> according to the following equation:</p> +</div> +<div class="paragraph"> +<p><em><strong>f<sub>SCL</sub></strong></em> = <em>f<sub>main</sub>[Hz]</em> / (4 * <code>clock_prescaler</code> * (1 + TWI_CTRL_CDIV))</p> +</div> +<div class="paragraph"> +<p>Hence, the maximum TWI clock is f<sub>main</sub> / 8 and the lowest TWI clock is f<sub>main</sub> / 262144. The generated TWI clock is +always symmetric having a duty cycle of exactly 50%.</p> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">Clock Stretching</div> +An accessed peripheral can slow down/halt the controller&#8217;s bus clock by using clock stretching (= actively keeping the +SCL line low). The controller will halt operation in this case. Clock stretching is enabled by setting the +<code>TWI_CTRL_CLKSTR</code> bit in the module&#8217;s control register <code>CTRL</code>. +</td> +</tr> +</table> +</div> +<div class="paragraph"> +<p><strong>TWI Transfers</strong></p> +</div> +<div class="paragraph"> +<p>The TWI is enabled via the <code>TWI_CTRL_EN</code> bit in the <code>CTRL</code> control register. All TWI operations are controlled by +the <code>DCMD</code> register. The actual operation is selected by a 2-bit value that is written to the register&#8217;s <code>TWI_DCMD_CMD_*</code> +bit-field:</p> +</div> +<div class="ulist"> +<ul> +<li> +<p><code>00</code>: NOP (no-operation); all further bit-fields in <code>DCMD</code> are ignored</p> +</li> +<li> +<p><code>01</code>: Generate a (repeated) START conditions; all further bit-fields in <code>DCMD</code> are ignored</p> +</li> +<li> +<p><code>10</code>: Generate a STOP conditions; all further bit-fields in <code>DCMD</code> are ignored</p> +</li> +<li> +<p><code>11</code>: Trigger a data transmission; the data to be send has to be written to the register&#8217;s <code>TWI_DCMD_MSB : TWI_DCMD_LSB</code> +bit-field; if <code>TWI_DCMD_ACK</code> is set the controller will send a host-ACK in the ACK/NACK time slot; after the transmission +is completed <code>TWI_DCMD_MSB : TWI_DCMD_LSB</code> contains the RX data and <code>TWI_DCMD_ACK</code> the device&#8217;s response if no host-ACK was +configured (<code>0</code> = ACK, <code>1</code> = ACK)</p> +</li> +</ul> +</div> +<div class="paragraph"> +<p>All operations/data written to the <code>DCMD</code> register are buffered by a configurable data/command FIFO. The depth of the FIFO is +configured by the <code>IO_TWI_FIFO</code> top generic. Software can retrieve this size by reading the control register&#8217;s <code>TWI_CTRL_FIFO</code> bits.</p> +</div> +<div class="paragraph"> +<p>The command/data FIFO is internally split into a TX FIFO and a RX FIFO. Writing to <code>DCMD</code> will write to the TX FIFO while reading from +<code>DCMD</code> will read from the RX FIFO. The TX FIFO is full when the <code>TWI_CTRL_TX_FULL</code> flag is set. Accordingly, the RX FIFO contains valid +data when the <code>TWI_CTRL_RX_AVAIL</code> flag is set.</p> +</div> +<div class="paragraph"> +<p>The control register&#8217;s busy flag <code>TWI_CTRL_BUSY</code> is set as long as the TX FIFO contains valid data (i.e. programmed TWI operations +that have not been executed yet) or of the TWI bus engine is still processing an operation.</p> +</div> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +An active transmission can be terminated at any time by disabling the TWI module. This will also clear the data/command FIFO. +</td> +</tr> +</table> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +When reading data from a device, an all-one byte (<code>0xFF</code>) has to be written to TWI data register <code>NEORV32_TWI.DATA</code> +so the accessed device can actively pull-down SDA when required. +</td> +</tr> +</table> +</div> +<div class="paragraph"> +<p><strong>TWI Interrupt</strong></p> +</div> +<div class="paragraph"> +<p>The TWI module provides a single interrupt to signal "idle condition" to the CPU. The interrupt becomes active when the +TWI module is enabled (<code>TWI_CTRL_EN</code> = <code>1</code>) and the TX FIFO is empty and the TWI bus engine is idle.</p> +</div> +<div class="paragraph"> +<p><strong>Register Map</strong></p> +</div> +<table class="tableblock frame-all grid-all stretch"> +<caption class="title">Table 21. TWI register map (<code>struct NEORV32_TWI</code>)</caption> +<colgroup> +<col style="width: 13.3333%;"> +<col style="width: 6.6666%;"> +<col style="width: 26.6666%;"> +<col style="width: 6.6666%;"> +<col style="width: 46.6669%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-left valign-top">Address</th> +<th class="tableblock halign-left valign-top">Name [C]</th> +<th class="tableblock halign-left valign-top">Bit(s), Name [C]</th> +<th class="tableblock halign-center valign-top">R/W</th> +<th class="tableblock halign-left valign-top">Function</th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-left valign-top" rowspan="10"><p class="tableblock"><code>0xfffff900</code></p></td> +<td class="tableblock halign-left valign-top" rowspan="10"><p class="tableblock"><code>CTRL</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0</code> <code>TWI_CTRL_EN</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">TWI enable, reset if cleared</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>3:1</code> <code>TWI_CTRL_PRSC2 : TWI_CTRL_PRSC0</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">3-bit clock prescaler select</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>7:4</code> <code>TWI_CTRL_CDIV3 : TWI_CTRL_CDIV0</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">4-bit clock divider</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>8</code> <code>TWI_CTRL_CLKSTR</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Enable (allow) clock stretching</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>14:9</code> -</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><em>reserved</em>, read as zero</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>18:15</code> <code>TWI_CTRL_FIFO_MSB : TWI_CTRL_FIFO_LSB</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">FIFO depth; log2(<code>IO_TWI_FIFO</code>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>28:12</code> -</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><em>reserved</em>, read as zero</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>29</code> <code>TWI_CTRL_TX_FULL</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">set if the TWI bus is claimed by any controller</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>30</code> <code>TWI_CTRL_RX_AVAIL</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">RX FIFO data available</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>31</code> <code>TWI_CTRL_BUSY</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">TWI bus engine busy or TX FIFO not empty</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top" rowspan="3"><p class="tableblock"><code>0xfffff904</code></p></td> +<td class="tableblock halign-left valign-top" rowspan="3"><p class="tableblock"><code>DCMD</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>7:0</code> <code>TWI_DCMD_MSB : TWI_DCMD_LSB</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">RX/TX data byte</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>8</code> <code>TWI_DCMD_ACK</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">write: ACK bit sent by controller; read: <code>1</code> = device NACK, <code>0</code> = device ACK</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>10:9</code> <code>TWI_DCMD_CMD_HI : TWI_DCMD_CMD_LO</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">TWI operation (<code>00</code> = NOP, <code>01</code> = START conditions, <code>10</code> = STOP condition, <code>11</code> = data transmission)</p></td> +</tr> +</tbody> +</table> +<div style="page-break-after: always;"></div> +</div> +<div class="sect3"> +<h4 id="_one_wire_serial_interface_controller_onewire">2.7.18. One-Wire Serial Interface Controller (ONEWIRE)</h4> +<table class="tableblock frame-ends grid-none stretch"> +<colgroup> +<col style="width: 30%;"> +<col style="width: 30%;"> +<col style="width: 40%;"> +</colgroup> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Hardware source files:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">neorv32_onewire.vhd</p></td> +<td class="tableblock halign-left valign-top"></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Software driver files:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">neorv32_onewire.c</p></td> +<td class="tableblock halign-left valign-top"></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">neorv32_onewire.h</p></td> +<td class="tableblock halign-left valign-top"></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Top entity ports:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>onewire_i</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">1-bit 1-wire bus sense input</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>onewire_o</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">1-bit 1-wire bus output (pull low only)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Configuration generics:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>IO_ONEWIRE_EN</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">implement ONEWIRE interface controller when <code>true</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">CPU interrupts:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">fast IRQ channel 13</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">operation done interrupt (see <a href="#_processor_interrupts">Processor Interrupts</a>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Access restrictions:</p></td> +<td class="tableblock halign-left valign-top" colspan="2"><p class="tableblock">privileged access only, non-32-bit write accesses are ignored</p></td> +</tr> +</tbody> +</table> +<div class="paragraph"> +<p><strong>Overview</strong></p> +</div> +<div class="paragraph"> +<p>The NEORV32 ONEWIRE module implements a single-wire interface controller that is compatible to the +<em>Dallas/Maxim 1-Wire</em> protocol, which is an asynchronous half-duplex bus requiring only a single signal wire +connected to <code>onewire_io</code> (plus ground).</p> +</div> +<div class="paragraph"> +<p>The bus is based on a single open-drain signal. The controller and all the devices can only pull-down the bus actively. +Hence, an external pull-up resistor is required. Recommended values are between 1kΩ and 4kΩ depending on the bus +characteristics (wire length, number of devices, etc.). Furthermore, a series resistor (~100Ω) at the controller side +is recommended to control the slew rate and to reduce signal reflections. Also, additional external ESD protection clamp diodes +should be added to the bus line.</p> +</div> +<div class="paragraph"> +<p><strong>Tri-State Drivers</strong></p> +</div> +<div class="paragraph"> +<p>The ONEWIRE module requires a tri-state driver (actually, open-drain) for the 1-wire bus line, which has to be implemented +in the top module of the setup. A generic VHDL example is given below (<code>onewire</code> is the actual 1-wire +bus signal, which is of type <code>std_logic</code>).</p> +</div> +<div class="listingblock"> +<div class="title">Listing 6. ONEWIRE VHDL tri-state driver example</div> +<div class="content"> +<pre class="highlight"><code class="language-VHDL" data-lang="VHDL">onewire &lt;= '0' when (onewire_o = '0') else 'Z'; -- drive +onewire_i &lt;= std_ulogic(onewire); -- sense</code></pre> +</div> +</div> +<div class="paragraph"> +<p><strong>Theory of Operation</strong></p> +</div> +<div class="paragraph"> +<p>The ONEWIRE controller provides two interface registers: <code>CTRL</code> and <code>DATA.</code> The control registers (<code>CTRL</code>) +is used to configure the module, to trigger bus transactions and to monitor the current state of the module. +The <code>DATA</code> register is used to read/write data from/to the bus.</p> +</div> +<div class="paragraph"> +<p>The module is enabled by setting the <code>ONEWIRE_CTRL_EN</code> bit in the control register. If this bit is cleared, the +module is automatically reset and the bus is brought to high-level (due to the external pull-up resistor). +The basic timing configuration is programmed via the clock prescaler bits <code>ONEWIRE_CTRL_PRSCx</code> and the +clock divider bits <code>ONEWIRE_CTRL_CLKDIVx</code> (see next section).</p> +</div> +<div class="paragraph"> +<p>The controller can execute three basic bus operations, which are triggered by setting one out of three specific +control register bits (the bits auto-clear):</p> +</div> +<div class="olist arabic"> +<ol class="arabic" start="1"> +<li> +<p>generate reset pulse and check for device presence; triggered when setting <code>ONEWIRE_CTRL_TRIG_RST</code></p> +</li> +<li> +<p>transfer a single-bit (read-while-write); triggered when setting <code>ONEWIRE_CTRL_TRIG_BIT</code></p> +</li> +<li> +<p>transfer a full-byte (read-while-write); triggered when setting <code>ONEWIRE_CTRL_TRIG_BYTE</code></p> +</li> +</ol> +</div> +<div class="admonitionblock important"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-important" title="Important"></i> +</td> +<td class="content"> +Only one trigger bit may be set at once, otherwise undefined behavior might occur. +</td> +</tr> +</table> +</div> +<div class="paragraph"> +<p>When a single-bit operation has been triggered, the data previously written to <code>DATA[0]</code> will be send to the bus +and <code>DATA[7]</code> will be sampled from the bus. Accordingly, a full-byte transmission will send the previously +byte written to <code>DATA[7:0]</code> to the bus and will update <code>DATA[7:0]</code> with the data read from the bus (LSB-first). +The triggered operation has completed when the module&#8217;s busy flag <code>ONEWIRE_CTRL_BUSY</code> has cleared again.</p> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">Read from Bus</div> +In order to read a single bit from the bus <code>DATA[0]</code> has to set to <code>1</code> before triggering the bit transmission +operation to allow the accessed device to pull-down the bus. Accordingly, <code>DATA</code> has to be set to <code>0xFF</code> before +triggering the byte transmission operation when the controller shall read a byte from the bus. +</td> +</tr> +</table> +</div> +<div class="paragraph"> +<p>The <code>ONEWIRE_CTRL_PRESENCE</code> bit gets set if at least one device has send a "presence" signal right after the +reset pulse.</p> +</div> +<div class="paragraph"> +<p><strong>Bus Timing</strong></p> +</div> +<div class="paragraph"> +<p>The control register provides a 2-bit clock prescaler select (<code>ONEWIRE_CTRL_PRSCx</code>) and a 8-bit clock divider +(<code>ONEWIRE_CTRL_CLKDIVx</code>) for timing configuration. Both are used to define the elementary <strong>base time T<sub>base</sub></strong>. +All bus operations are timed using <em>multiples</em> of this elementary base time.</p> +</div> +<table class="tableblock frame-all grid-rows stretch"> +<caption class="title">Table 22. ONEWIRE Clock Prescaler Configurations</caption> +<colgroup> +<col style="width: 50%;"> +<col style="width: 12.5%;"> +<col style="width: 12.5%;"> +<col style="width: 12.5%;"> +<col style="width: 12.5%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-left valign-top"><strong><code>ONEWIRE_CTRL_PRSCx</code></strong></th> +<th class="tableblock halign-center valign-top"><code>0b00</code></th> +<th class="tableblock halign-center valign-top"><code>0b01</code></th> +<th class="tableblock halign-center valign-top"><code>0b10</code></th> +<th class="tableblock halign-center valign-top"><code>0b11</code></th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Resulting <code>clock_prescaler</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">2</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">4</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">8</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">64</p></td> +</tr> +</tbody> +</table> +<div class="paragraph"> +<p>Together with the clock divider value (<code>ONEWIRE_CTRL_PRSCx</code> bits = <code>clock_divider</code>) the base time is defined by the +following formula:</p> +</div> +<div class="paragraph"> +<p><em><strong>T<sub>base</sub></strong></em> = (1 / <em>f<sub>main</sub>[Hz]</em>) * <code>clock_prescaler</code> * (<code>clock_divider</code> + 1)</p> +</div> +<div class="paragraph"> +<p>Example:</p> +</div> +<div class="ulist"> +<ul> +<li> +<p><em>f<sub>main</sub></em> = 100MHz</p> +</li> +<li> +<p>clock prescaler select = <code>0b01</code> &#8594; <code>clock_prescaler</code> = 4</p> +</li> +<li> +<p>clock divider <code>clock_divider</code> = 249</p> +</li> +</ul> +</div> +<div class="paragraph"> +<p><em><strong>T<sub>base</sub></strong></em> = (1 / 100000000Hz) * 4 * (249 + 1) = 10000ns = <strong>10µs</strong></p> +</div> +<div class="paragraph"> +<p>The base time is used to coordinate all bus interactions. Hence, all delays, time slots and points in time are +quantized as multiples of the base time. The following images show the two basic operations of the ONEWIRE +controller: single-bit (0 or 1) transaction and reset with presence detect. The relevant points in time are +shown as <em>absolute</em> time (in multiples of the time base) with the bus' falling edge as reference point.</p> +</div> +<table class="tableblock frame-all grid-none stretch"> +<colgroup> +<col style="width: 50%;"> +<col style="width: 50%;"> +</colgroup> +<tbody> +<tr> +<td class="tableblock halign-center valign-top"><div class="content"><div class="imageblock text-center"> +<div class="content"> +<img src="img/onewire_data.png" alt="onewire data"> +</div> +</div></div></td> +<td class="tableblock halign-center valign-top"><div class="content"><div class="imageblock text-center"> +<div class="content"> +<img src="img/onewire_reset.png" alt="onewire reset"> +</div> +</div></div></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">Single-bit data transmission (not to scale)</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">Reset pulse and presence detect (not to scale)</p></td> +</tr> +</tbody> +</table> +<table class="tableblock frame-all grid-rows stretch"> +<caption class="title">Table 23. Data Transmission Timing</caption> +<colgroup> +<col style="width: 14.2857%;"> +<col style="width: 42.8571%;"> +<col style="width: 21.4285%;"> +<col style="width: 21.4287%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-left valign-top">Symbol</th> +<th class="tableblock halign-left valign-top">Description</th> +<th class="tableblock halign-center valign-top">Multiples of T<sub>base</sub></th> +<th class="tableblock halign-center valign-top">Time when T<sub>base</sub> = 10µs</th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-center valign-top" colspan="4"><p class="tableblock"><strong>Single-bit data transmission</strong></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>t0</code> (a&#8594;b)</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Time until end of active low-phase when writing a <code>'1'</code> or when reading</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">1</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">10µs</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>t1</code> (a&#8594;c)</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Time until controller samples bus state (read operation)</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">2</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">20µs</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>t2</code> (a&#8594;d)</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Time until end of bit time slot (when writing a <code>'0'</code> or when reading)</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">7</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">70µs</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>t3</code> (a&#8594;e)</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Time until end of inter-slot pause (= total duration of one bit)</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">9</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">90µs</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top" colspan="4"><p class="tableblock"><strong>Reset pulse and presence detect</strong></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>t4</code> (f&#8594;g)</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Time until end of active reset pulse</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">48</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">480µs</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>t5</code> (f&#8594;h)</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Time until controller samples bus presence</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">55</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">550µs</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>t6</code> (f&#8594;i)</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Time until end of presence phase</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">96</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">960µs</p></td> +</tr> +</tbody> +</table> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +The default values for base time multiples were chosen to for stable and reliable bus +operation (not for maximum throughput). +</td> +</tr> +</table> +</div> +<div class="paragraph"> +<p>The absolute points in time are hardwired by the VHDL code and cannot be changed during runtime. +However, the timing parameter can be customized by editing the ONEWIRE&#8217;s VHDL source file:</p> +</div> +<div class="listingblock"> +<div class="title">Listing 7. Hardwired time configuration in <code>neorv32_onewire.vhd</code></div> +<div class="content"> +<pre class="highlight"><code class="language-VHDL" data-lang="VHDL">-- timing configuration (absolute time in multiples of the base tick time t_base) -- +constant t_write_one_c : unsigned(6 downto 0) := to_unsigned( 1, 7); -- t0 +constant t_read_sample_c : unsigned(6 downto 0) := to_unsigned( 2, 7); -- t1 +constant t_slot_end_c : unsigned(6 downto 0) := to_unsigned( 7, 7); -- t2 +constant t_pause_end_c : unsigned(6 downto 0) := to_unsigned( 9, 7); -- t3 +constant t_reset_end_c : unsigned(6 downto 0) := to_unsigned(48, 7); -- t4 +constant t_presence_sample_c : unsigned(6 downto 0) := to_unsigned(55, 7); -- t5 +constant t_presence_end_c : unsigned(6 downto 0) := to_unsigned(96, 7); -- t6</code></pre> +</div> +</div> +<div class="admonitionblock important"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-important" title="Important"></i> +</td> +<td class="content"> +<div class="title">Overdrive</div> +The ONEWIRE controller does not support the <em>overdrive</em> mode. However, it can be implemented by reducing the base +time <strong>T<sub>base</sub></strong> (and by eventually changing the hardwired timing configuration in the VHDL source file). +</td> +</tr> +</table> +</div> +<div class="paragraph"> +<p><strong>Interrupt</strong></p> +</div> +<div class="paragraph"> +<p>A single interrupt is provided by the ONEWIRE module to signal "idle" condition to the CPU. Whenever the +controller is idle (again) the interrupt becomes active.</p> +</div> +<div class="paragraph"> +<p><strong>Register Map</strong></p> +</div> +<table class="tableblock frame-all grid-all stretch"> +<caption class="title">Table 24. ONEWIRE register map (<code>struct NEORV32_ONEWIRE</code>)</caption> +<colgroup> +<col style="width: 20%;"> +<col style="width: 10%;"> +<col style="width: 30%;"> +<col style="width: 10%;"> +<col style="width: 30%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-left valign-top">Address</th> +<th class="tableblock halign-left valign-top">Name [C]</th> +<th class="tableblock halign-left valign-top">Bit(s), Name [C]</th> +<th class="tableblock halign-center valign-top">R/W</th> +<th class="tableblock halign-left valign-top">Function</th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-left valign-top" rowspan="10"><p class="tableblock"><code>0xfffff200</code></p></td> +<td class="tableblock halign-left valign-top" rowspan="10"><p class="tableblock"><code>CTRL</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0</code> <code>ONEWIRE_CTRL_EN</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">ONEWIRE enable, reset if cleared</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>2:1</code> <code>ONEWIRE_CTRL_PRSC1 : ONEWIRE_CTRL_PRSC0</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">2-bit clock prescaler select</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>10:3</code> <code>ONEWIRE_CTRL_CLKDIV7 : ONEWIRE_CTRL_CLKDIV0</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">8-bit clock divider value</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>11</code> <code>ONEWIRE_CTRL_TRIG_RST</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">-/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">trigger reset pulse, auto-clears</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>12</code> <code>ONEWIRE_CTRL_TRIG_BIT</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">-/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">trigger single bit transmission, auto-clears</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>13</code> <code>ONEWIRE_CTRL_TRIG_BYTE</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">-/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">trigger full-byte transmission, auto-clears</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>28:14</code> -</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><em>reserved</em>, read as zero</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>29</code> <code>ONEWIRE_CTRL_SENSE</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">current state of the bus line</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>30</code> <code>ONEWIRE_CTRL_PRESENCE</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">device presence detected after reset pulse</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>31</code> <code>ONEWIRE_CTRL_BUSY</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">operation in progress when set</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0xfffff204</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>DATA</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>7:0</code> <code>ONEWIRE_DATA_MSB : ONEWIRE_DATA_LSB</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">receive/transmit data (8-bit)</p></td> +</tr> +</tbody> +</table> +<div style="page-break-after: always;"></div> +</div> +<div class="sect3"> +<h4 id="_pulse_width_modulation_controller_pwm">2.7.19. Pulse-Width Modulation Controller (PWM)</h4> +<table class="tableblock frame-ends grid-none stretch"> +<colgroup> +<col style="width: 30%;"> +<col style="width: 30%;"> +<col style="width: 40%;"> +</colgroup> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Hardware source files:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">neorv32_pwm.vhd</p></td> +<td class="tableblock halign-left valign-top"></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Software driver files:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">neorv32_pwm.c</p></td> +<td class="tableblock halign-left valign-top"></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">neorv32_pwm.h</p></td> +<td class="tableblock halign-left valign-top"></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Top entity ports:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>pwm_o</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">PWM output channels (12-bit)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Configuration generics:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>IO_PWM_NUM_CH</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">number of PWM channels to implement (0..12)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">CPU interrupts:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">none</p></td> +<td class="tableblock halign-left valign-top"></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Access restrictions:</p></td> +<td class="tableblock halign-left valign-top" colspan="2"><p class="tableblock">privileged access only, non-32-bit write accesses are ignored</p></td> +</tr> +</tbody> +</table> +<div class="paragraph"> +<p><strong>Overview</strong></p> +</div> +<div class="paragraph"> +<p>The PWM module implements a pulse-width modulation controller with up to 12 independent channels providing +8-bit resolution per channel. The actual number of implemented channels is defined by the <code>IO_PWM_NUM_CH</code> generic. +Setting this generic to zero will completely remove the PWM controller from the design.</p> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +The <code>pwm_o</code> has a static size of 12-bit. If less than 12 PWM channels are configured, only the LSB-aligned channel +bits are used while the remaining bits are hardwired to zero. +</td> +</tr> +</table> +</div> +<div class="paragraph"> +<p><strong>Theory of Operation</strong></p> +</div> +<div class="paragraph"> +<p>The PWM controller is activated by setting the <code>PWM_CTRL_EN</code> bit in the module&#8217;s control register <code>CTRL</code>. When this +bit is cleared, the unit is reset and all PWM output channels are set to zero. The module +provides three duty cycle registers <code>DC[0]</code> to <code>DC[2]</code>. Each register contains the duty cycle configuration for four +consecutive channels. For example, the duty cycle of channel 0 is defined via bits 7:0 in <code>DC[0]</code>. The duty cycle of +channel 2 is defined via bits 15:0 in <code>DC[0]</code> and so on.</p> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +Regardless of the configuration of <code>IO_PWM_NUM_CH</code> all module registers can be accessed without raising an exception. +Software can discover the number of available channels by writing 0xff to all duty cycle configuration bytes and +reading those values back. The duty-cycle of channels that were not implemented always reads as zero. +</td> +</tr> +</table> +</div> +<div class="paragraph"> +<p>Based on the configured duty cycle the according intensity of the channel can be computed by the following formula:</p> +</div> +<div class="paragraph"> +<p><em><strong>Intensity<sub>x</sub></strong></em> = <code>DC[y](i*8+7 downto i*8)</code> / (2<sup>8</sup>)</p> +</div> +<div class="paragraph"> +<p>The base frequency of the generated PWM signals is defined by the PWM core clock. This clock is derived +from the main processor clock and divided by a prescaler via the 3-bit <code>PWM_CTRL_PRSCx</code> in the unit&#8217;s control +register.</p> +</div> +<table class="tableblock frame-all grid-rows stretch"> +<caption class="title">Table 25. PWM prescaler configuration</caption> +<colgroup> +<col style="width: 33.3333%;"> +<col style="width: 8.3333%;"> +<col style="width: 8.3333%;"> +<col style="width: 8.3333%;"> +<col style="width: 8.3333%;"> +<col style="width: 8.3333%;"> +<col style="width: 8.3333%;"> +<col style="width: 8.3333%;"> +<col style="width: 8.3336%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-left valign-top"><strong><code>PWM_CTRL_PRSCx</code></strong></th> +<th class="tableblock halign-center valign-top"><code>0b000</code></th> +<th class="tableblock halign-center valign-top"><code>0b001</code></th> +<th class="tableblock halign-center valign-top"><code>0b010</code></th> +<th class="tableblock halign-center valign-top"><code>0b011</code></th> +<th class="tableblock halign-center valign-top"><code>0b100</code></th> +<th class="tableblock halign-center valign-top"><code>0b101</code></th> +<th class="tableblock halign-center valign-top"><code>0b110</code></th> +<th class="tableblock halign-center valign-top"><code>0b111</code></th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Resulting <code>clock_prescaler</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">2</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">4</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">8</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">64</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">128</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">1024</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">2048</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">4096</p></td> +</tr> +</tbody> +</table> +<div class="paragraph"> +<p>The resulting PWM carrier frequency is defined by:</p> +</div> +<div class="paragraph"> +<p><em><strong>f<sub>PWM</sub></strong></em> = <em>f<sub>main</sub>[Hz]</em> / (2<sup>8</sup> * <code>clock_prescaler</code>)</p> +</div> +<div class="paragraph"> +<p><strong>Register Map</strong></p> +</div> +<table class="tableblock frame-all grid-all stretch"> +<caption class="title">Table 26. PWM register map (<code>struct neorv32_pwm_t</code>)</caption> +<colgroup> +<col style="width: 18.1818%;"> +<col style="width: 9.0909%;"> +<col style="width: 27.2727%;"> +<col style="width: 9.0909%;"> +<col style="width: 36.3637%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-left valign-top">Address</th> +<th class="tableblock halign-left valign-top">Name [C]</th> +<th class="tableblock halign-left valign-top">Bit(s), Name [C]</th> +<th class="tableblock halign-center valign-top">R/W</th> +<th class="tableblock halign-left valign-top">Function</th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-left valign-top" rowspan="3"><p class="tableblock"><code>0xfffff000</code></p></td> +<td class="tableblock halign-left valign-top" rowspan="3"><p class="tableblock"><code>CTRL</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0</code> <code>PWM_CTRL_EN</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">PWM enable</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>3:1</code> <code>PWM_CTRL_PRSC2 : PWM_CTRL_PRSC0</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">3-bit clock prescaler select</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>31:4</code> -</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><em>reserved</em>, read as zero</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top" rowspan="4"><p class="tableblock"><code>0xfffff004</code></p></td> +<td class="tableblock halign-left valign-top" rowspan="4"><p class="tableblock"><code>DC[0]</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>7:0</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">8-bit duty cycle for channel 0</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>15:8</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">8-bit duty cycle for channel 1</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>23:16</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">8-bit duty cycle for channel 2</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>31:24</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">8-bit duty cycle for channel 3</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top" rowspan="4"><p class="tableblock"><code>0xfffff008</code></p></td> +<td class="tableblock halign-left valign-top" rowspan="4"><p class="tableblock"><code>DC[1]</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>7:0</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">8-bit duty cycle for channel 4</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>15:8</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">8-bit duty cycle for channel 5</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>23:16</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">8-bit duty cycle for channel 6</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>31:24</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">8-bit duty cycle for channel 7</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top" rowspan="4"><p class="tableblock"><code>0xfffff00c</code></p></td> +<td class="tableblock halign-left valign-top" rowspan="4"><p class="tableblock"><code>DC[2]</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>7:0</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">8-bit duty cycle for channel 8</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>15:8</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">8-bit duty cycle for channel 9</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>23:16</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">8-bit duty cycle for channel 10</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>31:24</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">8-bit duty cycle for channel 11</p></td> +</tr> +</tbody> +</table> +<div style="page-break-after: always;"></div> +</div> +<div class="sect3"> +<h4 id="_true_random_number_generator_trng">2.7.20. True Random-Number Generator (TRNG)</h4> +<table class="tableblock frame-ends grid-none stretch"> +<colgroup> +<col style="width: 30%;"> +<col style="width: 30%;"> +<col style="width: 40%;"> +</colgroup> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Hardware source files:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">neorv32_trng.vhd</p></td> +<td class="tableblock halign-left valign-top"></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Software driver files:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">neorv32_trng.c</p></td> +<td class="tableblock halign-left valign-top"></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">neorv32_trng.h</p></td> +<td class="tableblock halign-left valign-top"></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Top entity ports:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">none</p></td> +<td class="tableblock halign-left valign-top"></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Configuration generics:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>IO_TRNG_EN</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">implement TRNG when <code>true</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>IO_TRNG_FIFO</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">data FIFO depth, min 1, has to be a power of two</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">CPU interrupts:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">fast IRQ channel 0</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">TRNG data available interrupt (see <a href="#_processor_interrupts">Processor Interrupts</a>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Access restrictions:</p></td> +<td class="tableblock halign-left valign-top" colspan="2"><p class="tableblock">privileged access only, non-32-bit write accesses are ignored</p></td> +</tr> +</tbody> +</table> +<div class="paragraph"> +<p><strong>Overview</strong></p> +</div> +<div class="paragraph"> +<p>The NEORV32 true random number generator provides <em>physically</em> true random numbers. It is based on free-running +ring-oscillators that generate <strong>phase noise</strong> when being sampled by a constant clock. This phase noise is +used as physical entropy source. The TRNG features a platform independent architecture without FPGA-specific +primitives, macros or attributes so it can be synthesized for <em>any</em> FPGA.</p> +</div> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +<div class="title">In-Depth Documentation</div> +For more information about the neoTRNG architecture and an analysis of its random quality check out the +neoTRNG repository: <a href="https://github.com/stnolting/neoTRNG" class="bare">https://github.com/stnolting/neoTRNG</a> +</td> +</tr> +</table> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">Inferring Latches</div> +The synthesis tool might emit warnings regarding <strong>inferred latches</strong> or <strong>combinatorial loops</strong>. However, this +is not design flaw as this is exactly what we want. ;) +</td> +</tr> +</table> +</div> +<div class="admonitionblock important"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-important" title="Important"></i> +</td> +<td class="content"> +<div class="title">Simulation</div> +When simulating the processor the TRNG is automatically set to "simulation mode". In this mode the physical entropy +sources (the ring oscillators) are replaced by a simple <strong>pseudo RNG</strong> based on a LFSR providing only +<strong>deterministic pseudo-random</strong> data. The <code>TRNG_CTRL_SIM_MODE</code> flag of the control register is set if simulation +mode is active. +</td> +</tr> +</table> +</div> +<div class="paragraph"> +<p><strong>Theory of Operation</strong></p> +</div> +<div class="paragraph"> +<p>The TRNG features a single control register <code>CTRL</code> for control, status check and data access. When the <code>TRNG_CTRL_EN</code> +bit is set, the TRNG is enabled and starts operation. As soon as the <code>TRNG_CTRL_VALID</code> bit is set a new random data byte +is available and can be obtained from the lowest 8 bits of the <code>CTRL</code> register. If this bit is cleared, there is no +valid data available and the lowest 8 bit of the <code>CTRL</code> register are set to all-zero.</p> +</div> +<div class="paragraph"> +<p>An internal entropy FIFO can be configured using the <code>IO_TRNG_FIFO</code> generic. This FIFO automatically samples +new random data from the TRNG to provide some kind of <em>random data pool</em> for applications, which require a large number +of random data in a short time. The random data FIFO can be cleared at any time either by disabling the TRNG or by +setting the <code>TRNG_CTRL_FIFO_CLR</code> flag. The FIFO depth can be retrieved by software via the <code>TRNG_CTRL_FIFO_*</code> bits.</p> +</div> +<div class="paragraph"> +<p><strong>TRNG Interrupt</strong></p> +</div> +<div class="paragraph"> +<p>As the neoTRNG is a rather slow entropy source, a "data available" interrupt is provided to inform the application +software that new random data is available. This interrupt can be trigger by either of two conditions: trigger the +interrupt if <em>any</em> random data is available (i.e. the data FIFO is not empty; <code>TRNG_CTRL_IRQ_SEL = 0</code>) or trigger +the interrupt if the random pool is full (i.e. the data FIFO is full; <code>TRNG_CTRL_IRQ_SEL = 1</code>). +Once the TRNG interrupt has fired it remains pending until the actual cause of the interrupt is resolved.</p> +</div> +<div class="paragraph"> +<p><strong>Register Map</strong></p> +</div> +<table class="tableblock frame-all grid-all stretch"> +<caption class="title">Table 27. TRNG register map (<code>struct NEORV32_TRNG</code>)</caption> +<colgroup> +<col style="width: 13.3333%;"> +<col style="width: 6.6666%;"> +<col style="width: 26.6666%;"> +<col style="width: 6.6666%;"> +<col style="width: 46.6669%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-left valign-top">Address</th> +<th class="tableblock halign-left valign-top">Name [C]</th> +<th class="tableblock halign-left valign-top">Bit(s), Name [C]</th> +<th class="tableblock halign-center valign-top">R/W</th> +<th class="tableblock halign-left valign-top">Function</th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-left valign-top" rowspan="9"><p class="tableblock"><code>0xfffffa00</code></p></td> +<td class="tableblock halign-left valign-top" rowspan="9"><p class="tableblock"><code>CTRL</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>7:0</code> <code>TRNG_CTRL_DATA_MSB : TRNG_CTRL_DATA_MSB</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">8-bit random data</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>15:8</code> -</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">reserved, read as zero</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>19:16</code> <code>TRNG_CTRL_FIFO_MSB : TRNG_CTRL_FIFO_MSB</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">FIFO depth, log2(<code>IO_TRNG_FIFO</code>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>27:20</code> -</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">reserved, read as zero</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>27</code> <code>TRNG_CTRL_IRQ_SEL</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">interrupt trigger select (0 = data available, 1 = FIFO full)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>28</code> <code>TRNG_CTRL_FIFO_CLR</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">-/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">flush random data FIFO when set; flag auto-clears</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>29</code> <code>TRNG_CTRL_SIM_MODE</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">simulation mode (PRNG!)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>30</code> <code>TRNG_CTRL_EN</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">TRNG enable</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>31</code> <code>TRNG_CTRL_VALID</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">random data is valid when set</p></td> +</tr> +</tbody> +</table> +<div style="page-break-after: always;"></div> +</div> +<div class="sect3"> +<h4 id="_custom_functions_subsystem_cfs">2.7.21. Custom Functions Subsystem (CFS)</h4> +<table class="tableblock frame-ends grid-none stretch"> +<colgroup> +<col style="width: 30%;"> +<col style="width: 30%;"> +<col style="width: 40%;"> +</colgroup> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Hardware source files:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">neorv32_cfs.vhd</p></td> +<td class="tableblock halign-left valign-top"></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Software driver files:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">neorv32_cfs.c</p></td> +<td class="tableblock halign-left valign-top"></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">neorv32_cfs.h</p></td> +<td class="tableblock halign-left valign-top"></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Top entity ports:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>cfs_in_i</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">custom input conduit</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>cfs_out_o</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">custom output conduit</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Configuration generics:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>IO_CFS_EN</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">implement CFS when <code>true</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>IO_CFS_CONFIG</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">custom generic conduit</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>IO_CFS_IN_SIZE</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">size of <code>cfs_in_i</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>IO_CFS_OUT_SIZE</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">size of <code>cfs_out_o</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">CPU interrupts:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">fast IRQ channel 1</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">CFS interrupt (see <a href="#_processor_interrupts">Processor Interrupts</a>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Access restrictions:</p></td> +<td class="tableblock halign-left valign-top" colspan="2"><p class="tableblock">privileged access only, non-32-bit write accesses are ignored</p></td> +</tr> +</tbody> +</table> +<div class="paragraph"> +<p><strong>Overview</strong></p> +</div> +<div class="paragraph"> +<p>The custom functions subsystem is meant for implementing custom tightly-coupled co-processors or interfaces. +IT provides up to 64 32-bit memory-mapped read/write registers (<code>REG</code>, see register map below) that can be +accessed by the CPU via normal load/store operations. The actual functionality of these register has to be +defined by the hardware designer. Furthermore, the CFS provides two IO conduits to implement custom on-chip +or off-chip interfaces.</p> +</div> +<div class="paragraph"> +<p>Just like any other externally-connected IP, logic implemented within the custom functions subsystem can operate +<em>independently</em> of the CPU providing true parallel processing capabilities. Potential use cases might include +dedicated hardware accelerators for en-/decryption (AES), signal processing (FFT) or AI applications +(CNNs) as well as custom IO systems like fast memory interfaces (DDR) and mass storage (SDIO), networking (CAN) +or real-time data transport (I2S).</p> +</div> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +If you like to implement <em>custom instructions</em> that are executed right within the CPU&#8217;s ALU +see the <a href="#_zxcfu_isa_extension"><code>Zxcfu</code> ISA Extension</a> and the according <a href="#_custom_functions_unit_cfu">Custom Functions Unit (CFU)</a>. +</td> +</tr> +</table> +</div> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +Take a look at the template CFS VHDL source file (<code>rtl/core/neorv32_cfs.vhd</code>). The file is highly +commented to illustrate all aspects that are relevant for implementing custom CFS-based co-processor designs. +</td> +</tr> +</table> +</div> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +The CFS can also be used to <em>replicate</em> existing NEORV32 modules - for example to implement several TWI controllers. +</td> +</tr> +</table> +</div> +<div class="paragraph"> +<p><strong>CFS Software Access</strong></p> +</div> +<div class="paragraph"> +<p>The CFS memory-mapped registers can be accessed by software using the provided C-language aliases (see +register map table below). Note that all interface registers are defined as 32-bit words of type <code>uint32_t</code>.</p> +</div> +<div class="listingblock"> +<div class="title">Listing 8. CFS Software Access Example</div> +<div class="content"> +<pre class="highlight"><code class="language-c" data-lang="c">// C-code CFS usage example +NEORV32_CFS-&gt;REG[0] = (uint32_t)some_data_array(i); // write to CFS register 0 +int temp = (int)NEORV32_CFS-&gt;REG[20]; // read from CFS register 20</code></pre> +</div> +</div> +<div class="paragraph"> +<p><strong>CFS Interrupt</strong></p> +</div> +<div class="paragraph"> +<p>The CFS provides a single high-level-triggered interrupt request signal mapped to the CPU&#8217;s fast interrupt channel 1.</p> +</div> +<div class="paragraph"> +<p><strong>CFS Configuration Generic</strong></p> +</div> +<div class="paragraph"> +<p>By default, the CFS provides a single 32-bit <code>std_ulogic_vector</code> configuration generic <code>IO_CFS_CONFIG</code> +that is available in the processor&#8217;s top entity. This generic can be used to pass custom configuration options +from the top entity directly down to the CFS. The actual definition of the generic and it&#8217;s usage inside the +CFS is left to the hardware designer.</p> +</div> +<div class="paragraph"> +<p><strong>CFS Custom IOs</strong></p> +</div> +<div class="paragraph"> +<p>By default, the CFS also provides two unidirectional input and output conduits <code>cfs_in_i</code> and <code>cfs_out_o</code>. +These signals are directly propagated to the processor&#8217;s top entity. These conduits can be used to implement +application-specific interfaces like memory or peripheral connections. The actual use case of these signals +has to be defined by the hardware designer.</p> +</div> +<div class="paragraph"> +<p>The size of the input signal conduit <code>cfs_in_i</code> is defined via the top&#8217;s <code>IO_CFS_IN_SIZE</code> configuration +generic (default = 32-bit). The size of the output signal conduit <code>cfs_out_o</code> is defined via the top&#8217;s +<code>IO_CFS_OUT_SIZE</code> configuration generic (default = 32-bit). If the custom function subsystem is not implemented +(<code>IO_CFS_EN</code> = false) the <code>cfs_out_o</code> signal is tied to all-zero.</p> +</div> +<div class="paragraph"> +<p><strong>Register Map</strong></p> +</div> +<table class="tableblock frame-all grid-all stretch"> +<caption class="title">Table 28. CFS register map (<code>struct NEORV32_CFS</code>)</caption> +<colgroup> +<col style="width: 25%;"> +<col style="width: 12.5%;"> +<col style="width: 12.5%;"> +<col style="width: 12.5%;"> +<col style="width: 37.5%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-center valign-top">Address</th> +<th class="tableblock halign-left valign-top">Name [C]</th> +<th class="tableblock halign-center valign-top">Bit(s)</th> +<th class="tableblock halign-center valign-top">R/W</th> +<th class="tableblock halign-left valign-top">Function</th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>0xffffeb00</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>REG[0]</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>31:0</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">(r)/(w)</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">custom CFS register 0</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>0xffffeb04</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>REG[1]</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>31:0</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">(r)/(w)</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">custom CFS register 1</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">&#8230;&#8203;</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">&#8230;&#8203;</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>31:0</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">(r)/(w)</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">&#8230;&#8203;</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>0xffffebf8</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>REG[62]</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>31:0</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">(r)/(w)</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">custom CFS register 62</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>0xffffebfc</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>REG[63]</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>31:0</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">(r)/(w)</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">custom CFS register 63</p></td> +</tr> +</tbody> +</table> +<div style="page-break-after: always;"></div> +</div> +<div class="sect3"> +<h4 id="_smart_led_interface_neoled">2.7.22. Smart LED Interface (NEOLED)</h4> +<table class="tableblock frame-ends grid-none stretch"> +<colgroup> +<col style="width: 30%;"> +<col style="width: 30%;"> +<col style="width: 40%;"> +</colgroup> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Hardware source files:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">neorv32_neoled.vhd</p></td> +<td class="tableblock halign-left valign-top"></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Software driver files:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">neorv32_neoled.c</p></td> +<td class="tableblock halign-left valign-top"></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">neorv32_neoled.h</p></td> +<td class="tableblock halign-left valign-top"></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Top entity ports:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>neoled_o</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">1-bit serial data output</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Configuration generics:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>IO_NEOLED_EN</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">implement NEOLED controller when <code>true</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>IO_NEOLED_TX_FIFO</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">TX FIFO depth, has to be a power of 2, min 1</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">CPU interrupts:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">fast IRQ channel 9</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">configurable NEOLED data FIFO interrupt (see <a href="#_processor_interrupts">Processor Interrupts</a>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Access restrictions:</p></td> +<td class="tableblock halign-left valign-top" colspan="2"><p class="tableblock">privileged access only, non-32-bit write accesses are ignored</p></td> +</tr> +</tbody> +</table> +<div class="paragraph"> +<p><strong>Overview</strong></p> +</div> +<div class="paragraph"> +<p>The NEOLED module provides a dedicated interface for "smart RGB LEDs" like WS2812, WS2811 or any other compatible +LEDs. These LEDs provide a single-wire interface that uses an asynchronous serial protocol for transmitting color +data. Using the NEOLED module allows CPU-independent operation of an arbitrary number of smart LEDs. A configurable data +buffer (FIFO) allows to utilize block transfer operation without requiring the CPU.</p> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +The NEOLED interface is compatible to the "Adafruit Industries NeoPixel&#8482;" products, which feature +WS2812 (or older WS2811) smart LEDs. Other LEDs might be compatible as well when adjusting the controller&#8217;s programmable +timing configuration. +</td> +</tr> +</table> +</div> +<div class="paragraph"> +<p>The interface provides a single 1-bit output <code>neoled_o</code> to drive an arbitrary number of cascaded LEDs. Since the +NEOLED module provides 24-bit and 32-bit operating modes, a mixed setup with RGB LEDs (24-bit color) +and RGBW LEDs (32-bit color including a dedicated white LED chip) is possible.</p> +</div> +<div class="paragraph"> +<p><strong>Theory of Operation</strong></p> +</div> +<div class="paragraph"> +<p>The NEOLED modules provides two accessible interface registers: the control register <code>CTRL</code> and the write-only +TX data register <code>DATA</code>. The NEOLED module is globally enabled via the control register&#8217;s +<code>NEOLED_CTRL_EN</code> bit. Clearing this bit will terminate any current operation, clear the TX buffer, reset the module +and set the <code>neoled_o</code> output to zero. The precise timing (e.g. implementing the <strong>WS2812</strong> protocol) and transmission +mode are fully programmable via the <code>CTRL</code> register to provide maximum flexibility.</p> +</div> +<div class="paragraph"> +<p><strong>RGB / RGBW Configuration</strong></p> +</div> +<div class="paragraph"> +<p>NeoPixel&#8482; LEDs are available in two "color" version: LEDs with three chips providing RGB color and LEDs with +four chips providing RGB color plus a dedicated white LED chip (= RGBW). Since the intensity of every +LED chip is defined via an 8-bit value the RGB LEDs require a frame of 24-bit per module and the RGBW +LEDs require a frame of 32-bit per module.</p> +</div> +<div class="paragraph"> +<p>The data transfer quantity of the NEOLED module can be programmed via the <code>NEOLED_MODE_EN</code> control +register bit. If this bit is cleared, the NEOLED interface operates in 24-bit mode and will transmit bits <code>23:0</code> of +the data written to <code>DATA</code> to the LEDs. If <code>NEOLED_MODE_EN</code> is set, the NEOLED interface operates in 32-bit +mode and will transmit bits <code>31:0</code> of the data written to <code>DATA</code> to the LEDs.</p> +</div> +<div class="paragraph"> +<p>The mode bit can be reconfigured before writing a new data word to <code>DATA</code> in order to support an arbitrary setup/mixture +of RGB and RGBW LEDs.</p> +</div> +<div class="paragraph"> +<p><strong>Protocol</strong></p> +</div> +<div class="paragraph"> +<p>The interface of the WS2812 LEDs uses an 800kHz carrier signal. Data is transmitted in a serial manner +starting with LSB-first. The intensity for each R, G &amp; B (&amp; W) LED chip (= color code) is defined via an 8-bit +value. The actual data bits are transferred by modifying the duty cycle of the signal (the timings for the +WS2812 are shown below). A RESET command is "send" by pulling the data line LOW for at least 50μs.</p> +</div> +<div class="imageblock text-left"> +<div class="content"> +<img src="img/neopixel_timing.png" alt="neopixel timing"> +</div> +<div class="title">Figure 8. WS2812 bit-level timing (timing does not scale)</div> +</div> +<table class="tableblock frame-all grid-all stretch"> +<caption class="title">Table 29. WS2812 interface timing</caption> +<colgroup> +<col style="width: 20%;"> +<col style="width: 20%;"> +<col style="width: 60%;"> +</colgroup> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">T<sub>total</sub> (T<sub>carrier</sub>)</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">1.25μs +/- 300ns</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">period for a single bit</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">T<sub>0H</sub></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">0.4μs +/- 150ns</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">high-time for sending a <code>1</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">T<sub>0L</sub></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">0.8μs +/- 150ns</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">low-time for sending a <code>1</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">T<sub>1H</sub></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">0.85μs +/- 150ns</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">high-time for sending a <code>0</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">T<sub>1L</sub></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">0.45μs +/- 150 ns</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">low-time for sending a <code>0</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">RESET</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Above 50μs</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">low-time for sending a RESET command</p></td> +</tr> +</tbody> +</table> +<div class="paragraph"> +<p><strong>Timing Configuration</strong></p> +</div> +<div class="paragraph"> +<p>The basic carrier frequency (800kHz for the WS2812 LEDs) is configured via a 3-bit main clock prescaler +(<code>NEOLED_CTRL_PRSC*</code>, see table below) that scales the main processor clock f<sub>main</sub> and a 5-bit cycle +multiplier <code>NEOLED_CTRL_T_TOT_*</code>.</p> +</div> +<table class="tableblock frame-all grid-rows stretch"> +<caption class="title">Table 30. NEOLED Prescaler Configuration</caption> +<colgroup> +<col style="width: 33.3333%;"> +<col style="width: 8.3333%;"> +<col style="width: 8.3333%;"> +<col style="width: 8.3333%;"> +<col style="width: 8.3333%;"> +<col style="width: 8.3333%;"> +<col style="width: 8.3333%;"> +<col style="width: 8.3333%;"> +<col style="width: 8.3336%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-left valign-top"><strong><code>NEOLED_CTRL_PRSCx</code></strong></th> +<th class="tableblock halign-center valign-top"><code>0b000</code></th> +<th class="tableblock halign-center valign-top"><code>0b001</code></th> +<th class="tableblock halign-center valign-top"><code>0b010</code></th> +<th class="tableblock halign-center valign-top"><code>0b011</code></th> +<th class="tableblock halign-center valign-top"><code>0b100</code></th> +<th class="tableblock halign-center valign-top"><code>0b101</code></th> +<th class="tableblock halign-center valign-top"><code>0b110</code></th> +<th class="tableblock halign-center valign-top"><code>0b111</code></th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Resulting <code>clock_prescaler</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">2</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">4</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">8</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">64</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">128</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">1024</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">2048</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">4096</p></td> +</tr> +</tbody> +</table> +<div class="paragraph"> +<p>The duty-cycles (or more precisely: the high- and low-times for sending either a '1' bit or a '0' bit) are +defined via the 5-bit <code>NEOLED_CTRL_T_ONE_H_*</code> and <code>NEOLED_CTRL_T_ZERO_H_*</code> values, respectively. These programmable +timing constants allow to adapt the interface for a wide variety of smart LED protocol (for example WS2812 vs. +WS2811).</p> +</div> +<div class="paragraph"> +<p><strong>Timing Configuration - Example (WS2812)</strong></p> +</div> +<div class="paragraph"> +<p>Generate the base clock f<sub>TX</sub> for the NEOLED TX engine:</p> +</div> +<div class="ulist"> +<ul> +<li> +<p>processor clock f<sub>main</sub> = 100 MHz</p> +</li> +<li> +<p><code>NEOLED_CTRL_PRSCx</code> = <code>0b001</code> = f<sub>main</sub> / 4</p> +</li> +</ul> +</div> +<div class="paragraph"> +<p><em><strong>f<sub>TX</sub></strong></em> = <em>f<sub>main</sub>[Hz]</em> / <code>clock_prescaler</code> = 100MHz / 4 = 25MHz</p> +</div> +<div class="paragraph"> +<p><em><strong>T<sub>TX</sub></strong></em> = 1 / <em><strong>f<sub>TX</sub></strong></em> = 40ns</p> +</div> +<div class="paragraph"> +<p>Generate carrier period (T<sub>carrier</sub>) and <strong>high-times</strong> (duty cycle) for sending <code>0</code> (T<sub>0H</sub>) and <code>1</code> (T<sub>1H</sub>) bits:</p> +</div> +<div class="ulist"> +<ul> +<li> +<p><code>NEOLED_CTRL_T_TOT</code> = <code>0b11110</code> (= decimal 30)</p> +</li> +<li> +<p><code>NEOLED_CTRL_T_ZERO_H</code> = <code>0b01010</code> (= decimal 10)</p> +</li> +<li> +<p><code>NEOLED_CTRL_T_ONE_H</code> = <code>0b10100</code> (= decimal 20)</p> +</li> +</ul> +</div> +<div class="paragraph"> +<p><em><strong>T<sub>carrier</sub></strong></em> = <em><strong>T<sub>TX</sub></strong></em> * <code>NEOLED_CTRL_T_TOT</code> = 40ns * 30 = 1.4µs</p> +</div> +<div class="paragraph"> +<p><em><strong>T<sub>0H</sub></strong></em> = <em><strong>T<sub>TX</sub></strong></em> * <code>NEOLED_CTRL_T_ZERO_H</code> = 40ns * 10 = 0.4µs</p> +</div> +<div class="paragraph"> +<p><em><strong>T<sub>1H</sub></strong></em> = <em><strong>T<sub>TX</sub></strong></em> * <code>NEOLED_CTRL_T_ONE_H</code> = 40ns * 20 = 0.8µs</p> +</div> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +The NEOLED SW driver library (<code>neorv32_neoled.h</code>) provides a simplified configuration +function that configures all timing parameters for driving WS2812 LEDs based on the processor +clock frequency. +</td> +</tr> +</table> +</div> +<div class="paragraph"> +<p><strong>TX Data FIFO</strong></p> +</div> +<div class="paragraph"> +<p>The interface features a configurable TX data buffer (a FIFO) to allow more CPU-independent operation. The buffer +depth is configured via the <code>IO_NEOLED_TX_FIFO</code> top generic (default = 1 entry). The FIFO size configuration can be +read via the <code>NEOLED_CTRL_BUFS_x</code> control register bits, which result log2(<em>IO_NEOLED_TX_FIFO</em>).</p> +</div> +<div class="paragraph"> +<p>When writing data to the <code>DATA</code> register the data is automatically written to the TX buffer. Whenever +data is available in the buffer the serial transmission engine will take and transmit it to the LEDs. +The data transfer size (<code>NEOLED_MODE_EN</code>) can be modified at any time since this control register bit is also buffered +in the FIFO. This allows an arbitrary mix of RGB and RGBW LEDs in the chain.</p> +</div> +<div class="paragraph"> +<p>Software can check the FIFO fill level via the control register&#8217;s <code>NEOLED_CTRL_TX_EMPTY</code>, <code>NEOLED_CTRL_TX_HALF</code> +and <code>NEOLED_CTRL_TX_FULL</code> flags. The <code>NEOLED_CTRL_TX_BUSY</code> flags provides additional information if the the serial +transmit engine is still busy sending data.</p> +</div> +<div class="admonitionblock warning"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-warning" title="Warning"></i> +</td> +<td class="content"> +Please note that the timing configurations (<code>NEOLED_CTRL_PRSCx</code>, <code>NEOLED_CTRL_T_TOT_x</code>, +<code>NEOLED_CTRL_T_ONE_H_x</code> and <code>NEOLED_CTRL_T_ZERO_H_x</code>) are <strong>NOT</strong> stored to the buffer. Changing +these value while the buffer is not empty or the TX engine is still busy will cause data corruption. +</td> +</tr> +</table> +</div> +<div class="paragraph"> +<p><strong>Strobe Command ("RESET")</strong></p> +</div> +<div class="paragraph"> +<p>According to the WS2812 specs the data written to the LED&#8217;s shift registers is strobed to the actual PWM driver +registers when the data line is low for 50μs ("RESET" command, see table above). This can be implemented +using busy-wait for at least 50μs. Obviously, this concept wastes a lot of processing power.</p> +</div> +<div class="paragraph"> +<p>To circumvent this, the NEOLED module provides an option to automatically issue an idle time for creating the RESET +command. If the <code>NEOLED_CTRL_STROBE</code> control register bit is set, <em>all</em> data written to the data FIFO (via <code>DATA</code>, +the actually written data is irrelevant) will trigger an idle phase (<code>neoled_o</code> = zero) of 127 periods (= <em><strong>T<sub>carrier</sub></strong></em>). +This idle time will cause the LEDs to strobe the color data into the PWM driver registers.</p> +</div> +<div class="paragraph"> +<p>Since the <code>NEOLED_CTRL_STROBE</code> flag is also buffered in the TX buffer, the RESET command is treated just as another +data word being written to the TX buffer making busy wait concepts obsolete and allowing maximum refresh rates.</p> +</div> +<div class="paragraph"> +<p><strong>NEOLED Interrupt</strong></p> +</div> +<div class="paragraph"> +<p>The NEOLED modules features a single interrupt that triggers based on the current TX buffer fill level. +The interrupt can only become pending if the NEOLED module is enabled. The specific interrupt condition +is configured via the <code>NEOLED_CTRL_IRQ_CONF</code> bit in the unit&#8217;s control register.</p> +</div> +<div class="paragraph"> +<p>If <code>NEOLED_CTRL_IRQ_CONF</code> is set, the module&#8217;s interrupt is generated whenever the TX FIFO is less than half-full. +In this case software can write up to <code>IO_NEOLED_TX_FIFO</code>/2 new data words to <code>DATA</code> without checking the FIFO +status flags. If <code>NEOLED_CTRL_IRQ_CONF</code> is cleared, an interrupt is generated when the TX FIFO is empty.</p> +</div> +<div class="paragraph"> +<p>Once the NEOLED interrupt has fired it remains pending until the actual cause of the interrupt is resolved.</p> +</div> +<div class="paragraph"> +<p><strong>Register Map</strong></p> +</div> +<table class="tableblock frame-all grid-all stretch"> +<caption class="title">Table 31. NEOLED register map (<code>struct NEORV32_NEOLED</code>)</caption> +<colgroup> +<col style="width: 14.2857%;"> +<col style="width: 7.1428%;"> +<col style="width: 35.7142%;"> +<col style="width: 7.1428%;"> +<col style="width: 35.7145%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-left valign-top">Address</th> +<th class="tableblock halign-left valign-top">Name [C]</th> +<th class="tableblock halign-left valign-top">Bit(s), Name [C]</th> +<th class="tableblock halign-center valign-top">R/W</th> +<th class="tableblock halign-left valign-top">Function</th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-left valign-top" rowspan="13"><p class="tableblock"><code>0xfffffd00</code></p></td> +<td class="tableblock halign-left valign-top" rowspan="13"><p class="tableblock"><code>CTRL</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0</code> <code>NEOLED_CTRL_EN</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">NEOLED enable</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>1</code> <code>NEOLED_CTRL_MODE</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">data transfer size; <code>0</code>=24-bit; <code>1</code>=32-bit</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>2</code> <code>NEOLED_CTRL_STROBE</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0</code>=send normal color data; <code>1</code>=send RESET command on data write access</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>5:3</code> <code>NEOLED_CTRL_PRSC2 : NEOLED_CTRL_PRSC0</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">3-bit clock prescaler, bit 0</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>9:6</code> <code>NEOLED_CTRL_BUFS3 : NEOLED_CTRL_BUFS0</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">4-bit log2(<em>IO_NEOLED_TX_FIFO</em>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>14:10</code> <code>NEOLED_CTRL_T_TOT_4 : NEOLED_CTRL_T_TOT_0</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">5-bit pulse clock ticks per total single-bit period (T<sub>total</sub>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>19:15</code> <code>NEOLED_CTRL_T_ZERO_H_4 : NEOLED_CTRL_T_ZERO_H_0</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">5-bit pulse clock ticks per high-time for sending a zero-bit (T<sub>0H</sub>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>24:20</code> <code>NEOLED_CTRL_T_ONE_H_4 : NEOLED_CTRL_T_ONE_H_0</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">5-bit pulse clock ticks per high-time for sending a one-bit (T<sub>1H</sub>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>27</code> <code>NEOLED_CTRL_IRQ_CONF</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">TX FIFO interrupt configuration: <code>0</code>=IRQ if FIFO is empty, <code>1</code>=IRQ if FIFO is less than half-full</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>28</code> <code>NEOLED_CTRL_TX_EMPTY</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">TX FIFO is empty</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>29</code> <code>NEOLED_CTRL_TX_HALF</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">TX FIFO is <em>at least</em> half full</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>30</code> <code>NEOLED_CTRL_TX_FULL</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">TX FIFO is full</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>31</code> <code>NEOLED_CTRL_TX_BUSY</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">TX serial engine is busy when set</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0xfffffd04</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>DATA</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>31:0</code> / <code>23:0</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">-/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">TX data (32- or 24-bit, depending on <em>NEOLED_CTRL_MODE</em> bit)</p></td> +</tr> +</tbody> +</table> +<div style="page-break-after: always;"></div> +</div> +<div class="sect3"> +<h4 id="_external_interrupt_controller_xirq">2.7.23. External Interrupt Controller (XIRQ)</h4> +<table class="tableblock frame-ends grid-none stretch"> +<colgroup> +<col style="width: 30%;"> +<col style="width: 30%;"> +<col style="width: 40%;"> +</colgroup> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Hardware source files:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">neorv32_xirq.vhd</p></td> +<td class="tableblock halign-left valign-top"></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Software driver files:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">neorv32_xirq.c</p></td> +<td class="tableblock halign-left valign-top"></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">neorv32_xirq.h</p></td> +<td class="tableblock halign-left valign-top"></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Top entity ports:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>xirq_i</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">External interrupts input (32-bit)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Configuration generics:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>XIRQ_NUM_CH</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Number of external IRQ channels to implement (0..32)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">CPU interrupts:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">fast IRQ channel 8</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">XIRQ (see <a href="#_processor_interrupts">Processor Interrupts</a>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Access restrictions:</p></td> +<td class="tableblock halign-left valign-top" colspan="2"><p class="tableblock">privileged access only, non-32-bit write accesses are ignored</p></td> +</tr> +</tbody> +</table> +<div class="paragraph"> +<p><strong>Overview</strong></p> +</div> +<div class="paragraph"> +<p>The external interrupt controller provides a simple mechanism to implement up to 32 platform-level / processor-external +interrupt request signals. The external IRQ requests are prioritized, queued and signaled to the CPU via a +<em>single</em> CPU fast interrupt request channel.</p> +</div> +<div class="paragraph"> +<p><strong>Theory of Operation</strong></p> +</div> +<div class="paragraph"> +<p>The XIRQ provides up to 32 external interrupt channels configured via the <code>XIRQ_NUM_CH</code> generic. Each bit in the +<code>xirq_i</code> input signal vector represents one interrupt channel. If less than 32 channels are configured, only the +LSB-aligned channels are used while the remaining ones are left unconnected internally.</p> +</div> +<div class="paragraph"> +<p>The external interrupt controller features five interface registers:</p> +</div> +<div class="olist arabic"> +<ol class="arabic" start="1"> +<li> +<p>external interrupt channel enable (<code>EIE</code>)</p> +</li> +<li> +<p>external interrupt channel pending (<code>EIP</code>)</p> +</li> +<li> +<p>external interrupt source (<code>ESC</code>)</p> +</li> +<li> +<p>trigger type configuration (<code>TTYP</code>)</p> +</li> +<li> +<p>trigger polarity configuration (<code>TPOL</code>)</p> +</li> +</ol> +</div> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +From a functional point of view, the <code>EIE</code>, <code>EIP</code> and <code>ESC</code> registers follow the behavior +of the RISC-V <a href="#_mie"><strong><code>mie</code></strong></a>, <a href="#_mip"><strong><code>mip</code></strong></a> and <a href="#_mcause"><strong><code>mcause</code></strong></a> CSRs. +</td> +</tr> +</table> +</div> +<div class="paragraph"> +<p>The actual interrupt trigger type can be configured individually for each channel using the <code>TTYP</code> and <code>TPOL</code> +registers. <code>TTYP</code> defines the actual trigger type (level-triggered or edge-triggered), while <code>TPOL</code> defines +the trigger&#8217;s polarity (low-level/falling-edge or high-level_/rising-edge). The position of each bit in these +registers corresponds the according XIRQ channel.</p> +</div> +<table class="tableblock frame-all grid-all stretch"> +<caption class="title">Table 32. XIRQ Trigger Configuration</caption> +<colgroup> +<col style="width: 28.5714%;"> +<col style="width: 28.5714%;"> +<col style="width: 42.8572%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-center valign-top"><code>TTYP(i)</code></th> +<th class="tableblock halign-center valign-top"><code>TPOL(i)</code></th> +<th class="tableblock halign-left valign-top">Resulting trigger of <code>xirq_i(i)</code></th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>0</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>0</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">low-level</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>0</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>1</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">high-level</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>1</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>0</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">falling-edge</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>1</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>1</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">rising-edge</p></td> +</tr> +</tbody> +</table> +<div class="paragraph"> +<p>When the configured trigger of an interrupt channel fires the according interrupt channel becomes <em>pending</em> +which is indicated by the according channel bit being set in the <code>EIP</code> register. This pending interrupt can +be manually cleared at any time by writing zero to the according <code>EIP</code> bit.</p> +</div> +<div class="paragraph"> +<p>A pending interrupt can only generate a CPU interrupt if the according channel is enabled by the <code>EIE</code> +register. Once triggered, disabled channels that <strong>were already triggered</strong> remain pending until explicitly +(= manually) cleared. The channels are prioritized in a static order, i.e. channel 0 (<code>xirq_i(0)</code>) has the +highest priority and channel 31 (<code>xirq_i(31)</code>) has the lowest priority. If <strong>any</strong> pending interrupt channel is +also enabled, an interrupt request is sent to the CPU.</p> +</div> +<div class="paragraph"> +<p>The CPU can determine the most prioritized external interrupt request either by checking the bits in the <code>EIP</code> +register or by reading the interrupt source register <code>ESC</code>. This register provides a 5-bit wide ID (0..31) +identifying the currently firing external interrupt source channel. Writing <em>any</em> value to this register will +acknowledge and clear the <em>current</em> CPU interrupt (so the XIRQ controller can issue a new CPU interrupt).</p> +</div> +<div class="paragraph"> +<p>In order to acknowledge an XIRQ interrupt, the interrupt handler has to&#8230;&#8203; +* clear the pending XIRQ channel by clearing the according <code>EIP</code> bit +* writing <em>any</em> value to <code>ESC</code> to acknowledge the XIRQ CPU interrupt</p> +</div> +<div class="paragraph"> +<p><strong>Register Map</strong></p> +</div> +<table class="tableblock frame-all grid-all stretch"> +<caption class="title">Table 33. XIRQ register map (<code>struct NEORV32_XIRQ</code>)</caption> +<colgroup> +<col style="width: 16.6666%;"> +<col style="width: 8.3333%;"> +<col style="width: 8.3333%;"> +<col style="width: 8.3333%;"> +<col style="width: 58.3335%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-center valign-top">Address</th> +<th class="tableblock halign-left valign-top">Name [C]</th> +<th class="tableblock halign-center valign-top">Bit(s)</th> +<th class="tableblock halign-center valign-top">R/W</th> +<th class="tableblock halign-left valign-top">Description</th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>0xfffff300</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>EIE</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>31:0</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">External interrupt enable register (one bit per channel, LSB-aligned)</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>0xfffff304</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>EIP</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>31:0</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">External interrupt pending register (one bit per channel, LSB-aligned); writing 0 to a bit clears the according pending interrupt</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>0xfffff308</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>ESC</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>4:0</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Interrupt source ID (0..31) of firing IRQ (prioritized!); writing <em>any</em> value will acknowledge the current XIRQ CPU interrupt</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>0xfffff30c</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>TTYP</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>31:0</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Trigger type select (<code>0</code> = level trigger, <code>1</code> = edge trigger); each bit corresponds to the according channel number</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>0xfffff310</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>TPOL</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>31:0</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Trigger polarity select (<code>0</code> = low-level/falling-edge, <code>1</code> = high-level/rising-edge); each bit corresponds to the according channel number</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>0xfffff314</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">-</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>31:0</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><em>reserved</em>, read as zero</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>0xfffff318</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">-</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>31:0</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><em>reserved</em>, read as zero</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>0xfffff31c</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">-</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>31:0</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><em>reserved</em>, read as zero</p></td> +</tr> +</tbody> +</table> +<div style="page-break-after: always;"></div> +</div> +<div class="sect3"> +<h4 id="_general_purpose_timer_gptmr">2.7.24. General Purpose Timer (GPTMR)</h4> +<table class="tableblock frame-ends grid-none stretch"> +<colgroup> +<col style="width: 30%;"> +<col style="width: 30%;"> +<col style="width: 40%;"> +</colgroup> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Hardware source files:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">neorv32_gptmr.vhd</p></td> +<td class="tableblock halign-left valign-top"></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Software driver files:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">neorv32_gptmr.c</p></td> +<td class="tableblock halign-left valign-top"></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">neorv32_gptmr.h</p></td> +<td class="tableblock halign-left valign-top"></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Top entity ports:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">none</p></td> +<td class="tableblock halign-left valign-top"></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Configuration generics:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>IO_GPTMR_EN</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">implement general purpose timer when <code>true</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">CPU interrupts:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">fast IRQ channel 12</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">timer interrupt (see <a href="#_processor_interrupts">Processor Interrupts</a>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Access restrictions:</p></td> +<td class="tableblock halign-left valign-top" colspan="2"><p class="tableblock">privileged access only, non-32-bit write accesses are ignored</p></td> +</tr> +</tbody> +</table> +<div class="paragraph"> +<p><strong>Overview</strong></p> +</div> +<div class="paragraph"> +<p>The general purpose timer module implements a simple yet universal 32-bit timer. It is implemented if the processor&#8217;s +<code>IO_GPTMR_EN</code> top generic is set <code>true</code>. The timer provides a pre-scaled counter register that can trigger an interrupt +when reaching a programmable threshold value.</p> +</div> +<div class="paragraph"> +<p>The GPTMR provides three interface registers : a control register (<code>CTRL</code>), a 32-bit counter register (<code>COUNT</code>) and a +32-bit threshold register (<code>THRES</code>). The timer is globally enabled by setting the <code>GPTMR_CTRL_EN</code> bit in the module&#8217;s +control register. When the timer is enable the <code>COUNT</code> register will start incrementing from zero at a programmable +rate that scales the main processor clock. this pre-scaler is configured via the three <code>GPTMR_CTRL_PRSCx</code> +control register bits:</p> +</div> +<table class="tableblock frame-all grid-rows stretch"> +<caption class="title">Table 34. GPTMR prescaler configuration</caption> +<colgroup> +<col style="width: 33.3333%;"> +<col style="width: 8.3333%;"> +<col style="width: 8.3333%;"> +<col style="width: 8.3333%;"> +<col style="width: 8.3333%;"> +<col style="width: 8.3333%;"> +<col style="width: 8.3333%;"> +<col style="width: 8.3333%;"> +<col style="width: 8.3336%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-left valign-top"><strong><code>GPTMR_CTRL_PRSCx</code></strong></th> +<th class="tableblock halign-center valign-top"><code>0b000</code></th> +<th class="tableblock halign-center valign-top"><code>0b001</code></th> +<th class="tableblock halign-center valign-top"><code>0b010</code></th> +<th class="tableblock halign-center valign-top"><code>0b011</code></th> +<th class="tableblock halign-center valign-top"><code>0b100</code></th> +<th class="tableblock halign-center valign-top"><code>0b101</code></th> +<th class="tableblock halign-center valign-top"><code>0b110</code></th> +<th class="tableblock halign-center valign-top"><code>0b111</code></th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Resulting <code>clock_prescaler</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">2</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">4</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">8</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">64</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">128</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">1024</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">2048</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">4096</p></td> +</tr> +</tbody> +</table> +<div class="paragraph"> +<p>Whenever the counter register <code>COUNT</code> equals the programmable threshold value <code>THRES</code> the module&#8217;s interrupt +signal becomes pending (indicated by <code>GPTMR_CTRL_IRQ_PND</code> being set). Note that a pending interrupt has to be +cleared manually by writing a <code>1</code> to <code>GPTMR_CTRL_IRQ_CLR</code>.</p> +</div> +<div class="paragraph"> +<p>The control register&#8217;s <code>GPTMR_CTRL_MODE</code> bit defines what will happen when <code>COUNT == THRES</code>.</p> +</div> +<div class="ulist"> +<ul> +<li> +<p><code>GPTMR_CTRL_MODE = 0</code>: <strong>single-shot mode</strong> - the <code>COUNT</code> register will stop incrementing</p> +</li> +<li> +<p><code>GPTMR_CTRL_MODE = 1</code>: <strong>continuous mode</strong> - the <code>COUNT</code> register is automatically reset and restarts incrementing from zero</p> +</li> +</ul> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">Resetting the Counter</div> +Disabling the GPTMR will also clear the <code>COUNT</code> register. +</td> +</tr> +</table> +</div> +<div class="paragraph"> +<p><strong>Interrupt</strong></p> +</div> +<div class="paragraph"> +<p>The GPTRM provides a single interrupt line is triggered whenever <code>COUNT</code> equals <code>THRES</code>. Once triggered, the interrupt will +stay pending until explicitly cleared by writing a 1 to <code>GPTMR_CTRL_IRQ_CLR</code>.</p> +</div> +<div class="paragraph"> +<p><strong>Register Map</strong></p> +</div> +<table class="tableblock frame-all grid-all stretch"> +<caption class="title">Table 35. GPTMR register map (<code>struct NEORV32_GPTMR</code>)</caption> +<colgroup> +<col style="width: 22.2222%;"> +<col style="width: 11.1111%;"> +<col style="width: 22.2222%;"> +<col style="width: 5.5555%;"> +<col style="width: 38.889%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-left valign-top">Address</th> +<th class="tableblock halign-left valign-top">Name [C]</th> +<th class="tableblock halign-left valign-top">Bit(s), Name [C]</th> +<th class="tableblock halign-center valign-top">R/W</th> +<th class="tableblock halign-left valign-top">Function</th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-left valign-top" rowspan="6"><p class="tableblock"><code>0xfffff100</code></p></td> +<td class="tableblock halign-left valign-top" rowspan="6"><p class="tableblock"><code>CTRL</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0</code> <code>GPTMR_CTRL_EN</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Timer enable flag</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>3:1</code> <code>GPTMR_CTRL_PRSC2 : GPTMR_CTRL_PRSC0</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">3-bit clock prescaler select</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>4</code> <code>GPTMR_CTRL_MODE</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Operation mode (0=single-shot, 1=continuous)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>29:5</code> -</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><em>reserved</em>, read as zero</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>30</code> <code>GPTMR_CTRL_IRQ_CLR</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">-/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Write <code>1</code> to clear timer-match interrupt; auto-clears</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>31</code> <code>GPTMR_CTRL_IRQ_PND</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Timer-match interrupt pending</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0xfffff104</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>THRES</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>31:0</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Threshold value register</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0xfffff108</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>COUNT</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>31:0</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Counter register</p></td> +</tr> +</tbody> +</table> +<div style="page-break-after: always;"></div> +</div> +<div class="sect3"> +<h4 id="_execute_in_place_module_xip">2.7.25. Execute In Place Module (XIP)</h4> +<table class="tableblock frame-ends grid-none stretch"> +<colgroup> +<col style="width: 30%;"> +<col style="width: 30%;"> +<col style="width: 40%;"> +</colgroup> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Hardware source files:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">neorv32_xip.vhd</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">XIP module</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">neorv32_cache.vhd</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Generic cache module</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Software driver files:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">neorv32_xip.c</p></td> +<td class="tableblock halign-left valign-top"></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">neorv32_xip.h</p></td> +<td class="tableblock halign-left valign-top"></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Top entity ports:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>xip_csn_o</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">1-bit chip select, low-active</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>xip_clk_o</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">1-bit serial clock output</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>xip_dat_i</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">1-bit serial data input</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>xip_dat_o</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">1-bit serial data output</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Configuration generics:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>XIP_EN</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">implement XIP module when <code>true</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>XIP_CACHE_EN</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">implement XIP cache when <code>true</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>XIP_CACHE_NUM_BLOCKS</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">number of blocks in XIP cache; has to be a power of two</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>XIP_CACHE_BLOCK_SIZE</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">number of bytes per XIP cache block; has to be a power of two, min 4</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">CPU interrupts:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">none</p></td> +<td class="tableblock halign-left valign-top"></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Access restrictions:</p></td> +<td class="tableblock halign-left valign-top" colspan="2"><p class="tableblock">control registers: privileged access only, non-32-bit write accesses are ignored</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top" colspan="2"><p class="tableblock">XIP data access: read-only</p></td> +</tr> +</tbody> +</table> +<div class="paragraph"> +<p><strong>Overview</strong></p> +</div> +<div class="paragraph"> +<p>The execute in-place (XIP) module allows to execute code (and read constant data) directly from an external SPI flash memory. +The standard serial peripheral interface (SPI) is used as transfer protocol. All bus requests issued by the CPU +are converted transparently into SPI flash access commands. Hence, the external XIP flash behaves like a simple on-chip ROM.</p> +</div> +<div class="paragraph"> +<p>From the CPU side, the modules provides two independent interfaces: one for transparently accessing the XIP flash and another +one for accessing the module&#8217;s control and status registers. The first interface provides the <em>transparent</em> +gateway to the SPI flash, so the CPU can directly fetch and execute instructions and/or read constant data. +Note that this interface is read-only. Any write access will raise a bus error exception. The second interface is +mapped to the processor&#8217;s IO space and allows accesses to the XIP module&#8217;s configuration registers as well as +conducting individual SPI transfers.</p> +</div> +<div class="paragraph"> +<p>The XIP module provides an optional configurable cache to accelerate SPI flash accesses.</p> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">XIP Address Mapping</div> +When XIP mode is enabled the flash is mapped to fixed address space region starting at address +<code>0xE0000000</code> (see section <a href="#_address_space">Address Space</a>) supporting a maximum flash size of 256MB. +</td> +</tr> +</table> +</div> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +<div class="title">XIP Example Program</div> +An example program is provided in <code>sw/example/demo_xip</code> that illustrate how to program and configure +an external SPI flash to run a program from it. +</td> +</tr> +</table> +</div> +<div class="paragraph"> +<p><strong>SPI Configuration</strong></p> +</div> +<div class="paragraph"> +<p>The XIP module accesses external flash using the standard SPI protocol. The module always sends data MSB-first and +provides all of the standard four clock modes (0..3), which are configured via the <code>XIP_CTRL_CPOL</code> (clock polarity) +and <code>XIP_CTRL_CPHA</code> (clock phase) control register bits, respectively. The flash&#8217;s "read command", which initiates +a read access, is defined by the <code>XIP_CTRL_RD_CMD</code> control register bits. For most SPI flash memories this is <code>0x03</code> +for <em>normal</em> SPI mode.</p> +</div> +<div class="paragraph"> +<p>The SPI clock (<code>xip_clk_o</code>) frequency is programmed by the 3-bit <code>XIP_CTRL_PRSCx</code> clock prescaler for a coarse clock +selection and a 4-bit clock divider <code>XPI_CTRL_CDIVx</code> for a fine clock selection. +The following clock prescalers (<code>XIP_CTRL_PRSCx</code>) are available:</p> +</div> +<table class="tableblock frame-all grid-rows stretch"> +<caption class="title">Table 36. XIP clock prescaler configuration</caption> +<colgroup> +<col style="width: 33.3333%;"> +<col style="width: 8.3333%;"> +<col style="width: 8.3333%;"> +<col style="width: 8.3333%;"> +<col style="width: 8.3333%;"> +<col style="width: 8.3333%;"> +<col style="width: 8.3333%;"> +<col style="width: 8.3333%;"> +<col style="width: 8.3336%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-left valign-top"><strong><code>XIP_CTRL_PRSCx</code></strong></th> +<th class="tableblock halign-center valign-top"><code>0b000</code></th> +<th class="tableblock halign-center valign-top"><code>0b001</code></th> +<th class="tableblock halign-center valign-top"><code>0b010</code></th> +<th class="tableblock halign-center valign-top"><code>0b011</code></th> +<th class="tableblock halign-center valign-top"><code>0b100</code></th> +<th class="tableblock halign-center valign-top"><code>0b101</code></th> +<th class="tableblock halign-center valign-top"><code>0b110</code></th> +<th class="tableblock halign-center valign-top"><code>0b111</code></th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Resulting <code>clock_prescaler</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">2</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">4</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">8</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">64</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">128</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">1024</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">2048</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">4096</p></td> +</tr> +</tbody> +</table> +<div class="paragraph"> +<p>Based on the programmed clock configuration, the actual SPI clock frequency f<sub>SPI</sub> is derived +from the processor&#8217;s main clock f<sub>main</sub> according to the following equation:</p> +</div> +<div class="paragraph"> +<p><em><strong>f<sub>SPI</sub></strong></em> = <em>f<sub>main</sub>[Hz]</em> / (2 * <code>clock_prescaler</code> * (1 + <code>XPI_CTRL_CDIVx</code>))</p> +</div> +<div class="paragraph"> +<p>Hence, the maximum SPI clock is f<sub>main</sub> / 4 and the lowest SPI clock is f<sub>main</sub> / 131072. The SPI clock is always +symmetric having a duty cycle of 50%.</p> +</div> +<div class="paragraph"> +<p><strong>High-Speed Mode</strong></p> +</div> +<div class="paragraph"> +<p>The XIP module provides a high-speed mode to further boost the maximum SPI clock frequency. When enabled via the control +register&#8217;s <code>XIP_CTRL_HIGHSPEED</code> bit the clock prescaler configuration (<code>XIP_CTRL_PRSCx</code> bits) is overridden setting it +to a minimal factor of 1. However, the clock speed can still be fine-tuned using the <code>XPI_CTRL_CDIVx</code> bits.</p> +</div> +<div class="paragraph"> +<p><em><strong>f<sub>SPI</sub></strong></em> = <em>f<sub>main</sub>[Hz]</em> / (2 * 1 * (1 + <code>XPI_CTRL_CDIVx</code>))</p> +</div> +<div class="paragraph"> +<p>Hence, the maximum SPI clock when in high-speed mode is f<sub>main</sub> / 2.</p> +</div> +<div class="paragraph"> +<p><strong>Direct SPI Access</strong></p> +</div> +<div class="paragraph"> +<p>The XIP module allows to initiate <em>direct</em> SPI transactions. This feature can be used to configure the attached SPI +flash or to perform direct read and write accesses to the flash memory. Two data registers <code>DATA_LO</code> and +<code>DATA_HI</code> are provided to send up to 64-bit of SPI data. The <code>DATA_HI</code> register is write-only, +so a total of just 32-bits of receive data is provided. Note that the module handles the chip-select +line (<code>xip_csn_o</code>) by itself so it is not possible to construct larger consecutive transfers.</p> +</div> +<div class="paragraph"> +<p>The actual data transmission size in bytes is defined by the control register&#8217;s <code>XIP_CTRL_SPI_NBYTES</code> bits. +Any configuration from 1 byte to 8 bytes is valid. Other value will result in unpredictable behavior.</p> +</div> +<div class="paragraph"> +<p>Since data is always transferred MSB-first, the data in <code>DATA_HI:DATA_LO</code> also has to be MSB-aligned. Receive data is +available in <code>DATA_LO</code> only since <code>DATA_HI</code> is write-only. Writing to <code>DATA_HI</code> triggers the actual SPI transmission. +The <code>XIP_CTRL_PHY_BUSY</code> control register flag indicates a transmission being in progress.</p> +</div> +<div class="paragraph"> +<p>The chip-select line of the XIP module (<code>xip_csn_o</code>) will only become asserted (enabled, pulled low) if the +<code>XIP_CTRL_SPI_CSEN</code> control register bit is set. If this bit is cleared, <code>xip_csn_o</code> is always disabled +(pulled high).</p> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +Direct SPI mode is only possible when the module is enabled (setting <code>XIP_CTRL_EN</code>) but <strong>before</strong> the actual +XIP mode is enabled via <code>XIP_CTRL_XIP_EN</code>. +</td> +</tr> +</table> +</div> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +When the XIP mode is not enabled, the XIP module can also be used as additional general purpose SPI controller +with a transfer size of up to 64 bits per transmission. +</td> +</tr> +</table> +</div> +<div class="paragraph"> +<p><strong>Using the XIP Mode</strong></p> +</div> +<div class="paragraph"> +<p>The XIP module is globally enabled by setting the <code>XIP_CTRL_EN</code> bit in the device&#8217;s <code>CTRL</code> control register. +Clearing this bit will reset the whole module and will also terminate any pending SPI transfer.</p> +</div> +<div class="paragraph"> +<p>Since there is a wide variety of SPI flash components with different sizes, the XIP module allows to specify +the address width of the flash: the number of address bytes used for addressing flash memory content has to be +configured using the control register&#8217;s <em>XIP_CTRL_XIP_ABYTES</em> bits. These two bits contain the number of SPI +address bytes (<strong>minus one</strong>). For example for a SPI flash with 24-bit addresses these bits have to be set to +<code>0b10</code>.</p> +</div> +<div class="paragraph"> +<p>The transparent XIP accesses are transformed into SPI transmissions with the following format (starting with the MSB):</p> +</div> +<div class="ulist"> +<ul> +<li> +<p>8-bit command: configured by the <code>XIP_CTRL_RD_CMD</code> control register bits ("SPI read command")</p> +</li> +<li> +<p>8 to 32 bits address: defined by the <code>XIP_CTRL_XIP_ABYTES</code> control register bits ("number of address bytes")</p> +</li> +<li> +<p>32-bit data: sending zeros and receiving the according flash word (32-bit)</p> +</li> +</ul> +</div> +<div class="paragraph"> +<p>Hence, the maximum XIP transmission size is 72-bit, which has to be configured via the <code>XIP_CTRL_SPI_NBYTES</code> +control register bits. Note that the 72-bit transmission size is only available in XIP mode. The transmission +size of the direct SPI accesses is limited to 64-bit.</p> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +When using four SPI flash address bytes, the most significant 4 bits of the address are always hardwired +to zero allowing a maximum <strong>accessible</strong> flash size of 256MB. +</td> +</tr> +</table> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +The XIP module always fetches a full naturally aligned 32-bit word from the SPI flash. Any sub-word data masking +or alignment will be performed by the CPU core logic. +</td> +</tr> +</table> +</div> +<div class="admonitionblock important"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-important" title="Important"></i> +</td> +<td class="content"> +The XIP mode requires the 4-byte data words in the flash to be ordered in <strong>little-endian</strong> byte order. +</td> +</tr> +</table> +</div> +<div class="paragraph"> +<p>After the SPI properties (including the amount of address bytes <strong>and</strong> the total amount of SPI transfer bytes) +and XIP address mapping are configured, the actual XIP mode can be enabled by setting +the control register&#8217;s <code>XIP_CTRL_XIP_EN</code> bit. This will enable the "transparent SPI access port" of the module and thus, +the <em>transparent</em> conversion of access requests into proper SPI flash transmissions. Hence, any access to the processor&#8217;s +memory-mapped XIP region (<code>0xE0000000</code> to <code>0xEFFFFFFF</code>) will be converted into SPI flash accesses. +Make sure <code>XIP_CTRL_SPI_CSEN</code> is also set so the module can actually select/enable the attached SPI flash. +No more direct SPI accesses via <code>DATA_HI:DATA_LO</code> are possible when the XIP mode is enabled. However, the +XIP mode can be disabled at any time.</p> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +If the XIP module is disabled (<em>XIP_CTRL_EN</em> = <code>0</code>) any accesses to the memory-mapped XIP flash address region +will raise a bus access exception. If the XIP module is enabled (<em>XIP_CTRL_EN</em> = <code>1</code>) but XIP mode is not enabled +yet (<em>XIP_CTRL_XIP_EN</em> = '0') any access to the programmed XIP memory segment will also raise a bus access exception. +</td> +</tr> +</table> +</div> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +It is highly recommended to enable the <a href="#_processor_internal_instruction_cache_icache">Processor-Internal Instruction Cache (iCACHE)</a> to cover some +of the SPI access latency. +</td> +</tr> +</table> +</div> +<div class="paragraph"> +<p><strong>XIP Cache</strong></p> +</div> +<div class="paragraph"> +<p>Since every single instruction fetch request from the CPU is translated into serial SPI transmissions the access latency is +very high resulting in a low throughput. In order to improve performance, the XIP module provides an optional cache that +allows to buffer recently-accessed data. The cache is implemented as a simple direct-mapped read-only cache with a configurable +cache layout:</p> +</div> +<div class="ulist"> +<ul> +<li> +<p><code>XIP_CACHE_EN</code>: when set to <code>true</code> the CIP cache is implemented</p> +</li> +<li> +<p><code>XIP_CACHE_NUM_BLOCKS</code> defines the number of cache blocks (or lines)</p> +</li> +<li> +<p><code>XIP_CACHE_BLOCK_SIZE</code> defines the size in bytes of each cache block</p> +</li> +</ul> +</div> +<div class="paragraph"> +<p>When the cache is implemented, the XIP module operates in <strong>burst mode</strong> utilizing the flash&#8217;s <em>incremental read</em> capabilities. +Thus, several bytes (= <code>XIP_CACHE_BLOCK_SIZE</code>) are read consecutively from the flash using a single read command.</p> +</div> +<div class="paragraph"> +<p>The XIP cache is cleared when the XIP module is disabled (<code>XIP_CTRL_EN = 0</code>), when XIP mode is disabled +(<code>XIP_CTRL_XIP_EN = 0</code>) or when the CPU issues a <code>fence(.i)</code> instruction.</p> +</div> +<div class="paragraph"> +<p><strong>Register Map</strong></p> +</div> +<table class="tableblock frame-all grid-all stretch"> +<caption class="title">Table 37. XIP Register Map (<code>struct NEORV32_XIP</code>)</caption> +<colgroup> +<col style="width: 13.3333%;"> +<col style="width: 6.6666%;"> +<col style="width: 26.6666%;"> +<col style="width: 6.6666%;"> +<col style="width: 46.6669%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-left valign-top">Address</th> +<th class="tableblock halign-left valign-top">Name [C]</th> +<th class="tableblock halign-left valign-top">Bit(s), Name [C]</th> +<th class="tableblock halign-center valign-top">R/W</th> +<th class="tableblock halign-left valign-top">Function</th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-left valign-top" rowspan="14"><p class="tableblock"><code>0xffffff40</code></p></td> +<td class="tableblock halign-left valign-top" rowspan="14"><p class="tableblock"><code>CTRL</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0</code> <code>XIP_CTRL_EN</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">XIP module enable</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>3:1</code> <code>XIP_CTRL_PRSC2 : XIP_CTRL_PRSC0</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">3-bit SPI clock prescaler select</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>4</code> <code>XIP_CTRL_CPOL</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">SPI clock polarity</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>5</code> <code>XIP_CTRL_CPHA</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">SPI clock phase</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>9:6</code> <code>XIP_CTRL_SPI_NBYTES_MSB : XIP_CTRL_SPI_NBYTES_LSB</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Number of bytes in SPI transaction (1..9)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>10</code> <code>XIP_CTRL_XIP_EN</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">XIP mode enable</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>12:11</code> <code>XIP_CTRL_XIP_ABYTES_MSB : XIP_CTRL_XIP_ABYTES_LSB</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Number of address bytes for XIP flash (minus 1)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>20:13</code> <code>XIP_CTRL_RD_CMD_MSB : XIP_CTRL_RD_CMD_LSB</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Flash read command</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>21</code> <code>XIP_CTRL_SPI_CSEN</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Allow SPI chip-select to be actually asserted when set</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>22</code> <code>XIP_CTRL_HIGHSPEED</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">enable SPI high-speed mode (ignoring <code>XIP_CTRL_PRSCx</code>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>26:23</code> <code>XIP_CTRL_CDIV3 : XIP_CTRL_CDIV0</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">4-bit clock divider for fine-tuning</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>29:27</code> -</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><em>reserved</em>, read as zero</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>30</code> <code>XIP_CTRL_PHY_BUSY</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">SPI PHY busy when set</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>31</code> <code>XIP_CTRL_XIP_BUSY</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">XIP access in progress when set</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0xffffff44</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><em>reserved</em></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>31:0</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><em>reserved</em>, read as zero</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0xffffff48</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>DATA_LO</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>31:0</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Direct SPI access - data register low</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0xffffff4C</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>DATA_HI</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>31:0</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">-/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Direct SPI access - data register high; write access triggers SPI transfer</p></td> +</tr> +</tbody> +</table> +<div style="page-break-after: always;"></div> +</div> +<div class="sect3"> +<h4 id="_system_configuration_information_memory_sysinfo">2.7.26. System Configuration Information Memory (SYSINFO)</h4> +<table class="tableblock frame-ends grid-none stretch"> +<colgroup> +<col style="width: 30%;"> +<col style="width: 30%;"> +<col style="width: 40%;"> +</colgroup> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Hardware source files:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">neorv32_sysinfo.vhd</p></td> +<td class="tableblock halign-left valign-top"></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Software driver files:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">neorv32_sysinfo.h</p></td> +<td class="tableblock halign-left valign-top"></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Top entity ports:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">none</p></td> +<td class="tableblock halign-left valign-top"></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Configuration generics:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">*</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">most of the top&#8217;s configuration generics</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">CPU interrupts:</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">none</p></td> +<td class="tableblock halign-left valign-top"></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Access restrictions:</p></td> +<td class="tableblock halign-left valign-top" colspan="2"><p class="tableblock">privileged access only, non-32-bit write accesses are ignored</p></td> +</tr> +</tbody> +</table> +<div class="paragraph"> +<p><strong>Overview</strong></p> +</div> +<div class="paragraph"> +<p>The SYSINFO allows the application software to determine the setting of most of the <a href="#_processor_top_entity_generics">Processor Top Entity - Generics</a> +that are related to processor/SoC configuration. All registers of this unit are read-only. +This device is always implemented - regardless of the actual hardware configuration. The bootloader as well +as the NEORV32 software runtime environment require information from this device (like memory layout +and default clock frequency) for correct operation.</p> +</div> +<div class="paragraph"> +<p><strong>Register Map</strong></p> +</div> +<table class="tableblock frame-all grid-all stretch"> +<caption class="title">Table 38. SYSINFO register map (<code>struct NEORV32_SYSINFO</code>)</caption> +<colgroup> +<col style="width: 20%;"> +<col style="width: 10%;"> +<col style="width: 70%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-left valign-top">Address</th> +<th class="tableblock halign-left valign-top">Name [C]</th> +<th class="tableblock halign-left valign-top">Function</th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0xfffffe00</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>CLK</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">clock frequency in Hz (via top&#8217;s <code>CLOCK_FREQUENCY</code> generic)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0xfffffe04</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>MEM[4]</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">internal memory configuration (see <a href="#_sysinfo_memory_configuration">SYSINFO - Memory Configuration</a>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0xfffffe08</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>SOC</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">specific SoC configuration (see <a href="#_sysinfo_soc_configuration">SYSINFO - SoC Configuration</a>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0xfffffe0c</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>CACHE</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">cache configuration information (see <a href="#_sysinfo_cache_configuration">SYSINFO - Cache Configuration</a>)</p></td> +</tr> +</tbody> +</table> +<div class="sect4"> +<h5 id="_sysinfo_memory_configuration">SYSINFO - Memory Configuration</h5> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +Bit fields in this register are set to all-zero if the according cache is not implemented. +</td> +</tr> +</table> +</div> +<table class="tableblock frame-all grid-all stretch"> +<caption class="title">Table 39. SYSINFO <code>MEM</code> Bytes</caption> +<colgroup> +<col style="width: 10%;"> +<col style="width: 20%;"> +<col style="width: 70%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-center valign-top">Byte</th> +<th class="tableblock halign-left valign-top">Name [C]</th> +<th class="tableblock halign-left valign-top">Function</th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>0</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>SYSINFO_MEM_IMEM</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><em>log2</em>(internal IMEM size in bytes), via top&#8217;s <code>MEM_INT_IMEM_SIZE</code> generic</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>1</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>SYSINFO_MEM_DMEM</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><em>log2</em>(internal DMEM size in bytes), via top&#8217;s <code>MEM_INT_DMEM_SIZE</code> generic</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>2</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><em>reserved</em>, read as zero</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>3</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><em>reserved</em>, read as zero</p></td> +</tr> +</tbody> +</table> +</div> +<div class="sect4"> +<h5 id="_sysinfo_soc_configuration">SYSINFO - SoC Configuration</h5> +<table class="tableblock frame-all grid-all stretch"> +<caption class="title">Table 40. SYSINFO <code>SOC</code> Bits</caption> +<colgroup> +<col style="width: 11.1111%;"> +<col style="width: 33.3333%;"> +<col style="width: 55.5556%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-center valign-top">Bit</th> +<th class="tableblock halign-left valign-top">Name [C]</th> +<th class="tableblock halign-left valign-top">Function</th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>0</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>SYSINFO_SOC_BOOTLOADER</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">set if processor-internal bootloader is implemented (via top&#8217;s <code>INT_BOOTLOADER_EN</code> generic)</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>1</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>SYSINFO_SOC_XBUS</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">set if external Wishbone bus interface is implemented (via top&#8217;s <code>XBUS_EN</code> generic)</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>2</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>SYSINFO_SOC_MEM_INT_IMEM</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">set if processor-internal DMEM implemented (via top&#8217;s <code>MEM_INT_DMEM_EN</code> generic)</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>3</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>SYSINFO_SOC_MEM_INT_DMEM</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">set if processor-internal IMEM is implemented (via top&#8217;s <code>MEM_INT_IMEM_EN</code> generic)</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>4</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>SYSINFO_SOC_OCD</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">set if on-chip debugger is implemented (via top&#8217;s <code>ON_CHIP_DEBUGGER_EN</code> generic)</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>5</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>SYSINFO_SOC_ICACHE</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">set if processor-internal instruction cache is implemented (via top&#8217;s <code>ICACHE_EN</code> generic)</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>6</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>SYSINFO_SOC_DCACHE</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">set if processor-internal data cache is implemented (via top&#8217;s <code>DCACHE_EN</code> generic)</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>7</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>SYSINFO_SOC_CLOCK_GATING</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">set if CPU clock gating is implemented (via top&#8217;s <code>CLOCK_GATING_EN</code> generic)</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>8</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>SYSINFO_SOC_XBUS_CACHE</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">set if external bus interface cache is implemented (via top&#8217;s <code>XBUS_CACHE_EN</code> generic)</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>9</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>SYSINFO_SOC_XIP</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">set if XIP module is implemented (via top&#8217;s <code>XIP_EN</code> generic)</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>10</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>SYSINFO_SOC_XIP_CACHE</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">set if XIP cache is implemented (via top&#8217;s <code>XIP_CACHE_EN</code> generic)</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>13:11</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><em>reserved</em>, read as zero</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>14</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>SYSINFO_SOC_IO_DMA</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">set if direct memory access controller is implemented (via top&#8217;s <code>IO_DMA_EN</code> generic)</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>15</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>SYSINFO_SOC_IO_GPIO</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">set if GPIO is implemented (via top&#8217;s <code>IO_GPIO_EN</code> generic)</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>16</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>SYSINFO_SOC_IO_MTIME</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">set if MTIME is implemented (via top&#8217;s <code>IO_MTIME_EN</code> generic)</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>17</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>SYSINFO_SOC_IO_UART0</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">set if primary UART0 is implemented (via top&#8217;s <code>IO_UART0_EN</code> generic)</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>18</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>SYSINFO_SOC_IO_SPI</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">set if SPI is implemented (via top&#8217;s <code>IO_SPI_EN</code> generic)</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>19</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>SYSINFO_SOC_IO_TWI</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">set if TWI is implemented (via top&#8217;s <code>IO_TWI_EN</code> generic)</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>20</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>SYSINFO_SOC_IO_PWM</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">set if PWM is implemented (via top&#8217;s <code>IO_PWM_NUM_CH</code> generic)</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>21</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>SYSINFO_SOC_IO_WDT</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">set if WDT is implemented (via top&#8217;s <code>IO_WDT_EN</code> generic)</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>22</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>SYSINFO_SOC_IO_CFS</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">set if custom functions subsystem is implemented (via top&#8217;s <code>IO_CFS_EN</code> generic)</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>23</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>SYSINFO_SOC_IO_TRNG</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">set if TRNG is implemented (via top&#8217;s <code>IO_TRNG_EN</code> generic)</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>24</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>SYSINFO_SOC_IO_SDI</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">set if SDI is implemented (via top&#8217;s <code>IO_SDI_EN</code> generic)</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>25</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>SYSINFO_SOC_IO_UART1</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">set if secondary UART1 is implemented (via top&#8217;s <code>IO_UART1_EN</code> generic)</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>26</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>SYSINFO_SOC_IO_NEOLED</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">set if NEOLED is implemented (via top&#8217;s <code>IO_NEOLED_EN</code> generic)</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>27</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>SYSINFO_SOC_IO_XIRQ</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">set if XIRQ is implemented (via top&#8217;s <code>XIRQ_NUM_CH</code> generic)</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>28</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>SYSINFO_SOC_IO_GPTMR</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">set if GPTMR is implemented (via top&#8217;s <code>IO_GPTMR_EN</code> generic)</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>29</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>SYSINFO_SOC_IO_SLINK</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">set if stream link interface is implemented (via top&#8217;s <code>IO_SLINK_EN</code> generic)</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>30</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>SYSINFO_SOC_IO_ONEWIRE</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">set if ONEWIRE interface is implemented (via top&#8217;s <code>IO_ONEWIRE_EN</code> generic)</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>31</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>SYSINFO_SOC_IO_CRC</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">set if cyclic redundancy check unit is implemented (via top&#8217;s <code>IO_CRC_EN</code> generic)</p></td> +</tr> +</tbody> +</table> +</div> +<div class="sect4"> +<h5 id="_sysinfo_cache_configuration">SYSINFO - Cache Configuration</h5> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +Bit fields in this register are set to all-zero if the according cache is not implemented. +</td> +</tr> +</table> +</div> +<table class="tableblock frame-all grid-all stretch"> +<caption class="title">Table 41. SYSINFO <code>CACHE</code> Bits</caption> +<colgroup> +<col style="width: 4.7619%;"> +<col style="width: 47.619%;"> +<col style="width: 47.6191%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-center valign-top">Bit</th> +<th class="tableblock halign-left valign-top">Name [C]</th> +<th class="tableblock halign-left valign-top">Function</th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>3:0</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>SYSINFO_CACHE_INST_BLOCK_SIZE_3 : SYSINFO_CACHE_INST_BLOCK_SIZE_0</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><em>log2</em>(i-cache block size in bytes), via top&#8217;s <code>ICACHE_BLOCK_SIZE</code> generic</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>7:4</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>SYSINFO_CACHE_INST_NUM_BLOCKS_3 : SYSINFO_CACHE_INST_NUM_BLOCKS_0</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><em>log2</em>(i-cache number of cache blocks), via top&#8217;s <code>ICACHE_NUM_BLOCKS</code> generic</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>11:8</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>SYSINFO_CACHE_DATA_BLOCK_SIZE_3 : SYSINFO_CACHE_DATA_BLOCK_SIZE_0</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><em>log2</em>(d-cache block size in bytes), via top&#8217;s <code>DCACHE_BLOCK_SIZE</code> generic</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>15:12</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>SYSINFO_CACHE_DATA_NUM_BLOCKS_3 : SYSINFO_CACHE_DATA_NUM_BLOCKS_0</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><em>log2</em>(d-cache number of cache blocks), via top&#8217;s <code>DCACHE_NUM_BLOCKS</code> generic</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>19:16</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>SYSINFO_CACHE_XIP_BLOCK_SIZE_3 : SYSINFO_CACHE_XIP_BLOCK_SIZE_0</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><em>log2</em>(xip-cache block size in bytes), via top&#8217;s <code>XIP_CACHE_BLOCK_SIZE</code> generic</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>23:20</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>SYSINFO_CACHE_XIP_NUM_BLOCKS_3 : SYSINFO_CACHE_XIP_NUM_BLOCKS_0</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><em>log2</em>(xip-cache number of cache blocks), via top&#8217;s <code>XIP_CACHE_NUM_BLOCKS</code> generic</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>27:24</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>SYSINFO_CACHE_XBUS_BLOCK_SIZE_3 : SYSINFO_CACHE_XBUS_BLOCK_SIZE_0</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><em>log2</em>(xbus-cache block size in bytes), via top&#8217;s <code>XBUS_CACHE_BLOCK_SIZE</code> generic</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>31:28</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>SYSINFO_CACHE_XBUS_NUM_BLOCKS_3 : SYSINFO_CACHE_XBUS_NUM_BLOCKS_0</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><em>log2</em>(xbus-cache number of cache blocks), via top&#8217;s <code>XBUS_CACHE_NUM_BLOCKS</code> generic</p></td> +</tr> +</tbody> +</table> +</div> +</div> +</div> +</div> +</div> +<div class="sect1"> +<h2 id="_neorv32_central_processing_unit_cpu">3. NEORV32 Central Processing Unit (CPU)</h2> +<div class="sectionbody"> +<div class="paragraph"> +<p>The NEORV32 CPU is an area-optimized RISC-V core implementing the <code>rv32i_zicsr_zifencei</code> base (privileged) ISA and +supporting several additional/optional ISA extensions. The CPU&#8217;s micro architecture is based on a von-Neumann +machine build upon a mixture of multi-cycle and pipelined execution schemes.</p> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +This chapter assumes that the reader is familiar with the official +RISC-V <em>User</em> and <em>Privileged Architecture</em> specifications. +</td> +</tr> +</table> +</div> +<div class="paragraph"> +<p><strong>Section Structure</strong></p> +</div> +<div class="ulist"> +<ul> +<li> +<p><a href="#_risc_v_compatibility">RISC-V Compatibility</a></p> +</li> +<li> +<p><a href="#_cpu_top_entity_signals">CPU Top Entity - Signals</a> and <a href="#_cpu_top_entity_generics">CPU Top Entity - Generics</a></p> +</li> +<li> +<p><a href="#_architecture">Architecture</a> and <a href="#_full_virtualization">Full Virtualization</a></p> +</li> +<li> +<p><a href="#_instruction_sets_and_extensions">Instruction Sets and Extensions</a> and <a href="#_custom_functions_unit_cfu">Custom Functions Unit (CFU)</a></p> +</li> +<li> +<p><a href="#_control_and_status_registers_csrs">Control and Status Registers (CSRs)</a></p> +</li> +<li> +<p><a href="#_traps_exceptions_and_interrupts">Traps, Exceptions and Interrupts</a></p> +</li> +<li> +<p><a href="#_bus_interface">Bus Interface</a></p> +</li> +</ul> +</div> +<div class="sect2"> +<h3 id="_risc_v_compatibility">3.1. RISC-V Compatibility</h3> +<div class="paragraph"> +<p>The NEORV32 CPU passes the tests of the <strong>official RISCOF RISC-V Architecture Test Framework</strong>. This framework is used to check +RISC-V implementations for compatibility to the official RISC-V user/privileged ISA specifications. The NEORV32 port of this +test framework is available in a separate repository at GitHub: <a href="https://github.com/stnolting/neorv32-riscof" class="bare">https://github.com/stnolting/neorv32-riscof</a></p> +</div> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +<div class="title">Unsupported ISA Extensions</div> +Executing instructions or accessing CSRs from yet unsupported ISA extensions will raise an illegal +instruction exception (see section <a href="#_full_virtualization">Full Virtualization</a>). +</td> +</tr> +</table> +</div> +<div class="paragraph"> +<p><strong>Incompatibility Issues and Limitations</strong></p> +</div> +<div class="admonitionblock important"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-important" title="Important"></i> +</td> +<td class="content"> +<div class="title"><code>time[h]</code> CSRs (Wall Clock Time)</div> +The NEORV32 does not implement the <code>time[h]</code> registers. Any access to these registers will trap. It is +recommended that the trap handler software provides a means of accessing the platform-defined <a href="#_machine_system_timer_mtime">Machine System Timer (MTIME)</a>. +</td> +</tr> +</table> +</div> +<div class="admonitionblock important"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-important" title="Important"></i> +</td> +<td class="content"> +<div class="title">No Hardware Support of Misaligned Memory Accesses</div> +The CPU does not support resolving unaligned memory access by the hardware (this is not a +RISC-V-incompatibility issue but an important thing to know!). Any kind of unaligned memory access +will raise an exception to allow a <em>software-based</em> emulation provided by the application. However, unaligned memory +access can be <strong>emulated</strong> using the NEORV32 runtime environment. See section <a href="#_application_context_handling">Application Context Handling</a> +for more information. +</td> +</tr> +</table> +</div> +<div class="admonitionblock important"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-important" title="Important"></i> +</td> +<td class="content"> +<div class="title">No Atomic Read-Modify-Write Operations</div> +The NEORV32 <a href="#_a_isa_extension"><code>A</code> ISA Extension</a> only supports the load-reservate (LR) and store-conditional (SR) instructions. +The remaining read-modify-write operations are not supported. However, these missing instructions can +be emulated. The NEORV32 <a href="#_core_libraries">Core Libraries</a> provide an emulation wrapper for the missing AMO/read-modify-write +instructions that is based on LR/SC pairs. A demo/program can be found in <code>sw/example/atomic_test</code>. +</td> +</tr> +</table> +</div> +<div style="page-break-after: always;"></div> +</div> +<div class="sect2"> +<h3 id="_cpu_top_entity_signals">3.2. CPU Top Entity - Signals</h3> +<div class="paragraph"> +<p>The following table shows all interface signals of the CPU top entity <code>rtl/core/neorv32_cpu.vhd</code>. The +type of all signals is <em>std_ulogic</em> or <em>std_ulogic_vector</em>, respectively. The "Dir." column shows the signal +direction as seen from the CPU.</p> +</div> +<table class="tableblock frame-all grid-rows stretch"> +<caption class="title">Table 42. NEORV32 CPU Signal List</caption> +<colgroup> +<col style="width: 25%;"> +<col style="width: 25%;"> +<col style="width: 8.3333%;"> +<col style="width: 41.6667%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-left valign-top">Signal</th> +<th class="tableblock halign-center valign-top">Width/Type</th> +<th class="tableblock halign-center valign-top">Dir</th> +<th class="tableblock halign-left valign-top">Description</th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-center valign-top" colspan="4"><p class="tableblock"><strong>Global Signals</strong></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>clk_i</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">1</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">in</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Global clock line, all registers triggering on rising edge, this clock can be switched off during <a href="#_sleep_mode">Sleep Mode</a></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>clk_aux_i</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">1</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">in</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Always-on clock, used to keep the the sleep control active when <code>clk_i</code> is switched off</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>rstn_i</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">1</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">in</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Global reset, low-active</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>sleep_o</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">1</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">out</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">CPU is in <a href="#_sleep_mode">Sleep Mode</a> when set</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>debug_o</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">1</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">out</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">CPU is in <a href="#_cpu_debug_mode">debug mode</a> when set</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top" colspan="4"><p class="tableblock"><strong>Interrupts (<a href="#_traps_exceptions_and_interrupts">Traps, Exceptions and Interrupts</a>)</strong></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>msi_i</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">1</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">in</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">RISC-V machine software interrupt</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>mei_i</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">1</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">in</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">RISC-V machine external interrupt</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>mti_i</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">1</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">in</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">RISC-V machine timer interrupt</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>firq_i</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">16</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">in</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Custom fast interrupt request signals</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>dbi_i</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">1</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">in</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Request CPU to halt and enter debug mode (RISC-V <a href="#_on_chip_debugger_ocd">On-Chip Debugger (OCD)</a>)</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top" colspan="4"><p class="tableblock"><strong>Instruction <a href="#_bus_interface">Bus Interface</a></strong></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>ibus_req_o</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>bus_req_t</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">out</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Instruction fetch bus request</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>ibus_rsp_i</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>bus_rsp_t</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">in</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Instruction fetch bus response</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top" colspan="4"><p class="tableblock"><strong>Data <a href="#_bus_interface">Bus Interface</a></strong></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>dbus_req_o</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>bus_req_t</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">out</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Data access (load/store) bus request</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>dbus_rsp_i</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>bus_rsp_t</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">in</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Data access (load/store) bus response</p></td> +</tr> +</tbody> +</table> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +<div class="title">Bus Interface Protocol</div> +See section <a href="#_bus_interface">Bus Interface</a> for the instruction fetch and data access interface protocol and the +according interface types (<code>bus_req_t</code> and <code>bus_rsp_t</code>). +</td> +</tr> +</table> +</div> +<div style="page-break-after: always;"></div> +</div> +<div class="sect2"> +<h3 id="_cpu_top_entity_generics">3.3. CPU Top Entity - Generics</h3> +<div class="paragraph"> +<p>Most of the CPU configuration generics are a subset of the actual Processor configuration generics +(see section <a href="#_processor_top_entity_generics">Processor Top Entity - Generics</a>). and are not listed here. However, the CPU provides +some <em>specific</em> generics that are used to configure the CPU for the NEORV32 processor setup. These generics +are assigned by the processor setup only and are not available for user defined configuration. +The specific generics are listed below.</p> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">Table Abbreviations</div> +The generic type "suv(x:y)" defines a <code>std_ulogic_vector(x downto y)</code>. +</td> +</tr> +</table> +</div> +<table class="tableblock frame-all grid-rows stretch"> +<caption class="title">Table 43. NEORV32 CPU-Exclusive Generic List</caption> +<colgroup> +<col style="width: 28.5714%;"> +<col style="width: 14.2857%;"> +<col style="width: 57.1429%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-left valign-top">Name</th> +<th class="tableblock halign-center valign-top">Type</th> +<th class="tableblock halign-left valign-top">Description</th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>VENDOR_ID</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">suv(31:0)</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Value for the <a href="#_mvendorid"><strong><code>mvendorid</code></strong></a> CSR.</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>CPU_BOOT_ADDR</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">suv(31:0)</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">CPU reset address. See section <a href="#_address_space">Address Space</a>.</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>CPU_DEBUG_PARK_ADDR</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">suv(31:0)</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">"Park loop" entry address for the <a href="#_on_chip_debugger_ocd">On-Chip Debugger (OCD)</a>, has to be 4-byte aligned.</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>CPU_DEBUG_EXC_ADDR</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">suv(31:0)</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">"Exception" entry address for the <a href="#_on_chip_debugger_ocd">On-Chip Debugger (OCD)</a>, has to be 4-byte aligned.</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>CPU_EXTENSION_RISCV_Sdext</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">boolean</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Implement RISC-V-compatible "debug" CPU operation mode required for the <a href="#_on_chip_debugger_ocd">On-Chip Debugger (OCD)</a>.</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>CPU_EXTENSION_RISCV_Sdtrig</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">boolean</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Implement RISC-V-compatible trigger module. See section <a href="#_on_chip_debugger_ocd">On-Chip Debugger (OCD)</a>.</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>CPU_EXTENSION_RISCV_Smpmp</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">boolean</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Implement RISC-V-compatible physical memory protection (PMP). See section <a href="#_smpmp_isa_extension"><code>Smpmp</code> ISA Extension</a>.</p></td> +</tr> +</tbody> +</table> +<div style="page-break-after: always;"></div> +</div> +<div class="sect2"> +<h3 id="_architecture">3.4. Architecture</h3> +<div class="imageblock text-center"> +<div class="content"> +<img src="img/neorv32_cpu.png" alt="neorv32 cpu"> +</div> +</div> +<div class="paragraph"> +<p>The CPU implements a pipelined multi-cycle architecture: each instruction is executed as a series of consecutive +micro-operations. In order to increase performance, the CPU&#8217;s front-end (instruction fetch) and back-end +(instruction execution) are de-couples via a FIFO (the instruction prefetch buffer. Thus, the front-end can already +fetch new instructions while the back-end is still processing the previously-fetched instructions.</p> +</div> +<div class="paragraph"> +<p>Basically, the CPU&#8217;s micro architecture is somewhere between a classical pipelined architecture, where each stage +requires exactly one processing cycle (if not stalled) and a classical multi-cycle architecture, which executes +every single instruction (<em>including</em> fetch) in a series of consecutive micro-operations. The combination of these +two design paradigms allows an increased instruction execution in contrast to a pure multi-cycle approach (due to +overlapping operation of fetch and execute) at a reduced hardware footprint (due to the multi-cycle concept).</p> +</div> +<div class="paragraph"> +<p>As a Von-Neumann machine, the CPU provides independent interfaces for instruction fetch and data access. However, +these two bus interfaces are merged into a single processor-internal bus via a prioritizing bus switch (data accesses +have higher priority). Hence, <em>all</em> memory addresses including peripheral devices are mapped to a single unified 32-bit +<a href="#_address_space">Address Space</a>.</p> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +The CPU does not perform any speculative/out-of-order operations at all. Hence, it is not vulnerable to security issues +caused by speculative execution (like Spectre or Meltdown). +</td> +</tr> +</table> +</div> +<div class="sect3"> +<h4 id="_cpu_register_file">3.4.1. CPU Register File</h4> +<div class="paragraph"> +<p>The data register file contains the general purpose architecture registers <code>x0</code> to <code>x31</code>. For the <code>rv32e</code> ISA only the lower +16 registers are implemented. Register zero (<code>x0</code>/<code>zero</code>) always read as zero and any write access to it has no effect. +Up to four individual synchronous read ports allow to fetch up to 4 register operands at once. The write and read accesses +are mutually exclusive as they happen in separate cycles. Hence, there is no need to consider things like "read-during-write" +behavior.</p> +</div> +<div class="paragraph"> +<p>The register file provides two different implementation options configured via the top&#8217;s <code>REGFILE_HW_RST</code> generic.</p> +</div> +<div class="ulist"> +<ul> +<li> +<p><code>REGFILE_HW_RST = false</code> (default): In this configuration the register file is implemented as plain memory array without a +dictated hardware reset. This architecture allows to infer FPGA block RAM for the entire register file resulting in minimal +logic utilization and optimal timing.</p> +</li> +<li> +<p><code>REGFILE_HW_RST = true</code>: This configuration is based on individual FFs that do provide a dedicated hardware reset. +Hence, the register cannot be mapped to FPGA block RAM. This optional should only be selected if the application requires a +reset of the register file (e.g. for security reasons) or if the design shall be synthesized for an <strong>ASIC</strong> implementation.</p> +</li> +</ul> +</div> +<div class="paragraph"> +<p>The state of this configuration generic can be checked by software via the <a href="#_mxisa"><strong><code>mxisa</code></strong></a> CSR.</p> +</div> +<div class="admonitionblock warning"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-warning" title="Warning"></i> +</td> +<td class="content"> +<div class="title">FPGA Implementation</div> +Enabling the <code>REGFILE_HW_RST</code> option for FPGA implementation is not recommended as this will massively increase the amount +of required logic resources. +</td> +</tr> +</table> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">Implementation of the <code>zero</code> Register within FPGA Block RAM</div> +Register <code>zero</code> is also mapped to a <em>physical memory location</em> within the register file&#8217;s block RAM. By this, there is no need +to add a further multiplexer to "insert" zero if reading from register <code>zero</code> reducing logic requirements and shortening the +critical path. However, this also requires that the physical storage bits of register <code>zero</code> are explicitly initialized (set +to zero) by the hardware. This is done transparently by the CPU control requiring no additional processing overhead. +</td> +</tr> +</table> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">Block RAM Ports</div> +The default register file configuration uses two access ports: a read-only port for reading register <code>rs2</code> (second source operand) +and a read/write port for reading register <code>rs1</code> (first source operand) and for writing processing results to register <code>rd</code> +(destination register). Hence, a simple dual-port RAM can be used to implement the entire register file. From a functional point +of view, read and write accesses to the register file do never occur in the same clock cycle, so no bypass logic is required at all. +</td> +</tr> +</table> +</div> +</div> +<div class="sect3"> +<h4 id="_cpu_arithmetic_logic_unit">3.4.2. CPU Arithmetic Logic Unit</h4> +<div class="paragraph"> +<p>The arithmetic/logic unit (ALU) is used for actual data processing as well as generating memory and branch addresses. +All "simple" <a href="#_i_isa_extension"><code>I</code> ISA Extension</a> computational instructions (like <code>add</code> and <code>or</code>) are implemented as plain combinatorial logic +requiring only a single cycle to complete. More sophisticated instructions like shift operations or multiplications are processed +by so-called "ALU co-processors".</p> +</div> +<div class="paragraph"> +<p>The co-processors are implemented as iterative units that require several cycles to complete processing. Besides the base ISA&#8217;s +shift instructions, the co-processors are used to implement all further processing-based ISA extensions (e.g. <a href="#_m_isa_extension"><code>M</code> ISA Extension</a> +and <a href="#_b_isa_extension"><code>B</code> ISA Extension</a>).</p> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">Multi-Cycle Execution Monitor</div> +The CPU control will raise an illegal instruction exception if a multi-cycle functional unit (like the <a href="#_custom_functions_unit_cfu">Custom Functions Unit (CFU)</a>) +does not complete processing in a bound amount of time (configured via the package&#8217;s <code>monitor_mc_tmo_c</code> constant; default = 512 clock cycles). +</td> +</tr> +</table> +</div> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +<div class="title">Tuning Options</div> +The ALU architecture can be tuned for an application-specific area-vs-performance trade-off. The <code>FAST_MUL_EN</code> and <code>FAST_SHIFT_EN</code> +generics can be used to implement performance-optimized barrel shifters and DSP blocks, respectively. See sections <a href="#_i_isa_extension"><code>I</code> ISA Extension</a>, +<a href="#_b_isa_extension"><code>B</code> ISA Extension</a> and <a href="#_m_isa_extension"><code>M</code> ISA Extension</a> for specific examples. +</td> +</tr> +</table> +</div> +</div> +<div class="sect3"> +<h4 id="_cpu_bus_unit">3.4.3. CPU Bus Unit</h4> +<div class="paragraph"> +<p>The bus unit takes care of handling data memory accesses via load and store instructions. It handles data adjustment when accessing +sub-word data quantities (16-bit or 8-bit) and performs sign-extension for singed load operations. The bus unit also includes the optional +<a href="#_smpmp_isa_extension"><code>Smpmp</code> ISA Extension</a> that performs permission checks for all data and instruction accesses.</p> +</div> +<div class="paragraph"> +<p>A list of the bus interface signals and a detailed description of the protocol can be found in section <a href="#_bus_interface">Bus Interface</a>. +All bus interface signals are driven/buffered by registers; so even a complex SoC interconnection bus network will not +effect maximal operation frequency.</p> +</div> +<div class="admonitionblock warning"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-warning" title="Warning"></i> +</td> +<td class="content"> +<div class="title">Unaligned Accesses</div> +The CPU does not support a hardware-based handling of unaligned memory accesses! Any unaligned access will raise a bus load/store unaligned +address exception. The exception handler can be used to <em>emulate</em> unaligned memory accesses in software. +See the NEORV32 Runtime Environment&#8217;s <a href="#_application_context_handling">Application Context Handling</a> section for more information. +</td> +</tr> +</table> +</div> +</div> +<div class="sect3"> +<h4 id="_cpu_control_unit">3.4.4. CPU Control Unit</h4> +<div class="paragraph"> +<p>The CPU control unit is responsible for generating all the control signals for the different CPU modules. +The control unit is split into a "front-end" and a "back-end".</p> +</div> +<div class="paragraph"> +<p><strong>Front-End</strong></p> +</div> +<div class="paragraph"> +<p>The front-end is responsible for fetching instructions in chunks of 32-bits. This can be a single aligned 32-bit instruction, +two aligned 16-bit instructions or a mixture of those. The instructions including control and exception information are stored +to a FIFO queue - the instruction prefetch buffer (IPB). This FIFO has a depth of two entries by default but can be customized +via the <code>ipb_depth_c</code> VHDL package constant.</p> +</div> +<div class="paragraph"> +<p>The FIFO allows the front-end to do "speculative" instruction fetches, as it keeps fetching the next consecutive instruction +all the time. This also allows to decouple front-end (instruction fetch) and back-end (instruction execution) so both modules +can operate in parallel to increase performance. However, all potential side effects that are caused by this "speculative" +instruction fetch are already handled by the CPU front-end ensuring a defined execution stage while preventing security +side attacks.</p> +</div> +<div class="paragraph"> +<p><strong>Back-End</strong></p> +</div> +<div class="paragraph"> +<p>Instruction data from the instruction prefetch buffer is decompressed (if the <code>C</code> ISA extension is enabled) and sent to the +CPU back-end for actual execution. Execution is conducted by a state-machine that controls all of the CPU modules. The back-end also +includes the <a href="#_control_and_status_registers_csrs">Control and Status Registers (CSRs)</a> as well as the trap controller.</p> +</div> +</div> +<div class="sect3"> +<h4 id="_sleep_mode">3.4.5. Sleep Mode</h4> +<div class="paragraph"> +<p>The NEORV32 CPU provides a single sleep mode that can be entered to power-down the core reducing +dynamic power consumption. Sleep mode is entered by executing the <code>wfi</code> ("wait for interrupt") instruction.</p> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +The <code>wfi</code> instruction will raise an illegal instruction exception when executed in user-mode +if <code>TW</code> in <a href="#_mstatus"><strong><code>mstatus</code></strong></a> is set. When executed in debug-mode or during single-stepping <code>wfi</code> will behave as +simple <code>nop</code> without entering sleep mode. +</td> +</tr> +</table> +</div> +<div class="paragraph"> +<p>After executing the <code>wfi</code> instruction the CPU&#8217;s <code>sleep_o</code> signal (<a href="#_cpu_top_entity_signals">CPU Top Entity - Signals</a>) will become set +as soon as the CPU has fully halted ("CPU is sleeping"):</p> +</div> +<div class="paragraph"> +<div class="title">There is no enabled interrupt being pending.</div> +<p>CPU-external modules like memories, timers and peripheral interfaces are not affected by this. Furthermore, the CPU will +continue to buffer/enqueue incoming interrupt. The CPU will leave sleep mode as soon as any <em>enabled</em> interrupt (via <a href="#_mie"><strong><code>mie</code></strong></a>) +source becomes <em>pending</em> or if a debug session is started.</p> +</div> +<div class="sect4"> +<h5 id="_power_down_mode">Power-Down Mode</h5> +<div class="paragraph"> +<p>Optionally, the sleep mode can also be used to shut down the CPU&#8217;s main clock to further reduce power consumption +by halting the core&#8217;s clock tree. This clock gating mode is enabled by the <code>CLOCK_GATING_EN</code> generic +(<a href="#_processor_top_entity_generics">Processor Top Entity - Generics</a>). See section <a href="#_processor_clocking">Processor Clocking</a> for more information.</p> +</div> +</div> +</div> +<div class="sect3"> +<h4 id="_full_virtualization">3.4.6. Full Virtualization</h4> +<div class="paragraph"> +<p>Just like the RISC-V ISA, the NEORV32 aims to provide <em>maximum virtualization</em> capabilities on CPU and SoC level to +allow a high standard of <strong>execution safety</strong>. The CPU supports <strong>all</strong> traps specified by the official RISC-V +specifications. Thus, the CPU provides defined hardware fall-backs via traps for any expected and unexpected situations +(e.g. executing a malformed or not supported instruction or accessing a non-allocated memory address). For any kind +of trap the core is always in a defined and fully synchronized state throughout the whole system (i.e. there are no +out-of-order operations that might have to be reverted). This allows a defined and predictable execution behavior +at any time improving overall execution safety.</p> +</div> +<div style="page-break-after: always;"></div> +</div> +</div> +<div class="sect2"> +<h3 id="_bus_interface">3.5. Bus Interface</h3> +<div class="paragraph"> +<p>The NEORV32 CPU provides separated instruction fetch and data access interfaces making it a <strong>Harvard Architecture</strong>: +the instruction fetch interface (<code>i_bus_*</code> signals) is used for fetching instructions and the data access interface +(<code>d_bus_*</code> signals) is used to access data via load and store operations. Each of these interfaces can access an address +space of up to 2<sup>32</sup> bytes (4GB).</p> +</div> +<div class="paragraph"> +<p>The bus interface uses two custom interface types: <code>bus_req_t</code> is used to propagate the bus access <strong>requests</strong>. These +signals are driven by the <em>accessing</em> device (i.e. the CPU core). <code>bus_rsp_t</code> is used to return the bus <strong>response</strong> and +is driven by the <em>accessed</em> device or bus system (i.e. a processor-internal memory or IO device).</p> +</div> +<table class="tableblock frame-all grid-rows stretch"> +<caption class="title">Table 44. Bus Interface - Request Bus (<code>bus_req_t</code>)</caption> +<colgroup> +<col style="width: 12.5%;"> +<col style="width: 12.5%;"> +<col style="width: 75%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-center valign-top">Signal</th> +<th class="tableblock halign-center valign-top">Width</th> +<th class="tableblock halign-left valign-top">Description</th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>addr</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">32</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Access address (byte addressing)</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>data</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">32</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Write data</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>ben</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">4</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Byte-enable for each byte in <code>data</code></p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>stb</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">1</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Request trigger ("strobe", single-shot)</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>rw</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">1</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Access direction (<code>0</code> = read, <code>1</code> = write)</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>src</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">1</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Access source (<code>0</code> = instruction fetch, <code>1</code> = load/store)</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>priv</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">1</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Set if privileged (M-mode) access</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>rvso</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">1</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Set if current access is a reservation-set operation (atomic <code>lr</code> or <code>sc</code> instruction)</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>fence</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">1</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Data/instruction fence operation; valid without <code>stb</code> being set</p></td> +</tr> +</tbody> +</table> +<table class="tableblock frame-all grid-rows stretch"> +<caption class="title">Table 45. Bus Interface - Response Bus (<code>bus_rsp_t</code>)</caption> +<colgroup> +<col style="width: 12.5%;"> +<col style="width: 12.5%;"> +<col style="width: 75%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-center valign-top">Signal</th> +<th class="tableblock halign-center valign-top">Width</th> +<th class="tableblock halign-left valign-top">Description</th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>data</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">32</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Read data (single-shot)</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>ack</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">1</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Transfer acknowledge / success (single-shot)</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>err</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">1</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Transfer error / fail (single-shot)</p></td> +</tr> +</tbody> +</table> +<div class="sect3"> +<h4 id="_bus_interface_protocol">3.5.1. Bus Interface Protocol</h4> +<div class="paragraph"> +<p>Transactions are triggered entirely by the request bus. A new bus request is initiated by setting the <em>strobe</em> +signal <code>stb</code> high for exactly one cycle. All remaining signals of the bus are set together with <code>stb</code> and will +remain unchanged until the transaction is completed.</p> +</div> +<div class="paragraph"> +<p>The transaction is completed when the accessed device returns a response via the response interface: +<code>ack</code> is high for exactly one cycle if the transaction was completed successfully. <code>err</code> is high for exactly +one cycle if the transaction failed to complete. These two signals are mutually exclusive. In case of a read +access the read data is returned together with the <code>ack</code> signal. Otherwise, the return data signal is +kept at all-zero allowing wired-or interconnection of all response buses.</p> +</div> +<div class="paragraph"> +<p>The figure below shows three exemplary bus accesses:</p> +</div> +<div class="olist arabic"> +<ol class="arabic" start="1"> +<li> +<p>A read access to address <code>A_addr</code> returning <code>rdata</code> after several cycles (slow response; <code>ACK</code> arrives after several cycles).</p> +</li> +<li> +<p>A write access to address <code>B_addr</code> writing <code>wdata</code> (fastest response; <code>ACK</code> arrives right in the next cycle).</p> +</li> +<li> +<p>A failing read access to address <code>C_addr</code> (slow response; <code>ERR</code> arrives after several cycles).</p> +</li> +</ol> +</div> +<div class="imageblock"> +<div class="content"> +<img src="img/bus_interface.png" alt="700"> +</div> +<div class="title">Figure 9. Three Exemplary Bus Transactions</div> +</div> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +<div class="title">Adding Register Stages</div> +Arbitrary pipeline stages can be added to the request and response buses at any point to relax timing (at the cost of +additional latency). However, <em>all</em> bus signals (request and response) need to be registered. +</td> +</tr> +</table> +</div> +</div> +<div class="sect3"> +<h4 id="_atomic_accesses">3.5.2. Atomic Accesses</h4> +<div class="paragraph"> +<p>The load-reservate (<code>lr.w</code>) and store-conditional (<code>sc.w</code>) instructions from the <a href="#_a_isa_extension"><code>A</code> ISA Extension</a> execute as standard +load/store bus transactions but with the <code>rvso</code> ("reservation set operation") signal being set. It is the task of the +<a href="#_reservation_set_controller">Reservation Set Controller</a> to handle these LR/SC bus transactions accordingly. Note that these reservation set operations +are intended for processor-internal usage only (i.e. the reservation state is not available for processor-external modules yet).</p> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">Reservation Set Controller</div> +See section <a href="#_address_space">Address Space</a> / <a href="#_reservation_set_controller">Reservation Set Controller</a> for more information. +</td> +</tr> +</table> +</div> +<div class="admonitionblock important"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-important" title="Important"></i> +</td> +<td class="content"> +<div class="title">Read-Modify-Write Operations</div> +Read-modify-write operations (like an atomic swap / <code>amoswap.w</code>) are <strong>not</strong> supported yet. However, the NEORV32 +<a href="#_core_libraries">Core Libraries</a> provide an emulation wrapper for those unsupported instructions that is +based on LR/SC pairs. A demo/program can be found in <code>sw/example/atomic_test</code>. +</td> +</tr> +</table> +</div> +<div class="paragraph"> +<p>The figure below shows three exemplary bus accesses (1 to 3 from left to right). The <code>req</code> signal record represents +the CPU-side of the bus interface. For easier understanding the current state of the reservation set is added as <code>rvs_valid</code> signal.</p> +</div> +<div class="olist arabic"> +<ol class="arabic" start="1"> +<li> +<p>A load-reservate (LR) instruction using <code>addr</code> as address. This instruction returns the loaded data <code>rdata</code> via <code>rsp.data</code> +and also registers a reservation for the address <code>addr</code> (<code>rvs_valid</code> becomes set).</p> +</li> +<li> +<p>A store-conditional (SC) instruction attempts to write <code>wdata1</code> to address <code>addr</code>. This SC operation <strong>succeeds</strong>, so +<code>wdata1</code> is actually written to address <code>addr</code>. The successful operation is indicated by a <strong>0</strong> being returned via +<code>rsp.data</code> together with <code>ack</code>. As the LR/SC is completed the registered reservation is invalidated (<code>rvs_valid</code> becomes cleared).</p> +</li> +<li> +<p>Another store-conditional (SC) instruction attempts to write <code>wdata2</code> to address <code>addr</code>. As the reservation set is already +invalidated (<code>rvs_valid</code> is <code>0</code>) the store access fails, so <code>wdata2</code> is <strong>not</strong> written to address <code>addr</code> at all. The failed +operation is indicated by a <strong>1</strong> being returned via <code>rsp.data</code> together with <code>ack</code>.</p> +</li> +</ol> +</div> +<div class="imageblock"> +<div class="content"> +<img src="img/bus_interface_atomic.png" alt="700"> +</div> +<div class="title">Figure 10. Three Exemplary LR/SC Bus Transactions</div> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">SC Status</div> +The "normal" load data mechanism is used to return success/failure of the <code>sc.w</code> instruction to the CPU (via the LSB of <code>rsp.data</code>). +</td> +</tr> +</table> +</div> +<div style="page-break-after: always;"></div> +</div> +</div> +<div class="sect2"> +<h3 id="_instruction_sets_and_extensions">3.6. Instruction Sets and Extensions</h3> +<div class="paragraph"> +<p>The NEORV32 CPU provides several optional RISC-V and custom ISA extensions. The extensions can be enabled/configured +via the according <a href="#_processor_top_entity_generics">Processor Top Entity - Generics</a>. This chapter gives a brief overview of the different ISA extensions.</p> +</div> +<table class="tableblock frame-all grid-rows stretch"> +<caption class="title">Table 46. NEORV32 Instruction Set Extensions</caption> +<colgroup> +<col style="width: 20%;"> +<col style="width: 50%;"> +<col style="width: 30%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-left valign-top">Name</th> +<th class="tableblock halign-left valign-top">Description</th> +<th class="tableblock halign-left valign-top"><a href="#_processor_top_entity_generics">Enabled by Generic</a></th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_a_isa_extension"><code>A</code></a></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Atomic memory access instructions</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>CPU_EXTENSION_RISCV_A</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_b_isa_extension"><code>B</code></a></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Bit-manipulation instructions</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>CPU_EXTENSION_RISCV_B</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_c_isa_extension"><code>C</code></a></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Compressed (16-bit) instructions</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>CPU_EXTENSION_RISCV_C</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_e_isa_extension"><code>E</code></a></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Embedded CPU extension (reduced register file size)</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>CPU_EXTENSION_RISCV_E</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_i_isa_extension"><code>I</code></a></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Integer base ISA</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Enabled if <code>CPU_EXTENSION_RISCV_E</code> is <strong>not</strong> enabled</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_m_isa_extension"><code>M</code></a></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Integer multiplication and division instructions</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>CPU_EXTENSION_RISCV_M</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_u_isa_extension"><code>U</code></a></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Less-privileged <em>user</em> mode extension</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>CPU_EXTENSION_RISCV_U</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_x_isa_extension"><code>X</code></a></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Platform-specific / NEORV32-specific extension</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Always enabled</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_zifencei_isa_extension"><code>Zifencei</code></a></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Instruction stream synchronization instruction</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Always enabled</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_zfinx_isa_extension"><code>Zfinx</code></a></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Floating-point instructions using integer registers</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>CPU_EXTENSION_RISCV_Zfinx</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_zicntr_isa_extension"><code>Zicntr</code></a></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Base counters extension</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>CPU_EXTENSION_RISCV_Zicntr</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_zicond_isa_extension"><code>Zicond</code></a></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Integer conditional operations</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>CPU_EXTENSION_RISCV_Zicond</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_zicsr_isa_extension"><code>Zicsr</code></a></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Control and status register access instructions</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Always enabled</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_zihpm_isa_extension"><code>Zihpm</code></a></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Hardware performance monitors extension</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>CPU_EXTENSION_RISCV_Zihpm</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_zmmul_isa_extension"><code>Zmmul</code></a></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Integer multiplication-only instruction</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>CPU_EXTENSION_RISCV_Zmmul</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_zcfu_isa_extension"><code>Zcfu</code></a></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Custom / user-defined instructions</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>CPU_EXTENSION_RISCV_Zxcfu</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_smpmp_isa_extension"><code>Smpmp</code></a></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Physical memory protection (PMP) extension</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>CPU_EXTENSION_RISCV_Smpmp</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_sdext_isa_extension"><code>Sdext</code></a></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">External debug support extension</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>ON_CHIP_DEBUGGER_EN</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_sdtrig_isa_extension"><code>Sdtrig</code></a></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Trigger module extension</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>ON_CHIP_DEBUGGER_EN</code></p></td> +</tr> +</tbody> +</table> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +<div class="title">RISC-V ISA Specifications</div> +For more information regarding the RISC-V ISA extensions please refer to the "RISC-V Instruction Set Manual - Volume +I: Unprivileged ISA" and "The RISC-V Instruction Set Manual Volume II: Privileged Architecture" Acopy of all currently +implemented ISA extensions can be found in the projects <code>docs/references</code> folder. +</td> +</tr> +</table> +</div> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +<div class="title">Discovering ISA Extensions</div> +Software can discover available ISA extensions via the <a href="#_misa"><strong><code>misa</code></strong></a> and <a href="#_mxisa"><strong><code>mxisa</code></strong></a> CSRs or by executing an instruction +and checking for an illegal instruction exception (i.e. <a href="#_full_virtualization">Full Virtualization</a>). +</td> +</tr> +</table> +</div> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +<div class="title">Instruction Cycles</div> +This chapter shows the CPI values (cycles per instruction) for each individual instruction/type. Note that +values reflect <em>optimal conditions</em> (i.e. not additional memory delay, no cache misses, no pipeline waits, etc.). +To benchmark a certain processor configuration for its setup-specific CPI value please refer to the +<code>sw/example/performance_tests</code> test programs. +</td> +</tr> +</table> +</div> +<div class="sect3"> +<h4 id="_a_isa_extension">3.6.1. <code>A</code> ISA Extension</h4> +<div class="paragraph"> +<p>The <code>A</code> ISA extension adds instructions and mechanisms for atomic memory access operations. Note that the NEORV32 <code>A</code> +only includes the <em>load-reservate</em> (<code>lr.w</code>) and <em>store-conditional</em> (<code>sc.w</code>) instructions - the remaining read-modify-write +instructions (like <code>amoswap</code>) are <strong>not supported</strong>. However, these missing instructions can be emulated using the +LR and SC operations (quote from the RISC-V spec.: "<em>Any AMO can be emulated by an LR/SC pair.</em>").</p> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">AMO Emulation</div> +The NEORV32 <a href="#_core_libraries">Core Libraries</a> provide an emulation wrapper for the missing AMO/read-modify-write instructions that is +based on LR/SC pairs. A demo/program can be found in <code>sw/example/atomic_test</code>. +</td> +</tr> +</table> +</div> +<div class="paragraph"> +<p>Atomic instructions allow to notify an application if a certain memory location has been altered by another instance +(like another process running on the same CPU or a DMA access). Hence, they can be used to implement synchronization +mechanisms like mutexes and semaphores).</p> +</div> +<div class="paragraph"> +<p>The NEORV32 <code>A</code> extension is enabled via the <code>CPU_EXTENSION_RISCV_A</code> generic (see <a href="#_processor_top_entity_generics">Processor Top Entity - Generics</a>). +When enabled the following additional instructions are available.</p> +</div> +<table class="tableblock frame-all grid-rows stretch"> +<caption class="title">Table 47. Instructions and Timing</caption> +<colgroup> +<col style="width: 22.2222%;"> +<col style="width: 44.4444%;"> +<col style="width: 33.3334%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-left valign-top">Class</th> +<th class="tableblock halign-left valign-top">Instructions</th> +<th class="tableblock halign-left valign-top">Execution cycles</th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Load-reservate word</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>lr.w</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">5</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Store-conditional word</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>sc.w</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">5</p></td> +</tr> +</tbody> +</table> +<div class="paragraph"> +<p>The <code>lr.w</code> instructions stores one word to a word-aligned address and registers a <em>reservation set</em>. The <code>sc.w</code> +instruction stores a word to a word-aligned address only if the reservation set is still valid. Furthermore, the +<code>sc.w</code> operations returns the state of the reservation set (0 = reservation set still valid, data has been written; +1 = reservation set was broken, no data has been written). The reservation set is invalidated if another <code>lr.w</code> instruction +is executed or if any write access to the <em>reservated</em> address takes place. Traps and/or CPU privilege level changes +do not modify current reservation sets.</p> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title"><code>aq</code> and <code>rl</code> Bits</div> +The instruction word&#8217;s <code>aq</code> and <code>lr</code> memory ordering bits are not evaluated by the hardware at all. +</td> +</tr> +</table> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">Atomic Memory Access on Hardware Level</div> +More information regarding the atomic memory accesses and the according reservation +sets can be found in section <a href="#_reservation_set_controller">Reservation Set Controller</a>. +</td> +</tr> +</table> +</div> +<div class="admonitionblock important"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-important" title="Important"></i> +</td> +<td class="content"> +<div class="title">Cache Coherency</div> +Atomic operations <strong>always bypass</strong> the CPU caches using direct/uncached accesses. Care must be taken +to maintain data cache coherency (e.g. by using the <code>fence</code> instruction). +</td> +</tr> +</table> +</div> +</div> +<div class="sect3"> +<h4 id="_b_isa_extension">3.6.2. <code>B</code> ISA Extension</h4> +<div class="paragraph"> +<p>The <code>B</code> ISA extension adds instructions for bit-manipulation operations. +This ISA extension is implemented as multi-cycle ALU co-process (<code>rtl/core/neorv32_cpu_cp_bitmanip.vhd</code>). +The NEORV32 <code>B</code> ISA extension includes the following sub-extensions:</p> +</div> +<div class="ulist"> +<ul> +<li> +<p><code>Zba</code> - Address-generation instructions</p> +</li> +<li> +<p><code>Zbb</code> - Basic bit-manipulation instructions</p> +</li> +<li> +<p><code>Zbs</code> - Single-bit instructions</p> +</li> +</ul> +</div> +<table class="tableblock frame-all grid-rows stretch"> +<caption class="title">Table 48. Instructions and Timing</caption> +<colgroup> +<col style="width: 22.2222%;"> +<col style="width: 44.4444%;"> +<col style="width: 33.3334%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-left valign-top">Class</th> +<th class="tableblock halign-left valign-top">Instructions</th> +<th class="tableblock halign-left valign-top">Execution cycles</th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Arithmetic/logic</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>min[u]</code> <code>max[u]</code> <code>sext.b</code> <code>sext.h</code> <code>andn</code> <code>orn</code> <code>xnor</code> <code>zext</code>(pack) <code>rev8</code>(grevi) <code>orc.b</code>(gorci)</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">4</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Shifts</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>clz</code> <code>ctz</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">3 + 1..32; FAST_SHIFT: 4</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Shifts</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>cpop</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">36; FAST_SHIFT: 4</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Shifts</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>rol</code> <code>ror[i]</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">4 + <em>shift_amount</em>; FAST_SHIFT: 4</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Shifted-add</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>sh1add</code> <code>sh2add</code> <code>sh3add</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">4</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Single-bit</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>sbset[i]</code> <code>sbclr[i]</code> <code>sbinv[i]</code> <code>sbext[i]</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">4</p></td> +</tr> +</tbody> +</table> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +<div class="title">Shift Operations</div> +Shift operations can be accelerated (at the cost of additional logic resources) by enabling the <code>FAST_SHIFT_EN</code> +configuration option that will replace the (time-variant) bit-serial shifter by a (time-constant) barrel shifter. +</td> +</tr> +</table> +</div> +</div> +<div class="sect3"> +<h4 id="_c_isa_extension">3.6.3. <code>C</code> ISA Extension</h4> +<div class="paragraph"> +<p>The "compressed" ISA extension provides 16-bit encodings of commonly used instructions to reduce code space size.</p> +</div> +<table class="tableblock frame-all grid-rows stretch"> +<caption class="title">Table 49. Instructions and Timing</caption> +<colgroup> +<col style="width: 22.2222%;"> +<col style="width: 44.4444%;"> +<col style="width: 33.3334%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-left valign-top">Class</th> +<th class="tableblock halign-left valign-top">Instructions</th> +<th class="tableblock halign-left valign-top">Execution cycles</th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">ALU</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>c.addi4spn</code> <code>c.nop</code> <code>c.add[i]</code> <code>c.li</code> <code>c.addi16sp</code> <code>c.lui</code> <code>c.and[i]</code> <code>c.sub</code> <code>c.xor</code> <code>c.or</code> <code>c.mv</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">2</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">ALU</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>c.srli</code> <code>c.srai</code> <code>c.slli</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">3 + 1..32; FAST_SHIFT: 4</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Branches</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>c.beqz</code> <code>c.bnez</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">taken: 6; not taken: 3</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Jumps / calls</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>c.jal[r]</code> <code>c.j</code> <code>c.jr</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">6</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Memory access</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>c.lw</code> <code>c.sw</code> <code>c.lwsp</code> <code>c.swsp</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">4</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">System</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>c.break</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">3</p></td> +</tr> +</tbody> +</table> +</div> +<div class="sect3"> +<h4 id="_e_isa_extension">3.6.4. <code>E</code> ISA Extension</h4> +<div class="paragraph"> +<p>The "embedded" ISA extensions reduces the size of the general purpose register file from 32 entries to 16 entries to +shrink hardware size. It provides the same instructions as the the base <code>I</code> ISA extensions.</p> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +Due to the reduced register file size an alternate toolchain ABI (<code>ilp32e*</code>) is required. +</td> +</tr> +</table> +</div> +</div> +<div class="sect3"> +<h4 id="_i_isa_extension">3.6.5. <code>I</code> ISA Extension</h4> +<div class="paragraph"> +<p>The <code>I</code> ISA extensions is the base RISC-V integer ISA that is always enabled.</p> +</div> +<table class="tableblock frame-all grid-rows stretch"> +<caption class="title">Table 50. Instructions and Timing</caption> +<colgroup> +<col style="width: 22.2222%;"> +<col style="width: 44.4444%;"> +<col style="width: 33.3334%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-left valign-top">Class</th> +<th class="tableblock halign-left valign-top">Instructions</th> +<th class="tableblock halign-left valign-top">Execution cycles</th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">ALU</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>add[i]</code> <code>slt[i]</code> <code>slt[i]u</code> <code>xor[i]</code> <code>or[i]</code> <code>and[i]</code> <code>sub</code> <code>lui</code> <code>auipc</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">2</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">ALU shifts</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>sll[i]</code> <code>srl[i]</code> <code>sra[i]</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">3 + 1..32; FAST_SHIFT: 4</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Branches</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>beq</code> <code>bne</code> <code>blt</code> <code>bge</code> <code>bltu</code> <code>bgeu</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">taken: 6; not taken: 3</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Jump/call</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>jal[r]</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">6</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Load/store</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>lb</code> <code>lh</code> <code>lw</code> <code>lbu</code> <code>lhu</code> <code>sb</code> <code>sh</code> <code>sw</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">5</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">System</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>ecall</code> <code>ebreak</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">3</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Data fence</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>fence</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">5</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">System</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>wfi</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">3</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">System</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>mret</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">5</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Illegal inst.</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">3</p></td> +</tr> +</tbody> +</table> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title"><code>fence</code> Instruction</div> +The <code>fence</code> instruction word&#8217;s <em>predecessor</em> and <em>successor</em> bits (used for memory ordering) are not evaluated +by the hardware at all. For the NEORV32 the <code>fence</code> instruction behaves exactly like the <code>fence.i</code> instruction +(see <a href="#_zifencei_isa_extension"><code>Zifencei</code> ISA Extension</a>). However, software should still use distinct <code>fence</code> and <code>fence.i</code> to provide +platform-compatibility and to indicate the actual intention of the according fence instruction(s). +</td> +</tr> +</table> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title"><code>wfi</code> Instruction</div> +The <code>wfi</code> instruction is used to enter <a href="#_sleep_mode">Sleep Mode</a>. Executing the <code>wfi</code> instruction in user-mode +will raise an illegal instruction exception if the <code>TW</code> bit of <a href="#_mstatus"><strong><code>mstatus</code></strong></a> is set. +</td> +</tr> +</table> +</div> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +<div class="title">Barrel Shifter</div> +The shift operations are implemented as multi-cycle ALU co-process (<code>rtl/core/neorv32_cpu_cp_shifter.vhd</code>). +These operations can be accelerated (at the cost of additional logic resources) by enabling the <code>FAST_SHIFT_EN</code> +configuration option that will replace the (time-variant) bit-serial shifter by a (time-constant) barrel shifter. +</td> +</tr> +</table> +</div> +</div> +<div class="sect3"> +<h4 id="_m_isa_extension">3.6.6. <code>M</code> ISA Extension</h4> +<div class="paragraph"> +<p>Hardware-accelerated integer multiplication and division operations are available via the RISC-V <code>M</code> ISA extension. +This ISA extension is implemented as multi-cycle ALU co-process (<code>rtl/core/neorv32_cpu_cp_muldiv.vhd</code>).</p> +</div> +<table class="tableblock frame-all grid-rows stretch"> +<caption class="title">Table 51. Instructions and Timing</caption> +<colgroup> +<col style="width: 22.2222%;"> +<col style="width: 44.4444%;"> +<col style="width: 33.3334%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-left valign-top">Class</th> +<th class="tableblock halign-left valign-top">Instructions</th> +<th class="tableblock halign-left valign-top">Execution cycles</th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Multiplication</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>mul</code> <code>mulh</code> <code>mulhsu</code> <code>mulhu</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">36; FAST_MUL: 4</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Division</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>div</code> <code>divu</code> <code>rem</code> <code>remu</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">36</p></td> +</tr> +</tbody> +</table> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +<div class="title">DSP Blocks</div> +Multiplication operations can be accelerated (at the cost of additional logic resources) by enabling the <code>FAST_MUL_EN</code> +configuration option that will replace the (time-variant) bit-serial multiplier by (time-constant) FPGA DSP blocks. +</td> +</tr> +</table> +</div> +</div> +<div class="sect3"> +<h4 id="_u_isa_extension">3.6.7. <code>U</code> ISA Extension</h4> +<div class="paragraph"> +<p>In addition to the highest-privileged machine-mode, the user-mode ISA extensions adds a second <strong>less-privileged</strong> +operation mode. Code executed in user-mode has reduced CSR access rights. Furthermore, user-mode accesses to the address space +(like peripheral/IO devices) can be constrained via the physical memory protection. +Any kind of privilege rights violation will raise an exception to allow <a href="#_full_virtualization">Full Virtualization</a>.</p> +</div> +</div> +<div class="sect3"> +<h4 id="_x_isa_extension">3.6.8. <code>X</code> ISA Extension</h4> +<div class="paragraph"> +<p>The NEORV32-specific ISA extensions <code>X</code> is always enabled. The most important points of the NEORV32-specific extensions are: +* The CPU provides 16 <em>fast interrupt</em> interrupts (<code>FIRQ</code>), which are controlled via custom bits in the <a href="#_mie"><strong><code>mie</code></strong></a> +and <a href="#_mip"><strong><code>mip</code></strong></a> CSRs. These extensions are mapped to CSR bits, that are available for custom use according to the +RISC-V specs. Also, custom trap codes for <a href="#_mcause"><strong><code>mcause</code></strong></a> are implemented. +* All undefined/unimplemented/malformed/illegal instructions do raise an illegal instruction exception (see <a href="#_full_virtualization">Full Virtualization</a>). +* There are <a href="#_neorv32_specific_csrs">NEORV32-Specific CSRs</a>.</p> +</div> +</div> +<div class="sect3"> +<h4 id="_zifencei_isa_extension">3.6.9. <code>Zifencei</code> ISA Extension</h4> +<div class="paragraph"> +<p>The <code>Zifencei</code> CPU extension allows manual synchronization of the instruction stream. This extension is always enabled.</p> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">NEORV32 Fence Instructions</div> +The NEORV32 treats both fence instructions (<code>fence</code> = data fence, <code>fence.i</code> = instruction fence) in exactly the same way. +Both instructions cause a flush of the CPU&#8217;s instruction prefetch buffer and also send a fence request via the system +bus (see <a href="#_bus_interface">Bus Interface</a>). This system bus fence operation will, for example, clear/flush all downstream caches. +</td> +</tr> +</table> +</div> +<table class="tableblock frame-all grid-rows stretch"> +<caption class="title">Table 52. Instructions and Timing</caption> +<colgroup> +<col style="width: 22.2222%;"> +<col style="width: 44.4444%;"> +<col style="width: 33.3334%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-left valign-top">Class</th> +<th class="tableblock halign-left valign-top">Instructions</th> +<th class="tableblock halign-left valign-top">Execution cycles</th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Instruction fence</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>fence.i</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">5</p></td> +</tr> +</tbody> +</table> +</div> +<div class="sect3"> +<h4 id="_zfinx_isa_extension">3.6.10. <code>Zfinx</code> ISA Extension</h4> +<div class="paragraph"> +<p>The <code>Zfinx</code> floating-point extension is an <em>alternative</em> of the standard <code>F</code> floating-point ISA extension. +It also uses the integer register file <code>x</code> to store and operate on floating-point data +instead of a dedicated floating-point register file. Thus, the <code>Zfinx</code> extension requires +less hardware resources and features faster context changes. This also implies that there are NO dedicated <code>f</code> +register file-related load/store or move instructions. The <code>Zfinx</code> extension&#8217;S floating-point unit is controlled +via dedicated <a href="#_floating_point_csrs">Floating-Point CSRs</a>. +This ISA extension is implemented as multi-cycle ALU co-process (<code>rtl/core/neorv32_cpu_cp_fpu.vhd</code>).</p> +</div> +<div class="admonitionblock warning"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-warning" title="Warning"></i> +</td> +<td class="content"> +<div class="title">Fused / Multiply-Add Instructions</div> +Fused multiply-add instructions <code>f[n]m[add/sub].s</code> are not supported. A special GCC switch is used to prevent the +compiler from emitting contracted/fused floating-point operations (see <a href="#_default_compiler_flags">Default Compiler Flags</a>). +</td> +</tr> +</table> +</div> +<div class="admonitionblock warning"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-warning" title="Warning"></i> +</td> +<td class="content"> +<div class="title">Division and Squarer Root Instructions</div> +Division <code>fdiv.s</code> and square root <code>fsqrt.s</code> instructions are not supported yet. +</td> +</tr> +</table> +</div> +<div class="admonitionblock warning"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-warning" title="Warning"></i> +</td> +<td class="content"> +<div class="title">Subnormal Number</div> +Subnormal numbers ("de-normalized" numbers, i.e. exponent = 0) are not supported by the NEORV32 FPU. +Subnormal numbers are <em>flushed to zero</em> setting them to +/- 0 before being processed by <strong>any</strong> FPU operation. +If a computational instruction generates a subnormal result it is also flushed to zero during normalization. +</td> +</tr> +</table> +</div> +<table class="tableblock frame-all grid-rows stretch"> +<caption class="title">Table 53. Instructions and Timing</caption> +<colgroup> +<col style="width: 22.2222%;"> +<col style="width: 44.4444%;"> +<col style="width: 33.3334%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-left valign-top">Class</th> +<th class="tableblock halign-left valign-top">Instructions</th> +<th class="tableblock halign-left valign-top">Execution cycles</th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Artihmetic</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>fadd.s</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">110</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Artihmetic</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>fsub.s</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">112</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Artihmetic</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>fmul.s</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">22</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Compare</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>fmin.s</code> <code>fmax.s</code> <code>feq.s</code> <code>flt.s</code> <code>fle.s</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">13</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Conversion</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>fcvt.w.s</code> <code>fcvt.wu.s</code> <code>fcvt.s.w</code> <code>fcvt.s.wu</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">48</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Misc</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>fsgnj.s</code> <code>fsgnjn.s</code> <code>fsgnjx.s</code> <code>fclass.s</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">12</p></td> +</tr> +</tbody> +</table> +</div> +<div class="sect3"> +<h4 id="_zicntr_isa_extension">3.6.11. <code>Zicntr</code> ISA Extension</h4> +<div class="paragraph"> +<p>The <code>Zicntr</code> ISA extension adds the basic <a href="#_cycleh"><strong><code>cycle[h]</code></strong></a>, <a href="#_mcycleh"><strong><code>mcycle[h]</code></strong></a>, <a href="#_instreth"><strong><code>instret[h]</code></strong></a> and <a href="#_minstreth"><strong><code>minstret[h]</code></strong></a> +counter CSRs. Section <a href="#_machine_counter_and_timer_csrs">(Machine) Counter and Timer CSRs</a> shows a list of all <code>Zicntr</code>-related CSRs.</p> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +The user-mode <code>time[h]</code> CSRs are <strong>not implemented</strong>. Any access will trap allowing the trap handler to +retrieve system time from the <a href="#_machine_system_timer_mtime">Machine System Timer (MTIME)</a>. +</td> +</tr> +</table> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +This extensions is stated as <em>mandatory</em> by the RISC-V spec. However, area-constrained setups may remove +support for these counters. +</td> +</tr> +</table> +</div> +</div> +<div class="sect3"> +<h4 id="_zicond_isa_extension">3.6.12. <code>Zicond</code> ISA Extension</h4> +<div class="paragraph"> +<p>The <code>Zicond</code> ISA extension adds integer conditional move primitives that allow to implement branch-less +control flows. It is enabled by the top&#8217;s <code>CPU_EXTENSION_RISCV_Zicond</code> generic. +This ISA extension is implemented as multi-cycle ALU co-process (<code>rtl/core/neorv32_cpu_cp_cond.vhd</code>).</p> +</div> +<table class="tableblock frame-all grid-rows stretch"> +<caption class="title">Table 54. Instructions and Timing</caption> +<colgroup> +<col style="width: 22.2222%;"> +<col style="width: 44.4444%;"> +<col style="width: 33.3334%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-left valign-top">Class</th> +<th class="tableblock halign-left valign-top">Instructions</th> +<th class="tableblock halign-left valign-top">Execution cycles</th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Conditional</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>czero.eqz</code> <code>czero.nez</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">3</p></td> +</tr> +</tbody> +</table> +</div> +<div class="sect3"> +<h4 id="_zicsr_isa_extension">3.6.13. <code>Zicsr</code> ISA Extension</h4> +<div class="paragraph"> +<p>This ISA extensions provides instructions for accessing the <a href="#_control_and_status_registers_csrs">Control and Status Registers (CSRs)</a> as well as further +privileged-architecture extensions. This extension is mandatory and cannot be disabled. Hence, there is no generic +for enabling/disabling this ISA extension.</p> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +If <code>rd=x0</code> for the <code>csrrw[i]</code> instructions there will be no actual read access to the according CSR. +However, access privileges are still enforced so these instruction variants <em>do</em> cause side-effects +(the RISC-V spec. state that these combinations "shall" not cause any side-effects). +</td> +</tr> +</table> +</div> +<table class="tableblock frame-all grid-rows stretch"> +<caption class="title">Table 55. Instructions and Timing</caption> +<colgroup> +<col style="width: 22.2222%;"> +<col style="width: 44.4444%;"> +<col style="width: 33.3334%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-left valign-top">Class</th> +<th class="tableblock halign-left valign-top">Instructions</th> +<th class="tableblock halign-left valign-top">Execution cycles</th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">System</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>csrrw[i]</code> <code>csrrs[i]</code> <code>csrrc[i]</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">3</p></td> +</tr> +</tbody> +</table> +</div> +<div class="sect3"> +<h4 id="_zihpm_isa_extension">3.6.14. <code>Zihpm</code> ISA Extension</h4> +<div class="paragraph"> +<p>In additions to the base counters the NEORV32 CPU provides up to 13 hardware performance monitors (HPM 3..15), +which can be used to benchmark applications. Each HPM consists of an N-bit wide counter (split in a high-word 32-bit +CSR and a low-word 32-bit CSR), where N is defined via the top&#8217;s +<code>HPM_CNT_WIDTH</code> generic and a corresponding event configuration CSR. The event configuration +CSR defines the architectural events that lead to an increment of the associated HPM counter. See section +<a href="#_hardware_performance_monitors_hpm_csrs">Hardware Performance Monitors (HPM) CSRs</a> for a list of all HPM-related CSRs and event configurations.</p> +</div> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +Auto-increment of the HPMs can be deactivated individually via the <a href="#_mcountinhibit"><strong><code>mcountinhibit</code></strong></a> CSR. +</td> +</tr> +</table> +</div> +</div> +<div class="sect3"> +<h4 id="_zmmul_isa_extension">3.6.15. <code>Zmmul</code> - ISA Extension</h4> +<div class="paragraph"> +<p>This is a sub-extension of the <a href="#_m_isa_extension"><code>M</code> ISA Extension</a> ISA extension. It implements only the multiplication operations +of the <code>M</code> extensions and is intended for size-constrained setups that require hardware-based +integer multiplications but not hardware-based divisions, which will be computed entirely in software.</p> +</div> +</div> +<div class="sect3"> +<h4 id="_zxcfu_isa_extension">3.6.16. <code>Zxcfu</code> ISA Extension</h4> +<div class="paragraph"> +<p>The <code>Zxcfu</code> presents a NEORV32-specific ISA extension. It adds the <a href="#_custom_functions_unit_cfu">Custom Functions Unit (CFU)</a> to +the CPU core, which allows to add custom RISC-V instructions to the processor core. +For detailed information regarding the CFU, its hardware and the according software interface +see section <a href="#_custom_functions_unit_cfu">Custom Functions Unit (CFU)</a>.</p> +</div> +<div class="paragraph"> +<p>Software can utilize the custom instructions by using <em>intrinsics</em>, which are basically inline assembly functions that +behave like regular C functions but that evaluate to a single custom instruction word (no calling overhead at all).</p> +</div> +</div> +<div class="sect3"> +<h4 id="_smpmp_isa_extension">3.6.17. <code>Smpmp</code> ISA Extension</h4> +<div class="paragraph"> +<p>The NEORV32 physical memory protection (PMP) provides an elementary memory +protection mechanism that can be used to constrain read, write and execute rights of arbitrary memory regions. +The NEORV32 PMP is fully compatible to the RISC-V Privileged Architecture Specifications. In general, the PMP can +<strong>grant permissions to user mode</strong>, which by default has none, and can <strong>revoke permissions from M-mode</strong>, which +by default has full permissions. The PMP is configured via the <a href="#_machine_physical_memory_protection_csrs">Machine Physical Memory Protection CSRs</a>.</p> +</div> +<div class="paragraph"> +<p>Several <a href="#_processor_top_entity_generics">Processor Top Entity - Generics</a> are provided to fine-tune the CPU&#8217;s PMP capabilities: +* <code>PMP_NUM_REGIONS</code> defines the number of implemented PMP region +* <code>PMP_MIN_GRANULARITY</code> defines the minimal granularity of each region +* <code>PMP_TOR_MODE_EN</code> controls the implementation of the top-of-region (TOR) mode +* <code>PMP_NAP_MODE_EN</code> controls the implementation of the naturally-aligned-power-of-two (NA4 and NAPOT) modes</p> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">PMP Rules when in Debug Mode</div> +When in debug-mode all PMP rules are ignored making the debugger have maximum access rights. +</td> +</tr> +</table> +</div> +<div class="admonitionblock important"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-important" title="Important"></i> +</td> +<td class="content"> +<div class="title">Protected Instruction Fetches</div> +New instruction fetches are <strong>always triggered even when denied</strong> by a certain PMP rule. However, the fetched instruction(s) +will not be executed and will not change CPU core state. Instead, they will raise a bus exception when reaching the CPU&#8217;s +executions stage. +</td> +</tr> +</table> +</div> +</div> +<div class="sect3"> +<h4 id="_sdext_isa_extension">3.6.18. <code>Sdext</code> ISA Extension</h4> +<div class="paragraph"> +<p>This ISA extension enables the RISC-V-compatible "external debug support" by implementing +the CPU "debug mode", which is required for the on-chip debugger. +See section <a href="#_on_chip_debugger_ocd">On-Chip Debugger (OCD)</a> / <a href="#_cpu_debug_mode">CPU Debug Mode</a> for more information.</p> +</div> +<table class="tableblock frame-all grid-rows stretch"> +<caption class="title">Table 56. Instructions and Timing</caption> +<colgroup> +<col style="width: 22.2222%;"> +<col style="width: 44.4444%;"> +<col style="width: 33.3334%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-left valign-top">Class</th> +<th class="tableblock halign-left valign-top">Instructions</th> +<th class="tableblock halign-left valign-top">Execution cycles</th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">System</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>dret</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">5</p></td> +</tr> +</tbody> +</table> +</div> +<div class="sect3"> +<h4 id="_sdtrig_isa_extension">3.6.19. <code>Sdtrig</code> ISA Extension</h4> +<div class="paragraph"> +<p>This ISA extension implements the RISC-V-compatible "trigger module". +See section <a href="#_on_chip_debugger_ocd">On-Chip Debugger (OCD)</a> / <a href="#_trigger_module">Trigger Module</a> for more information.</p> +</div> +<div style="page-break-after: always;"></div> +<div style="page-break-after: always;"></div> +</div> +</div> +<div class="sect2"> +<h3 id="_custom_functions_unit_cfu">3.7. Custom Functions Unit (CFU)</h3> +<div class="paragraph"> +<p>The Custom Functions Unit (CFU) is the central part of the NEORV32-specific <a href="#_zxcfu_isa_extension"><code>Zxcfu</code> ISA Extension</a> and +represents the actual hardware module that can be used to implement <strong>custom RISC-V instructions</strong>.</p> +</div> +<div class="paragraph"> +<p>The CFU is intended for operations that are inefficient in terms of performance, latency, energy consumption or +program memory requirements when implemented entirely in software. Some potential application fields and exemplary +use-cases might include:</p> +</div> +<div class="ulist"> +<ul> +<li> +<p><strong>AI:</strong> sub-word / vector / SIMD operations like processing all four bytes of a 32-bit data word in parallel</p> +</li> +<li> +<p><strong>Cryptographic:</strong> bit substitution and permutation</p> +</li> +<li> +<p><strong>Communication:</strong> conversions like binary to gray-code; multiply-add operations</p> +</li> +<li> +<p><strong>Image processing:</strong> look-up-tables for color space transformations</p> +</li> +<li> +<p>implementing instructions from <strong>other RISC-V ISA extensions</strong> that are not yet supported by NEORV32</p> +</li> +</ul> +</div> +<div class="paragraph"> +<p>The CFU is not intended for complex and <strong>CPU-independent</strong> functional units that implement complete accelerators +(like block-based AES encryption). These kind of accelerators should be implemented as memory-mapped +<a href="#_custom_functions_subsystem_cfs">Custom Functions Subsystem (CFS)</a>. A comparison of all NEORV32-specific chip-internal hardware extension +options is provided in the user guide section +<a href="https://stnolting.github.io/neorv32/ug/#_adding_custom_hardware_modules">Adding Custom Hardware Modules</a>.</p> +</div> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +<div class="title">Default CFU Hardware Example</div> +The default CFU module (<code>rtl/core/neorv32_cpu_cp_cfu.vhd</code>) implements the <em>Extended Tiny Encryption Algorithm (XTEA)</em> +as "real world" application example. +</td> +</tr> +</table> +</div> +<div class="sect3"> +<h4 id="_cfu_instruction_formats">3.7.1. CFU Instruction Formats</h4> +<div class="paragraph"> +<p>The custom instructions executed by the CFU utilize a specific opcode space in the <code>rv32</code> 32-bit instruction +encoding space that has been explicitly reserved for user-defined extensions by the RISC-V specifications ("Guaranteed +Non-Standard Encoding Space"). The NEORV32 CFU uses the <code>custom-*</code> opcodes to identify the instructions implemented +by the CFU and to differentiate between the predefined instruction formats. The according binary encoding of these +opcodes is shown below:</p> +</div> +<div class="ulist"> +<ul> +<li> +<p><code>custom-0</code>: <code>0001011</code> RISC-V standard, used for <a href="#_cfu_r3_type_instructions">CFU R3-Type Instructions</a></p> +</li> +<li> +<p><code>custom-1</code>: <code>0101011</code> RISC-V standard, used for <a href="#_cfu_r4_type_instructions">CFU R4-Type Instructions</a></p> +</li> +<li> +<p><code>custom-2</code>: <code>1011011</code> NEORV32-specific, used for <a href="#_cfu_r5_type_instructions">CFU R5-Type Instructions</a> type A</p> +</li> +<li> +<p><code>custom-3</code>: <code>1111011</code> NEORV32-specific, used for <a href="#_cfu_r5_type_instructions">CFU R5-Type Instructions</a> type B</p> +</li> +</ul> +</div> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +The four presented instructions types/formats are predefined to allow an easy integration framework. +However, system designers are free to ignore those and use their own instruction types and formats. +</td> +</tr> +</table> +</div> +<div class="sect4"> +<h5 id="_cfu_r3_type_instructions">CFU R3-Type Instructions</h5> +<div class="paragraph"> +<p>The R3-type CFU instructions operate on two source registers <code>rs1</code> and <code>rs2</code> and return the processing result to +the destination register <code>rd</code>. The actual operation can be defined by using the <code>funct7</code> and <code>funct3</code> bit fields. +These immediates can also be used to pass additional data to the CFU like offsets, look-up-tables addresses or +shift-amounts. However, the actual functionality is entirely user-defined. Note that all immediate values are +always compile-time-static.</p> +</div> +<div class="paragraph"> +<p>Example operation: <code>rd &#8656; rs1 xnor rs2</code> (bit-wise XNOR)</p> +</div> +<div class="imageblock text-left"> +<div class="content"> +<img src="img/cfu_r3type_instruction.png" alt="cfu r3type instruction"> +</div> +<div class="title">Figure 11. CFU R3-type instruction format</div> +</div> +<div class="ulist"> +<ul> +<li> +<p><code>funct7</code>: 7-bit immediate (immediate data or function select)</p> +</li> +<li> +<p><code>rs2</code>: address of second source register (32-bit source data)</p> +</li> +<li> +<p><code>rs1</code>: address of first source register (32-bit source data)</p> +</li> +<li> +<p><code>funct3</code>: 3-bit immediate (immediate data or function select)</p> +</li> +<li> +<p><code>rd</code>: address of destination register (for the 32-bit processing result)</p> +</li> +<li> +<p><code>opcode</code>: <code>0001011</code> (RISC-V "custom-0" opcode)</p> +</li> +</ul> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">RISC-V compatibility</div> +The CFU R3-type instruction format is compliant to the RISC-V ISA specification. +</td> +</tr> +</table> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">Instruction encoding space</div> +By using the <code>funct7</code> and <code>funct3</code> bit fields entirely for selecting the actual operation a total of 1024 custom +R3-type instructions can be implemented (7-bit + 3-bit = 10 bit &#8594; 1024 different values). +</td> +</tr> +</table> +</div> +</div> +<div class="sect4"> +<h5 id="_cfu_r4_type_instructions">CFU R4-Type Instructions</h5> +<div class="paragraph"> +<p>The R4-type CFU instructions operate on three source registers <code>rs1</code>, <code>rs2</code> and <code>rs2</code> and return the processing +result to the destination register <code>rd</code>. The actual operation can be defined by using the <code>funct3</code> bit field. +Alternatively, this immediate can also be used to pass additional data to the CFU like offsets, look-up-tables +addresses or shift-amounts. However, the actual functionality is entirely user-defined. Note that all immediate +values are always compile-time-static.</p> +</div> +<div class="paragraph"> +<p>Example operation: <code>rd &#8656; (rs1 * rs2 + rs3)[31:0]</code> (multiply-and-accumulate; "MAC")</p> +</div> +<div class="imageblock text-left"> +<div class="content"> +<img src="img/cfu_r4type_instruction.png" alt="cfu r4type instruction"> +</div> +<div class="title">Figure 12. CFU R4-type instruction format</div> +</div> +<div class="ulist"> +<ul> +<li> +<p><code>rs3</code>: address of third source register (32-bit source data)</p> +</li> +<li> +<p><code>rs2</code>: address of second source register (32-bit source data)</p> +</li> +<li> +<p><code>rs1</code>: address of first source register (32-bit source data)</p> +</li> +<li> +<p><code>funct3</code>: 3-bit immediate (immediate data or function select)</p> +</li> +<li> +<p><code>rd</code>: address of destination register (for the 32-bit processing result)</p> +</li> +<li> +<p><code>opcode</code>: <code>0101011</code> (RISC-V "custom-1" opcode)</p> +</li> +</ul> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">RISC-V compatibility</div> +The CFU R4-type instruction format is compliant to the RISC-V ISA specification. +</td> +</tr> +</table> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">Unused instruction bits</div> +The RISC-V ISA specification defines bits [26:25] of the R4-type instruction word to be all-zero. These bits +are ignored by the hardware (CFU and illegal instruction check logic) and should be set to all-zero to preserve +compatibility with future ISA spec. versions. +</td> +</tr> +</table> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">Instruction encoding space</div> +By using the <code>funct3</code> bit field entirely for selecting the actual operation a total of 8 custom R4-type +instructions can be implemented (3-bit &#8594; 8 different values). +</td> +</tr> +</table> +</div> +</div> +<div class="sect4"> +<h5 id="_cfu_r5_type_instructions">CFU R5-Type Instructions</h5> +<div class="paragraph"> +<p>The R5-type CFU instructions operate on four source registers <code>rs1</code>, <code>rs2</code>, <code>rs3</code> and <code>r4</code> and return the +processing result to the destination register <code>rd</code>. As all bits of the instruction word are used to encode the +five registers and the opcode, no further immediate bits are available to specify the actual operation. There +are two different R5-type instruction with two different opcodes available. Hence, only two R5-type operations +can be implemented by default.</p> +</div> +<div class="paragraph"> +<p>Example operation: <code>rd &#8656; rs1 &amp; rs2 &amp; rs3 &amp; rs4</code> (bit-wise AND of 4 operands)</p> +</div> +<div class="imageblock text-left"> +<div class="content"> +<img src="img/cfu_r5type_instruction_a.png" alt="cfu r5type instruction a"> +</div> +<div class="title">Figure 13. CFU R5-type instruction A format</div> +</div> +<div class="imageblock text-left"> +<div class="content"> +<img src="img/cfu_r5type_instruction_b.png" alt="cfu r5type instruction b"> +</div> +<div class="title">Figure 14. CFU R5-type instruction B format</div> +</div> +<div class="ulist"> +<ul> +<li> +<p><code>rs4.hi</code> &amp; <code>rs4.lo</code>: address of fourth source register (32-bit source data)</p> +</li> +<li> +<p><code>rs3</code>: address of third source register (32-bit source data)</p> +</li> +<li> +<p><code>rs2</code>: address of second source register (32-bit source data)</p> +</li> +<li> +<p><code>rs1</code>: address of first source register (32-bit source data)</p> +</li> +<li> +<p><code>rd</code>: address of destination register (for the 32-bit processing result)</p> +</li> +<li> +<p><code>opcode</code>: <code>1011011</code> (RISC-V "custom-2" opcode) and/or <code>1111011</code> (RISC-V "custom-3" opcode)</p> +</li> +</ul> +</div> +<div class="admonitionblock important"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-important" title="Important"></i> +</td> +<td class="content"> +<div class="title">RISC-V compatibility</div> +The RISC-V ISA specifications does not specify a R5-type instruction format. Hence, this instruction +format is NEORV32-specific. +</td> +</tr> +</table> +</div> +<div class="admonitionblock important"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-important" title="Important"></i> +</td> +<td class="content"> +<div class="title">Instruction encoding space</div> +There are no immediate fields in the CFU R5-type instruction so the actual operation is specified entirely +by the opcode resulting in just two different operations out of the box. However, another CFU instruction +(like a R3-type instruction) can be used to "program" the actual operation of a R5-type instruction by +writing operation information to a CFU-internal "command" register. +</td> +</tr> +</table> +</div> +</div> +</div> +<div class="sect3"> +<h4 id="_using_custom_instructions_in_software">3.7.2. Using Custom Instructions in Software</h4> +<div class="paragraph"> +<p>The custom instructions provided by the CFU can be used in plain C code by using <strong>intrinsics</strong>. Intrinsics +behave like "normal" C functions but under the hood they are a set of macros that hide the complexity of inline assembly. +Using intrinsics removes the need to modify the compiler, built-in libraries or the assembler when using custom +instructions. Each intrinsic will be compiled into a single 32-bit instruction word providing maximum code efficiency.</p> +</div> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +<div class="title">CFU Example Program</div> +There is an example program for the CFU, which shows how to use the <em>default</em> CFU hardware module. +This example program is located in <code>sw/example/demo_cfu</code>. +</td> +</tr> +</table> +</div> +<div class="paragraph"> +<p>The NEORV32 software framework provides four pre-defined prototypes for custom instructions, which are defined in +<code>sw/lib/include/neorv32_cpu_cfu.h</code>:</p> +</div> +<div class="listingblock"> +<div class="title">Listing 9. CFU instruction prototypes</div> +<div class="content"> +<pre class="highlight"><code class="language-c" data-lang="c">neorv32_cfu_r3_instr(funct7, funct3, rs1, rs2) // R3-type instructions +neorv32_cfu_r4_instr(funct3, rs1, rs2, rs3) // R4-type instructions +neorv32_cfu_r5_instr_a(rs1, rs2, rs3, rs4) // R5-type instruction A +neorv32_cfu_r5_instr_b(rs1, rs2, rs3, rs4) // R5-type instruction B</code></pre> +</div> +</div> +<div class="paragraph"> +<p>The intrinsic functions always return a 32-bit value of type <code>uint32_t</code> (the processing result), which can be discarded +if not needed. Each intrinsic function requires several arguments depending on the instruction type/format:</p> +</div> +<div class="ulist"> +<ul> +<li> +<p><code>funct7</code> - 7-bit immediate (R3-type only)</p> +</li> +<li> +<p><code>funct3</code> - 3-bit immediate (R3-type, R4-type)</p> +</li> +<li> +<p><code>rs1</code> - source operand 1, 32-bit (R3-type, R4-type)</p> +</li> +<li> +<p><code>rs2</code> - source operand 2, 32-bit (R3-type, R4-type)</p> +</li> +<li> +<p><code>rs3</code> - source operand 3, 32-bit (R3-type, R4-type, R5-type)</p> +</li> +<li> +<p><code>rs4</code> - source operand 4, 32-bit (R4-type, R4-type, R5-type)</p> +</li> +</ul> +</div> +<div class="paragraph"> +<p>The <code>funct3</code> and <code>funct7</code> bit-fields are used to pass 3-bit or 7-bit literals to the CFU. The <code>rs1</code>, <code>rs2</code>, <code>rs3</code> +and <code>r4</code> arguments pass the actual data to the CFU. These register arguments can be populated with variables or +literals. The following example shows how to pass arguments:</p> +</div> +<div class="listingblock"> +<div class="title">Listing 10. CFU instruction usage example</div> +<div class="content"> +<pre class="highlight"><code class="language-c" data-lang="c">uint32_t tmp = some_function(); +... +uint32_t res = neorv32_cfu_r3_instr(0b0000000, 0b101, tmp, 123); +uint32_t foo = neorv32_cfu_r4_instr(0b011, tmp, res, (uint32_t)some_array[i]); +uint32_t bar = neorv32_cfu_r5_instr_a(tmp, res, foo, tmp);</code></pre> +</div> +</div> +</div> +<div class="sect3"> +<h4 id="_cfu_control_and_status_registers_cfu_csrs">3.7.3. CFU Control and Status Registers (CFU-CSRs)</h4> +<div class="paragraph"> +<p>The CPU provides up to four control and status registers (<a href="#_cfureg"><code>cfureg*</code></a>) to be +used within the CFU. These CSRs are mapped to the "custom user-mode read/write" CSR address space, which is +explicitly reserved for platform-specific application by the RISC-V spec. For example, these CSRs can be used +to pass additional operands to the CFU, to obtain additional results, to check processing status or to program +operation modes.</p> +</div> +<div class="listingblock"> +<div class="title">Listing 11. CFU CSR Access Example</div> +<div class="content"> +<pre class="highlight"><code class="language-c" data-lang="c">neorv32_cpu_csr_write(CSR_CFUREG0, 0xabcdabcd); // write data to CFU CSR 0 +uint32_t tmp = neorv32_cpu_csr_read(CSR_CFUREG3); // read data from CFU CSR 3</code></pre> +</div> +</div> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +<div class="title">Additional CFU-internal CSRs</div> +If more than four CFU-internal CSRs are required the designer can implement an "indirect access mechanism" based +on just two of the default CSRs: one CSR is used to configure the index while the other is used as alias to exchange +data with the indexed CFU-internal CSR - this concept is similar to the RISC-V Indirect CSR Access Extension +Specification (<code>Smcsrind</code>). +</td> +</tr> +</table> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">Security Considerations</div> +The CFU CSRs are mapped to the user-mode CSR space so software running at <em>any privilege level</em> can access these +CSRs. However, accesses can be constrained to certain privilege level (see <a href="#_custom_instructions_hardware">Custom Instructions Hardware</a>). +</td> +</tr> +</table> +</div> +</div> +<div class="sect3"> +<h4 id="_custom_instructions_hardware">3.7.4. Custom Instructions Hardware</h4> +<div class="paragraph"> +<p>The actual functionality of the CFU&#8217;s custom instructions is defined by the user-defined logic inside +the CFU hardware module <code>rtl/core/neorv32_cpu_cp_cfu.vhd</code>. This file is highly commented to illustrate the +hardware design considerations.</p> +</div> +<div class="paragraph"> +<p>CFU operations can be entirely combinatorial (like bit-reversal) so the result is available at the end of +the current clock cycle. Operations can also take several clock cycles to complete (like multiplications) +and may also include internal states and memories. The CFU&#8217;s internal control unit takes care of +interfacing the custom user logic to the CPU pipeline.</p> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">CFU Hardware Resource Requirements</div> +Enabling the CFU and actually implementing R4-type and/or R5-type instructions (or more precisely, using +the according operands for the CFU hardware) will add one or two, respectively, additional read ports to +the core&#8217;s register file significantly increasing resource requirements. +</td> +</tr> +</table> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">CFU Access Privilege Levels</div> +The CFU is accessible from all privilege modes (including CFU-internal registers accessed via the indirects CSR +access mechanism). It is the task of the CFU designers to add according access-constraining logic if certain CFU +states shall not be exposed to all privilege levels (i.e. encryption keys). +</td> +</tr> +</table> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">CFU Execution Time</div> +The CFU has to complete computation within a <strong>bound time window</strong>. Otherwise, the CFU operation is terminated +by the hardware and an illegal instruction exception is raised. See section <a href="#_cpu_arithmetic_logic_unit">CPU Arithmetic Logic Unit</a> +for more information. +</td> +</tr> +</table> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">CFU Exception</div> +The CFU can intentionally raise an illegal instruction exception by not asserting the <code>done</code> at all causing an +execution timeout. For example this can be used to signal invalid configurations/operations to the runtime +environment. See the CFU&#8217;s VHDL file for more information. +</td> +</tr> +</table> +</div> +<div style="page-break-after: always;"></div> +<div style="page-break-after: always;"></div> +</div> +</div> +<div class="sect2"> +<h3 id="_control_and_status_registers_csrs">3.8. Control and Status Registers (CSRs)</h3> +<div class="paragraph"> +<p>The following table shows a summary of all available NEORV32 CSRs. The address field defines the CSR address for +the CSR access instructions. The "Name [ASM]" column provides the CSR name aliases that can be used in (inline) assembly. +The "Name [C]" column lists the name aliases that are defined by the NEORV32 core library. These can be used in plain C code. +The "Access" column shows the minimal required privilege mode required for accessing the according CSR (<code>M</code> = machine-mode, +<code>U</code> = user-mode, <code>D</code> = debug-mode) and the read/write capabilities (<code>RW</code> = read-write, <code>RO</code> = read-only)</p> +</div> +<div class="admonitionblock important"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-important" title="Important"></i> +</td> +<td class="content"> +<div class="title">Unused, Reserved, Unimplemented and Disabled CSRs</div> +All CSRs and CSR bits that are not listed in the table below are <em>unimplemented</em> and are <em>hardwired to zero</em>. Additionally, +CSRs that are unavailable ("disabled") because the according ISA extension is not enabled are also considered <em>unimplemented</em> +and are also hardwired to zero. Any access to such a CSR will raise an illegal instruction exception. All writable CSRs provide +<strong>WARL</strong> behavior (write all values; read only legal values). Application software should always read back a CSR after writing +to check if the targeted bits can actually be modified. +</td> +</tr> +</table> +</div> +<table class="tableblock frame-all grid-all stretch"> +<caption class="title">Table 57. NEORV32 Control and Status Registers (CSRs)</caption> +<colgroup> +<col style="width: 8.6956%;"> +<col style="width: 17.3913%;"> +<col style="width: 21.7391%;"> +<col style="width: 4.3478%;"> +<col style="width: 47.8262%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-left valign-top">Address</th> +<th class="tableblock halign-left valign-top">Name [ASM]</th> +<th class="tableblock halign-left valign-top">Name [C]</th> +<th class="tableblock halign-center valign-top">Access</th> +<th class="tableblock halign-left valign-top">Description</th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-center valign-top" colspan="5"><p class="tableblock"><strong><a href="#_floating_point_csrs">Floating-Point CSRs</a></strong></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">0x001</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_fflags"><strong><code>fflags</code></strong></a></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>CSR_FFLAGS</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">URW</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Floating-point accrued exceptions</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">0x002</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_frm"><strong><code>frm</code></strong></a></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>CSR_FRM</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">URW</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Floating-point dynamic rounding mode</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">0x003</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_fcsr"><strong><code>fcsr</code></strong></a></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>CSR_FCSR</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">URW</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Floating-point control and status</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top" colspan="5"><p class="tableblock"><strong><a href="#_machine_trap_setup_csrs">Machine Trap Setup CSRs</a></strong></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">0x300</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_mstatus"><strong><code>mstatus</code></strong></a></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>CSR_MSTATUS</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">MRW</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Machine status register - low word</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">0x301</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_misa"><strong><code>misa</code></strong></a></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>CSR_MISA</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">MRW</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Machine CPU ISA and extensions</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">0x304</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_mie"><strong><code>mie</code></strong></a></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>CSR_MIE</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">MRW</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Machine interrupt enable register</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">0x305</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_mtvec"><strong><code>mtvec</code></strong></a></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>CSR_MTVEC</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">MRW</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Machine trap-handler base address for ALL traps</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">0x306</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_mcounteren"><strong><code>mcounteren</code></strong></a></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>CSR_MCOUNTEREN</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">MRW</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Machine counter-enable register</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">0x310</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_mstatush"><strong><code>mstatush</code></strong></a></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>CSR_MSTATUSH</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">MRW</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Machine status register - high word</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top" colspan="5"><p class="tableblock"><strong><a href="#_machine_configuration_csrs">Machine Configuration CSRs</a></strong></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">0x30a</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_menvcfg"><strong><code>menvcfg</code></strong></a></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>CSR_MENVCFG</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">MRW</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Machine environment configuration register - low word</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">0x31a</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_menvcfgh"><strong><code>menvcfgh</code></strong></a></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>CSR_MENVCFGH</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">MRW</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Machine environment configuration register - high word</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top" colspan="5"><p class="tableblock"><strong><a href="#_machine_counter_setup_csrs">Machine Counter Setup CSRs</a></strong></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">0x320</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_mcountinhibit"><strong><code>mcountinhibit</code></strong></a></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>CSR_MCOUNTINHIBIT</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">MRW</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Machine counter-inhibit register</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top" colspan="5"><p class="tableblock"><strong><a href="#_machine_trap_handling_csrs">Machine Trap Handling CSRs</a></strong></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">0x340</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_mscratch"><strong><code>mscratch</code></strong></a></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>CSR_MSCRATCH</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">MRW</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Machine scratch register</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">0x341</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_mepc"><strong><code>mepc</code></strong></a></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>CSR_MEPC</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">MRW</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Machine exception program counter</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">0x342</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_mcause"><strong><code>mcause</code></strong></a></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>CSR_MCAUSE</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">MRW</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Machine trap cause</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">0x343</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_mtval"><strong><code>mtval</code></strong></a></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>CSR_MTVAL</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">MRW</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Machine trap value</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">0x344</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_mip"><strong><code>mip</code></strong></a></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>CSR_MIP</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">MRW</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Machine interrupt pending register</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">0x34a</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_mtinst"><strong><code>mtinst</code></strong></a></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>CSR_MTINST</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">MRW</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Machine trap instruction</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top" colspan="5"><p class="tableblock"><strong><a href="#_machine_physical_memory_protection_csrs">Machine Physical Memory Protection CSRs</a></strong></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">0x3a0 .. 0x303</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_pmpcfg"><code>pmpcfg0</code></a> .. <a href="#_pmpcfg"><code>pmpcfg3</code></a></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>CSR_PMPCFG0</code> .. <code>CSR_PMPCFG3</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">MRW</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Physical memory protection configuration registers</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">0x3b0 .. 0x3bf</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_pmpaddr"><code>pmpaddr0</code></a> .. <a href="#_pmpaddr"><code>pmpaddr15</code></a></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>CSR_PMPADDR0</code> .. <code>CSR_PMPADDR15</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">MRW</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Physical memory protection address registers</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top" colspan="5"><p class="tableblock"><strong><a href="#_trigger_module_csrs">Trigger Module CSRs</a></strong></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">0x7a0</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_tselect"><strong><code>tselect</code></strong></a></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>CSR_TSELECT</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">MRW</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Trigger select register</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">0x7a1</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_tdata1"><strong><code>tdata1</code></strong></a></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>CSR_TDATA1</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">MRW</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Trigger data register 1</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">0x7a2</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_tdata2"><strong><code>tdata2</code></strong></a></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>CSR_TDATA2</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">MRW</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Trigger data register 2</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">0x7a4</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_tinfo"><strong><code>tinfo</code></strong></a></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>CSR_TINFO</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">MRW</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Trigger information register</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top" colspan="5"><p class="tableblock"><strong><a href="#_cpu_debug_mode_csrs">CPU Debug Mode CSRs</a></strong></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">0x7b0</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_dcsr"><strong><code>dcsr</code></strong></a></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">-</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">DRW</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Debug control and status register</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">0x7b1</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_dpc"><strong><code>dpc</code></strong></a></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">-</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">DRW</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Debug program counter</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">0x7b2</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_dscratch0"><strong><code>dscratch0</code></strong></a></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">-</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">DRW</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Debug scratch register 0</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top" colspan="5"><p class="tableblock"><strong><a href="#_custom_functions_unit_cfu_csrs">Custom Functions Unit (CFU) CSRs</a></strong></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">0x800 .. 0x803</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_cfureg"><code>cfureg0</code></a> .. <a href="#_cfureg"><code>cfureg3</code></a></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>CSR_CFUCREG0</code> .. <code>CSR_CFUCREG3</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">URW</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Custom CFU registers 0 to 3</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top" colspan="5"><p class="tableblock"><strong><a href="#_machine_counter_and_timer_csrs">(Machine) Counter and Timer CSRs</a></strong></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">0xb00</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_mcycleh"><code>mcycle</code></a></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>CSR_MCYCLE</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">MRW</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Machine cycle counter low word</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">0xb02</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_minstreth"><code>minstret</code></a></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>CSR_MINSTRET</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">MRW</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Machine instruction-retired counter low word</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">0xb80</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_mcycleh"><code>mcycleh</code></a></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>CSR_MCYCLEH</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">MRW</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Machine cycle counter high word</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">0xb82</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_minstreth"><code>minstreth</code></a></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>CSR_MINSTRETH</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">MRW</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Machine instruction-retired counter high word</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">0xc00</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_cycleh"><code>cycle</code></a></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>CSR_CYCLE</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">URO</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Cycle counter low word</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">0xc02</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_instreth"><code>instret</code></a></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>CSR_INSTRET</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">URO</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Instruction-retired counter low word</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">0xc80</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_cycleh"><code>cycleh</code></a></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>CSR_CYCLEH</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">URO</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Cycle counter high word</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">0xc82</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_instreth"><code>instreth</code></a></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>CSR_INSTRETH</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">URO</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Instruction-retired counter high word</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top" colspan="5"><p class="tableblock"><strong><a href="#_hardware_performance_monitors_hpm_csrs">Hardware Performance Monitors (HPM) CSRs</a></strong></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">0x323 .. 0x32f</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_mhpmevent"><code>mhpmevent3</code></a> .. <a href="#_mhpmevent"><code>mhpmevent15</code></a></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>CSR_MHPMEVENT3</code> .. <code>CSR_MHPMEVENT15</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">MRW</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Machine performance-monitoring event select for counter 3..15</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">0xb03 .. 0xb0f</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_mhpmcounterh"><code>mhpmcounter3</code></a> .. <a href="#_mhpmcounterh"><code>mhpmcounter15</code></a></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>CSR_MHPMCOUNTER3</code> .. <code>CSR_MHPMCOUNTER15</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">MRW</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Machine performance-monitoring counter 3..15 low word</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">0xb83 .. 0xb8f</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_mhpmcounterh"><code>mhpmcounter3h</code></a> .. <a href="#_mhpmcounterh"><code>mhpmcounter15h</code></a></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>CSR_MHPMCOUNTER3H</code> .. <code>CSR_MHPMCOUNTER15H</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">MRW</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Machine performance-monitoring counter 3..15 high word</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">0xc03 .. 0xc0f</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_hpmcounterh"><code>hpmcounter3</code></a> .. <a href="#_hpmcounterh"><code>hpmcounter15</code></a></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>CSR_HPMCOUNTER3</code> .. <code>CSR_HPMCOUNTER15H</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">URO</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">User performance-monitoring counter 3..15 low word</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">0xc83 .. 0xc8f</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_hpmcounterh"><code>hpmcounter3h</code></a> .. <a href="#_hpmcounterh"><code>hpmcounter15h</code></a></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>CSR_HPMCOUNTER3H</code> .. <code>CSR_HPMCOUNTER15H</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">URO</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">User performance-monitoring counter 3..15 high word</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top" colspan="5"><p class="tableblock"><strong><a href="#_machine_information_csrs">Machine Information CSRs</a></strong></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">0xf11</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_mvendorid"><strong><code>mvendorid</code></strong></a></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>CSR_MVENDORID</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">MRO</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Machine vendor ID</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">0xf12</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_marchid"><strong><code>marchid</code></strong></a></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>CSR_MARCHID</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">MRO</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Machine architecture ID</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">0xf13</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_mimpid"><strong><code>mimpid</code></strong></a></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>CSR_MIMPID</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">MRO</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Machine implementation ID / version</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">0xf14</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_mhartid"><strong><code>mhartid</code></strong></a></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>CSR_MHARTID</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">MRO</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Machine hardware thread ID</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">0xf15</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_mconfigptr"><strong><code>mconfigptr</code></strong></a></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>CSR_MCONFIGPTR</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">MRO</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Machine configuration pointer register</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top" colspan="5"><p class="tableblock"><strong><a href="#_neorv32_specific_csrs">NEORV32-Specific CSRs</a></strong></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">0xfc0</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_mxisa"><strong><code>mxisa</code></strong></a></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>CSR_MXISA</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">MRO</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">NEORV32-specific "eXtended" machine CPU ISA and extensions</p></td> +</tr> +</tbody> +</table> +<div style="page-break-after: always;"></div> +<div class="sect3"> +<h4 id="_floating_point_csrs">3.8.1. Floating-Point CSRs</h4> +<h5 id="_fflags" class="discrete"><strong><code>fflags</code></strong></h5> +<table class="tableblock frame-ends grid-none stretch"> +<colgroup> +<col style="width: 11.1111%;"> +<col style="width: 88.8889%;"> +</colgroup> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Name</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Floating-point accrued exceptions</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Address</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x001</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Reset value</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x00000000</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">ISA</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>Zicsr</code> &amp; <code>Zfinx</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Description</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">FPU status flags.</p></td> +</tr> +</tbody> +</table> +<table class="tableblock frame-all grid-rows stretch"> +<caption class="title">Table 58. <code>fflags</code> CSR bits</caption> +<colgroup> +<col style="width: 8.3333%;"> +<col style="width: 8.3333%;"> +<col style="width: 83.3334%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-center valign-top">Bit</th> +<th class="tableblock halign-center valign-top">R/W</th> +<th class="tableblock halign-left valign-top">Function</th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">0</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><strong>NX</strong>: inexact</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">1</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><strong>UF</strong>: underflow</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">2</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><strong>OF</strong>: overflow</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">3</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><strong>DZ</strong>: division by zero</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">4</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><strong>NV</strong>: invalid operation</p></td> +</tr> +</tbody> +</table> +<div class="paragraph"> +<p><br></p> +</div> +<h5 id="_frm" class="discrete"><strong><code>frm</code></strong></h5> +<table class="tableblock frame-ends grid-none stretch"> +<colgroup> +<col style="width: 11.1111%;"> +<col style="width: 88.8889%;"> +</colgroup> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Name</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Floating-point dynamic rounding mode</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Address</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x002</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Reset value</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x00000000</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">ISA</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>Zicsr</code> &amp; <code>Zfinx</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Description</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">The <code>frm</code> CSR is used to configure the rounding mode of the FPU.</p></td> +</tr> +</tbody> +</table> +<table class="tableblock frame-all grid-rows stretch"> +<caption class="title">Table 59. <code>frm</code> CSR bits</caption> +<colgroup> +<col style="width: 8.3333%;"> +<col style="width: 8.3333%;"> +<col style="width: 83.3334%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-center valign-top">Bit</th> +<th class="tableblock halign-center valign-top">R/W</th> +<th class="tableblock halign-left valign-top">Function</th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">2:0</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Rounding mode</p></td> +</tr> +</tbody> +</table> +<div class="paragraph"> +<p><br></p> +</div> +<h5 id="_fcsr" class="discrete"><strong><code>fcsr</code></strong></h5> +<table class="tableblock frame-ends grid-none stretch"> +<colgroup> +<col style="width: 11.1111%;"> +<col style="width: 88.8889%;"> +</colgroup> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Name</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Floating-point control and status register</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Address</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x003</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Reset value</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x00000000</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">ISA</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>Zicsr</code> &amp; <code>Zfinx</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Description</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">The <code>fcsr</code> provides combined access to the <a href="#_fflags"><strong><code>fflags</code></strong></a> and <a href="#_frm"><strong><code>frm</code></strong></a> flags.</p></td> +</tr> +</tbody> +</table> +<table class="tableblock frame-all grid-rows stretch"> +<caption class="title">Table 60. <code>fcsr</code> CSR bits</caption> +<colgroup> +<col style="width: 8.3333%;"> +<col style="width: 8.3333%;"> +<col style="width: 83.3334%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-center valign-top">Bit</th> +<th class="tableblock halign-center valign-top">R/W</th> +<th class="tableblock halign-left valign-top">Function</th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">4:0</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Accrued exception flags (<a href="#_fflags"><strong><code>fflags</code></strong></a>)</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">7:5</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Rounding mode (<a href="#_frm"><strong><code>frm</code></strong></a>)</p></td> +</tr> +</tbody> +</table> +<div style="page-break-after: always;"></div> +</div> +<div class="sect3"> +<h4 id="_machine_trap_setup_csrs">3.8.2. Machine Trap Setup CSRs</h4> +<h5 id="_mstatus" class="discrete"><strong><code>mstatus</code></strong></h5> +<table class="tableblock frame-ends grid-none stretch"> +<colgroup> +<col style="width: 11.1111%;"> +<col style="width: 88.8889%;"> +</colgroup> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Name</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Machine status register - low word</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Address</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x300</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Reset value</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x00001800</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">ISA</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>Zicsr</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Description</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">The <code>mstatus</code> CSR is used to configure general machine environment parameters.</p></td> +</tr> +</tbody> +</table> +<table class="tableblock frame-all grid-rows stretch"> +<caption class="title">Table 61. <code>mstatus</code> CSR bits</caption> +<colgroup> +<col style="width: 7.1428%;"> +<col style="width: 21.4285%;"> +<col style="width: 7.1428%;"> +<col style="width: 64.2859%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-center valign-top">Bit</th> +<th class="tableblock halign-center valign-top">Name [C]</th> +<th class="tableblock halign-center valign-top">R/W</th> +<th class="tableblock halign-left valign-top">Function</th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">3</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>CSR_MSTATUS_MIE</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><strong>MIE</strong>: Machine-mode interrupt enable flag</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">7</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>CSR_MSTATUS_MPIE</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><strong>MPIE</strong>: Previous machine-mode interrupt enable flag state</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">12:11</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>CSR_MSTATUS_MPP_H</code> : <code>CSR_MSTATUS_MPP_L</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><strong>MPP</strong>: Previous machine privilege mode, <code>11</code> = machine-mode "M", <code>00</code> = user-mode "U"; other values will fall-back to machine-mode</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">17</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>CSR_MSTATUS_MPRV</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><strong>MPRV</strong>: Effective privilege mode for load/stores; use <code>MPP</code> as effective privilege mode when set; hardwired to zero if user-mode not implemented</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">21</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>CSR_MSTATUS_TW</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><strong>TW</strong>: Trap on execution of <code>wfi</code> instruction in user mode when set; hardwired to zero if user-mode not implemented</p></td> +</tr> +</tbody> +</table> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +If the core is in user-mode, machine-mode interrupts are globally <strong>enabled</strong> even if <code>mstatus.mie</code> is cleared: +"Interrupts for higher-privilege modes, y&gt;x, are always globally enabled regardless of the setting of the global yIE +bit for the higher-privilege mode." - RISC-V ISA Spec. +</td> +</tr> +</table> +</div> +<div class="paragraph"> +<p><br></p> +</div> +<h5 id="_misa" class="discrete"><strong><code>misa</code></strong></h5> +<table class="tableblock frame-ends grid-none stretch"> +<colgroup> +<col style="width: 11.1111%;"> +<col style="width: 88.8889%;"> +</colgroup> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Name</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">ISA and extensions</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Address</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x301</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Reset value</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>DEFINED</code>, according to enabled ISA extensions</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">ISA</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>Zicsr</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Description</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">The <code>misa</code> CSR provides information regarding the availability of basic RISC-V ISa extensions.</p></td> +</tr> +</tbody> +</table> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +The NEORV32 <code>misa</code> CSR is read-only. Hence, active CPU extensions are entirely defined by pre-synthesis configurations +and cannot be switched on/off during runtime. For compatibility reasons any write access to this CSR is simply ignored and +will <em>not</em> cause an illegal instruction exception. +</td> +</tr> +</table> +</div> +<table class="tableblock frame-all grid-rows stretch"> +<caption class="title">Table 62. <code>misa</code> CSR bits</caption> +<colgroup> +<col style="width: 7.1428%;"> +<col style="width: 21.4285%;"> +<col style="width: 7.1428%;"> +<col style="width: 64.2859%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-center valign-top">Bit</th> +<th class="tableblock halign-center valign-top">Name [C]</th> +<th class="tableblock halign-center valign-top">R/W</th> +<th class="tableblock halign-left valign-top">Function</th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">0</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>CSR_MISA_A_EXT</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><strong>A</strong>: CPU extension (atomic memory access) available, set when <a href="#_a_isa_extension"><code>A</code> ISA Extension</a> enabled</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">1</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>CSR_MISA_B_EXT</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><strong>B</strong>: CPU extension (bit-manipulation) available, set when <a href="#_b_isa_extension"><code>B</code> ISA Extension</a> enabled</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">2</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>CSR_MISA_C_EXT</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><strong>C</strong>: CPU extension (compressed instruction) available, set when <a href="#_c_isa_extension"><code>C</code> ISA Extension</a> enabled</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">4</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>CSR_MISA_E_EXT</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><strong>E</strong>: CPU extension (embedded) available, set when <a href="#_e_isa_extension"><code>E</code> ISA Extension</a> enabled</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">8</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>CSR_MISA_I_EXT</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><strong>I</strong>: CPU base ISA, cleared when <a href="#_e_isa_extension"><code>E</code> ISA Extension</a> enabled</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">12</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>CSR_MISA_M_EXT</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><strong>M</strong>: CPU extension (mul/div) available, set when <a href="#_m_isa_extension"><code>M</code> ISA Extension</a> enabled</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">20</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>CSR_MISA_U_EXT</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><strong>U</strong>: CPU extension (user mode) available, set when <a href="#_u_isa_extension"><code>U</code> ISA Extension</a> enabled</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">23</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>CSR_MISA_X_EXT</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><strong>X</strong>: bit is always set to indicate non-standard / NEORV32-specific extensions</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">31:30</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>CSR_MISA_MXL_HI_EXT</code> : <code>CSR_MISA_MXL_LO_EXT</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><strong>MXL</strong>: 32-bit architecture indicator (always <code>01</code>)</p></td> +</tr> +</tbody> +</table> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +Machine-mode software can discover available <code>Z*</code> <em>sub-extensions</em> (like <code>Zicsr</code> or <code>Zfinx</code>) by checking the NEORV32-specific +<a href="#_mxisa"><strong><code>mxisa</code></strong></a> CSR. +</td> +</tr> +</table> +</div> +<div class="paragraph"> +<p><br></p> +</div> +<h5 id="_mie" class="discrete"><strong><code>mie</code></strong></h5> +<table class="tableblock frame-ends grid-none stretch"> +<colgroup> +<col style="width: 11.1111%;"> +<col style="width: 88.8889%;"> +</colgroup> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Name</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Machine interrupt-enable register</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Address</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x304</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Reset value</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x00000000</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">ISA</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>Zicsr</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Description</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">The <code>mie</code> CSR is used to enable/disable individual interrupt sources.</p></td> +</tr> +</tbody> +</table> +<table class="tableblock frame-all grid-rows stretch"> +<caption class="title">Table 63. <code>mie</code> CSR bits</caption> +<colgroup> +<col style="width: 7.1428%;"> +<col style="width: 21.4285%;"> +<col style="width: 7.1428%;"> +<col style="width: 64.2859%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-center valign-top">Bit</th> +<th class="tableblock halign-center valign-top">Name [C]</th> +<th class="tableblock halign-center valign-top">R/W</th> +<th class="tableblock halign-left valign-top">Function</th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">3</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>CSR_MIE_MSIE</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><strong>MSIE</strong>: Machine <em>software</em> interrupt enable</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">7</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>CSR_MIE_MTIE</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><strong>MTIE</strong>: Machine <em>timer</em> interrupt enable (from <a href="#_machine_system_timer_mtime">Machine System Timer (MTIME)</a>)</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">11</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>CSR_MIE_MEIE</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><strong>MEIE</strong>: Machine <em>external</em> interrupt enable</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">31:16</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>CSR_MIE_FIRQ15E</code> : <code>CSR_MIE_FIRQ0E</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Fast interrupt channel 15..0 enable</p></td> +</tr> +</tbody> +</table> +<div class="paragraph"> +<p><br></p> +</div> +<h5 id="_mtvec" class="discrete"><strong><code>mtvec</code></strong></h5> +<table class="tableblock frame-ends grid-none stretch"> +<colgroup> +<col style="width: 11.1111%;"> +<col style="width: 88.8889%;"> +</colgroup> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Name</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Machine trap-handler base address</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Address</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x305</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Reset value</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>CPU_BOOT_ADDR</code>, CPU boot address, 4-byte aligned (see <a href="#_cpu_top_entity_generics">CPU Top Entity - Generics</a> and <a href="#_address_space">Address Space</a>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">ISA</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>Zicsr</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Description</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">The <code>mtvec</code> CSR holds the trap vector configuration.</p></td> +</tr> +</tbody> +</table> +<table class="tableblock frame-all grid-rows stretch"> +<caption class="title">Table 64. <code>mtvec</code> CSR bits</caption> +<colgroup> +<col style="width: 8.3333%;"> +<col style="width: 8.3333%;"> +<col style="width: 83.3334%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-center valign-top">Bit</th> +<th class="tableblock halign-center valign-top">R/W</th> +<th class="tableblock halign-left valign-top">Function</th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">1:0</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><strong>MODE</strong>: mode configuration, <code>00</code> = DIRECT, <code>01</code> = VECTORED. (Others will fall back to DIRECT mode.)</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">31:2</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><strong>BASE</strong>: in DIRECT mode = 4-byte aligned base address of trap base handler, <em>all</em> traps set <code>pc</code> = <code>BASE</code>; in VECTORED mode = 128-byte aligned base address of trap vector table, interrupts cause a jump to <code>pc</code> = <code>BASE</code> + 4 * <code>mcause</code> and exceptions to <code>pc</code> = <code>BASE</code>.</p></td> +</tr> +</tbody> +</table> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +<div class="title">Interrupt Latency</div> +The vectored <code>mtvec</code> mode is useful for reducing the time between interrupt request (IRQ) and servicing it (ISR). As software does not need to determine the interrupt cause the reduction in latency can be 5 to 10 times and as low as <em>26</em> cycles. +</td> +</tr> +</table> +</div> +<div class="paragraph"> +<p><br></p> +</div> +<h5 id="_mcounteren" class="discrete"><strong><code>mcounteren</code></strong></h5> +<table class="tableblock frame-ends grid-none stretch"> +<colgroup> +<col style="width: 11.1111%;"> +<col style="width: 88.8889%;"> +</colgroup> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Name</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Machine counter enable</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Address</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x306</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Reset value</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x00000000</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">ISA</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>Zicsr</code> &amp; <code>U</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Description</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">The <code>mcounteren</code> CSR is used to constrain user-mode access to the CPU&#8217;s counter CSRs.</p></td> +</tr> +</tbody> +</table> +<table class="tableblock frame-all grid-rows stretch"> +<caption class="title">Table 65. <code>mcounteren</code> CSR bits</caption> +<colgroup> +<col style="width: 10%;"> +<col style="width: 10%;"> +<col style="width: 80%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-center valign-top">Bit</th> +<th class="tableblock halign-center valign-top">R/W</th> +<th class="tableblock halign-left valign-top">Function</th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">0</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w (!)</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><strong>CY</strong>: User-mode is allowed to read <a href="#_cycleh"><strong><code>cycle[h]</code></strong></a> CSRs when set</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">1</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><strong>TM</strong>: not implemented, hardwired to zero</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">2</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w (!)</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><strong>IR</strong>: User-mode is allowed to read <a href="#_instreth"><strong><code>instret[h]</code></strong></a> CSRs when set</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">15:3</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w (!)</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><strong>HPM</strong>: user-mode is allowed to read <a href="#_hpmcounterh"><strong><code>hpmcounter[h]</code></strong></a> CSRs when set</p></td> +</tr> +</tbody> +</table> +<div class="admonitionblock important"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-important" title="Important"></i> +</td> +<td class="content"> +Physically, the NEORV32&#8217;s <code>mcounteren</code> CSR is implemented as a <strong>single 1-bit register</strong>. Setting <em>any</em> bit of +the CSR will result in all bits being set. Hence, user-mode access can either be granted for <strong>all</strong> counter CSRs +or entirely denied allowing access to <strong>none</strong> counter CSRs. +</td> +</tr> +</table> +</div> +<div class="paragraph"> +<p><br></p> +</div> +<h5 id="_mstatush" class="discrete"><strong><code>mstatush</code></strong></h5> +<table class="tableblock frame-ends grid-none stretch"> +<colgroup> +<col style="width: 11.1111%;"> +<col style="width: 88.8889%;"> +</colgroup> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Name</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Machine status register - high word</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Address</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x310</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Reset value</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x00000000</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">ISA</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>Zicsr</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Description</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">The features of this CSR are not implemented yet. The register is read-only and always returns zero.</p></td> +</tr> +</tbody> +</table> +<div style="page-break-after: always;"></div> +</div> +<div class="sect3"> +<h4 id="_machine_trap_handling_csrs">3.8.3. Machine Trap Handling CSRs</h4> +<h5 id="_mscratch" class="discrete"><strong><code>mscratch</code></strong></h5> +<table class="tableblock frame-ends grid-none stretch"> +<colgroup> +<col style="width: 11.1111%;"> +<col style="width: 88.8889%;"> +</colgroup> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Name</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Scratch register for machine trap handlers</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Address</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x340</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Reset value</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x00000000</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">ISA</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>Zicsr</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Description</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">The <code>mscratch</code> is a general-purpose machine-mode scratch register.</p></td> +</tr> +</tbody> +</table> +<div class="paragraph"> +<p><br></p> +</div> +<h5 id="_mepc" class="discrete"><strong><code>mepc</code></strong></h5> +<table class="tableblock frame-ends grid-none stretch"> +<colgroup> +<col style="width: 11.1111%;"> +<col style="width: 88.8889%;"> +</colgroup> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Name</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Machine exception program counter</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Address</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x341</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Reset value</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>CPU_BOOT_ADDR</code>, CPU boot address, 4-byte aligned (see <a href="#_cpu_top_entity_generics">CPU Top Entity - Generics</a> and <a href="#_address_space">Address Space</a>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">ISA</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>Zicsr</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Description</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">The <code>mepc</code> CSR provides the instruction address where execution has stopped/failed when +an instruction is triggered / an exception is raised. See section <a href="#_traps_exceptions_and_interrupts">Traps, Exceptions and Interrupts</a> for a list of all legal values. +The <code>mret</code> instruction will return to the address stored in <code>mepc</code> by automatically moving <code>mepc</code> to the program counter.</p></td> +</tr> +</tbody> +</table> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<code>mepc[0]</code> is hardwired to zero. If IALIGN = 32 (i.e. <a href="#_c_isa_extension"><code>C</code> ISA Extension</a> is disabled) then <code>mepc[1]</code> is also hardwired to zero. +</td> +</tr> +</table> +</div> +<div class="paragraph"> +<p><br></p> +</div> +<h5 id="_mcause" class="discrete"><strong><code>mcause</code></strong></h5> +<table class="tableblock frame-ends grid-none stretch"> +<colgroup> +<col style="width: 11.1111%;"> +<col style="width: 88.8889%;"> +</colgroup> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Name</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Machine trap cause</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Address</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x342</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Reset value</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x00000000</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">ISA</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>Zicsr</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Description</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">The <code>mcause</code> CSRs shows the exact cause of a trap. See section <a href="#_traps_exceptions_and_interrupts">Traps, Exceptions and Interrupts</a> for a list of all legal values.</p></td> +</tr> +</tbody> +</table> +<table class="tableblock frame-all grid-rows stretch"> +<caption class="title">Table 66. <code>mcause</code> CSR bits</caption> +<colgroup> +<col style="width: 8.3333%;"> +<col style="width: 8.3333%;"> +<col style="width: 83.3334%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-center valign-top">Bit</th> +<th class="tableblock halign-center valign-top">R/W</th> +<th class="tableblock halign-left valign-top">Function</th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">4:0</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><strong>Exception code</strong>: see <a href="#_neorv32_trap_listing">NEORV32 Trap Listing</a></p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">31</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><strong>Interrupt</strong>: <code>1</code> if the trap is caused by an interrupt (<code>0</code> if the trap is caused by an exception)</p></td> +</tr> +</tbody> +</table> +<div class="paragraph"> +<p><br></p> +</div> +<h5 id="_mtval" class="discrete"><strong><code>mtval</code></strong></h5> +<table class="tableblock frame-ends grid-none stretch"> +<colgroup> +<col style="width: 11.1111%;"> +<col style="width: 88.8889%;"> +</colgroup> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Name</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Machine trap value</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Address</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x343</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Reset value</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x00000000</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">ISA</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>Zicsr</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Description</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">The <code>mtval</code> CSR provides additional information why a trap was entered. See section <a href="#_traps_exceptions_and_interrupts">Traps, Exceptions and Interrupts</a> for more information.</p></td> +</tr> +</tbody> +</table> +<div class="admonitionblock important"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-important" title="Important"></i> +</td> +<td class="content"> +<div class="title">Read-Only</div> +Note that the NEORV32 <code>mtval</code> CSR is updated by the hardware only and cannot be written from software. +However, any write-access will be ignored and will not cause an exception to maintain RISC-V compatibility. +</td> +</tr> +</table> +</div> +<div class="paragraph"> +<p><br></p> +</div> +<h5 id="_mip" class="discrete"><strong><code>mip</code></strong></h5> +<table class="tableblock frame-ends grid-none stretch"> +<colgroup> +<col style="width: 11.1111%;"> +<col style="width: 88.8889%;"> +</colgroup> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Name</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Machine interrupt pending</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Address</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x344</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Reset value</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x00000000</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">ISA</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>Zicsr</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Description</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">The <code>mip</code> CSR shows currently <em>pending</em> machine-mode interrupt requests. Any write access to this register is ignored.</p></td> +</tr> +</tbody> +</table> +<table class="tableblock frame-all grid-rows stretch"> +<caption class="title">Table 67. <code>mip</code> CSR bits</caption> +<colgroup> +<col style="width: 7.1428%;"> +<col style="width: 21.4285%;"> +<col style="width: 7.1428%;"> +<col style="width: 64.2859%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-center valign-top">Bit</th> +<th class="tableblock halign-center valign-top">Name [C]</th> +<th class="tableblock halign-center valign-top">R/W</th> +<th class="tableblock halign-left valign-top">Function</th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">3</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>CSR_MIP_MSIP</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><strong>MSIP</strong>: Machine <em>software</em> interrupt pending; <em>cleared by platform-defined mechanism</em></p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">7</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>CSR_MIP_MTIP</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><strong>MTIP</strong>: Machine <em>timer</em> interrupt pending; <em>cleared by platform-defined mechanism</em></p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">11</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>CSR_MIP_MEIP</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><strong>MEIP</strong>: Machine <em>external</em> interrupt pending; <em>cleared by platform-defined mechanism</em></p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">31:16</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>CSR_MIP_FIRQ15P</code> : <code>CSR_MIP_FIRQ0P</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><strong>FIRQxP</strong>: Fast interrupt channel 15..0 pending; <em>cleared by platform-defined mechanism</em></p></td> +</tr> +</tbody> +</table> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +<div class="title">FIRQ Channel Mapping</div> +See section <a href="#_neorv32_specific_fast_interrupt_requests">NEORV32-Specific Fast Interrupt Requests</a> for the mapping of the FIRQ channels and the according +interrupt-triggering processor module. +</td> +</tr> +</table> +</div> +<div class="paragraph"> +<p><br></p> +</div> +<h5 id="_mtinst" class="discrete"><strong><code>mtinst</code></strong></h5> +<table class="tableblock frame-ends grid-none stretch"> +<colgroup> +<col style="width: 11.1111%;"> +<col style="width: 88.8889%;"> +</colgroup> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Name</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Machine trap instruction</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Address</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x34a</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Reset value</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x00000000</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">ISA</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>Zicsr</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Description</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">The <code>mtinst</code> CSR provides additional information why a trap was entered. See section <a href="#_traps_exceptions_and_interrupts">Traps, Exceptions and Interrupts</a> for more information.</p></td> +</tr> +</tbody> +</table> +<div class="admonitionblock important"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-important" title="Important"></i> +</td> +<td class="content"> +<div class="title">Read-Only</div> +Note that the NEORV32 <code>mtinst</code> CSR is updated by the hardware only and cannot be written from software. +However, any write-access will be ignored and will not cause an exception to maintain RISC-V compatibility. +</td> +</tr> +</table> +</div> +<div class="admonitionblock important"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-important" title="Important"></i> +</td> +<td class="content"> +<div class="title">Instruction Transformation</div> +The RISC-V priv. spec. suggests that the instruction word written to <code>mtinst</code> by the hardware should be "transformed". +However, the NEORV32 <code>mtinst</code> CSR uses a simplified transformation scheme: if the trap-causing instruction is a +standard 32-bit instruction, <code>mtinst</code> contains the exact instruction word that caused the trap. If the trap-causing +instruction is a compressed instruction, <code>mtinst</code> contains the de-compressed 32-bit equivalent with bit 1 being cleared +while all remaining bits represent the pre-decoded 32-bit instruction equivalent. +</td> +</tr> +</table> +</div> +<div style="page-break-after: always;"></div> +</div> +<div class="sect3"> +<h4 id="_machine_configuration_csrs">3.8.4. Machine Configuration CSRs</h4> +<h5 id="_menvcfg" class="discrete"><strong><code>menvcfg</code></strong></h5> +<table class="tableblock frame-ends grid-none stretch"> +<colgroup> +<col style="width: 11.1111%;"> +<col style="width: 88.8889%;"> +</colgroup> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Name</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Machine environment configuration register - low word</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Address</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x30a</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Reset value</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x00000000</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">ISA</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>Zicsr</code> &amp; <code>U</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Description</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Currently, the features of this CSR are not supported. Hence, the entire register is hardwired to all-zero.</p></td> +</tr> +</tbody> +</table> +<div class="paragraph"> +<p><br></p> +</div> +<h5 id="_menvcfgh" class="discrete"><strong><code>menvcfgh</code></strong></h5> +<table class="tableblock frame-ends grid-none stretch"> +<colgroup> +<col style="width: 11.1111%;"> +<col style="width: 88.8889%;"> +</colgroup> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Name</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Machine environment configuration register - high word</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Address</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x31a</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Reset value</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x00000000</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">ISA</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>Zicsr</code> &amp; <code>U</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Description</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Currently, the features of this CSR are not supported. Hence, the entire register is hardwired to all-zero.</p></td> +</tr> +</tbody> +</table> +<div style="page-break-after: always;"></div> +</div> +<div class="sect3"> +<h4 id="_machine_physical_memory_protection_csrs">3.8.5. Machine Physical Memory Protection CSRs</h4> +<div class="paragraph"> +<p>The physical memory protection system is configured via the <code>PMP_NUM_REGIONS</code> and <code>PMP_MIN_GRANULARITY</code> top entity +generics. <code>PMP_NUM_REGIONS</code> defines the total number of implemented regions. Note that the maximum number of regions +is constrained to 16. If trying to access a PMP-related CSR beyond <code>PMP_NUM_REGIONS</code> <strong>no illegal instruction exception</strong> +is triggered. The according CSRs are read-only (writes are ignored) and always return zero. +See section <a href="#_smpmp_isa_extension"><code>Smpmp</code> ISA Extension</a> for more information.</p> +</div> +<h5 id="_pmpcfg" class="discrete"><strong><code>pmpcfg</code></strong></h5> +<table class="tableblock frame-ends grid-none stretch"> +<colgroup> +<col style="width: 11.1111%;"> +<col style="width: 88.8889%;"> +</colgroup> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Name</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">PMP region configuration registers</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Address</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x3a0</code> (<code>pmpcfg0</code>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x3a1</code> (<code>pmpcfg1</code>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x3a2</code> (<code>pmpcfg2</code>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x3a3</code> (<code>pmpcfg3</code>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Reset value</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x00000000</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">ISA</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>Zicsr</code> &amp; <code>PMP</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Description</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Configuration of physical memory protection regions. Each region provides an individual 8-bit array in these CSRs.</p></td> +</tr> +</tbody> +</table> +<table class="tableblock frame-all grid-rows stretch"> +<caption class="title">Table 68. <code>pmpcfg0</code> CSR Bits</caption> +<colgroup> +<col style="width: 6.6666%;"> +<col style="width: 13.3333%;"> +<col style="width: 6.6666%;"> +<col style="width: 73.3335%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-center valign-top">Bit</th> +<th class="tableblock halign-center valign-top">Name [C]</th> +<th class="tableblock halign-center valign-top">R/W</th> +<th class="tableblock halign-left valign-top">Function</th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">0</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>PMPCFG_R</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><strong>R</strong>: Read permission</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">1</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>PMPCFG_W</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><strong>W</strong>: Write permission</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">2</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>PMPCFG_X</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><strong>X</strong>: Execute permission</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">4:3</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>PMPCFG_A_MSB</code> : <code>PMPCFG_A_LSB</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><strong>A</strong>: Mode configuration (<code>00</code> = OFF, <code>01</code> = TOR, <code>10</code> = NA4, <code>11</code> = NAPOT)</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">7</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>PMPCFG_L</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><strong>L</strong>: Lock bit, prevents further write accesses, also enforces access rights in machine-mode, can only be cleared by CPU reset</p></td> +</tr> +</tbody> +</table> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">Implemented Modes</div> +In order to reduce the CPU size certain PMP modes (<code>A</code> bits) can be excluded from synthesis. +Use the <code>PMP_TOR_MODE_EN</code> and <code>PMP_NAP_MODE_EN</code> <a href="#_processor_top_entity_generics">Processor Top Entity - Generics</a> to control +implementation of the according modes. +</td> +</tr> +</table> +</div> +<div class="paragraph"> +<p><br></p> +</div> +<h5 id="_pmpaddr" class="discrete"><strong><code>pmpaddr</code></strong></h5> +<div class="paragraph"> +<p>The <code>pmpaddr*</code> CSRs are used to configure the region&#8217;s address boundaries.</p> +</div> +<table class="tableblock frame-ends grid-none stretch"> +<colgroup> +<col style="width: 11.1111%;"> +<col style="width: 88.8889%;"> +</colgroup> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Name</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Physical memory protection address registers</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Address</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x3b0</code> (<code>pmpaddr1</code>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x3b1</code> (<code>pmpaddr2</code>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x3b2</code> (<code>pmpaddr3</code>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x3b3</code> (<code>pmpaddr4</code>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x3b4</code> (<code>pmpaddr5</code>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x3b5</code> (<code>pmpaddr6</code>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x3b6</code> (<code>pmpaddr6</code>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x3b7</code> (<code>pmpaddr7</code>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x3b8</code> (<code>pmpaddr8</code>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x3b9</code> (<code>pmpaddr9</code>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x3ba</code> (<code>pmpaddr10</code>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x3bb</code> (<code>pmpaddr11</code>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x3bc</code> (<code>pmpaddr12</code>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x3bd</code> (<code>pmpaddr13</code>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x3be</code> (<code>pmpaddr14</code>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x3bf</code> (<code>pmpaddr15</code>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Reset value</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x00000000</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">ISA</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>Zicsr</code> &amp; <code>PMP</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Description</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Region address configuration. The two MSBs of each CSR are hardwired to zero (= bits 33:32 of the physical address).</p></td> +</tr> +</tbody> +</table> +<div style="page-break-after: always;"></div> +</div> +<div class="sect3"> +<h4 id="_custom_functions_unit_cfu_csrs">3.8.6. Custom Functions Unit (CFU) CSRs</h4> +<h5 id="_cfureg" class="discrete"><strong><code>cfureg</code></strong></h5> +<table class="tableblock frame-ends grid-none stretch"> +<colgroup> +<col style="width: 11.1111%;"> +<col style="width: 88.8889%;"> +</colgroup> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Name</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Custom (user-defined) CFU CSRs</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Address</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x800</code> (<code>cfureg0</code>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x801</code> (<code>cfureg1</code>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x802</code> (<code>cfureg2</code>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x803</code> (<code>cfureg3</code>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Reset value</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x00000000</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">ISA</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>Zicsr</code> &amp; <code>Zxcfu</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Description</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">User-defined CSRs to be used within the <a href="#_custom_functions_unit_cfu">Custom Functions Unit (CFU)</a>.</p></td> +</tr> +</tbody> +</table> +<div style="page-break-after: always;"></div> +</div> +<div class="sect3"> +<h4 id="_machine_counter_and_timer_csrs">3.8.7. (Machine) Counter and Timer CSRs</h4> +<div class="admonitionblock important"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-important" title="Important"></i> +</td> +<td class="content"> +<div class="title"><code>time[h]</code> CSRs (Wall Clock Time)</div> +The NEORV32 does not implement the user-mode <code>time[h]</code> registers. Any access to these registers will trap. +It is recommended that the trap handler software provides a means of accessing the platform-defined <a href="#_machine_system_timer_mtime">Machine System Timer (MTIME)</a>. +</td> +</tr> +</table> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">Instruction Retired Counter Increment</div> +The <code>[m]instret[h]</code> counter always increments when a instruction enters the pipeline&#8217;s execute stage no matter +if this instruction is actually going to retire or if it causes an exception. +</td> +</tr> +</table> +</div> +<h5 id="_cycleh" class="discrete"><strong><code>cycle[h]</code></strong></h5> +<table class="tableblock frame-ends grid-none stretch"> +<colgroup> +<col style="width: 11.1111%;"> +<col style="width: 88.8889%;"> +</colgroup> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Name</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Cycle counter</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Address</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0xc00</code> (<code>cycle</code>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0xc80</code> (<code>cycleh</code>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Reset value</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x00000000</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">ISA</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>Zicsr</code> &amp; <code>Zicntr</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Description</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">The <code>cycle[h]</code> CSRs are user-mode shadow copies of the according <a href="#_mcycleh"><strong><code>mcycle[h]</code></strong></a> CSRs. The user-mode +counter are read-only. Any write access will raise an illegal instruction exception.</p></td> +</tr> +</tbody> +</table> +<div class="paragraph"> +<p><br></p> +</div> +<h5 id="_instreth" class="discrete"><strong><code>instret[h]</code></strong></h5> +<table class="tableblock frame-ends grid-none stretch"> +<colgroup> +<col style="width: 11.1111%;"> +<col style="width: 88.8889%;"> +</colgroup> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Name</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Instructions-retired counter</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Address</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0xc02</code> (<code>instret</code>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0xc82</code> (<code>instreth</code>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Reset value</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x00000000</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">ISA</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>Zicsr</code> &amp; <code>Zicntr</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Description</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">The <code>instret[h]</code> CSRs are user-mode shadow copies of the according <a href="#_minstreth"><strong><code>minstret[h]</code></strong></a> CSRs. The user-mode +counter are read-only. Any write access will raise an illegal instruction exception.</p></td> +</tr> +</tbody> +</table> +<div class="paragraph"> +<p><br></p> +</div> +<h5 id="_mcycleh" class="discrete"><strong><code>mcycle[h]</code></strong></h5> +<table class="tableblock frame-ends grid-none stretch"> +<colgroup> +<col style="width: 11.1111%;"> +<col style="width: 88.8889%;"> +</colgroup> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Name</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Machine cycle counter</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Address</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0xb00</code> (<code>mcycle</code>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0xb80</code> (<code>mcycleh</code>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Reset value</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x00000000</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">ISA</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>Zicsr</code> &amp; <code>Zicntr</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Description</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">If not halted via the <a href="#_mcountinhibit"><strong><code>mcountinhibit</code></strong></a> CSR the <code>cycle[h]</code> CSRs will increment with every active CPU clock +cycle (CPU not in sleep mode). These registers are read/write only for machine-mode software.</p></td> +</tr> +</tbody> +</table> +<div class="paragraph"> +<p><br></p> +</div> +<h5 id="_minstreth" class="discrete"><strong><code>minstret[h]</code></strong></h5> +<table class="tableblock frame-ends grid-none stretch"> +<colgroup> +<col style="width: 11.1111%;"> +<col style="width: 88.8889%;"> +</colgroup> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Name</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Machine instructions-retired counter</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Address</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0xb02</code> (<code>minstret</code>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0xb82</code> (<code>minstreth</code>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Reset value</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x00000000</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">ISA</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>Zicsr</code> &amp; <code>Zicntr</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Description</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">If not halted via the <a href="#_mcountinhibit"><strong><code>mcountinhibit</code></strong></a> CSR the <code>minstret[h]</code> CSRs will increment with every retired instruction. +These registers are read/write only for machine-mode software</p></td> +</tr> +</tbody> +</table> +<div class="admonitionblock important"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-important" title="Important"></i> +</td> +<td class="content"> +<div class="title">Instruction Retiring</div> +Note that <strong>all</strong> executed instruction do increment the <code>[m]instret</code>[h] counters even if they do not retire +(e.g. if the instruction causes an exception). +</td> +</tr> +</table> +</div> +<div style="page-break-after: always;"></div> +</div> +<div class="sect3"> +<h4 id="_hardware_performance_monitors_hpm_csrs">3.8.8. Hardware Performance Monitors (HPM) CSRs</h4> +<div class="paragraph"> +<p>The actual number of implemented hardware performance monitors is configured via the <code>HPM_NUM_CNTS</code> top entity generic, +Note that always all 13 HPM counter and configuration registers (<code>mhpmcounter*[h]</code> and <code>mhpmevent*</code>) are implemented, but +only the actually configured ones are implemented as "real" physical registers - the remaining ones will be hardwired to zero.</p> +</div> +<div class="paragraph"> +<p>If trying to access an HPM-related CSR beyond <code>HPM_NUM_CNTS</code> <strong>no illegal instruction exception is +triggered</strong>. These CSRs are read-only (writes are ignored) and always return zero.</p> +</div> +<div class="paragraph"> +<p>The total counter width of the HPMs can be configured before synthesis via the <code>HPM_CNT_WIDTH</code> generic (0..64-bit). +If <code>HPM_NUM_CNTS</code> is less than 64, all remaining MSB-aligned bits are hardwired to zero.</p> +</div> +<h5 id="_mhpmevent" class="discrete"><strong><code>mhpmevent</code></strong></h5> +<table class="tableblock frame-ends grid-none stretch"> +<colgroup> +<col style="width: 11.1111%;"> +<col style="width: 88.8889%;"> +</colgroup> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Name</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Machine hardware performance monitor event select</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Address</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x233</code> (<code>mhpmevent3</code>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x234</code> (<code>mhpmevent4</code>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x235</code> (<code>mhpmevent5</code>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x236</code> (<code>mhpmevent6</code>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x237</code> (<code>mhpmevent7</code>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x238</code> (<code>mhpmevent8</code>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x239</code> (<code>mhpmevent9</code>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x23a</code> (<code>mhpmevent10</code>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x23b</code> (<code>mhpmevent11</code>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x23c</code> (<code>mhpmevent12</code>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x23d</code> (<code>mhpmevent13</code>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x23e</code> (<code>mhpmevent14</code>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x23f</code> (<code>mhpmevent15</code>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Reset value</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x00000000</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">ISA</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>Zicsr</code> &amp; <code>Zihpm</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Description</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">The value in these CSRs define the architectural events that cause an increment of the according <code>mhpmcounter*[h]</code> counter(s). +All available events are listed in the table below. If more than one event is selected, the according counter will increment if <em>any</em> of +the enabled events is observed (logical OR). Note that the counter will only increment by 1 step per clock +cycle even if more than one trigger event is observed.</p></td> +</tr> +</tbody> +</table> +<table class="tableblock frame-all grid-rows stretch"> +<caption class="title">Table 69. <code>mhpmevent*</code> CSR Bits</caption> +<colgroup> +<col style="width: 7.1428%;"> +<col style="width: 21.4285%;"> +<col style="width: 7.1428%;"> +<col style="width: 64.2859%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-center valign-top">Bit</th> +<th class="tableblock halign-center valign-top">Name [C]</th> +<th class="tableblock halign-center valign-top">R/W</th> +<th class="tableblock halign-left valign-top">Event Description</th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-center valign-top" colspan="4"><p class="tableblock"><strong>RISC-V-compatible</strong></p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">0</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>HPMCNT_EVENT_CY</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">active clock cycle (CPU not in <a href="#_sleep_mode">Sleep Mode</a>)</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">1</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>HPMCNT_EVENT_TM</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><em>not implemented</em>, hardwired to zero</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">2</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>HPMCNT_EVENT_IR</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">any executed instruction (16-bit/compressed or 32-bit/uncompressed)</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top" colspan="4"><p class="tableblock"><strong>NEORV32-specific</strong></p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">3</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>HPMCNT_EVENT_COMPR</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">any executed 16-bit/compressed (<a href="#_c_isa_extension"><code>C</code> ISA Extension</a>) instruction</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">4</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>HPMCNT_EVENT_WAIT_DIS</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">instruction dispatch wait cycle (wait for instruction prefetch-buffer refill (<a href="#_cpu_control_unit">CPU Control Unit</a> IPB); +caused by a fence instruction, a control flow transfer or a instruction fetch bus wait cycle)</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">5</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>HPMCNT_EVENT_WAIT_ALU</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">any delay/wait cycle caused by a <em>multi-cycle</em> <a href="#_cpu_arithmetic_logic_unit">CPU Arithmetic Logic Unit</a> operation</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">6</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>HPMCNT_EVENT_BRANCH</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">any executed branch instruction (unconditional, conditional-taken or conditional-not-taken)</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">7</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>HPMCNT_EVENT_BRANCHED</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">any control transfer operation (unconditional jump, taken conditional branch or trap entry/exit)</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">8</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>HPMCNT_EVENT_LOAD</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">any executed load operation (including atomic memory operations, <a href="#_a_isa_extension"><code>A</code> ISA Extension</a>)</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">9</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>HPMCNT_EVENT_STORE</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">any executed store operation (including atomic memory operations, <a href="#_a_isa_extension"><code>A</code> ISA Extension</a>)</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">10</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>HPMCNT_EVENT_WAIT_LSU</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">any memory/bus/cache/etc. delay/wait cycle while executing any load or store operation (caused by a data bus wait cycle))</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">11</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>HPMCNT_EVENT_TRAP</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">starting processing of any trap (<a href="#_traps_exceptions_and_interrupts">Traps, Exceptions and Interrupts</a>)</p></td> +</tr> +</tbody> +</table> +<div class="admonitionblock important"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-important" title="Important"></i> +</td> +<td class="content"> +<div class="title">Instruction Retiring ("Retired == Executed")</div> +The CPU HPM/counter logic treats all executed instruction as "retired" even if they raise an exception, +cause an interrupt, trigger a privilege mode change or were not meant to retire (by the RISC-V spec.). +</td> +</tr> +</table> +</div> +<div class="paragraph"> +<p><br></p> +</div> +<h5 id="_mhpmcounterh" class="discrete"><strong><code>mhpmcounter[h]</code></strong></h5> +<table class="tableblock frame-ends grid-none stretch"> +<colgroup> +<col style="width: 11.1111%;"> +<col style="width: 88.8889%;"> +</colgroup> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Name</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Machine hardware performance monitor (HPM) counter</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Address</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0xb03</code>, <code>0xb83</code> (<code>mhpmcounter3</code>, <code>mhpmcounter3h</code>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0xb04</code>, <code>0xb84</code> (<code>mhpmcounter4</code>, <code>mhpmcounter4h</code>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0xb05</code>, <code>0xb85</code> (<code>mhpmcounter5</code>, <code>mhpmcounter5h</code>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0xb06</code>, <code>0xb86</code> (<code>mhpmcounter6</code>, <code>mhpmcounter6h</code>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0xb07</code>, <code>0xb87</code> (<code>mhpmcounter7</code>, <code>mhpmcounter7h</code>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0xb08</code>, <code>0xb88</code> (<code>mhpmcounter8</code>, <code>mhpmcounter8h</code>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0xb09</code>, <code>0xb89</code> (<code>mhpmcounter9</code>, <code>mhpmcounter9h</code>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0xb0a</code>, <code>0xb8a</code> (<code>mhpmcounter10</code>, <code>mhpmcounter10h</code>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0xb0b</code>, <code>0xb8b</code> (<code>mhpmcounter11</code>, <code>mhpmcounter11h</code>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0xb0c</code>, <code>0xb8c</code> (<code>mhpmcounter12</code>, <code>mhpmcounter12h</code>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0xb0d</code>, <code>0xb8d</code> (<code>mhpmcounter13</code>, <code>mhpmcounter13h</code>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0xb0e</code>, <code>0xb8e</code> (<code>mhpmcounter14</code>, <code>mhpmcounter14h</code>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0xb0f</code>, <code>0xb8f</code> (<code>mhpmcounter15</code>, <code>mhpmcounter15h</code>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Reset value</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x00000000</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">ISA</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>Zicsr</code> &amp; <code>Zihpm</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Description</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">If not halted via the <a href="#_mcountinhibit"><strong><code>mcountinhibit</code></strong></a> CSR the HPM counter CSR(s) increment whenever a +configured event from the according <a href="#_mhpmevent"><strong><code>mhpmevent</code></strong></a> CSR occurs. The counter registers are read/write for machine mode +and are not accessible for lower-privileged software.</p></td> +</tr> +</tbody> +</table> +<div class="paragraph"> +<p><br></p> +</div> +<h5 id="_hpmcounterh" class="discrete"><strong><code>hpmcounter[h]</code></strong></h5> +<table class="tableblock frame-ends grid-none stretch"> +<colgroup> +<col style="width: 11.1111%;"> +<col style="width: 88.8889%;"> +</colgroup> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Name</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">User hardware performance monitor (HPM) counter</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Address</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0xc03</code>, <code>0xc83</code> (<code>hpmcounter3</code>, <code>hpmcounter3h</code>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0xc04</code>, <code>0xc84</code> (<code>hpmcounter4</code>, <code>hpmcounter4h</code>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0xc05</code>, <code>0xc85</code> (<code>hpmcounter5</code>, <code>hpmcounter5h</code>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0xc06</code>, <code>0xc86</code> (<code>hpmcounter6</code>, <code>hpmcounter6h</code>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0xc07</code>, <code>0xc87</code> (<code>hpmcounter7</code>, <code>hpmcounter7h</code>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0xc08</code>, <code>0xc88</code> (<code>hpmcounter8</code>, <code>hpmcounter8h</code>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0xc09</code>, <code>0xc89</code> (<code>hpmcounter9</code>, <code>hpmcounter9h</code>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0xc0a</code>, <code>0xc8a</code> (<code>hpmcounter10</code>, <code>hpmcounter10h</code>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0xc0b</code>, <code>0xc8b</code> (<code>hpmcounter11</code>, <code>hpmcounter11h</code>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0xc0c</code>, <code>0xc8c</code> (<code>hpmcounter12</code>, <code>hpmcounter12h</code>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0xc0d</code>, <code>0xc8d</code> (<code>hpmcounter13</code>, <code>hpmcounter13h</code>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0xc0e</code>, <code>0xc8e</code> (<code>hpmcounter14</code>, <code>hpmcounter14h</code>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0xc0f</code>, <code>0xc8f</code> (<code>hpmcounter15</code>, <code>hpmcounter15h</code>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Reset value</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x00000000</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">ISA</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>Zicsr</code> &amp; <code>Zihpm</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Description</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">The <code>hpmcounter*[h]</code> are user-mode shadow copies of the according <a href="#_mhpmcounterh"><strong><code>mhpmcounter[h]</code></strong></a> CSRs. The user mode +counter CSRs are read-only. Any write access will raise an illegal instruction exception.</p></td> +</tr> +</tbody> +</table> +<div style="page-break-after: always;"></div> +</div> +<div class="sect3"> +<h4 id="_machine_counter_setup_csrs">3.8.9. Machine Counter Setup CSRs</h4> +<h5 id="_mcountinhibit" class="discrete"><strong><code>mcountinhibit</code></strong></h5> +<table class="tableblock frame-ends grid-none stretch"> +<colgroup> +<col style="width: 11.1111%;"> +<col style="width: 88.8889%;"> +</colgroup> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Name</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Machine counter-inhibit register</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Address</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x320</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Reset value</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x00000000</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">ISA</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>Zicsr</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Description</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Set bit to halt the according counter CSR.</p></td> +</tr> +</tbody> +</table> +<table class="tableblock frame-all grid-rows stretch"> +<caption class="title">Table 70. <code>mcountinhibit</code> CSR Bits</caption> +<colgroup> +<col style="width: 7.1428%;"> +<col style="width: 21.4285%;"> +<col style="width: 7.1428%;"> +<col style="width: 64.2859%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-center valign-top">Bit</th> +<th class="tableblock halign-center valign-top">Name [C]</th> +<th class="tableblock halign-center valign-top">R/W</th> +<th class="tableblock halign-left valign-top">Description</th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">0</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>CSR_MCOUNTINHIBIT_IR</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><strong>IR</strong>: Set to <code>1</code> to halt <code>[m]instret[h]</code>; hardwired to zero if <code>Zicntr</code> ISA extension is disabled</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">1</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">-</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><strong>TM</strong>: Hardwired to zero as <code>time[h]</code> CSRs are not implemented</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">2</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>CSR_MCOUNTINHIBIT_CY</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><strong>CY</strong>: Set to <code>1</code> to halt <code>[m]cycle[h]</code>; hardwired to zero if <code>Zicntr</code> ISA extension is disabled</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">15:3</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>CSR_MCOUNTINHIBIT_HPM3</code> : <code>CSR_MCOUNTINHIBIT_HPM15</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><strong>HPMx</strong>: Set to <code>1</code> to halt <code>[m]hpmcount*[h]</code>; hardwired to zero if <code>Zihpm</code> ISA extension is disabled</p></td> +</tr> +</tbody> +</table> +<div style="page-break-after: always;"></div> +</div> +<div class="sect3"> +<h4 id="_machine_information_csrs">3.8.10. Machine Information CSRs</h4> +<h5 id="_mvendorid" class="discrete"><strong><code>mvendorid</code></strong></h5> +<table class="tableblock frame-ends grid-none stretch"> +<colgroup> +<col style="width: 11.1111%;"> +<col style="width: 88.8889%;"> +</colgroup> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Name</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Machine vendor ID</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Address</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0xf11</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Reset value</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>DEFINED</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">ISA</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>Zicsr</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Description</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Vendor ID (JEDEC identifier, lowest 11 bits), assigned via the <code>JEDEC_ID</code> top generic (<a href="#_processor_top_entity_generics">Processor Top Entity - Generics</a>).</p></td> +</tr> +</tbody> +</table> +<div class="paragraph"> +<p><br></p> +</div> +<h5 id="_marchid" class="discrete"><strong><code>marchid</code></strong></h5> +<table class="tableblock frame-ends grid-none stretch"> +<colgroup> +<col style="width: 11.1111%;"> +<col style="width: 88.8889%;"> +</colgroup> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Name</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Machine architecture ID</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Address</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0xf12</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Reset value</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x00000013</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">ISA</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>Zicsr</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Description</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">The <code>marchid</code> CSR is read-only and provides the NEORV32 official RISC-V open-source architecture ID +(decimal: 19, 32-bit hexadecimal: 0x00000013).</p></td> +</tr> +</tbody> +</table> +<div class="paragraph"> +<p><br></p> +</div> +<h5 id="_mimpid" class="discrete"><strong><code>mimpid</code></strong></h5> +<table class="tableblock frame-ends grid-none stretch"> +<colgroup> +<col style="width: 11.1111%;"> +<col style="width: 88.8889%;"> +</colgroup> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Name</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Machine implementation ID</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Address</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0xf13</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Reset value</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>DEFINED</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">ISA</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>Zicsr</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Description</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">The <code>mimpid</code> CSR is read-only and provides the version of the +NEORV32 as BCD-coded number (example: <code>mimpid = 0x01020312</code> → 01.02.03.12 → version 1.2.3.12).</p></td> +</tr> +</tbody> +</table> +<div class="paragraph"> +<p><br></p> +</div> +<h5 id="_mhartid" class="discrete"><strong><code>mhartid</code></strong></h5> +<table class="tableblock frame-ends grid-none stretch"> +<colgroup> +<col style="width: 11.1111%;"> +<col style="width: 88.8889%;"> +</colgroup> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Name</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Machine hardware thread ID</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Address</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0xf14</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Reset value</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>DEFINED</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">ISA</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>Zicsr</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Description</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">The <code>mhartid</code> CSR is read-only and provides the core&#8217;s hart ID, +which is assigned via the <code>HW_THREAD_ID</code> top generic (<a href="#_processor_top_entity_generics">Processor Top Entity - Generics</a>).</p></td> +</tr> +</tbody> +</table> +<div class="paragraph"> +<p><br></p> +</div> +<h5 id="_mconfigptr" class="discrete"><strong><code>mconfigptr</code></strong></h5> +<table class="tableblock frame-ends grid-none stretch"> +<colgroup> +<col style="width: 11.1111%;"> +<col style="width: 88.8889%;"> +</colgroup> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Name</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Machine configuration pointer register</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Address</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0xf15</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Reset value</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x00000000</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">ISA</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>Zicsr</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Description</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">The features of this CSR are not implemented yet. The register is read-only and always returns zero.</p></td> +</tr> +</tbody> +</table> +<div style="page-break-after: always;"></div> +</div> +<div class="sect3"> +<h4 id="_neorv32_specific_csrs">3.8.11. NEORV32-Specific CSRs</h4> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +All NEORV32-specific CSRs are mapped to addresses that are explicitly reserved for custom <strong>Machine-Mode, read-only</strong> CSRs +(assured by the RISC-V privileged specifications). Hence, these CSRs can only be accessed when in machine-mode. Any access +outside of machine-mode will raise an illegal instruction exception. +</td> +</tr> +</table> +</div> +<h5 id="_mxisa" class="discrete"><strong><code>mxisa</code></strong></h5> +<table class="tableblock frame-ends grid-none stretch"> +<colgroup> +<col style="width: 11.1111%;"> +<col style="width: 88.8889%;"> +</colgroup> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Name</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Machine extended isa and extensions register</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Address</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0xfc0</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Reset value</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>DEFINED</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">ISA</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>Zicsr</code> &amp; <code>X</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Description</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">The <code>mxisa</code> CSRs is a NEORV32-specific read-only CSR that helps machine-mode software to +discover ISA sub-extensions and CPU configuration options</p></td> +</tr> +</tbody> +</table> +<table class="tableblock frame-all grid-rows stretch"> +<caption class="title">Table 71. <code>mxisa</code> CSR Bits</caption> +<colgroup> +<col style="width: 10%;"> +<col style="width: 30%;"> +<col style="width: 10%;"> +<col style="width: 50%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-center valign-top">Bit</th> +<th class="tableblock halign-center valign-top">Name [C]</th> +<th class="tableblock halign-center valign-top">R/W</th> +<th class="tableblock halign-left valign-top">Description</th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">0</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>CSR_MXISA_ZICSR</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_zicsr_isa_extension"><code>Zicsr</code> ISA Extension</a> available</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">1</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>CSR_MXISA_ZIFENCEI</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_zifencei_isa_extension"><code>Zifencei</code> ISA Extension</a> available</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">2</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>CSR_MXISA_ZMMUL</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_zmmul_isa_extension"><code>Zmmul</code> - ISA Extension</a> available</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">3</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>CSR_MXISA_ZXCFU</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_zxcfu_isa_extension"><code>Zxcfu</code> ISA Extension</a> available</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">4</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">-</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><em>reserved</em>, hardwired to zero</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">5</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>CSR_MXISA_ZFINX</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_zfinx_isa_extension"><code>Zfinx</code> ISA Extension</a> available</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">6</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>CSR_MXISA_ZICOND</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_zicond_isa_extension"><code>Zicond</code> ISA Extension</a> available</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">7</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>CSR_MXISA_ZICNTR</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_zicntr_isa_extension"><code>Zicntr</code> ISA Extension</a> available</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">8</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>CSR_MXISA_SMPMP</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_smpmp_isa_extension"><code>Smpmp</code> ISA Extension</a> available</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">9</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>CSR_MXISA_ZIHPM</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_zihpm_isa_extension"><code>Zihpm</code> ISA Extension</a> available</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">10</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>CSR_MXISA_SDEXT</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_sdext_isa_extension"><code>Sdext</code> ISA Extension</a> available</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">11</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>CSR_MXISA_SDTRIG</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_sdtrig_isa_extension"><code>Sdtrig</code> ISA Extension</a> available</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">19:12</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">-</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">hardwired to zero</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">20</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>CSR_MXISA_IS_SIM</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">set if CPU is being <strong>simulated</strong> (⚠️ not guaranteed)</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">28:21</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">-</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">hardwired to zero</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">29</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>CSR_MXISA_RFHWRST</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">full hardware reset of register file available when set (<code>REGFILE_HW_RST</code>)</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">30</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>CSR_MXISA_FASTMUL</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">fast multiplication available when set (<code>FAST_MUL_EN</code>)</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">31</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>CSR_MXISA_FASTSHIFT</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">fast shifts available when set (<code>FAST_SHIFT_EN</code>)</p></td> +</tr> +</tbody> +</table> +<div style="page-break-after: always;"></div> +</div> +<div class="sect3"> +<h4 id="_traps_exceptions_and_interrupts">3.8.12. Traps, Exceptions and Interrupts</h4> +<div class="paragraph"> +<p>In this document the following terminology is used (derived from the RISC-V trace specification +available at <a href="https://github.com/riscv-non-isa/riscv-trace-spec" class="bare">https://github.com/riscv-non-isa/riscv-trace-spec</a>):</p> +</div> +<div class="ulist"> +<ul> +<li> +<p><strong>exception</strong>: an unusual condition occurring at run time associated (i.e. <em>synchronous</em>) with an instruction in a RISC-V hart</p> +</li> +<li> +<p><strong>interrupt</strong>: an external <em>asynchronous</em> event that may cause a RISC-V hart to experience an unexpected transfer of control</p> +</li> +<li> +<p><strong>trap</strong>: the transfer of control to a trap handler caused by either an <em>exception</em> or an <em>interrupt</em></p> +</li> +</ul> +</div> +<div class="paragraph"> +<p>Whenever an exception or interrupt is triggered, the CPU switches to machine-mode (if not already in machine-mode) +and continues operation at the address being stored in the <a href="#_mtvec"><strong><code>mtvec</code></strong></a> CSR. The cause of the the trap can be determined via the +<a href="#_mcause"><strong><code>mcause</code></strong></a> CSR. A list of all implemented <code>mcause</code> values and the according description can be found below in section +<a href="#_neorv32_trap_listing">NEORV32 Trap Listing</a>. The address that reflects the current program counter when a trap was taken is stored to +<a href="#_mepc"><strong><code>mepc</code></strong></a> CSR. Additional information regarding the cause of the trap can be retrieved from the <a href="#_mtval"><strong><code>mtval</code></strong></a> and <a href="#_mtinst"><strong><code>mtinst</code></strong></a> CSRs.</p> +</div> +<div class="paragraph"> +<p>The traps are prioritized. If several <em>exceptions</em> occur at once only the one with highest priority is triggered +while all remaining exceptions are ignored and discarded. If several <em>interrupts</em> trigger at once, the one with highest priority +is serviced first while the remaining ones stay <em>pending</em>. After completing the interrupt handler the interrupt with +the second highest priority will get serviced and so on until no further interrupts are pending.</p> +</div> +<div class="admonitionblock important"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-important" title="Important"></i> +</td> +<td class="content"> +<div class="title">Interrupts when in User-Mode</div> +If the core is currently operating in less privileged user-mode, interrupts are globally enabled +even if <a href="#_mstatus"><strong><code>mstatus</code></strong></a>.mie is cleared. +</td> +</tr> +</table> +</div> +<div class="admonitionblock important"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-important" title="Important"></i> +</td> +<td class="content"> +<div class="title">Interrupt Signal Requirements - Standard RISC-V Interrupts</div> +All interrupt request signals are <strong>high-active</strong>. Once triggered, a interrupt request line should stay high +until it is explicitly acknowledged by a source-specific mechanism (for example by writing to a specific memory-mapped register). +</td> +</tr> +</table> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">Instruction Atomicity and Forward-Progress</div> +All instructions execute as atomic operations - interrupts can only trigger <em>between</em> consecutive instructions. +Additionally, if there is a permanent interrupt request, exactly one instruction from the interrupted program will be executed before +another interrupt handler can start. This allows program progress even if there are permanent interrupt requests. +</td> +</tr> +</table> +</div> +<div class="sect4"> +<h5 id="_memory_access_exceptions">Memory Access Exceptions</h5> +<div class="paragraph"> +<p>If a load operation causes any exception, the instruction&#8217;s destination register is <strong>not written</strong> at all. Furthermore, +exceptions caused by a misaligned memory address a physical memory protection fault do not trigger a memory access request at all.</p> +</div> +<div class="paragraph"> +<p>For 32-bit-only instructions (= no <code>C</code> extension) the misaligned instruction exception is raised if bit 1 of the fetch +address is set (i.e. not on a 32-bit boundary). If the <code>C</code> extension is implemented there will <strong>never</strong> be a misaligned +instruction exception at all.</p> +</div> +</div> +<div class="sect4"> +<h5 id="_custom_fast_interrupt_request_lines">Custom Fast Interrupt Request Lines</h5> +<div class="paragraph"> +<p>As a custom extension, the NEORV32 CPU features 16 fast interrupt request (FIRQ) lines via the <code>firq_i</code> CPU top +entity signals. These interrupts have custom configuration and status flags in the <a href="#_mie"><strong><code>mie</code></strong></a> and <a href="#_mip"><strong><code>mip</code></strong></a> CSRs and also +provide custom trap codes in <a href="#_mcause"><strong><code>mcause</code></strong></a>. These FIRQs are reserved for NEORV32 processor-internal usage only.</p> +</div> +</div> +<div class="sect4"> +<h5 id="_neorv32_trap_listing">NEORV32 Trap Listing</h5> +<div class="paragraph"> +<p>The following tables show all traps that are currently supported by the NEORV32 CPU. It also shows the prioritization +and the CSR side-effects.</p> +</div> +<div class="paragraph"> +<p><strong>Table Annotations</strong></p> +</div> +<div class="paragraph"> +<p>The "Prio." column shows the priority of each trap with the highest priority being 1. The "RTE Trap ID" aliases are +defined by the NEORV32 core library (the runtime environment <em>RTE</em>) and can be used in plain C code when interacting +with the pre-defined RTE function. The <a href="#_mcause"><strong><code>mcause</code></strong></a>, <a href="#_mepc"><strong><code>mepc</code></strong></a>, <a href="#_mtval"><strong><code>mtval</code></strong></a> and <a href="#_mtinst"><strong><code>mtinst</code></strong></a> columns show the value being +written to the according CSRs when a trap is triggered:</p> +</div> +<div class="ulist"> +<ul> +<li> +<p><strong>I-PC</strong> - address of intercepted instruction (instruction has <em>not</em> been executed yet)</p> +</li> +<li> +<p><strong>PC</strong> - address of instruction that caused the trap (instruction has been executed)</p> +</li> +<li> +<p><strong>ADR</strong> - bad data memory access address that caused the trap</p> +</li> +<li> +<p><strong>INS</strong> - the transformed/decompressed instruction word that caused the trap</p> +</li> +<li> +<p><strong>0</strong> - zero</p> +</li> +</ul> +</div> +<table class="tableblock frame-all grid-rows stretch"> +<caption class="title">Table 72. NEORV32 Trap Listing</caption> +<colgroup> +<col style="width: 3.4482%;"> +<col style="width: 13.7931%;"> +<col style="width: 27.5862%;"> +<col style="width: 34.4827%;"> +<col style="width: 6.8965%;"> +<col style="width: 6.8965%;"> +<col style="width: 6.8968%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-left valign-top">Prio.</th> +<th class="tableblock halign-left valign-top"><code>mcause</code></th> +<th class="tableblock halign-left valign-top">RTE Trap ID</th> +<th class="tableblock halign-left valign-top">Cause</th> +<th class="tableblock halign-left valign-top"><code>mepc</code></th> +<th class="tableblock halign-left valign-top"><code>mtval</code></th> +<th class="tableblock halign-left valign-top"><code>mtinst</code></th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-center valign-top" colspan="7"><p class="tableblock"><strong>Exceptions</strong> (<em>synchronous</em> to instruction execution)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">1</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x00000001</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>TRAP_CODE_I_ACCESS</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">instruction access fault</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">I-PC</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">0</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">INS</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">2</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x00000002</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>TRAP_CODE_I_ILLEGAL</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">illegal instruction</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">PC</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">0</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">INS</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">3</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x00000000</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>TRAP_CODE_I_MISALIGNED</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">instruction address misaligned</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">PC</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">0</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">INS</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">4</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x0000000b</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>TRAP_CODE_MENV_CALL</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">environment call from M-mode</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">PC</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">0</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">INS</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">5</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x00000008</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>TRAP_CODE_UENV_CALL</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">environment call from U-mode</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">PC</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">0</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">INS</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">6</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x00000003</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>TRAP_CODE_BREAKPOINT</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">software breakpoint / trigger firing</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">PC</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">0</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">INS</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">7</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x00000006</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>TRAP_CODE_S_MISALIGNED</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">store address misaligned</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">PC</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">ADR</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">INS</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">8</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x00000004</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>TRAP_CODE_L_MISALIGNED</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">load address misaligned</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">PC</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">ADR</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">INS</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">9</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x00000007</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>TRAP_CODE_S_ACCESS</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">store access fault</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">PC</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">ADR</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">INS</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">10</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x00000005</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>TRAP_CODE_L_ACCESS</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">load access fault</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">PC</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">ADR</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">INS</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top" colspan="7"><p class="tableblock"><strong>Interrupts</strong> (<em>asynchronous</em> to instruction execution)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">11</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x80000010</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>TRAP_CODE_FIRQ_0</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">fast interrupt request channel 0</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">I-PC</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">0</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">0</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">12</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x80000011</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>TRAP_CODE_FIRQ_1</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">fast interrupt request channel 1</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">I-PC</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">0</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">0</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">13</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x80000012</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>TRAP_CODE_FIRQ_2</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">fast interrupt request channel 2</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">I-PC</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">0</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">0</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">14</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x80000013</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>TRAP_CODE_FIRQ_3</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">fast interrupt request channel 3</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">I-PC</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">0</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">0</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">15</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x80000014</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>TRAP_CODE_FIRQ_4</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">fast interrupt request channel 4</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">I-PC</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">0</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">0</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">16</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x80000015</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>TRAP_CODE_FIRQ_5</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">fast interrupt request channel 5</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">I-PC</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">0</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">0</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">17</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x80000016</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>TRAP_CODE_FIRQ_6</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">fast interrupt request channel 6</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">I-PC</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">0</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">0</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">18</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x80000017</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>TRAP_CODE_FIRQ_7</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">fast interrupt request channel 7</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">I-PC</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">0</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">0</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">19</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x80000018</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>TRAP_CODE_FIRQ_8</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">fast interrupt request channel 8</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">I-PC</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">0</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">0</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">20</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x80000019</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>TRAP_CODE_FIRQ_9</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">fast interrupt request channel 9</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">I-PC</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">0</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">0</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">21</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x8000001a</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>TRAP_CODE_FIRQ_10</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">fast interrupt request channel 10</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">I-PC</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">0</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">0</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">22</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x8000001b</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>TRAP_CODE_FIRQ_11</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">fast interrupt request channel 11</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">I-PC</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">0</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">0</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">23</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x8000001c</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>TRAP_CODE_FIRQ_12</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">fast interrupt request channel 12</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">I-PC</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">0</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">0</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">24</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x8000001d</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>TRAP_CODE_FIRQ_13</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">fast interrupt request channel 13</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">I-PC</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">0</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">0</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">25</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x8000001e</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>TRAP_CODE_FIRQ_14</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">fast interrupt request channel 14</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">I-PC</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">0</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">0</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">26</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x8000001f</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>TRAP_CODE_FIRQ_15</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">fast interrupt request channel 15</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">I-PC</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">0</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">0</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">27</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x8000000B</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>TRAP_CODE_MEI</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">machine external interrupt (MEI)</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">I-PC</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">0</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">0</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">28</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x80000003</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>TRAP_CODE_MSI</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">machine software interrupt (MSI)</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">I-PC</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">0</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">0</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">29</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x80000007</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>TRAP_CODE_MTI</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">machine timer interrupt (MTI)</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">I-PC</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">0</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">0</p></td> +</tr> +</tbody> +</table> +<table class="tableblock frame-all grid-rows stretch"> +<caption class="title">Table 73. NEORV32 Trap Description</caption> +<colgroup> +<col style="width: 30%;"> +<col style="width: 70%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-left valign-top">Trap ID [C]</th> +<th class="tableblock halign-left valign-top">Triggered when &#8230;&#8203;</th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>TRAP_CODE_I_ACCESS</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">bus timeout, bus access error or <a href="#_smpmp_isa_extension">PMP</a> rule violation during instruction fetch</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>TRAP_CODE_I_ILLEGAL</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">trying to execute an invalid instruction word (malformed or not supported) or on a privilege violation</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>TRAP_CODE_I_MISALIGNED</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">fetching a 32-bit instruction word that is not 32-bit-aligned (see note below)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>TRAP_CODE_MENV_CALL</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">executing <code>ecall</code> instruction in machine-mode</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>TRAP_CODE_UENV_CALL</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">executing <code>ecall</code> instruction in user-mode</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>TRAP_CODE_BREAKPOINT</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">executing <code>ebreak</code> instruction or if <a href="#_trigger_module">Trigger Module</a> fires</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>TRAP_CODE_S_MISALIGNED</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">storing data to an address that is not naturally aligned to the data size (half/word)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>TRAP_CODE_L_MISALIGNED</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">loading data from an address that is not naturally aligned to the data size (half/word)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>TRAP_CODE_S_ACCESS</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">bus timeout, bus access error or <a href="#_smpmp_isa_extension">PMP</a> rule violation during load data operation</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>TRAP_CODE_L_ACCESS</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">bus timeout, bus access error or <a href="#_smpmp_isa_extension">PMP</a> rule violation during store data operation</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>TRAP_CODE_FIRQ_*</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">caused by interrupt-condition of <strong>processor-internal modules</strong>, see <a href="#_neorv32_specific_fast_interrupt_requests">NEORV32-Specific Fast Interrupt Requests</a></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>TRAP_CODE_MEI</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">machine external interrupt (via dedicated <a href="#_processor_top_entity_signals">Processor Top Entity - Signals</a>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>TRAP_CODE_MSI</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">machine software interrupt (via dedicated <a href="#_processor_top_entity_signals">Processor Top Entity - Signals</a>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>TRAP_CODE_MTI</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">machine timer interrupt (internal <a href="#_machine_system_timer_mtime">Machine System Timer (MTIME)</a> or via dedicated <a href="#_processor_top_entity_signals">Processor Top Entity - Signals</a>)</p></td> +</tr> +</tbody> +</table> +<div class="admonitionblock warning"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-warning" title="Warning"></i> +</td> +<td class="content"> +<div class="title">Resumable Exceptions</div> +Note that not all exceptions are resumable. For example, the "instruction access fault" exception or the "instruction +address misaligned" exception are not resumable in most cases. These exception might indicate a fatal memory hardware failure. +</td> +</tr> +</table> +</div> +</div> +</div> +</div> +</div> +</div> +<div class="sect1"> +<h2 id="_software_framework">4. Software Framework</h2> +<div class="sectionbody"> +<div class="paragraph"> +<p>The NEORV32 project comes with a complete software ecosystem called the "software framework", which +is based on the C-language RISC-V GCC port and consists of the following parts:</p> +</div> +<div class="ulist"> +<ul> +<li> +<p><a href="#_compiler_toolchain">Compiler Toolchain</a></p> +</li> +<li> +<p><a href="#_core_libraries">Core Libraries</a></p> +</li> +<li> +<p><a href="#_application_makefile">Application Makefile</a></p> +</li> +<li> +<p><a href="#_executable_image_format">Executable Image Format</a></p> +<div class="ulist"> +<ul> +<li> +<p><a href="#_linker_script">Linker Script</a></p> +</li> +<li> +<p><a href="#_ram_layout">RAM Layout</a></p> +</li> +<li> +<p><a href="#_c_standard_library">C Standard Library</a></p> +</li> +<li> +<p><a href="#_start_up_code_crt0">Start-Up Code (crt0)</a></p> +</li> +</ul> +</div> +</li> +<li> +<p><a href="#_bootloader">Bootloader</a></p> +</li> +<li> +<p><a href="#_neorv32_runtime_environment">NEORV32 Runtime Environment</a></p> +</li> +</ul> +</div> +<div class="paragraph"> +<p>A summarizing list of the most important elements of the software framework and their according +files and folders is shown below:</p> +</div> +<table class="tableblock frame-all grid-none stretch"> +<colgroup> +<col style="width: 50%;"> +<col style="width: 50%;"> +</colgroup> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Application start-up code</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>sw/common/crt0.S</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Application linker script</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>sw/common/neorv32.ld</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Core hardware driver libraries ("HAL")</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>sw/lib/include/</code> &amp; <code>sw/lib/source/</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Central application makefile</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>sw/common/common.mk</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Tool for generating NEORV32 executables</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>sw/image_gen/</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Default bootloader</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>sw/bootloader</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Example programs</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>sw/example</code></p></td> +</tr> +</tbody> +</table> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +<div class="title">Software Documentation</div> +All core libraries and example programs are documented "in-code" using <strong>Doxygen</strong>. +The documentation is automatically built and deployed to GitHub pages and is available online +at <a href="https://stnolting.github.io/neorv32/sw/files.html" class="bare">https://stnolting.github.io/neorv32/sw/files.html</a>. +</td> +</tr> +</table> +</div> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +<div class="title">Example Programs</div> +A collection of annotated example programs, which show how to use certain CPU functions +and peripheral/IO modules, can be found in <code>sw/example</code>. +</td> +</tr> +</table> +</div> +<div class="sect2"> +<h3 id="_compiler_toolchain">4.1. Compiler Toolchain</h3> +<div class="paragraph"> +<p>The toolchain for this project is based on the free and open RISC-V GCC-port. You can find the compiler sources and +build instructions on the official RISC-V GNU toolchain GitHub page: <a href="https://github.com/riscv/riscv-gnutoolchain" class="bare">https://github.com/riscv/riscv-gnutoolchain</a>.</p> +</div> +<div class="paragraph"> +<p>The NEORV32 implements a 32-bit RISC-V architecture and uses a 32-bit integer and soft-float ABI by default. +Make sure the toolchain / toolchain build is configured accordingly.</p> +</div> +<div class="ulist"> +<ul> +<li> +<p><code>MARCH=rv32i</code></p> +</li> +<li> +<p><code>MABI=ilp32</code></p> +</li> +<li> +<p><code>RISCV_PREFIX=riscv32-unknown-elf-</code></p> +</li> +</ul> +</div> +<div class="paragraph"> +<p>These default configurations can be overridden at any times using <a href="#_application_makefile">Application Makefile</a> variables.</p> +</div> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +More information regarding the toolchain (building from scratch or downloading prebuilt ones) can be found in the +user guide section <a href="https://stnolting.github.io/neorv32/ug/#_software_toolchain_setup">Software Toolchain Setup</a>. +</td> +</tr> +</table> +</div> +<div style="page-break-after: always;"></div> +</div> +<div class="sect2"> +<h3 id="_core_libraries">4.2. Core Libraries</h3> +<div class="paragraph"> +<p>The NEORV32 project provides a set of pre-defined C libraries that allow an easy integration of the processor/CPU features +(also called "HAL" - <em>hardware abstraction layer</em>). All driver and runtime-related files are located in +<code>sw/lib</code>. These library files are automatically included and linked by adding the following include statement:</p> +</div> +<div class="listingblock"> +<div class="content"> +<pre class="highlight"><code class="language-c" data-lang="c">#include &lt;neorv32.h&gt; // NEORV32 HAL, core and runtime libraries</code></pre> +</div> +</div> +<table class="tableblock frame-all grid-rows stretch"> +<caption class="title">Table 74. NEORV32 Hardware Abstraction Layer File List</caption> +<colgroup> +<col style="width: 25%;"> +<col style="width: 25%;"> +<col style="width: 50%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-left valign-top">C source file</th> +<th class="tableblock halign-left valign-top">C header file</th> +<th class="tableblock halign-left valign-top">Description</th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>neorv32.h</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Main NEORV32 library file</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>neorv32_aux.c</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>neorv32_aux.h</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">General auxiliary/helper function</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>neorv32_cfs.c</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>neorv32_cfs.h</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_custom_functions_subsystem_cfs">Custom Functions Subsystem (CFS)</a> HAL</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>neorv32_crc.c</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>neorv32_crc.h</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_cyclic_redundancy_check_crc">Cyclic Redundancy Check (CRC)</a> HAL</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>neorv32_cpu.c</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>neorv32_cpu.h</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_neorv32_central_processing_unit_cpu">NEORV32 Central Processing Unit (CPU)</a> HAL</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>neorv32_cpu_amo.c</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>neorv32_cpu_amo.h</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Emulation functions for the read-modify-write <a href="#_a_isa_extension"><code>A</code> ISA Extension</a> instructions</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>neorv32_cpu_csr.h</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_control_and_status_registers_csrs">Control and Status Registers (CSRs)</a> definitions</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>neorv32_cpu_cfu.c</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>neorv32_cpu_cfu.h</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_custom_functions_unit_cfu">Custom Functions Unit (CFU)</a> HAL</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>neorv32_dma.c</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>neorv32_dma.h</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_direct_memory_access_controller_dma">Direct Memory Access Controller (DMA)</a> HAL</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>neorv32_gpio.c</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>neorv32_gpio.h</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_general_purpose_input_and_output_port_gpio">General Purpose Input and Output Port (GPIO)</a> HAL</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>neorv32_gptmr.c</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>neorv32_gptmr.h</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_general_purpose_timer_gptmr">General Purpose Timer (GPTMR)</a> HAL</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>neorv32_intrinsics.h</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Macros for intrinsics and custom instructions</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>neorv32_legacy.h</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Legacy compatibility layer / wrappers (<strong>do not use for new designs!</strong>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>neorv32_mtime.c</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>neorv32_mtime.h</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_machine_system_timer_mtime">Machine System Timer (MTIME)</a> HAL</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>neorv32_neoled.c</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>neorv32_neoled.h</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_smart_led_interface_neoled">Smart LED Interface (NEOLED)</a> HAL</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>neorv32_onewire.c</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>neorv32_onewire.h</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_one_wire_serial_interface_controller_onewire">One-Wire Serial Interface Controller (ONEWIRE)</a> HAL</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>neorv32_pwm.c</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>neorv32_pwm.h</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_pulse_width_modulation_controller_pwm">Pulse-Width Modulation Controller (PWM)</a> HAL</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>neorv32_rte.c</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>neorv32_rte.h</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_neorv32_runtime_environment">NEORV32 Runtime Environment</a></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>neorv32_sdi.c</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>neorv32_sdi.h</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_serial_data_interface_controller_sdi">Serial Data Interface Controller (SDI)</a> HAL</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>neorv32_slink.c</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>neorv32_slink.h</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_stream_link_interface_slink">Stream Link Interface (SLINK)</a> HAL</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>neorv32_spi.c</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>neorv32_spi.h</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_serial_peripheral_interface_controller_spi">Serial Peripheral Interface Controller (SPI)</a> HAL</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>neorv32_sysinfo.h</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_system_configuration_information_memory_sysinfo">System Configuration Information Memory (SYSINFO)</a> HAL</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>neorv32_trng.c</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>neorv32_trng.h</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_true_random_number_generator_trng">True Random-Number Generator (TRNG)</a> HAL</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>neorv32_twi.c</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>neorv32_twi.h</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_two_wire_serial_interface_controller_twi">Two-Wire Serial Interface Controller (TWI)</a> HAL</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>neorv32_uart.c</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>neorv32_uart.h</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_primary_universal_asynchronous_receiver_and_transmitter_uart0">Primary Universal Asynchronous Receiver and Transmitter (UART0)</a> and UART1 HAL</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>neorv32_wdt.c</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>neorv32_wdt.h</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_watchdog_timer_wdt">Watchdog Timer (WDT)</a> HAL</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>neorv32_xip.c</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>neorv32_xip.h</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_execute_in_place_module_xip">Execute In Place Module (XIP)</a> HAL</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>neorv32_xirq.c</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>neorv32_xirq.h</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><a href="#_external_interrupt_controller_xirq">External Interrupt Controller (XIRQ)</a> HAL</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>syscalls.c</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Newlib "system calls" (stubs)</p></td> +</tr> +</tbody> +</table> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +<div class="title">Core Library Documentation</div> +The <em>doxygen</em>-based documentation of the software framework including all core libraries is available online at +<a href="https://stnolting.github.io/neorv32/sw/files.html" class="bare">https://stnolting.github.io/neorv32/sw/files.html</a>. +</td> +</tr> +</table> +</div> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +<div class="title">CMSIS System View Description File (SVD)</div> +A CMSIS-SVD-compatible <strong>System View Description (SVD)</strong> file including all peripherals is available in <code>sw/svd</code>. +Together with a third-party plugin the processor&#8217;s SVD file can be imported right into GDB to allow comfortable +debugging of peripheral/IO devices (see <a href="https://github.com/stnolting/neorv32/discussions/656" class="bare">https://github.com/stnolting/neorv32/discussions/656</a>). +</td> +</tr> +</table> +</div> +<div style="page-break-after: always;"></div> +</div> +<div class="sect2"> +<h3 id="_application_makefile">4.3. Application Makefile</h3> +<div class="paragraph"> +<p>Application compilation is based on a single, centralized GNU makefile (<code>sw/common/common.mk</code>). Each project in the +<code>sw/example</code> folder provides a makefile that just <em>includes</em> this central makefile.</p> +</div> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +When creating a new project, copy an existing project folder or at least the makefile to the new project folder. +It is recommended to create new projects also in <code>sw/example</code> to keep the file dependencies. However, these +dependencies can be manually configured via makefile variables if the new project is located somewhere else. +</td> +</tr> +</table> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +Before the makefile can be used to compile applications, the RISC-V GCC toolchain needs to be installed and +the compiler&#8217;s <code>bin</code> folder has to be added to the system&#8217;s <code>PATH</code> environment variable. More information can be +found in <a href="https://stnolting.github.io/neorv32/ug/#_software_toolchain_setup">User Guide: Software Toolchain Setup</a>. +</td> +</tr> +</table> +</div> +<div class="sect3"> +<h4 id="_makefile_targets">4.3.1. Makefile Targets</h4> +<div class="paragraph"> +<p>Just executing <code>make</code> (or executing <code>make help</code>) will show the help menu listing all available targets.</p> +</div> +<div class="listingblock"> +<div class="content"> +<pre class="highlight"><code class="language-makefile" data-lang="makefile">$ make +NEORV32 Software Application Makefile +Find more information at https://github.com/stnolting/neorv32 + +Targets: + help - show this text + check - check toolchain + info - show makefile/toolchain configuration + gdb - run GNU debugging session + asm - compile and generate &lt;main.asm&gt; assembly listing file for manual debugging + elf - compile and generate &lt;main.elf&gt; ELF file + exe - compile and generate &lt;neorv32_exe.bin&gt; executable image file for upload via default bootloader (binary file) + bin - compile and generate &lt;neorv32_raw_exe.bin&gt; RAW executable memory image (binary file) + hex - compile and generate &lt;neorv32_raw_exe.hex&gt; RAW executable memory image (hex char file) + coe - compile and generate &lt;neorv32_raw_exe.coe&gt; RAW executable memory image (COE file) + mem - compile and generate &lt;neorv32_raw_exe.mem&gt; RAW executable memory image (MEM file) + mif - compile and generate &lt;neorv32_raw_exe.mif&gt; RAW executable memory image (MIF file) + image - compile and generate VHDL IMEM boot image (for application, no header) in local folder + install - compile, generate and install VHDL IMEM boot image (for application, no header) + sim - in-console simulation using default/simple testbench and GHDL + all - exe + install + hex + bin + asm + elf_info - show ELF layout info + clean - clean up project home folder + clean_all - clean up whole project, core libraries and image generator + bl_image - compile and generate VHDL BOOTROM boot image (for bootloader only, no header) in local folder + bootloader - compile, generate and install VHDL BOOTROM boot image (for bootloader only, no header) + +Variables: + USER_FLAGS - Custom toolchain flags [append only]: "" + USER_LIBS - Custom libraries [append only]: "" + EFFORT - Optimization level: "-Os" + MARCH - Machine architecture: "rv32i_zicsr_zifencei" + MABI - Machine binary interface: "ilp32" + APP_INC - C include folder(s) [append only]: "-I ." + ASM_INC - ASM include folder(s) [append only]: "-I ." + RISCV_PREFIX - Toolchain prefix: "riscv32-unknown-elf-" + NEORV32_HOME - NEORV32 home folder: "../../.." + GDB_ARGS - GDB (connection) arguments: "-ex target extended-remote localhost:3333" + GHDL_RUN_FLAGS - GHDL simulation run arguments: ""</code></pre> +</div> +</div> +</div> +<div class="sect3"> +<h4 id="_makefile_configuration">4.3.2. Makefile Configuration</h4> +<div class="paragraph"> +<p>The compilation flow is configured via variables right at the beginning of the central +makefile (<code>sw/common/common.mk</code>):</p> +</div> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +<div class="title">Customizing Makefile Variables</div> +The makefile configuration variables can be overridden or extended directly when invoking the makefile. For +example <code>$ make MARCH=rv32ic_zicsr_zifencei clean_all exe</code> overrides the default <code>MARCH</code> variable definitions. +</td> +</tr> +</table> +</div> +<div class="listingblock"> +<div class="title">Listing 12. Default Makefile Configuration</div> +<div class="content"> +<pre class="highlight"><code class="language-makefile" data-lang="makefile"># ***************************************************************************** +# USER CONFIGURATION +# ***************************************************************************** +# User's application sources (*.c, *.cpp, *.s, *.S); add additional files here +APP_SRC ?= $(wildcard ./*.c) $(wildcard ./*.s) $(wildcard ./*.cpp) $(wildcard ./*.S) +# User's application include folders (don't forget the '-I' before each entry) +APP_INC ?= -I . +# User's application include folders - for assembly files only (don't forget the '-I' before each +entry) +ASM_INC ?= -I . +# Optimization +EFFORT ?= -Os +# Compiler toolchain +RISCV_PREFIX ?= riscv32-unknown-elf- +# CPU architecture and ABI +MARCH ?= rv32i_zicsr_zifencei +MABI ?= ilp32 +# User flags for additional configuration (will be added to compiler flags) +USER_FLAGS ?= +# User libraries (will be included by linker) +USER_LIBS ?= +# Language specific compiler flags: C +CFLAGS ?= +# C++ +CXXFLAGS ?= +# Assembly +ASFLAGS ?= +# Flags passed only to the linker +LDFLAGS ?= +# Relative or absolute path to the NEORV32 home folder +NEORV32_HOME ?= ../../.. +# GDB arguments +GDB_ARGS ?= -ex "target extended-remote localhost:3333" +# *****************************************************************************</code></pre> +</div> +</div> +<table class="tableblock frame-all grid-none stretch"> +<caption class="title">Table 75. Variables Description</caption> +<colgroup> +<col style="width: 20%;"> +<col style="width: 80%;"> +</colgroup> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>APP_SRC</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">The source files of the application (<code><strong>.c</code>, <code></strong>.cpp</code>, <code><strong>.S</code> and <code></strong>.s</code> files are allowed; files of these types in the project folder are automatically added via wild cards). Additional files can be added separated by white spaces</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>APP_INC</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Include file folders; separated by white spaces; must be defined with <code>-I</code> prefix</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>ASM_INC</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Include file folders that are used only for the assembly source files (<code><strong>.S</code>/<code></strong>.s</code>).</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>EFFORT</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Optimization level, optimize for size (<code>-Os</code>) is default; legal values: <code>-O0</code>, <code>-O1</code>, <code>-O2</code>, <code>-O3</code>, <code>-Os</code>, <code>-Ofast</code>, &#8230;&#8203;</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>RISCV_PREFIX</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">The toolchain prefix to be used; follows the triplet naming convention <code>[architecture]-[host_system]-[output]-&#8230;&#8203;</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>MARCH</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">The targeted RISC-V architecture/ISA</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>MABI</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Application binary interface (default: 32-bit integer ABI <code>ilp32</code>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>USER_FLAGS</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Additional flags that will be forwarded to the compiler tools</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>USER_LIBS</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Additional libraries to include during linking (<code>*.a</code>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>CFLAGS</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Additional flags that will be forwarded to the C compiler</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>CXXFLAGS</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Additional flags that will be forwarded to the C++ compiler</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>ASFLAGS</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Additional flags that will be forwarded to the assembler</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>LDFLAGS</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Additional flags that will be forwarded to the linker</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>NEORV32_HOME</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Relative or absolute path to the NEORV32 project home folder; adapt this if the makefile/project is not in the project&#8217;s default <code>sw/example</code> folder</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>GDB_ARGS</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Default GDB arguments when running the <code>gdb</code> target</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>GHDL_RUN_FLAGS</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">GHDL run arguments (e.g. <code>--stop-time=1ms</code>)</p></td> +</tr> +</tbody> +</table> +</div> +<div class="sect3"> +<h4 id="_default_compiler_flags">4.3.3. Default Compiler Flags</h4> +<div class="paragraph"> +<p>The following default compiler flags are used for compiling an application. These flags are defined via the +<code>CC_OPTS</code> variable.</p> +</div> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +The makefile&#8217;s <code>CC_OPTS</code> is exported as <strong>define</strong> to be available within a C program; for example +<code>neorv32_uart0_printf("%s\n", CC_OPTS);</code>. +</td> +</tr> +</table> +</div> +<table class="tableblock frame-all grid-none stretch"> +<colgroup> +<col style="width: 25%;"> +<col style="width: 75%;"> +</colgroup> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>-Wall</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Enable all compiler warnings.</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>-ffunction-sections</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Put functions and data segment in independent sections. This allows a code optimization as dead code and unused data can be easily removed.</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>-nostartfiles</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Do not use the default start code. Instead, the NEORV32-specific start-up code (<code>sw/common/crt0.S</code>) is used (pulled-in by the linker script).</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>-Wl,--gc-sections</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Make the linker perform dead code elimination.</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>-lm</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Include/link with <code>math.h</code>.</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>-lc</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Search for the standard C library when linking.</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>-lgcc</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Make sure we have no unresolved references to internal GCC library subroutines.</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>-mno-fdiv</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Use built-in software functions for floating-point divisions and square roots (since the according instructions are not supported yet).</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>-g</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Include debugging information/symbols in ELF.</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>-mstrict-align</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Unaligned memory accesses cannot be resolved by the hardware and require emulation.</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>-mbranch-cost=10</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Branching costs a lot of cycles.</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>-ffp-contract=off</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Do not allow contraction of floating-point operations (no fused operations as they are not supported).</p></td> +</tr> +</tbody> +</table> +</div> +<div class="sect3"> +<h4 id="_custom_compiler_flags">4.3.4. Custom (Compiler) Flags</h4> +<div class="paragraph"> +<p>Custom flags can be <em>appended</em> to the <code>USER_FLAGS</code> variable. This allows to customize the entire software framework while +calling <code>make</code> without the need to change the makefile(s) or the linker script. The following example will add debug symbols +to the executable (<code>-g</code>) and will also re-define the linker script&#8217;s <code>__neorv32_heap_size</code> variable setting the maximal heap +size to 4096 bytes (see sections <a href="#_linker_script">Linker Script</a> and <a href="#_ram_layout">RAM Layout</a>):</p> +</div> +<div class="listingblock"> +<div class="title">Listing 13. Using the <code>USER_FLAGS</code> Variable for Customization</div> +<div class="content"> +<pre class="highlight"><code class="language-bash" data-lang="bash">$ make USER_FLAGS+="-g -Wl,--__neorv32_heap_size,__heap_size=4096" clean_all exe</code></pre> +</div> +</div> +<div class="paragraph"> +<p>The configuration can also be made "permanent" by adapting the application&#8217;s makefile (make sure to use the +<code>override</code> command here):</p> +</div> +<div class="listingblock"> +<div class="title">Listing 14. Using the <code>USER_FLAGS</code> Variable for Permanent Customization</div> +<div class="content"> +<pre class="highlight"><code class="language-makefile" data-lang="makefile">override USER_FLAGS += "-g -Wl,--__neorv32_heap_size,__heap_size=4096"</code></pre> +</div> +</div> +<div style="page-break-after: always;"></div> +</div> +</div> +<div class="sect2"> +<h3 id="_executable_image_format">4.4. Executable Image Format</h3> +<div class="paragraph"> +<p>In order to generate an executable for the processors all source files have to be compiled, linked +and packed into a final executable. This executable can be further converted into several image formats.</p> +</div> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +<div class="title">Memory Image Formats</div> +The NEORV32 software framework includes an <a href="#_executable_image_generator">Executable Image Generator</a> than can convert an application +into several different file formats. These include raw hex files, a proprietary format for uploading via the +default <a href="#_bootloader">Bootloader</a> as well as several standard FPGA memory initialization file types (e.g. <code><strong>.coe</code>, +<code></strong>.mem</code> and <code>*.mif</code>). These image file formats are generated by the according <a href="#_makefile_targets">Makefile Targets</a>. +</td> +</tr> +</table> +</div> +<div class="sect3"> +<h4 id="_linker_script">4.4.1. Linker Script</h4> +<div class="paragraph"> +<p>After all the application sources have been compiled, they need to be <em>linked</em>. +For this purpose the makefile uses the NEORV32-specific linker script. This linker script defines several sections +for the final executable (compare with <a href="#_address_space">Address Space</a>). However, only the <code>ram</code> and <code>rom</code> sections are +relevant for the executable itself; the remaining sections are just listed for completeness.</p> +</div> +<table class="tableblock frame-all grid-rows stretch"> +<caption class="title">Table 76. Linker script - memory sections</caption> +<colgroup> +<col style="width: 20%;"> +<col style="width: 80%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-left valign-top">Memory section</th> +<th class="tableblock halign-left valign-top">Description</th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>ram</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Data memory address space (processor-internal <a href="#_data_memory_dmem">Data Memory (DMEM)</a> and/or external memory)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>rom</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Instruction memory address space (processor-internal <a href="#_instruction_memory_imem">Instruction Memory (IMEM)</a> and/or external memory)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>xip</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Address space for the <a href="#_execute_in_place_module_xip">Execute In Place Module (XIP)</a> (accessing an external SPI memory)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>boot</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Address space for the processor-internal <a href="#_bootloader_rom_bootrom">Bootloader ROM (BOOTROM)</a></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>io</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Address space for the processor-internal IO/peripheral devices</p></td> +</tr> +</tbody> +</table> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +The <code>rom</code> section is automatically re-mapped to the processor-internal <a href="#_bootloader_rom_bootrom">Bootloader ROM (BOOTROM)</a> when compiling the +bootloader sources. +</td> +</tr> +</table> +</div> +<div class="paragraph"> +<p>Each section has two main attributes: <code>ORIGIN</code> and <code>LENGTH</code>. <code>ORIGIN</code> defines the base address of the according section +while <code>LENGTH</code> defines its size in bytes. For the <code>ram</code> and <code>rom</code> sections these attributes are configured indirectly +via variables that provide default values.</p> +</div> +<div class="listingblock"> +<div class="title">Listing 15. Linker script - section configuration</div> +<div class="content"> +<pre class="highlight"><code>/* Default rom/ram (IMEM/DMEM) sizes */ +__neorv32_rom_size = DEFINED(__neorv32_rom_size) ? __neorv32_rom_size : 2048M; +__neorv32_ram_size = DEFINED(__neorv32_ram_size) ? __neorv32_ram_size : 8K; + +/* Default section base addresses */ +__neorv32_rom_base = DEFINED(__neorv32_rom_base) ? __neorv32_rom_base : 0x00000000; +__neorv32_ram_base = DEFINED(__neorv32_ram_base) ? __neorv32_ram_base : 0x80000000;</code></pre> +</div> +</div> +<div class="paragraph"> +<p>The region size and base address configuration can be edited by the user - either by explicitly +changing the default values in the linker script or by overriding them when invoking <code>make</code>:</p> +</div> +<div class="listingblock"> +<div class="title">Listing 16. Overriding default <code>rom</code> size configuration (configuring 4096 bytes)</div> +<div class="content"> +<pre class="highlight"><code class="language-bash" data-lang="bash">$ make USER_FLAGS+="-Wl,--defsym,__neorv32_rom_size=4096" clean_all exe</code></pre> +</div> +</div> +<div class="admonitionblock important"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-important" title="Important"></i> +</td> +<td class="content"> +<code><em>neorv32_rom_base</code> (= <code>ORIGIN</code> of the <code>rom</code> section) and <code></em>neorv32_ram_base</code> (= <code>ORIGIN</code> of the <code>ram</code> section) have to +be sync to the actual memory layout configuration of the processor (see section <a href="#_address_space">Address Space</a>). +</td> +</tr> +</table> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +The default configuration for the <code>rom</code> section assumes a maximum of 2GB <em>logical</em> memory address space. This size does not +have to reflect the <em>actual</em> physical size of the entire instruction memory. It just provides a maximum limit. When uploading +a new executable via the bootloader, the bootloader itself checks if sufficient <em>physical</em> instruction memory is available. +If a new executable is embedded right into the internal-IMEM the synthesis tool will check, if the configured instruction memory +size is sufficient. +</td> +</tr> +</table> +</div> +<div class="paragraph"> +<p>The linker maps all the regions from the compiled object files into five final sections: <code>.text</code>, +<code>.rodata</code>, <code>.data</code>, <code>.bss</code> and <code>.heap</code>:</p> +</div> +<table class="tableblock frame-all grid-rows stretch"> +<caption class="title">Table 77. Linker script - memory regions</caption> +<colgroup> +<col style="width: 10%;"> +<col style="width: 90%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-left valign-top">Region</th> +<th class="tableblock halign-left valign-top">Description</th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>.text</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Executable instructions generated from the start-up code and all application sources.</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>.rodata</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Constants (like strings) from the application; also the initial data for initialized variables.</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>.data</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">This section is required for the address generation of fixed (= global) variables only.</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>.bss</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">This section is required for the address generation of dynamic memory constructs only.</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>.heap</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">This section is required for the address generation of dynamic memory constructs only.</p></td> +</tr> +</tbody> +</table> +<div class="paragraph"> +<p>The <code>.text</code> and <code>.rodata</code> sections are mapped to processor&#8217;s instruction memory space and the <code>.data</code>, +<code>.bss</code> and <code>heap</code> sections are mapped to the processor&#8217;s data memory space. Finally, the <code>.text</code>, <code>.rodata</code> and <code>.data</code> +sections are extracted and concatenated into a single file <code>main.bin</code>.</p> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">Section Alignment</div> +The default NEORV32 linker script aligns <em>all</em> regions so they start and end on a 32-bit (word) boundaries. The default +NEORV32 start-up code (crt0) makes use of this alignment by using word-level memory instructions to initialize the <code>.data</code> +section and to clear the <code>.bss</code> section (faster!). +</td> +</tr> +</table> +</div> +</div> +<div class="sect3"> +<h4 id="_ram_layout">4.4.2. RAM Layout</h4> +<div class="paragraph"> +<p>The default NEORV32 linker script uses all of the defined RAM (linker script memory section <code>ram</code>) to several sections. +Note that depending on the application some sections might have zero size.</p> +</div> +<div class="imageblock"> +<div class="content"> +<img src="img/ram_layout.png" alt="400"> +</div> +<div class="title">Figure 15. Default RAM Layout</div> +</div> +<div class="olist arabic"> +<ol class="arabic" start="1"> +<li> +<p><strong>Constant data (<code>.data</code>)</strong>: The constant data section is placed right at the beginning of the RAM. For example, this section +contains <em>explicitly initialized</em> global variables. This section is initialized by the executable.</p> +</li> +<li> +<p><strong>Dynamic data (<code>.bss</code>)</strong>: The constant data section is followed by the dynamic data section, which contains <em>uninitialized</em> data +like global variables without explicit initialization. This section is cleared by the start-up code <code>crt0.S</code>.</p> +</li> +<li> +<p><strong>Heap (<code>.heap</code>)</strong>: The heap is used for dynamic memory that is managed by functions like <code>malloc()</code> and <code>free()</code>. The heap +grows upwards. This section is not initialized at all.</p> +</li> +<li> +<p><strong>Stack</strong>: The stack starts at the very end of the RAM at address <code>ORIGIN(ram) + LENGTH(ram) - 4</code>. The stack grows downwards.</p> +</li> +</ol> +</div> +<div class="paragraph"> +<p>There is <em>no explicit limit</em> for the maximum stack size as this is hard to check. However, a physical memory protection rule could +be used to configure a maximum size by adding a "protection area" between stack and heap (a PMP region without any access rights).</p> +</div> +<div class="admonitionblock important"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-important" title="Important"></i> +</td> +<td class="content"> +<div class="title">Heap Size</div> +The maximum size of the heap is defined by the linker script&#8217;s <code><em>neorv32_heap_size</code> variable. This variable has to be +<strong>explicitly defined</strong> in order to define a heap size (and to use dynamic memory allocation at all) other than zero. The user +can define the heap size while invoking the application makefile: <code>$ USER_FLAGS+="-Wl,--defsym,</em>neorv32_heap_size=4k" make clean_all exe</code> +(defines a heap size of 4*1024 bytes). +</td> +</tr> +</table> +</div> +<div class="admonitionblock warning"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-warning" title="Warning"></i> +</td> +<td class="content"> +<div class="title">Heap-Stack Collisions</div> +Take care when using dynamic memory to avoid collision of the heap and stack memory areas. There is no compile-time protection +mechanism available as the actual heap and stack size are defined by <em>runtime</em> data. Also beware of fragmentation when +using dynamic memory allocation. +</td> +</tr> +</table> +</div> +</div> +<div class="sect3"> +<h4 id="_c_standard_library">4.4.3. C Standard Library</h4> +<div class="paragraph"> +<p>The default software framework relies on <strong>newlib</strong> as default C standard library.</p> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">RTOS Support</div> +The NEORV32 CPU and processor <strong>do support</strong> embedded RTOS like FreeRTOS and Zephyr. See the User guide section +<a href="https://stnolting.github.io/neorv32/ug/#_zephyr_rtos_support">Zephyr RTOS Support</a> and +<a href="https://stnolting.github.io/neorv32/ug/#_freertos_support">FreeRTOS Support</a> +for more information.<br> +</td> +</tr> +</table> +</div> +<div class="paragraph"> +<p>+ +The FreeRTOS port and demo is available in a separate repository: <a href="https://github.com/stnolting/neorv32-freertos" class="bare">https://github.com/stnolting/neorv32-freertos</a></p> +</div> +<div class="paragraph"> +<p>Newlib provides stubs for common "system calls" (like file handling and standard input/output) that are used by other +C libraries like <code>stdio</code>. These stubs are available in <code>sw/source/source/syscalls.c</code> and were adapted for the NEORV32 processor.</p> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">Standard Consoles</div> +The <a href="#_primary_universal_asynchronous_receiver_and_transmitter_uart0">UART0</a> +is used to implement all the standard input, output and error consoles (<code>STDIN</code>, <code>STDOUT</code> and <code>STDERR</code>). +</td> +</tr> +</table> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">Constructors and Destructors</div> +Constructors and destructors for plain C code or for C++ applications are supported by the software framework. +See <code>sw/example/hello_cpp</code> for a minimal example. +</td> +</tr> +</table> +</div> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +<div class="title">Newlib Test/Demo Program</div> +A simple test and demo program, which uses some of newlib&#8217;s core functions (like <code>malloc</code>/<code>free</code> and <code>read</code>/<code>write</code>) +is available in <code>sw/example/demo_newlib</code> +</td> +</tr> +</table> +</div> +</div> +<div class="sect3"> +<h4 id="_executable_image_generator">4.4.4. Executable Image Generator</h4> +<div class="paragraph"> +<p>The <code>main.bin</code> file is packed by the NEORV32 image generator (<code>sw/image_gen</code>) to generate the final executable file. +The image generator can generate several types of executable file formats selected by a flag when calling the generator:</p> +</div> +<table class="tableblock frame-all grid-none stretch"> +<colgroup> +<col style="width: 20%;"> +<col style="width: 80%;"> +</colgroup> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>-app_bin</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Generates an executable binary file <code>neorv32_exe.bin</code> (including bootloader header) for uploading via the bootloader.</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>-app_img</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Generates an executable VHDL memory initialization image for the processor-internal IMEM. This option regenerates the <code>rtl/core/neorv32_application_image.vhd</code> file.</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>-bld_img</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Generates an executable VHDL memory initialization image for the processor-internal BOOT ROM. This option regenerates the <code>rtl/core/neorv32_bootloader_image.vhd</code> file.</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>-raw_hex</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Generates a raw 8x ASCII hex-char file <code>neorv32_raw_exe.hex</code> for custom purpose.</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>-raw_bin</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Generates a raw binary file <code>neorv32_raw_exe.bin</code> for custom purpose.</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>-raw_coe</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Generates a raw COE file <code>neorv32_raw_exe.coe</code> for FPGA memory initialization.</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>-raw_mem</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Generates a raw MEM file <code>neorv32_raw_exe.mem</code> for FPGA memory initialization.</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>-raw_mif</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Generates a raw MIF file <code>neorv32_raw_exe.mif</code> for FPGA memory initialization.</p></td> +</tr> +</tbody> +</table> +<div class="paragraph"> +<p><strong>All these options are managed by the makefile (see <a href="#_makefile_targets">Makefile Targets</a>).</strong></p> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">Image Generator Compilation</div> +The sources of the image generator are automatically compiled when invoking the makefile (requiring a <em>native</em> GCC installation). +</td> +</tr> +</table> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">Executable Header</div> +The image generator add a small header to the <code>neorv32_exe.bin</code> executable, which consists of three 32-bit words located right +at the beginning of the file. The first word of the executable is the signature word and is always <code>0x4788cafe</code>. Based on this +word the bootloader can identify a valid image file. The next word represents the size in bytes of the actual program image in +bytes. A simple "complement" checksum of the actual program image is given by the third word. This provides a simple protection +against data transmission or storage errors. <strong>Note that this executable format cannot be used for <em>direct</em> execution (e.g. via +XIP or direct memory access).</strong> +</td> +</tr> +</table> +</div> +</div> +<div class="sect3"> +<h4 id="_start_up_code_crt0">4.4.5. Start-Up Code (crt0)</h4> +<div class="paragraph"> +<p>The CPU and also the processor require a minimal start-up and initialization code to bring the CPU (and the SoC) +into a stable and initialized state and to initialize the C runtime environment before the actual application can be executed. +This start-up code is located in <code>sw/common/crt0.S</code> and is automatically linked <em>every</em> application program +and placed right before the actual application code so it gets executed right after reset.</p> +</div> +<div class="paragraph"> +<p>The <code>crt0.S</code> start-up performs the following operations:</p> +</div> +<div class="olist arabic"> +<ol class="arabic" start="1"> +<li> +<p>Clear <a href="#_mstatus"><strong><code>mstatus</code></strong></a>.</p> +</li> +<li> +<p>Clear <a href="#_mie"><strong><code>mie</code></strong></a> disabling all interrupt sources.</p> +</li> +<li> +<p>Install an <a href="#_early_trap_handler">Early Trap Handler</a> to <a href="#_mtvec"><strong><code>mtvec</code></strong></a>.</p> +</li> +<li> +<p>Initialize the global pointer <code>gp</code> and the stack pointer <code>sp</code> according to the <a href="#_ram_layout">RAM Layout</a> provided by the linker script.</p> +</li> +<li> +<p>Initialize all integer register <code>x1</code> - <code>x31</code> (only <code>x1</code> - <code>x15</code> if the <code>E</code> CPU extension is enabled).</p> +</li> +<li> +<p>Setup <code>.data</code> section to configure initialized variables.</p> +</li> +<li> +<p>Clear the <code>.bss</code> section.</p> +</li> +<li> +<p>Call all <em>constructors</em> (if there are any).</p> +</li> +<li> +<p>Call the application&#8217;s <code>main</code> function (with no arguments: <code>argc</code> = <code>argv</code> = 0).</p> +</li> +<li> +<p>If <code>main</code> returns:</p> +<div class="ulist"> +<ul> +<li> +<p>All interrupt sources are disabled by clearing <a href="#_mie"><strong><code>mie</code></strong></a>.</p> +</li> +<li> +<p>The return value of <code>main</code> is copied to the <a href="#_mscratch"><strong><code>mscratch</code></strong></a> CSR to allow inspection by the debugger.</p> +</li> +<li> +<p>Call all <em>destructors</em> (if there are any). If any destructor causes an exception the crt0&#8217;s trap handler is used for handling (= skipping) this.</p> +</li> +<li> +<p>The CPU enters sleep mode executing the <code>wfi</code> instruction in an endless loop.</p> +</li> +</ul> +</div> +</li> +</ol> +</div> +<div class="sect4"> +<h5 id="_early_trap_handler">Early Trap Handler</h5> +<div class="paragraph"> +<p>The start-up code provides a very basic trap handler for the early boot stage. This handler does nothing but trying to move +on to the next linear instruction whenever an interrupt or synchronous exception is encountered.</p> +</div> +<div class="paragraph"> +<p>This simple trap handler does not interact with the stack at all as it just uses a single register that is backup-ed +using the <a href="#_mscratch"><strong><code>mscratch</code></strong></a> CSR. Furthermore, the information if the trap-causing instruction is compressed or uncompressed +is <strong>not</strong> determined by loading the instruction from memory. Instead, the transformed instruction word is read from the +<a href="#_mtinst"><strong><code>mtinst</code></strong></a> CSRs. These two features allow the trap handler to execute with minimal latency and high robustness.</p> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +The early-trap handler should be replaced by a more capable / informative one as soon as the application software is started +(for example by using the <a href="#_neorv32_runtime_environment">NEORV32 Runtime Environment</a>). +</td> +</tr> +</table> +</div> +<div style="page-break-after: always;"></div> +</div> +</div> +</div> +<div class="sect2"> +<h3 id="_bootloader">4.5. Bootloader</h3> +<div class="admonitionblock important"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-important" title="Important"></i> +</td> +<td class="content"> +<div class="title">Pre-Built Bootloader Image</div> +This section refers to the <strong>default</strong> NEORV32 bootloader. A pre-compiled memory image for the processor-internal +<a href="#_bootloader_rom_bootrom">Bootloader ROM (BOOTROM)</a> is available in the project&#8217;s rtl folder: <code>rtl/core/neorv32_bootloader_image.vhd</code>. +This image is automatically inserted into the boot ROM when synthesizing the processor with the bootloader being +enabled. <strong>Note that the default bootloader image was compiled for a minimal <code>rv32i</code> + priv. ISA!</strong> +</td> +</tr> +</table> +</div> +<div class="paragraph"> +<p>The NEORV32 bootloader (<code>sw/bootloader/bootloader.c</code>) provides an optional built-in firmware that +allows to upload new application executables at <em>any time</em> without the need to re-synthesize the FPGA&#8217;s bitstream. +A UART connection is used to provide a simple text-based user interface that allows to upload executables.</p> +</div> +<div class="paragraph"> +<p>Furthermore, the bootloader provides options to store an executable to a processor-external SPI flash. +An "auto boot" feature can optionally fetch this executable right after reset if there is no user interaction +via UART. This allows to build processor setups with <em>non-volatile application storage</em> while maintaining the option +to update the application software at any timer.</p> +</div> +<div class="sect3"> +<h4 id="_bootloader_soccpu_requirements">4.5.1. Bootloader SoC/CPU Requirements</h4> +<div class="paragraph"> +<p>The bootloader requires certain CPU and SoC extensions and modules to be enabled in order to operate correctly.</p> +</div> +<table class="tableblock frame-all grid-none stretch"> +<colgroup> +<col style="width: 20%;"> +<col style="width: 80%;"> +</colgroup> +<tbody> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><strong>REQUIRED</strong></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">The bootloader is implemented only if the <code>INT_BOOTLOADER_EN</code> top generic is <code>true</code>. This will automatically select the CPU&#8217;s <a href="#_indirect_boot">Indirect Boot</a> boot configuration.</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><strong>REQUIRED</strong></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">The bootloader requires the privileged architecture CPU extension (<a href="#_zicsr_isa_extension"><code>Zicsr</code> ISA Extension</a>) to be enabled.</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><strong>REQUIRED</strong></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">At least 512 bytes of data memory (processor-internal DMEM or processor-external DMEM) are required for the bootloader&#8217;s stack and global variables.</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><em>RECOMMENDED</em></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">For user interaction via the <a href="#_bootloader_console">Bootloader Console</a> (like uploading executables) the primary UART (<a href="#_primary_universal_asynchronous_receiver_and_transmitter_uart0">Primary Universal Asynchronous Receiver and Transmitter (UART0)</a>) is required.</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><em>RECOMMENDED</em></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">The default bootloader uses bit 0 of the <a href="#_general_purpose_input_and_output_port_gpio">General Purpose Input and Output Port (GPIO)</a> output port to drive a high-active "heart beat" status LED.</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><em>RECOMMENDED</em></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">The <a href="#_machine_system_timer_mtime">Machine System Timer (MTIME)</a> is used to control blinking of the status LED and also to automatically trigger the <a href="#_auto_boot_sequence">Auto Boot Sequence</a>.</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">OPTIONAL</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">The SPI controller (<a href="#_serial_peripheral_interface_controller_spi">Serial Peripheral Interface Controller (SPI)</a>) is needed to store/load executable from external flash using the <a href="#_auto_boot_sequence">Auto Boot Sequence</a>.</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">OPTIONAL</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">The XIP controller (<a href="#_execute_in_place_module_xip">Execute In Place Module (XIP)</a>) is needed to boot/execute code directly from a pre-programmed SPI flash.</p></td> +</tr> +</tbody> +</table> +</div> +<div class="sect3"> +<h4 id="_bootloader_flash_requirements">4.5.2. Bootloader Flash Requirements</h4> +<div class="paragraph"> +<p>The bootloader can access an SPI-compatible flash via the processor&#8217;s top entity SPI port. By default, the flash +chip-select line is driven by <code>spi_csn_o(0)</code> and the SPI clock uses 1/8 of the processor&#8217;s main clock as clock frequency. +The SPI flash has to support single-byte read and write operations, 24-bit addresses and at least the following standard commands:</p> +</div> +<div class="ulist"> +<ul> +<li> +<p><code>0x02</code>: Program page (write byte)</p> +</li> +<li> +<p><code>0x03</code>: Read data (byte)</p> +</li> +<li> +<p><code>0x04</code>: Write disable (for volatile status register)</p> +</li> +<li> +<p><code>0x05</code>: Read (first) status register</p> +</li> +<li> +<p><code>0x06</code>: Write enable (for volatile status register)</p> +</li> +<li> +<p><code>0xAB</code>: Wake-up from sleep mode (optional)</p> +</li> +<li> +<p><code>0xD8</code>: Block erase (64kB)</p> +</li> +</ul> +</div> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +<div class="title">Custom Configuration</div> +Most properties (like chip select line, flash address width, SPI clock frequency, &#8230;&#8203;) of the default bootloader can be reconfigured +without the need to change the source code. Custom configuration can be made using command line switches (defines) when recompiling +the bootloader. See the User Guide <a href="https://stnolting.github.io/neorv32/ug/#_customizing_the_internal_bootloader" class="bare">https://stnolting.github.io/neorv32/ug/#_customizing_the_internal_bootloader</a> for more information. +</td> +</tr> +</table> +</div> +</div> +<div class="sect3"> +<h4 id="_bootloader_console">4.5.3. Bootloader Console</h4> +<div class="paragraph"> +<p>To interact with the bootloader, connect the primary UART (UART0) signals (<code>uart0_txd_o</code> and <code>uart0_rxd_o</code>) of the processor&#8217;s top +entity via a serial port (-adapter) to your computer (hardware flow control is not used so the according interface signals can be +ignored), configure your terminal program using the following settings and perform a reset of the processor.</p> +</div> +<div class="paragraph"> +<p>Terminal console settings (<code>19200-8-N-1</code>):</p> +</div> +<div class="ulist"> +<ul> +<li> +<p>19200 Baud</p> +</li> +<li> +<p>8 data bits</p> +</li> +<li> +<p>no parity bit</p> +</li> +<li> +<p>1 stop bit</p> +</li> +<li> +<p>newline on <code>\r\n</code> (carriage return, newline)</p> +</li> +<li> +<p>no transfer protocol / control flow protocol - just raw bytes</p> +</li> +</ul> +</div> +<div class="admonitionblock important"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-important" title="Important"></i> +</td> +<td class="content"> +<div class="title">Terminal Program</div> +Any terminal program that can connect to a serial port should work. However, make sure the program +can transfer data in <em>raw</em> byte mode without any protocol overhead (e.g. XMODEM). Some terminal programs struggle with +transmitting files larger than 4kB (see <a href="https://github.com/stnolting/neorv32/pull/215" class="bare">https://github.com/stnolting/neorv32/pull/215</a>). Try a different terminal program +if uploading of a binary does not work. +</td> +</tr> +</table> +</div> +<div class="paragraph"> +<p>The bootloader uses the LSB of the top entity&#8217;s <code>gpio_o</code> output port as high-active status LED. All other +output pins are set to low level and won&#8217;t be altered. After reset, the status LED will start blinking at 2Hz and the +following intro screen shows up:</p> +</div> +<div class="listingblock"> +<div class="content"> +<pre class="highlight"><code>&lt;&lt; NEORV32 Bootloader &gt;&gt; + +BLDV: Mar 7 2023 +HWV: 0x01080107 +CLK: 0x05f5e100 +MISA: 0x40901106 +XISA: 0xc0000fab +SOC: 0xffff402f +IMEM: 0x00008000 +DMEM: 0x00002000 + +Autoboot in 10s. Press any key to abort.</code></pre> +</div> +</div> +<div class="paragraph"> +<p>The start-up screen gives some brief information about the bootloader and several system configuration parameters:</p> +</div> +<table class="tableblock frame-all grid-none stretch"> +<colgroup> +<col style="width: 11.7647%;"> +<col style="width: 88.2353%;"> +</colgroup> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>BLDV</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Bootloader version (built date).</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>HWV</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Processor hardware version (the <a href="#_mimpid"><strong><code>mimpid</code></strong></a> CSR); in BCD format; example: <code>0x01040606</code> = v1.4.6.6).</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>CLK</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Processor clock speed in Hz (via the <code>CLK</code> register from the <a href="#_system_configuration_information_memory_sysinfo">System Configuration Information Memory (SYSINFO)</a>.</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>MISA</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">RISC-V CPU extensions (<a href="#_misa"><strong><code>misa</code></strong></a> CSR).</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>XISA</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">NEORV32-specific CPU extensions (<a href="#_mxisa"><strong><code>mxisa</code></strong></a> CSR).</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>SOC</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Processor configuration (via the <code>SOC</code> register from the <a href="#_system_configuration_information_memory_sysinfo">System Configuration Information Memory (SYSINFO)</a>.</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>IMEM</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Internal IMEM size in byte (via the <code>MEM</code> register from the <a href="#_system_configuration_information_memory_sysinfo">System Configuration Information Memory (SYSINFO)</a>.</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>DMEM</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Internal DMEM size in byte (via the <code>MEM</code> register from the <a href="#_system_configuration_information_memory_sysinfo">System Configuration Information Memory (SYSINFO)</a>.</p></td> +</tr> +</tbody> +</table> +<div class="paragraph"> +<p>Now you have 10 seconds to press <em>any</em> key. Otherwise, the bootloader starts the <a href="#_auto_boot_sequence">Auto Boot Sequence</a>. When +you press any key within the 10 seconds, the actual bootloader user console starts:</p> +</div> +<div class="listingblock"> +<div class="content"> +<pre class="highlight"><code>&lt;&lt; NEORV32 Bootloader &gt;&gt; + +BLDV: Mar 7 2023 +HWV: 0x01080107 +CLK: 0x05f5e100 +MISA: 0x40901106 +XISA: 0xc0000fab +SOC: 0xffff402f +IMEM: 0x00008000 +DMEM: 0x00002000 + +Autoboot in 10s. Press any key to abort. <i class="conum" data-value="1"></i><b>(1)</b> +Aborted. + +Available CMDs: + h: Help + r: Restart + u: Upload + s: Store to flash + l: Load from flash + x: Boot from flash (XIP) + e: Execute +CMD:&gt;</code></pre> +</div> +</div> +<div class="colist arabic"> +<table> +<tr> +<td><i class="conum" data-value="1"></i><b>1</b></td> +<td>Auto boot sequence aborted due to user console input.</td> +</tr> +</table> +</div> +<div class="paragraph"> +<p>The auto boot countdown is stopped and the bootloader&#8217;s user console is ready to receive one of the following commands:</p> +</div> +<div class="ulist"> +<ul> +<li> +<p><code>h</code>: Show the help text (again)</p> +</li> +<li> +<p><code>r</code>: Restart the bootloader and the auto-boot sequence</p> +</li> +<li> +<p><code>u</code>: Upload new program executable (<code>neorv32_exe.bin</code>) via UART into the instruction memory</p> +</li> +<li> +<p><code>s</code>: Store executable to SPI flash at <code>spi_csn_o(0)</code> (little-endian byte order)</p> +</li> +<li> +<p><code>l</code>: Load executable from SPI flash at <code>spi_csn_o(0)</code> (little-endian byte order)</p> +</li> +<li> +<p><code>x</code>: Boot program directly from flash via XIP (requires a pre-programmed image)</p> +</li> +<li> +<p><code>e</code>: Start the application, which is currently stored in the instruction memory (IMEM)</p> +</li> +</ul> +</div> +<div class="paragraph"> +<p>A new executable can be uploaded via UART by executing the <code>u</code> command. After that, the executable can be directly +executed via the <code>e</code> command. To store the recently uploaded executable to an attached SPI flash press <code>s</code>. To +directly load an executable from the SPI flash press <code>l</code>. The bootloader and the auto-boot sequence can be +manually restarted via the <code>r</code> command.</p> +</div> +<div class="admonitionblock important"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-important" title="Important"></i> +</td> +<td class="content"> +<div class="title">Executable Upload</div> +Make sure to upload the NEORV32 executable <code>neorv32_exe.bin</code>. Uploading any other file (like <code>main.bin</code>) +will cause an <code>ERR_EXE</code> bootloader error (see <a href="#_bootloader_error_codes">Bootloader Error Codes</a>). +</td> +</tr> +</table> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">Booting via XIP</div> +The bootloader allows to execute an application right from flash using the <a href="#_execute_in_place_module_xip">Execute In Place Module (XIP)</a> module. +This requires a pre-programmed flash. The bootloader&#8217;s "store" option can <strong>not</strong> be used to program an XIP image. +</td> +</tr> +</table> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">SPI Flash Power Down Mode</div> +The bootloader will issue a "wake-up" command prior to using the SPI flash to ensure it is not +in sleep mode / power-down mode (see <a href="https://github.com/stnolting/neorv32/pull/552" class="bare">https://github.com/stnolting/neorv32/pull/552</a>). +</td> +</tr> +</table> +</div> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +<div class="title">Default Configuration</div> +More information regarding the default SPI, GPIO, XIP, etc. configuration can be found in the User Guide +section <a href="https://stnolting.github.io/neorv32/ug/#_customizing_the_internal_bootloader" class="bare">https://stnolting.github.io/neorv32/ug/#_customizing_the_internal_bootloader</a>. +</td> +</tr> +</table> +</div> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +<div class="title">SPI Flash Programming</div> +For detailed information on using an SPI flash for application storage see User Guide section +<a href="https://stnolting.github.io/neorv32/ug/#_programming_an_external_spi_flash_via_the_bootloader">Programming an External SPI Flash via the Bootloader</a>. +</td> +</tr> +</table> +</div> +</div> +<div class="sect3"> +<h4 id="_auto_boot_sequence">4.5.4. Auto Boot Sequence</h4> +<div class="paragraph"> +<p>When you reset the NEORV32 processor, the bootloader waits 8 seconds for a UART console input before it +starts the automatic boot sequence. This sequence tries to fetch a valid boot image from the external SPI +flash, connected to SPI chip select <code>spi_csn_o(0)</code>. If a valid boot image is found that can be successfully +transferred into the instruction memory, it is automatically started. If no SPI flash is detected or if there +is no valid boot image found, and error code will be shown.</p> +</div> +</div> +<div class="sect3"> +<h4 id="_bootloader_error_codes">4.5.5. Bootloader Error Codes</h4> +<div class="paragraph"> +<p>If something goes wrong during bootloader operation an error code and a short message is shown. In this case the processor +is halted, the bootloader status LED is permanently activated and the processor has to be reset manually.</p> +</div> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +In many cases the error source is just <em>temporary</em> (like some HF spike during an UART upload). Just try again. +</td> +</tr> +</table> +</div> +<table class="tableblock frame-all grid-rows stretch"> +<colgroup> +<col style="width: 20%;"> +<col style="width: 80%;"> +</colgroup> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><strong><code>ERR_EXE</code></strong></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">If you try to transfer an invalid executable (via UART or from the external SPI flash), this error message shows up. There might be a transfer protocol configuration error in the terminal program or maybe just the wrong file was selected. Also, if no SPI flash was found during an auto-boot attempt, this message will be displayed.</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><strong><code>ERR_SIZE</code></strong></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Your program is way too big for the internal processor’s instructions memory. Increase the memory size or reduce your application code.</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><strong><code>ERR_CHKS</code></strong></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">This indicates a checksum error. Something went wrong during the transfer of the program image (upload via UART or loading from the external SPI flash). If the error was caused by a UART upload, just try it again. When the error was generated during a flash access, the stored image might be corrupted.</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><strong><code>ERR_FLSH</code></strong></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">This error occurs if the attached SPI flash cannot be accessed. Make sure you have the right type of flash and that it is properly connected to the NEORV32 SPI port using chip select #0.</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><strong><code>ERR_EXC</code></strong></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">The bootloader encountered an unexpected exception during operation. This might be caused when it tries to access peripherals that were not implemented during synthesis. Example: executing commands <code>l</code> or <code>s</code> (SPI flash operations) without the SPI module being implemented.</p></td> +</tr> +</tbody> +</table> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +If an unexpected exception has been raised the bootloader prints hexadecimal debug information showing +the <a href="#_mcause"><strong><code>mcause</code></strong></a>, <a href="#_mepc"><strong><code>mepc</code></strong></a> and <a href="#_mtval"><strong><code>mtval</code></strong></a> CSR values. +</td> +</tr> +</table> +</div> +<div style="page-break-after: always;"></div> +</div> +</div> +<div class="sect2"> +<h3 id="_neorv32_runtime_environment">4.6. NEORV32 Runtime Environment</h3> +<div class="paragraph"> +<p>The NEORV32 software framework provides a minimal <strong>runtime environment</strong> (abbreviated "RTE") that takes care of a stable +and <em>safe</em> execution environment by handling <em>all</em> traps (exceptions &amp; interrupts). The RTE simplifies trap handling +by wrapping the CPU&#8217;s privileged architecture (i.e. trap-related CSRs) into a unified software API.</p> +</div> +<div class="paragraph"> +<p>Once initialized, the RTE provides <a href="#_default_rte_trap_handlers">Default RTE Trap Handlers</a> that catch all possible traps. These +default handlers just output a message via UART to inform the user when a certain trap has been triggered. The +default handlers can be overridden by the application code to install application-specific handler functions for each trap.</p> +</div> +<div class="admonitionblock important"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-important" title="Important"></i> +</td> +<td class="content"> +Using the RTE is <strong>optional but highly recommended</strong>. The RTE provides a simple and comfortable way of delegating +traps to application-specific handlers while making sure that all traps (even though they are not explicitly used +by the application) are handled correctly. Performance-optimized applications or embedded operating systems may +not use the RTE at all in order to increase response time. +</td> +</tr> +</table> +</div> +<div class="sect3"> +<h4 id="_rte_operation">4.6.1. RTE Operation</h4> +<div class="paragraph"> +<p>The RTE manages the trap-related CSRs of the CPU&#8217;s privileged architecture (<a href="#_machine_trap_handling_csrs">Machine Trap Handling CSRs</a>). +It initializes the <a href="#_mtvec"><strong><code>mtvec</code></strong></a> CSR in DIRECT mode, which then provides the base entry point for <em>all</em> traps. The address +stored to this register defines the address of the <strong>first-level trap handler</strong>, which is provided by the +NEORV32 RTE. Whenever an exception or interrupt is triggered this first-level trap handler is executed.</p> +</div> +<div class="paragraph"> +<p>The first-level handler performs a complete context save, analyzes the source of the trap and +calls the according <strong>second-level trap handler</strong>, which takes care of the actual exception/interrupt +handling. The RTE manages a private look-up table to store the addresses of the according second-level trap handlers.</p> +</div> +<div class="paragraph"> +<p>After the initial RTE setup, each entry in the RTE&#8217;s trap handler look-up table is initialized with a +<a href="#_default_rte_trap_handlers">Default RTE Trap Handlers</a>. These default handler do not execute any trap-related operations - they +just output a message via the <strong>primary UART (UART0)</strong> to inform the user that a trap has occurred, which is not (yet) +handled by the actual application. After sending this message, the RTE tries to continue executing the actual program +by resolving the trap cause.</p> +</div> +</div> +<div class="sect3"> +<h4 id="_using_the_rte">4.6.2. Using the RTE</h4> +<div class="admonitionblock important"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-important" title="Important"></i> +</td> +<td class="content"> +All provided RTE functions can be called only from machine-mode code. +</td> +</tr> +</table> +</div> +<div class="paragraph"> +<p>The NEORV32 is part of the default NEORV32 software framework. However, it has to explicitly enabled by calling +the RTE&#8217;s setup function:</p> +</div> +<div class="listingblock"> +<div class="title">Listing 17. RTE Setup (Function Prototype)</div> +<div class="content"> +<pre class="highlight"><code class="language-c" data-lang="c">void neorv32_rte_setup(void);</code></pre> +</div> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +The RTE should be enabled right at the beginning of the application&#8217;s <code>main</code> function. +</td> +</tr> +</table> +</div> +<div class="admonitionblock important"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-important" title="Important"></i> +</td> +<td class="content"> +It is recommended to not use the <a href="#_mscratch"><strong><code>mscratch</code></strong></a> CSR when using the RTE as this register is used to provide services +for <a href="#_application_context_handling">Application Context Handling</a> (i.e. modifying the registers of application code that caused a trap). +</td> +</tr> +</table> +</div> +<div class="paragraph"> +<p>As mentioned above, all traps will just trigger execution of the RTE&#8217;s <a href="#_default_rte_trap_handlers">Default RTE Trap Handlers</a> at first. +To use application-specific handlers, which actually "handle" a trap, the default handlers can be overridden +by installing user-defined ones:</p> +</div> +<div class="listingblock"> +<div class="title">Listing 18. Installing an Application-Specific Trap Handler (Function Prototype)</div> +<div class="content"> +<pre class="highlight"><code class="language-c" data-lang="c">int neorv32_rte_handler_install(uint8_t id, void (*handler)(void));</code></pre> +</div> +</div> +<div class="paragraph"> +<p>The first argument <code>id</code> defines the "trap ID" (for example a certain interrupt request) that shall be handled +by the user-defined handler. These IDs are defined in <code>sw/lib/include/neorv32_rte.h</code>:</p> +</div> +<div class="listingblock"> +<div class="title">Listing 19. RTE Trap Identifiers (cut-out)</div> +<div class="content"> +<pre class="highlight"><code class="language-c" data-lang="c">enum NEORV32_RTE_TRAP_enum { + RTE_TRAP_I_MISALIGNED = 0, /**&lt; Instruction address misaligned */ + RTE_TRAP_I_ACCESS = 1, /**&lt; Instruction (bus) access fault */ + RTE_TRAP_I_ILLEGAL = 2, /**&lt; Illegal instruction */ + RTE_TRAP_BREAKPOINT = 3, /**&lt; Breakpoint (EBREAK instruction) */ + RTE_TRAP_L_MISALIGNED = 4, /**&lt; Load address misaligned */ + RTE_TRAP_L_ACCESS = 5, /**&lt; Load (bus) access fault */ + RTE_TRAP_S_MISALIGNED = 6, /**&lt; Store address misaligned */ + RTE_TRAP_S_ACCESS = 7, /**&lt; Store (bus) access fault */ + RTE_TRAP_UENV_CALL = 8, /**&lt; Environment call from user mode (ECALL instruction) */ + RTE_TRAP_MENV_CALL = 9, /**&lt; Environment call from machine mode (ECALL instruction) */ + RTE_TRAP_MSI = 10, /**&lt; Machine software interrupt */ + RTE_TRAP_MTI = 11, /**&lt; Machine timer interrupt */ + RTE_TRAP_MEI = 12, /**&lt; Machine external interrupt */ + RTE_TRAP_FIRQ_0 = 13, /**&lt; Fast interrupt channel 0 */ + RTE_TRAP_FIRQ_1 = 14, /**&lt; Fast interrupt channel 1 */ + RTE_TRAP_FIRQ_2 = 15, /**&lt; Fast interrupt channel 2 */ + RTE_TRAP_FIRQ_3 = 16, /**&lt; Fast interrupt channel 3 */ + RTE_TRAP_FIRQ_4 = 17, /**&lt; Fast interrupt channel 4 */ + RTE_TRAP_FIRQ_5 = 18, /**&lt; Fast interrupt channel 5 */ + RTE_TRAP_FIRQ_6 = 19, /**&lt; Fast interrupt channel 6 */ + RTE_TRAP_FIRQ_7 = 20, /**&lt; Fast interrupt channel 7 */ + RTE_TRAP_FIRQ_8 = 21, /**&lt; Fast interrupt channel 8 */ + RTE_TRAP_FIRQ_9 = 22, /**&lt; Fast interrupt channel 9 */ + RTE_TRAP_FIRQ_10 = 23, /**&lt; Fast interrupt channel 10 */ + RTE_TRAP_FIRQ_11 = 24, /**&lt; Fast interrupt channel 11 */ + RTE_TRAP_FIRQ_12 = 25, /**&lt; Fast interrupt channel 12 */ + RTE_TRAP_FIRQ_13 = 26, /**&lt; Fast interrupt channel 13 */ + RTE_TRAP_FIRQ_14 = 27, /**&lt; Fast interrupt channel 14 */ + RTE_TRAP_FIRQ_15 = 28 /**&lt; Fast interrupt channel 15 */</code></pre> +</div> +</div> +<div class="paragraph"> +<p>The second argument <code>*handler</code> is the actual function that implements the user-defined trap handler. +The custom handler functions need to have a specific format without any arguments and with no return value:</p> +</div> +<div class="listingblock"> +<div class="title">Listing 20. Custom Trap Handler (Function Prototype)</div> +<div class="content"> +<pre class="highlight"><code class="language-c" data-lang="c">void custom_trap_handler_xyz(void) { + + // handle trap... +}</code></pre> +</div> +</div> +<div class="admonitionblock warning"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-warning" title="Warning"></i> +</td> +<td class="content"> +<div class="title">Custom Trap Handler Attributes</div> +Do <strong>NOT</strong> use the <code>interrupt</code> attribute for the application trap handler functions! This +will place a <code>mret</code> instruction to the end of it making it impossible to return to the first-level +trap handler of the RTE core, which will cause stack corruption. +</td> +</tr> +</table> +</div> +<div class="paragraph"> +<p>The following example shows how to install a custom handler (<code>custom_mtime_irq_handler</code>) for handling +the RISC-V machine timer (MTIME) interrupt:</p> +</div> +<div class="listingblock"> +<div class="title">Listing 21. Installing a MTIME IRQ Handler</div> +<div class="content"> +<pre class="highlight"><code class="language-c" data-lang="c">neorv32_rte_handler_install(RTE_TRAP_MTI, custom_mtime_irq_handler);</code></pre> +</div> +</div> +<div class="paragraph"> +<p>User-defined trap handlers can also be un-installed. This will remove the users trap handler from the RTE core +and will re-install the <a href="#_default_rte_trap_handlers">Default RTE Trap Handlers</a> for the specific trap.</p> +</div> +<div class="listingblock"> +<div class="title">Listing 22. Function Prototype: Installing an Application-Specific Trap Handler</div> +<div class="content"> +<pre class="highlight"><code class="language-c" data-lang="c">int neorv32_rte_handler_uninstall(uint8_t id);</code></pre> +</div> +</div> +<div class="paragraph"> +<p>The argument <code>id</code> defines the identifier of the according trap that shall be un-installed. +The following example shows how to un-install the custom handler <code>custom_mtime_irq_handler</code> from the +RISC-V machine timer (MTIME) interrupt:</p> +</div> +<div class="listingblock"> +<div class="title">Listing 23. Example: Removing the Custom MTIME IRQ Handler</div> +<div class="content"> +<pre class="highlight"><code class="language-c" data-lang="c">neorv32_rte_handler_uninstall(RTE_TRAP_MTI);</code></pre> +</div> +</div> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +The current RTE configuration can be printed via UART0 via the <code>neorv32_rte_info</code> function. +</td> +</tr> +</table> +</div> +</div> +<div class="sect3"> +<h4 id="_default_rte_trap_handlers">4.6.3. Default RTE Trap Handlers</h4> +<div class="paragraph"> +<p>The default RTE trap handlers are executed when a certain trap is triggered that is not (yet) handled by an +application-defined trap handler. The default handler will output a message giving additional debug information +via the <a href="#_primary_universal_asynchronous_receiver_and_transmitter_uart0">Primary Universal Asynchronous Receiver and Transmitter (UART0)</a> to inform the user and it will also +try to resume normal program execution. Some exemplary RTE outputs are shown below.</p> +</div> +<div class="admonitionblock warning"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-warning" title="Warning"></i> +</td> +<td class="content"> +<div class="title">Continuing Execution</div> +In most cases the RTE can successfully continue operation - for example if it catches an <strong>interrupt</strong> request +that is not handled by the actual application program. However, if the RTE catches an un-handled <strong>trap</strong> like +a bus access fault exception continuing execution will most likely fail making the CPU crash. Some exceptions +cannot be resolved by the default debug trap handlers and will halt the CPU (see example below). +</td> +</tr> +</table> +</div> +<div class="listingblock"> +<div class="title">Listing 24. RTE Default Trap Handler Output Examples</div> +<div class="content"> +<pre class="highlight"><code>&lt;NEORV32-RTE&gt; [M] Illegal instruction @ PC=0x000002d6, MTINST=0x000000FF, MTVAL=0x00000000 &lt;/NEORV32-RTE&gt; <i class="conum" data-value="1"></i><b>(1)</b> +&lt;NEORV32-RTE&gt; [U] Illegal instruction @ PC=0x00000302, MTINST=0x00000000, MTVAL=0x00000000 &lt;/NEORV32-RTE&gt; <i class="conum" data-value="2"></i><b>(2)</b> +&lt;NEORV32-RTE&gt; [U] Load address misaligned @ PC=0x00000440, MTINST=0x01052603, MTVAL=0x80000101 &lt;/NEORV32-RTE&gt; <i class="conum" data-value="3"></i><b>(3)</b> +&lt;NEORV32-RTE&gt; [M] Fast IRQ 0x00000003 @ PC=0x00000820, MTINST=0x00000000, MTVAL=0x00000000 &lt;/NEORV32-RTE&gt; <i class="conum" data-value="4"></i><b>(4)</b> +&lt;NEORV32-RTE&gt; [M] Instruction access fault @ PC=0x90000000, MTINST=0x42078b63, MTVAL=0x00000000 !!FATAL EXCEPTION!! Halting CPU. &lt;/NEORV32-RTE&gt;\n <i class="conum" data-value="5"></i><b>(5)</b></code></pre> +</div> +</div> +<div class="colist arabic"> +<table> +<tr> +<td><i class="conum" data-value="1"></i><b>1</b></td> +<td>Illegal 32-bit instruction <code>MTINST=0x000000FF</code> at address <code>PC=0x000002d6</code> while the CPU was in machine-mode (<code>[M]</code>).</td> +</tr> +<tr> +<td><i class="conum" data-value="2"></i><b>2</b></td> +<td>Illegal 16-bit instruction <code>MTINST=0x00000000</code> at address <code>PC=0x00000302</code> while the CPU was in user-mode (<code>[U]</code>).</td> +</tr> +<tr> +<td><i class="conum" data-value="3"></i><b>3</b></td> +<td>Misaligned load access at address <code>PC=0x00000440</code> caused by instruction <code>MTINST=0x01052603</code> (trying to load a full 32-bit word from address <code>MTVAL=0x80000101</code>) while the CPU was in machine-mode (<code>[U]</code>).</td> +</tr> +<tr> +<td><i class="conum" data-value="4"></i><b>4</b></td> +<td>Fast interrupt request from channel 3 before executing instruction at address <code>PC=0x00000820</code> while the CPU was in machine-mode (<code>[M]</code>).</td> +</tr> +<tr> +<td><i class="conum" data-value="5"></i><b>5</b></td> +<td>Instruction bus access fault at address <code>PC=0x90000000</code> while executing instruction <code>MTINST=0x42078b63</code> - this is fatal for the default debug trap handler while the CPU was in machine-mode (<code>[M]</code>).</td> +</tr> +</table> +</div> +<div class="paragraph"> +<p>The specific message right at the beginning of the debug trap handler message corresponds to the trap code +obtained from the <a href="#_mcause"><strong><code>mcause</code></strong></a> CSR (see <a href="#_neorv32_trap_listing">NEORV32 Trap Listing</a>). A full list of all messages and the according +<code>mcause</code> trap codes is shown below.</p> +</div> +<table class="tableblock frame-all grid-rows stretch"> +<caption class="title">Table 78. RTE Default Trap Handler Messages and According <code>mcause</code> Values</caption> +<colgroup> +<col style="width: 50%;"> +<col style="width: 50%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-left valign-top">Trap identifier</th> +<th class="tableblock halign-center valign-top">According <code>mcause</code> CSR value</th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">"Instruction address misaligned"</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>0x00000000</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">"Instruction access fault"</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>0x00000001</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">"Illegal instruction"</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>0x00000002</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">"Breakpoint"</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>0x00000003</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">"Load address misaligned"</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>0x00000004</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">"Load access fault"</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>0x00000005</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">"Store address misaligned"</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>0x00000006</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">"Store access fault"</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>0x00000007</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">"Environment call from U-mode"</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>0x00000008</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">"Environment call from M-mode"</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>0x0000000b</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">"Machine software IRQ"</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>0x80000003</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">"Machine timer IRQ"</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>0x80000007</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">"Machine external IRQ"</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>0x8000000b</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">"Fast IRQ 0x00000000"</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>0x80000010</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">"Fast IRQ 0x00000001"</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>0x80000011</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">"Fast IRQ 0x00000002"</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>0x80000012</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">"Fast IRQ 0x00000003"</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>0x80000013</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">"Fast IRQ 0x00000004"</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>0x80000014</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">"Fast IRQ 0x00000005"</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>0x80000015</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">"Fast IRQ 0x00000006"</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>0x80000016</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">"Fast IRQ 0x00000007"</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>0x80000017</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">"Fast IRQ 0x00000008"</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>0x80000018</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">"Fast IRQ 0x00000009"</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>0x80000019</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">"Fast IRQ 0x0000000a"</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>0x8000001a</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">"Fast IRQ 0x0000000b"</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>0x8000001b</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">"Fast IRQ 0x0000000c"</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>0x8000001c</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">"Fast IRQ 0x0000000d"</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>0x8000001d</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">"Fast IRQ 0x0000000e"</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>0x8000001e</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">"Fast IRQ 0x0000000f"</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>0x8000001f</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">"Unknown trap cause"</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">undefined</p></td> +</tr> +</tbody> +</table> +</div> +<div class="sect3"> +<h4 id="_application_context_handling">4.6.4. Application Context Handling</h4> +<div class="paragraph"> +<p>Upon trap entry the RTE backups the <em>entire</em> application context (i.e. all <code>x</code> general purpose registers) +to the stack. The context is restored automatically after trap completion. The base address of the according +stack frame is copied to the <a href="#_mscratch"><strong><code>mscratch</code></strong></a> CSR. By having this information available, the RTE provides dedicated +functions for accessing and <em>altering</em> the application context:</p> +</div> +<div class="listingblock"> +<div class="title">Listing 25. Context Access Functions</div> +<div class="content"> +<pre class="highlight"><code class="language-c" data-lang="c">// Prototypes +uint32_t neorv32_rte_context_get(int x); // read register x +void neorv32_rte_context_put(int x, uint32_t data); write data to register x + +// Examples +uint32_t tmp = neorv32_rte_context_get(9); // read register 'x9' +neorv32_rte_context_put(28, tmp); // write 'tmp' to register 'x28'</code></pre> +</div> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">RISC-V <code>E</code> Extension</div> +Registers <code>x16..x31</code> are not available if the RISC-V <a href="#_e_isa_extension"><code>E</code> ISA Extension</a> is enabled. +</td> +</tr> +</table> +</div> +<div class="paragraph"> +<p>The context access functions can be used by application-specific trap handlers to emulate unsupported +CPU / SoC features like unimplemented IO modules, unsupported instructions and even unaligned memory accesses.</p> +</div> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +<div class="title">Demo Program: Emulate Unaligned Memory Access</div> +A demo program, which showcases how to emulate unaligned memory accesses using the NEORV32 runtime environment +can be found in <code>sw/example/demo_emulate_unaligned</code>. +</td> +</tr> +</table> +</div> +<div style="page-break-after: always;"></div> +</div> +</div> +</div> +</div> +<div class="sect1"> +<h2 id="_on_chip_debugger_ocd">5. On-Chip Debugger (OCD)</h2> +<div class="sectionbody"> +<div class="paragraph"> +<p>The NEORV32 Processor features an <em>on-chip debugger</em> (OCD) implementing the <strong>execution-based debugging</strong> scheme +compatible to the <strong>Minimal RISC-V Debug Specification</strong>. A copy of the specification is +available in <code>docs/references</code>.</p> +</div> +<div class="paragraph"> +<p><strong>Key Features</strong></p> +</div> +<div class="ulist"> +<ul> +<li> +<p>standard JTAG access port</p> +</li> +<li> +<p>full control of the CPU: halting, single-stepping and resuming</p> +</li> +<li> +<p>indirect access to all core registers (via program buffer)</p> +</li> +<li> +<p>indirect access to the whole processor address space (via program buffer)</p> +</li> +<li> +<p>trigger module for hardware breakpoints</p> +</li> +<li> +<p>compatible with upstream OpenOCD and GDB</p> +</li> +</ul> +</div> +<div class="paragraph"> +<p><strong>Section Structure</strong></p> +</div> +<div class="paragraph"> +<p>This chapter is separated into four sections:</p> +</div> +<div class="ulist"> +<ul> +<li> +<p><a href="#_debug_transport_module_dtm">Debug Transport Module (DTM)</a></p> +</li> +<li> +<p><a href="#_debug_module_dm">Debug Module (DM)</a></p> +</li> +<li> +<p><a href="#_cpu_debug_mode">CPU Debug Mode</a></p> +</li> +<li> +<p><a href="#_trigger_module">Trigger Module</a></p> +</li> +</ul> +</div> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +<div class="title">GDB + SVD</div> +Together with a third-party plugin the processor&#8217;s SVD file can be imported right into GDB to allow comfortable +debugging of peripheral/IO devices (see <a href="https://github.com/stnolting/neorv32/discussions/656" class="bare">https://github.com/stnolting/neorv32/discussions/656</a>). +</td> +</tr> +</table> +</div> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +<div class="title">Hands-On Tutorial</div> +A simple example on how to use NEORV32 on-chip debugger in combination with OpenOCD and the GNU debugger is shown in +section <a href="https://stnolting.github.io/neorv32/ug/#_debugging_using_the_on_chip_debugger">Debugging using the On-Chip Debugger</a> +of the User Guide. +</td> +</tr> +</table> +</div> +<div class="paragraph"> +<p>The NEORV32 on-chip debugger is based on four hardware modules:</p> +</div> +<div class="imageblock text-center"> +<div class="content"> +<img src="img/neorv32_ocd_complex.png" alt="neorv32 ocd complex"> +</div> +<div class="title">Figure 16. NEORV32 on-chip debugger complex</div> +</div> +<div class="olist arabic"> +<ol class="arabic" start="1"> +<li> +<p><a href="#_debug_transport_module_dtm">Debug Transport Module (DTM)</a> (<code>rtl/core/neorv32_debug_dtm.vhd</code>): JTAG access tap to allow an external +adapter to interface with the <em>debug module (DM)</em> using the <em>debug module interface (dmi)</em>.</p> +</li> +<li> +<p><a href="#_debug_module_dm">Debug Module (DM)</a> (<code>rtl/core/neorv32_debug_tm.vhd</code>): RISC-V debug module that is configured by the DTM via the dmi. +From the CPU&#8217;s "point of view" this module behaves as another memory-mapped peripheral that can be accessed via the +processor-internal bus. The memory-mapped registers provide an internal <em>data buffer</em> for data transfer from/to the DM, a +<em>code ROM</em> containing the "park loop" code, a <em>program buffer</em> to allow the debugger to execute small programs defined by the +DM and a <em>status register</em> that is used to communicate <em>exception</em>, <em>halt</em>, <em>resume</em> and <em>execute</em> requests/acknowledges from/to the DM.</p> +</li> +<li> +<p><a href="#_cpu_debug_mode">CPU Debug Mode</a> extension (part of <code>rtl/core/neorv32_cpu_control.vhd</code>): This extension provides the "debug execution mode" +as another operation mode, which is used to execute the park loop code from the DM. This mode also provides additional CSRs and instructions.</p> +</li> +<li> +<p>CPU <a href="#_trigger_module">Trigger Module</a> (also part of <code>rtl/core/neorv32_cpu_control.vhd</code>): This module provides a single <em>hardware</em> breakpoint.</p> +</li> +</ol> +</div> +<div class="paragraph"> +<p><strong>Theory of Operation</strong></p> +</div> +<div class="paragraph"> +<p>When debugging the system using the OCD, the debugger issues a halt request to the CPU (via the CPU&#8217;s +<code>db_halt_req_i</code> signal) to make the CPU enter <em>debug mode</em>. In this mode, the application-defined architectural +state of the system/CPU is "frozen" so the debugger can monitor if without interfering with the actual application. +However, the OCD can also modify the entire architectural state at any time. While in debug mode, the debugger has +full control over the entire CPU and processor operating at highest-privileged mode.</p> +</div> +<div class="paragraph"> +<p>While in debug mode, the CPU executes the "park loop" code from the code ROM of the debug module (DM). +This park loop implements an endless loop, where the CPU polls a memory-mapped <a href="#_status_register">Status Register</a> that is +controlled by the DM. The flags in this register are used to communicate requests from +the DM and to acknowledge them by the CPU: trigger execution of the program buffer or resume the halted +application. Furthermore, the CPU uses this register to signal that the CPU has halted after a halt request +and to signal that an exception has been triggered while being in debug mode.</p> +</div> +<div style="page-break-after: always;"></div> +<div class="sect2"> +<h3 id="_debug_transport_module_dtm">5.1. Debug Transport Module (DTM)</h3> +<div class="paragraph"> +<p>The debug transport module "DTM" (VHDL module: <code>rtl/core/neorv32_debug_dtm.vhd</code>) provides a JTAG test access port ("tap"). +External JTAG access is provided by the following top-level ports:</p> +</div> +<table class="tableblock frame-all grid-rows stretch"> +<caption class="title">Table 79. JTAG top level signals</caption> +<colgroup> +<col style="width: 14.2857%;"> +<col style="width: 14.2857%;"> +<col style="width: 14.2857%;"> +<col style="width: 57.1429%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-center valign-top">Name</th> +<th class="tableblock halign-center valign-top">Width</th> +<th class="tableblock halign-center valign-top">Direction</th> +<th class="tableblock halign-left valign-top">Description</th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>jtag_tck_i</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">1</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">in</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">serial clock</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>jtag_tdi_i</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">1</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">in</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">serial data input</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>jtag_tdo_o</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">1</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">out</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">serial data output</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>jtag_tms_i</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">1</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">in</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">mode select</p></td> +</tr> +</tbody> +</table> +<div class="admonitionblock important"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-important" title="Important"></i> +</td> +<td class="content"> +<div class="title">Maximum JTAG Clock</div> +All JTAG signals are synchronized to the processor&#8217;s clock domain. Hence, no additional clock domain is required for the DTM. +However, this constraints the maximal JTAG clock frequency (<code>jtag_tck_i</code>) to be less than or equal to <strong>1/5</strong> of the processor +clock frequency (<code>clk_i</code>). +</td> +</tr> +</table> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">JTAG TAP Reset</div> +The NEORV32 JTAG TAP does not provide a dedicated reset signal ("TRST"). However, the missing TRST is not a problem, +since JTAG-level resets can be triggered using with TMS signaling. +</td> +</tr> +</table> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">Maintaining JTAG Chain</div> +If the on-chip debugger is disabled the JTAG serial input <code>jtag_tdi_i</code> is directly +connected to the JTAG serial output <code>jtag_tdo_o</code> to maintain the JTAG chain. +</td> +</tr> +</table> +</div> +<div class="paragraph"> +<p>JTAG accesses are based on a single <em>instruction register</em> <code>IR</code>, which is 5 bit wide, and several <em>data registers</em> <code>DR</code> +with different sizes. The individual data registers are accessed by writing the according address to the instruction +register. The following table shows the available data registers and their addresses:</p> +</div> +<table class="tableblock frame-all grid-rows stretch"> +<caption class="title">Table 80. JTAG TAP registers</caption> +<colgroup> +<col style="width: 14.2857%;"> +<col style="width: 14.2857%;"> +<col style="width: 14.2857%;"> +<col style="width: 57.1429%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-center valign-top">Address (via <code>IR</code>)</th> +<th class="tableblock halign-center valign-top">Name</th> +<th class="tableblock halign-center valign-top">Size (bits)</th> +<th class="tableblock halign-left valign-top">Description</th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>00001</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>IDCODE</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">32</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">identifier, version and part ID fields are hardwired to zero, manufacturer ID is assigned via the <code>JEDEC_ID</code> top generic (<a href="#_processor_top_entity_generics">Processor Top Entity - Generics</a>)</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>10000</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>DTMCS</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">32</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">debug transport module control and status register</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>10001</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>DMI</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">41</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">debug module interface (<em>dmi</em>); 7-bit address, 32-bit read/write data, 2-bit operation (<code>00</code> = NOP; <code>10</code> = write; <code>01</code> = read)</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">others</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>BYPASS</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">1</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">default JTAG bypass register</p></td> +</tr> +</tbody> +</table> +<table class="tableblock frame-all grid-rows stretch"> +<caption class="title">Table 81. <code>DTMCS</code> - DTM Control and Status Register</caption> +<colgroup> +<col style="width: 14.2857%;"> +<col style="width: 21.4285%;"> +<col style="width: 7.1428%;"> +<col style="width: 57.143%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-center valign-top">Bit(s)</th> +<th class="tableblock halign-center valign-top">Name</th> +<th class="tableblock halign-center valign-top">R/W</th> +<th class="tableblock halign-left valign-top">Description</th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">31:18</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">-</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><em>reserved</em>, hardwired to zero</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">17</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>dmihardreset</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">setting this bit will reset the debug module interface; this bit auto-clears</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">16</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>dmireset</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">setting this bit will clear the sticky error state; this bit auto-clears</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">15</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">-</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><em>reserved</em>, hardwired to zero</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">14:12</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>idle</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">recommended idle states (= 0, no idle states required)</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">11:10</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>dmistat</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">DMI status: <code>00</code> = no error, <code>01</code> = reserved, <code>10</code> = operation failed, <code>11</code> = failed operation during pending DMI operation</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">9:4</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>abits</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">number of address bits in <code>DMI</code> register (= 6)</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">3:0</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>version</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0001</code> = DTM is compatible to spec. versions v0.13 and v1.0</p></td> +</tr> +</tbody> +</table> +<div style="page-break-after: always;"></div> +</div> +<div class="sect2"> +<h3 id="_debug_module_dm">5.2. Debug Module (DM)</h3> +<div class="paragraph"> +<p>The debug module "DM" (VHDL module: <code>rtl/core/neorv32_debug_dm.vhd</code>) acts as a translation interface between abstract +operations issued by the debugger application (like GDB) and the platform-specific debugger hardware. +It supports the following features:</p> +</div> +<div class="ulist"> +<ul> +<li> +<p>Gives the debugger necessary information about the implementation.</p> +</li> +<li> +<p>Allows the hart to be halted/resumed/reset and provides the current status.</p> +</li> +<li> +<p>Provides abstract read and write access to the halted hart&#8217;s generap purpose registers.</p> +</li> +<li> +<p>Provides access to a reset signal that allows debugging from the very first instruction after reset.</p> +</li> +<li> +<p>Provides a <em>Program Buffer</em> to force the hart to execute arbitrary instructions.</p> +</li> +<li> +<p>Allows memory access from a hart&#8217;s point of view.</p> +</li> +</ul> +</div> +<div class="paragraph"> +<p>The NEORV32 DM follows the "Minimal RISC-V External Debug Specification" to provide full debugging capabilities while +keeping resource/area requirements at a minimum. It implements the <strong>execution based debugging scheme</strong> for a +single hart and provides the following core features:</p> +</div> +<div class="ulist"> +<ul> +<li> +<p>program buffer with 2 entries and an implicit <code>ebreak</code> instruction</p> +</li> +<li> +<p>indirect bus access via the CPU using the program buffer</p> +</li> +<li> +<p>abstract commands: "access register" plus auto-execution</p> +</li> +<li> +<p>halt-on-reset capability</p> +</li> +</ul> +</div> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +<div class="title">DM Spec. Version</div> +By default, the OCD&#8217;s debug module supports version 1.0 of the RISC-V debug spec. For backwards compatibility, the DM +can be "downgraded" back to version 0.13 via the <code>DM_LEGACY_MODE</code> generic (see <a href="#_processor_top_entity_generics">Processor Top Entity - Generics</a>). +</td> +</tr> +</table> +</div> +<div class="paragraph"> +<p>The DM provides two access "point of views": accesses from the DTM via the <em>debug module interface (dmi)</em> and +accesses from the CPU via the processor-internal bus system. From the DTM&#8217;s point of view, the DM implements a set of +<a href="#_dm_registers">DM Registers</a> that are used to control and monitor the debugging session. From the CPU&#8217;s point of view, the +DM implements several memory-mapped registers (within the <em>normal</em> address space) that are used for communicating +debugging control and status (<a href="#_dm_cpu_access">DM CPU Access</a>).</p> +</div> +<div class="sect3"> +<h4 id="_dm_registers">5.2.1. DM Registers</h4> +<div class="paragraph"> +<p>The DM is controlled via a set of registers that are accessed via the DTM&#8217;s <em>debug module interface</em> (dmi). +The following registers are implemented:</p> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +Write accesses to registers that are not implemented are simply ignored and read accesses +to these registers will always return zero. +</td> +</tr> +</table> +</div> +<table class="tableblock frame-all grid-rows stretch"> +<caption class="title">Table 82. Available DM registers</caption> +<colgroup> +<col style="width: 16.6666%;"> +<col style="width: 25%;"> +<col style="width: 58.3334%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-center valign-top">Address</th> +<th class="tableblock halign-center valign-top">Name</th> +<th class="tableblock halign-left valign-top">Description</th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>0x04</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><a href="#_data0"><strong><code>data0</code></strong></a></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Abstract data 0, used for data transfer between debugger and processor</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>0x10</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><a href="#_dmcontrol"><strong><code>dmcontrol</code></strong></a></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Debug module control</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>0x11</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><a href="#_dmstatus"><strong><code>dmstatus</code></strong></a></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Debug module status</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>0x12</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><a href="#_hartinfo"><strong><code>hartinfo</code></strong></a></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Hart information</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>0x16</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><a href="#_abstracts"><strong><code>abstracts</code></strong></a></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Abstract control and status</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>0x17</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><a href="#_command"><strong><code>command</code></strong></a></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Abstract command</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>0x18</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><a href="#_abstractauto"><strong><code>abstractauto</code></strong></a></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Abstract command auto-execution</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>0x1d</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>nextdm</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Base address of next DM; reads as zero to indicate there is only one DM</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>0x20</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><a href="#_progbuf"><code>progbuf0</code></a></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Program buffer 0</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>0x21</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><a href="#_progbuf"><code>progbuf1</code></a></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Program buffer 1</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>0x38</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>sbcs</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">System bus access control and status; reads as zero to indicate there is <strong>no</strong> direct system bus access</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>0x40</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><a href="#_haltsum0"><strong><code>haltsum0</code></strong></a></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Halted harts</p></td> +</tr> +</tbody> +</table> +<div class="sect4"> +<h5 id="_data0"><strong><code>data0</code></strong></h5> +<table class="tableblock frame-ends grid-none stretch"> +<colgroup> +<col style="width: 10.5263%;"> +<col style="width: 71.0526%;"> +<col style="width: 18.4211%;"> +</colgroup> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">0x04</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><strong>Abstract data 0</strong></p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock"><code>data0</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top" colspan="3"><p class="tableblock">Reset value: <code>0x00000000</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top" colspan="3"><p class="tableblock">Basic read/write data exchange register to be used with abstract commands (for example to read/write data from/to CPU GPRs).</p></td> +</tr> +</tbody> +</table> +</div> +<div class="sect4"> +<h5 id="_dmcontrol"><strong><code>dmcontrol</code></strong></h5> +<table class="tableblock frame-ends grid-none stretch"> +<colgroup> +<col style="width: 10.5263%;"> +<col style="width: 71.0526%;"> +<col style="width: 18.4211%;"> +</colgroup> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">0x10</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><strong>Debug module control register</strong></p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock"><code>dmcontrol</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top" colspan="3"><p class="tableblock">Reset value: <code>0x00000000</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top" colspan="3"><p class="tableblock">Control of the overall debug module and the hart. The following table shows all implemented bits. All remaining bits/bit-fields +are configured as "zero" and are read-only. Writing '1' to these bits/fields will be ignored.</p></td> +</tr> +</tbody> +</table> +<table class="tableblock frame-all grid-rows stretch"> +<caption class="title">Table 83. <code>dmcontrol</code> Register Bits</caption> +<colgroup> +<col style="width: 8.3333%;"> +<col style="width: 16.6666%;"> +<col style="width: 8.3333%;"> +<col style="width: 66.6668%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-center valign-top">Bit</th> +<th class="tableblock halign-center valign-top">Name [RISC-V]</th> +<th class="tableblock halign-center valign-top">R/W</th> +<th class="tableblock halign-left valign-top">Description</th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">31</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>haltreq</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">-/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">set/clear hart halt request</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">30</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>resumereq</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">-/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">request hart to resume</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">28</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>ackhavereset</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">-/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">write <code>1</code> to clear <code>*havereset</code> flags</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">1</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>ndmreset</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">put whole system (except OCD) into reset state when <code>1</code></p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">0</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>dmactive</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">DM enable; writing <code>0</code>-<code>1</code> will reset the DM</p></td> +</tr> +</tbody> +</table> +</div> +<div class="sect4"> +<h5 id="_dmstatus"><strong><code>dmstatus</code></strong></h5> +<table class="tableblock frame-ends grid-none stretch"> +<colgroup> +<col style="width: 10.5263%;"> +<col style="width: 71.0526%;"> +<col style="width: 18.4211%;"> +</colgroup> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">0x11</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><strong>Debug module status register</strong></p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock"><code>dmstatus</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top" colspan="3"><p class="tableblock">Reset value: <code>0x00400083</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top" colspan="3"><p class="tableblock">Current status of the overall debug module and the hart. The entire register is read-only.</p></td> +</tr> +</tbody> +</table> +<table class="tableblock frame-all grid-rows stretch"> +<caption class="title">Table 84. <code>dmstatus</code> Register Bits</caption> +<colgroup> +<col style="width: 7.6923%;"> +<col style="width: 15.3846%;"> +<col style="width: 76.9231%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-center valign-top">Bit</th> +<th class="tableblock halign-center valign-top">Name [RISC-V]</th> +<th class="tableblock halign-left valign-top">Description</th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">31:23</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><em>reserved</em></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">reserved; always zero</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">22</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>impebreak</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">always <code>1</code>; indicates an implicit <code>ebreak</code> instruction after the last program buffer entry</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">21:20</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><em>reserved</em></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">reserved; always zero</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">19</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>allhavereset</code></p></td> +<td class="tableblock halign-left valign-top" rowspan="2"><p class="tableblock"><code>1</code> when the hart is in reset</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">18</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>anyhavereset</code></p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">17</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>allresumeack</code></p></td> +<td class="tableblock halign-left valign-top" rowspan="2"><p class="tableblock"><code>1</code> when the hart has acknowledged a resume request</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">16</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>anyresumeack</code></p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">15</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>allnonexistent</code></p></td> +<td class="tableblock halign-left valign-top" rowspan="2"><p class="tableblock">always zero to indicate the hart is always existent</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">14</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>anynonexistent</code></p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">13</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>allunavail</code></p></td> +<td class="tableblock halign-left valign-top" rowspan="2"><p class="tableblock"><code>1</code> when the DM is disabled to indicate the hart is unavailable</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">12</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>anyunavail</code></p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">11</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>allrunning</code></p></td> +<td class="tableblock halign-left valign-top" rowspan="2"><p class="tableblock"><code>1</code> when the hart is running</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">10</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>anyrunning</code></p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">9</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>allhalted</code></p></td> +<td class="tableblock halign-left valign-top" rowspan="2"><p class="tableblock"><code>1</code> when the hart is halted</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">8</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>anyhalted</code></p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">7</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>authenticated</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">always <code>1</code>; there is no authentication</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">6</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>authbusy</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">always <code>0</code>; there is no authentication</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">5</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>hasresethaltreq</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">always <code>0</code>; halt-on-reset is not supported (directly)</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">4</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>confstrptrvalid</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">always <code>0</code>; no configuration string available</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">3:0</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>version</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">debug spec. version; <code>0011</code> (v1.0) or <code>0010</code> (v0.13); configured via the <code>DM_LEGACY_MODE</code> <a href="#_processor_top_entity_generics">Processor Top Entity - Generics</a></p></td> +</tr> +</tbody> +</table> +<div class="admonitionblock warning"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-warning" title="Warning"></i> +</td> +<td class="content"> +<div class="title">OCD Security</div> +JTAG access via the OCD is <strong>always authenticated</strong> (<code>dmstatus.authenticated = 1</code>). Hence, the entire system can always +be accessed via the on-chip debugger. +</td> +</tr> +</table> +</div> +</div> +<div class="sect4"> +<h5 id="_hartinfo"><strong><code>hartinfo</code></strong></h5> +<table class="tableblock frame-ends grid-none stretch"> +<colgroup> +<col style="width: 10.5263%;"> +<col style="width: 71.0526%;"> +<col style="width: 18.4211%;"> +</colgroup> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">0x12</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><strong>Hart information</strong></p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock"><code>hartinfo</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top" colspan="3"><p class="tableblock">Reset value: <em>see below</em></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top" colspan="3"><p class="tableblock">This register gives information about the hart. The entire register is read-only.</p></td> +</tr> +</tbody> +</table> +<table class="tableblock frame-all grid-rows stretch"> +<caption class="title">Table 85. <code>hartinfo</code> Register Bits</caption> +<colgroup> +<col style="width: 9.0909%;"> +<col style="width: 18.1818%;"> +<col style="width: 72.7273%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-center valign-top">Bit</th> +<th class="tableblock halign-center valign-top">Name [RISC-V]</th> +<th class="tableblock halign-left valign-top">Description</th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">31:24</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><em>reserved</em></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">reserved; always zero</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">23:20</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>nscratch</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0001</code>, number of <code>dscratch*</code> CPU registers = 1</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">19:17</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><em>reserved</em></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">reserved; always zero</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">16</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>dataccess</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0</code>, the <code>data</code> registers are shadowed in the hart&#8217;s address space</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">15:12</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>datasize</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0001</code>, number of 32-bit words in the address space dedicated to shadowing the <code>data</code> registers (1 register)</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">11:0</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>dataaddr</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">= <code>dm_data_base_c(11:0)</code>, signed base address of <code>data</code> words (see address map in <a href="#_dm_cpu_access">DM CPU Access</a>)</p></td> +</tr> +</tbody> +</table> +</div> +<div class="sect4"> +<h5 id="_abstracts"><strong><code>abstracts</code></strong></h5> +<table class="tableblock frame-ends grid-none stretch"> +<colgroup> +<col style="width: 10.5263%;"> +<col style="width: 71.0526%;"> +<col style="width: 18.4211%;"> +</colgroup> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">0x16</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><strong>Abstract control and status</strong></p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock"><code>abstracts</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top" colspan="3"><p class="tableblock">Reset value: <code>0x02000801</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top" colspan="3"><p class="tableblock">Command execution info and status.</p></td> +</tr> +</tbody> +</table> +<table class="tableblock frame-all grid-rows stretch"> +<caption class="title">Table 86. <code>abstracts</code> Register Bits</caption> +<colgroup> +<col style="width: 8.3333%;"> +<col style="width: 16.6666%;"> +<col style="width: 8.3333%;"> +<col style="width: 66.6668%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-center valign-top">Bit</th> +<th class="tableblock halign-center valign-top">Name [RISC-V]</th> +<th class="tableblock halign-center valign-top">R/W</th> +<th class="tableblock halign-left valign-top">Description</th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">31:29</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><em>reserved</em></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">reserved; always zero</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">28:24</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>progbufsize</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">always <code>0010</code>: size of the program buffer (<code>progbuf</code>) = 2 entries</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">23:11</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><em>reserved</em></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">reserved; always zero</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">12</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>busy</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>1</code> when a command is being executed</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">11</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>relaxedpriv</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">always <code>1</code>: PMP rules are ignored when in debug mode</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">10:8</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>cmderr</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">error during command execution (see below); has to be cleared by writing <code>111</code></p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">7:4</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><em>reserved</em></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">reserved; always zero</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">3:0</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>datacount</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">always <code>0001</code>: number of implemented <code>data</code> registers for abstract commands = 1</p></td> +</tr> +</tbody> +</table> +<div class="paragraph"> +<p>Error codes in <code>cmderr</code> (highest priority first):</p> +</div> +<div class="ulist"> +<ul> +<li> +<p><code>000</code> - no error</p> +</li> +<li> +<p><code>100</code> - command cannot be executed since hart is not in expected state</p> +</li> +<li> +<p><code>011</code> - exception during command execution</p> +</li> +<li> +<p><code>010</code> - unsupported command</p> +</li> +<li> +<p><code>001</code> - invalid DM register read/write while command is/was executing</p> +</li> +</ul> +</div> +</div> +<div class="sect4"> +<h5 id="_command"><strong><code>command</code></strong></h5> +<table class="tableblock frame-ends grid-none stretch"> +<colgroup> +<col style="width: 10.5263%;"> +<col style="width: 71.0526%;"> +<col style="width: 18.4211%;"> +</colgroup> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">0x17</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><strong>Abstract command</strong></p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock"><code>command</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top" colspan="3"><p class="tableblock">Reset value: <code>0x00000000</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top" colspan="3"><p class="tableblock">Writing this register will trigger the execution of an abstract command. New command can only be executed if +<code>cmderr</code> is zero. The entire register in write-only (reads will return zero).</p></td> +</tr> +</tbody> +</table> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +The NEORV32 DM only supports <strong>Access Register</strong> abstract commands. These commands can only access the +hart&#8217;s GPRs x0 - x15/31 (abstract command register index <code>0x1000</code> - <code>0x101f</code>). +</td> +</tr> +</table> +</div> +<table class="tableblock frame-all grid-rows stretch"> +<caption class="title">Table 87. <code>command</code> Register Bits</caption> +<colgroup> +<col style="width: 8.3333%;"> +<col style="width: 16.6666%;"> +<col style="width: 8.3333%;"> +<col style="width: 66.6668%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-center valign-top">Bit</th> +<th class="tableblock halign-center valign-top">Name [RISC-V]</th> +<th class="tableblock halign-center valign-top">R/W</th> +<th class="tableblock halign-left valign-top">Description / required value</th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">31:24</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>cmdtype</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">-/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>00000000</code> to indicate "access register" command</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">23</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><em>reserved</em></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">-/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">reserved, has to be <code>0</code> when writing</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">22:20</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>aarsize</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">-/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>010</code> to indicate 32-bit accesses</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">21</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>aarpostincrement</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">-/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0</code>, post-increment is not supported</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">18</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>postexec</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">-/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">if set the program buffer is executed <em>after</em> the command</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">17</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>transfer</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">-/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">if set the operation in <code>write</code> is conducted</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">16</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>write</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">-/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>1</code>: copy <code>data0</code> to <code>[regno]</code>, <code>0</code>: copy <code>[regno]</code> to <code>data0</code></p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">15:0</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>regno</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">-/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">GPR-access only; has to be <code>0x1000</code> - <code>0x101f</code></p></td> +</tr> +</tbody> +</table> +</div> +<div class="sect4"> +<h5 id="_abstractauto"><strong><code>abstractauto</code></strong></h5> +<table class="tableblock frame-ends grid-none stretch"> +<colgroup> +<col style="width: 10.5263%;"> +<col style="width: 71.0526%;"> +<col style="width: 18.4211%;"> +</colgroup> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">0x18</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><strong>Abstract command auto-execution</strong></p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock"><code>abstractauto</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top" colspan="3"><p class="tableblock">Reset value: <code>0x00000000</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top" colspan="3"><p class="tableblock">Register to configure if a read/write access to a DM register re-triggers execution of the last abstract command.</p></td> +</tr> +</tbody> +</table> +<table class="tableblock frame-all grid-rows stretch"> +<caption class="title">Table 88. <code>abstractauto</code> Register Bits</caption> +<colgroup> +<col style="width: 8.3333%;"> +<col style="width: 16.6666%;"> +<col style="width: 8.3333%;"> +<col style="width: 66.6668%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-center valign-top">Bit</th> +<th class="tableblock halign-center valign-top">Name [RISC-V]</th> +<th class="tableblock halign-center valign-top">R/W</th> +<th class="tableblock halign-left valign-top">Description</th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">17</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>autoexecprogbuf[1]</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">when set reading/writing from/to <code>progbuf1</code> will execute <code>command</code> again</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">16</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>autoexecprogbuf[0]</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">when set reading/writing from/to <code>progbuf0</code> will execute <code>command</code> again</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">0</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>autoexecdata[0]</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">when set reading/writing from/to <code>data0</code> will execute <code>command</code> again</p></td> +</tr> +</tbody> +</table> +</div> +<div class="sect4"> +<h5 id="_progbuf"><strong><code>progbuf</code></strong></h5> +<table class="tableblock frame-ends grid-none stretch"> +<colgroup> +<col style="width: 10.5263%;"> +<col style="width: 71.0526%;"> +<col style="width: 18.4211%;"> +</colgroup> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">0x20</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><strong>Program buffer 0</strong></p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock"><code>progbuf0</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">0x21</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><strong>Program buffer 1</strong></p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock"><code>progbuf1</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top" colspan="3"><p class="tableblock">Reset value: <code>0x00000013</code> ("NOP")</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top" colspan="3"><p class="tableblock">Program buffer (two entries) for the DM.</p></td> +</tr> +</tbody> +</table> +</div> +<div class="sect4"> +<h5 id="_haltsum0"><strong><code>haltsum0</code></strong></h5> +<table class="tableblock frame-ends grid-none stretch"> +<colgroup> +<col style="width: 10.5263%;"> +<col style="width: 71.0526%;"> +<col style="width: 18.4211%;"> +</colgroup> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">0x408</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><strong>Halted harts status</strong></p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock"><code>haltsum0</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top" colspan="3"><p class="tableblock">Reset value: <code>0x00000000</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top" colspan="3"><p class="tableblock">Hart has halted when according bit is set.</p></td> +</tr> +</tbody> +</table> +<table class="tableblock frame-all grid-rows stretch"> +<caption class="title">Table 89. <code>haltsum0</code> Register Bits</caption> +<colgroup> +<col style="width: 8.3333%;"> +<col style="width: 16.6666%;"> +<col style="width: 8.3333%;"> +<col style="width: 66.6668%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-center valign-top">Bit</th> +<th class="tableblock halign-center valign-top">Name [RISC-V]</th> +<th class="tableblock halign-center valign-top">R/W</th> +<th class="tableblock halign-left valign-top">Description</th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">0</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>haltsum0[0]</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Hart is halted when set.</p></td> +</tr> +</tbody> +</table> +</div> +</div> +<div class="sect3"> +<h4 id="_dm_cpu_access">5.2.2. DM CPU Access</h4> +<div class="paragraph"> +<p>From the CPU&#8217;s perspective, the DM acts like another memory-mapped peripheral. It occupies 256 bytes of the CPU&#8217;s address +space starting at address <code>dm_base_c</code> (see table below). This address space is divided into four sections of 64 bytes +each to provide access to the <em>park loop code ROM</em>, the <em>program buffer</em>, the <em>data buffer</em> and the <em>status register</em>. +The program buffer, the data buffer and the status register do not fully occupy the 64-byte-wide sections and are +mirrored several times to fill the entire section.</p> +</div> +<table class="tableblock frame-all grid-rows stretch"> +<caption class="title">Table 90. DM CPU Access - Address Map</caption> +<colgroup> +<col style="width: 22.2222%;"> +<col style="width: 22.2222%;"> +<col style="width: 55.5556%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-center valign-top">Base address</th> +<th class="tableblock halign-center valign-top">Actual size</th> +<th class="tableblock halign-left valign-top">Description</th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>0xffffff00</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">64 bytes</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">ROM for the "park loop" code</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>0xffffff40</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">16 bytes</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Program buffer (<a href="#_progbuf"><strong><code>progbuf</code></strong></a>)</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>0xffffff80</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">4 bytes</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Data buffer (<a href="#_data0"><strong><code>data0</code></strong></a>)</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>0xffffffc0</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">4 bytes</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Control and <a href="#_status_register">Status Register</a></p></td> +</tr> +</tbody> +</table> +<div class="admonitionblock important"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-important" title="Important"></i> +</td> +<td class="content"> +<div class="title">DM Register Access</div> +All memory-mapped registers of the DM can only be accessed by the CPU if it is actually in debug mode. +Hence, the DM registers are not "visible" for normal CPU operations. +Any CPU access outside of debug mode will raise a bus access fault exception. +</td> +</tr> +</table> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">Park Loop Code Sources ("OCD Firmware")</div> +The assembly sources of the <strong>park loop code</strong> are available in <code>sw/ocd-firmware/park_loop.S</code>. +</td> +</tr> +</table> +</div> +<div class="sect4"> +<h5 id="_code_rom_entry_points">Code ROM Entry Points</h5> +<div class="paragraph"> +<p>The park loop code provides two entry points where the actual code execution can start. These are used to enter +the park loop either when an explicit debug-entry request has been issued (for example a halt request) or when an exception +has occurred while executing code <em>inside</em> debug mode.</p> +</div> +<table class="tableblock frame-all grid-rows stretch"> +<caption class="title">Table 91. Park Loop Entry Points</caption> +<colgroup> +<col style="width: 60%;"> +<col style="width: 40%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-center valign-top">Address</th> +<th class="tableblock halign-left valign-top">Description</th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>dm_exc_entry_c</code> (<code>dm_base_c</code> + 0)</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Exception entry address</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>dm_park_entry_c</code> (<code>dm_base_c</code> + 8)</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Normal entry address</p></td> +</tr> +</tbody> +</table> +<div class="paragraph"> +<p>When the CPU enters or re-enters debug mode (for example via an <code>ebreak</code> in the DM&#8217;s program buffer), it jumps to +the <em>normal entry point</em> that is configured via the <code>CPU_DEBUG_PARK_ADDR</code> (= <code>dm_base_c</code>) generic +(<a href="#_cpu_top_entity_generics">CPU Top Entity - Generics</a>). By default, this generic is set to <code>dm_park_entry_c</code>, which is defined in main +package file. If an exception is encountered during debug mode, the CPU jumps to the address of the <em>exception +entry point</em> configured via the <code>CPU_DEBUG_EXC_ADDR</code> generic (<a href="#_cpu_top_entity_generics">CPU Top Entity - Generics</a>). By default, this generic +is set to <code>dm_exc_entry_c</code>, which is also defined in main package file.</p> +</div> +</div> +<div class="sect4"> +<h5 id="_status_register">Status Register</h5> +<div class="paragraph"> +<p>The status register provides a direct communication channel between the CPU&#8217;s debug mode executing the park loop +and the debugger-controlled debug module. This register is used to communicate <em>requests</em>, which are issued by the +DM and the according <em>acknowledges</em>, which are generated by the CPU.</p> +</div> +<div class="paragraph"> +<p>There are only 4 bits in this register that are used to implement the requests/acknowledges. Each bit is left-aligned +in one sub-byte of the entire 32-bit register. Thus, the CPU can access each bit individually using <em>store-byte</em> and +<em>load-byte</em> instructions. This eliminates the need to perform bit-masking in the park loop code leading to less code size +and faster execution.</p> +</div> +<table class="tableblock frame-all grid-rows stretch"> +<caption class="title">Table 92. DM Status Register - CPU Access</caption> +<colgroup> +<col style="width: 7.1428%;"> +<col style="width: 21.4285%;"> +<col style="width: 14.2857%;"> +<col style="width: 57.143%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-center valign-top">Bit</th> +<th class="tableblock halign-center valign-top">Name</th> +<th class="tableblock halign-center valign-top">CPU access</th> +<th class="tableblock halign-left valign-top">Description</th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-center valign-top" rowspan="2"><p class="tableblock">0</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>sreg_halt_ack</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">read</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">-</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">-</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">write</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Set by the CPU while it is halted (and executing the park loop).</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top" rowspan="2"><p class="tableblock">8</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>sreg_resume_req</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">read</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Set by the DM to request the CPU to resume normal operation.</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>sreg_resume_ack</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">write</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Set by the CPU before it starts resuming.</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top" rowspan="2"><p class="tableblock">16</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>sreg_execute_req</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">read</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Set by the DM to request execution of the program buffer.</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>sreg_execute_ack</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">write</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Set by the CPU before it starts executing the program buffer.</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top" rowspan="2"><p class="tableblock">24</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">-</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">read</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">-</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>sreg_execute_ack</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">write</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Set by the CPU if an exception occurs while being in debug mode.</p></td> +</tr> +</tbody> +</table> +<div style="page-break-after: always;"></div> +</div> +</div> +</div> +<div class="sect2"> +<h3 id="_cpu_debug_mode">5.3. CPU Debug Mode</h3> +<div class="paragraph"> +<p>The NEORV32 CPU Debug Mode is compatible to the <strong>Minimal RISC-V Debug Specification 1.0</strong> +<code>Sdext</code> (external debug) ISA extension. When enabled via the CPU&#8217;s <a href="#_sdext_isa_extension"><code>Sdext</code> ISA Extension</a> generic and/or +the processor&#8217;s <code>ON_CHIP_DEBUGGER_EN</code> it adds a new CPU operation mode ("debug mode"), three additional +<a href="#_cpu_debug_mode_csrs">CPU Debug Mode CSRs</a> and one additional instruction (<code>dret</code>) to the core.</p> +</div> +<div class="paragraph"> +<p>Debug-mode is entered on any of the following events:</p> +</div> +<div class="olist arabic"> +<ol class="arabic" start="1"> +<li> +<p>The CPU executes an <code>ebreak</code> instruction (when in machine-mode and <code>ebreakm</code> in <a href="#_dcsr"><strong><code>dcsr</code></strong></a> is set OR when in user-mode and <code>ebreaku</code> in <a href="#_dcsr"><strong><code>dcsr</code></strong></a> is set).</p> +</li> +<li> +<p>A debug halt request is issued by the DM (via CPU signal <code>db_halt_req_i</code>, high-active).</p> +</li> +<li> +<p>The CPU completes executing of a single instruction while being in single-step debugging mode (<code>step</code> in <a href="#_dcsr"><strong><code>dcsr</code></strong></a> is set).</p> +</li> +<li> +<p>A hardware trigger from the <a href="#_trigger_module">Trigger Module</a> fires (<code>exe</code> and <code>action</code> in <a href="#_tdata1"><strong><code>tdata1</code></strong></a> / <code>mcontrol</code> are set).</p> +</li> +</ol> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +From a hardware point of view these debug-mode-entry conditions are special traps (synchronous exceptions or +asynchronous interrupts) that are handled transparently by the control logic. +</td> +</tr> +</table> +</div> +<div class="paragraph"> +<p><strong>Whenever the CPU enters debug-mode it performs the following operations:</strong></p> +</div> +<div class="ulist"> +<ul> +<li> +<p>wake-up CPU if it was send to sleep mode by the <code>wfi</code> instruction</p> +</li> +<li> +<p>switch to debug-mode privilege level</p> +</li> +<li> +<p>move the current program counter to <a href="#_dpc"><strong><code>dpc</code></strong></a></p> +</li> +<li> +<p>copy the hart&#8217;s current privilege level to the <code>prv</code> flags in <a href="#_dcsr"><strong><code>dcsr</code></strong></a></p> +</li> +<li> +<p>set <code>cause</code> in <a href="#_dcrs">[_dcrs]</a> according to the cause why debug mode is entered</p> +</li> +<li> +<p><strong>no update</strong> of <code>mtval</code>, <code>mcause</code>, <code>mtval</code> and <code>mstatus</code> CSRs</p> +</li> +<li> +<p>load the address configured via the CPU&#8217;s <code>CPU_DEBUG_PARK_ADDR</code> (<a href="#_cpu_top_entity_generics">CPU Top Entity - Generics</a>) generic to the program counter jumping to the +"debugger park loop" code stored in the debug module (DM)</p> +</li> +</ul> +</div> +<div class="paragraph"> +<p><strong>When the CPU is in debug-mode the following things are important:</strong></p> +</div> +<div class="ulist"> +<ul> +<li> +<p>while in debug mode, the CPU executes the parking loop and - if requested by the DM - the program buffer</p> +</li> +<li> +<p>effective CPU privilege level is <code>machine</code> mode; any active physical memory protection (PMP) configuration is bypassed</p> +</li> +<li> +<p>the <code>wfi</code> instruction acts as a <code>nop</code> (also during single-stepping)</p> +</li> +<li> +<p>if an exception occurs while being in debug mode:</p> +<div class="ulist"> +<ul> +<li> +<p>if the exception was caused by any debug-mode entry action the CPU jumps to the normal entry point (defined by <code>CPU_DEBUG_PARK_ADDR</code> generic of the <a href="#_cpu_top_entity_generics">CPU Top Entity - Generics</a>) of the park loop again (for example when executing <code>ebreak</code> while in debug-mode)</p> +</li> +<li> +<p>for all other exception sources the CPU jumps to the exception entry point (defined by <code>CPU_DEBUG_EXC_ADDR</code> generic of the <a href="#_cpu_top_entity_generics">CPU Top Entity - Generics</a>) to signal an exception to the DM; the CPU restarts the park loop again afterwards</p> +</li> +</ul> +</div> +</li> +<li> +<p>interrupts are disabled; however, they will remain pending and will get executed after the CPU has left debug mode and is not being single-stepped</p> +</li> +<li> +<p>if the DM makes a resume request, the park loop exits and the CPU leaves debug mode (executing <code>dret</code>)</p> +</li> +<li> +<p>the standard counters <a href="#_machine_counter_and_timer_csrs">(Machine) Counter and Timer CSRs</a> <code>[m]cycle[h]</code> and <code>[m]instret[h]</code> are stopped</p> +</li> +<li> +<p>all <a href="#_hardware_performance_monitors_hpm_csrs">Hardware Performance Monitors (HPM) CSRs</a> are stopped</p> +</li> +</ul> +</div> +<div class="paragraph"> +<p>Debug mode is left either by executing the <code>dret</code> instruction or by performing a hardware reset of the CPU. +Executing <code>dret</code> outside of debug mode will raise an illegal instruction exception.</p> +</div> +<div class="paragraph"> +<p><strong>Whenever the CPU leaves debug mode it performs the following operations:</strong></p> +</div> +<div class="ulist"> +<ul> +<li> +<p>set the hart&#8217;s current privilege level according to the <code>prv</code> flags of <a href="#_dcsr"><strong><code>dcsr</code></strong></a></p> +</li> +<li> +<p>restore the original program counter from <a href="#_dpcs">[_dpcs]</a> resuming normal operation</p> +</li> +</ul> +</div> +<div class="sect3"> +<h4 id="_cpu_debug_mode_csrs">5.3.1. CPU Debug Mode CSRs</h4> +<div class="paragraph"> +<p>Two additional CSRs are required by the <em>Minimal RISC-V Debug Specification</em>: the debug mode control and status register +<code>dcsr</code> and the debug program counter <code>dpc</code>. An additional general purpose scratch register for debug-mode-only +(<code>dscratch0</code>) allows faster execution by having a fast-accessible backup register. +These CSRs are only accessible when the CPU is <em>in</em> debug mode. If these CSRs are accessed outside of debug mode +an illegal instruction exception is raised.</p> +</div> +<div class="sect4"> +<h5 id="_dcsr"><strong><code>dcsr</code></strong></h5> +<table class="tableblock frame-ends grid-none stretch"> +<colgroup> +<col style="width: 11.1111%;"> +<col style="width: 88.8889%;"> +</colgroup> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Name</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Debug control and status register</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Address</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x7b0</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Reset value</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x40000413</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">ISA</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>Zicsr</code> &amp; <code>Sdext</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Description</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">This register is used to configure the debug mode environment and provides additional status information.</p></td> +</tr> +</tbody> +</table> +<table class="tableblock frame-all grid-rows stretch"> +<caption class="title">Table 93. Debug control and status register <code>dcsr</code> bits</caption> +<colgroup> +<col style="width: 8.3333%;"> +<col style="width: 16.6666%;"> +<col style="width: 8.3333%;"> +<col style="width: 66.6668%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-center valign-top">Bit</th> +<th class="tableblock halign-center valign-top">Name [RISC-V]</th> +<th class="tableblock halign-center valign-top">R/W</th> +<th class="tableblock halign-left valign-top">Description</th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">31:28</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>xdebugver</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0100</code> - CPU debug mode is compatible to spec. version 1.0</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">27:16</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">-</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>000000000000</code> - <em>reserved</em></p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">15</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>ebereakm</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>ebreak</code> instructions in <code>machine</code> mode will <em>enter</em> debug mode when set</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">14</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>ebereakh</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0</code> - hypervisor mode not supported</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">13</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>ebereaks</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0</code> - supervisor mode not supported</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">12</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>ebereaku</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>ebreak</code> instructions in <code>user</code> mode will <em>enter</em> debug mode when set</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">11</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>stepie</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0</code> - IRQs are disabled during single-stepping</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">10</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>stopcount</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>1</code> - standard counters and HPMs are stopped when in debug mode</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">9</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>stoptime</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0</code> - timers increment as usual</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">8:6</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>cause</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">cause identifier - why debug mode was entered (see below)</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">5</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">-</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0</code> - <em>reserved</em></p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">4</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>mprven</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>1</code> - <code>mprv</code> in <a href="#_mstatus"><strong><code>mstatus</code></strong></a> is also evaluated when in debug mode</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">3</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>nmip</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0</code> - non-maskable interrupt is pending</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">2</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>step</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">enable single-stepping when set</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">1:0</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>prv</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">CPU privilege level before/after debug mode</p></td> +</tr> +</tbody> +</table> +<div class="paragraph"> +<p>Cause codes in <code>dcsr.cause</code> (highest priority first):</p> +</div> +<div class="ulist"> +<ul> +<li> +<p><code>010</code> - triggered by hardware <a href="#_trigger_module">Trigger Module</a></p> +</li> +<li> +<p><code>001</code> - executed <code>EBREAK</code> instruction</p> +</li> +<li> +<p><code>011</code> - external halt request (from DM)</p> +</li> +<li> +<p><code>100</code> - return from single-stepping</p> +</li> +</ul> +</div> +</div> +<div class="sect4"> +<h5 id="_dpc"><strong><code>dpc</code></strong></h5> +<table class="tableblock frame-ends grid-none stretch"> +<colgroup> +<col style="width: 11.1111%;"> +<col style="width: 88.8889%;"> +</colgroup> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Name</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Debug program counter</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Address</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x7b1</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Reset value</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>CPU_BOOT_ADDR</code>, CPU boot address, 4-byte aligned (see <a href="#_cpu_top_entity_generics">CPU Top Entity - Generics</a> and <a href="#_address_space">Address Space</a>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">ISA</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>Zicsr</code> &amp; <code>Sdext</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Description</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">The register is used to store the current program counter when debug mode is entered. The <code>dret</code> instruction will +return to the address stored in <code>dpc</code> by automatically moving <code>dpc</code> to the program counter.</p></td> +</tr> +</tbody> +</table> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<code>dpc[0]</code> is hardwired to zero. If <code>IALIGN</code> = 32 (i.e. <a href="#_c_isa_extension"><code>C</code> ISA Extension</a> is disabled) then <code>dpc[1]</code> is also hardwired to zero. +</td> +</tr> +</table> +</div> +</div> +<div class="sect4"> +<h5 id="_dscratch0"><strong><code>dscratch0</code></strong></h5> +<table class="tableblock frame-ends grid-none stretch"> +<colgroup> +<col style="width: 11.1111%;"> +<col style="width: 88.8889%;"> +</colgroup> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Name</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Debug scratch register 0</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Address</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x7b2</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Reset value</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x00000000</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">ISA</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>Zicsr</code> &amp; <code>Sdext</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Description</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">The register provides a general purpose debug mode-only scratch register.</p></td> +</tr> +</tbody> +</table> +<div style="page-break-after: always;"></div> +</div> +</div> +</div> +<div class="sect2"> +<h3 id="_trigger_module">5.4. Trigger Module</h3> +<div class="paragraph"> +<p>"Normal" <em>software</em> breakpoints (using GDB&#8217;s <code>b</code>/<code>break</code> command) are implemented by temporarily replacing the according +instruction word by an <code>[c.]ebreak</code> instruction. However, this is not possible when debugging code that is executed from +read-only memory (for example when debugging programs that are executed via the <a href="#_execute_in_place_module_xip">Execute In Place Module (XIP)</a>). +To circumvent this limitation a hardware trigger logic allows to (re-)enter debug-mode when instruction execution +reaches a programmable address. These "hardware-assisted breakpoints" are used by GDB&#8217;s <code>hb</code>/<code>hbreak</code> commands.</p> +</div> +<div class="paragraph"> +<p>The RISC-V <code>Sdtrig</code> ISA extension adds a programmable <em>trigger module</em> to the CPU core that is enabled via the +<a href="#_sdtrig_isa_extension"><code>Sdtrig</code> ISA Extension</a> generic. The trigger module implements a subset of the features described in the +"RISC-V Debug Specification / Trigger Module" and complies to version v1.0 of the <code>Sdtrig</code> spec.</p> +</div> +<div class="paragraph"> +<p>The NEORV32 trigger module features only a <em>single</em> trigger implementing a "type 6 - instruction address match" trigger. +This limitation is granted by the RISC-V debug spec and is sufficient to <strong>debug code executed from read-only memory (ROM)</strong>. +The trigger module can also be used independently of the CPU debug-mode / <code>Sdext</code> ISA extension. +Machine-mode software can use the trigger module to raise a breakpoint exception when instruction execution +reaches a programmed address.</p> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">Trigger Timing</div> +When enabled the address match trigger will fire <strong>BEFORE</strong> the instruction at the programmed address gets executed. +</td> +</tr> +</table> +</div> +<div class="admonitionblock warning"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-warning" title="Warning"></i> +</td> +<td class="content"> +<div class="title">MEPC &amp; DPC CSRs</div> +The breakpoint exception when raised by the trigger module behaves different then the "normal" trapping (see +<a href="#_neorv32_trap_listing">NEORV32 Trap Listing</a>): <a href="#_mepc"><strong><code>mepc</code></strong></a> / <a href="#_dpc"><strong><code>dpc</code></strong></a> is set to the address of the next instruction that needs to be +executed to preserve the program flow. A "normal" breakpoint exception would set <a href="#_mepc"><strong><code>mepc</code></strong></a> / <a href="#_dpc"><strong><code>dpc</code></strong></a> to the address +of the actual <code>ebreak</code> instruction itself. +</td> +</tr> +</table> +</div> +<div class="sect3"> +<h4 id="_trigger_module_csrs">5.4.1. Trigger Module CSRs</h4> +<div class="paragraph"> +<p>The <code>Sdtrig</code> ISA extension adds 4 additional CSRs that are accessible from debug-mode and also from machine-mode. +Machine-mode write accesses can be ignored by setting ´dmode´ in <a href="#_tdata1"><strong><code>tdata1</code></strong></a>. This is automatically done by the debugger +if it uses the trigger module for implementing a "hardware breakpoint"</p> +</div> +<div class="sect4"> +<h5 id="_tselect"><strong><code>tselect</code></strong></h5> +<table class="tableblock frame-ends grid-none stretch"> +<colgroup> +<col style="width: 11.1111%;"> +<col style="width: 88.8889%;"> +</colgroup> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Name</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Trigger select register</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Address</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x7a0</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Reset value</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x00000000</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">ISA</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>Zicsr</code> &amp; <code>Sdtrig</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Description</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">This CSR is hardwired to zero indicating there is only one trigger available. Any write access is ignored.</p></td> +</tr> +</tbody> +</table> +</div> +<div class="sect4"> +<h5 id="_tdata1"><strong><code>tdata1</code></strong></h5> +<table class="tableblock frame-ends grid-none stretch"> +<colgroup> +<col style="width: 11.1111%;"> +<col style="width: 88.8889%;"> +</colgroup> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Name</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Trigger data register 1, visible as trigger "type 6 match control" (<code>mcontrol6</code>)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Address</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x7a1</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Reset value</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x60000048</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">ISA</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>Zicsr</code> &amp; <code>Sdtrig</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Description</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">This CSR is used to configure the address match trigger using the "type 6" format.</p></td> +</tr> +</tbody> +</table> +<table class="tableblock frame-all grid-rows stretch"> +<caption class="title">Table 94. Match Control CSR (<code>tdata1</code>) Bits</caption> +<colgroup> +<col style="width: 8.3333%;"> +<col style="width: 16.6666%;"> +<col style="width: 8.3333%;"> +<col style="width: 66.6668%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-center valign-top">Bit</th> +<th class="tableblock halign-center valign-top">Name [RISC-V]</th> +<th class="tableblock halign-center valign-top">R/W</th> +<th class="tableblock halign-left valign-top">Description</th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">31:28</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>type</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0100</code> - address match trigger type 6</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">27</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>dmode</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">set to ignore write accesses to <a href="#_tdata1"><strong><code>tdata1</code></strong></a> and <a href="#_tdata2"><strong><code>tdata2</code></strong></a> from machine-mode; writable from debug-mode only</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">26</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>uncertain</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0</code> - trigger satisfies the configured conditions</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">25</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>hit1</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0</code> - hardwired to zero, only <code>hit0</code> is used</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">24</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>vs</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0</code> - VS-mode not supported</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">23</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>vu</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0</code> - VU-mode not supported</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">22</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>hit0</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/c</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">set when trigger has fired (<strong>BEFORE</strong> executing the triggering address); must be explicitly cleared by writing zero; writing 1 has no effect</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">21</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>select</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0</code> - only address matching is supported</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">20:19</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">reserved</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>00</code> - hardwired to zero</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">18:16</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>size</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>000</code> - match accesses of any size</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">15:12</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>action</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0000</code> = breakpoint exception on trigger match, <code>0001</code> = enter debug-mode on trigger match</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">11</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>chain</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0</code> - chaining is not supported as there is only one trigger</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">10:6</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>match</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0000</code> - equal-match only</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">6</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>m</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>1</code> - trigger enabled when in machine-mode</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">5</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>uncertainen</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0</code> - feature not supported, hardwired to zero</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">4</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>s</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0</code> - supervisor-mode not supported</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">3</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>u</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0</code>/<code>1</code> - trigger enabled when in user-mode, set if <code>U</code> ISA extension is enabled</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">2</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>execute</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/w</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">set to enable trigger matching on instruction address</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">1</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>store</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0</code> - store address/data matching not supported</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">0</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>load</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0</code> - load address/data matching not supported</p></td> +</tr> +</tbody> +</table> +</div> +<div class="sect4"> +<h5 id="_tdata2"><strong><code>tdata2</code></strong></h5> +<table class="tableblock frame-ends grid-none stretch"> +<colgroup> +<col style="width: 11.1111%;"> +<col style="width: 88.8889%;"> +</colgroup> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Name</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Trigger data register 2</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Address</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x7a2</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Reset value</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x00000000</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">ISA</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>Zicsr</code> &amp; <code>Sdtrig</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Description</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Since only the "address match trigger" type is supported, this r/w CSR is used to configure the address of the triggering instruction. +Note that the trigger module will fire <strong>before</strong> the instruction at the programmed address gets executed.</p></td> +</tr> +</tbody> +</table> +</div> +<div class="sect4"> +<h5 id="_tinfo"><strong><code>tinfo</code></strong></h5> +<table class="tableblock frame-ends grid-none stretch"> +<colgroup> +<col style="width: 11.1111%;"> +<col style="width: 88.8889%;"> +</colgroup> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Name</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Trigger information register</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Address</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x7a4</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Reset value</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x01000006</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">ISA</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>Zicsr</code> &amp; <code>Sdtrig</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock">Description</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">The CSR shows global trigger information (see below). Any write access is ignored.</p></td> +</tr> +</tbody> +</table> +<table class="tableblock frame-all grid-rows stretch"> +<caption class="title">Table 95. Trigger Info CSR (<code>tinfo</code>) Bits</caption> +<colgroup> +<col style="width: 8.3333%;"> +<col style="width: 16.6666%;"> +<col style="width: 8.3333%;"> +<col style="width: 66.6668%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-center valign-top">Bit</th> +<th class="tableblock halign-center valign-top">Name [RISC-V]</th> +<th class="tableblock halign-center valign-top">R/W</th> +<th class="tableblock halign-left valign-top">Description</th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">31:24</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>version</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x01</code> - compatible to spec. version v1.0</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">23:15</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">reserved</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x00</code> - hardwired to zero</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock">15:0</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>info</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">r/-</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>0x0006</code> - only the "type 6 trigger" is supported</p></td> +</tr> +</tbody> +</table> +<div style="page-break-after: always;"></div> +</div> +</div> +</div> +</div> +</div> +<div class="sect1"> +<h2 id="_legal">6. Legal</h2> +<div class="sectionbody"> +<div class="sect2"> +<h3 id="_about">About</h3> +<div class="exampleblock"> +<div class="content"> +<div class="paragraph"> +<p><strong>The NEORV32 RISC-V Processor</strong><br> +<a href="https://github.com/stnolting/neorv32" class="bare">https://github.com/stnolting/neorv32</a><br> +Dipl.-Ing. Stephan Nolting (M.Sc.)<br> +🇪🇺 European Union, Germany<br> +<a href="mailto:stnolting@gmail.com">stnolting@gmail.com</a></p> +</div> +</div> +</div> +</div> +<div class="sect2"> +<h3 id="_license">License</h3> +<div class="paragraph"> +<p><strong>BSD 3-Clause License</strong></p> +</div> +<div class="paragraph"> +<p>Copyright (c) NEORV32 contributors. +Copyright (c) 2020 - 2024, Stephan Nolting. All rights reserved.</p> +</div> +<div class="paragraph"> +<p>Redistribution and use in source and binary forms, with or without modification, are permitted provided that +the following conditions are met:</p> +</div> +<div class="olist arabic"> +<ol class="arabic"> +<li> +<p>Redistributions of source code must retain the above copyright notice, this list of conditions and the +following disclaimer.</p> +</li> +<li> +<p>Redistributions in binary form must reproduce the above copyright notice, this list of conditions and +the following disclaimer in the documentation and/or other materials provided with the distribution.</p> +</li> +<li> +<p>Neither the name of the copyright holder nor the names of its contributors may be used to endorse or +promote products derived from this software without specific prior written permission.</p> +</li> +</ol> +</div> +<div class="paragraph"> +<p>THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" +AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE +IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE +ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE +LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR +CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF +SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS +INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN +CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) +ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED +OF THE POSSIBILITY OF SUCH DAMAGE.</p> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">SPDX Identifier</div> +<code>SPDX-License-Identifier: BSD-3-Clause</code> +</td> +</tr> +</table> +</div> +<div style="page-break-after: always;"></div> +</div> +<div class="sect2"> +<h3 id="_proprietary_notice">Proprietary Notice</h3> +<div class="ulist"> +<ul> +<li> +<p>"GitHub" is a Subsidiary of Microsoft Corporation.</p> +</li> +<li> +<p>"Vivado" and "Artix" are trademarks of AMD Inc.</p> +</li> +<li> +<p>"AXI", "AXI", "AXI4-Lite", "AXI4-Stream", "AHB", "AHB3" and "AHB3-Lite" are trademarks of Arm Holdings plc.</p> +</li> +<li> +<p>"ModelSim" is a trademark of Mentor Graphics – A Siemens Business.</p> +</li> +<li> +<p>"Quartus Prime" and "Cyclone" are trademarks of Intel Corporation.</p> +</li> +<li> +<p>"iCE40", "UltraPlus" and "Radiant" are trademarks of Lattice Semiconductor Corporation.</p> +</li> +<li> +<p>"Windows" is a trademark of Microsoft Corporation.</p> +</li> +<li> +<p>"Tera Term" copyright by T. Teranishi.</p> +</li> +<li> +<p>"NeoPixel" is a trademark of Adafruit Industries.</p> +</li> +<li> +<p>"Segger Embedded Studio" and "J-Link" are trademarks of Segger Microcontroller Systems GmbH.</p> +</li> +<li> +<p>Images/figures made with <em>Microsoft Power Point</em>.</p> +</li> +<li> +<p>Timing diagrams made with <em>WaveDrom Editor</em>.</p> +</li> +<li> +<p>Documentation made with <code>asciidoctor</code>.</p> +</li> +</ul> +</div> +<div class="paragraph"> +<p>All further/unreferenced projects/products/brands belong to their according copyright holders. +No copyright infringement intended.</p> +</div> +</div> +<div class="sect2"> +<h3 id="_disclaimer">Disclaimer</h3> +<div class="paragraph"> +<p>This project is released under the BSD 3-Clause license. No copyright infringement intended. +Other implied or used projects/sources might have different licensing – see their according +documentation for more information.</p> +</div> +</div> +<div class="sect2"> +<h3 id="_limitation_of_liability_for_external_links">Limitation of Liability for External Links</h3> +<div class="paragraph"> +<p>This document contains links to the websites of third parties ("external links"). As the content of these websites +is not under our control, we cannot assume any liability for such external content. In all cases, the provider of +information of the linked websites is liable for the content and accuracy of the information provided. At the +point in time when the links were placed, no infringements of the law were recognizable to us. As soon as an +infringement of the law becomes known to us, we will immediately remove the link in question.</p> +</div> +</div> +<div class="sect2"> +<h3 id="_citing">Citing</h3> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +This is an open-source project that is free of charge. Use this project in any way you like +(as long as it complies to the permissive license). Please cite it appropriately. 👍 +</td> +</tr> +</table> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">Contributors &amp; Community 🤝</div> +Please add as many <a href="https://github.com/stnolting/neorv32/graphs/contributors">contributors</a> as possible to the <code>author</code> field.<br> +This project would not be where it is without them. +</td> +</tr> +</table> +</div> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +<div class="title">DOI</div> +This project provides a <em>digital object identifier</em> provided by <a href="https://zenodo.org">zenodo</a>: +<a href="https://doi.org/10.5281/zenodo.5018888"><span class="image"><img src="https://zenodo.org/badge/DOI/10.5281/zenodo.5018888.svg" alt="zenodo.5018888" title="zenodo"></span></a> +</td> +</tr> +</table> +</div> +</div> +<div class="sect2"> +<h3 id="_acknowledgments">Acknowledgments</h3> +<div class="paragraph"> +<p><strong>A big shout-out to the community and all the <a href="https://github.com/stnolting/neorv32/graphs/contributors">contributors</a>, +who helped improving this project! This project would not be where it is without them. ❤️</strong></p> +</div> +<div class="paragraph"> +<p><a href="https://riscv.org">RISC-V</a> - instruction sets want to be free!</p> +</div> +<div class="paragraph"> +<p>Continuous integration provided by <a href="https://github.com/features/actions">GitHub Actions</a> and powered by <a href="https://github.com/ghdl/ghdl">GHDL</a>.</p> +</div> +</div> +</div> +</div> +</div> +<div id="footer"> +<div id="footer-text"> +Version v1.10.1-r126-g74b0d5cf<br> +</div> +</div> +<script type="text/x-mathjax-config"> +MathJax.Hub.Config({ + messageStyle: "none", + tex2jax: { + inlineMath: [["\\(", "\\)"]], + displayMath: [["\\[", "\\]"]], + ignoreClass: "nostem|nolatexmath" + }, + asciimath2jax: { + delimiters: [["\\$", "\\$"]], + ignoreClass: "nostem|noasciimath" + }, + TeX: { equationNumbers: { autoNumber: "none" } } +}) +MathJax.Hub.Register.StartupHook("AsciiMath Jax Ready", function () { + MathJax.InputJax.AsciiMath.postfilterHooks.Add(function (data, node) { + if ((node = data.script.parentNode) && (node = node.parentNode) && node.classList.contains("stemblock")) { + data.math.root.display = "block" + } + return data + }) +}) +</script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.9/MathJax.js?config=TeX-MML-AM_HTMLorMML"></script> +</body> +</html> \ No newline at end of file diff --git a/sw/annotated.html b/sw/annotated.html new file mode 100644 index 0000000000..e6e646d19f --- /dev/null +++ b/sw/annotated.html @@ -0,0 +1,129 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: Data Structures</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +</div><!-- top --> +<div id="doc-content"> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div class="header"> + <div class="headertitle"><div class="title">Data Structures</div></div> +</div><!--header--> +<div class="contents"> +<div class="textblock">Here are the data structures with brief descriptions:</div><div class="directory"> +<table class="directory"> +<tr id="row_0_" class="even"><td class="entry"><span style="width:16px;display:inline-block;">&#160;</span><span class="icona"><span class="icon">C</span></span><a class="el" href="structdate__t.html" target="_self">date_t</a></td><td class="desc"></td></tr> +<tr id="row_1_" class="odd"><td class="entry"><span style="width:16px;display:inline-block;">&#160;</span><span class="icona"><span class="icon">C</span></span><a class="el" href="unionfloat__conv__t.html" target="_self">float_conv_t</a></td><td class="desc"></td></tr> +<tr id="row_2_" class="even"><td class="entry"><span style="width:16px;display:inline-block;">&#160;</span><span class="icona"><span class="icon">C</span></span><a class="el" href="structneorv32__cfs__t.html" target="_self">neorv32_cfs_t</a></td><td class="desc"></td></tr> +<tr id="row_3_" class="odd"><td class="entry"><span style="width:16px;display:inline-block;">&#160;</span><span class="icona"><span class="icon">C</span></span><a class="el" href="structneorv32__crc__t.html" target="_self">neorv32_crc_t</a></td><td class="desc"></td></tr> +<tr id="row_4_" class="even"><td class="entry"><span style="width:16px;display:inline-block;">&#160;</span><span class="icona"><span class="icon">C</span></span><a class="el" href="structneorv32__dma__t.html" target="_self">neorv32_dma_t</a></td><td class="desc"></td></tr> +<tr id="row_5_" class="odd"><td class="entry"><span style="width:16px;display:inline-block;">&#160;</span><span class="icona"><span class="icon">C</span></span><a class="el" href="structneorv32__gpio__t.html" target="_self">neorv32_gpio_t</a></td><td class="desc"></td></tr> +<tr id="row_6_" class="even"><td class="entry"><span style="width:16px;display:inline-block;">&#160;</span><span class="icona"><span class="icon">C</span></span><a class="el" href="structneorv32__gptmr__t.html" target="_self">neorv32_gptmr_t</a></td><td class="desc"></td></tr> +<tr id="row_7_" class="odd"><td class="entry"><span style="width:16px;display:inline-block;">&#160;</span><span class="icona"><span class="icon">C</span></span><a class="el" href="structneorv32__mtime__t.html" target="_self">neorv32_mtime_t</a></td><td class="desc"></td></tr> +<tr id="row_8_" class="even"><td class="entry"><span style="width:16px;display:inline-block;">&#160;</span><span class="icona"><span class="icon">C</span></span><a class="el" href="structneorv32__neoled__t.html" target="_self">neorv32_neoled_t</a></td><td class="desc"></td></tr> +<tr id="row_9_" class="odd"><td class="entry"><span style="width:16px;display:inline-block;">&#160;</span><span class="icona"><span class="icon">C</span></span><a class="el" href="structneorv32__onewire__t.html" target="_self">neorv32_onewire_t</a></td><td class="desc"></td></tr> +<tr id="row_10_" class="even"><td class="entry"><span style="width:16px;display:inline-block;">&#160;</span><span class="icona"><span class="icon">C</span></span><a class="el" href="structneorv32__pwm__t.html" target="_self">neorv32_pwm_t</a></td><td class="desc"></td></tr> +<tr id="row_11_" class="odd"><td class="entry"><span style="width:16px;display:inline-block;">&#160;</span><span class="icona"><span class="icon">C</span></span><a class="el" href="structneorv32__sdi__t.html" target="_self">neorv32_sdi_t</a></td><td class="desc"></td></tr> +<tr id="row_12_" class="even"><td class="entry"><span style="width:16px;display:inline-block;">&#160;</span><span class="icona"><span class="icon">C</span></span><a class="el" href="structneorv32__slink__t.html" target="_self">neorv32_slink_t</a></td><td class="desc"></td></tr> +<tr id="row_13_" class="odd"><td class="entry"><span style="width:16px;display:inline-block;">&#160;</span><span class="icona"><span class="icon">C</span></span><a class="el" href="structneorv32__spi__t.html" target="_self">neorv32_spi_t</a></td><td class="desc"></td></tr> +<tr id="row_14_" class="even"><td class="entry"><span style="width:16px;display:inline-block;">&#160;</span><span class="icona"><span class="icon">C</span></span><a class="el" href="structneorv32__sysinfo__t.html" target="_self">neorv32_sysinfo_t</a></td><td class="desc"></td></tr> +<tr id="row_15_" class="odd"><td class="entry"><span style="width:16px;display:inline-block;">&#160;</span><span class="icona"><span class="icon">C</span></span><a class="el" href="structneorv32__trng__t.html" target="_self">neorv32_trng_t</a></td><td class="desc"></td></tr> +<tr id="row_16_" class="even"><td class="entry"><span style="width:16px;display:inline-block;">&#160;</span><span class="icona"><span class="icon">C</span></span><a class="el" href="structneorv32__twi__t.html" target="_self">neorv32_twi_t</a></td><td class="desc"></td></tr> +<tr id="row_17_" class="odd"><td class="entry"><span style="width:16px;display:inline-block;">&#160;</span><span class="icona"><span class="icon">C</span></span><a class="el" href="structneorv32__uart__t.html" target="_self">neorv32_uart_t</a></td><td class="desc"></td></tr> +<tr id="row_18_" class="even"><td class="entry"><span style="width:16px;display:inline-block;">&#160;</span><span class="icona"><span class="icon">C</span></span><a class="el" href="structneorv32__wdt__t.html" target="_self">neorv32_wdt_t</a></td><td class="desc"></td></tr> +<tr id="row_19_" class="odd"><td class="entry"><span style="width:16px;display:inline-block;">&#160;</span><span class="icona"><span class="icon">C</span></span><a class="el" href="structneorv32__xip__t.html" target="_self">neorv32_xip_t</a></td><td class="desc"></td></tr> +<tr id="row_20_" class="even"><td class="entry"><span style="width:16px;display:inline-block;">&#160;</span><span class="icona"><span class="icon">C</span></span><a class="el" href="structneorv32__xirq__t.html" target="_self">neorv32_xirq_t</a></td><td class="desc"></td></tr> +<tr id="row_21_" class="odd"><td class="entry"><span style="width:16px;display:inline-block;">&#160;</span><span class="icona"><span class="icon">C</span></span><a class="el" href="structrecord.html" target="_self">record</a></td><td class="desc"></td></tr> +<tr id="row_22_" class="even"><td class="entry"><span style="width:16px;display:inline-block;">&#160;</span><span class="icona"><span class="icon">C</span></span><a class="el" href="unionsubwords16__t.html" target="_self">subwords16_t</a></td><td class="desc"></td></tr> +<tr id="row_23_" class="odd"><td class="entry"><span style="width:16px;display:inline-block;">&#160;</span><span class="icona"><span class="icon">C</span></span><a class="el" href="unionsubwords32__t.html" target="_self">subwords32_t</a></td><td class="desc"></td></tr> +<tr id="row_24_" class="even"><td class="entry"><span style="width:16px;display:inline-block;">&#160;</span><span class="icona"><span class="icon">C</span></span><a class="el" href="unionsubwords64__t.html" target="_self">subwords64_t</a></td><td class="desc"></td></tr> +<tr id="row_25_" class="odd"><td class="entry"><span style="width:16px;display:inline-block;">&#160;</span><span class="icona"><span class="icon">C</span></span><a class="el" href="structt__neorv32__spi.html" target="_self">t_neorv32_spi</a></td><td class="desc"></td></tr> +</table> +</div><!-- directory --> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/atomic__test_2main_8c.html b/sw/atomic__test_2main_8c.html new file mode 100644 index 0000000000..bb5283f995 --- /dev/null +++ b/sw/atomic__test_2main_8c.html @@ -0,0 +1,308 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/example/atomic_test/main.c File Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_f0f9b27afba2e8cc2da6e5fddcc1a8c9.html">example</a></li><li class="navelem"><a class="el" href="dir_449d8ba5f8b78dc90092f20d15a2386a.html">atomic_test</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="headertitle"><div class="title">main.c File Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p>Test program for the NEORV32 'A' ISA extension - check the emulation of the AMO (read-modify-write) operations. +<a href="#details">More...</a></p> +<div class="textblock"><code>#include &lt;<a class="el" href="neorv32_8h_source.html">neorv32.h</a>&gt;</code><br /> +</div><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader">User configuration</h2></td></tr> +<tr class="memitem:ad4455691936f92fdd6c37566fc58ba1f" id="r_ad4455691936f92fdd6c37566fc58ba1f"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ad4455691936f92fdd6c37566fc58ba1f">BAUD_RATE</a>&#160;&#160;&#160;(19200)</td></tr> +<tr class="separator:ad4455691936f92fdd6c37566fc58ba1f"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a83792c34853f1d2801b59ad46adc7e1e" id="r_a83792c34853f1d2801b59ad46adc7e1e"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a83792c34853f1d2801b59ad46adc7e1e">NUM_TEST_CASES</a>&#160;&#160;&#160;(1000)</td></tr> +<tr class="separator:a83792c34853f1d2801b59ad46adc7e1e"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a87f296d7594bb8178cf76f0c045b7013" id="r_a87f296d7594bb8178cf76f0c045b7013"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a87f296d7594bb8178cf76f0c045b7013">SILENT_MODE</a>&#160;&#160;&#160;(1)</td></tr> +<tr class="separator:a87f296d7594bb8178cf76f0c045b7013"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a9141e95a5f98420ddf8a43e6d20ff6dc" id="r_a9141e95a5f98420ddf8a43e6d20ff6dc"><td class="memItemLeft" align="right" valign="top">volatile uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a9141e95a5f98420ddf8a43e6d20ff6dc">amo_var</a></td></tr> +<tr class="separator:a9141e95a5f98420ddf8a43e6d20ff6dc"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a4f4c6d8481b4100f90955ba5a70428a4" id="r_a4f4c6d8481b4100f90955ba5a70428a4"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a4f4c6d8481b4100f90955ba5a70428a4">check_result</a> (uint32_t num, uint32_t amo_var_old, uint32_t amo_var_pre, uint32_t amo_var_new, uint32_t <a class="el" href="#a9141e95a5f98420ddf8a43e6d20ff6dc">amo_var</a>)</td></tr> +<tr class="separator:a4f4c6d8481b4100f90955ba5a70428a4"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a99377a057d14aaa9b45f8cab890e8cf7" id="r_a99377a057d14aaa9b45f8cab890e8cf7"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a99377a057d14aaa9b45f8cab890e8cf7">print_report</a> (int num_err, int num_tests)</td></tr> +<tr class="separator:a99377a057d14aaa9b45f8cab890e8cf7"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aafcbf639ae4f66e5dfe9dea511a59f9d" id="r_aafcbf639ae4f66e5dfe9dea511a59f9d"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aafcbf639ae4f66e5dfe9dea511a59f9d">trap_handler_emulate_amo</a> (void)</td></tr> +<tr class="separator:aafcbf639ae4f66e5dfe9dea511a59f9d"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ae66f6b31b5ad750f1fe042a706a4e3d4" id="r_ae66f6b31b5ad750f1fe042a706a4e3d4"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ae66f6b31b5ad750f1fe042a706a4e3d4">main</a> ()</td></tr> +<tr class="separator:ae66f6b31b5ad750f1fe042a706a4e3d4"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>Test program for the NEORV32 'A' ISA extension - check the emulation of the AMO (read-modify-write) operations. </p> +<dl class="section author"><dt>Author</dt><dd>Stephan Nolting </dd></dl> +</div><h2 class="groupheader">Macro Definition Documentation</h2> +<a id="ad4455691936f92fdd6c37566fc58ba1f" name="ad4455691936f92fdd6c37566fc58ba1f"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ad4455691936f92fdd6c37566fc58ba1f">&#9670;&#160;</a></span>BAUD_RATE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define BAUD_RATE&#160;&#160;&#160;(19200)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>UART BAUD rate </p> + +</div> +</div> +<a id="a83792c34853f1d2801b59ad46adc7e1e" name="a83792c34853f1d2801b59ad46adc7e1e"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a83792c34853f1d2801b59ad46adc7e1e">&#9670;&#160;</a></span>NUM_TEST_CASES</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define NUM_TEST_CASES&#160;&#160;&#160;(1000)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>UART BAUD rate </p> + +</div> +</div> +<a id="a87f296d7594bb8178cf76f0c045b7013" name="a87f296d7594bb8178cf76f0c045b7013"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a87f296d7594bb8178cf76f0c045b7013">&#9670;&#160;</a></span>SILENT_MODE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define SILENT_MODE&#160;&#160;&#160;(1)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>UART BAUD rate </p> + +</div> +</div> +<h2 class="groupheader">Function Documentation</h2> +<a id="a4f4c6d8481b4100f90955ba5a70428a4" name="a4f4c6d8481b4100f90955ba5a70428a4"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a4f4c6d8481b4100f90955ba5a70428a4">&#9670;&#160;</a></span>check_result()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t check_result </td> + <td>(</td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>num</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>amo_var_old</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>amo_var_pre</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>amo_var_new</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>amo_var</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Check results (reference (SW) vs actual hardware).</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">num</td><td>Test case number </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">amo_var_old</td><td>Initial value of atomic variable. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">amo_var_pre</td><td>Value of atomic variable read from memory (before operation). </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">amo_var_new</td><td>Expected new value of atomic variable. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">amo_var</td><td>Actual new value of atomic variable. </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>zero if results are correct. </dd></dl> + +</div> +</div> +<a id="ae66f6b31b5ad750f1fe042a706a4e3d4" name="ae66f6b31b5ad750f1fe042a706a4e3d4"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ae66f6b31b5ad750f1fe042a706a4e3d4">&#9670;&#160;</a></span>main()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int main </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Main function; test all provided AMO emulation functions.</p> +<dl class="section note"><dt>Note</dt><dd>This program requires the RISC-V A CPU extension.</dd></dl> +<dl class="section return"><dt>Returns</dt><dd>Irrelevant. </dd></dl> + +</div> +</div> +<a id="a99377a057d14aaa9b45f8cab890e8cf7" name="a99377a057d14aaa9b45f8cab890e8cf7"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a99377a057d14aaa9b45f8cab890e8cf7">&#9670;&#160;</a></span>print_report()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void print_report </td> + <td>(</td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>num_err</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>num_tests</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Print test report.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">num_err</td><td>Number or errors in this test. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">num_tests</td><td>Total number of conducted tests. </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="aafcbf639ae4f66e5dfe9dea511a59f9d" name="aafcbf639ae4f66e5dfe9dea511a59f9d"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aafcbf639ae4f66e5dfe9dea511a59f9d">&#9670;&#160;</a></span>trap_handler_emulate_amo()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void trap_handler_emulate_amo </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Emulate atomic memory operation.</p> +<dl class="section note"><dt>Note</dt><dd>This is a RTE "second-level" trap handler. </dd></dl> + +</div> +</div> +<h2 class="groupheader">Variable Documentation</h2> +<a id="a9141e95a5f98420ddf8a43e6d20ff6dc" name="a9141e95a5f98420ddf8a43e6d20ff6dc"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a9141e95a5f98420ddf8a43e6d20ff6dc">&#9670;&#160;</a></span>amo_var</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">volatile uint32_t amo_var</td> + </tr> + </table> +</div><div class="memdoc"> +<p>UART BAUD rate </p> + +</div> +</div> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/bc_s.png b/sw/bc_s.png new file mode 100644 index 0000000000000000000000000000000000000000..224b29aa9847d5a4b3902efd602b7ddf7d33e6c2 GIT binary patch literal 676 zcmV;V0$crwP)<h;3K|Lk000e1NJLTq000O80015c1^@s65rAI}0007ONkl<ZcmeI5 z%WD%+6voe;xyj6=NhXt~4{e$zF*P<SZp4L@2Hd!iQY<tJD@e5{RU55hl&Talf{KWb zN*6A=C`Gqz5#NvcXzNOCOH(I9n<#?l<k5ws2omoMCgj%s3y1G=&gJ~>y__>=_9%My z{n931IS})GlGUF8K#6VIbs%684A^L3@%PlP2>_sk`UWPq@f;rU*V%rPy_ekbhXT&s z(GN{DxFv}*vZp`F>S!r||M`I*nOwwKX+BC~3P5N3-)Y{65c;ywYiAh-1*hZcToLHK ztpl1xomJ+Yb}K(cfbJr2=GNOnT!UFA7Vy~fBz8?J>XHsbZoDad^8PxfSa0GDgENZS zuLCEqzb*xWX2CG*b&5IiO#NzrW*;`VC9455M`o1NBh+(k8~`XCEEoC1Ybwf;vr4K3 zg|EB<07?SOqHp9DhLpS&bzgo70I+ghB_#)K7H%AMU3v}xuyQq9&Bm~++VYhF09a+U zl7>n7Jjm$K#b*FONz~fj;I->Bf;ule1prFN9FovcDGBkpg>)O*-}eLnC{6oZHZ$o% zXKW$;0_{8hxHQ>l;_*HATI(`7t#^{$(zLe}h*mqwOc*nRY9=?Sx4OOeVIfI|0V(V2 zBrW#G7Ss9wvzr@>H*`r>zE<Gz)cj&*s5lRy$b&*W@2j<GZEpXZ$P|Z!4Q$_|`5gj> z+e8bOBgqIgldUJlG(YUDviMB`9+DH8n-s9SXRLyJHO1!=wY^79WYZMTa(wiZ!zP66 zA~!21vmF3H2{ngD;+`6j#~6j;$*f*G_2ZD1E;9(yaw7d-QnSCpK(cR1zU3qU0000< KMNUMnLSTYoA~SLT literal 0 HcmV?d00001 diff --git a/sw/bc_sd.png b/sw/bc_sd.png new file mode 100644 index 0000000000000000000000000000000000000000..31ca888dc71049713b35c351933a8d0f36180bf1 GIT binary patch literal 635 zcmV->0)+jEP)<h;3K|Lk000e1NJLTq000O80015c1^@s65rAI}0006)Nkl<ZcmeI5 z%WD%+6vn?hGsz_BG}An0CMId~a1z?2@1!l&KD1&hN-bD~LQoLFg%1h=btAfQrT8}# z3Wb7hbmdl%7_p+bkU-OdEt;+haU+O==ZX_E^FIvdH|INN4tMUkkG+_kSV4Z~DiQ-{ z;P(0visfy<EG{=E&fjlNuRPJr;xe4DqlF9WF1aJGbq{R<c>Jwi0r1~gdSq#w{Bu1q z`craw(p2!<S-^e8ry2oOOW$qO-@LFDq=px{zr>hu$4C_$Oc3X(sI6e=9QSTwPt{G) z=htT&^~&c~L2~e{r5_5SYe7#Is-$ln>~Kd<Pyf6{jQBpfP;O2vJy5MYx^t)6*`&7L zk1yW4Y2_GywLP=M2DSV{5Z#%B-6~kD_XGf&edtglet$T5qp?$c$)cGl05-eEMCrPb z82v&mFR>%$F#tC65?{LvQ}8O`A~RBB0N~`2M+waajO;5>3B&-viHGJeEK2TQOiPRa zfDKyqwMc4wfaEh4jt>H`nW_Zidwk@Bowp`}(VUaj-pSI(-1L>FJVsX}Yl9~JsqgsZ zUD9(rMwf23Gez6KPa|wwInZodP-2}9@fK0Ga_9{8SOjU&4l`pH4@qlQp83>>HT$xW zER^U>)MyV%t(Lu=`d=Y?{k1@}&r7ZGkFQ%z%N+sE9BtYjovzxyxCPxN6&@wLK{soQ zSmkj$aLI}miuE^p@~4}mg9OjDfGEkgY4~^XzLRUBB*O{+&vq<3v(E%+k_i%=`~j%{ Vj14gnt9}3g002ovPDHLkV1n!oC4m3{ literal 0 HcmV?d00001 diff --git a/sw/bootloader_8c.html b/sw/bootloader_8c.html new file mode 100644 index 0000000000..27a8ecdd00 --- /dev/null +++ b/sw/bootloader_8c.html @@ -0,0 +1,1184 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/bootloader/bootloader.c File Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_4316bb0e553b51b8b65560981547ce0f.html">bootloader</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#define-members">Macros</a> &#124; +<a href="#enum-members">Enumerations</a> &#124; +<a href="#func-members">Functions</a> &#124; +<a href="#var-members">Variables</a> </div> + <div class="headertitle"><div class="title">bootloader.c File Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p>Default NEORV32 bootloader. +<a href="#details">More...</a></p> +<div class="textblock"><code>#include &lt;stdint.h&gt;</code><br /> +<code>#include &lt;<a class="el" href="neorv32_8h_source.html">neorv32.h</a>&gt;</code><br /> +</div><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="define-members" name="define-members"></a> +Macros</h2></td></tr> +<tr class="memitem:a0035ad41f622dbfc2412318a8ed39257" id="r_a0035ad41f622dbfc2412318a8ed39257"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a0035ad41f622dbfc2412318a8ed39257">EXE_SIGNATURE</a>&#160;&#160;&#160;0x4788CAFE</td></tr> +<tr class="separator:a0035ad41f622dbfc2412318a8ed39257"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr><td colspan="2"><div class="groupHeader">Bootloader configuration (override via console to customize);</div></td></tr> +<tr><td colspan="2"><div class="groupText"><p>default values are used if not explicitly customized </p> +</div></td></tr> +<tr class="memitem:a18936dc79b9e5aa84df016b046a6b977" id="r_a18936dc79b9e5aa84df016b046a6b977"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a18936dc79b9e5aa84df016b046a6b977">EXE_BASE_ADDR</a>&#160;&#160;&#160;0x00000000UL</td></tr> +<tr class="separator:a18936dc79b9e5aa84df016b046a6b977"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:af1c2f103ac6e3183f08b39099fab2be9" id="r_af1c2f103ac6e3183f08b39099fab2be9"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#af1c2f103ac6e3183f08b39099fab2be9">UART_EN</a>&#160;&#160;&#160;1</td></tr> +<tr class="separator:af1c2f103ac6e3183f08b39099fab2be9"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a1fac9153314479ad0ad495d752f0224a" id="r_a1fac9153314479ad0ad495d752f0224a"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a1fac9153314479ad0ad495d752f0224a">UART_BAUD</a>&#160;&#160;&#160;19200</td></tr> +<tr class="separator:a1fac9153314479ad0ad495d752f0224a"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a20e93d623ce07939c3fdd53898f9d583" id="r_a20e93d623ce07939c3fdd53898f9d583"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a20e93d623ce07939c3fdd53898f9d583">UART_HW_HANDSHAKE_EN</a>&#160;&#160;&#160;0</td></tr> +<tr class="separator:a20e93d623ce07939c3fdd53898f9d583"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aa9696325b450773c7a87c991abca3a54" id="r_aa9696325b450773c7a87c991abca3a54"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aa9696325b450773c7a87c991abca3a54">STATUS_LED_EN</a>&#160;&#160;&#160;1</td></tr> +<tr class="separator:aa9696325b450773c7a87c991abca3a54"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a089a71f836911c71b3f73fdd3b4b890b" id="r_a089a71f836911c71b3f73fdd3b4b890b"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a089a71f836911c71b3f73fdd3b4b890b">STATUS_LED_PIN</a>&#160;&#160;&#160;0</td></tr> +<tr class="separator:a089a71f836911c71b3f73fdd3b4b890b"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:af6fcb607a9c320da869b72aa30893a69" id="r_af6fcb607a9c320da869b72aa30893a69"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#af6fcb607a9c320da869b72aa30893a69">AUTO_BOOT_TIMEOUT</a>&#160;&#160;&#160;10</td></tr> +<tr class="separator:af6fcb607a9c320da869b72aa30893a69"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aea75cf0485ce0a4ea320eba994859686" id="r_aea75cf0485ce0a4ea320eba994859686"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aea75cf0485ce0a4ea320eba994859686">SPI_EN</a>&#160;&#160;&#160;1</td></tr> +<tr class="separator:aea75cf0485ce0a4ea320eba994859686"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aa2132454aada86216009f3af206899b1" id="r_aa2132454aada86216009f3af206899b1"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aa2132454aada86216009f3af206899b1">SPI_FLASH_CS</a>&#160;&#160;&#160;0</td></tr> +<tr class="separator:aa2132454aada86216009f3af206899b1"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:afe60a31c8561952f2f734fd67e6f7406" id="r_afe60a31c8561952f2f734fd67e6f7406"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#afe60a31c8561952f2f734fd67e6f7406">SPI_FLASH_ADDR_BYTES</a>&#160;&#160;&#160;3</td></tr> +<tr class="separator:afe60a31c8561952f2f734fd67e6f7406"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a00924a8ba223b2ca0e7031259b292c84" id="r_a00924a8ba223b2ca0e7031259b292c84"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a00924a8ba223b2ca0e7031259b292c84">SPI_FLASH_SECTOR_SIZE</a>&#160;&#160;&#160;65536</td></tr> +<tr class="separator:a00924a8ba223b2ca0e7031259b292c84"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a709071a651213770b4efe6e6e055ec3d" id="r_a709071a651213770b4efe6e6e055ec3d"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a709071a651213770b4efe6e6e055ec3d">SPI_FLASH_CLK_PRSC</a>&#160;&#160;&#160;<a class="el" href="neorv32_8h.html#a10022df4c223533b04d5aebe222e8b73aa4e3a6a5b3cd895f63b4544f63ce22c9">CLK_PRSC_8</a></td></tr> +<tr class="separator:a709071a651213770b4efe6e6e055ec3d"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a418adcf57119600c3580fd2297d28de0" id="r_a418adcf57119600c3580fd2297d28de0"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a418adcf57119600c3580fd2297d28de0">SPI_BOOT_BASE_ADDR</a>&#160;&#160;&#160;0x00400000UL</td></tr> +<tr class="separator:a418adcf57119600c3580fd2297d28de0"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a2cf31934b909299fb93bb5eebdbc7c9e" id="r_a2cf31934b909299fb93bb5eebdbc7c9e"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a2cf31934b909299fb93bb5eebdbc7c9e">XIP_EN</a>&#160;&#160;&#160;1</td></tr> +<tr class="separator:a2cf31934b909299fb93bb5eebdbc7c9e"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr><td colspan="2"><div class="groupHeader"></div></td></tr> +<tr class="memitem:aff6b53dd58cea43d24393a9a2f79e772" id="r_aff6b53dd58cea43d24393a9a2f79e772"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aff6b53dd58cea43d24393a9a2f79e772">xstr</a>(a)&#160;&#160;&#160;<a class="el" href="#af6cf19e40e97afb5a7c29f7b439d091d">str</a>(a)</td></tr> +<tr class="separator:aff6b53dd58cea43d24393a9a2f79e772"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:af6cf19e40e97afb5a7c29f7b439d091d" id="r_af6cf19e40e97afb5a7c29f7b439d091d"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#af6cf19e40e97afb5a7c29f7b439d091d">str</a>(a)&#160;&#160;&#160;#a</td></tr> +<tr class="separator:af6cf19e40e97afb5a7c29f7b439d091d"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a0e5a66f68ecc7a6f42088f349707e852" id="r_a0e5a66f68ecc7a6f42088f349707e852"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a0e5a66f68ecc7a6f42088f349707e852">PRINT_TEXT</a>(...)</td></tr> +<tr class="separator:a0e5a66f68ecc7a6f42088f349707e852"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a2f5cc04cf9c85f5d2958b384e053053b" id="r_a2f5cc04cf9c85f5d2958b384e053053b"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a2f5cc04cf9c85f5d2958b384e053053b">PRINT_XNUM</a>(a)</td></tr> +<tr class="separator:a2f5cc04cf9c85f5d2958b384e053053b"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a999b04603115ce08b0cb33e333312480" id="r_a999b04603115ce08b0cb33e333312480"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a999b04603115ce08b0cb33e333312480">PRINT_GETC</a>(a)&#160;&#160;&#160;0</td></tr> +<tr class="separator:a999b04603115ce08b0cb33e333312480"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aa7afbe8348ebd1a876a4d247553292e9" id="r_aa7afbe8348ebd1a876a4d247553292e9"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aa7afbe8348ebd1a876a4d247553292e9">PRINT_PUTC</a>(a)</td></tr> +<tr class="separator:aa7afbe8348ebd1a876a4d247553292e9"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="enum-members" name="enum-members"></a> +Enumerations</h2></td></tr> +<tr class="memitem:abcbf77626fdd0b475d245f836eab7a83" id="r_abcbf77626fdd0b475d245f836eab7a83"><td class="memItemLeft" align="right" valign="top">enum &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#abcbf77626fdd0b475d245f836eab7a83">EXE_STREAM_SOURCE_enum</a> { <a class="el" href="#abcbf77626fdd0b475d245f836eab7a83ab149261ddf3f08e44e9d2538e384f58f">EXE_STREAM_UART</a> = 0 +, <a class="el" href="#abcbf77626fdd0b475d245f836eab7a83a98526cd8f81d570c57d98193b32cf114">EXE_STREAM_FLASH</a> = 1 + }</td></tr> +<tr class="separator:abcbf77626fdd0b475d245f836eab7a83"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aa0c639898508ff8e4fab6290101f3088" id="r_aa0c639898508ff8e4fab6290101f3088"><td class="memItemLeft" align="right" valign="top">enum &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aa0c639898508ff8e4fab6290101f3088">ERROR_CODES_enum</a> { <a class="el" href="#aa0c639898508ff8e4fab6290101f3088ad41014563cb3ca69ab69b94d43e97caa">ERROR_SIGNATURE</a> = 0 +, <a class="el" href="#aa0c639898508ff8e4fab6290101f3088a2d77ed1c715fb969a1faa01c71625f2d">ERROR_SIZE</a> = 1 +, <a class="el" href="#aa0c639898508ff8e4fab6290101f3088a471ebe6c0766abc6fa4e82a09bfdb985">ERROR_CHECKSUM</a> = 2 +, <a class="el" href="#aa0c639898508ff8e4fab6290101f3088a684d6723fa25e7651e13d99fb249363c">ERROR_FLASH</a> = 3 + }</td></tr> +<tr class="separator:aa0c639898508ff8e4fab6290101f3088"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aa5e5723e4cbf83805c3b1197cd401fed" id="r_aa5e5723e4cbf83805c3b1197cd401fed"><td class="memItemLeft" align="right" valign="top">enum &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aa5e5723e4cbf83805c3b1197cd401fed">SPI_FLASH_CMD_enum</a> { <br /> +&#160;&#160;<a class="el" href="#aa5e5723e4cbf83805c3b1197cd401feda31c8d698c551d081a0adeafb988ed49e">SPI_FLASH_CMD_PAGE_PROGRAM</a> = 0x02 +, <a class="el" href="#aa5e5723e4cbf83805c3b1197cd401feda6c1994ba2cfd97e0c77dcdf8bbdfdfa6">SPI_FLASH_CMD_READ</a> = 0x03 +, <a class="el" href="#aa5e5723e4cbf83805c3b1197cd401fedaa91d3c1d788b21fc798a5976c9f0da77">SPI_FLASH_CMD_WRITE_DISABLE</a> = 0x04 +, <a class="el" href="#aa5e5723e4cbf83805c3b1197cd401feda5fbc6551a10549b38e5ab4a76c38f214">SPI_FLASH_CMD_READ_STATUS</a> = 0x05 +, <br /> +&#160;&#160;<a class="el" href="#aa5e5723e4cbf83805c3b1197cd401feda152e091e93778f217f8b766298351513">SPI_FLASH_CMD_WRITE_ENABLE</a> = 0x06 +, <a class="el" href="#aa5e5723e4cbf83805c3b1197cd401feda25bf16cd42b1fd1d95e0957b5be137d2">SPI_FLASH_CMD_WAKE</a> = 0xAB +, <a class="el" href="#aa5e5723e4cbf83805c3b1197cd401fedacd62141d6331f66e31bd252e2a92b836">SPI_FLASH_CMD_SECTOR_ERASE</a> = 0xD8 +<br /> + }</td></tr> +<tr class="separator:aa5e5723e4cbf83805c3b1197cd401fed"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a97299f563ebc1fca4c663b025a15136f" id="r_a97299f563ebc1fca4c663b025a15136f"><td class="memItemLeft" align="right" valign="top">enum &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a97299f563ebc1fca4c663b025a15136f">SPI_FLASH_SREG_enum</a> { <a class="el" href="#a97299f563ebc1fca4c663b025a15136fa133cd87673ce9a612da494583e03dae9">FLASH_SREG_BUSY</a> = 0 +, <a class="el" href="#a97299f563ebc1fca4c663b025a15136fa22e8c983d74430ea0930e37781e88bf9">FLASH_SREG_WEL</a> = 1 + }</td></tr> +<tr class="separator:a97299f563ebc1fca4c663b025a15136f"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a165a347c51d8aae06a564a2f297f2feb" id="r_a165a347c51d8aae06a564a2f297f2feb"><td class="memItemLeft" align="right" valign="top">enum &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a165a347c51d8aae06a564a2f297f2feb">NEORV32_EXECUTABLE_enum</a> { <a class="el" href="#a165a347c51d8aae06a564a2f297f2feba61100996f309c45b8b628ade2e3acc7f">EXE_OFFSET_SIGNATURE</a> = 0 +, <a class="el" href="#a165a347c51d8aae06a564a2f297f2febacc430caa4bff2fef4568c757893fe2fe">EXE_OFFSET_SIZE</a> = 4 +, <a class="el" href="#a165a347c51d8aae06a564a2f297f2febabc27a855096a70dca0f8bc148a123be4">EXE_OFFSET_CHECKSUM</a> = 8 +, <a class="el" href="#a165a347c51d8aae06a564a2f297f2febaea032c54a21057710ef2021638972ce6">EXE_OFFSET_DATA</a> = 12 + }</td></tr> +<tr class="separator:a165a347c51d8aae06a564a2f297f2feb"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="func-members" name="func-members"></a> +Functions</h2></td></tr> +<tr class="memitem:af13b4b3d5e6597feacf331e6d16b08e9" id="r_af13b4b3d5e6597feacf331e6d16b08e9"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#af13b4b3d5e6597feacf331e6d16b08e9">bootloader_trap_handler</a> (void)</td></tr> +<tr class="separator:af13b4b3d5e6597feacf331e6d16b08e9"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a402ea961bfc2ffeee61e3a7c330b1559" id="r_a402ea961bfc2ffeee61e3a7c330b1559"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a402ea961bfc2ffeee61e3a7c330b1559">print_help</a> (void)</td></tr> +<tr class="separator:a402ea961bfc2ffeee61e3a7c330b1559"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ae8de91537ac2782f0f0ebc3b2d4fb1df" id="r_ae8de91537ac2782f0f0ebc3b2d4fb1df"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ae8de91537ac2782f0f0ebc3b2d4fb1df">start_app</a> (int boot_xip)</td></tr> +<tr class="separator:ae8de91537ac2782f0f0ebc3b2d4fb1df"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ac18819795adb6dbdd52b0587e7fbb569" id="r_ac18819795adb6dbdd52b0587e7fbb569"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ac18819795adb6dbdd52b0587e7fbb569">get_exe</a> (int src)</td></tr> +<tr class="separator:ac18819795adb6dbdd52b0587e7fbb569"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ababfffe8e7036179e150ad3b9bda3a74" id="r_ababfffe8e7036179e150ad3b9bda3a74"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ababfffe8e7036179e150ad3b9bda3a74">save_exe</a> (void)</td></tr> +<tr class="separator:ababfffe8e7036179e150ad3b9bda3a74"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ac58d9f7dc79a549bde1cb50f619c19af" id="r_ac58d9f7dc79a549bde1cb50f619c19af"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ac58d9f7dc79a549bde1cb50f619c19af">get_exe_word</a> (int src, uint32_t addr)</td></tr> +<tr class="separator:ac58d9f7dc79a549bde1cb50f619c19af"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a3bdfe2f25b1bfb42f80624ffff22ab01" id="r_a3bdfe2f25b1bfb42f80624ffff22ab01"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a3bdfe2f25b1bfb42f80624ffff22ab01">system_error</a> (uint8_t err_code)</td></tr> +<tr class="separator:a3bdfe2f25b1bfb42f80624ffff22ab01"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a70b7d5c3b3ae97e4e72e84c4bc28fb8a" id="r_a70b7d5c3b3ae97e4e72e84c4bc28fb8a"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a70b7d5c3b3ae97e4e72e84c4bc28fb8a">print_hex_word</a> (uint32_t num)</td></tr> +<tr class="separator:a70b7d5c3b3ae97e4e72e84c4bc28fb8a"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a1fbdccc60f05756213c9f3d64bac6d47" id="r_a1fbdccc60f05756213c9f3d64bac6d47"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a1fbdccc60f05756213c9f3d64bac6d47">spi_flash_wakeup</a> (void)</td></tr> +<tr class="separator:a1fbdccc60f05756213c9f3d64bac6d47"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a1919595ed2232aebb3e774b916ab1662" id="r_a1919595ed2232aebb3e774b916ab1662"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a1919595ed2232aebb3e774b916ab1662">spi_flash_check</a> (void)</td></tr> +<tr class="separator:a1919595ed2232aebb3e774b916ab1662"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a09e72e2debdd94929b2be4c7713d5e17" id="r_a09e72e2debdd94929b2be4c7713d5e17"><td class="memItemLeft" align="right" valign="top">uint8_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a09e72e2debdd94929b2be4c7713d5e17">spi_flash_read_byte</a> (uint32_t addr)</td></tr> +<tr class="separator:a09e72e2debdd94929b2be4c7713d5e17"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a006c27b7d80897b78ab8cd83a391331f" id="r_a006c27b7d80897b78ab8cd83a391331f"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a006c27b7d80897b78ab8cd83a391331f">spi_flash_write_byte</a> (uint32_t addr, uint8_t wdata)</td></tr> +<tr class="separator:a006c27b7d80897b78ab8cd83a391331f"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a717c72166af7c2ff7e73bd0b47128338" id="r_a717c72166af7c2ff7e73bd0b47128338"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a717c72166af7c2ff7e73bd0b47128338">spi_flash_write_word</a> (uint32_t addr, uint32_t wdata)</td></tr> +<tr class="separator:a717c72166af7c2ff7e73bd0b47128338"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a0d877f0611dfcee32a483c8a3660eb1b" id="r_a0d877f0611dfcee32a483c8a3660eb1b"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a0d877f0611dfcee32a483c8a3660eb1b">spi_flash_erase_sector</a> (uint32_t addr)</td></tr> +<tr class="separator:a0d877f0611dfcee32a483c8a3660eb1b"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a9642e28ef2baec5b356ad9a70970d0e6" id="r_a9642e28ef2baec5b356ad9a70970d0e6"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a9642e28ef2baec5b356ad9a70970d0e6">spi_flash_write_enable</a> (void)</td></tr> +<tr class="separator:a9642e28ef2baec5b356ad9a70970d0e6"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a82d26a2d6293ed7fd44a5c622adfbd45" id="r_a82d26a2d6293ed7fd44a5c622adfbd45"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a82d26a2d6293ed7fd44a5c622adfbd45">spi_flash_write_disable</a> (void)</td></tr> +<tr class="separator:a82d26a2d6293ed7fd44a5c622adfbd45"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a005966cd0b32f3d5c041028c4b1c99f5" id="r_a005966cd0b32f3d5c041028c4b1c99f5"><td class="memItemLeft" align="right" valign="top">uint8_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a005966cd0b32f3d5c041028c4b1c99f5">spi_flash_read_status</a> (void)</td></tr> +<tr class="separator:a005966cd0b32f3d5c041028c4b1c99f5"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a6a8caddda6e729d747726471b0b0f742" id="r_a6a8caddda6e729d747726471b0b0f742"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a6a8caddda6e729d747726471b0b0f742">spi_flash_write_addr</a> (uint32_t addr)</td></tr> +<tr class="separator:a6a8caddda6e729d747726471b0b0f742"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a840291bc02cba5474a4cb46a9b9566fe" id="r_a840291bc02cba5474a4cb46a9b9566fe"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a840291bc02cba5474a4cb46a9b9566fe">main</a> (void)</td></tr> +<tr class="separator:a840291bc02cba5474a4cb46a9b9566fe"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="var-members" name="var-members"></a> +Variables</h2></td></tr> +<tr class="memitem:a6fea855ffe2fa0cd5ea9f98c0d5adc4d" id="r_a6fea855ffe2fa0cd5ea9f98c0d5adc4d"><td class="memItemLeft" align="right" valign="top">const char&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a6fea855ffe2fa0cd5ea9f98c0d5adc4d">error_message</a> [4][5]</td></tr> +<tr class="separator:a6fea855ffe2fa0cd5ea9f98c0d5adc4d"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a0f9fcfdf758260b9b79b6eda063dd87a" id="r_a0f9fcfdf758260b9b79b6eda063dd87a"><td class="memItemLeft" align="right" valign="top">volatile uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a0f9fcfdf758260b9b79b6eda063dd87a">exe_available</a></td></tr> +<tr class="separator:a0f9fcfdf758260b9b79b6eda063dd87a"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a5fa6b109bf211d1768f84c9d38eef240" id="r_a5fa6b109bf211d1768f84c9d38eef240"><td class="memItemLeft" align="right" valign="top">volatile uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a5fa6b109bf211d1768f84c9d38eef240">getting_exe</a></td></tr> +<tr class="separator:a5fa6b109bf211d1768f84c9d38eef240"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>Default NEORV32 bootloader. </p> +</div><h2 class="groupheader">Macro Definition Documentation</h2> +<a id="af6fcb607a9c320da869b72aa30893a69" name="af6fcb607a9c320da869b72aa30893a69"></a> +<h2 class="memtitle"><span class="permalink"><a href="#af6fcb607a9c320da869b72aa30893a69">&#9670;&#160;</a></span>AUTO_BOOT_TIMEOUT</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define AUTO_BOOT_TIMEOUT&#160;&#160;&#160;10</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Time until the auto-boot sequence starts (in seconds); 0 = disabled </p> + +</div> +</div> +<a id="a18936dc79b9e5aa84df016b046a6b977" name="a18936dc79b9e5aa84df016b046a6b977"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a18936dc79b9e5aa84df016b046a6b977">&#9670;&#160;</a></span>EXE_BASE_ADDR</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define EXE_BASE_ADDR&#160;&#160;&#160;0x00000000UL</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Memory base address for the executable </p> + +</div> +</div> +<a id="a0035ad41f622dbfc2412318a8ed39257" name="a0035ad41f622dbfc2412318a8ed39257"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a0035ad41f622dbfc2412318a8ed39257">&#9670;&#160;</a></span>EXE_SIGNATURE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define EXE_SIGNATURE&#160;&#160;&#160;0x4788CAFE</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Valid executable identification signature </p> + +</div> +</div> +<a id="a999b04603115ce08b0cb33e333312480" name="a999b04603115ce08b0cb33e333312480"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a999b04603115ce08b0cb33e333312480">&#9670;&#160;</a></span>PRINT_GETC</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define PRINT_GETC</td> + <td>(</td> + <td class="paramtype"></td> <td class="paramname"><span class="paramname"><em>a</em></span></td><td>)</td> + <td>&#160;&#160;&#160;0</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Helper macros Actual define-to-string helper </p> + +</div> +</div> +<a id="aa7afbe8348ebd1a876a4d247553292e9" name="aa7afbe8348ebd1a876a4d247553292e9"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aa7afbe8348ebd1a876a4d247553292e9">&#9670;&#160;</a></span>PRINT_PUTC</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define PRINT_PUTC</td> + <td>(</td> + <td class="paramtype"></td> <td class="paramname"><span class="paramname"><em>a</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Helper macros Actual define-to-string helper </p> + +</div> +</div> +<a id="a0e5a66f68ecc7a6f42088f349707e852" name="a0e5a66f68ecc7a6f42088f349707e852"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a0e5a66f68ecc7a6f42088f349707e852">&#9670;&#160;</a></span>PRINT_TEXT</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define PRINT_TEXT</td> + <td>(</td> + <td class="paramtype"></td> <td class="paramname"><span class="paramname"><em></em></span>...</td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Print to UART 0 </p> + +</div> +</div> +<a id="a2f5cc04cf9c85f5d2958b384e053053b" name="a2f5cc04cf9c85f5d2958b384e053053b"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a2f5cc04cf9c85f5d2958b384e053053b">&#9670;&#160;</a></span>PRINT_XNUM</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define PRINT_XNUM</td> + <td>(</td> + <td class="paramtype"></td> <td class="paramname"><span class="paramname"><em>a</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Helper macros Actual define-to-string helper </p> + +</div> +</div> +<a id="a418adcf57119600c3580fd2297d28de0" name="a418adcf57119600c3580fd2297d28de0"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a418adcf57119600c3580fd2297d28de0">&#9670;&#160;</a></span>SPI_BOOT_BASE_ADDR</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define SPI_BOOT_BASE_ADDR&#160;&#160;&#160;0x00400000UL</td> + </tr> + </table> +</div><div class="memdoc"> +<p>SPI flash boot base address </p> + +</div> +</div> +<a id="aea75cf0485ce0a4ea320eba994859686" name="aea75cf0485ce0a4ea320eba994859686"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aea75cf0485ce0a4ea320eba994859686">&#9670;&#160;</a></span>SPI_EN</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define SPI_EN&#160;&#160;&#160;1</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Enable SPI (default) including SPI flash boot options </p> + +</div> +</div> +<a id="afe60a31c8561952f2f734fd67e6f7406" name="afe60a31c8561952f2f734fd67e6f7406"></a> +<h2 class="memtitle"><span class="permalink"><a href="#afe60a31c8561952f2f734fd67e6f7406">&#9670;&#160;</a></span>SPI_FLASH_ADDR_BYTES</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define SPI_FLASH_ADDR_BYTES&#160;&#160;&#160;3</td> + </tr> + </table> +</div><div class="memdoc"> +<p>SPI flash address width (in numbers of bytes; 2,3,4) </p> + +</div> +</div> +<a id="a709071a651213770b4efe6e6e055ec3d" name="a709071a651213770b4efe6e6e055ec3d"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a709071a651213770b4efe6e6e055ec3d">&#9670;&#160;</a></span>SPI_FLASH_CLK_PRSC</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define SPI_FLASH_CLK_PRSC&#160;&#160;&#160;<a class="el" href="neorv32_8h.html#a10022df4c223533b04d5aebe222e8b73aa4e3a6a5b3cd895f63b4544f63ce22c9">CLK_PRSC_8</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>SPI flash clock pre-scaler; see <a class="el" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3b">NEORV32_SPI_CTRL_enum</a> </p> + +</div> +</div> +<a id="aa2132454aada86216009f3af206899b1" name="aa2132454aada86216009f3af206899b1"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aa2132454aada86216009f3af206899b1">&#9670;&#160;</a></span>SPI_FLASH_CS</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define SPI_FLASH_CS&#160;&#160;&#160;0</td> + </tr> + </table> +</div><div class="memdoc"> +<p>SPI flash chip select (low-active) at SPI.spi_csn_o(SPI_FLASH_CS) </p> + +</div> +</div> +<a id="a00924a8ba223b2ca0e7031259b292c84" name="a00924a8ba223b2ca0e7031259b292c84"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a00924a8ba223b2ca0e7031259b292c84">&#9670;&#160;</a></span>SPI_FLASH_SECTOR_SIZE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define SPI_FLASH_SECTOR_SIZE&#160;&#160;&#160;65536</td> + </tr> + </table> +</div><div class="memdoc"> +<p>SPI flash sector size in bytes </p> + +</div> +</div> +<a id="aa9696325b450773c7a87c991abca3a54" name="aa9696325b450773c7a87c991abca3a54"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aa9696325b450773c7a87c991abca3a54">&#9670;&#160;</a></span>STATUS_LED_EN</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define STATUS_LED_EN&#160;&#160;&#160;1</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Set to 0 to disable bootloader status LED (heart beat) at GPIO.gpio_o(STATUS_LED_PIN) </p> + +</div> +</div> +<a id="a089a71f836911c71b3f73fdd3b4b890b" name="a089a71f836911c71b3f73fdd3b4b890b"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a089a71f836911c71b3f73fdd3b4b890b">&#9670;&#160;</a></span>STATUS_LED_PIN</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define STATUS_LED_PIN&#160;&#160;&#160;0</td> + </tr> + </table> +</div><div class="memdoc"> +<p>GPIO output pin for high-active bootloader status LED (heart beat) </p> + +</div> +</div> +<a id="af6cf19e40e97afb5a7c29f7b439d091d" name="af6cf19e40e97afb5a7c29f7b439d091d"></a> +<h2 class="memtitle"><span class="permalink"><a href="#af6cf19e40e97afb5a7c29f7b439d091d">&#9670;&#160;</a></span>str</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define str</td> + <td>(</td> + <td class="paramtype"></td> <td class="paramname"><span class="paramname"><em>a</em></span></td><td>)</td> + <td>&#160;&#160;&#160;#a</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Internal helper macro </p> + +</div> +</div> +<a id="a1fac9153314479ad0ad495d752f0224a" name="a1fac9153314479ad0ad495d752f0224a"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a1fac9153314479ad0ad495d752f0224a">&#9670;&#160;</a></span>UART_BAUD</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define UART_BAUD&#160;&#160;&#160;19200</td> + </tr> + </table> +</div><div class="memdoc"> +<p>UART BAUD rate for serial interface </p> + +</div> +</div> +<a id="af1c2f103ac6e3183f08b39099fab2be9" name="af1c2f103ac6e3183f08b39099fab2be9"></a> +<h2 class="memtitle"><span class="permalink"><a href="#af1c2f103ac6e3183f08b39099fab2be9">&#9670;&#160;</a></span>UART_EN</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define UART_EN&#160;&#160;&#160;1</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Set to 0 to disable UART interface </p> + +</div> +</div> +<a id="a20e93d623ce07939c3fdd53898f9d583" name="a20e93d623ce07939c3fdd53898f9d583"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a20e93d623ce07939c3fdd53898f9d583">&#9670;&#160;</a></span>UART_HW_HANDSHAKE_EN</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define UART_HW_HANDSHAKE_EN&#160;&#160;&#160;0</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Set to 1 to enable UART HW handshaking </p> + +</div> +</div> +<a id="a2cf31934b909299fb93bb5eebdbc7c9e" name="a2cf31934b909299fb93bb5eebdbc7c9e"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a2cf31934b909299fb93bb5eebdbc7c9e">&#9670;&#160;</a></span>XIP_EN</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define XIP_EN&#160;&#160;&#160;1</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Enable XIP boot options </p> + +</div> +</div> +<a id="aff6b53dd58cea43d24393a9a2f79e772" name="aff6b53dd58cea43d24393a9a2f79e772"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aff6b53dd58cea43d24393a9a2f79e772">&#9670;&#160;</a></span>xstr</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define xstr</td> + <td>(</td> + <td class="paramtype"></td> <td class="paramname"><span class="paramname"><em>a</em></span></td><td>)</td> + <td>&#160;&#160;&#160;<a class="el" href="#af6cf19e40e97afb5a7c29f7b439d091d">str</a>(a)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Helper macros Actual define-to-string helper </p> + +</div> +</div> +<h2 class="groupheader">Enumeration Type Documentation</h2> +<a id="aa0c639898508ff8e4fab6290101f3088" name="aa0c639898508ff8e4fab6290101f3088"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aa0c639898508ff8e4fab6290101f3088">&#9670;&#160;</a></span>ERROR_CODES_enum</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">enum <a class="el" href="#aa0c639898508ff8e4fab6290101f3088">ERROR_CODES_enum</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Error codes </p> +<table class="fieldtable"> +<tr><th colspan="2">Enumerator</th></tr><tr><td class="fieldname"><a id="aa0c639898508ff8e4fab6290101f3088ad41014563cb3ca69ab69b94d43e97caa" name="aa0c639898508ff8e4fab6290101f3088ad41014563cb3ca69ab69b94d43e97caa"></a>ERROR_SIGNATURE&#160;</td><td class="fielddoc"><p>0: Wrong signature in executable </p> +</td></tr> +<tr><td class="fieldname"><a id="aa0c639898508ff8e4fab6290101f3088a2d77ed1c715fb969a1faa01c71625f2d" name="aa0c639898508ff8e4fab6290101f3088a2d77ed1c715fb969a1faa01c71625f2d"></a>ERROR_SIZE&#160;</td><td class="fielddoc"><p>1: Insufficient instruction memory capacity </p> +</td></tr> +<tr><td class="fieldname"><a id="aa0c639898508ff8e4fab6290101f3088a471ebe6c0766abc6fa4e82a09bfdb985" name="aa0c639898508ff8e4fab6290101f3088a471ebe6c0766abc6fa4e82a09bfdb985"></a>ERROR_CHECKSUM&#160;</td><td class="fielddoc"><p>2: Checksum error in executable </p> +</td></tr> +<tr><td class="fieldname"><a id="aa0c639898508ff8e4fab6290101f3088a684d6723fa25e7651e13d99fb249363c" name="aa0c639898508ff8e4fab6290101f3088a684d6723fa25e7651e13d99fb249363c"></a>ERROR_FLASH&#160;</td><td class="fielddoc"><p>3: SPI flash access error </p> +</td></tr> +</table> + +</div> +</div> +<a id="abcbf77626fdd0b475d245f836eab7a83" name="abcbf77626fdd0b475d245f836eab7a83"></a> +<h2 class="memtitle"><span class="permalink"><a href="#abcbf77626fdd0b475d245f836eab7a83">&#9670;&#160;</a></span>EXE_STREAM_SOURCE_enum</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">enum <a class="el" href="#abcbf77626fdd0b475d245f836eab7a83">EXE_STREAM_SOURCE_enum</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Executable stream source select (for copying into IMEM) </p> +<table class="fieldtable"> +<tr><th colspan="2">Enumerator</th></tr><tr><td class="fieldname"><a id="abcbf77626fdd0b475d245f836eab7a83ab149261ddf3f08e44e9d2538e384f58f" name="abcbf77626fdd0b475d245f836eab7a83ab149261ddf3f08e44e9d2538e384f58f"></a>EXE_STREAM_UART&#160;</td><td class="fielddoc"><p>Get executable via UART </p> +</td></tr> +<tr><td class="fieldname"><a id="abcbf77626fdd0b475d245f836eab7a83a98526cd8f81d570c57d98193b32cf114" name="abcbf77626fdd0b475d245f836eab7a83a98526cd8f81d570c57d98193b32cf114"></a>EXE_STREAM_FLASH&#160;</td><td class="fielddoc"><p>Get executable via SPI flash </p> +</td></tr> +</table> + +</div> +</div> +<a id="a165a347c51d8aae06a564a2f297f2feb" name="a165a347c51d8aae06a564a2f297f2feb"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a165a347c51d8aae06a564a2f297f2feb">&#9670;&#160;</a></span>NEORV32_EXECUTABLE_enum</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">enum <a class="el" href="#a165a347c51d8aae06a564a2f297f2feb">NEORV32_EXECUTABLE_enum</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>NEORV32 executable </p> +<table class="fieldtable"> +<tr><th colspan="2">Enumerator</th></tr><tr><td class="fieldname"><a id="a165a347c51d8aae06a564a2f297f2feba61100996f309c45b8b628ade2e3acc7f" name="a165a347c51d8aae06a564a2f297f2feba61100996f309c45b8b628ade2e3acc7f"></a>EXE_OFFSET_SIGNATURE&#160;</td><td class="fielddoc"><p>Offset in bytes from start to signature (32-bit) </p> +</td></tr> +<tr><td class="fieldname"><a id="a165a347c51d8aae06a564a2f297f2febacc430caa4bff2fef4568c757893fe2fe" name="a165a347c51d8aae06a564a2f297f2febacc430caa4bff2fef4568c757893fe2fe"></a>EXE_OFFSET_SIZE&#160;</td><td class="fielddoc"><p>Offset in bytes from start to size (32-bit) </p> +</td></tr> +<tr><td class="fieldname"><a id="a165a347c51d8aae06a564a2f297f2febabc27a855096a70dca0f8bc148a123be4" name="a165a347c51d8aae06a564a2f297f2febabc27a855096a70dca0f8bc148a123be4"></a>EXE_OFFSET_CHECKSUM&#160;</td><td class="fielddoc"><p>Offset in bytes from start to checksum (32-bit) </p> +</td></tr> +<tr><td class="fieldname"><a id="a165a347c51d8aae06a564a2f297f2febaea032c54a21057710ef2021638972ce6" name="a165a347c51d8aae06a564a2f297f2febaea032c54a21057710ef2021638972ce6"></a>EXE_OFFSET_DATA&#160;</td><td class="fielddoc"><p>Offset in bytes from start to data (32-bit) </p> +</td></tr> +</table> + +</div> +</div> +<a id="aa5e5723e4cbf83805c3b1197cd401fed" name="aa5e5723e4cbf83805c3b1197cd401fed"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aa5e5723e4cbf83805c3b1197cd401fed">&#9670;&#160;</a></span>SPI_FLASH_CMD_enum</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">enum <a class="el" href="#aa5e5723e4cbf83805c3b1197cd401fed">SPI_FLASH_CMD_enum</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>SPI flash commands </p> +<table class="fieldtable"> +<tr><th colspan="2">Enumerator</th></tr><tr><td class="fieldname"><a id="aa5e5723e4cbf83805c3b1197cd401feda31c8d698c551d081a0adeafb988ed49e" name="aa5e5723e4cbf83805c3b1197cd401feda31c8d698c551d081a0adeafb988ed49e"></a>SPI_FLASH_CMD_PAGE_PROGRAM&#160;</td><td class="fielddoc"><p>Program page </p> +</td></tr> +<tr><td class="fieldname"><a id="aa5e5723e4cbf83805c3b1197cd401feda6c1994ba2cfd97e0c77dcdf8bbdfdfa6" name="aa5e5723e4cbf83805c3b1197cd401feda6c1994ba2cfd97e0c77dcdf8bbdfdfa6"></a>SPI_FLASH_CMD_READ&#160;</td><td class="fielddoc"><p>Read data </p> +</td></tr> +<tr><td class="fieldname"><a id="aa5e5723e4cbf83805c3b1197cd401fedaa91d3c1d788b21fc798a5976c9f0da77" name="aa5e5723e4cbf83805c3b1197cd401fedaa91d3c1d788b21fc798a5976c9f0da77"></a>SPI_FLASH_CMD_WRITE_DISABLE&#160;</td><td class="fielddoc"><p>Disallow write access </p> +</td></tr> +<tr><td class="fieldname"><a id="aa5e5723e4cbf83805c3b1197cd401feda5fbc6551a10549b38e5ab4a76c38f214" name="aa5e5723e4cbf83805c3b1197cd401feda5fbc6551a10549b38e5ab4a76c38f214"></a>SPI_FLASH_CMD_READ_STATUS&#160;</td><td class="fielddoc"><p>Get status register </p> +</td></tr> +<tr><td class="fieldname"><a id="aa5e5723e4cbf83805c3b1197cd401feda152e091e93778f217f8b766298351513" name="aa5e5723e4cbf83805c3b1197cd401feda152e091e93778f217f8b766298351513"></a>SPI_FLASH_CMD_WRITE_ENABLE&#160;</td><td class="fielddoc"><p>Allow write access </p> +</td></tr> +<tr><td class="fieldname"><a id="aa5e5723e4cbf83805c3b1197cd401feda25bf16cd42b1fd1d95e0957b5be137d2" name="aa5e5723e4cbf83805c3b1197cd401feda25bf16cd42b1fd1d95e0957b5be137d2"></a>SPI_FLASH_CMD_WAKE&#160;</td><td class="fielddoc"><p>Wake up from sleep mode </p> +</td></tr> +<tr><td class="fieldname"><a id="aa5e5723e4cbf83805c3b1197cd401fedacd62141d6331f66e31bd252e2a92b836" name="aa5e5723e4cbf83805c3b1197cd401fedacd62141d6331f66e31bd252e2a92b836"></a>SPI_FLASH_CMD_SECTOR_ERASE&#160;</td><td class="fielddoc"><p>Erase complete sector </p> +</td></tr> +</table> + +</div> +</div> +<a id="a97299f563ebc1fca4c663b025a15136f" name="a97299f563ebc1fca4c663b025a15136f"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a97299f563ebc1fca4c663b025a15136f">&#9670;&#160;</a></span>SPI_FLASH_SREG_enum</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">enum <a class="el" href="#a97299f563ebc1fca4c663b025a15136f">SPI_FLASH_SREG_enum</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>SPI flash status register bits </p> +<table class="fieldtable"> +<tr><th colspan="2">Enumerator</th></tr><tr><td class="fieldname"><a id="a97299f563ebc1fca4c663b025a15136fa133cd87673ce9a612da494583e03dae9" name="a97299f563ebc1fca4c663b025a15136fa133cd87673ce9a612da494583e03dae9"></a>FLASH_SREG_BUSY&#160;</td><td class="fielddoc"><p>Busy, write/erase in progress when set, read-only </p> +</td></tr> +<tr><td class="fieldname"><a id="a97299f563ebc1fca4c663b025a15136fa22e8c983d74430ea0930e37781e88bf9" name="a97299f563ebc1fca4c663b025a15136fa22e8c983d74430ea0930e37781e88bf9"></a>FLASH_SREG_WEL&#160;</td><td class="fielddoc"><p>Write access enabled when set, read-only </p> +</td></tr> +</table> + +</div> +</div> +<h2 class="groupheader">Function Documentation</h2> +<a id="af13b4b3d5e6597feacf331e6d16b08e9" name="af13b4b3d5e6597feacf331e6d16b08e9"></a> +<h2 class="memtitle"><span class="permalink"><a href="#af13b4b3d5e6597feacf331e6d16b08e9">&#9670;&#160;</a></span>bootloader_trap_handler()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void bootloader_trap_handler </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Function prototypes</p> +<p>Bootloader trap handler. Used for the MTIME tick and to capture any other traps.</p> +<dl class="section note"><dt>Note</dt><dd>Since we have no runtime environment we have to use the interrupt attribute here. </dd></dl> + +</div> +</div> +<a id="ac18819795adb6dbdd52b0587e7fbb569" name="ac18819795adb6dbdd52b0587e7fbb569"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ac18819795adb6dbdd52b0587e7fbb569">&#9670;&#160;</a></span>get_exe()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void get_exe </td> + <td>(</td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>src</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Get executable stream.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramname">src</td><td>Source of executable stream data. See <a class="el" href="#abcbf77626fdd0b475d245f836eab7a83">EXE_STREAM_SOURCE_enum</a>. </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="ac58d9f7dc79a549bde1cb50f619c19af" name="ac58d9f7dc79a549bde1cb50f619c19af"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ac58d9f7dc79a549bde1cb50f619c19af">&#9670;&#160;</a></span>get_exe_word()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t get_exe_word </td> + <td>(</td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>src</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>addr</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Get word from executable stream</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramname">src</td><td>Source of executable stream data. See <a class="el" href="#abcbf77626fdd0b475d245f836eab7a83">EXE_STREAM_SOURCE_enum</a>. </td></tr> + <tr><td class="paramname">addr</td><td>Address when accessing SPI flash. </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>32-bit data word from stream. </dd></dl> + +</div> +</div> +<a id="a840291bc02cba5474a4cb46a9b9566fe" name="a840291bc02cba5474a4cb46a9b9566fe"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a840291bc02cba5474a4cb46a9b9566fe">&#9670;&#160;</a></span>main()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int main </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Sanity check: Base RV32I ISA only! Bootloader main. </p> + +</div> +</div> +<a id="a402ea961bfc2ffeee61e3a7c330b1559" name="a402ea961bfc2ffeee61e3a7c330b1559"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a402ea961bfc2ffeee61e3a7c330b1559">&#9670;&#160;</a></span>print_help()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void print_help </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Print help menu. </p> + +</div> +</div> +<a id="a70b7d5c3b3ae97e4e72e84c4bc28fb8a" name="a70b7d5c3b3ae97e4e72e84c4bc28fb8a"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a70b7d5c3b3ae97e4e72e84c4bc28fb8a">&#9670;&#160;</a></span>print_hex_word()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void print_hex_word </td> + <td>(</td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>num</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Print 32-bit number as 8-digit hexadecimal value (with "0x" suffix).</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">num</td><td>Number to print as hexadecimal. </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="ababfffe8e7036179e150ad3b9bda3a74" name="ababfffe8e7036179e150ad3b9bda3a74"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ababfffe8e7036179e150ad3b9bda3a74">&#9670;&#160;</a></span>save_exe()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void save_exe </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Store content of instruction memory to SPI flash. </p> + +</div> +</div> +<a id="a1919595ed2232aebb3e774b916ab1662" name="a1919595ed2232aebb3e774b916ab1662"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a1919595ed2232aebb3e774b916ab1662">&#9670;&#160;</a></span>spi_flash_check()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int spi_flash_check </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Check if SPI and flash are available/working by making sure the WEL flag of the flash status register can be set and cleared again.</p> +<dl class="section return"><dt>Returns</dt><dd>0 if success, -1 if error </dd></dl> + +</div> +</div> +<a id="a0d877f0611dfcee32a483c8a3660eb1b" name="a0d877f0611dfcee32a483c8a3660eb1b"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a0d877f0611dfcee32a483c8a3660eb1b">&#9670;&#160;</a></span>spi_flash_erase_sector()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void spi_flash_erase_sector </td> + <td>(</td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>addr</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Erase sector (64kB) at base address.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">addr</td><td>Base address of sector to erase. </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="a09e72e2debdd94929b2be4c7713d5e17" name="a09e72e2debdd94929b2be4c7713d5e17"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a09e72e2debdd94929b2be4c7713d5e17">&#9670;&#160;</a></span>spi_flash_read_byte()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint8_t spi_flash_read_byte </td> + <td>(</td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>addr</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Read byte from SPI flash.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">addr</td><td>Flash read address. </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Read byte from SPI flash. </dd></dl> + +</div> +</div> +<a id="a005966cd0b32f3d5c041028c4b1c99f5" name="a005966cd0b32f3d5c041028c4b1c99f5"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a005966cd0b32f3d5c041028c4b1c99f5">&#9670;&#160;</a></span>spi_flash_read_status()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint8_t spi_flash_read_status </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Read flash status register.</p> +<dl class="section return"><dt>Returns</dt><dd>SPI flash status register (32-bit zero-extended). </dd></dl> + +</div> +</div> +<a id="a1fbdccc60f05756213c9f3d64bac6d47" name="a1fbdccc60f05756213c9f3d64bac6d47"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a1fbdccc60f05756213c9f3d64bac6d47">&#9670;&#160;</a></span>spi_flash_wakeup()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void spi_flash_wakeup </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Wake up flash from deep sleep state </p> + +</div> +</div> +<a id="a6a8caddda6e729d747726471b0b0f742" name="a6a8caddda6e729d747726471b0b0f742"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a6a8caddda6e729d747726471b0b0f742">&#9670;&#160;</a></span>spi_flash_write_addr()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void spi_flash_write_addr </td> + <td>(</td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>addr</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Send address word to flash (MSB-first, 16-bit, 24-bit or 32-bit address size).</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">addr</td><td>Address word. </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="a006c27b7d80897b78ab8cd83a391331f" name="a006c27b7d80897b78ab8cd83a391331f"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a006c27b7d80897b78ab8cd83a391331f">&#9670;&#160;</a></span>spi_flash_write_byte()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void spi_flash_write_byte </td> + <td>(</td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>addr</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">uint8_t</td> <td class="paramname"><span class="paramname"><em>wdata</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Write byte to SPI flash.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">addr</td><td>SPI flash read address. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">wdata</td><td>SPI flash read data. </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="a82d26a2d6293ed7fd44a5c622adfbd45" name="a82d26a2d6293ed7fd44a5c622adfbd45"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a82d26a2d6293ed7fd44a5c622adfbd45">&#9670;&#160;</a></span>spi_flash_write_disable()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void spi_flash_write_disable </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Disable flash write access. </p> + +</div> +</div> +<a id="a9642e28ef2baec5b356ad9a70970d0e6" name="a9642e28ef2baec5b356ad9a70970d0e6"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a9642e28ef2baec5b356ad9a70970d0e6">&#9670;&#160;</a></span>spi_flash_write_enable()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void spi_flash_write_enable </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Enable flash write access. </p> + +</div> +</div> +<a id="a717c72166af7c2ff7e73bd0b47128338" name="a717c72166af7c2ff7e73bd0b47128338"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a717c72166af7c2ff7e73bd0b47128338">&#9670;&#160;</a></span>spi_flash_write_word()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void spi_flash_write_word </td> + <td>(</td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>addr</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>wdata</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Write word to SPI flash.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramname">addr</td><td>SPI flash write address. </td></tr> + <tr><td class="paramname">wdata</td><td>SPI flash write data. </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="ae8de91537ac2782f0f0ebc3b2d4fb1df" name="ae8de91537ac2782f0f0ebc3b2d4fb1df"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ae8de91537ac2782f0f0ebc3b2d4fb1df">&#9670;&#160;</a></span>start_app()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void start_app </td> + <td>(</td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>boot_xip</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Start application program.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramname">boot_xip</td><td>Set to boot via XIP. </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="a3bdfe2f25b1bfb42f80624ffff22ab01" name="a3bdfe2f25b1bfb42f80624ffff22ab01"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a3bdfe2f25b1bfb42f80624ffff22ab01">&#9670;&#160;</a></span>system_error()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void system_error </td> + <td>(</td> + <td class="paramtype">uint8_t</td> <td class="paramname"><span class="paramname"><em>err_code</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Output system error ID and halt.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">err_code</td><td>Error code. See #ERROR_CODES and <a class="el" href="#a6fea855ffe2fa0cd5ea9f98c0d5adc4d">error_message</a>. </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<h2 class="groupheader">Variable Documentation</h2> +<a id="a6fea855ffe2fa0cd5ea9f98c0d5adc4d" name="a6fea855ffe2fa0cd5ea9f98c0d5adc4d"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a6fea855ffe2fa0cd5ea9f98c0d5adc4d">&#9670;&#160;</a></span>error_message</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">const char error_message[4][5]</td> + </tr> + </table> +</div><div class="memdoc"> +<b>Initial value:</b><div class="fragment"><div class="line">= {</div> +<div class="line"> <span class="stringliteral">&quot;EXE&quot;</span>,</div> +<div class="line"> <span class="stringliteral">&quot;SIZE&quot;</span>,</div> +<div class="line"> <span class="stringliteral">&quot;CHKS&quot;</span>,</div> +<div class="line"> <span class="stringliteral">&quot;FLSH&quot;</span></div> +<div class="line">}</div> +</div><!-- fragment --><p>Error messages </p> + +</div> +</div> +<a id="a0f9fcfdf758260b9b79b6eda063dd87a" name="a0f9fcfdf758260b9b79b6eda063dd87a"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a0f9fcfdf758260b9b79b6eda063dd87a">&#9670;&#160;</a></span>exe_available</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">volatile uint32_t exe_available</td> + </tr> + </table> +</div><div class="memdoc"> +<p>This global variable keeps the size of the available executable in bytes. If =0 no executable is available (yet). </p> + +</div> +</div> +<a id="a5fa6b109bf211d1768f84c9d38eef240" name="a5fa6b109bf211d1768f84c9d38eef240"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a5fa6b109bf211d1768f84c9d38eef240">&#9670;&#160;</a></span>getting_exe</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">volatile uint32_t getting_exe</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Only set during executable fetch (required for capturing STORE BUS-TIMOUT exception). </p> + +</div> +</div> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/bus__explorer_2main_8c.html b/sw/bus__explorer_2main_8c.html new file mode 100644 index 0000000000..bec35287d1 --- /dev/null +++ b/sw/bus__explorer_2main_8c.html @@ -0,0 +1,299 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/example/bus_explorer/main.c File Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_f0f9b27afba2e8cc2da6e5fddcc1a8c9.html">example</a></li><li class="navelem"><a class="el" href="dir_0d2921e55a1172a4726516961ee96ab5.html">bus_explorer</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#func-members">Functions</a> &#124; +<a href="#var-members">Variables</a> </div> + <div class="headertitle"><div class="title">main.c File Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p>Interactive memory inspector. +<a href="#details">More...</a></p> +<div class="textblock"><code>#include &lt;<a class="el" href="neorv32_8h_source.html">neorv32.h</a>&gt;</code><br /> +<code>#include &lt;string.h&gt;</code><br /> +</div><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="define-members" name="define-members"></a> +Macros</h2></td></tr> +<tr><td colspan="2"><div class="groupHeader">User configuration</div></td></tr> +<tr class="memitem:ad4455691936f92fdd6c37566fc58ba1f" id="r_ad4455691936f92fdd6c37566fc58ba1f"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ad4455691936f92fdd6c37566fc58ba1f">BAUD_RATE</a>&#160;&#160;&#160;19200</td></tr> +<tr class="separator:ad4455691936f92fdd6c37566fc58ba1f"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="func-members" name="func-members"></a> +Functions</h2></td></tr> +<tr class="memitem:afc9b1ab3db46eccf51d55c715fa2fbd4" id="r_afc9b1ab3db46eccf51d55c715fa2fbd4"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#afc9b1ab3db46eccf51d55c715fa2fbd4">read_memory</a> (uint32_t address)</td></tr> +<tr class="separator:afc9b1ab3db46eccf51d55c715fa2fbd4"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a2b6196c2e97a7f7702c0068780304ec1" id="r_a2b6196c2e97a7f7702c0068780304ec1"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a2b6196c2e97a7f7702c0068780304ec1">setup_access</a> (void)</td></tr> +<tr class="separator:a2b6196c2e97a7f7702c0068780304ec1"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a96729fb5279642ac56c8e6a513789b45" id="r_a96729fb5279642ac56c8e6a513789b45"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a96729fb5279642ac56c8e6a513789b45">write_memory</a> (uint32_t address, uint32_t data)</td></tr> +<tr class="separator:a96729fb5279642ac56c8e6a513789b45"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a6405739c6012158151eb082c31c312da" id="r_a6405739c6012158151eb082c31c312da"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a6405739c6012158151eb082c31c312da">dump_memory</a> (uint32_t address)</td></tr> +<tr class="separator:a6405739c6012158151eb082c31c312da"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a02640a99db37b8d92b9edffc9720a210" id="r_a02640a99db37b8d92b9edffc9720a210"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a02640a99db37b8d92b9edffc9720a210">hexdump</a> (uint32_t address)</td></tr> +<tr class="separator:a02640a99db37b8d92b9edffc9720a210"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ac582208281cd6fce4eb61c234f312ef6" id="r_ac582208281cd6fce4eb61c234f312ef6"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ac582208281cd6fce4eb61c234f312ef6">aux_print_hex_byte</a> (uint8_t byte)</td></tr> +<tr class="separator:ac582208281cd6fce4eb61c234f312ef6"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ae66f6b31b5ad750f1fe042a706a4e3d4" id="r_ae66f6b31b5ad750f1fe042a706a4e3d4"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ae66f6b31b5ad750f1fe042a706a4e3d4">main</a> ()</td></tr> +<tr class="separator:ae66f6b31b5ad750f1fe042a706a4e3d4"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="var-members" name="var-members"></a> +Variables</h2></td></tr> +<tr class="memitem:a12606de4f336516339c495642a436032" id="r_a12606de4f336516339c495642a436032"><td class="memItemLeft" align="right" valign="top"><a id="a12606de4f336516339c495642a436032" name="a12606de4f336516339c495642a436032"></a> +char&#160;</td><td class="memItemRight" valign="bottom"><b>access_size</b></td></tr> +<tr class="separator:a12606de4f336516339c495642a436032"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>Interactive memory inspector. </p> +<dl class="section author"><dt>Author</dt><dd>Stephan Nolting </dd></dl> +</div><h2 class="groupheader">Macro Definition Documentation</h2> +<a id="ad4455691936f92fdd6c37566fc58ba1f" name="ad4455691936f92fdd6c37566fc58ba1f"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ad4455691936f92fdd6c37566fc58ba1f">&#9670;&#160;</a></span>BAUD_RATE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define BAUD_RATE&#160;&#160;&#160;19200</td> + </tr> + </table> +</div><div class="memdoc"> +<p>UART BAUD rate </p> + +</div> +</div> +<h2 class="groupheader">Function Documentation</h2> +<a id="ac582208281cd6fce4eb61c234f312ef6" name="ac582208281cd6fce4eb61c234f312ef6"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ac582208281cd6fce4eb61c234f312ef6">&#9670;&#160;</a></span>aux_print_hex_byte()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void aux_print_hex_byte </td> + <td>(</td> + <td class="paramtype">uint8_t</td> <td class="paramname"><span class="paramname"><em>byte</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Print HEX byte.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">byte</td><td>Byte to be printed as 2-cahr hex value. </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="a6405739c6012158151eb082c31c312da" name="a6405739c6012158151eb082c31c312da"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a6405739c6012158151eb082c31c312da">&#9670;&#160;</a></span>dump_memory()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void dump_memory </td> + <td>(</td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>address</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Read several bytes/halfs/word from memory base address </p> + +</div> +</div> +<a id="a02640a99db37b8d92b9edffc9720a210" name="a02640a99db37b8d92b9edffc9720a210"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a02640a99db37b8d92b9edffc9720a210">&#9670;&#160;</a></span>hexdump()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void hexdump </td> + <td>(</td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>address</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Make pretty hexadecimal + ASCII dump (byte-wise) </p> + +</div> +</div> +<a id="ae66f6b31b5ad750f1fe042a706a4e3d4" name="ae66f6b31b5ad750f1fe042a706a4e3d4"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ae66f6b31b5ad750f1fe042a706a4e3d4">&#9670;&#160;</a></span>main()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int main </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>This program provides an interactive console to read/write memory.</p> +<dl class="section note"><dt>Note</dt><dd>This program requires the UART to be synthesized.</dd></dl> +<dl class="section return"><dt>Returns</dt><dd>0 if execution was successful </dd></dl> + +</div> +</div> +<a id="afc9b1ab3db46eccf51d55c715fa2fbd4" name="afc9b1ab3db46eccf51d55c715fa2fbd4"></a> +<h2 class="memtitle"><span class="permalink"><a href="#afc9b1ab3db46eccf51d55c715fa2fbd4">&#9670;&#160;</a></span>read_memory()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void read_memory </td> + <td>(</td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>address</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Read from memory address </p> + +</div> +</div> +<a id="a2b6196c2e97a7f7702c0068780304ec1" name="a2b6196c2e97a7f7702c0068780304ec1"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a2b6196c2e97a7f7702c0068780304ec1">&#9670;&#160;</a></span>setup_access()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void setup_access </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Configure memory access size </p> + +</div> +</div> +<a id="a96729fb5279642ac56c8e6a513789b45" name="a96729fb5279642ac56c8e6a513789b45"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a96729fb5279642ac56c8e6a513789b45">&#9670;&#160;</a></span>write_memory()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void write_memory </td> + <td>(</td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>address</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>data</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Write to memory address </p> + +</div> +</div> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/classes.html b/sw/classes.html new file mode 100644 index 0000000000..61381d9d4c --- /dev/null +++ b/sw/classes.html @@ -0,0 +1,120 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: Data Structure Index</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +</div><!-- top --> +<div id="doc-content"> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div class="header"> + <div class="headertitle"><div class="title">Data Structure Index</div></div> +</div><!--header--> +<div class="contents"> +<div class="qindex"><a class="qindex" href="#letter_D">D</a>&#160;|&#160;<a class="qindex" href="#letter_F">F</a>&#160;|&#160;<a class="qindex" href="#letter_N">N</a>&#160;|&#160;<a class="qindex" href="#letter_R">R</a>&#160;|&#160;<a class="qindex" href="#letter_S">S</a>&#160;|&#160;<a class="qindex" href="#letter_T">T</a></div> +<div class="classindex"> +<dl class="classindex even"> +<dt class="alphachar"><a id="letter_D" name="letter_D">D</a></dt> +<dd><a class="el" href="structdate__t.html">date_t</a></dd></dl> +<dl class="classindex odd"> +<dt class="alphachar"><a id="letter_F" name="letter_F">F</a></dt> +<dd><a class="el" href="unionfloat__conv__t.html">float_conv_t</a></dd></dl> +<dl class="classindex even"> +<dt class="alphachar"><a id="letter_N" name="letter_N">N</a></dt> +<dd><a class="el" href="structneorv32__cfs__t.html">neorv32_cfs_t</a></dd><dd><a class="el" href="structneorv32__crc__t.html">neorv32_crc_t</a></dd><dd><a class="el" href="structneorv32__dma__t.html">neorv32_dma_t</a></dd><dd><a class="el" href="structneorv32__gpio__t.html">neorv32_gpio_t</a></dd><dd><a class="el" href="structneorv32__gptmr__t.html">neorv32_gptmr_t</a></dd><dd><a class="el" href="structneorv32__mtime__t.html">neorv32_mtime_t</a></dd><dd><a class="el" href="structneorv32__neoled__t.html">neorv32_neoled_t</a></dd><dd><a class="el" href="structneorv32__onewire__t.html">neorv32_onewire_t</a></dd><dd><a class="el" href="structneorv32__pwm__t.html">neorv32_pwm_t</a></dd><dd><a class="el" href="structneorv32__sdi__t.html">neorv32_sdi_t</a></dd><dd><a class="el" href="structneorv32__slink__t.html">neorv32_slink_t</a></dd><dd><a class="el" href="structneorv32__spi__t.html">neorv32_spi_t</a></dd><dd><a class="el" href="structneorv32__sysinfo__t.html">neorv32_sysinfo_t</a></dd><dd><a class="el" href="structneorv32__trng__t.html">neorv32_trng_t</a></dd><dd><a class="el" href="structneorv32__twi__t.html">neorv32_twi_t</a></dd><dd><a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a></dd><dd><a class="el" href="structneorv32__wdt__t.html">neorv32_wdt_t</a></dd><dd><a class="el" href="structneorv32__xip__t.html">neorv32_xip_t</a></dd><dd><a class="el" href="structneorv32__xirq__t.html">neorv32_xirq_t</a></dd></dl> +<dl class="classindex odd"> +<dt class="alphachar"><a id="letter_R" name="letter_R">R</a></dt> +<dd><a class="el" href="structrecord.html">record</a></dd></dl> +<dl class="classindex even"> +<dt class="alphachar"><a id="letter_S" name="letter_S">S</a></dt> +<dd><a class="el" href="unionsubwords16__t.html">subwords16_t</a></dd><dd><a class="el" href="unionsubwords32__t.html">subwords32_t</a></dd><dd><a class="el" href="unionsubwords64__t.html">subwords64_t</a></dd></dl> +<dl class="classindex odd"> +<dt class="alphachar"><a id="letter_T" name="letter_T">T</a></dt> +<dd><a class="el" href="structt__neorv32__spi.html">t_neorv32_spi</a></dd></dl> +</div> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/clipboard.js b/sw/clipboard.js new file mode 100644 index 0000000000..42c1fb0e02 --- /dev/null +++ b/sw/clipboard.js @@ -0,0 +1,61 @@ +/** + +The code below is based on the Doxygen Awesome project, see +https://github.com/jothepro/doxygen-awesome-css + +MIT License + +Copyright (c) 2021 - 2022 jothepro + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +SOFTWARE. + +*/ + +let clipboard_title = "Copy to clipboard" +let clipboard_icon = `<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" width="24" height="24"><path d="M0 0h24v24H0V0z" fill="none"/><path d="M16 1H4c-1.1 0-2 .9-2 2v14h2V3h12V1zm3 4H8c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h11c1.1 0 2-.9 2-2V7c0-1.1-.9-2-2-2zm0 16H8V7h11v14z"/></svg>` +let clipboard_successIcon = `<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" width="24" height="24"><path d="M0 0h24v24H0V0z" fill="none"/><path d="M9 16.17L4.83 12l-1.42 1.41L9 19 21 7l-1.41-1.41L9 16.17z"/></svg>` +let clipboard_successDuration = 1000 + +$(function() { + if(navigator.clipboard) { + const fragments = document.getElementsByClassName("fragment") + for(const fragment of fragments) { + const clipboard_div = document.createElement("div") + clipboard_div.classList.add("clipboard") + clipboard_div.innerHTML = clipboard_icon + clipboard_div.title = clipboard_title + $(clipboard_div).click(function() { + const content = this.parentNode.cloneNode(true) + // filter out line number and folded fragments from file listings + content.querySelectorAll(".lineno, .ttc, .foldclosed").forEach((node) => { node.remove() }) + let text = content.textContent + // remove trailing newlines and trailing spaces from empty lines + text = text.replace(/^\s*\n/gm,'\n').replace(/\n*$/,'') + navigator.clipboard.writeText(text); + this.classList.add("success") + this.innerHTML = clipboard_successIcon + window.setTimeout(() => { // switch back to normal icon after timeout + this.classList.remove("success") + this.innerHTML = clipboard_icon + }, clipboard_successDuration); + }) + fragment.insertBefore(clipboard_div, fragment.firstChild) + } + } +}) diff --git a/sw/closed.png b/sw/closed.png new file mode 100644 index 0000000000000000000000000000000000000000..98cc2c909da37a6df914fbf67780eebd99c597f5 GIT binary patch literal 132 zcmeAS@N?(olHy`uVBq!ia0vp^oFL4>1|%O$WD@{V-kvUwAr*{o@8<G4C~~x2bkCl7 zlF9slZh~6z%aUT|WfKm3{P*dDAfv<6>{^CZMh(5KoB^r_<4^zF@3)Cp&&t3hdujKf f*?bjBoY!V+E))@{xMcbjXe@)LtDnm{r-UW|*e5JT literal 0 HcmV?d00001 diff --git a/sw/cookie.js b/sw/cookie.js new file mode 100644 index 0000000000..53ad21d981 --- /dev/null +++ b/sw/cookie.js @@ -0,0 +1,58 @@ +/*! + Cookie helper functions + Copyright (c) 2023 Dimitri van Heesch + Released under MIT license. +*/ +let Cookie = { + cookie_namespace: 'doxygen_', + + readSetting(cookie,defVal) { + if (window.chrome) { + const val = localStorage.getItem(this.cookie_namespace+cookie) || + sessionStorage.getItem(this.cookie_namespace+cookie); + if (val) return val; + } else { + let myCookie = this.cookie_namespace+cookie+"="; + if (document.cookie) { + const index = document.cookie.indexOf(myCookie); + if (index != -1) { + const valStart = index + myCookie.length; + let valEnd = document.cookie.indexOf(";", valStart); + if (valEnd == -1) { + valEnd = document.cookie.length; + } + return document.cookie.substring(valStart, valEnd); + } + } + } + return defVal; + }, + + writeSetting(cookie,val,days=10*365) { // default days='forever', 0=session cookie, -1=delete + if (window.chrome) { + if (days==0) { + sessionStorage.setItem(this.cookie_namespace+cookie,val); + } else { + localStorage.setItem(this.cookie_namespace+cookie,val); + } + } else { + let date = new Date(); + date.setTime(date.getTime()+(days*24*60*60*1000)); + const expiration = days!=0 ? "expires="+date.toGMTString()+";" : ""; + document.cookie = this.cookie_namespace + cookie + "=" + + val + "; SameSite=Lax;" + expiration + "path=/"; + } + }, + + eraseSetting(cookie) { + if (window.chrome) { + if (localStorage.getItem(this.cookie_namespace+cookie)) { + localStorage.removeItem(this.cookie_namespace+cookie); + } else if (sessionStorage.getItem(this.cookie_namespace+cookie)) { + sessionStorage.removeItem(this.cookie_namespace+cookie); + } + } else { + this.writeSetting(cookie,'',-1); + } + }, +} diff --git a/sw/demo__blink__led_2main_8c.html b/sw/demo__blink__led_2main_8c.html new file mode 100644 index 0000000000..c29432b83a --- /dev/null +++ b/sw/demo__blink__led_2main_8c.html @@ -0,0 +1,139 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/example/demo_blink_led/main.c File Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_f0f9b27afba2e8cc2da6e5fddcc1a8c9.html">example</a></li><li class="navelem"><a class="el" href="dir_9a1c128d67c35790e92af404beb936aa.html">demo_blink_led</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#func-members">Functions</a> </div> + <div class="headertitle"><div class="title">main.c File Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p>Minimal blinking LED demo program using the lowest 8 bits of the GPIO.output port. +<a href="#details">More...</a></p> +<div class="textblock"><code>#include &lt;<a class="el" href="neorv32_8h_source.html">neorv32.h</a>&gt;</code><br /> +</div><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="func-members" name="func-members"></a> +Functions</h2></td></tr> +<tr class="memitem:ae66f6b31b5ad750f1fe042a706a4e3d4" id="r_ae66f6b31b5ad750f1fe042a706a4e3d4"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ae66f6b31b5ad750f1fe042a706a4e3d4">main</a> ()</td></tr> +<tr class="separator:ae66f6b31b5ad750f1fe042a706a4e3d4"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>Minimal blinking LED demo program using the lowest 8 bits of the GPIO.output port. </p> +<dl class="section author"><dt>Author</dt><dd>Stephan Nolting </dd></dl> +</div><h2 class="groupheader">Function Documentation</h2> +<a id="ae66f6b31b5ad750f1fe042a706a4e3d4" name="ae66f6b31b5ad750f1fe042a706a4e3d4"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ae66f6b31b5ad750f1fe042a706a4e3d4">&#9670;&#160;</a></span>main()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int main </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Main function; shows an incrementing 8-bit counter on GPIO.output(7:0).</p> +<dl class="section note"><dt>Note</dt><dd>This program requires the GPIO controller to be synthesized.</dd></dl> +<dl class="section return"><dt>Returns</dt><dd>Will never return. </dd></dl> + +</div> +</div> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/demo__cfs_2main_8c.html b/sw/demo__cfs_2main_8c.html new file mode 100644 index 0000000000..57bde1f8ea --- /dev/null +++ b/sw/demo__cfs_2main_8c.html @@ -0,0 +1,178 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/example/demo_cfs/main.c File Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_f0f9b27afba2e8cc2da6e5fddcc1a8c9.html">example</a></li><li class="navelem"><a class="el" href="dir_01cde3d98944a579dc3b5e43a5311a79.html">demo_cfs</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#func-members">Functions</a> </div> + <div class="headertitle"><div class="title">main.c File Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p>Simple demo program for the <em>default</em> custom functions subsystem (CFS) module. +<a href="#details">More...</a></p> +<div class="textblock"><code>#include &lt;<a class="el" href="neorv32_8h_source.html">neorv32.h</a>&gt;</code><br /> +</div><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="define-members" name="define-members"></a> +Macros</h2></td></tr> +<tr><td colspan="2"><div class="groupHeader">User configuration</div></td></tr> +<tr class="memitem:ad4455691936f92fdd6c37566fc58ba1f" id="r_ad4455691936f92fdd6c37566fc58ba1f"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ad4455691936f92fdd6c37566fc58ba1f">BAUD_RATE</a>&#160;&#160;&#160;19200</td></tr> +<tr class="separator:ad4455691936f92fdd6c37566fc58ba1f"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a906949f076e3e0d0082af3c3b1acb518" id="r_a906949f076e3e0d0082af3c3b1acb518"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a906949f076e3e0d0082af3c3b1acb518">TESTCASES</a>&#160;&#160;&#160;4</td></tr> +<tr class="separator:a906949f076e3e0d0082af3c3b1acb518"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="func-members" name="func-members"></a> +Functions</h2></td></tr> +<tr class="memitem:ae66f6b31b5ad750f1fe042a706a4e3d4" id="r_ae66f6b31b5ad750f1fe042a706a4e3d4"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ae66f6b31b5ad750f1fe042a706a4e3d4">main</a> ()</td></tr> +<tr class="separator:ae66f6b31b5ad750f1fe042a706a4e3d4"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>Simple demo program for the <em>default</em> custom functions subsystem (CFS) module. </p> +<dl class="section author"><dt>Author</dt><dd>Stephan Nolting </dd></dl> +</div><h2 class="groupheader">Macro Definition Documentation</h2> +<a id="ad4455691936f92fdd6c37566fc58ba1f" name="ad4455691936f92fdd6c37566fc58ba1f"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ad4455691936f92fdd6c37566fc58ba1f">&#9670;&#160;</a></span>BAUD_RATE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define BAUD_RATE&#160;&#160;&#160;19200</td> + </tr> + </table> +</div><div class="memdoc"> +<p>UART BAUD rate </p> + +</div> +</div> +<a id="a906949f076e3e0d0082af3c3b1acb518" name="a906949f076e3e0d0082af3c3b1acb518"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a906949f076e3e0d0082af3c3b1acb518">&#9670;&#160;</a></span>TESTCASES</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define TESTCASES&#160;&#160;&#160;4</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Number of test cases per CFS function </p> + +</div> +</div> +<h2 class="groupheader">Function Documentation</h2> +<a id="ae66f6b31b5ad750f1fe042a706a4e3d4" name="ae66f6b31b5ad750f1fe042a706a4e3d4"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ae66f6b31b5ad750f1fe042a706a4e3d4">&#9670;&#160;</a></span>main()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int main </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Main function</p> +<dl class="section note"><dt>Note</dt><dd>This program requires the CFS and UART0.</dd></dl> +<dl class="section return"><dt>Returns</dt><dd>0 if execution was successful </dd></dl> + +</div> +</div> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/demo__cfu_2main_8c.html b/sw/demo__cfu_2main_8c.html new file mode 100644 index 0000000000..8959480374 --- /dev/null +++ b/sw/demo__cfu_2main_8c.html @@ -0,0 +1,483 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/example/demo_cfu/main.c File Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_f0f9b27afba2e8cc2da6e5fddcc1a8c9.html">example</a></li><li class="navelem"><a class="el" href="dir_09a89dfa1596b6613cf2c29528a32844.html">demo_cfu</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#func-members">Functions</a> </div> + <div class="headertitle"><div class="title">main.c File Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p>Example program showing how to use the CFU's custom instructions (XTEA example). +<a href="#details">More...</a></p> +<div class="textblock"><code>#include &lt;<a class="el" href="neorv32_8h_source.html">neorv32.h</a>&gt;</code><br /> +</div><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="define-members" name="define-members"></a> +Macros</h2></td></tr> +<tr><td colspan="2"><div class="groupHeader">User configuration</div></td></tr> +<tr class="memitem:ad4455691936f92fdd6c37566fc58ba1f" id="r_ad4455691936f92fdd6c37566fc58ba1f"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ad4455691936f92fdd6c37566fc58ba1f">BAUD_RATE</a>&#160;&#160;&#160;19200</td></tr> +<tr class="separator:ad4455691936f92fdd6c37566fc58ba1f"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a34755f457331741d24090b3819b5d416" id="r_a34755f457331741d24090b3819b5d416"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a34755f457331741d24090b3819b5d416">XTEA_CYCLES</a>&#160;&#160;&#160;20</td></tr> +<tr class="separator:a34755f457331741d24090b3819b5d416"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ac637695e266f3af7799e352b374412ad" id="r_ac637695e266f3af7799e352b374412ad"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ac637695e266f3af7799e352b374412ad">DATA_NUM</a>&#160;&#160;&#160;64</td></tr> +<tr class="separator:ac637695e266f3af7799e352b374412ad"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr><td colspan="2"><div class="groupHeader">Define macros for easy CFU instruction wrapping</div></td></tr> +<tr class="memitem:a0ff5df4be3476f4e7756c472f2644726" id="r_a0ff5df4be3476f4e7756c472f2644726"><td class="memItemLeft" align="right" valign="top"><a id="a0ff5df4be3476f4e7756c472f2644726" name="a0ff5df4be3476f4e7756c472f2644726"></a> +#define&#160;</td><td class="memItemRight" valign="bottom"><b>xtea_hw_init</b>(sum)&#160;&#160;&#160;<a class="el" href="neorv32__cpu__cfu_8h.html#a69d60ccd0cee950b08ce585c3f13b85c">neorv32_cfu_r3_instr</a>(0b0000000, 0b100, sum, 0 )</td></tr> +<tr class="separator:a0ff5df4be3476f4e7756c472f2644726"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a8fddbd0364944fa3dca477599079c78e" id="r_a8fddbd0364944fa3dca477599079c78e"><td class="memItemLeft" align="right" valign="top"><a id="a8fddbd0364944fa3dca477599079c78e" name="a8fddbd0364944fa3dca477599079c78e"></a> +#define&#160;</td><td class="memItemRight" valign="bottom"><b>xtea_hw_enc_v0_step</b>(v0, v1)&#160;&#160;&#160;<a class="el" href="neorv32__cpu__cfu_8h.html#a69d60ccd0cee950b08ce585c3f13b85c">neorv32_cfu_r3_instr</a>(0b0000000, 0b000, v0, v1)</td></tr> +<tr class="separator:a8fddbd0364944fa3dca477599079c78e"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:af6c6097c851dc97679d939d0d506342c" id="r_af6c6097c851dc97679d939d0d506342c"><td class="memItemLeft" align="right" valign="top"><a id="af6c6097c851dc97679d939d0d506342c" name="af6c6097c851dc97679d939d0d506342c"></a> +#define&#160;</td><td class="memItemRight" valign="bottom"><b>xtea_hw_enc_v1_step</b>(v0, v1)&#160;&#160;&#160;<a class="el" href="neorv32__cpu__cfu_8h.html#a69d60ccd0cee950b08ce585c3f13b85c">neorv32_cfu_r3_instr</a>(0b0000000, 0b001, v0, v1)</td></tr> +<tr class="separator:af6c6097c851dc97679d939d0d506342c"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a2e76463aadbf0cd788191401f42d89aa" id="r_a2e76463aadbf0cd788191401f42d89aa"><td class="memItemLeft" align="right" valign="top"><a id="a2e76463aadbf0cd788191401f42d89aa" name="a2e76463aadbf0cd788191401f42d89aa"></a> +#define&#160;</td><td class="memItemRight" valign="bottom"><b>xtea_hw_dec_v0_step</b>(v0, v1)&#160;&#160;&#160;<a class="el" href="neorv32__cpu__cfu_8h.html#a69d60ccd0cee950b08ce585c3f13b85c">neorv32_cfu_r3_instr</a>(0b0000000, 0b010, v0, v1)</td></tr> +<tr class="separator:a2e76463aadbf0cd788191401f42d89aa"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:af139f37dd13866ecb4aa9002ac8f798e" id="r_af139f37dd13866ecb4aa9002ac8f798e"><td class="memItemLeft" align="right" valign="top"><a id="af139f37dd13866ecb4aa9002ac8f798e" name="af139f37dd13866ecb4aa9002ac8f798e"></a> +#define&#160;</td><td class="memItemRight" valign="bottom"><b>xtea_hw_dec_v1_step</b>(v0, v1)&#160;&#160;&#160;<a class="el" href="neorv32__cpu__cfu_8h.html#a69d60ccd0cee950b08ce585c3f13b85c">neorv32_cfu_r3_instr</a>(0b0000000, 0b011, v0, v1)</td></tr> +<tr class="separator:af139f37dd13866ecb4aa9002ac8f798e"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aaa2516cd7853e9c7c274cb3de35cb2d5" id="r_aaa2516cd7853e9c7c274cb3de35cb2d5"><td class="memItemLeft" align="right" valign="top"><a id="aaa2516cd7853e9c7c274cb3de35cb2d5" name="aaa2516cd7853e9c7c274cb3de35cb2d5"></a> +#define&#160;</td><td class="memItemRight" valign="bottom"><b>xtea_hw_illegal_inst</b>()&#160;&#160;&#160;<a class="el" href="neorv32__cpu__cfu_8h.html#a69d60ccd0cee950b08ce585c3f13b85c">neorv32_cfu_r3_instr</a>(0b0000000, 0b111, 0, 0 )</td></tr> +<tr class="separator:aaa2516cd7853e9c7c274cb3de35cb2d5"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="func-members" name="func-members"></a> +Functions</h2></td></tr> +<tr class="memitem:a8dc502bf508491eed1f39c4acf040efb" id="r_a8dc502bf508491eed1f39c4acf040efb"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a8dc502bf508491eed1f39c4acf040efb">xtea_sw_encipher</a> (uint32_t num_cycles, uint32_t *v, const uint32_t k[4])</td></tr> +<tr class="separator:a8dc502bf508491eed1f39c4acf040efb"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a0e980c5d81b1eca90b8073e54099bdb0" id="r_a0e980c5d81b1eca90b8073e54099bdb0"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a0e980c5d81b1eca90b8073e54099bdb0">xtea_sw_decipher</a> (unsigned int num_cycles, uint32_t *v, const uint32_t k[4])</td></tr> +<tr class="separator:a0e980c5d81b1eca90b8073e54099bdb0"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ae66f6b31b5ad750f1fe042a706a4e3d4" id="r_ae66f6b31b5ad750f1fe042a706a4e3d4"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ae66f6b31b5ad750f1fe042a706a4e3d4">main</a> ()</td></tr> +<tr class="separator:ae66f6b31b5ad750f1fe042a706a4e3d4"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="var-members" name="var-members"></a> +Variables</h2></td></tr> +<tr><td colspan="2"><div class="groupHeader">Global variables</div></td></tr> +<tr class="memitem:a26da64691624f3c899f2394a427d6593" id="r_a26da64691624f3c899f2394a427d6593"><td class="memItemLeft" align="right" valign="top">const uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a26da64691624f3c899f2394a427d6593">xtea_delta</a> = 0x9e3779b9</td></tr> +<tr class="separator:a26da64691624f3c899f2394a427d6593"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ab5c498f9da12ab2d6ddc89bf4a46dec6" id="r_ab5c498f9da12ab2d6ddc89bf4a46dec6"><td class="memItemLeft" align="right" valign="top">const uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ab5c498f9da12ab2d6ddc89bf4a46dec6">key</a> [4] = {0x207230ba, 0x1ffba710, 0xc45271ef, 0xdd01768a}</td></tr> +<tr class="separator:ab5c498f9da12ab2d6ddc89bf4a46dec6"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a2e2ccb9136736a673dbef71f207e97a0" id="r_a2e2ccb9136736a673dbef71f207e97a0"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a2e2ccb9136736a673dbef71f207e97a0">input_data</a> [<a class="el" href="#ac637695e266f3af7799e352b374412ad">DATA_NUM</a>]</td></tr> +<tr class="separator:a2e2ccb9136736a673dbef71f207e97a0"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a33b2d9298edf94c5961e67a59c371d00" id="r_a33b2d9298edf94c5961e67a59c371d00"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a33b2d9298edf94c5961e67a59c371d00">cypher_data_sw</a> [<a class="el" href="#ac637695e266f3af7799e352b374412ad">DATA_NUM</a>]</td></tr> +<tr class="separator:a33b2d9298edf94c5961e67a59c371d00"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a9ad2780a4cfe0d9cb4f1a846a92063ae" id="r_a9ad2780a4cfe0d9cb4f1a846a92063ae"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a9ad2780a4cfe0d9cb4f1a846a92063ae">cypher_data_hw</a> [<a class="el" href="#ac637695e266f3af7799e352b374412ad">DATA_NUM</a>]</td></tr> +<tr class="separator:a9ad2780a4cfe0d9cb4f1a846a92063ae"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a72ba1460776ad684028448ca51810bbe" id="r_a72ba1460776ad684028448ca51810bbe"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a72ba1460776ad684028448ca51810bbe">plain_data_sw</a> [<a class="el" href="#ac637695e266f3af7799e352b374412ad">DATA_NUM</a>]</td></tr> +<tr class="separator:a72ba1460776ad684028448ca51810bbe"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aee8dde13fe2f5ac52dd6075e2fe1eab5" id="r_aee8dde13fe2f5ac52dd6075e2fe1eab5"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aee8dde13fe2f5ac52dd6075e2fe1eab5">plain_data_hw</a> [<a class="el" href="#ac637695e266f3af7799e352b374412ad">DATA_NUM</a>]</td></tr> +<tr class="separator:aee8dde13fe2f5ac52dd6075e2fe1eab5"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ad424a26173bd8d84b8d1cae94a55f248" id="r_ad424a26173bd8d84b8d1cae94a55f248"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ad424a26173bd8d84b8d1cae94a55f248">time_enc_sw</a></td></tr> +<tr class="separator:ad424a26173bd8d84b8d1cae94a55f248"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a094212e3731a9aecbd278fac243de6ec" id="r_a094212e3731a9aecbd278fac243de6ec"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a094212e3731a9aecbd278fac243de6ec">time_enc_hw</a></td></tr> +<tr class="separator:a094212e3731a9aecbd278fac243de6ec"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a2d3853c367c3bce99e787c0df445030a" id="r_a2d3853c367c3bce99e787c0df445030a"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a2d3853c367c3bce99e787c0df445030a">time_dec_sw</a></td></tr> +<tr class="separator:a2d3853c367c3bce99e787c0df445030a"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:acb6dd9d6ab74ac94f174a11ff3ad76af" id="r_acb6dd9d6ab74ac94f174a11ff3ad76af"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#acb6dd9d6ab74ac94f174a11ff3ad76af">time_dec_hw</a></td></tr> +<tr class="separator:acb6dd9d6ab74ac94f174a11ff3ad76af"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>Example program showing how to use the CFU's custom instructions (XTEA example). </p> +<dl class="section author"><dt>Author</dt><dd>Stephan Nolting </dd></dl> +<dl class="section note"><dt>Note</dt><dd>Take a look at the highly-commented "hardware-counterpart" of this CFU example in 'rtl/core/neorv32_cpu_cp_cfu.vhd'. </dd></dl> +</div><h2 class="groupheader">Macro Definition Documentation</h2> +<a id="ad4455691936f92fdd6c37566fc58ba1f" name="ad4455691936f92fdd6c37566fc58ba1f"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ad4455691936f92fdd6c37566fc58ba1f">&#9670;&#160;</a></span>BAUD_RATE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define BAUD_RATE&#160;&#160;&#160;19200</td> + </tr> + </table> +</div><div class="memdoc"> +<p>UART BAUD rate </p> + +</div> +</div> +<a id="ac637695e266f3af7799e352b374412ad" name="ac637695e266f3af7799e352b374412ad"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ac637695e266f3af7799e352b374412ad">&#9670;&#160;</a></span>DATA_NUM</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define DATA_NUM&#160;&#160;&#160;64</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Input data size (in number of 32-bit words), has to be even </p> + +</div> +</div> +<a id="a34755f457331741d24090b3819b5d416" name="a34755f457331741d24090b3819b5d416"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a34755f457331741d24090b3819b5d416">&#9670;&#160;</a></span>XTEA_CYCLES</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define XTEA_CYCLES&#160;&#160;&#160;20</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Number XTEA cycles </p> + +</div> +</div> +<h2 class="groupheader">Function Documentation</h2> +<a id="ae66f6b31b5ad750f1fe042a706a4e3d4" name="ae66f6b31b5ad750f1fe042a706a4e3d4"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ae66f6b31b5ad750f1fe042a706a4e3d4">&#9670;&#160;</a></span>main()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int main </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Main function: run pure-SW XTEA and compare with HW-XTEA</p> +<dl class="section note"><dt>Note</dt><dd>This program requires the CFU, UART0 and the Zicntr ISA extension.</dd></dl> +<dl class="section return"><dt>Returns</dt><dd>0 if execution was successful </dd></dl> + +</div> +</div> +<a id="a0e980c5d81b1eca90b8073e54099bdb0" name="a0e980c5d81b1eca90b8073e54099bdb0"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a0e980c5d81b1eca90b8073e54099bdb0">&#9670;&#160;</a></span>xtea_sw_decipher()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void xtea_sw_decipher </td> + <td>(</td> + <td class="paramtype">unsigned int</td> <td class="paramname"><span class="paramname"><em>num_cycles</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">uint32_t *</td> <td class="paramname"><span class="paramname"><em>v</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">const uint32_t</td> <td class="paramname"><span class="paramname"><em>k</em></span>[4]&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>XTEA decryption - software reference</p> +<p>Source: <a href="https://de.wikipedia.org/wiki/Extended_Tiny_Encryption_Algorithm">https://de.wikipedia.org/wiki/Extended_Tiny_Encryption_Algorithm</a></p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">num_cycles</td><td>Number of encryption cycles. </td></tr> + <tr><td class="paramdir">[in,out]</td><td class="paramname">v</td><td>Decryption data/result array (2x32-bit). </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">k</td><td>Decryption key array (4x32-bit). </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="a8dc502bf508491eed1f39c4acf040efb" name="a8dc502bf508491eed1f39c4acf040efb"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a8dc502bf508491eed1f39c4acf040efb">&#9670;&#160;</a></span>xtea_sw_encipher()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void xtea_sw_encipher </td> + <td>(</td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>num_cycles</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">uint32_t *</td> <td class="paramname"><span class="paramname"><em>v</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">const uint32_t</td> <td class="paramname"><span class="paramname"><em>k</em></span>[4]&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>XTEA encryption - software reference</p> +<p>Source: <a href="https://de.wikipedia.org/wiki/Extended_Tiny_Encryption_Algorithm">https://de.wikipedia.org/wiki/Extended_Tiny_Encryption_Algorithm</a></p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">num_cycles</td><td>Number of encryption cycles. </td></tr> + <tr><td class="paramdir">[in,out]</td><td class="paramname">v</td><td>Encryption data/result array (2x32-bit). </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">k</td><td>Encryption key array (4x32-bit). </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<h2 class="groupheader">Variable Documentation</h2> +<a id="a9ad2780a4cfe0d9cb4f1a846a92063ae" name="a9ad2780a4cfe0d9cb4f1a846a92063ae"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a9ad2780a4cfe0d9cb4f1a846a92063ae">&#9670;&#160;</a></span>cypher_data_hw</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t cypher_data_hw[<a class="el" href="#ac637695e266f3af7799e352b374412ad">DATA_NUM</a>]</td> + </tr> + </table> +</div><div class="memdoc"> +<p>XTEA delta (round-key update) </p> + +</div> +</div> +<a id="a33b2d9298edf94c5961e67a59c371d00" name="a33b2d9298edf94c5961e67a59c371d00"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a33b2d9298edf94c5961e67a59c371d00">&#9670;&#160;</a></span>cypher_data_sw</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t cypher_data_sw[<a class="el" href="#ac637695e266f3af7799e352b374412ad">DATA_NUM</a>]</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Encryption results </p> + +</div> +</div> +<a id="a2e2ccb9136736a673dbef71f207e97a0" name="a2e2ccb9136736a673dbef71f207e97a0"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a2e2ccb9136736a673dbef71f207e97a0">&#9670;&#160;</a></span>input_data</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t input_data[<a class="el" href="#ac637695e266f3af7799e352b374412ad">DATA_NUM</a>]</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Encryption input data </p> + +</div> +</div> +<a id="ab5c498f9da12ab2d6ddc89bf4a46dec6" name="ab5c498f9da12ab2d6ddc89bf4a46dec6"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ab5c498f9da12ab2d6ddc89bf4a46dec6">&#9670;&#160;</a></span>key</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">const uint32_t key[4] = {0x207230ba, 0x1ffba710, 0xc45271ef, 0xdd01768a}</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Encryption/decryption key (128-bit) </p> + +</div> +</div> +<a id="aee8dde13fe2f5ac52dd6075e2fe1eab5" name="aee8dde13fe2f5ac52dd6075e2fe1eab5"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aee8dde13fe2f5ac52dd6075e2fe1eab5">&#9670;&#160;</a></span>plain_data_hw</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t plain_data_hw[<a class="el" href="#ac637695e266f3af7799e352b374412ad">DATA_NUM</a>]</td> + </tr> + </table> +</div><div class="memdoc"> +<p>XTEA delta (round-key update) </p> + +</div> +</div> +<a id="a72ba1460776ad684028448ca51810bbe" name="a72ba1460776ad684028448ca51810bbe"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a72ba1460776ad684028448ca51810bbe">&#9670;&#160;</a></span>plain_data_sw</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t plain_data_sw[<a class="el" href="#ac637695e266f3af7799e352b374412ad">DATA_NUM</a>]</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Decryption results </p> + +</div> +</div> +<a id="acb6dd9d6ab74ac94f174a11ff3ad76af" name="acb6dd9d6ab74ac94f174a11ff3ad76af"></a> +<h2 class="memtitle"><span class="permalink"><a href="#acb6dd9d6ab74ac94f174a11ff3ad76af">&#9670;&#160;</a></span>time_dec_hw</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t time_dec_hw</td> + </tr> + </table> +</div><div class="memdoc"> +<p>XTEA delta (round-key update) </p> + +</div> +</div> +<a id="a2d3853c367c3bce99e787c0df445030a" name="a2d3853c367c3bce99e787c0df445030a"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a2d3853c367c3bce99e787c0df445030a">&#9670;&#160;</a></span>time_dec_sw</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t time_dec_sw</td> + </tr> + </table> +</div><div class="memdoc"> +<p>XTEA delta (round-key update) </p> + +</div> +</div> +<a id="a094212e3731a9aecbd278fac243de6ec" name="a094212e3731a9aecbd278fac243de6ec"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a094212e3731a9aecbd278fac243de6ec">&#9670;&#160;</a></span>time_enc_hw</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t time_enc_hw</td> + </tr> + </table> +</div><div class="memdoc"> +<p>XTEA delta (round-key update) </p> + +</div> +</div> +<a id="ad424a26173bd8d84b8d1cae94a55f248" name="ad424a26173bd8d84b8d1cae94a55f248"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ad424a26173bd8d84b8d1cae94a55f248">&#9670;&#160;</a></span>time_enc_sw</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t time_enc_sw</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Timing data </p> + +</div> +</div> +<a id="a26da64691624f3c899f2394a427d6593" name="a26da64691624f3c899f2394a427d6593"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a26da64691624f3c899f2394a427d6593">&#9670;&#160;</a></span>xtea_delta</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">const uint32_t xtea_delta = 0x9e3779b9</td> + </tr> + </table> +</div><div class="memdoc"> +<p>XTEA delta (round-key update) </p> + +</div> +</div> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/demo__crc_2main_8c.html b/sw/demo__crc_2main_8c.html new file mode 100644 index 0000000000..645259d13f --- /dev/null +++ b/sw/demo__crc_2main_8c.html @@ -0,0 +1,168 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/example/demo_crc/main.c File Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_f0f9b27afba2e8cc2da6e5fddcc1a8c9.html">example</a></li><li class="navelem"><a class="el" href="dir_bf935196a1ea0ca9cb42aae56d70946a.html">demo_crc</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#func-members">Functions</a> &#124; +<a href="#var-members">Variables</a> </div> + <div class="headertitle"><div class="title">main.c File Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p>CRC demo program. +<a href="#details">More...</a></p> +<div class="textblock"><code>#include &lt;<a class="el" href="neorv32_8h_source.html">neorv32.h</a>&gt;</code><br /> +</div><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="define-members" name="define-members"></a> +Macros</h2></td></tr> +<tr><td colspan="2"><div class="groupHeader">User configuration</div></td></tr> +<tr class="memitem:ad4455691936f92fdd6c37566fc58ba1f" id="r_ad4455691936f92fdd6c37566fc58ba1f"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ad4455691936f92fdd6c37566fc58ba1f">BAUD_RATE</a>&#160;&#160;&#160;19200</td></tr> +<tr class="separator:ad4455691936f92fdd6c37566fc58ba1f"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="func-members" name="func-members"></a> +Functions</h2></td></tr> +<tr class="memitem:ae66f6b31b5ad750f1fe042a706a4e3d4" id="r_ae66f6b31b5ad750f1fe042a706a4e3d4"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ae66f6b31b5ad750f1fe042a706a4e3d4">main</a> ()</td></tr> +<tr class="separator:ae66f6b31b5ad750f1fe042a706a4e3d4"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="var-members" name="var-members"></a> +Variables</h2></td></tr> +<tr class="memitem:a61cf3bdb35d76183cca44c4496ed39a1" id="r_a61cf3bdb35d76183cca44c4496ed39a1"><td class="memItemLeft" align="right" valign="top"><a id="a61cf3bdb35d76183cca44c4496ed39a1" name="a61cf3bdb35d76183cca44c4496ed39a1"></a> +const uint8_t&#160;</td><td class="memItemRight" valign="bottom"><b>test_string</b> [] = {0x31, 0x32, 0x33, 0x34, 0x35, 0x36, 0x37, 0x38, 0x00}</td></tr> +<tr class="separator:a61cf3bdb35d76183cca44c4496ed39a1"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>CRC demo program. </p> +<dl class="section author"><dt>Author</dt><dd>Stephan Nolting </dd></dl> +</div><h2 class="groupheader">Macro Definition Documentation</h2> +<a id="ad4455691936f92fdd6c37566fc58ba1f" name="ad4455691936f92fdd6c37566fc58ba1f"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ad4455691936f92fdd6c37566fc58ba1f">&#9670;&#160;</a></span>BAUD_RATE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define BAUD_RATE&#160;&#160;&#160;19200</td> + </tr> + </table> +</div><div class="memdoc"> +<p>UART BAUD rate </p> + +</div> +</div> +<h2 class="groupheader">Function Documentation</h2> +<a id="ae66f6b31b5ad750f1fe042a706a4e3d4" name="ae66f6b31b5ad750f1fe042a706a4e3d4"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ae66f6b31b5ad750f1fe042a706a4e3d4">&#9670;&#160;</a></span>main()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int main </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Simple demo program to showcase the NEORV32 CRC unit.</p> +<dl class="section note"><dt>Note</dt><dd>This program requires UART0 and the CRC unit to be synthesized. The DMA controller is optional.</dd></dl> +<dl class="section return"><dt>Returns</dt><dd>Irrelevant. </dd></dl> + +</div> +</div> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/demo__dma_2main_8c.html b/sw/demo__dma_2main_8c.html new file mode 100644 index 0000000000..849c59514b --- /dev/null +++ b/sw/demo__dma_2main_8c.html @@ -0,0 +1,212 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/example/demo_dma/main.c File Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_f0f9b27afba2e8cc2da6e5fddcc1a8c9.html">example</a></li><li class="navelem"><a class="el" href="dir_8c514361e1f16692c783b23503f30f16.html">demo_dma</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#func-members">Functions</a> &#124; +<a href="#var-members">Variables</a> </div> + <div class="headertitle"><div class="title">main.c File Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p>DMA demo program. +<a href="#details">More...</a></p> +<div class="textblock"><code>#include &lt;<a class="el" href="neorv32_8h_source.html">neorv32.h</a>&gt;</code><br /> +</div><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="define-members" name="define-members"></a> +Macros</h2></td></tr> +<tr><td colspan="2"><div class="groupHeader">User configuration</div></td></tr> +<tr class="memitem:ad4455691936f92fdd6c37566fc58ba1f" id="r_ad4455691936f92fdd6c37566fc58ba1f"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ad4455691936f92fdd6c37566fc58ba1f">BAUD_RATE</a>&#160;&#160;&#160;19200</td></tr> +<tr class="separator:ad4455691936f92fdd6c37566fc58ba1f"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="func-members" name="func-members"></a> +Functions</h2></td></tr> +<tr class="memitem:a8ad0c7bfd07edb6d42d86b166347206b" id="r_a8ad0c7bfd07edb6d42d86b166347206b"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a8ad0c7bfd07edb6d42d86b166347206b">show_arrays</a> (void)</td></tr> +<tr class="separator:a8ad0c7bfd07edb6d42d86b166347206b"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aefcc5abb86a652587ff69be120a66487" id="r_aefcc5abb86a652587ff69be120a66487"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aefcc5abb86a652587ff69be120a66487">dma_firq_handler</a> (void)</td></tr> +<tr class="separator:aefcc5abb86a652587ff69be120a66487"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ae66f6b31b5ad750f1fe042a706a4e3d4" id="r_ae66f6b31b5ad750f1fe042a706a4e3d4"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ae66f6b31b5ad750f1fe042a706a4e3d4">main</a> ()</td></tr> +<tr class="separator:ae66f6b31b5ad750f1fe042a706a4e3d4"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="var-members" name="var-members"></a> +Variables</h2></td></tr> +<tr class="memitem:a5d49f871680881f4a84770fc76e40b77" id="r_a5d49f871680881f4a84770fc76e40b77"><td class="memItemLeft" align="right" valign="top"><a id="a5d49f871680881f4a84770fc76e40b77" name="a5d49f871680881f4a84770fc76e40b77"></a> +volatile uint32_t&#160;</td><td class="memItemRight" valign="bottom"><b>dma_src</b> [4]</td></tr> +<tr class="separator:a5d49f871680881f4a84770fc76e40b77"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a71821daf63f808350ae702ca7edb38e2" id="r_a71821daf63f808350ae702ca7edb38e2"><td class="memItemLeft" align="right" valign="top"><a id="a71821daf63f808350ae702ca7edb38e2" name="a71821daf63f808350ae702ca7edb38e2"></a> +volatile uint32_t&#160;</td><td class="memItemRight" valign="bottom"><b>dma_dst</b> [4]</td></tr> +<tr class="separator:a71821daf63f808350ae702ca7edb38e2"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>DMA demo program. </p> +<dl class="section author"><dt>Author</dt><dd>Stephan Nolting </dd></dl> +</div><h2 class="groupheader">Macro Definition Documentation</h2> +<a id="ad4455691936f92fdd6c37566fc58ba1f" name="ad4455691936f92fdd6c37566fc58ba1f"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ad4455691936f92fdd6c37566fc58ba1f">&#9670;&#160;</a></span>BAUD_RATE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define BAUD_RATE&#160;&#160;&#160;19200</td> + </tr> + </table> +</div><div class="memdoc"> +<p>UART BAUD rate </p> + +</div> +</div> +<h2 class="groupheader">Function Documentation</h2> +<a id="aefcc5abb86a652587ff69be120a66487" name="aefcc5abb86a652587ff69be120a66487"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aefcc5abb86a652587ff69be120a66487">&#9670;&#160;</a></span>dma_firq_handler()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void dma_firq_handler </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>DMA FIRQ handler.</p> +<dl class="section warning"><dt>Warning</dt><dd>This function has to be of type "void xyz(void)" and must not use any interrupt attributes! </dd></dl> + +</div> +</div> +<a id="ae66f6b31b5ad750f1fe042a706a4e3d4" name="ae66f6b31b5ad750f1fe042a706a4e3d4"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ae66f6b31b5ad750f1fe042a706a4e3d4">&#9670;&#160;</a></span>main()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int main </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Simple demo program to showcase the NEORV32 DMA controller.</p> +<dl class="section note"><dt>Note</dt><dd>This program requires UART0 and the DMA controller to be synthesized.</dd></dl> +<dl class="section return"><dt>Returns</dt><dd>Irrelevant. </dd></dl> + +</div> +</div> +<a id="a8ad0c7bfd07edb6d42d86b166347206b" name="a8ad0c7bfd07edb6d42d86b166347206b"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a8ad0c7bfd07edb6d42d86b166347206b">&#9670;&#160;</a></span>show_arrays()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void show_arrays </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Print test data arrays </p> + +</div> +</div> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/demo__emulate__unaligned_2main_8c.html b/sw/demo__emulate__unaligned_2main_8c.html new file mode 100644 index 0000000000..af8c6f5855 --- /dev/null +++ b/sw/demo__emulate__unaligned_2main_8c.html @@ -0,0 +1,216 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/example/demo_emulate_unaligned/main.c File Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_f0f9b27afba2e8cc2da6e5fddcc1a8c9.html">example</a></li><li class="navelem"><a class="el" href="dir_2ba96d3140b089dada6fb9f817b7975f.html">demo_emulate_unaligned</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="headertitle"><div class="title">main.c File Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p>Demo program for emulating unaligned memory accesses using the NEORV32 run-time environment (RTE). +<a href="#details">More...</a></p> +<div class="textblock"><code>#include &lt;<a class="el" href="neorv32_8h_source.html">neorv32.h</a>&gt;</code><br /> +</div><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="define-members" name="define-members"></a> +Macros</h2></td></tr> +<tr><td colspan="2"><div class="groupHeader">User configuration</div></td></tr> +<tr class="memitem:ad4455691936f92fdd6c37566fc58ba1f" id="r_ad4455691936f92fdd6c37566fc58ba1f"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ad4455691936f92fdd6c37566fc58ba1f">BAUD_RATE</a>&#160;&#160;&#160;19200</td></tr> +<tr class="separator:ad4455691936f92fdd6c37566fc58ba1f"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a4407b4d6eae3ba7fe9538b1242a7e165" id="r_a4407b4d6eae3ba7fe9538b1242a7e165"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a4407b4d6eae3ba7fe9538b1242a7e165">DEBUG_INFO</a>&#160;&#160;&#160;0</td></tr> +<tr class="separator:a4407b4d6eae3ba7fe9538b1242a7e165"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader">Global variables</h2></td></tr> +<tr class="memitem:a556f675911f865ead06c36072b1b9c3b" id="r_a556f675911f865ead06c36072b1b9c3b"><td class="memItemLeft" align="right" valign="top">volatile uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a556f675911f865ead06c36072b1b9c3b">data_block</a> [2]</td></tr> +<tr class="separator:a556f675911f865ead06c36072b1b9c3b"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a07da42351229525998965b219e827460" id="r_a07da42351229525998965b219e827460"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a07da42351229525998965b219e827460">trap_handler_emulate_unaligned_lw</a> (void)</td></tr> +<tr class="separator:a07da42351229525998965b219e827460"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ae66f6b31b5ad750f1fe042a706a4e3d4" id="r_ae66f6b31b5ad750f1fe042a706a4e3d4"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ae66f6b31b5ad750f1fe042a706a4e3d4">main</a> ()</td></tr> +<tr class="separator:ae66f6b31b5ad750f1fe042a706a4e3d4"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>Demo program for emulating unaligned memory accesses using the NEORV32 run-time environment (RTE). </p> +<dl class="section author"><dt>Author</dt><dd>Stephan Nolting </dd></dl> +</div><h2 class="groupheader">Macro Definition Documentation</h2> +<a id="ad4455691936f92fdd6c37566fc58ba1f" name="ad4455691936f92fdd6c37566fc58ba1f"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ad4455691936f92fdd6c37566fc58ba1f">&#9670;&#160;</a></span>BAUD_RATE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define BAUD_RATE&#160;&#160;&#160;19200</td> + </tr> + </table> +</div><div class="memdoc"> +<p>UART BAUD rate </p> + +</div> +</div> +<a id="a4407b4d6eae3ba7fe9538b1242a7e165" name="a4407b4d6eae3ba7fe9538b1242a7e165"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a4407b4d6eae3ba7fe9538b1242a7e165">&#9670;&#160;</a></span>DEBUG_INFO</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define DEBUG_INFO&#160;&#160;&#160;0</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Show debug info when 1 </p> + +</div> +</div> +<h2 class="groupheader">Function Documentation</h2> +<a id="ae66f6b31b5ad750f1fe042a706a4e3d4" name="ae66f6b31b5ad750f1fe042a706a4e3d4"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ae66f6b31b5ad750f1fe042a706a4e3d4">&#9670;&#160;</a></span>main()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int main </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Demo program to showcase RTE-based emulation of unaligned memory accesses.</p> +<dl class="section return"><dt>Returns</dt><dd>Irrelevant. </dd></dl> + +</div> +</div> +<a id="a07da42351229525998965b219e827460" name="a07da42351229525998965b219e827460"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a07da42351229525998965b219e827460">&#9670;&#160;</a></span>trap_handler_emulate_unaligned_lw()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void trap_handler_emulate_unaligned_lw </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Emulate unaligned load-word operation</p> +<dl class="section note"><dt>Note</dt><dd>This is a RTE "second-level" trap handler.</dd></dl> +<dl class="section warning"><dt>Warning</dt><dd>Compressed load instructions are not supported here! </dd></dl> + +</div> +</div> +<h2 class="groupheader">Variable Documentation</h2> +<a id="a556f675911f865ead06c36072b1b9c3b" name="a556f675911f865ead06c36072b1b9c3b"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a556f675911f865ead06c36072b1b9c3b">&#9670;&#160;</a></span>data_block</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">volatile uint32_t data_block[2]</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Emulate unaligned load-word operation</p> +<dl class="section note"><dt>Note</dt><dd>This is a RTE "second-level" trap handler.</dd></dl> +<dl class="section warning"><dt>Warning</dt><dd>Compressed load instructions are not supported here! </dd></dl> + +</div> +</div> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/demo__gptmr_2main_8c.html b/sw/demo__gptmr_2main_8c.html new file mode 100644 index 0000000000..fbdac7f3a7 --- /dev/null +++ b/sw/demo__gptmr_2main_8c.html @@ -0,0 +1,182 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/example/demo_gptmr/main.c File Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_f0f9b27afba2e8cc2da6e5fddcc1a8c9.html">example</a></li><li class="navelem"><a class="el" href="dir_b68ac2efc0c6ed3018151f7bb6c45670.html">demo_gptmr</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#func-members">Functions</a> </div> + <div class="headertitle"><div class="title">main.c File Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p>Simple GPTMR timer-match interrupt example. +<a href="#details">More...</a></p> +<div class="textblock"><code>#include &lt;<a class="el" href="neorv32_8h_source.html">neorv32.h</a>&gt;</code><br /> +</div><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="define-members" name="define-members"></a> +Macros</h2></td></tr> +<tr><td colspan="2"><div class="groupHeader">User configuration</div></td></tr> +<tr class="memitem:ad4455691936f92fdd6c37566fc58ba1f" id="r_ad4455691936f92fdd6c37566fc58ba1f"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ad4455691936f92fdd6c37566fc58ba1f">BAUD_RATE</a>&#160;&#160;&#160;19200</td></tr> +<tr class="separator:ad4455691936f92fdd6c37566fc58ba1f"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="func-members" name="func-members"></a> +Functions</h2></td></tr> +<tr class="memitem:a2bd89412466a65329711bfd5c29199c9" id="r_a2bd89412466a65329711bfd5c29199c9"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a2bd89412466a65329711bfd5c29199c9">gptmr_firq_handler</a> (void)</td></tr> +<tr class="separator:a2bd89412466a65329711bfd5c29199c9"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ae66f6b31b5ad750f1fe042a706a4e3d4" id="r_ae66f6b31b5ad750f1fe042a706a4e3d4"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ae66f6b31b5ad750f1fe042a706a4e3d4">main</a> ()</td></tr> +<tr class="separator:ae66f6b31b5ad750f1fe042a706a4e3d4"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>Simple GPTMR timer-match interrupt example. </p> +<dl class="section author"><dt>Author</dt><dd>Stephan Nolting </dd></dl> +</div><h2 class="groupheader">Macro Definition Documentation</h2> +<a id="ad4455691936f92fdd6c37566fc58ba1f" name="ad4455691936f92fdd6c37566fc58ba1f"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ad4455691936f92fdd6c37566fc58ba1f">&#9670;&#160;</a></span>BAUD_RATE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define BAUD_RATE&#160;&#160;&#160;19200</td> + </tr> + </table> +</div><div class="memdoc"> +<p>UART BAUD rate </p> + +</div> +</div> +<h2 class="groupheader">Function Documentation</h2> +<a id="a2bd89412466a65329711bfd5c29199c9" name="a2bd89412466a65329711bfd5c29199c9"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a2bd89412466a65329711bfd5c29199c9">&#9670;&#160;</a></span>gptmr_firq_handler()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void gptmr_firq_handler </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>GPTMR FIRQ handler.</p> +<dl class="section warning"><dt>Warning</dt><dd>This function has to be of type "void xyz(void)" and must not use any interrupt attributes! </dd></dl> + +</div> +</div> +<a id="ae66f6b31b5ad750f1fe042a706a4e3d4" name="ae66f6b31b5ad750f1fe042a706a4e3d4"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ae66f6b31b5ad750f1fe042a706a4e3d4">&#9670;&#160;</a></span>main()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int main </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>This program blinks an LED at GPIO.output(0) at 1Hz using the general purpose timer interrupt.</p> +<dl class="section note"><dt>Note</dt><dd>This program requires the GPTMR unit to be synthesized (and UART0 and GPIO).</dd></dl> +<dl class="section return"><dt>Returns</dt><dd>Should not return. </dd></dl> + +</div> +</div> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/demo__hpm_2main_8c.html b/sw/demo__hpm_2main_8c.html new file mode 100644 index 0000000000..4eb7c4794c --- /dev/null +++ b/sw/demo__hpm_2main_8c.html @@ -0,0 +1,161 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/example/demo_hpm/main.c File Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_f0f9b27afba2e8cc2da6e5fddcc1a8c9.html">example</a></li><li class="navelem"><a class="el" href="dir_93967190e0d2e549ceca77007097849b.html">demo_hpm</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#func-members">Functions</a> </div> + <div class="headertitle"><div class="title">main.c File Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p>Hardware performance monitor (HPM) example program. +<a href="#details">More...</a></p> +<div class="textblock"><code>#include &lt;<a class="el" href="neorv32_8h_source.html">neorv32.h</a>&gt;</code><br /> +</div><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="define-members" name="define-members"></a> +Macros</h2></td></tr> +<tr><td colspan="2"><div class="groupHeader">User configuration</div></td></tr> +<tr class="memitem:ad4455691936f92fdd6c37566fc58ba1f" id="r_ad4455691936f92fdd6c37566fc58ba1f"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ad4455691936f92fdd6c37566fc58ba1f">BAUD_RATE</a>&#160;&#160;&#160;19200</td></tr> +<tr class="separator:ad4455691936f92fdd6c37566fc58ba1f"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="func-members" name="func-members"></a> +Functions</h2></td></tr> +<tr class="memitem:ae66f6b31b5ad750f1fe042a706a4e3d4" id="r_ae66f6b31b5ad750f1fe042a706a4e3d4"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ae66f6b31b5ad750f1fe042a706a4e3d4">main</a> ()</td></tr> +<tr class="separator:ae66f6b31b5ad750f1fe042a706a4e3d4"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>Hardware performance monitor (HPM) example program. </p> +<dl class="section author"><dt>Author</dt><dd>Stephan Nolting </dd></dl> +</div><h2 class="groupheader">Macro Definition Documentation</h2> +<a id="ad4455691936f92fdd6c37566fc58ba1f" name="ad4455691936f92fdd6c37566fc58ba1f"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ad4455691936f92fdd6c37566fc58ba1f">&#9670;&#160;</a></span>BAUD_RATE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define BAUD_RATE&#160;&#160;&#160;19200</td> + </tr> + </table> +</div><div class="memdoc"> +<p>UART BAUD rate </p> + +</div> +</div> +<h2 class="groupheader">Function Documentation</h2> +<a id="ae66f6b31b5ad750f1fe042a706a4e3d4" name="ae66f6b31b5ad750f1fe042a706a4e3d4"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ae66f6b31b5ad750f1fe042a706a4e3d4">&#9670;&#160;</a></span>main()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int main </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Main function</p> +<dl class="section note"><dt>Note</dt><dd>This program requires the CPU Zihpm extension (with at least 2 regions) and UART0.</dd></dl> +<dl class="section return"><dt>Returns</dt><dd>0 if execution was successful </dd></dl> + +</div> +</div> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/demo__mtime_2main_8c.html b/sw/demo__mtime_2main_8c.html new file mode 100644 index 0000000000..1cdc157e46 --- /dev/null +++ b/sw/demo__mtime_2main_8c.html @@ -0,0 +1,174 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/example/demo_mtime/main.c File Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_f0f9b27afba2e8cc2da6e5fddcc1a8c9.html">example</a></li><li class="navelem"><a class="el" href="dir_8d341cbe0581f44e1ae95d82d74e8bc8.html">demo_mtime</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#define-members">Macros</a> &#124; +<a href="#func-members">Functions</a> &#124; +<a href="#var-members">Variables</a> </div> + <div class="headertitle"><div class="title">main.c File Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p>Simple machine timer (MTIME) usage example. +<a href="#details">More...</a></p> +<div class="textblock"><code>#include &lt;<a class="el" href="neorv32_8h_source.html">neorv32.h</a>&gt;</code><br /> +</div><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="define-members" name="define-members"></a> +Macros</h2></td></tr> +<tr class="memitem:ad4455691936f92fdd6c37566fc58ba1f" id="r_ad4455691936f92fdd6c37566fc58ba1f"><td class="memItemLeft" align="right" valign="top"><a id="ad4455691936f92fdd6c37566fc58ba1f" name="ad4455691936f92fdd6c37566fc58ba1f"></a> +#define&#160;</td><td class="memItemRight" valign="bottom"><b>BAUD_RATE</b>&#160;&#160;&#160;19200</td></tr> +<tr class="separator:ad4455691936f92fdd6c37566fc58ba1f"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="func-members" name="func-members"></a> +Functions</h2></td></tr> +<tr class="memitem:a329137855a7c2e098715a0771c5585d7" id="r_a329137855a7c2e098715a0771c5585d7"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a329137855a7c2e098715a0771c5585d7">mtime_irq_handler</a> (void)</td></tr> +<tr class="separator:a329137855a7c2e098715a0771c5585d7"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ae66f6b31b5ad750f1fe042a706a4e3d4" id="r_ae66f6b31b5ad750f1fe042a706a4e3d4"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ae66f6b31b5ad750f1fe042a706a4e3d4">main</a> ()</td></tr> +<tr class="separator:ae66f6b31b5ad750f1fe042a706a4e3d4"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="var-members" name="var-members"></a> +Variables</h2></td></tr> +<tr class="memitem:a8cc234243e9622043b343cde3d4dccac" id="r_a8cc234243e9622043b343cde3d4dccac"><td class="memItemLeft" align="right" valign="top"><a id="a8cc234243e9622043b343cde3d4dccac" name="a8cc234243e9622043b343cde3d4dccac"></a> +const char&#160;</td><td class="memItemRight" valign="bottom"><b>weekdays</b> [7][4] = {&quot;Mon&quot;, &quot;Tue&quot;, &quot;Wed&quot;, &quot;Thu&quot;, &quot;Fri&quot;, &quot;Sat&quot;, &quot;Sun&quot;}</td></tr> +<tr class="separator:a8cc234243e9622043b343cde3d4dccac"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>Simple machine timer (MTIME) usage example. </p> +<dl class="section author"><dt>Author</dt><dd>Stephan Nolting </dd></dl> +</div><h2 class="groupheader">Function Documentation</h2> +<a id="ae66f6b31b5ad750f1fe042a706a4e3d4" name="ae66f6b31b5ad750f1fe042a706a4e3d4"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ae66f6b31b5ad750f1fe042a706a4e3d4">&#9670;&#160;</a></span>main()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int main </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>This program toggles an LED at GPIO.output(0) at 1Hz and also prints and updates the Unix time in human-readable format using the machine timer interrupt.</p> +<dl class="section note"><dt>Note</dt><dd>This program requires the MTIME unit to be synthesized (and UART0 and GPIO).</dd></dl> +<dl class="section return"><dt>Returns</dt><dd>Should not return. </dd></dl> + +</div> +</div> +<a id="a329137855a7c2e098715a0771c5585d7" name="a329137855a7c2e098715a0771c5585d7"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a329137855a7c2e098715a0771c5585d7">&#9670;&#160;</a></span>mtime_irq_handler()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void mtime_irq_handler </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>MTIME IRQ handler.</p> +<dl class="section warning"><dt>Warning</dt><dd>This function has to be of type "void xyz(void)" and must not use any interrupt attributes! </dd></dl> + +</div> +</div> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/demo__neopixel_2main_8c.html b/sw/demo__neopixel_2main_8c.html new file mode 100644 index 0000000000..0fbec26b4b --- /dev/null +++ b/sw/demo__neopixel_2main_8c.html @@ -0,0 +1,228 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/example/demo_neopixel/main.c File Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_f0f9b27afba2e8cc2da6e5fddcc1a8c9.html">example</a></li><li class="navelem"><a class="el" href="dir_d68bb921df3f2482fe9ace49b286ab86.html">demo_neopixel</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#func-members">Functions</a> </div> + <div class="headertitle"><div class="title">main.c File Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p>NeoPixel (WS2812) interface demo using the processor's smart LED interface (NEOLED). +<a href="#details">More...</a></p> +<div class="textblock"><code>#include &lt;<a class="el" href="neorv32_8h_source.html">neorv32.h</a>&gt;</code><br /> +</div><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="define-members" name="define-members"></a> +Macros</h2></td></tr> +<tr><td colspan="2"><div class="groupHeader">User configuration</div></td></tr> +<tr class="memitem:ad4455691936f92fdd6c37566fc58ba1f" id="r_ad4455691936f92fdd6c37566fc58ba1f"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ad4455691936f92fdd6c37566fc58ba1f">BAUD_RATE</a>&#160;&#160;&#160;19200</td></tr> +<tr class="separator:ad4455691936f92fdd6c37566fc58ba1f"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aa1dddb8d6b3b4d2f19afc3c09e2ff572" id="r_aa1dddb8d6b3b4d2f19afc3c09e2ff572"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aa1dddb8d6b3b4d2f19afc3c09e2ff572">NUM_LEDS_24BIT</a>&#160;&#160;&#160;(12)</td></tr> +<tr class="separator:aa1dddb8d6b3b4d2f19afc3c09e2ff572"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a1d1d5e7ff16f25b68fdf779befd298f7" id="r_a1d1d5e7ff16f25b68fdf779befd298f7"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a1d1d5e7ff16f25b68fdf779befd298f7">MAX_INTENSITY</a>&#160;&#160;&#160;(16)</td></tr> +<tr class="separator:a1d1d5e7ff16f25b68fdf779befd298f7"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="func-members" name="func-members"></a> +Functions</h2></td></tr> +<tr class="memitem:a2736ec755f9e10c80bf66f727f870ffc" id="r_a2736ec755f9e10c80bf66f727f870ffc"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a2736ec755f9e10c80bf66f727f870ffc">hsv2rgb</a> (int h, int v)</td></tr> +<tr class="separator:a2736ec755f9e10c80bf66f727f870ffc"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ae66f6b31b5ad750f1fe042a706a4e3d4" id="r_ae66f6b31b5ad750f1fe042a706a4e3d4"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ae66f6b31b5ad750f1fe042a706a4e3d4">main</a> ()</td></tr> +<tr class="separator:ae66f6b31b5ad750f1fe042a706a4e3d4"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>NeoPixel (WS2812) interface demo using the processor's smart LED interface (NEOLED). </p> +<dl class="section author"><dt>Author</dt><dd>Stephan Nolting </dd></dl> +</div><h2 class="groupheader">Macro Definition Documentation</h2> +<a id="ad4455691936f92fdd6c37566fc58ba1f" name="ad4455691936f92fdd6c37566fc58ba1f"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ad4455691936f92fdd6c37566fc58ba1f">&#9670;&#160;</a></span>BAUD_RATE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define BAUD_RATE&#160;&#160;&#160;19200</td> + </tr> + </table> +</div><div class="memdoc"> +<p>UART BAUD rate </p> + +</div> +</div> +<a id="a1d1d5e7ff16f25b68fdf779befd298f7" name="a1d1d5e7ff16f25b68fdf779befd298f7"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a1d1d5e7ff16f25b68fdf779befd298f7">&#9670;&#160;</a></span>MAX_INTENSITY</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define MAX_INTENSITY&#160;&#160;&#160;(16)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Max intensity (0..255) </p> + +</div> +</div> +<a id="aa1dddb8d6b3b4d2f19afc3c09e2ff572" name="aa1dddb8d6b3b4d2f19afc3c09e2ff572"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aa1dddb8d6b3b4d2f19afc3c09e2ff572">&#9670;&#160;</a></span>NUM_LEDS_24BIT</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define NUM_LEDS_24BIT&#160;&#160;&#160;(12)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Number of RGB LEDs in stripe (24-bit data) </p> + +</div> +</div> +<h2 class="groupheader">Function Documentation</h2> +<a id="a2736ec755f9e10c80bf66f727f870ffc" name="a2736ec755f9e10c80bf66f727f870ffc"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a2736ec755f9e10c80bf66f727f870ffc">&#9670;&#160;</a></span>hsv2rgb()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t hsv2rgb </td> + <td>(</td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>h</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>v</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Convert HSV color to RGB.</p> +<dl class="section note"><dt>Note</dt><dd>Very simple version: using integer arithmetic and ignoring saturation (saturation is always MAX).</dd></dl> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">h</td><td>Hue (color angle), 0..359 </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">v</td><td>Value (intensity), 0..255 </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>LSB-aligned 24-bit RGB data [G,R,B] </dd></dl> + +</div> +</div> +<a id="ae66f6b31b5ad750f1fe042a706a4e3d4" name="ae66f6b31b5ad750f1fe042a706a4e3d4"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ae66f6b31b5ad750f1fe042a706a4e3d4">&#9670;&#160;</a></span>main()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int main </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Main function This demo uses a 12-LED RGB ring</p> +<dl class="section note"><dt>Note</dt><dd>This program requires the NEOLED controller to be synthesized (UART0 is optional).</dd></dl> +<dl class="section return"><dt>Returns</dt><dd>0 if execution was successful </dd></dl> + +</div> +</div> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/demo__newlib_2main_8c.html b/sw/demo__newlib_2main_8c.html new file mode 100644 index 0000000000..d067b9df05 --- /dev/null +++ b/sw/demo__newlib_2main_8c.html @@ -0,0 +1,196 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/example/demo_newlib/main.c File Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_f0f9b27afba2e8cc2da6e5fddcc1a8c9.html">example</a></li><li class="navelem"><a class="el" href="dir_23717ebbabf7a51c0558262947e0fe3b.html">demo_newlib</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="headertitle"><div class="title">main.c File Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p>Demo/test program for NEORV32's newlib C standard library support. +<a href="#details">More...</a></p> +<div class="textblock"><code>#include &lt;<a class="el" href="neorv32_8h_source.html">neorv32.h</a>&gt;</code><br /> +<code>#include &lt;unistd.h&gt;</code><br /> +<code>#include &lt;time.h&gt;</code><br /> +<code>#include &lt;stdlib.h&gt;</code><br /> +</div><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="define-members" name="define-members"></a> +Macros</h2></td></tr> +<tr><td colspan="2"><div class="groupHeader">User configuration</div></td></tr> +<tr class="memitem:ad4455691936f92fdd6c37566fc58ba1f" id="r_ad4455691936f92fdd6c37566fc58ba1f"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ad4455691936f92fdd6c37566fc58ba1f">BAUD_RATE</a>&#160;&#160;&#160;19200</td></tr> +<tr class="separator:ad4455691936f92fdd6c37566fc58ba1f"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="func-members" name="func-members"></a> +Functions</h2></td></tr> +<tr><td colspan="2"><div class="groupHeader">Print main's return code using a destructor</div></td></tr> +<tr class="memitem:a7076a1dfd3c18c91fcf665ce54b087b3" id="r_a7076a1dfd3c18c91fcf665ce54b087b3"><td class="memItemLeft" align="right" valign="top"><a id="a7076a1dfd3c18c91fcf665ce54b087b3" name="a7076a1dfd3c18c91fcf665ce54b087b3"></a> +void&#160;</td><td class="memItemRight" valign="bottom"><b>main_destructor_test</b> (void)</td></tr> +<tr class="separator:a7076a1dfd3c18c91fcf665ce54b087b3"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader">Max heap size (from linker script's "__neorv32_heap_size")</h2></td></tr> +<tr class="memitem:aaa2cb9e7075a852870fd67eff2861b18" id="r_aaa2cb9e7075a852870fd67eff2861b18"><td class="memItemLeft" align="right" valign="top">char&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aaa2cb9e7075a852870fd67eff2861b18">__crt0_max_heap</a> []</td></tr> +<tr class="separator:aaa2cb9e7075a852870fd67eff2861b18"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ae66f6b31b5ad750f1fe042a706a4e3d4" id="r_ae66f6b31b5ad750f1fe042a706a4e3d4"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ae66f6b31b5ad750f1fe042a706a4e3d4">main</a> ()</td></tr> +<tr class="separator:ae66f6b31b5ad750f1fe042a706a4e3d4"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>Demo/test program for NEORV32's newlib C standard library support. </p> +<dl class="section author"><dt>Author</dt><dd>Stephan Nolting </dd></dl> +</div><h2 class="groupheader">Macro Definition Documentation</h2> +<a id="ad4455691936f92fdd6c37566fc58ba1f" name="ad4455691936f92fdd6c37566fc58ba1f"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ad4455691936f92fdd6c37566fc58ba1f">&#9670;&#160;</a></span>BAUD_RATE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define BAUD_RATE&#160;&#160;&#160;19200</td> + </tr> + </table> +</div><div class="memdoc"> +<p>UART BAUD rate </p> + +</div> +</div> +<h2 class="groupheader">Function Documentation</h2> +<a id="ae66f6b31b5ad750f1fe042a706a4e3d4" name="ae66f6b31b5ad750f1fe042a706a4e3d4"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ae66f6b31b5ad750f1fe042a706a4e3d4">&#9670;&#160;</a></span>main()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int main </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Main function: Check some of newlib's core functions.</p> +<dl class="section note"><dt>Note</dt><dd>This program requires UART0.</dd></dl> +<dl class="section return"><dt>Returns</dt><dd>0 if execution was successful </dd></dl> + +</div> +</div> +<h2 class="groupheader">Variable Documentation</h2> +<a id="aaa2cb9e7075a852870fd67eff2861b18" name="aaa2cb9e7075a852870fd67eff2861b18"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aaa2cb9e7075a852870fd67eff2861b18">&#9670;&#160;</a></span>__crt0_max_heap</h2> + +<div class="memitem"> +<div class="memproto"> +<table class="mlabels"> + <tr> + <td class="mlabels-left"> + <table class="memname"> + <tr> + <td class="memname">char __crt0_max_heap[]</td> + </tr> + </table> + </td> + <td class="mlabels-right"> +<span class="mlabels"><span class="mlabel">extern</span></span> </td> + </tr> +</table> +</div><div class="memdoc"> +<p>Main function: Check some of newlib's core functions.</p> +<dl class="section note"><dt>Note</dt><dd>This program requires UART0.</dd></dl> +<dl class="section return"><dt>Returns</dt><dd>0 if execution was successful </dd></dl> + +</div> +</div> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/demo__onewire_2main_8c.html b/sw/demo__onewire_2main_8c.html new file mode 100644 index 0000000000..25af896062 --- /dev/null +++ b/sw/demo__onewire_2main_8c.html @@ -0,0 +1,270 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/example/demo_onewire/main.c File Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_f0f9b27afba2e8cc2da6e5fddcc1a8c9.html">example</a></li><li class="navelem"><a class="el" href="dir_3b3bafc48b460f797485cc75b94aa81c.html">demo_onewire</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#func-members">Functions</a> &#124; +<a href="#var-members">Variables</a> </div> + <div class="headertitle"><div class="title">main.c File Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p>Demo program for the NEORV32 1-Wire interface controller (ONEWIRE). +<a href="#details">More...</a></p> +<div class="textblock"><code>#include &lt;<a class="el" href="neorv32_8h_source.html">neorv32.h</a>&gt;</code><br /> +<code>#include &lt;string.h&gt;</code><br /> +<code>#include &quot;onewire_aux.h&quot;</code><br /> +</div><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="define-members" name="define-members"></a> +Macros</h2></td></tr> +<tr><td colspan="2"><div class="groupHeader">User configuration</div></td></tr> +<tr class="memitem:ad4455691936f92fdd6c37566fc58ba1f" id="r_ad4455691936f92fdd6c37566fc58ba1f"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ad4455691936f92fdd6c37566fc58ba1f">BAUD_RATE</a>&#160;&#160;&#160;19200</td></tr> +<tr class="separator:ad4455691936f92fdd6c37566fc58ba1f"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="func-members" name="func-members"></a> +Functions</h2></td></tr> +<tr class="memitem:af25820ed386a66a0d6bb4dcdd2204704" id="r_af25820ed386a66a0d6bb4dcdd2204704"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#af25820ed386a66a0d6bb4dcdd2204704">show_help</a> (void)</td></tr> +<tr class="separator:af25820ed386a66a0d6bb4dcdd2204704"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a29d5831498c2eaf0415d6f01efb9e7ce" id="r_a29d5831498c2eaf0415d6f01efb9e7ce"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a29d5831498c2eaf0415d6f01efb9e7ce">show_1wire_commands</a> (void)</td></tr> +<tr class="separator:a29d5831498c2eaf0415d6f01efb9e7ce"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a951a31029af34715f20856eb82432637" id="r_a951a31029af34715f20856eb82432637"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a951a31029af34715f20856eb82432637">read_byte</a> (void)</td></tr> +<tr class="separator:a951a31029af34715f20856eb82432637"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a28283848f09bf8feebc860a51545f487" id="r_a28283848f09bf8feebc860a51545f487"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a28283848f09bf8feebc860a51545f487">write_byte</a> (void)</td></tr> +<tr class="separator:a28283848f09bf8feebc860a51545f487"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ac07c9cfd80ac2e24be9dac6cf943b7de" id="r_ac07c9cfd80ac2e24be9dac6cf943b7de"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ac07c9cfd80ac2e24be9dac6cf943b7de">scan_bus</a> (void)</td></tr> +<tr class="separator:ac07c9cfd80ac2e24be9dac6cf943b7de"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ae66f6b31b5ad750f1fe042a706a4e3d4" id="r_ae66f6b31b5ad750f1fe042a706a4e3d4"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ae66f6b31b5ad750f1fe042a706a4e3d4">main</a> ()</td></tr> +<tr class="separator:ae66f6b31b5ad750f1fe042a706a4e3d4"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="var-members" name="var-members"></a> +Variables</h2></td></tr> +<tr class="memitem:a8c86c6436e898f550d96b4ae9aa8c2cd" id="r_a8c86c6436e898f550d96b4ae9aa8c2cd"><td class="memItemLeft" align="right" valign="top"><a id="a8c86c6436e898f550d96b4ae9aa8c2cd" name="a8c86c6436e898f550d96b4ae9aa8c2cd"></a> +const char&#160;</td><td class="memItemRight" valign="bottom"><b>hex_c</b> [16] = {'0','1','2','3','4','5','6','7','8','9','a','b','c','d','e','f'}</td></tr> +<tr class="separator:a8c86c6436e898f550d96b4ae9aa8c2cd"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>Demo program for the NEORV32 1-Wire interface controller (ONEWIRE). </p> +<dl class="section author"><dt>Author</dt><dd>Stephan Nolting </dd></dl> +</div><h2 class="groupheader">Macro Definition Documentation</h2> +<a id="ad4455691936f92fdd6c37566fc58ba1f" name="ad4455691936f92fdd6c37566fc58ba1f"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ad4455691936f92fdd6c37566fc58ba1f">&#9670;&#160;</a></span>BAUD_RATE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define BAUD_RATE&#160;&#160;&#160;19200</td> + </tr> + </table> +</div><div class="memdoc"> +<p>UART BAUD rate </p> + +</div> +</div> +<h2 class="groupheader">Function Documentation</h2> +<a id="ae66f6b31b5ad750f1fe042a706a4e3d4" name="ae66f6b31b5ad750f1fe042a706a4e3d4"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ae66f6b31b5ad750f1fe042a706a4e3d4">&#9670;&#160;</a></span>main()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int main </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Main function</p> +<dl class="section note"><dt>Note</dt><dd>This program requires the ONEWIRE and UART0 modules. Only non-blocking ONEWIRE functions are used.</dd></dl> +<dl class="section return"><dt>Returns</dt><dd>!=0 if setup error </dd></dl> + +</div> +</div> +<a id="a951a31029af34715f20856eb82432637" name="a951a31029af34715f20856eb82432637"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a951a31029af34715f20856eb82432637">&#9670;&#160;</a></span>read_byte()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void read_byte </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Read full byte from bus. </p> + +</div> +</div> +<a id="ac07c9cfd80ac2e24be9dac6cf943b7de" name="ac07c9cfd80ac2e24be9dac6cf943b7de"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ac07c9cfd80ac2e24be9dac6cf943b7de">&#9670;&#160;</a></span>scan_bus()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void scan_bus </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Scan bus for devices and print IDs. </p> + +</div> +</div> +<a id="a29d5831498c2eaf0415d6f01efb9e7ce" name="a29d5831498c2eaf0415d6f01efb9e7ce"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a29d5831498c2eaf0415d6f01efb9e7ce">&#9670;&#160;</a></span>show_1wire_commands()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void show_1wire_commands </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Show standard 1-wire commands. </p> + +</div> +</div> +<a id="af25820ed386a66a0d6bb4dcdd2204704" name="af25820ed386a66a0d6bb4dcdd2204704"></a> +<h2 class="memtitle"><span class="permalink"><a href="#af25820ed386a66a0d6bb4dcdd2204704">&#9670;&#160;</a></span>show_help()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void show_help </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Show help menu. </p> + +</div> +</div> +<a id="a28283848f09bf8feebc860a51545f487" name="a28283848f09bf8feebc860a51545f487"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a28283848f09bf8feebc860a51545f487">&#9670;&#160;</a></span>write_byte()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void write_byte </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Write full byte to bus. </p> + +</div> +</div> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/demo__pwm_2main_8c.html b/sw/demo__pwm_2main_8c.html new file mode 100644 index 0000000000..dd60ce236f --- /dev/null +++ b/sw/demo__pwm_2main_8c.html @@ -0,0 +1,178 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/example/demo_pwm/main.c File Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_f0f9b27afba2e8cc2da6e5fddcc1a8c9.html">example</a></li><li class="navelem"><a class="el" href="dir_b683da3a5fc966bff32ebf7cda721811.html">demo_pwm</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#func-members">Functions</a> </div> + <div class="headertitle"><div class="title">main.c File Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p>Simple PWM demo program. +<a href="#details">More...</a></p> +<div class="textblock"><code>#include &lt;<a class="el" href="neorv32_8h_source.html">neorv32.h</a>&gt;</code><br /> +</div><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="define-members" name="define-members"></a> +Macros</h2></td></tr> +<tr><td colspan="2"><div class="groupHeader">User configuration</div></td></tr> +<tr class="memitem:ad4455691936f92fdd6c37566fc58ba1f" id="r_ad4455691936f92fdd6c37566fc58ba1f"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ad4455691936f92fdd6c37566fc58ba1f">BAUD_RATE</a>&#160;&#160;&#160;19200</td></tr> +<tr class="separator:ad4455691936f92fdd6c37566fc58ba1f"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a391fa1e490bd712720989b58fa0d9904" id="r_a391fa1e490bd712720989b58fa0d9904"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a391fa1e490bd712720989b58fa0d9904">PWM_MAX</a>&#160;&#160;&#160;200</td></tr> +<tr class="separator:a391fa1e490bd712720989b58fa0d9904"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="func-members" name="func-members"></a> +Functions</h2></td></tr> +<tr class="memitem:ae66f6b31b5ad750f1fe042a706a4e3d4" id="r_ae66f6b31b5ad750f1fe042a706a4e3d4"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ae66f6b31b5ad750f1fe042a706a4e3d4">main</a> ()</td></tr> +<tr class="separator:ae66f6b31b5ad750f1fe042a706a4e3d4"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>Simple PWM demo program. </p> +<dl class="section author"><dt>Author</dt><dd>Stephan Nolting </dd></dl> +</div><h2 class="groupheader">Macro Definition Documentation</h2> +<a id="ad4455691936f92fdd6c37566fc58ba1f" name="ad4455691936f92fdd6c37566fc58ba1f"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ad4455691936f92fdd6c37566fc58ba1f">&#9670;&#160;</a></span>BAUD_RATE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define BAUD_RATE&#160;&#160;&#160;19200</td> + </tr> + </table> +</div><div class="memdoc"> +<p>UART BAUD rate </p> + +</div> +</div> +<a id="a391fa1e490bd712720989b58fa0d9904" name="a391fa1e490bd712720989b58fa0d9904"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a391fa1e490bd712720989b58fa0d9904">&#9670;&#160;</a></span>PWM_MAX</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define PWM_MAX&#160;&#160;&#160;200</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Maximum PWM output intensity (8-bit) </p> + +</div> +</div> +<h2 class="groupheader">Function Documentation</h2> +<a id="ae66f6b31b5ad750f1fe042a706a4e3d4" name="ae66f6b31b5ad750f1fe042a706a4e3d4"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ae66f6b31b5ad750f1fe042a706a4e3d4">&#9670;&#160;</a></span>main()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int main </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>This program generates a simple dimming sequence for PWM channels 0 to 3.</p> +<dl class="section note"><dt>Note</dt><dd>This program requires the PWM controller to be synthesized (the UART is optional).</dd></dl> +<dl class="section return"><dt>Returns</dt><dd>!=0 if error. </dd></dl> + +</div> +</div> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/demo__sdi_2main_8c.html b/sw/demo__sdi_2main_8c.html new file mode 100644 index 0000000000..bbb4d60fd3 --- /dev/null +++ b/sw/demo__sdi_2main_8c.html @@ -0,0 +1,202 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/example/demo_sdi/main.c File Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_f0f9b27afba2e8cc2da6e5fddcc1a8c9.html">example</a></li><li class="navelem"><a class="el" href="dir_c413aba6cb5da07a571465ba333950af.html">demo_sdi</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#func-members">Functions</a> </div> + <div class="headertitle"><div class="title">main.c File Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p>SDI test program (direct access to the SDI module). +<a href="#details">More...</a></p> +<div class="textblock"><code>#include &lt;<a class="el" href="neorv32_8h_source.html">neorv32.h</a>&gt;</code><br /> +<code>#include &lt;string.h&gt;</code><br /> +</div><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="define-members" name="define-members"></a> +Macros</h2></td></tr> +<tr><td colspan="2"><div class="groupHeader">User configuration</div></td></tr> +<tr class="memitem:ad4455691936f92fdd6c37566fc58ba1f" id="r_ad4455691936f92fdd6c37566fc58ba1f"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ad4455691936f92fdd6c37566fc58ba1f">BAUD_RATE</a>&#160;&#160;&#160;19200</td></tr> +<tr class="separator:ad4455691936f92fdd6c37566fc58ba1f"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="func-members" name="func-members"></a> +Functions</h2></td></tr> +<tr class="memitem:ae3dc843520a800d7ba2b5d6be03d9c3d" id="r_ae3dc843520a800d7ba2b5d6be03d9c3d"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ae3dc843520a800d7ba2b5d6be03d9c3d">sdi_put</a> (void)</td></tr> +<tr class="separator:ae3dc843520a800d7ba2b5d6be03d9c3d"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aa25f620a5631e862252be1d5429e8585" id="r_aa25f620a5631e862252be1d5429e8585"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aa25f620a5631e862252be1d5429e8585">sdi_get</a> (void)</td></tr> +<tr class="separator:aa25f620a5631e862252be1d5429e8585"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ae66f6b31b5ad750f1fe042a706a4e3d4" id="r_ae66f6b31b5ad750f1fe042a706a4e3d4"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ae66f6b31b5ad750f1fe042a706a4e3d4">main</a> ()</td></tr> +<tr class="separator:ae66f6b31b5ad750f1fe042a706a4e3d4"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>SDI test program (direct access to the SDI module). </p> +<dl class="section author"><dt>Author</dt><dd>Stephan Nolting </dd></dl> +</div><h2 class="groupheader">Macro Definition Documentation</h2> +<a id="ad4455691936f92fdd6c37566fc58ba1f" name="ad4455691936f92fdd6c37566fc58ba1f"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ad4455691936f92fdd6c37566fc58ba1f">&#9670;&#160;</a></span>BAUD_RATE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define BAUD_RATE&#160;&#160;&#160;19200</td> + </tr> + </table> +</div><div class="memdoc"> +<p>UART BAUD rate </p> + +</div> +</div> +<h2 class="groupheader">Function Documentation</h2> +<a id="ae66f6b31b5ad750f1fe042a706a4e3d4" name="ae66f6b31b5ad750f1fe042a706a4e3d4"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ae66f6b31b5ad750f1fe042a706a4e3d4">&#9670;&#160;</a></span>main()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int main </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>This program provides an interactive console for the SDI module.</p> +<dl class="section note"><dt>Note</dt><dd>This program requires UART0 and the SDI to be synthesized.</dd></dl> +<dl class="section return"><dt>Returns</dt><dd>Irrelevant. </dd></dl> + +</div> +</div> +<a id="aa25f620a5631e862252be1d5429e8585" name="aa25f620a5631e862252be1d5429e8585"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aa25f620a5631e862252be1d5429e8585">&#9670;&#160;</a></span>sdi_get()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void sdi_get </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Read data from SDI RX buffer. </p> + +</div> +</div> +<a id="ae3dc843520a800d7ba2b5d6be03d9c3d" name="ae3dc843520a800d7ba2b5d6be03d9c3d"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ae3dc843520a800d7ba2b5d6be03d9c3d">&#9670;&#160;</a></span>sdi_put()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void sdi_put </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Write data to SDI TX buffer. </p> + +</div> +</div> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/demo__slink_2main_8c.html b/sw/demo__slink_2main_8c.html new file mode 100644 index 0000000000..ec62fe9e43 --- /dev/null +++ b/sw/demo__slink_2main_8c.html @@ -0,0 +1,182 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/example/demo_slink/main.c File Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_f0f9b27afba2e8cc2da6e5fddcc1a8c9.html">example</a></li><li class="navelem"><a class="el" href="dir_c2d46947bdd73c33f53326fc5ee3a272.html">demo_slink</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#func-members">Functions</a> </div> + <div class="headertitle"><div class="title">main.c File Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p>SLINK demo program. +<a href="#details">More...</a></p> +<div class="textblock"><code>#include &lt;<a class="el" href="neorv32_8h_source.html">neorv32.h</a>&gt;</code><br /> +<code>#include &lt;string.h&gt;</code><br /> +</div><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="define-members" name="define-members"></a> +Macros</h2></td></tr> +<tr><td colspan="2"><div class="groupHeader">User configuration</div></td></tr> +<tr class="memitem:ad4455691936f92fdd6c37566fc58ba1f" id="r_ad4455691936f92fdd6c37566fc58ba1f"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ad4455691936f92fdd6c37566fc58ba1f">BAUD_RATE</a>&#160;&#160;&#160;19200</td></tr> +<tr class="separator:ad4455691936f92fdd6c37566fc58ba1f"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="func-members" name="func-members"></a> +Functions</h2></td></tr> +<tr class="memitem:a48c79e20ed1d4138d61b5593bdbe537a" id="r_a48c79e20ed1d4138d61b5593bdbe537a"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a48c79e20ed1d4138d61b5593bdbe537a">slink_firq_handler</a> (void)</td></tr> +<tr class="separator:a48c79e20ed1d4138d61b5593bdbe537a"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ae66f6b31b5ad750f1fe042a706a4e3d4" id="r_ae66f6b31b5ad750f1fe042a706a4e3d4"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ae66f6b31b5ad750f1fe042a706a4e3d4">main</a> ()</td></tr> +<tr class="separator:ae66f6b31b5ad750f1fe042a706a4e3d4"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>SLINK demo program. </p> +<dl class="section author"><dt>Author</dt><dd>Stephan Nolting </dd></dl> +</div><h2 class="groupheader">Macro Definition Documentation</h2> +<a id="ad4455691936f92fdd6c37566fc58ba1f" name="ad4455691936f92fdd6c37566fc58ba1f"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ad4455691936f92fdd6c37566fc58ba1f">&#9670;&#160;</a></span>BAUD_RATE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define BAUD_RATE&#160;&#160;&#160;19200</td> + </tr> + </table> +</div><div class="memdoc"> +<p>UART BAUD rate </p> + +</div> +</div> +<h2 class="groupheader">Function Documentation</h2> +<a id="ae66f6b31b5ad750f1fe042a706a4e3d4" name="ae66f6b31b5ad750f1fe042a706a4e3d4"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ae66f6b31b5ad750f1fe042a706a4e3d4">&#9670;&#160;</a></span>main()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int main </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Simple SLINK demo program.</p> +<dl class="section note"><dt>Note</dt><dd>This program requires the UART0 and the SLINK to be synthesized.</dd></dl> +<dl class="section return"><dt>Returns</dt><dd>=! 0 if execution failed. </dd></dl> + +</div> +</div> +<a id="a48c79e20ed1d4138d61b5593bdbe537a" name="a48c79e20ed1d4138d61b5593bdbe537a"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a48c79e20ed1d4138d61b5593bdbe537a">&#9670;&#160;</a></span>slink_firq_handler()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void slink_firq_handler </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>SLINK interrupt handler. </p> + +</div> +</div> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/demo__spi_2main_8c.html b/sw/demo__spi_2main_8c.html new file mode 100644 index 0000000000..c3ef10e400 --- /dev/null +++ b/sw/demo__spi_2main_8c.html @@ -0,0 +1,261 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/example/demo_spi/main.c File Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_f0f9b27afba2e8cc2da6e5fddcc1a8c9.html">example</a></li><li class="navelem"><a class="el" href="dir_4c113257314015688a865e1bb8429184.html">demo_spi</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#func-members">Functions</a> &#124; +<a href="#var-members">Variables</a> </div> + <div class="headertitle"><div class="title">main.c File Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p>SPI bus explorer (execute SPI transactions by hand). +<a href="#details">More...</a></p> +<div class="textblock"><code>#include &lt;<a class="el" href="neorv32_8h_source.html">neorv32.h</a>&gt;</code><br /> +<code>#include &lt;string.h&gt;</code><br /> +</div><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="define-members" name="define-members"></a> +Macros</h2></td></tr> +<tr><td colspan="2"><div class="groupHeader">User configuration</div></td></tr> +<tr class="memitem:ad4455691936f92fdd6c37566fc58ba1f" id="r_ad4455691936f92fdd6c37566fc58ba1f"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ad4455691936f92fdd6c37566fc58ba1f">BAUD_RATE</a>&#160;&#160;&#160;19200</td></tr> +<tr class="separator:ad4455691936f92fdd6c37566fc58ba1f"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="func-members" name="func-members"></a> +Functions</h2></td></tr> +<tr class="memitem:a6f94991b8943a141ed4124585222470d" id="r_a6f94991b8943a141ed4124585222470d"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a6f94991b8943a141ed4124585222470d">spi_cs</a> (uint32_t type)</td></tr> +<tr class="separator:a6f94991b8943a141ed4124585222470d"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a13e10b34fbbffca6c31f0ce25b3f8432" id="r_a13e10b34fbbffca6c31f0ce25b3f8432"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a13e10b34fbbffca6c31f0ce25b3f8432">spi_trans</a> (void)</td></tr> +<tr class="separator:a13e10b34fbbffca6c31f0ce25b3f8432"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a755192be6c3cf9904564b0eee99de445" id="r_a755192be6c3cf9904564b0eee99de445"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a755192be6c3cf9904564b0eee99de445">spi_setup</a> (void)</td></tr> +<tr class="separator:a755192be6c3cf9904564b0eee99de445"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ac582208281cd6fce4eb61c234f312ef6" id="r_ac582208281cd6fce4eb61c234f312ef6"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ac582208281cd6fce4eb61c234f312ef6">aux_print_hex_byte</a> (uint8_t byte)</td></tr> +<tr class="separator:ac582208281cd6fce4eb61c234f312ef6"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ae66f6b31b5ad750f1fe042a706a4e3d4" id="r_ae66f6b31b5ad750f1fe042a706a4e3d4"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ae66f6b31b5ad750f1fe042a706a4e3d4">main</a> ()</td></tr> +<tr class="separator:ae66f6b31b5ad750f1fe042a706a4e3d4"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="var-members" name="var-members"></a> +Variables</h2></td></tr> +<tr class="memitem:a4ebbc33db8ee81cb971eba8365696709" id="r_a4ebbc33db8ee81cb971eba8365696709"><td class="memItemLeft" align="right" valign="top"><a id="a4ebbc33db8ee81cb971eba8365696709" name="a4ebbc33db8ee81cb971eba8365696709"></a> +uint32_t&#160;</td><td class="memItemRight" valign="bottom"><b>spi_configured</b></td></tr> +<tr class="separator:a4ebbc33db8ee81cb971eba8365696709"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>SPI bus explorer (execute SPI transactions by hand). </p> +<dl class="section author"><dt>Author</dt><dd>Stephan Nolting </dd></dl> +</div><h2 class="groupheader">Macro Definition Documentation</h2> +<a id="ad4455691936f92fdd6c37566fc58ba1f" name="ad4455691936f92fdd6c37566fc58ba1f"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ad4455691936f92fdd6c37566fc58ba1f">&#9670;&#160;</a></span>BAUD_RATE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define BAUD_RATE&#160;&#160;&#160;19200</td> + </tr> + </table> +</div><div class="memdoc"> +<p>UART BAUD rate </p> + +</div> +</div> +<h2 class="groupheader">Function Documentation</h2> +<a id="ac582208281cd6fce4eb61c234f312ef6" name="ac582208281cd6fce4eb61c234f312ef6"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ac582208281cd6fce4eb61c234f312ef6">&#9670;&#160;</a></span>aux_print_hex_byte()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void aux_print_hex_byte </td> + <td>(</td> + <td class="paramtype">uint8_t</td> <td class="paramname"><span class="paramname"><em>byte</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Print HEX byte.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">byte</td><td>Byte to be printed as 2-cahr hex value. </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="ae66f6b31b5ad750f1fe042a706a4e3d4" name="ae66f6b31b5ad750f1fe042a706a4e3d4"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ae66f6b31b5ad750f1fe042a706a4e3d4">&#9670;&#160;</a></span>main()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int main </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>This program provides an interactive console to communicate with SPI devices.</p> +<dl class="section note"><dt>Note</dt><dd>This program requires the UART and the SPI to be synthesized.</dd></dl> +<dl class="section return"><dt>Returns</dt><dd>Irrelevant. </dd></dl> + +</div> +</div> +<a id="a6f94991b8943a141ed4124585222470d" name="a6f94991b8943a141ed4124585222470d"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a6f94991b8943a141ed4124585222470d">&#9670;&#160;</a></span>spi_cs()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void spi_cs </td> + <td>(</td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>type</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Enable or disable chip-select line</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">type</td><td>0=disable, 1=enable </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="a755192be6c3cf9904564b0eee99de445" name="a755192be6c3cf9904564b0eee99de445"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a755192be6c3cf9904564b0eee99de445">&#9670;&#160;</a></span>spi_setup()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void spi_setup </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Configure SPI module </p> + +</div> +</div> +<a id="a13e10b34fbbffca6c31f0ce25b3f8432" name="a13e10b34fbbffca6c31f0ce25b3f8432"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a13e10b34fbbffca6c31f0ce25b3f8432">&#9670;&#160;</a></span>spi_trans()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void spi_trans </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>SPI data transfer </p> + +</div> +</div> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/demo__spi__irq_2main_8c.html b/sw/demo__spi__irq_2main_8c.html new file mode 100644 index 0000000000..e5b87d0d88 --- /dev/null +++ b/sw/demo__spi__irq_2main_8c.html @@ -0,0 +1,192 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/example/demo_spi_irq/main.c File Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_f0f9b27afba2e8cc2da6e5fddcc1a8c9.html">example</a></li><li class="navelem"><a class="el" href="dir_8f848e36ac87ced1c361afcc0549ca32.html">demo_spi_irq</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#func-members">Functions</a> &#124; +<a href="#var-members">Variables</a> </div> + <div class="headertitle"><div class="title">main.c File Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p>Example of an ISR driven SPI transfer. +<a href="#details">More...</a></p> +<div class="textblock"><code>#include &lt;<a class="el" href="neorv32_8h_source.html">neorv32.h</a>&gt;</code><br /> +<code>#include &lt;string.h&gt;</code><br /> +<code>#include &quot;<a class="el" href="neorv32__spi__irq_8h_source.html">neorv32_spi_irq.h</a>&quot;</code><br /> +</div><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="define-members" name="define-members"></a> +Macros</h2></td></tr> +<tr><td colspan="2"><div class="groupHeader">User configuration</div></td></tr> +<tr class="memitem:ad4455691936f92fdd6c37566fc58ba1f" id="r_ad4455691936f92fdd6c37566fc58ba1f"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ad4455691936f92fdd6c37566fc58ba1f">BAUD_RATE</a>&#160;&#160;&#160;19200</td></tr> +<tr class="separator:ad4455691936f92fdd6c37566fc58ba1f"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="func-members" name="func-members"></a> +Functions</h2></td></tr> +<tr class="memitem:a7e266cc5247c999948dacc2102bd184a" id="r_a7e266cc5247c999948dacc2102bd184a"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a7e266cc5247c999948dacc2102bd184a">spi_irq_handler</a> (void)</td></tr> +<tr class="separator:a7e266cc5247c999948dacc2102bd184a"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ae66f6b31b5ad750f1fe042a706a4e3d4" id="r_ae66f6b31b5ad750f1fe042a706a4e3d4"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ae66f6b31b5ad750f1fe042a706a4e3d4">main</a> ()</td></tr> +<tr class="separator:ae66f6b31b5ad750f1fe042a706a4e3d4"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="var-members" name="var-members"></a> +Variables</h2></td></tr> +<tr class="memitem:a9f865a7dd1c92230d701ba10cd81ad78" id="r_a9f865a7dd1c92230d701ba10cd81ad78"><td class="memItemLeft" align="right" valign="top"><a id="a9f865a7dd1c92230d701ba10cd81ad78" name="a9f865a7dd1c92230d701ba10cd81ad78"></a> +<a class="el" href="structt__neorv32__spi.html">t_neorv32_spi</a>&#160;</td><td class="memItemRight" valign="bottom"><b>g_neorv32_spi</b></td></tr> +<tr class="separator:a9f865a7dd1c92230d701ba10cd81ad78"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>Example of an ISR driven SPI transfer. </p> +<dl class="section author"><dt>Author</dt><dd>Andreas Kaeberlein </dd></dl> +</div><h2 class="groupheader">Macro Definition Documentation</h2> +<a id="ad4455691936f92fdd6c37566fc58ba1f" name="ad4455691936f92fdd6c37566fc58ba1f"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ad4455691936f92fdd6c37566fc58ba1f">&#9670;&#160;</a></span>BAUD_RATE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define BAUD_RATE&#160;&#160;&#160;19200</td> + </tr> + </table> +</div><div class="memdoc"> +<p>UART BAUD rate </p> + +</div> +</div> +<h2 class="groupheader">Function Documentation</h2> +<a id="ae66f6b31b5ad750f1fe042a706a4e3d4" name="ae66f6b31b5ad750f1fe042a706a4e3d4"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ae66f6b31b5ad750f1fe042a706a4e3d4">&#9670;&#160;</a></span>main()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int main </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>This program demonstrates the usage of an ISR driven SPI transfer</p> +<dl class="section note"><dt>Note</dt><dd>This program requires the UART and the SPI to be synthesized.</dd></dl> +<dl class="section return"><dt>Returns</dt><dd>Irrelevant. </dd></dl> + +</div> +</div> +<a id="a7e266cc5247c999948dacc2102bd184a" name="a7e266cc5247c999948dacc2102bd184a"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a7e266cc5247c999948dacc2102bd184a">&#9670;&#160;</a></span>spi_irq_handler()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void spi_irq_handler </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>SPI Interrupt Handler</p> +<dl class="section note"><dt>Note</dt><dd>Captures/Transmits the data to the SPI core</dd></dl> +<dl class="section return"><dt>Returns</dt><dd>void. </dd></dl> + +</div> +</div> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/demo__trng_2main_8c.html b/sw/demo__trng_2main_8c.html new file mode 100644 index 0000000000..148192316e --- /dev/null +++ b/sw/demo__trng_2main_8c.html @@ -0,0 +1,261 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/example/demo_trng/main.c File Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_f0f9b27afba2e8cc2da6e5fddcc1a8c9.html">example</a></li><li class="navelem"><a class="el" href="dir_237db5b95db643499d4c20f0bc5f6a7d.html">demo_trng</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#func-members">Functions</a> </div> + <div class="headertitle"><div class="title">main.c File Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p>True random number generator demo program. +<a href="#details">More...</a></p> +<div class="textblock"><code>#include &lt;<a class="el" href="neorv32_8h_source.html">neorv32.h</a>&gt;</code><br /> +</div><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="define-members" name="define-members"></a> +Macros</h2></td></tr> +<tr><td colspan="2"><div class="groupHeader">User configuration</div></td></tr> +<tr class="memitem:ad4455691936f92fdd6c37566fc58ba1f" id="r_ad4455691936f92fdd6c37566fc58ba1f"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ad4455691936f92fdd6c37566fc58ba1f">BAUD_RATE</a>&#160;&#160;&#160;19200</td></tr> +<tr class="separator:ad4455691936f92fdd6c37566fc58ba1f"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="func-members" name="func-members"></a> +Functions</h2></td></tr> +<tr class="memitem:a64205d97b57c99dc5e95b8621827f4a4" id="r_a64205d97b57c99dc5e95b8621827f4a4"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a64205d97b57c99dc5e95b8621827f4a4">print_random_data</a> (void)</td></tr> +<tr class="separator:a64205d97b57c99dc5e95b8621827f4a4"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:af37eae672fee5e81f00a1dbf51b7e417" id="r_af37eae672fee5e81f00a1dbf51b7e417"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#af37eae672fee5e81f00a1dbf51b7e417">repetition_count_test</a> (void)</td></tr> +<tr class="separator:af37eae672fee5e81f00a1dbf51b7e417"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a23a91e6fe2cc44f3c29baf0d331e05db" id="r_a23a91e6fe2cc44f3c29baf0d331e05db"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a23a91e6fe2cc44f3c29baf0d331e05db">adaptive_proportion_test</a> (void)</td></tr> +<tr class="separator:a23a91e6fe2cc44f3c29baf0d331e05db"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a4e49f5e3feb4bd5755f919cd3310b506" id="r_a4e49f5e3feb4bd5755f919cd3310b506"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a4e49f5e3feb4bd5755f919cd3310b506">generate_histogram</a> (void)</td></tr> +<tr class="separator:a4e49f5e3feb4bd5755f919cd3310b506"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:abbde1237eed617466fb971a78c3acd1e" id="r_abbde1237eed617466fb971a78c3acd1e"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#abbde1237eed617466fb971a78c3acd1e">compute_rate</a> (void)</td></tr> +<tr class="separator:abbde1237eed617466fb971a78c3acd1e"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a840291bc02cba5474a4cb46a9b9566fe" id="r_a840291bc02cba5474a4cb46a9b9566fe"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a840291bc02cba5474a4cb46a9b9566fe">main</a> (void)</td></tr> +<tr class="separator:a840291bc02cba5474a4cb46a9b9566fe"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>True random number generator demo program. </p> +<dl class="section author"><dt>Author</dt><dd>Stephan Nolting </dd></dl> +</div><h2 class="groupheader">Macro Definition Documentation</h2> +<a id="ad4455691936f92fdd6c37566fc58ba1f" name="ad4455691936f92fdd6c37566fc58ba1f"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ad4455691936f92fdd6c37566fc58ba1f">&#9670;&#160;</a></span>BAUD_RATE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define BAUD_RATE&#160;&#160;&#160;19200</td> + </tr> + </table> +</div><div class="memdoc"> +<p>UART BAUD rate </p> + +</div> +</div> +<h2 class="groupheader">Function Documentation</h2> +<a id="a23a91e6fe2cc44f3c29baf0d331e05db" name="a23a91e6fe2cc44f3c29baf0d331e05db"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a23a91e6fe2cc44f3c29baf0d331e05db">&#9670;&#160;</a></span>adaptive_proportion_test()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void adaptive_proportion_test </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Run adaptive proportion test (NIST SP 800-90B) </p> + +</div> +</div> +<a id="abbde1237eed617466fb971a78c3acd1e" name="abbde1237eed617466fb971a78c3acd1e"></a> +<h2 class="memtitle"><span class="permalink"><a href="#abbde1237eed617466fb971a78c3acd1e">&#9670;&#160;</a></span>compute_rate()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void compute_rate </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Compute average random generation rate </p> + +</div> +</div> +<a id="a4e49f5e3feb4bd5755f919cd3310b506" name="a4e49f5e3feb4bd5755f919cd3310b506"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a4e49f5e3feb4bd5755f919cd3310b506">&#9670;&#160;</a></span>generate_histogram()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void generate_histogram </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Generate and print histogram. Samples random data until a key is pressed. </p> + +</div> +</div> +<a id="a840291bc02cba5474a4cb46a9b9566fe" name="a840291bc02cba5474a4cb46a9b9566fe"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a840291bc02cba5474a4cb46a9b9566fe">&#9670;&#160;</a></span>main()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int main </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Simple true random number test/demo program.</p> +<dl class="section note"><dt>Note</dt><dd>This program requires the UART and the TRNG to be synthesized.</dd></dl> +<dl class="section return"><dt>Returns</dt><dd>0 if execution was successful </dd></dl> + +</div> +</div> +<a id="a64205d97b57c99dc5e95b8621827f4a4" name="a64205d97b57c99dc5e95b8621827f4a4"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a64205d97b57c99dc5e95b8621827f4a4">&#9670;&#160;</a></span>print_random_data()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void print_random_data </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Print random numbers until a key is pressed. </p> + +</div> +</div> +<a id="af37eae672fee5e81f00a1dbf51b7e417" name="af37eae672fee5e81f00a1dbf51b7e417"></a> +<h2 class="memtitle"><span class="permalink"><a href="#af37eae672fee5e81f00a1dbf51b7e417">&#9670;&#160;</a></span>repetition_count_test()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void repetition_count_test </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Run repetition count test (NIST SP 800-90B) </p> + +</div> +</div> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/demo__twi_2main_8c.html b/sw/demo__twi_2main_8c.html new file mode 100644 index 0000000000..cd983ae326 --- /dev/null +++ b/sw/demo__twi_2main_8c.html @@ -0,0 +1,248 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/example/demo_twi/main.c File Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_f0f9b27afba2e8cc2da6e5fddcc1a8c9.html">example</a></li><li class="navelem"><a class="el" href="dir_ebeff77b922fbb914a1494857a82a38e.html">demo_twi</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#func-members">Functions</a> </div> + <div class="headertitle"><div class="title">main.c File Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p>TWI bus explorer. +<a href="#details">More...</a></p> +<div class="textblock"><code>#include &lt;<a class="el" href="neorv32_8h_source.html">neorv32.h</a>&gt;</code><br /> +<code>#include &lt;string.h&gt;</code><br /> +</div><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="define-members" name="define-members"></a> +Macros</h2></td></tr> +<tr><td colspan="2"><div class="groupHeader">User configuration</div></td></tr> +<tr class="memitem:ad4455691936f92fdd6c37566fc58ba1f" id="r_ad4455691936f92fdd6c37566fc58ba1f"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ad4455691936f92fdd6c37566fc58ba1f">BAUD_RATE</a>&#160;&#160;&#160;19200</td></tr> +<tr class="separator:ad4455691936f92fdd6c37566fc58ba1f"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="func-members" name="func-members"></a> +Functions</h2></td></tr> +<tr class="memitem:aace46ee34e954f9ebee5873beb0785f1" id="r_aace46ee34e954f9ebee5873beb0785f1"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aace46ee34e954f9ebee5873beb0785f1">scan_twi</a> (void)</td></tr> +<tr class="separator:aace46ee34e954f9ebee5873beb0785f1"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:acee0c1770467f85a150d072ac7e1252f" id="r_acee0c1770467f85a150d072ac7e1252f"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#acee0c1770467f85a150d072ac7e1252f">set_clock</a> (void)</td></tr> +<tr class="separator:acee0c1770467f85a150d072ac7e1252f"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aa94edd4f55a3ac18913f661f4bc16fb1" id="r_aa94edd4f55a3ac18913f661f4bc16fb1"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aa94edd4f55a3ac18913f661f4bc16fb1">send_twi</a> (void)</td></tr> +<tr class="separator:aa94edd4f55a3ac18913f661f4bc16fb1"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a2ebc688bc1dad328693fc0974b378fa0" id="r_a2ebc688bc1dad328693fc0974b378fa0"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a2ebc688bc1dad328693fc0974b378fa0">print_hex_byte</a> (uint8_t data)</td></tr> +<tr class="separator:a2ebc688bc1dad328693fc0974b378fa0"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ae66f6b31b5ad750f1fe042a706a4e3d4" id="r_ae66f6b31b5ad750f1fe042a706a4e3d4"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ae66f6b31b5ad750f1fe042a706a4e3d4">main</a> ()</td></tr> +<tr class="separator:ae66f6b31b5ad750f1fe042a706a4e3d4"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>TWI bus explorer. </p> +<dl class="section author"><dt>Author</dt><dd>Stephan Nolting </dd></dl> +</div><h2 class="groupheader">Macro Definition Documentation</h2> +<a id="ad4455691936f92fdd6c37566fc58ba1f" name="ad4455691936f92fdd6c37566fc58ba1f"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ad4455691936f92fdd6c37566fc58ba1f">&#9670;&#160;</a></span>BAUD_RATE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define BAUD_RATE&#160;&#160;&#160;19200</td> + </tr> + </table> +</div><div class="memdoc"> +<p>UART BAUD rate </p> + +</div> +</div> +<h2 class="groupheader">Function Documentation</h2> +<a id="ae66f6b31b5ad750f1fe042a706a4e3d4" name="ae66f6b31b5ad750f1fe042a706a4e3d4"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ae66f6b31b5ad750f1fe042a706a4e3d4">&#9670;&#160;</a></span>main()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int main </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>This program provides an interactive console to communicate with TWI devices.</p> +<dl class="section note"><dt>Note</dt><dd>This program requires the UART to be synthesized.</dd></dl> +<dl class="section return"><dt>Returns</dt><dd>0 if execution was successful </dd></dl> + +</div> +</div> +<a id="a2ebc688bc1dad328693fc0974b378fa0" name="a2ebc688bc1dad328693fc0974b378fa0"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a2ebc688bc1dad328693fc0974b378fa0">&#9670;&#160;</a></span>print_hex_byte()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void print_hex_byte </td> + <td>(</td> + <td class="paramtype">uint8_t</td> <td class="paramname"><span class="paramname"><em>data</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Print byte as hex chars via UART0.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramname">data</td><td>8-bit data to be printed as two hex chars. </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="aace46ee34e954f9ebee5873beb0785f1" name="aace46ee34e954f9ebee5873beb0785f1"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aace46ee34e954f9ebee5873beb0785f1">&#9670;&#160;</a></span>scan_twi()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void scan_twi </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Scan 7-bit TWI address space and print results </p> + +</div> +</div> +<a id="aa94edd4f55a3ac18913f661f4bc16fb1" name="aa94edd4f55a3ac18913f661f4bc16fb1"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aa94edd4f55a3ac18913f661f4bc16fb1">&#9670;&#160;</a></span>send_twi()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void send_twi </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Read/write menu to transfer 1 byte from/to bus </p> + +</div> +</div> +<a id="acee0c1770467f85a150d072ac7e1252f" name="acee0c1770467f85a150d072ac7e1252f"></a> +<h2 class="memtitle"><span class="permalink"><a href="#acee0c1770467f85a150d072ac7e1252f">&#9670;&#160;</a></span>set_clock()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void set_clock </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>TWI clock setup </p> + +</div> +</div> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/demo__wdt_2main_8c.html b/sw/demo__wdt_2main_8c.html new file mode 100644 index 0000000000..7aa5f7f1d6 --- /dev/null +++ b/sw/demo__wdt_2main_8c.html @@ -0,0 +1,178 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/example/demo_wdt/main.c File Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_f0f9b27afba2e8cc2da6e5fddcc1a8c9.html">example</a></li><li class="navelem"><a class="el" href="dir_78d7bfa405ff3a31fa7539cfd8bc8262.html">demo_wdt</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#func-members">Functions</a> </div> + <div class="headertitle"><div class="title">main.c File Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p>Watchdog demo program. +<a href="#details">More...</a></p> +<div class="textblock"><code>#include &lt;<a class="el" href="neorv32_8h_source.html">neorv32.h</a>&gt;</code><br /> +</div><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="define-members" name="define-members"></a> +Macros</h2></td></tr> +<tr><td colspan="2"><div class="groupHeader">User configuration</div></td></tr> +<tr class="memitem:ad4455691936f92fdd6c37566fc58ba1f" id="r_ad4455691936f92fdd6c37566fc58ba1f"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ad4455691936f92fdd6c37566fc58ba1f">BAUD_RATE</a>&#160;&#160;&#160;19200</td></tr> +<tr class="separator:ad4455691936f92fdd6c37566fc58ba1f"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a01af3905e60b1869f669315f4a1297f5" id="r_a01af3905e60b1869f669315f4a1297f5"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a01af3905e60b1869f669315f4a1297f5">WDT_TIMEOUT_S</a>&#160;&#160;&#160;8</td></tr> +<tr class="separator:a01af3905e60b1869f669315f4a1297f5"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="func-members" name="func-members"></a> +Functions</h2></td></tr> +<tr class="memitem:ae66f6b31b5ad750f1fe042a706a4e3d4" id="r_ae66f6b31b5ad750f1fe042a706a4e3d4"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ae66f6b31b5ad750f1fe042a706a4e3d4">main</a> ()</td></tr> +<tr class="separator:ae66f6b31b5ad750f1fe042a706a4e3d4"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>Watchdog demo program. </p> +<dl class="section author"><dt>Author</dt><dd>Stephan Nolting </dd></dl> +</div><h2 class="groupheader">Macro Definition Documentation</h2> +<a id="ad4455691936f92fdd6c37566fc58ba1f" name="ad4455691936f92fdd6c37566fc58ba1f"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ad4455691936f92fdd6c37566fc58ba1f">&#9670;&#160;</a></span>BAUD_RATE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define BAUD_RATE&#160;&#160;&#160;19200</td> + </tr> + </table> +</div><div class="memdoc"> +<p>UART BAUD rate </p> + +</div> +</div> +<a id="a01af3905e60b1869f669315f4a1297f5" name="a01af3905e60b1869f669315f4a1297f5"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a01af3905e60b1869f669315f4a1297f5">&#9670;&#160;</a></span>WDT_TIMEOUT_S</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define WDT_TIMEOUT_S&#160;&#160;&#160;8</td> + </tr> + </table> +</div><div class="memdoc"> +<p>WDT timeout (until system reset) in seconds </p> + +</div> +</div> +<h2 class="groupheader">Function Documentation</h2> +<a id="ae66f6b31b5ad750f1fe042a706a4e3d4" name="ae66f6b31b5ad750f1fe042a706a4e3d4"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ae66f6b31b5ad750f1fe042a706a4e3d4">&#9670;&#160;</a></span>main()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int main </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Main function</p> +<dl class="section note"><dt>Note</dt><dd>This program requires the WDT and UART0 to be synthesized.</dd></dl> +<dl class="section return"><dt>Returns</dt><dd>0 if execution was successful </dd></dl> + +</div> +</div> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/demo__xip_2main_8c.html b/sw/demo__xip_2main_8c.html new file mode 100644 index 0000000000..41f3cbaa30 --- /dev/null +++ b/sw/demo__xip_2main_8c.html @@ -0,0 +1,479 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/example/demo_xip/main.c File Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_f0f9b27afba2e8cc2da6e5fddcc1a8c9.html">example</a></li><li class="navelem"><a class="el" href="dir_b6b50782b8271d07dffbc5f0cb9ff3f4.html">demo_xip</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#define-members">Macros</a> &#124; +<a href="#enum-members">Enumerations</a> </div> + <div class="headertitle"><div class="title">main.c File Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p>Interactive console program to upload and execute a XIP program. +<a href="#details">More...</a></p> +<div class="textblock"><code>#include &lt;<a class="el" href="neorv32_8h_source.html">neorv32.h</a>&gt;</code><br /> +</div><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="define-members" name="define-members"></a> +Macros</h2></td></tr> +<tr class="memitem:a0035ad41f622dbfc2412318a8ed39257" id="r_a0035ad41f622dbfc2412318a8ed39257"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a0035ad41f622dbfc2412318a8ed39257">EXE_SIGNATURE</a>&#160;&#160;&#160;0x4788CAFE</td></tr> +<tr class="separator:a0035ad41f622dbfc2412318a8ed39257"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr><td colspan="2"><div class="groupHeader">User configuration</div></td></tr> +<tr class="memitem:ad4455691936f92fdd6c37566fc58ba1f" id="r_ad4455691936f92fdd6c37566fc58ba1f"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ad4455691936f92fdd6c37566fc58ba1f">BAUD_RATE</a>&#160;&#160;&#160;19200</td></tr> +<tr class="separator:ad4455691936f92fdd6c37566fc58ba1f"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a23a9099a5f8fc9c6e253c0eecb2be8db" id="r_a23a9099a5f8fc9c6e253c0eecb2be8db"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a23a9099a5f8fc9c6e253c0eecb2be8db">FLASH_BASE</a>&#160;&#160;&#160;0x00400000</td></tr> +<tr class="separator:a23a9099a5f8fc9c6e253c0eecb2be8db"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:af9b3c37c806499fc435302f5bce6a122" id="r_af9b3c37c806499fc435302f5bce6a122"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#af9b3c37c806499fc435302f5bce6a122">FLASH_ABYTES</a>&#160;&#160;&#160;3</td></tr> +<tr class="separator:af9b3c37c806499fc435302f5bce6a122"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aec72efe062dbdb149ae6d4f8b1be6793" id="r_aec72efe062dbdb149ae6d4f8b1be6793"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aec72efe062dbdb149ae6d4f8b1be6793">XIP_CLK_PRSC</a>&#160;&#160;&#160;<a class="el" href="neorv32_8h.html#a10022df4c223533b04d5aebe222e8b73a933045a5405de55781d687315f42054e">CLK_PRSC_128</a></td></tr> +<tr class="separator:aec72efe062dbdb149ae6d4f8b1be6793"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a6b20d41d6252e9871430c242cb1a56e7" id="r_a6b20d41d6252e9871430c242cb1a56e7"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a6b20d41d6252e9871430c242cb1a56e7">BUFFER_SIZE</a>&#160;&#160;&#160;(7*1024)</td></tr> +<tr class="separator:a6b20d41d6252e9871430c242cb1a56e7"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="enum-members" name="enum-members"></a> +Enumerations</h2></td></tr> +<tr class="memitem:af30de1c8d8502ad374612d308cfbd12e" id="r_af30de1c8d8502ad374612d308cfbd12e"><td class="memItemLeft" align="right" valign="top">enum &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#af30de1c8d8502ad374612d308cfbd12e">SPI_FLASH_CMD</a> { <br /> +&#160;&#160;<a class="el" href="#af30de1c8d8502ad374612d308cfbd12ea528cebc54176f6f4c0a8f7f16fb28ca1">SPI_FLASH_CMD_WRITE</a> = 0x02 +, <a class="el" href="#af30de1c8d8502ad374612d308cfbd12ea6c1994ba2cfd97e0c77dcdf8bbdfdfa6">SPI_FLASH_CMD_READ</a> = 0x03 +, <a class="el" href="#af30de1c8d8502ad374612d308cfbd12eaa91d3c1d788b21fc798a5976c9f0da77">SPI_FLASH_CMD_WRITE_DISABLE</a> = 0x04 +, <a class="el" href="#af30de1c8d8502ad374612d308cfbd12ea5fbc6551a10549b38e5ab4a76c38f214">SPI_FLASH_CMD_READ_STATUS</a> = 0x05 +, <br /> +&#160;&#160;<a class="el" href="#af30de1c8d8502ad374612d308cfbd12ea152e091e93778f217f8b766298351513">SPI_FLASH_CMD_WRITE_ENABLE</a> = 0x06 +, <a class="el" href="#af30de1c8d8502ad374612d308cfbd12eacd62141d6331f66e31bd252e2a92b836">SPI_FLASH_CMD_SECTOR_ERASE</a> = 0xD8 +<br /> + }</td></tr> +<tr class="separator:af30de1c8d8502ad374612d308cfbd12e"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:adccf1bb8f1f203cb1350f7f2eb15a08e" id="r_adccf1bb8f1f203cb1350f7f2eb15a08e"><td class="memItemLeft" align="right" valign="top">enum &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#adccf1bb8f1f203cb1350f7f2eb15a08e">SPI_FLASH_SREG</a> { <a class="el" href="#adccf1bb8f1f203cb1350f7f2eb15a08eac84de63bbea3989c71bcc92d1d01cfa4">SPI_FLASH_SREG_WIP</a> = 0 +, <a class="el" href="#adccf1bb8f1f203cb1350f7f2eb15a08ea90f3b76faed13819ee13e574d1bff0c1">SPI_FLASH_SREG_WEL</a> = 1 + }</td></tr> +<tr class="separator:adccf1bb8f1f203cb1350f7f2eb15a08e"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="func-members" name="func-members"></a> +Functions</h2></td></tr> +<tr><td colspan="2"><div class="groupHeader">Function prototypes</div></td></tr> +<tr class="memitem:a23bd7bd7b0808d919fd09ac0a8258498" id="r_a23bd7bd7b0808d919fd09ac0a8258498"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a23bd7bd7b0808d919fd09ac0a8258498">xip_flash_access_check</a> (void)</td></tr> +<tr class="separator:a23bd7bd7b0808d919fd09ac0a8258498"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a9e0b2714126b6699ddb65485c93293e4" id="r_a9e0b2714126b6699ddb65485c93293e4"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a9e0b2714126b6699ddb65485c93293e4">xip_flash_erase_sector</a> (uint32_t base_addr)</td></tr> +<tr class="separator:a9e0b2714126b6699ddb65485c93293e4"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a4ddfa8fdc072cadeef18a4a10bc8b174" id="r_a4ddfa8fdc072cadeef18a4a10bc8b174"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a4ddfa8fdc072cadeef18a4a10bc8b174">xip_flash_program</a> (uint32_t *src, uint32_t base_addr, uint32_t size)</td></tr> +<tr class="separator:a4ddfa8fdc072cadeef18a4a10bc8b174"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a0458656f8a108ff31f4bbbd005f029a0" id="r_a0458656f8a108ff31f4bbbd005f029a0"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a0458656f8a108ff31f4bbbd005f029a0">uart_get_executable</a> (uint32_t *dst, uint32_t *size)</td></tr> +<tr class="separator:a0458656f8a108ff31f4bbbd005f029a0"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a3043d09bdc155f57f45cd91e0cd4d15b" id="r_a3043d09bdc155f57f45cd91e0cd4d15b"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a3043d09bdc155f57f45cd91e0cd4d15b">uart_get_word</a> (void)</td></tr> +<tr class="separator:a3043d09bdc155f57f45cd91e0cd4d15b"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader">RAM storage for executable</h2></td></tr> +<tr class="memitem:acc95e55a622d79c2a398397d1f9b8033" id="r_acc95e55a622d79c2a398397d1f9b8033"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#acc95e55a622d79c2a398397d1f9b8033">ram_buffer</a> [<a class="el" href="#a6b20d41d6252e9871430c242cb1a56e7">BUFFER_SIZE</a>/4]</td></tr> +<tr class="separator:acc95e55a622d79c2a398397d1f9b8033"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ae66f6b31b5ad750f1fe042a706a4e3d4" id="r_ae66f6b31b5ad750f1fe042a706a4e3d4"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ae66f6b31b5ad750f1fe042a706a4e3d4">main</a> ()</td></tr> +<tr class="separator:ae66f6b31b5ad750f1fe042a706a4e3d4"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>Interactive console program to upload and execute a XIP program. </p> +<dl class="section author"><dt>Author</dt><dd>Stephan Nolting </dd></dl> +</div><h2 class="groupheader">Macro Definition Documentation</h2> +<a id="ad4455691936f92fdd6c37566fc58ba1f" name="ad4455691936f92fdd6c37566fc58ba1f"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ad4455691936f92fdd6c37566fc58ba1f">&#9670;&#160;</a></span>BAUD_RATE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define BAUD_RATE&#160;&#160;&#160;19200</td> + </tr> + </table> +</div><div class="memdoc"> +<p>UART BAUD rate </p> + +</div> +</div> +<a id="a6b20d41d6252e9871430c242cb1a56e7" name="a6b20d41d6252e9871430c242cb1a56e7"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a6b20d41d6252e9871430c242cb1a56e7">&#9670;&#160;</a></span>BUFFER_SIZE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define BUFFER_SIZE&#160;&#160;&#160;(7*1024)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Executable RAM buffer size in bytes </p> + +</div> +</div> +<a id="a0035ad41f622dbfc2412318a8ed39257" name="a0035ad41f622dbfc2412318a8ed39257"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a0035ad41f622dbfc2412318a8ed39257">&#9670;&#160;</a></span>EXE_SIGNATURE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define EXE_SIGNATURE&#160;&#160;&#160;0x4788CAFE</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Valid executable identification signature </p> + +</div> +</div> +<a id="af9b3c37c806499fc435302f5bce6a122" name="af9b3c37c806499fc435302f5bce6a122"></a> +<h2 class="memtitle"><span class="permalink"><a href="#af9b3c37c806499fc435302f5bce6a122">&#9670;&#160;</a></span>FLASH_ABYTES</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define FLASH_ABYTES&#160;&#160;&#160;3</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Flash address bytes </p> + +</div> +</div> +<a id="a23a9099a5f8fc9c6e253c0eecb2be8db" name="a23a9099a5f8fc9c6e253c0eecb2be8db"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a23a9099a5f8fc9c6e253c0eecb2be8db">&#9670;&#160;</a></span>FLASH_BASE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define FLASH_BASE&#160;&#160;&#160;0x00400000</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Flash base address (32-bit) </p> + +</div> +</div> +<a id="aec72efe062dbdb149ae6d4f8b1be6793" name="aec72efe062dbdb149ae6d4f8b1be6793"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aec72efe062dbdb149ae6d4f8b1be6793">&#9670;&#160;</a></span>XIP_CLK_PRSC</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define XIP_CLK_PRSC&#160;&#160;&#160;<a class="el" href="neorv32_8h.html#a10022df4c223533b04d5aebe222e8b73a933045a5405de55781d687315f42054e">CLK_PRSC_128</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>XIP SPI clock prescaler select </p> + +</div> +</div> +<h2 class="groupheader">Enumeration Type Documentation</h2> +<a id="af30de1c8d8502ad374612d308cfbd12e" name="af30de1c8d8502ad374612d308cfbd12e"></a> +<h2 class="memtitle"><span class="permalink"><a href="#af30de1c8d8502ad374612d308cfbd12e">&#9670;&#160;</a></span>SPI_FLASH_CMD</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">enum <a class="el" href="#af30de1c8d8502ad374612d308cfbd12e">SPI_FLASH_CMD</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>SPI flash commands </p> +<table class="fieldtable"> +<tr><th colspan="2">Enumerator</th></tr><tr><td class="fieldname"><a id="af30de1c8d8502ad374612d308cfbd12ea528cebc54176f6f4c0a8f7f16fb28ca1" name="af30de1c8d8502ad374612d308cfbd12ea528cebc54176f6f4c0a8f7f16fb28ca1"></a>SPI_FLASH_CMD_WRITE&#160;</td><td class="fielddoc"><p>Write data </p> +</td></tr> +<tr><td class="fieldname"><a id="af30de1c8d8502ad374612d308cfbd12ea6c1994ba2cfd97e0c77dcdf8bbdfdfa6" name="af30de1c8d8502ad374612d308cfbd12ea6c1994ba2cfd97e0c77dcdf8bbdfdfa6"></a>SPI_FLASH_CMD_READ&#160;</td><td class="fielddoc"><p>Read data </p> +</td></tr> +<tr><td class="fieldname"><a id="af30de1c8d8502ad374612d308cfbd12eaa91d3c1d788b21fc798a5976c9f0da77" name="af30de1c8d8502ad374612d308cfbd12eaa91d3c1d788b21fc798a5976c9f0da77"></a>SPI_FLASH_CMD_WRITE_DISABLE&#160;</td><td class="fielddoc"><p>Disable write access </p> +</td></tr> +<tr><td class="fieldname"><a id="af30de1c8d8502ad374612d308cfbd12ea5fbc6551a10549b38e5ab4a76c38f214" name="af30de1c8d8502ad374612d308cfbd12ea5fbc6551a10549b38e5ab4a76c38f214"></a>SPI_FLASH_CMD_READ_STATUS&#160;</td><td class="fielddoc"><p>Get status register </p> +</td></tr> +<tr><td class="fieldname"><a id="af30de1c8d8502ad374612d308cfbd12ea152e091e93778f217f8b766298351513" name="af30de1c8d8502ad374612d308cfbd12ea152e091e93778f217f8b766298351513"></a>SPI_FLASH_CMD_WRITE_ENABLE&#160;</td><td class="fielddoc"><p>Enable write access </p> +</td></tr> +<tr><td class="fieldname"><a id="af30de1c8d8502ad374612d308cfbd12eacd62141d6331f66e31bd252e2a92b836" name="af30de1c8d8502ad374612d308cfbd12eacd62141d6331f66e31bd252e2a92b836"></a>SPI_FLASH_CMD_SECTOR_ERASE&#160;</td><td class="fielddoc"><p>Erase complete sector </p> +</td></tr> +</table> + +</div> +</div> +<a id="adccf1bb8f1f203cb1350f7f2eb15a08e" name="adccf1bb8f1f203cb1350f7f2eb15a08e"></a> +<h2 class="memtitle"><span class="permalink"><a href="#adccf1bb8f1f203cb1350f7f2eb15a08e">&#9670;&#160;</a></span>SPI_FLASH_SREG</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">enum <a class="el" href="#adccf1bb8f1f203cb1350f7f2eb15a08e">SPI_FLASH_SREG</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>SPI flash status register </p> +<table class="fieldtable"> +<tr><th colspan="2">Enumerator</th></tr><tr><td class="fieldname"><a id="adccf1bb8f1f203cb1350f7f2eb15a08eac84de63bbea3989c71bcc92d1d01cfa4" name="adccf1bb8f1f203cb1350f7f2eb15a08eac84de63bbea3989c71bcc92d1d01cfa4"></a>SPI_FLASH_SREG_WIP&#160;</td><td class="fielddoc"><p>Write-in-progress data </p> +</td></tr> +<tr><td class="fieldname"><a id="adccf1bb8f1f203cb1350f7f2eb15a08ea90f3b76faed13819ee13e574d1bff0c1" name="adccf1bb8f1f203cb1350f7f2eb15a08ea90f3b76faed13819ee13e574d1bff0c1"></a>SPI_FLASH_SREG_WEL&#160;</td><td class="fielddoc"><p>Write-enable latch </p> +</td></tr> +</table> + +</div> +</div> +<h2 class="groupheader">Function Documentation</h2> +<a id="ae66f6b31b5ad750f1fe042a706a4e3d4" name="ae66f6b31b5ad750f1fe042a706a4e3d4"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ae66f6b31b5ad750f1fe042a706a4e3d4">&#9670;&#160;</a></span>main()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int main </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Main function</p> +<dl class="section note"><dt>Note</dt><dd>This program requires the XIP module and UART0.</dd></dl> +<dl class="section return"><dt>Returns</dt><dd>0 if execution was successful </dd></dl> + +</div> +</div> +<a id="a0458656f8a108ff31f4bbbd005f029a0" name="a0458656f8a108ff31f4bbbd005f029a0"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a0458656f8a108ff31f4bbbd005f029a0">&#9670;&#160;</a></span>uart_get_executable()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int uart_get_executable </td> + <td>(</td> + <td class="paramtype">uint32_t *</td> <td class="paramname"><span class="paramname"><em>dst</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">uint32_t *</td> <td class="paramname"><span class="paramname"><em>length</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Get NEORV32 executable via UART.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">dst</td><td>Pointer to uin32_t data array where the executable will be stored. </td></tr> + <tr><td class="paramdir">[out]</td><td class="paramname">length</td><td>Pointer to a uin32_t to store the executable size in bytes. </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Returns 0 on success. </dd></dl> + +</div> +</div> +<a id="a3043d09bdc155f57f45cd91e0cd4d15b" name="a3043d09bdc155f57f45cd91e0cd4d15b"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a3043d09bdc155f57f45cd91e0cd4d15b">&#9670;&#160;</a></span>uart_get_word()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t uart_get_word </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Get 32-bit word from UART.</p> +<dl class="section return"><dt>Returns</dt><dd>32-bit data word. </dd></dl> + +</div> +</div> +<a id="a23bd7bd7b0808d919fd09ac0a8258498" name="a23bd7bd7b0808d919fd09ac0a8258498"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a23bd7bd7b0808d919fd09ac0a8258498">&#9670;&#160;</a></span>xip_flash_access_check()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int xip_flash_access_check </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Check SPI flash connection by toggling the status register's write enable latch.</p> +<dl class="section return"><dt>Returns</dt><dd>Returns 0 on success. </dd></dl> + +</div> +</div> +<a id="a9e0b2714126b6699ddb65485c93293e4" name="a9e0b2714126b6699ddb65485c93293e4"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a9e0b2714126b6699ddb65485c93293e4">&#9670;&#160;</a></span>xip_flash_erase_sector()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void xip_flash_erase_sector </td> + <td>(</td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>base_addr</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Erase sector starting at base address.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">base_addr</td><td>Base address of sector to erase. </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="a4ddfa8fdc072cadeef18a4a10bc8b174" name="a4ddfa8fdc072cadeef18a4a10bc8b174"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a4ddfa8fdc072cadeef18a4a10bc8b174">&#9670;&#160;</a></span>xip_flash_program()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void xip_flash_program </td> + <td>(</td> + <td class="paramtype">uint32_t *</td> <td class="paramname"><span class="paramname"><em>src</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>base_addr</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>size</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Helper function to program the XIP flash via the direct SPI access feature of the XIP module.</p> +<dl class="section warning"><dt>Warning</dt><dd>This function can only be used BEFORE the XIP-mode is activated! </dd></dl> +<dl class="section note"><dt>Note</dt><dd>This function is blocking and performs individual writes for each byte (little-endian byte order!).</dd></dl> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">src</td><td>Pointer to data that will be copied to flash (32-bit). </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">base_addr</td><td>Image base address (in flash). </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">size</td><td>Image size in bytes. </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Returns 0 if write was successful. </dd></dl> + +</div> +</div> +<h2 class="groupheader">Variable Documentation</h2> +<a id="acc95e55a622d79c2a398397d1f9b8033" name="acc95e55a622d79c2a398397d1f9b8033"></a> +<h2 class="memtitle"><span class="permalink"><a href="#acc95e55a622d79c2a398397d1f9b8033">&#9670;&#160;</a></span>ram_buffer</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t ram_buffer[<a class="el" href="#a6b20d41d6252e9871430c242cb1a56e7">BUFFER_SIZE</a>/4]</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Main function</p> +<dl class="section note"><dt>Note</dt><dd>This program requires the XIP module and UART0.</dd></dl> +<dl class="section return"><dt>Returns</dt><dd>0 if execution was successful </dd></dl> + +</div> +</div> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/demo__xirq_2main_8c.html b/sw/demo__xirq_2main_8c.html new file mode 100644 index 0000000000..2e3ace68f9 --- /dev/null +++ b/sw/demo__xirq_2main_8c.html @@ -0,0 +1,241 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/example/demo_xirq/main.c File Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_f0f9b27afba2e8cc2da6e5fddcc1a8c9.html">example</a></li><li class="navelem"><a class="el" href="dir_5534fa9035f54ab438a41c43d6f7fc7a.html">demo_xirq</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#func-members">Functions</a> </div> + <div class="headertitle"><div class="title">main.c File Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p>External interrupt controller (XIRQ) demo program (using hardware-assisted prioritization). +<a href="#details">More...</a></p> +<div class="textblock"><code>#include &lt;<a class="el" href="neorv32_8h_source.html">neorv32.h</a>&gt;</code><br /> +</div><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="define-members" name="define-members"></a> +Macros</h2></td></tr> +<tr><td colspan="2"><div class="groupHeader">User configuration</div></td></tr> +<tr class="memitem:ad4455691936f92fdd6c37566fc58ba1f" id="r_ad4455691936f92fdd6c37566fc58ba1f"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ad4455691936f92fdd6c37566fc58ba1f">BAUD_RATE</a>&#160;&#160;&#160;19200</td></tr> +<tr class="separator:ad4455691936f92fdd6c37566fc58ba1f"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="func-members" name="func-members"></a> +Functions</h2></td></tr> +<tr class="memitem:a8874ccfc0b56171c359b5c2ceaf2bd80" id="r_a8874ccfc0b56171c359b5c2ceaf2bd80"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a8874ccfc0b56171c359b5c2ceaf2bd80">xirq_handler_ch0</a> (void)</td></tr> +<tr class="separator:a8874ccfc0b56171c359b5c2ceaf2bd80"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:abfe0c0bc47a683ba55df2aed63a12d4b" id="r_abfe0c0bc47a683ba55df2aed63a12d4b"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#abfe0c0bc47a683ba55df2aed63a12d4b">xirq_handler_ch1</a> (void)</td></tr> +<tr class="separator:abfe0c0bc47a683ba55df2aed63a12d4b"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ae8e3b3236aa2303c2b5e6e421b72cf73" id="r_ae8e3b3236aa2303c2b5e6e421b72cf73"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ae8e3b3236aa2303c2b5e6e421b72cf73">xirq_handler_ch2</a> (void)</td></tr> +<tr class="separator:ae8e3b3236aa2303c2b5e6e421b72cf73"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a99e9ae3088f39995c852b2c53ec21266" id="r_a99e9ae3088f39995c852b2c53ec21266"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a99e9ae3088f39995c852b2c53ec21266">xirq_handler_ch3</a> (void)</td></tr> +<tr class="separator:a99e9ae3088f39995c852b2c53ec21266"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ae66f6b31b5ad750f1fe042a706a4e3d4" id="r_ae66f6b31b5ad750f1fe042a706a4e3d4"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ae66f6b31b5ad750f1fe042a706a4e3d4">main</a> ()</td></tr> +<tr class="separator:ae66f6b31b5ad750f1fe042a706a4e3d4"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>External interrupt controller (XIRQ) demo program (using hardware-assisted prioritization). </p> +<dl class="section author"><dt>Author</dt><dd>Stephan Nolting </dd></dl> +</div><h2 class="groupheader">Macro Definition Documentation</h2> +<a id="ad4455691936f92fdd6c37566fc58ba1f" name="ad4455691936f92fdd6c37566fc58ba1f"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ad4455691936f92fdd6c37566fc58ba1f">&#9670;&#160;</a></span>BAUD_RATE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define BAUD_RATE&#160;&#160;&#160;19200</td> + </tr> + </table> +</div><div class="memdoc"> +<p>UART BAUD rate </p> + +</div> +</div> +<h2 class="groupheader">Function Documentation</h2> +<a id="ae66f6b31b5ad750f1fe042a706a4e3d4" name="ae66f6b31b5ad750f1fe042a706a4e3d4"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ae66f6b31b5ad750f1fe042a706a4e3d4">&#9670;&#160;</a></span>main()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int main </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Main function</p> +<dl class="section note"><dt>Note</dt><dd>This program requires the XIRQ and the UART to be synthesized.</dd></dl> +<dl class="section return"><dt>Returns</dt><dd>0 if execution was successful </dd></dl> + +</div> +</div> +<a id="a8874ccfc0b56171c359b5c2ceaf2bd80" name="a8874ccfc0b56171c359b5c2ceaf2bd80"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a8874ccfc0b56171c359b5c2ceaf2bd80">&#9670;&#160;</a></span>xirq_handler_ch0()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void xirq_handler_ch0 </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>XIRQ handler channel 0. </p><dl class="section warning"><dt>Warning</dt><dd>This function has to be of type "void xyz(void)" and must not use any interrupt attributes! </dd></dl> + +</div> +</div> +<a id="abfe0c0bc47a683ba55df2aed63a12d4b" name="abfe0c0bc47a683ba55df2aed63a12d4b"></a> +<h2 class="memtitle"><span class="permalink"><a href="#abfe0c0bc47a683ba55df2aed63a12d4b">&#9670;&#160;</a></span>xirq_handler_ch1()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void xirq_handler_ch1 </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>XIRQ handler channel 1. </p><dl class="section warning"><dt>Warning</dt><dd>This function has to be of type "void xyz(void)" and must not use any interrupt attributes! </dd></dl> + +</div> +</div> +<a id="ae8e3b3236aa2303c2b5e6e421b72cf73" name="ae8e3b3236aa2303c2b5e6e421b72cf73"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ae8e3b3236aa2303c2b5e6e421b72cf73">&#9670;&#160;</a></span>xirq_handler_ch2()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void xirq_handler_ch2 </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>XIRQ handler channel 2. </p><dl class="section warning"><dt>Warning</dt><dd>This function has to be of type "void xyz(void)" and must not use any interrupt attributes! </dd></dl> + +</div> +</div> +<a id="a99e9ae3088f39995c852b2c53ec21266" name="a99e9ae3088f39995c852b2c53ec21266"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a99e9ae3088f39995c852b2c53ec21266">&#9670;&#160;</a></span>xirq_handler_ch3()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void xirq_handler_ch3 </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>XIRQ handler channel 3. </p><dl class="section warning"><dt>Warning</dt><dd>This function has to be of type "void xyz(void)" and must not use any interrupt attributes! </dd></dl> + +</div> +</div> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/dhry_8h_source.html b/sw/dhry_8h_source.html new file mode 100644 index 0000000000..f99f43ac20 --- /dev/null +++ b/sw/dhry_8h_source.html @@ -0,0 +1,557 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/example/dhrystone/dhry.h Source File</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_f0f9b27afba2e8cc2da6e5fddcc1a8c9.html">example</a></li><li class="navelem"><a class="el" href="dir_b5eb9f7d151d147efb5dbda58439e4e7.html">dhrystone</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="headertitle"><div class="title">dhry.h</div></div> +</div><!--header--> +<div class="contents"> +<div class="fragment"><div class="line"><a id="l00001" name="l00001"></a><span class="lineno"> 1</span><span class="comment">/*</span></div> +<div class="line"><a id="l00002" name="l00002"></a><span class="lineno"> 2</span><span class="comment"> ****************************************************************************</span></div> +<div class="line"><a id="l00003" name="l00003"></a><span class="lineno"> 3</span><span class="comment"> *</span></div> +<div class="line"><a id="l00004" name="l00004"></a><span class="lineno"> 4</span><span class="comment"> * &quot;DHRYSTONE&quot; Benchmark Program</span></div> +<div class="line"><a id="l00005" name="l00005"></a><span class="lineno"> 5</span><span class="comment"> * -----------------------------</span></div> +<div class="line"><a id="l00006" name="l00006"></a><span class="lineno"> 6</span><span class="comment"> *</span></div> +<div class="line"><a id="l00007" name="l00007"></a><span class="lineno"> 7</span><span class="comment"> * Version: C, Version 2.1</span></div> +<div class="line"><a id="l00008" name="l00008"></a><span class="lineno"> 8</span><span class="comment"> *</span></div> +<div class="line"><a id="l00009" name="l00009"></a><span class="lineno"> 9</span><span class="comment"> * File: dhry.h (part 1 of 3)</span></div> +<div class="line"><a id="l00010" name="l00010"></a><span class="lineno"> 10</span><span class="comment"> *</span></div> +<div class="line"><a id="l00011" name="l00011"></a><span class="lineno"> 11</span><span class="comment"> * Date: May 25, 1988</span></div> +<div class="line"><a id="l00012" name="l00012"></a><span class="lineno"> 12</span><span class="comment"> *</span></div> +<div class="line"><a id="l00013" name="l00013"></a><span class="lineno"> 13</span><span class="comment"> * Author: Reinhold P. Weicker</span></div> +<div class="line"><a id="l00014" name="l00014"></a><span class="lineno"> 14</span><span class="comment"> * Siemens AG, E STE 35</span></div> +<div class="line"><a id="l00015" name="l00015"></a><span class="lineno"> 15</span><span class="comment"> * Postfach 3240</span></div> +<div class="line"><a id="l00016" name="l00016"></a><span class="lineno"> 16</span><span class="comment"> * 8520 Erlangen</span></div> +<div class="line"><a id="l00017" name="l00017"></a><span class="lineno"> 17</span><span class="comment"> * Germany (West)</span></div> +<div class="line"><a id="l00018" name="l00018"></a><span class="lineno"> 18</span><span class="comment"> * Phone: [xxx-49]-9131-7-20330</span></div> +<div class="line"><a id="l00019" name="l00019"></a><span class="lineno"> 19</span><span class="comment"> * (8-17 Central European Time)</span></div> +<div class="line"><a id="l00020" name="l00020"></a><span class="lineno"> 20</span><span class="comment"> * Usenet: ..!mcvax!unido!estevax!weicker</span></div> +<div class="line"><a id="l00021" name="l00021"></a><span class="lineno"> 21</span><span class="comment"> *</span></div> +<div class="line"><a id="l00022" name="l00022"></a><span class="lineno"> 22</span><span class="comment"> * Original Version (in Ada) published in</span></div> +<div class="line"><a id="l00023" name="l00023"></a><span class="lineno"> 23</span><span class="comment"> * &quot;Communications of the ACM&quot; vol. 27., no. 10 (Oct. 1984),</span></div> +<div class="line"><a id="l00024" name="l00024"></a><span class="lineno"> 24</span><span class="comment"> * pp. 1013 - 1030, together with the statistics</span></div> +<div class="line"><a id="l00025" name="l00025"></a><span class="lineno"> 25</span><span class="comment"> * on which the distribution of statements etc. is based.</span></div> +<div class="line"><a id="l00026" name="l00026"></a><span class="lineno"> 26</span><span class="comment"> *</span></div> +<div class="line"><a id="l00027" name="l00027"></a><span class="lineno"> 27</span><span class="comment"> * In this C version, the following C library functions are used:</span></div> +<div class="line"><a id="l00028" name="l00028"></a><span class="lineno"> 28</span><span class="comment"> * - strcpy, strcmp (inside the measurement loop)</span></div> +<div class="line"><a id="l00029" name="l00029"></a><span class="lineno"> 29</span><span class="comment"> * - printf, scanf (outside the measurement loop)</span></div> +<div class="line"><a id="l00030" name="l00030"></a><span class="lineno"> 30</span><span class="comment"> * In addition, Berkeley UNIX system calls &quot;times ()&quot; or &quot;time ()&quot;</span></div> +<div class="line"><a id="l00031" name="l00031"></a><span class="lineno"> 31</span><span class="comment"> * are used for execution time measurement. For measurements</span></div> +<div class="line"><a id="l00032" name="l00032"></a><span class="lineno"> 32</span><span class="comment"> * on other systems, these calls have to be changed.</span></div> +<div class="line"><a id="l00033" name="l00033"></a><span class="lineno"> 33</span><span class="comment"> *</span></div> +<div class="line"><a id="l00034" name="l00034"></a><span class="lineno"> 34</span><span class="comment"> * Collection of Results:</span></div> +<div class="line"><a id="l00035" name="l00035"></a><span class="lineno"> 35</span><span class="comment"> * Reinhold Weicker (address see above) and</span></div> +<div class="line"><a id="l00036" name="l00036"></a><span class="lineno"> 36</span><span class="comment"> *</span></div> +<div class="line"><a id="l00037" name="l00037"></a><span class="lineno"> 37</span><span class="comment"> * Rick Richardson</span></div> +<div class="line"><a id="l00038" name="l00038"></a><span class="lineno"> 38</span><span class="comment"> * PC Research. Inc.</span></div> +<div class="line"><a id="l00039" name="l00039"></a><span class="lineno"> 39</span><span class="comment"> * 94 Apple Orchard Drive</span></div> +<div class="line"><a id="l00040" name="l00040"></a><span class="lineno"> 40</span><span class="comment"> * Tinton Falls, NJ 07724</span></div> +<div class="line"><a id="l00041" name="l00041"></a><span class="lineno"> 41</span><span class="comment"> * Phone: (201) 389-8963 (9-17 EST)</span></div> +<div class="line"><a id="l00042" name="l00042"></a><span class="lineno"> 42</span><span class="comment"> * Usenet: ...!uunet!pcrat!rick</span></div> +<div class="line"><a id="l00043" name="l00043"></a><span class="lineno"> 43</span><span class="comment"> *</span></div> +<div class="line"><a id="l00044" name="l00044"></a><span class="lineno"> 44</span><span class="comment"> * Please send results to Rick Richardson and/or Reinhold Weicker.</span></div> +<div class="line"><a id="l00045" name="l00045"></a><span class="lineno"> 45</span><span class="comment"> * Complete information should be given on hardware and software used.</span></div> +<div class="line"><a id="l00046" name="l00046"></a><span class="lineno"> 46</span><span class="comment"> * Hardware information includes: Machine type, CPU, type and size</span></div> +<div class="line"><a id="l00047" name="l00047"></a><span class="lineno"> 47</span><span class="comment"> * of caches; for microprocessors: clock frequency, memory speed</span></div> +<div class="line"><a id="l00048" name="l00048"></a><span class="lineno"> 48</span><span class="comment"> * (number of wait states).</span></div> +<div class="line"><a id="l00049" name="l00049"></a><span class="lineno"> 49</span><span class="comment"> * Software information includes: Compiler (and runtime library)</span></div> +<div class="line"><a id="l00050" name="l00050"></a><span class="lineno"> 50</span><span class="comment"> * manufacturer and version, compilation switches, OS version.</span></div> +<div class="line"><a id="l00051" name="l00051"></a><span class="lineno"> 51</span><span class="comment"> * The Operating System version may give an indication about the</span></div> +<div class="line"><a id="l00052" name="l00052"></a><span class="lineno"> 52</span><span class="comment"> * compiler; Dhrystone itself performs no OS calls in the measurement loop.</span></div> +<div class="line"><a id="l00053" name="l00053"></a><span class="lineno"> 53</span><span class="comment"> *</span></div> +<div class="line"><a id="l00054" name="l00054"></a><span class="lineno"> 54</span><span class="comment"> * The complete output generated by the program should be mailed</span></div> +<div class="line"><a id="l00055" name="l00055"></a><span class="lineno"> 55</span><span class="comment"> * such that at least some checks for correctness can be made.</span></div> +<div class="line"><a id="l00056" name="l00056"></a><span class="lineno"> 56</span><span class="comment"> *</span></div> +<div class="line"><a id="l00057" name="l00057"></a><span class="lineno"> 57</span><span class="comment"> ***************************************************************************</span></div> +<div class="line"><a id="l00058" name="l00058"></a><span class="lineno"> 58</span><span class="comment"> *</span></div> +<div class="line"><a id="l00059" name="l00059"></a><span class="lineno"> 59</span><span class="comment"> * History: This version C/2.1 has been made for two reasons:</span></div> +<div class="line"><a id="l00060" name="l00060"></a><span class="lineno"> 60</span><span class="comment"> *</span></div> +<div class="line"><a id="l00061" name="l00061"></a><span class="lineno"> 61</span><span class="comment"> * 1) There is an obvious need for a common C version of</span></div> +<div class="line"><a id="l00062" name="l00062"></a><span class="lineno"> 62</span><span class="comment"> * Dhrystone, since C is at present the most popular system</span></div> +<div class="line"><a id="l00063" name="l00063"></a><span class="lineno"> 63</span><span class="comment"> * programming language for the class of processors</span></div> +<div class="line"><a id="l00064" name="l00064"></a><span class="lineno"> 64</span><span class="comment"> * (microcomputers, minicomputers) where Dhrystone is used most.</span></div> +<div class="line"><a id="l00065" name="l00065"></a><span class="lineno"> 65</span><span class="comment"> * There should be, as far as possible, only one C version of</span></div> +<div class="line"><a id="l00066" name="l00066"></a><span class="lineno"> 66</span><span class="comment"> * Dhrystone such that results can be compared without</span></div> +<div class="line"><a id="l00067" name="l00067"></a><span class="lineno"> 67</span><span class="comment"> * restrictions. In the past, the C versions distributed</span></div> +<div class="line"><a id="l00068" name="l00068"></a><span class="lineno"> 68</span><span class="comment"> * by Rick Richardson (Version 1.1) and by Reinhold Weicker</span></div> +<div class="line"><a id="l00069" name="l00069"></a><span class="lineno"> 69</span><span class="comment"> * had small (though not significant) differences.</span></div> +<div class="line"><a id="l00070" name="l00070"></a><span class="lineno"> 70</span><span class="comment"> *</span></div> +<div class="line"><a id="l00071" name="l00071"></a><span class="lineno"> 71</span><span class="comment"> * 2) As far as it is possible without changes to the Dhrystone</span></div> +<div class="line"><a id="l00072" name="l00072"></a><span class="lineno"> 72</span><span class="comment"> * statistics, optimizing compilers should be prevented from</span></div> +<div class="line"><a id="l00073" name="l00073"></a><span class="lineno"> 73</span><span class="comment"> * removing significant statements.</span></div> +<div class="line"><a id="l00074" name="l00074"></a><span class="lineno"> 74</span><span class="comment"> *</span></div> +<div class="line"><a id="l00075" name="l00075"></a><span class="lineno"> 75</span><span class="comment"> * This C version has been developed in cooperation with</span></div> +<div class="line"><a id="l00076" name="l00076"></a><span class="lineno"> 76</span><span class="comment"> * Rick Richardson (Tinton Falls, NJ), it incorporates many</span></div> +<div class="line"><a id="l00077" name="l00077"></a><span class="lineno"> 77</span><span class="comment"> * ideas from the &quot;Version 1.1&quot; distributed previously by</span></div> +<div class="line"><a id="l00078" name="l00078"></a><span class="lineno"> 78</span><span class="comment"> * him over the UNIX network Usenet.</span></div> +<div class="line"><a id="l00079" name="l00079"></a><span class="lineno"> 79</span><span class="comment"> * I also thank Chaim Benedelac (National Semiconductor),</span></div> +<div class="line"><a id="l00080" name="l00080"></a><span class="lineno"> 80</span><span class="comment"> * David Ditzel (SUN), Earl Killian and John Mashey (MIPS),</span></div> +<div class="line"><a id="l00081" name="l00081"></a><span class="lineno"> 81</span><span class="comment"> * Alan Smith and Rafael Saavedra-Barrera (UC at Berkeley)</span></div> +<div class="line"><a id="l00082" name="l00082"></a><span class="lineno"> 82</span><span class="comment"> * for their help with comments on earlier versions of the</span></div> +<div class="line"><a id="l00083" name="l00083"></a><span class="lineno"> 83</span><span class="comment"> * benchmark.</span></div> +<div class="line"><a id="l00084" name="l00084"></a><span class="lineno"> 84</span><span class="comment"> *</span></div> +<div class="line"><a id="l00085" name="l00085"></a><span class="lineno"> 85</span><span class="comment"> * Changes: In the initialization part, this version follows mostly</span></div> +<div class="line"><a id="l00086" name="l00086"></a><span class="lineno"> 86</span><span class="comment"> * Rick Richardson&#39;s version distributed via Usenet, not the</span></div> +<div class="line"><a id="l00087" name="l00087"></a><span class="lineno"> 87</span><span class="comment"> * version distributed earlier via floppy disk by Reinhold Weicker.</span></div> +<div class="line"><a id="l00088" name="l00088"></a><span class="lineno"> 88</span><span class="comment"> * As a concession to older compilers, names have been made</span></div> +<div class="line"><a id="l00089" name="l00089"></a><span class="lineno"> 89</span><span class="comment"> * unique within the first 8 characters.</span></div> +<div class="line"><a id="l00090" name="l00090"></a><span class="lineno"> 90</span><span class="comment"> * Inside the measurement loop, this version follows the</span></div> +<div class="line"><a id="l00091" name="l00091"></a><span class="lineno"> 91</span><span class="comment"> * version previously distributed by Reinhold Weicker.</span></div> +<div class="line"><a id="l00092" name="l00092"></a><span class="lineno"> 92</span><span class="comment"> *</span></div> +<div class="line"><a id="l00093" name="l00093"></a><span class="lineno"> 93</span><span class="comment"> * At several places in the benchmark, code has been added,</span></div> +<div class="line"><a id="l00094" name="l00094"></a><span class="lineno"> 94</span><span class="comment"> * but within the measurement loop only in branches that</span></div> +<div class="line"><a id="l00095" name="l00095"></a><span class="lineno"> 95</span><span class="comment"> * are not executed. The intention is that optimizing compilers</span></div> +<div class="line"><a id="l00096" name="l00096"></a><span class="lineno"> 96</span><span class="comment"> * should be prevented from moving code out of the measurement</span></div> +<div class="line"><a id="l00097" name="l00097"></a><span class="lineno"> 97</span><span class="comment"> * loop, or from removing code altogether. Since the statements</span></div> +<div class="line"><a id="l00098" name="l00098"></a><span class="lineno"> 98</span><span class="comment"> * that are executed within the measurement loop have NOT been</span></div> +<div class="line"><a id="l00099" name="l00099"></a><span class="lineno"> 99</span><span class="comment"> * changed, the numbers defining the &quot;Dhrystone distribution&quot;</span></div> +<div class="line"><a id="l00100" name="l00100"></a><span class="lineno"> 100</span><span class="comment"> * (distribution of statements, operand types and locality)</span></div> +<div class="line"><a id="l00101" name="l00101"></a><span class="lineno"> 101</span><span class="comment"> * still hold. Except for sophisticated optimizing compilers,</span></div> +<div class="line"><a id="l00102" name="l00102"></a><span class="lineno"> 102</span><span class="comment"> * execution times for this version should be the same as</span></div> +<div class="line"><a id="l00103" name="l00103"></a><span class="lineno"> 103</span><span class="comment"> * for previous versions.</span></div> +<div class="line"><a id="l00104" name="l00104"></a><span class="lineno"> 104</span><span class="comment"> *</span></div> +<div class="line"><a id="l00105" name="l00105"></a><span class="lineno"> 105</span><span class="comment"> * Since it has proven difficult to subtract the time for the</span></div> +<div class="line"><a id="l00106" name="l00106"></a><span class="lineno"> 106</span><span class="comment"> * measurement loop overhead in a correct way, the loop check</span></div> +<div class="line"><a id="l00107" name="l00107"></a><span class="lineno"> 107</span><span class="comment"> * has been made a part of the benchmark. This does have</span></div> +<div class="line"><a id="l00108" name="l00108"></a><span class="lineno"> 108</span><span class="comment"> * an impact - though a very minor one - on the distribution</span></div> +<div class="line"><a id="l00109" name="l00109"></a><span class="lineno"> 109</span><span class="comment"> * statistics which have been updated for this version.</span></div> +<div class="line"><a id="l00110" name="l00110"></a><span class="lineno"> 110</span><span class="comment"> *</span></div> +<div class="line"><a id="l00111" name="l00111"></a><span class="lineno"> 111</span><span class="comment"> * All changes within the measurement loop are described</span></div> +<div class="line"><a id="l00112" name="l00112"></a><span class="lineno"> 112</span><span class="comment"> * and discussed in the companion paper &quot;Rationale for</span></div> +<div class="line"><a id="l00113" name="l00113"></a><span class="lineno"> 113</span><span class="comment"> * Dhrystone version 2&quot;.</span></div> +<div class="line"><a id="l00114" name="l00114"></a><span class="lineno"> 114</span><span class="comment"> *</span></div> +<div class="line"><a id="l00115" name="l00115"></a><span class="lineno"> 115</span><span class="comment"> * Because of the self-imposed limitation that the order and</span></div> +<div class="line"><a id="l00116" name="l00116"></a><span class="lineno"> 116</span><span class="comment"> * distribution of the executed statements should not be</span></div> +<div class="line"><a id="l00117" name="l00117"></a><span class="lineno"> 117</span><span class="comment"> * changed, there are still cases where optimizing compilers</span></div> +<div class="line"><a id="l00118" name="l00118"></a><span class="lineno"> 118</span><span class="comment"> * may not generate code for some statements. To a certain</span></div> +<div class="line"><a id="l00119" name="l00119"></a><span class="lineno"> 119</span><span class="comment"> * degree, this is unavoidable for small synthetic benchmarks.</span></div> +<div class="line"><a id="l00120" name="l00120"></a><span class="lineno"> 120</span><span class="comment"> * Users of the benchmark are advised to check code listings</span></div> +<div class="line"><a id="l00121" name="l00121"></a><span class="lineno"> 121</span><span class="comment"> * whether code is generated for all statements of Dhrystone.</span></div> +<div class="line"><a id="l00122" name="l00122"></a><span class="lineno"> 122</span><span class="comment"> *</span></div> +<div class="line"><a id="l00123" name="l00123"></a><span class="lineno"> 123</span><span class="comment"> * Version 2.1 is identical to version 2.0 distributed via</span></div> +<div class="line"><a id="l00124" name="l00124"></a><span class="lineno"> 124</span><span class="comment"> * the UNIX network Usenet in March 1988 except that it corrects</span></div> +<div class="line"><a id="l00125" name="l00125"></a><span class="lineno"> 125</span><span class="comment"> * some minor deficiencies that were found by users of version 2.0.</span></div> +<div class="line"><a id="l00126" name="l00126"></a><span class="lineno"> 126</span><span class="comment"> * The only change within the measurement loop is that a</span></div> +<div class="line"><a id="l00127" name="l00127"></a><span class="lineno"> 127</span><span class="comment"> * non-executed &quot;else&quot; part was added to the &quot;if&quot; statement in</span></div> +<div class="line"><a id="l00128" name="l00128"></a><span class="lineno"> 128</span><span class="comment"> * Func_3, and a non-executed &quot;else&quot; part removed from Proc_3.</span></div> +<div class="line"><a id="l00129" name="l00129"></a><span class="lineno"> 129</span><span class="comment"> *</span></div> +<div class="line"><a id="l00130" name="l00130"></a><span class="lineno"> 130</span><span class="comment"> ***************************************************************************</span></div> +<div class="line"><a id="l00131" name="l00131"></a><span class="lineno"> 131</span><span class="comment"> *</span></div> +<div class="line"><a id="l00132" name="l00132"></a><span class="lineno"> 132</span><span class="comment"> * Defines: The following &quot;Defines&quot; are possible:</span></div> +<div class="line"><a id="l00133" name="l00133"></a><span class="lineno"> 133</span><span class="comment"> * -DREG=register (default: Not defined)</span></div> +<div class="line"><a id="l00134" name="l00134"></a><span class="lineno"> 134</span><span class="comment"> * As an approximation to what an average C programmer</span></div> +<div class="line"><a id="l00135" name="l00135"></a><span class="lineno"> 135</span><span class="comment"> * might do, the &quot;register&quot; storage class is applied</span></div> +<div class="line"><a id="l00136" name="l00136"></a><span class="lineno"> 136</span><span class="comment"> * (if enabled by -DREG=register)</span></div> +<div class="line"><a id="l00137" name="l00137"></a><span class="lineno"> 137</span><span class="comment"> * - for local variables, if they are used (dynamically)</span></div> +<div class="line"><a id="l00138" name="l00138"></a><span class="lineno"> 138</span><span class="comment"> * five or more times</span></div> +<div class="line"><a id="l00139" name="l00139"></a><span class="lineno"> 139</span><span class="comment"> * - for parameters if they are used (dynamically)</span></div> +<div class="line"><a id="l00140" name="l00140"></a><span class="lineno"> 140</span><span class="comment"> * six or more times</span></div> +<div class="line"><a id="l00141" name="l00141"></a><span class="lineno"> 141</span><span class="comment"> * Note that an optimal &quot;register&quot; strategy is</span></div> +<div class="line"><a id="l00142" name="l00142"></a><span class="lineno"> 142</span><span class="comment"> * compiler-dependent, and that &quot;register&quot; declarations</span></div> +<div class="line"><a id="l00143" name="l00143"></a><span class="lineno"> 143</span><span class="comment"> * do not necessarily lead to faster execution.</span></div> +<div class="line"><a id="l00144" name="l00144"></a><span class="lineno"> 144</span><span class="comment"> * -DNOSTRUCTASSIGN (default: Not defined)</span></div> +<div class="line"><a id="l00145" name="l00145"></a><span class="lineno"> 145</span><span class="comment"> * Define if the C compiler does not support</span></div> +<div class="line"><a id="l00146" name="l00146"></a><span class="lineno"> 146</span><span class="comment"> * assignment of structures.</span></div> +<div class="line"><a id="l00147" name="l00147"></a><span class="lineno"> 147</span><span class="comment"> * -DNOENUMS (default: Not defined)</span></div> +<div class="line"><a id="l00148" name="l00148"></a><span class="lineno"> 148</span><span class="comment"> * Define if the C compiler does not support</span></div> +<div class="line"><a id="l00149" name="l00149"></a><span class="lineno"> 149</span><span class="comment"> * enumeration types.</span></div> +<div class="line"><a id="l00150" name="l00150"></a><span class="lineno"> 150</span><span class="comment"> * -DTIMES (default)</span></div> +<div class="line"><a id="l00151" name="l00151"></a><span class="lineno"> 151</span><span class="comment"> * -DTIME</span></div> +<div class="line"><a id="l00152" name="l00152"></a><span class="lineno"> 152</span><span class="comment"> * The &quot;times&quot; function of UNIX (returning process times)</span></div> +<div class="line"><a id="l00153" name="l00153"></a><span class="lineno"> 153</span><span class="comment"> * or the &quot;time&quot; function (returning wallclock time)</span></div> +<div class="line"><a id="l00154" name="l00154"></a><span class="lineno"> 154</span><span class="comment"> * is used for measurement.</span></div> +<div class="line"><a id="l00155" name="l00155"></a><span class="lineno"> 155</span><span class="comment"> * For single user machines, &quot;time ()&quot; is adequate. For</span></div> +<div class="line"><a id="l00156" name="l00156"></a><span class="lineno"> 156</span><span class="comment"> * multi-user machines where you cannot get single-user</span></div> +<div class="line"><a id="l00157" name="l00157"></a><span class="lineno"> 157</span><span class="comment"> * access, use the &quot;times ()&quot; function. If you have</span></div> +<div class="line"><a id="l00158" name="l00158"></a><span class="lineno"> 158</span><span class="comment"> * neither, use a stopwatch in the dead of night.</span></div> +<div class="line"><a id="l00159" name="l00159"></a><span class="lineno"> 159</span><span class="comment"> * &quot;printf&quot;s are provided marking the points &quot;Start Timer&quot;</span></div> +<div class="line"><a id="l00160" name="l00160"></a><span class="lineno"> 160</span><span class="comment"> * and &quot;Stop Timer&quot;. DO NOT use the UNIX &quot;time(1)&quot;</span></div> +<div class="line"><a id="l00161" name="l00161"></a><span class="lineno"> 161</span><span class="comment"> * command, as this will measure the total time to</span></div> +<div class="line"><a id="l00162" name="l00162"></a><span class="lineno"> 162</span><span class="comment"> * run this program, which will (erroneously) include</span></div> +<div class="line"><a id="l00163" name="l00163"></a><span class="lineno"> 163</span><span class="comment"> * the time to allocate storage (malloc) and to perform</span></div> +<div class="line"><a id="l00164" name="l00164"></a><span class="lineno"> 164</span><span class="comment"> * the initialization.</span></div> +<div class="line"><a id="l00165" name="l00165"></a><span class="lineno"> 165</span><span class="comment"> * -DHZ=nnn</span></div> +<div class="line"><a id="l00166" name="l00166"></a><span class="lineno"> 166</span><span class="comment"> * In Berkeley UNIX, the function &quot;times&quot; returns process</span></div> +<div class="line"><a id="l00167" name="l00167"></a><span class="lineno"> 167</span><span class="comment"> * time in 1/HZ seconds, with HZ = 60 for most systems.</span></div> +<div class="line"><a id="l00168" name="l00168"></a><span class="lineno"> 168</span><span class="comment"> * CHECK YOUR SYSTEM DESCRIPTION BEFORE YOU JUST APPLY</span></div> +<div class="line"><a id="l00169" name="l00169"></a><span class="lineno"> 169</span><span class="comment"> * A VALUE.</span></div> +<div class="line"><a id="l00170" name="l00170"></a><span class="lineno"> 170</span><span class="comment"> *</span></div> +<div class="line"><a id="l00171" name="l00171"></a><span class="lineno"> 171</span><span class="comment"> ***************************************************************************</span></div> +<div class="line"><a id="l00172" name="l00172"></a><span class="lineno"> 172</span><span class="comment"> *</span></div> +<div class="line"><a id="l00173" name="l00173"></a><span class="lineno"> 173</span><span class="comment"> * Compilation model and measurement (IMPORTANT):</span></div> +<div class="line"><a id="l00174" name="l00174"></a><span class="lineno"> 174</span><span class="comment"> *</span></div> +<div class="line"><a id="l00175" name="l00175"></a><span class="lineno"> 175</span><span class="comment"> * This C version of Dhrystone consists of three files:</span></div> +<div class="line"><a id="l00176" name="l00176"></a><span class="lineno"> 176</span><span class="comment"> * - dhry.h (this file, containing global definitions and comments)</span></div> +<div class="line"><a id="l00177" name="l00177"></a><span class="lineno"> 177</span><span class="comment"> * - dhry_1.c (containing the code corresponding to Ada package Pack_1)</span></div> +<div class="line"><a id="l00178" name="l00178"></a><span class="lineno"> 178</span><span class="comment"> * - dhry_2.c (containing the code corresponding to Ada package Pack_2)</span></div> +<div class="line"><a id="l00179" name="l00179"></a><span class="lineno"> 179</span><span class="comment"> *</span></div> +<div class="line"><a id="l00180" name="l00180"></a><span class="lineno"> 180</span><span class="comment"> * The following &quot;ground rules&quot; apply for measurements:</span></div> +<div class="line"><a id="l00181" name="l00181"></a><span class="lineno"> 181</span><span class="comment"> * - Separate compilation</span></div> +<div class="line"><a id="l00182" name="l00182"></a><span class="lineno"> 182</span><span class="comment"> * - No procedure merging</span></div> +<div class="line"><a id="l00183" name="l00183"></a><span class="lineno"> 183</span><span class="comment"> * - Otherwise, compiler optimizations are allowed but should be indicated</span></div> +<div class="line"><a id="l00184" name="l00184"></a><span class="lineno"> 184</span><span class="comment"> * - Default results are those without register declarations</span></div> +<div class="line"><a id="l00185" name="l00185"></a><span class="lineno"> 185</span><span class="comment"> * See the companion paper &quot;Rationale for Dhrystone Version 2&quot; for a more</span></div> +<div class="line"><a id="l00186" name="l00186"></a><span class="lineno"> 186</span><span class="comment"> * detailed discussion of these ground rules.</span></div> +<div class="line"><a id="l00187" name="l00187"></a><span class="lineno"> 187</span><span class="comment"> *</span></div> +<div class="line"><a id="l00188" name="l00188"></a><span class="lineno"> 188</span><span class="comment"> * For 16-Bit processors (e.g. 80186, 80286), times for all compilation</span></div> +<div class="line"><a id="l00189" name="l00189"></a><span class="lineno"> 189</span><span class="comment"> * models (&quot;small&quot;, &quot;medium&quot;, &quot;large&quot; etc.) should be given if possible,</span></div> +<div class="line"><a id="l00190" name="l00190"></a><span class="lineno"> 190</span><span class="comment"> * together with a definition of these models for the compiler system used.</span></div> +<div class="line"><a id="l00191" name="l00191"></a><span class="lineno"> 191</span><span class="comment"> *</span></div> +<div class="line"><a id="l00192" name="l00192"></a><span class="lineno"> 192</span><span class="comment"> **************************************************************************</span></div> +<div class="line"><a id="l00193" name="l00193"></a><span class="lineno"> 193</span><span class="comment"> *</span></div> +<div class="line"><a id="l00194" name="l00194"></a><span class="lineno"> 194</span><span class="comment"> * Dhrystone (C version) statistics:</span></div> +<div class="line"><a id="l00195" name="l00195"></a><span class="lineno"> 195</span><span class="comment"> *</span></div> +<div class="line"><a id="l00196" name="l00196"></a><span class="lineno"> 196</span><span class="comment"> * [Comment from the first distribution, updated for version 2.</span></div> +<div class="line"><a id="l00197" name="l00197"></a><span class="lineno"> 197</span><span class="comment"> * Note that because of language differences, the numbers are slightly</span></div> +<div class="line"><a id="l00198" name="l00198"></a><span class="lineno"> 198</span><span class="comment"> * different from the Ada version.]</span></div> +<div class="line"><a id="l00199" name="l00199"></a><span class="lineno"> 199</span><span class="comment"> *</span></div> +<div class="line"><a id="l00200" name="l00200"></a><span class="lineno"> 200</span><span class="comment"> * The following program contains statements of a high level programming</span></div> +<div class="line"><a id="l00201" name="l00201"></a><span class="lineno"> 201</span><span class="comment"> * language (here: C) in a distribution considered representative:</span></div> +<div class="line"><a id="l00202" name="l00202"></a><span class="lineno"> 202</span><span class="comment"> *</span></div> +<div class="line"><a id="l00203" name="l00203"></a><span class="lineno"> 203</span><span class="comment"> * assignments 52 (51.0 %)</span></div> +<div class="line"><a id="l00204" name="l00204"></a><span class="lineno"> 204</span><span class="comment"> * control statements 33 (32.4 %)</span></div> +<div class="line"><a id="l00205" name="l00205"></a><span class="lineno"> 205</span><span class="comment"> * procedure, function calls 17 (16.7 %)</span></div> +<div class="line"><a id="l00206" name="l00206"></a><span class="lineno"> 206</span><span class="comment"> *</span></div> +<div class="line"><a id="l00207" name="l00207"></a><span class="lineno"> 207</span><span class="comment"> * 103 statements are dynamically executed. The program is balanced with</span></div> +<div class="line"><a id="l00208" name="l00208"></a><span class="lineno"> 208</span><span class="comment"> * respect to the three aspects:</span></div> +<div class="line"><a id="l00209" name="l00209"></a><span class="lineno"> 209</span><span class="comment"> *</span></div> +<div class="line"><a id="l00210" name="l00210"></a><span class="lineno"> 210</span><span class="comment"> * - statement type</span></div> +<div class="line"><a id="l00211" name="l00211"></a><span class="lineno"> 211</span><span class="comment"> * - operand type</span></div> +<div class="line"><a id="l00212" name="l00212"></a><span class="lineno"> 212</span><span class="comment"> * - operand locality</span></div> +<div class="line"><a id="l00213" name="l00213"></a><span class="lineno"> 213</span><span class="comment"> * operand global, local, parameter, or constant.</span></div> +<div class="line"><a id="l00214" name="l00214"></a><span class="lineno"> 214</span><span class="comment"> *</span></div> +<div class="line"><a id="l00215" name="l00215"></a><span class="lineno"> 215</span><span class="comment"> * The combination of these three aspects is balanced only approximately.</span></div> +<div class="line"><a id="l00216" name="l00216"></a><span class="lineno"> 216</span><span class="comment"> *</span></div> +<div class="line"><a id="l00217" name="l00217"></a><span class="lineno"> 217</span><span class="comment"> * 1. Statement Type:</span></div> +<div class="line"><a id="l00218" name="l00218"></a><span class="lineno"> 218</span><span class="comment"> * ----------------- number</span></div> +<div class="line"><a id="l00219" name="l00219"></a><span class="lineno"> 219</span><span class="comment"> *</span></div> +<div class="line"><a id="l00220" name="l00220"></a><span class="lineno"> 220</span><span class="comment"> * V1 = V2 9</span></div> +<div class="line"><a id="l00221" name="l00221"></a><span class="lineno"> 221</span><span class="comment"> * (incl. V1 = F(..)</span></div> +<div class="line"><a id="l00222" name="l00222"></a><span class="lineno"> 222</span><span class="comment"> * V = Constant 12</span></div> +<div class="line"><a id="l00223" name="l00223"></a><span class="lineno"> 223</span><span class="comment"> * Assignment, 7</span></div> +<div class="line"><a id="l00224" name="l00224"></a><span class="lineno"> 224</span><span class="comment"> * with array element</span></div> +<div class="line"><a id="l00225" name="l00225"></a><span class="lineno"> 225</span><span class="comment"> * Assignment, 6</span></div> +<div class="line"><a id="l00226" name="l00226"></a><span class="lineno"> 226</span><span class="comment"> * with record component</span></div> +<div class="line"><a id="l00227" name="l00227"></a><span class="lineno"> 227</span><span class="comment"> * --</span></div> +<div class="line"><a id="l00228" name="l00228"></a><span class="lineno"> 228</span><span class="comment"> * 34 34</span></div> +<div class="line"><a id="l00229" name="l00229"></a><span class="lineno"> 229</span><span class="comment"> *</span></div> +<div class="line"><a id="l00230" name="l00230"></a><span class="lineno"> 230</span><span class="comment"> * X = Y +|-|&quot;&amp;&amp;&quot;|&quot;|&quot; Z 5</span></div> +<div class="line"><a id="l00231" name="l00231"></a><span class="lineno"> 231</span><span class="comment"> * X = Y +|-|&quot;==&quot; Constant 6</span></div> +<div class="line"><a id="l00232" name="l00232"></a><span class="lineno"> 232</span><span class="comment"> * X = X +|- 1 3</span></div> +<div class="line"><a id="l00233" name="l00233"></a><span class="lineno"> 233</span><span class="comment"> * X = Y *|/ Z 2</span></div> +<div class="line"><a id="l00234" name="l00234"></a><span class="lineno"> 234</span><span class="comment"> * X = Expression, 1</span></div> +<div class="line"><a id="l00235" name="l00235"></a><span class="lineno"> 235</span><span class="comment"> * two operators</span></div> +<div class="line"><a id="l00236" name="l00236"></a><span class="lineno"> 236</span><span class="comment"> * X = Expression, 1</span></div> +<div class="line"><a id="l00237" name="l00237"></a><span class="lineno"> 237</span><span class="comment"> * three operators</span></div> +<div class="line"><a id="l00238" name="l00238"></a><span class="lineno"> 238</span><span class="comment"> * --</span></div> +<div class="line"><a id="l00239" name="l00239"></a><span class="lineno"> 239</span><span class="comment"> * 18 18</span></div> +<div class="line"><a id="l00240" name="l00240"></a><span class="lineno"> 240</span><span class="comment"> *</span></div> +<div class="line"><a id="l00241" name="l00241"></a><span class="lineno"> 241</span><span class="comment"> * if .... 14</span></div> +<div class="line"><a id="l00242" name="l00242"></a><span class="lineno"> 242</span><span class="comment"> * with &quot;else&quot; 7</span></div> +<div class="line"><a id="l00243" name="l00243"></a><span class="lineno"> 243</span><span class="comment"> * without &quot;else&quot; 7</span></div> +<div class="line"><a id="l00244" name="l00244"></a><span class="lineno"> 244</span><span class="comment"> * executed 3</span></div> +<div class="line"><a id="l00245" name="l00245"></a><span class="lineno"> 245</span><span class="comment"> * not executed 4</span></div> +<div class="line"><a id="l00246" name="l00246"></a><span class="lineno"> 246</span><span class="comment"> * for ... 7 | counted every time</span></div> +<div class="line"><a id="l00247" name="l00247"></a><span class="lineno"> 247</span><span class="comment"> * while ... 4 | the loop condition</span></div> +<div class="line"><a id="l00248" name="l00248"></a><span class="lineno"> 248</span><span class="comment"> * do ... while 1 | is evaluated</span></div> +<div class="line"><a id="l00249" name="l00249"></a><span class="lineno"> 249</span><span class="comment"> * switch ... 1</span></div> +<div class="line"><a id="l00250" name="l00250"></a><span class="lineno"> 250</span><span class="comment"> * break 1</span></div> +<div class="line"><a id="l00251" name="l00251"></a><span class="lineno"> 251</span><span class="comment"> * declaration with 1</span></div> +<div class="line"><a id="l00252" name="l00252"></a><span class="lineno"> 252</span><span class="comment"> * initialization</span></div> +<div class="line"><a id="l00253" name="l00253"></a><span class="lineno"> 253</span><span class="comment"> * --</span></div> +<div class="line"><a id="l00254" name="l00254"></a><span class="lineno"> 254</span><span class="comment"> * 34 34</span></div> +<div class="line"><a id="l00255" name="l00255"></a><span class="lineno"> 255</span><span class="comment"> *</span></div> +<div class="line"><a id="l00256" name="l00256"></a><span class="lineno"> 256</span><span class="comment"> * P (...) procedure call 11</span></div> +<div class="line"><a id="l00257" name="l00257"></a><span class="lineno"> 257</span><span class="comment"> * user procedure 10</span></div> +<div class="line"><a id="l00258" name="l00258"></a><span class="lineno"> 258</span><span class="comment"> * library procedure 1</span></div> +<div class="line"><a id="l00259" name="l00259"></a><span class="lineno"> 259</span><span class="comment"> * X = F (...)</span></div> +<div class="line"><a id="l00260" name="l00260"></a><span class="lineno"> 260</span><span class="comment"> * function call 6</span></div> +<div class="line"><a id="l00261" name="l00261"></a><span class="lineno"> 261</span><span class="comment"> * user function 5</span></div> +<div class="line"><a id="l00262" name="l00262"></a><span class="lineno"> 262</span><span class="comment"> * library function 1</span></div> +<div class="line"><a id="l00263" name="l00263"></a><span class="lineno"> 263</span><span class="comment"> * --</span></div> +<div class="line"><a id="l00264" name="l00264"></a><span class="lineno"> 264</span><span class="comment"> * 17 17</span></div> +<div class="line"><a id="l00265" name="l00265"></a><span class="lineno"> 265</span><span class="comment"> * ---</span></div> +<div class="line"><a id="l00266" name="l00266"></a><span class="lineno"> 266</span><span class="comment"> * 103</span></div> +<div class="line"><a id="l00267" name="l00267"></a><span class="lineno"> 267</span><span class="comment"> *</span></div> +<div class="line"><a id="l00268" name="l00268"></a><span class="lineno"> 268</span><span class="comment"> * The average number of parameters in procedure or function calls</span></div> +<div class="line"><a id="l00269" name="l00269"></a><span class="lineno"> 269</span><span class="comment"> * is 1.82 (not counting the function values aX *</span></div> +<div class="line"><a id="l00270" name="l00270"></a><span class="lineno"> 270</span><span class="comment"> *</span></div> +<div class="line"><a id="l00271" name="l00271"></a><span class="lineno"> 271</span><span class="comment"> * 2. Operators</span></div> +<div class="line"><a id="l00272" name="l00272"></a><span class="lineno"> 272</span><span class="comment"> * ------------</span></div> +<div class="line"><a id="l00273" name="l00273"></a><span class="lineno"> 273</span><span class="comment"> * number approximate</span></div> +<div class="line"><a id="l00274" name="l00274"></a><span class="lineno"> 274</span><span class="comment"> * percentage</span></div> +<div class="line"><a id="l00275" name="l00275"></a><span class="lineno"> 275</span><span class="comment"> *</span></div> +<div class="line"><a id="l00276" name="l00276"></a><span class="lineno"> 276</span><span class="comment"> * Arithmetic 32 50.8</span></div> +<div class="line"><a id="l00277" name="l00277"></a><span class="lineno"> 277</span><span class="comment"> *</span></div> +<div class="line"><a id="l00278" name="l00278"></a><span class="lineno"> 278</span><span class="comment"> * + 21 33.3</span></div> +<div class="line"><a id="l00279" name="l00279"></a><span class="lineno"> 279</span><span class="comment"> * - 7 11.1</span></div> +<div class="line"><a id="l00280" name="l00280"></a><span class="lineno"> 280</span><span class="comment"> * * 3 4.8</span></div> +<div class="line"><a id="l00281" name="l00281"></a><span class="lineno"> 281</span><span class="comment"> * / (int div) 1 1.6</span></div> +<div class="line"><a id="l00282" name="l00282"></a><span class="lineno"> 282</span><span class="comment"> *</span></div> +<div class="line"><a id="l00283" name="l00283"></a><span class="lineno"> 283</span><span class="comment"> * Comparison 27 42.8</span></div> +<div class="line"><a id="l00284" name="l00284"></a><span class="lineno"> 284</span><span class="comment"> *</span></div> +<div class="line"><a id="l00285" name="l00285"></a><span class="lineno"> 285</span><span class="comment"> * == 9 14.3</span></div> +<div class="line"><a id="l00286" name="l00286"></a><span class="lineno"> 286</span><span class="comment"> * /= 4 6.3</span></div> +<div class="line"><a id="l00287" name="l00287"></a><span class="lineno"> 287</span><span class="comment"> * &gt; 1 1.6</span></div> +<div class="line"><a id="l00288" name="l00288"></a><span class="lineno"> 288</span><span class="comment"> * &lt; 3 4.8</span></div> +<div class="line"><a id="l00289" name="l00289"></a><span class="lineno"> 289</span><span class="comment"> * &gt;= 1 1.6</span></div> +<div class="line"><a id="l00290" name="l00290"></a><span class="lineno"> 290</span><span class="comment"> * &lt;= 9 14.3</span></div> +<div class="line"><a id="l00291" name="l00291"></a><span class="lineno"> 291</span><span class="comment"> *</span></div> +<div class="line"><a id="l00292" name="l00292"></a><span class="lineno"> 292</span><span class="comment"> * Logic 4 6.3</span></div> +<div class="line"><a id="l00293" name="l00293"></a><span class="lineno"> 293</span><span class="comment"> *</span></div> +<div class="line"><a id="l00294" name="l00294"></a><span class="lineno"> 294</span><span class="comment"> * &amp;&amp; (AND-THEN) 1 1.6</span></div> +<div class="line"><a id="l00295" name="l00295"></a><span class="lineno"> 295</span><span class="comment"> * | (OR) 1 1.6</span></div> +<div class="line"><a id="l00296" name="l00296"></a><span class="lineno"> 296</span><span class="comment"> * ! (NOT) 2 3.2</span></div> +<div class="line"><a id="l00297" name="l00297"></a><span class="lineno"> 297</span><span class="comment"> *</span></div> +<div class="line"><a id="l00298" name="l00298"></a><span class="lineno"> 298</span><span class="comment"> * -- -----</span></div> +<div class="line"><a id="l00299" name="l00299"></a><span class="lineno"> 299</span><span class="comment"> * 63 100.1</span></div> +<div class="line"><a id="l00300" name="l00300"></a><span class="lineno"> 300</span><span class="comment"> *</span></div> +<div class="line"><a id="l00301" name="l00301"></a><span class="lineno"> 301</span><span class="comment"> *</span></div> +<div class="line"><a id="l00302" name="l00302"></a><span class="lineno"> 302</span><span class="comment"> * 3. Operand Type (counted once per operand reference):</span></div> +<div class="line"><a id="l00303" name="l00303"></a><span class="lineno"> 303</span><span class="comment"> * ---------------</span></div> +<div class="line"><a id="l00304" name="l00304"></a><span class="lineno"> 304</span><span class="comment"> * number approximate</span></div> +<div class="line"><a id="l00305" name="l00305"></a><span class="lineno"> 305</span><span class="comment"> * percentage</span></div> +<div class="line"><a id="l00306" name="l00306"></a><span class="lineno"> 306</span><span class="comment"> *</span></div> +<div class="line"><a id="l00307" name="l00307"></a><span class="lineno"> 307</span><span class="comment"> * Integer 175 72.3 %</span></div> +<div class="line"><a id="l00308" name="l00308"></a><span class="lineno"> 308</span><span class="comment"> * Character 45 18.6 %</span></div> +<div class="line"><a id="l00309" name="l00309"></a><span class="lineno"> 309</span><span class="comment"> * Pointer 12 5.0 %</span></div> +<div class="line"><a id="l00310" name="l00310"></a><span class="lineno"> 310</span><span class="comment"> * String30 6 2.5 %</span></div> +<div class="line"><a id="l00311" name="l00311"></a><span class="lineno"> 311</span><span class="comment"> * Array 2 0.8 %</span></div> +<div class="line"><a id="l00312" name="l00312"></a><span class="lineno"> 312</span><span class="comment"> * Record 2 0.8 %</span></div> +<div class="line"><a id="l00313" name="l00313"></a><span class="lineno"> 313</span><span class="comment"> * --- -------</span></div> +<div class="line"><a id="l00314" name="l00314"></a><span class="lineno"> 314</span><span class="comment"> * 242 100.0 %</span></div> +<div class="line"><a id="l00315" name="l00315"></a><span class="lineno"> 315</span><span class="comment"> *</span></div> +<div class="line"><a id="l00316" name="l00316"></a><span class="lineno"> 316</span><span class="comment"> * When there is an access path leading to the final operand (e.g. a record</span></div> +<div class="line"><a id="l00317" name="l00317"></a><span class="lineno"> 317</span><span class="comment"> * component), only the final data type on the access path is counted.</span></div> +<div class="line"><a id="l00318" name="l00318"></a><span class="lineno"> 318</span><span class="comment"> *</span></div> +<div class="line"><a id="l00319" name="l00319"></a><span class="lineno"> 319</span><span class="comment"> *</span></div> +<div class="line"><a id="l00320" name="l00320"></a><span class="lineno"> 320</span><span class="comment"> * 4. Operand Locality:</span></div> +<div class="line"><a id="l00321" name="l00321"></a><span class="lineno"> 321</span><span class="comment"> * -------------------</span></div> +<div class="line"><a id="l00322" name="l00322"></a><span class="lineno"> 322</span><span class="comment"> * number approximate</span></div> +<div class="line"><a id="l00323" name="l00323"></a><span class="lineno"> 323</span><span class="comment"> * percentage</span></div> +<div class="line"><a id="l00324" name="l00324"></a><span class="lineno"> 324</span><span class="comment"> *</span></div> +<div class="line"><a id="l00325" name="l00325"></a><span class="lineno"> 325</span><span class="comment"> * local variable 114 47.1 %</span></div> +<div class="line"><a id="l00326" name="l00326"></a><span class="lineno"> 326</span><span class="comment"> * global variable 22 9.1 %</span></div> +<div class="line"><a id="l00327" name="l00327"></a><span class="lineno"> 327</span><span class="comment"> * parameter 45 18.6 %</span></div> +<div class="line"><a id="l00328" name="l00328"></a><span class="lineno"> 328</span><span class="comment"> * value 23 9.5 %</span></div> +<div class="line"><a id="l00329" name="l00329"></a><span class="lineno"> 329</span><span class="comment"> * reference 22 9.1 %</span></div> +<div class="line"><a id="l00330" name="l00330"></a><span class="lineno"> 330</span><span class="comment"> * function result 6 2.5 %</span></div> +<div class="line"><a id="l00331" name="l00331"></a><span class="lineno"> 331</span><span class="comment"> * constant 55 22.7 %</span></div> +<div class="line"><a id="l00332" name="l00332"></a><span class="lineno"> 332</span><span class="comment"> * --- -------</span></div> +<div class="line"><a id="l00333" name="l00333"></a><span class="lineno"> 333</span><span class="comment"> * 242 100.0 %</span></div> +<div class="line"><a id="l00334" name="l00334"></a><span class="lineno"> 334</span><span class="comment"> *</span></div> +<div class="line"><a id="l00335" name="l00335"></a><span class="lineno"> 335</span><span class="comment"> *</span></div> +<div class="line"><a id="l00336" name="l00336"></a><span class="lineno"> 336</span><span class="comment"> * The program does not compute anything meaningful, but it is syntactically</span></div> +<div class="line"><a id="l00337" name="l00337"></a><span class="lineno"> 337</span><span class="comment"> * and semantically correct. All variables have a value assigned to them</span></div> +<div class="line"><a id="l00338" name="l00338"></a><span class="lineno"> 338</span><span class="comment"> * before they are used as a source operand.</span></div> +<div class="line"><a id="l00339" name="l00339"></a><span class="lineno"> 339</span><span class="comment"> *</span></div> +<div class="line"><a id="l00340" name="l00340"></a><span class="lineno"> 340</span><span class="comment"> * There has been no explicit effort to account for the effects of a</span></div> +<div class="line"><a id="l00341" name="l00341"></a><span class="lineno"> 341</span><span class="comment"> * cache, or to balance the use of long or short displacements for code or</span></div> +<div class="line"><a id="l00342" name="l00342"></a><span class="lineno"> 342</span><span class="comment"> * data.</span></div> +<div class="line"><a id="l00343" name="l00343"></a><span class="lineno"> 343</span><span class="comment"> *</span></div> +<div class="line"><a id="l00344" name="l00344"></a><span class="lineno"> 344</span><span class="comment"> ***************************************************************************</span></div> +<div class="line"><a id="l00345" name="l00345"></a><span class="lineno"> 345</span><span class="comment"> */</span></div> +<div class="line"><a id="l00346" name="l00346"></a><span class="lineno"> 346</span> </div> +<div class="line"><a id="l00347" name="l00347"></a><span class="lineno"> 347</span><span class="preprocessor">#ifndef dhrystone_h</span></div> +<div class="line"><a id="l00348" name="l00348"></a><span class="lineno"> 348</span><span class="preprocessor">#define dhrystone_h</span></div> +<div class="line"><a id="l00349" name="l00349"></a><span class="lineno"> 349</span> </div> +<div class="line"><a id="l00350" name="l00350"></a><span class="lineno"> 350</span><span class="comment">/* Compiler and system dependent definitions: */</span></div> +<div class="line"><a id="l00351" name="l00351"></a><span class="lineno"> 351</span> </div> +<div class="line"><a id="l00352" name="l00352"></a><span class="lineno"> 352</span><span class="preprocessor">#ifndef TIME</span></div> +<div class="line"><a id="l00353" name="l00353"></a><span class="lineno"> 353</span><span class="preprocessor">#undef TIMES</span></div> +<div class="line"><a id="l00354" name="l00354"></a><span class="lineno"> 354</span><span class="preprocessor">#define TIMES</span></div> +<div class="line"><a id="l00355" name="l00355"></a><span class="lineno"> 355</span><span class="preprocessor">#endif</span></div> +<div class="line"><a id="l00356" name="l00356"></a><span class="lineno"> 356</span> <span class="comment">/* Use times(2) time function unless */</span></div> +<div class="line"><a id="l00357" name="l00357"></a><span class="lineno"> 357</span> <span class="comment">/* explicitly defined otherwise */</span></div> +<div class="line"><a id="l00358" name="l00358"></a><span class="lineno"> 358</span> </div> +<div class="line"><a id="l00359" name="l00359"></a><span class="lineno"> 359</span><span class="comment">//#ifdef MSC_CLOCK</span></div> +<div class="line"><a id="l00360" name="l00360"></a><span class="lineno"> 360</span><span class="comment">//#undef HZ</span></div> +<div class="line"><a id="l00361" name="l00361"></a><span class="lineno"> 361</span><span class="comment">//#undef TIMES</span></div> +<div class="line"><a id="l00362" name="l00362"></a><span class="lineno"> 362</span><span class="comment">//#include &lt;time.h&gt;</span></div> +<div class="line"><a id="l00363" name="l00363"></a><span class="lineno"> 363</span><span class="comment">//#define HZ CLK_TCK</span></div> +<div class="line"><a id="l00364" name="l00364"></a><span class="lineno"> 364</span><span class="comment">//#endif</span></div> +<div class="line"><a id="l00365" name="l00365"></a><span class="lineno"> 365</span><span class="comment">// /* Use Microsoft C hi-res clock */</span></div> +<div class="line"><a id="l00366" name="l00366"></a><span class="lineno"> 366</span> </div> +<div class="line"><a id="l00367" name="l00367"></a><span class="lineno"> 367</span><span class="preprocessor">#define HZ SYSINFO_CLK</span></div> +<div class="line"><a id="l00368" name="l00368"></a><span class="lineno"> 368</span> </div> +<div class="line"><a id="l00369" name="l00369"></a><span class="lineno"> 369</span><span class="preprocessor">#ifdef TIMES</span></div> +<div class="line"><a id="l00370" name="l00370"></a><span class="lineno"> 370</span><span class="preprocessor">#include &lt;sys/types.h&gt;</span></div> +<div class="line"><a id="l00371" name="l00371"></a><span class="lineno"> 371</span><span class="preprocessor">#include &lt;sys/times.h&gt;</span></div> +<div class="line"><a id="l00372" name="l00372"></a><span class="lineno"> 372</span> <span class="comment">/* for &quot;times&quot; */</span></div> +<div class="line"><a id="l00373" name="l00373"></a><span class="lineno"> 373</span><span class="preprocessor">#endif</span></div> +<div class="line"><a id="l00374" name="l00374"></a><span class="lineno"> 374</span> </div> +<div class="line"><a id="l00375" name="l00375"></a><span class="lineno"> 375</span><span class="preprocessor">#define Mic_secs_Per_Second 1000000</span></div> +<div class="line"><a id="l00376" name="l00376"></a><span class="lineno"> 376</span> <span class="comment">/* Berkeley UNIX C returns process times in seconds/HZ */</span></div> +<div class="line"><a id="l00377" name="l00377"></a><span class="lineno"> 377</span> </div> +<div class="line"><a id="l00378" name="l00378"></a><span class="lineno"> 378</span><span class="preprocessor">#ifdef NOSTRUCTASSIGN</span></div> +<div class="line"><a id="l00379" name="l00379"></a><span class="lineno"> 379</span><span class="preprocessor">#define structassign(d, s) memcpy(&amp;(d), &amp;(s), sizeof(d))</span></div> +<div class="line"><a id="l00380" name="l00380"></a><span class="lineno"> 380</span><span class="preprocessor">#else</span></div> +<div class="line"><a id="l00381" name="l00381"></a><span class="lineno"> 381</span><span class="preprocessor">#define structassign(d, s) d = s</span></div> +<div class="line"><a id="l00382" name="l00382"></a><span class="lineno"> 382</span><span class="preprocessor">#endif</span></div> +<div class="line"><a id="l00383" name="l00383"></a><span class="lineno"> 383</span> </div> +<div class="line"><a id="l00384" name="l00384"></a><span class="lineno"> 384</span><span class="preprocessor">#ifdef NOENUM</span></div> +<div class="line"><a id="l00385" name="l00385"></a><span class="lineno"> 385</span><span class="preprocessor">#define Ident_1 0</span></div> +<div class="line"><a id="l00386" name="l00386"></a><span class="lineno"> 386</span><span class="preprocessor">#define Ident_2 1</span></div> +<div class="line"><a id="l00387" name="l00387"></a><span class="lineno"> 387</span><span class="preprocessor">#define Ident_3 2</span></div> +<div class="line"><a id="l00388" name="l00388"></a><span class="lineno"> 388</span><span class="preprocessor">#define Ident_4 3</span></div> +<div class="line"><a id="l00389" name="l00389"></a><span class="lineno"> 389</span><span class="preprocessor">#define Ident_5 4</span></div> +<div class="line"><a id="l00390" name="l00390"></a><span class="lineno"> 390</span> <span class="keyword">typedef</span> <span class="keywordtype">int</span> Enumeration;</div> +<div class="line"><a id="l00391" name="l00391"></a><span class="lineno"> 391</span><span class="preprocessor">#else</span></div> +<div class="line"><a id="l00392" name="l00392"></a><span class="lineno"> 392</span> <span class="keyword">typedef</span> <span class="keyword">enum</span> {Ident_1, Ident_2, Ident_3, Ident_4, Ident_5}</div> +<div class="line"><a id="l00393" name="l00393"></a><span class="lineno"> 393</span> Enumeration;</div> +<div class="line"><a id="l00394" name="l00394"></a><span class="lineno"> 394</span><span class="preprocessor">#endif</span></div> +<div class="line"><a id="l00395" name="l00395"></a><span class="lineno"> 395</span> <span class="comment">/* for boolean and enumeration types in Ada, Pascal */</span></div> +<div class="line"><a id="l00396" name="l00396"></a><span class="lineno"> 396</span> </div> +<div class="line"><a id="l00397" name="l00397"></a><span class="lineno"> 397</span><span class="comment">/* General definitions: */</span></div> +<div class="line"><a id="l00398" name="l00398"></a><span class="lineno"> 398</span> </div> +<div class="line"><a id="l00399" name="l00399"></a><span class="lineno"> 399</span><span class="preprocessor">#include &lt;stdio.h&gt;</span></div> +<div class="line"><a id="l00400" name="l00400"></a><span class="lineno"> 400</span> <span class="comment">/* for strcpy, strcmp */</span></div> +<div class="line"><a id="l00401" name="l00401"></a><span class="lineno"> 401</span> </div> +<div class="line"><a id="l00402" name="l00402"></a><span class="lineno"> 402</span><span class="preprocessor">#define Null 0</span></div> +<div class="line"><a id="l00403" name="l00403"></a><span class="lineno"> 403</span> <span class="comment">/* Value of a Null pointer */</span></div> +<div class="line"><a id="l00404" name="l00404"></a><span class="lineno"> 404</span><span class="preprocessor">#define true 1</span></div> +<div class="line"><a id="l00405" name="l00405"></a><span class="lineno"> 405</span><span class="preprocessor">#define false 0</span></div> +<div class="line"><a id="l00406" name="l00406"></a><span class="lineno"> 406</span> </div> +<div class="line"><a id="l00407" name="l00407"></a><span class="lineno"> 407</span><span class="keyword">typedef</span> <span class="keywordtype">int</span> One_Thirty;</div> +<div class="line"><a id="l00408" name="l00408"></a><span class="lineno"> 408</span><span class="keyword">typedef</span> <span class="keywordtype">int</span> One_Fifty;</div> +<div class="line"><a id="l00409" name="l00409"></a><span class="lineno"> 409</span><span class="keyword">typedef</span> <span class="keywordtype">char</span> Capital_Letter;</div> +<div class="line"><a id="l00410" name="l00410"></a><span class="lineno"> 410</span><span class="keyword">typedef</span> <span class="keywordtype">int</span> Boolean;</div> +<div class="line"><a id="l00411" name="l00411"></a><span class="lineno"> 411</span><span class="keyword">typedef</span> <span class="keywordtype">char</span> Str_30 [31];</div> +<div class="line"><a id="l00412" name="l00412"></a><span class="lineno"> 412</span><span class="keyword">typedef</span> <span class="keywordtype">int</span> Arr_1_Dim [50];</div> +<div class="line"><a id="l00413" name="l00413"></a><span class="lineno"> 413</span><span class="keyword">typedef</span> <span class="keywordtype">int</span> Arr_2_Dim [50] [50];</div> +<div class="line"><a id="l00414" name="l00414"></a><span class="lineno"> 414</span> </div> +<div class="foldopen" id="foldopen00415" data-start="{" data-end="};"> +<div class="line"><a id="l00415" name="l00415"></a><span class="lineno"><a class="line" href="structrecord.html"> 415</a></span><span class="keyword">typedef</span> <span class="keyword">struct </span><a class="code hl_struct" href="structrecord.html">record</a></div> +<div class="line"><a id="l00416" name="l00416"></a><span class="lineno"> 416</span> {</div> +<div class="line"><a id="l00417" name="l00417"></a><span class="lineno"> 417</span> <span class="keyword">struct </span><a class="code hl_struct" href="structrecord.html">record</a> *Ptr_Comp;</div> +<div class="line"><a id="l00418" name="l00418"></a><span class="lineno"> 418</span> Enumeration Discr;</div> +<div class="line"><a id="l00419" name="l00419"></a><span class="lineno"> 419</span> <span class="keyword">union </span>{</div> +<div class="line"><a id="l00420" name="l00420"></a><span class="lineno"> 420</span> <span class="keyword">struct </span>{</div> +<div class="line"><a id="l00421" name="l00421"></a><span class="lineno"> 421</span> Enumeration Enum_Comp;</div> +<div class="line"><a id="l00422" name="l00422"></a><span class="lineno"> 422</span> <span class="keywordtype">int</span> Int_Comp;</div> +<div class="line"><a id="l00423" name="l00423"></a><span class="lineno"> 423</span> <span class="keywordtype">char</span> Str_Comp [31];</div> +<div class="line"><a id="l00424" name="l00424"></a><span class="lineno"> 424</span> } var_1;</div> +<div class="line"><a id="l00425" name="l00425"></a><span class="lineno"> 425</span> <span class="keyword">struct </span>{</div> +<div class="line"><a id="l00426" name="l00426"></a><span class="lineno"> 426</span> Enumeration E_Comp_2;</div> +<div class="line"><a id="l00427" name="l00427"></a><span class="lineno"> 427</span> <span class="keywordtype">char</span> Str_2_Comp [31];</div> +<div class="line"><a id="l00428" name="l00428"></a><span class="lineno"> 428</span> } var_2;</div> +<div class="line"><a id="l00429" name="l00429"></a><span class="lineno"> 429</span> <span class="keyword">struct </span>{</div> +<div class="line"><a id="l00430" name="l00430"></a><span class="lineno"> 430</span> <span class="keywordtype">char</span> Ch_1_Comp;</div> +<div class="line"><a id="l00431" name="l00431"></a><span class="lineno"> 431</span> <span class="keywordtype">char</span> Ch_2_Comp;</div> +<div class="line"><a id="l00432" name="l00432"></a><span class="lineno"> 432</span> } var_3;</div> +<div class="line"><a id="l00433" name="l00433"></a><span class="lineno"> 433</span> } variant;</div> +<div class="line"><a id="l00434" name="l00434"></a><span class="lineno"> 434</span> } <a class="code hl_struct" href="structrecord.html">Rec_Type</a>, *<a class="code hl_struct" href="structrecord.html">Rec_Pointer</a>;</div> +</div> +<div class="line"><a id="l00435" name="l00435"></a><span class="lineno"> 435</span> </div> +<div class="line"><a id="l00436" name="l00436"></a><span class="lineno"> 436</span> </div> +<div class="line"><a id="l00437" name="l00437"></a><span class="lineno"> 437</span><span class="comment">// function prototypes</span></div> +<div class="line"><a id="l00438" name="l00438"></a><span class="lineno"> 438</span>Enumeration Func_1 (Ch_1_Par_Val, Ch_2_Par_Val);</div> +<div class="line"><a id="l00439" name="l00439"></a><span class="lineno"> 439</span>Boolean Func_2 (Str_1_Par_Ref, Str_2_Par_Ref);</div> +<div class="line"><a id="l00440" name="l00440"></a><span class="lineno"> 440</span>Boolean Func_3 (Enum_Par_Val);</div> +<div class="line"><a id="l00441" name="l00441"></a><span class="lineno"> 441</span><span class="keywordtype">void</span> Proc_1 (Ptr_Val_Par);</div> +<div class="line"><a id="l00442" name="l00442"></a><span class="lineno"> 442</span><span class="keywordtype">void</span> Proc_2 (Int_Par_Ref);</div> +<div class="line"><a id="l00443" name="l00443"></a><span class="lineno"> 443</span><span class="keywordtype">void</span> Proc_3 (Ptr_Ref_Par);</div> +<div class="line"><a id="l00444" name="l00444"></a><span class="lineno"> 444</span><span class="keywordtype">void</span> Proc_4 (<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00445" name="l00445"></a><span class="lineno"> 445</span><span class="keywordtype">void</span> Proc_5 (<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00446" name="l00446"></a><span class="lineno"> 446</span><span class="keywordtype">void</span> Proc_6 (Enum_Val_Par, Enum_Ref_Par);</div> +<div class="line"><a id="l00447" name="l00447"></a><span class="lineno"> 447</span><span class="keywordtype">void</span> Proc_7 (Int_1_Par_Val, Int_2_Par_Val, Int_Par_Ref);</div> +<div class="line"><a id="l00448" name="l00448"></a><span class="lineno"> 448</span><span class="keywordtype">void</span> Proc_8 (Arr_1_Par_Ref, Arr_2_Par_Ref, Int_1_Par_Val, Int_2_Par_Val);</div> +<div class="line"><a id="l00449" name="l00449"></a><span class="lineno"> 449</span><span class="keywordtype">int</span> strcmp(<span class="keyword">const</span> <span class="keywordtype">char</span> *p1, <span class="keyword">const</span> <span class="keywordtype">char</span> *p2);</div> +<div class="line"><a id="l00450" name="l00450"></a><span class="lineno"> 450</span> </div> +<div class="line"><a id="l00451" name="l00451"></a><span class="lineno"> 451</span><span class="preprocessor">#endif </span><span class="comment">// dhrystone_h</span></div> +<div class="ttc" id="astructrecord_html"><div class="ttname"><a href="structrecord.html">record</a></div><div class="ttdef"><b>Definition</b> dhry.h:416</div></div> +</div><!-- fragment --></div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/dir_01cde3d98944a579dc3b5e43a5311a79.html b/sw/dir_01cde3d98944a579dc3b5e43a5311a79.html new file mode 100644 index 0000000000..5d2df6a673 --- /dev/null +++ b/sw/dir_01cde3d98944a579dc3b5e43a5311a79.html @@ -0,0 +1,110 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/example/demo_cfs Directory Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_f0f9b27afba2e8cc2da6e5fddcc1a8c9.html">example</a></li><li class="navelem"><a class="el" href="dir_01cde3d98944a579dc3b5e43a5311a79.html">demo_cfs</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="headertitle"><div class="title">demo_cfs Directory Reference</div></div> +</div><!--header--> +<div class="contents"> +<table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="files" name="files"></a> +Files</h2></td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><span class="icondoc"></span>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="demo__cfs_2main_8c.html">main.c</a></td></tr> +<tr class="memdesc:demo__cfs_2main_8c"><td class="mdescLeft">&#160;</td><td class="mdescRight">Simple demo program for the <em>default</em> custom functions subsystem (CFS) module. <br /></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/dir_01fcd3835fb4e7d9331b722d86291b65.html b/sw/dir_01fcd3835fb4e7d9331b722d86291b65.html new file mode 100644 index 0000000000..1a28ecd087 --- /dev/null +++ b/sw/dir_01fcd3835fb4e7d9331b722d86291b65.html @@ -0,0 +1,109 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw Directory Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="headertitle"><div class="title">sw Directory Reference</div></div> +</div><!--header--> +<div class="contents"> +<table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="subdirs" name="subdirs"></a> +Directories</h2></td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><span class="iconfclosed"></span>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="dir_4316bb0e553b51b8b65560981547ce0f.html">bootloader</a></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/dir_09a89dfa1596b6613cf2c29528a32844.html b/sw/dir_09a89dfa1596b6613cf2c29528a32844.html new file mode 100644 index 0000000000..6d18d9a268 --- /dev/null +++ b/sw/dir_09a89dfa1596b6613cf2c29528a32844.html @@ -0,0 +1,110 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/example/demo_cfu Directory Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_f0f9b27afba2e8cc2da6e5fddcc1a8c9.html">example</a></li><li class="navelem"><a class="el" href="dir_09a89dfa1596b6613cf2c29528a32844.html">demo_cfu</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="headertitle"><div class="title">demo_cfu Directory Reference</div></div> +</div><!--header--> +<div class="contents"> +<table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="files" name="files"></a> +Files</h2></td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><span class="icondoc"></span>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="demo__cfu_2main_8c.html">main.c</a></td></tr> +<tr class="memdesc:demo__cfu_2main_8c"><td class="mdescLeft">&#160;</td><td class="mdescRight">Example program showing how to use the CFU's custom instructions (XTEA example). <br /></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/dir_0c6ac14e2254a316d41123f98feeb67b.html b/sw/dir_0c6ac14e2254a316d41123f98feeb67b.html new file mode 100644 index 0000000000..b027c5cd1c --- /dev/null +++ b/sw/dir_0c6ac14e2254a316d41123f98feeb67b.html @@ -0,0 +1,176 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/lib/source Directory Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_7d04193005ada6f9450f847f4adb6b5b.html">lib</a></li><li class="navelem"><a class="el" href="dir_0c6ac14e2254a316d41123f98feeb67b.html">source</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="headertitle"><div class="title">source Directory Reference</div></div> +</div><!--header--> +<div class="contents"> +<table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="files" name="files"></a> +Files</h2></td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><span class="icondoc"></span>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="neorv32__aux_8c.html">neorv32_aux.c</a></td></tr> +<tr class="memdesc:neorv32__aux_8c"><td class="mdescLeft">&#160;</td><td class="mdescRight">General auxiliary functions source file. <br /></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><span class="icondoc"></span>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="neorv32__cfs_8c.html">neorv32_cfs.c</a></td></tr> +<tr class="memdesc:neorv32__cfs_8c"><td class="mdescLeft">&#160;</td><td class="mdescRight">Custom Functions Subsystem (CFS) HW driver source file. <br /></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><span class="icondoc"></span>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="neorv32__cpu_8c.html">neorv32_cpu.c</a></td></tr> +<tr class="memdesc:neorv32__cpu_8c"><td class="mdescLeft">&#160;</td><td class="mdescRight">CPU Core Functions HW driver source file. <br /></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><span class="icondoc"></span>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="neorv32__cpu__amo_8c.html">neorv32_cpu_amo.c</a></td></tr> +<tr class="memdesc:neorv32__cpu__amo_8c"><td class="mdescLeft">&#160;</td><td class="mdescRight">Atomic memory access (read-modify-write) emulation functions using LR/SC pairs - source file. <br /></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><span class="icondoc"></span>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="neorv32__cpu__cfu_8c.html">neorv32_cpu_cfu.c</a></td></tr> +<tr class="memdesc:neorv32__cpu__cfu_8c"><td class="mdescLeft">&#160;</td><td class="mdescRight">CPU Core custom functions unit HW driver source file. <br /></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><span class="icondoc"></span>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="neorv32__crc_8c.html">neorv32_crc.c</a></td></tr> +<tr class="memdesc:neorv32__crc_8c"><td class="mdescLeft">&#160;</td><td class="mdescRight">Cyclic redundancy check unit (CRC) HW driver source file. <br /></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><span class="icondoc"></span>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="neorv32__gpio_8c.html">neorv32_gpio.c</a></td></tr> +<tr class="memdesc:neorv32__gpio_8c"><td class="mdescLeft">&#160;</td><td class="mdescRight">General purpose input/output port unit (GPIO) HW driver source file. <br /></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><span class="icondoc"></span>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="neorv32__gptmr_8c.html">neorv32_gptmr.c</a></td></tr> +<tr class="memdesc:neorv32__gptmr_8c"><td class="mdescLeft">&#160;</td><td class="mdescRight">General purpose timer (GPTMR) HW driver source file. <br /></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><span class="icondoc"></span>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="neorv32__mtime_8c.html">neorv32_mtime.c</a></td></tr> +<tr class="memdesc:neorv32__mtime_8c"><td class="mdescLeft">&#160;</td><td class="mdescRight">Machine System Timer (MTIME) HW driver source file. <br /></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><span class="icondoc"></span>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="neorv32__neoled_8c.html">neorv32_neoled.c</a></td></tr> +<tr class="memdesc:neorv32__neoled_8c"><td class="mdescLeft">&#160;</td><td class="mdescRight">Smart LED Interface (NEOLED) HW driver source file. <br /></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><span class="icondoc"></span>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="neorv32__onewire_8c.html">neorv32_onewire.c</a></td></tr> +<tr class="memdesc:neorv32__onewire_8c"><td class="mdescLeft">&#160;</td><td class="mdescRight">1-Wire Interface Controller (ONEWIRE) HW driver source file. <br /></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><span class="icondoc"></span>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="neorv32__pwm_8c.html">neorv32_pwm.c</a></td></tr> +<tr class="memdesc:neorv32__pwm_8c"><td class="mdescLeft">&#160;</td><td class="mdescRight">Pulse-Width Modulation Controller (PWM) HW driver source file. <br /></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><span class="icondoc"></span>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="neorv32__rte_8c.html">neorv32_rte.c</a></td></tr> +<tr class="memdesc:neorv32__rte_8c"><td class="mdescLeft">&#160;</td><td class="mdescRight">NEORV32 Runtime Environment. <br /></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><span class="icondoc"></span>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="neorv32__sdi_8c.html">neorv32_sdi.c</a></td></tr> +<tr class="memdesc:neorv32__sdi_8c"><td class="mdescLeft">&#160;</td><td class="mdescRight">Serial data interface controller (SDI) HW driver source file. <br /></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><span class="icondoc"></span>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="neorv32__slink_8c.html">neorv32_slink.c</a></td></tr> +<tr class="memdesc:neorv32__slink_8c"><td class="mdescLeft">&#160;</td><td class="mdescRight">Stream Link Interface HW driver source file. <br /></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><span class="icondoc"></span>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="neorv32__spi_8c.html">neorv32_spi.c</a></td></tr> +<tr class="memdesc:neorv32__spi_8c"><td class="mdescLeft">&#160;</td><td class="mdescRight">Serial peripheral interface controller (SPI) HW driver source file. <br /></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><span class="icondoc"></span>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="neorv32__trng_8c.html">neorv32_trng.c</a></td></tr> +<tr class="memdesc:neorv32__trng_8c"><td class="mdescLeft">&#160;</td><td class="mdescRight">True Random Number Generator (TRNG) HW driver source file. <br /></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><span class="icondoc"></span>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="neorv32__twi_8c.html">neorv32_twi.c</a></td></tr> +<tr class="memdesc:neorv32__twi_8c"><td class="mdescLeft">&#160;</td><td class="mdescRight">Two-Wire Interface Controller (TWI) HW driver source file. <br /></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><span class="icondoc"></span>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="neorv32__uart_8c.html">neorv32_uart.c</a></td></tr> +<tr class="memdesc:neorv32__uart_8c"><td class="mdescLeft">&#160;</td><td class="mdescRight">Universal asynchronous receiver/transmitter (UART0/UART1) HW driver source file. <br /></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><span class="icondoc"></span>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="neorv32__wdt_8c.html">neorv32_wdt.c</a></td></tr> +<tr class="memdesc:neorv32__wdt_8c"><td class="mdescLeft">&#160;</td><td class="mdescRight">Direct Memory Access Controller (DMA) HW driver source file. <br /></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><span class="icondoc"></span>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="neorv32__xip_8c.html">neorv32_xip.c</a></td></tr> +<tr class="memdesc:neorv32__xip_8c"><td class="mdescLeft">&#160;</td><td class="mdescRight">Execute in place module (XIP) HW driver source file. <br /></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><span class="icondoc"></span>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="neorv32__xirq_8c.html">neorv32_xirq.c</a></td></tr> +<tr class="memdesc:neorv32__xirq_8c"><td class="mdescLeft">&#160;</td><td class="mdescRight">External Interrupt controller HW driver source file. <br /></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><span class="icondoc"></span>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="syscalls_8c.html">syscalls.c</a></td></tr> +<tr class="memdesc:syscalls_8c"><td class="mdescLeft">&#160;</td><td class="mdescRight">Newlib system calls. <br /></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/dir_0d2921e55a1172a4726516961ee96ab5.html b/sw/dir_0d2921e55a1172a4726516961ee96ab5.html new file mode 100644 index 0000000000..09a20bb469 --- /dev/null +++ b/sw/dir_0d2921e55a1172a4726516961ee96ab5.html @@ -0,0 +1,110 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/example/bus_explorer Directory Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_f0f9b27afba2e8cc2da6e5fddcc1a8c9.html">example</a></li><li class="navelem"><a class="el" href="dir_0d2921e55a1172a4726516961ee96ab5.html">bus_explorer</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="headertitle"><div class="title">bus_explorer Directory Reference</div></div> +</div><!--header--> +<div class="contents"> +<table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="files" name="files"></a> +Files</h2></td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><span class="icondoc"></span>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="bus__explorer_2main_8c.html">main.c</a></td></tr> +<tr class="memdesc:bus__explorer_2main_8c"><td class="mdescLeft">&#160;</td><td class="mdescRight">Interactive memory inspector. <br /></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/dir_0f35fd52d2216117815d19d974239550.html b/sw/dir_0f35fd52d2216117815d19d974239550.html new file mode 100644 index 0000000000..df8c99c4bf --- /dev/null +++ b/sw/dir_0f35fd52d2216117815d19d974239550.html @@ -0,0 +1,113 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/example/performance_tests Directory Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_f0f9b27afba2e8cc2da6e5fddcc1a8c9.html">example</a></li><li class="navelem"><a class="el" href="dir_0f35fd52d2216117815d19d974239550.html">performance_tests</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="headertitle"><div class="title">performance_tests Directory Reference</div></div> +</div><!--header--> +<div class="contents"> +<table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="subdirs" name="subdirs"></a> +Directories</h2></td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><span class="iconfclosed"></span>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="dir_f05036e2ccd24a7119a5bbccebab20b2.html">I</a></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><span class="iconfclosed"></span>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="dir_6a888d76b0f727dc821f77838927e542.html">M</a></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><span class="iconfclosed"></span>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="dir_4bd1267d34feeec0f679c16f884588e7.html">Zfinx</a></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/dir_23212395b5ee0866d2fdd629e0ddeae8.html b/sw/dir_23212395b5ee0866d2fdd629e0ddeae8.html new file mode 100644 index 0000000000..df2d9d098b --- /dev/null +++ b/sw/dir_23212395b5ee0866d2fdd629e0ddeae8.html @@ -0,0 +1,112 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/example/float_corner_test Directory Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_f0f9b27afba2e8cc2da6e5fddcc1a8c9.html">example</a></li><li class="navelem"><a class="el" href="dir_23212395b5ee0866d2fdd629e0ddeae8.html">float_corner_test</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="headertitle"><div class="title">float_corner_test Directory Reference</div></div> +</div><!--header--> +<div class="contents"> +<table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="files" name="files"></a> +Files</h2></td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><span class="icondoc"></span>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="float__corner__test_2main_8c.html">main.c</a></td></tr> +<tr class="memdesc:float__corner__test_2main_8c"><td class="mdescLeft">&#160;</td><td class="mdescRight">Verification program for the NEORV32 'Zfinx' extension (floating-point in x registers) using pseudo-random data as input; compares results from hardware against pure-sw reference functions. <br /></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><a href="float__corner__test_2neorv32__zfinx__extension__intrinsics_8h_source.html"><span class="icondoc"></span></a>&#160;</td><td class="memItemRight" valign="bottom"><b>neorv32_zfinx_extension_intrinsics.h</b></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/dir_23717ebbabf7a51c0558262947e0fe3b.html b/sw/dir_23717ebbabf7a51c0558262947e0fe3b.html new file mode 100644 index 0000000000..a952412ff4 --- /dev/null +++ b/sw/dir_23717ebbabf7a51c0558262947e0fe3b.html @@ -0,0 +1,110 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/example/demo_newlib Directory Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_f0f9b27afba2e8cc2da6e5fddcc1a8c9.html">example</a></li><li class="navelem"><a class="el" href="dir_23717ebbabf7a51c0558262947e0fe3b.html">demo_newlib</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="headertitle"><div class="title">demo_newlib Directory Reference</div></div> +</div><!--header--> +<div class="contents"> +<table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="files" name="files"></a> +Files</h2></td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><span class="icondoc"></span>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="demo__newlib_2main_8c.html">main.c</a></td></tr> +<tr class="memdesc:demo__newlib_2main_8c"><td class="mdescLeft">&#160;</td><td class="mdescRight">Demo/test program for NEORV32's newlib C standard library support. <br /></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/dir_237db5b95db643499d4c20f0bc5f6a7d.html b/sw/dir_237db5b95db643499d4c20f0bc5f6a7d.html new file mode 100644 index 0000000000..65ad820793 --- /dev/null +++ b/sw/dir_237db5b95db643499d4c20f0bc5f6a7d.html @@ -0,0 +1,110 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/example/demo_trng Directory Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_f0f9b27afba2e8cc2da6e5fddcc1a8c9.html">example</a></li><li class="navelem"><a class="el" href="dir_237db5b95db643499d4c20f0bc5f6a7d.html">demo_trng</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="headertitle"><div class="title">demo_trng Directory Reference</div></div> +</div><!--header--> +<div class="contents"> +<table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="files" name="files"></a> +Files</h2></td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><span class="icondoc"></span>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="demo__trng_2main_8c.html">main.c</a></td></tr> +<tr class="memdesc:demo__trng_2main_8c"><td class="mdescLeft">&#160;</td><td class="mdescRight">True random number generator demo program. <br /></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/dir_2ba96d3140b089dada6fb9f817b7975f.html b/sw/dir_2ba96d3140b089dada6fb9f817b7975f.html new file mode 100644 index 0000000000..bb5336fc67 --- /dev/null +++ b/sw/dir_2ba96d3140b089dada6fb9f817b7975f.html @@ -0,0 +1,110 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/example/demo_emulate_unaligned Directory Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_f0f9b27afba2e8cc2da6e5fddcc1a8c9.html">example</a></li><li class="navelem"><a class="el" href="dir_2ba96d3140b089dada6fb9f817b7975f.html">demo_emulate_unaligned</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="headertitle"><div class="title">demo_emulate_unaligned Directory Reference</div></div> +</div><!--header--> +<div class="contents"> +<table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="files" name="files"></a> +Files</h2></td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><span class="icondoc"></span>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="demo__emulate__unaligned_2main_8c.html">main.c</a></td></tr> +<tr class="memdesc:demo__emulate__unaligned_2main_8c"><td class="mdescLeft">&#160;</td><td class="mdescRight">Demo program for emulating unaligned memory accesses using the NEORV32 run-time environment (RTE). <br /></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/dir_3b3bafc48b460f797485cc75b94aa81c.html b/sw/dir_3b3bafc48b460f797485cc75b94aa81c.html new file mode 100644 index 0000000000..2cae6d1e14 --- /dev/null +++ b/sw/dir_3b3bafc48b460f797485cc75b94aa81c.html @@ -0,0 +1,112 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/example/demo_onewire Directory Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_f0f9b27afba2e8cc2da6e5fddcc1a8c9.html">example</a></li><li class="navelem"><a class="el" href="dir_3b3bafc48b460f797485cc75b94aa81c.html">demo_onewire</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="headertitle"><div class="title">demo_onewire Directory Reference</div></div> +</div><!--header--> +<div class="contents"> +<table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="files" name="files"></a> +Files</h2></td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><span class="icondoc"></span>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="demo__onewire_2main_8c.html">main.c</a></td></tr> +<tr class="memdesc:demo__onewire_2main_8c"><td class="mdescLeft">&#160;</td><td class="mdescRight">Demo program for the NEORV32 1-Wire interface controller (ONEWIRE). <br /></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><a href="onewire__aux_8h_source.html"><span class="icondoc"></span></a>&#160;</td><td class="memItemRight" valign="bottom"><b>onewire_aux.h</b></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/dir_4316bb0e553b51b8b65560981547ce0f.html b/sw/dir_4316bb0e553b51b8b65560981547ce0f.html new file mode 100644 index 0000000000..6554562fc4 --- /dev/null +++ b/sw/dir_4316bb0e553b51b8b65560981547ce0f.html @@ -0,0 +1,110 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/bootloader Directory Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_4316bb0e553b51b8b65560981547ce0f.html">bootloader</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="headertitle"><div class="title">bootloader Directory Reference</div></div> +</div><!--header--> +<div class="contents"> +<table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="files" name="files"></a> +Files</h2></td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><span class="icondoc"></span>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="bootloader_8c.html">bootloader.c</a></td></tr> +<tr class="memdesc:bootloader_8c"><td class="mdescLeft">&#160;</td><td class="mdescRight">Default NEORV32 bootloader. <br /></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/dir_449d8ba5f8b78dc90092f20d15a2386a.html b/sw/dir_449d8ba5f8b78dc90092f20d15a2386a.html new file mode 100644 index 0000000000..48313c669b --- /dev/null +++ b/sw/dir_449d8ba5f8b78dc90092f20d15a2386a.html @@ -0,0 +1,110 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/example/atomic_test Directory Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_f0f9b27afba2e8cc2da6e5fddcc1a8c9.html">example</a></li><li class="navelem"><a class="el" href="dir_449d8ba5f8b78dc90092f20d15a2386a.html">atomic_test</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="headertitle"><div class="title">atomic_test Directory Reference</div></div> +</div><!--header--> +<div class="contents"> +<table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="files" name="files"></a> +Files</h2></td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><span class="icondoc"></span>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="atomic__test_2main_8c.html">main.c</a></td></tr> +<tr class="memdesc:atomic__test_2main_8c"><td class="mdescLeft">&#160;</td><td class="mdescRight">Test program for the NEORV32 'A' ISA extension - check the emulation of the AMO (read-modify-write) operations. <br /></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/dir_46981071cfd8ec44311b09fdcf6c06a8.html b/sw/dir_46981071cfd8ec44311b09fdcf6c06a8.html new file mode 100644 index 0000000000..0d7221f481 --- /dev/null +++ b/sw/dir_46981071cfd8ec44311b09fdcf6c06a8.html @@ -0,0 +1,110 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/example/game_of_life Directory Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_f0f9b27afba2e8cc2da6e5fddcc1a8c9.html">example</a></li><li class="navelem"><a class="el" href="dir_46981071cfd8ec44311b09fdcf6c06a8.html">game_of_life</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="headertitle"><div class="title">game_of_life Directory Reference</div></div> +</div><!--header--> +<div class="contents"> +<table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="files" name="files"></a> +Files</h2></td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><span class="icondoc"></span>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="game__of__life_2main_8c.html">main.c</a></td></tr> +<tr class="memdesc:game__of__life_2main_8c"><td class="mdescLeft">&#160;</td><td class="mdescRight">Conway's game of life in a UART terminal. <br /></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/dir_4bd1267d34feeec0f679c16f884588e7.html b/sw/dir_4bd1267d34feeec0f679c16f884588e7.html new file mode 100644 index 0000000000..e8733265d9 --- /dev/null +++ b/sw/dir_4bd1267d34feeec0f679c16f884588e7.html @@ -0,0 +1,103 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/example/performance_tests/Zfinx Directory Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_f0f9b27afba2e8cc2da6e5fddcc1a8c9.html">example</a></li><li class="navelem"><a class="el" href="dir_0f35fd52d2216117815d19d974239550.html">performance_tests</a></li><li class="navelem"><a class="el" href="dir_4bd1267d34feeec0f679c16f884588e7.html">Zfinx</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="headertitle"><div class="title">Zfinx Directory Reference</div></div> +</div><!--header--> +<div class="contents"> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/dir_4c113257314015688a865e1bb8429184.html b/sw/dir_4c113257314015688a865e1bb8429184.html new file mode 100644 index 0000000000..82d07d2cd7 --- /dev/null +++ b/sw/dir_4c113257314015688a865e1bb8429184.html @@ -0,0 +1,110 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/example/demo_spi Directory Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_f0f9b27afba2e8cc2da6e5fddcc1a8c9.html">example</a></li><li class="navelem"><a class="el" href="dir_4c113257314015688a865e1bb8429184.html">demo_spi</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="headertitle"><div class="title">demo_spi Directory Reference</div></div> +</div><!--header--> +<div class="contents"> +<table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="files" name="files"></a> +Files</h2></td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><span class="icondoc"></span>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="demo__spi_2main_8c.html">main.c</a></td></tr> +<tr class="memdesc:demo__spi_2main_8c"><td class="mdescLeft">&#160;</td><td class="mdescRight">SPI bus explorer (execute SPI transactions by hand). <br /></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/dir_5534fa9035f54ab438a41c43d6f7fc7a.html b/sw/dir_5534fa9035f54ab438a41c43d6f7fc7a.html new file mode 100644 index 0000000000..6802e437ff --- /dev/null +++ b/sw/dir_5534fa9035f54ab438a41c43d6f7fc7a.html @@ -0,0 +1,110 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/example/demo_xirq Directory Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_f0f9b27afba2e8cc2da6e5fddcc1a8c9.html">example</a></li><li class="navelem"><a class="el" href="dir_5534fa9035f54ab438a41c43d6f7fc7a.html">demo_xirq</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="headertitle"><div class="title">demo_xirq Directory Reference</div></div> +</div><!--header--> +<div class="contents"> +<table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="files" name="files"></a> +Files</h2></td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><span class="icondoc"></span>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="demo__xirq_2main_8c.html">main.c</a></td></tr> +<tr class="memdesc:demo__xirq_2main_8c"><td class="mdescLeft">&#160;</td><td class="mdescRight">External interrupt controller (XIRQ) demo program (using hardware-assisted prioritization). <br /></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/dir_6a888d76b0f727dc821f77838927e542.html b/sw/dir_6a888d76b0f727dc821f77838927e542.html new file mode 100644 index 0000000000..52f2ec38a6 --- /dev/null +++ b/sw/dir_6a888d76b0f727dc821f77838927e542.html @@ -0,0 +1,103 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/example/performance_tests/M Directory Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_f0f9b27afba2e8cc2da6e5fddcc1a8c9.html">example</a></li><li class="navelem"><a class="el" href="dir_0f35fd52d2216117815d19d974239550.html">performance_tests</a></li><li class="navelem"><a class="el" href="dir_6a888d76b0f727dc821f77838927e542.html">M</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="headertitle"><div class="title">M Directory Reference</div></div> +</div><!--header--> +<div class="contents"> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/dir_752b1e5d3973bf735fa78bf6b4727df9.html b/sw/dir_752b1e5d3973bf735fa78bf6b4727df9.html new file mode 100644 index 0000000000..9c6d66a3a2 --- /dev/null +++ b/sw/dir_752b1e5d3973bf735fa78bf6b4727df9.html @@ -0,0 +1,190 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/lib/include Directory Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_7d04193005ada6f9450f847f4adb6b5b.html">lib</a></li><li class="navelem"><a class="el" href="dir_752b1e5d3973bf735fa78bf6b4727df9.html">include</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="headertitle"><div class="title">include Directory Reference</div></div> +</div><!--header--> +<div class="contents"> +<table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="files" name="files"></a> +Files</h2></td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><a href="neorv32_8h_source.html"><span class="icondoc"></span></a>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="neorv32_8h.html">neorv32.h</a></td></tr> +<tr class="memdesc:neorv32_8h"><td class="mdescLeft">&#160;</td><td class="mdescRight">Main NEORV32 core library / driver / HAL include file. <br /></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><a href="neorv32__aux_8h_source.html"><span class="icondoc"></span></a>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="neorv32__aux_8h.html">neorv32_aux.h</a></td></tr> +<tr class="memdesc:neorv32__aux_8h"><td class="mdescLeft">&#160;</td><td class="mdescRight">General auxiliary functions header file. <br /></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><a href="neorv32__cfs_8h_source.html"><span class="icondoc"></span></a>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="neorv32__cfs_8h.html">neorv32_cfs.h</a></td></tr> +<tr class="memdesc:neorv32__cfs_8h"><td class="mdescLeft">&#160;</td><td class="mdescRight">Custom Functions Subsystem (CFS) HW driver header file. <br /></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><a href="neorv32__cpu_8h_source.html"><span class="icondoc"></span></a>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="neorv32__cpu_8h.html">neorv32_cpu.h</a></td></tr> +<tr class="memdesc:neorv32__cpu_8h"><td class="mdescLeft">&#160;</td><td class="mdescRight">CPU Core Functions HW driver header file. <br /></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><a href="neorv32__cpu__amo_8h_source.html"><span class="icondoc"></span></a>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="neorv32__cpu__amo_8h.html">neorv32_cpu_amo.h</a></td></tr> +<tr class="memdesc:neorv32__cpu__amo_8h"><td class="mdescLeft">&#160;</td><td class="mdescRight">Atomic memory access (read-modify-write) emulation functions using LR/SC pairs - header file. <br /></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><a href="neorv32__cpu__cfu_8h_source.html"><span class="icondoc"></span></a>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="neorv32__cpu__cfu_8h.html">neorv32_cpu_cfu.h</a></td></tr> +<tr class="memdesc:neorv32__cpu__cfu_8h"><td class="mdescLeft">&#160;</td><td class="mdescRight">CPU Core custom functions unit HW driver header file. <br /></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><a href="neorv32__cpu__csr_8h_source.html"><span class="icondoc"></span></a>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="neorv32__cpu__csr_8h.html">neorv32_cpu_csr.h</a></td></tr> +<tr class="memdesc:neorv32__cpu__csr_8h"><td class="mdescLeft">&#160;</td><td class="mdescRight">Control and Status Registers (CSR) definitions. <br /></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><a href="neorv32__crc_8h_source.html"><span class="icondoc"></span></a>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="neorv32__crc_8h.html">neorv32_crc.h</a></td></tr> +<tr class="memdesc:neorv32__crc_8h"><td class="mdescLeft">&#160;</td><td class="mdescRight">Cyclic redundancy check unit (CRC) HW driver header file. <br /></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><a href="neorv32__dma_8h_source.html"><span class="icondoc"></span></a>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="neorv32__dma_8h.html">neorv32_dma.h</a></td></tr> +<tr class="memdesc:neorv32__dma_8h"><td class="mdescLeft">&#160;</td><td class="mdescRight">Direct Memory Access Controller (DMA) HW driver header file. <br /></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><a href="neorv32__gpio_8h_source.html"><span class="icondoc"></span></a>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="neorv32__gpio_8h.html">neorv32_gpio.h</a></td></tr> +<tr class="memdesc:neorv32__gpio_8h"><td class="mdescLeft">&#160;</td><td class="mdescRight">General purpose input/output port unit (GPIO) HW driver header file. <br /></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><a href="neorv32__gptmr_8h_source.html"><span class="icondoc"></span></a>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="neorv32__gptmr_8h.html">neorv32_gptmr.h</a></td></tr> +<tr class="memdesc:neorv32__gptmr_8h"><td class="mdescLeft">&#160;</td><td class="mdescRight">General purpose timer (GPTMR) HW driver header file. <br /></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><a href="neorv32__intrinsics_8h_source.html"><span class="icondoc"></span></a>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="neorv32__intrinsics_8h.html">neorv32_intrinsics.h</a></td></tr> +<tr class="memdesc:neorv32__intrinsics_8h"><td class="mdescLeft">&#160;</td><td class="mdescRight">Helper functions and macros for custom "intrinsics" / instructions. <br /></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><a href="neorv32__legacy_8h_source.html"><span class="icondoc"></span></a>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="neorv32__legacy_8h.html">neorv32_legacy.h</a></td></tr> +<tr class="memdesc:neorv32__legacy_8h"><td class="mdescLeft">&#160;</td><td class="mdescRight">Legacy compatibility layer. <br /></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><a href="neorv32__mtime_8h_source.html"><span class="icondoc"></span></a>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="neorv32__mtime_8h.html">neorv32_mtime.h</a></td></tr> +<tr class="memdesc:neorv32__mtime_8h"><td class="mdescLeft">&#160;</td><td class="mdescRight">Machine System Timer (MTIME) HW driver header file. <br /></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><a href="neorv32__neoled_8h_source.html"><span class="icondoc"></span></a>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="neorv32__neoled_8h.html">neorv32_neoled.h</a></td></tr> +<tr class="memdesc:neorv32__neoled_8h"><td class="mdescLeft">&#160;</td><td class="mdescRight">Smart LED Interface (NEOLED) HW driver header file. <br /></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><a href="neorv32__onewire_8h_source.html"><span class="icondoc"></span></a>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="neorv32__onewire_8h.html">neorv32_onewire.h</a></td></tr> +<tr class="memdesc:neorv32__onewire_8h"><td class="mdescLeft">&#160;</td><td class="mdescRight">1-Wire Interface Controller (ONEWIRE) HW driver header file. <br /></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><a href="neorv32__pwm_8h_source.html"><span class="icondoc"></span></a>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="neorv32__pwm_8h.html">neorv32_pwm.h</a></td></tr> +<tr class="memdesc:neorv32__pwm_8h"><td class="mdescLeft">&#160;</td><td class="mdescRight">Pulse-Width Modulation Controller (PWM) HW driver header file. <br /></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><a href="neorv32__rte_8h_source.html"><span class="icondoc"></span></a>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="neorv32__rte_8h.html">neorv32_rte.h</a></td></tr> +<tr class="memdesc:neorv32__rte_8h"><td class="mdescLeft">&#160;</td><td class="mdescRight">NEORV32 Runtime Environment. <br /></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><a href="neorv32__sdi_8h_source.html"><span class="icondoc"></span></a>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="neorv32__sdi_8h.html">neorv32_sdi.h</a></td></tr> +<tr class="memdesc:neorv32__sdi_8h"><td class="mdescLeft">&#160;</td><td class="mdescRight">Serial data interface controller (SPPI) HW driver header file. <br /></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><a href="neorv32__slink_8h_source.html"><span class="icondoc"></span></a>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="neorv32__slink_8h.html">neorv32_slink.h</a></td></tr> +<tr class="memdesc:neorv32__slink_8h"><td class="mdescLeft">&#160;</td><td class="mdescRight">Stream Link Interface HW driver header file. <br /></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><a href="neorv32__spi_8h_source.html"><span class="icondoc"></span></a>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="neorv32__spi_8h.html">neorv32_spi.h</a></td></tr> +<tr class="memdesc:neorv32__spi_8h"><td class="mdescLeft">&#160;</td><td class="mdescRight">Serial peripheral interface controller (SPI) HW driver header file. <br /></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><a href="neorv32__sysinfo_8h_source.html"><span class="icondoc"></span></a>&#160;</td><td class="memItemRight" valign="bottom"><b>neorv32_sysinfo.h</b></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><a href="neorv32__trng_8h_source.html"><span class="icondoc"></span></a>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="neorv32__trng_8h.html">neorv32_trng.h</a></td></tr> +<tr class="memdesc:neorv32__trng_8h"><td class="mdescLeft">&#160;</td><td class="mdescRight">True Random Number Generator (TRNG) HW driver header file. <br /></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><a href="neorv32__twi_8h_source.html"><span class="icondoc"></span></a>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="neorv32__twi_8h.html">neorv32_twi.h</a></td></tr> +<tr class="memdesc:neorv32__twi_8h"><td class="mdescLeft">&#160;</td><td class="mdescRight">Two-Wire Interface Controller (TWI) HW driver header file. <br /></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><a href="neorv32__uart_8h_source.html"><span class="icondoc"></span></a>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="neorv32__uart_8h.html">neorv32_uart.h</a></td></tr> +<tr class="memdesc:neorv32__uart_8h"><td class="mdescLeft">&#160;</td><td class="mdescRight">Universal asynchronous receiver/transmitter (UART0/UART1) HW driver header file. <br /></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><a href="neorv32__wdt_8h_source.html"><span class="icondoc"></span></a>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="neorv32__wdt_8h.html">neorv32_wdt.h</a></td></tr> +<tr class="memdesc:neorv32__wdt_8h"><td class="mdescLeft">&#160;</td><td class="mdescRight">Watchdog Timer (WDT) HW driver header file. <br /></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><a href="neorv32__xip_8h_source.html"><span class="icondoc"></span></a>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="neorv32__xip_8h.html">neorv32_xip.h</a></td></tr> +<tr class="memdesc:neorv32__xip_8h"><td class="mdescLeft">&#160;</td><td class="mdescRight">Execute in place module (XIP) HW driver header file. <br /></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><a href="neorv32__xirq_8h_source.html"><span class="icondoc"></span></a>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="neorv32__xirq_8h.html">neorv32_xirq.h</a></td></tr> +<tr class="memdesc:neorv32__xirq_8h"><td class="mdescLeft">&#160;</td><td class="mdescRight">External Interrupt controller HW driver header file. <br /></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/dir_78d7bfa405ff3a31fa7539cfd8bc8262.html b/sw/dir_78d7bfa405ff3a31fa7539cfd8bc8262.html new file mode 100644 index 0000000000..3a998d58fc --- /dev/null +++ b/sw/dir_78d7bfa405ff3a31fa7539cfd8bc8262.html @@ -0,0 +1,110 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/example/demo_wdt Directory Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_f0f9b27afba2e8cc2da6e5fddcc1a8c9.html">example</a></li><li class="navelem"><a class="el" href="dir_78d7bfa405ff3a31fa7539cfd8bc8262.html">demo_wdt</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="headertitle"><div class="title">demo_wdt Directory Reference</div></div> +</div><!--header--> +<div class="contents"> +<table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="files" name="files"></a> +Files</h2></td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><span class="icondoc"></span>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="demo__wdt_2main_8c.html">main.c</a></td></tr> +<tr class="memdesc:demo__wdt_2main_8c"><td class="mdescLeft">&#160;</td><td class="mdescRight">Watchdog demo program. <br /></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/dir_7a2c74f70a4cdf2e836a07048e2f71dd.html b/sw/dir_7a2c74f70a4cdf2e836a07048e2f71dd.html new file mode 100644 index 0000000000..c1f1440dd1 --- /dev/null +++ b/sw/dir_7a2c74f70a4cdf2e836a07048e2f71dd.html @@ -0,0 +1,110 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/example/processor_check Directory Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_f0f9b27afba2e8cc2da6e5fddcc1a8c9.html">example</a></li><li class="navelem"><a class="el" href="dir_7a2c74f70a4cdf2e836a07048e2f71dd.html">processor_check</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="headertitle"><div class="title">processor_check Directory Reference</div></div> +</div><!--header--> +<div class="contents"> +<table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="files" name="files"></a> +Files</h2></td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><span class="icondoc"></span>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="processor__check_2main_8c.html">main.c</a></td></tr> +<tr class="memdesc:processor__check_2main_8c"><td class="mdescLeft">&#160;</td><td class="mdescRight">CPU/Processor test/verification program. <br /></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/dir_7d04193005ada6f9450f847f4adb6b5b.html b/sw/dir_7d04193005ada6f9450f847f4adb6b5b.html new file mode 100644 index 0000000000..2a9507455a --- /dev/null +++ b/sw/dir_7d04193005ada6f9450f847f4adb6b5b.html @@ -0,0 +1,111 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/lib Directory Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_7d04193005ada6f9450f847f4adb6b5b.html">lib</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="headertitle"><div class="title">lib Directory Reference</div></div> +</div><!--header--> +<div class="contents"> +<table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="subdirs" name="subdirs"></a> +Directories</h2></td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><span class="iconfclosed"></span>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="dir_752b1e5d3973bf735fa78bf6b4727df9.html">include</a></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><span class="iconfclosed"></span>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="dir_0c6ac14e2254a316d41123f98feeb67b.html">source</a></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/dir_8c514361e1f16692c783b23503f30f16.html b/sw/dir_8c514361e1f16692c783b23503f30f16.html new file mode 100644 index 0000000000..cb07b13c95 --- /dev/null +++ b/sw/dir_8c514361e1f16692c783b23503f30f16.html @@ -0,0 +1,110 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/example/demo_dma Directory Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_f0f9b27afba2e8cc2da6e5fddcc1a8c9.html">example</a></li><li class="navelem"><a class="el" href="dir_8c514361e1f16692c783b23503f30f16.html">demo_dma</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="headertitle"><div class="title">demo_dma Directory Reference</div></div> +</div><!--header--> +<div class="contents"> +<table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="files" name="files"></a> +Files</h2></td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><span class="icondoc"></span>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="demo__dma_2main_8c.html">main.c</a></td></tr> +<tr class="memdesc:demo__dma_2main_8c"><td class="mdescLeft">&#160;</td><td class="mdescRight">DMA demo program. <br /></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/dir_8d341cbe0581f44e1ae95d82d74e8bc8.html b/sw/dir_8d341cbe0581f44e1ae95d82d74e8bc8.html new file mode 100644 index 0000000000..19ca05c1c6 --- /dev/null +++ b/sw/dir_8d341cbe0581f44e1ae95d82d74e8bc8.html @@ -0,0 +1,110 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/example/demo_mtime Directory Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_f0f9b27afba2e8cc2da6e5fddcc1a8c9.html">example</a></li><li class="navelem"><a class="el" href="dir_8d341cbe0581f44e1ae95d82d74e8bc8.html">demo_mtime</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="headertitle"><div class="title">demo_mtime Directory Reference</div></div> +</div><!--header--> +<div class="contents"> +<table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="files" name="files"></a> +Files</h2></td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><span class="icondoc"></span>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="demo__mtime_2main_8c.html">main.c</a></td></tr> +<tr class="memdesc:demo__mtime_2main_8c"><td class="mdescLeft">&#160;</td><td class="mdescRight">Simple machine timer (MTIME) usage example. <br /></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/dir_8f848e36ac87ced1c361afcc0549ca32.html b/sw/dir_8f848e36ac87ced1c361afcc0549ca32.html new file mode 100644 index 0000000000..2f962a50a2 --- /dev/null +++ b/sw/dir_8f848e36ac87ced1c361afcc0549ca32.html @@ -0,0 +1,115 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/example/demo_spi_irq Directory Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_f0f9b27afba2e8cc2da6e5fddcc1a8c9.html">example</a></li><li class="navelem"><a class="el" href="dir_8f848e36ac87ced1c361afcc0549ca32.html">demo_spi_irq</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="headertitle"><div class="title">demo_spi_irq Directory Reference</div></div> +</div><!--header--> +<div class="contents"> +<table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="subdirs" name="subdirs"></a> +Directories</h2></td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><span class="iconfclosed"></span>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="dir_9d04cdc586d6978be343bda7adcdc371.html">drv</a></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="files" name="files"></a> +Files</h2></td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><span class="icondoc"></span>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="demo__spi__irq_2main_8c.html">main.c</a></td></tr> +<tr class="memdesc:demo__spi__irq_2main_8c"><td class="mdescLeft">&#160;</td><td class="mdescRight">Example of an ISR driven SPI transfer. <br /></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/dir_93967190e0d2e549ceca77007097849b.html b/sw/dir_93967190e0d2e549ceca77007097849b.html new file mode 100644 index 0000000000..1ce2cdd3e6 --- /dev/null +++ b/sw/dir_93967190e0d2e549ceca77007097849b.html @@ -0,0 +1,110 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/example/demo_hpm Directory Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_f0f9b27afba2e8cc2da6e5fddcc1a8c9.html">example</a></li><li class="navelem"><a class="el" href="dir_93967190e0d2e549ceca77007097849b.html">demo_hpm</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="headertitle"><div class="title">demo_hpm Directory Reference</div></div> +</div><!--header--> +<div class="contents"> +<table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="files" name="files"></a> +Files</h2></td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><span class="icondoc"></span>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="demo__hpm_2main_8c.html">main.c</a></td></tr> +<tr class="memdesc:demo__hpm_2main_8c"><td class="mdescLeft">&#160;</td><td class="mdescRight">Hardware performance monitor (HPM) example program. <br /></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/dir_9a1c128d67c35790e92af404beb936aa.html b/sw/dir_9a1c128d67c35790e92af404beb936aa.html new file mode 100644 index 0000000000..d9edba63c9 --- /dev/null +++ b/sw/dir_9a1c128d67c35790e92af404beb936aa.html @@ -0,0 +1,110 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/example/demo_blink_led Directory Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_f0f9b27afba2e8cc2da6e5fddcc1a8c9.html">example</a></li><li class="navelem"><a class="el" href="dir_9a1c128d67c35790e92af404beb936aa.html">demo_blink_led</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="headertitle"><div class="title">demo_blink_led Directory Reference</div></div> +</div><!--header--> +<div class="contents"> +<table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="files" name="files"></a> +Files</h2></td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><span class="icondoc"></span>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="demo__blink__led_2main_8c.html">main.c</a></td></tr> +<tr class="memdesc:demo__blink__led_2main_8c"><td class="mdescLeft">&#160;</td><td class="mdescRight">Minimal blinking LED demo program using the lowest 8 bits of the GPIO.output port. <br /></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/dir_9d04cdc586d6978be343bda7adcdc371.html b/sw/dir_9d04cdc586d6978be343bda7adcdc371.html new file mode 100644 index 0000000000..2f6bc33aed --- /dev/null +++ b/sw/dir_9d04cdc586d6978be343bda7adcdc371.html @@ -0,0 +1,113 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/example/demo_spi_irq/drv Directory Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_f0f9b27afba2e8cc2da6e5fddcc1a8c9.html">example</a></li><li class="navelem"><a class="el" href="dir_8f848e36ac87ced1c361afcc0549ca32.html">demo_spi_irq</a></li><li class="navelem"><a class="el" href="dir_9d04cdc586d6978be343bda7adcdc371.html">drv</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="headertitle"><div class="title">drv Directory Reference</div></div> +</div><!--header--> +<div class="contents"> +<table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="files" name="files"></a> +Files</h2></td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><span class="icondoc"></span>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="neorv32__spi__irq_8c.html">neorv32_spi_irq.c</a></td></tr> +<tr class="memdesc:neorv32__spi__irq_8c"><td class="mdescLeft">&#160;</td><td class="mdescRight">Addition to <a class="el" href="neorv32__spi_8c.html" title="Serial peripheral interface controller (SPI) HW driver source file.">neorv32_spi.c</a>, which provides an IRQ driven data flow. <br /></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><a href="neorv32__spi__irq_8h_source.html"><span class="icondoc"></span></a>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="neorv32__spi__irq_8h.html">neorv32_spi_irq.h</a></td></tr> +<tr class="memdesc:neorv32__spi__irq_8h"><td class="mdescLeft">&#160;</td><td class="mdescRight">Addition to <a class="el" href="neorv32__spi_8h.html" title="Serial peripheral interface controller (SPI) HW driver header file.">neorv32_spi.h</a>, which provides an IRQ driven data flow. <br /></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/dir_b5eb9f7d151d147efb5dbda58439e4e7.html b/sw/dir_b5eb9f7d151d147efb5dbda58439e4e7.html new file mode 100644 index 0000000000..edfc89c876 --- /dev/null +++ b/sw/dir_b5eb9f7d151d147efb5dbda58439e4e7.html @@ -0,0 +1,109 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/example/dhrystone Directory Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_f0f9b27afba2e8cc2da6e5fddcc1a8c9.html">example</a></li><li class="navelem"><a class="el" href="dir_b5eb9f7d151d147efb5dbda58439e4e7.html">dhrystone</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="headertitle"><div class="title">dhrystone Directory Reference</div></div> +</div><!--header--> +<div class="contents"> +<table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="files" name="files"></a> +Files</h2></td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><a href="dhry_8h_source.html"><span class="icondoc"></span></a>&#160;</td><td class="memItemRight" valign="bottom"><b>dhry.h</b></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/dir_b683da3a5fc966bff32ebf7cda721811.html b/sw/dir_b683da3a5fc966bff32ebf7cda721811.html new file mode 100644 index 0000000000..ac1a0c846d --- /dev/null +++ b/sw/dir_b683da3a5fc966bff32ebf7cda721811.html @@ -0,0 +1,110 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/example/demo_pwm Directory Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_f0f9b27afba2e8cc2da6e5fddcc1a8c9.html">example</a></li><li class="navelem"><a class="el" href="dir_b683da3a5fc966bff32ebf7cda721811.html">demo_pwm</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="headertitle"><div class="title">demo_pwm Directory Reference</div></div> +</div><!--header--> +<div class="contents"> +<table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="files" name="files"></a> +Files</h2></td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><span class="icondoc"></span>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="demo__pwm_2main_8c.html">main.c</a></td></tr> +<tr class="memdesc:demo__pwm_2main_8c"><td class="mdescLeft">&#160;</td><td class="mdescRight">Simple PWM demo program. <br /></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/dir_b68ac2efc0c6ed3018151f7bb6c45670.html b/sw/dir_b68ac2efc0c6ed3018151f7bb6c45670.html new file mode 100644 index 0000000000..aa9733bd21 --- /dev/null +++ b/sw/dir_b68ac2efc0c6ed3018151f7bb6c45670.html @@ -0,0 +1,110 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/example/demo_gptmr Directory Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_f0f9b27afba2e8cc2da6e5fddcc1a8c9.html">example</a></li><li class="navelem"><a class="el" href="dir_b68ac2efc0c6ed3018151f7bb6c45670.html">demo_gptmr</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="headertitle"><div class="title">demo_gptmr Directory Reference</div></div> +</div><!--header--> +<div class="contents"> +<table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="files" name="files"></a> +Files</h2></td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><span class="icondoc"></span>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="demo__gptmr_2main_8c.html">main.c</a></td></tr> +<tr class="memdesc:demo__gptmr_2main_8c"><td class="mdescLeft">&#160;</td><td class="mdescRight">Simple GPTMR timer-match interrupt example. <br /></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/dir_b6b50782b8271d07dffbc5f0cb9ff3f4.html b/sw/dir_b6b50782b8271d07dffbc5f0cb9ff3f4.html new file mode 100644 index 0000000000..e4140ee776 --- /dev/null +++ b/sw/dir_b6b50782b8271d07dffbc5f0cb9ff3f4.html @@ -0,0 +1,110 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/example/demo_xip Directory Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_f0f9b27afba2e8cc2da6e5fddcc1a8c9.html">example</a></li><li class="navelem"><a class="el" href="dir_b6b50782b8271d07dffbc5f0cb9ff3f4.html">demo_xip</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="headertitle"><div class="title">demo_xip Directory Reference</div></div> +</div><!--header--> +<div class="contents"> +<table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="files" name="files"></a> +Files</h2></td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><span class="icondoc"></span>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="demo__xip_2main_8c.html">main.c</a></td></tr> +<tr class="memdesc:demo__xip_2main_8c"><td class="mdescLeft">&#160;</td><td class="mdescRight">Interactive console program to upload and execute a XIP program. <br /></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/dir_bf935196a1ea0ca9cb42aae56d70946a.html b/sw/dir_bf935196a1ea0ca9cb42aae56d70946a.html new file mode 100644 index 0000000000..8c80e76525 --- /dev/null +++ b/sw/dir_bf935196a1ea0ca9cb42aae56d70946a.html @@ -0,0 +1,110 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/example/demo_crc Directory Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_f0f9b27afba2e8cc2da6e5fddcc1a8c9.html">example</a></li><li class="navelem"><a class="el" href="dir_bf935196a1ea0ca9cb42aae56d70946a.html">demo_crc</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="headertitle"><div class="title">demo_crc Directory Reference</div></div> +</div><!--header--> +<div class="contents"> +<table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="files" name="files"></a> +Files</h2></td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><span class="icondoc"></span>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="demo__crc_2main_8c.html">main.c</a></td></tr> +<tr class="memdesc:demo__crc_2main_8c"><td class="mdescLeft">&#160;</td><td class="mdescRight">CRC demo program. <br /></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/dir_c2d46947bdd73c33f53326fc5ee3a272.html b/sw/dir_c2d46947bdd73c33f53326fc5ee3a272.html new file mode 100644 index 0000000000..9f6cc628bb --- /dev/null +++ b/sw/dir_c2d46947bdd73c33f53326fc5ee3a272.html @@ -0,0 +1,110 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/example/demo_slink Directory Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_f0f9b27afba2e8cc2da6e5fddcc1a8c9.html">example</a></li><li class="navelem"><a class="el" href="dir_c2d46947bdd73c33f53326fc5ee3a272.html">demo_slink</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="headertitle"><div class="title">demo_slink Directory Reference</div></div> +</div><!--header--> +<div class="contents"> +<table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="files" name="files"></a> +Files</h2></td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><span class="icondoc"></span>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="demo__slink_2main_8c.html">main.c</a></td></tr> +<tr class="memdesc:demo__slink_2main_8c"><td class="mdescLeft">&#160;</td><td class="mdescRight">SLINK demo program. <br /></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/dir_c413aba6cb5da07a571465ba333950af.html b/sw/dir_c413aba6cb5da07a571465ba333950af.html new file mode 100644 index 0000000000..78e39be988 --- /dev/null +++ b/sw/dir_c413aba6cb5da07a571465ba333950af.html @@ -0,0 +1,110 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/example/demo_sdi Directory Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_f0f9b27afba2e8cc2da6e5fddcc1a8c9.html">example</a></li><li class="navelem"><a class="el" href="dir_c413aba6cb5da07a571465ba333950af.html">demo_sdi</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="headertitle"><div class="title">demo_sdi Directory Reference</div></div> +</div><!--header--> +<div class="contents"> +<table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="files" name="files"></a> +Files</h2></td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><span class="icondoc"></span>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="demo__sdi_2main_8c.html">main.c</a></td></tr> +<tr class="memdesc:demo__sdi_2main_8c"><td class="mdescLeft">&#160;</td><td class="mdescRight">SDI test program (direct access to the SDI module). <br /></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/dir_d4640980cbf1943e4a4aee6e8b810c7a.html b/sw/dir_d4640980cbf1943e4a4aee6e8b810c7a.html new file mode 100644 index 0000000000..7b9f64872c --- /dev/null +++ b/sw/dir_d4640980cbf1943e4a4aee6e8b810c7a.html @@ -0,0 +1,110 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/example/hello_world Directory Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_f0f9b27afba2e8cc2da6e5fddcc1a8c9.html">example</a></li><li class="navelem"><a class="el" href="dir_d4640980cbf1943e4a4aee6e8b810c7a.html">hello_world</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="headertitle"><div class="title">hello_world Directory Reference</div></div> +</div><!--header--> +<div class="contents"> +<table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="files" name="files"></a> +Files</h2></td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><span class="icondoc"></span>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="hello__world_2main_8c.html">main.c</a></td></tr> +<tr class="memdesc:hello__world_2main_8c"><td class="mdescLeft">&#160;</td><td class="mdescRight">Classic 'hello world' demo program. <br /></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/dir_d68bb921df3f2482fe9ace49b286ab86.html b/sw/dir_d68bb921df3f2482fe9ace49b286ab86.html new file mode 100644 index 0000000000..9097286a45 --- /dev/null +++ b/sw/dir_d68bb921df3f2482fe9ace49b286ab86.html @@ -0,0 +1,110 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/example/demo_neopixel Directory Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_f0f9b27afba2e8cc2da6e5fddcc1a8c9.html">example</a></li><li class="navelem"><a class="el" href="dir_d68bb921df3f2482fe9ace49b286ab86.html">demo_neopixel</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="headertitle"><div class="title">demo_neopixel Directory Reference</div></div> +</div><!--header--> +<div class="contents"> +<table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="files" name="files"></a> +Files</h2></td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><span class="icondoc"></span>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="demo__neopixel_2main_8c.html">main.c</a></td></tr> +<tr class="memdesc:demo__neopixel_2main_8c"><td class="mdescLeft">&#160;</td><td class="mdescRight">NeoPixel (WS2812) interface demo using the processor's smart LED interface (NEOLED). <br /></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/dir_e9ffd83269fb7f0c372f5ffbe8545008.html b/sw/dir_e9ffd83269fb7f0c372f5ffbe8545008.html new file mode 100644 index 0000000000..377dee1055 --- /dev/null +++ b/sw/dir_e9ffd83269fb7f0c372f5ffbe8545008.html @@ -0,0 +1,113 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/example/floating_point_test Directory Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_f0f9b27afba2e8cc2da6e5fddcc1a8c9.html">example</a></li><li class="navelem"><a class="el" href="dir_e9ffd83269fb7f0c372f5ffbe8545008.html">floating_point_test</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="headertitle"><div class="title">floating_point_test Directory Reference</div></div> +</div><!--header--> +<div class="contents"> +<table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="files" name="files"></a> +Files</h2></td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><span class="icondoc"></span>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="floating__point__test_2main_8c.html">main.c</a></td></tr> +<tr class="memdesc:floating__point__test_2main_8c"><td class="mdescLeft">&#160;</td><td class="mdescRight">Verification program for the NEORV32 'Zfinx' extension (floating-point in x registers) using pseudo-random data as input; compares results from hardware against pure-sw reference functions. <br /></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><a href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h_source.html"><span class="icondoc"></span></a>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html">neorv32_zfinx_extension_intrinsics.h</a></td></tr> +<tr class="memdesc:floating__point__test_2neorv32__zfinx__extension__intrinsics_8h"><td class="mdescLeft">&#160;</td><td class="mdescRight">"Intrinsic" library for the NEORV32 single-precision floating-point in x registers (Zfinx) extension <br /></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/dir_ebeff77b922fbb914a1494857a82a38e.html b/sw/dir_ebeff77b922fbb914a1494857a82a38e.html new file mode 100644 index 0000000000..031d02f3e8 --- /dev/null +++ b/sw/dir_ebeff77b922fbb914a1494857a82a38e.html @@ -0,0 +1,110 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/example/demo_twi Directory Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_f0f9b27afba2e8cc2da6e5fddcc1a8c9.html">example</a></li><li class="navelem"><a class="el" href="dir_ebeff77b922fbb914a1494857a82a38e.html">demo_twi</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="headertitle"><div class="title">demo_twi Directory Reference</div></div> +</div><!--header--> +<div class="contents"> +<table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="files" name="files"></a> +Files</h2></td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><span class="icondoc"></span>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="demo__twi_2main_8c.html">main.c</a></td></tr> +<tr class="memdesc:demo__twi_2main_8c"><td class="mdescLeft">&#160;</td><td class="mdescRight">TWI bus explorer. <br /></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/dir_eea6eb9fd693422884580f70321908d2.html b/sw/dir_eea6eb9fd693422884580f70321908d2.html new file mode 100644 index 0000000000..5c046212bf --- /dev/null +++ b/sw/dir_eea6eb9fd693422884580f70321908d2.html @@ -0,0 +1,103 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/example/eclipse Directory Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_f0f9b27afba2e8cc2da6e5fddcc1a8c9.html">example</a></li><li class="navelem"><a class="el" href="dir_eea6eb9fd693422884580f70321908d2.html">eclipse</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="headertitle"><div class="title">eclipse Directory Reference</div></div> +</div><!--header--> +<div class="contents"> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/dir_f05036e2ccd24a7119a5bbccebab20b2.html b/sw/dir_f05036e2ccd24a7119a5bbccebab20b2.html new file mode 100644 index 0000000000..98296c26d0 --- /dev/null +++ b/sw/dir_f05036e2ccd24a7119a5bbccebab20b2.html @@ -0,0 +1,103 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/example/performance_tests/I Directory Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_f0f9b27afba2e8cc2da6e5fddcc1a8c9.html">example</a></li><li class="navelem"><a class="el" href="dir_0f35fd52d2216117815d19d974239550.html">performance_tests</a></li><li class="navelem"><a class="el" href="dir_f05036e2ccd24a7119a5bbccebab20b2.html">I</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="headertitle"><div class="title">I Directory Reference</div></div> +</div><!--header--> +<div class="contents"> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/dir_f0f9b27afba2e8cc2da6e5fddcc1a8c9.html b/sw/dir_f0f9b27afba2e8cc2da6e5fddcc1a8c9.html new file mode 100644 index 0000000000..e7b483d72f --- /dev/null +++ b/sw/dir_f0f9b27afba2e8cc2da6e5fddcc1a8c9.html @@ -0,0 +1,169 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/example Directory Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_f0f9b27afba2e8cc2da6e5fddcc1a8c9.html">example</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="headertitle"><div class="title">example Directory Reference</div></div> +</div><!--header--> +<div class="contents"> +<table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="subdirs" name="subdirs"></a> +Directories</h2></td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><span class="iconfclosed"></span>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="dir_449d8ba5f8b78dc90092f20d15a2386a.html">atomic_test</a></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><span class="iconfclosed"></span>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="dir_0d2921e55a1172a4726516961ee96ab5.html">bus_explorer</a></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><span class="iconfclosed"></span>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="dir_9a1c128d67c35790e92af404beb936aa.html">demo_blink_led</a></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><span class="iconfclosed"></span>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="dir_01cde3d98944a579dc3b5e43a5311a79.html">demo_cfs</a></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><span class="iconfclosed"></span>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="dir_09a89dfa1596b6613cf2c29528a32844.html">demo_cfu</a></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><span class="iconfclosed"></span>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="dir_bf935196a1ea0ca9cb42aae56d70946a.html">demo_crc</a></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><span class="iconfclosed"></span>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="dir_8c514361e1f16692c783b23503f30f16.html">demo_dma</a></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><span class="iconfclosed"></span>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="dir_2ba96d3140b089dada6fb9f817b7975f.html">demo_emulate_unaligned</a></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><span class="iconfclosed"></span>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="dir_b68ac2efc0c6ed3018151f7bb6c45670.html">demo_gptmr</a></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><span class="iconfclosed"></span>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="dir_93967190e0d2e549ceca77007097849b.html">demo_hpm</a></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><span class="iconfclosed"></span>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="dir_8d341cbe0581f44e1ae95d82d74e8bc8.html">demo_mtime</a></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><span class="iconfclosed"></span>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="dir_d68bb921df3f2482fe9ace49b286ab86.html">demo_neopixel</a></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><span class="iconfclosed"></span>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="dir_23717ebbabf7a51c0558262947e0fe3b.html">demo_newlib</a></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><span class="iconfclosed"></span>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="dir_3b3bafc48b460f797485cc75b94aa81c.html">demo_onewire</a></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><span class="iconfclosed"></span>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="dir_b683da3a5fc966bff32ebf7cda721811.html">demo_pwm</a></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><span class="iconfclosed"></span>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="dir_c413aba6cb5da07a571465ba333950af.html">demo_sdi</a></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><span class="iconfclosed"></span>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="dir_c2d46947bdd73c33f53326fc5ee3a272.html">demo_slink</a></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><span class="iconfclosed"></span>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="dir_4c113257314015688a865e1bb8429184.html">demo_spi</a></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><span class="iconfclosed"></span>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="dir_8f848e36ac87ced1c361afcc0549ca32.html">demo_spi_irq</a></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><span class="iconfclosed"></span>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="dir_237db5b95db643499d4c20f0bc5f6a7d.html">demo_trng</a></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><span class="iconfclosed"></span>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="dir_ebeff77b922fbb914a1494857a82a38e.html">demo_twi</a></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><span class="iconfclosed"></span>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="dir_78d7bfa405ff3a31fa7539cfd8bc8262.html">demo_wdt</a></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><span class="iconfclosed"></span>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="dir_b6b50782b8271d07dffbc5f0cb9ff3f4.html">demo_xip</a></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><span class="iconfclosed"></span>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="dir_5534fa9035f54ab438a41c43d6f7fc7a.html">demo_xirq</a></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><span class="iconfclosed"></span>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="dir_b5eb9f7d151d147efb5dbda58439e4e7.html">dhrystone</a></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><span class="iconfclosed"></span>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="dir_eea6eb9fd693422884580f70321908d2.html">eclipse</a></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><span class="iconfclosed"></span>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="dir_23212395b5ee0866d2fdd629e0ddeae8.html">float_corner_test</a></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><span class="iconfclosed"></span>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="dir_e9ffd83269fb7f0c372f5ffbe8545008.html">floating_point_test</a></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><span class="iconfclosed"></span>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="dir_46981071cfd8ec44311b09fdcf6c06a8.html">game_of_life</a></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><span class="iconfclosed"></span>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="dir_d4640980cbf1943e4a4aee6e8b810c7a.html">hello_world</a></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top"><span class="iconfclosed"></span>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="dir_7a2c74f70a4cdf2e836a07048e2f71dd.html">processor_check</a></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/doc.svg b/sw/doc.svg new file mode 100644 index 0000000000..0b928a5317 --- /dev/null +++ b/sw/doc.svg @@ -0,0 +1,12 @@ +<?xml version="1.0" encoding="UTF-8" standalone="no"?> +<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" + "https://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd"> +<svg version="1.1" width="16" height="24" viewBox="0 0 80 60" id="doc" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" xml:space="preserve"> +<g style="fill:#4665A2"> +<path d="m 14,-1.1445312 c -2.824372,0 -5.1445313,2.320159 -5.1445312,5.1445312 v 72 c 0,2.824372 2.3201592,5.144531 5.1445312,5.144531 h 52 c 2.824372,0 5.144531,-2.320159 5.144531,-5.144531 V 23.699219 a 1.1447968,1.1447968 0 0 0 -0.01563,-0.1875 C 70.977847,22.605363 70.406495,21.99048 70.007812,21.591797 L 48.208984,-0.20898438 C 47.606104,-0.81186474 46.804652,-1.1445313 46,-1.1445312 Z m 1.144531,6.2890624 H 42.855469 V 24 c 0,1.724372 1.420159,3.144531 3.144531,3.144531 H 64.855469 V 74.855469 H 15.144531 Z m 34,4.4179688 L 60.4375,20.855469 H 49.144531 Z"/> +</g> +<g style="fill:#D8DFEE;stroke-width:0"> +<path d="M 3.0307167,13.993174 V 7.0307167 h 2.7576792 2.7576792 v 1.8826151 c 0,1.2578262 0.0099,1.9287572 0.029818,2.0216512 0.03884,0.181105 0.168631,0.348218 0.33827,0.43554 l 0.1355017,0.06975 1.9598092,0.0079 1.959809,0.0078 v 4.749829 4.749829 H 8 3.0307167 Z" transform="matrix(5,0,0,5,0,-30)" /> +<path d="M 9.8293515,9.0581469 V 7.9456453 l 1.1058025,1.1055492 c 0.608191,0.6080521 1.105802,1.1086775 1.105802,1.1125015 0,0.0038 -0.497611,0.007 -1.105802,0.007 H 9.8293515 Z" transform="matrix(5,0,0,5,0,-30)" /> +</g> +</svg> diff --git a/sw/docd.svg b/sw/docd.svg new file mode 100644 index 0000000000..ac18b27552 --- /dev/null +++ b/sw/docd.svg @@ -0,0 +1,12 @@ +<?xml version="1.0" encoding="UTF-8" standalone="no"?> +<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" + "https://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd"> +<svg version="1.1" width="16" height="24" viewBox="0 0 80 60" id="doc" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" xml:space="preserve"> +<g style="fill:#C4CFE5"> +<path d="m 14,-1.1445312 c -2.824372,0 -5.1445313,2.320159 -5.1445312,5.1445312 v 72 c 0,2.824372 2.3201592,5.144531 5.1445312,5.144531 h 52 c 2.824372,0 5.144531,-2.320159 5.144531,-5.144531 V 23.699219 a 1.1447968,1.1447968 0 0 0 -0.01563,-0.1875 C 70.977847,22.605363 70.406495,21.99048 70.007812,21.591797 L 48.208984,-0.20898438 C 47.606104,-0.81186474 46.804652,-1.1445313 46,-1.1445312 Z m 1.144531,6.2890624 H 42.855469 V 24 c 0,1.724372 1.420159,3.144531 3.144531,3.144531 H 64.855469 V 74.855469 H 15.144531 Z m 34,4.4179688 L 60.4375,20.855469 H 49.144531 Z"/> +</g> +<g style="fill:#4665A2;stroke-width:0"> +<path d="M 3.0307167,13.993174 V 7.0307167 h 2.7576792 2.7576792 v 1.8826151 c 0,1.2578262 0.0099,1.9287572 0.029818,2.0216512 0.03884,0.181105 0.168631,0.348218 0.33827,0.43554 l 0.1355017,0.06975 1.9598092,0.0079 1.959809,0.0078 v 4.749829 4.749829 H 8 3.0307167 Z" transform="matrix(5,0,0,5,0,-30)" /> +<path d="M 9.8293515,9.0581469 V 7.9456453 l 1.1058025,1.1055492 c 0.608191,0.6080521 1.105802,1.1086775 1.105802,1.1125015 0,0.0038 -0.497611,0.007 -1.105802,0.007 H 9.8293515 Z" transform="matrix(5,0,0,5,0,-30)" /> +</g> +</svg> diff --git a/sw/doxygen.css b/sw/doxygen.css new file mode 100644 index 0000000000..209912c711 --- /dev/null +++ b/sw/doxygen.css @@ -0,0 +1,2244 @@ +/* The standard CSS for doxygen 1.11.0*/ + +html { +/* page base colors */ +--page-background-color: white; +--page-foreground-color: black; +--page-link-color: #3D578C; +--page-visited-link-color: #4665A2; + +/* index */ +--index-odd-item-bg-color: #F8F9FC; +--index-even-item-bg-color: white; +--index-header-color: black; +--index-separator-color: #A0A0A0; + +/* header */ +--header-background-color: #F9FAFC; +--header-separator-color: #C4CFE5; +--header-gradient-image: url('nav_h.png'); +--group-header-separator-color: #879ECB; +--group-header-color: #354C7B; +--inherit-header-color: gray; + +--footer-foreground-color: #2A3D61; +--footer-logo-width: 104px; +--citation-label-color: #334975; +--glow-color: cyan; + +--title-background-color: white; +--title-separator-color: #5373B4; +--directory-separator-color: #9CAFD4; +--separator-color: #4A6AAA; + +--blockquote-background-color: #F7F8FB; +--blockquote-border-color: #9CAFD4; + +--scrollbar-thumb-color: #9CAFD4; +--scrollbar-background-color: #F9FAFC; + +--icon-background-color: #728DC1; +--icon-foreground-color: white; +--icon-doc-image: url('doc.svg'); +--icon-folder-open-image: url('folderopen.svg'); +--icon-folder-closed-image: url('folderclosed.svg'); + +/* brief member declaration list */ +--memdecl-background-color: #F9FAFC; +--memdecl-separator-color: #DEE4F0; +--memdecl-foreground-color: #555; +--memdecl-template-color: #4665A2; + +/* detailed member list */ +--memdef-border-color: #A8B8D9; +--memdef-title-background-color: #E2E8F2; +--memdef-title-gradient-image: url('nav_f.png'); +--memdef-proto-background-color: #DFE5F1; +--memdef-proto-text-color: #253555; +--memdef-proto-text-shadow: 0px 1px 1px rgba(255, 255, 255, 0.9); +--memdef-doc-background-color: white; +--memdef-param-name-color: #602020; +--memdef-template-color: #4665A2; + +/* tables */ +--table-cell-border-color: #2D4068; +--table-header-background-color: #374F7F; +--table-header-foreground-color: #FFFFFF; + +/* labels */ +--label-background-color: #728DC1; +--label-left-top-border-color: #5373B4; +--label-right-bottom-border-color: #C4CFE5; +--label-foreground-color: white; + +/** navigation bar/tree/menu */ +--nav-background-color: #F9FAFC; +--nav-foreground-color: #364D7C; +--nav-gradient-image: url('tab_b.png'); +--nav-gradient-hover-image: url('tab_h.png'); +--nav-gradient-active-image: url('tab_a.png'); +--nav-gradient-active-image-parent: url("../tab_a.png"); +--nav-separator-image: url('tab_s.png'); +--nav-breadcrumb-image: url('bc_s.png'); +--nav-breadcrumb-border-color: #C2CDE4; +--nav-splitbar-image: url('splitbar.png'); +--nav-font-size-level1: 13px; +--nav-font-size-level2: 10px; +--nav-font-size-level3: 9px; +--nav-text-normal-color: #283A5D; +--nav-text-hover-color: white; +--nav-text-active-color: white; +--nav-text-normal-shadow: 0px 1px 1px rgba(255, 255, 255, 0.9); +--nav-text-hover-shadow: 0px 1px 1px rgba(0, 0, 0, 1.0); +--nav-text-active-shadow: 0px 1px 1px rgba(0, 0, 0, 1.0); +--nav-menu-button-color: #364D7C; +--nav-menu-background-color: white; +--nav-menu-foreground-color: #555555; +--nav-menu-toggle-color: rgba(255, 255, 255, 0.5); +--nav-arrow-color: #9CAFD4; +--nav-arrow-selected-color: #9CAFD4; + +/* table of contents */ +--toc-background-color: #F4F6FA; +--toc-border-color: #D8DFEE; +--toc-header-color: #4665A2; +--toc-down-arrow-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' version='1.1' height='10px' width='5px' fill='grey'><text x='0' y='5' font-size='10'>&%238595;</text></svg>"); + +/** search field */ +--search-background-color: white; +--search-foreground-color: #909090; +--search-magnification-image: url('mag.svg'); +--search-magnification-select-image: url('mag_sel.svg'); +--search-active-color: black; +--search-filter-background-color: #F9FAFC; +--search-filter-foreground-color: black; +--search-filter-border-color: #90A5CE; +--search-filter-highlight-text-color: white; +--search-filter-highlight-bg-color: #3D578C; +--search-results-foreground-color: #425E97; +--search-results-background-color: #EEF1F7; +--search-results-border-color: black; +--search-box-shadow: inset 0.5px 0.5px 3px 0px #555; + +/** code fragments */ +--code-keyword-color: #008000; +--code-type-keyword-color: #604020; +--code-flow-keyword-color: #E08000; +--code-comment-color: #800000; +--code-preprocessor-color: #806020; +--code-string-literal-color: #002080; +--code-char-literal-color: #008080; +--code-xml-cdata-color: black; +--code-vhdl-digit-color: #FF00FF; +--code-vhdl-char-color: #000000; +--code-vhdl-keyword-color: #700070; +--code-vhdl-logic-color: #FF0000; +--code-link-color: #4665A2; +--code-external-link-color: #4665A2; +--fragment-foreground-color: black; +--fragment-background-color: #FBFCFD; +--fragment-border-color: #C4CFE5; +--fragment-lineno-border-color: #00FF00; +--fragment-lineno-background-color: #E8E8E8; +--fragment-lineno-foreground-color: black; +--fragment-lineno-link-fg-color: #4665A2; +--fragment-lineno-link-bg-color: #D8D8D8; +--fragment-lineno-link-hover-fg-color: #4665A2; +--fragment-lineno-link-hover-bg-color: #C8C8C8; +--fragment-copy-ok-color: #2EC82E; +--tooltip-foreground-color: black; +--tooltip-background-color: white; +--tooltip-border-color: gray; +--tooltip-doc-color: grey; +--tooltip-declaration-color: #006318; +--tooltip-link-color: #4665A2; +--tooltip-shadow: 1px 1px 7px gray; +--fold-line-color: #808080; +--fold-minus-image: url('minus.svg'); +--fold-plus-image: url('plus.svg'); +--fold-minus-image-relpath: url('../../minus.svg'); +--fold-plus-image-relpath: url('../../plus.svg'); + +/** font-family */ +--font-family-normal: Roboto,sans-serif; +--font-family-monospace: 'JetBrains Mono',Consolas,Monaco,'Andale Mono','Ubuntu Mono',monospace,fixed; +--font-family-nav: 'Lucida Grande',Geneva,Helvetica,Arial,sans-serif; +--font-family-title: Tahoma,Arial,sans-serif; +--font-family-toc: Verdana,'DejaVu Sans',Geneva,sans-serif; +--font-family-search: Arial,Verdana,sans-serif; +--font-family-icon: Arial,Helvetica; +--font-family-tooltip: Roboto,sans-serif; + +/** special sections */ +--warning-color-bg: #f8d1cc; +--warning-color-hl: #b61825; +--warning-color-text: #75070f; +--note-color-bg: #faf3d8; +--note-color-hl: #f3a600; +--note-color-text: #5f4204; +--todo-color-bg: #e4f3ff; +--todo-color-hl: #1879C4; +--todo-color-text: #274a5c; +--test-color-bg: #e8e8ff; +--test-color-hl: #3939C4; +--test-color-text: #1a1a5c; +--deprecated-color-bg: #ecf0f3; +--deprecated-color-hl: #5b6269; +--deprecated-color-text: #43454a; +--bug-color-bg: #e4dafd; +--bug-color-hl: #5b2bdd; +--bug-color-text: #2a0d72; +--invariant-color-bg: #d8f1e3; +--invariant-color-hl: #44b86f; +--invariant-color-text: #265532; +} + +@media (prefers-color-scheme: dark) { + html:not(.dark-mode) { + color-scheme: dark; + +/* page base colors */ +--page-background-color: black; +--page-foreground-color: #C9D1D9; +--page-link-color: #90A5CE; +--page-visited-link-color: #A3B4D7; + +/* index */ +--index-odd-item-bg-color: #0B101A; +--index-even-item-bg-color: black; +--index-header-color: #C4CFE5; +--index-separator-color: #334975; + +/* header */ +--header-background-color: #070B11; +--header-separator-color: #141C2E; +--header-gradient-image: url('nav_hd.png'); +--group-header-separator-color: #283A5D; +--group-header-color: #90A5CE; +--inherit-header-color: #A0A0A0; + +--footer-foreground-color: #5B7AB7; +--footer-logo-width: 60px; +--citation-label-color: #90A5CE; +--glow-color: cyan; + +--title-background-color: #090D16; +--title-separator-color: #354C79; +--directory-separator-color: #283A5D; +--separator-color: #283A5D; + +--blockquote-background-color: #101826; +--blockquote-border-color: #283A5D; + +--scrollbar-thumb-color: #283A5D; +--scrollbar-background-color: #070B11; + +--icon-background-color: #334975; +--icon-foreground-color: #C4CFE5; +--icon-doc-image: url('docd.svg'); +--icon-folder-open-image: url('folderopend.svg'); +--icon-folder-closed-image: url('folderclosedd.svg'); + +/* brief member declaration list */ +--memdecl-background-color: #0B101A; +--memdecl-separator-color: #2C3F65; +--memdecl-foreground-color: #BBB; +--memdecl-template-color: #7C95C6; + +/* detailed member list */ +--memdef-border-color: #233250; +--memdef-title-background-color: #1B2840; +--memdef-title-gradient-image: url('nav_fd.png'); +--memdef-proto-background-color: #19243A; +--memdef-proto-text-color: #9DB0D4; +--memdef-proto-text-shadow: 0px 1px 1px rgba(0, 0, 0, 0.9); +--memdef-doc-background-color: black; +--memdef-param-name-color: #D28757; +--memdef-template-color: #7C95C6; + +/* tables */ +--table-cell-border-color: #283A5D; +--table-header-background-color: #283A5D; +--table-header-foreground-color: #C4CFE5; + +/* labels */ +--label-background-color: #354C7B; +--label-left-top-border-color: #4665A2; +--label-right-bottom-border-color: #283A5D; +--label-foreground-color: #CCCCCC; + +/** navigation bar/tree/menu */ +--nav-background-color: #101826; +--nav-foreground-color: #364D7C; +--nav-gradient-image: url('tab_bd.png'); +--nav-gradient-hover-image: url('tab_hd.png'); +--nav-gradient-active-image: url('tab_ad.png'); +--nav-gradient-active-image-parent: url("../tab_ad.png"); +--nav-separator-image: url('tab_sd.png'); +--nav-breadcrumb-image: url('bc_sd.png'); +--nav-breadcrumb-border-color: #2A3D61; +--nav-splitbar-image: url('splitbard.png'); +--nav-font-size-level1: 13px; +--nav-font-size-level2: 10px; +--nav-font-size-level3: 9px; +--nav-text-normal-color: #B6C4DF; +--nav-text-hover-color: #DCE2EF; +--nav-text-active-color: #DCE2EF; +--nav-text-normal-shadow: 0px 1px 1px black; +--nav-text-hover-shadow: 0px 1px 1px rgba(0, 0, 0, 1.0); +--nav-text-active-shadow: 0px 1px 1px rgba(0, 0, 0, 1.0); +--nav-menu-button-color: #B6C4DF; +--nav-menu-background-color: #05070C; +--nav-menu-foreground-color: #BBBBBB; +--nav-menu-toggle-color: rgba(255, 255, 255, 0.2); +--nav-arrow-color: #334975; +--nav-arrow-selected-color: #90A5CE; + +/* table of contents */ +--toc-background-color: #151E30; +--toc-border-color: #202E4A; +--toc-header-color: #A3B4D7; +--toc-down-arrow-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' version='1.1' height='10px' width='5px'><text x='0' y='5' font-size='10' fill='grey'>&%238595;</text></svg>"); + +/** search field */ +--search-background-color: black; +--search-foreground-color: #C5C5C5; +--search-magnification-image: url('mag_d.svg'); +--search-magnification-select-image: url('mag_seld.svg'); +--search-active-color: #C5C5C5; +--search-filter-background-color: #101826; +--search-filter-foreground-color: #90A5CE; +--search-filter-border-color: #7C95C6; +--search-filter-highlight-text-color: #BCC9E2; +--search-filter-highlight-bg-color: #283A5D; +--search-results-background-color: #101826; +--search-results-foreground-color: #90A5CE; +--search-results-border-color: #7C95C6; +--search-box-shadow: inset 0.5px 0.5px 3px 0px #2F436C; + +/** code fragments */ +--code-keyword-color: #CC99CD; +--code-type-keyword-color: #AB99CD; +--code-flow-keyword-color: #E08000; +--code-comment-color: #717790; +--code-preprocessor-color: #65CABE; +--code-string-literal-color: #7EC699; +--code-char-literal-color: #00E0F0; +--code-xml-cdata-color: #C9D1D9; +--code-vhdl-digit-color: #FF00FF; +--code-vhdl-char-color: #C0C0C0; +--code-vhdl-keyword-color: #CF53C9; +--code-vhdl-logic-color: #FF0000; +--code-link-color: #79C0FF; +--code-external-link-color: #79C0FF; +--fragment-foreground-color: #C9D1D9; +--fragment-background-color: #090D16; +--fragment-border-color: #30363D; +--fragment-lineno-border-color: #30363D; +--fragment-lineno-background-color: black; +--fragment-lineno-foreground-color: #6E7681; +--fragment-lineno-link-fg-color: #6E7681; +--fragment-lineno-link-bg-color: #303030; +--fragment-lineno-link-hover-fg-color: #8E96A1; +--fragment-lineno-link-hover-bg-color: #505050; +--fragment-copy-ok-color: #0EA80E; +--tooltip-foreground-color: #C9D1D9; +--tooltip-background-color: #202020; +--tooltip-border-color: #C9D1D9; +--tooltip-doc-color: #D9E1E9; +--tooltip-declaration-color: #20C348; +--tooltip-link-color: #79C0FF; +--tooltip-shadow: none; +--fold-line-color: #808080; +--fold-minus-image: url('minusd.svg'); +--fold-plus-image: url('plusd.svg'); +--fold-minus-image-relpath: url('../../minusd.svg'); +--fold-plus-image-relpath: url('../../plusd.svg'); + +/** font-family */ +--font-family-normal: Roboto,sans-serif; +--font-family-monospace: 'JetBrains Mono',Consolas,Monaco,'Andale Mono','Ubuntu Mono',monospace,fixed; +--font-family-nav: 'Lucida Grande',Geneva,Helvetica,Arial,sans-serif; +--font-family-title: Tahoma,Arial,sans-serif; +--font-family-toc: Verdana,'DejaVu Sans',Geneva,sans-serif; +--font-family-search: Arial,Verdana,sans-serif; +--font-family-icon: Arial,Helvetica; +--font-family-tooltip: Roboto,sans-serif; + +/** special sections */ +--warning-color-bg: #2e1917; +--warning-color-hl: #ad2617; +--warning-color-text: #f5b1aa; +--note-color-bg: #3b2e04; +--note-color-hl: #f1b602; +--note-color-text: #ceb670; +--todo-color-bg: #163750; +--todo-color-hl: #1982D2; +--todo-color-text: #dcf0fa; +--test-color-bg: #121258; +--test-color-hl: #4242cf; +--test-color-text: #c0c0da; +--deprecated-color-bg: #2e323b; +--deprecated-color-hl: #738396; +--deprecated-color-text: #abb0bd; +--bug-color-bg: #2a2536; +--bug-color-hl: #7661b3; +--bug-color-text: #ae9ed6; +--invariant-color-bg: #303a35; +--invariant-color-hl: #76ce96; +--invariant-color-text: #cceed5; +}} +body { + background-color: var(--page-background-color); + color: var(--page-foreground-color); +} + +body, table, div, p, dl { + font-weight: 400; + font-size: 14px; + font-family: var(--font-family-normal); + line-height: 22px; +} + +/* @group Heading Levels */ + +.title { + font-family: var(--font-family-normal); + line-height: 28px; + font-size: 150%; + font-weight: bold; + margin: 10px 2px; +} + +h1.groupheader { + font-size: 150%; +} + +h2.groupheader { + border-bottom: 1px solid var(--group-header-separator-color); + color: var(--group-header-color); + font-size: 150%; + font-weight: normal; + margin-top: 1.75em; + padding-top: 8px; + padding-bottom: 4px; + width: 100%; +} + +h3.groupheader { + font-size: 100%; +} + +h1, h2, h3, h4, h5, h6 { + -webkit-transition: text-shadow 0.5s linear; + -moz-transition: text-shadow 0.5s linear; + -ms-transition: text-shadow 0.5s linear; + -o-transition: text-shadow 0.5s linear; + transition: text-shadow 0.5s linear; + margin-right: 15px; +} + +h1.glow, h2.glow, h3.glow, h4.glow, h5.glow, h6.glow { + text-shadow: 0 0 15px var(--glow-color); +} + +dt { + font-weight: bold; +} + +p.startli, p.startdd { + margin-top: 2px; +} + +th p.starttd, th p.intertd, th p.endtd { + font-size: 100%; + font-weight: 700; +} + +p.starttd { + margin-top: 0px; +} + +p.endli { + margin-bottom: 0px; +} + +p.enddd { + margin-bottom: 4px; +} + +p.endtd { + margin-bottom: 2px; +} + +p.interli { +} + +p.interdd { +} + +p.intertd { +} + +/* @end */ + +caption { + font-weight: bold; +} + +span.legend { + font-size: 70%; + text-align: center; +} + +h3.version { + font-size: 90%; + text-align: center; +} + +div.navtab { + padding-right: 15px; + text-align: right; + line-height: 110%; +} + +div.navtab table { + border-spacing: 0; +} + +td.navtab { + padding-right: 6px; + padding-left: 6px; +} + +td.navtabHL { + background-image: var(--nav-gradient-active-image); + background-repeat:repeat-x; + padding-right: 6px; + padding-left: 6px; +} + +td.navtabHL a, td.navtabHL a:visited { + color: var(--nav-text-hover-color); + text-shadow: var(--nav-text-hover-shadow); +} + +a.navtab { + font-weight: bold; +} + +div.qindex{ + text-align: center; + width: 100%; + line-height: 140%; + font-size: 130%; + color: var(--index-separator-color); +} + +#main-menu a:focus { + outline: auto; + z-index: 10; + position: relative; +} + +dt.alphachar{ + font-size: 180%; + font-weight: bold; +} + +.alphachar a{ + color: var(--index-header-color); +} + +.alphachar a:hover, .alphachar a:visited{ + text-decoration: none; +} + +.classindex dl { + padding: 25px; + column-count:1 +} + +.classindex dd { + display:inline-block; + margin-left: 50px; + width: 90%; + line-height: 1.15em; +} + +.classindex dl.even { + background-color: var(--index-even-item-bg-color); +} + +.classindex dl.odd { + background-color: var(--index-odd-item-bg-color); +} + +@media(min-width: 1120px) { + .classindex dl { + column-count:2 + } +} + +@media(min-width: 1320px) { + .classindex dl { + column-count:3 + } +} + + +/* @group Link Styling */ + +a { + color: var(--page-link-color); + font-weight: normal; + text-decoration: none; +} + +.contents a:visited { + color: var(--page-visited-link-color); +} + +a:hover { + text-decoration: none; + background: linear-gradient(to bottom, transparent 0,transparent calc(100% - 1px), currentColor 100%); +} + +a:hover > span.arrow { + text-decoration: none; + background : var(--nav-background-color); +} + +a.el { + font-weight: bold; +} + +a.elRef { +} + +a.code, a.code:visited, a.line, a.line:visited { + color: var(--code-link-color); +} + +a.codeRef, a.codeRef:visited, a.lineRef, a.lineRef:visited { + color: var(--code-external-link-color); +} + +a.code.hl_class { /* style for links to class names in code snippets */ } +a.code.hl_struct { /* style for links to struct names in code snippets */ } +a.code.hl_union { /* style for links to union names in code snippets */ } +a.code.hl_interface { /* style for links to interface names in code snippets */ } +a.code.hl_protocol { /* style for links to protocol names in code snippets */ } +a.code.hl_category { /* style for links to category names in code snippets */ } +a.code.hl_exception { /* style for links to exception names in code snippets */ } +a.code.hl_service { /* style for links to service names in code snippets */ } +a.code.hl_singleton { /* style for links to singleton names in code snippets */ } +a.code.hl_concept { /* style for links to concept names in code snippets */ } +a.code.hl_namespace { /* style for links to namespace names in code snippets */ } +a.code.hl_package { /* style for links to package names in code snippets */ } +a.code.hl_define { /* style for links to macro names in code snippets */ } +a.code.hl_function { /* style for links to function names in code snippets */ } +a.code.hl_variable { /* style for links to variable names in code snippets */ } +a.code.hl_typedef { /* style for links to typedef names in code snippets */ } +a.code.hl_enumvalue { /* style for links to enum value names in code snippets */ } +a.code.hl_enumeration { /* style for links to enumeration names in code snippets */ } +a.code.hl_signal { /* style for links to Qt signal names in code snippets */ } +a.code.hl_slot { /* style for links to Qt slot names in code snippets */ } +a.code.hl_friend { /* style for links to friend names in code snippets */ } +a.code.hl_dcop { /* style for links to KDE3 DCOP names in code snippets */ } +a.code.hl_property { /* style for links to property names in code snippets */ } +a.code.hl_event { /* style for links to event names in code snippets */ } +a.code.hl_sequence { /* style for links to sequence names in code snippets */ } +a.code.hl_dictionary { /* style for links to dictionary names in code snippets */ } + +/* @end */ + +dl.el { + margin-left: -1cm; +} + +ul.check { + list-style:none; + text-indent: -16px; + padding-left: 38px; +} +li.unchecked:before { + content: "\2610\A0"; +} +li.checked:before { + content: "\2611\A0"; +} + +ol { + text-indent: 0px; +} + +ul { + text-indent: 0px; + overflow: visible; +} + +ul.multicol { + -moz-column-gap: 1em; + -webkit-column-gap: 1em; + column-gap: 1em; + -moz-column-count: 3; + -webkit-column-count: 3; + column-count: 3; + list-style-type: none; +} + +#side-nav ul { + overflow: visible; /* reset ul rule for scroll bar in GENERATE_TREEVIEW window */ +} + +#main-nav ul { + overflow: visible; /* reset ul rule for the navigation bar drop down lists */ +} + +.fragment { + text-align: left; + direction: ltr; + overflow-x: auto; + overflow-y: hidden; + position: relative; + min-height: 12px; + margin: 10px 0px; + padding: 10px 10px; + border: 1px solid var(--fragment-border-color); + border-radius: 4px; + background-color: var(--fragment-background-color); + color: var(--fragment-foreground-color); +} + +pre.fragment { + word-wrap: break-word; + font-size: 10pt; + line-height: 125%; + font-family: var(--font-family-monospace); +} + +.clipboard { + width: 24px; + height: 24px; + right: 5px; + top: 5px; + opacity: 0; + position: absolute; + display: inline; + overflow: auto; + fill: var(--fragment-foreground-color); + justify-content: center; + align-items: center; + cursor: pointer; +} + +.clipboard.success { + border: 1px solid var(--fragment-foreground-color); + border-radius: 4px; +} + +.fragment:hover .clipboard, .clipboard.success { + opacity: .28; +} + +.clipboard:hover, .clipboard.success { + opacity: 1 !important; +} + +.clipboard:active:not([class~=success]) svg { + transform: scale(.91); +} + +.clipboard.success svg { + fill: var(--fragment-copy-ok-color); +} + +.clipboard.success { + border-color: var(--fragment-copy-ok-color); +} + +div.line { + font-family: var(--font-family-monospace); + font-size: 13px; + min-height: 13px; + line-height: 1.2; + text-wrap: unrestricted; + white-space: -moz-pre-wrap; /* Moz */ + white-space: -pre-wrap; /* Opera 4-6 */ + white-space: -o-pre-wrap; /* Opera 7 */ + white-space: pre-wrap; /* CSS3 */ + word-wrap: break-word; /* IE 5.5+ */ + text-indent: -53px; + padding-left: 53px; + padding-bottom: 0px; + margin: 0px; + -webkit-transition-property: background-color, box-shadow; + -webkit-transition-duration: 0.5s; + -moz-transition-property: background-color, box-shadow; + -moz-transition-duration: 0.5s; + -ms-transition-property: background-color, box-shadow; + -ms-transition-duration: 0.5s; + -o-transition-property: background-color, box-shadow; + -o-transition-duration: 0.5s; + transition-property: background-color, box-shadow; + transition-duration: 0.5s; +} + +div.line:after { + content:"\000A"; + white-space: pre; +} + +div.line.glow { + background-color: var(--glow-color); + box-shadow: 0 0 10px var(--glow-color); +} + +span.fold { + margin-left: 5px; + margin-right: 1px; + margin-top: 0px; + margin-bottom: 0px; + padding: 0px; + display: inline-block; + width: 12px; + height: 12px; + background-repeat:no-repeat; + background-position:center; +} + +span.lineno { + padding-right: 4px; + margin-right: 9px; + text-align: right; + border-right: 2px solid var(--fragment-lineno-border-color); + color: var(--fragment-lineno-foreground-color); + background-color: var(--fragment-lineno-background-color); + white-space: pre; +} +span.lineno a, span.lineno a:visited { + color: var(--fragment-lineno-link-fg-color); + background-color: var(--fragment-lineno-link-bg-color); +} + +span.lineno a:hover { + color: var(--fragment-lineno-link-hover-fg-color); + background-color: var(--fragment-lineno-link-hover-bg-color); +} + +.lineno { + -webkit-touch-callout: none; + -webkit-user-select: none; + -khtml-user-select: none; + -moz-user-select: none; + -ms-user-select: none; + user-select: none; +} + +div.classindex ul { + list-style: none; + padding-left: 0; +} + +div.classindex span.ai { + display: inline-block; +} + +div.groupHeader { + margin-left: 16px; + margin-top: 12px; + font-weight: bold; +} + +div.groupText { + margin-left: 16px; + font-style: italic; +} + +body { + color: var(--page-foreground-color); + margin: 0; +} + +div.contents { + margin-top: 10px; + margin-left: 12px; + margin-right: 8px; +} + +p.formulaDsp { + text-align: center; +} + +img.dark-mode-visible { + display: none; +} +img.light-mode-visible { + display: none; +} + +img.formulaInl, img.inline { + vertical-align: middle; +} + +div.center { + text-align: center; + margin-top: 0px; + margin-bottom: 0px; + padding: 0px; +} + +div.center img { + border: 0px; +} + +address.footer { + text-align: right; + padding-right: 12px; +} + +img.footer { + border: 0px; + vertical-align: middle; + width: var(--footer-logo-width); +} + +.compoundTemplParams { + color: var(--memdecl-template-color); + font-size: 80%; + line-height: 120%; +} + +/* @group Code Colorization */ + +span.keyword { + color: var(--code-keyword-color); +} + +span.keywordtype { + color: var(--code-type-keyword-color); +} + +span.keywordflow { + color: var(--code-flow-keyword-color); +} + +span.comment { + color: var(--code-comment-color); +} + +span.preprocessor { + color: var(--code-preprocessor-color); +} + +span.stringliteral { + color: var(--code-string-literal-color); +} + +span.charliteral { + color: var(--code-char-literal-color); +} + +span.xmlcdata { + color: var(--code-xml-cdata-color); +} + +span.vhdldigit { + color: var(--code-vhdl-digit-color); +} + +span.vhdlchar { + color: var(--code-vhdl-char-color); +} + +span.vhdlkeyword { + color: var(--code-vhdl-keyword-color); +} + +span.vhdllogic { + color: var(--code-vhdl-logic-color); +} + +blockquote { + background-color: var(--blockquote-background-color); + border-left: 2px solid var(--blockquote-border-color); + margin: 0 24px 0 4px; + padding: 0 12px 0 16px; +} + +/* @end */ + +td.tiny { + font-size: 75%; +} + +.dirtab { + padding: 4px; + border-collapse: collapse; + border: 1px solid var(--table-cell-border-color); +} + +th.dirtab { + background-color: var(--table-header-background-color); + color: var(--table-header-foreground-color); + font-weight: bold; +} + +hr { + height: 0px; + border: none; + border-top: 1px solid var(--separator-color); +} + +hr.footer { + height: 1px; +} + +/* @group Member Descriptions */ + +table.memberdecls { + border-spacing: 0px; + padding: 0px; +} + +.memberdecls td, .fieldtable tr { + -webkit-transition-property: background-color, box-shadow; + -webkit-transition-duration: 0.5s; + -moz-transition-property: background-color, box-shadow; + -moz-transition-duration: 0.5s; + -ms-transition-property: background-color, box-shadow; + -ms-transition-duration: 0.5s; + -o-transition-property: background-color, box-shadow; + -o-transition-duration: 0.5s; + transition-property: background-color, box-shadow; + transition-duration: 0.5s; +} + +.memberdecls td.glow, .fieldtable tr.glow { + background-color: var(--glow-color); + box-shadow: 0 0 15px var(--glow-color); +} + +.mdescLeft, .mdescRight, +.memItemLeft, .memItemRight, +.memTemplItemLeft, .memTemplItemRight, .memTemplParams { + background-color: var(--memdecl-background-color); + border: none; + margin: 4px; + padding: 1px 0 0 8px; +} + +.mdescLeft, .mdescRight { + padding: 0px 8px 4px 8px; + color: var(--memdecl-foreground-color); +} + +.memSeparator { + border-bottom: 1px solid var(--memdecl-separator-color); + line-height: 1px; + margin: 0px; + padding: 0px; +} + +.memItemLeft, .memTemplItemLeft { + white-space: nowrap; +} + +.memItemRight, .memTemplItemRight { + width: 100%; +} + +.memTemplParams { + color: var(--memdecl-template-color); + white-space: nowrap; + font-size: 80%; +} + +/* @end */ + +/* @group Member Details */ + +/* Styles for detailed member documentation */ + +.memtitle { + padding: 8px; + border-top: 1px solid var(--memdef-border-color); + border-left: 1px solid var(--memdef-border-color); + border-right: 1px solid var(--memdef-border-color); + border-top-right-radius: 4px; + border-top-left-radius: 4px; + margin-bottom: -1px; + background-image: var(--memdef-title-gradient-image); + background-repeat: repeat-x; + background-color: var(--memdef-title-background-color); + line-height: 1.25; + font-weight: 300; + float:left; +} + +.permalink +{ + font-size: 65%; + display: inline-block; + vertical-align: middle; +} + +.memtemplate { + font-size: 80%; + color: var(--memdef-template-color); + font-weight: normal; + margin-left: 9px; +} + +.mempage { + width: 100%; +} + +.memitem { + padding: 0; + margin-bottom: 10px; + margin-right: 5px; + -webkit-transition: box-shadow 0.5s linear; + -moz-transition: box-shadow 0.5s linear; + -ms-transition: box-shadow 0.5s linear; + -o-transition: box-shadow 0.5s linear; + transition: box-shadow 0.5s linear; + display: table !important; + width: 100%; +} + +.memitem.glow { + box-shadow: 0 0 15px var(--glow-color); +} + +.memname { + font-weight: 400; + margin-left: 6px; +} + +.memname td { + vertical-align: bottom; +} + +.memproto, dl.reflist dt { + border-top: 1px solid var(--memdef-border-color); + border-left: 1px solid var(--memdef-border-color); + border-right: 1px solid var(--memdef-border-color); + padding: 6px 0px 6px 0px; + color: var(--memdef-proto-text-color); + font-weight: bold; + text-shadow: var(--memdef-proto-text-shadow); + background-color: var(--memdef-proto-background-color); + box-shadow: 5px 5px 5px rgba(0, 0, 0, 0.15); + border-top-right-radius: 4px; +} + +.overload { + font-family: var(--font-family-monospace); + font-size: 65%; +} + +.memdoc, dl.reflist dd { + border-bottom: 1px solid var(--memdef-border-color); + border-left: 1px solid var(--memdef-border-color); + border-right: 1px solid var(--memdef-border-color); + padding: 6px 10px 2px 10px; + border-top-width: 0; + background-image:url('nav_g.png'); + background-repeat:repeat-x; + background-color: var(--memdef-doc-background-color); + /* opera specific markup */ + border-bottom-left-radius: 4px; + border-bottom-right-radius: 4px; + box-shadow: 5px 5px 5px rgba(0, 0, 0, 0.15); + /* firefox specific markup */ + -moz-border-radius-bottomleft: 4px; + -moz-border-radius-bottomright: 4px; + -moz-box-shadow: rgba(0, 0, 0, 0.15) 5px 5px 5px; + /* webkit specific markup */ + -webkit-border-bottom-left-radius: 4px; + -webkit-border-bottom-right-radius: 4px; + -webkit-box-shadow: 5px 5px 5px rgba(0, 0, 0, 0.15); +} + +dl.reflist dt { + padding: 5px; +} + +dl.reflist dd { + margin: 0px 0px 10px 0px; + padding: 5px; +} + +.paramkey { + text-align: right; +} + +.paramtype { + white-space: nowrap; + padding: 0px; + padding-bottom: 1px; +} + +.paramname { + white-space: nowrap; + padding: 0px; + padding-bottom: 1px; + margin-left: 2px; +} + +.paramname em { + color: var(--memdef-param-name-color); + font-style: normal; + margin-right: 1px; +} + +.paramname .paramdefval { + font-family: var(--font-family-monospace); +} + +.params, .retval, .exception, .tparams { + margin-left: 0px; + padding-left: 0px; +} + +.params .paramname, .retval .paramname, .tparams .paramname, .exception .paramname { + font-weight: bold; + vertical-align: top; +} + +.params .paramtype, .tparams .paramtype { + font-style: italic; + vertical-align: top; +} + +.params .paramdir, .tparams .paramdir { + font-family: var(--font-family-monospace); + vertical-align: top; +} + +table.mlabels { + border-spacing: 0px; +} + +td.mlabels-left { + width: 100%; + padding: 0px; +} + +td.mlabels-right { + vertical-align: bottom; + padding: 0px; + white-space: nowrap; +} + +span.mlabels { + margin-left: 8px; +} + +span.mlabel { + background-color: var(--label-background-color); + border-top:1px solid var(--label-left-top-border-color); + border-left:1px solid var(--label-left-top-border-color); + border-right:1px solid var(--label-right-bottom-border-color); + border-bottom:1px solid var(--label-right-bottom-border-color); + text-shadow: none; + color: var(--label-foreground-color); + margin-right: 4px; + padding: 2px 3px; + border-radius: 3px; + font-size: 7pt; + white-space: nowrap; + vertical-align: middle; +} + + + +/* @end */ + +/* these are for tree view inside a (index) page */ + +div.directory { + margin: 10px 0px; + border-top: 1px solid var(--directory-separator-color); + border-bottom: 1px solid var(--directory-separator-color); + width: 100%; +} + +.directory table { + border-collapse:collapse; +} + +.directory td { + margin: 0px; + padding: 0px; + vertical-align: top; +} + +.directory td.entry { + white-space: nowrap; + padding-right: 6px; + padding-top: 3px; +} + +.directory td.entry a { + outline:none; +} + +.directory td.entry a img { + border: none; +} + +.directory td.desc { + width: 100%; + padding-left: 6px; + padding-right: 6px; + padding-top: 3px; + border-left: 1px solid rgba(0,0,0,0.05); +} + +.directory tr.odd { + padding-left: 6px; + background-color: var(--index-odd-item-bg-color); +} + +.directory tr.even { + padding-left: 6px; + background-color: var(--index-even-item-bg-color); +} + +.directory img { + vertical-align: -30%; +} + +.directory .levels { + white-space: nowrap; + width: 100%; + text-align: right; + font-size: 9pt; +} + +.directory .levels span { + cursor: pointer; + padding-left: 2px; + padding-right: 2px; + color: var(--page-link-color); +} + +.arrow { + color: var(--nav-arrow-color); + -webkit-user-select: none; + -khtml-user-select: none; + -moz-user-select: none; + -ms-user-select: none; + user-select: none; + cursor: pointer; + font-size: 80%; + display: inline-block; + width: 16px; + height: 22px; +} + +.icon { + font-family: var(--font-family-icon); + line-height: normal; + font-weight: bold; + font-size: 12px; + height: 14px; + width: 16px; + display: inline-block; + background-color: var(--icon-background-color); + color: var(--icon-foreground-color); + text-align: center; + border-radius: 4px; + margin-left: 2px; + margin-right: 2px; +} + +.icona { + width: 24px; + height: 22px; + display: inline-block; +} + +.iconfopen { + width: 24px; + height: 18px; + margin-bottom: 4px; + background-image:var(--icon-folder-open-image); + background-repeat: repeat-y; + vertical-align:top; + display: inline-block; +} + +.iconfclosed { + width: 24px; + height: 18px; + margin-bottom: 4px; + background-image:var(--icon-folder-closed-image); + background-repeat: repeat-y; + vertical-align:top; + display: inline-block; +} + +.icondoc { + width: 24px; + height: 18px; + margin-bottom: 4px; + background-image:var(--icon-doc-image); + background-position: 0px -4px; + background-repeat: repeat-y; + vertical-align:top; + display: inline-block; +} + +/* @end */ + +div.dynheader { + margin-top: 8px; + -webkit-touch-callout: none; + -webkit-user-select: none; + -khtml-user-select: none; + -moz-user-select: none; + -ms-user-select: none; + user-select: none; +} + +address { + font-style: normal; + color: var(--footer-foreground-color); +} + +table.doxtable caption { + caption-side: top; +} + +table.doxtable { + border-collapse:collapse; + margin-top: 4px; + margin-bottom: 4px; +} + +table.doxtable td, table.doxtable th { + border: 1px solid var(--table-cell-border-color); + padding: 3px 7px 2px; +} + +table.doxtable th { + background-color: var(--table-header-background-color); + color: var(--table-header-foreground-color); + font-size: 110%; + padding-bottom: 4px; + padding-top: 5px; +} + +table.fieldtable { + margin-bottom: 10px; + border: 1px solid var(--memdef-border-color); + border-spacing: 0px; + border-radius: 4px; + box-shadow: 2px 2px 2px rgba(0, 0, 0, 0.15); +} + +.fieldtable td, .fieldtable th { + padding: 3px 7px 2px; +} + +.fieldtable td.fieldtype, .fieldtable td.fieldname { + white-space: nowrap; + border-right: 1px solid var(--memdef-border-color); + border-bottom: 1px solid var(--memdef-border-color); + vertical-align: top; +} + +.fieldtable td.fieldname { + padding-top: 3px; +} + +.fieldtable td.fielddoc { + border-bottom: 1px solid var(--memdef-border-color); +} + +.fieldtable td.fielddoc p:first-child { + margin-top: 0px; +} + +.fieldtable td.fielddoc p:last-child { + margin-bottom: 2px; +} + +.fieldtable tr:last-child td { + border-bottom: none; +} + +.fieldtable th { + background-image: var(--memdef-title-gradient-image); + background-repeat:repeat-x; + background-color: var(--memdef-title-background-color); + font-size: 90%; + color: var(--memdef-proto-text-color); + padding-bottom: 4px; + padding-top: 5px; + text-align:left; + font-weight: 400; + border-top-left-radius: 4px; + border-top-right-radius: 4px; + border-bottom: 1px solid var(--memdef-border-color); +} + + +.tabsearch { + top: 0px; + left: 10px; + height: 36px; + background-image: var(--nav-gradient-image); + z-index: 101; + overflow: hidden; + font-size: 13px; +} + +.navpath ul +{ + font-size: 11px; + background-image: var(--nav-gradient-image); + background-repeat:repeat-x; + background-position: 0 -5px; + height:30px; + line-height:30px; + color:var(--nav-text-normal-color); + border:solid 1px var(--nav-breadcrumb-border-color); + overflow:hidden; + margin:0px; + padding:0px; +} + +.navpath li +{ + list-style-type:none; + float:left; + padding-left:10px; + padding-right:15px; + background-image:var(--nav-breadcrumb-image); + background-repeat:no-repeat; + background-position:right; + color: var(--nav-foreground-color); +} + +.navpath li.navelem a +{ + height:32px; + display:block; + outline: none; + color: var(--nav-text-normal-color); + font-family: var(--font-family-nav); + text-shadow: var(--nav-text-normal-shadow); + text-decoration: none; +} + +.navpath li.navelem a:hover +{ + color: var(--nav-text-hover-color); + text-shadow: var(--nav-text-hover-shadow); +} + +.navpath li.footer +{ + list-style-type:none; + float:right; + padding-left:10px; + padding-right:15px; + background-image:none; + background-repeat:no-repeat; + background-position:right; + color: var(--footer-foreground-color); + font-size: 8pt; +} + + +div.summary +{ + float: right; + font-size: 8pt; + padding-right: 5px; + width: 50%; + text-align: right; +} + +div.summary a +{ + white-space: nowrap; +} + +table.classindex +{ + margin: 10px; + white-space: nowrap; + margin-left: 3%; + margin-right: 3%; + width: 94%; + border: 0; + border-spacing: 0; + padding: 0; +} + +div.ingroups +{ + font-size: 8pt; + width: 50%; + text-align: left; +} + +div.ingroups a +{ + white-space: nowrap; +} + +div.header +{ + background-image: var(--header-gradient-image); + background-repeat:repeat-x; + background-color: var(--header-background-color); + margin: 0px; + border-bottom: 1px solid var(--header-separator-color); +} + +div.headertitle +{ + padding: 5px 5px 5px 10px; +} + +.PageDocRTL-title div.headertitle { + text-align: right; + direction: rtl; +} + +dl { + padding: 0 0 0 0; +} + +/* + +dl.section { + margin-left: 0px; + padding-left: 0px; +} + +dl.note { + margin-left: -7px; + padding-left: 3px; + border-left: 4px solid; + border-color: #D0C000; +} + +dl.warning, dl.attention, dl.important { + margin-left: -7px; + padding-left: 3px; + border-left: 4px solid; + border-color: #FF0000; +} + +dl.pre, dl.post, dl.invariant { + margin-left: -7px; + padding-left: 3px; + border-left: 4px solid; + border-color: #00D000; +} + +dl.deprecated { + margin-left: -7px; + padding-left: 3px; + border-left: 4px solid; + border-color: #505050; +} + +dl.todo { + margin-left: -7px; + padding-left: 3px; + border-left: 4px solid; + border-color: #00C0E0; +} + +dl.test { + margin-left: -7px; + padding-left: 3px; + border-left: 4px solid; + border-color: #3030E0; +} + +dl.bug { + margin-left: -7px; + padding-left: 3px; + border-left: 4px solid; + border-color: #C08050; +} + +*/ + +dl.bug dt a, dl.deprecated dt a, dl.todo dt a, dl.test a { + font-weight: bold !important; +} + +dl.warning, dl.attention, dl.important, dl.note, dl.deprecated, dl.bug, +dl.invariant, dl.pre, dl.post, dl.todo, dl.test, dl.remark { + padding: 10px; + margin: 10px 0px; + overflow: hidden; + margin-left: 0; + border-radius: 4px; +} + +dl.section dd { + margin-bottom: 2px; +} + +dl.warning, dl.attention, dl.important { + background: var(--warning-color-bg); + border-left: 8px solid var(--warning-color-hl); + color: var(--warning-color-text); +} + +dl.warning dt, dl.attention dt, dl.important dt { + color: var(--warning-color-hl); +} + +dl.note, dl.remark { + background: var(--note-color-bg); + border-left: 8px solid var(--note-color-hl); + color: var(--note-color-text); +} + +dl.note dt, dl.remark dt { + color: var(--note-color-hl); +} + +dl.todo { + background: var(--todo-color-bg); + border-left: 8px solid var(--todo-color-hl); + color: var(--todo-color-text); +} + +dl.todo dt { + color: var(--todo-color-hl); +} + +dl.test { + background: var(--test-color-bg); + border-left: 8px solid var(--test-color-hl); + color: var(--test-color-text); +} + +dl.test dt { + color: var(--test-color-hl); +} + +dl.bug dt a { + color: var(--bug-color-hl) !important; +} + +dl.bug { + background: var(--bug-color-bg); + border-left: 8px solid var(--bug-color-hl); + color: var(--bug-color-text); +} + +dl.bug dt a { + color: var(--bug-color-hl) !important; +} + +dl.deprecated { + background: var(--deprecated-color-bg); + border-left: 8px solid var(--deprecated-color-hl); + color: var(--deprecated-color-text); +} + +dl.deprecated dt a { + color: var(--deprecated-color-hl) !important; +} + +dl.note dd, dl.warning dd, dl.pre dd, dl.post dd, +dl.remark dd, dl.attention dd, dl.important dd, dl.invariant dd, +dl.bug dd, dl.deprecated dd, dl.todo dd, dl.test dd { + margin-inline-start: 0px; +} + +dl.invariant, dl.pre, dl.post { + background: var(--invariant-color-bg); + border-left: 8px solid var(--invariant-color-hl); + color: var(--invariant-color-text); +} + +dl.invariant dt, dl.pre dt, dl.post dt { + color: var(--invariant-color-hl); +} + + +#projectrow +{ + height: 56px; +} + +#projectlogo +{ + text-align: center; + vertical-align: bottom; + border-collapse: separate; +} + +#projectlogo img +{ + border: 0px none; +} + +#projectalign +{ + vertical-align: middle; + padding-left: 0.5em; +} + +#projectname +{ + font-size: 200%; + font-family: var(--font-family-title); + margin: 0px; + padding: 2px 0px; +} + +#projectbrief +{ + font-size: 90%; + font-family: var(--font-family-title); + margin: 0px; + padding: 0px; +} + +#projectnumber +{ + font-size: 50%; + font-family: 50% var(--font-family-title); + margin: 0px; + padding: 0px; +} + +#titlearea +{ + padding: 0px; + margin: 0px; + width: 100%; + border-bottom: 1px solid var(--title-separator-color); + background-color: var(--title-background-color); +} + +.image +{ + text-align: center; +} + +.dotgraph +{ + text-align: center; +} + +.mscgraph +{ + text-align: center; +} + +.plantumlgraph +{ + text-align: center; +} + +.diagraph +{ + text-align: center; +} + +.caption +{ + font-weight: bold; +} + +dl.citelist { + margin-bottom:50px; +} + +dl.citelist dt { + color:var(--citation-label-color); + float:left; + font-weight:bold; + margin-right:10px; + padding:5px; + text-align:right; + width:52px; +} + +dl.citelist dd { + margin:2px 0 2px 72px; + padding:5px 0; +} + +div.toc { + padding: 14px 25px; + background-color: var(--toc-background-color); + border: 1px solid var(--toc-border-color); + border-radius: 7px 7px 7px 7px; + float: right; + height: auto; + margin: 0 8px 10px 10px; + width: 200px; +} + +div.toc li { + background: var(--toc-down-arrow-image) no-repeat scroll 0 5px transparent; + font: 10px/1.2 var(--font-family-toc); + margin-top: 5px; + padding-left: 10px; + padding-top: 2px; +} + +div.toc h3 { + font: bold 12px/1.2 var(--font-family-toc); + color: var(--toc-header-color); + border-bottom: 0 none; + margin: 0; +} + +div.toc ul { + list-style: none outside none; + border: medium none; + padding: 0px; +} + +div.toc li.level1 { + margin-left: 0px; +} + +div.toc li.level2 { + margin-left: 15px; +} + +div.toc li.level3 { + margin-left: 15px; +} + +div.toc li.level4 { + margin-left: 15px; +} + +span.emoji { + /* font family used at the site: https://unicode.org/emoji/charts/full-emoji-list.html + * font-family: "Noto Color Emoji", "Apple Color Emoji", "Segoe UI Emoji", Times, Symbola, Aegyptus, Code2000, Code2001, Code2002, Musica, serif, LastResort; + */ +} + +span.obfuscator { + display: none; +} + +.inherit_header { + font-weight: bold; + color: var(--inherit-header-color); + cursor: pointer; + -webkit-touch-callout: none; + -webkit-user-select: none; + -khtml-user-select: none; + -moz-user-select: none; + -ms-user-select: none; + user-select: none; +} + +.inherit_header td { + padding: 6px 0px 2px 5px; +} + +.inherit { + display: none; +} + +tr.heading h2 { + margin-top: 12px; + margin-bottom: 4px; +} + +/* tooltip related style info */ + +.ttc { + position: absolute; + display: none; +} + +#powerTip { + cursor: default; + /*white-space: nowrap;*/ + color: var(--tooltip-foreground-color); + background-color: var(--tooltip-background-color); + border: 1px solid var(--tooltip-border-color); + border-radius: 4px 4px 4px 4px; + box-shadow: var(--tooltip-shadow); + display: none; + font-size: smaller; + max-width: 80%; + opacity: 0.9; + padding: 1ex 1em 1em; + position: absolute; + z-index: 2147483647; +} + +#powerTip div.ttdoc { + color: var(--tooltip-doc-color); + font-style: italic; +} + +#powerTip div.ttname a { + font-weight: bold; +} + +#powerTip a { + color: var(--tooltip-link-color); +} + +#powerTip div.ttname { + font-weight: bold; +} + +#powerTip div.ttdeci { + color: var(--tooltip-declaration-color); +} + +#powerTip div { + margin: 0px; + padding: 0px; + font-size: 12px; + font-family: var(--font-family-tooltip); + line-height: 16px; +} + +#powerTip:before, #powerTip:after { + content: ""; + position: absolute; + margin: 0px; +} + +#powerTip.n:after, #powerTip.n:before, +#powerTip.s:after, #powerTip.s:before, +#powerTip.w:after, #powerTip.w:before, +#powerTip.e:after, #powerTip.e:before, +#powerTip.ne:after, #powerTip.ne:before, +#powerTip.se:after, #powerTip.se:before, +#powerTip.nw:after, #powerTip.nw:before, +#powerTip.sw:after, #powerTip.sw:before { + border: solid transparent; + content: " "; + height: 0; + width: 0; + position: absolute; +} + +#powerTip.n:after, #powerTip.s:after, +#powerTip.w:after, #powerTip.e:after, +#powerTip.nw:after, #powerTip.ne:after, +#powerTip.sw:after, #powerTip.se:after { + border-color: rgba(255, 255, 255, 0); +} + +#powerTip.n:before, #powerTip.s:before, +#powerTip.w:before, #powerTip.e:before, +#powerTip.nw:before, #powerTip.ne:before, +#powerTip.sw:before, #powerTip.se:before { + border-color: rgba(128, 128, 128, 0); +} + +#powerTip.n:after, #powerTip.n:before, +#powerTip.ne:after, #powerTip.ne:before, +#powerTip.nw:after, #powerTip.nw:before { + top: 100%; +} + +#powerTip.n:after, #powerTip.ne:after, #powerTip.nw:after { + border-top-color: var(--tooltip-background-color); + border-width: 10px; + margin: 0px -10px; +} +#powerTip.n:before, #powerTip.ne:before, #powerTip.nw:before { + border-top-color: var(--tooltip-border-color); + border-width: 11px; + margin: 0px -11px; +} +#powerTip.n:after, #powerTip.n:before { + left: 50%; +} + +#powerTip.nw:after, #powerTip.nw:before { + right: 14px; +} + +#powerTip.ne:after, #powerTip.ne:before { + left: 14px; +} + +#powerTip.s:after, #powerTip.s:before, +#powerTip.se:after, #powerTip.se:before, +#powerTip.sw:after, #powerTip.sw:before { + bottom: 100%; +} + +#powerTip.s:after, #powerTip.se:after, #powerTip.sw:after { + border-bottom-color: var(--tooltip-background-color); + border-width: 10px; + margin: 0px -10px; +} + +#powerTip.s:before, #powerTip.se:before, #powerTip.sw:before { + border-bottom-color: var(--tooltip-border-color); + border-width: 11px; + margin: 0px -11px; +} + +#powerTip.s:after, #powerTip.s:before { + left: 50%; +} + +#powerTip.sw:after, #powerTip.sw:before { + right: 14px; +} + +#powerTip.se:after, #powerTip.se:before { + left: 14px; +} + +#powerTip.e:after, #powerTip.e:before { + left: 100%; +} +#powerTip.e:after { + border-left-color: var(--tooltip-border-color); + border-width: 10px; + top: 50%; + margin-top: -10px; +} +#powerTip.e:before { + border-left-color: var(--tooltip-border-color); + border-width: 11px; + top: 50%; + margin-top: -11px; +} + +#powerTip.w:after, #powerTip.w:before { + right: 100%; +} +#powerTip.w:after { + border-right-color: var(--tooltip-border-color); + border-width: 10px; + top: 50%; + margin-top: -10px; +} +#powerTip.w:before { + border-right-color: var(--tooltip-border-color); + border-width: 11px; + top: 50%; + margin-top: -11px; +} + +@media print +{ + #top { display: none; } + #side-nav { display: none; } + #nav-path { display: none; } + body { overflow:visible; } + h1, h2, h3, h4, h5, h6 { page-break-after: avoid; } + .summary { display: none; } + .memitem { page-break-inside: avoid; } + #doc-content + { + margin-left:0 !important; + height:auto !important; + width:auto !important; + overflow:inherit; + display:inline; + } +} + +/* @group Markdown */ + +table.markdownTable { + border-collapse:collapse; + margin-top: 4px; + margin-bottom: 4px; +} + +table.markdownTable td, table.markdownTable th { + border: 1px solid var(--table-cell-border-color); + padding: 3px 7px 2px; +} + +table.markdownTable tr { +} + +th.markdownTableHeadLeft, th.markdownTableHeadRight, th.markdownTableHeadCenter, th.markdownTableHeadNone { + background-color: var(--table-header-background-color); + color: var(--table-header-foreground-color); + font-size: 110%; + padding-bottom: 4px; + padding-top: 5px; +} + +th.markdownTableHeadLeft, td.markdownTableBodyLeft { + text-align: left +} + +th.markdownTableHeadRight, td.markdownTableBodyRight { + text-align: right +} + +th.markdownTableHeadCenter, td.markdownTableBodyCenter { + text-align: center +} + +tt, code, kbd, samp +{ + display: inline-block; +} +/* @end */ + +u { + text-decoration: underline; +} + +details>summary { + list-style-type: none; +} + +details > summary::-webkit-details-marker { + display: none; +} + +details>summary::before { + content: "\25ba"; + padding-right:4px; + font-size: 80%; +} + +details[open]>summary::before { + content: "\25bc"; + padding-right:4px; + font-size: 80%; +} + +body { + scrollbar-color: var(--scrollbar-thumb-color) var(--scrollbar-background-color); +} + +::-webkit-scrollbar { + background-color: var(--scrollbar-background-color); + height: 12px; + width: 12px; +} +::-webkit-scrollbar-thumb { + border-radius: 6px; + box-shadow: inset 0 0 12px 12px var(--scrollbar-thumb-color); + border: solid 2px transparent; +} +::-webkit-scrollbar-corner { + background-color: var(--scrollbar-background-color); +} + diff --git a/sw/doxygen.svg b/sw/doxygen.svg new file mode 100644 index 0000000000..79a7635407 --- /dev/null +++ b/sw/doxygen.svg @@ -0,0 +1,28 @@ +<?xml version="1.0" encoding="UTF-8"?> +<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" + "https://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd"> +<svg version="1.1" viewBox="0 0 104 31" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink"> + <defs> + <linearGradient id="a"> + <stop stop-color="#5373B4" offset="0"/> + <stop stop-color="#7C95C6" offset="1"/> + </linearGradient> + <linearGradient id="d" x1="31.474" x2="31.474" y1="24.821" y2="26.773" gradientUnits="userSpaceOnUse" xlink:href="#a"/> + <linearGradient id="c" x1="31.474" x2="31.474" y1="24.821" y2="26.773" gradientTransform="matrix(.6816 0 0 1.0248 72.391 -.91809)" gradientUnits="userSpaceOnUse" xlink:href="#a"/> + <linearGradient id="b" x1="56.295" x2="56.295" y1="24.622" y2="26.574" gradientUnits="userSpaceOnUse" xlink:href="#a"/> + <linearGradient id="e" x1="49.067" x2="48.956" y1="19.719" y2="9.5227" gradientTransform="matrix(.97968 0 0 1.0207 -.25579 -.25579)" gradientUnits="userSpaceOnUse"> + <stop stop-color="#C0CCE3" offset="0"/> + <stop stop-color="#EEF1F7" offset="1"/> + </linearGradient> + <filter id="f" x="-.010676" y="-.045304" width="1.0214" height="1.0906" color-interpolation-filters="sRGB"> + <feGaussianBlur stdDeviation="0.45293203"/> + </filter> + </defs> + <g> + <path transform="translate(-2.5759 -27.848)" d="m13.609 32.203v6.8633h-0.05078c-0.40533-0.66867-0.96254-1.1715-1.6719-1.5059-0.69244-0.35193-1.4282-0.52734-2.2051-0.52734-0.96267 0-1.807 0.2027-2.5332 0.60742-0.72622 0.38713-1.3344 0.90556-1.8242 1.5566-0.47289 0.65108-0.83456 1.4092-1.0879 2.2715-0.23644 0.84464-0.35547 1.7236-0.35547 2.6387 0 0.95022 0.11902 1.8643 0.35547 2.7441 0.25333 0.87983 0.615 1.6633 1.0879 2.3496 0.48978 0.66867 1.1065 1.2066 1.8496 1.6113 0.74311 0.38713 1.6044 0.58008 2.584 0.58008 0.86133 0 1.6311-0.15787 2.3066-0.47461 0.69244-0.33434 1.2497-0.87227 1.6719-1.6113h0.05078v1.7422h3.4199v-18.846zm12.875 4.8301c-1.0302 0-1.9596 0.17541-2.7871 0.52734-0.82756 0.33434-1.5358 0.81965-2.127 1.4531-0.59111 0.61588-1.0483 1.3721-1.3691 2.2695-0.32089 0.87983-0.48047 1.866-0.48047 2.957s0.15958 2.0752 0.48047 2.9551c0.32089 0.87983 0.77803 1.6361 1.3691 2.2695 0.59111 0.61588 1.2994 1.0914 2.127 1.4258 0.82756 0.33434 1.7569 0.50195 2.7871 0.50195 1.0302 0 1.9596-0.16762 2.7871-0.50195 0.84444-0.33434 1.5612-0.8099 2.1523-1.4258 0.59111-0.63348 1.0483-1.3897 1.3691-2.2695 0.32089-0.87983 0.48047-1.8641 0.48047-2.9551s-0.15958-2.0772-0.48047-2.957c-0.32089-0.89743-0.77803-1.6536-1.3691-2.2695-0.59111-0.63348-1.3079-1.1188-2.1523-1.4531-0.82756-0.35193-1.7569-0.52734-2.7871-0.52734zm41.715 0c-0.912 0-1.7223 0.18516-2.4316 0.55469-0.69244 0.36953-1.2752 0.87043-1.748 1.5039-0.47289 0.61588-0.83651 1.337-1.0898 2.1641-0.23645 0.80944-0.35352 1.6553-0.35352 2.5352 0 0.93262 0.10007 1.8214 0.30273 2.666 0.21956 0.82704 0.55767 1.556 1.0137 2.1895 0.456 0.61588 1.0387 1.109 1.748 1.4785 0.70933 0.35193 1.5536 0.5293 2.5332 0.5293 0.79378 0 1.5446-0.16762 2.2539-0.50195 0.72622-0.35193 1.2834-0.88986 1.6719-1.6113h0.05078v1.7949c0.01689 0.96782-0.21071 1.7689-0.68359 2.4023-0.456 0.63348-1.1898 0.95117-2.2031 0.95117-0.64178 0-1.2075-0.14228-1.6973-0.42383-0.48978-0.26395-0.81939-0.74731-0.98828-1.4512h-3.5723c0.05067 0.77425 0.25276 1.435 0.60742 1.9805 0.37156 0.56309 0.8287 1.0192 1.3691 1.3711 0.55733 0.35193 1.1656 0.60726 1.8242 0.76562 0.67556 0.17597 1.3328 0.26562 1.9746 0.26562 1.5031 0 2.7025-0.21245 3.5977-0.63477 0.89511-0.42232 1.5798-0.94076 2.0527-1.5566 0.47289-0.59829 0.777-1.2493 0.91211-1.9531 0.152-0.70386 0.22656-1.3295 0.22656-1.875v-12.775h-3.4199v1.8223h-0.05078c-0.43911-0.79185-0.98782-1.3551-1.6465-1.6895-0.64178-0.33434-1.3926-0.50195-2.2539-0.50195zm16.523 0c-0.99644 0-1.9088 0.18516-2.7363 0.55469-0.81067 0.36953-1.5124 0.88018-2.1035 1.5312-0.59111 0.63348-1.0463 1.3897-1.3672 2.2695s-0.48047 1.831-0.48047 2.8516c0 1.0558 0.15108 2.0225 0.45508 2.9023 0.32089 0.87983 0.76758 1.6361 1.3418 2.2695 0.57422 0.63348 1.276 1.1266 2.1035 1.4785 0.82756 0.33434 1.7569 0.50195 2.7871 0.50195 1.4862 0 2.7517-0.35277 3.7988-1.0566 1.0471-0.70387 1.8254-1.8733 2.332-3.5098h-3.168c-0.11822 0.42232-0.43934 0.82772-0.96289 1.2148-0.52355 0.36953-1.1468 0.55274-1.873 0.55273-1.0133 0-1.7916-0.27286-2.332-0.81836-0.54044-0.5455-0.83605-1.4245-0.88672-2.6387h9.4492c0.06756-1.0558-0.01551-2.0673-0.25195-3.0352-0.23644-0.96782-0.62557-1.8293-1.166-2.5859-0.52356-0.75666-1.1998-1.355-2.0273-1.7949-0.82756-0.45751-1.7974-0.6875-2.9121-0.6875zm16.189 0c-0.76 0-1.5023 0.18516-2.2285 0.55469-0.72622 0.35193-1.3174 0.92299-1.7734 1.7148h-0.07617v-1.9004h-3.4199v13.646h3.5977v-7.1523c0-1.3901 0.21909-2.3841 0.6582-2.9824 0.43911-0.61588 1.1494-0.92383 2.1289-0.92383 0.86133 0 1.4611 0.28066 1.7988 0.84375 0.33777 0.5455 0.50586 1.3816 0.50586 2.5078v7.707h3.5976v-8.3926c0-0.84464-0.0765-1.6106-0.22851-2.2969-0.13511-0.70387-0.37971-1.2925-0.73438-1.7676-0.35466-0.49271-0.84386-0.87277-1.4688-1.1367-0.608-0.28155-1.3948-0.42188-2.3574-0.42188zm-66.063 0.36914 4.3066 6.4668-4.7129 7.1797h4.0293l2.7363-4.3027 2.7344 4.3027h4.1055l-4.8398-7.2578 4.3066-6.3887h-3.9766l-2.2793 3.5645-2.3066-3.5645zm13.275 0 4.584 12.803c0.10133 0.26395 0.15234 0.54461 0.15234 0.84375 0 0.40472-0.11707 0.77504-0.35352 1.1094-0.21956 0.33434-0.56617 0.52729-1.0391 0.58008-0.35467 0.0176-0.70979 0.0098-1.0645-0.02539-0.35467-0.03519-0.70128-0.07028-1.0391-0.10547v3.0879c0.37156 0.03519 0.73518 0.06051 1.0898 0.07813 0.37156 0.03519 0.74368 0.05273 1.1152 0.05273 1.2329 0 2.1943-0.23778 2.8867-0.71289 0.69244-0.47511 1.2326-1.2664 1.6211-2.375l5.4727-15.336h-3.7246l-2.8613 9.3438h-0.05078l-2.9648-9.3438zm-37.48 2.4551c0.59111 0 1.0823 0.12279 1.4707 0.36914 0.38844 0.24635 0.6991 0.57184 0.93555 0.97656 0.25333 0.38713 0.43187 0.84515 0.5332 1.373 0.10133 0.5103 0.15234 1.0482 0.15234 1.6113 0 0.56309-0.05101 1.1069-0.15234 1.6348-0.10133 0.5279-0.27137 1.0035-0.50781 1.4258-0.23644 0.40472-0.5556 0.73021-0.96094 0.97656-0.38844 0.24635-0.87959 0.36914-1.4707 0.36914-0.55733 0-1.038-0.12279-1.4434-0.36914-0.38844-0.26395-0.71806-0.59723-0.98828-1.002-0.25333-0.42232-0.43842-0.89788-0.55664-1.4258s-0.17773-1.0561-0.17773-1.584c-1e-7 -0.56309 0.05101-1.0991 0.15234-1.6094 0.11822-0.5279 0.29481-0.99567 0.53125-1.4004 0.25333-0.40472 0.58295-0.73021 0.98828-0.97656 0.40533-0.24635 0.90303-0.36914 1.4941-0.36914zm15.84 0c0.608 0 1.1142 0.13253 1.5195 0.39648 0.42222 0.24635 0.75184 0.57184 0.98828 0.97656 0.25333 0.40472 0.42992 0.87054 0.53125 1.3984 0.10133 0.5279 0.15234 1.0658 0.15234 1.6113 0 0.5455-0.05101 1.0815-0.15234 1.6094-0.10134 0.5103-0.27792 0.97612-0.53125 1.3984-0.23644 0.40472-0.56606 0.73021-0.98828 0.97656-0.40533 0.24635-0.91153 0.36914-1.5195 0.36914-0.608 0-1.1142-0.12279-1.5195-0.36914s-0.73495-0.57184-0.98828-0.97656c-0.23644-0.42232-0.40648-0.88814-0.50781-1.3984-0.10133-0.5279-0.15234-1.0639-0.15234-1.6094 0-0.5455 0.05101-1.0834 0.15234-1.6113 0.10133-0.5279 0.27137-0.99371 0.50781-1.3984 0.25333-0.40472 0.58295-0.73021 0.98828-0.97656 0.40533-0.26395 0.91153-0.39648 1.5195-0.39648zm42.602 0c0.59111 0 1.0803 0.11499 1.4688 0.34375 0.38844 0.22876 0.70105 0.5367 0.9375 0.92383 0.23644 0.38713 0.40648 0.8354 0.50781 1.3457 0.10133 0.49271 0.15039 1.0209 0.15039 1.584 0 0.4927-0.06606 0.96827-0.20117 1.4258-0.11822 0.43992-0.30526 0.83557-0.55859 1.1875-0.25333 0.35193-0.57445 0.63259-0.96289 0.84375-0.38844 0.21116-0.83513 0.31836-1.3418 0.31836-0.55733 0-1.021-0.12474-1.3926-0.37109-0.37156-0.24635-0.67566-0.56209-0.91211-0.94922-0.21956-0.38713-0.38109-0.81786-0.48242-1.293-0.08444-0.49271-0.12695-0.98581-0.12695-1.4785 0-0.5103 0.05101-0.99366 0.15234-1.4512 0.11822-0.47511 0.29676-0.89025 0.5332-1.2422 0.25333-0.36953 0.55744-0.65993 0.91211-0.87109 0.37156-0.21116 0.80974-0.31641 1.3164-0.31641zm15.535 0c0.87822 0 1.529 0.24753 1.9512 0.74023 0.43911 0.49271 0.74322 1.2138 0.91211 2.1641h-5.8535c0.01689-0.26395 0.0679-0.5641 0.15234-0.89844 0.10133-0.33434 0.26287-0.65008 0.48242-0.94922 0.23644-0.29914 0.54055-0.54667 0.91211-0.74023 0.38845-0.21116 0.86914-0.31641 1.4434-0.31641z" filter="url(#f)" opacity=".3" stroke="#969696"/> + <path d="m0.97202 24.161 43.605-0.0019 0.0508 3.3061-43.6 0.04174z" fill="url(#d)" stroke="#000" stroke-width=".5"/> + <path d="m10.283 3.5547v6.8633h-0.05078c-0.40533-0.66867-0.96254-1.1715-1.6719-1.5059-0.69244-0.35193-1.4282-0.52734-2.2051-0.52734-0.96267 0-1.807 0.2027-2.5332 0.60742-0.72622 0.38713-1.3344 0.90556-1.8242 1.5566-0.47289 0.65108-0.83456 1.4092-1.0879 2.2715-0.23644 0.84464-0.35547 1.7236-0.35547 2.6387 0 0.95022 0.11902 1.8643 0.35547 2.7441 0.25333 0.87983 0.615 1.6633 1.0879 2.3496 0.48978 0.66867 1.1065 1.2066 1.8496 1.6113 0.74311 0.38713 1.6044 0.58008 2.584 0.58008 0.86133 0 1.6311-0.15787 2.3066-0.47461 0.69244-0.33434 1.2497-0.87227 1.6719-1.6113h0.05078v1.7422h3.4199v-18.846zm12.875 4.8301c-1.0302 0-1.9596 0.17541-2.7871 0.52734-0.82756 0.33434-1.5358 0.81965-2.127 1.4531-0.59111 0.61588-1.0483 1.3721-1.3691 2.2695-0.32089 0.87983-0.48047 1.866-0.48047 2.957s0.15958 2.0752 0.48047 2.9551c0.32089 0.87983 0.77803 1.6361 1.3691 2.2695 0.59111 0.61588 1.2994 1.0914 2.127 1.4258 0.82756 0.33434 1.7569 0.50195 2.7871 0.50195 1.0302 0 1.9596-0.16762 2.7871-0.50195 0.84444-0.33434 1.5612-0.8099 2.1523-1.4258 0.59111-0.63348 1.0483-1.3897 1.3691-2.2695 0.32089-0.87983 0.48047-1.8641 0.48047-2.9551s-0.15958-2.0772-0.48047-2.957c-0.32089-0.89743-0.77803-1.6536-1.3691-2.2695-0.59111-0.63348-1.3079-1.1188-2.1523-1.4531-0.82756-0.35193-1.7569-0.52734-2.7871-0.52734zm41.715 0c-0.912 0-1.7223 0.18516-2.4316 0.55469-0.69244 0.36953-1.2752 0.87043-1.748 1.5039-0.47289 0.61588-0.83651 1.337-1.0898 2.1641-0.23644 0.80944-0.35352 1.6553-0.35352 2.5352 0 0.93262 0.10007 1.8214 0.30273 2.666 0.21956 0.82704 0.55767 1.556 1.0137 2.1895 0.456 0.61588 1.0387 1.109 1.748 1.4785 0.70933 0.35193 1.5536 0.5293 2.5332 0.5293 0.79378 0 1.5446-0.16762 2.2539-0.50195 0.72622-0.35193 1.2834-0.88986 1.6719-1.6113h0.05078v1.7949c0.01689 0.96782-0.21071 1.7689-0.68359 2.4023-0.456 0.63348-1.1898 0.95117-2.2031 0.95117-0.64178 0-1.2075-0.14228-1.6973-0.42383-0.48978-0.26395-0.81939-0.74731-0.98828-1.4512h-3.5723c0.05067 0.77425 0.25276 1.435 0.60742 1.9805 0.37156 0.56309 0.8287 1.0192 1.3691 1.3711 0.55733 0.35193 1.1656 0.60726 1.8242 0.76562 0.67556 0.17597 1.3328 0.26562 1.9746 0.26562 1.5031 0 2.7025-0.21245 3.5977-0.63477 0.89511-0.42232 1.5798-0.94076 2.0527-1.5566 0.47289-0.59829 0.777-1.2493 0.91211-1.9531 0.152-0.70386 0.22656-1.3295 0.22656-1.875v-12.775h-3.4199v1.8223h-0.05078c-0.43911-0.79185-0.98782-1.3551-1.6465-1.6895-0.64178-0.33434-1.3926-0.50195-2.2539-0.50195zm16.523 0c-0.99644 0-1.9088 0.18516-2.7363 0.55469-0.81067 0.36953-1.5124 0.88017-2.1035 1.5312-0.59111 0.63348-1.0463 1.3897-1.3672 2.2695s-0.48047 1.831-0.48047 2.8516c0 1.0558 0.15108 2.0225 0.45508 2.9023 0.32089 0.87983 0.76758 1.6361 1.3418 2.2695 0.57422 0.63348 1.276 1.1266 2.1035 1.4785 0.82756 0.33434 1.7569 0.50195 2.7871 0.50195 1.4862 0 2.7517-0.35278 3.7988-1.0566 1.0471-0.70386 1.8254-1.8733 2.332-3.5098h-3.168c-0.11822 0.42232-0.43934 0.82772-0.96289 1.2148-0.52355 0.36953-1.1468 0.55274-1.873 0.55273-1.0133 0-1.7916-0.27286-2.332-0.81836-0.54044-0.5455-0.83605-1.4245-0.88672-2.6387h9.4492c0.06756-1.0558-0.01551-2.0673-0.25195-3.0352-0.23644-0.96782-0.62557-1.8293-1.166-2.5859-0.52356-0.75666-1.1998-1.355-2.0273-1.7949-0.82756-0.45751-1.7974-0.6875-2.9121-0.6875zm16.189 0c-0.76 0-1.5023 0.18516-2.2285 0.55469-0.72622 0.35193-1.3174 0.923-1.7734 1.7148h-0.07617v-1.9004h-3.4199v13.646h3.5977v-7.1523c0-1.3901 0.21909-2.3841 0.6582-2.9824 0.43911-0.61588 1.1494-0.92383 2.1289-0.92383 0.86133 0 1.461 0.28066 1.7988 0.84375 0.33778 0.5455 0.50586 1.3816 0.50586 2.5078v7.707h3.5977v-8.3926c0-0.84464-0.0765-1.6106-0.22852-2.2969-0.13511-0.70387-0.3797-1.2925-0.73437-1.7676-0.35466-0.49271-0.84386-0.87277-1.4688-1.1367-0.608-0.28155-1.3948-0.42188-2.3574-0.42188zm-66.062 0.36914 4.3066 6.4668-4.7129 7.1797h4.0293l2.7363-4.3027 2.7344 4.3027h4.1055l-4.8398-7.2578 4.3066-6.3887h-3.9766l-2.2793 3.5645-2.3066-3.5645zm13.275 0 4.584 12.803c0.10133 0.26395 0.15234 0.54461 0.15234 0.84375 0 0.40472-0.11707 0.77504-0.35352 1.1094-0.21956 0.33434-0.56617 0.52729-1.0391 0.58008-0.35467 0.0176-0.70979 0.0098-1.0645-0.02539-0.35467-0.03519-0.70128-0.07027-1.0391-0.10547v3.0879c0.37156 0.03519 0.73518 0.06052 1.0898 0.07813 0.37156 0.03519 0.74368 0.05273 1.1152 0.05273 1.2329 0 2.1943-0.23778 2.8867-0.71289 0.69244-0.47511 1.2326-1.2664 1.6211-2.375l5.4727-15.336h-3.7246l-2.8613 9.3437h-0.05078l-2.9648-9.3437zm-37.48 2.4551c0.59111 0 1.0823 0.12279 1.4707 0.36914s0.6991 0.57184 0.93555 0.97656c0.25333 0.38713 0.43187 0.84515 0.5332 1.373 0.10133 0.5103 0.15234 1.0482 0.15234 1.6113 0 0.56309-0.05101 1.1069-0.15234 1.6348-0.10133 0.5279-0.27137 1.0035-0.50781 1.4258-0.23644 0.40472-0.5556 0.73021-0.96094 0.97656-0.38844 0.24635-0.87959 0.36914-1.4707 0.36914-0.55733 0-1.038-0.12279-1.4434-0.36914-0.38844-0.26395-0.71806-0.59723-0.98828-1.002-0.25333-0.42232-0.43842-0.89788-0.55664-1.4258s-0.17773-1.0561-0.17773-1.584c-1e-7 -0.56309 0.05101-1.0991 0.15234-1.6094 0.11822-0.5279 0.29481-0.99567 0.53125-1.4004 0.25333-0.40472 0.58295-0.73021 0.98828-0.97656 0.40533-0.24635 0.90303-0.36914 1.4941-0.36914zm15.84 0c0.608 0 1.1142 0.13254 1.5195 0.39648 0.42222 0.24635 0.75184 0.57184 0.98828 0.97656 0.25333 0.40472 0.42992 0.87054 0.53125 1.3984 0.10133 0.5279 0.15234 1.0658 0.15234 1.6113 0 0.5455-0.05101 1.0815-0.15234 1.6094-0.10133 0.5103-0.27792 0.97612-0.53125 1.3984-0.23644 0.40472-0.56606 0.73021-0.98828 0.97656-0.40533 0.24635-0.91153 0.36914-1.5195 0.36914-0.608 0-1.1142-0.12279-1.5195-0.36914s-0.73495-0.57184-0.98828-0.97656c-0.23644-0.42232-0.40648-0.88813-0.50781-1.3984-0.10133-0.5279-0.15234-1.0639-0.15234-1.6094 0-0.5455 0.05101-1.0834 0.15234-1.6113 0.10133-0.5279 0.27137-0.99371 0.50781-1.3984 0.25333-0.40472 0.58295-0.73021 0.98828-0.97656 0.40533-0.26395 0.91153-0.39648 1.5195-0.39648zm42.602 0c0.59111 0 1.0803 0.11499 1.4688 0.34375 0.38844 0.22876 0.70106 0.5367 0.9375 0.92383 0.23644 0.38713 0.40648 0.8354 0.50781 1.3457 0.10133 0.49271 0.15039 1.0209 0.15039 1.584 0 0.49271-0.06606 0.96827-0.20117 1.4258-0.11822 0.43992-0.30526 0.83557-0.55859 1.1875-0.25333 0.35193-0.57445 0.63259-0.96289 0.84375-0.38844 0.21116-0.83513 0.31836-1.3418 0.31836-0.55733 0-1.021-0.12474-1.3926-0.37109-0.37156-0.24635-0.67566-0.56209-0.91211-0.94922-0.21956-0.38713-0.38109-0.81786-0.48242-1.293-0.08444-0.49271-0.12695-0.98581-0.12695-1.4785 0-0.5103 0.05101-0.99366 0.15234-1.4512 0.11822-0.47511 0.29676-0.89026 0.5332-1.2422 0.25333-0.36953 0.55744-0.65993 0.91211-0.87109 0.37156-0.21116 0.80974-0.31641 1.3164-0.31641zm15.535 0c0.87822 0 1.529 0.24753 1.9512 0.74024 0.43911 0.49271 0.74322 1.2138 0.91211 2.1641h-5.8535c0.01689-0.26395 0.0679-0.5641 0.15234-0.89844 0.10133-0.33434 0.26287-0.65008 0.48242-0.94922 0.23644-0.29914 0.54055-0.54667 0.91211-0.74023 0.38845-0.21116 0.86914-0.31641 1.4434-0.31641z" fill="url(#e)" stroke="#4665A2" stroke-width=".7"/> + <path d="m52.988 27.291c0.99602-1.0359 1.3944-1.8725 1.7928-3.1076l3.8247-0.03984c0.3113 1.6096 0.82413 2.5137 1.6335 3.1474z" fill="url(#b)" stroke="#000" stroke-width=".5"/> + <path d="m73.89 24.04 28.885-0.2011-0.12476 3.3879-31.033 0.16229c1.2621-1.0234 1.9665-2.2859 2.2724-3.3491z" fill="url(#c)" stroke="#000" stroke-width=".41788"/> + </g> +</svg> diff --git a/sw/doxygen_crawl.html b/sw/doxygen_crawl.html new file mode 100644 index 0000000000..79657e3d07 --- /dev/null +++ b/sw/doxygen_crawl.html @@ -0,0 +1,2128 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<title>Validator / crawler helper</title> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +</head> +<body> +<a href="onewire__aux_8h_source.html"/> +<a href="neorv32__spi__irq_8h_source.html"/> +<a href="dhry_8h_source.html"/> +<a href="float__corner__test_2neorv32__zfinx__extension__intrinsics_8h_source.html"/> +<a href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h_source.html"/> +<a href="neorv32_8h_source.html"/> +<a href="neorv32__aux_8h_source.html"/> +<a href="neorv32__cfs_8h_source.html"/> +<a href="neorv32__cpu_8h_source.html"/> +<a href="neorv32__cpu__amo_8h_source.html"/> +<a href="neorv32__cpu__cfu_8h_source.html"/> +<a href="neorv32__cpu__csr_8h_source.html"/> +<a href="neorv32__crc_8h_source.html"/> +<a href="neorv32__dma_8h_source.html"/> +<a href="neorv32__gpio_8h_source.html"/> +<a href="neorv32__gptmr_8h_source.html"/> +<a href="neorv32__intrinsics_8h_source.html"/> +<a href="neorv32__legacy_8h_source.html"/> +<a href="neorv32__mtime_8h_source.html"/> +<a href="neorv32__neoled_8h_source.html"/> +<a href="neorv32__onewire_8h_source.html"/> +<a href="neorv32__pwm_8h_source.html"/> +<a href="neorv32__rte_8h_source.html"/> +<a href="neorv32__sdi_8h_source.html"/> +<a href="neorv32__slink_8h_source.html"/> +<a href="neorv32__spi_8h_source.html"/> +<a href="neorv32__sysinfo_8h_source.html"/> +<a href="neorv32__trng_8h_source.html"/> +<a href="neorv32__twi_8h_source.html"/> +<a href="neorv32__uart_8h_source.html"/> +<a href="neorv32__wdt_8h_source.html"/> +<a href="neorv32__xip_8h_source.html"/> +<a href="neorv32__xirq_8h_source.html"/> +<a href="bootloader_8c.html"/> +<a href="neorv32__spi__irq_8c.html"/> +<a href="neorv32__spi__irq_8h.html"/> +<a href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html"/> +<a href="atomic__test_2main_8c.html"/> +<a href="bus__explorer_2main_8c.html"/> +<a href="demo__blink__led_2main_8c.html"/> +<a href="demo__cfs_2main_8c.html"/> +<a href="demo__cfu_2main_8c.html"/> +<a href="demo__crc_2main_8c.html"/> +<a href="demo__dma_2main_8c.html"/> +<a href="demo__emulate__unaligned_2main_8c.html"/> +<a href="demo__gptmr_2main_8c.html"/> +<a href="demo__hpm_2main_8c.html"/> +<a href="demo__mtime_2main_8c.html"/> +<a href="demo__neopixel_2main_8c.html"/> +<a href="demo__newlib_2main_8c.html"/> +<a href="demo__onewire_2main_8c.html"/> +<a href="demo__pwm_2main_8c.html"/> +<a href="demo__sdi_2main_8c.html"/> +<a href="demo__slink_2main_8c.html"/> +<a href="demo__spi_2main_8c.html"/> +<a href="demo__spi__irq_2main_8c.html"/> +<a href="demo__trng_2main_8c.html"/> +<a href="demo__twi_2main_8c.html"/> +<a href="demo__wdt_2main_8c.html"/> +<a href="demo__xip_2main_8c.html"/> +<a href="demo__xirq_2main_8c.html"/> +<a href="float__corner__test_2main_8c.html"/> +<a href="floating__point__test_2main_8c.html"/> +<a href="game__of__life_2main_8c.html"/> +<a href="hello__world_2main_8c.html"/> +<a href="processor__check_2main_8c.html"/> +<a href="neorv32_8h.html"/> +<a href="neorv32__aux_8h.html"/> +<a href="neorv32__cfs_8h.html"/> +<a href="neorv32__cpu_8h.html"/> +<a href="neorv32__cpu__amo_8h.html"/> +<a href="neorv32__cpu__cfu_8h.html"/> +<a href="neorv32__cpu__csr_8h.html"/> +<a href="neorv32__crc_8h.html"/> +<a href="neorv32__dma_8h.html"/> +<a href="neorv32__gpio_8h.html"/> +<a href="neorv32__gptmr_8h.html"/> +<a href="neorv32__intrinsics_8h.html"/> +<a href="neorv32__legacy_8h.html"/> +<a href="neorv32__mtime_8h.html"/> +<a href="neorv32__neoled_8h.html"/> +<a href="neorv32__onewire_8h.html"/> +<a href="neorv32__pwm_8h.html"/> +<a href="neorv32__rte_8h.html"/> +<a href="neorv32__sdi_8h.html"/> +<a href="neorv32__slink_8h.html"/> +<a href="neorv32__spi_8h.html"/> +<a href="neorv32__trng_8h.html"/> +<a href="neorv32__twi_8h.html"/> +<a href="neorv32__uart_8h.html"/> +<a href="neorv32__wdt_8h.html"/> +<a href="neorv32__xip_8h.html"/> +<a href="neorv32__xirq_8h.html"/> +<a href="neorv32__aux_8c.html"/> +<a href="neorv32__cfs_8c.html"/> +<a href="neorv32__cpu_8c.html"/> +<a href="neorv32__cpu__amo_8c.html"/> +<a href="neorv32__cpu__cfu_8c.html"/> +<a href="neorv32__crc_8c.html"/> +<a href="neorv32__gpio_8c.html"/> +<a href="neorv32__gptmr_8c.html"/> +<a href="neorv32__mtime_8c.html"/> +<a href="neorv32__neoled_8c.html"/> +<a href="neorv32__onewire_8c.html"/> +<a href="neorv32__pwm_8c.html"/> +<a href="neorv32__rte_8c.html"/> +<a href="neorv32__sdi_8c.html"/> +<a href="neorv32__slink_8c.html"/> +<a href="neorv32__spi_8c.html"/> +<a href="neorv32__trng_8c.html"/> +<a href="neorv32__twi_8c.html"/> +<a href="neorv32__uart_8c.html"/> +<a href="neorv32__wdt_8c.html"/> +<a href="neorv32__xip_8c.html"/> +<a href="neorv32__xirq_8c.html"/> +<a href="syscalls_8c.html"/> +<a href="md_README.html"/> +<a href="structdate__t.html"/> +<a href="unionfloat__conv__t.html"/> +<a href="structneorv32__cfs__t.html"/> +<a href="structneorv32__crc__t.html"/> +<a href="structneorv32__dma__t.html"/> +<a href="structneorv32__gpio__t.html"/> +<a href="structneorv32__gptmr__t.html"/> +<a href="structneorv32__mtime__t.html"/> +<a href="structneorv32__neoled__t.html"/> +<a href="structneorv32__onewire__t.html"/> +<a href="structneorv32__pwm__t.html"/> +<a href="structneorv32__sdi__t.html"/> +<a href="structneorv32__slink__t.html"/> +<a href="structneorv32__spi__t.html"/> +<a href="structneorv32__sysinfo__t.html"/> +<a href="structneorv32__trng__t.html"/> +<a href="structneorv32__twi__t.html"/> +<a href="structneorv32__uart__t.html"/> +<a href="structneorv32__wdt__t.html"/> +<a href="structneorv32__xip__t.html"/> +<a href="structneorv32__xirq__t.html"/> +<a href="structrecord.html"/> +<a href="unionsubwords16__t.html"/> +<a href="unionsubwords32__t.html"/> +<a href="unionsubwords64__t.html"/> +<a href="structt__neorv32__spi.html"/> +<a href="dir_449d8ba5f8b78dc90092f20d15a2386a.html"/> +<a href="dir_4316bb0e553b51b8b65560981547ce0f.html"/> +<a href="dir_0d2921e55a1172a4726516961ee96ab5.html"/> +<a href="dir_9a1c128d67c35790e92af404beb936aa.html"/> +<a href="dir_01cde3d98944a579dc3b5e43a5311a79.html"/> +<a href="dir_09a89dfa1596b6613cf2c29528a32844.html"/> +<a href="dir_bf935196a1ea0ca9cb42aae56d70946a.html"/> +<a href="dir_8c514361e1f16692c783b23503f30f16.html"/> +<a href="dir_2ba96d3140b089dada6fb9f817b7975f.html"/> +<a href="dir_b68ac2efc0c6ed3018151f7bb6c45670.html"/> +<a href="dir_93967190e0d2e549ceca77007097849b.html"/> +<a href="dir_8d341cbe0581f44e1ae95d82d74e8bc8.html"/> +<a href="dir_d68bb921df3f2482fe9ace49b286ab86.html"/> +<a href="dir_23717ebbabf7a51c0558262947e0fe3b.html"/> +<a href="dir_3b3bafc48b460f797485cc75b94aa81c.html"/> +<a href="dir_b683da3a5fc966bff32ebf7cda721811.html"/> +<a href="dir_c413aba6cb5da07a571465ba333950af.html"/> +<a href="dir_c2d46947bdd73c33f53326fc5ee3a272.html"/> +<a href="dir_4c113257314015688a865e1bb8429184.html"/> +<a href="dir_8f848e36ac87ced1c361afcc0549ca32.html"/> +<a href="dir_237db5b95db643499d4c20f0bc5f6a7d.html"/> +<a href="dir_ebeff77b922fbb914a1494857a82a38e.html"/> +<a href="dir_78d7bfa405ff3a31fa7539cfd8bc8262.html"/> +<a href="dir_b6b50782b8271d07dffbc5f0cb9ff3f4.html"/> +<a href="dir_5534fa9035f54ab438a41c43d6f7fc7a.html"/> +<a href="dir_b5eb9f7d151d147efb5dbda58439e4e7.html"/> +<a href="dir_9d04cdc586d6978be343bda7adcdc371.html"/> +<a href="dir_eea6eb9fd693422884580f70321908d2.html"/> +<a href="dir_f0f9b27afba2e8cc2da6e5fddcc1a8c9.html"/> +<a href="dir_23212395b5ee0866d2fdd629e0ddeae8.html"/> +<a href="dir_e9ffd83269fb7f0c372f5ffbe8545008.html"/> +<a href="dir_46981071cfd8ec44311b09fdcf6c06a8.html"/> +<a href="dir_d4640980cbf1943e4a4aee6e8b810c7a.html"/> +<a href="dir_f05036e2ccd24a7119a5bbccebab20b2.html"/> +<a href="dir_752b1e5d3973bf735fa78bf6b4727df9.html"/> +<a href="dir_7d04193005ada6f9450f847f4adb6b5b.html"/> +<a href="dir_6a888d76b0f727dc821f77838927e542.html"/> +<a href="dir_0f35fd52d2216117815d19d974239550.html"/> +<a href="dir_7a2c74f70a4cdf2e836a07048e2f71dd.html"/> +<a href="dir_0c6ac14e2254a316d41123f98feeb67b.html"/> +<a href="dir_01fcd3835fb4e7d9331b722d86291b65.html"/> +<a href="dir_4bd1267d34feeec0f679c16f884588e7.html"/> +<a href="index.html"/> +<a href="doxygen_crawl.html"/> +<a href="pages.html"/> +<a href="annotated.html"/> +<a href="classes.html"/> +<a href="functions.html"/> +<a href="functions.html"/> +<a href="functions.html"/> +<a href="functions.html"/> +<a href="functions.html"/> +<a href="functions.html"/> +<a href="functions.html"/> +<a href="functions.html"/> +<a href="functions.html"/> +<a href="functions.html"/> +<a href="functions.html"/> +<a href="functions.html"/> +<a href="functions.html"/> +<a href="functions.html"/> +<a href="functions.html"/> +<a href="functions.html"/> +<a href="functions_vars.html"/> +<a href="functions_vars.html"/> +<a href="functions_vars.html"/> +<a href="functions_vars.html"/> +<a href="functions_vars.html"/> +<a href="functions_vars.html"/> +<a href="functions_vars.html"/> +<a href="functions_vars.html"/> +<a href="functions_vars.html"/> +<a href="functions_vars.html"/> +<a href="functions_vars.html"/> +<a href="functions_vars.html"/> +<a href="functions_vars.html"/> +<a href="functions_vars.html"/> +<a href="functions_vars.html"/> +<a href="functions_vars.html"/> +<a href="files.html"/> +<a href="globals.html"/> +<a href="globals_a.html"/> +<a href="globals_b.html"/> +<a href="globals_c.html"/> +<a href="globals_d.html"/> +<a href="globals_e.html"/> +<a href="globals_f.html"/> +<a href="globals_g.html"/> +<a href="globals_h.html"/> +<a href="globals_i.html"/> +<a href="globals_k.html"/> +<a href="globals_m.html"/> +<a href="globals_n.html"/> +<a href="globals_o.html"/> +<a href="globals_p.html"/> +<a href="globals_r.html"/> +<a href="globals_s.html"/> +<a href="globals_t.html"/> +<a href="globals_u.html"/> +<a href="globals_v.html"/> +<a href="globals_w.html"/> +<a href="globals_x.html"/> +<a href="globals_func.html"/> +<a href="globals_func_a.html"/> +<a href="globals_func_b.html"/> +<a href="globals_func_c.html"/> +<a href="globals_func_d.html"/> +<a href="globals_func_g.html"/> +<a href="globals_func_h.html"/> +<a href="globals_func_m.html"/> +<a href="globals_func_n.html"/> +<a href="globals_func_p.html"/> +<a href="globals_func_r.html"/> +<a href="globals_func_s.html"/> +<a href="globals_func_t.html"/> +<a href="globals_func_u.html"/> +<a href="globals_func_v.html"/> +<a href="globals_func_w.html"/> +<a href="globals_func_x.html"/> +<a href="globals_vars.html"/> +<a href="globals_vars.html"/> +<a href="globals_vars.html"/> +<a href="globals_vars.html"/> +<a href="globals_vars.html"/> +<a href="globals_vars.html"/> +<a href="globals_vars.html"/> +<a href="globals_vars.html"/> +<a href="globals_vars.html"/> +<a href="globals_vars.html"/> +<a href="globals_vars.html"/> +<a href="globals_vars.html"/> +<a href="globals_vars.html"/> +<a href="globals_enum.html"/> +<a href="globals_enum.html"/> +<a href="globals_enum.html"/> +<a href="globals_eval.html"/> +<a href="globals_eval_d.html"/> +<a href="globals_eval_e.html"/> +<a href="globals_eval_f.html"/> +<a href="globals_eval_g.html"/> +<a href="globals_eval_h.html"/> +<a href="globals_eval_n.html"/> +<a href="globals_eval_o.html"/> +<a href="globals_eval_p.html"/> +<a href="globals_eval_r.html"/> +<a href="globals_eval_s.html"/> +<a href="globals_eval_t.html"/> +<a href="globals_eval_u.html"/> +<a href="globals_eval_w.html"/> +<a href="globals_eval_x.html"/> +<a href="globals_defs.html"/> +<a href="globals_defs_b.html"/> +<a href="globals_defs_c.html"/> +<a href="globals_defs_d.html"/> +<a href="globals_defs_e.html"/> +<a href="globals_defs_f.html"/> +<a href="globals_defs_g.html"/> +<a href="globals_defs_i.html"/> +<a href="globals_defs_m.html"/> +<a href="globals_defs_n.html"/> +<a href="globals_defs_o.html"/> +<a href="globals_defs_p.html"/> +<a href="globals_defs_r.html"/> +<a href="globals_defs_s.html"/> +<a href="globals_defs_t.html"/> +<a href="globals_defs_u.html"/> +<a href="globals_defs_w.html"/> +<a href="globals_defs_x.html"/> +<a href="annotated.html"/> +<a href="atomic__test_2main_8c.html"/> +<a href="atomic__test_2main_8c.html#a4f4c6d8481b4100f90955ba5a70428a4"/> +<a href="atomic__test_2main_8c.html#a83792c34853f1d2801b59ad46adc7e1e"/> +<a href="atomic__test_2main_8c.html#a87f296d7594bb8178cf76f0c045b7013"/> +<a href="atomic__test_2main_8c.html#a9141e95a5f98420ddf8a43e6d20ff6dc"/> +<a href="atomic__test_2main_8c.html#a99377a057d14aaa9b45f8cab890e8cf7"/> +<a href="atomic__test_2main_8c.html#aafcbf639ae4f66e5dfe9dea511a59f9d"/> +<a href="atomic__test_2main_8c.html#ad4455691936f92fdd6c37566fc58ba1f"/> +<a href="atomic__test_2main_8c.html#ae66f6b31b5ad750f1fe042a706a4e3d4"/> +<a href="bootloader_8c.html"/> +<a href="bootloader_8c.html#a0035ad41f622dbfc2412318a8ed39257"/> +<a href="bootloader_8c.html#a005966cd0b32f3d5c041028c4b1c99f5"/> +<a href="bootloader_8c.html#a006c27b7d80897b78ab8cd83a391331f"/> +<a href="bootloader_8c.html#a00924a8ba223b2ca0e7031259b292c84"/> +<a href="bootloader_8c.html#a089a71f836911c71b3f73fdd3b4b890b"/> +<a href="bootloader_8c.html#a09e72e2debdd94929b2be4c7713d5e17"/> +<a href="bootloader_8c.html#a0d877f0611dfcee32a483c8a3660eb1b"/> +<a href="bootloader_8c.html#a0e5a66f68ecc7a6f42088f349707e852"/> +<a href="bootloader_8c.html#a0f9fcfdf758260b9b79b6eda063dd87a"/> +<a href="bootloader_8c.html#a165a347c51d8aae06a564a2f297f2feb"/> +<a href="bootloader_8c.html#a165a347c51d8aae06a564a2f297f2feba61100996f309c45b8b628ade2e3acc7f"/> +<a href="bootloader_8c.html#a165a347c51d8aae06a564a2f297f2febabc27a855096a70dca0f8bc148a123be4"/> +<a href="bootloader_8c.html#a165a347c51d8aae06a564a2f297f2febacc430caa4bff2fef4568c757893fe2fe"/> +<a href="bootloader_8c.html#a165a347c51d8aae06a564a2f297f2febaea032c54a21057710ef2021638972ce6"/> +<a href="bootloader_8c.html#a18936dc79b9e5aa84df016b046a6b977"/> +<a href="bootloader_8c.html#a1919595ed2232aebb3e774b916ab1662"/> +<a href="bootloader_8c.html#a1fac9153314479ad0ad495d752f0224a"/> +<a href="bootloader_8c.html#a1fbdccc60f05756213c9f3d64bac6d47"/> +<a href="bootloader_8c.html#a20e93d623ce07939c3fdd53898f9d583"/> +<a href="bootloader_8c.html#a2cf31934b909299fb93bb5eebdbc7c9e"/> +<a href="bootloader_8c.html#a2f5cc04cf9c85f5d2958b384e053053b"/> +<a href="bootloader_8c.html#a3bdfe2f25b1bfb42f80624ffff22ab01"/> +<a href="bootloader_8c.html#a402ea961bfc2ffeee61e3a7c330b1559"/> +<a href="bootloader_8c.html#a418adcf57119600c3580fd2297d28de0"/> +<a href="bootloader_8c.html#a5fa6b109bf211d1768f84c9d38eef240"/> +<a href="bootloader_8c.html#a6a8caddda6e729d747726471b0b0f742"/> +<a href="bootloader_8c.html#a6fea855ffe2fa0cd5ea9f98c0d5adc4d"/> +<a href="bootloader_8c.html#a709071a651213770b4efe6e6e055ec3d"/> +<a href="bootloader_8c.html#a70b7d5c3b3ae97e4e72e84c4bc28fb8a"/> +<a href="bootloader_8c.html#a717c72166af7c2ff7e73bd0b47128338"/> +<a href="bootloader_8c.html#a82d26a2d6293ed7fd44a5c622adfbd45"/> +<a href="bootloader_8c.html#a840291bc02cba5474a4cb46a9b9566fe"/> +<a href="bootloader_8c.html#a9642e28ef2baec5b356ad9a70970d0e6"/> +<a href="bootloader_8c.html#a97299f563ebc1fca4c663b025a15136f"/> +<a href="bootloader_8c.html#a97299f563ebc1fca4c663b025a15136fa133cd87673ce9a612da494583e03dae9"/> +<a href="bootloader_8c.html#a97299f563ebc1fca4c663b025a15136fa22e8c983d74430ea0930e37781e88bf9"/> +<a href="bootloader_8c.html#a999b04603115ce08b0cb33e333312480"/> +<a href="bootloader_8c.html#aa0c639898508ff8e4fab6290101f3088"/> +<a href="bootloader_8c.html#aa0c639898508ff8e4fab6290101f3088a2d77ed1c715fb969a1faa01c71625f2d"/> +<a href="bootloader_8c.html#aa0c639898508ff8e4fab6290101f3088a471ebe6c0766abc6fa4e82a09bfdb985"/> +<a href="bootloader_8c.html#aa0c639898508ff8e4fab6290101f3088a684d6723fa25e7651e13d99fb249363c"/> +<a href="bootloader_8c.html#aa0c639898508ff8e4fab6290101f3088ad41014563cb3ca69ab69b94d43e97caa"/> +<a href="bootloader_8c.html#aa2132454aada86216009f3af206899b1"/> +<a href="bootloader_8c.html#aa5e5723e4cbf83805c3b1197cd401fed"/> +<a href="bootloader_8c.html#aa5e5723e4cbf83805c3b1197cd401feda152e091e93778f217f8b766298351513"/> +<a href="bootloader_8c.html#aa5e5723e4cbf83805c3b1197cd401feda25bf16cd42b1fd1d95e0957b5be137d2"/> +<a href="bootloader_8c.html#aa5e5723e4cbf83805c3b1197cd401feda31c8d698c551d081a0adeafb988ed49e"/> +<a href="bootloader_8c.html#aa5e5723e4cbf83805c3b1197cd401feda5fbc6551a10549b38e5ab4a76c38f214"/> +<a href="bootloader_8c.html#aa5e5723e4cbf83805c3b1197cd401feda6c1994ba2cfd97e0c77dcdf8bbdfdfa6"/> +<a href="bootloader_8c.html#aa5e5723e4cbf83805c3b1197cd401fedaa91d3c1d788b21fc798a5976c9f0da77"/> +<a href="bootloader_8c.html#aa5e5723e4cbf83805c3b1197cd401fedacd62141d6331f66e31bd252e2a92b836"/> +<a href="bootloader_8c.html#aa7afbe8348ebd1a876a4d247553292e9"/> +<a href="bootloader_8c.html#aa9696325b450773c7a87c991abca3a54"/> +<a href="bootloader_8c.html#ababfffe8e7036179e150ad3b9bda3a74"/> +<a href="bootloader_8c.html#abcbf77626fdd0b475d245f836eab7a83"/> +<a href="bootloader_8c.html#abcbf77626fdd0b475d245f836eab7a83a98526cd8f81d570c57d98193b32cf114"/> +<a href="bootloader_8c.html#abcbf77626fdd0b475d245f836eab7a83ab149261ddf3f08e44e9d2538e384f58f"/> +<a href="bootloader_8c.html#ac18819795adb6dbdd52b0587e7fbb569"/> +<a href="bootloader_8c.html#ac58d9f7dc79a549bde1cb50f619c19af"/> +<a href="bootloader_8c.html#ae8de91537ac2782f0f0ebc3b2d4fb1df"/> +<a href="bootloader_8c.html#aea75cf0485ce0a4ea320eba994859686"/> +<a href="bootloader_8c.html#af13b4b3d5e6597feacf331e6d16b08e9"/> +<a href="bootloader_8c.html#af1c2f103ac6e3183f08b39099fab2be9"/> +<a href="bootloader_8c.html#af6cf19e40e97afb5a7c29f7b439d091d"/> +<a href="bootloader_8c.html#af6fcb607a9c320da869b72aa30893a69"/> +<a href="bootloader_8c.html#afe60a31c8561952f2f734fd67e6f7406"/> +<a href="bootloader_8c.html#aff6b53dd58cea43d24393a9a2f79e772"/> +<a href="bus__explorer_2main_8c.html"/> +<a href="bus__explorer_2main_8c.html#a02640a99db37b8d92b9edffc9720a210"/> +<a href="bus__explorer_2main_8c.html#a2b6196c2e97a7f7702c0068780304ec1"/> +<a href="bus__explorer_2main_8c.html#a6405739c6012158151eb082c31c312da"/> +<a href="bus__explorer_2main_8c.html#a96729fb5279642ac56c8e6a513789b45"/> +<a href="bus__explorer_2main_8c.html#ac582208281cd6fce4eb61c234f312ef6"/> +<a href="bus__explorer_2main_8c.html#ad4455691936f92fdd6c37566fc58ba1f"/> +<a href="bus__explorer_2main_8c.html#ae66f6b31b5ad750f1fe042a706a4e3d4"/> +<a href="bus__explorer_2main_8c.html#afc9b1ab3db46eccf51d55c715fa2fbd4"/> +<a href="classes.html"/> +<a href="demo__blink__led_2main_8c.html"/> +<a href="demo__blink__led_2main_8c.html#ae66f6b31b5ad750f1fe042a706a4e3d4"/> +<a href="demo__cfs_2main_8c.html"/> +<a href="demo__cfs_2main_8c.html#a906949f076e3e0d0082af3c3b1acb518"/> +<a href="demo__cfs_2main_8c.html#ad4455691936f92fdd6c37566fc58ba1f"/> +<a href="demo__cfs_2main_8c.html#ae66f6b31b5ad750f1fe042a706a4e3d4"/> +<a href="demo__cfu_2main_8c.html"/> +<a href="demo__cfu_2main_8c.html#a094212e3731a9aecbd278fac243de6ec"/> +<a href="demo__cfu_2main_8c.html#a0e980c5d81b1eca90b8073e54099bdb0"/> +<a href="demo__cfu_2main_8c.html#a26da64691624f3c899f2394a427d6593"/> +<a href="demo__cfu_2main_8c.html#a2d3853c367c3bce99e787c0df445030a"/> +<a href="demo__cfu_2main_8c.html#a2e2ccb9136736a673dbef71f207e97a0"/> +<a href="demo__cfu_2main_8c.html#a33b2d9298edf94c5961e67a59c371d00"/> +<a href="demo__cfu_2main_8c.html#a34755f457331741d24090b3819b5d416"/> +<a href="demo__cfu_2main_8c.html#a72ba1460776ad684028448ca51810bbe"/> +<a href="demo__cfu_2main_8c.html#a8dc502bf508491eed1f39c4acf040efb"/> +<a href="demo__cfu_2main_8c.html#a9ad2780a4cfe0d9cb4f1a846a92063ae"/> +<a href="demo__cfu_2main_8c.html#ab5c498f9da12ab2d6ddc89bf4a46dec6"/> +<a href="demo__cfu_2main_8c.html#ac637695e266f3af7799e352b374412ad"/> +<a href="demo__cfu_2main_8c.html#acb6dd9d6ab74ac94f174a11ff3ad76af"/> +<a href="demo__cfu_2main_8c.html#ad424a26173bd8d84b8d1cae94a55f248"/> +<a href="demo__cfu_2main_8c.html#ad4455691936f92fdd6c37566fc58ba1f"/> +<a href="demo__cfu_2main_8c.html#ae66f6b31b5ad750f1fe042a706a4e3d4"/> +<a href="demo__cfu_2main_8c.html#aee8dde13fe2f5ac52dd6075e2fe1eab5"/> +<a href="demo__crc_2main_8c.html"/> +<a href="demo__crc_2main_8c.html#ad4455691936f92fdd6c37566fc58ba1f"/> +<a href="demo__crc_2main_8c.html#ae66f6b31b5ad750f1fe042a706a4e3d4"/> +<a href="demo__dma_2main_8c.html"/> +<a href="demo__dma_2main_8c.html#a8ad0c7bfd07edb6d42d86b166347206b"/> +<a href="demo__dma_2main_8c.html#ad4455691936f92fdd6c37566fc58ba1f"/> +<a href="demo__dma_2main_8c.html#ae66f6b31b5ad750f1fe042a706a4e3d4"/> +<a href="demo__dma_2main_8c.html#aefcc5abb86a652587ff69be120a66487"/> +<a href="demo__emulate__unaligned_2main_8c.html"/> +<a href="demo__emulate__unaligned_2main_8c.html#a07da42351229525998965b219e827460"/> +<a href="demo__emulate__unaligned_2main_8c.html#a4407b4d6eae3ba7fe9538b1242a7e165"/> +<a href="demo__emulate__unaligned_2main_8c.html#a556f675911f865ead06c36072b1b9c3b"/> +<a href="demo__emulate__unaligned_2main_8c.html#ad4455691936f92fdd6c37566fc58ba1f"/> +<a href="demo__emulate__unaligned_2main_8c.html#ae66f6b31b5ad750f1fe042a706a4e3d4"/> +<a href="demo__gptmr_2main_8c.html"/> +<a href="demo__gptmr_2main_8c.html#a2bd89412466a65329711bfd5c29199c9"/> +<a href="demo__gptmr_2main_8c.html#ad4455691936f92fdd6c37566fc58ba1f"/> +<a href="demo__gptmr_2main_8c.html#ae66f6b31b5ad750f1fe042a706a4e3d4"/> +<a href="demo__hpm_2main_8c.html"/> +<a href="demo__hpm_2main_8c.html#ad4455691936f92fdd6c37566fc58ba1f"/> +<a href="demo__hpm_2main_8c.html#ae66f6b31b5ad750f1fe042a706a4e3d4"/> +<a href="demo__mtime_2main_8c.html"/> +<a href="demo__mtime_2main_8c.html#a329137855a7c2e098715a0771c5585d7"/> +<a href="demo__mtime_2main_8c.html#ae66f6b31b5ad750f1fe042a706a4e3d4"/> +<a href="demo__neopixel_2main_8c.html"/> +<a href="demo__neopixel_2main_8c.html#a1d1d5e7ff16f25b68fdf779befd298f7"/> +<a href="demo__neopixel_2main_8c.html#a2736ec755f9e10c80bf66f727f870ffc"/> +<a href="demo__neopixel_2main_8c.html#aa1dddb8d6b3b4d2f19afc3c09e2ff572"/> +<a href="demo__neopixel_2main_8c.html#ad4455691936f92fdd6c37566fc58ba1f"/> +<a href="demo__neopixel_2main_8c.html#ae66f6b31b5ad750f1fe042a706a4e3d4"/> +<a href="demo__newlib_2main_8c.html"/> +<a href="demo__newlib_2main_8c.html#aaa2cb9e7075a852870fd67eff2861b18"/> +<a href="demo__newlib_2main_8c.html#ad4455691936f92fdd6c37566fc58ba1f"/> +<a href="demo__newlib_2main_8c.html#ae66f6b31b5ad750f1fe042a706a4e3d4"/> +<a href="demo__onewire_2main_8c.html"/> +<a href="demo__onewire_2main_8c.html#a28283848f09bf8feebc860a51545f487"/> +<a href="demo__onewire_2main_8c.html#a29d5831498c2eaf0415d6f01efb9e7ce"/> +<a href="demo__onewire_2main_8c.html#a951a31029af34715f20856eb82432637"/> +<a href="demo__onewire_2main_8c.html#ac07c9cfd80ac2e24be9dac6cf943b7de"/> +<a href="demo__onewire_2main_8c.html#ad4455691936f92fdd6c37566fc58ba1f"/> +<a href="demo__onewire_2main_8c.html#ae66f6b31b5ad750f1fe042a706a4e3d4"/> +<a href="demo__onewire_2main_8c.html#af25820ed386a66a0d6bb4dcdd2204704"/> +<a href="demo__pwm_2main_8c.html"/> +<a href="demo__pwm_2main_8c.html#a391fa1e490bd712720989b58fa0d9904"/> +<a href="demo__pwm_2main_8c.html#ad4455691936f92fdd6c37566fc58ba1f"/> +<a href="demo__pwm_2main_8c.html#ae66f6b31b5ad750f1fe042a706a4e3d4"/> +<a href="demo__sdi_2main_8c.html"/> +<a href="demo__sdi_2main_8c.html#aa25f620a5631e862252be1d5429e8585"/> +<a href="demo__sdi_2main_8c.html#ad4455691936f92fdd6c37566fc58ba1f"/> +<a href="demo__sdi_2main_8c.html#ae3dc843520a800d7ba2b5d6be03d9c3d"/> +<a href="demo__sdi_2main_8c.html#ae66f6b31b5ad750f1fe042a706a4e3d4"/> +<a href="demo__slink_2main_8c.html"/> +<a href="demo__slink_2main_8c.html#a48c79e20ed1d4138d61b5593bdbe537a"/> +<a href="demo__slink_2main_8c.html#ad4455691936f92fdd6c37566fc58ba1f"/> +<a href="demo__slink_2main_8c.html#ae66f6b31b5ad750f1fe042a706a4e3d4"/> +<a href="demo__spi_2main_8c.html"/> +<a href="demo__spi_2main_8c.html#a13e10b34fbbffca6c31f0ce25b3f8432"/> +<a href="demo__spi_2main_8c.html#a6f94991b8943a141ed4124585222470d"/> +<a href="demo__spi_2main_8c.html#a755192be6c3cf9904564b0eee99de445"/> +<a href="demo__spi_2main_8c.html#ac582208281cd6fce4eb61c234f312ef6"/> +<a href="demo__spi_2main_8c.html#ad4455691936f92fdd6c37566fc58ba1f"/> +<a href="demo__spi_2main_8c.html#ae66f6b31b5ad750f1fe042a706a4e3d4"/> +<a href="demo__spi__irq_2main_8c.html"/> +<a href="demo__spi__irq_2main_8c.html#a7e266cc5247c999948dacc2102bd184a"/> +<a href="demo__spi__irq_2main_8c.html#ad4455691936f92fdd6c37566fc58ba1f"/> +<a href="demo__spi__irq_2main_8c.html#ae66f6b31b5ad750f1fe042a706a4e3d4"/> +<a href="demo__trng_2main_8c.html"/> +<a href="demo__trng_2main_8c.html#a23a91e6fe2cc44f3c29baf0d331e05db"/> +<a href="demo__trng_2main_8c.html#a4e49f5e3feb4bd5755f919cd3310b506"/> +<a href="demo__trng_2main_8c.html#a64205d97b57c99dc5e95b8621827f4a4"/> +<a href="demo__trng_2main_8c.html#a840291bc02cba5474a4cb46a9b9566fe"/> +<a href="demo__trng_2main_8c.html#abbde1237eed617466fb971a78c3acd1e"/> +<a href="demo__trng_2main_8c.html#ad4455691936f92fdd6c37566fc58ba1f"/> +<a href="demo__trng_2main_8c.html#af37eae672fee5e81f00a1dbf51b7e417"/> +<a href="demo__twi_2main_8c.html"/> +<a href="demo__twi_2main_8c.html#a2ebc688bc1dad328693fc0974b378fa0"/> +<a href="demo__twi_2main_8c.html#aa94edd4f55a3ac18913f661f4bc16fb1"/> +<a href="demo__twi_2main_8c.html#aace46ee34e954f9ebee5873beb0785f1"/> +<a href="demo__twi_2main_8c.html#acee0c1770467f85a150d072ac7e1252f"/> +<a href="demo__twi_2main_8c.html#ad4455691936f92fdd6c37566fc58ba1f"/> +<a href="demo__twi_2main_8c.html#ae66f6b31b5ad750f1fe042a706a4e3d4"/> +<a href="demo__wdt_2main_8c.html"/> +<a href="demo__wdt_2main_8c.html#a01af3905e60b1869f669315f4a1297f5"/> +<a href="demo__wdt_2main_8c.html#ad4455691936f92fdd6c37566fc58ba1f"/> +<a href="demo__wdt_2main_8c.html#ae66f6b31b5ad750f1fe042a706a4e3d4"/> +<a href="demo__xip_2main_8c.html"/> +<a href="demo__xip_2main_8c.html#a0035ad41f622dbfc2412318a8ed39257"/> +<a href="demo__xip_2main_8c.html#a0458656f8a108ff31f4bbbd005f029a0"/> +<a href="demo__xip_2main_8c.html#a23a9099a5f8fc9c6e253c0eecb2be8db"/> +<a href="demo__xip_2main_8c.html#a23bd7bd7b0808d919fd09ac0a8258498"/> +<a href="demo__xip_2main_8c.html#a3043d09bdc155f57f45cd91e0cd4d15b"/> +<a href="demo__xip_2main_8c.html#a4ddfa8fdc072cadeef18a4a10bc8b174"/> +<a href="demo__xip_2main_8c.html#a6b20d41d6252e9871430c242cb1a56e7"/> +<a href="demo__xip_2main_8c.html#a9e0b2714126b6699ddb65485c93293e4"/> +<a href="demo__xip_2main_8c.html#acc95e55a622d79c2a398397d1f9b8033"/> +<a href="demo__xip_2main_8c.html#ad4455691936f92fdd6c37566fc58ba1f"/> +<a href="demo__xip_2main_8c.html#adccf1bb8f1f203cb1350f7f2eb15a08e"/> +<a href="demo__xip_2main_8c.html#adccf1bb8f1f203cb1350f7f2eb15a08ea90f3b76faed13819ee13e574d1bff0c1"/> +<a href="demo__xip_2main_8c.html#adccf1bb8f1f203cb1350f7f2eb15a08eac84de63bbea3989c71bcc92d1d01cfa4"/> +<a href="demo__xip_2main_8c.html#ae66f6b31b5ad750f1fe042a706a4e3d4"/> +<a href="demo__xip_2main_8c.html#aec72efe062dbdb149ae6d4f8b1be6793"/> +<a href="demo__xip_2main_8c.html#af30de1c8d8502ad374612d308cfbd12e"/> +<a href="demo__xip_2main_8c.html#af30de1c8d8502ad374612d308cfbd12ea152e091e93778f217f8b766298351513"/> +<a href="demo__xip_2main_8c.html#af30de1c8d8502ad374612d308cfbd12ea528cebc54176f6f4c0a8f7f16fb28ca1"/> +<a href="demo__xip_2main_8c.html#af30de1c8d8502ad374612d308cfbd12ea5fbc6551a10549b38e5ab4a76c38f214"/> +<a href="demo__xip_2main_8c.html#af30de1c8d8502ad374612d308cfbd12ea6c1994ba2cfd97e0c77dcdf8bbdfdfa6"/> +<a href="demo__xip_2main_8c.html#af30de1c8d8502ad374612d308cfbd12eaa91d3c1d788b21fc798a5976c9f0da77"/> +<a href="demo__xip_2main_8c.html#af30de1c8d8502ad374612d308cfbd12eacd62141d6331f66e31bd252e2a92b836"/> +<a href="demo__xip_2main_8c.html#af9b3c37c806499fc435302f5bce6a122"/> +<a href="demo__xirq_2main_8c.html"/> +<a href="demo__xirq_2main_8c.html#a8874ccfc0b56171c359b5c2ceaf2bd80"/> +<a href="demo__xirq_2main_8c.html#a99e9ae3088f39995c852b2c53ec21266"/> +<a href="demo__xirq_2main_8c.html#abfe0c0bc47a683ba55df2aed63a12d4b"/> +<a href="demo__xirq_2main_8c.html#ad4455691936f92fdd6c37566fc58ba1f"/> +<a href="demo__xirq_2main_8c.html#ae66f6b31b5ad750f1fe042a706a4e3d4"/> +<a href="demo__xirq_2main_8c.html#ae8e3b3236aa2303c2b5e6e421b72cf73"/> +<a href="dhry_8h_source.html"/> +<a href="dir_01cde3d98944a579dc3b5e43a5311a79.html"/> +<a href="dir_01fcd3835fb4e7d9331b722d86291b65.html"/> +<a href="dir_09a89dfa1596b6613cf2c29528a32844.html"/> +<a href="dir_0c6ac14e2254a316d41123f98feeb67b.html"/> +<a href="dir_0d2921e55a1172a4726516961ee96ab5.html"/> +<a href="dir_23212395b5ee0866d2fdd629e0ddeae8.html"/> +<a href="dir_23717ebbabf7a51c0558262947e0fe3b.html"/> +<a href="dir_237db5b95db643499d4c20f0bc5f6a7d.html"/> +<a href="dir_2ba96d3140b089dada6fb9f817b7975f.html"/> +<a href="dir_3b3bafc48b460f797485cc75b94aa81c.html"/> +<a href="dir_4316bb0e553b51b8b65560981547ce0f.html"/> +<a href="dir_449d8ba5f8b78dc90092f20d15a2386a.html"/> +<a href="dir_46981071cfd8ec44311b09fdcf6c06a8.html"/> +<a href="dir_4c113257314015688a865e1bb8429184.html"/> +<a href="dir_5534fa9035f54ab438a41c43d6f7fc7a.html"/> +<a href="dir_752b1e5d3973bf735fa78bf6b4727df9.html"/> +<a href="dir_78d7bfa405ff3a31fa7539cfd8bc8262.html"/> +<a href="dir_7a2c74f70a4cdf2e836a07048e2f71dd.html"/> +<a href="dir_7d04193005ada6f9450f847f4adb6b5b.html"/> +<a href="dir_8c514361e1f16692c783b23503f30f16.html"/> +<a href="dir_8d341cbe0581f44e1ae95d82d74e8bc8.html"/> +<a href="dir_8f848e36ac87ced1c361afcc0549ca32.html"/> +<a href="dir_93967190e0d2e549ceca77007097849b.html"/> +<a href="dir_9a1c128d67c35790e92af404beb936aa.html"/> +<a href="dir_9d04cdc586d6978be343bda7adcdc371.html"/> +<a href="dir_b5eb9f7d151d147efb5dbda58439e4e7.html"/> +<a href="dir_b683da3a5fc966bff32ebf7cda721811.html"/> +<a href="dir_b68ac2efc0c6ed3018151f7bb6c45670.html"/> +<a href="dir_b6b50782b8271d07dffbc5f0cb9ff3f4.html"/> +<a href="dir_bf935196a1ea0ca9cb42aae56d70946a.html"/> +<a href="dir_c2d46947bdd73c33f53326fc5ee3a272.html"/> +<a href="dir_c413aba6cb5da07a571465ba333950af.html"/> +<a href="dir_d4640980cbf1943e4a4aee6e8b810c7a.html"/> +<a href="dir_d68bb921df3f2482fe9ace49b286ab86.html"/> +<a href="dir_e9ffd83269fb7f0c372f5ffbe8545008.html"/> +<a href="dir_ebeff77b922fbb914a1494857a82a38e.html"/> +<a href="dir_f0f9b27afba2e8cc2da6e5fddcc1a8c9.html"/> +<a href="files.html"/> +<a href="float__corner__test_2main_8c.html"/> +<a href="float__corner__test_2main_8c.html#a1740720aa8ce1a30fcf642be9140d203"/> +<a href="float__corner__test_2main_8c.html#a2d16b9e484b7af7897c7ae83f945ceca"/> +<a href="float__corner__test_2main_8c.html#a4ee0f6d28896a97d2c0cad866e77b874"/> +<a href="float__corner__test_2main_8c.html#a6969308bd3633928893a2666f1df66fc"/> +<a href="float__corner__test_2main_8c.html#a73c70bd0fb6d695cb113eaeb50923e3e"/> +<a href="float__corner__test_2main_8c.html#a7e134923925fa24fd1090281c3a416c3"/> +<a href="float__corner__test_2main_8c.html#a83792c34853f1d2801b59ad46adc7e1e"/> +<a href="float__corner__test_2main_8c.html#a87f296d7594bb8178cf76f0c045b7013"/> +<a href="float__corner__test_2main_8c.html#a923de9c3e55322d85522740c0d0ff867"/> +<a href="float__corner__test_2main_8c.html#a941ef8d24fd8e8fe4536626b2ce72410"/> +<a href="float__corner__test_2main_8c.html#a94f0b0908f48f383145ed61ef8eb0713"/> +<a href="float__corner__test_2main_8c.html#a97323ecaf1ae85e68a736b06bc3b58f8"/> +<a href="float__corner__test_2main_8c.html#aa3b6c4d49be7372de9e771a0475306ac"/> +<a href="float__corner__test_2main_8c.html#ad4455691936f92fdd6c37566fc58ba1f"/> +<a href="float__corner__test_2main_8c.html#ae66f6b31b5ad750f1fe042a706a4e3d4"/> +<a href="float__corner__test_2main_8c.html#aed386f612417aeeeac8b08db27d515e4"/> +<a href="float__corner__test_2neorv32__zfinx__extension__intrinsics_8h_source.html"/> +<a href="floating__point__test_2main_8c.html"/> +<a href="floating__point__test_2main_8c.html#a1740720aa8ce1a30fcf642be9140d203"/> +<a href="floating__point__test_2main_8c.html#a1a1af220e72c69b03d13b2df53650e10"/> +<a href="floating__point__test_2main_8c.html#a2d16b9e484b7af7897c7ae83f945ceca"/> +<a href="floating__point__test_2main_8c.html#a4ee0f6d28896a97d2c0cad866e77b874"/> +<a href="floating__point__test_2main_8c.html#a6969308bd3633928893a2666f1df66fc"/> +<a href="floating__point__test_2main_8c.html#a73c70bd0fb6d695cb113eaeb50923e3e"/> +<a href="floating__point__test_2main_8c.html#a7e134923925fa24fd1090281c3a416c3"/> +<a href="floating__point__test_2main_8c.html#a7ec330b668b5b24d666d7769ccecfee3"/> +<a href="floating__point__test_2main_8c.html#a83792c34853f1d2801b59ad46adc7e1e"/> +<a href="floating__point__test_2main_8c.html#a87f296d7594bb8178cf76f0c045b7013"/> +<a href="floating__point__test_2main_8c.html#a923de9c3e55322d85522740c0d0ff867"/> +<a href="floating__point__test_2main_8c.html#a941ef8d24fd8e8fe4536626b2ce72410"/> +<a href="floating__point__test_2main_8c.html#a94f0b0908f48f383145ed61ef8eb0713"/> +<a href="floating__point__test_2main_8c.html#a97323ecaf1ae85e68a736b06bc3b58f8"/> +<a href="floating__point__test_2main_8c.html#aa3b6c4d49be7372de9e771a0475306ac"/> +<a href="floating__point__test_2main_8c.html#ad4455691936f92fdd6c37566fc58ba1f"/> +<a href="floating__point__test_2main_8c.html#ae66f6b31b5ad750f1fe042a706a4e3d4"/> +<a href="floating__point__test_2main_8c.html#aed386f612417aeeeac8b08db27d515e4"/> +<a href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html"/> +<a href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a03aba9c70c5286dacebaeb0ef5219cc9"/> +<a href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a05d0d5a8eb9422e93448efdeb679cabf"/> +<a href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a0c985e626ed1d69314f4e3a0f1f58624"/> +<a href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a0f2260b7b5793a95c49670379fc89617"/> +<a href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a10a05bface37bff32c78ed0746845794"/> +<a href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a12498d635f422f607b9b83facf3050dd"/> +<a href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a17e2b7a399c956d548a609185084ea3c"/> +<a href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a1ceb3450f1e5c62d3079cd0e93c03501"/> +<a href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a2103eb86052f6f8e24a8a848ffc6528a"/> +<a href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a2235d91cdac03bf8071003a5c59b9dd0"/> +<a href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a292365fe41a7a661e61ae746306ba5e9"/> +<a href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a2b802122d53a2ce517b3d39fec34d7e0"/> +<a href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a3064a5c57b5f45d57c4d19eb798724f6"/> +<a href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a39212f2e2bb0f1752092a1732f93edf3"/> +<a href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a3bc6ee3059a7e99b187c4ea5e217715b"/> +<a href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a4b151fcb252fc7b894f247f5af6a1809"/> +<a href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a523fa0fb6f521311c7f44692c586b3ee"/> +<a href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a639fc7bd75933888540e9cceb67221a0"/> +<a href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a791f880781a1bcea1861471be7d1a851"/> +<a href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a7cb3c6570b911cd1dfb7b6e798cc1d21"/> +<a href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a833638b346722dfa9d7d5c8d60998ec8"/> +<a href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a837b7330f9d568791687ae1384b8ef28"/> +<a href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a85aa18294a58997db2c324184196669c"/> +<a href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a872cd30fb61190bd1ac719d25b01f5a3"/> +<a href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a87a106e0d24a3183712e438d2bcbfa2d"/> +<a href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a87c1ce499e5e43554cb0f407cf0d3f7f"/> +<a href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a98caf7f310820052ae96ce0f45e6cd26"/> +<a href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a9d676567276439875c9b1a15b892b555"/> +<a href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#aa4010772a986d03929ba7a43dfdcddd9"/> +<a href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#aa6473bc2d2721b57277b83a3ae0cfdb6"/> +<a href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#aad9fc7337e09081cf8c5bff8c28776c8"/> +<a href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#ab6a9d15643e3085ff80c7883f183a42b"/> +<a href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#abbdb403cdeef414fa2f867b702d5f6eb"/> +<a href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#abf7f9e466906306d9755fd5bc7946e3c"/> +<a href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#ac5fdef0607602fa0bdb93b3535fd709e"/> +<a href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#ac8bb4450b39854ab07839e8f3505361c"/> +<a href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#ace5d95b855ec1aa8eacdb5bbeea58197"/> +<a href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#ad43e8bdf4a6fbe229d22d24680f2be80"/> +<a href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#adb83fab39d91e9291da2b7b07830cf82"/> +<a href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#ae41a0bf9d28c35f4d6db7177ccf8ee06"/> +<a href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#aeaf46a17b671278be2bf804159827a40"/> +<a href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#af4ddfae45807d4e41f758672ee14cf7b"/> +<a href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#af8473ba61abab8ae2e3ecbaf22d70e89"/> +<a href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#af9b16a32d2bb13c8af5a678271d74889"/> +<a href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#aff3acd90bcfbda96945f95a0e0bae12b"/> +<a href="functions.html"/> +<a href="functions_vars.html"/> +<a href="game__of__life_2main_8c.html"/> +<a href="game__of__life_2main_8c.html#a3f33bf77abbf35c245956489f8f7e3a7"/> +<a href="game__of__life_2main_8c.html#a5315eb56128f1ca40d9f4d477c345dd7"/> +<a href="game__of__life_2main_8c.html#a6bd541a19c62ea9ec620eaad3f218d16"/> +<a href="game__of__life_2main_8c.html#a78c5b500f0f057bcaedf6fedeca7c537"/> +<a href="game__of__life_2main_8c.html#a819f10c5b644a07eeb069b6e7f12050e"/> +<a href="game__of__life_2main_8c.html#a840291bc02cba5474a4cb46a9b9566fe"/> +<a href="game__of__life_2main_8c.html#a977190adaa24a3f49fca1540b51d25a0"/> +<a href="game__of__life_2main_8c.html#a9a455dea83a25f656fcc5217ad513dac"/> +<a href="game__of__life_2main_8c.html#aac4bec7738b12f5a4b4d7a3a6cb1ab8d"/> +<a href="game__of__life_2main_8c.html#abe6bebcf1cb4f5b4d522c1706eb48663"/> +<a href="game__of__life_2main_8c.html#ad4455691936f92fdd6c37566fc58ba1f"/> +<a href="game__of__life_2main_8c.html#ae0b5214cf0cd93049e9df8a95a09d826"/> +<a href="game__of__life_2main_8c.html#aed77778557404b38bebb05b5830368b4"/> +<a href="game__of__life_2main_8c.html#afa6488273e16792d9c3da5e40e3f572d"/> +<a href="globals.html"/> +<a href="globals_a.html"/> +<a href="globals_b.html"/> +<a href="globals_c.html"/> +<a href="globals_d.html"/> +<a href="globals_defs.html"/> +<a href="globals_defs_b.html"/> +<a href="globals_defs_c.html"/> +<a href="globals_defs_d.html"/> +<a href="globals_defs_e.html"/> +<a href="globals_defs_f.html"/> +<a href="globals_defs_g.html"/> +<a href="globals_defs_i.html"/> +<a href="globals_defs_m.html"/> +<a href="globals_defs_n.html"/> +<a href="globals_defs_o.html"/> +<a href="globals_defs_p.html"/> +<a href="globals_defs_r.html"/> +<a href="globals_defs_s.html"/> +<a href="globals_defs_t.html"/> +<a href="globals_defs_u.html"/> +<a href="globals_defs_w.html"/> +<a href="globals_defs_x.html"/> +<a href="globals_e.html"/> +<a href="globals_enum.html"/> +<a href="globals_eval.html"/> +<a href="globals_eval_d.html"/> +<a href="globals_eval_e.html"/> +<a href="globals_eval_f.html"/> +<a href="globals_eval_g.html"/> +<a href="globals_eval_h.html"/> +<a href="globals_eval_n.html"/> +<a href="globals_eval_o.html"/> +<a href="globals_eval_p.html"/> +<a href="globals_eval_r.html"/> +<a href="globals_eval_s.html"/> +<a href="globals_eval_t.html"/> +<a href="globals_eval_u.html"/> +<a href="globals_eval_w.html"/> +<a href="globals_eval_x.html"/> +<a href="globals_f.html"/> +<a href="globals_func.html"/> +<a href="globals_func_a.html"/> +<a href="globals_func_b.html"/> +<a href="globals_func_c.html"/> +<a href="globals_func_d.html"/> +<a href="globals_func_g.html"/> +<a href="globals_func_h.html"/> +<a href="globals_func_m.html"/> +<a href="globals_func_n.html"/> +<a href="globals_func_p.html"/> +<a href="globals_func_r.html"/> +<a href="globals_func_s.html"/> +<a href="globals_func_t.html"/> +<a href="globals_func_u.html"/> +<a href="globals_func_v.html"/> +<a href="globals_func_w.html"/> +<a href="globals_func_x.html"/> +<a href="globals_g.html"/> +<a href="globals_h.html"/> +<a href="globals_i.html"/> +<a href="globals_k.html"/> +<a href="globals_m.html"/> +<a href="globals_n.html"/> +<a href="globals_o.html"/> +<a href="globals_p.html"/> +<a href="globals_r.html"/> +<a href="globals_s.html"/> +<a href="globals_t.html"/> +<a href="globals_u.html"/> +<a href="globals_v.html"/> +<a href="globals_vars.html"/> +<a href="globals_w.html"/> +<a href="globals_x.html"/> +<a href="hello__world_2main_8c.html"/> +<a href="hello__world_2main_8c.html#ad4455691936f92fdd6c37566fc58ba1f"/> +<a href="hello__world_2main_8c.html#ae66f6b31b5ad750f1fe042a706a4e3d4"/> +<a href="md_README.html"/> +<a href="md_README.html#autotoc_md0"/> +<a href="md_README.html#autotoc_md1"/> +<a href="md_README.html#autotoc_md10"/> +<a href="md_README.html#autotoc_md11"/> +<a href="md_README.html#autotoc_md12"/> +<a href="md_README.html#autotoc_md13"/> +<a href="md_README.html#autotoc_md14"/> +<a href="md_README.html#autotoc_md2"/> +<a href="md_README.html#autotoc_md3"/> +<a href="md_README.html#autotoc_md4"/> +<a href="md_README.html#autotoc_md5"/> +<a href="md_README.html#autotoc_md6"/> +<a href="md_README.html#autotoc_md7"/> +<a href="md_README.html#autotoc_md8"/> +<a href="md_README.html#autotoc_md9"/> +<a href="neorv32_8h.html"/> +<a href="neorv32_8h.html#a000b37f710043fe21e49b2fdbc039d94"/> +<a href="neorv32_8h.html#a0039bae3454a22e71d64e70d674f5d6a"/> +<a href="neorv32_8h.html#a0913144fce247e24ccd0f178b9ac32b7"/> +<a href="neorv32_8h.html#a095f41fbefaa7acc1bfdd65cd3ce06ea"/> +<a href="neorv32_8h.html#a0991b1a5ba1e8c3550eb9770d43589d0"/> +<a href="neorv32_8h.html#a0a59186908b498cb92273b7767966e26"/> +<a href="neorv32_8h.html#a0afc1a759116d4d73a199ef769bced47"/> +<a href="neorv32_8h.html#a0b738b26abb2b951f1f5c5d9525d7701"/> +<a href="neorv32_8h.html#a0e2377055bdc0f416b5ae4385610600d"/> +<a href="neorv32_8h.html#a10022df4c223533b04d5aebe222e8b73"/> +<a href="neorv32_8h.html#a10022df4c223533b04d5aebe222e8b73a0f20c29722bf9afc478b1a286a6b7eee"/> +<a href="neorv32_8h.html#a10022df4c223533b04d5aebe222e8b73a18aac15afd5ebd8d3a00dd6e513daf17"/> +<a href="neorv32_8h.html#a10022df4c223533b04d5aebe222e8b73a5990532893f2d9606e3c02aff60ca5da"/> +<a href="neorv32_8h.html#a10022df4c223533b04d5aebe222e8b73a648249b3ab8c2500880c1e68b98f81d1"/> +<a href="neorv32_8h.html#a10022df4c223533b04d5aebe222e8b73a933045a5405de55781d687315f42054e"/> +<a href="neorv32_8h.html#a10022df4c223533b04d5aebe222e8b73aa138f0cad547028d5124f89d6dcc8c79"/> +<a href="neorv32_8h.html#a10022df4c223533b04d5aebe222e8b73aa4e3a6a5b3cd895f63b4544f63ce22c9"/> +<a href="neorv32_8h.html#a10022df4c223533b04d5aebe222e8b73ad63d40139c50d76618cf1258cbdc0d05"/> +<a href="neorv32_8h.html#a11e34802c61a01fd6cba46e3f92d5ac1"/> +<a href="neorv32_8h.html#a142f4a1c754edfab292706618d427b94"/> +<a href="neorv32_8h.html#a16b9a7444833b5581df073661deb8f3a"/> +<a href="neorv32_8h.html#a1ac29f2f7bace5ba92b2b68a4541a60c"/> +<a href="neorv32_8h.html#a1eb0cb7fed7e154e15cb4009880a879c"/> +<a href="neorv32_8h.html#a1fa2b25383e6d05cf26f3517091ddbbf"/> +<a href="neorv32_8h.html#a232fe0eb5665373b6e2b464bdc228df2"/> +<a href="neorv32_8h.html#a26a1defe18ce222b8b4ed1c760344700"/> +<a href="neorv32_8h.html#a2896d832852c016eb85210b523642f11"/> +<a href="neorv32_8h.html#a2e70d3a4e2973d224643813fcf315a20"/> +<a href="neorv32_8h.html#a3012986cdd5748ee96bcc74cd7108dea"/> +<a href="neorv32_8h.html#a30cf20b6d704c50cc5c46238bb43646f"/> +<a href="neorv32_8h.html#a3853ef999f99ca062e6025038811d0f0"/> +<a href="neorv32_8h.html#a3e7aaa405a7d1fcd71a36c4b6b5a4081"/> +<a href="neorv32_8h.html#a41d6f97daef61641da96b9f72f6b272f"/> +<a href="neorv32_8h.html#a445543c36d1f78477aa8ea4841c720a1"/> +<a href="neorv32_8h.html#a48b80113ca718fbdc50d75e1ec96a1ff"/> +<a href="neorv32_8h.html#a4a3164d123ddddd07750f868e67d82d8"/> +<a href="neorv32_8h.html#a4a741408a4bb0938e03b99555306db9c"/> +<a href="neorv32_8h.html#a4c1cd9ec9f80da2080e5d0d35cc524dd"/> +<a href="neorv32_8h.html#a4cc50287c7a53982761a8116396ff7dd"/> +<a href="neorv32_8h.html#a4e039d13b8d3f20453e1bb6b40512e43"/> +<a href="neorv32_8h.html#a4fff18e72d10377cdcb8d2ac0a617a5d"/> +<a href="neorv32_8h.html#a559fdce92e8af5efc426c8fc48d14f99"/> +<a href="neorv32_8h.html#a568b54ba7dfdae736d8d685dc4d32113"/> +<a href="neorv32_8h.html#a5aa936f38782232c7ed3eab1283ee536"/> +<a href="neorv32_8h.html#a5c48d5c4effb47cdb019aa2da7c84526"/> +<a href="neorv32_8h.html#a68611c0dfbe331739eff10230ac3fede"/> +<a href="neorv32_8h.html#a68925ca3f482f148caedd36118fd8d79"/> +<a href="neorv32_8h.html#a6af270d7ae8b1cde30e44eb9142491d3"/> +<a href="neorv32_8h.html#a6b55ce6abe6b141000a6bb00949169e9"/> +<a href="neorv32_8h.html#a6c118c1784d8446360b00cde97437ca7"/> +<a href="neorv32_8h.html#a7a849638eff31f2e1955bdc53d4fc84d"/> +<a href="neorv32_8h.html#a7fbe28901775e284d5700086f0b0bfcd"/> +<a href="neorv32_8h.html#a7fd1e24d4de2eed7bf9cd5391562c7f4"/> +<a href="neorv32_8h.html#a83c212f1f5d8ee2a5921b3b2b19e9cc4"/> +<a href="neorv32_8h.html#a866768963f8648363dce40de9f34d61b"/> +<a href="neorv32_8h.html#a8680ab1f14e512f21913572b35cbbf77"/> +<a href="neorv32_8h.html#a8bb1918679e32e898af2d485cfa44afb"/> +<a href="neorv32_8h.html#a8d0409818600c0b2acfe8253e8f027b8"/> +<a href="neorv32_8h.html#a8d0b612e52b77395a05d4f18af6fcf00"/> +<a href="neorv32_8h.html#a942a897be2d4ae6820bee0f7bb3a0ff1"/> +<a href="neorv32_8h.html#a95387d3482ec8e5c1d734805fdf64fa5"/> +<a href="neorv32_8h.html#a9b316ec038bd94ada42c9dab57a0a3cb"/> +<a href="neorv32_8h.html#a9bf0149681677f7d87abf8f62e2d9a3d"/> +<a href="neorv32_8h.html#a9c387ca4e2736a27056c11819947c84a"/> +<a href="neorv32_8h.html#a9dc37695ca169bc0eb93898e7aeeee58"/> +<a href="neorv32_8h.html#aa01bea676e878a9e87ca10ce2d91e51f"/> +<a href="neorv32_8h.html#aa0ff72ea560d7e1462787dc31bd467cf"/> +<a href="neorv32_8h.html#aa466dc5eace7351bd438606f0f7475a7"/> +<a href="neorv32_8h.html#aa8d3a83ffad1e71f0832a5da78d62008"/> +<a href="neorv32_8h.html#aac38deeef36de0a474ab238a3054f860"/> +<a href="neorv32_8h.html#aae182648a2c23d070b9db0295388e001"/> +<a href="neorv32_8h.html#aae6b2ae3fba20ff80bfb59735f179c26"/> +<a href="neorv32_8h.html#ab1c351f5ea19ac9ea864155be9cc0b4b"/> +<a href="neorv32_8h.html#ab1fdaedb2c4c8753ef3be87c82568dda"/> +<a href="neorv32_8h.html#ab2f58f746febb29a9828447c733f8043"/> +<a href="neorv32_8h.html#ab4846cd153e8a23deec45d81cc8372a2"/> +<a href="neorv32_8h.html#ab4a2ac455d7426992de6877ea7325f21"/> +<a href="neorv32_8h.html#ab50df423fdba86bb83bc5d90a4c3bb20"/> +<a href="neorv32_8h.html#ab5e6dc57886cd5ed98b86f22fc37d7cc"/> +<a href="neorv32_8h.html#ab8fcd3f80c373eb0f9d0fc6bf64ca626"/> +<a href="neorv32_8h.html#ab98f762df259a2bbc28d19d2acfe9e23"/> +<a href="neorv32_8h.html#abd8c9b7d79f49de1722611b2835cde58"/> +<a href="neorv32_8h.html#ac4060532b7aa390623f54720460a2680"/> +<a href="neorv32_8h.html#ac8e98b2af75c8e31f9815dee3dcbaf8e"/> +<a href="neorv32_8h.html#aca6cfc3f580c4dfe1e213009ee450c58"/> +<a href="neorv32_8h.html#ace46f95dec73b33bf2535eb653bf8f65"/> +<a href="neorv32_8h.html#ace79ee46daf3a1b689d9fe79dfcd6627"/> +<a href="neorv32_8h.html#ad0b9eb2ee1f411d7fccdf4fe263214e1"/> +<a href="neorv32_8h.html#ad2e81443af8a4ce2db3a4e3c1a8fb784"/> +<a href="neorv32_8h.html#addbe29166bb77bc045ad0e3db68e57e9"/> +<a href="neorv32_8h.html#aded7d7f5f4ba3a6d90f9a29e62a8cfab"/> +<a href="neorv32_8h.html#ae0978315beac8399f96f520bda81c7fe"/> +<a href="neorv32_8h.html#ae8588cca20d5e36f74c5207c376389a1"/> +<a href="neorv32_8h.html#afaa705a674acf3fd6c8cb294eaf11c5e"/> +<a href="neorv32_8h.html#afe0cb262d517c7da73d6b5dc78886334"/> +<a href="neorv32_8h.html#afef7a6b121a788560b29e2ee2a58c725"/> +<a href="neorv32_8h.html#aff756a395771f22c5f412f23f177ea7d"/> +<a href="neorv32__aux_8c.html"/> +<a href="neorv32__aux_8c.html#a885a81838a91b57797e849cb835c6887"/> +<a href="neorv32__aux_8c.html#a94aa8369ba5f4ebdf5628fcb1ab2ba1c"/> +<a href="neorv32__aux_8c.html#aec4703f369e1567c22f140d2ec9daafc"/> +<a href="neorv32__aux_8c.html#aff31dd983f75f70eeae331c65acaa50e"/> +<a href="neorv32__aux_8h.html"/> +<a href="neorv32__aux_8h.html#a885a81838a91b57797e849cb835c6887"/> +<a href="neorv32__aux_8h.html#a94aa8369ba5f4ebdf5628fcb1ab2ba1c"/> +<a href="neorv32__aux_8h.html#aec4703f369e1567c22f140d2ec9daafc"/> +<a href="neorv32__aux_8h.html#aff31dd983f75f70eeae331c65acaa50e"/> +<a href="neorv32__cfs_8c.html"/> +<a href="neorv32__cfs_8c.html#abac96dfaefe433eca1c0b93fa6183d2e"/> +<a href="neorv32__cfs_8h.html"/> +<a href="neorv32__cfs_8h.html#a6c101b306bd096f78d351e39b308d3e2"/> +<a href="neorv32__cfs_8h.html#abac96dfaefe433eca1c0b93fa6183d2e"/> +<a href="neorv32__cpu_8c.html"/> +<a href="neorv32__cpu_8c.html#a232d0290c459dc790d989fcdc4d121bf"/> +<a href="neorv32__cpu_8c.html#a27dd614bc270dfa30ed73323ebda2d2d"/> +<a href="neorv32__cpu_8c.html#a387aa304770b05594c4acca128a60a75"/> +<a href="neorv32__cpu_8c.html#a5c3cf52498abb3cf3c14a724b287ecf0"/> +<a href="neorv32__cpu_8c.html#a70f49b80322aa457f29f7671f94a183d"/> +<a href="neorv32__cpu_8c.html#a8346fb926f84f3d7bccbb4741105505f"/> +<a href="neorv32__cpu_8c.html#aa458a700619b2f7666cfcffe02ec2e2c"/> +<a href="neorv32__cpu_8c.html#aa9027535b13d9f9325e734997fc4a137"/> +<a href="neorv32__cpu_8c.html#ac3fd7dc7cd1e0a08225c41820af27f92"/> +<a href="neorv32__cpu_8c.html#aca49efb45d3808ad76cf65ba291f546d"/> +<a href="neorv32__cpu_8c.html#ad4f8160f4821b6691e9682ef60c7cd7b"/> +<a href="neorv32__cpu_8c.html#adb3ae542bbb0ddf9f562a4e42bc24d10"/> +<a href="neorv32__cpu_8h.html"/> +<a href="neorv32__cpu_8h.html#a173bb06b4ae9c8964469068dafcb7b0e"/> +<a href="neorv32__cpu_8h.html#a232d0290c459dc790d989fcdc4d121bf"/> +<a href="neorv32__cpu_8h.html#a25a09de97229aac839ef6f74da604acf"/> +<a href="neorv32__cpu_8h.html#a27dd614bc270dfa30ed73323ebda2d2d"/> +<a href="neorv32__cpu_8h.html#a31f30f6d6542758cd3073a9939b07653"/> +<a href="neorv32__cpu_8h.html#a31f903596ab1bcddea79fdf608eaa666"/> +<a href="neorv32__cpu_8h.html#a32544cd652debb4affb308806a115d5b"/> +<a href="neorv32__cpu_8h.html#a387aa304770b05594c4acca128a60a75"/> +<a href="neorv32__cpu_8h.html#a3b6cf445e2136486564ef3d3473c91dd"/> +<a href="neorv32__cpu_8h.html#a5c3cf52498abb3cf3c14a724b287ecf0"/> +<a href="neorv32__cpu_8h.html#a70f49b80322aa457f29f7671f94a183d"/> +<a href="neorv32__cpu_8h.html#a769ca4556213619f6fea4ff6bfb979dd"/> +<a href="neorv32__cpu_8h.html#a8346fb926f84f3d7bccbb4741105505f"/> +<a href="neorv32__cpu_8h.html#aa458a700619b2f7666cfcffe02ec2e2c"/> +<a href="neorv32__cpu_8h.html#aa9027535b13d9f9325e734997fc4a137"/> +<a href="neorv32__cpu_8h.html#aab7a9f9cf608599f2b124dd499cb8418"/> +<a href="neorv32__cpu_8h.html#ab8f533ddbc3a3af5e3bca2287ac10122"/> +<a href="neorv32__cpu_8h.html#ac3fd7dc7cd1e0a08225c41820af27f92"/> +<a href="neorv32__cpu_8h.html#ac54ec9b59e17c7cd9b9907abee82ce95"/> +<a href="neorv32__cpu_8h.html#aca49efb45d3808ad76cf65ba291f546d"/> +<a href="neorv32__cpu_8h.html#ad4f8160f4821b6691e9682ef60c7cd7b"/> +<a href="neorv32__cpu_8h.html#adb3ae542bbb0ddf9f562a4e42bc24d10"/> +<a href="neorv32__cpu_8h.html#ae9c8b6c681536ddea3aff0e63f30ef70"/> +<a href="neorv32__cpu_8h.html#aeec8ad2a82885c40a307346f9003483e"/> +<a href="neorv32__cpu_8h.html#afb5ef6e0b1a3e26570edfd8379490455"/> +<a href="neorv32__cpu__amo_8c.html"/> +<a href="neorv32__cpu__amo_8c.html#a1281e18b95cd525073e1123c5d04e9e2"/> +<a href="neorv32__cpu__amo_8c.html#a31a6a3b5a33655f4a7b27d4c85b75f07"/> +<a href="neorv32__cpu__amo_8c.html#a62cf36637d7a04079228acecfe8a5cf3"/> +<a href="neorv32__cpu__amo_8c.html#a65b67f48356fa9b30596485473311377"/> +<a href="neorv32__cpu__amo_8c.html#a8e383fb8825538b5579d5ce075830697"/> +<a href="neorv32__cpu__amo_8c.html#a9b4540dadbfd5da907117570d8006e36"/> +<a href="neorv32__cpu__amo_8c.html#aad0d96e61bacc3af13ff471dd44ca8e9"/> +<a href="neorv32__cpu__amo_8c.html#ada27ec89b2530f7b7f14de947cc82bf9"/> +<a href="neorv32__cpu__amo_8c.html#adc80b1f2b3a4e70fee44c0edb08fc402"/> +<a href="neorv32__cpu__amo_8h.html"/> +<a href="neorv32__cpu__amo_8h.html#a1281e18b95cd525073e1123c5d04e9e2"/> +<a href="neorv32__cpu__amo_8h.html#a31a6a3b5a33655f4a7b27d4c85b75f07"/> +<a href="neorv32__cpu__amo_8h.html#a5e73eaa273c41a06972e862976fda53c"/> +<a href="neorv32__cpu__amo_8h.html#a62cf36637d7a04079228acecfe8a5cf3"/> +<a href="neorv32__cpu__amo_8h.html#a65b67f48356fa9b30596485473311377"/> +<a href="neorv32__cpu__amo_8h.html#a8e383fb8825538b5579d5ce075830697"/> +<a href="neorv32__cpu__amo_8h.html#a9b4540dadbfd5da907117570d8006e36"/> +<a href="neorv32__cpu__amo_8h.html#aad0d96e61bacc3af13ff471dd44ca8e9"/> +<a href="neorv32__cpu__amo_8h.html#ad4437bbc61a4e40d7d01dfe9459f6639"/> +<a href="neorv32__cpu__amo_8h.html#ada27ec89b2530f7b7f14de947cc82bf9"/> +<a href="neorv32__cpu__amo_8h.html#adc80b1f2b3a4e70fee44c0edb08fc402"/> +<a href="neorv32__cpu__cfu_8c.html"/> +<a href="neorv32__cpu__cfu_8c.html#a13019b8afa1a80c0e5c24eb4d72e75c1"/> +<a href="neorv32__cpu__cfu_8h.html"/> +<a href="neorv32__cpu__cfu_8h.html#a046a640f7f4a7b1b99a824fb325e2079"/> +<a href="neorv32__cpu__cfu_8h.html#a13019b8afa1a80c0e5c24eb4d72e75c1"/> +<a href="neorv32__cpu__cfu_8h.html#a65198d9caf04a5cd3a72accc2cecf870"/> +<a href="neorv32__cpu__cfu_8h.html#a69d60ccd0cee950b08ce585c3f13b85c"/> +<a href="neorv32__cpu__cfu_8h.html#ab3affefbff898567c6c02c4d10765b04"/> +<a href="neorv32__cpu__csr_8h.html"/> +<a href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33"/> +<a href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a06fdb61dab31c3490da6c37d47914f19"/> +<a href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a134ed02c7293008b21b1df472be8f11f"/> +<a href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a3079a8fbf3b8e376865bff76f2173698"/> +<a href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a3658e8663e94cd8eaa7201b7a850d083"/> +<a href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a396c6c4b425b3fff598e2f846052f98e"/> +<a href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a3d9d729940170609affbc6813054ebe8"/> +<a href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a41f91a37f7e0c75c783312af6a72e943"/> +<a href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a592939f1b7d79097f7f13d6ab0c268dc"/> +<a href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a666066099d6cebadbef21d81c179e8db"/> +<a href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a864d135708530016cfc52a65a1e4d79b"/> +<a href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a96315d6b5b9531bcbc1e78a3c9ab166a"/> +<a href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a99f43f8bbfb29fba6224f081c363ac7d"/> +<a href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33aa2dfa1183af312de2959dadd217fddc1"/> +<a href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33ac1e1d44becec1b393f79a118ed3d8beb"/> +<a href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33ae8e4f0ee46abbbb3361de035a57b8324"/> +<a href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33af058342854a0becd3bcc33877d9244cd"/> +<a href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33afc805280e20ffface116ca61e11645f7"/> +<a href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33afd2f1c78c442c8c29ab075cacee0a27a"/> +<a href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33affcb52dc57bb8c0cb1e7d3c1392d544a"/> +<a href="neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfe"/> +<a href="neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfea0f15c5a824cb1678423ac4ef72a5f4f5"/> +<a href="neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfea1a06f216e1a12afa0b90d6e1218b3c91"/> +<a href="neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfea2b683572525adc02ce0910031cfea914"/> +<a href="neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfea3a4f5bf9251def87a71162dbcf9043c5"/> +<a href="neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfea578ef6fc107c22b5cb7be5950f695640"/> +<a href="neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfea67a59934bc66bc7ccf82d24fe8a18a3b"/> +<a href="neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfea685ed663611d988702ec59c254eb61dd"/> +<a href="neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfea6a942852e3cd85616a63addb8e9d76f2"/> +<a href="neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfea9e1e2b50352b2555e9c64e76776919a6"/> +<a href="neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfeaab438295e5f00ffe4c2457a54ee9bfc4"/> +<a href="neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfeabcb123b5b150b4413e5fd48475faab27"/> +<a href="neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfeaffbb04d0053ebd079c6cacb4e5e7ed6b"/> +<a href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21b"/> +<a href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba03edd398920b817150d29107c0b40792"/> +<a href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba12da8c32d38d5a3539a0b766718bfd2d"/> +<a href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba1470cfe04f9d3ce45b7156b2a7fae159"/> +<a href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba14da6a2a962bf82970638a948ffbc570"/> +<a href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba1d761ef98f88c40509168ac66b7a4872"/> +<a href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba28a85ad8bd4c30fd3a91298dfa4fdb00"/> +<a href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba2b50cfa8be461b088ea8506ce4c741ba"/> +<a href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba2b577b1da1074c29ad58005af1f91d52"/> +<a href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba344943c62922561378d33ec51ac236e4"/> +<a href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba69ea0d3d76d4cec398f3b96959cc3544"/> +<a href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba7512bb6c4841ddd477422b49ebb2a155"/> +<a href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21baaa55d19f9a47889bc364c94bda04b677"/> +<a href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21baad1e5e452a9c37561308765431f0260d"/> +<a href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21baad691486001a68f2375dcf5793ee795a"/> +<a href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21bab6421f242bb8a487a986346e11196eb8"/> +<a href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21bad94c9691ce59b97fcfec14d345046c3e"/> +<a href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21badf45c5a135431f958fa63574c1dfac6e"/> +<a href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21baf5bbd23d4f311f640db42e9015f87580"/> +<a href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21baffa7342631aa0526aaa44c0c549b1f3e"/> +<a href="neorv32__cpu__csr_8h.html#a76b70a2334131e7589d84c1ee96de485"/> +<a href="neorv32__cpu__csr_8h.html#a76b70a2334131e7589d84c1ee96de485a75cefdbdef36b7fc248765b27c606a44"/> +<a href="neorv32__cpu__csr_8h.html#a76b70a2334131e7589d84c1ee96de485a8067c609c2360cab3bafa3c43e03dbf0"/> +<a href="neorv32__cpu__csr_8h.html#a76b70a2334131e7589d84c1ee96de485aaa1d482f828ac9cafc40fcfc298bec34"/> +<a href="neorv32__cpu__csr_8h.html#a76b70a2334131e7589d84c1ee96de485ac94a070f3fe7962e8c49a81545cacf2d"/> +<a href="neorv32__cpu__csr_8h.html#a76b70a2334131e7589d84c1ee96de485ae2603e365b3f1abfb46d53ed6b13dc56"/> +<a href="neorv32__cpu__csr_8h.html#a76b70a2334131e7589d84c1ee96de485af0ae9aca74144aa7dbdf656f71cc5c97"/> +<a href="neorv32__cpu__csr_8h.html#a8f2418fb5e2175f35ee2362469ce01f5"/> +<a href="neorv32__cpu__csr_8h.html#a8f2418fb5e2175f35ee2362469ce01f5a003ccfae4aae1dad4fd65d5d4c7737c4"/> +<a href="neorv32__cpu__csr_8h.html#a8f2418fb5e2175f35ee2362469ce01f5a629a81a205abee94bad9d5bb5dfa26b1"/> +<a href="neorv32__cpu__csr_8h.html#a8f2418fb5e2175f35ee2362469ce01f5aae0e0c33b0d034cb50286239f955d892"/> +<a href="neorv32__cpu__csr_8h.html#a8f2418fb5e2175f35ee2362469ce01f5ad555e9dfc0c00612bdea623617ff2820"/> +<a href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfe"/> +<a href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea0b547cb5876c0e7956e3d062e0784085"/> +<a href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea0f207455df0fed75fa68ba49c435889a"/> +<a href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea0f45818fa4cb9033a3093987fa8515c7"/> +<a href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea141a4a211c496d2af1c79d8e8e0c2a74"/> +<a href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea1da1186ef2f4e7297a4fecaaccdc1d05"/> +<a href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea1dc0276a5354c805ac56fd46c5037d38"/> +<a href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea201ac39b0eba389b0d02c3951a3311a3"/> +<a href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea2769a6e6a75f2f903523e4e95a899bb6"/> +<a href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea33d0fd3378ec3a2fcc3c8738c6cd2f32"/> +<a href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea3683e296caafe771b6dd57f4cf86f3dc"/> +<a href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea3b3571fceb687da2d3807b0e59bdf7ab"/> +<a href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea40427b799da049413c5536afa623c61d"/> +<a href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea46def851d4582b4bcec1f9d8bafd58db"/> +<a href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea5f182f39f9a4b871a097a51e57865bfa"/> +<a href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea68aba71ea77aba4005fb24a945ef38e4"/> +<a href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea74ec85a2e94aa0b9e8af29401ef7ecb1"/> +<a href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea85c0c2b2a5101380dec72516dda1a904"/> +<a href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea8d57acf13a086635a63bc13ccdf479b3"/> +<a href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea8d866a4c815d8ba890a1e00ce9600486"/> +<a href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea9517cd32744c5064fa30780f911cd22e"/> +<a href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfeaa39882f7dad9b7e16b317c75bad31382"/> +<a href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfeaa680d196d2ba0e403801a860bb9d8ce0"/> +<a href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfeaa83c0688869b1c43de0c4474e940f987"/> +<a href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfeabd21344124eda4402523203185a58b8a"/> +<a href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfeacaf997fe8b912596224e2bb632e6a806"/> +<a href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfead55b6af15841617d7dca3ab4fab893db"/> +<a href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfead9f6c4eb4284ee82b9e8d0c79f62b3ed"/> +<a href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfeaeb4b1b6abafd22eec0764d5503878cca"/> +<a href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfeaee2b5a2b7bd7ac07dae45900bc2faf46"/> +<a href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfeaf1b6153a0c664367bfefb78b2ca8b34e"/> +<a href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfeaf7020159e0ba346561bfba101d22c752"/> +<a href="neorv32__cpu__csr_8h.html#abc0e8daad1e9beda4d9950452cc930ea"/> +<a href="neorv32__cpu__csr_8h.html#abc0e8daad1e9beda4d9950452cc930eaa59c294bc43d2117bb55e301eec683f14"/> +<a href="neorv32__cpu__csr_8h.html#abc0e8daad1e9beda4d9950452cc930eaa67ad3243eeb74f86a01efbade76f21e4"/> +<a href="neorv32__cpu__csr_8h.html#abc0e8daad1e9beda4d9950452cc930eaa7689905760f917499b1151cced384d2f"/> +<a href="neorv32__cpu__csr_8h.html#abc0e8daad1e9beda4d9950452cc930eaaae1e6440956ad6b7cbf6062aa50f43b1"/> +<a href="neorv32__cpu__csr_8h.html#abc0e8daad1e9beda4d9950452cc930eaad3aca82a2ab57364e83f677d3d4f71a6"/> +<a href="neorv32__cpu__csr_8h.html#abc0e8daad1e9beda4d9950452cc930eaaec94712deafba09c0cf956c6fd68fa8d"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a03f29e792be2854efc9e66d710b78a1d"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a0545d0921b3f90d037dbb25bc5fcc2f9"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a067ed3778590ae97dc9b16069f0ed850"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a06d39cf0f13d6401dcf426d56149c8cd"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a06dfdeed757606529e4a99c033691b54"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a0c9492f6b956f088847f72b28e7b1446"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a0f4a1ae740efd80d14d21e90f355e9d7"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a11169bd08920d40c8f94fd29e1d33eff"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a125c4d0051548dea9104808b7bee1316"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a1328a226d36d23cc81740397bde47a4e"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a1860dd9579906c67a3565063043dcf78"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a18c2a249f1f7852f42f9e10dc59d46bb"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a1cfa1e3bc3c8a1c9a86c251a510d11cd"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a1e41d2b27d7e8da14871852d81123cfd"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a20400929087fabba410a098667d2d4ff"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a22eea318ec1ac72cc14e133b71ef4b16"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a23026793ee53c8d55d23f63195368a6b"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a23850b1804966cde2c1e84cde752d512"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a24d8617a6ff2c1e49c9a73853ad9e450"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a2524659ca2785af51af7acf9cd560a9d"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a252980a4da90c1f5c1ef85d164f72f25"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a28fcfd06ca1012c19cf053e57689687b"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a2af8c5dcc87d92bcce392fb5b3aa065e"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a2e14b57fee5376741634db7980a5005b"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a2e53e6e01ca8d1b801f6dfba602f3f59"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a2e9cfbf3c2828dd4bd92d2b8a1c99f85"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a30879e88b250d3e94d9d9e728ffcc2cc"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a32c22641ed66c6d20902306a2b1fad77"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a332ec2b0740f8e899a1b2ec86f7ee9f2"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a382304065a6db773f925b80b9447b8a8"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a396847bcf1634a1602ab117bfb57bdd2"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a3ce1dc0e2810f0df78feaa1c607a5ca6"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a3e5708c0f79cf58ae761b6bb8c2a4383"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a3ee699d5b2886c54c92992f66b109b67"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a427d7cf036b49efd46166c01f0504b68"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a438a65757b85f182dfb1f2a06c9ad520"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a46b8d3c288cbbfbf5a0af6e5cd8c5bc8"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a49b7bc2df67a6c73a68757de9b218f77"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a4a93ac5ab276cfd2f9cd296c8ce1bff6"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a4f229c169ada239033a1383412ce58c8"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a4fa22699e96d6da8665077e3c95891ef"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a54d38c8cf364d886eb7ac64463eedf77"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a575e5342d8ec304c32dbbe99d6fd6c0f"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a5a4cde90c547e913bddc719b3ab75e79"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a5d60a25a66754066589e8facb7d41153"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a5de5c5a036dc594a554d37df9ccf657d"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a5e1abf46b4f55bd18e1d132b32696ab6"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a625f606c14fd4d7224d7109e10508e7a"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a6332d4ff090aa7c302d191219e846fff"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a6879b4bf5d2db92d236b9091df4841f2"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a6a2933f3a1fa243de02db8a795e3ca41"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a6ba48e2306ae92f498552e1ea04d6790"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a6bb3ba59a25803d6f98faad67609a9a9"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a7277a8f929a5a250f7227fbbdf545dbc"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a7341886c7a4aed6fc7d8677c016a2cb8"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a74359db2583feb7119d4bcaa926242a0"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a7648dd0a47007d44a14e95ba47726599"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a76d30359e3b54197fb53f9939734cf1e"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a7f198c465959dde37b7056dd06d45812"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a7fb1de2019dd2b548084d5ca1630efbf"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a7fd76fcfc0d0dd47e112786bea5e4071"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a80eab0e17f5fe41edde485044674dc57"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a8144da8cd8691ac54aa0712685865b66"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a8837ff8d2741639aa69da59659f9a080"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a8840b3d4f45453fc96813ccb369a68e5"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a8941071db6145d34fff842249c0dcb9f"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a89bad989197e9358563557311b3c97e9"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a8c31899b81bb5dba9b92a0f0ca71aea6"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a919f39b0d299feb80403b42a466de444"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a91a8b5008b4e08ab34c1516e21bf0ba8"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a964a6a50d0138447fad47e9c982a7ba4"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a98ed49716d0d89712863e7a542d38d2a"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a98f5e2cf2d5dbb0125a222b0065c86eb"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a9b66978d76260283007d399fc735d153"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a9b84bd948dd52a7779b5fd16beddaab9"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a9bdd102877ff50d38c86c3d741aeb4b0"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a9c55619ffb05e84b7210e2d47326fa98"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a9e75518df7d14a009e3a0d5588641ddc"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a9fd1ff4e8a42992c0a3ec02c397dd7f8"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aa0b8c0561e8a778dce9c3b86499ffc50"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aa276bedb7dab28935163397b4879f6db"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aa2f644a4f54ba3834bafa738208c0803"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aa407e701bdbb9d26f84684b811c008a9"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aa47ed1a4a4f9fcabceed0d6d626d0aaf"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aa632d218400268df6dc6b289ff088d21"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aa8ce8fc8a57dd82872d02b4113249a77"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aaa3e6a1ac8999be42d7c13891546bb50"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aaae2f0b2e3f5a31dff933868873f6d5d"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aaaf0f6b17a06d5922bcfdb47b382137e"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ab2376c3b7c3ec0b44105ec1ed951bfb0"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ab45ebb3bd861074a15cc2ad874756e8f"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ab5f998725e002ffc2ff516ee973fe459"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ac0183bb6f357ed33136493ae7ded987a"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ac2541060307369b2031e9ec07bbd0067"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ac65bab6fd71439600c8fc549171251fa"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49acac87125f8c723cc5df4d4169a82852b"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49acc0f9f5f3b5702f1b57f2ba3b6b62610"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49acdf793b30919e7fa1b85995abe531a20"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ace4529c53ad2d46767f86d920eada507"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49acf336638697242b691b691dc56b9aadc"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ad0e5de789d6390f750b8af03cdd15450"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ad489feaa5ad1feb00d3df71d3e5b0cac"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ad6296ca83bbe1280624f3c21adbd8a79"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ad648b5ece209d47e9484fd7aa83e8e5f"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ad95cb95266533123447ff0e917f890e4"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ad97b6fe934a3bed6b02d0c8d81165d60"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ad9e78f71409fd7783cc2ae7c28b5e42c"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49adae22d860d8162e15120051951e45229"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49addb485275c954d1181d5bd4e4609082c"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ade079242596ce14ce1ba9842ed29b84c"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ae0a96f499dcde474af6ee620fbb1ebdc"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ae0e9cf0b99b8614ea0b870d38970281f"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ae29976bb072639975ad0cdb985c7f004"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ae56e95d6d6dd63ff6f5b4192cf48c88b"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ae58f15a95aa41126819effe046ced804"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ae8ea19cf3e527dbc0d36a43dfd1b7346"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aec68bf7e26e44170c24599f7c6a8365b"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aefefa1cff0cf5d01109486e5a8bebedf"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49af15d389bb8f91c989df488d231666394"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49af1a79349e46a4829af78d2cdfd0dc44f"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49af4c98d949d2eb44f2518fdf314344d3b"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49af57b5b7b57cd6e8b3489a27dfd702444"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49af5c5a21909aaca2b57f9a15f4bac246b"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49af609807e2917f73e27e5f27b38a0fa46"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49af65b9e99b9cadb3cb8d37f97cdbfeb9d"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49af6727a9bdd60ccf020812095b7396632"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49af67c819c104f7e3ec34f2cbb847cf83b"/> +<a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49afffb28b62b9baa127ae3bad919208988"/> +<a href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1"/> +<a href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a0a8010d7cc91b9557973a7a118828bee"/> +<a href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a0cef77904935798d247d8396838297c1"/> +<a href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a151f01e5f284f876cafafc7427720e4c"/> +<a href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a187ae38819b81672c15808e63c3b46b7"/> +<a href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a19708405f9f6300edf6b992c6d408a2d"/> +<a href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a1a412b9d8eefba7880555d34625d2cc0"/> +<a href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a20e5a2680f2f5956bfa92852d5544eac"/> +<a href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a28448f0c670169140dc28b6794310cea"/> +<a href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a2c9510cb7583a0144f96678fc217335e"/> +<a href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a350e762a599479fb2c6d23ccc5ee22b4"/> +<a href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a356f8485166529503d0fb246bd0aeeb0"/> +<a href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a4f6b9c6bba91fe04becb776ad22dcf42"/> +<a href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a5789dfabd8ec265fa0734ddd94e98757"/> +<a href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a69e68a954da0bb33d1624484a6777ff9"/> +<a href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a6a0ebfce4e18f36aeb43d5a65445cfe1"/> +<a href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a70bcfc75fe1056d93a3606f78c0cb887"/> +<a href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a7c8e97297cc4dcd6d5a1de65a124f3e9"/> +<a href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a809e997f55e83c6812c965655511d473"/> +<a href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a821f813de47eb781ab7715f780da3b1e"/> +<a href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a874dcc43cf8fbbf2e0614e7db9e38334"/> +<a href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1aa102472d6a264bb92e0581ccaa413e02"/> +<a href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1aa4eeafe2f6f59aff01e29461c664a110"/> +<a href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1aaa8e7bb251852ef75a78be71eef0b547"/> +<a href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1abfd21d1380dcacb9282e525da104d916"/> +<a href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1ad753d3e2563b4fd663430af9f3888dc7"/> +<a href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1ae0b1049ae7f8cbfb6ff216e69ed5dae7"/> +<a href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1ae0cebf99f36ef6be60e4a9d2c9f894b0"/> +<a href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1aeab719bcce9e9551bd6da65a7ae08a26"/> +<a href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1af1ad8f557f3b685b59a913611e1da173"/> +<a href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387"/> +<a href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387a42a3b78195741af4b6aeeb98cbea46fe"/> +<a href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387a48e57689f8a5b51d9ee9d648da7efc64"/> +<a href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387a56ec3195d0d27f362f58fadb2e037ed1"/> +<a href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387a59eae4272528f589f299ef9cce45af5b"/> +<a href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387a6843c660d75f33e4252c7fccd4565a2d"/> +<a href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387a6938948290d86b0ad25923f35d6c86d3"/> +<a href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387a6979d4389ed9f8605d338fc616d29f0e"/> +<a href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387a79b2b4b20e08ad31b50724a7a27fb20f"/> +<a href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387a9b121ec0ad6271b6e07658f861015f6a"/> +<a href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387ab1f289cfaa9f54f7831a2abcdf9fca2e"/> +<a href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387ab6aec595e6aa5ce7c98c7806d23d7af5"/> +<a href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387ac13e6883af3a9da18057462239b9fb34"/> +<a href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387accf1dd12be89e45df1423a5600789f2c"/> +<a href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387ad5ac9e2188757e6c42c159f0c5887868"/> +<a href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387af422ae3b5caba59e33a29b5d069597e0"/> +<a href="neorv32__cpu__csr_8h.html#afde0761e3150d82511136f56179c204b"/> +<a href="neorv32__cpu__csr_8h.html#afde0761e3150d82511136f56179c204ba365f3f519bca34a349907c82c873d52b"/> +<a href="neorv32__cpu__csr_8h.html#afde0761e3150d82511136f56179c204ba3ac330a4b03178e756c980eaa48ad165"/> +<a href="neorv32__cpu__csr_8h.html#afde0761e3150d82511136f56179c204ba612390e07a065fa13eeaeac84af48c6e"/> +<a href="neorv32__cpu__csr_8h.html#afde0761e3150d82511136f56179c204ba91a314defd310786a9ed67f7ef2ef5a6"/> +<a href="neorv32__cpu__csr_8h.html#afde0761e3150d82511136f56179c204babc6d405724563844569028f463885819"/> +<a href="neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830c"/> +<a href="neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830ca0ac798fd19cb7dbe1146afecda448fec"/> +<a href="neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830ca0b119a20be29fcae8fecf2a81c60d193"/> +<a href="neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830ca1dd1be1071450f9b00a817bce19fa665"/> +<a href="neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830ca317a631e4598532f5bffe8fb93aff94b"/> +<a href="neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830ca6091fd2c7ae38ad33be68a0fdfa50cca"/> +<a href="neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830ca886699013158c74810598fa2fd6b07fa"/> +<a href="neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830ca89412df9f99d2a0ddc4665446397f1a2"/> +<a href="neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830ca9ec2cae2b948de1043540a4ca1665c40"/> +<a href="neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830cab5a55e97b8511f42fe68559a38f7f138"/> +<a href="neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830cacd9d71e674d3a6d04984b6df706d9deb"/> +<a href="neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830cadd469404a928e012a298773ec46926ad"/> +<a href="neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830cafb3e4b08b87f5c161468a9e58ade12cc"/> +<a href="neorv32__crc_8c.html"/> +<a href="neorv32__crc_8c.html#a444b88f1536f65acc301fb19eddcf227"/> +<a href="neorv32__crc_8c.html#a4ff5f7b91e9f668535ed33b6382ae623"/> +<a href="neorv32__crc_8c.html#a9243006e6cc94c03450646d26a7289b2"/> +<a href="neorv32__crc_8c.html#aa46c647317752f8bb6d5836d4876a704"/> +<a href="neorv32__crc_8c.html#ad9d50c76a485160667d486bce32cbeb8"/> +<a href="neorv32__crc_8h.html"/> +<a href="neorv32__crc_8h.html#a110962d2b370f9d7997e459d9fd34271"/> +<a href="neorv32__crc_8h.html#a1ae84a58f475bafc2fc3f2c690fd6447"/> +<a href="neorv32__crc_8h.html#a1ae84a58f475bafc2fc3f2c690fd6447a7cf26bd4a7e8d6e45016633f650f00aa"/> +<a href="neorv32__crc_8h.html#a1ae84a58f475bafc2fc3f2c690fd6447a9409185edbae1bd0afdeda4e58aa6d1a"/> +<a href="neorv32__crc_8h.html#a1ae84a58f475bafc2fc3f2c690fd6447aa5cfd5d285b4cb8997c7e754491d050f"/> +<a href="neorv32__crc_8h.html#a444b88f1536f65acc301fb19eddcf227"/> +<a href="neorv32__crc_8h.html#a4ff5f7b91e9f668535ed33b6382ae623"/> +<a href="neorv32__crc_8h.html#a9243006e6cc94c03450646d26a7289b2"/> +<a href="neorv32__crc_8h.html#aa46c647317752f8bb6d5836d4876a704"/> +<a href="neorv32__crc_8h.html#ad9d50c76a485160667d486bce32cbeb8"/> +<a href="neorv32__dma_8h.html"/> +<a href="neorv32__dma_8h.html#a002cb188ea5156df0ba282e239a6e74b"/> +<a href="neorv32__dma_8h.html#a002cb188ea5156df0ba282e239a6e74ba038b6ef194c3db158cb59168f763a7b8"/> +<a href="neorv32__dma_8h.html#a002cb188ea5156df0ba282e239a6e74bac9c380cd5729386e5f5673e20b86326f"/> +<a href="neorv32__dma_8h.html#a002cb188ea5156df0ba282e239a6e74bad0f66e962296f5451d73dc1cae1fdc0d"/> +<a href="neorv32__dma_8h.html#a002cb188ea5156df0ba282e239a6e74baed7242b847e3cc8cf20d7da99f9b1492"/> +<a href="neorv32__dma_8h.html#a0dcb61a0e0d2b45beb7818015adc8639"/> +<a href="neorv32__dma_8h.html#a13260c3252f0375d8982590d270d7dfd"/> +<a href="neorv32__dma_8h.html#a13a16ba8d6daf9c82312bf4d392d15a8"/> +<a href="neorv32__dma_8h.html#a18fb7faa0a35f562821ca854d7c648b4"/> +<a href="neorv32__dma_8h.html#a2c7257567ccdb7a986f5ef7c74d3917c"/> +<a href="neorv32__dma_8h.html#a2ce0d31e04604b2523135d52a877febf"/> +<a href="neorv32__dma_8h.html#a33187c5a074d62b46d2262e352edb8d9"/> +<a href="neorv32__dma_8h.html#a33187c5a074d62b46d2262e352edb8d9a37ea8ef1e6b342db330d3885545fc802"/> +<a href="neorv32__dma_8h.html#a33187c5a074d62b46d2262e352edb8d9a4217c9a8ac4ccc52bb45944f30a598c5"/> +<a href="neorv32__dma_8h.html#a33187c5a074d62b46d2262e352edb8d9a4b99a30b851851f3388dd4e77effacec"/> +<a href="neorv32__dma_8h.html#a33187c5a074d62b46d2262e352edb8d9a61553eee00ed2382565bf826074c44bd"/> +<a href="neorv32__dma_8h.html#a33187c5a074d62b46d2262e352edb8d9a8dba4160c033c763f5102928c471e450"/> +<a href="neorv32__dma_8h.html#a33187c5a074d62b46d2262e352edb8d9abb1293915b076e5d37be6724b44ab0da"/> +<a href="neorv32__dma_8h.html#a33187c5a074d62b46d2262e352edb8d9afcfdedeca4c4a1def4905660811e31e2"/> +<a href="neorv32__dma_8h.html#a5e01d4454c97eb8e4ecd1455090bbfa9"/> +<a href="neorv32__dma_8h.html#a61caa2602c6b148af55d990e3c0ae6be"/> +<a href="neorv32__dma_8h.html#a6716eddb145b80ad38799da3b87cb2a4"/> +<a href="neorv32__dma_8h.html#a6716eddb145b80ad38799da3b87cb2a4a0d51df1bb87dc54d331891c5db787bcc"/> +<a href="neorv32__dma_8h.html#a6716eddb145b80ad38799da3b87cb2a4a3eba1f7868f0c985effb69785ced011a"/> +<a href="neorv32__dma_8h.html#a6716eddb145b80ad38799da3b87cb2a4a539609fc4d80867b3eb98c78206f5f96"/> +<a href="neorv32__dma_8h.html#a6716eddb145b80ad38799da3b87cb2a4a5aeeb05d6365d94d92808df2490daa3b"/> +<a href="neorv32__dma_8h.html#a6716eddb145b80ad38799da3b87cb2a4a5f39deea0212f45423243c8100c40838"/> +<a href="neorv32__dma_8h.html#a6716eddb145b80ad38799da3b87cb2a4a8e5ff34ac48eea4b352378bb2af47bcb"/> +<a href="neorv32__dma_8h.html#a6716eddb145b80ad38799da3b87cb2a4aaf040e663494b39b890d7171d0a584b9"/> +<a href="neorv32__dma_8h.html#a6716eddb145b80ad38799da3b87cb2a4ace9fdcdfa8784abad30e033c273e7d00"/> +<a href="neorv32__dma_8h.html#a6716eddb145b80ad38799da3b87cb2a4aeaf5ee8f6a84668aa15cd3e21f076afe"/> +<a href="neorv32__dma_8h.html#a6716eddb145b80ad38799da3b87cb2a4af7e038b0b0e3ac64f5a2c598eb9c5101"/> +<a href="neorv32__dma_8h.html#a6a0ce532aad39e6489e9d52bcb6f4cd2"/> +<a href="neorv32__dma_8h.html#a6df244028455cf7f8d4cf1520c4670a7"/> +<a href="neorv32__dma_8h.html#a6ebd1595ee6fa0e6cbfbd1ce7476f18e"/> +<a href="neorv32__dma_8h.html#a8f37adfa07050b0a1cb8430c9ce1fcc2"/> +<a href="neorv32__dma_8h.html#aa116f9714174abbe8a3583e441fee24b"/> +<a href="neorv32__dma_8h.html#ac3b72447e8a132faf26577ac714b8284"/> +<a href="neorv32__dma_8h.html#acc081d58b53d1eddd2bff35b128d7da2"/> +<a href="neorv32__dma_8h.html#adfecb3debff251070e4f6eb809412129"/> +<a href="neorv32__dma_8h.html#ae380022d8b8fb70da91f0892f2bc32c8"/> +<a href="neorv32__dma_8h.html#aeb63f99217f14d1ddde35c1f6c104e72"/> +<a href="neorv32__dma_8h.html#afc8cc32f7d80d0f5ab33b2f1ecf77956"/> +<a href="neorv32__gpio_8c.html"/> +<a href="neorv32__gpio_8c.html#a1958850fc1689eae9ddfcaa4a7513400"/> +<a href="neorv32__gpio_8c.html#a210529f789779387d3f014e6253e803f"/> +<a href="neorv32__gpio_8c.html#a41d39a41ba5879eb85d3ed4481fcff81"/> +<a href="neorv32__gpio_8c.html#a60fd0830d634f0c1f784d815384665cb"/> +<a href="neorv32__gpio_8c.html#a8dc7846945e4609fc96d81caee99ac00"/> +<a href="neorv32__gpio_8c.html#ac42379f2fb5ca0bb63850d7957852b84"/> +<a href="neorv32__gpio_8c.html#afa3ee54aca47ff35f706b627ac66e95a"/> +<a href="neorv32__gpio_8h.html"/> +<a href="neorv32__gpio_8h.html#a1958850fc1689eae9ddfcaa4a7513400"/> +<a href="neorv32__gpio_8h.html#a1e35bbf26b9d1aa5373af0b9468eb445"/> +<a href="neorv32__gpio_8h.html#a210529f789779387d3f014e6253e803f"/> +<a href="neorv32__gpio_8h.html#a41d39a41ba5879eb85d3ed4481fcff81"/> +<a href="neorv32__gpio_8h.html#a60fd0830d634f0c1f784d815384665cb"/> +<a href="neorv32__gpio_8h.html#a789222709485cd8467aad5eddf69d2df"/> +<a href="neorv32__gpio_8h.html#ac42379f2fb5ca0bb63850d7957852b84"/> +<a href="neorv32__gpio_8h.html#afa3ee54aca47ff35f706b627ac66e95a"/> +<a href="neorv32__gptmr_8c.html"/> +<a href="neorv32__gptmr_8c.html#a59e684348835772a7e83446e478d4a13"/> +<a href="neorv32__gptmr_8c.html#a6aa27efd2163eebf8fc49fe1c591708f"/> +<a href="neorv32__gptmr_8c.html#a7c9bc6d28ad12611b08fa2867c2db874"/> +<a href="neorv32__gptmr_8c.html#ac73aa4e41a064abb4ca554a389888e67"/> +<a href="neorv32__gptmr_8c.html#ae79a08c52ad3e83f9c4393acfabf035f"/> +<a href="neorv32__gptmr_8h.html"/> +<a href="neorv32__gptmr_8h.html#a135b0750d4afed16e5867134e3843988"/> +<a href="neorv32__gptmr_8h.html#a135b0750d4afed16e5867134e3843988a185861fbdc5f276735481237ad844833"/> +<a href="neorv32__gptmr_8h.html#a135b0750d4afed16e5867134e3843988a1e1e8e516fa4918441e3c77153940298"/> +<a href="neorv32__gptmr_8h.html#a135b0750d4afed16e5867134e3843988a3a868dc710ab9add083137e4e3fe888a"/> +<a href="neorv32__gptmr_8h.html#a135b0750d4afed16e5867134e3843988a473870880c0eca71578d6969e816af43"/> +<a href="neorv32__gptmr_8h.html#a135b0750d4afed16e5867134e3843988aadb663ad9a0dfd37fc65dffc1a289b38"/> +<a href="neorv32__gptmr_8h.html#a135b0750d4afed16e5867134e3843988abbfa7abcbd80b9c47e83e23e5cefaf90"/> +<a href="neorv32__gptmr_8h.html#a135b0750d4afed16e5867134e3843988ae4716a7a9e356484a8e478f07920cde3"/> +<a href="neorv32__gptmr_8h.html#a59e684348835772a7e83446e478d4a13"/> +<a href="neorv32__gptmr_8h.html#a6aa27efd2163eebf8fc49fe1c591708f"/> +<a href="neorv32__gptmr_8h.html#a7c9bc6d28ad12611b08fa2867c2db874"/> +<a href="neorv32__gptmr_8h.html#a9e047791588ff21fc4dc1b06456bdfd2"/> +<a href="neorv32__gptmr_8h.html#ac73aa4e41a064abb4ca554a389888e67"/> +<a href="neorv32__gptmr_8h.html#ae79a08c52ad3e83f9c4393acfabf035f"/> +<a href="neorv32__intrinsics_8h.html"/> +<a href="neorv32__legacy_8h.html"/> +<a href="neorv32__mtime_8c.html"/> +<a href="neorv32__mtime_8c.html#a022c3292c6e75095bb3ffd4c42fd4bfa"/> +<a href="neorv32__mtime_8c.html#a1c30809d6e887f022a7794f720243015"/> +<a href="neorv32__mtime_8c.html#a50d08fcc3d91fc2d88b9a6a80c656f1a"/> +<a href="neorv32__mtime_8c.html#a81ff371c1aa10901264873316ee84a49"/> +<a href="neorv32__mtime_8c.html#ab2b49a0594c66692aedf76ff9935581c"/> +<a href="neorv32__mtime_8c.html#acb3cc18ff8421ebd6ef471e089c23491"/> +<a href="neorv32__mtime_8c.html#adedbbdeb71c06d2d60d3af73451de01e"/> +<a href="neorv32__mtime_8h.html"/> +<a href="neorv32__mtime_8h.html#a022c3292c6e75095bb3ffd4c42fd4bfa"/> +<a href="neorv32__mtime_8h.html#a1c30809d6e887f022a7794f720243015"/> +<a href="neorv32__mtime_8h.html#a50d08fcc3d91fc2d88b9a6a80c656f1a"/> +<a href="neorv32__mtime_8h.html#a68935be182e0081039326a9f344a36b3"/> +<a href="neorv32__mtime_8h.html#a81ff371c1aa10901264873316ee84a49"/> +<a href="neorv32__mtime_8h.html#ab2b49a0594c66692aedf76ff9935581c"/> +<a href="neorv32__mtime_8h.html#acb3cc18ff8421ebd6ef471e089c23491"/> +<a href="neorv32__mtime_8h.html#adedbbdeb71c06d2d60d3af73451de01e"/> +<a href="neorv32__neoled_8c.html"/> +<a href="neorv32__neoled_8c.html#a3ee5b3602da3ae982628e2802587e451"/> +<a href="neorv32__neoled_8c.html#a484fcc6797b6d9cef86192e9593ec33d"/> +<a href="neorv32__neoled_8c.html#a57398d92fb4fc735b33e89271726e1d6"/> +<a href="neorv32__neoled_8c.html#a5aa9eb4dd3655fa08e1b61eb0f36589c"/> +<a href="neorv32__neoled_8c.html#a8181d5c1d15b7b5eecdc018341ac14fa"/> +<a href="neorv32__neoled_8c.html#a81c2c49198531fb6551eb288e29c084e"/> +<a href="neorv32__neoled_8c.html#a8daaa97a85e0eb94d4a38eb2119ea183"/> +<a href="neorv32__neoled_8c.html#abf7882b949373df0774fc9cc20c2bd2e"/> +<a href="neorv32__neoled_8c.html#ac6e94602453779a2791bd0734465f5a3"/> +<a href="neorv32__neoled_8c.html#adade69c7368c28180b9992d5f0ab6031"/> +<a href="neorv32__neoled_8h.html"/> +<a href="neorv32__neoled_8h.html#a3ccc1097bc70f92235d693b612fa994a"/> +<a href="neorv32__neoled_8h.html#a3ee5b3602da3ae982628e2802587e451"/> +<a href="neorv32__neoled_8h.html#a484fcc6797b6d9cef86192e9593ec33d"/> +<a href="neorv32__neoled_8h.html#a57398d92fb4fc735b33e89271726e1d6"/> +<a href="neorv32__neoled_8h.html#a5aa9eb4dd3655fa08e1b61eb0f36589c"/> +<a href="neorv32__neoled_8h.html#a8181d5c1d15b7b5eecdc018341ac14fa"/> +<a href="neorv32__neoled_8h.html#a81c2c49198531fb6551eb288e29c084e"/> +<a href="neorv32__neoled_8h.html#a8daaa97a85e0eb94d4a38eb2119ea183"/> +<a href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412"/> +<a href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a0c15850d0ab005b075f1a317646e18b1"/> +<a href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a0d5d01b8d30119bb86c1d079f7d5a9ad"/> +<a href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a0f4178d81ec6fe9a8b0e30230d318a91"/> +<a href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a142ed3fd65e01f853666a1169f920ad0"/> +<a href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a16c09df2784cfb6fafffaeaf245f1b73"/> +<a href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a1ef56b35c966786c42f2a2f800e30eae"/> +<a href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a23937f0a728da197590e1d383507cb23"/> +<a href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a369f36e73783c2923d07ca333081a4a6"/> +<a href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a37421074b86a260b276534b7c4949339"/> +<a href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a3bb5d0d1f78cebccbc8620a0194f43b8"/> +<a href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a3d8d54c05080fddb16df4176527bafa8"/> +<a href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a3f1a0ad71d9fd892829ec0246be343b3"/> +<a href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a42d09d42d39fc0eb2697853c99f4d5b0"/> +<a href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a436ad310b025bd3000af37986c193de5"/> +<a href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a44d8f064decabc690ed1f092be2b049b"/> +<a href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a4d362af8c630823b5104401a9c7d734e"/> +<a href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a55da98b018c7cc32cd1e80087ed9018e"/> +<a href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a7285e332ec7c2b3aeb34290e3e60ded7"/> +<a href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a770df505d47353f6c9289059c416d9c8"/> +<a href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a9d9411382d943c1659b6b761c462319b"/> +<a href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412abf2ea111a4ff34b6cb4dd987c5692f5c"/> +<a href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412abf6779cbeae87ab55efc9573932fc865"/> +<a href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412ac1922a5311e91a74710eddbf86ccc1c1"/> +<a href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412acbcd3c046b528e1900e86428da231df2"/> +<a href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412acfac5269688b2a03794dc17b11f1b983"/> +<a href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412addf4d6d1fd09f145d8aa497c4a7479c2"/> +<a href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412ae7b9d45c4ef69ca15fa13aa107e68156"/> +<a href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412aea15666ad4bb9eb1eba5dc9ed96114a6"/> +<a href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412aed0a878e73ad501bed3bbe6905974368"/> +<a href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412af97ab77b33a250d87025c3dd3a21fea7"/> +<a href="neorv32__neoled_8h.html#abf7882b949373df0774fc9cc20c2bd2e"/> +<a href="neorv32__neoled_8h.html#ac6e94602453779a2791bd0734465f5a3"/> +<a href="neorv32__neoled_8h.html#ad2a318bd59be12de34797ced0f7743c6"/> +<a href="neorv32__neoled_8h.html#adade69c7368c28180b9992d5f0ab6031"/> +<a href="neorv32__onewire_8c.html"/> +<a href="neorv32__onewire_8c.html#a01b6236b89c045ddbd58398361c6ee0a"/> +<a href="neorv32__onewire_8c.html#a01ddba7a9148be542b5c52e39e6f46d6"/> +<a href="neorv32__onewire_8c.html#a122531c7154126858c46d89e003d838d"/> +<a href="neorv32__onewire_8c.html#a224005037387484dfa510a1355a62828"/> +<a href="neorv32__onewire_8c.html#a23b96b68c3214b188525eb102cafb620"/> +<a href="neorv32__onewire_8c.html#a3072f7167831edc95dee44ecfef6a0d4"/> +<a href="neorv32__onewire_8c.html#a43eb8a08eeaa83e3d7e9aa5058a4269f"/> +<a href="neorv32__onewire_8c.html#a49d0a2a386f129fd2f4fed880bba31d4"/> +<a href="neorv32__onewire_8c.html#a4c7eec15c095c97c939163f631f51dab"/> +<a href="neorv32__onewire_8c.html#a6f7b6690a2437e0b574a8a9a23dc0eaa"/> +<a href="neorv32__onewire_8c.html#a7510e65a26aeefb40e994fd00667537e"/> +<a href="neorv32__onewire_8c.html#a7e329eeb1cd98301a53b271a6a102385"/> +<a href="neorv32__onewire_8c.html#a865e5c381fd3c27c6981a589a5124d1e"/> +<a href="neorv32__onewire_8c.html#aa4a19d2d8dc3b3401307615aec201190"/> +<a href="neorv32__onewire_8c.html#aace8398062b759256a516e6245aced83"/> +<a href="neorv32__onewire_8c.html#ac78557c77482b59394677f42fda4fdf1"/> +<a href="neorv32__onewire_8c.html#ace8b7cf697b068b6b51676d84dec5960"/> +<a href="neorv32__onewire_8c.html#ae6fe766e7decf18869cfb86bba741ca4"/> +<a href="neorv32__onewire_8c.html#af8ca6be495176797b7da3857e2f794f9"/> +<a href="neorv32__onewire_8h.html"/> +<a href="neorv32__onewire_8h.html#a01b6236b89c045ddbd58398361c6ee0a"/> +<a href="neorv32__onewire_8h.html#a01ddba7a9148be542b5c52e39e6f46d6"/> +<a href="neorv32__onewire_8h.html#a122531c7154126858c46d89e003d838d"/> +<a href="neorv32__onewire_8h.html#a224005037387484dfa510a1355a62828"/> +<a href="neorv32__onewire_8h.html#a23b96b68c3214b188525eb102cafb620"/> +<a href="neorv32__onewire_8h.html#a3072f7167831edc95dee44ecfef6a0d4"/> +<a href="neorv32__onewire_8h.html#a43eb8a08eeaa83e3d7e9aa5058a4269f"/> +<a href="neorv32__onewire_8h.html#a49d0a2a386f129fd2f4fed880bba31d4"/> +<a href="neorv32__onewire_8h.html#a4c7eec15c095c97c939163f631f51dab"/> +<a href="neorv32__onewire_8h.html#a6f119e35d7ac01f110987508ff3becc9"/> +<a href="neorv32__onewire_8h.html#a6f7b6690a2437e0b574a8a9a23dc0eaa"/> +<a href="neorv32__onewire_8h.html#a7510e65a26aeefb40e994fd00667537e"/> +<a href="neorv32__onewire_8h.html#a7e329eeb1cd98301a53b271a6a102385"/> +<a href="neorv32__onewire_8h.html#a865e5c381fd3c27c6981a589a5124d1e"/> +<a href="neorv32__onewire_8h.html#aa4a19d2d8dc3b3401307615aec201190"/> +<a href="neorv32__onewire_8h.html#aace8398062b759256a516e6245aced83"/> +<a href="neorv32__onewire_8h.html#ac78557c77482b59394677f42fda4fdf1"/> +<a href="neorv32__onewire_8h.html#ace8b7cf697b068b6b51676d84dec5960"/> +<a href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831"/> +<a href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831a27f040454bebc6218b490f7160ea2312"/> +<a href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831a32af8c86e7166e02e801727bd261c179"/> +<a href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831a789d65fd9b0ab17bffd0d6de9d2e132a"/> +<a href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831a7ecbccef9e77e68caf22ed2c416e1f77"/> +<a href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831a8b19096f72ef96a7597fda9be625ed40"/> +<a href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831a92e1ff9fa10319d64c8d2c6a6d61b37e"/> +<a href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831a98624ec944e0413a208cdf54bbbf4c75"/> +<a href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831aac8933755e80d72e1e9c293198d831b9"/> +<a href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831ab8600bd09d74e39869259881b84ebfbf"/> +<a href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831ab87882c202f80185278c69e482f147da"/> +<a href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831abfed6417c3abd7ef94cd18a3b32c4393"/> +<a href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831acdfca08f34d7379aaf8505ba3425c6f5"/> +<a href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831acfd8a56f668ca55dbbaa1714b1235dfe"/> +<a href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831aec9f056072e1db747e74a5c695d2a1df"/> +<a href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831aee1e24261e263c70bf2e36dcafc9dc74"/> +<a href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831af992c94d0b9a7b7b92a5a23366b9a8c6"/> +<a href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831afa1476a5e04eb4eabf4d7a595eca2df9"/> +<a href="neorv32__onewire_8h.html#ae6fe766e7decf18869cfb86bba741ca4"/> +<a href="neorv32__onewire_8h.html#ae770490afa8662fb8577065531d51368"/> +<a href="neorv32__onewire_8h.html#ae770490afa8662fb8577065531d51368a6ad35475e3f80a8c68ce0caa9c3754a5"/> +<a href="neorv32__onewire_8h.html#ae770490afa8662fb8577065531d51368af967429634efb019ada46bf75f373aa3"/> +<a href="neorv32__onewire_8h.html#af8ca6be495176797b7da3857e2f794f9"/> +<a href="neorv32__pwm_8c.html"/> +<a href="neorv32__pwm_8c.html#a43d8a47dc79ebac24c8a7d2d8247d2a5"/> +<a href="neorv32__pwm_8c.html#a5502d483de07d2d8c42e2388ed987069"/> +<a href="neorv32__pwm_8c.html#a64f66ae4f9689a650a70f3c5b45802b6"/> +<a href="neorv32__pwm_8c.html#a8f16fdc6e048899305a3234f42fe272f"/> +<a href="neorv32__pwm_8c.html#aa24bc867effa7756bfbe7818d85aface"/> +<a href="neorv32__pwm_8c.html#abc62a63dc139b185cdf53d0267501288"/> +<a href="neorv32__pwm_8c.html#afb12c860b2f7fa6cd1e069ea540da41c"/> +<a href="neorv32__pwm_8h.html"/> +<a href="neorv32__pwm_8h.html#a43d8a47dc79ebac24c8a7d2d8247d2a5"/> +<a href="neorv32__pwm_8h.html#a5502d483de07d2d8c42e2388ed987069"/> +<a href="neorv32__pwm_8h.html#a64f66ae4f9689a650a70f3c5b45802b6"/> +<a href="neorv32__pwm_8h.html#a8f16fdc6e048899305a3234f42fe272f"/> +<a href="neorv32__pwm_8h.html#aa24bc867effa7756bfbe7818d85aface"/> +<a href="neorv32__pwm_8h.html#abc62a63dc139b185cdf53d0267501288"/> +<a href="neorv32__pwm_8h.html#ad4cb534c29e26fa56c10bef7afab8f51"/> +<a href="neorv32__pwm_8h.html#af350f93b601a92ef56516198d1570b7d"/> +<a href="neorv32__pwm_8h.html#af350f93b601a92ef56516198d1570b7da01ab6de6ac34be1ed68f22e17acbe274"/> +<a href="neorv32__pwm_8h.html#af350f93b601a92ef56516198d1570b7da0fd36a63fd4c37ef3bc4732518ebf13d"/> +<a href="neorv32__pwm_8h.html#af350f93b601a92ef56516198d1570b7daa6fca8a4eecfb99b8f0fa99e187e30bb"/> +<a href="neorv32__pwm_8h.html#af350f93b601a92ef56516198d1570b7dafb99fba508460086efdd495d4649c65a"/> +<a href="neorv32__pwm_8h.html#afb12c860b2f7fa6cd1e069ea540da41c"/> +<a href="neorv32__rte_8c.html"/> +<a href="neorv32__rte_8c.html#a01bf6c01f5a8cda2132b9ac98824edc1"/> +<a href="neorv32__rte_8c.html#a05e8304963e402d228a76aff1868771c"/> +<a href="neorv32__rte_8c.html#a10fde6229bf391e46148405616404a65"/> +<a href="neorv32__rte_8c.html#a16df1b48f2e1258a51d3bb7f49531cf3"/> +<a href="neorv32__rte_8c.html#a2c8272b4628edddb943bcfad829b561a"/> +<a href="neorv32__rte_8c.html#a2cf31cfa569a03a20d554b6400c4c5e2"/> +<a href="neorv32__rte_8c.html#a343e1913bdc37db9b168fb4def0e6170"/> +<a href="neorv32__rte_8c.html#a53f1e006f0bf61deb7ad018f35228873"/> +<a href="neorv32__rte_8c.html#a65422bb44f1e7bc011e9bfc5d8451ebe"/> +<a href="neorv32__rte_8c.html#a65e71acc8916b42b59dc2cf6bba30ba3"/> +<a href="neorv32__rte_8c.html#aa442c0e39f9156a131c3432fda587692"/> +<a href="neorv32__rte_8c.html#aad6f5256a265807c4cde163bcba8dae9"/> +<a href="neorv32__rte_8c.html#acd96aa73eebe6d4bbc9aabe1230cbabc"/> +<a href="neorv32__rte_8c.html#ae13a9c1fd59ad71afb0d47cf9a0b303e"/> +<a href="neorv32__rte_8h.html"/> +<a href="neorv32__rte_8h.html#a05e8304963e402d228a76aff1868771c"/> +<a href="neorv32__rte_8h.html#a10fde6229bf391e46148405616404a65"/> +<a href="neorv32__rte_8h.html#a16df1b48f2e1258a51d3bb7f49531cf3"/> +<a href="neorv32__rte_8h.html#a2cf31cfa569a03a20d554b6400c4c5e2"/> +<a href="neorv32__rte_8h.html#a343e1913bdc37db9b168fb4def0e6170"/> +<a href="neorv32__rte_8h.html#a65422bb44f1e7bc011e9bfc5d8451ebe"/> +<a href="neorv32__rte_8h.html#a65e71acc8916b42b59dc2cf6bba30ba3"/> +<a href="neorv32__rte_8h.html#aa442c0e39f9156a131c3432fda587692"/> +<a href="neorv32__rte_8h.html#aad6f5256a265807c4cde163bcba8dae9"/> +<a href="neorv32__rte_8h.html#acd96aa73eebe6d4bbc9aabe1230cbabc"/> +<a href="neorv32__rte_8h.html#ad14a1ca41df1e9300bfd01aef07dce59"/> +<a href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70a"/> +<a href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa01f562418ddbbb6b84be168673deeea9"/> +<a href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa155f84a52bace69f81a99de59701decc"/> +<a href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa1d18312227bfd5332ebcc1f74c979dbe"/> +<a href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa29ffa3108fadc78bf375773c3232c489"/> +<a href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa2cd04189d91465dad2bc2a8852406b76"/> +<a href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa3edbf47bd9a278e100bb808c8bb68308"/> +<a href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa463611404367b5910c42dd31c0a218a2"/> +<a href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa48f4d253b260784a1ffaaded508166e2"/> +<a href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa4a74188fd87ea17a594ac6fe8ddf71be"/> +<a href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa609613cf25bb8f2d0e323089d6798220"/> +<a href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa73bb84f7b6c7528bec552ac1d3e9ccdb"/> +<a href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa85934b3fd8b5268340f84810b3f67232"/> +<a href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa8b39868bf91da54f9ec492918e0c01ff"/> +<a href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa8e2cc9a533ebbc0e1d29c3ec8afbe61f"/> +<a href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa931a4f314b04233924b01e8245153be4"/> +<a href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa97047b024b72807a0b312979c9359dab"/> +<a href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aaa9b8334712ecad0500c7610a25741ec7"/> +<a href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aaadd66d9b9c33a6869fa3c30e1e434313"/> +<a href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aab199b53a1458017fa5278e0aeecf41fd"/> +<a href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aab36a403cd7b833439ce7f9a708c33922"/> +<a href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aab49ff0110481f22da22a085d2633a0e0"/> +<a href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aac9fb28ea8bafff182f12c29d2fad6998"/> +<a href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aacf17d4b2454c43a1cb544e532d247fff"/> +<a href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aad2a55d5586d33497fd21b1da8aa98fff"/> +<a href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aadddffa9acdfcce80dd68ad4b26725174"/> +<a href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aadebcc4d91aea1364b1481111f1060c52"/> +<a href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aaea6027bf0354c3120fa61c8094dd7a1d"/> +<a href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aaecea4f1d524a33d02324382357b2bcb9"/> +<a href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aaf647ff8d55d021379202879627c91d81"/> +<a href="neorv32__rte_8h.html#ae13a9c1fd59ad71afb0d47cf9a0b303e"/> +<a href="neorv32__sdi_8c.html"/> +<a href="neorv32__sdi_8c.html#a2636cf1959ce1f3eb4b77c00ca2e2707"/> +<a href="neorv32__sdi_8c.html#a3246118dc0d7e1f61bc2485bbab44149"/> +<a href="neorv32__sdi_8c.html#a4d54ce22ec97eb83da118439576e3277"/> +<a href="neorv32__sdi_8c.html#a51412722efdb18cd09667622b215e825"/> +<a href="neorv32__sdi_8c.html#a5d68b9b1642baf3519076e55a22a8f61"/> +<a href="neorv32__sdi_8c.html#a7390faeb01b4de3dd5ac18335736b90c"/> +<a href="neorv32__sdi_8c.html#a8bd54bca8aea6147651c8115ee616f54"/> +<a href="neorv32__sdi_8c.html#ac7a262d16c42bbac27723ff779545569"/> +<a href="neorv32__sdi_8h.html"/> +<a href="neorv32__sdi_8h.html#a2636cf1959ce1f3eb4b77c00ca2e2707"/> +<a href="neorv32__sdi_8h.html#a3246118dc0d7e1f61bc2485bbab44149"/> +<a href="neorv32__sdi_8h.html#a4d54ce22ec97eb83da118439576e3277"/> +<a href="neorv32__sdi_8h.html#a51412722efdb18cd09667622b215e825"/> +<a href="neorv32__sdi_8h.html#a5d68b9b1642baf3519076e55a22a8f61"/> +<a href="neorv32__sdi_8h.html#a7390faeb01b4de3dd5ac18335736b90c"/> +<a href="neorv32__sdi_8h.html#a8bd54bca8aea6147651c8115ee616f54"/> +<a href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6"/> +<a href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6a051d69f43c2b0f15c5e9e9252c906c9d"/> +<a href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6a2a611e339fd9ae7854931743802ff5c0"/> +<a href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6a45ade3854c01dc1b14a80e3fea29417a"/> +<a href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6a5df074faedb03cf3cc0cfa90eaccd210"/> +<a href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6a762237a6107ee690276c36108fa1c1ed"/> +<a href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6a840c74518f55028608e2353ec6ce58c4"/> +<a href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6aa9b89463a37e3a9c554195c2f87fb8d8"/> +<a href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6ab3b57f906bd3fc16242fa06601ce1716"/> +<a href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6ac9381cffb4da427baf31cdbbeae5e1f4"/> +<a href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6ad288a52f2bdaa1ea6ddbadf7f32a3a63"/> +<a href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6adb5c4613ce0a6178a01599cf8fd6984a"/> +<a href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6ae15186a46909f1a957269b21af6a14a0"/> +<a href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6aeac16a67f250cce5ea420790e80b8bb9"/> +<a href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6af1e2abec3b3bc2ff9ecb2698d933a281"/> +<a href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6af6016d120844c2d8d8da4fccc09f9809"/> +<a href="neorv32__sdi_8h.html#ac7a262d16c42bbac27723ff779545569"/> +<a href="neorv32__sdi_8h.html#afd0921633d6523d9b7235055e9bbf928"/> +<a href="neorv32__slink_8c.html"/> +<a href="neorv32__slink_8c.html#a1a9269f42552a849450aecd99f7ec7a0"/> +<a href="neorv32__slink_8c.html#a2136bc0b12ee2e6703e84a6417a1e8eb"/> +<a href="neorv32__slink_8c.html#a3e02c558548c1c6178c49adee9a007f7"/> +<a href="neorv32__slink_8c.html#a575c7663ca0bd07c95b1d45152a3ddf8"/> +<a href="neorv32__slink_8c.html#a8f0b4a768f53a72a5c16034e160ce321"/> +<a href="neorv32__slink_8c.html#aaa9fdb9cbfa7888e92790ab65431d21d"/> +<a href="neorv32__slink_8c.html#aaf0d0d1b890353d4f3bf49450ec2fad2"/> +<a href="neorv32__slink_8c.html#aaf0f7bc96b797e819ccaae94292d9ddb"/> +<a href="neorv32__slink_8c.html#ac7484e9e3848f94efe016dd064f6a57f"/> +<a href="neorv32__slink_8c.html#ace319592c12dc6a0fe1b7dd66bdf9284"/> +<a href="neorv32__slink_8c.html#ad0252e7ae915e5840cd17e8c52e94a1c"/> +<a href="neorv32__slink_8c.html#ad149fea81e6d28f77450b8ba50cf706e"/> +<a href="neorv32__slink_8c.html#ad57fc0941fe32e8bf423ce3e57e2c10a"/> +<a href="neorv32__slink_8c.html#ad857d7e78ca2b5eb0d0a4f2c515fe7bc"/> +<a href="neorv32__slink_8h.html"/> +<a href="neorv32__slink_8h.html#a1a9269f42552a849450aecd99f7ec7a0"/> +<a href="neorv32__slink_8h.html#a2136bc0b12ee2e6703e84a6417a1e8eb"/> +<a href="neorv32__slink_8h.html#a3e02c558548c1c6178c49adee9a007f7"/> +<a href="neorv32__slink_8h.html#a575c7663ca0bd07c95b1d45152a3ddf8"/> +<a href="neorv32__slink_8h.html#a6380d894432de119a20993096db534df"/> +<a href="neorv32__slink_8h.html#a84f7fe82f188bd4e68f41549587822bf"/> +<a href="neorv32__slink_8h.html#a84f7fe82f188bd4e68f41549587822bfa2f96e61f0e07ef4ecd40f14e69b69211"/> +<a href="neorv32__slink_8h.html#a84f7fe82f188bd4e68f41549587822bfa9f24886f55b7f78ae8909ea8a573058c"/> +<a href="neorv32__slink_8h.html#a84f7fe82f188bd4e68f41549587822bfadc37988b8aee38e85626064b2c3704f9"/> +<a href="neorv32__slink_8h.html#a8f0b4a768f53a72a5c16034e160ce321"/> +<a href="neorv32__slink_8h.html#aaa9fdb9cbfa7888e92790ab65431d21d"/> +<a href="neorv32__slink_8h.html#aaf0d0d1b890353d4f3bf49450ec2fad2"/> +<a href="neorv32__slink_8h.html#aaf0f7bc96b797e819ccaae94292d9ddb"/> +<a href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1"/> +<a href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1a156fa3209b2652af6b58b0fdfc6cab1b"/> +<a href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1a308cf7829ecca32f7a3da1bd74339854"/> +<a href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1a530b8b76301f36fbda134b330447de78"/> +<a href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1a5452eab0fe12d174ec804c4c72060854"/> +<a href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1a624723683d247668ef44137393e576aa"/> +<a href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1a739187f413b7436dc4037187e4a9e86a"/> +<a href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1a7bf757dbfb1fdaddceaed3a3887003cf"/> +<a href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1a8f994f256f57c006c88b9e38df3f54fa"/> +<a href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1a945e2b7eda65dc13ca38eb21c9c4f657"/> +<a href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1a9c68af961c1147846929ca55e9e4e88c"/> +<a href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1aa7521fbe691fef233c0dff4053e4493e"/> +<a href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1aba613343fc17715fc1bb07729588a12d"/> +<a href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1ac8a688706aee72d2027e022b64664309"/> +<a href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1ad366597a44d3dff7dbab4cde72bed82f"/> +<a href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1ae06ad5f627f8902e2368e0daff6cfa88"/> +<a href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1ae78f82e54bd9d737bbcbc5c7af0e9d4b"/> +<a href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1af27a9e6e50b169d3f5efd0a08ba4a943"/> +<a href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1af695158b9cf5466d87c207f9bd0a688e"/> +<a href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1af94314ed65c6a8d9c364d99d7ae960ee"/> +<a href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1afa9353cd824d1b2833930ce9e922e392"/> +<a href="neorv32__slink_8h.html#ac3e5e02fd89a357135adca6d28cd0e45"/> +<a href="neorv32__slink_8h.html#ac3e5e02fd89a357135adca6d28cd0e45a69942c3a7b7b0550634f4016e639b0c2"/> +<a href="neorv32__slink_8h.html#ac3e5e02fd89a357135adca6d28cd0e45a7b7b0b9bd4fe448cae97a3a21460f983"/> +<a href="neorv32__slink_8h.html#ac3e5e02fd89a357135adca6d28cd0e45a7e8da208ecaf142107587033e2d63ec1"/> +<a href="neorv32__slink_8h.html#ac3e5e02fd89a357135adca6d28cd0e45a9a2311357bd87c85a5cc45f08b0d8f80"/> +<a href="neorv32__slink_8h.html#ac7484e9e3848f94efe016dd064f6a57f"/> +<a href="neorv32__slink_8h.html#ace319592c12dc6a0fe1b7dd66bdf9284"/> +<a href="neorv32__slink_8h.html#ad0252e7ae915e5840cd17e8c52e94a1c"/> +<a href="neorv32__slink_8h.html#ad149fea81e6d28f77450b8ba50cf706e"/> +<a href="neorv32__slink_8h.html#ad57fc0941fe32e8bf423ce3e57e2c10a"/> +<a href="neorv32__slink_8h.html#ad857d7e78ca2b5eb0d0a4f2c515fe7bc"/> +<a href="neorv32__spi_8c.html"/> +<a href="neorv32__spi_8c.html#a01c6b63d7349447e2277f2649c3c89f2"/> +<a href="neorv32__spi_8c.html#a332c7a1be511812ac0a2b102c165398a"/> +<a href="neorv32__spi_8c.html#a67e9717635e272bc0e04408135a2f04d"/> +<a href="neorv32__spi_8c.html#a7266ee439d0ec11c5cedd4bf1a258272"/> +<a href="neorv32__spi_8c.html#a737961d040ac09567350f89034f9e122"/> +<a href="neorv32__spi_8c.html#a7af79950eefc26e67a89bde02f255532"/> +<a href="neorv32__spi_8c.html#a7d8124d986b69210081df6f1aa653552"/> +<a href="neorv32__spi_8c.html#a817dd9a38bfceb2048e40874a83ba169"/> +<a href="neorv32__spi_8c.html#a82bb4d4c222b2bdc57e917c348481501"/> +<a href="neorv32__spi_8c.html#a8fa25d144ccb20a2faf0450c8dddd16e"/> +<a href="neorv32__spi_8c.html#a97b5536347a27b053f071ba49071ba6f"/> +<a href="neorv32__spi_8c.html#aa10ec90ccba6325eeeebb8f6f298d30c"/> +<a href="neorv32__spi_8c.html#aad66fa8f8d1a92d4f355de7579bfbfd2"/> +<a href="neorv32__spi_8c.html#acf131faa3ad970c19a3cd8a47cb54f65"/> +<a href="neorv32__spi_8c.html#ad8dd1b5a85a9daef4c8c21c9990884c1"/> +<a href="neorv32__spi_8c.html#ae1c4da7e4dc2e42b04d7187f684f142c"/> +<a href="neorv32__spi_8c.html#aec8583e988789e846d21c2a35e6b06e7"/> +<a href="neorv32__spi_8h.html"/> +<a href="neorv32__spi_8h.html#a01c6b63d7349447e2277f2649c3c89f2"/> +<a href="neorv32__spi_8h.html#a332c7a1be511812ac0a2b102c165398a"/> +<a href="neorv32__spi_8h.html#a5f3afc4e268670c54d90df67fa38ca22"/> +<a href="neorv32__spi_8h.html#a67e9717635e272bc0e04408135a2f04d"/> +<a href="neorv32__spi_8h.html#a7266ee439d0ec11c5cedd4bf1a258272"/> +<a href="neorv32__spi_8h.html#a737961d040ac09567350f89034f9e122"/> +<a href="neorv32__spi_8h.html#a7af79950eefc26e67a89bde02f255532"/> +<a href="neorv32__spi_8h.html#a7d8124d986b69210081df6f1aa653552"/> +<a href="neorv32__spi_8h.html#a817dd9a38bfceb2048e40874a83ba169"/> +<a href="neorv32__spi_8h.html#a82bb4d4c222b2bdc57e917c348481501"/> +<a href="neorv32__spi_8h.html#a8fa25d144ccb20a2faf0450c8dddd16e"/> +<a href="neorv32__spi_8h.html#a97b5536347a27b053f071ba49071ba6f"/> +<a href="neorv32__spi_8h.html#aa10ec90ccba6325eeeebb8f6f298d30c"/> +<a href="neorv32__spi_8h.html#aab478c23898c0b06cee53a1cbda38bf8"/> +<a href="neorv32__spi_8h.html#aab478c23898c0b06cee53a1cbda38bf8a0167ec9c252ee0228ab9d21f4acba600"/> +<a href="neorv32__spi_8h.html#aab478c23898c0b06cee53a1cbda38bf8a5673b6a3382dc5452e3cfcd4e8f3c8a2"/> +<a href="neorv32__spi_8h.html#aab478c23898c0b06cee53a1cbda38bf8a8b565083f989905b8335d9d22a14c4b6"/> +<a href="neorv32__spi_8h.html#aab478c23898c0b06cee53a1cbda38bf8ae3c36a644c05cea0fccaefb9da90a1b4"/> +<a href="neorv32__spi_8h.html#aad66fa8f8d1a92d4f355de7579bfbfd2"/> +<a href="neorv32__spi_8h.html#acf131faa3ad970c19a3cd8a47cb54f65"/> +<a href="neorv32__spi_8h.html#ad8dd1b5a85a9daef4c8c21c9990884c1"/> +<a href="neorv32__spi_8h.html#ae1c4da7e4dc2e42b04d7187f684f142c"/> +<a href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3b"/> +<a href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba0b9ca202963b68b999f94baab50fbc48"/> +<a href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba115b097b76b3b99716f54a63c6ce5633"/> +<a href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba12f67abd206066651c1d62fc29fafcdb"/> +<a href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba2cd2350ffc819b7198d1833b525c5ca0"/> +<a href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba3f80e9c6ef6445ad769038c955c171a2"/> +<a href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba487b87333d33db0a05cd2a229225ffc6"/> +<a href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba49c38a34b95c034249a094fbc93e0a61"/> +<a href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba4d787c993152a9417fcd50f76820c7b0"/> +<a href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba5e12c05349444d3d1defff49dec00580"/> +<a href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba5efcaded20b93d2bffeaa4ea813f73b4"/> +<a href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba647a6357971f94b79b7672785c06a4ea"/> +<a href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba7661acb97cc8c6dd7f333be4f4a2d315"/> +<a href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba7957cf1cf3997cd059ed81cba73a688c"/> +<a href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba7a5244e443e1fe4ff6b7a2176f90ae7a"/> +<a href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba85164e4e00b5ccd34158f98f691bca29"/> +<a href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba8c0426f70974f0ab129481f2db7cf0ed"/> +<a href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba8c18d975418ad444255f80317448d26b"/> +<a href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba96860d260b31ee4c232b6b0eb45f7905"/> +<a href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba97aaa7a4ffcc6d17a00c4f992e517c46"/> +<a href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3babc927c4ea78433de697a9fe96f47248e"/> +<a href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3bac38b12af6b8fb6bf2fc6f6ff6baee91e"/> +<a href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3bae6db5cfa843a58d7c09783e7f29fa49f"/> +<a href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3bafcdc17528f9f4521c02ec5c473b44622"/> +<a href="neorv32__spi_8h.html#aec8583e988789e846d21c2a35e6b06e7"/> +<a href="neorv32__spi__irq_8c.html"/> +<a href="neorv32__spi__irq_8c.html#a1863e19932bc6a79f2ca27d23eb74ef5"/> +<a href="neorv32__spi__irq_8c.html#a1f44ed849415d8e1d659c0485762c485"/> +<a href="neorv32__spi__irq_8c.html#a4aa4746fd210ecc0c3614089a6951ddf"/> +<a href="neorv32__spi__irq_8c.html#aa641816bb302df497664aa21ea69ed16"/> +<a href="neorv32__spi__irq_8h.html"/> +<a href="neorv32__spi__irq_8h.html#a1863e19932bc6a79f2ca27d23eb74ef5"/> +<a href="neorv32__spi__irq_8h.html#a1f44ed849415d8e1d659c0485762c485"/> +<a href="neorv32__spi__irq_8h.html#a4aa4746fd210ecc0c3614089a6951ddf"/> +<a href="neorv32__spi__irq_8h.html#aa641816bb302df497664aa21ea69ed16"/> +<a href="neorv32__sysinfo_8h_source.html"/> +<a href="neorv32__trng_8c.html"/> +<a href="neorv32__trng_8c.html#a87cfe338e2ff559f96c73f729465f967"/> +<a href="neorv32__trng_8c.html#a8b8a1771e37a152792264561b93228fa"/> +<a href="neorv32__trng_8c.html#a9148bcb6a7c448c364e78fa98aac6985"/> +<a href="neorv32__trng_8c.html#aba36f08dd88f2f3e58353ae72eaa14f7"/> +<a href="neorv32__trng_8c.html#ad24e44372f4fd1ed29a6967dccab4fb0"/> +<a href="neorv32__trng_8c.html#ae838bc980e28c300dc2c9c3f34a46bb8"/> +<a href="neorv32__trng_8c.html#af0c4139ff68763623b3d658a8dd8b5ce"/> +<a href="neorv32__trng_8h.html"/> +<a href="neorv32__trng_8h.html#a1440e1355bf5bff17760992adc156b1a"/> +<a href="neorv32__trng_8h.html#a1440e1355bf5bff17760992adc156b1aa0bdf0194eefe95884c5c5853a2f7670d"/> +<a href="neorv32__trng_8h.html#a1440e1355bf5bff17760992adc156b1aa2e0079358668db409fb763eaccb93da9"/> +<a href="neorv32__trng_8h.html#a1440e1355bf5bff17760992adc156b1aa50bb6e10e245a977dcf29a7a138776c6"/> +<a href="neorv32__trng_8h.html#a1440e1355bf5bff17760992adc156b1aa8c0325eede4ffec4530cfd5dc700dc52"/> +<a href="neorv32__trng_8h.html#a1440e1355bf5bff17760992adc156b1aa919c3105723e4fe46e341c63cbf276f5"/> +<a href="neorv32__trng_8h.html#a1440e1355bf5bff17760992adc156b1aa95620874acc9393a05d670824c0bbed2"/> +<a href="neorv32__trng_8h.html#a1440e1355bf5bff17760992adc156b1aa968a770fe6b172183dd97818e09c63da"/> +<a href="neorv32__trng_8h.html#a1440e1355bf5bff17760992adc156b1aaa6990058793ac7d96250693f935837c5"/> +<a href="neorv32__trng_8h.html#a1440e1355bf5bff17760992adc156b1aabf1bb7bc3b44394c85709edd1c9f03ac"/> +<a href="neorv32__trng_8h.html#a87cfe338e2ff559f96c73f729465f967"/> +<a href="neorv32__trng_8h.html#a8b8a1771e37a152792264561b93228fa"/> +<a href="neorv32__trng_8h.html#a9148bcb6a7c448c364e78fa98aac6985"/> +<a href="neorv32__trng_8h.html#a9794ff3746eb5321ad9c2bf522ea26dd"/> +<a href="neorv32__trng_8h.html#aba36f08dd88f2f3e58353ae72eaa14f7"/> +<a href="neorv32__trng_8h.html#ad24e44372f4fd1ed29a6967dccab4fb0"/> +<a href="neorv32__trng_8h.html#ae838bc980e28c300dc2c9c3f34a46bb8"/> +<a href="neorv32__trng_8h.html#af0c4139ff68763623b3d658a8dd8b5ce"/> +<a href="neorv32__twi_8c.html"/> +<a href="neorv32__twi_8c.html#a22717887cffff1e6830756bc73140e7b"/> +<a href="neorv32__twi_8c.html#a28fc44cce5d28f6e8c32268b239b07d5"/> +<a href="neorv32__twi_8c.html#a2c8f3bc55f4a9a8bdcb111759cf56ae2"/> +<a href="neorv32__twi_8c.html#a4fff1ddade320f6cc568c6266f2c2acd"/> +<a href="neorv32__twi_8c.html#a633d460e4735eb369d74a834b03c8b78"/> +<a href="neorv32__twi_8c.html#a7735376d26560866b153ed205dfcb2ba"/> +<a href="neorv32__twi_8c.html#a7ea6f3509a7cf622234d4b83e33afbe3"/> +<a href="neorv32__twi_8c.html#aa22430aab0a38d88cbd2c4220c573da0"/> +<a href="neorv32__twi_8c.html#aa2e01ebbc0c82d65ed4ded351f4d8711"/> +<a href="neorv32__twi_8c.html#ac7020f3379602f11c47ca16f1bd82f2e"/> +<a href="neorv32__twi_8c.html#ad352447adcccccabd4e20577b34fbece"/> +<a href="neorv32__twi_8c.html#adbf2eaed0c76221da5c3091665fc885e"/> +<a href="neorv32__twi_8c.html#ae5f31e737c7a6c3c86070ff34cb0d861"/> +<a href="neorv32__twi_8h.html"/> +<a href="neorv32__twi_8h.html#a22717887cffff1e6830756bc73140e7b"/> +<a href="neorv32__twi_8h.html#a2769c2fe5e0de01b12fe4a5fad029768"/> +<a href="neorv32__twi_8h.html#a28fc44cce5d28f6e8c32268b239b07d5"/> +<a href="neorv32__twi_8h.html#a2c8f3bc55f4a9a8bdcb111759cf56ae2"/> +<a href="neorv32__twi_8h.html#a3421852c63baca60fe58c990b1c653d8"/> +<a href="neorv32__twi_8h.html#a3421852c63baca60fe58c990b1c653d8ab2e20f7f5a5b131c31772341caa97e5e"/> +<a href="neorv32__twi_8h.html#a3421852c63baca60fe58c990b1c653d8ab7f53f7cef06031c1a34db04c602a50d"/> +<a href="neorv32__twi_8h.html#a3421852c63baca60fe58c990b1c653d8accd7e8be435db3055c27f0a6d5e0201e"/> +<a href="neorv32__twi_8h.html#a3421852c63baca60fe58c990b1c653d8adf6176c87655bbbb5c7cea9dea29ce56"/> +<a href="neorv32__twi_8h.html#a3421852c63baca60fe58c990b1c653d8af64359afd3627db0a79733d00128f3a5"/> +<a href="neorv32__twi_8h.html#a4fff1ddade320f6cc568c6266f2c2acd"/> +<a href="neorv32__twi_8h.html#a633d460e4735eb369d74a834b03c8b78"/> +<a href="neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafa"/> +<a href="neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaa183f5b9c3993d04cc9aea2a79e9a4f75"/> +<a href="neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaa43381fe5ab9fe64ebdf76638eba5a694"/> +<a href="neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaa443a2a65ee810f428d40a4f8474d8e6d"/> +<a href="neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaa4473769463a0c7e4b58ed0b983610674"/> +<a href="neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaa4d55ed983ca2f94fa9deac196d949b31"/> +<a href="neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaa74126d424719b1db61f5e1ab567489fb"/> +<a href="neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaa75d3a61b5e642e5d5c1f699c35c26b31"/> +<a href="neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaa8b666cd2e40ca9ba3f9a635f0ed107df"/> +<a href="neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaa9033ac6cc891bff0da52449aa4b6a8d9"/> +<a href="neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaa99e2153a53cc1f9d7cc83d52c698cbcc"/> +<a href="neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaaa0597dc9dea3f6f7a2f19dbcc7a2dabb"/> +<a href="neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaaa6db454861ad5be70846ed4f9eb2ea12"/> +<a href="neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaac62d6e3c47a8195a6a9ccc79129bfe48"/> +<a href="neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaad2798dfabf3a72e6138135e983734671"/> +<a href="neorv32__twi_8h.html#a7735376d26560866b153ed205dfcb2ba"/> +<a href="neorv32__twi_8h.html#a7ea6f3509a7cf622234d4b83e33afbe3"/> +<a href="neorv32__twi_8h.html#aa22430aab0a38d88cbd2c4220c573da0"/> +<a href="neorv32__twi_8h.html#aa2e01ebbc0c82d65ed4ded351f4d8711"/> +<a href="neorv32__twi_8h.html#ac7020f3379602f11c47ca16f1bd82f2e"/> +<a href="neorv32__twi_8h.html#ad352447adcccccabd4e20577b34fbece"/> +<a href="neorv32__twi_8h.html#adbf2eaed0c76221da5c3091665fc885e"/> +<a href="neorv32__twi_8h.html#ae5f31e737c7a6c3c86070ff34cb0d861"/> +<a href="neorv32__uart_8c.html"/> +<a href="neorv32__uart_8c.html#a031e3e27c8783c299623468020a22b0e"/> +<a href="neorv32__uart_8c.html#a07036e93939040c563e862a6a31b65bc"/> +<a href="neorv32__uart_8c.html#a27971954262a2fd1f21d3bf1ba27e87c"/> +<a href="neorv32__uart_8c.html#a2efd432f63b8d36d44263d0b1f39a6dc"/> +<a href="neorv32__uart_8c.html#a3543435827204d82755b0a23bdea1296"/> +<a href="neorv32__uart_8c.html#a3e29caa20f7cffe18f410f01278905a8"/> +<a href="neorv32__uart_8c.html#a45a07d5e71677162baaa1025759c67a2"/> +<a href="neorv32__uart_8c.html#a734b610f4cd1b474d7763f9700a715ec"/> +<a href="neorv32__uart_8c.html#a7b2f924ef4554b1fa90433c38d97558d"/> +<a href="neorv32__uart_8c.html#a8714cdb1c04d94bec322c6215ea10238"/> +<a href="neorv32__uart_8c.html#a9bc7bb94a50b74e1145b78eec6094129"/> +<a href="neorv32__uart_8c.html#a9cdec36f2723c5373664022d1b68b841"/> +<a href="neorv32__uart_8c.html#aa490df3a9bb2aa3215fa6fad34ffe7d1"/> +<a href="neorv32__uart_8c.html#aa7bef48a58e044c246b8c4ad32864502"/> +<a href="neorv32__uart_8c.html#ab8c1f9f451def9126ab2749d7bbe50d9"/> +<a href="neorv32__uart_8c.html#abef6415b0391dc055713404312196682"/> +<a href="neorv32__uart_8c.html#ac429964878bd6deab61d9ed8659bca75"/> +<a href="neorv32__uart_8c.html#adedb0e07efb232717534017167a5be98"/> +<a href="neorv32__uart_8c.html#adf807d0476b475276b8b29924297cda9"/> +<a href="neorv32__uart_8c.html#ae18804ccd29ec2fd1cc06e9ce985b704"/> +<a href="neorv32__uart_8c.html#aefa844cd170e50e088c42829029060f3"/> +<a href="neorv32__uart_8c.html#af85fb929c912d3edef3d86ffa833982a"/> +<a href="neorv32__uart_8c.html#afa0533e81d53057c36f4997a2dbbe2bc"/> +<a href="neorv32__uart_8c.html#afe0de59c14faff1e0c890d5465be25f0"/> +<a href="neorv32__uart_8h.html"/> +<a href="neorv32__uart_8h.html#a031e3e27c8783c299623468020a22b0e"/> +<a href="neorv32__uart_8h.html#a27971954262a2fd1f21d3bf1ba27e87c"/> +<a href="neorv32__uart_8h.html#a2efd432f63b8d36d44263d0b1f39a6dc"/> +<a href="neorv32__uart_8h.html#a45a07d5e71677162baaa1025759c67a2"/> +<a href="neorv32__uart_8h.html#a4c880a6b27e46f459e750425258b1bdb"/> +<a href="neorv32__uart_8h.html#a734b610f4cd1b474d7763f9700a715ec"/> +<a href="neorv32__uart_8h.html#a7b2f924ef4554b1fa90433c38d97558d"/> +<a href="neorv32__uart_8h.html#a8714cdb1c04d94bec322c6215ea10238"/> +<a href="neorv32__uart_8h.html#a9bc7bb94a50b74e1145b78eec6094129"/> +<a href="neorv32__uart_8h.html#a9cdec36f2723c5373664022d1b68b841"/> +<a href="neorv32__uart_8h.html#aa2a9ded4523f001bf69935c80247fa2d"/> +<a href="neorv32__uart_8h.html#aa490df3a9bb2aa3215fa6fad34ffe7d1"/> +<a href="neorv32__uart_8h.html#aa7bef48a58e044c246b8c4ad32864502"/> +<a href="neorv32__uart_8h.html#ab8c1f9f451def9126ab2749d7bbe50d9"/> +<a href="neorv32__uart_8h.html#abef6415b0391dc055713404312196682"/> +<a href="neorv32__uart_8h.html#ac429964878bd6deab61d9ed8659bca75"/> +<a href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afc"/> +<a href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca09c311eb1f6b38500e6fcbb6ad9dd9ff"/> +<a href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca0eb636d8b7961d7073c5c7341b5bbe25"/> +<a href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca15b9fca73877aad446a8cd338e228e2c"/> +<a href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca1ddbca448bb30c77c42499fff1312183"/> +<a href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca1e702002402897eca82bf398504bc439"/> +<a href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca2015dd85e361aa0476e847953b62baff"/> +<a href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca36266026e11f22aca1584bd81cd38cd6"/> +<a href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca36b4195e5d1f12e1fd1a0d30cad0e411"/> +<a href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca38f6c0e5991f8f80159a388c1080f7c2"/> +<a href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca3fc934d0ce6b36e3e131c6682db22247"/> +<a href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca408412a32673cc7f6ea70682e3e61431"/> +<a href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca42ed376220259ab22c6f837d08273ef1"/> +<a href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca47c44fa21e51401621c28019025c1166"/> +<a href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca569ea830518914c5330fa14680b02851"/> +<a href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca58190cd41c2ce69512bea10740d35276"/> +<a href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca5b0e40ab30bdb198f496d09e89d2d0d9"/> +<a href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca5da1d6007af0265fe48ace8469e07833"/> +<a href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca697321bddeaa2cac1ea034c418be540e"/> +<a href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca726b73ef9c44ccc1a45a4230a8bda9d1"/> +<a href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca81a52e0b81018f2cf43e64d74caba632"/> +<a href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca81ea805f01b93a59664823b940c7a424"/> +<a href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca8afd60e4bd3854fab623b91fa4f33f70"/> +<a href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca9ac3c1e23d684cb2f67060d6ebe1fa63"/> +<a href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca9c12648f7f058f444db434cd8a8d854e"/> +<a href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca9c1d8e8763a653339210ff4e6e3067d2"/> +<a href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afcaa219ea3ed5b21f5023bbc5ffa5c5f175"/> +<a href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afcac5c044233b6c4162cf862f3d9831ef46"/> +<a href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afcacab78fcd440167c5a2c0f5d300c8f07c"/> +<a href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afcad38432e7e050276d4667daf92c1e3fd5"/> +<a href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afcae5f01868b170d71a5f3064023c96a82a"/> +<a href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afcaefbef37247d88a7e38e1c53b8a33ed33"/> +<a href="neorv32__uart_8h.html#adcf35350a9ea18a59c32c35f528643f2"/> +<a href="neorv32__uart_8h.html#adcf35350a9ea18a59c32c35f528643f2a19926d013ca202645d38f2c704782ebb"/> +<a href="neorv32__uart_8h.html#adcf35350a9ea18a59c32c35f528643f2a43b296e86d1f2ec7400d57655c3180ef"/> +<a href="neorv32__uart_8h.html#adcf35350a9ea18a59c32c35f528643f2a6d718ad0bb82a5cb053c117cd2d6ca8e"/> +<a href="neorv32__uart_8h.html#adcf35350a9ea18a59c32c35f528643f2a81a82ac0dc5c8c8d7af21553288e3225"/> +<a href="neorv32__uart_8h.html#adcf35350a9ea18a59c32c35f528643f2ada92cbbe278e3e0592eba58c97699529"/> +<a href="neorv32__uart_8h.html#adcf35350a9ea18a59c32c35f528643f2ae70e9f6cd69af724932e79ea7e7f7195"/> +<a href="neorv32__uart_8h.html#adedb0e07efb232717534017167a5be98"/> +<a href="neorv32__uart_8h.html#ae18804ccd29ec2fd1cc06e9ce985b704"/> +<a href="neorv32__uart_8h.html#af85fb929c912d3edef3d86ffa833982a"/> +<a href="neorv32__uart_8h.html#afa0533e81d53057c36f4997a2dbbe2bc"/> +<a href="neorv32__uart_8h.html#afe0de59c14faff1e0c890d5465be25f0"/> +<a href="neorv32__wdt_8c.html"/> +<a href="neorv32__wdt_8c.html#a2aa72608191d34ef41c5f545988ff400"/> +<a href="neorv32__wdt_8c.html#a2e4df2b352d11c31063ef2fc16c510ad"/> +<a href="neorv32__wdt_8c.html#a459a918c5a86c0167e8c748352d39827"/> +<a href="neorv32__wdt_8c.html#a80fa8d178d18c9b02d32d93e815b532e"/> +<a href="neorv32__wdt_8c.html#aba52520582392a671e2b717715a330b2"/> +<a href="neorv32__wdt_8h.html"/> +<a href="neorv32__wdt_8h.html#a0a4cb24fd818277c5bb9b10ff519f23e"/> +<a href="neorv32__wdt_8h.html#a0a4cb24fd818277c5bb9b10ff519f23ea0e078b41b69bd6089acceb592e14553f"/> +<a href="neorv32__wdt_8h.html#a0a4cb24fd818277c5bb9b10ff519f23ea0e7d3e97517f97042ce5606dd5247779"/> +<a href="neorv32__wdt_8h.html#a0a4cb24fd818277c5bb9b10ff519f23ea25dea2104b29a3c20dcc3782c2d43dc7"/> +<a href="neorv32__wdt_8h.html#a0a4cb24fd818277c5bb9b10ff519f23ea28dd25b66c4a50d0ea47a16c460031ac"/> +<a href="neorv32__wdt_8h.html#a0a4cb24fd818277c5bb9b10ff519f23ea45df3c9100beb420add34bf71a0e8609"/> +<a href="neorv32__wdt_8h.html#a0a4cb24fd818277c5bb9b10ff519f23ea4b0d994fe5ff8d8004c7f25b621fb3a9"/> +<a href="neorv32__wdt_8h.html#a0a4cb24fd818277c5bb9b10ff519f23ea6012d63ea4734fc8a063c9edc6785abd"/> +<a href="neorv32__wdt_8h.html#a0a4cb24fd818277c5bb9b10ff519f23ea7b7ea5bd390ecbb5ee0d9542ef124148"/> +<a href="neorv32__wdt_8h.html#a0a4cb24fd818277c5bb9b10ff519f23eadc44267502fceb8e7311dfa502fe54d3"/> +<a href="neorv32__wdt_8h.html#a2aa72608191d34ef41c5f545988ff400"/> +<a href="neorv32__wdt_8h.html#a2e4df2b352d11c31063ef2fc16c510ad"/> +<a href="neorv32__wdt_8h.html#a459a918c5a86c0167e8c748352d39827"/> +<a href="neorv32__wdt_8h.html#a70098b4ee893774864536fb4100ff049"/> +<a href="neorv32__wdt_8h.html#a70098b4ee893774864536fb4100ff049a764a7797f17d82f619a6d30c0878bf1e"/> +<a href="neorv32__wdt_8h.html#a70098b4ee893774864536fb4100ff049a974e73fb98b6a3591c214eba6071fd3c"/> +<a href="neorv32__wdt_8h.html#a70098b4ee893774864536fb4100ff049ac5fc25cdc29c248b1a570b6095ddded0"/> +<a href="neorv32__wdt_8h.html#a78615b08cd799063011606d084fef46c"/> +<a href="neorv32__wdt_8h.html#a80fa8d178d18c9b02d32d93e815b532e"/> +<a href="neorv32__wdt_8h.html#aba52520582392a671e2b717715a330b2"/> +<a href="neorv32__wdt_8h.html#af2a2bd9c74bdba1b46bd92025bd00ab6"/> +<a href="neorv32__xip_8c.html"/> +<a href="neorv32__xip_8c.html#a0ab2c36c973030a811e6d7abe0afc393"/> +<a href="neorv32__xip_8c.html#a549d68abdf5a3d7484abe6d5370bb999"/> +<a href="neorv32__xip_8c.html#a6aef2ea29451ba2aa55160da777a5115"/> +<a href="neorv32__xip_8c.html#a88f728101e82939bf7f8b9ab5a904706"/> +<a href="neorv32__xip_8c.html#a92f1446a3bb7fe6dee5dbed33882b223"/> +<a href="neorv32__xip_8c.html#ad74f2842ed2251e3ae5c19e06dced0c3"/> +<a href="neorv32__xip_8c.html#afe2e5682a26cafdb0585d2233bccc7c6"/> +<a href="neorv32__xip_8h.html"/> +<a href="neorv32__xip_8h.html#a0ab2c36c973030a811e6d7abe0afc393"/> +<a href="neorv32__xip_8h.html#a3d6f138a347c16883b51069428eb7c1e"/> +<a href="neorv32__xip_8h.html#a549d68abdf5a3d7484abe6d5370bb999"/> +<a href="neorv32__xip_8h.html#a6aef2ea29451ba2aa55160da777a5115"/> +<a href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceb"/> +<a href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba23be66e49d28dd12c5321e576d2f0c7a"/> +<a href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba27658ce3cc81c9e258b73fb02d7f1045"/> +<a href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba2c4a47f88d299782b8618b68fb87d59a"/> +<a href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba2c78cd2d32cfba4d89f7aab92f7939e7"/> +<a href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba3cbd45a66e05a4fcfc5ec810b8cee937"/> +<a href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba43d7305e0e0398cb44c99e70dcd96445"/> +<a href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba5885ed5fcd2eed969bd921afe8dff4fc"/> +<a href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba5aadb2c374d34b878b56a660baec2080"/> +<a href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba5d13c4fe190fcd68dfcbbbe33d2e844c"/> +<a href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba603f9d8d22ae2a6abc61b666bc88a4df"/> +<a href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba61ffffe9acda5c622b48b6360e357eef"/> +<a href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba67a0c0483eaf92e9cd03e9076be5b50d"/> +<a href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba68775854b8f2cfa2f32d2eb82a714073"/> +<a href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba76d2379d0e7ab09e7e686bc886888fa5"/> +<a href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba7ad9f81356d6923d524d1c9e39acdd2c"/> +<a href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba8287016f167727f147806aa11129e05b"/> +<a href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba896815c075a91a8291585eb61b6e0086"/> +<a href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba95ae19cf5d5140df397ead62f151247f"/> +<a href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483cebaaeb104a59215667aabb5a751632ae781"/> +<a href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483cebad31736f4a159745be94b487079c4c14d"/> +<a href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483cebae47f2e1e8c023fd52e25a3dad5e332af"/> +<a href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483cebaf9b56aa629973ce4a9c8ff61a2c90ba3"/> +<a href="neorv32__xip_8h.html#a88f728101e82939bf7f8b9ab5a904706"/> +<a href="neorv32__xip_8h.html#a92f1446a3bb7fe6dee5dbed33882b223"/> +<a href="neorv32__xip_8h.html#ad74f2842ed2251e3ae5c19e06dced0c3"/> +<a href="neorv32__xip_8h.html#afe2e5682a26cafdb0585d2233bccc7c6"/> +<a href="neorv32__xirq_8c.html"/> +<a href="neorv32__xirq_8c.html#a0d137f09d1e7dcd31c157b856033ac42"/> +<a href="neorv32__xirq_8c.html#a14661d628dd31e6bfce89376c6614627"/> +<a href="neorv32__xirq_8c.html#a49ae67d1d5066cd795149e96b81127f7"/> +<a href="neorv32__xirq_8c.html#a717a8e34908cc01345e68920e76f229c"/> +<a href="neorv32__xirq_8c.html#a76468156ef52b371e06bc2ca8eddcd27"/> +<a href="neorv32__xirq_8c.html#a76d73c3bf372989703c685a9e8d229ac"/> +<a href="neorv32__xirq_8c.html#a83ecaf568a6f6bcb1e1efdb1eef6df9c"/> +<a href="neorv32__xirq_8c.html#a9129984f91c02afafaa072a5d86f9876"/> +<a href="neorv32__xirq_8c.html#a9295997fce7114a8205325c4d75dd200"/> +<a href="neorv32__xirq_8c.html#aaf30757d526030a8d81081915ab29a76"/> +<a href="neorv32__xirq_8c.html#abe63c0968c94b472082c8156a1a7db5c"/> +<a href="neorv32__xirq_8c.html#ac64d3ff5619968499bccebebe6a6cab3"/> +<a href="neorv32__xirq_8c.html#ae17509ad0c828aa9b36747b253cdbf0a"/> +<a href="neorv32__xirq_8c.html#ae4d9362b23a1341c595a4cd239a87091"/> +<a href="neorv32__xirq_8h.html"/> +<a href="neorv32__xirq_8h.html#a0c0886139e9837867202e5f6a83307c4"/> +<a href="neorv32__xirq_8h.html#a0d137f09d1e7dcd31c157b856033ac42"/> +<a href="neorv32__xirq_8h.html#a49ae67d1d5066cd795149e96b81127f7"/> +<a href="neorv32__xirq_8h.html#a59316ffc7ee1aacf1d55d460bdca4d04"/> +<a href="neorv32__xirq_8h.html#a717a8e34908cc01345e68920e76f229c"/> +<a href="neorv32__xirq_8h.html#a76468156ef52b371e06bc2ca8eddcd27"/> +<a href="neorv32__xirq_8h.html#a83ecaf568a6f6bcb1e1efdb1eef6df9c"/> +<a href="neorv32__xirq_8h.html#a8bc89e6a47b4d0d95fb2afac4cdc9292"/> +<a href="neorv32__xirq_8h.html#a9129984f91c02afafaa072a5d86f9876"/> +<a href="neorv32__xirq_8h.html#a9295997fce7114a8205325c4d75dd200"/> +<a href="neorv32__xirq_8h.html#a9b10e89b2e257e1af410bff89f29911c"/> +<a href="neorv32__xirq_8h.html#aaf30757d526030a8d81081915ab29a76"/> +<a href="neorv32__xirq_8h.html#ab7a05371e4dc3de3a9be11c59f5376ee"/> +<a href="neorv32__xirq_8h.html#abe63c0968c94b472082c8156a1a7db5c"/> +<a href="neorv32__xirq_8h.html#ac64d3ff5619968499bccebebe6a6cab3"/> +<a href="neorv32__xirq_8h.html#ae17509ad0c828aa9b36747b253cdbf0a"/> +<a href="onewire__aux_8h_source.html"/> +<a href="processor__check_2main_8c.html"/> +<a href="processor__check_2main_8c.html#a0d695ebfaae3b4614ddb62640cbf8b7b"/> +<a href="processor__check_2main_8c.html#a1a455bede4ab48f32d3ed0868e398044"/> +<a href="processor__check_2main_8c.html#a1e0a5d63896fa26a6c25c0012fc6b938"/> +<a href="processor__check_2main_8c.html#a277cb06ef74e4cfe1ef783069f9b6527"/> +<a href="processor__check_2main_8c.html#a31d9e432f6a368e6222f5e0907eeb6f4"/> +<a href="processor__check_2main_8c.html#a349743a03307abb5130a3e89d903971b"/> +<a href="processor__check_2main_8c.html#a9504ca74fdb80711a88d2a16d4cb4cf4"/> +<a href="processor__check_2main_8c.html#a9a64ce0ee69c4c32cecc8b2b2746604c"/> +<a href="processor__check_2main_8c.html#aa4fe70578c4dccabe1e31fae941378cb"/> +<a href="processor__check_2main_8c.html#ac91bfdd45696444673dc7d6b1b644082"/> +<a href="processor__check_2main_8c.html#ada24f2cd9d2d384265517f539711de62"/> +<a href="processor__check_2main_8c.html#ae61d39109b2747429ec3a3c1b5533598"/> +<a href="processor__check_2main_8c.html#ae66f6b31b5ad750f1fe042a706a4e3d4"/> +<a href="structdate__t.html"/> +<a href="structdate__t.html#a1071948e7754cb415da9714d59a315bf"/> +<a href="structdate__t.html#a1a97f6a755cd4209a0880cf811d52c7b"/> +<a href="structdate__t.html#a2ab79834ebae42979e359bf30ad5f67a"/> +<a href="structdate__t.html#a39a23695634a2814d827984f4eea54eb"/> +<a href="structdate__t.html#a44167cd71416886e55048310af6d4e1b"/> +<a href="structdate__t.html#a482ad87226bae7841dfec63e035aeace"/> +<a href="structdate__t.html#aabab1b1efd94b69bfb28b639c612dd4f"/> +<a href="structneorv32__cfs__t.html"/> +<a href="structneorv32__cfs__t.html#a48d3e81b207f4dcce0b0cc901583dc4d"/> +<a href="structneorv32__crc__t.html"/> +<a href="structneorv32__crc__t.html#a47f286612848f597859aaef0d2d5da4d"/> +<a href="structneorv32__crc__t.html#a9bbcab843ddba4f9772d07478947a661"/> +<a href="structneorv32__crc__t.html#abf2b419f2aefdb6f2a6b81a02cb8612d"/> +<a href="structneorv32__crc__t.html#ad720502701f16e6e952bbcaee980017c"/> +<a href="structneorv32__dma__t.html"/> +<a href="structneorv32__dma__t.html#a3b214d1a373c7f15b374e113d7110b42"/> +<a href="structneorv32__dma__t.html#a70c28642195765409d97b941e98f47ca"/> +<a href="structneorv32__dma__t.html#a8480d6ad3ba5063cdf21dca286711569"/> +<a href="structneorv32__dma__t.html#aee8a6cf3cbd9fe3c5995f046ffb9a1c0"/> +<a href="structneorv32__gpio__t.html"/> +<a href="structneorv32__gpio__t.html#a208ee622d43fee3574072f19a98c8808"/> +<a href="structneorv32__gpio__t.html#abaf7de4f79adfc3debcde93fa4a921bb"/> +<a href="structneorv32__gptmr__t.html"/> +<a href="structneorv32__gptmr__t.html#a1abc5bae1dffc64006e965d4570da479"/> +<a href="structneorv32__gptmr__t.html#a3c477ccb24ed12122d9d90244431c7e9"/> +<a href="structneorv32__gptmr__t.html#a666ebcbea13dafcf1987629f3e0092ee"/> +<a href="structneorv32__mtime__t.html"/> +<a href="structneorv32__mtime__t.html#a1ffe0be2c45f5d7aa2686abf40cd1693"/> +<a href="structneorv32__mtime__t.html#ab5fa56ca5c2f9d547f58d169d6da96e5"/> +<a href="structneorv32__mtime__t.html#acccaa3dd87a57ebd5f7ae504771e904e"/> +<a href="structneorv32__mtime__t.html#af05df268c8f699401cf752e4249ba422"/> +<a href="structneorv32__neoled__t.html"/> +<a href="structneorv32__neoled__t.html#a995fb1d63a9dfb3f20d715932781c1de"/> +<a href="structneorv32__neoled__t.html#adfe7618c002ff88dd22e65fcedfd6139"/> +<a href="structneorv32__onewire__t.html"/> +<a href="structneorv32__onewire__t.html#a2c04aa736b901940ed65b96202c8af7a"/> +<a href="structneorv32__onewire__t.html#a310df3bab43e4438417b2ff948f4712a"/> +<a href="structneorv32__pwm__t.html"/> +<a href="structneorv32__pwm__t.html#a6d29528ca60921a6ef8e5bcde81925e7"/> +<a href="structneorv32__pwm__t.html#ab86705332ebd9c45635c3195c6b3dcc5"/> +<a href="structneorv32__sdi__t.html"/> +<a href="structneorv32__sdi__t.html#a3ea6903c0924d0a1b633b6a2b0ae44f1"/> +<a href="structneorv32__sdi__t.html#af494f25cbcd8478cf384eb868e447303"/> +<a href="structneorv32__slink__t.html"/> +<a href="structneorv32__slink__t.html#a0b2417a1a587da45909ce2a948f90e22"/> +<a href="structneorv32__slink__t.html#a39ece6aeeea6982002e164902a1e784f"/> +<a href="structneorv32__slink__t.html#a8af7d4ea9787cf94c599c82133c6aa74"/> +<a href="structneorv32__slink__t.html#ada8f10141d2161b83a5a367722ed6a77"/> +<a href="structneorv32__spi__t.html"/> +<a href="structneorv32__spi__t.html#a34fa748f0e3ceb75822c0a5553bd0420"/> +<a href="structneorv32__spi__t.html#a3901bad351213e34820197a33d589f1e"/> +<a href="structneorv32__sysinfo__t.html"/> +<a href="structneorv32__sysinfo__t.html#a51eee92b1824c1b19eb0a83a0a9c7d4c"/> +<a href="structneorv32__sysinfo__t.html#ac43abe3b416da3a2895d1d06537a14c3"/> +<a href="structneorv32__sysinfo__t.html#ada99a36ccda38b254d5b6a84883101f6"/> +<a href="structneorv32__sysinfo__t.html#afc225843ee31efff6350415b5aaae761"/> +<a href="structneorv32__trng__t.html"/> +<a href="structneorv32__trng__t.html#ae2ff37ce30fb85ef59d9012534bc7e67"/> +<a href="structneorv32__twi__t.html"/> +<a href="structneorv32__twi__t.html#a148a1c681a2632881b25ee41652b5304"/> +<a href="structneorv32__twi__t.html#ae311e0827bdb178c6dd8c4535b80d5cb"/> +<a href="structneorv32__uart__t.html"/> +<a href="structneorv32__uart__t.html#a0a6227aeea38335d2b9a9da46b35451b"/> +<a href="structneorv32__uart__t.html#a38eec82aae9ed522a0d2afb9a9560036"/> +<a href="structneorv32__wdt__t.html"/> +<a href="structneorv32__wdt__t.html#a0a273e8ca2bd92547bf7727ec65a9449"/> +<a href="structneorv32__wdt__t.html#a6ae41e28d08b0f06118c499f52b56f41"/> +<a href="structneorv32__xip__t.html"/> +<a href="structneorv32__xip__t.html#a516ab9c075ef6d1fb741e243db7703b2"/> +<a href="structneorv32__xip__t.html#a7ead9d6a4f784d766a6b2755c6d35235"/> +<a href="structneorv32__xip__t.html#aacb77d586c3caec518e8e0024cfe745c"/> +<a href="structneorv32__xip__t.html#ad64048bb3544e712b1c668c2ef343ccb"/> +<a href="structneorv32__xirq__t.html"/> +<a href="structneorv32__xirq__t.html#a5fe0036a2cada585228b60aaa780e92a"/> +<a href="structneorv32__xirq__t.html#a788d8004f3b85fb66e947415d8fcc058"/> +<a href="structneorv32__xirq__t.html#a9be02c0398fab5763a3afbd7a018f092"/> +<a href="structneorv32__xirq__t.html#ab7117c210b5f0a8ebc369eeba6a4a5bc"/> +<a href="structneorv32__xirq__t.html#ac4c999cf3da75e39753619f917d9d654"/> +<a href="structneorv32__xirq__t.html#ae4f7f3f41210ff329b6f82d5dfada88a"/> +<a href="structneorv32__xirq__t.html#aef3c2b491207abd68bf6392f97096a74"/> +<a href="structneorv32__xirq__t.html#afba6ed500e1448719783923975b2dc64"/> +<a href="structrecord.html"/> +<a href="structt__neorv32__spi.html"/> +<a href="structt__neorv32__spi.html#a435c266758a440d32de4344472e3514a"/> +<a href="structt__neorv32__spi.html#a487a6510820871ff8d0da7699463f6d9"/> +<a href="structt__neorv32__spi.html#a5750a54f8312ec2fed349eb9fbeff323"/> +<a href="structt__neorv32__spi.html#a71fb3f91af197e1abdbe97d62130ad0f"/> +<a href="structt__neorv32__spi.html#a8ed31f9393bee5b963e08582b6c517ed"/> +<a href="structt__neorv32__spi.html#aa4d96f72e57fb6930ab43de6fb0a85ae"/> +<a href="structt__neorv32__spi.html#aa89b7a769e54e331798e4d68d02a7b43"/> +<a href="syscalls_8c.html"/> +<a href="unionfloat__conv__t.html"/> +<a href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606"/> +<a href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788"/> +<a href="unionsubwords16__t.html"/> +<a href="unionsubwords32__t.html"/> +<a href="unionsubwords64__t.html"/> +</body> +</html> diff --git a/sw/dynsections.js b/sw/dynsections.js new file mode 100644 index 0000000000..b05f4c8d70 --- /dev/null +++ b/sw/dynsections.js @@ -0,0 +1,198 @@ +/* + @licstart The following is the entire license notice for the JavaScript code in this file. + + The MIT License (MIT) + + Copyright (C) 1997-2020 by Dimitri van Heesch + + Permission is hereby granted, free of charge, to any person obtaining a copy of this software + and associated documentation files (the "Software"), to deal in the Software without restriction, + including without limitation the rights to use, copy, modify, merge, publish, distribute, + sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is + furnished to do so, subject to the following conditions: + + The above copyright notice and this permission notice shall be included in all copies or + substantial portions of the Software. + + THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING + BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND + NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, + DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. + + @licend The above is the entire license notice for the JavaScript code in this file + */ + +function toggleVisibility(linkObj) { + return dynsection.toggleVisibility(linkObj); +} + +let dynsection = { + + // helper function + updateStripes : function() { + $('table.directory tr'). + removeClass('even').filter(':visible:even').addClass('even'); + $('table.directory tr'). + removeClass('odd').filter(':visible:odd').addClass('odd'); + }, + + toggleVisibility : function(linkObj) { + const base = $(linkObj).attr('id'); + const summary = $('#'+base+'-summary'); + const content = $('#'+base+'-content'); + const trigger = $('#'+base+'-trigger'); + const src=$(trigger).attr('src'); + if (content.is(':visible')===true) { + content.hide(); + summary.show(); + $(linkObj).addClass('closed').removeClass('opened'); + $(trigger).attr('src',src.substring(0,src.length-8)+'closed.png'); + } else { + content.show(); + summary.hide(); + $(linkObj).removeClass('closed').addClass('opened'); + $(trigger).attr('src',src.substring(0,src.length-10)+'open.png'); + } + return false; + }, + + toggleLevel : function(level) { + $('table.directory tr').each(function() { + const l = this.id.split('_').length-1; + const i = $('#img'+this.id.substring(3)); + const a = $('#arr'+this.id.substring(3)); + if (l<level+1) { + i.removeClass('iconfopen iconfclosed').addClass('iconfopen'); + a.html('&#9660;'); + $(this).show(); + } else if (l==level+1) { + i.removeClass('iconfclosed iconfopen').addClass('iconfclosed'); + a.html('&#9658;'); + $(this).show(); + } else { + $(this).hide(); + } + }); + this.updateStripes(); + }, + + toggleFolder : function(id) { + // the clicked row + const currentRow = $('#row_'+id); + + // all rows after the clicked row + const rows = currentRow.nextAll("tr"); + + const re = new RegExp('^row_'+id+'\\d+_$', "i"); //only one sub + + // only match elements AFTER this one (can't hide elements before) + const childRows = rows.filter(function() { return this.id.match(re); }); + + // first row is visible we are HIDING + if (childRows.filter(':first').is(':visible')===true) { + // replace down arrow by right arrow for current row + const currentRowSpans = currentRow.find("span"); + currentRowSpans.filter(".iconfopen").removeClass("iconfopen").addClass("iconfclosed"); + currentRowSpans.filter(".arrow").html('&#9658;'); + rows.filter("[id^=row_"+id+"]").hide(); // hide all children + } else { // we are SHOWING + // replace right arrow by down arrow for current row + const currentRowSpans = currentRow.find("span"); + currentRowSpans.filter(".iconfclosed").removeClass("iconfclosed").addClass("iconfopen"); + currentRowSpans.filter(".arrow").html('&#9660;'); + // replace down arrows by right arrows for child rows + const childRowsSpans = childRows.find("span"); + childRowsSpans.filter(".iconfopen").removeClass("iconfopen").addClass("iconfclosed"); + childRowsSpans.filter(".arrow").html('&#9658;'); + childRows.show(); //show all children + } + this.updateStripes(); + }, + + toggleInherit : function(id) { + const rows = $('tr.inherit.'+id); + const img = $('tr.inherit_header.'+id+' img'); + const src = $(img).attr('src'); + if (rows.filter(':first').is(':visible')===true) { + rows.css('display','none'); + $(img).attr('src',src.substring(0,src.length-8)+'closed.png'); + } else { + rows.css('display','table-row'); // using show() causes jump in firefox + $(img).attr('src',src.substring(0,src.length-10)+'open.png'); + } + }, +}; + +let codefold = { + opened : true, + + // in case HTML_COLORSTYLE is LIGHT or DARK the vars will be replaced, so we write them out explicitly and use double quotes + plusImg: [ "var(--fold-plus-image)", "var(--fold-plus-image-relpath)" ], + minusImg: [ "var(--fold-minus-image)", "var(--fold-minus-image-relpath)" ], + + // toggle all folding blocks + toggle_all : function(relPath) { + if (this.opened) { + $('#fold_all').css('background-image',this.plusImg[relPath]); + $('div[id^=foldopen]').hide(); + $('div[id^=foldclosed]').show(); + } else { + $('#fold_all').css('background-image',this.minusImg[relPath]); + $('div[id^=foldopen]').show(); + $('div[id^=foldclosed]').hide(); + } + this.opened=!this.opened; + }, + + // toggle single folding block + toggle : function(id) { + $('#foldopen'+id).toggle(); + $('#foldclosed'+id).toggle(); + }, + + init : function(relPath) { + $('span[class=lineno]').css({ + 'padding-right':'4px', + 'margin-right':'2px', + 'display':'inline-block', + 'width':'54px', + 'background':'linear-gradient(var(--fold-line-color),var(--fold-line-color)) no-repeat 46px/2px 100%' + }); + // add global toggle to first line + $('span[class=lineno]:first').append('<span class="fold" id="fold_all" '+ + 'onclick="javascript:codefold.toggle_all('+relPath+');" '+ + 'style="background-image:'+this.minusImg[relPath]+';"></span>'); + // add vertical lines to other rows + $('span[class=lineno]').not(':eq(0)').append('<span class="fold"></span>'); + // add toggle controls to lines with fold divs + $('div[class=foldopen]').each(function() { + // extract specific id to use + const id = $(this).attr('id').replace('foldopen',''); + // extract start and end foldable fragment attributes + const start = $(this).attr('data-start'); + const end = $(this).attr('data-end'); + // replace normal fold span with controls for the first line of a foldable fragment + $(this).find('span[class=fold]:first').replaceWith('<span class="fold" '+ + 'onclick="javascript:codefold.toggle(\''+id+'\');" '+ + 'style="background-image:'+codefold.minusImg[relPath]+';"></span>'); + // append div for folded (closed) representation + $(this).after('<div id="foldclosed'+id+'" class="foldclosed" style="display:none;"></div>'); + // extract the first line from the "open" section to represent closed content + const line = $(this).children().first().clone(); + // remove any glow that might still be active on the original line + $(line).removeClass('glow'); + if (start) { + // if line already ends with a start marker (e.g. trailing {), remove it + $(line).html($(line).html().replace(new RegExp('\\s*'+start+'\\s*$','g'),'')); + } + // replace minus with plus symbol + $(line).find('span[class=fold]').css('background-image',codefold.plusImg[relPath]); + // append ellipsis + $(line).append(' '+start+'<a href="javascript:codefold.toggle(\''+id+'\')">&#8230;</a>'+end); + // insert constructed line into closed div + $('#foldclosed'+id).html(line); + }); + }, +}; +/* @license-end */ diff --git a/sw/files.html b/sw/files.html new file mode 100644 index 0000000000..378558d808 --- /dev/null +++ b/sw/files.html @@ -0,0 +1,227 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: File List</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +</div><!-- top --> +<div id="doc-content"> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div class="header"> + <div class="headertitle"><div class="title">File List</div></div> +</div><!--header--> +<div class="contents"> +<div class="textblock">Here is a list of all documented files with brief descriptions:</div><div class="directory"> +<div class="levels">[detail level <span onclick="javascript:dynsection.toggleLevel(1);">1</span><span onclick="javascript:dynsection.toggleLevel(2);">2</span><span onclick="javascript:dynsection.toggleLevel(3);">3</span><span onclick="javascript:dynsection.toggleLevel(4);">4</span><span onclick="javascript:dynsection.toggleLevel(5);">5</span>]</div><table class="directory"> +<tr id="row_0_" class="even"><td class="entry"><span style="width:0px;display:inline-block;">&#160;</span><span id="arr_0_" class="arrow" onclick="dynsection.toggleFolder('0_')">&#9660;</span><span id="img_0_" class="iconfopen" onclick="dynsection.toggleFolder('0_')">&#160;</span><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html" target="_self">sw</a></td><td class="desc"></td></tr> +<tr id="row_0_0_" class="odd"><td class="entry"><span style="width:16px;display:inline-block;">&#160;</span><span id="arr_0_0_" class="arrow" onclick="dynsection.toggleFolder('0_0_')">&#9660;</span><span id="img_0_0_" class="iconfopen" onclick="dynsection.toggleFolder('0_0_')">&#160;</span><a class="el" href="dir_4316bb0e553b51b8b65560981547ce0f.html" target="_self">bootloader</a></td><td class="desc"></td></tr> +<tr id="row_0_0_0_" class="even"><td class="entry"><span style="width:48px;display:inline-block;">&#160;</span><span class="icondoc"></span><a class="el" href="bootloader_8c.html" target="_self">bootloader.c</a></td><td class="desc">Default NEORV32 bootloader </td></tr> +<tr id="row_0_1_" class="odd"><td class="entry"><span style="width:16px;display:inline-block;">&#160;</span><span id="arr_0_1_" class="arrow" onclick="dynsection.toggleFolder('0_1_')">&#9660;</span><span id="img_0_1_" class="iconfopen" onclick="dynsection.toggleFolder('0_1_')">&#160;</span><a class="el" href="dir_f0f9b27afba2e8cc2da6e5fddcc1a8c9.html" target="_self">example</a></td><td class="desc"></td></tr> +<tr id="row_0_1_0_" class="even"><td class="entry"><span style="width:32px;display:inline-block;">&#160;</span><span id="arr_0_1_0_" class="arrow" onclick="dynsection.toggleFolder('0_1_0_')">&#9658;</span><span id="img_0_1_0_" class="iconfclosed" onclick="dynsection.toggleFolder('0_1_0_')">&#160;</span><a class="el" href="dir_449d8ba5f8b78dc90092f20d15a2386a.html" target="_self">atomic_test</a></td><td class="desc"></td></tr> +<tr id="row_0_1_0_0_" class="odd" style="display:none;"><td class="entry"><span style="width:64px;display:inline-block;">&#160;</span><span class="icondoc"></span><a class="el" href="atomic__test_2main_8c.html" target="_self">main.c</a></td><td class="desc">Test program for the NEORV32 'A' ISA extension - check the emulation of the AMO (read-modify-write) operations </td></tr> +<tr id="row_0_1_1_" class="odd"><td class="entry"><span style="width:32px;display:inline-block;">&#160;</span><span id="arr_0_1_1_" class="arrow" onclick="dynsection.toggleFolder('0_1_1_')">&#9658;</span><span id="img_0_1_1_" class="iconfclosed" onclick="dynsection.toggleFolder('0_1_1_')">&#160;</span><a class="el" href="dir_0d2921e55a1172a4726516961ee96ab5.html" target="_self">bus_explorer</a></td><td class="desc"></td></tr> +<tr id="row_0_1_1_0_" class="even" style="display:none;"><td class="entry"><span style="width:64px;display:inline-block;">&#160;</span><span class="icondoc"></span><a class="el" href="bus__explorer_2main_8c.html" target="_self">main.c</a></td><td class="desc">Interactive memory inspector </td></tr> +<tr id="row_0_1_2_" class="even"><td class="entry"><span style="width:32px;display:inline-block;">&#160;</span><span id="arr_0_1_2_" class="arrow" onclick="dynsection.toggleFolder('0_1_2_')">&#9658;</span><span id="img_0_1_2_" class="iconfclosed" onclick="dynsection.toggleFolder('0_1_2_')">&#160;</span><a class="el" href="dir_9a1c128d67c35790e92af404beb936aa.html" target="_self">demo_blink_led</a></td><td class="desc"></td></tr> +<tr id="row_0_1_2_0_" class="odd" style="display:none;"><td class="entry"><span style="width:64px;display:inline-block;">&#160;</span><span class="icondoc"></span><a class="el" href="demo__blink__led_2main_8c.html" target="_self">main.c</a></td><td class="desc">Minimal blinking LED demo program using the lowest 8 bits of the GPIO.output port </td></tr> +<tr id="row_0_1_3_" class="odd"><td class="entry"><span style="width:32px;display:inline-block;">&#160;</span><span id="arr_0_1_3_" class="arrow" onclick="dynsection.toggleFolder('0_1_3_')">&#9658;</span><span id="img_0_1_3_" class="iconfclosed" onclick="dynsection.toggleFolder('0_1_3_')">&#160;</span><a class="el" href="dir_01cde3d98944a579dc3b5e43a5311a79.html" target="_self">demo_cfs</a></td><td class="desc"></td></tr> +<tr id="row_0_1_3_0_" class="even" style="display:none;"><td class="entry"><span style="width:64px;display:inline-block;">&#160;</span><span class="icondoc"></span><a class="el" href="demo__cfs_2main_8c.html" target="_self">main.c</a></td><td class="desc">Simple demo program for the <em>default</em> custom functions subsystem (CFS) module </td></tr> +<tr id="row_0_1_4_" class="even"><td class="entry"><span style="width:32px;display:inline-block;">&#160;</span><span id="arr_0_1_4_" class="arrow" onclick="dynsection.toggleFolder('0_1_4_')">&#9658;</span><span id="img_0_1_4_" class="iconfclosed" onclick="dynsection.toggleFolder('0_1_4_')">&#160;</span><a class="el" href="dir_09a89dfa1596b6613cf2c29528a32844.html" target="_self">demo_cfu</a></td><td class="desc"></td></tr> +<tr id="row_0_1_4_0_" class="odd" style="display:none;"><td class="entry"><span style="width:64px;display:inline-block;">&#160;</span><span class="icondoc"></span><a class="el" href="demo__cfu_2main_8c.html" target="_self">main.c</a></td><td class="desc">Example program showing how to use the CFU's custom instructions (XTEA example) </td></tr> +<tr id="row_0_1_5_" class="odd"><td class="entry"><span style="width:32px;display:inline-block;">&#160;</span><span id="arr_0_1_5_" class="arrow" onclick="dynsection.toggleFolder('0_1_5_')">&#9658;</span><span id="img_0_1_5_" class="iconfclosed" onclick="dynsection.toggleFolder('0_1_5_')">&#160;</span><a class="el" href="dir_bf935196a1ea0ca9cb42aae56d70946a.html" target="_self">demo_crc</a></td><td class="desc"></td></tr> +<tr id="row_0_1_5_0_" class="even" style="display:none;"><td class="entry"><span style="width:64px;display:inline-block;">&#160;</span><span class="icondoc"></span><a class="el" href="demo__crc_2main_8c.html" target="_self">main.c</a></td><td class="desc">CRC demo program </td></tr> +<tr id="row_0_1_6_" class="even"><td class="entry"><span style="width:32px;display:inline-block;">&#160;</span><span id="arr_0_1_6_" class="arrow" onclick="dynsection.toggleFolder('0_1_6_')">&#9658;</span><span id="img_0_1_6_" class="iconfclosed" onclick="dynsection.toggleFolder('0_1_6_')">&#160;</span><a class="el" href="dir_8c514361e1f16692c783b23503f30f16.html" target="_self">demo_dma</a></td><td class="desc"></td></tr> +<tr id="row_0_1_6_0_" class="odd" style="display:none;"><td class="entry"><span style="width:64px;display:inline-block;">&#160;</span><span class="icondoc"></span><a class="el" href="demo__dma_2main_8c.html" target="_self">main.c</a></td><td class="desc">DMA demo program </td></tr> +<tr id="row_0_1_7_" class="odd"><td class="entry"><span style="width:32px;display:inline-block;">&#160;</span><span id="arr_0_1_7_" class="arrow" onclick="dynsection.toggleFolder('0_1_7_')">&#9658;</span><span id="img_0_1_7_" class="iconfclosed" onclick="dynsection.toggleFolder('0_1_7_')">&#160;</span><a class="el" href="dir_2ba96d3140b089dada6fb9f817b7975f.html" target="_self">demo_emulate_unaligned</a></td><td class="desc"></td></tr> +<tr id="row_0_1_7_0_" class="even" style="display:none;"><td class="entry"><span style="width:64px;display:inline-block;">&#160;</span><span class="icondoc"></span><a class="el" href="demo__emulate__unaligned_2main_8c.html" target="_self">main.c</a></td><td class="desc">Demo program for emulating unaligned memory accesses using the NEORV32 run-time environment (RTE) </td></tr> +<tr id="row_0_1_8_" class="even"><td class="entry"><span style="width:32px;display:inline-block;">&#160;</span><span id="arr_0_1_8_" class="arrow" onclick="dynsection.toggleFolder('0_1_8_')">&#9658;</span><span id="img_0_1_8_" class="iconfclosed" onclick="dynsection.toggleFolder('0_1_8_')">&#160;</span><a class="el" href="dir_b68ac2efc0c6ed3018151f7bb6c45670.html" target="_self">demo_gptmr</a></td><td class="desc"></td></tr> +<tr id="row_0_1_8_0_" class="odd" style="display:none;"><td class="entry"><span style="width:64px;display:inline-block;">&#160;</span><span class="icondoc"></span><a class="el" href="demo__gptmr_2main_8c.html" target="_self">main.c</a></td><td class="desc">Simple GPTMR timer-match interrupt example </td></tr> +<tr id="row_0_1_9_" class="odd"><td class="entry"><span style="width:32px;display:inline-block;">&#160;</span><span id="arr_0_1_9_" class="arrow" onclick="dynsection.toggleFolder('0_1_9_')">&#9658;</span><span id="img_0_1_9_" class="iconfclosed" onclick="dynsection.toggleFolder('0_1_9_')">&#160;</span><a class="el" href="dir_93967190e0d2e549ceca77007097849b.html" target="_self">demo_hpm</a></td><td class="desc"></td></tr> +<tr id="row_0_1_9_0_" class="even" style="display:none;"><td class="entry"><span style="width:64px;display:inline-block;">&#160;</span><span class="icondoc"></span><a class="el" href="demo__hpm_2main_8c.html" target="_self">main.c</a></td><td class="desc">Hardware performance monitor (HPM) example program </td></tr> +<tr id="row_0_1_10_" class="even"><td class="entry"><span style="width:32px;display:inline-block;">&#160;</span><span id="arr_0_1_10_" class="arrow" onclick="dynsection.toggleFolder('0_1_10_')">&#9658;</span><span id="img_0_1_10_" class="iconfclosed" onclick="dynsection.toggleFolder('0_1_10_')">&#160;</span><a class="el" href="dir_8d341cbe0581f44e1ae95d82d74e8bc8.html" target="_self">demo_mtime</a></td><td class="desc"></td></tr> +<tr id="row_0_1_10_0_" class="odd" style="display:none;"><td class="entry"><span style="width:64px;display:inline-block;">&#160;</span><span class="icondoc"></span><a class="el" href="demo__mtime_2main_8c.html" target="_self">main.c</a></td><td class="desc">Simple machine timer (MTIME) usage example </td></tr> +<tr id="row_0_1_11_" class="odd"><td class="entry"><span style="width:32px;display:inline-block;">&#160;</span><span id="arr_0_1_11_" class="arrow" onclick="dynsection.toggleFolder('0_1_11_')">&#9658;</span><span id="img_0_1_11_" class="iconfclosed" onclick="dynsection.toggleFolder('0_1_11_')">&#160;</span><a class="el" href="dir_d68bb921df3f2482fe9ace49b286ab86.html" target="_self">demo_neopixel</a></td><td class="desc"></td></tr> +<tr id="row_0_1_11_0_" class="even" style="display:none;"><td class="entry"><span style="width:64px;display:inline-block;">&#160;</span><span class="icondoc"></span><a class="el" href="demo__neopixel_2main_8c.html" target="_self">main.c</a></td><td class="desc">NeoPixel (WS2812) interface demo using the processor's smart LED interface (NEOLED) </td></tr> +<tr id="row_0_1_12_" class="even"><td class="entry"><span style="width:32px;display:inline-block;">&#160;</span><span id="arr_0_1_12_" class="arrow" onclick="dynsection.toggleFolder('0_1_12_')">&#9658;</span><span id="img_0_1_12_" class="iconfclosed" onclick="dynsection.toggleFolder('0_1_12_')">&#160;</span><a class="el" href="dir_23717ebbabf7a51c0558262947e0fe3b.html" target="_self">demo_newlib</a></td><td class="desc"></td></tr> +<tr id="row_0_1_12_0_" class="odd" style="display:none;"><td class="entry"><span style="width:64px;display:inline-block;">&#160;</span><span class="icondoc"></span><a class="el" href="demo__newlib_2main_8c.html" target="_self">main.c</a></td><td class="desc">Demo/test program for NEORV32's newlib C standard library support </td></tr> +<tr id="row_0_1_13_" class="odd"><td class="entry"><span style="width:32px;display:inline-block;">&#160;</span><span id="arr_0_1_13_" class="arrow" onclick="dynsection.toggleFolder('0_1_13_')">&#9658;</span><span id="img_0_1_13_" class="iconfclosed" onclick="dynsection.toggleFolder('0_1_13_')">&#160;</span><a class="el" href="dir_3b3bafc48b460f797485cc75b94aa81c.html" target="_self">demo_onewire</a></td><td class="desc"></td></tr> +<tr id="row_0_1_13_0_" class="even" style="display:none;"><td class="entry"><span style="width:64px;display:inline-block;">&#160;</span><span class="icondoc"></span><a class="el" href="demo__onewire_2main_8c.html" target="_self">main.c</a></td><td class="desc">Demo program for the NEORV32 1-Wire interface controller (ONEWIRE) </td></tr> +<tr id="row_0_1_13_1_" class="even" style="display:none;"><td class="entry"><span style="width:64px;display:inline-block;">&#160;</span><a href="onewire__aux_8h_source.html"><span class="icondoc"></span></a><b>onewire_aux.h</b></td><td class="desc"></td></tr> +<tr id="row_0_1_14_" class="even"><td class="entry"><span style="width:32px;display:inline-block;">&#160;</span><span id="arr_0_1_14_" class="arrow" onclick="dynsection.toggleFolder('0_1_14_')">&#9658;</span><span id="img_0_1_14_" class="iconfclosed" onclick="dynsection.toggleFolder('0_1_14_')">&#160;</span><a class="el" href="dir_b683da3a5fc966bff32ebf7cda721811.html" target="_self">demo_pwm</a></td><td class="desc"></td></tr> +<tr id="row_0_1_14_0_" class="odd" style="display:none;"><td class="entry"><span style="width:64px;display:inline-block;">&#160;</span><span class="icondoc"></span><a class="el" href="demo__pwm_2main_8c.html" target="_self">main.c</a></td><td class="desc">Simple PWM demo program </td></tr> +<tr id="row_0_1_15_" class="odd"><td class="entry"><span style="width:32px;display:inline-block;">&#160;</span><span id="arr_0_1_15_" class="arrow" onclick="dynsection.toggleFolder('0_1_15_')">&#9658;</span><span id="img_0_1_15_" class="iconfclosed" onclick="dynsection.toggleFolder('0_1_15_')">&#160;</span><a class="el" href="dir_c413aba6cb5da07a571465ba333950af.html" target="_self">demo_sdi</a></td><td class="desc"></td></tr> +<tr id="row_0_1_15_0_" class="even" style="display:none;"><td class="entry"><span style="width:64px;display:inline-block;">&#160;</span><span class="icondoc"></span><a class="el" href="demo__sdi_2main_8c.html" target="_self">main.c</a></td><td class="desc">SDI test program (direct access to the SDI module) </td></tr> +<tr id="row_0_1_16_" class="even"><td class="entry"><span style="width:32px;display:inline-block;">&#160;</span><span id="arr_0_1_16_" class="arrow" onclick="dynsection.toggleFolder('0_1_16_')">&#9658;</span><span id="img_0_1_16_" class="iconfclosed" onclick="dynsection.toggleFolder('0_1_16_')">&#160;</span><a class="el" href="dir_c2d46947bdd73c33f53326fc5ee3a272.html" target="_self">demo_slink</a></td><td class="desc"></td></tr> +<tr id="row_0_1_16_0_" class="odd" style="display:none;"><td class="entry"><span style="width:64px;display:inline-block;">&#160;</span><span class="icondoc"></span><a class="el" href="demo__slink_2main_8c.html" target="_self">main.c</a></td><td class="desc">SLINK demo program </td></tr> +<tr id="row_0_1_17_" class="odd"><td class="entry"><span style="width:32px;display:inline-block;">&#160;</span><span id="arr_0_1_17_" class="arrow" onclick="dynsection.toggleFolder('0_1_17_')">&#9658;</span><span id="img_0_1_17_" class="iconfclosed" onclick="dynsection.toggleFolder('0_1_17_')">&#160;</span><a class="el" href="dir_4c113257314015688a865e1bb8429184.html" target="_self">demo_spi</a></td><td class="desc"></td></tr> +<tr id="row_0_1_17_0_" class="even" style="display:none;"><td class="entry"><span style="width:64px;display:inline-block;">&#160;</span><span class="icondoc"></span><a class="el" href="demo__spi_2main_8c.html" target="_self">main.c</a></td><td class="desc">SPI bus explorer (execute SPI transactions by hand) </td></tr> +<tr id="row_0_1_18_" class="even"><td class="entry"><span style="width:32px;display:inline-block;">&#160;</span><span id="arr_0_1_18_" class="arrow" onclick="dynsection.toggleFolder('0_1_18_')">&#9658;</span><span id="img_0_1_18_" class="iconfclosed" onclick="dynsection.toggleFolder('0_1_18_')">&#160;</span><a class="el" href="dir_8f848e36ac87ced1c361afcc0549ca32.html" target="_self">demo_spi_irq</a></td><td class="desc"></td></tr> +<tr id="row_0_1_18_0_" class="odd" style="display:none;"><td class="entry"><span style="width:48px;display:inline-block;">&#160;</span><span id="arr_0_1_18_0_" class="arrow" onclick="dynsection.toggleFolder('0_1_18_0_')">&#9658;</span><span id="img_0_1_18_0_" class="iconfclosed" onclick="dynsection.toggleFolder('0_1_18_0_')">&#160;</span><a class="el" href="dir_9d04cdc586d6978be343bda7adcdc371.html" target="_self">drv</a></td><td class="desc"></td></tr> +<tr id="row_0_1_18_0_0_" class="odd" style="display:none;"><td class="entry"><span style="width:80px;display:inline-block;">&#160;</span><span class="icondoc"></span><a class="el" href="neorv32__spi__irq_8c.html" target="_self">neorv32_spi_irq.c</a></td><td class="desc">Addition to <a class="el" href="neorv32__spi_8c.html" title="Serial peripheral interface controller (SPI) HW driver source file.">neorv32_spi.c</a>, which provides an IRQ driven data flow </td></tr> +<tr id="row_0_1_18_0_1_" class="odd" style="display:none;"><td class="entry"><span style="width:80px;display:inline-block;">&#160;</span><a href="neorv32__spi__irq_8h_source.html"><span class="icondoc"></span></a><a class="el" href="neorv32__spi__irq_8h.html" target="_self">neorv32_spi_irq.h</a></td><td class="desc">Addition to <a class="el" href="neorv32__spi_8h.html" title="Serial peripheral interface controller (SPI) HW driver header file.">neorv32_spi.h</a>, which provides an IRQ driven data flow </td></tr> +<tr id="row_0_1_18_1_" class="odd" style="display:none;"><td class="entry"><span style="width:64px;display:inline-block;">&#160;</span><span class="icondoc"></span><a class="el" href="demo__spi__irq_2main_8c.html" target="_self">main.c</a></td><td class="desc">Example of an ISR driven SPI transfer </td></tr> +<tr id="row_0_1_19_" class="odd"><td class="entry"><span style="width:32px;display:inline-block;">&#160;</span><span id="arr_0_1_19_" class="arrow" onclick="dynsection.toggleFolder('0_1_19_')">&#9658;</span><span id="img_0_1_19_" class="iconfclosed" onclick="dynsection.toggleFolder('0_1_19_')">&#160;</span><a class="el" href="dir_237db5b95db643499d4c20f0bc5f6a7d.html" target="_self">demo_trng</a></td><td class="desc"></td></tr> +<tr id="row_0_1_19_0_" class="even" style="display:none;"><td class="entry"><span style="width:64px;display:inline-block;">&#160;</span><span class="icondoc"></span><a class="el" href="demo__trng_2main_8c.html" target="_self">main.c</a></td><td class="desc">True random number generator demo program </td></tr> +<tr id="row_0_1_20_" class="even"><td class="entry"><span style="width:32px;display:inline-block;">&#160;</span><span id="arr_0_1_20_" class="arrow" onclick="dynsection.toggleFolder('0_1_20_')">&#9658;</span><span id="img_0_1_20_" class="iconfclosed" onclick="dynsection.toggleFolder('0_1_20_')">&#160;</span><a class="el" href="dir_ebeff77b922fbb914a1494857a82a38e.html" target="_self">demo_twi</a></td><td class="desc"></td></tr> +<tr id="row_0_1_20_0_" class="odd" style="display:none;"><td class="entry"><span style="width:64px;display:inline-block;">&#160;</span><span class="icondoc"></span><a class="el" href="demo__twi_2main_8c.html" target="_self">main.c</a></td><td class="desc">TWI bus explorer </td></tr> +<tr id="row_0_1_21_" class="odd"><td class="entry"><span style="width:32px;display:inline-block;">&#160;</span><span id="arr_0_1_21_" class="arrow" onclick="dynsection.toggleFolder('0_1_21_')">&#9658;</span><span id="img_0_1_21_" class="iconfclosed" onclick="dynsection.toggleFolder('0_1_21_')">&#160;</span><a class="el" href="dir_78d7bfa405ff3a31fa7539cfd8bc8262.html" target="_self">demo_wdt</a></td><td class="desc"></td></tr> +<tr id="row_0_1_21_0_" class="even" style="display:none;"><td class="entry"><span style="width:64px;display:inline-block;">&#160;</span><span class="icondoc"></span><a class="el" href="demo__wdt_2main_8c.html" target="_self">main.c</a></td><td class="desc">Watchdog demo program </td></tr> +<tr id="row_0_1_22_" class="even"><td class="entry"><span style="width:32px;display:inline-block;">&#160;</span><span id="arr_0_1_22_" class="arrow" onclick="dynsection.toggleFolder('0_1_22_')">&#9658;</span><span id="img_0_1_22_" class="iconfclosed" onclick="dynsection.toggleFolder('0_1_22_')">&#160;</span><a class="el" href="dir_b6b50782b8271d07dffbc5f0cb9ff3f4.html" target="_self">demo_xip</a></td><td class="desc"></td></tr> +<tr id="row_0_1_22_0_" class="odd" style="display:none;"><td class="entry"><span style="width:64px;display:inline-block;">&#160;</span><span class="icondoc"></span><a class="el" href="demo__xip_2main_8c.html" target="_self">main.c</a></td><td class="desc">Interactive console program to upload and execute a XIP program </td></tr> +<tr id="row_0_1_23_" class="odd"><td class="entry"><span style="width:32px;display:inline-block;">&#160;</span><span id="arr_0_1_23_" class="arrow" onclick="dynsection.toggleFolder('0_1_23_')">&#9658;</span><span id="img_0_1_23_" class="iconfclosed" onclick="dynsection.toggleFolder('0_1_23_')">&#160;</span><a class="el" href="dir_5534fa9035f54ab438a41c43d6f7fc7a.html" target="_self">demo_xirq</a></td><td class="desc"></td></tr> +<tr id="row_0_1_23_0_" class="even" style="display:none;"><td class="entry"><span style="width:64px;display:inline-block;">&#160;</span><span class="icondoc"></span><a class="el" href="demo__xirq_2main_8c.html" target="_self">main.c</a></td><td class="desc">External interrupt controller (XIRQ) demo program (using hardware-assisted prioritization) </td></tr> +<tr id="row_0_1_24_" class="even"><td class="entry"><span style="width:32px;display:inline-block;">&#160;</span><span id="arr_0_1_24_" class="arrow" onclick="dynsection.toggleFolder('0_1_24_')">&#9658;</span><span id="img_0_1_24_" class="iconfclosed" onclick="dynsection.toggleFolder('0_1_24_')">&#160;</span><a class="el" href="dir_b5eb9f7d151d147efb5dbda58439e4e7.html" target="_self">dhrystone</a></td><td class="desc"></td></tr> +<tr id="row_0_1_24_0_" class="odd" style="display:none;"><td class="entry"><span style="width:64px;display:inline-block;">&#160;</span><a href="dhry_8h_source.html"><span class="icondoc"></span></a><b>dhry.h</b></td><td class="desc"></td></tr> +<tr id="row_0_1_25_" class="odd"><td class="entry"><span style="width:32px;display:inline-block;">&#160;</span><span id="arr_0_1_25_" class="arrow" onclick="dynsection.toggleFolder('0_1_25_')">&#9658;</span><span id="img_0_1_25_" class="iconfclosed" onclick="dynsection.toggleFolder('0_1_25_')">&#160;</span><a class="el" href="dir_23212395b5ee0866d2fdd629e0ddeae8.html" target="_self">float_corner_test</a></td><td class="desc"></td></tr> +<tr id="row_0_1_25_0_" class="even" style="display:none;"><td class="entry"><span style="width:64px;display:inline-block;">&#160;</span><span class="icondoc"></span><a class="el" href="float__corner__test_2main_8c.html" target="_self">main.c</a></td><td class="desc">Verification program for the NEORV32 'Zfinx' extension (floating-point in x registers) using pseudo-random data as input; compares results from hardware against pure-sw reference functions </td></tr> +<tr id="row_0_1_25_1_" class="even" style="display:none;"><td class="entry"><span style="width:64px;display:inline-block;">&#160;</span><a href="float__corner__test_2neorv32__zfinx__extension__intrinsics_8h_source.html"><span class="icondoc"></span></a><b>neorv32_zfinx_extension_intrinsics.h</b></td><td class="desc"></td></tr> +<tr id="row_0_1_26_" class="even"><td class="entry"><span style="width:32px;display:inline-block;">&#160;</span><span id="arr_0_1_26_" class="arrow" onclick="dynsection.toggleFolder('0_1_26_')">&#9658;</span><span id="img_0_1_26_" class="iconfclosed" onclick="dynsection.toggleFolder('0_1_26_')">&#160;</span><a class="el" href="dir_e9ffd83269fb7f0c372f5ffbe8545008.html" target="_self">floating_point_test</a></td><td class="desc"></td></tr> +<tr id="row_0_1_26_0_" class="odd" style="display:none;"><td class="entry"><span style="width:64px;display:inline-block;">&#160;</span><span class="icondoc"></span><a class="el" href="floating__point__test_2main_8c.html" target="_self">main.c</a></td><td class="desc">Verification program for the NEORV32 'Zfinx' extension (floating-point in x registers) using pseudo-random data as input; compares results from hardware against pure-sw reference functions </td></tr> +<tr id="row_0_1_26_1_" class="odd" style="display:none;"><td class="entry"><span style="width:64px;display:inline-block;">&#160;</span><a href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h_source.html"><span class="icondoc"></span></a><a class="el" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html" target="_self">neorv32_zfinx_extension_intrinsics.h</a></td><td class="desc">"Intrinsic" library for the NEORV32 single-precision floating-point in x registers (Zfinx) extension </td></tr> +<tr id="row_0_1_27_" class="odd"><td class="entry"><span style="width:32px;display:inline-block;">&#160;</span><span id="arr_0_1_27_" class="arrow" onclick="dynsection.toggleFolder('0_1_27_')">&#9658;</span><span id="img_0_1_27_" class="iconfclosed" onclick="dynsection.toggleFolder('0_1_27_')">&#160;</span><a class="el" href="dir_46981071cfd8ec44311b09fdcf6c06a8.html" target="_self">game_of_life</a></td><td class="desc"></td></tr> +<tr id="row_0_1_27_0_" class="even" style="display:none;"><td class="entry"><span style="width:64px;display:inline-block;">&#160;</span><span class="icondoc"></span><a class="el" href="game__of__life_2main_8c.html" target="_self">main.c</a></td><td class="desc">Conway's game of life in a UART terminal </td></tr> +<tr id="row_0_1_28_" class="even"><td class="entry"><span style="width:32px;display:inline-block;">&#160;</span><span id="arr_0_1_28_" class="arrow" onclick="dynsection.toggleFolder('0_1_28_')">&#9658;</span><span id="img_0_1_28_" class="iconfclosed" onclick="dynsection.toggleFolder('0_1_28_')">&#160;</span><a class="el" href="dir_d4640980cbf1943e4a4aee6e8b810c7a.html" target="_self">hello_world</a></td><td class="desc"></td></tr> +<tr id="row_0_1_28_0_" class="odd" style="display:none;"><td class="entry"><span style="width:64px;display:inline-block;">&#160;</span><span class="icondoc"></span><a class="el" href="hello__world_2main_8c.html" target="_self">main.c</a></td><td class="desc">Classic 'hello world' demo program </td></tr> +<tr id="row_0_1_29_" class="odd"><td class="entry"><span style="width:32px;display:inline-block;">&#160;</span><span id="arr_0_1_29_" class="arrow" onclick="dynsection.toggleFolder('0_1_29_')">&#9658;</span><span id="img_0_1_29_" class="iconfclosed" onclick="dynsection.toggleFolder('0_1_29_')">&#160;</span><a class="el" href="dir_7a2c74f70a4cdf2e836a07048e2f71dd.html" target="_self">processor_check</a></td><td class="desc"></td></tr> +<tr id="row_0_1_29_0_" class="even" style="display:none;"><td class="entry"><span style="width:64px;display:inline-block;">&#160;</span><span class="icondoc"></span><a class="el" href="processor__check_2main_8c.html" target="_self">main.c</a></td><td class="desc">CPU/Processor test/verification program </td></tr> +<tr id="row_0_2_" class="even"><td class="entry"><span style="width:16px;display:inline-block;">&#160;</span><span id="arr_0_2_" class="arrow" onclick="dynsection.toggleFolder('0_2_')">&#9660;</span><span id="img_0_2_" class="iconfopen" onclick="dynsection.toggleFolder('0_2_')">&#160;</span><a class="el" href="dir_7d04193005ada6f9450f847f4adb6b5b.html" target="_self">lib</a></td><td class="desc"></td></tr> +<tr id="row_0_2_0_" class="odd"><td class="entry"><span style="width:32px;display:inline-block;">&#160;</span><span id="arr_0_2_0_" class="arrow" onclick="dynsection.toggleFolder('0_2_0_')">&#9658;</span><span id="img_0_2_0_" class="iconfclosed" onclick="dynsection.toggleFolder('0_2_0_')">&#160;</span><a class="el" href="dir_752b1e5d3973bf735fa78bf6b4727df9.html" target="_self">include</a></td><td class="desc"></td></tr> +<tr id="row_0_2_0_0_" class="even" style="display:none;"><td class="entry"><span style="width:64px;display:inline-block;">&#160;</span><a href="neorv32_8h_source.html"><span class="icondoc"></span></a><a class="el" href="neorv32_8h.html" target="_self">neorv32.h</a></td><td class="desc">Main NEORV32 core library / driver / HAL include file </td></tr> +<tr id="row_0_2_0_1_" class="even" style="display:none;"><td class="entry"><span style="width:64px;display:inline-block;">&#160;</span><a href="neorv32__aux_8h_source.html"><span class="icondoc"></span></a><a class="el" href="neorv32__aux_8h.html" target="_self">neorv32_aux.h</a></td><td class="desc">General auxiliary functions header file </td></tr> +<tr id="row_0_2_0_2_" class="even" style="display:none;"><td class="entry"><span style="width:64px;display:inline-block;">&#160;</span><a href="neorv32__cfs_8h_source.html"><span class="icondoc"></span></a><a class="el" href="neorv32__cfs_8h.html" target="_self">neorv32_cfs.h</a></td><td class="desc">Custom Functions Subsystem (CFS) HW driver header file </td></tr> +<tr id="row_0_2_0_3_" class="even" style="display:none;"><td class="entry"><span style="width:64px;display:inline-block;">&#160;</span><a href="neorv32__cpu_8h_source.html"><span class="icondoc"></span></a><a class="el" href="neorv32__cpu_8h.html" target="_self">neorv32_cpu.h</a></td><td class="desc">CPU Core Functions HW driver header file </td></tr> +<tr id="row_0_2_0_4_" class="even" style="display:none;"><td class="entry"><span style="width:64px;display:inline-block;">&#160;</span><a href="neorv32__cpu__amo_8h_source.html"><span class="icondoc"></span></a><a class="el" href="neorv32__cpu__amo_8h.html" target="_self">neorv32_cpu_amo.h</a></td><td class="desc">Atomic memory access (read-modify-write) emulation functions using LR/SC pairs - header file </td></tr> +<tr id="row_0_2_0_5_" class="even" style="display:none;"><td class="entry"><span style="width:64px;display:inline-block;">&#160;</span><a href="neorv32__cpu__cfu_8h_source.html"><span class="icondoc"></span></a><a class="el" href="neorv32__cpu__cfu_8h.html" target="_self">neorv32_cpu_cfu.h</a></td><td class="desc">CPU Core custom functions unit HW driver header file </td></tr> +<tr id="row_0_2_0_6_" class="even" style="display:none;"><td class="entry"><span style="width:64px;display:inline-block;">&#160;</span><a href="neorv32__cpu__csr_8h_source.html"><span class="icondoc"></span></a><a class="el" href="neorv32__cpu__csr_8h.html" target="_self">neorv32_cpu_csr.h</a></td><td class="desc">Control and Status Registers (CSR) definitions </td></tr> +<tr id="row_0_2_0_7_" class="even" style="display:none;"><td class="entry"><span style="width:64px;display:inline-block;">&#160;</span><a href="neorv32__crc_8h_source.html"><span class="icondoc"></span></a><a class="el" href="neorv32__crc_8h.html" target="_self">neorv32_crc.h</a></td><td class="desc">Cyclic redundancy check unit (CRC) HW driver header file </td></tr> +<tr id="row_0_2_0_8_" class="even" style="display:none;"><td class="entry"><span style="width:64px;display:inline-block;">&#160;</span><a href="neorv32__dma_8h_source.html"><span class="icondoc"></span></a><a class="el" href="neorv32__dma_8h.html" target="_self">neorv32_dma.h</a></td><td class="desc">Direct Memory Access Controller (DMA) HW driver header file </td></tr> +<tr id="row_0_2_0_9_" class="even" style="display:none;"><td class="entry"><span style="width:64px;display:inline-block;">&#160;</span><a href="neorv32__gpio_8h_source.html"><span class="icondoc"></span></a><a class="el" href="neorv32__gpio_8h.html" target="_self">neorv32_gpio.h</a></td><td class="desc">General purpose input/output port unit (GPIO) HW driver header file </td></tr> +<tr id="row_0_2_0_10_" class="even" style="display:none;"><td class="entry"><span style="width:64px;display:inline-block;">&#160;</span><a href="neorv32__gptmr_8h_source.html"><span class="icondoc"></span></a><a class="el" href="neorv32__gptmr_8h.html" target="_self">neorv32_gptmr.h</a></td><td class="desc">General purpose timer (GPTMR) HW driver header file </td></tr> +<tr id="row_0_2_0_11_" class="even" style="display:none;"><td class="entry"><span style="width:64px;display:inline-block;">&#160;</span><a href="neorv32__intrinsics_8h_source.html"><span class="icondoc"></span></a><a class="el" href="neorv32__intrinsics_8h.html" target="_self">neorv32_intrinsics.h</a></td><td class="desc">Helper functions and macros for custom "intrinsics" / instructions </td></tr> +<tr id="row_0_2_0_12_" class="even" style="display:none;"><td class="entry"><span style="width:64px;display:inline-block;">&#160;</span><a href="neorv32__legacy_8h_source.html"><span class="icondoc"></span></a><a class="el" href="neorv32__legacy_8h.html" target="_self">neorv32_legacy.h</a></td><td class="desc">Legacy compatibility layer </td></tr> +<tr id="row_0_2_0_13_" class="even" style="display:none;"><td class="entry"><span style="width:64px;display:inline-block;">&#160;</span><a href="neorv32__mtime_8h_source.html"><span class="icondoc"></span></a><a class="el" href="neorv32__mtime_8h.html" target="_self">neorv32_mtime.h</a></td><td class="desc">Machine System Timer (MTIME) HW driver header file </td></tr> +<tr id="row_0_2_0_14_" class="even" style="display:none;"><td class="entry"><span style="width:64px;display:inline-block;">&#160;</span><a href="neorv32__neoled_8h_source.html"><span class="icondoc"></span></a><a class="el" href="neorv32__neoled_8h.html" target="_self">neorv32_neoled.h</a></td><td class="desc">Smart LED Interface (NEOLED) HW driver header file </td></tr> +<tr id="row_0_2_0_15_" class="even" style="display:none;"><td class="entry"><span style="width:64px;display:inline-block;">&#160;</span><a href="neorv32__onewire_8h_source.html"><span class="icondoc"></span></a><a class="el" href="neorv32__onewire_8h.html" target="_self">neorv32_onewire.h</a></td><td class="desc">1-Wire Interface Controller (ONEWIRE) HW driver header file </td></tr> +<tr id="row_0_2_0_16_" class="even" style="display:none;"><td class="entry"><span style="width:64px;display:inline-block;">&#160;</span><a href="neorv32__pwm_8h_source.html"><span class="icondoc"></span></a><a class="el" href="neorv32__pwm_8h.html" target="_self">neorv32_pwm.h</a></td><td class="desc">Pulse-Width Modulation Controller (PWM) HW driver header file </td></tr> +<tr id="row_0_2_0_17_" class="even" style="display:none;"><td class="entry"><span style="width:64px;display:inline-block;">&#160;</span><a href="neorv32__rte_8h_source.html"><span class="icondoc"></span></a><a class="el" href="neorv32__rte_8h.html" target="_self">neorv32_rte.h</a></td><td class="desc">NEORV32 Runtime Environment </td></tr> +<tr id="row_0_2_0_18_" class="even" style="display:none;"><td class="entry"><span style="width:64px;display:inline-block;">&#160;</span><a href="neorv32__sdi_8h_source.html"><span class="icondoc"></span></a><a class="el" href="neorv32__sdi_8h.html" target="_self">neorv32_sdi.h</a></td><td class="desc">Serial data interface controller (SPPI) HW driver header file </td></tr> +<tr id="row_0_2_0_19_" class="even" style="display:none;"><td class="entry"><span style="width:64px;display:inline-block;">&#160;</span><a href="neorv32__slink_8h_source.html"><span class="icondoc"></span></a><a class="el" href="neorv32__slink_8h.html" target="_self">neorv32_slink.h</a></td><td class="desc">Stream Link Interface HW driver header file </td></tr> +<tr id="row_0_2_0_20_" class="even" style="display:none;"><td class="entry"><span style="width:64px;display:inline-block;">&#160;</span><a href="neorv32__spi_8h_source.html"><span class="icondoc"></span></a><a class="el" href="neorv32__spi_8h.html" target="_self">neorv32_spi.h</a></td><td class="desc">Serial peripheral interface controller (SPI) HW driver header file </td></tr> +<tr id="row_0_2_0_21_" class="even" style="display:none;"><td class="entry"><span style="width:64px;display:inline-block;">&#160;</span><a href="neorv32__sysinfo_8h_source.html"><span class="icondoc"></span></a><b>neorv32_sysinfo.h</b></td><td class="desc"></td></tr> +<tr id="row_0_2_0_22_" class="even" style="display:none;"><td class="entry"><span style="width:64px;display:inline-block;">&#160;</span><a href="neorv32__trng_8h_source.html"><span class="icondoc"></span></a><a class="el" href="neorv32__trng_8h.html" target="_self">neorv32_trng.h</a></td><td class="desc">True Random Number Generator (TRNG) HW driver header file </td></tr> +<tr id="row_0_2_0_23_" class="even" style="display:none;"><td class="entry"><span style="width:64px;display:inline-block;">&#160;</span><a href="neorv32__twi_8h_source.html"><span class="icondoc"></span></a><a class="el" href="neorv32__twi_8h.html" target="_self">neorv32_twi.h</a></td><td class="desc">Two-Wire Interface Controller (TWI) HW driver header file </td></tr> +<tr id="row_0_2_0_24_" class="even" style="display:none;"><td class="entry"><span style="width:64px;display:inline-block;">&#160;</span><a href="neorv32__uart_8h_source.html"><span class="icondoc"></span></a><a class="el" href="neorv32__uart_8h.html" target="_self">neorv32_uart.h</a></td><td class="desc">Universal asynchronous receiver/transmitter (UART0/UART1) HW driver header file </td></tr> +<tr id="row_0_2_0_25_" class="even" style="display:none;"><td class="entry"><span style="width:64px;display:inline-block;">&#160;</span><a href="neorv32__wdt_8h_source.html"><span class="icondoc"></span></a><a class="el" href="neorv32__wdt_8h.html" target="_self">neorv32_wdt.h</a></td><td class="desc">Watchdog Timer (WDT) HW driver header file </td></tr> +<tr id="row_0_2_0_26_" class="even" style="display:none;"><td class="entry"><span style="width:64px;display:inline-block;">&#160;</span><a href="neorv32__xip_8h_source.html"><span class="icondoc"></span></a><a class="el" href="neorv32__xip_8h.html" target="_self">neorv32_xip.h</a></td><td class="desc">Execute in place module (XIP) HW driver header file </td></tr> +<tr id="row_0_2_0_27_" class="even" style="display:none;"><td class="entry"><span style="width:64px;display:inline-block;">&#160;</span><a href="neorv32__xirq_8h_source.html"><span class="icondoc"></span></a><a class="el" href="neorv32__xirq_8h.html" target="_self">neorv32_xirq.h</a></td><td class="desc">External Interrupt controller HW driver header file </td></tr> +<tr id="row_0_2_1_" class="even"><td class="entry"><span style="width:32px;display:inline-block;">&#160;</span><span id="arr_0_2_1_" class="arrow" onclick="dynsection.toggleFolder('0_2_1_')">&#9658;</span><span id="img_0_2_1_" class="iconfclosed" onclick="dynsection.toggleFolder('0_2_1_')">&#160;</span><a class="el" href="dir_0c6ac14e2254a316d41123f98feeb67b.html" target="_self">source</a></td><td class="desc"></td></tr> +<tr id="row_0_2_1_0_" class="odd" style="display:none;"><td class="entry"><span style="width:64px;display:inline-block;">&#160;</span><span class="icondoc"></span><a class="el" href="neorv32__aux_8c.html" target="_self">neorv32_aux.c</a></td><td class="desc">General auxiliary functions source file </td></tr> +<tr id="row_0_2_1_1_" class="odd" style="display:none;"><td class="entry"><span style="width:64px;display:inline-block;">&#160;</span><span class="icondoc"></span><a class="el" href="neorv32__cfs_8c.html" target="_self">neorv32_cfs.c</a></td><td class="desc">Custom Functions Subsystem (CFS) HW driver source file </td></tr> +<tr id="row_0_2_1_2_" class="odd" style="display:none;"><td class="entry"><span style="width:64px;display:inline-block;">&#160;</span><span class="icondoc"></span><a class="el" href="neorv32__cpu_8c.html" target="_self">neorv32_cpu.c</a></td><td class="desc">CPU Core Functions HW driver source file </td></tr> +<tr id="row_0_2_1_3_" class="odd" style="display:none;"><td class="entry"><span style="width:64px;display:inline-block;">&#160;</span><span class="icondoc"></span><a class="el" href="neorv32__cpu__amo_8c.html" target="_self">neorv32_cpu_amo.c</a></td><td class="desc">Atomic memory access (read-modify-write) emulation functions using LR/SC pairs - source file </td></tr> +<tr id="row_0_2_1_4_" class="odd" style="display:none;"><td class="entry"><span style="width:64px;display:inline-block;">&#160;</span><span class="icondoc"></span><a class="el" href="neorv32__cpu__cfu_8c.html" target="_self">neorv32_cpu_cfu.c</a></td><td class="desc">CPU Core custom functions unit HW driver source file </td></tr> +<tr id="row_0_2_1_5_" class="odd" style="display:none;"><td class="entry"><span style="width:64px;display:inline-block;">&#160;</span><span class="icondoc"></span><a class="el" href="neorv32__crc_8c.html" target="_self">neorv32_crc.c</a></td><td class="desc">Cyclic redundancy check unit (CRC) HW driver source file </td></tr> +<tr id="row_0_2_1_6_" class="odd" style="display:none;"><td class="entry"><span style="width:64px;display:inline-block;">&#160;</span><span class="icondoc"></span><a class="el" href="neorv32__gpio_8c.html" target="_self">neorv32_gpio.c</a></td><td class="desc">General purpose input/output port unit (GPIO) HW driver source file </td></tr> +<tr id="row_0_2_1_7_" class="odd" style="display:none;"><td class="entry"><span style="width:64px;display:inline-block;">&#160;</span><span class="icondoc"></span><a class="el" href="neorv32__gptmr_8c.html" target="_self">neorv32_gptmr.c</a></td><td class="desc">General purpose timer (GPTMR) HW driver source file </td></tr> +<tr id="row_0_2_1_8_" class="odd" style="display:none;"><td class="entry"><span style="width:64px;display:inline-block;">&#160;</span><span class="icondoc"></span><a class="el" href="neorv32__mtime_8c.html" target="_self">neorv32_mtime.c</a></td><td class="desc">Machine System Timer (MTIME) HW driver source file </td></tr> +<tr id="row_0_2_1_9_" class="odd" style="display:none;"><td class="entry"><span style="width:64px;display:inline-block;">&#160;</span><span class="icondoc"></span><a class="el" href="neorv32__neoled_8c.html" target="_self">neorv32_neoled.c</a></td><td class="desc">Smart LED Interface (NEOLED) HW driver source file </td></tr> +<tr id="row_0_2_1_10_" class="odd" style="display:none;"><td class="entry"><span style="width:64px;display:inline-block;">&#160;</span><span class="icondoc"></span><a class="el" href="neorv32__onewire_8c.html" target="_self">neorv32_onewire.c</a></td><td class="desc">1-Wire Interface Controller (ONEWIRE) HW driver source file </td></tr> +<tr id="row_0_2_1_11_" class="odd" style="display:none;"><td class="entry"><span style="width:64px;display:inline-block;">&#160;</span><span class="icondoc"></span><a class="el" href="neorv32__pwm_8c.html" target="_self">neorv32_pwm.c</a></td><td class="desc">Pulse-Width Modulation Controller (PWM) HW driver source file </td></tr> +<tr id="row_0_2_1_12_" class="odd" style="display:none;"><td class="entry"><span style="width:64px;display:inline-block;">&#160;</span><span class="icondoc"></span><a class="el" href="neorv32__rte_8c.html" target="_self">neorv32_rte.c</a></td><td class="desc">NEORV32 Runtime Environment </td></tr> +<tr id="row_0_2_1_13_" class="odd" style="display:none;"><td class="entry"><span style="width:64px;display:inline-block;">&#160;</span><span class="icondoc"></span><a class="el" href="neorv32__sdi_8c.html" target="_self">neorv32_sdi.c</a></td><td class="desc">Serial data interface controller (SDI) HW driver source file </td></tr> +<tr id="row_0_2_1_14_" class="odd" style="display:none;"><td class="entry"><span style="width:64px;display:inline-block;">&#160;</span><span class="icondoc"></span><a class="el" href="neorv32__slink_8c.html" target="_self">neorv32_slink.c</a></td><td class="desc">Stream Link Interface HW driver source file </td></tr> +<tr id="row_0_2_1_15_" class="odd" style="display:none;"><td class="entry"><span style="width:64px;display:inline-block;">&#160;</span><span class="icondoc"></span><a class="el" href="neorv32__spi_8c.html" target="_self">neorv32_spi.c</a></td><td class="desc">Serial peripheral interface controller (SPI) HW driver source file </td></tr> +<tr id="row_0_2_1_16_" class="odd" style="display:none;"><td class="entry"><span style="width:64px;display:inline-block;">&#160;</span><span class="icondoc"></span><a class="el" href="neorv32__trng_8c.html" target="_self">neorv32_trng.c</a></td><td class="desc">True Random Number Generator (TRNG) HW driver source file </td></tr> +<tr id="row_0_2_1_17_" class="odd" style="display:none;"><td class="entry"><span style="width:64px;display:inline-block;">&#160;</span><span class="icondoc"></span><a class="el" href="neorv32__twi_8c.html" target="_self">neorv32_twi.c</a></td><td class="desc">Two-Wire Interface Controller (TWI) HW driver source file </td></tr> +<tr id="row_0_2_1_18_" class="odd" style="display:none;"><td class="entry"><span style="width:64px;display:inline-block;">&#160;</span><span class="icondoc"></span><a class="el" href="neorv32__uart_8c.html" target="_self">neorv32_uart.c</a></td><td class="desc">Universal asynchronous receiver/transmitter (UART0/UART1) HW driver source file </td></tr> +<tr id="row_0_2_1_19_" class="odd" style="display:none;"><td class="entry"><span style="width:64px;display:inline-block;">&#160;</span><span class="icondoc"></span><a class="el" href="neorv32__wdt_8c.html" target="_self">neorv32_wdt.c</a></td><td class="desc">Direct Memory Access Controller (DMA) HW driver source file </td></tr> +<tr id="row_0_2_1_20_" class="odd" style="display:none;"><td class="entry"><span style="width:64px;display:inline-block;">&#160;</span><span class="icondoc"></span><a class="el" href="neorv32__xip_8c.html" target="_self">neorv32_xip.c</a></td><td class="desc">Execute in place module (XIP) HW driver source file </td></tr> +<tr id="row_0_2_1_21_" class="odd" style="display:none;"><td class="entry"><span style="width:64px;display:inline-block;">&#160;</span><span class="icondoc"></span><a class="el" href="neorv32__xirq_8c.html" target="_self">neorv32_xirq.c</a></td><td class="desc">External Interrupt controller HW driver source file </td></tr> +<tr id="row_0_2_1_22_" class="odd" style="display:none;"><td class="entry"><span style="width:64px;display:inline-block;">&#160;</span><span class="icondoc"></span><a class="el" href="syscalls_8c.html" target="_self">syscalls.c</a></td><td class="desc">Newlib system calls </td></tr> +</table> +</div><!-- directory --> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/float__corner__test_2main_8c.html b/sw/float__corner__test_2main_8c.html new file mode 100644 index 0000000000..5fd8066d8c --- /dev/null +++ b/sw/float__corner__test_2main_8c.html @@ -0,0 +1,448 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/example/float_corner_test/main.c File Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_f0f9b27afba2e8cc2da6e5fddcc1a8c9.html">example</a></li><li class="navelem"><a class="el" href="dir_23212395b5ee0866d2fdd629e0ddeae8.html">float_corner_test</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#func-members">Functions</a> </div> + <div class="headertitle"><div class="title">main.c File Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p>Verification program for the NEORV32 'Zfinx' extension (floating-point in x registers) using pseudo-random data as input; compares results from hardware against pure-sw reference functions. +<a href="#details">More...</a></p> +<div class="textblock"><code>#include &lt;<a class="el" href="neorv32_8h_source.html">neorv32.h</a>&gt;</code><br /> +<code>#include &lt;float.h&gt;</code><br /> +<code>#include &lt;math.h&gt;</code><br /> +<code>#include &quot;neorv32_zfinx_extension_intrinsics.h&quot;</code><br /> +</div><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="define-members" name="define-members"></a> +Macros</h2></td></tr> +<tr><td colspan="2"><div class="groupHeader">User configuration</div></td></tr> +<tr class="memitem:ad4455691936f92fdd6c37566fc58ba1f" id="r_ad4455691936f92fdd6c37566fc58ba1f"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ad4455691936f92fdd6c37566fc58ba1f">BAUD_RATE</a>&#160;&#160;&#160;(19200)</td></tr> +<tr class="separator:ad4455691936f92fdd6c37566fc58ba1f"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a83792c34853f1d2801b59ad46adc7e1e" id="r_a83792c34853f1d2801b59ad46adc7e1e"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a83792c34853f1d2801b59ad46adc7e1e">NUM_TEST_CASES</a>&#160;&#160;&#160;(1000000)</td></tr> +<tr class="separator:a83792c34853f1d2801b59ad46adc7e1e"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a87f296d7594bb8178cf76f0c045b7013" id="r_a87f296d7594bb8178cf76f0c045b7013"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a87f296d7594bb8178cf76f0c045b7013">SILENT_MODE</a>&#160;&#160;&#160;(1)</td></tr> +<tr class="separator:a87f296d7594bb8178cf76f0c045b7013"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aa3b6c4d49be7372de9e771a0475306ac" id="r_aa3b6c4d49be7372de9e771a0475306ac"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aa3b6c4d49be7372de9e771a0475306ac">RUN_CONV_TESTS</a>&#160;&#160;&#160;(1)</td></tr> +<tr class="separator:aa3b6c4d49be7372de9e771a0475306ac"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a2d16b9e484b7af7897c7ae83f945ceca" id="r_a2d16b9e484b7af7897c7ae83f945ceca"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a2d16b9e484b7af7897c7ae83f945ceca">RUN_ADDSUB_TESTS</a>&#160;&#160;&#160;(1)</td></tr> +<tr class="separator:a2d16b9e484b7af7897c7ae83f945ceca"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a97323ecaf1ae85e68a736b06bc3b58f8" id="r_a97323ecaf1ae85e68a736b06bc3b58f8"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a97323ecaf1ae85e68a736b06bc3b58f8">RUN_MUL_TESTS</a>&#160;&#160;&#160;(1)</td></tr> +<tr class="separator:a97323ecaf1ae85e68a736b06bc3b58f8"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aed386f612417aeeeac8b08db27d515e4" id="r_aed386f612417aeeeac8b08db27d515e4"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aed386f612417aeeeac8b08db27d515e4">RUN_MINMAX_TESTS</a>&#160;&#160;&#160;(1)</td></tr> +<tr class="separator:aed386f612417aeeeac8b08db27d515e4"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a4ee0f6d28896a97d2c0cad866e77b874" id="r_a4ee0f6d28896a97d2c0cad866e77b874"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a4ee0f6d28896a97d2c0cad866e77b874">RUN_COMPARE_TESTS</a>&#160;&#160;&#160;(1)</td></tr> +<tr class="separator:a4ee0f6d28896a97d2c0cad866e77b874"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a94f0b0908f48f383145ed61ef8eb0713" id="r_a94f0b0908f48f383145ed61ef8eb0713"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a94f0b0908f48f383145ed61ef8eb0713">RUN_SGNINJ_TESTS</a>&#160;&#160;&#160;(1)</td></tr> +<tr class="separator:a94f0b0908f48f383145ed61ef8eb0713"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a7e134923925fa24fd1090281c3a416c3" id="r_a7e134923925fa24fd1090281c3a416c3"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a7e134923925fa24fd1090281c3a416c3">RUN_CLASSIFY_TESTS</a>&#160;&#160;&#160;(1)</td></tr> +<tr class="separator:a7e134923925fa24fd1090281c3a416c3"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a923de9c3e55322d85522740c0d0ff867" id="r_a923de9c3e55322d85522740c0d0ff867"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a923de9c3e55322d85522740c0d0ff867">RUN_UNAVAIL_TESTS</a>&#160;&#160;&#160;(1)</td></tr> +<tr class="separator:a923de9c3e55322d85522740c0d0ff867"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a6969308bd3633928893a2666f1df66fc" id="r_a6969308bd3633928893a2666f1df66fc"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a6969308bd3633928893a2666f1df66fc">RUN_TIMING_TESTS</a>&#160;&#160;&#160;(0)</td></tr> +<tr class="separator:a6969308bd3633928893a2666f1df66fc"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="func-members" name="func-members"></a> +Functions</h2></td></tr> +<tr class="memitem:a73c70bd0fb6d695cb113eaeb50923e3e" id="r_a73c70bd0fb6d695cb113eaeb50923e3e"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a73c70bd0fb6d695cb113eaeb50923e3e">get_test_vector</a> (void)</td></tr> +<tr class="separator:a73c70bd0fb6d695cb113eaeb50923e3e"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a941ef8d24fd8e8fe4536626b2ce72410" id="r_a941ef8d24fd8e8fe4536626b2ce72410"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a941ef8d24fd8e8fe4536626b2ce72410">verify_result</a> (uint32_t num, uint32_t opa, uint32_t opb, uint32_t ref, uint32_t res)</td></tr> +<tr class="separator:a941ef8d24fd8e8fe4536626b2ce72410"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a1740720aa8ce1a30fcf642be9140d203" id="r_a1740720aa8ce1a30fcf642be9140d203"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a1740720aa8ce1a30fcf642be9140d203">print_report</a> (uint32_t num_err)</td></tr> +<tr class="separator:a1740720aa8ce1a30fcf642be9140d203"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ae66f6b31b5ad750f1fe042a706a4e3d4" id="r_ae66f6b31b5ad750f1fe042a706a4e3d4"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ae66f6b31b5ad750f1fe042a706a4e3d4">main</a> ()</td></tr> +<tr class="separator:ae66f6b31b5ad750f1fe042a706a4e3d4"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>Verification program for the NEORV32 'Zfinx' extension (floating-point in x registers) using pseudo-random data as input; compares results from hardware against pure-sw reference functions. </p> +<dl class="section author"><dt>Author</dt><dd>Mikael Mortensen </dd></dl> +</div><h2 class="groupheader">Macro Definition Documentation</h2> +<a id="ad4455691936f92fdd6c37566fc58ba1f" name="ad4455691936f92fdd6c37566fc58ba1f"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ad4455691936f92fdd6c37566fc58ba1f">&#9670;&#160;</a></span>BAUD_RATE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define BAUD_RATE&#160;&#160;&#160;(19200)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>UART BAUD rate </p> + +</div> +</div> +<a id="a83792c34853f1d2801b59ad46adc7e1e" name="a83792c34853f1d2801b59ad46adc7e1e"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a83792c34853f1d2801b59ad46adc7e1e">&#9670;&#160;</a></span>NUM_TEST_CASES</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define NUM_TEST_CASES&#160;&#160;&#160;(1000000)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>UART BAUD rate </p> + +</div> +</div> +<a id="a2d16b9e484b7af7897c7ae83f945ceca" name="a2d16b9e484b7af7897c7ae83f945ceca"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a2d16b9e484b7af7897c7ae83f945ceca">&#9670;&#160;</a></span>RUN_ADDSUB_TESTS</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define RUN_ADDSUB_TESTS&#160;&#160;&#160;(1)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>UART BAUD rate </p> + +</div> +</div> +<a id="a7e134923925fa24fd1090281c3a416c3" name="a7e134923925fa24fd1090281c3a416c3"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a7e134923925fa24fd1090281c3a416c3">&#9670;&#160;</a></span>RUN_CLASSIFY_TESTS</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define RUN_CLASSIFY_TESTS&#160;&#160;&#160;(1)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>UART BAUD rate </p> + +</div> +</div> +<a id="a4ee0f6d28896a97d2c0cad866e77b874" name="a4ee0f6d28896a97d2c0cad866e77b874"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a4ee0f6d28896a97d2c0cad866e77b874">&#9670;&#160;</a></span>RUN_COMPARE_TESTS</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define RUN_COMPARE_TESTS&#160;&#160;&#160;(1)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>UART BAUD rate </p> + +</div> +</div> +<a id="aa3b6c4d49be7372de9e771a0475306ac" name="aa3b6c4d49be7372de9e771a0475306ac"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aa3b6c4d49be7372de9e771a0475306ac">&#9670;&#160;</a></span>RUN_CONV_TESTS</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define RUN_CONV_TESTS&#160;&#160;&#160;(1)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>UART BAUD rate </p> + +</div> +</div> +<a id="aed386f612417aeeeac8b08db27d515e4" name="aed386f612417aeeeac8b08db27d515e4"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aed386f612417aeeeac8b08db27d515e4">&#9670;&#160;</a></span>RUN_MINMAX_TESTS</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define RUN_MINMAX_TESTS&#160;&#160;&#160;(1)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>UART BAUD rate </p> + +</div> +</div> +<a id="a97323ecaf1ae85e68a736b06bc3b58f8" name="a97323ecaf1ae85e68a736b06bc3b58f8"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a97323ecaf1ae85e68a736b06bc3b58f8">&#9670;&#160;</a></span>RUN_MUL_TESTS</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define RUN_MUL_TESTS&#160;&#160;&#160;(1)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>UART BAUD rate </p> + +</div> +</div> +<a id="a94f0b0908f48f383145ed61ef8eb0713" name="a94f0b0908f48f383145ed61ef8eb0713"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a94f0b0908f48f383145ed61ef8eb0713">&#9670;&#160;</a></span>RUN_SGNINJ_TESTS</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define RUN_SGNINJ_TESTS&#160;&#160;&#160;(1)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>UART BAUD rate </p> + +</div> +</div> +<a id="a6969308bd3633928893a2666f1df66fc" name="a6969308bd3633928893a2666f1df66fc"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a6969308bd3633928893a2666f1df66fc">&#9670;&#160;</a></span>RUN_TIMING_TESTS</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define RUN_TIMING_TESTS&#160;&#160;&#160;(0)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>UART BAUD rate </p> + +</div> +</div> +<a id="a923de9c3e55322d85522740c0d0ff867" name="a923de9c3e55322d85522740c0d0ff867"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a923de9c3e55322d85522740c0d0ff867">&#9670;&#160;</a></span>RUN_UNAVAIL_TESTS</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define RUN_UNAVAIL_TESTS&#160;&#160;&#160;(1)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>UART BAUD rate </p> + +</div> +</div> +<a id="a87f296d7594bb8178cf76f0c045b7013" name="a87f296d7594bb8178cf76f0c045b7013"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a87f296d7594bb8178cf76f0c045b7013">&#9670;&#160;</a></span>SILENT_MODE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define SILENT_MODE&#160;&#160;&#160;(1)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>UART BAUD rate </p> + +</div> +</div> +<h2 class="groupheader">Function Documentation</h2> +<a id="a73c70bd0fb6d695cb113eaeb50923e3e" name="a73c70bd0fb6d695cb113eaeb50923e3e"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a73c70bd0fb6d695cb113eaeb50923e3e">&#9670;&#160;</a></span>get_test_vector()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t get_test_vector </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Generate 32-bit test data (including special values like INFINITY every now and then).</p> +<dl class="section return"><dt>Returns</dt><dd>Test data (32-bit). </dd></dl> + +</div> +</div> +<a id="ae66f6b31b5ad750f1fe042a706a4e3d4" name="ae66f6b31b5ad750f1fe042a706a4e3d4"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ae66f6b31b5ad750f1fe042a706a4e3d4">&#9670;&#160;</a></span>main()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int main </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Main function; test all available operations of the NEORV32 'Zfinx' extensions using bit floating-point hardware intrinsics and software-only reference functions (emulation).</p> +<dl class="section note"><dt>Note</dt><dd>This program requires the Zfinx CPU extension.</dd></dl> +<dl class="section return"><dt>Returns</dt><dd>0 if execution was successful </dd></dl> + +</div> +</div> +<a id="a1740720aa8ce1a30fcf642be9140d203" name="a1740720aa8ce1a30fcf642be9140d203"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a1740720aa8ce1a30fcf642be9140d203">&#9670;&#160;</a></span>print_report()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void print_report </td> + <td>(</td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>num_err</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Print test report.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">num_err</td><td>Number or errors in this test. </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="a941ef8d24fd8e8fe4536626b2ce72410" name="a941ef8d24fd8e8fe4536626b2ce72410"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a941ef8d24fd8e8fe4536626b2ce72410">&#9670;&#160;</a></span>verify_result()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t verify_result </td> + <td>(</td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>num</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>opa</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>opb</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>ref</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>res</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Verify results (software reference vs. actual hardware).</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">num</td><td>Test case number </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">opa</td><td>Operand 1 </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">opb</td><td>Operand 2 </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">ref</td><td>Software reference </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">res</td><td>Actual results from hardware </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>zero if results are equal. </dd></dl> + +</div> +</div> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/float__corner__test_2neorv32__zfinx__extension__intrinsics_8h_source.html b/sw/float__corner__test_2neorv32__zfinx__extension__intrinsics_8h_source.html new file mode 100644 index 0000000000..a7ccc7d0e7 --- /dev/null +++ b/sw/float__corner__test_2neorv32__zfinx__extension__intrinsics_8h_source.html @@ -0,0 +1,945 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/example/float_corner_test/neorv32_zfinx_extension_intrinsics.h Source File</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_f0f9b27afba2e8cc2da6e5fddcc1a8c9.html">example</a></li><li class="navelem"><a class="el" href="dir_23212395b5ee0866d2fdd629e0ddeae8.html">float_corner_test</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="headertitle"><div class="title">neorv32_zfinx_extension_intrinsics.h</div></div> +</div><!--header--> +<div class="contents"> +<div class="fragment"><div class="line"><a id="l00001" name="l00001"></a><span class="lineno"> 1</span><span class="comment">// #################################################################################################</span></div> +<div class="line"><a id="l00002" name="l00002"></a><span class="lineno"> 2</span><span class="comment">// # &lt;&lt; NEORV32 - Intrinsics + Emulation Functions for the RISC-V &quot;Zfinx&quot; CPU extension &gt;&gt; #</span></div> +<div class="line"><a id="l00003" name="l00003"></a><span class="lineno"> 3</span><span class="comment">// # ********************************************************************************************* #</span></div> +<div class="line"><a id="l00004" name="l00004"></a><span class="lineno"> 4</span><span class="comment">// # The intrinsics provided by this library allow to use the hardware floating-point unit of the #</span></div> +<div class="line"><a id="l00005" name="l00005"></a><span class="lineno"> 5</span><span class="comment">// # RISC-V Zfinx CPU extension without the need for Zfinx support by the compiler / toolchain. #</span></div> +<div class="line"><a id="l00006" name="l00006"></a><span class="lineno"> 6</span><span class="comment">// # ********************************************************************************************* #</span></div> +<div class="line"><a id="l00007" name="l00007"></a><span class="lineno"> 7</span><span class="comment">// # BSD 3-Clause License #</span></div> +<div class="line"><a id="l00008" name="l00008"></a><span class="lineno"> 8</span><span class="comment">// # #</span></div> +<div class="line"><a id="l00009" name="l00009"></a><span class="lineno"> 9</span><span class="comment">// # Copyright (c) 2022, Stephan Nolting. All rights reserved. #</span></div> +<div class="line"><a id="l00010" name="l00010"></a><span class="lineno"> 10</span><span class="comment">// # #</span></div> +<div class="line"><a id="l00011" name="l00011"></a><span class="lineno"> 11</span><span class="comment">// # Redistribution and use in source and binary forms, with or without modification, are #</span></div> +<div class="line"><a id="l00012" name="l00012"></a><span class="lineno"> 12</span><span class="comment">// # permitted provided that the following conditions are met: #</span></div> +<div class="line"><a id="l00013" name="l00013"></a><span class="lineno"> 13</span><span class="comment">// # #</span></div> +<div class="line"><a id="l00014" name="l00014"></a><span class="lineno"> 14</span><span class="comment">// # 1. Redistributions of source code must retain the above copyright notice, this list of #</span></div> +<div class="line"><a id="l00015" name="l00015"></a><span class="lineno"> 15</span><span class="comment">// # conditions and the following disclaimer. #</span></div> +<div class="line"><a id="l00016" name="l00016"></a><span class="lineno"> 16</span><span class="comment">// # #</span></div> +<div class="line"><a id="l00017" name="l00017"></a><span class="lineno"> 17</span><span class="comment">// # 2. Redistributions in binary form must reproduce the above copyright notice, this list of #</span></div> +<div class="line"><a id="l00018" name="l00018"></a><span class="lineno"> 18</span><span class="comment">// # conditions and the following disclaimer in the documentation and/or other materials #</span></div> +<div class="line"><a id="l00019" name="l00019"></a><span class="lineno"> 19</span><span class="comment">// # provided with the distribution. #</span></div> +<div class="line"><a id="l00020" name="l00020"></a><span class="lineno"> 20</span><span class="comment">// # #</span></div> +<div class="line"><a id="l00021" name="l00021"></a><span class="lineno"> 21</span><span class="comment">// # 3. Neither the name of the copyright holder nor the names of its contributors may be used to #</span></div> +<div class="line"><a id="l00022" name="l00022"></a><span class="lineno"> 22</span><span class="comment">// # endorse or promote products derived from this software without specific prior written #</span></div> +<div class="line"><a id="l00023" name="l00023"></a><span class="lineno"> 23</span><span class="comment">// # permission. #</span></div> +<div class="line"><a id="l00024" name="l00024"></a><span class="lineno"> 24</span><span class="comment">// # #</span></div> +<div class="line"><a id="l00025" name="l00025"></a><span class="lineno"> 25</span><span class="comment">// # THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS &quot;AS IS&quot; AND ANY EXPRESS #</span></div> +<div class="line"><a id="l00026" name="l00026"></a><span class="lineno"> 26</span><span class="comment">// # OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF #</span></div> +<div class="line"><a id="l00027" name="l00027"></a><span class="lineno"> 27</span><span class="comment">// # MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE #</span></div> +<div class="line"><a id="l00028" name="l00028"></a><span class="lineno"> 28</span><span class="comment">// # COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, #</span></div> +<div class="line"><a id="l00029" name="l00029"></a><span class="lineno"> 29</span><span class="comment">// # EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE #</span></div> +<div class="line"><a id="l00030" name="l00030"></a><span class="lineno"> 30</span><span class="comment">// # GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED #</span></div> +<div class="line"><a id="l00031" name="l00031"></a><span class="lineno"> 31</span><span class="comment">// # AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING #</span></div> +<div class="line"><a id="l00032" name="l00032"></a><span class="lineno"> 32</span><span class="comment">// # NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED #</span></div> +<div class="line"><a id="l00033" name="l00033"></a><span class="lineno"> 33</span><span class="comment">// # OF THE POSSIBILITY OF SUCH DAMAGE. #</span></div> +<div class="line"><a id="l00034" name="l00034"></a><span class="lineno"> 34</span><span class="comment">// # ********************************************************************************************* #</span></div> +<div class="line"><a id="l00035" name="l00035"></a><span class="lineno"> 35</span><span class="comment">// # The NEORV32 Processor - https://github.com/stnolting/neorv32 (c) Stephan Nolting #</span></div> +<div class="line"><a id="l00036" name="l00036"></a><span class="lineno"> 36</span><span class="comment">// #################################################################################################</span></div> +<div class="line"><a id="l00037" name="l00037"></a><span class="lineno"> 37</span> </div> +<div class="line"><a id="l00038" name="l00038"></a><span class="lineno"> 38</span> </div> +<div class="line"><a id="l00039" name="l00039"></a><span class="lineno"> 39</span><span class="comment">/**********************************************************************/</span></div> +<div class="line"><a id="l00052" name="l00052"></a><span class="lineno"> 52</span><span class="preprocessor">#ifndef neorv32_zfinx_extension_intrinsics_h</span></div> +<div class="line"><a id="l00053" name="l00053"></a><span class="lineno"> 53</span><span class="preprocessor">#define neorv32_zfinx_extension_intrinsics_h</span></div> +<div class="line"><a id="l00054" name="l00054"></a><span class="lineno"> 54</span> </div> +<div class="line"><a id="l00055" name="l00055"></a><span class="lineno"> 55</span><span class="preprocessor">#define __USE_GNU</span></div> +<div class="line"><a id="l00056" name="l00056"></a><span class="lineno"> 56</span> </div> +<div class="line"><a id="l00057" name="l00057"></a><span class="lineno"> 57</span><span class="preprocessor">#include &lt;fenv.h&gt;</span></div> +<div class="line"><a id="l00058" name="l00058"></a><span class="lineno"> 58</span><span class="comment">//#pragma STDC FENV_ACCESS ON</span></div> +<div class="line"><a id="l00059" name="l00059"></a><span class="lineno"> 59</span> </div> +<div class="line"><a id="l00060" name="l00060"></a><span class="lineno"> 60</span><span class="preprocessor">#define _GNU_SOURCE</span></div> +<div class="line"><a id="l00061" name="l00061"></a><span class="lineno"> 61</span> </div> +<div class="line"><a id="l00062" name="l00062"></a><span class="lineno"> 62</span><span class="preprocessor">#include &lt;float.h&gt;</span></div> +<div class="line"><a id="l00063" name="l00063"></a><span class="lineno"> 63</span><span class="preprocessor">#include &lt;math.h&gt;</span></div> +<div class="line"><a id="l00064" name="l00064"></a><span class="lineno"> 64</span> </div> +<div class="line"><a id="l00065" name="l00065"></a><span class="lineno"> 65</span> </div> +<div class="line"><a id="l00066" name="l00066"></a><span class="lineno"> 66</span><span class="comment">/**********************************************************************/</span></div> +<div class="line"><a id="l00069" name="l00069"></a><span class="lineno"> 69</span><span class="preprocessor">#if defined __riscv_f || (__riscv_flen == 32)</span></div> +<div class="line"><a id="l00070" name="l00070"></a><span class="lineno"> 70</span><span class="preprocessor"> #error Application programs using the Zfinx intrinsic library have to be compiled WITHOUT the &lt;F&gt; MARCH ISA attribute!</span></div> +<div class="line"><a id="l00071" name="l00071"></a><span class="lineno"> 71</span><span class="preprocessor">#endif</span></div> +<div class="line"><a id="l00072" name="l00072"></a><span class="lineno"> 72</span> </div> +<div class="line"><a id="l00073" name="l00073"></a><span class="lineno"> 73</span> </div> +<div class="line"><a id="l00074" name="l00074"></a><span class="lineno"> 74</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen00077" data-start="{" data-end="};"> +<div class="line"><a id="l00077" name="l00077"></a><span class="lineno"><a class="line" href="unionfloat__conv__t.html"> 77</a></span><span class="keyword">typedef</span> <span class="keyword">union</span></div> +<div class="line"><a id="l00078" name="l00078"></a><span class="lineno"> 78</span>{</div> +<div class="line"><a id="l00079" name="l00079"></a><span class="lineno"><a class="line" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606"> 79</a></span> uint32_t <a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a>; </div> +<div class="line"><a id="l00080" name="l00080"></a><span class="lineno"><a class="line" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788"> 80</a></span> <span class="keywordtype">float</span> <a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a>; </div> +<div class="line"><a id="l00081" name="l00081"></a><span class="lineno"> 81</span>} <a class="code hl_union" href="unionfloat__conv__t.html">float_conv_t</a>;</div> +</div> +<div class="line"><a id="l00082" name="l00082"></a><span class="lineno"> 82</span> </div> +<div class="line"><a id="l00083" name="l00083"></a><span class="lineno"> 83</span> </div> +<div class="line"><a id="l00084" name="l00084"></a><span class="lineno"> 84</span><span class="comment">// ################################################################################################</span></div> +<div class="line"><a id="l00085" name="l00085"></a><span class="lineno"> 85</span><span class="comment">// Helper functions</span></div> +<div class="line"><a id="l00086" name="l00086"></a><span class="lineno"> 86</span><span class="comment">// ################################################################################################</span></div> +<div class="line"><a id="l00087" name="l00087"></a><span class="lineno"> 87</span> </div> +<div class="line"><a id="l00088" name="l00088"></a><span class="lineno"> 88</span><span class="comment">/**********************************************************************/</span></div> +<div class="line"><a id="l00096" name="l00096"></a><span class="lineno"> 96</span><span class="keywordtype">float</span> subnormal_flush(<span class="keywordtype">float</span> tmp) {</div> +<div class="line"><a id="l00097" name="l00097"></a><span class="lineno"> 97</span> </div> +<div class="line"><a id="l00098" name="l00098"></a><span class="lineno"> 98</span> <span class="keywordtype">float</span> res = tmp;</div> +<div class="line"><a id="l00099" name="l00099"></a><span class="lineno"> 99</span> </div> +<div class="line"><a id="l00100" name="l00100"></a><span class="lineno"> 100</span> <span class="comment">// flush to zero if subnormal</span></div> +<div class="line"><a id="l00101" name="l00101"></a><span class="lineno"> 101</span> <span class="keywordflow">if</span> (fpclassify(tmp) == FP_SUBNORMAL) {</div> +<div class="line"><a id="l00102" name="l00102"></a><span class="lineno"> 102</span> <span class="keywordflow">if</span> (signbit(tmp) != 0) {</div> +<div class="line"><a id="l00103" name="l00103"></a><span class="lineno"> 103</span> res = -0.0f;</div> +<div class="line"><a id="l00104" name="l00104"></a><span class="lineno"> 104</span> }</div> +<div class="line"><a id="l00105" name="l00105"></a><span class="lineno"> 105</span> <span class="keywordflow">else</span> {</div> +<div class="line"><a id="l00106" name="l00106"></a><span class="lineno"> 106</span> res = +0.0f;</div> +<div class="line"><a id="l00107" name="l00107"></a><span class="lineno"> 107</span> }</div> +<div class="line"><a id="l00108" name="l00108"></a><span class="lineno"> 108</span> }</div> +<div class="line"><a id="l00109" name="l00109"></a><span class="lineno"> 109</span> </div> +<div class="line"><a id="l00110" name="l00110"></a><span class="lineno"> 110</span> <span class="keywordflow">return</span> res;</div> +<div class="line"><a id="l00111" name="l00111"></a><span class="lineno"> 111</span>}</div> +<div class="line"><a id="l00112" name="l00112"></a><span class="lineno"> 112</span> </div> +<div class="line"><a id="l00113" name="l00113"></a><span class="lineno"> 113</span> </div> +<div class="line"><a id="l00114" name="l00114"></a><span class="lineno"> 114</span><span class="comment">// ################################################################################################</span></div> +<div class="line"><a id="l00115" name="l00115"></a><span class="lineno"> 115</span><span class="comment">// Exception access</span></div> +<div class="line"><a id="l00116" name="l00116"></a><span class="lineno"> 116</span><span class="comment">// ################################################################################################</span></div> +<div class="line"><a id="l00117" name="l00117"></a><span class="lineno"> 117</span> </div> +<div class="line"><a id="l00118" name="l00118"></a><span class="lineno"> 118</span><span class="comment">/**********************************************************************/</span></div> +<div class="line"><a id="l00123" name="l00123"></a><span class="lineno"> 123</span>uint32_t get_hw_exceptions(<span class="keywordtype">void</span>) {</div> +<div class="line"><a id="l00124" name="l00124"></a><span class="lineno"> 124</span> </div> +<div class="line"><a id="l00125" name="l00125"></a><span class="lineno"> 125</span> uint32_t res = <a class="code hl_function" href="neorv32__cpu_8h.html#aab7a9f9cf608599f2b124dd499cb8418">neorv32_cpu_csr_read</a>(<a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a625f606c14fd4d7224d7109e10508e7a">CSR_FFLAGS</a>);</div> +<div class="line"><a id="l00126" name="l00126"></a><span class="lineno"> 126</span> </div> +<div class="line"><a id="l00127" name="l00127"></a><span class="lineno"> 127</span> <a class="code hl_function" href="neorv32__cpu_8h.html#afb5ef6e0b1a3e26570edfd8379490455">neorv32_cpu_csr_write</a>(<a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a625f606c14fd4d7224d7109e10508e7a">CSR_FFLAGS</a>, 0); <span class="comment">// clear status word</span></div> +<div class="line"><a id="l00128" name="l00128"></a><span class="lineno"> 128</span> </div> +<div class="line"><a id="l00129" name="l00129"></a><span class="lineno"> 129</span> <span class="keywordflow">return</span> res;</div> +<div class="line"><a id="l00130" name="l00130"></a><span class="lineno"> 130</span>}</div> +<div class="line"><a id="l00131" name="l00131"></a><span class="lineno"> 131</span> </div> +<div class="line"><a id="l00132" name="l00132"></a><span class="lineno"> 132</span> </div> +<div class="line"><a id="l00133" name="l00133"></a><span class="lineno"> 133</span><span class="comment">/**********************************************************************/</span></div> +<div class="line"><a id="l00140" name="l00140"></a><span class="lineno"> 140</span>uint32_t get_sw_exceptions(<span class="keywordtype">void</span>) {</div> +<div class="line"><a id="l00141" name="l00141"></a><span class="lineno"> 141</span> </div> +<div class="line"><a id="l00142" name="l00142"></a><span class="lineno"> 142</span> <span class="keyword">const</span> uint32_t FP_EXC_NV_C = 1 &lt;&lt; 0; <span class="comment">// invalid operation</span></div> +<div class="line"><a id="l00143" name="l00143"></a><span class="lineno"> 143</span> <span class="keyword">const</span> uint32_t FP_EXC_DZ_C = 1 &lt;&lt; 1; <span class="comment">// divide by zero</span></div> +<div class="line"><a id="l00144" name="l00144"></a><span class="lineno"> 144</span> <span class="keyword">const</span> uint32_t FP_EXC_OF_C = 1 &lt;&lt; 2; <span class="comment">// overflow</span></div> +<div class="line"><a id="l00145" name="l00145"></a><span class="lineno"> 145</span> <span class="keyword">const</span> uint32_t FP_EXC_UF_C = 1 &lt;&lt; 3; <span class="comment">// underflow</span></div> +<div class="line"><a id="l00146" name="l00146"></a><span class="lineno"> 146</span> <span class="keyword">const</span> uint32_t FP_EXC_NX_C = 1 &lt;&lt; 4; <span class="comment">// inexact</span></div> +<div class="line"><a id="l00147" name="l00147"></a><span class="lineno"> 147</span> </div> +<div class="line"><a id="l00148" name="l00148"></a><span class="lineno"> 148</span> <span class="keywordtype">int</span> fpeRaised = fetestexcept(FE_ALL_EXCEPT);</div> +<div class="line"><a id="l00149" name="l00149"></a><span class="lineno"> 149</span> </div> +<div class="line"><a id="l00150" name="l00150"></a><span class="lineno"> 150</span> uint32_t res = 0;</div> +<div class="line"><a id="l00151" name="l00151"></a><span class="lineno"> 151</span> </div> +<div class="line"><a id="l00152" name="l00152"></a><span class="lineno"> 152</span> <span class="keywordflow">if</span> (fpeRaised &amp; FE_INVALID) { res |= FP_EXC_NV_C; }</div> +<div class="line"><a id="l00153" name="l00153"></a><span class="lineno"> 153</span> <span class="keywordflow">if</span> (fpeRaised &amp; FE_DIVBYZERO) { res |= FP_EXC_DZ_C; }</div> +<div class="line"><a id="l00154" name="l00154"></a><span class="lineno"> 154</span> <span class="keywordflow">if</span> (fpeRaised &amp; FE_OVERFLOW) { res |= FP_EXC_OF_C; }</div> +<div class="line"><a id="l00155" name="l00155"></a><span class="lineno"> 155</span> <span class="keywordflow">if</span> (fpeRaised &amp; FE_UNDERFLOW) { res |= FP_EXC_UF_C; }</div> +<div class="line"><a id="l00156" name="l00156"></a><span class="lineno"> 156</span> <span class="keywordflow">if</span> (fpeRaised &amp; FE_INEXACT) { res |= FP_EXC_NX_C; }</div> +<div class="line"><a id="l00157" name="l00157"></a><span class="lineno"> 157</span> </div> +<div class="line"><a id="l00158" name="l00158"></a><span class="lineno"> 158</span> feclearexcept(FE_ALL_EXCEPT);</div> +<div class="line"><a id="l00159" name="l00159"></a><span class="lineno"> 159</span> </div> +<div class="line"><a id="l00160" name="l00160"></a><span class="lineno"> 160</span> <span class="keywordflow">return</span> res;</div> +<div class="line"><a id="l00161" name="l00161"></a><span class="lineno"> 161</span>}</div> +<div class="line"><a id="l00162" name="l00162"></a><span class="lineno"> 162</span> </div> +<div class="line"><a id="l00163" name="l00163"></a><span class="lineno"> 163</span> </div> +<div class="line"><a id="l00164" name="l00164"></a><span class="lineno"> 164</span><span class="comment">// ################################################################################################</span></div> +<div class="line"><a id="l00165" name="l00165"></a><span class="lineno"> 165</span><span class="comment">// &quot;Intrinsics&quot;</span></div> +<div class="line"><a id="l00166" name="l00166"></a><span class="lineno"> 166</span><span class="comment">// ################################################################################################</span></div> +<div class="line"><a id="l00167" name="l00167"></a><span class="lineno"> 167</span> </div> +<div class="line"><a id="l00168" name="l00168"></a><span class="lineno"> 168</span><span class="comment">/**********************************************************************/</span></div> +<div class="line"><a id="l00175" name="l00175"></a><span class="lineno"> 175</span><span class="keyword">inline</span> <span class="keywordtype">float</span> __attribute__ ((always_inline)) riscv_intrinsic_fadds(<span class="keywordtype">float</span> rs1, <span class="keywordtype">float</span> rs2) {</div> +<div class="line"><a id="l00176" name="l00176"></a><span class="lineno"> 176</span> </div> +<div class="line"><a id="l00177" name="l00177"></a><span class="lineno"> 177</span> <a class="code hl_union" href="unionfloat__conv__t.html">float_conv_t</a> opa, opb, res;</div> +<div class="line"><a id="l00178" name="l00178"></a><span class="lineno"> 178</span> opa.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a> = rs1;</div> +<div class="line"><a id="l00179" name="l00179"></a><span class="lineno"> 179</span> opb.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a> = rs2;</div> +<div class="line"><a id="l00180" name="l00180"></a><span class="lineno"> 180</span> </div> +<div class="line"><a id="l00181" name="l00181"></a><span class="lineno"> 181</span> res.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a> = CUSTOM_INSTR_R3_TYPE(0b0000000, opb.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a>, opa.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a>, 0b000, 0b1010011);</div> +<div class="line"><a id="l00182" name="l00182"></a><span class="lineno"> 182</span> <span class="keywordflow">return</span> res.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a>;</div> +<div class="line"><a id="l00183" name="l00183"></a><span class="lineno"> 183</span>}</div> +<div class="line"><a id="l00184" name="l00184"></a><span class="lineno"> 184</span> </div> +<div class="line"><a id="l00185" name="l00185"></a><span class="lineno"> 185</span> </div> +<div class="line"><a id="l00186" name="l00186"></a><span class="lineno"> 186</span><span class="comment">/**********************************************************************/</span></div> +<div class="line"><a id="l00193" name="l00193"></a><span class="lineno"> 193</span><span class="keyword">inline</span> <span class="keywordtype">float</span> __attribute__ ((always_inline)) riscv_intrinsic_fsubs(<span class="keywordtype">float</span> rs1, <span class="keywordtype">float</span> rs2) {</div> +<div class="line"><a id="l00194" name="l00194"></a><span class="lineno"> 194</span> </div> +<div class="line"><a id="l00195" name="l00195"></a><span class="lineno"> 195</span> <a class="code hl_union" href="unionfloat__conv__t.html">float_conv_t</a> opa, opb, res;</div> +<div class="line"><a id="l00196" name="l00196"></a><span class="lineno"> 196</span> opa.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a> = rs1;</div> +<div class="line"><a id="l00197" name="l00197"></a><span class="lineno"> 197</span> opb.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a> = rs2;</div> +<div class="line"><a id="l00198" name="l00198"></a><span class="lineno"> 198</span> </div> +<div class="line"><a id="l00199" name="l00199"></a><span class="lineno"> 199</span> res.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a> = CUSTOM_INSTR_R3_TYPE(0b0000100, opb.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a>, opa.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a>, 0b000, 0b1010011);</div> +<div class="line"><a id="l00200" name="l00200"></a><span class="lineno"> 200</span> <span class="keywordflow">return</span> res.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a>;</div> +<div class="line"><a id="l00201" name="l00201"></a><span class="lineno"> 201</span>}</div> +<div class="line"><a id="l00202" name="l00202"></a><span class="lineno"> 202</span> </div> +<div class="line"><a id="l00203" name="l00203"></a><span class="lineno"> 203</span> </div> +<div class="line"><a id="l00204" name="l00204"></a><span class="lineno"> 204</span><span class="comment">/**********************************************************************/</span></div> +<div class="line"><a id="l00211" name="l00211"></a><span class="lineno"> 211</span><span class="keyword">inline</span> <span class="keywordtype">float</span> __attribute__ ((always_inline)) riscv_intrinsic_fmuls(<span class="keywordtype">float</span> rs1, <span class="keywordtype">float</span> rs2) {</div> +<div class="line"><a id="l00212" name="l00212"></a><span class="lineno"> 212</span> </div> +<div class="line"><a id="l00213" name="l00213"></a><span class="lineno"> 213</span> <a class="code hl_union" href="unionfloat__conv__t.html">float_conv_t</a> opa, opb, res;</div> +<div class="line"><a id="l00214" name="l00214"></a><span class="lineno"> 214</span> opa.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a> = rs1;</div> +<div class="line"><a id="l00215" name="l00215"></a><span class="lineno"> 215</span> opb.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a> = rs2;</div> +<div class="line"><a id="l00216" name="l00216"></a><span class="lineno"> 216</span> </div> +<div class="line"><a id="l00217" name="l00217"></a><span class="lineno"> 217</span> res.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a> = CUSTOM_INSTR_R3_TYPE(0b0001000, opb.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a>, opa.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a>, 0b000, 0b1010011);</div> +<div class="line"><a id="l00218" name="l00218"></a><span class="lineno"> 218</span> <span class="keywordflow">return</span> res.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a>;</div> +<div class="line"><a id="l00219" name="l00219"></a><span class="lineno"> 219</span>}</div> +<div class="line"><a id="l00220" name="l00220"></a><span class="lineno"> 220</span> </div> +<div class="line"><a id="l00221" name="l00221"></a><span class="lineno"> 221</span> </div> +<div class="line"><a id="l00222" name="l00222"></a><span class="lineno"> 222</span><span class="comment">/**********************************************************************/</span></div> +<div class="line"><a id="l00229" name="l00229"></a><span class="lineno"> 229</span><span class="keyword">inline</span> <span class="keywordtype">float</span> __attribute__ ((always_inline)) riscv_intrinsic_fmins(<span class="keywordtype">float</span> rs1, <span class="keywordtype">float</span> rs2) {</div> +<div class="line"><a id="l00230" name="l00230"></a><span class="lineno"> 230</span> </div> +<div class="line"><a id="l00231" name="l00231"></a><span class="lineno"> 231</span> <a class="code hl_union" href="unionfloat__conv__t.html">float_conv_t</a> opa, opb, res;</div> +<div class="line"><a id="l00232" name="l00232"></a><span class="lineno"> 232</span> opa.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a> = rs1;</div> +<div class="line"><a id="l00233" name="l00233"></a><span class="lineno"> 233</span> opb.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a> = rs2;</div> +<div class="line"><a id="l00234" name="l00234"></a><span class="lineno"> 234</span> </div> +<div class="line"><a id="l00235" name="l00235"></a><span class="lineno"> 235</span> res.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a> = CUSTOM_INSTR_R3_TYPE(0b0010100, opb.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a>, opa.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a>, 0b000, 0b1010011);</div> +<div class="line"><a id="l00236" name="l00236"></a><span class="lineno"> 236</span> <span class="keywordflow">return</span> res.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a>;</div> +<div class="line"><a id="l00237" name="l00237"></a><span class="lineno"> 237</span>}</div> +<div class="line"><a id="l00238" name="l00238"></a><span class="lineno"> 238</span> </div> +<div class="line"><a id="l00239" name="l00239"></a><span class="lineno"> 239</span> </div> +<div class="line"><a id="l00240" name="l00240"></a><span class="lineno"> 240</span><span class="comment">/**********************************************************************/</span></div> +<div class="line"><a id="l00247" name="l00247"></a><span class="lineno"> 247</span><span class="keyword">inline</span> <span class="keywordtype">float</span> __attribute__ ((always_inline)) riscv_intrinsic_fmaxs(<span class="keywordtype">float</span> rs1, <span class="keywordtype">float</span> rs2) {</div> +<div class="line"><a id="l00248" name="l00248"></a><span class="lineno"> 248</span> </div> +<div class="line"><a id="l00249" name="l00249"></a><span class="lineno"> 249</span> <a class="code hl_union" href="unionfloat__conv__t.html">float_conv_t</a> opa, opb, res;</div> +<div class="line"><a id="l00250" name="l00250"></a><span class="lineno"> 250</span> opa.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a> = rs1;</div> +<div class="line"><a id="l00251" name="l00251"></a><span class="lineno"> 251</span> opb.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a> = rs2;</div> +<div class="line"><a id="l00252" name="l00252"></a><span class="lineno"> 252</span> </div> +<div class="line"><a id="l00253" name="l00253"></a><span class="lineno"> 253</span> res.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a> = CUSTOM_INSTR_R3_TYPE(0b0010100, opb.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a>, opa.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a>, 0b001, 0b1010011);</div> +<div class="line"><a id="l00254" name="l00254"></a><span class="lineno"> 254</span> <span class="keywordflow">return</span> res.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a>;</div> +<div class="line"><a id="l00255" name="l00255"></a><span class="lineno"> 255</span>}</div> +<div class="line"><a id="l00256" name="l00256"></a><span class="lineno"> 256</span> </div> +<div class="line"><a id="l00257" name="l00257"></a><span class="lineno"> 257</span> </div> +<div class="line"><a id="l00258" name="l00258"></a><span class="lineno"> 258</span><span class="comment">/**********************************************************************/</span></div> +<div class="line"><a id="l00264" name="l00264"></a><span class="lineno"> 264</span><span class="keyword">inline</span> uint32_t __attribute__ ((always_inline)) riscv_intrinsic_fcvt_wus(<span class="keywordtype">float</span> rs1) {</div> +<div class="line"><a id="l00265" name="l00265"></a><span class="lineno"> 265</span> </div> +<div class="line"><a id="l00266" name="l00266"></a><span class="lineno"> 266</span> <a class="code hl_union" href="unionfloat__conv__t.html">float_conv_t</a> opa;</div> +<div class="line"><a id="l00267" name="l00267"></a><span class="lineno"> 267</span> opa.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a> = rs1;</div> +<div class="line"><a id="l00268" name="l00268"></a><span class="lineno"> 268</span> </div> +<div class="line"><a id="l00269" name="l00269"></a><span class="lineno"> 269</span> <span class="keywordflow">return</span> CUSTOM_INSTR_R2_TYPE(0b1100000, 0b00001, opa.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a>, 0b000, 0b1010011);</div> +<div class="line"><a id="l00270" name="l00270"></a><span class="lineno"> 270</span>}</div> +<div class="line"><a id="l00271" name="l00271"></a><span class="lineno"> 271</span> </div> +<div class="line"><a id="l00272" name="l00272"></a><span class="lineno"> 272</span> </div> +<div class="line"><a id="l00273" name="l00273"></a><span class="lineno"> 273</span><span class="comment">/**********************************************************************/</span></div> +<div class="line"><a id="l00279" name="l00279"></a><span class="lineno"> 279</span><span class="keyword">inline</span> int32_t __attribute__ ((always_inline)) riscv_intrinsic_fcvt_ws(<span class="keywordtype">float</span> rs1) {</div> +<div class="line"><a id="l00280" name="l00280"></a><span class="lineno"> 280</span> </div> +<div class="line"><a id="l00281" name="l00281"></a><span class="lineno"> 281</span> <a class="code hl_union" href="unionfloat__conv__t.html">float_conv_t</a> opa;</div> +<div class="line"><a id="l00282" name="l00282"></a><span class="lineno"> 282</span> opa.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a> = rs1;</div> +<div class="line"><a id="l00283" name="l00283"></a><span class="lineno"> 283</span> </div> +<div class="line"><a id="l00284" name="l00284"></a><span class="lineno"> 284</span> <span class="keywordflow">return</span> (int32_t)CUSTOM_INSTR_R2_TYPE(0b1100000, 0b00000, opa.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a>, 0b000, 0b1010011);</div> +<div class="line"><a id="l00285" name="l00285"></a><span class="lineno"> 285</span>}</div> +<div class="line"><a id="l00286" name="l00286"></a><span class="lineno"> 286</span> </div> +<div class="line"><a id="l00287" name="l00287"></a><span class="lineno"> 287</span> </div> +<div class="line"><a id="l00288" name="l00288"></a><span class="lineno"> 288</span><span class="comment">/**********************************************************************/</span></div> +<div class="line"><a id="l00294" name="l00294"></a><span class="lineno"> 294</span><span class="keyword">inline</span> <span class="keywordtype">float</span> __attribute__ ((always_inline)) riscv_intrinsic_fcvt_swu(uint32_t rs1) {</div> +<div class="line"><a id="l00295" name="l00295"></a><span class="lineno"> 295</span> </div> +<div class="line"><a id="l00296" name="l00296"></a><span class="lineno"> 296</span> <a class="code hl_union" href="unionfloat__conv__t.html">float_conv_t</a> res;</div> +<div class="line"><a id="l00297" name="l00297"></a><span class="lineno"> 297</span> </div> +<div class="line"><a id="l00298" name="l00298"></a><span class="lineno"> 298</span> res.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a> = CUSTOM_INSTR_R2_TYPE(0b1101000, 0b00001, rs1, 0b000, 0b1010011);</div> +<div class="line"><a id="l00299" name="l00299"></a><span class="lineno"> 299</span> <span class="keywordflow">return</span> res.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a>;</div> +<div class="line"><a id="l00300" name="l00300"></a><span class="lineno"> 300</span>}</div> +<div class="line"><a id="l00301" name="l00301"></a><span class="lineno"> 301</span> </div> +<div class="line"><a id="l00302" name="l00302"></a><span class="lineno"> 302</span> </div> +<div class="line"><a id="l00303" name="l00303"></a><span class="lineno"> 303</span><span class="comment">/**********************************************************************/</span></div> +<div class="line"><a id="l00309" name="l00309"></a><span class="lineno"> 309</span><span class="keyword">inline</span> <span class="keywordtype">float</span> __attribute__ ((always_inline)) riscv_intrinsic_fcvt_sw(int32_t rs1) {</div> +<div class="line"><a id="l00310" name="l00310"></a><span class="lineno"> 310</span> </div> +<div class="line"><a id="l00311" name="l00311"></a><span class="lineno"> 311</span> <a class="code hl_union" href="unionfloat__conv__t.html">float_conv_t</a> res;</div> +<div class="line"><a id="l00312" name="l00312"></a><span class="lineno"> 312</span> </div> +<div class="line"><a id="l00313" name="l00313"></a><span class="lineno"> 313</span> res.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a> = CUSTOM_INSTR_R2_TYPE(0b1101000, 0b00000, rs1, 0b000, 0b1010011);</div> +<div class="line"><a id="l00314" name="l00314"></a><span class="lineno"> 314</span> <span class="keywordflow">return</span> res.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a>;</div> +<div class="line"><a id="l00315" name="l00315"></a><span class="lineno"> 315</span>}</div> +<div class="line"><a id="l00316" name="l00316"></a><span class="lineno"> 316</span> </div> +<div class="line"><a id="l00317" name="l00317"></a><span class="lineno"> 317</span> </div> +<div class="line"><a id="l00318" name="l00318"></a><span class="lineno"> 318</span><span class="comment">/**********************************************************************/</span></div> +<div class="line"><a id="l00325" name="l00325"></a><span class="lineno"> 325</span><span class="keyword">inline</span> uint32_t __attribute__ ((always_inline)) riscv_intrinsic_feqs(<span class="keywordtype">float</span> rs1, <span class="keywordtype">float</span> rs2) {</div> +<div class="line"><a id="l00326" name="l00326"></a><span class="lineno"> 326</span> </div> +<div class="line"><a id="l00327" name="l00327"></a><span class="lineno"> 327</span> <a class="code hl_union" href="unionfloat__conv__t.html">float_conv_t</a> opa, opb;</div> +<div class="line"><a id="l00328" name="l00328"></a><span class="lineno"> 328</span> opa.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a> = rs1;</div> +<div class="line"><a id="l00329" name="l00329"></a><span class="lineno"> 329</span> opb.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a> = rs2;</div> +<div class="line"><a id="l00330" name="l00330"></a><span class="lineno"> 330</span> </div> +<div class="line"><a id="l00331" name="l00331"></a><span class="lineno"> 331</span> <span class="keywordflow">return</span> CUSTOM_INSTR_R3_TYPE(0b1010000, opb.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a>, opa.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a>, 0b010, 0b1010011);</div> +<div class="line"><a id="l00332" name="l00332"></a><span class="lineno"> 332</span>}</div> +<div class="line"><a id="l00333" name="l00333"></a><span class="lineno"> 333</span> </div> +<div class="line"><a id="l00334" name="l00334"></a><span class="lineno"> 334</span> </div> +<div class="line"><a id="l00335" name="l00335"></a><span class="lineno"> 335</span><span class="comment">/**********************************************************************/</span></div> +<div class="line"><a id="l00342" name="l00342"></a><span class="lineno"> 342</span><span class="keyword">inline</span> uint32_t __attribute__ ((always_inline)) riscv_intrinsic_flts(<span class="keywordtype">float</span> rs1, <span class="keywordtype">float</span> rs2) {</div> +<div class="line"><a id="l00343" name="l00343"></a><span class="lineno"> 343</span> </div> +<div class="line"><a id="l00344" name="l00344"></a><span class="lineno"> 344</span> <a class="code hl_union" href="unionfloat__conv__t.html">float_conv_t</a> opa, opb;</div> +<div class="line"><a id="l00345" name="l00345"></a><span class="lineno"> 345</span> opa.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a> = rs1;</div> +<div class="line"><a id="l00346" name="l00346"></a><span class="lineno"> 346</span> opb.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a> = rs2;</div> +<div class="line"><a id="l00347" name="l00347"></a><span class="lineno"> 347</span> </div> +<div class="line"><a id="l00348" name="l00348"></a><span class="lineno"> 348</span> <span class="keywordflow">return</span> CUSTOM_INSTR_R3_TYPE(0b1010000, opb.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a>, opa.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a>, 0b001, 0b1010011);</div> +<div class="line"><a id="l00349" name="l00349"></a><span class="lineno"> 349</span>}</div> +<div class="line"><a id="l00350" name="l00350"></a><span class="lineno"> 350</span> </div> +<div class="line"><a id="l00351" name="l00351"></a><span class="lineno"> 351</span> </div> +<div class="line"><a id="l00352" name="l00352"></a><span class="lineno"> 352</span><span class="comment">/**********************************************************************/</span></div> +<div class="line"><a id="l00359" name="l00359"></a><span class="lineno"> 359</span><span class="keyword">inline</span> uint32_t __attribute__ ((always_inline)) riscv_intrinsic_fles(<span class="keywordtype">float</span> rs1, <span class="keywordtype">float</span> rs2) {</div> +<div class="line"><a id="l00360" name="l00360"></a><span class="lineno"> 360</span> </div> +<div class="line"><a id="l00361" name="l00361"></a><span class="lineno"> 361</span> <a class="code hl_union" href="unionfloat__conv__t.html">float_conv_t</a> opa, opb;</div> +<div class="line"><a id="l00362" name="l00362"></a><span class="lineno"> 362</span> opa.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a> = rs1;</div> +<div class="line"><a id="l00363" name="l00363"></a><span class="lineno"> 363</span> opb.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a> = rs2;</div> +<div class="line"><a id="l00364" name="l00364"></a><span class="lineno"> 364</span> </div> +<div class="line"><a id="l00365" name="l00365"></a><span class="lineno"> 365</span> <span class="keywordflow">return</span> CUSTOM_INSTR_R3_TYPE(0b1010000, opb.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a>, opa.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a>, 0b000, 0b1010011);</div> +<div class="line"><a id="l00366" name="l00366"></a><span class="lineno"> 366</span>}</div> +<div class="line"><a id="l00367" name="l00367"></a><span class="lineno"> 367</span> </div> +<div class="line"><a id="l00368" name="l00368"></a><span class="lineno"> 368</span> </div> +<div class="line"><a id="l00369" name="l00369"></a><span class="lineno"> 369</span><span class="comment">/**********************************************************************/</span></div> +<div class="line"><a id="l00376" name="l00376"></a><span class="lineno"> 376</span><span class="keyword">inline</span> <span class="keywordtype">float</span> __attribute__ ((always_inline)) riscv_intrinsic_fsgnjs(<span class="keywordtype">float</span> rs1, <span class="keywordtype">float</span> rs2) {</div> +<div class="line"><a id="l00377" name="l00377"></a><span class="lineno"> 377</span> </div> +<div class="line"><a id="l00378" name="l00378"></a><span class="lineno"> 378</span> <a class="code hl_union" href="unionfloat__conv__t.html">float_conv_t</a> opa, opb, res;</div> +<div class="line"><a id="l00379" name="l00379"></a><span class="lineno"> 379</span> opa.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a> = rs1;</div> +<div class="line"><a id="l00380" name="l00380"></a><span class="lineno"> 380</span> opb.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a> = rs2;</div> +<div class="line"><a id="l00381" name="l00381"></a><span class="lineno"> 381</span> </div> +<div class="line"><a id="l00382" name="l00382"></a><span class="lineno"> 382</span> res.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a> = CUSTOM_INSTR_R3_TYPE(0b0010000, opb.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a>, opa.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a>, 0b000, 0b1010011);</div> +<div class="line"><a id="l00383" name="l00383"></a><span class="lineno"> 383</span> <span class="keywordflow">return</span> res.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a>;</div> +<div class="line"><a id="l00384" name="l00384"></a><span class="lineno"> 384</span>}</div> +<div class="line"><a id="l00385" name="l00385"></a><span class="lineno"> 385</span> </div> +<div class="line"><a id="l00386" name="l00386"></a><span class="lineno"> 386</span> </div> +<div class="line"><a id="l00387" name="l00387"></a><span class="lineno"> 387</span><span class="comment">/**********************************************************************/</span></div> +<div class="line"><a id="l00394" name="l00394"></a><span class="lineno"> 394</span><span class="keyword">inline</span> <span class="keywordtype">float</span> __attribute__ ((always_inline)) riscv_intrinsic_fsgnjns(<span class="keywordtype">float</span> rs1, <span class="keywordtype">float</span> rs2) {</div> +<div class="line"><a id="l00395" name="l00395"></a><span class="lineno"> 395</span> </div> +<div class="line"><a id="l00396" name="l00396"></a><span class="lineno"> 396</span> <a class="code hl_union" href="unionfloat__conv__t.html">float_conv_t</a> opa, opb, res;</div> +<div class="line"><a id="l00397" name="l00397"></a><span class="lineno"> 397</span> opa.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a> = rs1;</div> +<div class="line"><a id="l00398" name="l00398"></a><span class="lineno"> 398</span> opb.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a> = rs2;</div> +<div class="line"><a id="l00399" name="l00399"></a><span class="lineno"> 399</span> </div> +<div class="line"><a id="l00400" name="l00400"></a><span class="lineno"> 400</span> res.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a> = CUSTOM_INSTR_R3_TYPE(0b0010000, opb.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a>, opa.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a>, 0b001, 0b1010011);</div> +<div class="line"><a id="l00401" name="l00401"></a><span class="lineno"> 401</span> <span class="keywordflow">return</span> res.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a>;</div> +<div class="line"><a id="l00402" name="l00402"></a><span class="lineno"> 402</span>}</div> +<div class="line"><a id="l00403" name="l00403"></a><span class="lineno"> 403</span> </div> +<div class="line"><a id="l00404" name="l00404"></a><span class="lineno"> 404</span> </div> +<div class="line"><a id="l00405" name="l00405"></a><span class="lineno"> 405</span><span class="comment">/**********************************************************************/</span></div> +<div class="line"><a id="l00412" name="l00412"></a><span class="lineno"> 412</span><span class="keyword">inline</span> <span class="keywordtype">float</span> __attribute__ ((always_inline)) riscv_intrinsic_fsgnjxs(<span class="keywordtype">float</span> rs1, <span class="keywordtype">float</span> rs2) {</div> +<div class="line"><a id="l00413" name="l00413"></a><span class="lineno"> 413</span> </div> +<div class="line"><a id="l00414" name="l00414"></a><span class="lineno"> 414</span> <a class="code hl_union" href="unionfloat__conv__t.html">float_conv_t</a> opa, opb, res;</div> +<div class="line"><a id="l00415" name="l00415"></a><span class="lineno"> 415</span> opa.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a> = rs1;</div> +<div class="line"><a id="l00416" name="l00416"></a><span class="lineno"> 416</span> opb.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a> = rs2;</div> +<div class="line"><a id="l00417" name="l00417"></a><span class="lineno"> 417</span> </div> +<div class="line"><a id="l00418" name="l00418"></a><span class="lineno"> 418</span> res.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a> = CUSTOM_INSTR_R3_TYPE(0b0010000, opb.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a>, opa.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a>, 0b010, 0b1010011);</div> +<div class="line"><a id="l00419" name="l00419"></a><span class="lineno"> 419</span> <span class="keywordflow">return</span> res.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a>;</div> +<div class="line"><a id="l00420" name="l00420"></a><span class="lineno"> 420</span>}</div> +<div class="line"><a id="l00421" name="l00421"></a><span class="lineno"> 421</span> </div> +<div class="line"><a id="l00422" name="l00422"></a><span class="lineno"> 422</span> </div> +<div class="line"><a id="l00423" name="l00423"></a><span class="lineno"> 423</span><span class="comment">/**********************************************************************/</span></div> +<div class="line"><a id="l00429" name="l00429"></a><span class="lineno"> 429</span><span class="keyword">inline</span> uint32_t __attribute__ ((always_inline)) riscv_intrinsic_fclasss(<span class="keywordtype">float</span> rs1) {</div> +<div class="line"><a id="l00430" name="l00430"></a><span class="lineno"> 430</span> </div> +<div class="line"><a id="l00431" name="l00431"></a><span class="lineno"> 431</span> <a class="code hl_union" href="unionfloat__conv__t.html">float_conv_t</a> opa;</div> +<div class="line"><a id="l00432" name="l00432"></a><span class="lineno"> 432</span> opa.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a> = rs1;</div> +<div class="line"><a id="l00433" name="l00433"></a><span class="lineno"> 433</span> </div> +<div class="line"><a id="l00434" name="l00434"></a><span class="lineno"> 434</span> <span class="keywordflow">return</span> CUSTOM_INSTR_R2_TYPE(0b1110000, 0b00000, opa.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a>, 0b001, 0b1010011);</div> +<div class="line"><a id="l00435" name="l00435"></a><span class="lineno"> 435</span>}</div> +<div class="line"><a id="l00436" name="l00436"></a><span class="lineno"> 436</span> </div> +<div class="line"><a id="l00437" name="l00437"></a><span class="lineno"> 437</span> </div> +<div class="line"><a id="l00438" name="l00438"></a><span class="lineno"> 438</span><span class="comment">// ################################################################################################</span></div> +<div class="line"><a id="l00439" name="l00439"></a><span class="lineno"> 439</span><span class="comment">// !!! UNSUPPORTED instructions !!!</span></div> +<div class="line"><a id="l00440" name="l00440"></a><span class="lineno"> 440</span><span class="comment">// ################################################################################################</span></div> +<div class="line"><a id="l00441" name="l00441"></a><span class="lineno"> 441</span> </div> +<div class="line"><a id="l00442" name="l00442"></a><span class="lineno"> 442</span><span class="comment">/**********************************************************************/</span></div> +<div class="line"><a id="l00451" name="l00451"></a><span class="lineno"> 451</span><span class="keyword">inline</span> <span class="keywordtype">float</span> __attribute__ ((always_inline)) riscv_intrinsic_fdivs(<span class="keywordtype">float</span> rs1, <span class="keywordtype">float</span> rs2) {</div> +<div class="line"><a id="l00452" name="l00452"></a><span class="lineno"> 452</span> </div> +<div class="line"><a id="l00453" name="l00453"></a><span class="lineno"> 453</span> <a class="code hl_union" href="unionfloat__conv__t.html">float_conv_t</a> opa, opb, res;</div> +<div class="line"><a id="l00454" name="l00454"></a><span class="lineno"> 454</span> opa.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a> = rs1;</div> +<div class="line"><a id="l00455" name="l00455"></a><span class="lineno"> 455</span> opb.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a> = rs2;</div> +<div class="line"><a id="l00456" name="l00456"></a><span class="lineno"> 456</span> </div> +<div class="line"><a id="l00457" name="l00457"></a><span class="lineno"> 457</span> res.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a> = CUSTOM_INSTR_R3_TYPE(0b0001100, opb.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a>, opa.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a>, 0b000, 0b1010011);</div> +<div class="line"><a id="l00458" name="l00458"></a><span class="lineno"> 458</span> <span class="keywordflow">return</span> res.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a>;</div> +<div class="line"><a id="l00459" name="l00459"></a><span class="lineno"> 459</span>}</div> +<div class="line"><a id="l00460" name="l00460"></a><span class="lineno"> 460</span> </div> +<div class="line"><a id="l00461" name="l00461"></a><span class="lineno"> 461</span> </div> +<div class="line"><a id="l00462" name="l00462"></a><span class="lineno"> 462</span><span class="comment">/**********************************************************************/</span></div> +<div class="line"><a id="l00470" name="l00470"></a><span class="lineno"> 470</span><span class="keyword">inline</span> <span class="keywordtype">float</span> __attribute__ ((always_inline)) riscv_intrinsic_fsqrts(<span class="keywordtype">float</span> rs1) {</div> +<div class="line"><a id="l00471" name="l00471"></a><span class="lineno"> 471</span> </div> +<div class="line"><a id="l00472" name="l00472"></a><span class="lineno"> 472</span> <a class="code hl_union" href="unionfloat__conv__t.html">float_conv_t</a> opa, res;</div> +<div class="line"><a id="l00473" name="l00473"></a><span class="lineno"> 473</span> opa.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a> = rs1;</div> +<div class="line"><a id="l00474" name="l00474"></a><span class="lineno"> 474</span> </div> +<div class="line"><a id="l00475" name="l00475"></a><span class="lineno"> 475</span> res.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a> = CUSTOM_INSTR_R2_TYPE(0b0101100, 0b00000, opa.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a>, 0b000, 0b1010011);</div> +<div class="line"><a id="l00476" name="l00476"></a><span class="lineno"> 476</span> <span class="keywordflow">return</span> res.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a>;</div> +<div class="line"><a id="l00477" name="l00477"></a><span class="lineno"> 477</span>}</div> +<div class="line"><a id="l00478" name="l00478"></a><span class="lineno"> 478</span> </div> +<div class="line"><a id="l00479" name="l00479"></a><span class="lineno"> 479</span> </div> +<div class="line"><a id="l00480" name="l00480"></a><span class="lineno"> 480</span><span class="comment">/**********************************************************************/</span></div> +<div class="line"><a id="l00490" name="l00490"></a><span class="lineno"> 490</span><span class="keyword">inline</span> <span class="keywordtype">float</span> __attribute__ ((always_inline)) riscv_intrinsic_fmadds(<span class="keywordtype">float</span> rs1, <span class="keywordtype">float</span> rs2, <span class="keywordtype">float</span> rs3) {</div> +<div class="line"><a id="l00491" name="l00491"></a><span class="lineno"> 491</span> </div> +<div class="line"><a id="l00492" name="l00492"></a><span class="lineno"> 492</span> <a class="code hl_union" href="unionfloat__conv__t.html">float_conv_t</a> opa, opb, opc, res;</div> +<div class="line"><a id="l00493" name="l00493"></a><span class="lineno"> 493</span> opa.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a> = rs1;</div> +<div class="line"><a id="l00494" name="l00494"></a><span class="lineno"> 494</span> opb.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a> = rs2;</div> +<div class="line"><a id="l00495" name="l00495"></a><span class="lineno"> 495</span> opc.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a> = rs3;</div> +<div class="line"><a id="l00496" name="l00496"></a><span class="lineno"> 496</span> </div> +<div class="line"><a id="l00497" name="l00497"></a><span class="lineno"> 497</span> res.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a> = CUSTOM_INSTR_R4_TYPE(opc.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a>, opb.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a>, opa.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a>, 0b000, 0b1000011);</div> +<div class="line"><a id="l00498" name="l00498"></a><span class="lineno"> 498</span> <span class="keywordflow">return</span> res.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a>;</div> +<div class="line"><a id="l00499" name="l00499"></a><span class="lineno"> 499</span>}</div> +<div class="line"><a id="l00500" name="l00500"></a><span class="lineno"> 500</span> </div> +<div class="line"><a id="l00501" name="l00501"></a><span class="lineno"> 501</span> </div> +<div class="line"><a id="l00502" name="l00502"></a><span class="lineno"> 502</span><span class="comment">/**********************************************************************/</span></div> +<div class="line"><a id="l00512" name="l00512"></a><span class="lineno"> 512</span><span class="keyword">inline</span> <span class="keywordtype">float</span> __attribute__ ((always_inline)) riscv_intrinsic_fmsubs(<span class="keywordtype">float</span> rs1, <span class="keywordtype">float</span> rs2, <span class="keywordtype">float</span> rs3) {</div> +<div class="line"><a id="l00513" name="l00513"></a><span class="lineno"> 513</span> </div> +<div class="line"><a id="l00514" name="l00514"></a><span class="lineno"> 514</span> <a class="code hl_union" href="unionfloat__conv__t.html">float_conv_t</a> opa, opb, opc, res;</div> +<div class="line"><a id="l00515" name="l00515"></a><span class="lineno"> 515</span> opa.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a> = rs1;</div> +<div class="line"><a id="l00516" name="l00516"></a><span class="lineno"> 516</span> opb.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a> = rs2;</div> +<div class="line"><a id="l00517" name="l00517"></a><span class="lineno"> 517</span> opc.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a> = rs3;</div> +<div class="line"><a id="l00518" name="l00518"></a><span class="lineno"> 518</span> </div> +<div class="line"><a id="l00519" name="l00519"></a><span class="lineno"> 519</span> res.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a> = CUSTOM_INSTR_R4_TYPE(opc.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a>, opb.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a>, opa.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a>, 0b000, 0b1000111);</div> +<div class="line"><a id="l00520" name="l00520"></a><span class="lineno"> 520</span> <span class="keywordflow">return</span> res.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a>;</div> +<div class="line"><a id="l00521" name="l00521"></a><span class="lineno"> 521</span>}</div> +<div class="line"><a id="l00522" name="l00522"></a><span class="lineno"> 522</span> </div> +<div class="line"><a id="l00523" name="l00523"></a><span class="lineno"> 523</span> </div> +<div class="line"><a id="l00524" name="l00524"></a><span class="lineno"> 524</span><span class="comment">/**********************************************************************/</span></div> +<div class="line"><a id="l00534" name="l00534"></a><span class="lineno"> 534</span><span class="keyword">inline</span> <span class="keywordtype">float</span> __attribute__ ((always_inline)) riscv_intrinsic_fnmsubs(<span class="keywordtype">float</span> rs1, <span class="keywordtype">float</span> rs2, <span class="keywordtype">float</span> rs3) {</div> +<div class="line"><a id="l00535" name="l00535"></a><span class="lineno"> 535</span> </div> +<div class="line"><a id="l00536" name="l00536"></a><span class="lineno"> 536</span> <a class="code hl_union" href="unionfloat__conv__t.html">float_conv_t</a> opa, opb, opc, res;</div> +<div class="line"><a id="l00537" name="l00537"></a><span class="lineno"> 537</span> opa.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a> = rs1;</div> +<div class="line"><a id="l00538" name="l00538"></a><span class="lineno"> 538</span> opb.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a> = rs2;</div> +<div class="line"><a id="l00539" name="l00539"></a><span class="lineno"> 539</span> opc.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a> = rs3;</div> +<div class="line"><a id="l00540" name="l00540"></a><span class="lineno"> 540</span> </div> +<div class="line"><a id="l00541" name="l00541"></a><span class="lineno"> 541</span> res.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a> = CUSTOM_INSTR_R4_TYPE(opc.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a>, opb.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a>, opa.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a>, 0b000, 0b1001011);</div> +<div class="line"><a id="l00542" name="l00542"></a><span class="lineno"> 542</span> <span class="keywordflow">return</span> res.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a>;</div> +<div class="line"><a id="l00543" name="l00543"></a><span class="lineno"> 543</span>}</div> +<div class="line"><a id="l00544" name="l00544"></a><span class="lineno"> 544</span> </div> +<div class="line"><a id="l00545" name="l00545"></a><span class="lineno"> 545</span> </div> +<div class="line"><a id="l00546" name="l00546"></a><span class="lineno"> 546</span><span class="comment">/**********************************************************************/</span></div> +<div class="line"><a id="l00556" name="l00556"></a><span class="lineno"> 556</span><span class="keyword">inline</span> <span class="keywordtype">float</span> __attribute__ ((always_inline)) riscv_intrinsic_fnmadds(<span class="keywordtype">float</span> rs1, <span class="keywordtype">float</span> rs2, <span class="keywordtype">float</span> rs3) {</div> +<div class="line"><a id="l00557" name="l00557"></a><span class="lineno"> 557</span> </div> +<div class="line"><a id="l00558" name="l00558"></a><span class="lineno"> 558</span> <a class="code hl_union" href="unionfloat__conv__t.html">float_conv_t</a> opa, opb, opc, res;</div> +<div class="line"><a id="l00559" name="l00559"></a><span class="lineno"> 559</span> opa.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a> = rs1;</div> +<div class="line"><a id="l00560" name="l00560"></a><span class="lineno"> 560</span> opb.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a> = rs2;</div> +<div class="line"><a id="l00561" name="l00561"></a><span class="lineno"> 561</span> opc.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a> = rs3;</div> +<div class="line"><a id="l00562" name="l00562"></a><span class="lineno"> 562</span> </div> +<div class="line"><a id="l00563" name="l00563"></a><span class="lineno"> 563</span> res.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a> = CUSTOM_INSTR_R4_TYPE(opc.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a>, opb.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a>, opa.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a>, 0b000, 0b1001111);</div> +<div class="line"><a id="l00564" name="l00564"></a><span class="lineno"> 564</span> <span class="keywordflow">return</span> res.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a>;</div> +<div class="line"><a id="l00565" name="l00565"></a><span class="lineno"> 565</span>}</div> +<div class="line"><a id="l00566" name="l00566"></a><span class="lineno"> 566</span> </div> +<div class="line"><a id="l00567" name="l00567"></a><span class="lineno"> 567</span> </div> +<div class="line"><a id="l00568" name="l00568"></a><span class="lineno"> 568</span><span class="comment">// ################################################################################################</span></div> +<div class="line"><a id="l00569" name="l00569"></a><span class="lineno"> 569</span><span class="comment">// Emulation functions</span></div> +<div class="line"><a id="l00570" name="l00570"></a><span class="lineno"> 570</span><span class="comment">// ################################################################################################</span></div> +<div class="line"><a id="l00571" name="l00571"></a><span class="lineno"> 571</span> </div> +<div class="line"><a id="l00572" name="l00572"></a><span class="lineno"> 572</span><span class="comment">/**********************************************************************/</span></div> +<div class="line"><a id="l00579" name="l00579"></a><span class="lineno"> 579</span><span class="keywordtype">float</span> __attribute__ ((noinline)) riscv_emulate_fadds(<span class="keywordtype">float</span> rs1, <span class="keywordtype">float</span> rs2) {</div> +<div class="line"><a id="l00580" name="l00580"></a><span class="lineno"> 580</span> </div> +<div class="line"><a id="l00581" name="l00581"></a><span class="lineno"> 581</span> <span class="keywordtype">float</span> opa = subnormal_flush(rs1);</div> +<div class="line"><a id="l00582" name="l00582"></a><span class="lineno"> 582</span> <span class="keywordtype">float</span> opb = subnormal_flush(rs2);</div> +<div class="line"><a id="l00583" name="l00583"></a><span class="lineno"> 583</span> </div> +<div class="line"><a id="l00584" name="l00584"></a><span class="lineno"> 584</span> <span class="keywordtype">float</span> res = opa + opb;</div> +<div class="line"><a id="l00585" name="l00585"></a><span class="lineno"> 585</span> </div> +<div class="line"><a id="l00586" name="l00586"></a><span class="lineno"> 586</span> <span class="comment">// make NAN canonical</span></div> +<div class="line"><a id="l00587" name="l00587"></a><span class="lineno"> 587</span> <span class="keywordflow">if</span> (fpclassify(res) == FP_NAN) {</div> +<div class="line"><a id="l00588" name="l00588"></a><span class="lineno"> 588</span> res = NAN;</div> +<div class="line"><a id="l00589" name="l00589"></a><span class="lineno"> 589</span> }</div> +<div class="line"><a id="l00590" name="l00590"></a><span class="lineno"> 590</span> </div> +<div class="line"><a id="l00591" name="l00591"></a><span class="lineno"> 591</span> <span class="keywordflow">return</span> subnormal_flush(res);</div> +<div class="line"><a id="l00592" name="l00592"></a><span class="lineno"> 592</span>}</div> +<div class="line"><a id="l00593" name="l00593"></a><span class="lineno"> 593</span> </div> +<div class="line"><a id="l00594" name="l00594"></a><span class="lineno"> 594</span> </div> +<div class="line"><a id="l00595" name="l00595"></a><span class="lineno"> 595</span><span class="comment">/**********************************************************************/</span></div> +<div class="line"><a id="l00602" name="l00602"></a><span class="lineno"> 602</span><span class="keywordtype">float</span> __attribute__ ((noinline)) riscv_emulate_fsubs(<span class="keywordtype">float</span> rs1, <span class="keywordtype">float</span> rs2) {</div> +<div class="line"><a id="l00603" name="l00603"></a><span class="lineno"> 603</span> </div> +<div class="line"><a id="l00604" name="l00604"></a><span class="lineno"> 604</span> <span class="keywordtype">float</span> opa = subnormal_flush(rs1);</div> +<div class="line"><a id="l00605" name="l00605"></a><span class="lineno"> 605</span> <span class="keywordtype">float</span> opb = subnormal_flush(rs2);</div> +<div class="line"><a id="l00606" name="l00606"></a><span class="lineno"> 606</span> </div> +<div class="line"><a id="l00607" name="l00607"></a><span class="lineno"> 607</span> <span class="keywordtype">float</span> res = opa - opb;</div> +<div class="line"><a id="l00608" name="l00608"></a><span class="lineno"> 608</span> </div> +<div class="line"><a id="l00609" name="l00609"></a><span class="lineno"> 609</span> <span class="comment">// make NAN canonical</span></div> +<div class="line"><a id="l00610" name="l00610"></a><span class="lineno"> 610</span> <span class="keywordflow">if</span> (fpclassify(res) == FP_NAN) {</div> +<div class="line"><a id="l00611" name="l00611"></a><span class="lineno"> 611</span> res = NAN;</div> +<div class="line"><a id="l00612" name="l00612"></a><span class="lineno"> 612</span> }</div> +<div class="line"><a id="l00613" name="l00613"></a><span class="lineno"> 613</span> </div> +<div class="line"><a id="l00614" name="l00614"></a><span class="lineno"> 614</span> <span class="keywordflow">return</span> subnormal_flush(res);</div> +<div class="line"><a id="l00615" name="l00615"></a><span class="lineno"> 615</span>}</div> +<div class="line"><a id="l00616" name="l00616"></a><span class="lineno"> 616</span> </div> +<div class="line"><a id="l00617" name="l00617"></a><span class="lineno"> 617</span> </div> +<div class="line"><a id="l00618" name="l00618"></a><span class="lineno"> 618</span><span class="comment">/**********************************************************************/</span></div> +<div class="line"><a id="l00625" name="l00625"></a><span class="lineno"> 625</span><span class="keywordtype">float</span> __attribute__ ((noinline)) riscv_emulate_fmuls(<span class="keywordtype">float</span> rs1, <span class="keywordtype">float</span> rs2) {</div> +<div class="line"><a id="l00626" name="l00626"></a><span class="lineno"> 626</span> </div> +<div class="line"><a id="l00627" name="l00627"></a><span class="lineno"> 627</span> <span class="keywordtype">float</span> opa = subnormal_flush(rs1);</div> +<div class="line"><a id="l00628" name="l00628"></a><span class="lineno"> 628</span> <span class="keywordtype">float</span> opb = subnormal_flush(rs2);</div> +<div class="line"><a id="l00629" name="l00629"></a><span class="lineno"> 629</span> </div> +<div class="line"><a id="l00630" name="l00630"></a><span class="lineno"> 630</span> <span class="keywordtype">float</span> res = opa * opb;</div> +<div class="line"><a id="l00631" name="l00631"></a><span class="lineno"> 631</span> <span class="keywordflow">return</span> subnormal_flush(res);</div> +<div class="line"><a id="l00632" name="l00632"></a><span class="lineno"> 632</span>}</div> +<div class="line"><a id="l00633" name="l00633"></a><span class="lineno"> 633</span> </div> +<div class="line"><a id="l00634" name="l00634"></a><span class="lineno"> 634</span> </div> +<div class="line"><a id="l00635" name="l00635"></a><span class="lineno"> 635</span><span class="comment">/**********************************************************************/</span></div> +<div class="line"><a id="l00642" name="l00642"></a><span class="lineno"> 642</span><span class="keywordtype">float</span> __attribute__ ((noinline)) riscv_emulate_fmins(<span class="keywordtype">float</span> rs1, <span class="keywordtype">float</span> rs2) {</div> +<div class="line"><a id="l00643" name="l00643"></a><span class="lineno"> 643</span> </div> +<div class="line"><a id="l00644" name="l00644"></a><span class="lineno"> 644</span> <span class="keywordtype">float</span> opa = subnormal_flush(rs1);</div> +<div class="line"><a id="l00645" name="l00645"></a><span class="lineno"> 645</span> <span class="keywordtype">float</span> opb = subnormal_flush(rs2);</div> +<div class="line"><a id="l00646" name="l00646"></a><span class="lineno"> 646</span> </div> +<div class="line"><a id="l00647" name="l00647"></a><span class="lineno"> 647</span> <span class="keyword">union </span>{</div> +<div class="line"><a id="l00648" name="l00648"></a><span class="lineno"> 648</span> uint32_t binary_value; </div> +<div class="line"><a id="l00649" name="l00649"></a><span class="lineno"> 649</span> <span class="keywordtype">float</span> float_value; </div> +<div class="line"><a id="l00650" name="l00650"></a><span class="lineno"> 650</span> } tmp_a, tmp_b;</div> +<div class="line"><a id="l00651" name="l00651"></a><span class="lineno"> 651</span> </div> +<div class="line"><a id="l00652" name="l00652"></a><span class="lineno"> 652</span> <span class="keywordflow">if</span> ((fpclassify(opa) == FP_NAN) &amp;&amp; (fpclassify(opb) == FP_NAN)) {</div> +<div class="line"><a id="l00653" name="l00653"></a><span class="lineno"> 653</span> <span class="keywordflow">return</span> nanf(<span class="stringliteral">&quot;&quot;</span>);</div> +<div class="line"><a id="l00654" name="l00654"></a><span class="lineno"> 654</span> }</div> +<div class="line"><a id="l00655" name="l00655"></a><span class="lineno"> 655</span> </div> +<div class="line"><a id="l00656" name="l00656"></a><span class="lineno"> 656</span> <span class="keywordflow">if</span> (fpclassify(opa) == FP_NAN) {</div> +<div class="line"><a id="l00657" name="l00657"></a><span class="lineno"> 657</span> <span class="keywordflow">return</span> opb;</div> +<div class="line"><a id="l00658" name="l00658"></a><span class="lineno"> 658</span> }</div> +<div class="line"><a id="l00659" name="l00659"></a><span class="lineno"> 659</span> </div> +<div class="line"><a id="l00660" name="l00660"></a><span class="lineno"> 660</span> <span class="keywordflow">if</span> (fpclassify(opb) == FP_NAN) {</div> +<div class="line"><a id="l00661" name="l00661"></a><span class="lineno"> 661</span> <span class="keywordflow">return</span> opa;</div> +<div class="line"><a id="l00662" name="l00662"></a><span class="lineno"> 662</span> }</div> +<div class="line"><a id="l00663" name="l00663"></a><span class="lineno"> 663</span> </div> +<div class="line"><a id="l00664" name="l00664"></a><span class="lineno"> 664</span> <span class="comment">// RISC-V spec: -0 &lt; +0</span></div> +<div class="line"><a id="l00665" name="l00665"></a><span class="lineno"> 665</span> tmp_a.float_value = opa;</div> +<div class="line"><a id="l00666" name="l00666"></a><span class="lineno"> 666</span> tmp_b.float_value = opb;</div> +<div class="line"><a id="l00667" name="l00667"></a><span class="lineno"> 667</span> <span class="keywordflow">if</span> (((tmp_a.binary_value == 0x80000000) &amp;&amp; (tmp_b.binary_value == 0x00000000)) ||</div> +<div class="line"><a id="l00668" name="l00668"></a><span class="lineno"> 668</span> ((tmp_a.binary_value == 0x00000000) &amp;&amp; (tmp_b.binary_value == 0x80000000))) {</div> +<div class="line"><a id="l00669" name="l00669"></a><span class="lineno"> 669</span> <span class="keywordflow">return</span> -0.0f;</div> +<div class="line"><a id="l00670" name="l00670"></a><span class="lineno"> 670</span> }</div> +<div class="line"><a id="l00671" name="l00671"></a><span class="lineno"> 671</span> </div> +<div class="line"><a id="l00672" name="l00672"></a><span class="lineno"> 672</span> <span class="keywordflow">return</span> fmin(opa, opb);</div> +<div class="line"><a id="l00673" name="l00673"></a><span class="lineno"> 673</span>}</div> +<div class="line"><a id="l00674" name="l00674"></a><span class="lineno"> 674</span> </div> +<div class="line"><a id="l00675" name="l00675"></a><span class="lineno"> 675</span> </div> +<div class="line"><a id="l00676" name="l00676"></a><span class="lineno"> 676</span><span class="comment">/**********************************************************************/</span></div> +<div class="line"><a id="l00683" name="l00683"></a><span class="lineno"> 683</span><span class="keywordtype">float</span> __attribute__ ((noinline)) riscv_emulate_fmaxs(<span class="keywordtype">float</span> rs1, <span class="keywordtype">float</span> rs2) {</div> +<div class="line"><a id="l00684" name="l00684"></a><span class="lineno"> 684</span> </div> +<div class="line"><a id="l00685" name="l00685"></a><span class="lineno"> 685</span> <span class="keywordtype">float</span> opa = subnormal_flush(rs1);</div> +<div class="line"><a id="l00686" name="l00686"></a><span class="lineno"> 686</span> <span class="keywordtype">float</span> opb = subnormal_flush(rs2);</div> +<div class="line"><a id="l00687" name="l00687"></a><span class="lineno"> 687</span> </div> +<div class="line"><a id="l00688" name="l00688"></a><span class="lineno"> 688</span> <span class="keyword">union </span>{</div> +<div class="line"><a id="l00689" name="l00689"></a><span class="lineno"> 689</span> uint32_t binary_value; </div> +<div class="line"><a id="l00690" name="l00690"></a><span class="lineno"> 690</span> <span class="keywordtype">float</span> float_value; </div> +<div class="line"><a id="l00691" name="l00691"></a><span class="lineno"> 691</span> } tmp_a, tmp_b;</div> +<div class="line"><a id="l00692" name="l00692"></a><span class="lineno"> 692</span> </div> +<div class="line"><a id="l00693" name="l00693"></a><span class="lineno"> 693</span> </div> +<div class="line"><a id="l00694" name="l00694"></a><span class="lineno"> 694</span> <span class="keywordflow">if</span> ((fpclassify(opa) == FP_NAN) &amp;&amp; (fpclassify(opb) == FP_NAN)) {</div> +<div class="line"><a id="l00695" name="l00695"></a><span class="lineno"> 695</span> <span class="keywordflow">return</span> nanf(<span class="stringliteral">&quot;&quot;</span>);</div> +<div class="line"><a id="l00696" name="l00696"></a><span class="lineno"> 696</span> }</div> +<div class="line"><a id="l00697" name="l00697"></a><span class="lineno"> 697</span> </div> +<div class="line"><a id="l00698" name="l00698"></a><span class="lineno"> 698</span> <span class="keywordflow">if</span> (fpclassify(opa) == FP_NAN) {</div> +<div class="line"><a id="l00699" name="l00699"></a><span class="lineno"> 699</span> <span class="keywordflow">return</span> opb;</div> +<div class="line"><a id="l00700" name="l00700"></a><span class="lineno"> 700</span> }</div> +<div class="line"><a id="l00701" name="l00701"></a><span class="lineno"> 701</span> </div> +<div class="line"><a id="l00702" name="l00702"></a><span class="lineno"> 702</span> <span class="keywordflow">if</span> (fpclassify(opb) == FP_NAN) {</div> +<div class="line"><a id="l00703" name="l00703"></a><span class="lineno"> 703</span> <span class="keywordflow">return</span> opa;</div> +<div class="line"><a id="l00704" name="l00704"></a><span class="lineno"> 704</span> }</div> +<div class="line"><a id="l00705" name="l00705"></a><span class="lineno"> 705</span> </div> +<div class="line"><a id="l00706" name="l00706"></a><span class="lineno"> 706</span> <span class="comment">// RISC-V spec: -0 &lt; +0</span></div> +<div class="line"><a id="l00707" name="l00707"></a><span class="lineno"> 707</span> tmp_a.float_value = opa;</div> +<div class="line"><a id="l00708" name="l00708"></a><span class="lineno"> 708</span> tmp_b.float_value = opb;</div> +<div class="line"><a id="l00709" name="l00709"></a><span class="lineno"> 709</span> <span class="keywordflow">if</span> (((tmp_a.binary_value == 0x80000000) &amp;&amp; (tmp_b.binary_value == 0x00000000)) ||</div> +<div class="line"><a id="l00710" name="l00710"></a><span class="lineno"> 710</span> ((tmp_a.binary_value == 0x00000000) &amp;&amp; (tmp_b.binary_value == 0x80000000))) {</div> +<div class="line"><a id="l00711" name="l00711"></a><span class="lineno"> 711</span> <span class="keywordflow">return</span> +0.0f;</div> +<div class="line"><a id="l00712" name="l00712"></a><span class="lineno"> 712</span> }</div> +<div class="line"><a id="l00713" name="l00713"></a><span class="lineno"> 713</span> </div> +<div class="line"><a id="l00714" name="l00714"></a><span class="lineno"> 714</span> <span class="keywordflow">return</span> fmax(opa, opb);</div> +<div class="line"><a id="l00715" name="l00715"></a><span class="lineno"> 715</span>}</div> +<div class="line"><a id="l00716" name="l00716"></a><span class="lineno"> 716</span> </div> +<div class="line"><a id="l00717" name="l00717"></a><span class="lineno"> 717</span> </div> +<div class="line"><a id="l00718" name="l00718"></a><span class="lineno"> 718</span><span class="comment">/**********************************************************************/</span></div> +<div class="line"><a id="l00724" name="l00724"></a><span class="lineno"> 724</span>uint32_t __attribute__ ((noinline)) riscv_emulate_fcvt_wus(<span class="keywordtype">float</span> rs1) {</div> +<div class="line"><a id="l00725" name="l00725"></a><span class="lineno"> 725</span> </div> +<div class="line"><a id="l00726" name="l00726"></a><span class="lineno"> 726</span> <span class="keywordtype">float</span> opa = subnormal_flush(rs1);</div> +<div class="line"><a id="l00727" name="l00727"></a><span class="lineno"> 727</span> </div> +<div class="line"><a id="l00728" name="l00728"></a><span class="lineno"> 728</span> <span class="keywordflow">return</span> (uint32_t)roundf(opa);</div> +<div class="line"><a id="l00729" name="l00729"></a><span class="lineno"> 729</span>}</div> +<div class="line"><a id="l00730" name="l00730"></a><span class="lineno"> 730</span> </div> +<div class="line"><a id="l00731" name="l00731"></a><span class="lineno"> 731</span> </div> +<div class="line"><a id="l00732" name="l00732"></a><span class="lineno"> 732</span><span class="comment">/**********************************************************************/</span></div> +<div class="line"><a id="l00738" name="l00738"></a><span class="lineno"> 738</span>int32_t __attribute__ ((noinline)) riscv_emulate_fcvt_ws(<span class="keywordtype">float</span> rs1) {</div> +<div class="line"><a id="l00739" name="l00739"></a><span class="lineno"> 739</span> </div> +<div class="line"><a id="l00740" name="l00740"></a><span class="lineno"> 740</span> <span class="keywordtype">float</span> opa = subnormal_flush(rs1);</div> +<div class="line"><a id="l00741" name="l00741"></a><span class="lineno"> 741</span> </div> +<div class="line"><a id="l00742" name="l00742"></a><span class="lineno"> 742</span> <span class="keywordflow">return</span> (int32_t)roundf(opa);</div> +<div class="line"><a id="l00743" name="l00743"></a><span class="lineno"> 743</span>}</div> +<div class="line"><a id="l00744" name="l00744"></a><span class="lineno"> 744</span> </div> +<div class="line"><a id="l00745" name="l00745"></a><span class="lineno"> 745</span> </div> +<div class="line"><a id="l00746" name="l00746"></a><span class="lineno"> 746</span><span class="comment">/**********************************************************************/</span></div> +<div class="line"><a id="l00752" name="l00752"></a><span class="lineno"> 752</span><span class="keywordtype">float</span> __attribute__ ((noinline)) riscv_emulate_fcvt_swu(uint32_t rs1) {</div> +<div class="line"><a id="l00753" name="l00753"></a><span class="lineno"> 753</span> </div> +<div class="line"><a id="l00754" name="l00754"></a><span class="lineno"> 754</span> <span class="keywordflow">return</span> (<span class="keywordtype">float</span>)rs1;</div> +<div class="line"><a id="l00755" name="l00755"></a><span class="lineno"> 755</span>}</div> +<div class="line"><a id="l00756" name="l00756"></a><span class="lineno"> 756</span> </div> +<div class="line"><a id="l00757" name="l00757"></a><span class="lineno"> 757</span> </div> +<div class="line"><a id="l00758" name="l00758"></a><span class="lineno"> 758</span><span class="comment">/**********************************************************************/</span></div> +<div class="line"><a id="l00764" name="l00764"></a><span class="lineno"> 764</span><span class="keywordtype">float</span> __attribute__ ((noinline)) riscv_emulate_fcvt_sw(int32_t rs1) {</div> +<div class="line"><a id="l00765" name="l00765"></a><span class="lineno"> 765</span> </div> +<div class="line"><a id="l00766" name="l00766"></a><span class="lineno"> 766</span> <span class="keywordflow">return</span> (<span class="keywordtype">float</span>)rs1;</div> +<div class="line"><a id="l00767" name="l00767"></a><span class="lineno"> 767</span>}</div> +<div class="line"><a id="l00768" name="l00768"></a><span class="lineno"> 768</span> </div> +<div class="line"><a id="l00769" name="l00769"></a><span class="lineno"> 769</span> </div> +<div class="line"><a id="l00770" name="l00770"></a><span class="lineno"> 770</span><span class="comment">/**********************************************************************/</span></div> +<div class="line"><a id="l00777" name="l00777"></a><span class="lineno"> 777</span>uint32_t __attribute__ ((noinline)) riscv_emulate_feqs(<span class="keywordtype">float</span> rs1, <span class="keywordtype">float</span> rs2) {</div> +<div class="line"><a id="l00778" name="l00778"></a><span class="lineno"> 778</span> </div> +<div class="line"><a id="l00779" name="l00779"></a><span class="lineno"> 779</span> <span class="keywordtype">float</span> opa = subnormal_flush(rs1);</div> +<div class="line"><a id="l00780" name="l00780"></a><span class="lineno"> 780</span> <span class="keywordtype">float</span> opb = subnormal_flush(rs2);</div> +<div class="line"><a id="l00781" name="l00781"></a><span class="lineno"> 781</span> </div> +<div class="line"><a id="l00782" name="l00782"></a><span class="lineno"> 782</span> <span class="keywordflow">if</span> ((fpclassify(opa) == FP_NAN) || (fpclassify(opb) == FP_NAN)) {</div> +<div class="line"><a id="l00783" name="l00783"></a><span class="lineno"> 783</span> <span class="keywordflow">return</span> 0;</div> +<div class="line"><a id="l00784" name="l00784"></a><span class="lineno"> 784</span> }</div> +<div class="line"><a id="l00785" name="l00785"></a><span class="lineno"> 785</span> </div> +<div class="line"><a id="l00786" name="l00786"></a><span class="lineno"> 786</span> <span class="keywordflow">if</span> isless(opa, opb) {</div> +<div class="line"><a id="l00787" name="l00787"></a><span class="lineno"> 787</span> <span class="keywordflow">return</span> 0;</div> +<div class="line"><a id="l00788" name="l00788"></a><span class="lineno"> 788</span> }</div> +<div class="line"><a id="l00789" name="l00789"></a><span class="lineno"> 789</span> <span class="keywordflow">else</span> <span class="keywordflow">if</span> isgreater(opa, opb) {</div> +<div class="line"><a id="l00790" name="l00790"></a><span class="lineno"> 790</span> <span class="keywordflow">return</span> 0;</div> +<div class="line"><a id="l00791" name="l00791"></a><span class="lineno"> 791</span> }</div> +<div class="line"><a id="l00792" name="l00792"></a><span class="lineno"> 792</span> <span class="keywordflow">else</span> {</div> +<div class="line"><a id="l00793" name="l00793"></a><span class="lineno"> 793</span> <span class="keywordflow">return</span> 1;</div> +<div class="line"><a id="l00794" name="l00794"></a><span class="lineno"> 794</span> }</div> +<div class="line"><a id="l00795" name="l00795"></a><span class="lineno"> 795</span>}</div> +<div class="line"><a id="l00796" name="l00796"></a><span class="lineno"> 796</span> </div> +<div class="line"><a id="l00797" name="l00797"></a><span class="lineno"> 797</span> </div> +<div class="line"><a id="l00798" name="l00798"></a><span class="lineno"> 798</span><span class="comment">/**********************************************************************/</span></div> +<div class="line"><a id="l00805" name="l00805"></a><span class="lineno"> 805</span>uint32_t __attribute__ ((noinline)) riscv_emulate_flts(<span class="keywordtype">float</span> rs1, <span class="keywordtype">float</span> rs2) {</div> +<div class="line"><a id="l00806" name="l00806"></a><span class="lineno"> 806</span> </div> +<div class="line"><a id="l00807" name="l00807"></a><span class="lineno"> 807</span> <span class="keywordtype">float</span> opa = subnormal_flush(rs1);</div> +<div class="line"><a id="l00808" name="l00808"></a><span class="lineno"> 808</span> <span class="keywordtype">float</span> opb = subnormal_flush(rs2);</div> +<div class="line"><a id="l00809" name="l00809"></a><span class="lineno"> 809</span> </div> +<div class="line"><a id="l00810" name="l00810"></a><span class="lineno"> 810</span> <span class="keywordflow">if</span> ((fpclassify(opa) == FP_NAN) || (fpclassify(opb) == FP_NAN)) {</div> +<div class="line"><a id="l00811" name="l00811"></a><span class="lineno"> 811</span> <span class="keywordflow">return</span> 0;</div> +<div class="line"><a id="l00812" name="l00812"></a><span class="lineno"> 812</span> }</div> +<div class="line"><a id="l00813" name="l00813"></a><span class="lineno"> 813</span> </div> +<div class="line"><a id="l00814" name="l00814"></a><span class="lineno"> 814</span> <span class="keywordflow">if</span> isless(opa, opb) {</div> +<div class="line"><a id="l00815" name="l00815"></a><span class="lineno"> 815</span> <span class="keywordflow">return</span> 1;</div> +<div class="line"><a id="l00816" name="l00816"></a><span class="lineno"> 816</span> }</div> +<div class="line"><a id="l00817" name="l00817"></a><span class="lineno"> 817</span> <span class="keywordflow">else</span> {</div> +<div class="line"><a id="l00818" name="l00818"></a><span class="lineno"> 818</span> <span class="keywordflow">return</span> 0;</div> +<div class="line"><a id="l00819" name="l00819"></a><span class="lineno"> 819</span> }</div> +<div class="line"><a id="l00820" name="l00820"></a><span class="lineno"> 820</span>}</div> +<div class="line"><a id="l00821" name="l00821"></a><span class="lineno"> 821</span> </div> +<div class="line"><a id="l00822" name="l00822"></a><span class="lineno"> 822</span> </div> +<div class="line"><a id="l00823" name="l00823"></a><span class="lineno"> 823</span><span class="comment">/**********************************************************************/</span></div> +<div class="line"><a id="l00830" name="l00830"></a><span class="lineno"> 830</span>uint32_t __attribute__ ((noinline)) riscv_emulate_fles(<span class="keywordtype">float</span> rs1, <span class="keywordtype">float</span> rs2) {</div> +<div class="line"><a id="l00831" name="l00831"></a><span class="lineno"> 831</span> </div> +<div class="line"><a id="l00832" name="l00832"></a><span class="lineno"> 832</span> <span class="keywordtype">float</span> opa = subnormal_flush(rs1);</div> +<div class="line"><a id="l00833" name="l00833"></a><span class="lineno"> 833</span> <span class="keywordtype">float</span> opb = subnormal_flush(rs2);</div> +<div class="line"><a id="l00834" name="l00834"></a><span class="lineno"> 834</span> </div> +<div class="line"><a id="l00835" name="l00835"></a><span class="lineno"> 835</span> <span class="keywordflow">if</span> ((fpclassify(opa) == FP_NAN) || (fpclassify(opb) == FP_NAN)) {</div> +<div class="line"><a id="l00836" name="l00836"></a><span class="lineno"> 836</span> <span class="keywordflow">return</span> 0;</div> +<div class="line"><a id="l00837" name="l00837"></a><span class="lineno"> 837</span> }</div> +<div class="line"><a id="l00838" name="l00838"></a><span class="lineno"> 838</span> </div> +<div class="line"><a id="l00839" name="l00839"></a><span class="lineno"> 839</span> <span class="keywordflow">if</span> islessequal(opa, opb) {</div> +<div class="line"><a id="l00840" name="l00840"></a><span class="lineno"> 840</span> <span class="keywordflow">return</span> 1;</div> +<div class="line"><a id="l00841" name="l00841"></a><span class="lineno"> 841</span> }</div> +<div class="line"><a id="l00842" name="l00842"></a><span class="lineno"> 842</span> <span class="keywordflow">else</span> {</div> +<div class="line"><a id="l00843" name="l00843"></a><span class="lineno"> 843</span> <span class="keywordflow">return</span> 0;</div> +<div class="line"><a id="l00844" name="l00844"></a><span class="lineno"> 844</span> }</div> +<div class="line"><a id="l00845" name="l00845"></a><span class="lineno"> 845</span>}</div> +<div class="line"><a id="l00846" name="l00846"></a><span class="lineno"> 846</span> </div> +<div class="line"><a id="l00847" name="l00847"></a><span class="lineno"> 847</span> </div> +<div class="line"><a id="l00848" name="l00848"></a><span class="lineno"> 848</span><span class="comment">/**********************************************************************/</span></div> +<div class="line"><a id="l00855" name="l00855"></a><span class="lineno"> 855</span><span class="keywordtype">float</span> __attribute__ ((noinline)) riscv_emulate_fsgnjs(<span class="keywordtype">float</span> rs1, <span class="keywordtype">float</span> rs2) {</div> +<div class="line"><a id="l00856" name="l00856"></a><span class="lineno"> 856</span> </div> +<div class="line"><a id="l00857" name="l00857"></a><span class="lineno"> 857</span> <span class="keywordtype">float</span> opa = subnormal_flush(rs1);</div> +<div class="line"><a id="l00858" name="l00858"></a><span class="lineno"> 858</span> <span class="keywordtype">float</span> opb = subnormal_flush(rs2);</div> +<div class="line"><a id="l00859" name="l00859"></a><span class="lineno"> 859</span> </div> +<div class="line"><a id="l00860" name="l00860"></a><span class="lineno"> 860</span> <span class="keywordtype">int</span> sign_1 = (int)signbit(opa);</div> +<div class="line"><a id="l00861" name="l00861"></a><span class="lineno"> 861</span> <span class="keywordtype">int</span> sign_2 = (int)signbit(opb);</div> +<div class="line"><a id="l00862" name="l00862"></a><span class="lineno"> 862</span> <span class="keywordtype">float</span> res = 0;</div> +<div class="line"><a id="l00863" name="l00863"></a><span class="lineno"> 863</span> </div> +<div class="line"><a id="l00864" name="l00864"></a><span class="lineno"> 864</span> <span class="keywordflow">if</span> (sign_2 != 0) { <span class="comment">// opb is negative</span></div> +<div class="line"><a id="l00865" name="l00865"></a><span class="lineno"> 865</span> <span class="keywordflow">if</span> (sign_1 == 0) {</div> +<div class="line"><a id="l00866" name="l00866"></a><span class="lineno"> 866</span> res = -opa;</div> +<div class="line"><a id="l00867" name="l00867"></a><span class="lineno"> 867</span> }</div> +<div class="line"><a id="l00868" name="l00868"></a><span class="lineno"> 868</span> <span class="keywordflow">else</span> {</div> +<div class="line"><a id="l00869" name="l00869"></a><span class="lineno"> 869</span> res = opa;</div> +<div class="line"><a id="l00870" name="l00870"></a><span class="lineno"> 870</span> }</div> +<div class="line"><a id="l00871" name="l00871"></a><span class="lineno"> 871</span> }</div> +<div class="line"><a id="l00872" name="l00872"></a><span class="lineno"> 872</span> <span class="keywordflow">else</span> { <span class="comment">// opb is positive</span></div> +<div class="line"><a id="l00873" name="l00873"></a><span class="lineno"> 873</span> <span class="keywordflow">if</span> (sign_1 == 0) {</div> +<div class="line"><a id="l00874" name="l00874"></a><span class="lineno"> 874</span> res = opa;</div> +<div class="line"><a id="l00875" name="l00875"></a><span class="lineno"> 875</span> }</div> +<div class="line"><a id="l00876" name="l00876"></a><span class="lineno"> 876</span> <span class="keywordflow">else</span> {</div> +<div class="line"><a id="l00877" name="l00877"></a><span class="lineno"> 877</span> res = -opa;</div> +<div class="line"><a id="l00878" name="l00878"></a><span class="lineno"> 878</span> }</div> +<div class="line"><a id="l00879" name="l00879"></a><span class="lineno"> 879</span> }</div> +<div class="line"><a id="l00880" name="l00880"></a><span class="lineno"> 880</span> </div> +<div class="line"><a id="l00881" name="l00881"></a><span class="lineno"> 881</span> <span class="keywordflow">return</span> res;</div> +<div class="line"><a id="l00882" name="l00882"></a><span class="lineno"> 882</span>}</div> +<div class="line"><a id="l00883" name="l00883"></a><span class="lineno"> 883</span> </div> +<div class="line"><a id="l00884" name="l00884"></a><span class="lineno"> 884</span> </div> +<div class="line"><a id="l00885" name="l00885"></a><span class="lineno"> 885</span><span class="comment">/**********************************************************************/</span></div> +<div class="line"><a id="l00892" name="l00892"></a><span class="lineno"> 892</span><span class="keywordtype">float</span> __attribute__ ((noinline)) riscv_emulate_fsgnjns(<span class="keywordtype">float</span> rs1, <span class="keywordtype">float</span> rs2) {</div> +<div class="line"><a id="l00893" name="l00893"></a><span class="lineno"> 893</span> </div> +<div class="line"><a id="l00894" name="l00894"></a><span class="lineno"> 894</span> <span class="keywordtype">float</span> opa = subnormal_flush(rs1);</div> +<div class="line"><a id="l00895" name="l00895"></a><span class="lineno"> 895</span> <span class="keywordtype">float</span> opb = subnormal_flush(rs2);</div> +<div class="line"><a id="l00896" name="l00896"></a><span class="lineno"> 896</span> </div> +<div class="line"><a id="l00897" name="l00897"></a><span class="lineno"> 897</span> <span class="keywordtype">int</span> sign_1 = (int)signbit(opa);</div> +<div class="line"><a id="l00898" name="l00898"></a><span class="lineno"> 898</span> <span class="keywordtype">int</span> sign_2 = (int)signbit(opb);</div> +<div class="line"><a id="l00899" name="l00899"></a><span class="lineno"> 899</span> <span class="keywordtype">float</span> res = 0;</div> +<div class="line"><a id="l00900" name="l00900"></a><span class="lineno"> 900</span> </div> +<div class="line"><a id="l00901" name="l00901"></a><span class="lineno"> 901</span> <span class="keywordflow">if</span> (sign_2 != 0) { <span class="comment">// opb is negative</span></div> +<div class="line"><a id="l00902" name="l00902"></a><span class="lineno"> 902</span> <span class="keywordflow">if</span> (sign_1 == 0) {</div> +<div class="line"><a id="l00903" name="l00903"></a><span class="lineno"> 903</span> res = opa;</div> +<div class="line"><a id="l00904" name="l00904"></a><span class="lineno"> 904</span> }</div> +<div class="line"><a id="l00905" name="l00905"></a><span class="lineno"> 905</span> <span class="keywordflow">else</span> {</div> +<div class="line"><a id="l00906" name="l00906"></a><span class="lineno"> 906</span> res = -opa;</div> +<div class="line"><a id="l00907" name="l00907"></a><span class="lineno"> 907</span> }</div> +<div class="line"><a id="l00908" name="l00908"></a><span class="lineno"> 908</span> }</div> +<div class="line"><a id="l00909" name="l00909"></a><span class="lineno"> 909</span> <span class="keywordflow">else</span> { <span class="comment">// opb is positive</span></div> +<div class="line"><a id="l00910" name="l00910"></a><span class="lineno"> 910</span> <span class="keywordflow">if</span> (sign_1 == 0) {</div> +<div class="line"><a id="l00911" name="l00911"></a><span class="lineno"> 911</span> res = -opa;</div> +<div class="line"><a id="l00912" name="l00912"></a><span class="lineno"> 912</span> }</div> +<div class="line"><a id="l00913" name="l00913"></a><span class="lineno"> 913</span> <span class="keywordflow">else</span> {</div> +<div class="line"><a id="l00914" name="l00914"></a><span class="lineno"> 914</span> res = opa;</div> +<div class="line"><a id="l00915" name="l00915"></a><span class="lineno"> 915</span> }</div> +<div class="line"><a id="l00916" name="l00916"></a><span class="lineno"> 916</span> }</div> +<div class="line"><a id="l00917" name="l00917"></a><span class="lineno"> 917</span> </div> +<div class="line"><a id="l00918" name="l00918"></a><span class="lineno"> 918</span> <span class="keywordflow">return</span> res;</div> +<div class="line"><a id="l00919" name="l00919"></a><span class="lineno"> 919</span>}</div> +<div class="line"><a id="l00920" name="l00920"></a><span class="lineno"> 920</span> </div> +<div class="line"><a id="l00921" name="l00921"></a><span class="lineno"> 921</span> </div> +<div class="line"><a id="l00922" name="l00922"></a><span class="lineno"> 922</span><span class="comment">/**********************************************************************/</span></div> +<div class="line"><a id="l00929" name="l00929"></a><span class="lineno"> 929</span><span class="keywordtype">float</span> __attribute__ ((noinline)) riscv_emulate_fsgnjxs(<span class="keywordtype">float</span> rs1, <span class="keywordtype">float</span> rs2) {</div> +<div class="line"><a id="l00930" name="l00930"></a><span class="lineno"> 930</span> </div> +<div class="line"><a id="l00931" name="l00931"></a><span class="lineno"> 931</span> <span class="keywordtype">float</span> opa = subnormal_flush(rs1);</div> +<div class="line"><a id="l00932" name="l00932"></a><span class="lineno"> 932</span> <span class="keywordtype">float</span> opb = subnormal_flush(rs2);</div> +<div class="line"><a id="l00933" name="l00933"></a><span class="lineno"> 933</span> </div> +<div class="line"><a id="l00934" name="l00934"></a><span class="lineno"> 934</span> <span class="keywordtype">int</span> sign_1 = (int)signbit(opa);</div> +<div class="line"><a id="l00935" name="l00935"></a><span class="lineno"> 935</span> <span class="keywordtype">int</span> sign_2 = (int)signbit(opb);</div> +<div class="line"><a id="l00936" name="l00936"></a><span class="lineno"> 936</span> <span class="keywordtype">float</span> res = 0;</div> +<div class="line"><a id="l00937" name="l00937"></a><span class="lineno"> 937</span> </div> +<div class="line"><a id="l00938" name="l00938"></a><span class="lineno"> 938</span> <span class="keywordflow">if</span> (((sign_1 == 0) &amp;&amp; (sign_2 != 0)) || ((sign_1 != 0) &amp;&amp; (sign_2 == 0))) {</div> +<div class="line"><a id="l00939" name="l00939"></a><span class="lineno"> 939</span> <span class="keywordflow">if</span> (sign_1 == 0) {</div> +<div class="line"><a id="l00940" name="l00940"></a><span class="lineno"> 940</span> res = -opa;</div> +<div class="line"><a id="l00941" name="l00941"></a><span class="lineno"> 941</span> }</div> +<div class="line"><a id="l00942" name="l00942"></a><span class="lineno"> 942</span> <span class="keywordflow">else</span> {</div> +<div class="line"><a id="l00943" name="l00943"></a><span class="lineno"> 943</span> res = opa;</div> +<div class="line"><a id="l00944" name="l00944"></a><span class="lineno"> 944</span> }</div> +<div class="line"><a id="l00945" name="l00945"></a><span class="lineno"> 945</span> }</div> +<div class="line"><a id="l00946" name="l00946"></a><span class="lineno"> 946</span> <span class="keywordflow">else</span> {</div> +<div class="line"><a id="l00947" name="l00947"></a><span class="lineno"> 947</span> <span class="keywordflow">if</span> (sign_1 == 0) {</div> +<div class="line"><a id="l00948" name="l00948"></a><span class="lineno"> 948</span> res = opa;</div> +<div class="line"><a id="l00949" name="l00949"></a><span class="lineno"> 949</span> }</div> +<div class="line"><a id="l00950" name="l00950"></a><span class="lineno"> 950</span> <span class="keywordflow">else</span> {</div> +<div class="line"><a id="l00951" name="l00951"></a><span class="lineno"> 951</span> res = -opa;</div> +<div class="line"><a id="l00952" name="l00952"></a><span class="lineno"> 952</span> }</div> +<div class="line"><a id="l00953" name="l00953"></a><span class="lineno"> 953</span> }</div> +<div class="line"><a id="l00954" name="l00954"></a><span class="lineno"> 954</span> </div> +<div class="line"><a id="l00955" name="l00955"></a><span class="lineno"> 955</span> <span class="keywordflow">return</span> res;</div> +<div class="line"><a id="l00956" name="l00956"></a><span class="lineno"> 956</span>}</div> +<div class="line"><a id="l00957" name="l00957"></a><span class="lineno"> 957</span> </div> +<div class="line"><a id="l00958" name="l00958"></a><span class="lineno"> 958</span> </div> +<div class="line"><a id="l00959" name="l00959"></a><span class="lineno"> 959</span><span class="comment">/**********************************************************************/</span></div> +<div class="line"><a id="l00965" name="l00965"></a><span class="lineno"> 965</span>uint32_t __attribute__ ((noinline)) riscv_emulate_fclasss(<span class="keywordtype">float</span> rs1) {</div> +<div class="line"><a id="l00966" name="l00966"></a><span class="lineno"> 966</span> </div> +<div class="line"><a id="l00967" name="l00967"></a><span class="lineno"> 967</span> <span class="keywordtype">float</span> opa = subnormal_flush(rs1);</div> +<div class="line"><a id="l00968" name="l00968"></a><span class="lineno"> 968</span> </div> +<div class="line"><a id="l00969" name="l00969"></a><span class="lineno"> 969</span> <span class="keyword">union </span>{</div> +<div class="line"><a id="l00970" name="l00970"></a><span class="lineno"> 970</span> uint32_t binary_value; </div> +<div class="line"><a id="l00971" name="l00971"></a><span class="lineno"> 971</span> <span class="keywordtype">float</span> float_value; </div> +<div class="line"><a id="l00972" name="l00972"></a><span class="lineno"> 972</span> } aux;</div> +<div class="line"><a id="l00973" name="l00973"></a><span class="lineno"> 973</span> </div> +<div class="line"><a id="l00974" name="l00974"></a><span class="lineno"> 974</span> <span class="comment">// RISC-V classify result layout</span></div> +<div class="line"><a id="l00975" name="l00975"></a><span class="lineno"> 975</span> <span class="keyword">const</span> uint32_t CLASS_NEG_INF = 1 &lt;&lt; 0; <span class="comment">// negative infinity</span></div> +<div class="line"><a id="l00976" name="l00976"></a><span class="lineno"> 976</span> <span class="keyword">const</span> uint32_t CLASS_NEG_NORM = 1 &lt;&lt; 1; <span class="comment">// negative normal number</span></div> +<div class="line"><a id="l00977" name="l00977"></a><span class="lineno"> 977</span> <span class="keyword">const</span> uint32_t CLASS_NEG_DENORM = 1 &lt;&lt; 2; <span class="comment">// negative subnormal number</span></div> +<div class="line"><a id="l00978" name="l00978"></a><span class="lineno"> 978</span> <span class="keyword">const</span> uint32_t CLASS_NEG_ZERO = 1 &lt;&lt; 3; <span class="comment">// negative zero</span></div> +<div class="line"><a id="l00979" name="l00979"></a><span class="lineno"> 979</span> <span class="keyword">const</span> uint32_t CLASS_POS_ZERO = 1 &lt;&lt; 4; <span class="comment">// positive zero</span></div> +<div class="line"><a id="l00980" name="l00980"></a><span class="lineno"> 980</span> <span class="keyword">const</span> uint32_t CLASS_POS_DENORM = 1 &lt;&lt; 5; <span class="comment">// positive subnormal number</span></div> +<div class="line"><a id="l00981" name="l00981"></a><span class="lineno"> 981</span> <span class="keyword">const</span> uint32_t CLASS_POS_NORM = 1 &lt;&lt; 6; <span class="comment">// positive normal number</span></div> +<div class="line"><a id="l00982" name="l00982"></a><span class="lineno"> 982</span> <span class="keyword">const</span> uint32_t CLASS_POS_INF = 1 &lt;&lt; 7; <span class="comment">// positive infinity</span></div> +<div class="line"><a id="l00983" name="l00983"></a><span class="lineno"> 983</span> <span class="keyword">const</span> uint32_t CLASS_SNAN = 1 &lt;&lt; 8; <span class="comment">// signaling NaN (sNaN)</span></div> +<div class="line"><a id="l00984" name="l00984"></a><span class="lineno"> 984</span> <span class="keyword">const</span> uint32_t CLASS_QNAN = 1 &lt;&lt; 9; <span class="comment">// quiet NaN (qNaN)</span></div> +<div class="line"><a id="l00985" name="l00985"></a><span class="lineno"> 985</span> </div> +<div class="line"><a id="l00986" name="l00986"></a><span class="lineno"> 986</span> <span class="keywordtype">int</span> tmp = fpclassify(opa);</div> +<div class="line"><a id="l00987" name="l00987"></a><span class="lineno"> 987</span> <span class="keywordtype">int</span> sgn = (int)signbit(opa);</div> +<div class="line"><a id="l00988" name="l00988"></a><span class="lineno"> 988</span> </div> +<div class="line"><a id="l00989" name="l00989"></a><span class="lineno"> 989</span> uint32_t res = 0;</div> +<div class="line"><a id="l00990" name="l00990"></a><span class="lineno"> 990</span> </div> +<div class="line"><a id="l00991" name="l00991"></a><span class="lineno"> 991</span> <span class="comment">// infinity</span></div> +<div class="line"><a id="l00992" name="l00992"></a><span class="lineno"> 992</span> <span class="keywordflow">if</span> (tmp == FP_INFINITE) {</div> +<div class="line"><a id="l00993" name="l00993"></a><span class="lineno"> 993</span> <span class="keywordflow">if</span> (sgn) { res |= CLASS_NEG_INF; }</div> +<div class="line"><a id="l00994" name="l00994"></a><span class="lineno"> 994</span> <span class="keywordflow">else</span> { res |= CLASS_POS_INF; }</div> +<div class="line"><a id="l00995" name="l00995"></a><span class="lineno"> 995</span> }</div> +<div class="line"><a id="l00996" name="l00996"></a><span class="lineno"> 996</span> </div> +<div class="line"><a id="l00997" name="l00997"></a><span class="lineno"> 997</span> <span class="comment">// zero</span></div> +<div class="line"><a id="l00998" name="l00998"></a><span class="lineno"> 998</span> <span class="keywordflow">if</span> (tmp == FP_ZERO) {</div> +<div class="line"><a id="l00999" name="l00999"></a><span class="lineno"> 999</span> <span class="keywordflow">if</span> (sgn) { res |= CLASS_NEG_ZERO; }</div> +<div class="line"><a id="l01000" name="l01000"></a><span class="lineno"> 1000</span> <span class="keywordflow">else</span> { res |= CLASS_POS_ZERO; }</div> +<div class="line"><a id="l01001" name="l01001"></a><span class="lineno"> 1001</span> }</div> +<div class="line"><a id="l01002" name="l01002"></a><span class="lineno"> 1002</span> </div> +<div class="line"><a id="l01003" name="l01003"></a><span class="lineno"> 1003</span> <span class="comment">// normal</span></div> +<div class="line"><a id="l01004" name="l01004"></a><span class="lineno"> 1004</span> <span class="keywordflow">if</span> (tmp == FP_NORMAL) {</div> +<div class="line"><a id="l01005" name="l01005"></a><span class="lineno"> 1005</span> <span class="keywordflow">if</span> (sgn) { res |= CLASS_NEG_NORM; }</div> +<div class="line"><a id="l01006" name="l01006"></a><span class="lineno"> 1006</span> <span class="keywordflow">else</span> { res |= CLASS_POS_NORM; }</div> +<div class="line"><a id="l01007" name="l01007"></a><span class="lineno"> 1007</span> }</div> +<div class="line"><a id="l01008" name="l01008"></a><span class="lineno"> 1008</span> </div> +<div class="line"><a id="l01009" name="l01009"></a><span class="lineno"> 1009</span> <span class="comment">// subnormal</span></div> +<div class="line"><a id="l01010" name="l01010"></a><span class="lineno"> 1010</span> <span class="keywordflow">if</span> (tmp == FP_SUBNORMAL) {</div> +<div class="line"><a id="l01011" name="l01011"></a><span class="lineno"> 1011</span> <span class="keywordflow">if</span> (sgn) { res |= CLASS_NEG_DENORM; }</div> +<div class="line"><a id="l01012" name="l01012"></a><span class="lineno"> 1012</span> <span class="keywordflow">else</span> { res |= CLASS_POS_DENORM; }</div> +<div class="line"><a id="l01013" name="l01013"></a><span class="lineno"> 1013</span> }</div> +<div class="line"><a id="l01014" name="l01014"></a><span class="lineno"> 1014</span> </div> +<div class="line"><a id="l01015" name="l01015"></a><span class="lineno"> 1015</span> <span class="comment">// NaN</span></div> +<div class="line"><a id="l01016" name="l01016"></a><span class="lineno"> 1016</span> <span class="keywordflow">if</span> (tmp == FP_NAN) {</div> +<div class="line"><a id="l01017" name="l01017"></a><span class="lineno"> 1017</span> aux.float_value = opa;</div> +<div class="line"><a id="l01018" name="l01018"></a><span class="lineno"> 1018</span> <span class="keywordflow">if</span> ((aux.binary_value &gt;&gt; 22) &amp; 0b1) { <span class="comment">// bit 22 (mantissa&#39;s MSB) is set -&gt; canonical (quiet) NAN</span></div> +<div class="line"><a id="l01019" name="l01019"></a><span class="lineno"> 1019</span> res |= CLASS_QNAN;</div> +<div class="line"><a id="l01020" name="l01020"></a><span class="lineno"> 1020</span> }</div> +<div class="line"><a id="l01021" name="l01021"></a><span class="lineno"> 1021</span> <span class="keywordflow">else</span> {</div> +<div class="line"><a id="l01022" name="l01022"></a><span class="lineno"> 1022</span> res |= CLASS_SNAN;</div> +<div class="line"><a id="l01023" name="l01023"></a><span class="lineno"> 1023</span> }</div> +<div class="line"><a id="l01024" name="l01024"></a><span class="lineno"> 1024</span> }</div> +<div class="line"><a id="l01025" name="l01025"></a><span class="lineno"> 1025</span> </div> +<div class="line"><a id="l01026" name="l01026"></a><span class="lineno"> 1026</span> <span class="keywordflow">return</span> res;</div> +<div class="line"><a id="l01027" name="l01027"></a><span class="lineno"> 1027</span>}</div> +<div class="line"><a id="l01028" name="l01028"></a><span class="lineno"> 1028</span> </div> +<div class="line"><a id="l01029" name="l01029"></a><span class="lineno"> 1029</span> </div> +<div class="line"><a id="l01030" name="l01030"></a><span class="lineno"> 1030</span><span class="comment">/**********************************************************************/</span></div> +<div class="line"><a id="l01037" name="l01037"></a><span class="lineno"> 1037</span><span class="keywordtype">float</span> __attribute__ ((noinline)) riscv_emulate_fdivs(<span class="keywordtype">float</span> rs1, <span class="keywordtype">float</span> rs2) {</div> +<div class="line"><a id="l01038" name="l01038"></a><span class="lineno"> 1038</span> </div> +<div class="line"><a id="l01039" name="l01039"></a><span class="lineno"> 1039</span> <span class="keywordtype">float</span> opa = subnormal_flush(rs1);</div> +<div class="line"><a id="l01040" name="l01040"></a><span class="lineno"> 1040</span> <span class="keywordtype">float</span> opb = subnormal_flush(rs2);</div> +<div class="line"><a id="l01041" name="l01041"></a><span class="lineno"> 1041</span> </div> +<div class="line"><a id="l01042" name="l01042"></a><span class="lineno"> 1042</span> <span class="keywordtype">float</span> res = opa / opb;</div> +<div class="line"><a id="l01043" name="l01043"></a><span class="lineno"> 1043</span> <span class="keywordflow">return</span> subnormal_flush(res);</div> +<div class="line"><a id="l01044" name="l01044"></a><span class="lineno"> 1044</span>}</div> +<div class="line"><a id="l01045" name="l01045"></a><span class="lineno"> 1045</span> </div> +<div class="line"><a id="l01046" name="l01046"></a><span class="lineno"> 1046</span> </div> +<div class="line"><a id="l01047" name="l01047"></a><span class="lineno"> 1047</span><span class="comment">/**********************************************************************/</span></div> +<div class="line"><a id="l01053" name="l01053"></a><span class="lineno"> 1053</span><span class="keywordtype">float</span> __attribute__ ((noinline)) riscv_emulate_fsqrts(<span class="keywordtype">float</span> rs1) {</div> +<div class="line"><a id="l01054" name="l01054"></a><span class="lineno"> 1054</span> </div> +<div class="line"><a id="l01055" name="l01055"></a><span class="lineno"> 1055</span> <span class="keywordtype">float</span> opa = subnormal_flush(rs1);</div> +<div class="line"><a id="l01056" name="l01056"></a><span class="lineno"> 1056</span> </div> +<div class="line"><a id="l01057" name="l01057"></a><span class="lineno"> 1057</span> <span class="keywordtype">float</span> res = sqrtf(opa);</div> +<div class="line"><a id="l01058" name="l01058"></a><span class="lineno"> 1058</span> <span class="keywordflow">return</span> subnormal_flush(res);</div> +<div class="line"><a id="l01059" name="l01059"></a><span class="lineno"> 1059</span>}</div> +<div class="line"><a id="l01060" name="l01060"></a><span class="lineno"> 1060</span> </div> +<div class="line"><a id="l01061" name="l01061"></a><span class="lineno"> 1061</span> </div> +<div class="line"><a id="l01062" name="l01062"></a><span class="lineno"> 1062</span><span class="comment">/**********************************************************************/</span></div> +<div class="line"><a id="l01072" name="l01072"></a><span class="lineno"> 1072</span><span class="keywordtype">float</span> __attribute__ ((noinline)) riscv_emulate_fmadds(<span class="keywordtype">float</span> rs1, <span class="keywordtype">float</span> rs2, <span class="keywordtype">float</span> rs3) {</div> +<div class="line"><a id="l01073" name="l01073"></a><span class="lineno"> 1073</span> </div> +<div class="line"><a id="l01074" name="l01074"></a><span class="lineno"> 1074</span> <span class="keywordtype">float</span> opa = subnormal_flush(rs1);</div> +<div class="line"><a id="l01075" name="l01075"></a><span class="lineno"> 1075</span> <span class="keywordtype">float</span> opb = subnormal_flush(rs2);</div> +<div class="line"><a id="l01076" name="l01076"></a><span class="lineno"> 1076</span> <span class="keywordtype">float</span> opc = subnormal_flush(rs3);</div> +<div class="line"><a id="l01077" name="l01077"></a><span class="lineno"> 1077</span> </div> +<div class="line"><a id="l01078" name="l01078"></a><span class="lineno"> 1078</span> <span class="keywordtype">float</span> res = (opa * opb) + opc;</div> +<div class="line"><a id="l01079" name="l01079"></a><span class="lineno"> 1079</span> <span class="keywordflow">return</span> subnormal_flush(res);</div> +<div class="line"><a id="l01080" name="l01080"></a><span class="lineno"> 1080</span>}</div> +<div class="line"><a id="l01081" name="l01081"></a><span class="lineno"> 1081</span> </div> +<div class="line"><a id="l01082" name="l01082"></a><span class="lineno"> 1082</span> </div> +<div class="line"><a id="l01083" name="l01083"></a><span class="lineno"> 1083</span><span class="comment">/**********************************************************************/</span></div> +<div class="line"><a id="l01091" name="l01091"></a><span class="lineno"> 1091</span><span class="keywordtype">float</span> __attribute__ ((noinline)) riscv_emulate_fmsubs(<span class="keywordtype">float</span> rs1, <span class="keywordtype">float</span> rs2, <span class="keywordtype">float</span> rs3) {</div> +<div class="line"><a id="l01092" name="l01092"></a><span class="lineno"> 1092</span> </div> +<div class="line"><a id="l01093" name="l01093"></a><span class="lineno"> 1093</span> <span class="keywordtype">float</span> opa = subnormal_flush(rs1);</div> +<div class="line"><a id="l01094" name="l01094"></a><span class="lineno"> 1094</span> <span class="keywordtype">float</span> opb = subnormal_flush(rs2);</div> +<div class="line"><a id="l01095" name="l01095"></a><span class="lineno"> 1095</span> <span class="keywordtype">float</span> opc = subnormal_flush(rs3);</div> +<div class="line"><a id="l01096" name="l01096"></a><span class="lineno"> 1096</span> </div> +<div class="line"><a id="l01097" name="l01097"></a><span class="lineno"> 1097</span> <span class="keywordtype">float</span> res = (opa * opb) - opc;</div> +<div class="line"><a id="l01098" name="l01098"></a><span class="lineno"> 1098</span> <span class="keywordflow">return</span> subnormal_flush(res);</div> +<div class="line"><a id="l01099" name="l01099"></a><span class="lineno"> 1099</span>}</div> +<div class="line"><a id="l01100" name="l01100"></a><span class="lineno"> 1100</span> </div> +<div class="line"><a id="l01101" name="l01101"></a><span class="lineno"> 1101</span> </div> +<div class="line"><a id="l01102" name="l01102"></a><span class="lineno"> 1102</span><span class="comment">/**********************************************************************/</span></div> +<div class="line"><a id="l01110" name="l01110"></a><span class="lineno"> 1110</span><span class="keywordtype">float</span> __attribute__ ((noinline)) riscv_emulate_fnmsubs(<span class="keywordtype">float</span> rs1, <span class="keywordtype">float</span> rs2, <span class="keywordtype">float</span> rs3) {</div> +<div class="line"><a id="l01111" name="l01111"></a><span class="lineno"> 1111</span> </div> +<div class="line"><a id="l01112" name="l01112"></a><span class="lineno"> 1112</span> <span class="keywordtype">float</span> opa = subnormal_flush(rs1);</div> +<div class="line"><a id="l01113" name="l01113"></a><span class="lineno"> 1113</span> <span class="keywordtype">float</span> opb = subnormal_flush(rs2);</div> +<div class="line"><a id="l01114" name="l01114"></a><span class="lineno"> 1114</span> <span class="keywordtype">float</span> opc = subnormal_flush(rs3);</div> +<div class="line"><a id="l01115" name="l01115"></a><span class="lineno"> 1115</span> </div> +<div class="line"><a id="l01116" name="l01116"></a><span class="lineno"> 1116</span> <span class="keywordtype">float</span> res = -(opa * opb) + opc;</div> +<div class="line"><a id="l01117" name="l01117"></a><span class="lineno"> 1117</span> <span class="keywordflow">return</span> subnormal_flush(res);</div> +<div class="line"><a id="l01118" name="l01118"></a><span class="lineno"> 1118</span>}</div> +<div class="line"><a id="l01119" name="l01119"></a><span class="lineno"> 1119</span> </div> +<div class="line"><a id="l01120" name="l01120"></a><span class="lineno"> 1120</span> </div> +<div class="line"><a id="l01121" name="l01121"></a><span class="lineno"> 1121</span><span class="comment">/**********************************************************************/</span></div> +<div class="line"><a id="l01129" name="l01129"></a><span class="lineno"> 1129</span><span class="keywordtype">float</span> __attribute__ ((noinline)) riscv_emulate_fnmadds(<span class="keywordtype">float</span> rs1, <span class="keywordtype">float</span> rs2, <span class="keywordtype">float</span> rs3) {</div> +<div class="line"><a id="l01130" name="l01130"></a><span class="lineno"> 1130</span> </div> +<div class="line"><a id="l01131" name="l01131"></a><span class="lineno"> 1131</span> <span class="keywordtype">float</span> opa = subnormal_flush(rs1);</div> +<div class="line"><a id="l01132" name="l01132"></a><span class="lineno"> 1132</span> <span class="keywordtype">float</span> opb = subnormal_flush(rs2);</div> +<div class="line"><a id="l01133" name="l01133"></a><span class="lineno"> 1133</span> <span class="keywordtype">float</span> opc = subnormal_flush(rs3);</div> +<div class="line"><a id="l01134" name="l01134"></a><span class="lineno"> 1134</span> </div> +<div class="line"><a id="l01135" name="l01135"></a><span class="lineno"> 1135</span> <span class="keywordtype">float</span> res = -(opa * opb) - opc;</div> +<div class="line"><a id="l01136" name="l01136"></a><span class="lineno"> 1136</span> <span class="keywordflow">return</span> subnormal_flush(res);</div> +<div class="line"><a id="l01137" name="l01137"></a><span class="lineno"> 1137</span>}</div> +<div class="line"><a id="l01138" name="l01138"></a><span class="lineno"> 1138</span> </div> +<div class="line"><a id="l01139" name="l01139"></a><span class="lineno"> 1139</span> </div> +<div class="line"><a id="l01140" name="l01140"></a><span class="lineno"> 1140</span><span class="preprocessor">#endif </span><span class="comment">// neorv32_zfinx_extension_intrinsics_h</span></div> +<div class="line"><a id="l01141" name="l01141"></a><span class="lineno"> 1141</span> </div> +<div class="ttc" id="aneorv32__cpu_8h_html_aab7a9f9cf608599f2b124dd499cb8418"><div class="ttname"><a href="neorv32__cpu_8h.html#aab7a9f9cf608599f2b124dd499cb8418">neorv32_cpu_csr_read</a></div><div class="ttdeci">uint32_t neorv32_cpu_csr_read(const int csr_id)</div><div class="ttdef"><b>Definition</b> neorv32_cpu.h:174</div></div> +<div class="ttc" id="aneorv32__cpu_8h_html_afb5ef6e0b1a3e26570edfd8379490455"><div class="ttname"><a href="neorv32__cpu_8h.html#afb5ef6e0b1a3e26570edfd8379490455">neorv32_cpu_csr_write</a></div><div class="ttdeci">void neorv32_cpu_csr_write(const int csr_id, uint32_t data)</div><div class="ttdef"><b>Definition</b> neorv32_cpu.h:188</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49a625f606c14fd4d7224d7109e10508e7a"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a625f606c14fd4d7224d7109e10508e7a">CSR_FFLAGS</a></div><div class="ttdeci">@ CSR_FFLAGS</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:27</div></div> +<div class="ttc" id="aunionfloat__conv__t_html"><div class="ttname"><a href="unionfloat__conv__t.html">float_conv_t</a></div><div class="ttdef"><b>Definition</b> neorv32_zfinx_extension_intrinsics.h:78</div></div> +<div class="ttc" id="aunionfloat__conv__t_html_a59ad19d41b1d973a6bda9032e1937606"><div class="ttname"><a href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">float_conv_t::binary_value</a></div><div class="ttdeci">uint32_t binary_value</div><div class="ttdef"><b>Definition</b> neorv32_zfinx_extension_intrinsics.h:79</div></div> +<div class="ttc" id="aunionfloat__conv__t_html_a95f2e38b437bd8d4e8de7f61d7474788"><div class="ttname"><a href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_conv_t::float_value</a></div><div class="ttdeci">float float_value</div><div class="ttdef"><b>Definition</b> neorv32_zfinx_extension_intrinsics.h:80</div></div> +</div><!-- fragment --></div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/floating__point__test_2main_8c.html b/sw/floating__point__test_2main_8c.html new file mode 100644 index 0000000000..e3290ca57d --- /dev/null +++ b/sw/floating__point__test_2main_8c.html @@ -0,0 +1,492 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/example/floating_point_test/main.c File Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_f0f9b27afba2e8cc2da6e5fddcc1a8c9.html">example</a></li><li class="navelem"><a class="el" href="dir_e9ffd83269fb7f0c372f5ffbe8545008.html">floating_point_test</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#func-members">Functions</a> </div> + <div class="headertitle"><div class="title">main.c File Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p>Verification program for the NEORV32 'Zfinx' extension (floating-point in x registers) using pseudo-random data as input; compares results from hardware against pure-sw reference functions. +<a href="#details">More...</a></p> +<div class="textblock"><code>#include &lt;<a class="el" href="neorv32_8h_source.html">neorv32.h</a>&gt;</code><br /> +<code>#include &lt;float.h&gt;</code><br /> +<code>#include &lt;math.h&gt;</code><br /> +<code>#include &quot;<a class="el" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h_source.html">neorv32_zfinx_extension_intrinsics.h</a>&quot;</code><br /> +</div><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="define-members" name="define-members"></a> +Macros</h2></td></tr> +<tr><td colspan="2"><div class="groupHeader">User configuration</div></td></tr> +<tr class="memitem:ad4455691936f92fdd6c37566fc58ba1f" id="r_ad4455691936f92fdd6c37566fc58ba1f"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ad4455691936f92fdd6c37566fc58ba1f">BAUD_RATE</a>&#160;&#160;&#160;(19200)</td></tr> +<tr class="separator:ad4455691936f92fdd6c37566fc58ba1f"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a83792c34853f1d2801b59ad46adc7e1e" id="r_a83792c34853f1d2801b59ad46adc7e1e"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a83792c34853f1d2801b59ad46adc7e1e">NUM_TEST_CASES</a>&#160;&#160;&#160;(1000000)</td></tr> +<tr class="separator:a83792c34853f1d2801b59ad46adc7e1e"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a87f296d7594bb8178cf76f0c045b7013" id="r_a87f296d7594bb8178cf76f0c045b7013"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a87f296d7594bb8178cf76f0c045b7013">SILENT_MODE</a>&#160;&#160;&#160;(1)</td></tr> +<tr class="separator:a87f296d7594bb8178cf76f0c045b7013"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a7ec330b668b5b24d666d7769ccecfee3" id="r_a7ec330b668b5b24d666d7769ccecfee3"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a7ec330b668b5b24d666d7769ccecfee3">RUN_CSR_TESTS</a>&#160;&#160;&#160;(1)</td></tr> +<tr class="separator:a7ec330b668b5b24d666d7769ccecfee3"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a1a1af220e72c69b03d13b2df53650e10" id="r_a1a1af220e72c69b03d13b2df53650e10"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a1a1af220e72c69b03d13b2df53650e10">RUN_EXC_TESTS</a>&#160;&#160;&#160;(1)</td></tr> +<tr class="separator:a1a1af220e72c69b03d13b2df53650e10"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aa3b6c4d49be7372de9e771a0475306ac" id="r_aa3b6c4d49be7372de9e771a0475306ac"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aa3b6c4d49be7372de9e771a0475306ac">RUN_CONV_TESTS</a>&#160;&#160;&#160;(1)</td></tr> +<tr class="separator:aa3b6c4d49be7372de9e771a0475306ac"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a2d16b9e484b7af7897c7ae83f945ceca" id="r_a2d16b9e484b7af7897c7ae83f945ceca"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a2d16b9e484b7af7897c7ae83f945ceca">RUN_ADDSUB_TESTS</a>&#160;&#160;&#160;(1)</td></tr> +<tr class="separator:a2d16b9e484b7af7897c7ae83f945ceca"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a97323ecaf1ae85e68a736b06bc3b58f8" id="r_a97323ecaf1ae85e68a736b06bc3b58f8"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a97323ecaf1ae85e68a736b06bc3b58f8">RUN_MUL_TESTS</a>&#160;&#160;&#160;(1)</td></tr> +<tr class="separator:a97323ecaf1ae85e68a736b06bc3b58f8"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aed386f612417aeeeac8b08db27d515e4" id="r_aed386f612417aeeeac8b08db27d515e4"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aed386f612417aeeeac8b08db27d515e4">RUN_MINMAX_TESTS</a>&#160;&#160;&#160;(1)</td></tr> +<tr class="separator:aed386f612417aeeeac8b08db27d515e4"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a4ee0f6d28896a97d2c0cad866e77b874" id="r_a4ee0f6d28896a97d2c0cad866e77b874"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a4ee0f6d28896a97d2c0cad866e77b874">RUN_COMPARE_TESTS</a>&#160;&#160;&#160;(1)</td></tr> +<tr class="separator:a4ee0f6d28896a97d2c0cad866e77b874"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a94f0b0908f48f383145ed61ef8eb0713" id="r_a94f0b0908f48f383145ed61ef8eb0713"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a94f0b0908f48f383145ed61ef8eb0713">RUN_SGNINJ_TESTS</a>&#160;&#160;&#160;(1)</td></tr> +<tr class="separator:a94f0b0908f48f383145ed61ef8eb0713"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a7e134923925fa24fd1090281c3a416c3" id="r_a7e134923925fa24fd1090281c3a416c3"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a7e134923925fa24fd1090281c3a416c3">RUN_CLASSIFY_TESTS</a>&#160;&#160;&#160;(1)</td></tr> +<tr class="separator:a7e134923925fa24fd1090281c3a416c3"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a923de9c3e55322d85522740c0d0ff867" id="r_a923de9c3e55322d85522740c0d0ff867"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a923de9c3e55322d85522740c0d0ff867">RUN_UNAVAIL_TESTS</a>&#160;&#160;&#160;(1)</td></tr> +<tr class="separator:a923de9c3e55322d85522740c0d0ff867"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a6969308bd3633928893a2666f1df66fc" id="r_a6969308bd3633928893a2666f1df66fc"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a6969308bd3633928893a2666f1df66fc">RUN_TIMING_TESTS</a>&#160;&#160;&#160;(0)</td></tr> +<tr class="separator:a6969308bd3633928893a2666f1df66fc"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr><td colspan="2"><div class="groupHeader">Special floating-point encodings</div></td></tr> +<tr class="memitem:a1d43b83ff6bc32390f33da19567e5e43" id="r_a1d43b83ff6bc32390f33da19567e5e43"><td class="memItemLeft" align="right" valign="top"><a id="a1d43b83ff6bc32390f33da19567e5e43" name="a1d43b83ff6bc32390f33da19567e5e43"></a> +#define&#160;</td><td class="memItemRight" valign="bottom"><b>FLOAT32_SNAN</b>&#160;&#160;&#160;( (uint32_t)(0x7fa00000U) )</td></tr> +<tr class="separator:a1d43b83ff6bc32390f33da19567e5e43"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a45c163e2a1825fbcbf094edd8e6612cd" id="r_a45c163e2a1825fbcbf094edd8e6612cd"><td class="memItemLeft" align="right" valign="top"><a id="a45c163e2a1825fbcbf094edd8e6612cd" name="a45c163e2a1825fbcbf094edd8e6612cd"></a> +#define&#160;</td><td class="memItemRight" valign="bottom"><b>FLOAT32_PMIN</b>&#160;&#160;&#160;( (uint32_t)(0x00800000U) )</td></tr> +<tr class="separator:a45c163e2a1825fbcbf094edd8e6612cd"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a70a69778e78bc867439bc030e665d3c1" id="r_a70a69778e78bc867439bc030e665d3c1"><td class="memItemLeft" align="right" valign="top"><a id="a70a69778e78bc867439bc030e665d3c1" name="a70a69778e78bc867439bc030e665d3c1"></a> +#define&#160;</td><td class="memItemRight" valign="bottom"><b>FLOAT32_PMAX</b>&#160;&#160;&#160;( (uint32_t)(0x7f7fffffU) )</td></tr> +<tr class="separator:a70a69778e78bc867439bc030e665d3c1"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="func-members" name="func-members"></a> +Functions</h2></td></tr> +<tr class="memitem:a73c70bd0fb6d695cb113eaeb50923e3e" id="r_a73c70bd0fb6d695cb113eaeb50923e3e"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a73c70bd0fb6d695cb113eaeb50923e3e">get_test_vector</a> (void)</td></tr> +<tr class="separator:a73c70bd0fb6d695cb113eaeb50923e3e"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a941ef8d24fd8e8fe4536626b2ce72410" id="r_a941ef8d24fd8e8fe4536626b2ce72410"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a941ef8d24fd8e8fe4536626b2ce72410">verify_result</a> (uint32_t num, uint32_t opa, uint32_t opb, uint32_t ref, uint32_t res)</td></tr> +<tr class="separator:a941ef8d24fd8e8fe4536626b2ce72410"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a1740720aa8ce1a30fcf642be9140d203" id="r_a1740720aa8ce1a30fcf642be9140d203"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a1740720aa8ce1a30fcf642be9140d203">print_report</a> (uint32_t num_err)</td></tr> +<tr class="separator:a1740720aa8ce1a30fcf642be9140d203"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ae66f6b31b5ad750f1fe042a706a4e3d4" id="r_ae66f6b31b5ad750f1fe042a706a4e3d4"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ae66f6b31b5ad750f1fe042a706a4e3d4">main</a> ()</td></tr> +<tr class="separator:ae66f6b31b5ad750f1fe042a706a4e3d4"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>Verification program for the NEORV32 'Zfinx' extension (floating-point in x registers) using pseudo-random data as input; compares results from hardware against pure-sw reference functions. </p> +<dl class="section author"><dt>Author</dt><dd>Stephan Nolting </dd></dl> +</div><h2 class="groupheader">Macro Definition Documentation</h2> +<a id="ad4455691936f92fdd6c37566fc58ba1f" name="ad4455691936f92fdd6c37566fc58ba1f"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ad4455691936f92fdd6c37566fc58ba1f">&#9670;&#160;</a></span>BAUD_RATE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define BAUD_RATE&#160;&#160;&#160;(19200)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>UART BAUD rate </p> + +</div> +</div> +<a id="a83792c34853f1d2801b59ad46adc7e1e" name="a83792c34853f1d2801b59ad46adc7e1e"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a83792c34853f1d2801b59ad46adc7e1e">&#9670;&#160;</a></span>NUM_TEST_CASES</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define NUM_TEST_CASES&#160;&#160;&#160;(1000000)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>UART BAUD rate </p> + +</div> +</div> +<a id="a2d16b9e484b7af7897c7ae83f945ceca" name="a2d16b9e484b7af7897c7ae83f945ceca"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a2d16b9e484b7af7897c7ae83f945ceca">&#9670;&#160;</a></span>RUN_ADDSUB_TESTS</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define RUN_ADDSUB_TESTS&#160;&#160;&#160;(1)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>UART BAUD rate </p> + +</div> +</div> +<a id="a7e134923925fa24fd1090281c3a416c3" name="a7e134923925fa24fd1090281c3a416c3"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a7e134923925fa24fd1090281c3a416c3">&#9670;&#160;</a></span>RUN_CLASSIFY_TESTS</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define RUN_CLASSIFY_TESTS&#160;&#160;&#160;(1)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>UART BAUD rate </p> + +</div> +</div> +<a id="a4ee0f6d28896a97d2c0cad866e77b874" name="a4ee0f6d28896a97d2c0cad866e77b874"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a4ee0f6d28896a97d2c0cad866e77b874">&#9670;&#160;</a></span>RUN_COMPARE_TESTS</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define RUN_COMPARE_TESTS&#160;&#160;&#160;(1)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>UART BAUD rate </p> + +</div> +</div> +<a id="aa3b6c4d49be7372de9e771a0475306ac" name="aa3b6c4d49be7372de9e771a0475306ac"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aa3b6c4d49be7372de9e771a0475306ac">&#9670;&#160;</a></span>RUN_CONV_TESTS</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define RUN_CONV_TESTS&#160;&#160;&#160;(1)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>UART BAUD rate </p> + +</div> +</div> +<a id="a7ec330b668b5b24d666d7769ccecfee3" name="a7ec330b668b5b24d666d7769ccecfee3"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a7ec330b668b5b24d666d7769ccecfee3">&#9670;&#160;</a></span>RUN_CSR_TESTS</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define RUN_CSR_TESTS&#160;&#160;&#160;(1)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>UART BAUD rate </p> + +</div> +</div> +<a id="a1a1af220e72c69b03d13b2df53650e10" name="a1a1af220e72c69b03d13b2df53650e10"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a1a1af220e72c69b03d13b2df53650e10">&#9670;&#160;</a></span>RUN_EXC_TESTS</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define RUN_EXC_TESTS&#160;&#160;&#160;(1)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>UART BAUD rate </p> + +</div> +</div> +<a id="aed386f612417aeeeac8b08db27d515e4" name="aed386f612417aeeeac8b08db27d515e4"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aed386f612417aeeeac8b08db27d515e4">&#9670;&#160;</a></span>RUN_MINMAX_TESTS</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define RUN_MINMAX_TESTS&#160;&#160;&#160;(1)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>UART BAUD rate </p> + +</div> +</div> +<a id="a97323ecaf1ae85e68a736b06bc3b58f8" name="a97323ecaf1ae85e68a736b06bc3b58f8"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a97323ecaf1ae85e68a736b06bc3b58f8">&#9670;&#160;</a></span>RUN_MUL_TESTS</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define RUN_MUL_TESTS&#160;&#160;&#160;(1)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>UART BAUD rate </p> + +</div> +</div> +<a id="a94f0b0908f48f383145ed61ef8eb0713" name="a94f0b0908f48f383145ed61ef8eb0713"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a94f0b0908f48f383145ed61ef8eb0713">&#9670;&#160;</a></span>RUN_SGNINJ_TESTS</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define RUN_SGNINJ_TESTS&#160;&#160;&#160;(1)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>UART BAUD rate </p> + +</div> +</div> +<a id="a6969308bd3633928893a2666f1df66fc" name="a6969308bd3633928893a2666f1df66fc"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a6969308bd3633928893a2666f1df66fc">&#9670;&#160;</a></span>RUN_TIMING_TESTS</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define RUN_TIMING_TESTS&#160;&#160;&#160;(0)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>UART BAUD rate </p> + +</div> +</div> +<a id="a923de9c3e55322d85522740c0d0ff867" name="a923de9c3e55322d85522740c0d0ff867"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a923de9c3e55322d85522740c0d0ff867">&#9670;&#160;</a></span>RUN_UNAVAIL_TESTS</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define RUN_UNAVAIL_TESTS&#160;&#160;&#160;(1)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>UART BAUD rate </p> + +</div> +</div> +<a id="a87f296d7594bb8178cf76f0c045b7013" name="a87f296d7594bb8178cf76f0c045b7013"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a87f296d7594bb8178cf76f0c045b7013">&#9670;&#160;</a></span>SILENT_MODE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define SILENT_MODE&#160;&#160;&#160;(1)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>UART BAUD rate </p> + +</div> +</div> +<h2 class="groupheader">Function Documentation</h2> +<a id="a73c70bd0fb6d695cb113eaeb50923e3e" name="a73c70bd0fb6d695cb113eaeb50923e3e"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a73c70bd0fb6d695cb113eaeb50923e3e">&#9670;&#160;</a></span>get_test_vector()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t get_test_vector </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Generate 32-bit test data (including special values like INFINITY every now and then).</p> +<dl class="section return"><dt>Returns</dt><dd>Test data (32-bit). </dd></dl> + +</div> +</div> +<a id="ae66f6b31b5ad750f1fe042a706a4e3d4" name="ae66f6b31b5ad750f1fe042a706a4e3d4"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ae66f6b31b5ad750f1fe042a706a4e3d4">&#9670;&#160;</a></span>main()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int main </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Main function; test all available operations of the NEORV32 'Zfinx' extensions using floating-point * hardware intrinsics and software-only reference functions (emulation).</p> +<dl class="section note"><dt>Note</dt><dd>This program requires the Zfinx CPU extension.</dd></dl> +<dl class="section return"><dt>Returns</dt><dd>0 if execution was successful </dd></dl> + +</div> +</div> +<a id="a1740720aa8ce1a30fcf642be9140d203" name="a1740720aa8ce1a30fcf642be9140d203"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a1740720aa8ce1a30fcf642be9140d203">&#9670;&#160;</a></span>print_report()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void print_report </td> + <td>(</td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>num_err</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Print test report.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">num_err</td><td>Number or errors in this test. </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="a941ef8d24fd8e8fe4536626b2ce72410" name="a941ef8d24fd8e8fe4536626b2ce72410"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a941ef8d24fd8e8fe4536626b2ce72410">&#9670;&#160;</a></span>verify_result()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t verify_result </td> + <td>(</td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>num</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>opa</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>opb</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>ref</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>res</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Verify results (software reference vs. actual hardware).</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">num</td><td>Test case number </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">opa</td><td>Operand 1 </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">opb</td><td>Operand 2 </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">ref</td><td>Software reference </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">res</td><td>Actual results from hardware </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>zero if results are equal. </dd></dl> + +</div> +</div> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html b/sw/floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html new file mode 100644 index 0000000000..e74af0d520 --- /dev/null +++ b/sw/floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html @@ -0,0 +1,1744 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/example/floating_point_test/neorv32_zfinx_extension_intrinsics.h File Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_f0f9b27afba2e8cc2da6e5fddcc1a8c9.html">example</a></li><li class="navelem"><a class="el" href="dir_e9ffd83269fb7f0c372f5ffbe8545008.html">floating_point_test</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#nested-classes">Data Structures</a> &#124; +<a href="#define-members">Macros</a> &#124; +<a href="#func-members">Functions</a> </div> + <div class="headertitle"><div class="title">neorv32_zfinx_extension_intrinsics.h File Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p>"Intrinsic" library for the NEORV32 single-precision floating-point in x registers (Zfinx) extension +<a href="#details">More...</a></p> +<div class="textblock"><code>#include &lt;float.h&gt;</code><br /> +<code>#include &lt;math.h&gt;</code><br /> +</div> +<p><a href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h_source.html">Go to the source code of this file.</a></p> +<table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="nested-classes" name="nested-classes"></a> +Data Structures</h2></td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">union &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="unionfloat__conv__t.html">float_conv_t</a></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="func-members" name="func-members"></a> +Functions</h2></td></tr> +<tr class="memitem:a791f880781a1bcea1861471be7d1a851" id="r_a791f880781a1bcea1861471be7d1a851"><td class="memItemLeft" align="right" valign="top">float&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a791f880781a1bcea1861471be7d1a851">subnormal_flush</a> (float tmp)</td></tr> +<tr class="separator:a791f880781a1bcea1861471be7d1a851"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a4b151fcb252fc7b894f247f5af6a1809" id="r_a4b151fcb252fc7b894f247f5af6a1809"><td class="memItemLeft" align="right" valign="top">float&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a4b151fcb252fc7b894f247f5af6a1809">riscv_intrinsic_fadds</a> (float rs1, float rs2)</td></tr> +<tr class="separator:a4b151fcb252fc7b894f247f5af6a1809"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:af8473ba61abab8ae2e3ecbaf22d70e89" id="r_af8473ba61abab8ae2e3ecbaf22d70e89"><td class="memItemLeft" align="right" valign="top">float&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#af8473ba61abab8ae2e3ecbaf22d70e89">riscv_intrinsic_fsubs</a> (float rs1, float rs2)</td></tr> +<tr class="separator:af8473ba61abab8ae2e3ecbaf22d70e89"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a87a106e0d24a3183712e438d2bcbfa2d" id="r_a87a106e0d24a3183712e438d2bcbfa2d"><td class="memItemLeft" align="right" valign="top">float&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a87a106e0d24a3183712e438d2bcbfa2d">riscv_intrinsic_fmuls</a> (float rs1, float rs2)</td></tr> +<tr class="separator:a87a106e0d24a3183712e438d2bcbfa2d"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:abf7f9e466906306d9755fd5bc7946e3c" id="r_abf7f9e466906306d9755fd5bc7946e3c"><td class="memItemLeft" align="right" valign="top">float&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#abf7f9e466906306d9755fd5bc7946e3c">riscv_intrinsic_fmins</a> (float rs1, float rs2)</td></tr> +<tr class="separator:abf7f9e466906306d9755fd5bc7946e3c"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a87c1ce499e5e43554cb0f407cf0d3f7f" id="r_a87c1ce499e5e43554cb0f407cf0d3f7f"><td class="memItemLeft" align="right" valign="top">float&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a87c1ce499e5e43554cb0f407cf0d3f7f">riscv_intrinsic_fmaxs</a> (float rs1, float rs2)</td></tr> +<tr class="separator:a87c1ce499e5e43554cb0f407cf0d3f7f"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a3bc6ee3059a7e99b187c4ea5e217715b" id="r_a3bc6ee3059a7e99b187c4ea5e217715b"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a3bc6ee3059a7e99b187c4ea5e217715b">riscv_intrinsic_fcvt_wus</a> (float rs1)</td></tr> +<tr class="separator:a3bc6ee3059a7e99b187c4ea5e217715b"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a523fa0fb6f521311c7f44692c586b3ee" id="r_a523fa0fb6f521311c7f44692c586b3ee"><td class="memItemLeft" align="right" valign="top">int32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a523fa0fb6f521311c7f44692c586b3ee">riscv_intrinsic_fcvt_ws</a> (float rs1)</td></tr> +<tr class="separator:a523fa0fb6f521311c7f44692c586b3ee"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a837b7330f9d568791687ae1384b8ef28" id="r_a837b7330f9d568791687ae1384b8ef28"><td class="memItemLeft" align="right" valign="top">float&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a837b7330f9d568791687ae1384b8ef28">riscv_intrinsic_fcvt_swu</a> (uint32_t rs1)</td></tr> +<tr class="separator:a837b7330f9d568791687ae1384b8ef28"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a2103eb86052f6f8e24a8a848ffc6528a" id="r_a2103eb86052f6f8e24a8a848ffc6528a"><td class="memItemLeft" align="right" valign="top">float&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a2103eb86052f6f8e24a8a848ffc6528a">riscv_intrinsic_fcvt_sw</a> (int32_t rs1)</td></tr> +<tr class="separator:a2103eb86052f6f8e24a8a848ffc6528a"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:af4ddfae45807d4e41f758672ee14cf7b" id="r_af4ddfae45807d4e41f758672ee14cf7b"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#af4ddfae45807d4e41f758672ee14cf7b">riscv_intrinsic_feqs</a> (float rs1, float rs2)</td></tr> +<tr class="separator:af4ddfae45807d4e41f758672ee14cf7b"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a85aa18294a58997db2c324184196669c" id="r_a85aa18294a58997db2c324184196669c"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a85aa18294a58997db2c324184196669c">riscv_intrinsic_flts</a> (float rs1, float rs2)</td></tr> +<tr class="separator:a85aa18294a58997db2c324184196669c"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:adb83fab39d91e9291da2b7b07830cf82" id="r_adb83fab39d91e9291da2b7b07830cf82"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#adb83fab39d91e9291da2b7b07830cf82">riscv_intrinsic_fles</a> (float rs1, float rs2)</td></tr> +<tr class="separator:adb83fab39d91e9291da2b7b07830cf82"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aff3acd90bcfbda96945f95a0e0bae12b" id="r_aff3acd90bcfbda96945f95a0e0bae12b"><td class="memItemLeft" align="right" valign="top">float&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aff3acd90bcfbda96945f95a0e0bae12b">riscv_intrinsic_fsgnjs</a> (float rs1, float rs2)</td></tr> +<tr class="separator:aff3acd90bcfbda96945f95a0e0bae12b"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aa4010772a986d03929ba7a43dfdcddd9" id="r_aa4010772a986d03929ba7a43dfdcddd9"><td class="memItemLeft" align="right" valign="top">float&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aa4010772a986d03929ba7a43dfdcddd9">riscv_intrinsic_fsgnjns</a> (float rs1, float rs2)</td></tr> +<tr class="separator:aa4010772a986d03929ba7a43dfdcddd9"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a2235d91cdac03bf8071003a5c59b9dd0" id="r_a2235d91cdac03bf8071003a5c59b9dd0"><td class="memItemLeft" align="right" valign="top">float&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a2235d91cdac03bf8071003a5c59b9dd0">riscv_intrinsic_fsgnjxs</a> (float rs1, float rs2)</td></tr> +<tr class="separator:a2235d91cdac03bf8071003a5c59b9dd0"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a3064a5c57b5f45d57c4d19eb798724f6" id="r_a3064a5c57b5f45d57c4d19eb798724f6"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a3064a5c57b5f45d57c4d19eb798724f6">riscv_intrinsic_fclasss</a> (float rs1)</td></tr> +<tr class="separator:a3064a5c57b5f45d57c4d19eb798724f6"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ab6a9d15643e3085ff80c7883f183a42b" id="r_ab6a9d15643e3085ff80c7883f183a42b"><td class="memItemLeft" align="right" valign="top">float&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ab6a9d15643e3085ff80c7883f183a42b">riscv_intrinsic_fdivs</a> (float rs1, float rs2)</td></tr> +<tr class="separator:ab6a9d15643e3085ff80c7883f183a42b"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a17e2b7a399c956d548a609185084ea3c" id="r_a17e2b7a399c956d548a609185084ea3c"><td class="memItemLeft" align="right" valign="top">float&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a17e2b7a399c956d548a609185084ea3c">riscv_intrinsic_fsqrts</a> (float rs1)</td></tr> +<tr class="separator:a17e2b7a399c956d548a609185084ea3c"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:abbdb403cdeef414fa2f867b702d5f6eb" id="r_abbdb403cdeef414fa2f867b702d5f6eb"><td class="memItemLeft" align="right" valign="top">float&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#abbdb403cdeef414fa2f867b702d5f6eb">riscv_intrinsic_fmadds</a> (float rs1, float rs2, float rs3)</td></tr> +<tr class="separator:abbdb403cdeef414fa2f867b702d5f6eb"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a03aba9c70c5286dacebaeb0ef5219cc9" id="r_a03aba9c70c5286dacebaeb0ef5219cc9"><td class="memItemLeft" align="right" valign="top">float&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a03aba9c70c5286dacebaeb0ef5219cc9">riscv_intrinsic_fmsubs</a> (float rs1, float rs2, float rs3)</td></tr> +<tr class="separator:a03aba9c70c5286dacebaeb0ef5219cc9"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a639fc7bd75933888540e9cceb67221a0" id="r_a639fc7bd75933888540e9cceb67221a0"><td class="memItemLeft" align="right" valign="top">float&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a639fc7bd75933888540e9cceb67221a0">riscv_intrinsic_fnmsubs</a> (float rs1, float rs2, float rs3)</td></tr> +<tr class="separator:a639fc7bd75933888540e9cceb67221a0"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aa6473bc2d2721b57277b83a3ae0cfdb6" id="r_aa6473bc2d2721b57277b83a3ae0cfdb6"><td class="memItemLeft" align="right" valign="top">float&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aa6473bc2d2721b57277b83a3ae0cfdb6">riscv_intrinsic_fnmadds</a> (float rs1, float rs2, float rs3)</td></tr> +<tr class="separator:aa6473bc2d2721b57277b83a3ae0cfdb6"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a9d676567276439875c9b1a15b892b555" id="r_a9d676567276439875c9b1a15b892b555"><td class="memItemLeft" align="right" valign="top">float&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a9d676567276439875c9b1a15b892b555">riscv_emulate_fadds</a> (float rs1, float rs2)</td></tr> +<tr class="separator:a9d676567276439875c9b1a15b892b555"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ace5d95b855ec1aa8eacdb5bbeea58197" id="r_ace5d95b855ec1aa8eacdb5bbeea58197"><td class="memItemLeft" align="right" valign="top">float&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ace5d95b855ec1aa8eacdb5bbeea58197">riscv_emulate_fsubs</a> (float rs1, float rs2)</td></tr> +<tr class="separator:ace5d95b855ec1aa8eacdb5bbeea58197"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ad43e8bdf4a6fbe229d22d24680f2be80" id="r_ad43e8bdf4a6fbe229d22d24680f2be80"><td class="memItemLeft" align="right" valign="top">float&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ad43e8bdf4a6fbe229d22d24680f2be80">riscv_emulate_fmuls</a> (float rs1, float rs2)</td></tr> +<tr class="separator:ad43e8bdf4a6fbe229d22d24680f2be80"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a872cd30fb61190bd1ac719d25b01f5a3" id="r_a872cd30fb61190bd1ac719d25b01f5a3"><td class="memItemLeft" align="right" valign="top">float&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a872cd30fb61190bd1ac719d25b01f5a3">riscv_emulate_fmins</a> (float rs1, float rs2)</td></tr> +<tr class="separator:a872cd30fb61190bd1ac719d25b01f5a3"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:af9b16a32d2bb13c8af5a678271d74889" id="r_af9b16a32d2bb13c8af5a678271d74889"><td class="memItemLeft" align="right" valign="top">float&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#af9b16a32d2bb13c8af5a678271d74889">riscv_emulate_fmaxs</a> (float rs1, float rs2)</td></tr> +<tr class="separator:af9b16a32d2bb13c8af5a678271d74889"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aad9fc7337e09081cf8c5bff8c28776c8" id="r_aad9fc7337e09081cf8c5bff8c28776c8"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aad9fc7337e09081cf8c5bff8c28776c8">riscv_emulate_fcvt_wus</a> (float rs1)</td></tr> +<tr class="separator:aad9fc7337e09081cf8c5bff8c28776c8"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a292365fe41a7a661e61ae746306ba5e9" id="r_a292365fe41a7a661e61ae746306ba5e9"><td class="memItemLeft" align="right" valign="top">int32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a292365fe41a7a661e61ae746306ba5e9">riscv_emulate_fcvt_ws</a> (float rs1)</td></tr> +<tr class="separator:a292365fe41a7a661e61ae746306ba5e9"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a10a05bface37bff32c78ed0746845794" id="r_a10a05bface37bff32c78ed0746845794"><td class="memItemLeft" align="right" valign="top">float&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a10a05bface37bff32c78ed0746845794">riscv_emulate_fcvt_swu</a> (uint32_t rs1)</td></tr> +<tr class="separator:a10a05bface37bff32c78ed0746845794"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a0f2260b7b5793a95c49670379fc89617" id="r_a0f2260b7b5793a95c49670379fc89617"><td class="memItemLeft" align="right" valign="top">float&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a0f2260b7b5793a95c49670379fc89617">riscv_emulate_fcvt_sw</a> (int32_t rs1)</td></tr> +<tr class="separator:a0f2260b7b5793a95c49670379fc89617"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a7cb3c6570b911cd1dfb7b6e798cc1d21" id="r_a7cb3c6570b911cd1dfb7b6e798cc1d21"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a7cb3c6570b911cd1dfb7b6e798cc1d21">riscv_emulate_feqs</a> (float rs1, float rs2)</td></tr> +<tr class="separator:a7cb3c6570b911cd1dfb7b6e798cc1d21"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a2b802122d53a2ce517b3d39fec34d7e0" id="r_a2b802122d53a2ce517b3d39fec34d7e0"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a2b802122d53a2ce517b3d39fec34d7e0">riscv_emulate_flts</a> (float rs1, float rs2)</td></tr> +<tr class="separator:a2b802122d53a2ce517b3d39fec34d7e0"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ac5fdef0607602fa0bdb93b3535fd709e" id="r_ac5fdef0607602fa0bdb93b3535fd709e"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ac5fdef0607602fa0bdb93b3535fd709e">riscv_emulate_fles</a> (float rs1, float rs2)</td></tr> +<tr class="separator:ac5fdef0607602fa0bdb93b3535fd709e"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a12498d635f422f607b9b83facf3050dd" id="r_a12498d635f422f607b9b83facf3050dd"><td class="memItemLeft" align="right" valign="top">float&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a12498d635f422f607b9b83facf3050dd">riscv_emulate_fsgnjs</a> (float rs1, float rs2)</td></tr> +<tr class="separator:a12498d635f422f607b9b83facf3050dd"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a0c985e626ed1d69314f4e3a0f1f58624" id="r_a0c985e626ed1d69314f4e3a0f1f58624"><td class="memItemLeft" align="right" valign="top">float&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a0c985e626ed1d69314f4e3a0f1f58624">riscv_emulate_fsgnjns</a> (float rs1, float rs2)</td></tr> +<tr class="separator:a0c985e626ed1d69314f4e3a0f1f58624"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a98caf7f310820052ae96ce0f45e6cd26" id="r_a98caf7f310820052ae96ce0f45e6cd26"><td class="memItemLeft" align="right" valign="top">float&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a98caf7f310820052ae96ce0f45e6cd26">riscv_emulate_fsgnjxs</a> (float rs1, float rs2)</td></tr> +<tr class="separator:a98caf7f310820052ae96ce0f45e6cd26"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ae41a0bf9d28c35f4d6db7177ccf8ee06" id="r_ae41a0bf9d28c35f4d6db7177ccf8ee06"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ae41a0bf9d28c35f4d6db7177ccf8ee06">riscv_emulate_fclasss</a> (float rs1)</td></tr> +<tr class="separator:ae41a0bf9d28c35f4d6db7177ccf8ee06"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aeaf46a17b671278be2bf804159827a40" id="r_aeaf46a17b671278be2bf804159827a40"><td class="memItemLeft" align="right" valign="top">float&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aeaf46a17b671278be2bf804159827a40">riscv_emulate_fdivs</a> (float rs1, float rs2)</td></tr> +<tr class="separator:aeaf46a17b671278be2bf804159827a40"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a1ceb3450f1e5c62d3079cd0e93c03501" id="r_a1ceb3450f1e5c62d3079cd0e93c03501"><td class="memItemLeft" align="right" valign="top">float&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a1ceb3450f1e5c62d3079cd0e93c03501">riscv_emulate_fsqrts</a> (float rs1)</td></tr> +<tr class="separator:a1ceb3450f1e5c62d3079cd0e93c03501"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a39212f2e2bb0f1752092a1732f93edf3" id="r_a39212f2e2bb0f1752092a1732f93edf3"><td class="memItemLeft" align="right" valign="top">float&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a39212f2e2bb0f1752092a1732f93edf3">riscv_emulate_fmadds</a> (float rs1, float rs2, float rs3)</td></tr> +<tr class="separator:a39212f2e2bb0f1752092a1732f93edf3"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a05d0d5a8eb9422e93448efdeb679cabf" id="r_a05d0d5a8eb9422e93448efdeb679cabf"><td class="memItemLeft" align="right" valign="top">float&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a05d0d5a8eb9422e93448efdeb679cabf">riscv_emulate_fmsubs</a> (float rs1, float rs2, float rs3)</td></tr> +<tr class="separator:a05d0d5a8eb9422e93448efdeb679cabf"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a833638b346722dfa9d7d5c8d60998ec8" id="r_a833638b346722dfa9d7d5c8d60998ec8"><td class="memItemLeft" align="right" valign="top">float&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a833638b346722dfa9d7d5c8d60998ec8">riscv_emulate_fnmsubs</a> (float rs1, float rs2, float rs3)</td></tr> +<tr class="separator:a833638b346722dfa9d7d5c8d60998ec8"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ac8bb4450b39854ab07839e8f3505361c" id="r_ac8bb4450b39854ab07839e8f3505361c"><td class="memItemLeft" align="right" valign="top">float&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ac8bb4450b39854ab07839e8f3505361c">riscv_emulate_fnmadds</a> (float rs1, float rs2, float rs3)</td></tr> +<tr class="separator:ac8bb4450b39854ab07839e8f3505361c"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>"Intrinsic" library for the NEORV32 single-precision floating-point in x registers (Zfinx) extension </p> +<dl class="section author"><dt>Author</dt><dd>Stephan Nolting</dd></dl> +<p>Also provides emulation functions for all intrinsics (functionality re-built in pure software). The functionality of the emulation</p> +<p>functions is based on the RISC-V floating-point spec.</p> +<dl class="section note"><dt>Note</dt><dd>All operations from this library use the default GCC "round to nearest, ties to even" rounding mode.</dd></dl> +<dl class="section warning"><dt>Warning</dt><dd>This library is just a temporary fall-back until the Zfinx extensions are supported by the upstream RISC-V GCC port. </dd></dl> +</div><h2 class="groupheader">Function Documentation</h2> +<a id="a9d676567276439875c9b1a15b892b555" name="a9d676567276439875c9b1a15b892b555"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a9d676567276439875c9b1a15b892b555">&#9670;&#160;</a></span>riscv_emulate_fadds()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">float riscv_emulate_fadds </td> + <td>(</td> + <td class="paramtype">float</td> <td class="paramname"><span class="paramname"><em>rs1</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">float</td> <td class="paramname"><span class="paramname"><em>rs2</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Single-precision floating-point addition</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">rs1</td><td>Source operand 1. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">rs2</td><td>Source operand 2. </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Result. </dd></dl> + +</div> +</div> +<a id="ae41a0bf9d28c35f4d6db7177ccf8ee06" name="ae41a0bf9d28c35f4d6db7177ccf8ee06"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ae41a0bf9d28c35f4d6db7177ccf8ee06">&#9670;&#160;</a></span>riscv_emulate_fclasss()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t riscv_emulate_fclasss </td> + <td>(</td> + <td class="paramtype">float</td> <td class="paramname"><span class="paramname"><em>rs1</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Single-precision floating-point number classification</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">rs1</td><td>Source operand 1. </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Result. </dd></dl> +<p>&lt; Access as native float</p> +<p>&lt; Access in binary representation</p> + +</div> +</div> +<a id="a0f2260b7b5793a95c49670379fc89617" name="a0f2260b7b5793a95c49670379fc89617"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a0f2260b7b5793a95c49670379fc89617">&#9670;&#160;</a></span>riscv_emulate_fcvt_sw()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">float riscv_emulate_fcvt_sw </td> + <td>(</td> + <td class="paramtype">int32_t</td> <td class="paramname"><span class="paramname"><em>rs1</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Single-precision floating-point signed integer to float</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">rs1</td><td>Source operand 1. </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Result. </dd></dl> + +</div> +</div> +<a id="a10a05bface37bff32c78ed0746845794" name="a10a05bface37bff32c78ed0746845794"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a10a05bface37bff32c78ed0746845794">&#9670;&#160;</a></span>riscv_emulate_fcvt_swu()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">float riscv_emulate_fcvt_swu </td> + <td>(</td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>rs1</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Single-precision floating-point unsigned integer to float</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">rs1</td><td>Source operand 1. </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Result. </dd></dl> + +</div> +</div> +<a id="a292365fe41a7a661e61ae746306ba5e9" name="a292365fe41a7a661e61ae746306ba5e9"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a292365fe41a7a661e61ae746306ba5e9">&#9670;&#160;</a></span>riscv_emulate_fcvt_ws()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int32_t riscv_emulate_fcvt_ws </td> + <td>(</td> + <td class="paramtype">float</td> <td class="paramname"><span class="paramname"><em>rs1</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Single-precision floating-point float to signed integer</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">rs1</td><td>Source operand 1. </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Result. </dd></dl> + +</div> +</div> +<a id="aad9fc7337e09081cf8c5bff8c28776c8" name="aad9fc7337e09081cf8c5bff8c28776c8"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aad9fc7337e09081cf8c5bff8c28776c8">&#9670;&#160;</a></span>riscv_emulate_fcvt_wus()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t riscv_emulate_fcvt_wus </td> + <td>(</td> + <td class="paramtype">float</td> <td class="paramname"><span class="paramname"><em>rs1</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Single-precision floating-point float to unsigned integer</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">rs1</td><td>Source operand 1. </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Result. </dd></dl> + +</div> +</div> +<a id="aeaf46a17b671278be2bf804159827a40" name="aeaf46a17b671278be2bf804159827a40"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aeaf46a17b671278be2bf804159827a40">&#9670;&#160;</a></span>riscv_emulate_fdivs()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">float riscv_emulate_fdivs </td> + <td>(</td> + <td class="paramtype">float</td> <td class="paramname"><span class="paramname"><em>rs1</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">float</td> <td class="paramname"><span class="paramname"><em>rs2</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Single-precision floating-point division</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">rs1</td><td>Source operand 1. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">rs2</td><td>Source operand 2. </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Result. </dd></dl> + +</div> +</div> +<a id="a7cb3c6570b911cd1dfb7b6e798cc1d21" name="a7cb3c6570b911cd1dfb7b6e798cc1d21"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a7cb3c6570b911cd1dfb7b6e798cc1d21">&#9670;&#160;</a></span>riscv_emulate_feqs()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t riscv_emulate_feqs </td> + <td>(</td> + <td class="paramtype">float</td> <td class="paramname"><span class="paramname"><em>rs1</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">float</td> <td class="paramname"><span class="paramname"><em>rs2</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Single-precision floating-point equal comparison</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">rs1</td><td>Source operand 1. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">rs2</td><td>Source operand 2. </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Result. </dd></dl> + +</div> +</div> +<a id="ac5fdef0607602fa0bdb93b3535fd709e" name="ac5fdef0607602fa0bdb93b3535fd709e"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ac5fdef0607602fa0bdb93b3535fd709e">&#9670;&#160;</a></span>riscv_emulate_fles()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t riscv_emulate_fles </td> + <td>(</td> + <td class="paramtype">float</td> <td class="paramname"><span class="paramname"><em>rs1</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">float</td> <td class="paramname"><span class="paramname"><em>rs2</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Single-precision floating-point less-than-or-equal comparison</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">rs1</td><td>Source operand 1. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">rs2</td><td>Source operand 2. </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Result. </dd></dl> + +</div> +</div> +<a id="a2b802122d53a2ce517b3d39fec34d7e0" name="a2b802122d53a2ce517b3d39fec34d7e0"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a2b802122d53a2ce517b3d39fec34d7e0">&#9670;&#160;</a></span>riscv_emulate_flts()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t riscv_emulate_flts </td> + <td>(</td> + <td class="paramtype">float</td> <td class="paramname"><span class="paramname"><em>rs1</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">float</td> <td class="paramname"><span class="paramname"><em>rs2</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Single-precision floating-point less-than comparison</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">rs1</td><td>Source operand 1. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">rs2</td><td>Source operand 2. </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Result. </dd></dl> + +</div> +</div> +<a id="a39212f2e2bb0f1752092a1732f93edf3" name="a39212f2e2bb0f1752092a1732f93edf3"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a39212f2e2bb0f1752092a1732f93edf3">&#9670;&#160;</a></span>riscv_emulate_fmadds()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">float riscv_emulate_fmadds </td> + <td>(</td> + <td class="paramtype">float</td> <td class="paramname"><span class="paramname"><em>rs1</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">float</td> <td class="paramname"><span class="paramname"><em>rs2</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">float</td> <td class="paramname"><span class="paramname"><em>rs3</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Single-precision floating-point fused multiply-add</p> +<dl class="section warning"><dt>Warning</dt><dd>This instruction is not supported!</dd></dl> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">rs1</td><td>Source operand 1 </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">rs2</td><td>Source operand 2 </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">rs3</td><td>Source operand 3 </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Result. </dd></dl> + +</div> +</div> +<a id="af9b16a32d2bb13c8af5a678271d74889" name="af9b16a32d2bb13c8af5a678271d74889"></a> +<h2 class="memtitle"><span class="permalink"><a href="#af9b16a32d2bb13c8af5a678271d74889">&#9670;&#160;</a></span>riscv_emulate_fmaxs()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">float riscv_emulate_fmaxs </td> + <td>(</td> + <td class="paramtype">float</td> <td class="paramname"><span class="paramname"><em>rs1</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">float</td> <td class="paramname"><span class="paramname"><em>rs2</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Single-precision floating-point maximum</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">rs1</td><td>Source operand 1. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">rs2</td><td>Source operand 2. </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Result. </dd></dl> +<p>&lt; Access as native float</p> +<p>&lt; Access in binary representation</p> + +</div> +</div> +<a id="a872cd30fb61190bd1ac719d25b01f5a3" name="a872cd30fb61190bd1ac719d25b01f5a3"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a872cd30fb61190bd1ac719d25b01f5a3">&#9670;&#160;</a></span>riscv_emulate_fmins()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">float riscv_emulate_fmins </td> + <td>(</td> + <td class="paramtype">float</td> <td class="paramname"><span class="paramname"><em>rs1</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">float</td> <td class="paramname"><span class="paramname"><em>rs2</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Single-precision floating-point minimum</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">rs1</td><td>Source operand 1. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">rs2</td><td>Source operand 2. </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Result. </dd></dl> +<p>&lt; Access as native float</p> +<p>&lt; Access in binary representation</p> + +</div> +</div> +<a id="a05d0d5a8eb9422e93448efdeb679cabf" name="a05d0d5a8eb9422e93448efdeb679cabf"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a05d0d5a8eb9422e93448efdeb679cabf">&#9670;&#160;</a></span>riscv_emulate_fmsubs()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">float riscv_emulate_fmsubs </td> + <td>(</td> + <td class="paramtype">float</td> <td class="paramname"><span class="paramname"><em>rs1</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">float</td> <td class="paramname"><span class="paramname"><em>rs2</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">float</td> <td class="paramname"><span class="paramname"><em>rs3</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Single-precision floating-point fused multiply-sub</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">rs1</td><td>Source operand 1 </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">rs2</td><td>Source operand 2 </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">rs3</td><td>Source operand 3 </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Result. </dd></dl> + +</div> +</div> +<a id="ad43e8bdf4a6fbe229d22d24680f2be80" name="ad43e8bdf4a6fbe229d22d24680f2be80"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ad43e8bdf4a6fbe229d22d24680f2be80">&#9670;&#160;</a></span>riscv_emulate_fmuls()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">float riscv_emulate_fmuls </td> + <td>(</td> + <td class="paramtype">float</td> <td class="paramname"><span class="paramname"><em>rs1</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">float</td> <td class="paramname"><span class="paramname"><em>rs2</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Single-precision floating-point multiplication</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">rs1</td><td>Source operand 1. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">rs2</td><td>Source operand 2. </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Result. </dd></dl> + +</div> +</div> +<a id="ac8bb4450b39854ab07839e8f3505361c" name="ac8bb4450b39854ab07839e8f3505361c"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ac8bb4450b39854ab07839e8f3505361c">&#9670;&#160;</a></span>riscv_emulate_fnmadds()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">float riscv_emulate_fnmadds </td> + <td>(</td> + <td class="paramtype">float</td> <td class="paramname"><span class="paramname"><em>rs1</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">float</td> <td class="paramname"><span class="paramname"><em>rs2</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">float</td> <td class="paramname"><span class="paramname"><em>rs3</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Single-precision floating-point fused negated multiply-add</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">rs1</td><td>Source operand 1 </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">rs2</td><td>Source operand 2 </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">rs3</td><td>Source operand 3 </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Result. </dd></dl> + +</div> +</div> +<a id="a833638b346722dfa9d7d5c8d60998ec8" name="a833638b346722dfa9d7d5c8d60998ec8"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a833638b346722dfa9d7d5c8d60998ec8">&#9670;&#160;</a></span>riscv_emulate_fnmsubs()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">float riscv_emulate_fnmsubs </td> + <td>(</td> + <td class="paramtype">float</td> <td class="paramname"><span class="paramname"><em>rs1</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">float</td> <td class="paramname"><span class="paramname"><em>rs2</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">float</td> <td class="paramname"><span class="paramname"><em>rs3</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Single-precision floating-point fused negated multiply-sub</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">rs1</td><td>Source operand 1 </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">rs2</td><td>Source operand 2 </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">rs3</td><td>Source operand 3 </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Result. </dd></dl> + +</div> +</div> +<a id="a0c985e626ed1d69314f4e3a0f1f58624" name="a0c985e626ed1d69314f4e3a0f1f58624"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a0c985e626ed1d69314f4e3a0f1f58624">&#9670;&#160;</a></span>riscv_emulate_fsgnjns()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">float riscv_emulate_fsgnjns </td> + <td>(</td> + <td class="paramtype">float</td> <td class="paramname"><span class="paramname"><em>rs1</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">float</td> <td class="paramname"><span class="paramname"><em>rs2</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Single-precision floating-point sign-injection NOT</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">rs1</td><td>Source operand 1. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">rs2</td><td>Source operand 2. </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Result. </dd></dl> + +</div> +</div> +<a id="a12498d635f422f607b9b83facf3050dd" name="a12498d635f422f607b9b83facf3050dd"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a12498d635f422f607b9b83facf3050dd">&#9670;&#160;</a></span>riscv_emulate_fsgnjs()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">float riscv_emulate_fsgnjs </td> + <td>(</td> + <td class="paramtype">float</td> <td class="paramname"><span class="paramname"><em>rs1</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">float</td> <td class="paramname"><span class="paramname"><em>rs2</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Single-precision floating-point sign-injection</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">rs1</td><td>Source operand 1. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">rs2</td><td>Source operand 2. </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Result. </dd></dl> + +</div> +</div> +<a id="a98caf7f310820052ae96ce0f45e6cd26" name="a98caf7f310820052ae96ce0f45e6cd26"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a98caf7f310820052ae96ce0f45e6cd26">&#9670;&#160;</a></span>riscv_emulate_fsgnjxs()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">float riscv_emulate_fsgnjxs </td> + <td>(</td> + <td class="paramtype">float</td> <td class="paramname"><span class="paramname"><em>rs1</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">float</td> <td class="paramname"><span class="paramname"><em>rs2</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Single-precision floating-point sign-injection XOR</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">rs1</td><td>Source operand 1. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">rs2</td><td>Source operand 2. </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Result. </dd></dl> + +</div> +</div> +<a id="a1ceb3450f1e5c62d3079cd0e93c03501" name="a1ceb3450f1e5c62d3079cd0e93c03501"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a1ceb3450f1e5c62d3079cd0e93c03501">&#9670;&#160;</a></span>riscv_emulate_fsqrts()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">float riscv_emulate_fsqrts </td> + <td>(</td> + <td class="paramtype">float</td> <td class="paramname"><span class="paramname"><em>rs1</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Single-precision floating-point square root</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">rs1</td><td>Source operand 1. </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Result. </dd></dl> + +</div> +</div> +<a id="ace5d95b855ec1aa8eacdb5bbeea58197" name="ace5d95b855ec1aa8eacdb5bbeea58197"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ace5d95b855ec1aa8eacdb5bbeea58197">&#9670;&#160;</a></span>riscv_emulate_fsubs()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">float riscv_emulate_fsubs </td> + <td>(</td> + <td class="paramtype">float</td> <td class="paramname"><span class="paramname"><em>rs1</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">float</td> <td class="paramname"><span class="paramname"><em>rs2</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Single-precision floating-point subtraction</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">rs1</td><td>Source operand 1. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">rs2</td><td>Source operand 2. </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Result. </dd></dl> + +</div> +</div> +<a id="a4b151fcb252fc7b894f247f5af6a1809" name="a4b151fcb252fc7b894f247f5af6a1809"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a4b151fcb252fc7b894f247f5af6a1809">&#9670;&#160;</a></span>riscv_intrinsic_fadds()</h2> + +<div class="memitem"> +<div class="memproto"> +<table class="mlabels"> + <tr> + <td class="mlabels-left"> + <table class="memname"> + <tr> + <td class="memname">float riscv_intrinsic_fadds </td> + <td>(</td> + <td class="paramtype">float</td> <td class="paramname"><span class="paramname"><em>rs1</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">float</td> <td class="paramname"><span class="paramname"><em>rs2</em></span>&#160;)</td> + </tr> + </table> + </td> + <td class="mlabels-right"> +<span class="mlabels"><span class="mlabel">inline</span></span> </td> + </tr> +</table> +</div><div class="memdoc"> +<p>Single-precision floating-point addition</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">rs1</td><td>Source operand 1. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">rs2</td><td>Source operand 2. </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Result. </dd></dl> + +</div> +</div> +<a id="a3064a5c57b5f45d57c4d19eb798724f6" name="a3064a5c57b5f45d57c4d19eb798724f6"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a3064a5c57b5f45d57c4d19eb798724f6">&#9670;&#160;</a></span>riscv_intrinsic_fclasss()</h2> + +<div class="memitem"> +<div class="memproto"> +<table class="mlabels"> + <tr> + <td class="mlabels-left"> + <table class="memname"> + <tr> + <td class="memname">uint32_t riscv_intrinsic_fclasss </td> + <td>(</td> + <td class="paramtype">float</td> <td class="paramname"><span class="paramname"><em>rs1</em></span></td><td>)</td> + <td></td> + </tr> + </table> + </td> + <td class="mlabels-right"> +<span class="mlabels"><span class="mlabel">inline</span></span> </td> + </tr> +</table> +</div><div class="memdoc"> +<p>Single-precision floating-point number classification</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">rs1</td><td>Source operand 1. </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Result. </dd></dl> + +</div> +</div> +<a id="a2103eb86052f6f8e24a8a848ffc6528a" name="a2103eb86052f6f8e24a8a848ffc6528a"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a2103eb86052f6f8e24a8a848ffc6528a">&#9670;&#160;</a></span>riscv_intrinsic_fcvt_sw()</h2> + +<div class="memitem"> +<div class="memproto"> +<table class="mlabels"> + <tr> + <td class="mlabels-left"> + <table class="memname"> + <tr> + <td class="memname">float riscv_intrinsic_fcvt_sw </td> + <td>(</td> + <td class="paramtype">int32_t</td> <td class="paramname"><span class="paramname"><em>rs1</em></span></td><td>)</td> + <td></td> + </tr> + </table> + </td> + <td class="mlabels-right"> +<span class="mlabels"><span class="mlabel">inline</span></span> </td> + </tr> +</table> +</div><div class="memdoc"> +<p>Single-precision floating-point convert signed integer to float</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">rs1</td><td>Source operand 1. </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Result. </dd></dl> + +</div> +</div> +<a id="a837b7330f9d568791687ae1384b8ef28" name="a837b7330f9d568791687ae1384b8ef28"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a837b7330f9d568791687ae1384b8ef28">&#9670;&#160;</a></span>riscv_intrinsic_fcvt_swu()</h2> + +<div class="memitem"> +<div class="memproto"> +<table class="mlabels"> + <tr> + <td class="mlabels-left"> + <table class="memname"> + <tr> + <td class="memname">float riscv_intrinsic_fcvt_swu </td> + <td>(</td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>rs1</em></span></td><td>)</td> + <td></td> + </tr> + </table> + </td> + <td class="mlabels-right"> +<span class="mlabels"><span class="mlabel">inline</span></span> </td> + </tr> +</table> +</div><div class="memdoc"> +<p>Single-precision floating-point convert unsigned integer to float</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">rs1</td><td>Source operand 1. </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Result. </dd></dl> + +</div> +</div> +<a id="a523fa0fb6f521311c7f44692c586b3ee" name="a523fa0fb6f521311c7f44692c586b3ee"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a523fa0fb6f521311c7f44692c586b3ee">&#9670;&#160;</a></span>riscv_intrinsic_fcvt_ws()</h2> + +<div class="memitem"> +<div class="memproto"> +<table class="mlabels"> + <tr> + <td class="mlabels-left"> + <table class="memname"> + <tr> + <td class="memname">int32_t riscv_intrinsic_fcvt_ws </td> + <td>(</td> + <td class="paramtype">float</td> <td class="paramname"><span class="paramname"><em>rs1</em></span></td><td>)</td> + <td></td> + </tr> + </table> + </td> + <td class="mlabels-right"> +<span class="mlabels"><span class="mlabel">inline</span></span> </td> + </tr> +</table> +</div><div class="memdoc"> +<p>Single-precision floating-point convert float to signed integer</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">rs1</td><td>Source operand 1. </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Result. </dd></dl> + +</div> +</div> +<a id="a3bc6ee3059a7e99b187c4ea5e217715b" name="a3bc6ee3059a7e99b187c4ea5e217715b"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a3bc6ee3059a7e99b187c4ea5e217715b">&#9670;&#160;</a></span>riscv_intrinsic_fcvt_wus()</h2> + +<div class="memitem"> +<div class="memproto"> +<table class="mlabels"> + <tr> + <td class="mlabels-left"> + <table class="memname"> + <tr> + <td class="memname">uint32_t riscv_intrinsic_fcvt_wus </td> + <td>(</td> + <td class="paramtype">float</td> <td class="paramname"><span class="paramname"><em>rs1</em></span></td><td>)</td> + <td></td> + </tr> + </table> + </td> + <td class="mlabels-right"> +<span class="mlabels"><span class="mlabel">inline</span></span> </td> + </tr> +</table> +</div><div class="memdoc"> +<p>Single-precision floating-point convert float to unsigned integer</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">rs1</td><td>Source operand 1. </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Result. </dd></dl> + +</div> +</div> +<a id="ab6a9d15643e3085ff80c7883f183a42b" name="ab6a9d15643e3085ff80c7883f183a42b"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ab6a9d15643e3085ff80c7883f183a42b">&#9670;&#160;</a></span>riscv_intrinsic_fdivs()</h2> + +<div class="memitem"> +<div class="memproto"> +<table class="mlabels"> + <tr> + <td class="mlabels-left"> + <table class="memname"> + <tr> + <td class="memname">float riscv_intrinsic_fdivs </td> + <td>(</td> + <td class="paramtype">float</td> <td class="paramname"><span class="paramname"><em>rs1</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">float</td> <td class="paramname"><span class="paramname"><em>rs2</em></span>&#160;)</td> + </tr> + </table> + </td> + <td class="mlabels-right"> +<span class="mlabels"><span class="mlabel">inline</span></span> </td> + </tr> +</table> +</div><div class="memdoc"> +<p>Single-precision floating-point division</p> +<dl class="section warning"><dt>Warning</dt><dd>This instruction is not supported and should raise an illegal instruction exception when executed.</dd></dl> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">rs1</td><td>Source operand 1. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">rs2</td><td>Source operand 2. </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Result. </dd></dl> + +</div> +</div> +<a id="af4ddfae45807d4e41f758672ee14cf7b" name="af4ddfae45807d4e41f758672ee14cf7b"></a> +<h2 class="memtitle"><span class="permalink"><a href="#af4ddfae45807d4e41f758672ee14cf7b">&#9670;&#160;</a></span>riscv_intrinsic_feqs()</h2> + +<div class="memitem"> +<div class="memproto"> +<table class="mlabels"> + <tr> + <td class="mlabels-left"> + <table class="memname"> + <tr> + <td class="memname">uint32_t riscv_intrinsic_feqs </td> + <td>(</td> + <td class="paramtype">float</td> <td class="paramname"><span class="paramname"><em>rs1</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">float</td> <td class="paramname"><span class="paramname"><em>rs2</em></span>&#160;)</td> + </tr> + </table> + </td> + <td class="mlabels-right"> +<span class="mlabels"><span class="mlabel">inline</span></span> </td> + </tr> +</table> +</div><div class="memdoc"> +<p>Single-precision floating-point equal comparison</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">rs1</td><td>Source operand 1. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">rs2</td><td>Source operand 2. </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Result. </dd></dl> + +</div> +</div> +<a id="adb83fab39d91e9291da2b7b07830cf82" name="adb83fab39d91e9291da2b7b07830cf82"></a> +<h2 class="memtitle"><span class="permalink"><a href="#adb83fab39d91e9291da2b7b07830cf82">&#9670;&#160;</a></span>riscv_intrinsic_fles()</h2> + +<div class="memitem"> +<div class="memproto"> +<table class="mlabels"> + <tr> + <td class="mlabels-left"> + <table class="memname"> + <tr> + <td class="memname">uint32_t riscv_intrinsic_fles </td> + <td>(</td> + <td class="paramtype">float</td> <td class="paramname"><span class="paramname"><em>rs1</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">float</td> <td class="paramname"><span class="paramname"><em>rs2</em></span>&#160;)</td> + </tr> + </table> + </td> + <td class="mlabels-right"> +<span class="mlabels"><span class="mlabel">inline</span></span> </td> + </tr> +</table> +</div><div class="memdoc"> +<p>Single-precision floating-point less-than-or-equal comparison</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">rs1</td><td>Source operand 1. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">rs2</td><td>Source operand 2. </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Result. </dd></dl> + +</div> +</div> +<a id="a85aa18294a58997db2c324184196669c" name="a85aa18294a58997db2c324184196669c"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a85aa18294a58997db2c324184196669c">&#9670;&#160;</a></span>riscv_intrinsic_flts()</h2> + +<div class="memitem"> +<div class="memproto"> +<table class="mlabels"> + <tr> + <td class="mlabels-left"> + <table class="memname"> + <tr> + <td class="memname">uint32_t riscv_intrinsic_flts </td> + <td>(</td> + <td class="paramtype">float</td> <td class="paramname"><span class="paramname"><em>rs1</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">float</td> <td class="paramname"><span class="paramname"><em>rs2</em></span>&#160;)</td> + </tr> + </table> + </td> + <td class="mlabels-right"> +<span class="mlabels"><span class="mlabel">inline</span></span> </td> + </tr> +</table> +</div><div class="memdoc"> +<p>Single-precision floating-point less-than comparison</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">rs1</td><td>Source operand 1. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">rs2</td><td>Source operand 2. </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Result. </dd></dl> + +</div> +</div> +<a id="abbdb403cdeef414fa2f867b702d5f6eb" name="abbdb403cdeef414fa2f867b702d5f6eb"></a> +<h2 class="memtitle"><span class="permalink"><a href="#abbdb403cdeef414fa2f867b702d5f6eb">&#9670;&#160;</a></span>riscv_intrinsic_fmadds()</h2> + +<div class="memitem"> +<div class="memproto"> +<table class="mlabels"> + <tr> + <td class="mlabels-left"> + <table class="memname"> + <tr> + <td class="memname">float riscv_intrinsic_fmadds </td> + <td>(</td> + <td class="paramtype">float</td> <td class="paramname"><span class="paramname"><em>rs1</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">float</td> <td class="paramname"><span class="paramname"><em>rs2</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">float</td> <td class="paramname"><span class="paramname"><em>rs3</em></span>&#160;)</td> + </tr> + </table> + </td> + <td class="mlabels-right"> +<span class="mlabels"><span class="mlabel">inline</span></span> </td> + </tr> +</table> +</div><div class="memdoc"> +<p>Single-precision floating-point fused multiply-add</p> +<dl class="section warning"><dt>Warning</dt><dd>This instruction is not supported and should raise an illegal instruction exception when executed.</dd></dl> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">rs1</td><td>Source operand 1 </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">rs2</td><td>Source operand 2 </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">rs3</td><td>Source operand 3 </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Result. </dd></dl> + +</div> +</div> +<a id="a87c1ce499e5e43554cb0f407cf0d3f7f" name="a87c1ce499e5e43554cb0f407cf0d3f7f"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a87c1ce499e5e43554cb0f407cf0d3f7f">&#9670;&#160;</a></span>riscv_intrinsic_fmaxs()</h2> + +<div class="memitem"> +<div class="memproto"> +<table class="mlabels"> + <tr> + <td class="mlabels-left"> + <table class="memname"> + <tr> + <td class="memname">float riscv_intrinsic_fmaxs </td> + <td>(</td> + <td class="paramtype">float</td> <td class="paramname"><span class="paramname"><em>rs1</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">float</td> <td class="paramname"><span class="paramname"><em>rs2</em></span>&#160;)</td> + </tr> + </table> + </td> + <td class="mlabels-right"> +<span class="mlabels"><span class="mlabel">inline</span></span> </td> + </tr> +</table> +</div><div class="memdoc"> +<p>Single-precision floating-point maximum</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">rs1</td><td>Source operand 1. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">rs2</td><td>Source operand 2. </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Result. </dd></dl> + +</div> +</div> +<a id="abf7f9e466906306d9755fd5bc7946e3c" name="abf7f9e466906306d9755fd5bc7946e3c"></a> +<h2 class="memtitle"><span class="permalink"><a href="#abf7f9e466906306d9755fd5bc7946e3c">&#9670;&#160;</a></span>riscv_intrinsic_fmins()</h2> + +<div class="memitem"> +<div class="memproto"> +<table class="mlabels"> + <tr> + <td class="mlabels-left"> + <table class="memname"> + <tr> + <td class="memname">float riscv_intrinsic_fmins </td> + <td>(</td> + <td class="paramtype">float</td> <td class="paramname"><span class="paramname"><em>rs1</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">float</td> <td class="paramname"><span class="paramname"><em>rs2</em></span>&#160;)</td> + </tr> + </table> + </td> + <td class="mlabels-right"> +<span class="mlabels"><span class="mlabel">inline</span></span> </td> + </tr> +</table> +</div><div class="memdoc"> +<p>Single-precision floating-point minimum</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">rs1</td><td>Source operand 1. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">rs2</td><td>Source operand 2. </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Result. </dd></dl> + +</div> +</div> +<a id="a03aba9c70c5286dacebaeb0ef5219cc9" name="a03aba9c70c5286dacebaeb0ef5219cc9"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a03aba9c70c5286dacebaeb0ef5219cc9">&#9670;&#160;</a></span>riscv_intrinsic_fmsubs()</h2> + +<div class="memitem"> +<div class="memproto"> +<table class="mlabels"> + <tr> + <td class="mlabels-left"> + <table class="memname"> + <tr> + <td class="memname">float riscv_intrinsic_fmsubs </td> + <td>(</td> + <td class="paramtype">float</td> <td class="paramname"><span class="paramname"><em>rs1</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">float</td> <td class="paramname"><span class="paramname"><em>rs2</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">float</td> <td class="paramname"><span class="paramname"><em>rs3</em></span>&#160;)</td> + </tr> + </table> + </td> + <td class="mlabels-right"> +<span class="mlabels"><span class="mlabel">inline</span></span> </td> + </tr> +</table> +</div><div class="memdoc"> +<p>Single-precision floating-point fused multiply-sub</p> +<dl class="section warning"><dt>Warning</dt><dd>This instruction is not supported and should raise an illegal instruction exception when executed.</dd></dl> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">rs1</td><td>Source operand 1 </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">rs2</td><td>Source operand 2 </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">rs3</td><td>Source operand 3 </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Result. </dd></dl> + +</div> +</div> +<a id="a87a106e0d24a3183712e438d2bcbfa2d" name="a87a106e0d24a3183712e438d2bcbfa2d"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a87a106e0d24a3183712e438d2bcbfa2d">&#9670;&#160;</a></span>riscv_intrinsic_fmuls()</h2> + +<div class="memitem"> +<div class="memproto"> +<table class="mlabels"> + <tr> + <td class="mlabels-left"> + <table class="memname"> + <tr> + <td class="memname">float riscv_intrinsic_fmuls </td> + <td>(</td> + <td class="paramtype">float</td> <td class="paramname"><span class="paramname"><em>rs1</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">float</td> <td class="paramname"><span class="paramname"><em>rs2</em></span>&#160;)</td> + </tr> + </table> + </td> + <td class="mlabels-right"> +<span class="mlabels"><span class="mlabel">inline</span></span> </td> + </tr> +</table> +</div><div class="memdoc"> +<p>Single-precision floating-point multiplication</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">rs1</td><td>Source operand 1. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">rs2</td><td>Source operand 2. </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Result. </dd></dl> + +</div> +</div> +<a id="aa6473bc2d2721b57277b83a3ae0cfdb6" name="aa6473bc2d2721b57277b83a3ae0cfdb6"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aa6473bc2d2721b57277b83a3ae0cfdb6">&#9670;&#160;</a></span>riscv_intrinsic_fnmadds()</h2> + +<div class="memitem"> +<div class="memproto"> +<table class="mlabels"> + <tr> + <td class="mlabels-left"> + <table class="memname"> + <tr> + <td class="memname">float riscv_intrinsic_fnmadds </td> + <td>(</td> + <td class="paramtype">float</td> <td class="paramname"><span class="paramname"><em>rs1</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">float</td> <td class="paramname"><span class="paramname"><em>rs2</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">float</td> <td class="paramname"><span class="paramname"><em>rs3</em></span>&#160;)</td> + </tr> + </table> + </td> + <td class="mlabels-right"> +<span class="mlabels"><span class="mlabel">inline</span></span> </td> + </tr> +</table> +</div><div class="memdoc"> +<p>Single-precision floating-point fused negated multiply-add</p> +<dl class="section warning"><dt>Warning</dt><dd>This instruction is not supported and should raise an illegal instruction exception when executed.</dd></dl> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">rs1</td><td>Source operand 1 </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">rs2</td><td>Source operand 2 </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">rs3</td><td>Source operand 3 </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Result. </dd></dl> + +</div> +</div> +<a id="a639fc7bd75933888540e9cceb67221a0" name="a639fc7bd75933888540e9cceb67221a0"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a639fc7bd75933888540e9cceb67221a0">&#9670;&#160;</a></span>riscv_intrinsic_fnmsubs()</h2> + +<div class="memitem"> +<div class="memproto"> +<table class="mlabels"> + <tr> + <td class="mlabels-left"> + <table class="memname"> + <tr> + <td class="memname">float riscv_intrinsic_fnmsubs </td> + <td>(</td> + <td class="paramtype">float</td> <td class="paramname"><span class="paramname"><em>rs1</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">float</td> <td class="paramname"><span class="paramname"><em>rs2</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">float</td> <td class="paramname"><span class="paramname"><em>rs3</em></span>&#160;)</td> + </tr> + </table> + </td> + <td class="mlabels-right"> +<span class="mlabels"><span class="mlabel">inline</span></span> </td> + </tr> +</table> +</div><div class="memdoc"> +<p>Single-precision floating-point fused negated multiply-sub</p> +<dl class="section warning"><dt>Warning</dt><dd>This instruction is not supported and should raise an illegal instruction exception when executed.</dd></dl> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">rs1</td><td>Source operand 1 </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">rs2</td><td>Source operand 2 </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">rs3</td><td>Source operand 3 </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Result. </dd></dl> + +</div> +</div> +<a id="aa4010772a986d03929ba7a43dfdcddd9" name="aa4010772a986d03929ba7a43dfdcddd9"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aa4010772a986d03929ba7a43dfdcddd9">&#9670;&#160;</a></span>riscv_intrinsic_fsgnjns()</h2> + +<div class="memitem"> +<div class="memproto"> +<table class="mlabels"> + <tr> + <td class="mlabels-left"> + <table class="memname"> + <tr> + <td class="memname">float riscv_intrinsic_fsgnjns </td> + <td>(</td> + <td class="paramtype">float</td> <td class="paramname"><span class="paramname"><em>rs1</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">float</td> <td class="paramname"><span class="paramname"><em>rs2</em></span>&#160;)</td> + </tr> + </table> + </td> + <td class="mlabels-right"> +<span class="mlabels"><span class="mlabel">inline</span></span> </td> + </tr> +</table> +</div><div class="memdoc"> +<p>Single-precision floating-point sign-injection NOT</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">rs1</td><td>Source operand 1. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">rs2</td><td>Source operand 2. </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Result. </dd></dl> + +</div> +</div> +<a id="aff3acd90bcfbda96945f95a0e0bae12b" name="aff3acd90bcfbda96945f95a0e0bae12b"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aff3acd90bcfbda96945f95a0e0bae12b">&#9670;&#160;</a></span>riscv_intrinsic_fsgnjs()</h2> + +<div class="memitem"> +<div class="memproto"> +<table class="mlabels"> + <tr> + <td class="mlabels-left"> + <table class="memname"> + <tr> + <td class="memname">float riscv_intrinsic_fsgnjs </td> + <td>(</td> + <td class="paramtype">float</td> <td class="paramname"><span class="paramname"><em>rs1</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">float</td> <td class="paramname"><span class="paramname"><em>rs2</em></span>&#160;)</td> + </tr> + </table> + </td> + <td class="mlabels-right"> +<span class="mlabels"><span class="mlabel">inline</span></span> </td> + </tr> +</table> +</div><div class="memdoc"> +<p>Single-precision floating-point sign-injection</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">rs1</td><td>Source operand 1. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">rs2</td><td>Source operand 2. </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Result. </dd></dl> + +</div> +</div> +<a id="a2235d91cdac03bf8071003a5c59b9dd0" name="a2235d91cdac03bf8071003a5c59b9dd0"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a2235d91cdac03bf8071003a5c59b9dd0">&#9670;&#160;</a></span>riscv_intrinsic_fsgnjxs()</h2> + +<div class="memitem"> +<div class="memproto"> +<table class="mlabels"> + <tr> + <td class="mlabels-left"> + <table class="memname"> + <tr> + <td class="memname">float riscv_intrinsic_fsgnjxs </td> + <td>(</td> + <td class="paramtype">float</td> <td class="paramname"><span class="paramname"><em>rs1</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">float</td> <td class="paramname"><span class="paramname"><em>rs2</em></span>&#160;)</td> + </tr> + </table> + </td> + <td class="mlabels-right"> +<span class="mlabels"><span class="mlabel">inline</span></span> </td> + </tr> +</table> +</div><div class="memdoc"> +<p>Single-precision floating-point sign-injection XOR</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">rs1</td><td>Source operand 1. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">rs2</td><td>Source operand 2. </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Result. </dd></dl> + +</div> +</div> +<a id="a17e2b7a399c956d548a609185084ea3c" name="a17e2b7a399c956d548a609185084ea3c"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a17e2b7a399c956d548a609185084ea3c">&#9670;&#160;</a></span>riscv_intrinsic_fsqrts()</h2> + +<div class="memitem"> +<div class="memproto"> +<table class="mlabels"> + <tr> + <td class="mlabels-left"> + <table class="memname"> + <tr> + <td class="memname">float riscv_intrinsic_fsqrts </td> + <td>(</td> + <td class="paramtype">float</td> <td class="paramname"><span class="paramname"><em>rs1</em></span></td><td>)</td> + <td></td> + </tr> + </table> + </td> + <td class="mlabels-right"> +<span class="mlabels"><span class="mlabel">inline</span></span> </td> + </tr> +</table> +</div><div class="memdoc"> +<p>Single-precision floating-point square root</p> +<dl class="section warning"><dt>Warning</dt><dd>This instruction is not supported and should raise an illegal instruction exception when executed.</dd></dl> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">rs1</td><td>Source operand 1. </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Result. </dd></dl> + +</div> +</div> +<a id="af8473ba61abab8ae2e3ecbaf22d70e89" name="af8473ba61abab8ae2e3ecbaf22d70e89"></a> +<h2 class="memtitle"><span class="permalink"><a href="#af8473ba61abab8ae2e3ecbaf22d70e89">&#9670;&#160;</a></span>riscv_intrinsic_fsubs()</h2> + +<div class="memitem"> +<div class="memproto"> +<table class="mlabels"> + <tr> + <td class="mlabels-left"> + <table class="memname"> + <tr> + <td class="memname">float riscv_intrinsic_fsubs </td> + <td>(</td> + <td class="paramtype">float</td> <td class="paramname"><span class="paramname"><em>rs1</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">float</td> <td class="paramname"><span class="paramname"><em>rs2</em></span>&#160;)</td> + </tr> + </table> + </td> + <td class="mlabels-right"> +<span class="mlabels"><span class="mlabel">inline</span></span> </td> + </tr> +</table> +</div><div class="memdoc"> +<p>Single-precision floating-point subtraction</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">rs1</td><td>Source operand 1. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">rs2</td><td>Source operand 2. </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Result. </dd></dl> + +</div> +</div> +<a id="a791f880781a1bcea1861471be7d1a851" name="a791f880781a1bcea1861471be7d1a851"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a791f880781a1bcea1861471be7d1a851">&#9670;&#160;</a></span>subnormal_flush()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">float subnormal_flush </td> + <td>(</td> + <td class="paramtype">float</td> <td class="paramname"><span class="paramname"><em>tmp</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Flush to zero if de-normal number.</p> +<dl class="section warning"><dt>Warning</dt><dd>Subnormal numbers are not supported yet! Flush them to zero.</dd></dl> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">tmp</td><td>Source operand. </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Result. </dd></dl> + +</div> +</div> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/floating__point__test_2neorv32__zfinx__extension__intrinsics_8h_source.html b/sw/floating__point__test_2neorv32__zfinx__extension__intrinsics_8h_source.html new file mode 100644 index 0000000000..fa12d3a55d --- /dev/null +++ b/sw/floating__point__test_2neorv32__zfinx__extension__intrinsics_8h_source.html @@ -0,0 +1,985 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/example/floating_point_test/neorv32_zfinx_extension_intrinsics.h Source File</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_f0f9b27afba2e8cc2da6e5fddcc1a8c9.html">example</a></li><li class="navelem"><a class="el" href="dir_e9ffd83269fb7f0c372f5ffbe8545008.html">floating_point_test</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="headertitle"><div class="title">neorv32_zfinx_extension_intrinsics.h</div></div> +</div><!--header--> +<div class="contents"> +<a href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html">Go to the documentation of this file.</a><div class="fragment"><div class="line"><a id="l00001" name="l00001"></a><span class="lineno"> 1</span><span class="comment">// #################################################################################################</span></div> +<div class="line"><a id="l00002" name="l00002"></a><span class="lineno"> 2</span><span class="comment">// # &lt;&lt; NEORV32 - Intrinsics + Emulation Functions for the RISC-V &quot;Zfinx&quot; CPU extension &gt;&gt; #</span></div> +<div class="line"><a id="l00003" name="l00003"></a><span class="lineno"> 3</span><span class="comment">// # ********************************************************************************************* #</span></div> +<div class="line"><a id="l00004" name="l00004"></a><span class="lineno"> 4</span><span class="comment">// # The intrinsics provided by this library allow to use the hardware floating-point unit of the #</span></div> +<div class="line"><a id="l00005" name="l00005"></a><span class="lineno"> 5</span><span class="comment">// # RISC-V Zfinx CPU extension without the need for Zfinx support by the compiler / toolchain. #</span></div> +<div class="line"><a id="l00006" name="l00006"></a><span class="lineno"> 6</span><span class="comment">// # ********************************************************************************************* #</span></div> +<div class="line"><a id="l00007" name="l00007"></a><span class="lineno"> 7</span><span class="comment">// # BSD 3-Clause License #</span></div> +<div class="line"><a id="l00008" name="l00008"></a><span class="lineno"> 8</span><span class="comment">// # #</span></div> +<div class="line"><a id="l00009" name="l00009"></a><span class="lineno"> 9</span><span class="comment">// # Copyright (c) 2024, Stephan Nolting. All rights reserved. #</span></div> +<div class="line"><a id="l00010" name="l00010"></a><span class="lineno"> 10</span><span class="comment">// # #</span></div> +<div class="line"><a id="l00011" name="l00011"></a><span class="lineno"> 11</span><span class="comment">// # Redistribution and use in source and binary forms, with or without modification, are #</span></div> +<div class="line"><a id="l00012" name="l00012"></a><span class="lineno"> 12</span><span class="comment">// # permitted provided that the following conditions are met: #</span></div> +<div class="line"><a id="l00013" name="l00013"></a><span class="lineno"> 13</span><span class="comment">// # #</span></div> +<div class="line"><a id="l00014" name="l00014"></a><span class="lineno"> 14</span><span class="comment">// # 1. Redistributions of source code must retain the above copyright notice, this list of #</span></div> +<div class="line"><a id="l00015" name="l00015"></a><span class="lineno"> 15</span><span class="comment">// # conditions and the following disclaimer. #</span></div> +<div class="line"><a id="l00016" name="l00016"></a><span class="lineno"> 16</span><span class="comment">// # #</span></div> +<div class="line"><a id="l00017" name="l00017"></a><span class="lineno"> 17</span><span class="comment">// # 2. Redistributions in binary form must reproduce the above copyright notice, this list of #</span></div> +<div class="line"><a id="l00018" name="l00018"></a><span class="lineno"> 18</span><span class="comment">// # conditions and the following disclaimer in the documentation and/or other materials #</span></div> +<div class="line"><a id="l00019" name="l00019"></a><span class="lineno"> 19</span><span class="comment">// # provided with the distribution. #</span></div> +<div class="line"><a id="l00020" name="l00020"></a><span class="lineno"> 20</span><span class="comment">// # #</span></div> +<div class="line"><a id="l00021" name="l00021"></a><span class="lineno"> 21</span><span class="comment">// # 3. Neither the name of the copyright holder nor the names of its contributors may be used to #</span></div> +<div class="line"><a id="l00022" name="l00022"></a><span class="lineno"> 22</span><span class="comment">// # endorse or promote products derived from this software without specific prior written #</span></div> +<div class="line"><a id="l00023" name="l00023"></a><span class="lineno"> 23</span><span class="comment">// # permission. #</span></div> +<div class="line"><a id="l00024" name="l00024"></a><span class="lineno"> 24</span><span class="comment">// # #</span></div> +<div class="line"><a id="l00025" name="l00025"></a><span class="lineno"> 25</span><span class="comment">// # THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS &quot;AS IS&quot; AND ANY EXPRESS #</span></div> +<div class="line"><a id="l00026" name="l00026"></a><span class="lineno"> 26</span><span class="comment">// # OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF #</span></div> +<div class="line"><a id="l00027" name="l00027"></a><span class="lineno"> 27</span><span class="comment">// # MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE #</span></div> +<div class="line"><a id="l00028" name="l00028"></a><span class="lineno"> 28</span><span class="comment">// # COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, #</span></div> +<div class="line"><a id="l00029" name="l00029"></a><span class="lineno"> 29</span><span class="comment">// # EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE #</span></div> +<div class="line"><a id="l00030" name="l00030"></a><span class="lineno"> 30</span><span class="comment">// # GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED #</span></div> +<div class="line"><a id="l00031" name="l00031"></a><span class="lineno"> 31</span><span class="comment">// # AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING #</span></div> +<div class="line"><a id="l00032" name="l00032"></a><span class="lineno"> 32</span><span class="comment">// # NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED #</span></div> +<div class="line"><a id="l00033" name="l00033"></a><span class="lineno"> 33</span><span class="comment">// # OF THE POSSIBILITY OF SUCH DAMAGE. #</span></div> +<div class="line"><a id="l00034" name="l00034"></a><span class="lineno"> 34</span><span class="comment">// # ********************************************************************************************* #</span></div> +<div class="line"><a id="l00035" name="l00035"></a><span class="lineno"> 35</span><span class="comment">// # The NEORV32 Processor - https://github.com/stnolting/neorv32 (c) Stephan Nolting #</span></div> +<div class="line"><a id="l00036" name="l00036"></a><span class="lineno"> 36</span><span class="comment">// #################################################################################################</span></div> +<div class="line"><a id="l00037" name="l00037"></a><span class="lineno"> 37</span> </div> +<div class="line"><a id="l00038" name="l00038"></a><span class="lineno"> 38</span> </div> +<div class="line"><a id="l00039" name="l00039"></a><span class="lineno"> 39</span><span class="comment">/**********************************************************************/</span></div> +<div class="line"><a id="l00052" name="l00052"></a><span class="lineno"> 52</span><span class="preprocessor">#ifndef neorv32_zfinx_extension_intrinsics_h</span></div> +<div class="line"><a id="l00053" name="l00053"></a><span class="lineno"> 53</span><span class="preprocessor">#define neorv32_zfinx_extension_intrinsics_h</span></div> +<div class="line"><a id="l00054" name="l00054"></a><span class="lineno"> 54</span> </div> +<div class="line"><a id="l00055" name="l00055"></a><span class="lineno"> 55</span><span class="preprocessor">#define __USE_GNU</span></div> +<div class="line"><a id="l00056" name="l00056"></a><span class="lineno"> 56</span><span class="preprocessor">#define _GNU_SOURCE</span></div> +<div class="line"><a id="l00057" name="l00057"></a><span class="lineno"> 57</span><span class="preprocessor">#include &lt;float.h&gt;</span></div> +<div class="line"><a id="l00058" name="l00058"></a><span class="lineno"> 58</span><span class="preprocessor">#include &lt;math.h&gt;</span></div> +<div class="line"><a id="l00059" name="l00059"></a><span class="lineno"> 59</span> </div> +<div class="line"><a id="l00060" name="l00060"></a><span class="lineno"> 60</span> </div> +<div class="line"><a id="l00061" name="l00061"></a><span class="lineno"> 61</span><span class="comment">/**********************************************************************/</span></div> +<div class="line"><a id="l00064" name="l00064"></a><span class="lineno"> 64</span><span class="preprocessor">#if defined __riscv_f || (__riscv_flen == 32)</span></div> +<div class="line"><a id="l00065" name="l00065"></a><span class="lineno"> 65</span><span class="preprocessor"> #error Application programs using the Zfinx intrinsic library have to be compiled WITHOUT the &lt;F&gt; MARCH ISA attribute!</span></div> +<div class="line"><a id="l00066" name="l00066"></a><span class="lineno"> 66</span><span class="preprocessor">#endif</span></div> +<div class="line"><a id="l00067" name="l00067"></a><span class="lineno"> 67</span> </div> +<div class="line"><a id="l00068" name="l00068"></a><span class="lineno"> 68</span> </div> +<div class="line"><a id="l00069" name="l00069"></a><span class="lineno"> 69</span><span class="comment">/**********************************************************************/</span></div> +<div class="line"><a id="l00072" name="l00072"></a><span class="lineno"> 72</span><span class="keyword">typedef</span> <span class="keyword">union</span></div> +<div class="line"><a id="l00073" name="l00073"></a><span class="lineno"> 73</span>{</div> +<div class="line"><a id="l00074" name="l00074"></a><span class="lineno"> 74</span> uint32_t binary_value; </div> +<div class="line"><a id="l00075" name="l00075"></a><span class="lineno"> 75</span> <span class="keywordtype">float</span> float_value; </div> +<div class="line"><a id="l00076" name="l00076"></a><span class="lineno"> 76</span>} <a class="code hl_union" href="unionfloat__conv__t.html">float_conv_t</a>;</div> +<div class="line"><a id="l00077" name="l00077"></a><span class="lineno"> 77</span> </div> +<div class="line"><a id="l00078" name="l00078"></a><span class="lineno"> 78</span> </div> +<div class="line"><a id="l00079" name="l00079"></a><span class="lineno"> 79</span><span class="comment">// ################################################################################################</span></div> +<div class="line"><a id="l00080" name="l00080"></a><span class="lineno"> 80</span><span class="comment">// Helper functions</span></div> +<div class="line"><a id="l00081" name="l00081"></a><span class="lineno"> 81</span><span class="comment">// ################################################################################################</span></div> +<div class="line"><a id="l00082" name="l00082"></a><span class="lineno"> 82</span> </div> +<div class="line"><a id="l00083" name="l00083"></a><span class="lineno"> 83</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen00091" data-start="{" data-end="}"> +<div class="line"><a id="l00091" name="l00091"></a><span class="lineno"><a class="line" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a791f880781a1bcea1861471be7d1a851"> 91</a></span><span class="keywordtype">float</span> subnormal_flush(<span class="keywordtype">float</span> tmp) {</div> +<div class="line"><a id="l00092" name="l00092"></a><span class="lineno"> 92</span> </div> +<div class="line"><a id="l00093" name="l00093"></a><span class="lineno"> 93</span> <span class="keywordtype">float</span> res = tmp;</div> +<div class="line"><a id="l00094" name="l00094"></a><span class="lineno"> 94</span> </div> +<div class="line"><a id="l00095" name="l00095"></a><span class="lineno"> 95</span> <span class="comment">// flush to zero if subnormal</span></div> +<div class="line"><a id="l00096" name="l00096"></a><span class="lineno"> 96</span> <span class="keywordflow">if</span> (fpclassify(tmp) == FP_SUBNORMAL) {</div> +<div class="line"><a id="l00097" name="l00097"></a><span class="lineno"> 97</span> <span class="keywordflow">if</span> (signbit(tmp) != 0) {</div> +<div class="line"><a id="l00098" name="l00098"></a><span class="lineno"> 98</span> res = -0.0f;</div> +<div class="line"><a id="l00099" name="l00099"></a><span class="lineno"> 99</span> }</div> +<div class="line"><a id="l00100" name="l00100"></a><span class="lineno"> 100</span> <span class="keywordflow">else</span> {</div> +<div class="line"><a id="l00101" name="l00101"></a><span class="lineno"> 101</span> res = +0.0f;</div> +<div class="line"><a id="l00102" name="l00102"></a><span class="lineno"> 102</span> }</div> +<div class="line"><a id="l00103" name="l00103"></a><span class="lineno"> 103</span> }</div> +<div class="line"><a id="l00104" name="l00104"></a><span class="lineno"> 104</span> </div> +<div class="line"><a id="l00105" name="l00105"></a><span class="lineno"> 105</span> <span class="keywordflow">return</span> res;</div> +<div class="line"><a id="l00106" name="l00106"></a><span class="lineno"> 106</span>}</div> +</div> +<div class="line"><a id="l00107" name="l00107"></a><span class="lineno"> 107</span> </div> +<div class="line"><a id="l00108" name="l00108"></a><span class="lineno"> 108</span> </div> +<div class="line"><a id="l00109" name="l00109"></a><span class="lineno"> 109</span><span class="comment">// ################################################################################################</span></div> +<div class="line"><a id="l00110" name="l00110"></a><span class="lineno"> 110</span><span class="comment">// &quot;Intrinsics&quot;</span></div> +<div class="line"><a id="l00111" name="l00111"></a><span class="lineno"> 111</span><span class="comment">// ################################################################################################</span></div> +<div class="line"><a id="l00112" name="l00112"></a><span class="lineno"> 112</span> </div> +<div class="line"><a id="l00113" name="l00113"></a><span class="lineno"> 113</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen00120" data-start="{" data-end="}"> +<div class="line"><a id="l00120" name="l00120"></a><span class="lineno"><a class="line" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a4b151fcb252fc7b894f247f5af6a1809"> 120</a></span><span class="keyword">inline</span> <span class="keywordtype">float</span> __attribute__ ((always_inline)) riscv_intrinsic_fadds(<span class="keywordtype">float</span> rs1, <span class="keywordtype">float</span> rs2) {</div> +<div class="line"><a id="l00121" name="l00121"></a><span class="lineno"> 121</span> </div> +<div class="line"><a id="l00122" name="l00122"></a><span class="lineno"> 122</span> <a class="code hl_union" href="unionfloat__conv__t.html">float_conv_t</a> opa, opb, res;</div> +<div class="line"><a id="l00123" name="l00123"></a><span class="lineno"> 123</span> opa.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a> = rs1;</div> +<div class="line"><a id="l00124" name="l00124"></a><span class="lineno"> 124</span> opb.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a> = rs2;</div> +<div class="line"><a id="l00125" name="l00125"></a><span class="lineno"> 125</span> </div> +<div class="line"><a id="l00126" name="l00126"></a><span class="lineno"> 126</span> res.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a> = CUSTOM_INSTR_R3_TYPE(0b0000000, opb.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a>, opa.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a>, 0b000, 0b1010011);</div> +<div class="line"><a id="l00127" name="l00127"></a><span class="lineno"> 127</span> <span class="keywordflow">return</span> res.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a>;</div> +<div class="line"><a id="l00128" name="l00128"></a><span class="lineno"> 128</span>}</div> +</div> +<div class="line"><a id="l00129" name="l00129"></a><span class="lineno"> 129</span> </div> +<div class="line"><a id="l00130" name="l00130"></a><span class="lineno"> 130</span> </div> +<div class="line"><a id="l00131" name="l00131"></a><span class="lineno"> 131</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen00138" data-start="{" data-end="}"> +<div class="line"><a id="l00138" name="l00138"></a><span class="lineno"><a class="line" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#af8473ba61abab8ae2e3ecbaf22d70e89"> 138</a></span><span class="keyword">inline</span> <span class="keywordtype">float</span> __attribute__ ((always_inline)) riscv_intrinsic_fsubs(<span class="keywordtype">float</span> rs1, <span class="keywordtype">float</span> rs2) {</div> +<div class="line"><a id="l00139" name="l00139"></a><span class="lineno"> 139</span> </div> +<div class="line"><a id="l00140" name="l00140"></a><span class="lineno"> 140</span> <a class="code hl_union" href="unionfloat__conv__t.html">float_conv_t</a> opa, opb, res;</div> +<div class="line"><a id="l00141" name="l00141"></a><span class="lineno"> 141</span> opa.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a> = rs1;</div> +<div class="line"><a id="l00142" name="l00142"></a><span class="lineno"> 142</span> opb.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a> = rs2;</div> +<div class="line"><a id="l00143" name="l00143"></a><span class="lineno"> 143</span> </div> +<div class="line"><a id="l00144" name="l00144"></a><span class="lineno"> 144</span> res.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a> = CUSTOM_INSTR_R3_TYPE(0b0000100, opb.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a>, opa.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a>, 0b000, 0b1010011);</div> +<div class="line"><a id="l00145" name="l00145"></a><span class="lineno"> 145</span> <span class="keywordflow">return</span> res.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a>;</div> +<div class="line"><a id="l00146" name="l00146"></a><span class="lineno"> 146</span>}</div> +</div> +<div class="line"><a id="l00147" name="l00147"></a><span class="lineno"> 147</span> </div> +<div class="line"><a id="l00148" name="l00148"></a><span class="lineno"> 148</span> </div> +<div class="line"><a id="l00149" name="l00149"></a><span class="lineno"> 149</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen00156" data-start="{" data-end="}"> +<div class="line"><a id="l00156" name="l00156"></a><span class="lineno"><a class="line" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a87a106e0d24a3183712e438d2bcbfa2d"> 156</a></span><span class="keyword">inline</span> <span class="keywordtype">float</span> __attribute__ ((always_inline)) riscv_intrinsic_fmuls(<span class="keywordtype">float</span> rs1, <span class="keywordtype">float</span> rs2) {</div> +<div class="line"><a id="l00157" name="l00157"></a><span class="lineno"> 157</span> </div> +<div class="line"><a id="l00158" name="l00158"></a><span class="lineno"> 158</span> <a class="code hl_union" href="unionfloat__conv__t.html">float_conv_t</a> opa, opb, res;</div> +<div class="line"><a id="l00159" name="l00159"></a><span class="lineno"> 159</span> opa.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a> = rs1;</div> +<div class="line"><a id="l00160" name="l00160"></a><span class="lineno"> 160</span> opb.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a> = rs2;</div> +<div class="line"><a id="l00161" name="l00161"></a><span class="lineno"> 161</span> </div> +<div class="line"><a id="l00162" name="l00162"></a><span class="lineno"> 162</span> res.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a> = CUSTOM_INSTR_R3_TYPE(0b0001000, opb.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a>, opa.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a>, 0b000, 0b1010011);</div> +<div class="line"><a id="l00163" name="l00163"></a><span class="lineno"> 163</span> <span class="keywordflow">return</span> res.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a>;</div> +<div class="line"><a id="l00164" name="l00164"></a><span class="lineno"> 164</span>}</div> +</div> +<div class="line"><a id="l00165" name="l00165"></a><span class="lineno"> 165</span> </div> +<div class="line"><a id="l00166" name="l00166"></a><span class="lineno"> 166</span> </div> +<div class="line"><a id="l00167" name="l00167"></a><span class="lineno"> 167</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen00174" data-start="{" data-end="}"> +<div class="line"><a id="l00174" name="l00174"></a><span class="lineno"><a class="line" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#abf7f9e466906306d9755fd5bc7946e3c"> 174</a></span><span class="keyword">inline</span> <span class="keywordtype">float</span> __attribute__ ((always_inline)) riscv_intrinsic_fmins(<span class="keywordtype">float</span> rs1, <span class="keywordtype">float</span> rs2) {</div> +<div class="line"><a id="l00175" name="l00175"></a><span class="lineno"> 175</span> </div> +<div class="line"><a id="l00176" name="l00176"></a><span class="lineno"> 176</span> <a class="code hl_union" href="unionfloat__conv__t.html">float_conv_t</a> opa, opb, res;</div> +<div class="line"><a id="l00177" name="l00177"></a><span class="lineno"> 177</span> opa.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a> = rs1;</div> +<div class="line"><a id="l00178" name="l00178"></a><span class="lineno"> 178</span> opb.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a> = rs2;</div> +<div class="line"><a id="l00179" name="l00179"></a><span class="lineno"> 179</span> </div> +<div class="line"><a id="l00180" name="l00180"></a><span class="lineno"> 180</span> res.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a> = CUSTOM_INSTR_R3_TYPE(0b0010100, opb.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a>, opa.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a>, 0b000, 0b1010011);</div> +<div class="line"><a id="l00181" name="l00181"></a><span class="lineno"> 181</span> <span class="keywordflow">return</span> res.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a>;</div> +<div class="line"><a id="l00182" name="l00182"></a><span class="lineno"> 182</span>}</div> +</div> +<div class="line"><a id="l00183" name="l00183"></a><span class="lineno"> 183</span> </div> +<div class="line"><a id="l00184" name="l00184"></a><span class="lineno"> 184</span> </div> +<div class="line"><a id="l00185" name="l00185"></a><span class="lineno"> 185</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen00192" data-start="{" data-end="}"> +<div class="line"><a id="l00192" name="l00192"></a><span class="lineno"><a class="line" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a87c1ce499e5e43554cb0f407cf0d3f7f"> 192</a></span><span class="keyword">inline</span> <span class="keywordtype">float</span> __attribute__ ((always_inline)) riscv_intrinsic_fmaxs(<span class="keywordtype">float</span> rs1, <span class="keywordtype">float</span> rs2) {</div> +<div class="line"><a id="l00193" name="l00193"></a><span class="lineno"> 193</span> </div> +<div class="line"><a id="l00194" name="l00194"></a><span class="lineno"> 194</span> <a class="code hl_union" href="unionfloat__conv__t.html">float_conv_t</a> opa, opb, res;</div> +<div class="line"><a id="l00195" name="l00195"></a><span class="lineno"> 195</span> opa.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a> = rs1;</div> +<div class="line"><a id="l00196" name="l00196"></a><span class="lineno"> 196</span> opb.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a> = rs2;</div> +<div class="line"><a id="l00197" name="l00197"></a><span class="lineno"> 197</span> </div> +<div class="line"><a id="l00198" name="l00198"></a><span class="lineno"> 198</span> res.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a> = CUSTOM_INSTR_R3_TYPE(0b0010100, opb.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a>, opa.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a>, 0b001, 0b1010011);</div> +<div class="line"><a id="l00199" name="l00199"></a><span class="lineno"> 199</span> <span class="keywordflow">return</span> res.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a>;</div> +<div class="line"><a id="l00200" name="l00200"></a><span class="lineno"> 200</span>}</div> +</div> +<div class="line"><a id="l00201" name="l00201"></a><span class="lineno"> 201</span> </div> +<div class="line"><a id="l00202" name="l00202"></a><span class="lineno"> 202</span> </div> +<div class="line"><a id="l00203" name="l00203"></a><span class="lineno"> 203</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen00209" data-start="{" data-end="}"> +<div class="line"><a id="l00209" name="l00209"></a><span class="lineno"><a class="line" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a3bc6ee3059a7e99b187c4ea5e217715b"> 209</a></span><span class="keyword">inline</span> uint32_t __attribute__ ((always_inline)) riscv_intrinsic_fcvt_wus(<span class="keywordtype">float</span> rs1) {</div> +<div class="line"><a id="l00210" name="l00210"></a><span class="lineno"> 210</span> </div> +<div class="line"><a id="l00211" name="l00211"></a><span class="lineno"> 211</span> <a class="code hl_union" href="unionfloat__conv__t.html">float_conv_t</a> opa;</div> +<div class="line"><a id="l00212" name="l00212"></a><span class="lineno"> 212</span> opa.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a> = rs1;</div> +<div class="line"><a id="l00213" name="l00213"></a><span class="lineno"> 213</span> </div> +<div class="line"><a id="l00214" name="l00214"></a><span class="lineno"> 214</span> <span class="keywordflow">return</span> CUSTOM_INSTR_R2_TYPE(0b1100000, 0b00001, opa.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a>, 0b000, 0b1010011);</div> +<div class="line"><a id="l00215" name="l00215"></a><span class="lineno"> 215</span>}</div> +</div> +<div class="line"><a id="l00216" name="l00216"></a><span class="lineno"> 216</span> </div> +<div class="line"><a id="l00217" name="l00217"></a><span class="lineno"> 217</span> </div> +<div class="line"><a id="l00218" name="l00218"></a><span class="lineno"> 218</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen00224" data-start="{" data-end="}"> +<div class="line"><a id="l00224" name="l00224"></a><span class="lineno"><a class="line" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a523fa0fb6f521311c7f44692c586b3ee"> 224</a></span><span class="keyword">inline</span> int32_t __attribute__ ((always_inline)) riscv_intrinsic_fcvt_ws(<span class="keywordtype">float</span> rs1) {</div> +<div class="line"><a id="l00225" name="l00225"></a><span class="lineno"> 225</span> </div> +<div class="line"><a id="l00226" name="l00226"></a><span class="lineno"> 226</span> <a class="code hl_union" href="unionfloat__conv__t.html">float_conv_t</a> opa;</div> +<div class="line"><a id="l00227" name="l00227"></a><span class="lineno"> 227</span> opa.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a> = rs1;</div> +<div class="line"><a id="l00228" name="l00228"></a><span class="lineno"> 228</span> </div> +<div class="line"><a id="l00229" name="l00229"></a><span class="lineno"> 229</span> <span class="keywordflow">return</span> (int32_t)CUSTOM_INSTR_R2_TYPE(0b1100000, 0b00000, opa.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a>, 0b000, 0b1010011);</div> +<div class="line"><a id="l00230" name="l00230"></a><span class="lineno"> 230</span>}</div> +</div> +<div class="line"><a id="l00231" name="l00231"></a><span class="lineno"> 231</span> </div> +<div class="line"><a id="l00232" name="l00232"></a><span class="lineno"> 232</span> </div> +<div class="line"><a id="l00233" name="l00233"></a><span class="lineno"> 233</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen00239" data-start="{" data-end="}"> +<div class="line"><a id="l00239" name="l00239"></a><span class="lineno"><a class="line" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a837b7330f9d568791687ae1384b8ef28"> 239</a></span><span class="keyword">inline</span> <span class="keywordtype">float</span> __attribute__ ((always_inline)) riscv_intrinsic_fcvt_swu(uint32_t rs1) {</div> +<div class="line"><a id="l00240" name="l00240"></a><span class="lineno"> 240</span> </div> +<div class="line"><a id="l00241" name="l00241"></a><span class="lineno"> 241</span> <a class="code hl_union" href="unionfloat__conv__t.html">float_conv_t</a> res;</div> +<div class="line"><a id="l00242" name="l00242"></a><span class="lineno"> 242</span> </div> +<div class="line"><a id="l00243" name="l00243"></a><span class="lineno"> 243</span> res.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a> = CUSTOM_INSTR_R2_TYPE(0b1101000, 0b00001, rs1, 0b000, 0b1010011);</div> +<div class="line"><a id="l00244" name="l00244"></a><span class="lineno"> 244</span> <span class="keywordflow">return</span> res.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a>;</div> +<div class="line"><a id="l00245" name="l00245"></a><span class="lineno"> 245</span>}</div> +</div> +<div class="line"><a id="l00246" name="l00246"></a><span class="lineno"> 246</span> </div> +<div class="line"><a id="l00247" name="l00247"></a><span class="lineno"> 247</span> </div> +<div class="line"><a id="l00248" name="l00248"></a><span class="lineno"> 248</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen00254" data-start="{" data-end="}"> +<div class="line"><a id="l00254" name="l00254"></a><span class="lineno"><a class="line" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a2103eb86052f6f8e24a8a848ffc6528a"> 254</a></span><span class="keyword">inline</span> <span class="keywordtype">float</span> __attribute__ ((always_inline)) riscv_intrinsic_fcvt_sw(int32_t rs1) {</div> +<div class="line"><a id="l00255" name="l00255"></a><span class="lineno"> 255</span> </div> +<div class="line"><a id="l00256" name="l00256"></a><span class="lineno"> 256</span> <a class="code hl_union" href="unionfloat__conv__t.html">float_conv_t</a> res;</div> +<div class="line"><a id="l00257" name="l00257"></a><span class="lineno"> 257</span> </div> +<div class="line"><a id="l00258" name="l00258"></a><span class="lineno"> 258</span> res.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a> = CUSTOM_INSTR_R2_TYPE(0b1101000, 0b00000, rs1, 0b000, 0b1010011);</div> +<div class="line"><a id="l00259" name="l00259"></a><span class="lineno"> 259</span> <span class="keywordflow">return</span> res.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a>;</div> +<div class="line"><a id="l00260" name="l00260"></a><span class="lineno"> 260</span>}</div> +</div> +<div class="line"><a id="l00261" name="l00261"></a><span class="lineno"> 261</span> </div> +<div class="line"><a id="l00262" name="l00262"></a><span class="lineno"> 262</span> </div> +<div class="line"><a id="l00263" name="l00263"></a><span class="lineno"> 263</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen00270" data-start="{" data-end="}"> +<div class="line"><a id="l00270" name="l00270"></a><span class="lineno"><a class="line" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#af4ddfae45807d4e41f758672ee14cf7b"> 270</a></span><span class="keyword">inline</span> uint32_t __attribute__ ((always_inline)) riscv_intrinsic_feqs(<span class="keywordtype">float</span> rs1, <span class="keywordtype">float</span> rs2) {</div> +<div class="line"><a id="l00271" name="l00271"></a><span class="lineno"> 271</span> </div> +<div class="line"><a id="l00272" name="l00272"></a><span class="lineno"> 272</span> <a class="code hl_union" href="unionfloat__conv__t.html">float_conv_t</a> opa, opb;</div> +<div class="line"><a id="l00273" name="l00273"></a><span class="lineno"> 273</span> opa.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a> = rs1;</div> +<div class="line"><a id="l00274" name="l00274"></a><span class="lineno"> 274</span> opb.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a> = rs2;</div> +<div class="line"><a id="l00275" name="l00275"></a><span class="lineno"> 275</span> </div> +<div class="line"><a id="l00276" name="l00276"></a><span class="lineno"> 276</span> <span class="keywordflow">return</span> CUSTOM_INSTR_R3_TYPE(0b1010000, opb.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a>, opa.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a>, 0b010, 0b1010011);</div> +<div class="line"><a id="l00277" name="l00277"></a><span class="lineno"> 277</span>}</div> +</div> +<div class="line"><a id="l00278" name="l00278"></a><span class="lineno"> 278</span> </div> +<div class="line"><a id="l00279" name="l00279"></a><span class="lineno"> 279</span> </div> +<div class="line"><a id="l00280" name="l00280"></a><span class="lineno"> 280</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen00287" data-start="{" data-end="}"> +<div class="line"><a id="l00287" name="l00287"></a><span class="lineno"><a class="line" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a85aa18294a58997db2c324184196669c"> 287</a></span><span class="keyword">inline</span> uint32_t __attribute__ ((always_inline)) riscv_intrinsic_flts(<span class="keywordtype">float</span> rs1, <span class="keywordtype">float</span> rs2) {</div> +<div class="line"><a id="l00288" name="l00288"></a><span class="lineno"> 288</span> </div> +<div class="line"><a id="l00289" name="l00289"></a><span class="lineno"> 289</span> <a class="code hl_union" href="unionfloat__conv__t.html">float_conv_t</a> opa, opb;</div> +<div class="line"><a id="l00290" name="l00290"></a><span class="lineno"> 290</span> opa.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a> = rs1;</div> +<div class="line"><a id="l00291" name="l00291"></a><span class="lineno"> 291</span> opb.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a> = rs2;</div> +<div class="line"><a id="l00292" name="l00292"></a><span class="lineno"> 292</span> </div> +<div class="line"><a id="l00293" name="l00293"></a><span class="lineno"> 293</span> <span class="keywordflow">return</span> CUSTOM_INSTR_R3_TYPE(0b1010000, opb.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a>, opa.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a>, 0b001, 0b1010011);</div> +<div class="line"><a id="l00294" name="l00294"></a><span class="lineno"> 294</span>}</div> +</div> +<div class="line"><a id="l00295" name="l00295"></a><span class="lineno"> 295</span> </div> +<div class="line"><a id="l00296" name="l00296"></a><span class="lineno"> 296</span> </div> +<div class="line"><a id="l00297" name="l00297"></a><span class="lineno"> 297</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen00304" data-start="{" data-end="}"> +<div class="line"><a id="l00304" name="l00304"></a><span class="lineno"><a class="line" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#adb83fab39d91e9291da2b7b07830cf82"> 304</a></span><span class="keyword">inline</span> uint32_t __attribute__ ((always_inline)) riscv_intrinsic_fles(<span class="keywordtype">float</span> rs1, <span class="keywordtype">float</span> rs2) {</div> +<div class="line"><a id="l00305" name="l00305"></a><span class="lineno"> 305</span> </div> +<div class="line"><a id="l00306" name="l00306"></a><span class="lineno"> 306</span> <a class="code hl_union" href="unionfloat__conv__t.html">float_conv_t</a> opa, opb;</div> +<div class="line"><a id="l00307" name="l00307"></a><span class="lineno"> 307</span> opa.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a> = rs1;</div> +<div class="line"><a id="l00308" name="l00308"></a><span class="lineno"> 308</span> opb.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a> = rs2;</div> +<div class="line"><a id="l00309" name="l00309"></a><span class="lineno"> 309</span> </div> +<div class="line"><a id="l00310" name="l00310"></a><span class="lineno"> 310</span> <span class="keywordflow">return</span> CUSTOM_INSTR_R3_TYPE(0b1010000, opb.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a>, opa.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a>, 0b000, 0b1010011);</div> +<div class="line"><a id="l00311" name="l00311"></a><span class="lineno"> 311</span>}</div> +</div> +<div class="line"><a id="l00312" name="l00312"></a><span class="lineno"> 312</span> </div> +<div class="line"><a id="l00313" name="l00313"></a><span class="lineno"> 313</span> </div> +<div class="line"><a id="l00314" name="l00314"></a><span class="lineno"> 314</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen00321" data-start="{" data-end="}"> +<div class="line"><a id="l00321" name="l00321"></a><span class="lineno"><a class="line" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#aff3acd90bcfbda96945f95a0e0bae12b"> 321</a></span><span class="keyword">inline</span> <span class="keywordtype">float</span> __attribute__ ((always_inline)) riscv_intrinsic_fsgnjs(<span class="keywordtype">float</span> rs1, <span class="keywordtype">float</span> rs2) {</div> +<div class="line"><a id="l00322" name="l00322"></a><span class="lineno"> 322</span> </div> +<div class="line"><a id="l00323" name="l00323"></a><span class="lineno"> 323</span> <a class="code hl_union" href="unionfloat__conv__t.html">float_conv_t</a> opa, opb, res;</div> +<div class="line"><a id="l00324" name="l00324"></a><span class="lineno"> 324</span> opa.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a> = rs1;</div> +<div class="line"><a id="l00325" name="l00325"></a><span class="lineno"> 325</span> opb.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a> = rs2;</div> +<div class="line"><a id="l00326" name="l00326"></a><span class="lineno"> 326</span> </div> +<div class="line"><a id="l00327" name="l00327"></a><span class="lineno"> 327</span> res.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a> = CUSTOM_INSTR_R3_TYPE(0b0010000, opb.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a>, opa.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a>, 0b000, 0b1010011);</div> +<div class="line"><a id="l00328" name="l00328"></a><span class="lineno"> 328</span> <span class="keywordflow">return</span> res.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a>;</div> +<div class="line"><a id="l00329" name="l00329"></a><span class="lineno"> 329</span>}</div> +</div> +<div class="line"><a id="l00330" name="l00330"></a><span class="lineno"> 330</span> </div> +<div class="line"><a id="l00331" name="l00331"></a><span class="lineno"> 331</span> </div> +<div class="line"><a id="l00332" name="l00332"></a><span class="lineno"> 332</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen00339" data-start="{" data-end="}"> +<div class="line"><a id="l00339" name="l00339"></a><span class="lineno"><a class="line" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#aa4010772a986d03929ba7a43dfdcddd9"> 339</a></span><span class="keyword">inline</span> <span class="keywordtype">float</span> __attribute__ ((always_inline)) riscv_intrinsic_fsgnjns(<span class="keywordtype">float</span> rs1, <span class="keywordtype">float</span> rs2) {</div> +<div class="line"><a id="l00340" name="l00340"></a><span class="lineno"> 340</span> </div> +<div class="line"><a id="l00341" name="l00341"></a><span class="lineno"> 341</span> <a class="code hl_union" href="unionfloat__conv__t.html">float_conv_t</a> opa, opb, res;</div> +<div class="line"><a id="l00342" name="l00342"></a><span class="lineno"> 342</span> opa.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a> = rs1;</div> +<div class="line"><a id="l00343" name="l00343"></a><span class="lineno"> 343</span> opb.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a> = rs2;</div> +<div class="line"><a id="l00344" name="l00344"></a><span class="lineno"> 344</span> </div> +<div class="line"><a id="l00345" name="l00345"></a><span class="lineno"> 345</span> res.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a> = CUSTOM_INSTR_R3_TYPE(0b0010000, opb.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a>, opa.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a>, 0b001, 0b1010011);</div> +<div class="line"><a id="l00346" name="l00346"></a><span class="lineno"> 346</span> <span class="keywordflow">return</span> res.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a>;</div> +<div class="line"><a id="l00347" name="l00347"></a><span class="lineno"> 347</span>}</div> +</div> +<div class="line"><a id="l00348" name="l00348"></a><span class="lineno"> 348</span> </div> +<div class="line"><a id="l00349" name="l00349"></a><span class="lineno"> 349</span> </div> +<div class="line"><a id="l00350" name="l00350"></a><span class="lineno"> 350</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen00357" data-start="{" data-end="}"> +<div class="line"><a id="l00357" name="l00357"></a><span class="lineno"><a class="line" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a2235d91cdac03bf8071003a5c59b9dd0"> 357</a></span><span class="keyword">inline</span> <span class="keywordtype">float</span> __attribute__ ((always_inline)) riscv_intrinsic_fsgnjxs(<span class="keywordtype">float</span> rs1, <span class="keywordtype">float</span> rs2) {</div> +<div class="line"><a id="l00358" name="l00358"></a><span class="lineno"> 358</span> </div> +<div class="line"><a id="l00359" name="l00359"></a><span class="lineno"> 359</span> <a class="code hl_union" href="unionfloat__conv__t.html">float_conv_t</a> opa, opb, res;</div> +<div class="line"><a id="l00360" name="l00360"></a><span class="lineno"> 360</span> opa.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a> = rs1;</div> +<div class="line"><a id="l00361" name="l00361"></a><span class="lineno"> 361</span> opb.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a> = rs2;</div> +<div class="line"><a id="l00362" name="l00362"></a><span class="lineno"> 362</span> </div> +<div class="line"><a id="l00363" name="l00363"></a><span class="lineno"> 363</span> res.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a> = CUSTOM_INSTR_R3_TYPE(0b0010000, opb.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a>, opa.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a>, 0b010, 0b1010011);</div> +<div class="line"><a id="l00364" name="l00364"></a><span class="lineno"> 364</span> <span class="keywordflow">return</span> res.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a>;</div> +<div class="line"><a id="l00365" name="l00365"></a><span class="lineno"> 365</span>}</div> +</div> +<div class="line"><a id="l00366" name="l00366"></a><span class="lineno"> 366</span> </div> +<div class="line"><a id="l00367" name="l00367"></a><span class="lineno"> 367</span> </div> +<div class="line"><a id="l00368" name="l00368"></a><span class="lineno"> 368</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen00374" data-start="{" data-end="}"> +<div class="line"><a id="l00374" name="l00374"></a><span class="lineno"><a class="line" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a3064a5c57b5f45d57c4d19eb798724f6"> 374</a></span><span class="keyword">inline</span> uint32_t __attribute__ ((always_inline)) riscv_intrinsic_fclasss(<span class="keywordtype">float</span> rs1) {</div> +<div class="line"><a id="l00375" name="l00375"></a><span class="lineno"> 375</span> </div> +<div class="line"><a id="l00376" name="l00376"></a><span class="lineno"> 376</span> <a class="code hl_union" href="unionfloat__conv__t.html">float_conv_t</a> opa;</div> +<div class="line"><a id="l00377" name="l00377"></a><span class="lineno"> 377</span> opa.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a> = rs1;</div> +<div class="line"><a id="l00378" name="l00378"></a><span class="lineno"> 378</span> </div> +<div class="line"><a id="l00379" name="l00379"></a><span class="lineno"> 379</span> <span class="keywordflow">return</span> CUSTOM_INSTR_R2_TYPE(0b1110000, 0b00000, opa.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a>, 0b001, 0b1010011);</div> +<div class="line"><a id="l00380" name="l00380"></a><span class="lineno"> 380</span>}</div> +</div> +<div class="line"><a id="l00381" name="l00381"></a><span class="lineno"> 381</span> </div> +<div class="line"><a id="l00382" name="l00382"></a><span class="lineno"> 382</span> </div> +<div class="line"><a id="l00383" name="l00383"></a><span class="lineno"> 383</span><span class="comment">// ################################################################################################</span></div> +<div class="line"><a id="l00384" name="l00384"></a><span class="lineno"> 384</span><span class="comment">// !!! UNSUPPORTED instructions !!!</span></div> +<div class="line"><a id="l00385" name="l00385"></a><span class="lineno"> 385</span><span class="comment">// ################################################################################################</span></div> +<div class="line"><a id="l00386" name="l00386"></a><span class="lineno"> 386</span> </div> +<div class="line"><a id="l00387" name="l00387"></a><span class="lineno"> 387</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen00396" data-start="{" data-end="}"> +<div class="line"><a id="l00396" name="l00396"></a><span class="lineno"><a class="line" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#ab6a9d15643e3085ff80c7883f183a42b"> 396</a></span><span class="keyword">inline</span> <span class="keywordtype">float</span> __attribute__ ((always_inline)) riscv_intrinsic_fdivs(<span class="keywordtype">float</span> rs1, <span class="keywordtype">float</span> rs2) {</div> +<div class="line"><a id="l00397" name="l00397"></a><span class="lineno"> 397</span> </div> +<div class="line"><a id="l00398" name="l00398"></a><span class="lineno"> 398</span> <a class="code hl_union" href="unionfloat__conv__t.html">float_conv_t</a> opa, opb, res;</div> +<div class="line"><a id="l00399" name="l00399"></a><span class="lineno"> 399</span> opa.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a> = rs1;</div> +<div class="line"><a id="l00400" name="l00400"></a><span class="lineno"> 400</span> opb.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a> = rs2;</div> +<div class="line"><a id="l00401" name="l00401"></a><span class="lineno"> 401</span> </div> +<div class="line"><a id="l00402" name="l00402"></a><span class="lineno"> 402</span> res.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a> = CUSTOM_INSTR_R3_TYPE(0b0001100, opb.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a>, opa.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a>, 0b000, 0b1010011);</div> +<div class="line"><a id="l00403" name="l00403"></a><span class="lineno"> 403</span> <span class="keywordflow">return</span> res.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a>;</div> +<div class="line"><a id="l00404" name="l00404"></a><span class="lineno"> 404</span>}</div> +</div> +<div class="line"><a id="l00405" name="l00405"></a><span class="lineno"> 405</span> </div> +<div class="line"><a id="l00406" name="l00406"></a><span class="lineno"> 406</span> </div> +<div class="line"><a id="l00407" name="l00407"></a><span class="lineno"> 407</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen00415" data-start="{" data-end="}"> +<div class="line"><a id="l00415" name="l00415"></a><span class="lineno"><a class="line" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a17e2b7a399c956d548a609185084ea3c"> 415</a></span><span class="keyword">inline</span> <span class="keywordtype">float</span> __attribute__ ((always_inline)) riscv_intrinsic_fsqrts(<span class="keywordtype">float</span> rs1) {</div> +<div class="line"><a id="l00416" name="l00416"></a><span class="lineno"> 416</span> </div> +<div class="line"><a id="l00417" name="l00417"></a><span class="lineno"> 417</span> <a class="code hl_union" href="unionfloat__conv__t.html">float_conv_t</a> opa, res;</div> +<div class="line"><a id="l00418" name="l00418"></a><span class="lineno"> 418</span> opa.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a> = rs1;</div> +<div class="line"><a id="l00419" name="l00419"></a><span class="lineno"> 419</span> </div> +<div class="line"><a id="l00420" name="l00420"></a><span class="lineno"> 420</span> res.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a> = CUSTOM_INSTR_R2_TYPE(0b0101100, 0b00000, opa.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a>, 0b000, 0b1010011);</div> +<div class="line"><a id="l00421" name="l00421"></a><span class="lineno"> 421</span> <span class="keywordflow">return</span> res.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a>;</div> +<div class="line"><a id="l00422" name="l00422"></a><span class="lineno"> 422</span>}</div> +</div> +<div class="line"><a id="l00423" name="l00423"></a><span class="lineno"> 423</span> </div> +<div class="line"><a id="l00424" name="l00424"></a><span class="lineno"> 424</span> </div> +<div class="line"><a id="l00425" name="l00425"></a><span class="lineno"> 425</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen00435" data-start="{" data-end="}"> +<div class="line"><a id="l00435" name="l00435"></a><span class="lineno"><a class="line" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#abbdb403cdeef414fa2f867b702d5f6eb"> 435</a></span><span class="keyword">inline</span> <span class="keywordtype">float</span> __attribute__ ((always_inline)) riscv_intrinsic_fmadds(<span class="keywordtype">float</span> rs1, <span class="keywordtype">float</span> rs2, <span class="keywordtype">float</span> rs3) {</div> +<div class="line"><a id="l00436" name="l00436"></a><span class="lineno"> 436</span> </div> +<div class="line"><a id="l00437" name="l00437"></a><span class="lineno"> 437</span> <a class="code hl_union" href="unionfloat__conv__t.html">float_conv_t</a> opa, opb, opc, res;</div> +<div class="line"><a id="l00438" name="l00438"></a><span class="lineno"> 438</span> opa.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a> = rs1;</div> +<div class="line"><a id="l00439" name="l00439"></a><span class="lineno"> 439</span> opb.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a> = rs2;</div> +<div class="line"><a id="l00440" name="l00440"></a><span class="lineno"> 440</span> opc.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a> = rs3;</div> +<div class="line"><a id="l00441" name="l00441"></a><span class="lineno"> 441</span> </div> +<div class="line"><a id="l00442" name="l00442"></a><span class="lineno"> 442</span> res.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a> = CUSTOM_INSTR_R4_TYPE(opc.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a>, opb.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a>, opa.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a>, 0b000, 0b1000011);</div> +<div class="line"><a id="l00443" name="l00443"></a><span class="lineno"> 443</span> <span class="keywordflow">return</span> res.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a>;</div> +<div class="line"><a id="l00444" name="l00444"></a><span class="lineno"> 444</span>}</div> +</div> +<div class="line"><a id="l00445" name="l00445"></a><span class="lineno"> 445</span> </div> +<div class="line"><a id="l00446" name="l00446"></a><span class="lineno"> 446</span> </div> +<div class="line"><a id="l00447" name="l00447"></a><span class="lineno"> 447</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen00457" data-start="{" data-end="}"> +<div class="line"><a id="l00457" name="l00457"></a><span class="lineno"><a class="line" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a03aba9c70c5286dacebaeb0ef5219cc9"> 457</a></span><span class="keyword">inline</span> <span class="keywordtype">float</span> __attribute__ ((always_inline)) riscv_intrinsic_fmsubs(<span class="keywordtype">float</span> rs1, <span class="keywordtype">float</span> rs2, <span class="keywordtype">float</span> rs3) {</div> +<div class="line"><a id="l00458" name="l00458"></a><span class="lineno"> 458</span> </div> +<div class="line"><a id="l00459" name="l00459"></a><span class="lineno"> 459</span> <a class="code hl_union" href="unionfloat__conv__t.html">float_conv_t</a> opa, opb, opc, res;</div> +<div class="line"><a id="l00460" name="l00460"></a><span class="lineno"> 460</span> opa.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a> = rs1;</div> +<div class="line"><a id="l00461" name="l00461"></a><span class="lineno"> 461</span> opb.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a> = rs2;</div> +<div class="line"><a id="l00462" name="l00462"></a><span class="lineno"> 462</span> opc.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a> = rs3;</div> +<div class="line"><a id="l00463" name="l00463"></a><span class="lineno"> 463</span> </div> +<div class="line"><a id="l00464" name="l00464"></a><span class="lineno"> 464</span> res.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a> = CUSTOM_INSTR_R4_TYPE(opc.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a>, opb.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a>, opa.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a>, 0b000, 0b1000111);</div> +<div class="line"><a id="l00465" name="l00465"></a><span class="lineno"> 465</span> <span class="keywordflow">return</span> res.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a>;</div> +<div class="line"><a id="l00466" name="l00466"></a><span class="lineno"> 466</span>}</div> +</div> +<div class="line"><a id="l00467" name="l00467"></a><span class="lineno"> 467</span> </div> +<div class="line"><a id="l00468" name="l00468"></a><span class="lineno"> 468</span> </div> +<div class="line"><a id="l00469" name="l00469"></a><span class="lineno"> 469</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen00479" data-start="{" data-end="}"> +<div class="line"><a id="l00479" name="l00479"></a><span class="lineno"><a class="line" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a639fc7bd75933888540e9cceb67221a0"> 479</a></span><span class="keyword">inline</span> <span class="keywordtype">float</span> __attribute__ ((always_inline)) riscv_intrinsic_fnmsubs(<span class="keywordtype">float</span> rs1, <span class="keywordtype">float</span> rs2, <span class="keywordtype">float</span> rs3) {</div> +<div class="line"><a id="l00480" name="l00480"></a><span class="lineno"> 480</span> </div> +<div class="line"><a id="l00481" name="l00481"></a><span class="lineno"> 481</span> <a class="code hl_union" href="unionfloat__conv__t.html">float_conv_t</a> opa, opb, opc, res;</div> +<div class="line"><a id="l00482" name="l00482"></a><span class="lineno"> 482</span> opa.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a> = rs1;</div> +<div class="line"><a id="l00483" name="l00483"></a><span class="lineno"> 483</span> opb.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a> = rs2;</div> +<div class="line"><a id="l00484" name="l00484"></a><span class="lineno"> 484</span> opc.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a> = rs3;</div> +<div class="line"><a id="l00485" name="l00485"></a><span class="lineno"> 485</span> </div> +<div class="line"><a id="l00486" name="l00486"></a><span class="lineno"> 486</span> res.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a> = CUSTOM_INSTR_R4_TYPE(opc.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a>, opb.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a>, opa.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a>, 0b000, 0b1001011);</div> +<div class="line"><a id="l00487" name="l00487"></a><span class="lineno"> 487</span> <span class="keywordflow">return</span> res.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a>;</div> +<div class="line"><a id="l00488" name="l00488"></a><span class="lineno"> 488</span>}</div> +</div> +<div class="line"><a id="l00489" name="l00489"></a><span class="lineno"> 489</span> </div> +<div class="line"><a id="l00490" name="l00490"></a><span class="lineno"> 490</span> </div> +<div class="line"><a id="l00491" name="l00491"></a><span class="lineno"> 491</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen00501" data-start="{" data-end="}"> +<div class="line"><a id="l00501" name="l00501"></a><span class="lineno"><a class="line" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#aa6473bc2d2721b57277b83a3ae0cfdb6"> 501</a></span><span class="keyword">inline</span> <span class="keywordtype">float</span> __attribute__ ((always_inline)) riscv_intrinsic_fnmadds(<span class="keywordtype">float</span> rs1, <span class="keywordtype">float</span> rs2, <span class="keywordtype">float</span> rs3) {</div> +<div class="line"><a id="l00502" name="l00502"></a><span class="lineno"> 502</span> </div> +<div class="line"><a id="l00503" name="l00503"></a><span class="lineno"> 503</span> <a class="code hl_union" href="unionfloat__conv__t.html">float_conv_t</a> opa, opb, opc, res;</div> +<div class="line"><a id="l00504" name="l00504"></a><span class="lineno"> 504</span> opa.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a> = rs1;</div> +<div class="line"><a id="l00505" name="l00505"></a><span class="lineno"> 505</span> opb.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a> = rs2;</div> +<div class="line"><a id="l00506" name="l00506"></a><span class="lineno"> 506</span> opc.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a> = rs3;</div> +<div class="line"><a id="l00507" name="l00507"></a><span class="lineno"> 507</span> </div> +<div class="line"><a id="l00508" name="l00508"></a><span class="lineno"> 508</span> res.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a> = CUSTOM_INSTR_R4_TYPE(opc.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a>, opb.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a>, opa.<a class="code hl_variable" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">binary_value</a>, 0b000, 0b1001111);</div> +<div class="line"><a id="l00509" name="l00509"></a><span class="lineno"> 509</span> <span class="keywordflow">return</span> res.<a class="code hl_variable" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a>;</div> +<div class="line"><a id="l00510" name="l00510"></a><span class="lineno"> 510</span>}</div> +</div> +<div class="line"><a id="l00511" name="l00511"></a><span class="lineno"> 511</span> </div> +<div class="line"><a id="l00512" name="l00512"></a><span class="lineno"> 512</span> </div> +<div class="line"><a id="l00513" name="l00513"></a><span class="lineno"> 513</span><span class="comment">// ################################################################################################</span></div> +<div class="line"><a id="l00514" name="l00514"></a><span class="lineno"> 514</span><span class="comment">// Emulation functions</span></div> +<div class="line"><a id="l00515" name="l00515"></a><span class="lineno"> 515</span><span class="comment">// ################################################################################################</span></div> +<div class="line"><a id="l00516" name="l00516"></a><span class="lineno"> 516</span> </div> +<div class="line"><a id="l00517" name="l00517"></a><span class="lineno"> 517</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen00524" data-start="{" data-end="}"> +<div class="line"><a id="l00524" name="l00524"></a><span class="lineno"><a class="line" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a9d676567276439875c9b1a15b892b555"> 524</a></span><span class="keywordtype">float</span> __attribute__ ((noinline)) riscv_emulate_fadds(<span class="keywordtype">float</span> rs1, <span class="keywordtype">float</span> rs2) {</div> +<div class="line"><a id="l00525" name="l00525"></a><span class="lineno"> 525</span> </div> +<div class="line"><a id="l00526" name="l00526"></a><span class="lineno"> 526</span> <span class="keywordtype">float</span> opa = subnormal_flush(rs1);</div> +<div class="line"><a id="l00527" name="l00527"></a><span class="lineno"> 527</span> <span class="keywordtype">float</span> opb = subnormal_flush(rs2);</div> +<div class="line"><a id="l00528" name="l00528"></a><span class="lineno"> 528</span> </div> +<div class="line"><a id="l00529" name="l00529"></a><span class="lineno"> 529</span> <span class="keywordtype">float</span> res = opa + opb;</div> +<div class="line"><a id="l00530" name="l00530"></a><span class="lineno"> 530</span> </div> +<div class="line"><a id="l00531" name="l00531"></a><span class="lineno"> 531</span> <span class="comment">// make NAN canonical</span></div> +<div class="line"><a id="l00532" name="l00532"></a><span class="lineno"> 532</span> <span class="keywordflow">if</span> (fpclassify(res) == FP_NAN) {</div> +<div class="line"><a id="l00533" name="l00533"></a><span class="lineno"> 533</span> res = NAN;</div> +<div class="line"><a id="l00534" name="l00534"></a><span class="lineno"> 534</span> }</div> +<div class="line"><a id="l00535" name="l00535"></a><span class="lineno"> 535</span> </div> +<div class="line"><a id="l00536" name="l00536"></a><span class="lineno"> 536</span> <span class="keywordflow">return</span> subnormal_flush(res);</div> +<div class="line"><a id="l00537" name="l00537"></a><span class="lineno"> 537</span>}</div> +</div> +<div class="line"><a id="l00538" name="l00538"></a><span class="lineno"> 538</span> </div> +<div class="line"><a id="l00539" name="l00539"></a><span class="lineno"> 539</span> </div> +<div class="line"><a id="l00540" name="l00540"></a><span class="lineno"> 540</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen00547" data-start="{" data-end="}"> +<div class="line"><a id="l00547" name="l00547"></a><span class="lineno"><a class="line" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#ace5d95b855ec1aa8eacdb5bbeea58197"> 547</a></span><span class="keywordtype">float</span> __attribute__ ((noinline)) riscv_emulate_fsubs(<span class="keywordtype">float</span> rs1, <span class="keywordtype">float</span> rs2) {</div> +<div class="line"><a id="l00548" name="l00548"></a><span class="lineno"> 548</span> </div> +<div class="line"><a id="l00549" name="l00549"></a><span class="lineno"> 549</span> <span class="keywordtype">float</span> opa = subnormal_flush(rs1);</div> +<div class="line"><a id="l00550" name="l00550"></a><span class="lineno"> 550</span> <span class="keywordtype">float</span> opb = subnormal_flush(rs2);</div> +<div class="line"><a id="l00551" name="l00551"></a><span class="lineno"> 551</span> </div> +<div class="line"><a id="l00552" name="l00552"></a><span class="lineno"> 552</span> <span class="keywordtype">float</span> res = opa - opb;</div> +<div class="line"><a id="l00553" name="l00553"></a><span class="lineno"> 553</span> </div> +<div class="line"><a id="l00554" name="l00554"></a><span class="lineno"> 554</span> <span class="comment">// make NAN canonical</span></div> +<div class="line"><a id="l00555" name="l00555"></a><span class="lineno"> 555</span> <span class="keywordflow">if</span> (fpclassify(res) == FP_NAN) {</div> +<div class="line"><a id="l00556" name="l00556"></a><span class="lineno"> 556</span> res = NAN;</div> +<div class="line"><a id="l00557" name="l00557"></a><span class="lineno"> 557</span> }</div> +<div class="line"><a id="l00558" name="l00558"></a><span class="lineno"> 558</span> </div> +<div class="line"><a id="l00559" name="l00559"></a><span class="lineno"> 559</span> <span class="keywordflow">return</span> subnormal_flush(res);</div> +<div class="line"><a id="l00560" name="l00560"></a><span class="lineno"> 560</span>}</div> +</div> +<div class="line"><a id="l00561" name="l00561"></a><span class="lineno"> 561</span> </div> +<div class="line"><a id="l00562" name="l00562"></a><span class="lineno"> 562</span> </div> +<div class="line"><a id="l00563" name="l00563"></a><span class="lineno"> 563</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen00570" data-start="{" data-end="}"> +<div class="line"><a id="l00570" name="l00570"></a><span class="lineno"><a class="line" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#ad43e8bdf4a6fbe229d22d24680f2be80"> 570</a></span><span class="keywordtype">float</span> __attribute__ ((noinline)) riscv_emulate_fmuls(<span class="keywordtype">float</span> rs1, <span class="keywordtype">float</span> rs2) {</div> +<div class="line"><a id="l00571" name="l00571"></a><span class="lineno"> 571</span> </div> +<div class="line"><a id="l00572" name="l00572"></a><span class="lineno"> 572</span> <span class="keywordtype">float</span> opa = subnormal_flush(rs1);</div> +<div class="line"><a id="l00573" name="l00573"></a><span class="lineno"> 573</span> <span class="keywordtype">float</span> opb = subnormal_flush(rs2);</div> +<div class="line"><a id="l00574" name="l00574"></a><span class="lineno"> 574</span> </div> +<div class="line"><a id="l00575" name="l00575"></a><span class="lineno"> 575</span> <span class="keywordtype">float</span> res = opa * opb;</div> +<div class="line"><a id="l00576" name="l00576"></a><span class="lineno"> 576</span> <span class="keywordflow">return</span> subnormal_flush(res);</div> +<div class="line"><a id="l00577" name="l00577"></a><span class="lineno"> 577</span>}</div> +</div> +<div class="line"><a id="l00578" name="l00578"></a><span class="lineno"> 578</span> </div> +<div class="line"><a id="l00579" name="l00579"></a><span class="lineno"> 579</span> </div> +<div class="line"><a id="l00580" name="l00580"></a><span class="lineno"> 580</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen00587" data-start="{" data-end="}"> +<div class="line"><a id="l00587" name="l00587"></a><span class="lineno"><a class="line" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a872cd30fb61190bd1ac719d25b01f5a3"> 587</a></span><span class="keywordtype">float</span> __attribute__ ((noinline)) riscv_emulate_fmins(<span class="keywordtype">float</span> rs1, <span class="keywordtype">float</span> rs2) {</div> +<div class="line"><a id="l00588" name="l00588"></a><span class="lineno"> 588</span> </div> +<div class="line"><a id="l00589" name="l00589"></a><span class="lineno"> 589</span> <span class="keywordtype">float</span> opa = subnormal_flush(rs1);</div> +<div class="line"><a id="l00590" name="l00590"></a><span class="lineno"> 590</span> <span class="keywordtype">float</span> opb = subnormal_flush(rs2);</div> +<div class="line"><a id="l00591" name="l00591"></a><span class="lineno"> 591</span> </div> +<div class="line"><a id="l00592" name="l00592"></a><span class="lineno"> 592</span> <span class="keyword">union </span>{</div> +<div class="line"><a id="l00593" name="l00593"></a><span class="lineno"> 593</span> uint32_t binary_value; </div> +<div class="line"><a id="l00594" name="l00594"></a><span class="lineno"> 594</span> <span class="keywordtype">float</span> float_value; </div> +<div class="line"><a id="l00595" name="l00595"></a><span class="lineno"> 595</span> } tmp_a, tmp_b;</div> +<div class="line"><a id="l00596" name="l00596"></a><span class="lineno"> 596</span> </div> +<div class="line"><a id="l00597" name="l00597"></a><span class="lineno"> 597</span> <span class="keywordflow">if</span> ((fpclassify(opa) == FP_NAN) &amp;&amp; (fpclassify(opb) == FP_NAN)) {</div> +<div class="line"><a id="l00598" name="l00598"></a><span class="lineno"> 598</span> <span class="keywordflow">return</span> nanf(<span class="stringliteral">&quot;&quot;</span>);</div> +<div class="line"><a id="l00599" name="l00599"></a><span class="lineno"> 599</span> }</div> +<div class="line"><a id="l00600" name="l00600"></a><span class="lineno"> 600</span> </div> +<div class="line"><a id="l00601" name="l00601"></a><span class="lineno"> 601</span> <span class="keywordflow">if</span> (fpclassify(opa) == FP_NAN) {</div> +<div class="line"><a id="l00602" name="l00602"></a><span class="lineno"> 602</span> <span class="keywordflow">return</span> opb;</div> +<div class="line"><a id="l00603" name="l00603"></a><span class="lineno"> 603</span> }</div> +<div class="line"><a id="l00604" name="l00604"></a><span class="lineno"> 604</span> </div> +<div class="line"><a id="l00605" name="l00605"></a><span class="lineno"> 605</span> <span class="keywordflow">if</span> (fpclassify(opb) == FP_NAN) {</div> +<div class="line"><a id="l00606" name="l00606"></a><span class="lineno"> 606</span> <span class="keywordflow">return</span> opa;</div> +<div class="line"><a id="l00607" name="l00607"></a><span class="lineno"> 607</span> }</div> +<div class="line"><a id="l00608" name="l00608"></a><span class="lineno"> 608</span> </div> +<div class="line"><a id="l00609" name="l00609"></a><span class="lineno"> 609</span> <span class="comment">// RISC-V spec: -0 &lt; +0</span></div> +<div class="line"><a id="l00610" name="l00610"></a><span class="lineno"> 610</span> tmp_a.float_value = opa;</div> +<div class="line"><a id="l00611" name="l00611"></a><span class="lineno"> 611</span> tmp_b.float_value = opb;</div> +<div class="line"><a id="l00612" name="l00612"></a><span class="lineno"> 612</span> <span class="keywordflow">if</span> (((tmp_a.binary_value == 0x80000000) &amp;&amp; (tmp_b.binary_value == 0x00000000)) ||</div> +<div class="line"><a id="l00613" name="l00613"></a><span class="lineno"> 613</span> ((tmp_a.binary_value == 0x00000000) &amp;&amp; (tmp_b.binary_value == 0x80000000))) {</div> +<div class="line"><a id="l00614" name="l00614"></a><span class="lineno"> 614</span> <span class="keywordflow">return</span> -0.0f;</div> +<div class="line"><a id="l00615" name="l00615"></a><span class="lineno"> 615</span> }</div> +<div class="line"><a id="l00616" name="l00616"></a><span class="lineno"> 616</span> </div> +<div class="line"><a id="l00617" name="l00617"></a><span class="lineno"> 617</span> <span class="keywordflow">return</span> fmin(opa, opb);</div> +<div class="line"><a id="l00618" name="l00618"></a><span class="lineno"> 618</span>}</div> +</div> +<div class="line"><a id="l00619" name="l00619"></a><span class="lineno"> 619</span> </div> +<div class="line"><a id="l00620" name="l00620"></a><span class="lineno"> 620</span> </div> +<div class="line"><a id="l00621" name="l00621"></a><span class="lineno"> 621</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen00628" data-start="{" data-end="}"> +<div class="line"><a id="l00628" name="l00628"></a><span class="lineno"><a class="line" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#af9b16a32d2bb13c8af5a678271d74889"> 628</a></span><span class="keywordtype">float</span> __attribute__ ((noinline)) riscv_emulate_fmaxs(<span class="keywordtype">float</span> rs1, <span class="keywordtype">float</span> rs2) {</div> +<div class="line"><a id="l00629" name="l00629"></a><span class="lineno"> 629</span> </div> +<div class="line"><a id="l00630" name="l00630"></a><span class="lineno"> 630</span> <span class="keywordtype">float</span> opa = subnormal_flush(rs1);</div> +<div class="line"><a id="l00631" name="l00631"></a><span class="lineno"> 631</span> <span class="keywordtype">float</span> opb = subnormal_flush(rs2);</div> +<div class="line"><a id="l00632" name="l00632"></a><span class="lineno"> 632</span> </div> +<div class="line"><a id="l00633" name="l00633"></a><span class="lineno"> 633</span> <span class="keyword">union </span>{</div> +<div class="line"><a id="l00634" name="l00634"></a><span class="lineno"> 634</span> uint32_t binary_value; </div> +<div class="line"><a id="l00635" name="l00635"></a><span class="lineno"> 635</span> <span class="keywordtype">float</span> float_value; </div> +<div class="line"><a id="l00636" name="l00636"></a><span class="lineno"> 636</span> } tmp_a, tmp_b;</div> +<div class="line"><a id="l00637" name="l00637"></a><span class="lineno"> 637</span> </div> +<div class="line"><a id="l00638" name="l00638"></a><span class="lineno"> 638</span> </div> +<div class="line"><a id="l00639" name="l00639"></a><span class="lineno"> 639</span> <span class="keywordflow">if</span> ((fpclassify(opa) == FP_NAN) &amp;&amp; (fpclassify(opb) == FP_NAN)) {</div> +<div class="line"><a id="l00640" name="l00640"></a><span class="lineno"> 640</span> <span class="keywordflow">return</span> nanf(<span class="stringliteral">&quot;&quot;</span>);</div> +<div class="line"><a id="l00641" name="l00641"></a><span class="lineno"> 641</span> }</div> +<div class="line"><a id="l00642" name="l00642"></a><span class="lineno"> 642</span> </div> +<div class="line"><a id="l00643" name="l00643"></a><span class="lineno"> 643</span> <span class="keywordflow">if</span> (fpclassify(opa) == FP_NAN) {</div> +<div class="line"><a id="l00644" name="l00644"></a><span class="lineno"> 644</span> <span class="keywordflow">return</span> opb;</div> +<div class="line"><a id="l00645" name="l00645"></a><span class="lineno"> 645</span> }</div> +<div class="line"><a id="l00646" name="l00646"></a><span class="lineno"> 646</span> </div> +<div class="line"><a id="l00647" name="l00647"></a><span class="lineno"> 647</span> <span class="keywordflow">if</span> (fpclassify(opb) == FP_NAN) {</div> +<div class="line"><a id="l00648" name="l00648"></a><span class="lineno"> 648</span> <span class="keywordflow">return</span> opa;</div> +<div class="line"><a id="l00649" name="l00649"></a><span class="lineno"> 649</span> }</div> +<div class="line"><a id="l00650" name="l00650"></a><span class="lineno"> 650</span> </div> +<div class="line"><a id="l00651" name="l00651"></a><span class="lineno"> 651</span> <span class="comment">// RISC-V spec: -0 &lt; +0</span></div> +<div class="line"><a id="l00652" name="l00652"></a><span class="lineno"> 652</span> tmp_a.float_value = opa;</div> +<div class="line"><a id="l00653" name="l00653"></a><span class="lineno"> 653</span> tmp_b.float_value = opb;</div> +<div class="line"><a id="l00654" name="l00654"></a><span class="lineno"> 654</span> <span class="keywordflow">if</span> (((tmp_a.binary_value == 0x80000000) &amp;&amp; (tmp_b.binary_value == 0x00000000)) ||</div> +<div class="line"><a id="l00655" name="l00655"></a><span class="lineno"> 655</span> ((tmp_a.binary_value == 0x00000000) &amp;&amp; (tmp_b.binary_value == 0x80000000))) {</div> +<div class="line"><a id="l00656" name="l00656"></a><span class="lineno"> 656</span> <span class="keywordflow">return</span> +0.0f;</div> +<div class="line"><a id="l00657" name="l00657"></a><span class="lineno"> 657</span> }</div> +<div class="line"><a id="l00658" name="l00658"></a><span class="lineno"> 658</span> </div> +<div class="line"><a id="l00659" name="l00659"></a><span class="lineno"> 659</span> <span class="keywordflow">return</span> fmax(opa, opb);</div> +<div class="line"><a id="l00660" name="l00660"></a><span class="lineno"> 660</span>}</div> +</div> +<div class="line"><a id="l00661" name="l00661"></a><span class="lineno"> 661</span> </div> +<div class="line"><a id="l00662" name="l00662"></a><span class="lineno"> 662</span> </div> +<div class="line"><a id="l00663" name="l00663"></a><span class="lineno"> 663</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen00669" data-start="{" data-end="}"> +<div class="line"><a id="l00669" name="l00669"></a><span class="lineno"><a class="line" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#aad9fc7337e09081cf8c5bff8c28776c8"> 669</a></span>uint32_t __attribute__ ((noinline)) riscv_emulate_fcvt_wus(<span class="keywordtype">float</span> rs1) {</div> +<div class="line"><a id="l00670" name="l00670"></a><span class="lineno"> 670</span> </div> +<div class="line"><a id="l00671" name="l00671"></a><span class="lineno"> 671</span> <span class="keywordtype">float</span> opa = subnormal_flush(rs1);</div> +<div class="line"><a id="l00672" name="l00672"></a><span class="lineno"> 672</span> </div> +<div class="line"><a id="l00673" name="l00673"></a><span class="lineno"> 673</span> <span class="keywordflow">return</span> (uint32_t)rint(opa);</div> +<div class="line"><a id="l00674" name="l00674"></a><span class="lineno"> 674</span>}</div> +</div> +<div class="line"><a id="l00675" name="l00675"></a><span class="lineno"> 675</span> </div> +<div class="line"><a id="l00676" name="l00676"></a><span class="lineno"> 676</span> </div> +<div class="line"><a id="l00677" name="l00677"></a><span class="lineno"> 677</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen00683" data-start="{" data-end="}"> +<div class="line"><a id="l00683" name="l00683"></a><span class="lineno"><a class="line" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a292365fe41a7a661e61ae746306ba5e9"> 683</a></span>int32_t __attribute__ ((noinline)) riscv_emulate_fcvt_ws(<span class="keywordtype">float</span> rs1) {</div> +<div class="line"><a id="l00684" name="l00684"></a><span class="lineno"> 684</span> </div> +<div class="line"><a id="l00685" name="l00685"></a><span class="lineno"> 685</span> <span class="keywordtype">float</span> opa = subnormal_flush(rs1);</div> +<div class="line"><a id="l00686" name="l00686"></a><span class="lineno"> 686</span> </div> +<div class="line"><a id="l00687" name="l00687"></a><span class="lineno"> 687</span> <span class="keywordflow">return</span> (int32_t)rint(opa);</div> +<div class="line"><a id="l00688" name="l00688"></a><span class="lineno"> 688</span>}</div> +</div> +<div class="line"><a id="l00689" name="l00689"></a><span class="lineno"> 689</span> </div> +<div class="line"><a id="l00690" name="l00690"></a><span class="lineno"> 690</span> </div> +<div class="line"><a id="l00691" name="l00691"></a><span class="lineno"> 691</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen00697" data-start="{" data-end="}"> +<div class="line"><a id="l00697" name="l00697"></a><span class="lineno"><a class="line" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a10a05bface37bff32c78ed0746845794"> 697</a></span><span class="keywordtype">float</span> __attribute__ ((noinline)) riscv_emulate_fcvt_swu(uint32_t rs1) {</div> +<div class="line"><a id="l00698" name="l00698"></a><span class="lineno"> 698</span> </div> +<div class="line"><a id="l00699" name="l00699"></a><span class="lineno"> 699</span> <span class="keywordflow">return</span> (<span class="keywordtype">float</span>)rs1;</div> +<div class="line"><a id="l00700" name="l00700"></a><span class="lineno"> 700</span>}</div> +</div> +<div class="line"><a id="l00701" name="l00701"></a><span class="lineno"> 701</span> </div> +<div class="line"><a id="l00702" name="l00702"></a><span class="lineno"> 702</span> </div> +<div class="line"><a id="l00703" name="l00703"></a><span class="lineno"> 703</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen00709" data-start="{" data-end="}"> +<div class="line"><a id="l00709" name="l00709"></a><span class="lineno"><a class="line" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a0f2260b7b5793a95c49670379fc89617"> 709</a></span><span class="keywordtype">float</span> __attribute__ ((noinline)) riscv_emulate_fcvt_sw(int32_t rs1) {</div> +<div class="line"><a id="l00710" name="l00710"></a><span class="lineno"> 710</span> </div> +<div class="line"><a id="l00711" name="l00711"></a><span class="lineno"> 711</span> <span class="keywordflow">return</span> (<span class="keywordtype">float</span>)rs1;</div> +<div class="line"><a id="l00712" name="l00712"></a><span class="lineno"> 712</span>}</div> +</div> +<div class="line"><a id="l00713" name="l00713"></a><span class="lineno"> 713</span> </div> +<div class="line"><a id="l00714" name="l00714"></a><span class="lineno"> 714</span> </div> +<div class="line"><a id="l00715" name="l00715"></a><span class="lineno"> 715</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen00722" data-start="{" data-end="}"> +<div class="line"><a id="l00722" name="l00722"></a><span class="lineno"><a class="line" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a7cb3c6570b911cd1dfb7b6e798cc1d21"> 722</a></span>uint32_t __attribute__ ((noinline)) riscv_emulate_feqs(<span class="keywordtype">float</span> rs1, <span class="keywordtype">float</span> rs2) {</div> +<div class="line"><a id="l00723" name="l00723"></a><span class="lineno"> 723</span> </div> +<div class="line"><a id="l00724" name="l00724"></a><span class="lineno"> 724</span> <span class="keywordtype">float</span> opa = subnormal_flush(rs1);</div> +<div class="line"><a id="l00725" name="l00725"></a><span class="lineno"> 725</span> <span class="keywordtype">float</span> opb = subnormal_flush(rs2);</div> +<div class="line"><a id="l00726" name="l00726"></a><span class="lineno"> 726</span> </div> +<div class="line"><a id="l00727" name="l00727"></a><span class="lineno"> 727</span> <span class="keywordflow">if</span> ((fpclassify(opa) == FP_NAN) || (fpclassify(opb) == FP_NAN)) {</div> +<div class="line"><a id="l00728" name="l00728"></a><span class="lineno"> 728</span> <span class="keywordflow">return</span> 0;</div> +<div class="line"><a id="l00729" name="l00729"></a><span class="lineno"> 729</span> }</div> +<div class="line"><a id="l00730" name="l00730"></a><span class="lineno"> 730</span> </div> +<div class="line"><a id="l00731" name="l00731"></a><span class="lineno"> 731</span> <span class="keywordflow">if</span> isless(opa, opb) {</div> +<div class="line"><a id="l00732" name="l00732"></a><span class="lineno"> 732</span> <span class="keywordflow">return</span> 0;</div> +<div class="line"><a id="l00733" name="l00733"></a><span class="lineno"> 733</span> }</div> +<div class="line"><a id="l00734" name="l00734"></a><span class="lineno"> 734</span> <span class="keywordflow">else</span> <span class="keywordflow">if</span> isgreater(opa, opb) {</div> +<div class="line"><a id="l00735" name="l00735"></a><span class="lineno"> 735</span> <span class="keywordflow">return</span> 0;</div> +<div class="line"><a id="l00736" name="l00736"></a><span class="lineno"> 736</span> }</div> +<div class="line"><a id="l00737" name="l00737"></a><span class="lineno"> 737</span> <span class="keywordflow">else</span> {</div> +<div class="line"><a id="l00738" name="l00738"></a><span class="lineno"> 738</span> <span class="keywordflow">return</span> 1;</div> +<div class="line"><a id="l00739" name="l00739"></a><span class="lineno"> 739</span> }</div> +<div class="line"><a id="l00740" name="l00740"></a><span class="lineno"> 740</span>}</div> +</div> +<div class="line"><a id="l00741" name="l00741"></a><span class="lineno"> 741</span> </div> +<div class="line"><a id="l00742" name="l00742"></a><span class="lineno"> 742</span> </div> +<div class="line"><a id="l00743" name="l00743"></a><span class="lineno"> 743</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen00750" data-start="{" data-end="}"> +<div class="line"><a id="l00750" name="l00750"></a><span class="lineno"><a class="line" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a2b802122d53a2ce517b3d39fec34d7e0"> 750</a></span>uint32_t __attribute__ ((noinline)) riscv_emulate_flts(<span class="keywordtype">float</span> rs1, <span class="keywordtype">float</span> rs2) {</div> +<div class="line"><a id="l00751" name="l00751"></a><span class="lineno"> 751</span> </div> +<div class="line"><a id="l00752" name="l00752"></a><span class="lineno"> 752</span> <span class="keywordtype">float</span> opa = subnormal_flush(rs1);</div> +<div class="line"><a id="l00753" name="l00753"></a><span class="lineno"> 753</span> <span class="keywordtype">float</span> opb = subnormal_flush(rs2);</div> +<div class="line"><a id="l00754" name="l00754"></a><span class="lineno"> 754</span> </div> +<div class="line"><a id="l00755" name="l00755"></a><span class="lineno"> 755</span> <span class="keywordflow">if</span> ((fpclassify(opa) == FP_NAN) || (fpclassify(opb) == FP_NAN)) {</div> +<div class="line"><a id="l00756" name="l00756"></a><span class="lineno"> 756</span> <span class="keywordflow">return</span> 0;</div> +<div class="line"><a id="l00757" name="l00757"></a><span class="lineno"> 757</span> }</div> +<div class="line"><a id="l00758" name="l00758"></a><span class="lineno"> 758</span> </div> +<div class="line"><a id="l00759" name="l00759"></a><span class="lineno"> 759</span> <span class="keywordflow">if</span> isless(opa, opb) {</div> +<div class="line"><a id="l00760" name="l00760"></a><span class="lineno"> 760</span> <span class="keywordflow">return</span> 1;</div> +<div class="line"><a id="l00761" name="l00761"></a><span class="lineno"> 761</span> }</div> +<div class="line"><a id="l00762" name="l00762"></a><span class="lineno"> 762</span> <span class="keywordflow">else</span> {</div> +<div class="line"><a id="l00763" name="l00763"></a><span class="lineno"> 763</span> <span class="keywordflow">return</span> 0;</div> +<div class="line"><a id="l00764" name="l00764"></a><span class="lineno"> 764</span> }</div> +<div class="line"><a id="l00765" name="l00765"></a><span class="lineno"> 765</span>}</div> +</div> +<div class="line"><a id="l00766" name="l00766"></a><span class="lineno"> 766</span> </div> +<div class="line"><a id="l00767" name="l00767"></a><span class="lineno"> 767</span> </div> +<div class="line"><a id="l00768" name="l00768"></a><span class="lineno"> 768</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen00775" data-start="{" data-end="}"> +<div class="line"><a id="l00775" name="l00775"></a><span class="lineno"><a class="line" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#ac5fdef0607602fa0bdb93b3535fd709e"> 775</a></span>uint32_t __attribute__ ((noinline)) riscv_emulate_fles(<span class="keywordtype">float</span> rs1, <span class="keywordtype">float</span> rs2) {</div> +<div class="line"><a id="l00776" name="l00776"></a><span class="lineno"> 776</span> </div> +<div class="line"><a id="l00777" name="l00777"></a><span class="lineno"> 777</span> <span class="keywordtype">float</span> opa = subnormal_flush(rs1);</div> +<div class="line"><a id="l00778" name="l00778"></a><span class="lineno"> 778</span> <span class="keywordtype">float</span> opb = subnormal_flush(rs2);</div> +<div class="line"><a id="l00779" name="l00779"></a><span class="lineno"> 779</span> </div> +<div class="line"><a id="l00780" name="l00780"></a><span class="lineno"> 780</span> <span class="keywordflow">if</span> ((fpclassify(opa) == FP_NAN) || (fpclassify(opb) == FP_NAN)) {</div> +<div class="line"><a id="l00781" name="l00781"></a><span class="lineno"> 781</span> <span class="keywordflow">return</span> 0;</div> +<div class="line"><a id="l00782" name="l00782"></a><span class="lineno"> 782</span> }</div> +<div class="line"><a id="l00783" name="l00783"></a><span class="lineno"> 783</span> </div> +<div class="line"><a id="l00784" name="l00784"></a><span class="lineno"> 784</span> <span class="keywordflow">if</span> islessequal(opa, opb) {</div> +<div class="line"><a id="l00785" name="l00785"></a><span class="lineno"> 785</span> <span class="keywordflow">return</span> 1;</div> +<div class="line"><a id="l00786" name="l00786"></a><span class="lineno"> 786</span> }</div> +<div class="line"><a id="l00787" name="l00787"></a><span class="lineno"> 787</span> <span class="keywordflow">else</span> {</div> +<div class="line"><a id="l00788" name="l00788"></a><span class="lineno"> 788</span> <span class="keywordflow">return</span> 0;</div> +<div class="line"><a id="l00789" name="l00789"></a><span class="lineno"> 789</span> }</div> +<div class="line"><a id="l00790" name="l00790"></a><span class="lineno"> 790</span>}</div> +</div> +<div class="line"><a id="l00791" name="l00791"></a><span class="lineno"> 791</span> </div> +<div class="line"><a id="l00792" name="l00792"></a><span class="lineno"> 792</span> </div> +<div class="line"><a id="l00793" name="l00793"></a><span class="lineno"> 793</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen00800" data-start="{" data-end="}"> +<div class="line"><a id="l00800" name="l00800"></a><span class="lineno"><a class="line" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a12498d635f422f607b9b83facf3050dd"> 800</a></span><span class="keywordtype">float</span> __attribute__ ((noinline)) riscv_emulate_fsgnjs(<span class="keywordtype">float</span> rs1, <span class="keywordtype">float</span> rs2) {</div> +<div class="line"><a id="l00801" name="l00801"></a><span class="lineno"> 801</span> </div> +<div class="line"><a id="l00802" name="l00802"></a><span class="lineno"> 802</span> <span class="keywordtype">float</span> opa = rs1;</div> +<div class="line"><a id="l00803" name="l00803"></a><span class="lineno"> 803</span> <span class="keywordtype">float</span> opb = rs2;</div> +<div class="line"><a id="l00804" name="l00804"></a><span class="lineno"> 804</span> </div> +<div class="line"><a id="l00805" name="l00805"></a><span class="lineno"> 805</span> <span class="keywordtype">int</span> sign_1 = (int)signbit(opa);</div> +<div class="line"><a id="l00806" name="l00806"></a><span class="lineno"> 806</span> <span class="keywordtype">int</span> sign_2 = (int)signbit(opb);</div> +<div class="line"><a id="l00807" name="l00807"></a><span class="lineno"> 807</span> <span class="keywordtype">float</span> res = 0;</div> +<div class="line"><a id="l00808" name="l00808"></a><span class="lineno"> 808</span> </div> +<div class="line"><a id="l00809" name="l00809"></a><span class="lineno"> 809</span> <span class="keywordflow">if</span> (sign_2 != 0) { <span class="comment">// opb is negative</span></div> +<div class="line"><a id="l00810" name="l00810"></a><span class="lineno"> 810</span> <span class="keywordflow">if</span> (sign_1 == 0) {</div> +<div class="line"><a id="l00811" name="l00811"></a><span class="lineno"> 811</span> res = -opa;</div> +<div class="line"><a id="l00812" name="l00812"></a><span class="lineno"> 812</span> }</div> +<div class="line"><a id="l00813" name="l00813"></a><span class="lineno"> 813</span> <span class="keywordflow">else</span> {</div> +<div class="line"><a id="l00814" name="l00814"></a><span class="lineno"> 814</span> res = opa;</div> +<div class="line"><a id="l00815" name="l00815"></a><span class="lineno"> 815</span> }</div> +<div class="line"><a id="l00816" name="l00816"></a><span class="lineno"> 816</span> }</div> +<div class="line"><a id="l00817" name="l00817"></a><span class="lineno"> 817</span> <span class="keywordflow">else</span> { <span class="comment">// opb is positive</span></div> +<div class="line"><a id="l00818" name="l00818"></a><span class="lineno"> 818</span> <span class="keywordflow">if</span> (sign_1 == 0) {</div> +<div class="line"><a id="l00819" name="l00819"></a><span class="lineno"> 819</span> res = opa;</div> +<div class="line"><a id="l00820" name="l00820"></a><span class="lineno"> 820</span> }</div> +<div class="line"><a id="l00821" name="l00821"></a><span class="lineno"> 821</span> <span class="keywordflow">else</span> {</div> +<div class="line"><a id="l00822" name="l00822"></a><span class="lineno"> 822</span> res = -opa;</div> +<div class="line"><a id="l00823" name="l00823"></a><span class="lineno"> 823</span> }</div> +<div class="line"><a id="l00824" name="l00824"></a><span class="lineno"> 824</span> }</div> +<div class="line"><a id="l00825" name="l00825"></a><span class="lineno"> 825</span> </div> +<div class="line"><a id="l00826" name="l00826"></a><span class="lineno"> 826</span> <span class="keywordflow">return</span> res;</div> +<div class="line"><a id="l00827" name="l00827"></a><span class="lineno"> 827</span>}</div> +</div> +<div class="line"><a id="l00828" name="l00828"></a><span class="lineno"> 828</span> </div> +<div class="line"><a id="l00829" name="l00829"></a><span class="lineno"> 829</span> </div> +<div class="line"><a id="l00830" name="l00830"></a><span class="lineno"> 830</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen00837" data-start="{" data-end="}"> +<div class="line"><a id="l00837" name="l00837"></a><span class="lineno"><a class="line" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a0c985e626ed1d69314f4e3a0f1f58624"> 837</a></span><span class="keywordtype">float</span> __attribute__ ((noinline)) riscv_emulate_fsgnjns(<span class="keywordtype">float</span> rs1, <span class="keywordtype">float</span> rs2) {</div> +<div class="line"><a id="l00838" name="l00838"></a><span class="lineno"> 838</span> </div> +<div class="line"><a id="l00839" name="l00839"></a><span class="lineno"> 839</span> <span class="keywordtype">float</span> opa = rs1;</div> +<div class="line"><a id="l00840" name="l00840"></a><span class="lineno"> 840</span> <span class="keywordtype">float</span> opb = rs2;</div> +<div class="line"><a id="l00841" name="l00841"></a><span class="lineno"> 841</span> </div> +<div class="line"><a id="l00842" name="l00842"></a><span class="lineno"> 842</span> <span class="keywordtype">int</span> sign_1 = (int)signbit(opa);</div> +<div class="line"><a id="l00843" name="l00843"></a><span class="lineno"> 843</span> <span class="keywordtype">int</span> sign_2 = (int)signbit(opb);</div> +<div class="line"><a id="l00844" name="l00844"></a><span class="lineno"> 844</span> <span class="keywordtype">float</span> res = 0;</div> +<div class="line"><a id="l00845" name="l00845"></a><span class="lineno"> 845</span> </div> +<div class="line"><a id="l00846" name="l00846"></a><span class="lineno"> 846</span> <span class="keywordflow">if</span> (sign_2 != 0) { <span class="comment">// opb is negative</span></div> +<div class="line"><a id="l00847" name="l00847"></a><span class="lineno"> 847</span> <span class="keywordflow">if</span> (sign_1 == 0) {</div> +<div class="line"><a id="l00848" name="l00848"></a><span class="lineno"> 848</span> res = opa;</div> +<div class="line"><a id="l00849" name="l00849"></a><span class="lineno"> 849</span> }</div> +<div class="line"><a id="l00850" name="l00850"></a><span class="lineno"> 850</span> <span class="keywordflow">else</span> {</div> +<div class="line"><a id="l00851" name="l00851"></a><span class="lineno"> 851</span> res = -opa;</div> +<div class="line"><a id="l00852" name="l00852"></a><span class="lineno"> 852</span> }</div> +<div class="line"><a id="l00853" name="l00853"></a><span class="lineno"> 853</span> }</div> +<div class="line"><a id="l00854" name="l00854"></a><span class="lineno"> 854</span> <span class="keywordflow">else</span> { <span class="comment">// opb is positive</span></div> +<div class="line"><a id="l00855" name="l00855"></a><span class="lineno"> 855</span> <span class="keywordflow">if</span> (sign_1 == 0) {</div> +<div class="line"><a id="l00856" name="l00856"></a><span class="lineno"> 856</span> res = -opa;</div> +<div class="line"><a id="l00857" name="l00857"></a><span class="lineno"> 857</span> }</div> +<div class="line"><a id="l00858" name="l00858"></a><span class="lineno"> 858</span> <span class="keywordflow">else</span> {</div> +<div class="line"><a id="l00859" name="l00859"></a><span class="lineno"> 859</span> res = opa;</div> +<div class="line"><a id="l00860" name="l00860"></a><span class="lineno"> 860</span> }</div> +<div class="line"><a id="l00861" name="l00861"></a><span class="lineno"> 861</span> }</div> +<div class="line"><a id="l00862" name="l00862"></a><span class="lineno"> 862</span> </div> +<div class="line"><a id="l00863" name="l00863"></a><span class="lineno"> 863</span> <span class="keywordflow">return</span> res;</div> +<div class="line"><a id="l00864" name="l00864"></a><span class="lineno"> 864</span>}</div> +</div> +<div class="line"><a id="l00865" name="l00865"></a><span class="lineno"> 865</span> </div> +<div class="line"><a id="l00866" name="l00866"></a><span class="lineno"> 866</span> </div> +<div class="line"><a id="l00867" name="l00867"></a><span class="lineno"> 867</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen00874" data-start="{" data-end="}"> +<div class="line"><a id="l00874" name="l00874"></a><span class="lineno"><a class="line" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a98caf7f310820052ae96ce0f45e6cd26"> 874</a></span><span class="keywordtype">float</span> __attribute__ ((noinline)) riscv_emulate_fsgnjxs(<span class="keywordtype">float</span> rs1, <span class="keywordtype">float</span> rs2) {</div> +<div class="line"><a id="l00875" name="l00875"></a><span class="lineno"> 875</span> </div> +<div class="line"><a id="l00876" name="l00876"></a><span class="lineno"> 876</span> <span class="keywordtype">float</span> opa = rs1;</div> +<div class="line"><a id="l00877" name="l00877"></a><span class="lineno"> 877</span> <span class="keywordtype">float</span> opb = rs2;</div> +<div class="line"><a id="l00878" name="l00878"></a><span class="lineno"> 878</span> </div> +<div class="line"><a id="l00879" name="l00879"></a><span class="lineno"> 879</span> <span class="keywordtype">int</span> sign_1 = (int)signbit(opa);</div> +<div class="line"><a id="l00880" name="l00880"></a><span class="lineno"> 880</span> <span class="keywordtype">int</span> sign_2 = (int)signbit(opb);</div> +<div class="line"><a id="l00881" name="l00881"></a><span class="lineno"> 881</span> <span class="keywordtype">float</span> res = 0;</div> +<div class="line"><a id="l00882" name="l00882"></a><span class="lineno"> 882</span> </div> +<div class="line"><a id="l00883" name="l00883"></a><span class="lineno"> 883</span> <span class="keywordflow">if</span> (((sign_1 == 0) &amp;&amp; (sign_2 != 0)) || ((sign_1 != 0) &amp;&amp; (sign_2 == 0))) {</div> +<div class="line"><a id="l00884" name="l00884"></a><span class="lineno"> 884</span> <span class="keywordflow">if</span> (sign_1 == 0) {</div> +<div class="line"><a id="l00885" name="l00885"></a><span class="lineno"> 885</span> res = -opa;</div> +<div class="line"><a id="l00886" name="l00886"></a><span class="lineno"> 886</span> }</div> +<div class="line"><a id="l00887" name="l00887"></a><span class="lineno"> 887</span> <span class="keywordflow">else</span> {</div> +<div class="line"><a id="l00888" name="l00888"></a><span class="lineno"> 888</span> res = opa;</div> +<div class="line"><a id="l00889" name="l00889"></a><span class="lineno"> 889</span> }</div> +<div class="line"><a id="l00890" name="l00890"></a><span class="lineno"> 890</span> }</div> +<div class="line"><a id="l00891" name="l00891"></a><span class="lineno"> 891</span> <span class="keywordflow">else</span> {</div> +<div class="line"><a id="l00892" name="l00892"></a><span class="lineno"> 892</span> <span class="keywordflow">if</span> (sign_1 == 0) {</div> +<div class="line"><a id="l00893" name="l00893"></a><span class="lineno"> 893</span> res = opa;</div> +<div class="line"><a id="l00894" name="l00894"></a><span class="lineno"> 894</span> }</div> +<div class="line"><a id="l00895" name="l00895"></a><span class="lineno"> 895</span> <span class="keywordflow">else</span> {</div> +<div class="line"><a id="l00896" name="l00896"></a><span class="lineno"> 896</span> res = -opa;</div> +<div class="line"><a id="l00897" name="l00897"></a><span class="lineno"> 897</span> }</div> +<div class="line"><a id="l00898" name="l00898"></a><span class="lineno"> 898</span> }</div> +<div class="line"><a id="l00899" name="l00899"></a><span class="lineno"> 899</span> </div> +<div class="line"><a id="l00900" name="l00900"></a><span class="lineno"> 900</span> <span class="keywordflow">return</span> res;</div> +<div class="line"><a id="l00901" name="l00901"></a><span class="lineno"> 901</span>}</div> +</div> +<div class="line"><a id="l00902" name="l00902"></a><span class="lineno"> 902</span> </div> +<div class="line"><a id="l00903" name="l00903"></a><span class="lineno"> 903</span> </div> +<div class="line"><a id="l00904" name="l00904"></a><span class="lineno"> 904</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen00910" data-start="{" data-end="}"> +<div class="line"><a id="l00910" name="l00910"></a><span class="lineno"><a class="line" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#ae41a0bf9d28c35f4d6db7177ccf8ee06"> 910</a></span>uint32_t __attribute__ ((noinline)) riscv_emulate_fclasss(<span class="keywordtype">float</span> rs1) {</div> +<div class="line"><a id="l00911" name="l00911"></a><span class="lineno"> 911</span> </div> +<div class="line"><a id="l00912" name="l00912"></a><span class="lineno"> 912</span> <span class="keywordtype">float</span> opa = rs1;</div> +<div class="line"><a id="l00913" name="l00913"></a><span class="lineno"> 913</span> </div> +<div class="line"><a id="l00914" name="l00914"></a><span class="lineno"> 914</span> <span class="keyword">union </span>{</div> +<div class="line"><a id="l00915" name="l00915"></a><span class="lineno"> 915</span> uint32_t binary_value; </div> +<div class="line"><a id="l00916" name="l00916"></a><span class="lineno"> 916</span> <span class="keywordtype">float</span> float_value; </div> +<div class="line"><a id="l00917" name="l00917"></a><span class="lineno"> 917</span> } aux;</div> +<div class="line"><a id="l00918" name="l00918"></a><span class="lineno"> 918</span> </div> +<div class="line"><a id="l00919" name="l00919"></a><span class="lineno"> 919</span> <span class="comment">// RISC-V classify result layout</span></div> +<div class="line"><a id="l00920" name="l00920"></a><span class="lineno"> 920</span> <span class="keyword">const</span> uint32_t CLASS_NEG_INF = 1 &lt;&lt; 0; <span class="comment">// negative infinity</span></div> +<div class="line"><a id="l00921" name="l00921"></a><span class="lineno"> 921</span> <span class="keyword">const</span> uint32_t CLASS_NEG_NORM = 1 &lt;&lt; 1; <span class="comment">// negative normal number</span></div> +<div class="line"><a id="l00922" name="l00922"></a><span class="lineno"> 922</span> <span class="keyword">const</span> uint32_t CLASS_NEG_DENORM = 1 &lt;&lt; 2; <span class="comment">// negative subnormal number</span></div> +<div class="line"><a id="l00923" name="l00923"></a><span class="lineno"> 923</span> <span class="keyword">const</span> uint32_t CLASS_NEG_ZERO = 1 &lt;&lt; 3; <span class="comment">// negative zero</span></div> +<div class="line"><a id="l00924" name="l00924"></a><span class="lineno"> 924</span> <span class="keyword">const</span> uint32_t CLASS_POS_ZERO = 1 &lt;&lt; 4; <span class="comment">// positive zero</span></div> +<div class="line"><a id="l00925" name="l00925"></a><span class="lineno"> 925</span> <span class="keyword">const</span> uint32_t CLASS_POS_DENORM = 1 &lt;&lt; 5; <span class="comment">// positive subnormal number</span></div> +<div class="line"><a id="l00926" name="l00926"></a><span class="lineno"> 926</span> <span class="keyword">const</span> uint32_t CLASS_POS_NORM = 1 &lt;&lt; 6; <span class="comment">// positive normal number</span></div> +<div class="line"><a id="l00927" name="l00927"></a><span class="lineno"> 927</span> <span class="keyword">const</span> uint32_t CLASS_POS_INF = 1 &lt;&lt; 7; <span class="comment">// positive infinity</span></div> +<div class="line"><a id="l00928" name="l00928"></a><span class="lineno"> 928</span> <span class="keyword">const</span> uint32_t CLASS_SNAN = 1 &lt;&lt; 8; <span class="comment">// signaling NaN (sNaN)</span></div> +<div class="line"><a id="l00929" name="l00929"></a><span class="lineno"> 929</span> <span class="keyword">const</span> uint32_t CLASS_QNAN = 1 &lt;&lt; 9; <span class="comment">// quiet NaN (qNaN)</span></div> +<div class="line"><a id="l00930" name="l00930"></a><span class="lineno"> 930</span> </div> +<div class="line"><a id="l00931" name="l00931"></a><span class="lineno"> 931</span> <span class="keywordtype">int</span> tmp = fpclassify(opa);</div> +<div class="line"><a id="l00932" name="l00932"></a><span class="lineno"> 932</span> <span class="keywordtype">int</span> sgn = (int)signbit(opa);</div> +<div class="line"><a id="l00933" name="l00933"></a><span class="lineno"> 933</span> </div> +<div class="line"><a id="l00934" name="l00934"></a><span class="lineno"> 934</span> uint32_t res = 0;</div> +<div class="line"><a id="l00935" name="l00935"></a><span class="lineno"> 935</span> </div> +<div class="line"><a id="l00936" name="l00936"></a><span class="lineno"> 936</span> <span class="comment">// infinity</span></div> +<div class="line"><a id="l00937" name="l00937"></a><span class="lineno"> 937</span> <span class="keywordflow">if</span> (tmp == FP_INFINITE) {</div> +<div class="line"><a id="l00938" name="l00938"></a><span class="lineno"> 938</span> <span class="keywordflow">if</span> (sgn) { res |= CLASS_NEG_INF; }</div> +<div class="line"><a id="l00939" name="l00939"></a><span class="lineno"> 939</span> <span class="keywordflow">else</span> { res |= CLASS_POS_INF; }</div> +<div class="line"><a id="l00940" name="l00940"></a><span class="lineno"> 940</span> }</div> +<div class="line"><a id="l00941" name="l00941"></a><span class="lineno"> 941</span> </div> +<div class="line"><a id="l00942" name="l00942"></a><span class="lineno"> 942</span> <span class="comment">// zero</span></div> +<div class="line"><a id="l00943" name="l00943"></a><span class="lineno"> 943</span> <span class="keywordflow">if</span> (tmp == FP_ZERO) {</div> +<div class="line"><a id="l00944" name="l00944"></a><span class="lineno"> 944</span> <span class="keywordflow">if</span> (sgn) { res |= CLASS_NEG_ZERO; }</div> +<div class="line"><a id="l00945" name="l00945"></a><span class="lineno"> 945</span> <span class="keywordflow">else</span> { res |= CLASS_POS_ZERO; }</div> +<div class="line"><a id="l00946" name="l00946"></a><span class="lineno"> 946</span> }</div> +<div class="line"><a id="l00947" name="l00947"></a><span class="lineno"> 947</span> </div> +<div class="line"><a id="l00948" name="l00948"></a><span class="lineno"> 948</span> <span class="comment">// normal</span></div> +<div class="line"><a id="l00949" name="l00949"></a><span class="lineno"> 949</span> <span class="keywordflow">if</span> (tmp == FP_NORMAL) {</div> +<div class="line"><a id="l00950" name="l00950"></a><span class="lineno"> 950</span> <span class="keywordflow">if</span> (sgn) { res |= CLASS_NEG_NORM; }</div> +<div class="line"><a id="l00951" name="l00951"></a><span class="lineno"> 951</span> <span class="keywordflow">else</span> { res |= CLASS_POS_NORM; }</div> +<div class="line"><a id="l00952" name="l00952"></a><span class="lineno"> 952</span> }</div> +<div class="line"><a id="l00953" name="l00953"></a><span class="lineno"> 953</span> </div> +<div class="line"><a id="l00954" name="l00954"></a><span class="lineno"> 954</span> <span class="comment">// subnormal</span></div> +<div class="line"><a id="l00955" name="l00955"></a><span class="lineno"> 955</span> <span class="keywordflow">if</span> (tmp == FP_SUBNORMAL) {</div> +<div class="line"><a id="l00956" name="l00956"></a><span class="lineno"> 956</span> <span class="keywordflow">if</span> (sgn) { res |= CLASS_NEG_DENORM; }</div> +<div class="line"><a id="l00957" name="l00957"></a><span class="lineno"> 957</span> <span class="keywordflow">else</span> { res |= CLASS_POS_DENORM; }</div> +<div class="line"><a id="l00958" name="l00958"></a><span class="lineno"> 958</span> }</div> +<div class="line"><a id="l00959" name="l00959"></a><span class="lineno"> 959</span> </div> +<div class="line"><a id="l00960" name="l00960"></a><span class="lineno"> 960</span> <span class="comment">// NaN</span></div> +<div class="line"><a id="l00961" name="l00961"></a><span class="lineno"> 961</span> <span class="keywordflow">if</span> (tmp == FP_NAN) {</div> +<div class="line"><a id="l00962" name="l00962"></a><span class="lineno"> 962</span> aux.float_value = opa;</div> +<div class="line"><a id="l00963" name="l00963"></a><span class="lineno"> 963</span> <span class="keywordflow">if</span> ((aux.binary_value &gt;&gt; 22) &amp; 0b1) { <span class="comment">// bit 22 (mantissa&#39;s MSB) is set -&gt; canonical (quiet) NAN</span></div> +<div class="line"><a id="l00964" name="l00964"></a><span class="lineno"> 964</span> res |= CLASS_QNAN;</div> +<div class="line"><a id="l00965" name="l00965"></a><span class="lineno"> 965</span> }</div> +<div class="line"><a id="l00966" name="l00966"></a><span class="lineno"> 966</span> <span class="keywordflow">else</span> {</div> +<div class="line"><a id="l00967" name="l00967"></a><span class="lineno"> 967</span> res |= CLASS_SNAN;</div> +<div class="line"><a id="l00968" name="l00968"></a><span class="lineno"> 968</span> }</div> +<div class="line"><a id="l00969" name="l00969"></a><span class="lineno"> 969</span> }</div> +<div class="line"><a id="l00970" name="l00970"></a><span class="lineno"> 970</span> </div> +<div class="line"><a id="l00971" name="l00971"></a><span class="lineno"> 971</span> <span class="keywordflow">return</span> res;</div> +<div class="line"><a id="l00972" name="l00972"></a><span class="lineno"> 972</span>}</div> +</div> +<div class="line"><a id="l00973" name="l00973"></a><span class="lineno"> 973</span> </div> +<div class="line"><a id="l00974" name="l00974"></a><span class="lineno"> 974</span> </div> +<div class="line"><a id="l00975" name="l00975"></a><span class="lineno"> 975</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen00982" data-start="{" data-end="}"> +<div class="line"><a id="l00982" name="l00982"></a><span class="lineno"><a class="line" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#aeaf46a17b671278be2bf804159827a40"> 982</a></span><span class="keywordtype">float</span> __attribute__ ((noinline)) riscv_emulate_fdivs(<span class="keywordtype">float</span> rs1, <span class="keywordtype">float</span> rs2) {</div> +<div class="line"><a id="l00983" name="l00983"></a><span class="lineno"> 983</span> </div> +<div class="line"><a id="l00984" name="l00984"></a><span class="lineno"> 984</span> <span class="keywordtype">float</span> opa = subnormal_flush(rs1);</div> +<div class="line"><a id="l00985" name="l00985"></a><span class="lineno"> 985</span> <span class="keywordtype">float</span> opb = subnormal_flush(rs2);</div> +<div class="line"><a id="l00986" name="l00986"></a><span class="lineno"> 986</span> </div> +<div class="line"><a id="l00987" name="l00987"></a><span class="lineno"> 987</span> <span class="keywordtype">float</span> res = opa / opb;</div> +<div class="line"><a id="l00988" name="l00988"></a><span class="lineno"> 988</span> <span class="keywordflow">return</span> subnormal_flush(res);</div> +<div class="line"><a id="l00989" name="l00989"></a><span class="lineno"> 989</span>}</div> +</div> +<div class="line"><a id="l00990" name="l00990"></a><span class="lineno"> 990</span> </div> +<div class="line"><a id="l00991" name="l00991"></a><span class="lineno"> 991</span> </div> +<div class="line"><a id="l00992" name="l00992"></a><span class="lineno"> 992</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen00998" data-start="{" data-end="}"> +<div class="line"><a id="l00998" name="l00998"></a><span class="lineno"><a class="line" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a1ceb3450f1e5c62d3079cd0e93c03501"> 998</a></span><span class="keywordtype">float</span> __attribute__ ((noinline)) riscv_emulate_fsqrts(<span class="keywordtype">float</span> rs1) {</div> +<div class="line"><a id="l00999" name="l00999"></a><span class="lineno"> 999</span> </div> +<div class="line"><a id="l01000" name="l01000"></a><span class="lineno"> 1000</span> <span class="keywordtype">float</span> opa = subnormal_flush(rs1);</div> +<div class="line"><a id="l01001" name="l01001"></a><span class="lineno"> 1001</span> </div> +<div class="line"><a id="l01002" name="l01002"></a><span class="lineno"> 1002</span> <span class="keywordtype">float</span> res = sqrtf(opa);</div> +<div class="line"><a id="l01003" name="l01003"></a><span class="lineno"> 1003</span> <span class="keywordflow">return</span> subnormal_flush(res);</div> +<div class="line"><a id="l01004" name="l01004"></a><span class="lineno"> 1004</span>}</div> +</div> +<div class="line"><a id="l01005" name="l01005"></a><span class="lineno"> 1005</span> </div> +<div class="line"><a id="l01006" name="l01006"></a><span class="lineno"> 1006</span> </div> +<div class="line"><a id="l01007" name="l01007"></a><span class="lineno"> 1007</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen01017" data-start="{" data-end="}"> +<div class="line"><a id="l01017" name="l01017"></a><span class="lineno"><a class="line" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a39212f2e2bb0f1752092a1732f93edf3"> 1017</a></span><span class="keywordtype">float</span> __attribute__ ((noinline)) riscv_emulate_fmadds(<span class="keywordtype">float</span> rs1, <span class="keywordtype">float</span> rs2, <span class="keywordtype">float</span> rs3) {</div> +<div class="line"><a id="l01018" name="l01018"></a><span class="lineno"> 1018</span> </div> +<div class="line"><a id="l01019" name="l01019"></a><span class="lineno"> 1019</span> <span class="keywordtype">float</span> opa = subnormal_flush(rs1);</div> +<div class="line"><a id="l01020" name="l01020"></a><span class="lineno"> 1020</span> <span class="keywordtype">float</span> opb = subnormal_flush(rs2);</div> +<div class="line"><a id="l01021" name="l01021"></a><span class="lineno"> 1021</span> <span class="keywordtype">float</span> opc = subnormal_flush(rs3);</div> +<div class="line"><a id="l01022" name="l01022"></a><span class="lineno"> 1022</span> </div> +<div class="line"><a id="l01023" name="l01023"></a><span class="lineno"> 1023</span> <span class="keywordtype">float</span> res = (opa * opb) + opc;</div> +<div class="line"><a id="l01024" name="l01024"></a><span class="lineno"> 1024</span> <span class="keywordflow">return</span> subnormal_flush(res);</div> +<div class="line"><a id="l01025" name="l01025"></a><span class="lineno"> 1025</span>}</div> +</div> +<div class="line"><a id="l01026" name="l01026"></a><span class="lineno"> 1026</span> </div> +<div class="line"><a id="l01027" name="l01027"></a><span class="lineno"> 1027</span> </div> +<div class="line"><a id="l01028" name="l01028"></a><span class="lineno"> 1028</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen01036" data-start="{" data-end="}"> +<div class="line"><a id="l01036" name="l01036"></a><span class="lineno"><a class="line" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a05d0d5a8eb9422e93448efdeb679cabf"> 1036</a></span><span class="keywordtype">float</span> __attribute__ ((noinline)) riscv_emulate_fmsubs(<span class="keywordtype">float</span> rs1, <span class="keywordtype">float</span> rs2, <span class="keywordtype">float</span> rs3) {</div> +<div class="line"><a id="l01037" name="l01037"></a><span class="lineno"> 1037</span> </div> +<div class="line"><a id="l01038" name="l01038"></a><span class="lineno"> 1038</span> <span class="keywordtype">float</span> opa = subnormal_flush(rs1);</div> +<div class="line"><a id="l01039" name="l01039"></a><span class="lineno"> 1039</span> <span class="keywordtype">float</span> opb = subnormal_flush(rs2);</div> +<div class="line"><a id="l01040" name="l01040"></a><span class="lineno"> 1040</span> <span class="keywordtype">float</span> opc = subnormal_flush(rs3);</div> +<div class="line"><a id="l01041" name="l01041"></a><span class="lineno"> 1041</span> </div> +<div class="line"><a id="l01042" name="l01042"></a><span class="lineno"> 1042</span> <span class="keywordtype">float</span> res = (opa * opb) - opc;</div> +<div class="line"><a id="l01043" name="l01043"></a><span class="lineno"> 1043</span> <span class="keywordflow">return</span> subnormal_flush(res);</div> +<div class="line"><a id="l01044" name="l01044"></a><span class="lineno"> 1044</span>}</div> +</div> +<div class="line"><a id="l01045" name="l01045"></a><span class="lineno"> 1045</span> </div> +<div class="line"><a id="l01046" name="l01046"></a><span class="lineno"> 1046</span> </div> +<div class="line"><a id="l01047" name="l01047"></a><span class="lineno"> 1047</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen01055" data-start="{" data-end="}"> +<div class="line"><a id="l01055" name="l01055"></a><span class="lineno"><a class="line" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a833638b346722dfa9d7d5c8d60998ec8"> 1055</a></span><span class="keywordtype">float</span> __attribute__ ((noinline)) riscv_emulate_fnmsubs(<span class="keywordtype">float</span> rs1, <span class="keywordtype">float</span> rs2, <span class="keywordtype">float</span> rs3) {</div> +<div class="line"><a id="l01056" name="l01056"></a><span class="lineno"> 1056</span> </div> +<div class="line"><a id="l01057" name="l01057"></a><span class="lineno"> 1057</span> <span class="keywordtype">float</span> opa = subnormal_flush(rs1);</div> +<div class="line"><a id="l01058" name="l01058"></a><span class="lineno"> 1058</span> <span class="keywordtype">float</span> opb = subnormal_flush(rs2);</div> +<div class="line"><a id="l01059" name="l01059"></a><span class="lineno"> 1059</span> <span class="keywordtype">float</span> opc = subnormal_flush(rs3);</div> +<div class="line"><a id="l01060" name="l01060"></a><span class="lineno"> 1060</span> </div> +<div class="line"><a id="l01061" name="l01061"></a><span class="lineno"> 1061</span> <span class="keywordtype">float</span> res = -(opa * opb) + opc;</div> +<div class="line"><a id="l01062" name="l01062"></a><span class="lineno"> 1062</span> <span class="keywordflow">return</span> subnormal_flush(res);</div> +<div class="line"><a id="l01063" name="l01063"></a><span class="lineno"> 1063</span>}</div> +</div> +<div class="line"><a id="l01064" name="l01064"></a><span class="lineno"> 1064</span> </div> +<div class="line"><a id="l01065" name="l01065"></a><span class="lineno"> 1065</span> </div> +<div class="line"><a id="l01066" name="l01066"></a><span class="lineno"> 1066</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen01074" data-start="{" data-end="}"> +<div class="line"><a id="l01074" name="l01074"></a><span class="lineno"><a class="line" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#ac8bb4450b39854ab07839e8f3505361c"> 1074</a></span><span class="keywordtype">float</span> __attribute__ ((noinline)) riscv_emulate_fnmadds(<span class="keywordtype">float</span> rs1, <span class="keywordtype">float</span> rs2, <span class="keywordtype">float</span> rs3) {</div> +<div class="line"><a id="l01075" name="l01075"></a><span class="lineno"> 1075</span> </div> +<div class="line"><a id="l01076" name="l01076"></a><span class="lineno"> 1076</span> <span class="keywordtype">float</span> opa = subnormal_flush(rs1);</div> +<div class="line"><a id="l01077" name="l01077"></a><span class="lineno"> 1077</span> <span class="keywordtype">float</span> opb = subnormal_flush(rs2);</div> +<div class="line"><a id="l01078" name="l01078"></a><span class="lineno"> 1078</span> <span class="keywordtype">float</span> opc = subnormal_flush(rs3);</div> +<div class="line"><a id="l01079" name="l01079"></a><span class="lineno"> 1079</span> </div> +<div class="line"><a id="l01080" name="l01080"></a><span class="lineno"> 1080</span> <span class="keywordtype">float</span> res = -(opa * opb) - opc;</div> +<div class="line"><a id="l01081" name="l01081"></a><span class="lineno"> 1081</span> <span class="keywordflow">return</span> subnormal_flush(res);</div> +<div class="line"><a id="l01082" name="l01082"></a><span class="lineno"> 1082</span>}</div> +</div> +<div class="line"><a id="l01083" name="l01083"></a><span class="lineno"> 1083</span> </div> +<div class="line"><a id="l01084" name="l01084"></a><span class="lineno"> 1084</span> </div> +<div class="line"><a id="l01085" name="l01085"></a><span class="lineno"> 1085</span><span class="preprocessor">#endif </span><span class="comment">// neorv32_zfinx_extension_intrinsics_h</span></div> +<div class="line"><a id="l01086" name="l01086"></a><span class="lineno"> 1086</span> </div> +<div class="ttc" id="aunionfloat__conv__t_html"><div class="ttname"><a href="unionfloat__conv__t.html">float_conv_t</a></div><div class="ttdef"><b>Definition</b> neorv32_zfinx_extension_intrinsics.h:78</div></div> +<div class="ttc" id="aunionfloat__conv__t_html_a59ad19d41b1d973a6bda9032e1937606"><div class="ttname"><a href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">float_conv_t::binary_value</a></div><div class="ttdeci">uint32_t binary_value</div><div class="ttdef"><b>Definition</b> neorv32_zfinx_extension_intrinsics.h:79</div></div> +<div class="ttc" id="aunionfloat__conv__t_html_a95f2e38b437bd8d4e8de7f61d7474788"><div class="ttname"><a href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_conv_t::float_value</a></div><div class="ttdeci">float float_value</div><div class="ttdef"><b>Definition</b> neorv32_zfinx_extension_intrinsics.h:80</div></div> +</div><!-- fragment --></div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/folderclosed.svg b/sw/folderclosed.svg new file mode 100644 index 0000000000..b04bed2e72 --- /dev/null +++ b/sw/folderclosed.svg @@ -0,0 +1,11 @@ +<?xml version="1.0" encoding="UTF-8" standalone="no"?> +<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" + "https://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd"> +<svg version="1.1" width="16" height="24" viewBox="0 0 32 32" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" xml:space="preserve"> +<g style="fill:#4665A2;"> +<path d="M1,5.998l-0,16.002c-0,1.326 0.527,2.598 1.464,3.536c0.938,0.937 2.21,1.464 3.536,1.464c5.322,0 14.678,-0 20,0c1.326,0 2.598,-0.527 3.536,-1.464c0.937,-0.938 1.464,-2.21 1.464,-3.536c0,-3.486 0,-8.514 0,-12c0,-1.326 -0.527,-2.598 -1.464,-3.536c-0.938,-0.937 -2.21,-1.464 -3.536,-1.464c-0,0 -10.586,0 -10.586,0c0,-0 -3.707,-3.707 -3.707,-3.707c-0.187,-0.188 -0.442,-0.293 -0.707,-0.293l-5.002,0c-2.76,0 -4.998,2.238 -4.998,4.998Zm2,-0l-0,16.002c-0,0.796 0.316,1.559 0.879,2.121c0.562,0.563 1.325,0.879 2.121,0.879l20,0c0.796,0 1.559,-0.316 2.121,-0.879c0.563,-0.562 0.879,-1.325 0.879,-2.121c0,-3.486 0,-8.514 0,-12c0,-0.796 -0.316,-1.559 -0.879,-2.121c-0.562,-0.563 -1.325,-0.879 -2.121,-0.879c-7.738,0 -11,0 -11,0c-0.265,0 -0.52,-0.105 -0.707,-0.293c-0,0 -3.707,-3.707 -3.707,-3.707c-0,0 -4.588,0 -4.588,0c-1.656,0 -2.998,1.342 -2.998,2.998Z"/> +</g> +<g style="fill:#D8DFEE;stroke-width:0;"> +<path d="M 5.6063709,24.951908 C 4.3924646,24.775461 3.4197129,23.899792 3.1031586,22.698521 L 3.0216155,22.389078 V 13.997725 5.6063709 L 3.1037477,5.2982247 C 3.3956682,4.2029881 4.1802788,3.412126 5.2787258,3.105917 5.5646428,3.0262132 5.6154982,3.0244963 8.0611641,3.0119829 l 2.4911989,-0.012746 1.932009,1.9300342 c 1.344142,1.3427669 1.976319,1.9498819 2.07763,1.9952626 0.137456,0.061571 0.474218,0.066269 6.006826,0.083795 l 5.861206,0.018568 0.29124,0.081916 c 1.094895,0.3079569 1.890116,1.109428 2.175567,2.192667 l 0.08154,0.3094425 V 16 22.389078 l -0.08154,0.309443 c -0.28446,1.079482 -1.086411,1.888085 -2.175567,2.193614 l -0.29124,0.0817 -10.302616,0.0049 c -5.700217,0.0027 -10.4001945,-0.0093 -10.5210471,-0.02684 z"/> +</g> +</svg> diff --git a/sw/folderclosedd.svg b/sw/folderclosedd.svg new file mode 100644 index 0000000000..52f0166a23 --- /dev/null +++ b/sw/folderclosedd.svg @@ -0,0 +1,11 @@ +<?xml version="1.0" encoding="UTF-8" standalone="no"?> +<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" + "https://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd"> +<svg version="1.1" width="16" height="24" viewBox="0 0 32 32" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" xml:space="preserve"> +<g style="fill:#C4CFE5;"> +<path d="M1,5.998l-0,16.002c-0,1.326 0.527,2.598 1.464,3.536c0.938,0.937 2.21,1.464 3.536,1.464c5.322,0 14.678,-0 20,0c1.326,0 2.598,-0.527 3.536,-1.464c0.937,-0.938 1.464,-2.21 1.464,-3.536c0,-3.486 0,-8.514 0,-12c0,-1.326 -0.527,-2.598 -1.464,-3.536c-0.938,-0.937 -2.21,-1.464 -3.536,-1.464c-0,0 -10.586,0 -10.586,0c0,-0 -3.707,-3.707 -3.707,-3.707c-0.187,-0.188 -0.442,-0.293 -0.707,-0.293l-5.002,0c-2.76,0 -4.998,2.238 -4.998,4.998Zm2,-0l-0,16.002c-0,0.796 0.316,1.559 0.879,2.121c0.562,0.563 1.325,0.879 2.121,0.879l20,0c0.796,0 1.559,-0.316 2.121,-0.879c0.563,-0.562 0.879,-1.325 0.879,-2.121c0,-3.486 0,-8.514 0,-12c0,-0.796 -0.316,-1.559 -0.879,-2.121c-0.562,-0.563 -1.325,-0.879 -2.121,-0.879c-7.738,0 -11,0 -11,0c-0.265,0 -0.52,-0.105 -0.707,-0.293c-0,0 -3.707,-3.707 -3.707,-3.707c-0,0 -4.588,0 -4.588,0c-1.656,0 -2.998,1.342 -2.998,2.998Z"/> +</g> +<g style="fill:#4665A2;stroke-width:0;"> +<path d="M 5.6063709,24.951908 C 4.3924646,24.775461 3.4197129,23.899792 3.1031586,22.698521 L 3.0216155,22.389078 V 13.997725 5.6063709 L 3.1037477,5.2982247 C 3.3956682,4.2029881 4.1802788,3.412126 5.2787258,3.105917 5.5646428,3.0262132 5.6154982,3.0244963 8.0611641,3.0119829 l 2.4911989,-0.012746 1.932009,1.9300342 c 1.344142,1.3427669 1.976319,1.9498819 2.07763,1.9952626 0.137456,0.061571 0.474218,0.066269 6.006826,0.083795 l 5.861206,0.018568 0.29124,0.081916 c 1.094895,0.3079569 1.890116,1.109428 2.175567,2.192667 l 0.08154,0.3094425 V 16 22.389078 l -0.08154,0.309443 c -0.28446,1.079482 -1.086411,1.888085 -2.175567,2.193614 l -0.29124,0.0817 -10.302616,0.0049 c -5.700217,0.0027 -10.4001945,-0.0093 -10.5210471,-0.02684 z"/> +</g> +</svg> diff --git a/sw/folderopen.svg b/sw/folderopen.svg new file mode 100644 index 0000000000..f6896dd254 --- /dev/null +++ b/sw/folderopen.svg @@ -0,0 +1,17 @@ +<?xml version="1.0" encoding="UTF-8" standalone="no"?> +<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" + "https://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd"> +<svg version="1.1" width="16" height="24" viewBox="0 0 32 32" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" xml:space="preserve"> +<g style="fill:#4665A2;"> +<path + d="M1,5.998l0,16.002c-0,1.326 0.527,2.598 1.464,3.536c0.938,0.937 2.21,1.464 3.536,1.464c5.322,0 14.678,-0 20,0c1.326,0 2.598,-0.527 3.536,-1.464c0.937,-0.938 1.464,-2.21 1.464,-3.536c0,-3.486 0,-8.514 0,-12c0,-1.326 -0.527,-2.598 -1.464,-3.536c-0.938,-0.937 -2.21,-1.464 -3.536,-1.464c-0,0 -10.586,0 -10.586,0c0,-0 -3.707,-3.707 -3.707,-3.707c-0.187,-0.188 -0.442,-0.293 -0.707,-0.293l-5.002,0c-2.76,0 -4.998,2.238 -4.998,4.998Zm28,14.415l-3.456,-5.925c-0.538,-0.921 -1.524,-1.488 -2.591,-1.488c-0,0 -12.905,0 -12.906,0c-1.067,0 -2.053,0.567 -2.591,1.488l-4.453,7.635c0.03,0.751 0.342,1.465 0.876,1.998c0.562,0.563 1.325,0.879 2.121,0.879l20,0c0.796,0 1.559,-0.316 2.121,-0.879c0.563,-0.562 0.879,-1.325 0.879,-2.121l0,-1.587Zm0,-3.969l0,-6.444c0,-0.796 -0.316,-1.559 -0.879,-2.121c-0.562,-0.563 -1.325,-0.879 -2.121,-0.879c-7.738,0 -11,0 -11,0c-0.265,0 -0.52,-0.105 -0.707,-0.293c-0,0 -3.707,-3.707 -3.707,-3.707c-0,0 -4.588,0 -4.588,0c-1.656,0 -2.998,1.342 -2.998,2.998l0,12.16l2.729,-4.677c0.896,-1.536 2.54,-2.481 4.318,-2.481c3.354,0 9.552,0 12.906,0c1.778,0 3.422,0.945 4.318,2.481l1.729,2.963Z" + id="path2" /> +</g> +<g style="fill:#D8DFEE;stroke-width:0;"> +<path + d="M 5.3879408,24.913408 C 4.1598821,24.650818 3.1571088,23.558656 3.053503,22.370876 L 3.0312746,22.116041 5.2606813,18.293515 C 6.486855,16.191126 7.5598351,14.372696 7.6450818,14.25256 8.0043056,13.746312 8.5423079,13.363007 9.2104664,13.137285 l 0.2548351,-0.08609 6.9294785,-0.0097 c 6.805096,-0.0095 6.934944,-0.0084 7.234011,0.06267 0.695577,0.165199 1.290483,0.557253 1.714887,1.130141 0.08158,0.110125 0.938747,1.556711 1.90481,3.214634 l 1.756479,3.014406 -0.0186,0.971942 c -0.01387,0.724723 -0.03365,1.032131 -0.07778,1.208575 -0.242792,0.970733 -0.88732,1.735415 -1.772382,2.102793 -0.58835,0.244217 0.247209,0.227436 -11.161974,0.224159 -9.0281537,-0.0026 -10.3636023,-0.0098 -10.5862902,-0.05746 z" + id="path199" /><path + d="M 3.0126385,11.849829 3.0235061,5.5881684 3.1020974,5.2969283 C 3.3478146,4.3863605 3.93576,3.6757372 4.756668,3.2971229 5.3293315,3.0330025 5.1813272,3.0450949 8.0130385,3.0310668 l 2.5522875,-0.012644 1.918693,1.9107086 c 1.404146,1.3983023 1.964459,1.9332518 2.089351,1.9947704 l 0.170657,0.084062 5.897611,0.019367 c 5.553257,0.018236 5.910365,0.023213 6.116041,0.085231 1.102257,0.3323708 1.857042,1.1184422 2.154229,2.2435244 0.05645,0.2137228 0.06373,0.5643981 0.07519,3.6220748 0.0076,2.032169 -5.42e-4,3.370979 -0.02041,3.349261 -0.0182,-0.0199 -0.414296,-0.691472 -0.880217,-1.492382 -0.46592,-0.80091 -0.93093,-1.577954 -1.033354,-1.726764 -0.735716,-1.0689 -1.983568,-1.844244 -3.315972,-2.060353 -0.280375,-0.04548 -1.345158,-0.05334 -7.238708,-0.05347 -4.713933,-1.09e-4 -6.9931825,0.01221 -7.1717862,0.03874 -1.3002273,0.193134 -2.4770512,0.889916 -3.283628,1.944192 -0.1076466,0.140705 -0.8359664,1.353438 -1.6184885,2.694963 L 3.0017709,18.11149 Z" + id="path201" /> +</g> +</svg> diff --git a/sw/folderopend.svg b/sw/folderopend.svg new file mode 100644 index 0000000000..2d1f06e7bc --- /dev/null +++ b/sw/folderopend.svg @@ -0,0 +1,12 @@ +<?xml version="1.0" encoding="UTF-8" standalone="no"?> +<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" + "https://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd"> +<svg version="1.1" width="16" height="24" viewBox="0 0 32 32" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" xml:space="preserve"> +<g style="fill:#C4CFE5;"> +<path d="M1,5.998l0,16.002c-0,1.326 0.527,2.598 1.464,3.536c0.938,0.937 2.21,1.464 3.536,1.464c5.322,0 14.678,-0 20,0c1.326,0 2.598,-0.527 3.536,-1.464c0.937,-0.938 1.464,-2.21 1.464,-3.536c0,-3.486 0,-8.514 0,-12c0,-1.326 -0.527,-2.598 -1.464,-3.536c-0.938,-0.937 -2.21,-1.464 -3.536,-1.464c-0,0 -10.586,0 -10.586,0c0,-0 -3.707,-3.707 -3.707,-3.707c-0.187,-0.188 -0.442,-0.293 -0.707,-0.293l-5.002,0c-2.76,0 -4.998,2.238 -4.998,4.998Zm28,14.415l-3.456,-5.925c-0.538,-0.921 -1.524,-1.488 -2.591,-1.488c-0,0 -12.905,0 -12.906,0c-1.067,0 -2.053,0.567 -2.591,1.488l-4.453,7.635c0.03,0.751 0.342,1.465 0.876,1.998c0.562,0.563 1.325,0.879 2.121,0.879l20,0c0.796,0 1.559,-0.316 2.121,-0.879c0.563,-0.562 0.879,-1.325 0.879,-2.121l0,-1.587Zm0,-3.969l0,-6.444c0,-0.796 -0.316,-1.559 -0.879,-2.121c-0.562,-0.563 -1.325,-0.879 -2.121,-0.879c-7.738,0 -11,0 -11,0c-0.265,0 -0.52,-0.105 -0.707,-0.293c-0,0 -3.707,-3.707 -3.707,-3.707c-0,0 -4.588,0 -4.588,0c-1.656,0 -2.998,1.342 -2.998,2.998l0,12.16l2.729,-4.677c0.896,-1.536 2.54,-2.481 4.318,-2.481c3.354,0 9.552,0 12.906,0c1.778,0 3.422,0.945 4.318,2.481l1.729,2.963Z"/> +</g> +<g style="fill:#4665A2;stroke-width:0;"> +<path d="M 5.3879408,24.913408 C 4.1598821,24.650818 3.1571088,23.558656 3.053503,22.370876 L 3.0312746,22.116041 5.2606813,18.293515 C 6.486855,16.191126 7.5598351,14.372696 7.6450818,14.25256 8.0043056,13.746312 8.5423079,13.363007 9.2104664,13.137285 l 0.2548351,-0.08609 6.9294785,-0.0097 c 6.805096,-0.0095 6.934944,-0.0084 7.234011,0.06267 0.695577,0.165199 1.290483,0.557253 1.714887,1.130141 0.08158,0.110125 0.938747,1.556711 1.90481,3.214634 l 1.756479,3.014406 -0.0186,0.971942 c -0.01387,0.724723 -0.03365,1.032131 -0.07778,1.208575 -0.242792,0.970733 -0.88732,1.735415 -1.772382,2.102793 -0.58835,0.244217 0.247209,0.227436 -11.161974,0.224159 -9.0281537,-0.0026 -10.3636023,-0.0098 -10.5862902,-0.05746 z" /> +<path d="M 3.0126385,11.849829 3.0235061,5.5881684 3.1020974,5.2969283 C 3.3478146,4.3863605 3.93576,3.6757372 4.756668,3.2971229 5.3293315,3.0330025 5.1813272,3.0450949 8.0130385,3.0310668 l 2.5522875,-0.012644 1.918693,1.9107086 c 1.404146,1.3983023 1.964459,1.9332518 2.089351,1.9947704 l 0.170657,0.084062 5.897611,0.019367 c 5.553257,0.018236 5.910365,0.023213 6.116041,0.085231 1.102257,0.3323708 1.857042,1.1184422 2.154229,2.2435244 0.05645,0.2137228 0.06373,0.5643981 0.07519,3.6220748 0.0076,2.032169 -5.42e-4,3.370979 -0.02041,3.349261 -0.0182,-0.0199 -0.414296,-0.691472 -0.880217,-1.492382 -0.46592,-0.80091 -0.93093,-1.577954 -1.033354,-1.726764 -0.735716,-1.0689 -1.983568,-1.844244 -3.315972,-2.060353 -0.280375,-0.04548 -1.345158,-0.05334 -7.238708,-0.05347 -4.713933,-1.09e-4 -6.9931825,0.01221 -7.1717862,0.03874 -1.3002273,0.193134 -2.4770512,0.889916 -3.283628,1.944192 -0.1076466,0.140705 -0.8359664,1.353438 -1.6184885,2.694963 L 3.0017709,18.11149 Z" /> +</g> +</svg> diff --git a/sw/functions.html b/sw/functions.html new file mode 100644 index 0000000000..070514ef8c --- /dev/null +++ b/sw/functions.html @@ -0,0 +1,213 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: Data Fields</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +</div><!-- top --> +<div id="doc-content"> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div class="contents"> +<div class="textblock">Here is a list of all documented struct and union fields with links to the struct/union documentation for each field:</div> + +<h3><a id="index_b" name="index_b"></a>- b -</h3><ul> +<li>binary_value&#160;:&#160;<a class="el" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">float_conv_t</a></li> +</ul> + + +<h3><a id="index_c" name="index_c"></a>- c -</h3><ul> +<li>CACHE&#160;:&#160;<a class="el" href="structneorv32__sysinfo__t.html#ada99a36ccda38b254d5b6a84883101f6">neorv32_sysinfo_t</a></li> +<li>CLK&#160;:&#160;<a class="el" href="structneorv32__sysinfo__t.html#afc225843ee31efff6350415b5aaae761">neorv32_sysinfo_t</a></li> +<li>COUNT&#160;:&#160;<a class="el" href="structneorv32__gptmr__t.html#a1abc5bae1dffc64006e965d4570da479">neorv32_gptmr_t</a></li> +<li>CTRL&#160;:&#160;<a class="el" href="structneorv32__dma__t.html#a8480d6ad3ba5063cdf21dca286711569">neorv32_dma_t</a>, <a class="el" href="structneorv32__gptmr__t.html#a3c477ccb24ed12122d9d90244431c7e9">neorv32_gptmr_t</a>, <a class="el" href="structneorv32__neoled__t.html#adfe7618c002ff88dd22e65fcedfd6139">neorv32_neoled_t</a>, <a class="el" href="structneorv32__onewire__t.html#a310df3bab43e4438417b2ff948f4712a">neorv32_onewire_t</a>, <a class="el" href="structneorv32__pwm__t.html#ab86705332ebd9c45635c3195c6b3dcc5">neorv32_pwm_t</a>, <a class="el" href="structneorv32__sdi__t.html#af494f25cbcd8478cf384eb868e447303">neorv32_sdi_t</a>, <a class="el" href="structneorv32__slink__t.html#a39ece6aeeea6982002e164902a1e784f">neorv32_slink_t</a>, <a class="el" href="structneorv32__spi__t.html#a34fa748f0e3ceb75822c0a5553bd0420">neorv32_spi_t</a>, <a class="el" href="structneorv32__trng__t.html#ae2ff37ce30fb85ef59d9012534bc7e67">neorv32_trng_t</a>, <a class="el" href="structneorv32__twi__t.html#a148a1c681a2632881b25ee41652b5304">neorv32_twi_t</a>, <a class="el" href="structneorv32__uart__t.html#a0a6227aeea38335d2b9a9da46b35451b">neorv32_uart_t</a>, <a class="el" href="structneorv32__wdt__t.html#a6ae41e28d08b0f06118c499f52b56f41">neorv32_wdt_t</a>, <a class="el" href="structneorv32__xip__t.html#a7ead9d6a4f784d766a6b2755c6d35235">neorv32_xip_t</a></li> +</ul> + + +<h3><a id="index_d" name="index_d"></a>- d -</h3><ul> +<li>DATA&#160;:&#160;<a class="el" href="structneorv32__crc__t.html#a47f286612848f597859aaef0d2d5da4d">neorv32_crc_t</a>, <a class="el" href="structneorv32__neoled__t.html#a995fb1d63a9dfb3f20d715932781c1de">neorv32_neoled_t</a>, <a class="el" href="structneorv32__onewire__t.html#a2c04aa736b901940ed65b96202c8af7a">neorv32_onewire_t</a>, <a class="el" href="structneorv32__sdi__t.html#a3ea6903c0924d0a1b633b6a2b0ae44f1">neorv32_sdi_t</a>, <a class="el" href="structneorv32__slink__t.html#a8af7d4ea9787cf94c599c82133c6aa74">neorv32_slink_t</a>, <a class="el" href="structneorv32__spi__t.html#a3901bad351213e34820197a33d589f1e">neorv32_spi_t</a>, <a class="el" href="structneorv32__uart__t.html#a38eec82aae9ed522a0d2afb9a9560036">neorv32_uart_t</a></li> +<li>DATA_HI&#160;:&#160;<a class="el" href="structneorv32__xip__t.html#a516ab9c075ef6d1fb741e243db7703b2">neorv32_xip_t</a></li> +<li>DATA_LAST&#160;:&#160;<a class="el" href="structneorv32__slink__t.html#ada8f10141d2161b83a5a367722ed6a77">neorv32_slink_t</a></li> +<li>DATA_LO&#160;:&#160;<a class="el" href="structneorv32__xip__t.html#ad64048bb3544e712b1c668c2ef343ccb">neorv32_xip_t</a></li> +<li>day&#160;:&#160;<a class="el" href="structdate__t.html#a482ad87226bae7841dfec63e035aeace">date_t</a></li> +<li>DC&#160;:&#160;<a class="el" href="structneorv32__pwm__t.html#a6d29528ca60921a6ef8e5bcde81925e7">neorv32_pwm_t</a></li> +<li>DCMD&#160;:&#160;<a class="el" href="structneorv32__twi__t.html#ae311e0827bdb178c6dd8c4535b80d5cb">neorv32_twi_t</a></li> +<li>DST_BASE&#160;:&#160;<a class="el" href="structneorv32__dma__t.html#aee8a6cf3cbd9fe3c5995f046ffb9a1c0">neorv32_dma_t</a></li> +</ul> + + +<h3><a id="index_e" name="index_e"></a>- e -</h3><ul> +<li>EIE&#160;:&#160;<a class="el" href="structneorv32__xirq__t.html#aef3c2b491207abd68bf6392f97096a74">neorv32_xirq_t</a></li> +<li>EIP&#160;:&#160;<a class="el" href="structneorv32__xirq__t.html#a788d8004f3b85fb66e947415d8fcc058">neorv32_xirq_t</a></li> +<li>ESC&#160;:&#160;<a class="el" href="structneorv32__xirq__t.html#ae4f7f3f41210ff329b6f82d5dfada88a">neorv32_xirq_t</a></li> +</ul> + + +<h3><a id="index_f" name="index_f"></a>- f -</h3><ul> +<li>float_value&#160;:&#160;<a class="el" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_conv_t</a></li> +</ul> + + +<h3><a id="index_h" name="index_h"></a>- h -</h3><ul> +<li>hours&#160;:&#160;<a class="el" href="structdate__t.html#a39a23695634a2814d827984f4eea54eb">date_t</a></li> +</ul> + + +<h3><a id="index_i" name="index_i"></a>- i -</h3><ul> +<li>INPUT&#160;:&#160;<a class="el" href="structneorv32__gpio__t.html#a208ee622d43fee3574072f19a98c8808">neorv32_gpio_t</a></li> +</ul> + + +<h3><a id="index_m" name="index_m"></a>- m -</h3><ul> +<li>MEM&#160;:&#160;<a class="el" href="structneorv32__sysinfo__t.html#a51eee92b1824c1b19eb0a83a0a9c7d4c">neorv32_sysinfo_t</a></li> +<li>minutes&#160;:&#160;<a class="el" href="structdate__t.html#a2ab79834ebae42979e359bf30ad5f67a">date_t</a></li> +<li>MODE&#160;:&#160;<a class="el" href="structneorv32__crc__t.html#ad720502701f16e6e952bbcaee980017c">neorv32_crc_t</a></li> +<li>month&#160;:&#160;<a class="el" href="structdate__t.html#a1a97f6a755cd4209a0880cf811d52c7b">date_t</a></li> +</ul> + + +<h3><a id="index_o" name="index_o"></a>- o -</h3><ul> +<li>OUTPUT&#160;:&#160;<a class="el" href="structneorv32__gpio__t.html#abaf7de4f79adfc3debcde93fa4a921bb">neorv32_gpio_t</a></li> +</ul> + + +<h3><a id="index_p" name="index_p"></a>- p -</h3><ul> +<li>POLY&#160;:&#160;<a class="el" href="structneorv32__crc__t.html#a9bbcab843ddba4f9772d07478947a661">neorv32_crc_t</a></li> +<li>ptrSpiBuf&#160;:&#160;<a class="el" href="structt__neorv32__spi.html#a487a6510820871ff8d0da7699463f6d9">t_neorv32_spi</a></li> +</ul> + + +<h3><a id="index_r" name="index_r"></a>- r -</h3><ul> +<li>REG&#160;:&#160;<a class="el" href="structneorv32__cfs__t.html#a48d3e81b207f4dcce0b0cc901583dc4d">neorv32_cfs_t</a></li> +<li>reserved&#160;:&#160;<a class="el" href="structneorv32__xip__t.html#aacb77d586c3caec518e8e0024cfe745c">neorv32_xip_t</a></li> +<li>reserved0&#160;:&#160;<a class="el" href="structneorv32__xirq__t.html#a9be02c0398fab5763a3afbd7a018f092">neorv32_xirq_t</a></li> +<li>reserved1&#160;:&#160;<a class="el" href="structneorv32__xirq__t.html#ac4c999cf3da75e39753619f917d9d654">neorv32_xirq_t</a></li> +<li>reserved2&#160;:&#160;<a class="el" href="structneorv32__xirq__t.html#afba6ed500e1448719783923975b2dc64">neorv32_xirq_t</a></li> +<li>RESET&#160;:&#160;<a class="el" href="structneorv32__wdt__t.html#a0a273e8ca2bd92547bf7727ec65a9449">neorv32_wdt_t</a></li> +<li>ROUTE&#160;:&#160;<a class="el" href="structneorv32__slink__t.html#a0b2417a1a587da45909ce2a948f90e22">neorv32_slink_t</a></li> +</ul> + + +<h3><a id="index_s" name="index_s"></a>- s -</h3><ul> +<li>seconds&#160;:&#160;<a class="el" href="structdate__t.html#a1071948e7754cb415da9714d59a315bf">date_t</a></li> +<li>SOC&#160;:&#160;<a class="el" href="structneorv32__sysinfo__t.html#ac43abe3b416da3a2895d1d06537a14c3">neorv32_sysinfo_t</a></li> +<li>SRC_BASE&#160;:&#160;<a class="el" href="structneorv32__dma__t.html#a3b214d1a373c7f15b374e113d7110b42">neorv32_dma_t</a></li> +<li>SREG&#160;:&#160;<a class="el" href="structneorv32__crc__t.html#abf2b419f2aefdb6f2a6b81a02cb8612d">neorv32_crc_t</a></li> +</ul> + + +<h3><a id="index_t" name="index_t"></a>- t -</h3><ul> +<li>THRES&#160;:&#160;<a class="el" href="structneorv32__gptmr__t.html#a666ebcbea13dafcf1987629f3e0092ee">neorv32_gptmr_t</a></li> +<li>TIME_HI&#160;:&#160;<a class="el" href="structneorv32__mtime__t.html#a1ffe0be2c45f5d7aa2686abf40cd1693">neorv32_mtime_t</a></li> +<li>TIME_LO&#160;:&#160;<a class="el" href="structneorv32__mtime__t.html#acccaa3dd87a57ebd5f7ae504771e904e">neorv32_mtime_t</a></li> +<li>TIMECMP_HI&#160;:&#160;<a class="el" href="structneorv32__mtime__t.html#af05df268c8f699401cf752e4249ba422">neorv32_mtime_t</a></li> +<li>TIMECMP_LO&#160;:&#160;<a class="el" href="structneorv32__mtime__t.html#ab5fa56ca5c2f9d547f58d169d6da96e5">neorv32_mtime_t</a></li> +<li>TPOL&#160;:&#160;<a class="el" href="structneorv32__xirq__t.html#a5fe0036a2cada585228b60aaa780e92a">neorv32_xirq_t</a></li> +<li>TTYP&#160;:&#160;<a class="el" href="structneorv32__xirq__t.html#ab7117c210b5f0a8ebc369eeba6a4a5bc">neorv32_xirq_t</a></li> +<li>TTYPE&#160;:&#160;<a class="el" href="structneorv32__dma__t.html#a70c28642195765409d97b941e98f47ca">neorv32_dma_t</a></li> +</ul> + + +<h3><a id="index_u" name="index_u"></a>- u -</h3><ul> +<li>uint16Fifo&#160;:&#160;<a class="el" href="structt__neorv32__spi.html#a71fb3f91af197e1abdbe97d62130ad0f">t_neorv32_spi</a></li> +<li>uint32Read&#160;:&#160;<a class="el" href="structt__neorv32__spi.html#a5750a54f8312ec2fed349eb9fbeff323">t_neorv32_spi</a></li> +<li>uint32Total&#160;:&#160;<a class="el" href="structt__neorv32__spi.html#aa4d96f72e57fb6930ab43de6fb0a85ae">t_neorv32_spi</a></li> +<li>uint32Write&#160;:&#160;<a class="el" href="structt__neorv32__spi.html#aa89b7a769e54e331798e4d68d02a7b43">t_neorv32_spi</a></li> +<li>uint8Csn&#160;:&#160;<a class="el" href="structt__neorv32__spi.html#a435c266758a440d32de4344472e3514a">t_neorv32_spi</a></li> +<li>uint8IsBusy&#160;:&#160;<a class="el" href="structt__neorv32__spi.html#a8ed31f9393bee5b963e08582b6c517ed">t_neorv32_spi</a></li> +</ul> + + +<h3><a id="index_w" name="index_w"></a>- w -</h3><ul> +<li>weekday&#160;:&#160;<a class="el" href="structdate__t.html#a44167cd71416886e55048310af6d4e1b">date_t</a></li> +</ul> + + +<h3><a id="index_y" name="index_y"></a>- y -</h3><ul> +<li>year&#160;:&#160;<a class="el" href="structdate__t.html#aabab1b1efd94b69bfb28b639c612dd4f">date_t</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/functions_vars.html b/sw/functions_vars.html new file mode 100644 index 0000000000..b0f84700bf --- /dev/null +++ b/sw/functions_vars.html @@ -0,0 +1,213 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: Data Fields - Variables</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +</div><!-- top --> +<div id="doc-content"> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div class="contents"> +<div class="textblock">Here is a list of all documented variables with links to the struct/union documentation for each field:</div> + +<h3><a id="index_b" name="index_b"></a>- b -</h3><ul> +<li>binary_value&#160;:&#160;<a class="el" href="unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606">float_conv_t</a></li> +</ul> + + +<h3><a id="index_c" name="index_c"></a>- c -</h3><ul> +<li>CACHE&#160;:&#160;<a class="el" href="structneorv32__sysinfo__t.html#ada99a36ccda38b254d5b6a84883101f6">neorv32_sysinfo_t</a></li> +<li>CLK&#160;:&#160;<a class="el" href="structneorv32__sysinfo__t.html#afc225843ee31efff6350415b5aaae761">neorv32_sysinfo_t</a></li> +<li>COUNT&#160;:&#160;<a class="el" href="structneorv32__gptmr__t.html#a1abc5bae1dffc64006e965d4570da479">neorv32_gptmr_t</a></li> +<li>CTRL&#160;:&#160;<a class="el" href="structneorv32__dma__t.html#a8480d6ad3ba5063cdf21dca286711569">neorv32_dma_t</a>, <a class="el" href="structneorv32__gptmr__t.html#a3c477ccb24ed12122d9d90244431c7e9">neorv32_gptmr_t</a>, <a class="el" href="structneorv32__neoled__t.html#adfe7618c002ff88dd22e65fcedfd6139">neorv32_neoled_t</a>, <a class="el" href="structneorv32__onewire__t.html#a310df3bab43e4438417b2ff948f4712a">neorv32_onewire_t</a>, <a class="el" href="structneorv32__pwm__t.html#ab86705332ebd9c45635c3195c6b3dcc5">neorv32_pwm_t</a>, <a class="el" href="structneorv32__sdi__t.html#af494f25cbcd8478cf384eb868e447303">neorv32_sdi_t</a>, <a class="el" href="structneorv32__slink__t.html#a39ece6aeeea6982002e164902a1e784f">neorv32_slink_t</a>, <a class="el" href="structneorv32__spi__t.html#a34fa748f0e3ceb75822c0a5553bd0420">neorv32_spi_t</a>, <a class="el" href="structneorv32__trng__t.html#ae2ff37ce30fb85ef59d9012534bc7e67">neorv32_trng_t</a>, <a class="el" href="structneorv32__twi__t.html#a148a1c681a2632881b25ee41652b5304">neorv32_twi_t</a>, <a class="el" href="structneorv32__uart__t.html#a0a6227aeea38335d2b9a9da46b35451b">neorv32_uart_t</a>, <a class="el" href="structneorv32__wdt__t.html#a6ae41e28d08b0f06118c499f52b56f41">neorv32_wdt_t</a>, <a class="el" href="structneorv32__xip__t.html#a7ead9d6a4f784d766a6b2755c6d35235">neorv32_xip_t</a></li> +</ul> + + +<h3><a id="index_d" name="index_d"></a>- d -</h3><ul> +<li>DATA&#160;:&#160;<a class="el" href="structneorv32__crc__t.html#a47f286612848f597859aaef0d2d5da4d">neorv32_crc_t</a>, <a class="el" href="structneorv32__neoled__t.html#a995fb1d63a9dfb3f20d715932781c1de">neorv32_neoled_t</a>, <a class="el" href="structneorv32__onewire__t.html#a2c04aa736b901940ed65b96202c8af7a">neorv32_onewire_t</a>, <a class="el" href="structneorv32__sdi__t.html#a3ea6903c0924d0a1b633b6a2b0ae44f1">neorv32_sdi_t</a>, <a class="el" href="structneorv32__slink__t.html#a8af7d4ea9787cf94c599c82133c6aa74">neorv32_slink_t</a>, <a class="el" href="structneorv32__spi__t.html#a3901bad351213e34820197a33d589f1e">neorv32_spi_t</a>, <a class="el" href="structneorv32__uart__t.html#a38eec82aae9ed522a0d2afb9a9560036">neorv32_uart_t</a></li> +<li>DATA_HI&#160;:&#160;<a class="el" href="structneorv32__xip__t.html#a516ab9c075ef6d1fb741e243db7703b2">neorv32_xip_t</a></li> +<li>DATA_LAST&#160;:&#160;<a class="el" href="structneorv32__slink__t.html#ada8f10141d2161b83a5a367722ed6a77">neorv32_slink_t</a></li> +<li>DATA_LO&#160;:&#160;<a class="el" href="structneorv32__xip__t.html#ad64048bb3544e712b1c668c2ef343ccb">neorv32_xip_t</a></li> +<li>day&#160;:&#160;<a class="el" href="structdate__t.html#a482ad87226bae7841dfec63e035aeace">date_t</a></li> +<li>DC&#160;:&#160;<a class="el" href="structneorv32__pwm__t.html#a6d29528ca60921a6ef8e5bcde81925e7">neorv32_pwm_t</a></li> +<li>DCMD&#160;:&#160;<a class="el" href="structneorv32__twi__t.html#ae311e0827bdb178c6dd8c4535b80d5cb">neorv32_twi_t</a></li> +<li>DST_BASE&#160;:&#160;<a class="el" href="structneorv32__dma__t.html#aee8a6cf3cbd9fe3c5995f046ffb9a1c0">neorv32_dma_t</a></li> +</ul> + + +<h3><a id="index_e" name="index_e"></a>- e -</h3><ul> +<li>EIE&#160;:&#160;<a class="el" href="structneorv32__xirq__t.html#aef3c2b491207abd68bf6392f97096a74">neorv32_xirq_t</a></li> +<li>EIP&#160;:&#160;<a class="el" href="structneorv32__xirq__t.html#a788d8004f3b85fb66e947415d8fcc058">neorv32_xirq_t</a></li> +<li>ESC&#160;:&#160;<a class="el" href="structneorv32__xirq__t.html#ae4f7f3f41210ff329b6f82d5dfada88a">neorv32_xirq_t</a></li> +</ul> + + +<h3><a id="index_f" name="index_f"></a>- f -</h3><ul> +<li>float_value&#160;:&#160;<a class="el" href="unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788">float_conv_t</a></li> +</ul> + + +<h3><a id="index_h" name="index_h"></a>- h -</h3><ul> +<li>hours&#160;:&#160;<a class="el" href="structdate__t.html#a39a23695634a2814d827984f4eea54eb">date_t</a></li> +</ul> + + +<h3><a id="index_i" name="index_i"></a>- i -</h3><ul> +<li>INPUT&#160;:&#160;<a class="el" href="structneorv32__gpio__t.html#a208ee622d43fee3574072f19a98c8808">neorv32_gpio_t</a></li> +</ul> + + +<h3><a id="index_m" name="index_m"></a>- m -</h3><ul> +<li>MEM&#160;:&#160;<a class="el" href="structneorv32__sysinfo__t.html#a51eee92b1824c1b19eb0a83a0a9c7d4c">neorv32_sysinfo_t</a></li> +<li>minutes&#160;:&#160;<a class="el" href="structdate__t.html#a2ab79834ebae42979e359bf30ad5f67a">date_t</a></li> +<li>MODE&#160;:&#160;<a class="el" href="structneorv32__crc__t.html#ad720502701f16e6e952bbcaee980017c">neorv32_crc_t</a></li> +<li>month&#160;:&#160;<a class="el" href="structdate__t.html#a1a97f6a755cd4209a0880cf811d52c7b">date_t</a></li> +</ul> + + +<h3><a id="index_o" name="index_o"></a>- o -</h3><ul> +<li>OUTPUT&#160;:&#160;<a class="el" href="structneorv32__gpio__t.html#abaf7de4f79adfc3debcde93fa4a921bb">neorv32_gpio_t</a></li> +</ul> + + +<h3><a id="index_p" name="index_p"></a>- p -</h3><ul> +<li>POLY&#160;:&#160;<a class="el" href="structneorv32__crc__t.html#a9bbcab843ddba4f9772d07478947a661">neorv32_crc_t</a></li> +<li>ptrSpiBuf&#160;:&#160;<a class="el" href="structt__neorv32__spi.html#a487a6510820871ff8d0da7699463f6d9">t_neorv32_spi</a></li> +</ul> + + +<h3><a id="index_r" name="index_r"></a>- r -</h3><ul> +<li>REG&#160;:&#160;<a class="el" href="structneorv32__cfs__t.html#a48d3e81b207f4dcce0b0cc901583dc4d">neorv32_cfs_t</a></li> +<li>reserved&#160;:&#160;<a class="el" href="structneorv32__xip__t.html#aacb77d586c3caec518e8e0024cfe745c">neorv32_xip_t</a></li> +<li>reserved0&#160;:&#160;<a class="el" href="structneorv32__xirq__t.html#a9be02c0398fab5763a3afbd7a018f092">neorv32_xirq_t</a></li> +<li>reserved1&#160;:&#160;<a class="el" href="structneorv32__xirq__t.html#ac4c999cf3da75e39753619f917d9d654">neorv32_xirq_t</a></li> +<li>reserved2&#160;:&#160;<a class="el" href="structneorv32__xirq__t.html#afba6ed500e1448719783923975b2dc64">neorv32_xirq_t</a></li> +<li>RESET&#160;:&#160;<a class="el" href="structneorv32__wdt__t.html#a0a273e8ca2bd92547bf7727ec65a9449">neorv32_wdt_t</a></li> +<li>ROUTE&#160;:&#160;<a class="el" href="structneorv32__slink__t.html#a0b2417a1a587da45909ce2a948f90e22">neorv32_slink_t</a></li> +</ul> + + +<h3><a id="index_s" name="index_s"></a>- s -</h3><ul> +<li>seconds&#160;:&#160;<a class="el" href="structdate__t.html#a1071948e7754cb415da9714d59a315bf">date_t</a></li> +<li>SOC&#160;:&#160;<a class="el" href="structneorv32__sysinfo__t.html#ac43abe3b416da3a2895d1d06537a14c3">neorv32_sysinfo_t</a></li> +<li>SRC_BASE&#160;:&#160;<a class="el" href="structneorv32__dma__t.html#a3b214d1a373c7f15b374e113d7110b42">neorv32_dma_t</a></li> +<li>SREG&#160;:&#160;<a class="el" href="structneorv32__crc__t.html#abf2b419f2aefdb6f2a6b81a02cb8612d">neorv32_crc_t</a></li> +</ul> + + +<h3><a id="index_t" name="index_t"></a>- t -</h3><ul> +<li>THRES&#160;:&#160;<a class="el" href="structneorv32__gptmr__t.html#a666ebcbea13dafcf1987629f3e0092ee">neorv32_gptmr_t</a></li> +<li>TIME_HI&#160;:&#160;<a class="el" href="structneorv32__mtime__t.html#a1ffe0be2c45f5d7aa2686abf40cd1693">neorv32_mtime_t</a></li> +<li>TIME_LO&#160;:&#160;<a class="el" href="structneorv32__mtime__t.html#acccaa3dd87a57ebd5f7ae504771e904e">neorv32_mtime_t</a></li> +<li>TIMECMP_HI&#160;:&#160;<a class="el" href="structneorv32__mtime__t.html#af05df268c8f699401cf752e4249ba422">neorv32_mtime_t</a></li> +<li>TIMECMP_LO&#160;:&#160;<a class="el" href="structneorv32__mtime__t.html#ab5fa56ca5c2f9d547f58d169d6da96e5">neorv32_mtime_t</a></li> +<li>TPOL&#160;:&#160;<a class="el" href="structneorv32__xirq__t.html#a5fe0036a2cada585228b60aaa780e92a">neorv32_xirq_t</a></li> +<li>TTYP&#160;:&#160;<a class="el" href="structneorv32__xirq__t.html#ab7117c210b5f0a8ebc369eeba6a4a5bc">neorv32_xirq_t</a></li> +<li>TTYPE&#160;:&#160;<a class="el" href="structneorv32__dma__t.html#a70c28642195765409d97b941e98f47ca">neorv32_dma_t</a></li> +</ul> + + +<h3><a id="index_u" name="index_u"></a>- u -</h3><ul> +<li>uint16Fifo&#160;:&#160;<a class="el" href="structt__neorv32__spi.html#a71fb3f91af197e1abdbe97d62130ad0f">t_neorv32_spi</a></li> +<li>uint32Read&#160;:&#160;<a class="el" href="structt__neorv32__spi.html#a5750a54f8312ec2fed349eb9fbeff323">t_neorv32_spi</a></li> +<li>uint32Total&#160;:&#160;<a class="el" href="structt__neorv32__spi.html#aa4d96f72e57fb6930ab43de6fb0a85ae">t_neorv32_spi</a></li> +<li>uint32Write&#160;:&#160;<a class="el" href="structt__neorv32__spi.html#aa89b7a769e54e331798e4d68d02a7b43">t_neorv32_spi</a></li> +<li>uint8Csn&#160;:&#160;<a class="el" href="structt__neorv32__spi.html#a435c266758a440d32de4344472e3514a">t_neorv32_spi</a></li> +<li>uint8IsBusy&#160;:&#160;<a class="el" href="structt__neorv32__spi.html#a8ed31f9393bee5b963e08582b6c517ed">t_neorv32_spi</a></li> +</ul> + + +<h3><a id="index_w" name="index_w"></a>- w -</h3><ul> +<li>weekday&#160;:&#160;<a class="el" href="structdate__t.html#a44167cd71416886e55048310af6d4e1b">date_t</a></li> +</ul> + + +<h3><a id="index_y" name="index_y"></a>- y -</h3><ul> +<li>year&#160;:&#160;<a class="el" href="structdate__t.html#aabab1b1efd94b69bfb28b639c612dd4f">date_t</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/game__of__life_2main_8c.html b/sw/game__of__life_2main_8c.html new file mode 100644 index 0000000000..d7c37e0aeb --- /dev/null +++ b/sw/game__of__life_2main_8c.html @@ -0,0 +1,460 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/example/game_of_life/main.c File Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_f0f9b27afba2e8cc2da6e5fddcc1a8c9.html">example</a></li><li class="navelem"><a class="el" href="dir_46981071cfd8ec44311b09fdcf6c06a8.html">game_of_life</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#func-members">Functions</a> &#124; +<a href="#var-members">Variables</a> </div> + <div class="headertitle"><div class="title">main.c File Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p>Conway's game of life in a UART terminal. +<a href="#details">More...</a></p> +<div class="textblock"><code>#include &lt;<a class="el" href="neorv32_8h_source.html">neorv32.h</a>&gt;</code><br /> +</div><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="define-members" name="define-members"></a> +Macros</h2></td></tr> +<tr><td colspan="2"><div class="groupHeader">User configuration</div></td></tr> +<tr class="memitem:ad4455691936f92fdd6c37566fc58ba1f" id="r_ad4455691936f92fdd6c37566fc58ba1f"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ad4455691936f92fdd6c37566fc58ba1f">BAUD_RATE</a>&#160;&#160;&#160;19200</td></tr> +<tr class="separator:ad4455691936f92fdd6c37566fc58ba1f"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a78c5b500f0f057bcaedf6fedeca7c537" id="r_a78c5b500f0f057bcaedf6fedeca7c537"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a78c5b500f0f057bcaedf6fedeca7c537">NUM_CELLS_X</a>&#160;&#160;&#160;160</td></tr> +<tr class="separator:a78c5b500f0f057bcaedf6fedeca7c537"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aed77778557404b38bebb05b5830368b4" id="r_aed77778557404b38bebb05b5830368b4"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aed77778557404b38bebb05b5830368b4">NUM_CELLS_Y</a>&#160;&#160;&#160;40</td></tr> +<tr class="separator:aed77778557404b38bebb05b5830368b4"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a3f33bf77abbf35c245956489f8f7e3a7" id="r_a3f33bf77abbf35c245956489f8f7e3a7"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a3f33bf77abbf35c245956489f8f7e3a7">GEN_DELAY</a>&#160;&#160;&#160;500</td></tr> +<tr class="separator:a3f33bf77abbf35c245956489f8f7e3a7"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:abe6bebcf1cb4f5b4d522c1706eb48663" id="r_abe6bebcf1cb4f5b4d522c1706eb48663"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#abe6bebcf1cb4f5b4d522c1706eb48663">CELL_DEAD</a>&#160;&#160;&#160;(' ')</td></tr> +<tr class="separator:abe6bebcf1cb4f5b4d522c1706eb48663"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:afa6488273e16792d9c3da5e40e3f572d" id="r_afa6488273e16792d9c3da5e40e3f572d"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#afa6488273e16792d9c3da5e40e3f572d">CELL_ALIVE</a>&#160;&#160;&#160;('#')</td></tr> +<tr class="separator:afa6488273e16792d9c3da5e40e3f572d"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="func-members" name="func-members"></a> +Functions</h2></td></tr> +<tr class="memitem:a819f10c5b644a07eeb069b6e7f12050e" id="r_a819f10c5b644a07eeb069b6e7f12050e"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a819f10c5b644a07eeb069b6e7f12050e">clear_universe</a> (int u)</td></tr> +<tr class="separator:a819f10c5b644a07eeb069b6e7f12050e"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a5315eb56128f1ca40d9f4d477c345dd7" id="r_a5315eb56128f1ca40d9f4d477c345dd7"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a5315eb56128f1ca40d9f4d477c345dd7">set_cell</a> (int u, int x, int y)</td></tr> +<tr class="separator:a5315eb56128f1ca40d9f4d477c345dd7"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a6bd541a19c62ea9ec620eaad3f218d16" id="r_a6bd541a19c62ea9ec620eaad3f218d16"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a6bd541a19c62ea9ec620eaad3f218d16">get_cell</a> (int u, int x, int y)</td></tr> +<tr class="separator:a6bd541a19c62ea9ec620eaad3f218d16"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a977190adaa24a3f49fca1540b51d25a0" id="r_a977190adaa24a3f49fca1540b51d25a0"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a977190adaa24a3f49fca1540b51d25a0">get_neighborhood</a> (int u, int x, int y)</td></tr> +<tr class="separator:a977190adaa24a3f49fca1540b51d25a0"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a9a455dea83a25f656fcc5217ad513dac" id="r_a9a455dea83a25f656fcc5217ad513dac"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a9a455dea83a25f656fcc5217ad513dac">print_universe</a> (int u)</td></tr> +<tr class="separator:a9a455dea83a25f656fcc5217ad513dac"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aac4bec7738b12f5a4b4d7a3a6cb1ab8d" id="r_aac4bec7738b12f5a4b4d7a3a6cb1ab8d"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aac4bec7738b12f5a4b4d7a3a6cb1ab8d">pop_count</a> (int u)</td></tr> +<tr class="separator:aac4bec7738b12f5a4b4d7a3a6cb1ab8d"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a840291bc02cba5474a4cb46a9b9566fe" id="r_a840291bc02cba5474a4cb46a9b9566fe"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a840291bc02cba5474a4cb46a9b9566fe">main</a> (void)</td></tr> +<tr class="separator:a840291bc02cba5474a4cb46a9b9566fe"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="var-members" name="var-members"></a> +Variables</h2></td></tr> +<tr class="memitem:ae0b5214cf0cd93049e9df8a95a09d826" id="r_ae0b5214cf0cd93049e9df8a95a09d826"><td class="memItemLeft" align="right" valign="top">uint8_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ae0b5214cf0cd93049e9df8a95a09d826">universe</a> [2][<a class="el" href="#a78c5b500f0f057bcaedf6fedeca7c537">NUM_CELLS_X</a>/8][<a class="el" href="#aed77778557404b38bebb05b5830368b4">NUM_CELLS_Y</a>]</td></tr> +<tr class="separator:ae0b5214cf0cd93049e9df8a95a09d826"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>Conway's game of life in a UART terminal. </p> +<dl class="section author"><dt>Author</dt><dd>Stephan Nolting </dd></dl> +</div><h2 class="groupheader">Macro Definition Documentation</h2> +<a id="ad4455691936f92fdd6c37566fc58ba1f" name="ad4455691936f92fdd6c37566fc58ba1f"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ad4455691936f92fdd6c37566fc58ba1f">&#9670;&#160;</a></span>BAUD_RATE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define BAUD_RATE&#160;&#160;&#160;19200</td> + </tr> + </table> +</div><div class="memdoc"> +<p>UART BAUD rate </p> + +</div> +</div> +<a id="afa6488273e16792d9c3da5e40e3f572d" name="afa6488273e16792d9c3da5e40e3f572d"></a> +<h2 class="memtitle"><span class="permalink"><a href="#afa6488273e16792d9c3da5e40e3f572d">&#9670;&#160;</a></span>CELL_ALIVE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define CELL_ALIVE&#160;&#160;&#160;('#')</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Symbol for alive cell </p> + +</div> +</div> +<a id="abe6bebcf1cb4f5b4d522c1706eb48663" name="abe6bebcf1cb4f5b4d522c1706eb48663"></a> +<h2 class="memtitle"><span class="permalink"><a href="#abe6bebcf1cb4f5b4d522c1706eb48663">&#9670;&#160;</a></span>CELL_DEAD</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define CELL_DEAD&#160;&#160;&#160;(' ')</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Symbol for dead cell </p> + +</div> +</div> +<a id="a3f33bf77abbf35c245956489f8f7e3a7" name="a3f33bf77abbf35c245956489f8f7e3a7"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a3f33bf77abbf35c245956489f8f7e3a7">&#9670;&#160;</a></span>GEN_DELAY</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define GEN_DELAY&#160;&#160;&#160;500</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Delay between generations in ms </p> + +</div> +</div> +<a id="a78c5b500f0f057bcaedf6fedeca7c537" name="a78c5b500f0f057bcaedf6fedeca7c537"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a78c5b500f0f057bcaedf6fedeca7c537">&#9670;&#160;</a></span>NUM_CELLS_X</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define NUM_CELLS_X&#160;&#160;&#160;160</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Universe x size (has to be a multiple of 8) </p> + +</div> +</div> +<a id="aed77778557404b38bebb05b5830368b4" name="aed77778557404b38bebb05b5830368b4"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aed77778557404b38bebb05b5830368b4">&#9670;&#160;</a></span>NUM_CELLS_Y</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define NUM_CELLS_Y&#160;&#160;&#160;40</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Universe y size </p> + +</div> +</div> +<h2 class="groupheader">Function Documentation</h2> +<a id="a819f10c5b644a07eeb069b6e7f12050e" name="a819f10c5b644a07eeb069b6e7f12050e"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a819f10c5b644a07eeb069b6e7f12050e">&#9670;&#160;</a></span>clear_universe()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void clear_universe </td> + <td>(</td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>u</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Kill all cells in universe.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">u</td><td>Universe select (0 or 1). </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="a6bd541a19c62ea9ec620eaad3f218d16" name="a6bd541a19c62ea9ec620eaad3f218d16"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a6bd541a19c62ea9ec620eaad3f218d16">&#9670;&#160;</a></span>get_cell()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int get_cell </td> + <td>(</td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>u</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>x</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>y</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Get state of cell.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">u</td><td>Universe select (0 or 1). </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">x</td><td>X coordinate of cell. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">y</td><td>Y coordinate of cell. </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Cell is dead when 0, cell is alive when 1. </dd></dl> + +</div> +</div> +<a id="a977190adaa24a3f49fca1540b51d25a0" name="a977190adaa24a3f49fca1540b51d25a0"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a977190adaa24a3f49fca1540b51d25a0">&#9670;&#160;</a></span>get_neighborhood()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int get_neighborhood </td> + <td>(</td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>u</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>x</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>y</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Get number of living cells in neighborhood.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">u</td><td>Universe select (0 or 1). </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">x</td><td>X coordinate of the neighborhood's center cell. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">y</td><td>Y coordinate of the neighborhood's center cell. </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Number of living cells in neighborhood (0..9). </dd></dl> + +</div> +</div> +<a id="a840291bc02cba5474a4cb46a9b9566fe" name="a840291bc02cba5474a4cb46a9b9566fe"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a840291bc02cba5474a4cb46a9b9566fe">&#9670;&#160;</a></span>main()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int main </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Conway's Game of Life.</p> +<dl class="section note"><dt>Note</dt><dd>This program requires the UART to be synthesized (the TRNG is optional).</dd></dl> +<dl class="section return"><dt>Returns</dt><dd>0 if execution was successful </dd></dl> + +</div> +</div> +<a id="aac4bec7738b12f5a4b4d7a3a6cb1ab8d" name="aac4bec7738b12f5a4b4d7a3a6cb1ab8d"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aac4bec7738b12f5a4b4d7a3a6cb1ab8d">&#9670;&#160;</a></span>pop_count()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int pop_count </td> + <td>(</td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>u</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Count living cells in universe.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">u</td><td>Universe select (0 or 1). </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Number of living cells. </dd></dl> + +</div> +</div> +<a id="a9a455dea83a25f656fcc5217ad513dac" name="a9a455dea83a25f656fcc5217ad513dac"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a9a455dea83a25f656fcc5217ad513dac">&#9670;&#160;</a></span>print_universe()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void print_universe </td> + <td>(</td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>u</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Print universe via UARt.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">u</td><td>Universe select (0 or 1). </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="a5315eb56128f1ca40d9f4d477c345dd7" name="a5315eb56128f1ca40d9f4d477c345dd7"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a5315eb56128f1ca40d9f4d477c345dd7">&#9670;&#160;</a></span>set_cell()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void set_cell </td> + <td>(</td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>u</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>x</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>y</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Make cell alive.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">u</td><td>Universe select (0 or 1). </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">x</td><td>X coordinate of cell. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">y</td><td>Y coordinate of cell. </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<h2 class="groupheader">Variable Documentation</h2> +<a id="ae0b5214cf0cd93049e9df8a95a09d826" name="ae0b5214cf0cd93049e9df8a95a09d826"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ae0b5214cf0cd93049e9df8a95a09d826">&#9670;&#160;</a></span>universe</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint8_t universe[2][<a class="el" href="#a78c5b500f0f057bcaedf6fedeca7c537">NUM_CELLS_X</a>/8][<a class="el" href="#aed77778557404b38bebb05b5830368b4">NUM_CELLS_Y</a>]</td> + </tr> + </table> +</div><div class="memdoc"> +<p>The universe </p> + +</div> +</div> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/globals.html b/sw/globals.html new file mode 100644 index 0000000000..f3d3a9a15f --- /dev/null +++ b/sw/globals.html @@ -0,0 +1,110 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: Globals</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +</div><!-- top --> +<div id="doc-content"> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div class="contents"> +<div class="textblock">Here is a list of all documented functions, variables, defines, enums, and typedefs with links to the documentation:</div> + +<h3><a id="index__5F" name="index__5F"></a>- _ -</h3><ul> +<li>__crt0_max_heap&#160;:&#160;<a class="el" href="demo__newlib_2main_8c.html#aaa2cb9e7075a852870fd67eff2861b18">main.c</a></li> +<li>__neorv32_rte_core()&#160;:&#160;<a class="el" href="neorv32__rte_8c.html#a53f1e006f0bf61deb7ad018f35228873">neorv32_rte.c</a></li> +<li>__neorv32_rte_print_hex_word()&#160;:&#160;<a class="el" href="neorv32__rte_8c.html#a01bf6c01f5a8cda2132b9ac98824edc1">neorv32_rte.c</a></li> +<li>__neorv32_rte_vector_lut&#160;:&#160;<a class="el" href="neorv32__rte_8c.html#a2c8272b4628edddb943bcfad829b561a">neorv32_rte.c</a></li> +<li>__neorv32_uart_itoa()&#160;:&#160;<a class="el" href="neorv32__uart_8c.html#a3543435827204d82755b0a23bdea1296">neorv32_uart.c</a></li> +<li>__neorv32_uart_tohex()&#160;:&#160;<a class="el" href="neorv32__uart_8c.html#aefa844cd170e50e088c42829029060f3">neorv32_uart.c</a></li> +<li>__neorv32_uart_touppercase()&#160;:&#160;<a class="el" href="neorv32__uart_8c.html#adf807d0476b475276b8b29924297cda9">neorv32_uart.c</a></li> +<li>__neorv32_xirq_core()&#160;:&#160;<a class="el" href="neorv32__xirq_8c.html#a14661d628dd31e6bfce89376c6614627">neorv32_xirq.c</a></li> +<li>__neorv32_xirq_dummy_handler()&#160;:&#160;<a class="el" href="neorv32__xirq_8c.html#ae4d9362b23a1341c595a4cd239a87091">neorv32_xirq.c</a></li> +<li>__neorv32_xirq_vector_lut&#160;:&#160;<a class="el" href="neorv32__xirq_8c.html#a76d73c3bf372989703c685a9e8d229ac">neorv32_xirq.c</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/globals_a.html b/sw/globals_a.html new file mode 100644 index 0000000000..9de724d8d6 --- /dev/null +++ b/sw/globals_a.html @@ -0,0 +1,104 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: Globals</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +</div><!-- top --> +<div id="doc-content"> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div class="contents"> +<div class="textblock">Here is a list of all documented functions, variables, defines, enums, and typedefs with links to the documentation:</div> + +<h3><a id="index_a" name="index_a"></a>- a -</h3><ul> +<li>adaptive_proportion_test()&#160;:&#160;<a class="el" href="demo__trng_2main_8c.html#a23a91e6fe2cc44f3c29baf0d331e05db">main.c</a></li> +<li>amo_var&#160;:&#160;<a class="el" href="atomic__test_2main_8c.html#a9141e95a5f98420ddf8a43e6d20ff6dc">main.c</a></li> +<li>AUTO_BOOT_TIMEOUT&#160;:&#160;<a class="el" href="bootloader_8c.html#af6fcb607a9c320da869b72aa30893a69">bootloader.c</a></li> +<li>aux_print_hex_byte()&#160;:&#160;<a class="el" href="bus__explorer_2main_8c.html#ac582208281cd6fce4eb61c234f312ef6">main.c</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/globals_b.html b/sw/globals_b.html new file mode 100644 index 0000000000..bbe4e6719c --- /dev/null +++ b/sw/globals_b.html @@ -0,0 +1,104 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: Globals</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +</div><!-- top --> +<div id="doc-content"> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div class="contents"> +<div class="textblock">Here is a list of all documented functions, variables, defines, enums, and typedefs with links to the documentation:</div> + +<h3><a id="index_b" name="index_b"></a>- b -</h3><ul> +<li>BAUD_RATE&#160;:&#160;<a class="el" href="atomic__test_2main_8c.html#ad4455691936f92fdd6c37566fc58ba1f">main.c</a></li> +<li>BOOTLOADER_BASE_ADDRESS&#160;:&#160;<a class="el" href="neorv32_8h.html#abd8c9b7d79f49de1722611b2835cde58">neorv32.h</a></li> +<li>bootloader_trap_handler()&#160;:&#160;<a class="el" href="bootloader_8c.html#af13b4b3d5e6597feacf331e6d16b08e9">bootloader.c</a></li> +<li>BUFFER_SIZE&#160;:&#160;<a class="el" href="demo__xip_2main_8c.html#a6b20d41d6252e9871430c242cb1a56e7">main.c</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/globals_c.html b/sw/globals_c.html new file mode 100644 index 0000000000..53c1db83a4 --- /dev/null +++ b/sw/globals_c.html @@ -0,0 +1,357 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: Globals</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +</div><!-- top --> +<div id="doc-content"> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div class="contents"> +<div class="textblock">Here is a list of all documented functions, variables, defines, enums, and typedefs with links to the documentation:</div> + +<h3><a id="index_c" name="index_c"></a>- c -</h3><ul> +<li>CELL_ALIVE&#160;:&#160;<a class="el" href="game__of__life_2main_8c.html#afa6488273e16792d9c3da5e40e3f572d">main.c</a></li> +<li>CELL_DEAD&#160;:&#160;<a class="el" href="game__of__life_2main_8c.html#abe6bebcf1cb4f5b4d522c1706eb48663">main.c</a></li> +<li>CFS_FIRQ_ENABLE&#160;:&#160;<a class="el" href="neorv32_8h.html#ace79ee46daf3a1b689d9fe79dfcd6627">neorv32.h</a></li> +<li>CFS_FIRQ_PENDING&#160;:&#160;<a class="el" href="neorv32_8h.html#aae182648a2c23d070b9db0295388e001">neorv32.h</a></li> +<li>CFS_RTE_ID&#160;:&#160;<a class="el" href="neorv32_8h.html#a095f41fbefaa7acc1bfdd65cd3ce06ea">neorv32.h</a></li> +<li>CFS_TRAP_CODE&#160;:&#160;<a class="el" href="neorv32_8h.html#aae6b2ae3fba20ff80bfb59735f179c26">neorv32.h</a></li> +<li>check_result()&#160;:&#160;<a class="el" href="atomic__test_2main_8c.html#a4f4c6d8481b4100f90955ba5a70428a4">main.c</a></li> +<li>clear_universe()&#160;:&#160;<a class="el" href="game__of__life_2main_8c.html#a819f10c5b644a07eeb069b6e7f12050e">main.c</a></li> +<li>CLK_PRSC_1024&#160;:&#160;<a class="el" href="neorv32_8h.html#a10022df4c223533b04d5aebe222e8b73a18aac15afd5ebd8d3a00dd6e513daf17">neorv32.h</a></li> +<li>CLK_PRSC_128&#160;:&#160;<a class="el" href="neorv32_8h.html#a10022df4c223533b04d5aebe222e8b73a933045a5405de55781d687315f42054e">neorv32.h</a></li> +<li>CLK_PRSC_2&#160;:&#160;<a class="el" href="neorv32_8h.html#a10022df4c223533b04d5aebe222e8b73ad63d40139c50d76618cf1258cbdc0d05">neorv32.h</a></li> +<li>CLK_PRSC_2048&#160;:&#160;<a class="el" href="neorv32_8h.html#a10022df4c223533b04d5aebe222e8b73aa138f0cad547028d5124f89d6dcc8c79">neorv32.h</a></li> +<li>CLK_PRSC_4&#160;:&#160;<a class="el" href="neorv32_8h.html#a10022df4c223533b04d5aebe222e8b73a648249b3ab8c2500880c1e68b98f81d1">neorv32.h</a></li> +<li>CLK_PRSC_4096&#160;:&#160;<a class="el" href="neorv32_8h.html#a10022df4c223533b04d5aebe222e8b73a0f20c29722bf9afc478b1a286a6b7eee">neorv32.h</a></li> +<li>CLK_PRSC_64&#160;:&#160;<a class="el" href="neorv32_8h.html#a10022df4c223533b04d5aebe222e8b73a5990532893f2d9606e3c02aff60ca5da">neorv32.h</a></li> +<li>CLK_PRSC_8&#160;:&#160;<a class="el" href="neorv32_8h.html#a10022df4c223533b04d5aebe222e8b73aa4e3a6a5b3cd895f63b4544f63ce22c9">neorv32.h</a></li> +<li>compute_rate()&#160;:&#160;<a class="el" href="demo__trng_2main_8c.html#abbde1237eed617466fb971a78c3acd1e">main.c</a></li> +<li>CRC_MODE16&#160;:&#160;<a class="el" href="neorv32__crc_8h.html#a1ae84a58f475bafc2fc3f2c690fd6447aa5cfd5d285b4cb8997c7e754491d050f">neorv32_crc.h</a></li> +<li>CRC_MODE32&#160;:&#160;<a class="el" href="neorv32__crc_8h.html#a1ae84a58f475bafc2fc3f2c690fd6447a7cf26bd4a7e8d6e45016633f650f00aa">neorv32_crc.h</a></li> +<li>CRC_MODE8&#160;:&#160;<a class="el" href="neorv32__crc_8h.html#a1ae84a58f475bafc2fc3f2c690fd6447a9409185edbae1bd0afdeda4e58aa6d1a">neorv32_crc.h</a></li> +<li>CSR_CFUREG0&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ae0e9cf0b99b8614ea0b870d38970281f">neorv32_cpu_csr.h</a></li> +<li>CSR_CFUREG1&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a382304065a6db773f925b80b9447b8a8">neorv32_cpu_csr.h</a></li> +<li>CSR_CFUREG2&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a427d7cf036b49efd46166c01f0504b68">neorv32_cpu_csr.h</a></li> +<li>CSR_CFUREG3&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aefefa1cff0cf5d01109486e5a8bebedf">neorv32_cpu_csr.h</a></li> +<li>CSR_CYCLE&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aaaf0f6b17a06d5922bcfdb47b382137e">neorv32_cpu_csr.h</a></li> +<li>CSR_CYCLEH&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aa276bedb7dab28935163397b4879f6db">neorv32_cpu_csr.h</a></li> +<li>CSR_DCSR&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a6bb3ba59a25803d6f98faad67609a9a9">neorv32_cpu_csr.h</a></li> +<li>CSR_DPC&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49af4c98d949d2eb44f2518fdf314344d3b">neorv32_cpu_csr.h</a></li> +<li>CSR_DSCRATCH0&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a0f4a1ae740efd80d14d21e90f355e9d7">neorv32_cpu_csr.h</a></li> +<li>CSR_FCSR&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a5e1abf46b4f55bd18e1d132b32696ab6">neorv32_cpu_csr.h</a></li> +<li>CSR_FFLAGS&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a625f606c14fd4d7224d7109e10508e7a">neorv32_cpu_csr.h</a></li> +<li>CSR_FFLAGS_DZ&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#afde0761e3150d82511136f56179c204ba365f3f519bca34a349907c82c873d52b">neorv32_cpu_csr.h</a></li> +<li>CSR_FFLAGS_NV&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#afde0761e3150d82511136f56179c204ba3ac330a4b03178e756c980eaa48ad165">neorv32_cpu_csr.h</a></li> +<li>CSR_FFLAGS_NX&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#afde0761e3150d82511136f56179c204ba91a314defd310786a9ed67f7ef2ef5a6">neorv32_cpu_csr.h</a></li> +<li>CSR_FFLAGS_OF&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#afde0761e3150d82511136f56179c204ba612390e07a065fa13eeaeac84af48c6e">neorv32_cpu_csr.h</a></li> +<li>CSR_FFLAGS_UF&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#afde0761e3150d82511136f56179c204babc6d405724563844569028f463885819">neorv32_cpu_csr.h</a></li> +<li>CSR_FRM&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a7f198c465959dde37b7056dd06d45812">neorv32_cpu_csr.h</a></li> +<li>CSR_HPMCOUNTER10&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aa407e701bdbb9d26f84684b811c008a9">neorv32_cpu_csr.h</a></li> +<li>CSR_HPMCOUNTER10H&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ae56e95d6d6dd63ff6f5b4192cf48c88b">neorv32_cpu_csr.h</a></li> +<li>CSR_HPMCOUNTER11&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a9fd1ff4e8a42992c0a3ec02c397dd7f8">neorv32_cpu_csr.h</a></li> +<li>CSR_HPMCOUNTER11H&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a2af8c5dcc87d92bcce392fb5b3aa065e">neorv32_cpu_csr.h</a></li> +<li>CSR_HPMCOUNTER12&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ae58f15a95aa41126819effe046ced804">neorv32_cpu_csr.h</a></li> +<li>CSR_HPMCOUNTER12H&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a74359db2583feb7119d4bcaa926242a0">neorv32_cpu_csr.h</a></li> +<li>CSR_HPMCOUNTER13&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a24d8617a6ff2c1e49c9a73853ad9e450">neorv32_cpu_csr.h</a></li> +<li>CSR_HPMCOUNTER13H&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a4fa22699e96d6da8665077e3c95891ef">neorv32_cpu_csr.h</a></li> +<li>CSR_HPMCOUNTER14&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aa47ed1a4a4f9fcabceed0d6d626d0aaf">neorv32_cpu_csr.h</a></li> +<li>CSR_HPMCOUNTER14H&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a03f29e792be2854efc9e66d710b78a1d">neorv32_cpu_csr.h</a></li> +<li>CSR_HPMCOUNTER15&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a7277a8f929a5a250f7227fbbdf545dbc">neorv32_cpu_csr.h</a></li> +<li>CSR_HPMCOUNTER15H&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a11169bd08920d40c8f94fd29e1d33eff">neorv32_cpu_csr.h</a></li> +<li>CSR_HPMCOUNTER3&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a3ee699d5b2886c54c92992f66b109b67">neorv32_cpu_csr.h</a></li> +<li>CSR_HPMCOUNTER3H&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aaa3e6a1ac8999be42d7c13891546bb50">neorv32_cpu_csr.h</a></li> +<li>CSR_HPMCOUNTER4&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a98ed49716d0d89712863e7a542d38d2a">neorv32_cpu_csr.h</a></li> +<li>CSR_HPMCOUNTER4H&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a8837ff8d2741639aa69da59659f9a080">neorv32_cpu_csr.h</a></li> +<li>CSR_HPMCOUNTER5&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ab2376c3b7c3ec0b44105ec1ed951bfb0">neorv32_cpu_csr.h</a></li> +<li>CSR_HPMCOUNTER5H&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ad489feaa5ad1feb00d3df71d3e5b0cac">neorv32_cpu_csr.h</a></li> +<li>CSR_HPMCOUNTER6&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aa2f644a4f54ba3834bafa738208c0803">neorv32_cpu_csr.h</a></li> +<li>CSR_HPMCOUNTER6H&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a438a65757b85f182dfb1f2a06c9ad520">neorv32_cpu_csr.h</a></li> +<li>CSR_HPMCOUNTER7&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a125c4d0051548dea9104808b7bee1316">neorv32_cpu_csr.h</a></li> +<li>CSR_HPMCOUNTER7H&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a6332d4ff090aa7c302d191219e846fff">neorv32_cpu_csr.h</a></li> +<li>CSR_HPMCOUNTER8&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49acac87125f8c723cc5df4d4169a82852b">neorv32_cpu_csr.h</a></li> +<li>CSR_HPMCOUNTER8H&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aa8ce8fc8a57dd82872d02b4113249a77">neorv32_cpu_csr.h</a></li> +<li>CSR_HPMCOUNTER9&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ab45ebb3bd861074a15cc2ad874756e8f">neorv32_cpu_csr.h</a></li> +<li>CSR_HPMCOUNTER9H&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49acdf793b30919e7fa1b85995abe531a20">neorv32_cpu_csr.h</a></li> +<li>CSR_INSTRET&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a8144da8cd8691ac54aa0712685865b66">neorv32_cpu_csr.h</a></li> +<li>CSR_INSTRETH&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a9b66978d76260283007d399fc735d153">neorv32_cpu_csr.h</a></li> +<li>CSR_MARCHID&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ad95cb95266533123447ff0e917f890e4">neorv32_cpu_csr.h</a></li> +<li>CSR_MCAUSE&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a2e14b57fee5376741634db7980a5005b">neorv32_cpu_csr.h</a></li> +<li>CSR_MCONFIGPTR&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a0545d0921b3f90d037dbb25bc5fcc2f9">neorv32_cpu_csr.h</a></li> +<li>CSR_MCOUNTEREN&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a1860dd9579906c67a3565063043dcf78">neorv32_cpu_csr.h</a></li> +<li>CSR_MCOUNTINHIBIT&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a3ce1dc0e2810f0df78feaa1c607a5ca6">neorv32_cpu_csr.h</a></li> +<li>CSR_MCOUNTINHIBIT_CY&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea201ac39b0eba389b0d02c3951a3311a3">neorv32_cpu_csr.h</a></li> +<li>CSR_MCOUNTINHIBIT_HPM10&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea9517cd32744c5064fa30780f911cd22e">neorv32_cpu_csr.h</a></li> +<li>CSR_MCOUNTINHIBIT_HPM11&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfeacaf997fe8b912596224e2bb632e6a806">neorv32_cpu_csr.h</a></li> +<li>CSR_MCOUNTINHIBIT_HPM12&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea8d866a4c815d8ba890a1e00ce9600486">neorv32_cpu_csr.h</a></li> +<li>CSR_MCOUNTINHIBIT_HPM13&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfead9f6c4eb4284ee82b9e8d0c79f62b3ed">neorv32_cpu_csr.h</a></li> +<li>CSR_MCOUNTINHIBIT_HPM14&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfeaa83c0688869b1c43de0c4474e940f987">neorv32_cpu_csr.h</a></li> +<li>CSR_MCOUNTINHIBIT_HPM15&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea0b547cb5876c0e7956e3d062e0784085">neorv32_cpu_csr.h</a></li> +<li>CSR_MCOUNTINHIBIT_HPM16&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea68aba71ea77aba4005fb24a945ef38e4">neorv32_cpu_csr.h</a></li> +<li>CSR_MCOUNTINHIBIT_HPM17&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea8d57acf13a086635a63bc13ccdf479b3">neorv32_cpu_csr.h</a></li> +<li>CSR_MCOUNTINHIBIT_HPM18&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfeaa680d196d2ba0e403801a860bb9d8ce0">neorv32_cpu_csr.h</a></li> +<li>CSR_MCOUNTINHIBIT_HPM19&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea3683e296caafe771b6dd57f4cf86f3dc">neorv32_cpu_csr.h</a></li> +<li>CSR_MCOUNTINHIBIT_HPM20&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfeaeb4b1b6abafd22eec0764d5503878cca">neorv32_cpu_csr.h</a></li> +<li>CSR_MCOUNTINHIBIT_HPM21&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea1dc0276a5354c805ac56fd46c5037d38">neorv32_cpu_csr.h</a></li> +<li>CSR_MCOUNTINHIBIT_HPM22&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfeaf1b6153a0c664367bfefb78b2ca8b34e">neorv32_cpu_csr.h</a></li> +<li>CSR_MCOUNTINHIBIT_HPM23&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea85c0c2b2a5101380dec72516dda1a904">neorv32_cpu_csr.h</a></li> +<li>CSR_MCOUNTINHIBIT_HPM24&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea74ec85a2e94aa0b9e8af29401ef7ecb1">neorv32_cpu_csr.h</a></li> +<li>CSR_MCOUNTINHIBIT_HPM25&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfeaee2b5a2b7bd7ac07dae45900bc2faf46">neorv32_cpu_csr.h</a></li> +<li>CSR_MCOUNTINHIBIT_HPM26&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea141a4a211c496d2af1c79d8e8e0c2a74">neorv32_cpu_csr.h</a></li> +<li>CSR_MCOUNTINHIBIT_HPM27&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea46def851d4582b4bcec1f9d8bafd58db">neorv32_cpu_csr.h</a></li> +<li>CSR_MCOUNTINHIBIT_HPM28&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea33d0fd3378ec3a2fcc3c8738c6cd2f32">neorv32_cpu_csr.h</a></li> +<li>CSR_MCOUNTINHIBIT_HPM29&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfeaa39882f7dad9b7e16b317c75bad31382">neorv32_cpu_csr.h</a></li> +<li>CSR_MCOUNTINHIBIT_HPM3&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfeaf7020159e0ba346561bfba101d22c752">neorv32_cpu_csr.h</a></li> +<li>CSR_MCOUNTINHIBIT_HPM30&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea0f45818fa4cb9033a3093987fa8515c7">neorv32_cpu_csr.h</a></li> +<li>CSR_MCOUNTINHIBIT_HPM31&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea1da1186ef2f4e7297a4fecaaccdc1d05">neorv32_cpu_csr.h</a></li> +<li>CSR_MCOUNTINHIBIT_HPM4&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea40427b799da049413c5536afa623c61d">neorv32_cpu_csr.h</a></li> +<li>CSR_MCOUNTINHIBIT_HPM5&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea2769a6e6a75f2f903523e4e95a899bb6">neorv32_cpu_csr.h</a></li> +<li>CSR_MCOUNTINHIBIT_HPM6&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfead55b6af15841617d7dca3ab4fab893db">neorv32_cpu_csr.h</a></li> +<li>CSR_MCOUNTINHIBIT_HPM7&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea3b3571fceb687da2d3807b0e59bdf7ab">neorv32_cpu_csr.h</a></li> +<li>CSR_MCOUNTINHIBIT_HPM8&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfeabd21344124eda4402523203185a58b8a">neorv32_cpu_csr.h</a></li> +<li>CSR_MCOUNTINHIBIT_HPM9&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea0f207455df0fed75fa68ba49c435889a">neorv32_cpu_csr.h</a></li> +<li>CSR_MCOUNTINHIBIT_IR&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea5f182f39f9a4b871a097a51e57865bfa">neorv32_cpu_csr.h</a></li> +<li>CSR_MCYCLE&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a32c22641ed66c6d20902306a2b1fad77">neorv32_cpu_csr.h</a></li> +<li>CSR_MCYCLEH&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a28fcfd06ca1012c19cf053e57689687b">neorv32_cpu_csr.h</a></li> +<li>CSR_MENVCFG&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a9c55619ffb05e84b7210e2d47326fa98">neorv32_cpu_csr.h</a></li> +<li>CSR_MENVCFGH&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a46b8d3c288cbbfbf5a0af6e5cd8c5bc8">neorv32_cpu_csr.h</a></li> +<li>CSR_MEPC&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a5d60a25a66754066589e8facb7d41153">neorv32_cpu_csr.h</a></li> +<li>CSR_MHARTID&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a6ba48e2306ae92f498552e1ea04d6790">neorv32_cpu_csr.h</a></li> +<li>CSR_MHPMCOUNTER10&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a575e5342d8ec304c32dbbe99d6fd6c0f">neorv32_cpu_csr.h</a></li> +<li>CSR_MHPMCOUNTER10H&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a1e41d2b27d7e8da14871852d81123cfd">neorv32_cpu_csr.h</a></li> +<li>CSR_MHPMCOUNTER11&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a8840b3d4f45453fc96813ccb369a68e5">neorv32_cpu_csr.h</a></li> +<li>CSR_MHPMCOUNTER11H&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a7fd76fcfc0d0dd47e112786bea5e4071">neorv32_cpu_csr.h</a></li> +<li>CSR_MHPMCOUNTER12&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a1328a226d36d23cc81740397bde47a4e">neorv32_cpu_csr.h</a></li> +<li>CSR_MHPMCOUNTER12H&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a332ec2b0740f8e899a1b2ec86f7ee9f2">neorv32_cpu_csr.h</a></li> +<li>CSR_MHPMCOUNTER13&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a9bdd102877ff50d38c86c3d741aeb4b0">neorv32_cpu_csr.h</a></li> +<li>CSR_MHPMCOUNTER13H&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a5de5c5a036dc594a554d37df9ccf657d">neorv32_cpu_csr.h</a></li> +<li>CSR_MHPMCOUNTER14&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49adae22d860d8162e15120051951e45229">neorv32_cpu_csr.h</a></li> +<li>CSR_MHPMCOUNTER14H&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ac65bab6fd71439600c8fc549171251fa">neorv32_cpu_csr.h</a></li> +<li>CSR_MHPMCOUNTER15&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a20400929087fabba410a098667d2d4ff">neorv32_cpu_csr.h</a></li> +<li>CSR_MHPMCOUNTER15H&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49af609807e2917f73e27e5f27b38a0fa46">neorv32_cpu_csr.h</a></li> +<li>CSR_MHPMCOUNTER3&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ae0a96f499dcde474af6ee620fbb1ebdc">neorv32_cpu_csr.h</a></li> +<li>CSR_MHPMCOUNTER3H&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a252980a4da90c1f5c1ef85d164f72f25">neorv32_cpu_csr.h</a></li> +<li>CSR_MHPMCOUNTER4&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a9b84bd948dd52a7779b5fd16beddaab9">neorv32_cpu_csr.h</a></li> +<li>CSR_MHPMCOUNTER4H&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a2e9cfbf3c2828dd4bd92d2b8a1c99f85">neorv32_cpu_csr.h</a></li> +<li>CSR_MHPMCOUNTER5&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49af15d389bb8f91c989df488d231666394">neorv32_cpu_csr.h</a></li> +<li>CSR_MHPMCOUNTER5H&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a7648dd0a47007d44a14e95ba47726599">neorv32_cpu_csr.h</a></li> +<li>CSR_MHPMCOUNTER6&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49af65b9e99b9cadb3cb8d37f97cdbfeb9d">neorv32_cpu_csr.h</a></li> +<li>CSR_MHPMCOUNTER6H&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a49b7bc2df67a6c73a68757de9b218f77">neorv32_cpu_csr.h</a></li> +<li>CSR_MHPMCOUNTER7&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a919f39b0d299feb80403b42a466de444">neorv32_cpu_csr.h</a></li> +<li>CSR_MHPMCOUNTER7H&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ac0183bb6f357ed33136493ae7ded987a">neorv32_cpu_csr.h</a></li> +<li>CSR_MHPMCOUNTER8&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a5a4cde90c547e913bddc719b3ab75e79">neorv32_cpu_csr.h</a></li> +<li>CSR_MHPMCOUNTER8H&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a9e75518df7d14a009e3a0d5588641ddc">neorv32_cpu_csr.h</a></li> +<li>CSR_MHPMCOUNTER9&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a18c2a249f1f7852f42f9e10dc59d46bb">neorv32_cpu_csr.h</a></li> +<li>CSR_MHPMCOUNTER9H&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a7341886c7a4aed6fc7d8677c016a2cb8">neorv32_cpu_csr.h</a></li> +<li>CSR_MHPMEVENT10&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a23850b1804966cde2c1e84cde752d512">neorv32_cpu_csr.h</a></li> +<li>CSR_MHPMEVENT11&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a7fb1de2019dd2b548084d5ca1630efbf">neorv32_cpu_csr.h</a></li> +<li>CSR_MHPMEVENT12&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ad648b5ece209d47e9484fd7aa83e8e5f">neorv32_cpu_csr.h</a></li> +<li>CSR_MHPMEVENT13&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a8c31899b81bb5dba9b92a0f0ca71aea6">neorv32_cpu_csr.h</a></li> +<li>CSR_MHPMEVENT14&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a964a6a50d0138447fad47e9c982a7ba4">neorv32_cpu_csr.h</a></li> +<li>CSR_MHPMEVENT15&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a06dfdeed757606529e4a99c033691b54">neorv32_cpu_csr.h</a></li> +<li>CSR_MHPMEVENT3&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a4a93ac5ab276cfd2f9cd296c8ce1bff6">neorv32_cpu_csr.h</a></li> +<li>CSR_MHPMEVENT4&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ab5f998725e002ffc2ff516ee973fe459">neorv32_cpu_csr.h</a></li> +<li>CSR_MHPMEVENT5&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a2524659ca2785af51af7acf9cd560a9d">neorv32_cpu_csr.h</a></li> +<li>CSR_MHPMEVENT6&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a1cfa1e3bc3c8a1c9a86c251a510d11cd">neorv32_cpu_csr.h</a></li> +<li>CSR_MHPMEVENT7&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a2e53e6e01ca8d1b801f6dfba602f3f59">neorv32_cpu_csr.h</a></li> +<li>CSR_MHPMEVENT8&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ad6296ca83bbe1280624f3c21adbd8a79">neorv32_cpu_csr.h</a></li> +<li>CSR_MHPMEVENT9&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49af6727a9bdd60ccf020812095b7396632">neorv32_cpu_csr.h</a></li> +<li>CSR_MIE&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49acc0f9f5f3b5702f1b57f2ba3b6b62610">neorv32_cpu_csr.h</a></li> +<li>CSR_MIE_FIRQ0E&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a99f43f8bbfb29fba6224f081c363ac7d">neorv32_cpu_csr.h</a></li> +<li>CSR_MIE_FIRQ10E&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33affcb52dc57bb8c0cb1e7d3c1392d544a">neorv32_cpu_csr.h</a></li> +<li>CSR_MIE_FIRQ11E&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33af058342854a0becd3bcc33877d9244cd">neorv32_cpu_csr.h</a></li> +<li>CSR_MIE_FIRQ12E&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a41f91a37f7e0c75c783312af6a72e943">neorv32_cpu_csr.h</a></li> +<li>CSR_MIE_FIRQ13E&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a134ed02c7293008b21b1df472be8f11f">neorv32_cpu_csr.h</a></li> +<li>CSR_MIE_FIRQ14E&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a864d135708530016cfc52a65a1e4d79b">neorv32_cpu_csr.h</a></li> +<li>CSR_MIE_FIRQ15E&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33aa2dfa1183af312de2959dadd217fddc1">neorv32_cpu_csr.h</a></li> +<li>CSR_MIE_FIRQ1E&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33ac1e1d44becec1b393f79a118ed3d8beb">neorv32_cpu_csr.h</a></li> +<li>CSR_MIE_FIRQ2E&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33afc805280e20ffface116ca61e11645f7">neorv32_cpu_csr.h</a></li> +<li>CSR_MIE_FIRQ3E&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a666066099d6cebadbef21d81c179e8db">neorv32_cpu_csr.h</a></li> +<li>CSR_MIE_FIRQ4E&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a592939f1b7d79097f7f13d6ab0c268dc">neorv32_cpu_csr.h</a></li> +<li>CSR_MIE_FIRQ5E&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a3079a8fbf3b8e376865bff76f2173698">neorv32_cpu_csr.h</a></li> +<li>CSR_MIE_FIRQ6E&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a96315d6b5b9531bcbc1e78a3c9ab166a">neorv32_cpu_csr.h</a></li> +<li>CSR_MIE_FIRQ7E&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a3d9d729940170609affbc6813054ebe8">neorv32_cpu_csr.h</a></li> +<li>CSR_MIE_FIRQ8E&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a396c6c4b425b3fff598e2f846052f98e">neorv32_cpu_csr.h</a></li> +<li>CSR_MIE_FIRQ9E&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a06fdb61dab31c3490da6c37d47914f19">neorv32_cpu_csr.h</a></li> +<li>CSR_MIE_MEIE&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33ae8e4f0ee46abbbb3361de035a57b8324">neorv32_cpu_csr.h</a></li> +<li>CSR_MIE_MSIE&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33afd2f1c78c442c8c29ab075cacee0a27a">neorv32_cpu_csr.h</a></li> +<li>CSR_MIE_MTIE&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a3658e8663e94cd8eaa7201b7a850d083">neorv32_cpu_csr.h</a></li> +<li>CSR_MIMPID&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a06d39cf0f13d6401dcf426d56149c8cd">neorv32_cpu_csr.h</a></li> +<li>CSR_MINSTRET&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a98f5e2cf2d5dbb0125a222b0065c86eb">neorv32_cpu_csr.h</a></li> +<li>CSR_MINSTRETH&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49afffb28b62b9baa127ae3bad919208988">neorv32_cpu_csr.h</a></li> +<li>CSR_MIP&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49addb485275c954d1181d5bd4e4609082c">neorv32_cpu_csr.h</a></li> +<li>CSR_MIP_FIRQ0P&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba28a85ad8bd4c30fd3a91298dfa4fdb00">neorv32_cpu_csr.h</a></li> +<li>CSR_MIP_FIRQ10P&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba2b50cfa8be461b088ea8506ce4c741ba">neorv32_cpu_csr.h</a></li> +<li>CSR_MIP_FIRQ11P&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba69ea0d3d76d4cec398f3b96959cc3544">neorv32_cpu_csr.h</a></li> +<li>CSR_MIP_FIRQ12P&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba03edd398920b817150d29107c0b40792">neorv32_cpu_csr.h</a></li> +<li>CSR_MIP_FIRQ13P&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba14da6a2a962bf82970638a948ffbc570">neorv32_cpu_csr.h</a></li> +<li>CSR_MIP_FIRQ14P&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21baad1e5e452a9c37561308765431f0260d">neorv32_cpu_csr.h</a></li> +<li>CSR_MIP_FIRQ15P&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba12da8c32d38d5a3539a0b766718bfd2d">neorv32_cpu_csr.h</a></li> +<li>CSR_MIP_FIRQ1P&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba2b577b1da1074c29ad58005af1f91d52">neorv32_cpu_csr.h</a></li> +<li>CSR_MIP_FIRQ2P&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21badf45c5a135431f958fa63574c1dfac6e">neorv32_cpu_csr.h</a></li> +<li>CSR_MIP_FIRQ3P&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba7512bb6c4841ddd477422b49ebb2a155">neorv32_cpu_csr.h</a></li> +<li>CSR_MIP_FIRQ4P&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21bab6421f242bb8a487a986346e11196eb8">neorv32_cpu_csr.h</a></li> +<li>CSR_MIP_FIRQ5P&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21baaa55d19f9a47889bc364c94bda04b677">neorv32_cpu_csr.h</a></li> +<li>CSR_MIP_FIRQ6P&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21baffa7342631aa0526aaa44c0c549b1f3e">neorv32_cpu_csr.h</a></li> +<li>CSR_MIP_FIRQ7P&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21baad691486001a68f2375dcf5793ee795a">neorv32_cpu_csr.h</a></li> +<li>CSR_MIP_FIRQ8P&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21baf5bbd23d4f311f640db42e9015f87580">neorv32_cpu_csr.h</a></li> +<li>CSR_MIP_FIRQ9P&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21bad94c9691ce59b97fcfec14d345046c3e">neorv32_cpu_csr.h</a></li> +<li>CSR_MIP_MEIP&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba1d761ef98f88c40509168ac66b7a4872">neorv32_cpu_csr.h</a></li> +<li>CSR_MIP_MSIP&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba1470cfe04f9d3ce45b7156b2a7fae159">neorv32_cpu_csr.h</a></li> +<li>CSR_MIP_MTIP&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba344943c62922561378d33ec51ac236e4">neorv32_cpu_csr.h</a></li> +<li>CSR_MISA&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ade079242596ce14ce1ba9842ed29b84c">neorv32_cpu_csr.h</a></li> +<li>CSR_MISA_A&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830ca89412df9f99d2a0ddc4665446397f1a2">neorv32_cpu_csr.h</a></li> +<li>CSR_MISA_B&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830cadd469404a928e012a298773ec46926ad">neorv32_cpu_csr.h</a></li> +<li>CSR_MISA_C&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830ca886699013158c74810598fa2fd6b07fa">neorv32_cpu_csr.h</a></li> +<li>CSR_MISA_D&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830ca1dd1be1071450f9b00a817bce19fa665">neorv32_cpu_csr.h</a></li> +<li>CSR_MISA_E&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830ca0ac798fd19cb7dbe1146afecda448fec">neorv32_cpu_csr.h</a></li> +<li>CSR_MISA_F&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830ca9ec2cae2b948de1043540a4ca1665c40">neorv32_cpu_csr.h</a></li> +<li>CSR_MISA_I&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830ca6091fd2c7ae38ad33be68a0fdfa50cca">neorv32_cpu_csr.h</a></li> +<li>CSR_MISA_M&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830ca317a631e4598532f5bffe8fb93aff94b">neorv32_cpu_csr.h</a></li> +<li>CSR_MISA_MXL_HI&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830cafb3e4b08b87f5c161468a9e58ade12cc">neorv32_cpu_csr.h</a></li> +<li>CSR_MISA_MXL_LO&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830cab5a55e97b8511f42fe68559a38f7f138">neorv32_cpu_csr.h</a></li> +<li>CSR_MISA_U&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830cacd9d71e674d3a6d04984b6df706d9deb">neorv32_cpu_csr.h</a></li> +<li>CSR_MISA_X&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830ca0b119a20be29fcae8fecf2a81c60d193">neorv32_cpu_csr.h</a></li> +<li>CSR_MSCRATCH&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ae29976bb072639975ad0cdb985c7f004">neorv32_cpu_csr.h</a></li> +<li>CSR_MSTATUS&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ad0e5de789d6390f750b8af03cdd15450">neorv32_cpu_csr.h</a></li> +<li>CSR_MSTATUS_MIE&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a76b70a2334131e7589d84c1ee96de485ae2603e365b3f1abfb46d53ed6b13dc56">neorv32_cpu_csr.h</a></li> +<li>CSR_MSTATUS_MPIE&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a76b70a2334131e7589d84c1ee96de485aaa1d482f828ac9cafc40fcfc298bec34">neorv32_cpu_csr.h</a></li> +<li>CSR_MSTATUS_MPP_H&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a76b70a2334131e7589d84c1ee96de485a8067c609c2360cab3bafa3c43e03dbf0">neorv32_cpu_csr.h</a></li> +<li>CSR_MSTATUS_MPP_L&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a76b70a2334131e7589d84c1ee96de485af0ae9aca74144aa7dbdf656f71cc5c97">neorv32_cpu_csr.h</a></li> +<li>CSR_MSTATUS_MPRV&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a76b70a2334131e7589d84c1ee96de485a75cefdbdef36b7fc248765b27c606a44">neorv32_cpu_csr.h</a></li> +<li>CSR_MSTATUS_TW&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a76b70a2334131e7589d84c1ee96de485ac94a070f3fe7962e8c49a81545cacf2d">neorv32_cpu_csr.h</a></li> +<li>CSR_MSTATUSH&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ac2541060307369b2031e9ec07bbd0067">neorv32_cpu_csr.h</a></li> +<li>CSR_MTINST&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a4f229c169ada239033a1383412ce58c8">neorv32_cpu_csr.h</a></li> +<li>CSR_MTVAL&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a76d30359e3b54197fb53f9939734cf1e">neorv32_cpu_csr.h</a></li> +<li>CSR_MTVEC&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aa632d218400268df6dc6b289ff088d21">neorv32_cpu_csr.h</a></li> +<li>CSR_MVENDORID&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49af5c5a21909aaca2b57f9a15f4bac246b">neorv32_cpu_csr.h</a></li> +<li>CSR_MXISA&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a396847bcf1634a1602ab117bfb57bdd2">neorv32_cpu_csr.h</a></li> +<li>CSR_MXISA_FASTMUL&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387a48e57689f8a5b51d9ee9d648da7efc64">neorv32_cpu_csr.h</a></li> +<li>CSR_MXISA_FASTSHIFT&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387ad5ac9e2188757e6c42c159f0c5887868">neorv32_cpu_csr.h</a></li> +<li>CSR_MXISA_IS_SIM&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387a9b121ec0ad6271b6e07658f861015f6a">neorv32_cpu_csr.h</a></li> +<li>CSR_MXISA_RFHWRST&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387a6843c660d75f33e4252c7fccd4565a2d">neorv32_cpu_csr.h</a></li> +<li>CSR_MXISA_SDEXT&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387ab6aec595e6aa5ce7c98c7806d23d7af5">neorv32_cpu_csr.h</a></li> +<li>CSR_MXISA_SDTRIG&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387a59eae4272528f589f299ef9cce45af5b">neorv32_cpu_csr.h</a></li> +<li>CSR_MXISA_SMPMP&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387a6938948290d86b0ad25923f35d6c86d3">neorv32_cpu_csr.h</a></li> +<li>CSR_MXISA_ZFINX&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387a56ec3195d0d27f362f58fadb2e037ed1">neorv32_cpu_csr.h</a></li> +<li>CSR_MXISA_ZICNTR&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387a42a3b78195741af4b6aeeb98cbea46fe">neorv32_cpu_csr.h</a></li> +<li>CSR_MXISA_ZICOND&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387ab1f289cfaa9f54f7831a2abcdf9fca2e">neorv32_cpu_csr.h</a></li> +<li>CSR_MXISA_ZICSR&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387accf1dd12be89e45df1423a5600789f2c">neorv32_cpu_csr.h</a></li> +<li>CSR_MXISA_ZIFENCEI&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387a6979d4389ed9f8605d338fc616d29f0e">neorv32_cpu_csr.h</a></li> +<li>CSR_MXISA_ZIHPM&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387ac13e6883af3a9da18057462239b9fb34">neorv32_cpu_csr.h</a></li> +<li>CSR_MXISA_ZMMUL&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387a79b2b4b20e08ad31b50724a7a27fb20f">neorv32_cpu_csr.h</a></li> +<li>CSR_MXISA_ZXCFU&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387af422ae3b5caba59e33a29b5d069597e0">neorv32_cpu_csr.h</a></li> +<li>CSR_PMPADDR0&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a8941071db6145d34fff842249c0dcb9f">neorv32_cpu_csr.h</a></li> +<li>CSR_PMPADDR1&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a6a2933f3a1fa243de02db8a795e3ca41">neorv32_cpu_csr.h</a></li> +<li>CSR_PMPADDR10&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ad97b6fe934a3bed6b02d0c8d81165d60">neorv32_cpu_csr.h</a></li> +<li>CSR_PMPADDR11&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a3e5708c0f79cf58ae761b6bb8c2a4383">neorv32_cpu_csr.h</a></li> +<li>CSR_PMPADDR12&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a23026793ee53c8d55d23f63195368a6b">neorv32_cpu_csr.h</a></li> +<li>CSR_PMPADDR13&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a30879e88b250d3e94d9d9e728ffcc2cc">neorv32_cpu_csr.h</a></li> +<li>CSR_PMPADDR14&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a91a8b5008b4e08ab34c1516e21bf0ba8">neorv32_cpu_csr.h</a></li> +<li>CSR_PMPADDR15&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a6879b4bf5d2db92d236b9091df4841f2">neorv32_cpu_csr.h</a></li> +<li>CSR_PMPADDR2&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aa0b8c0561e8a778dce9c3b86499ffc50">neorv32_cpu_csr.h</a></li> +<li>CSR_PMPADDR3&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a89bad989197e9358563557311b3c97e9">neorv32_cpu_csr.h</a></li> +<li>CSR_PMPADDR4&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ace4529c53ad2d46767f86d920eada507">neorv32_cpu_csr.h</a></li> +<li>CSR_PMPADDR5&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ad9e78f71409fd7783cc2ae7c28b5e42c">neorv32_cpu_csr.h</a></li> +<li>CSR_PMPADDR6&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49af57b5b7b57cd6e8b3489a27dfd702444">neorv32_cpu_csr.h</a></li> +<li>CSR_PMPADDR7&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ae8ea19cf3e527dbc0d36a43dfd1b7346">neorv32_cpu_csr.h</a></li> +<li>CSR_PMPADDR8&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aec68bf7e26e44170c24599f7c6a8365b">neorv32_cpu_csr.h</a></li> +<li>CSR_PMPADDR9&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a54d38c8cf364d886eb7ac64463eedf77">neorv32_cpu_csr.h</a></li> +<li>CSR_PMPCFG0&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49af1a79349e46a4829af78d2cdfd0dc44f">neorv32_cpu_csr.h</a></li> +<li>CSR_PMPCFG1&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a22eea318ec1ac72cc14e133b71ef4b16">neorv32_cpu_csr.h</a></li> +<li>CSR_PMPCFG2&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a0c9492f6b956f088847f72b28e7b1446">neorv32_cpu_csr.h</a></li> +<li>CSR_PMPCFG3&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a067ed3778590ae97dc9b16069f0ed850">neorv32_cpu_csr.h</a></li> +<li>CSR_TDATA1&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a80eab0e17f5fe41edde485044674dc57">neorv32_cpu_csr.h</a></li> +<li>CSR_TDATA2&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49acf336638697242b691b691dc56b9aadc">neorv32_cpu_csr.h</a></li> +<li>CSR_TINFO&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49af67c819c104f7e3ec34f2cbb847cf83b">neorv32_cpu_csr.h</a></li> +<li>CSR_TSELECT&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aaae2f0b2e3f5a31dff933868873f6d5d">neorv32_cpu_csr.h</a></li> +<li>cypher_data_hw&#160;:&#160;<a class="el" href="demo__cfu_2main_8c.html#a9ad2780a4cfe0d9cb4f1a846a92063ae">main.c</a></li> +<li>cypher_data_sw&#160;:&#160;<a class="el" href="demo__cfu_2main_8c.html#a33b2d9298edf94c5961e67a59c371d00">main.c</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/globals_d.html b/sw/globals_d.html new file mode 100644 index 0000000000..f116493d01 --- /dev/null +++ b/sw/globals_d.html @@ -0,0 +1,139 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: Globals</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +</div><!-- top --> +<div id="doc-content"> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div class="contents"> +<div class="textblock">Here is a list of all documented functions, variables, defines, enums, and typedefs with links to the documentation:</div> + +<h3><a id="index_d" name="index_d"></a>- d -</h3><ul> +<li>data_block&#160;:&#160;<a class="el" href="demo__emulate__unaligned_2main_8c.html#a556f675911f865ead06c36072b1b9c3b">main.c</a></li> +<li>DATA_NUM&#160;:&#160;<a class="el" href="demo__cfu_2main_8c.html#ac637695e266f3af7799e352b374412ad">main.c</a></li> +<li>DEBUG_INFO&#160;:&#160;<a class="el" href="demo__emulate__unaligned_2main_8c.html#a4407b4d6eae3ba7fe9538b1242a7e165">main.c</a></li> +<li>DMA_CMD_B2B&#160;:&#160;<a class="el" href="neorv32__dma_8h.html#a5e01d4454c97eb8e4ecd1455090bbfa9">neorv32_dma.h</a></li> +<li>DMA_CMD_B2SW&#160;:&#160;<a class="el" href="neorv32__dma_8h.html#adfecb3debff251070e4f6eb809412129">neorv32_dma.h</a></li> +<li>DMA_CMD_B2UW&#160;:&#160;<a class="el" href="neorv32__dma_8h.html#aeb63f99217f14d1ddde35c1f6c104e72">neorv32_dma.h</a></li> +<li>DMA_CMD_DST_CONST&#160;:&#160;<a class="el" href="neorv32__dma_8h.html#a6a0ce532aad39e6489e9d52bcb6f4cd2">neorv32_dma.h</a></li> +<li>DMA_CMD_DST_INC&#160;:&#160;<a class="el" href="neorv32__dma_8h.html#a61caa2602c6b148af55d990e3c0ae6be">neorv32_dma.h</a></li> +<li>DMA_CMD_ENDIAN&#160;:&#160;<a class="el" href="neorv32__dma_8h.html#a18fb7faa0a35f562821ca854d7c648b4">neorv32_dma.h</a></li> +<li>DMA_CMD_SRC_CONST&#160;:&#160;<a class="el" href="neorv32__dma_8h.html#ae380022d8b8fb70da91f0892f2bc32c8">neorv32_dma.h</a></li> +<li>DMA_CMD_SRC_INC&#160;:&#160;<a class="el" href="neorv32__dma_8h.html#acc081d58b53d1eddd2bff35b128d7da2">neorv32_dma.h</a></li> +<li>DMA_CMD_W2W&#160;:&#160;<a class="el" href="neorv32__dma_8h.html#a13a16ba8d6daf9c82312bf4d392d15a8">neorv32_dma.h</a></li> +<li>DMA_CTRL_AUTO&#160;:&#160;<a class="el" href="neorv32__dma_8h.html#a6716eddb145b80ad38799da3b87cb2a4a5aeeb05d6365d94d92808df2490daa3b">neorv32_dma.h</a></li> +<li>DMA_CTRL_BUSY&#160;:&#160;<a class="el" href="neorv32__dma_8h.html#a6716eddb145b80ad38799da3b87cb2a4a8e5ff34ac48eea4b352378bb2af47bcb">neorv32_dma.h</a></li> +<li>DMA_CTRL_DONE&#160;:&#160;<a class="el" href="neorv32__dma_8h.html#a6716eddb145b80ad38799da3b87cb2a4a0d51df1bb87dc54d331891c5db787bcc">neorv32_dma.h</a></li> +<li>DMA_CTRL_EN&#160;:&#160;<a class="el" href="neorv32__dma_8h.html#a6716eddb145b80ad38799da3b87cb2a4a5f39deea0212f45423243c8100c40838">neorv32_dma.h</a></li> +<li>DMA_CTRL_ERROR_RD&#160;:&#160;<a class="el" href="neorv32__dma_8h.html#a6716eddb145b80ad38799da3b87cb2a4a539609fc4d80867b3eb98c78206f5f96">neorv32_dma.h</a></li> +<li>DMA_CTRL_ERROR_WR&#160;:&#160;<a class="el" href="neorv32__dma_8h.html#a6716eddb145b80ad38799da3b87cb2a4af7e038b0b0e3ac64f5a2c598eb9c5101">neorv32_dma.h</a></li> +<li>DMA_CTRL_FENCE&#160;:&#160;<a class="el" href="neorv32__dma_8h.html#a6716eddb145b80ad38799da3b87cb2a4ace9fdcdfa8784abad30e033c273e7d00">neorv32_dma.h</a></li> +<li>DMA_CTRL_FIRQ_SEL_LSB&#160;:&#160;<a class="el" href="neorv32__dma_8h.html#a6716eddb145b80ad38799da3b87cb2a4aaf040e663494b39b890d7171d0a584b9">neorv32_dma.h</a></li> +<li>DMA_CTRL_FIRQ_SEL_MSB&#160;:&#160;<a class="el" href="neorv32__dma_8h.html#a6716eddb145b80ad38799da3b87cb2a4a3eba1f7868f0c985effb69785ced011a">neorv32_dma.h</a></li> +<li>DMA_CTRL_FIRQ_TYPE&#160;:&#160;<a class="el" href="neorv32__dma_8h.html#a6716eddb145b80ad38799da3b87cb2a4aeaf5ee8f6a84668aa15cd3e21f076afe">neorv32_dma.h</a></li> +<li>DMA_FIRQ_ENABLE&#160;:&#160;<a class="el" href="neorv32_8h.html#ace46f95dec73b33bf2535eb653bf8f65">neorv32.h</a></li> +<li>dma_firq_handler()&#160;:&#160;<a class="el" href="demo__dma_2main_8c.html#aefcc5abb86a652587ff69be120a66487">main.c</a></li> +<li>DMA_FIRQ_PENDING&#160;:&#160;<a class="el" href="neorv32_8h.html#a1fa2b25383e6d05cf26f3517091ddbbf">neorv32.h</a></li> +<li>DMA_RTE_ID&#160;:&#160;<a class="el" href="neorv32_8h.html#a568b54ba7dfdae736d8d685dc4d32113">neorv32.h</a></li> +<li>DMA_STATUS_BUSY&#160;:&#160;<a class="el" href="neorv32__dma_8h.html#a002cb188ea5156df0ba282e239a6e74bad0f66e962296f5451d73dc1cae1fdc0d">neorv32_dma.h</a></li> +<li>DMA_STATUS_ERR_RD&#160;:&#160;<a class="el" href="neorv32__dma_8h.html#a002cb188ea5156df0ba282e239a6e74baed7242b847e3cc8cf20d7da99f9b1492">neorv32_dma.h</a></li> +<li>DMA_STATUS_ERR_WR&#160;:&#160;<a class="el" href="neorv32__dma_8h.html#a002cb188ea5156df0ba282e239a6e74ba038b6ef194c3db158cb59168f763a7b8">neorv32_dma.h</a></li> +<li>DMA_STATUS_IDLE&#160;:&#160;<a class="el" href="neorv32__dma_8h.html#a002cb188ea5156df0ba282e239a6e74bac9c380cd5729386e5f5673e20b86326f">neorv32_dma.h</a></li> +<li>DMA_TRAP_CODE&#160;:&#160;<a class="el" href="neorv32_8h.html#ad2e81443af8a4ce2db3a4e3c1a8fb784">neorv32.h</a></li> +<li>DMA_TTYPE_DST_INC&#160;:&#160;<a class="el" href="neorv32__dma_8h.html#a33187c5a074d62b46d2262e352edb8d9abb1293915b076e5d37be6724b44ab0da">neorv32_dma.h</a></li> +<li>DMA_TTYPE_ENDIAN&#160;:&#160;<a class="el" href="neorv32__dma_8h.html#a33187c5a074d62b46d2262e352edb8d9a37ea8ef1e6b342db330d3885545fc802">neorv32_dma.h</a></li> +<li>DMA_TTYPE_NUM_LSB&#160;:&#160;<a class="el" href="neorv32__dma_8h.html#a33187c5a074d62b46d2262e352edb8d9a8dba4160c033c763f5102928c471e450">neorv32_dma.h</a></li> +<li>DMA_TTYPE_NUM_MSB&#160;:&#160;<a class="el" href="neorv32__dma_8h.html#a33187c5a074d62b46d2262e352edb8d9a61553eee00ed2382565bf826074c44bd">neorv32_dma.h</a></li> +<li>DMA_TTYPE_QSEL_LSB&#160;:&#160;<a class="el" href="neorv32__dma_8h.html#a33187c5a074d62b46d2262e352edb8d9afcfdedeca4c4a1def4905660811e31e2">neorv32_dma.h</a></li> +<li>DMA_TTYPE_QSEL_MSB&#160;:&#160;<a class="el" href="neorv32__dma_8h.html#a33187c5a074d62b46d2262e352edb8d9a4217c9a8ac4ccc52bb45944f30a598c5">neorv32_dma.h</a></li> +<li>DMA_TTYPE_SRC_INC&#160;:&#160;<a class="el" href="neorv32__dma_8h.html#a33187c5a074d62b46d2262e352edb8d9a4b99a30b851851f3388dd4e77effacec">neorv32_dma.h</a></li> +<li>dump_memory()&#160;:&#160;<a class="el" href="bus__explorer_2main_8c.html#a6405739c6012158151eb082c31c312da">main.c</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/globals_defs.html b/sw/globals_defs.html new file mode 100644 index 0000000000..6f4785858d --- /dev/null +++ b/sw/globals_defs.html @@ -0,0 +1,101 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: Globals</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +</div><!-- top --> +<div id="doc-content"> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div class="contents"> +<div class="textblock">Here is a list of all documented macros with links to the documentation:</div> + +<h3><a id="index_a" name="index_a"></a>- a -</h3><ul> +<li>AUTO_BOOT_TIMEOUT&#160;:&#160;<a class="el" href="bootloader_8c.html#af6fcb607a9c320da869b72aa30893a69">bootloader.c</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/globals_defs_b.html b/sw/globals_defs_b.html new file mode 100644 index 0000000000..fa58ba3344 --- /dev/null +++ b/sw/globals_defs_b.html @@ -0,0 +1,103 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: Globals</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +</div><!-- top --> +<div id="doc-content"> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div class="contents"> +<div class="textblock">Here is a list of all documented macros with links to the documentation:</div> + +<h3><a id="index_b" name="index_b"></a>- b -</h3><ul> +<li>BAUD_RATE&#160;:&#160;<a class="el" href="atomic__test_2main_8c.html#ad4455691936f92fdd6c37566fc58ba1f">main.c</a></li> +<li>BOOTLOADER_BASE_ADDRESS&#160;:&#160;<a class="el" href="neorv32_8h.html#abd8c9b7d79f49de1722611b2835cde58">neorv32.h</a></li> +<li>BUFFER_SIZE&#160;:&#160;<a class="el" href="demo__xip_2main_8c.html#a6b20d41d6252e9871430c242cb1a56e7">main.c</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/globals_defs_c.html b/sw/globals_defs_c.html new file mode 100644 index 0000000000..3d66e21a31 --- /dev/null +++ b/sw/globals_defs_c.html @@ -0,0 +1,106 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: Globals</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +</div><!-- top --> +<div id="doc-content"> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div class="contents"> +<div class="textblock">Here is a list of all documented macros with links to the documentation:</div> + +<h3><a id="index_c" name="index_c"></a>- c -</h3><ul> +<li>CELL_ALIVE&#160;:&#160;<a class="el" href="game__of__life_2main_8c.html#afa6488273e16792d9c3da5e40e3f572d">main.c</a></li> +<li>CELL_DEAD&#160;:&#160;<a class="el" href="game__of__life_2main_8c.html#abe6bebcf1cb4f5b4d522c1706eb48663">main.c</a></li> +<li>CFS_FIRQ_ENABLE&#160;:&#160;<a class="el" href="neorv32_8h.html#ace79ee46daf3a1b689d9fe79dfcd6627">neorv32.h</a></li> +<li>CFS_FIRQ_PENDING&#160;:&#160;<a class="el" href="neorv32_8h.html#aae182648a2c23d070b9db0295388e001">neorv32.h</a></li> +<li>CFS_RTE_ID&#160;:&#160;<a class="el" href="neorv32_8h.html#a095f41fbefaa7acc1bfdd65cd3ce06ea">neorv32.h</a></li> +<li>CFS_TRAP_CODE&#160;:&#160;<a class="el" href="neorv32_8h.html#aae6b2ae3fba20ff80bfb59735f179c26">neorv32.h</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/globals_defs_d.html b/sw/globals_defs_d.html new file mode 100644 index 0000000000..e1ceabab1b --- /dev/null +++ b/sw/globals_defs_d.html @@ -0,0 +1,115 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: Globals</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +</div><!-- top --> +<div id="doc-content"> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div class="contents"> +<div class="textblock">Here is a list of all documented macros with links to the documentation:</div> + +<h3><a id="index_d" name="index_d"></a>- d -</h3><ul> +<li>DATA_NUM&#160;:&#160;<a class="el" href="demo__cfu_2main_8c.html#ac637695e266f3af7799e352b374412ad">main.c</a></li> +<li>DEBUG_INFO&#160;:&#160;<a class="el" href="demo__emulate__unaligned_2main_8c.html#a4407b4d6eae3ba7fe9538b1242a7e165">main.c</a></li> +<li>DMA_CMD_B2B&#160;:&#160;<a class="el" href="neorv32__dma_8h.html#a5e01d4454c97eb8e4ecd1455090bbfa9">neorv32_dma.h</a></li> +<li>DMA_CMD_B2SW&#160;:&#160;<a class="el" href="neorv32__dma_8h.html#adfecb3debff251070e4f6eb809412129">neorv32_dma.h</a></li> +<li>DMA_CMD_B2UW&#160;:&#160;<a class="el" href="neorv32__dma_8h.html#aeb63f99217f14d1ddde35c1f6c104e72">neorv32_dma.h</a></li> +<li>DMA_CMD_DST_CONST&#160;:&#160;<a class="el" href="neorv32__dma_8h.html#a6a0ce532aad39e6489e9d52bcb6f4cd2">neorv32_dma.h</a></li> +<li>DMA_CMD_DST_INC&#160;:&#160;<a class="el" href="neorv32__dma_8h.html#a61caa2602c6b148af55d990e3c0ae6be">neorv32_dma.h</a></li> +<li>DMA_CMD_ENDIAN&#160;:&#160;<a class="el" href="neorv32__dma_8h.html#a18fb7faa0a35f562821ca854d7c648b4">neorv32_dma.h</a></li> +<li>DMA_CMD_SRC_CONST&#160;:&#160;<a class="el" href="neorv32__dma_8h.html#ae380022d8b8fb70da91f0892f2bc32c8">neorv32_dma.h</a></li> +<li>DMA_CMD_SRC_INC&#160;:&#160;<a class="el" href="neorv32__dma_8h.html#acc081d58b53d1eddd2bff35b128d7da2">neorv32_dma.h</a></li> +<li>DMA_CMD_W2W&#160;:&#160;<a class="el" href="neorv32__dma_8h.html#a13a16ba8d6daf9c82312bf4d392d15a8">neorv32_dma.h</a></li> +<li>DMA_FIRQ_ENABLE&#160;:&#160;<a class="el" href="neorv32_8h.html#ace46f95dec73b33bf2535eb653bf8f65">neorv32.h</a></li> +<li>DMA_FIRQ_PENDING&#160;:&#160;<a class="el" href="neorv32_8h.html#a1fa2b25383e6d05cf26f3517091ddbbf">neorv32.h</a></li> +<li>DMA_RTE_ID&#160;:&#160;<a class="el" href="neorv32_8h.html#a568b54ba7dfdae736d8d685dc4d32113">neorv32.h</a></li> +<li>DMA_TRAP_CODE&#160;:&#160;<a class="el" href="neorv32_8h.html#ad2e81443af8a4ce2db3a4e3c1a8fb784">neorv32.h</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/globals_defs_e.html b/sw/globals_defs_e.html new file mode 100644 index 0000000000..6724c854f3 --- /dev/null +++ b/sw/globals_defs_e.html @@ -0,0 +1,102 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: Globals</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +</div><!-- top --> +<div id="doc-content"> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div class="contents"> +<div class="textblock">Here is a list of all documented macros with links to the documentation:</div> + +<h3><a id="index_e" name="index_e"></a>- e -</h3><ul> +<li>EXE_BASE_ADDR&#160;:&#160;<a class="el" href="bootloader_8c.html#a18936dc79b9e5aa84df016b046a6b977">bootloader.c</a></li> +<li>EXE_SIGNATURE&#160;:&#160;<a class="el" href="bootloader_8c.html#a0035ad41f622dbfc2412318a8ed39257">bootloader.c</a>, <a class="el" href="demo__xip_2main_8c.html#a0035ad41f622dbfc2412318a8ed39257">main.c</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/globals_defs_f.html b/sw/globals_defs_f.html new file mode 100644 index 0000000000..858e0985a9 --- /dev/null +++ b/sw/globals_defs_f.html @@ -0,0 +1,102 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: Globals</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +</div><!-- top --> +<div id="doc-content"> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div class="contents"> +<div class="textblock">Here is a list of all documented macros with links to the documentation:</div> + +<h3><a id="index_f" name="index_f"></a>- f -</h3><ul> +<li>FLASH_ABYTES&#160;:&#160;<a class="el" href="demo__xip_2main_8c.html#af9b3c37c806499fc435302f5bce6a122">main.c</a></li> +<li>FLASH_BASE&#160;:&#160;<a class="el" href="demo__xip_2main_8c.html#a23a9099a5f8fc9c6e253c0eecb2be8db">main.c</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/globals_defs_g.html b/sw/globals_defs_g.html new file mode 100644 index 0000000000..b2dab9bd11 --- /dev/null +++ b/sw/globals_defs_g.html @@ -0,0 +1,105 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: Globals</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +</div><!-- top --> +<div id="doc-content"> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div class="contents"> +<div class="textblock">Here is a list of all documented macros with links to the documentation:</div> + +<h3><a id="index_g" name="index_g"></a>- g -</h3><ul> +<li>GEN_DELAY&#160;:&#160;<a class="el" href="game__of__life_2main_8c.html#a3f33bf77abbf35c245956489f8f7e3a7">main.c</a></li> +<li>GPTMR_FIRQ_ENABLE&#160;:&#160;<a class="el" href="neorv32_8h.html#a0a59186908b498cb92273b7767966e26">neorv32.h</a></li> +<li>GPTMR_FIRQ_PENDING&#160;:&#160;<a class="el" href="neorv32_8h.html#a4a3164d123ddddd07750f868e67d82d8">neorv32.h</a></li> +<li>GPTMR_RTE_ID&#160;:&#160;<a class="el" href="neorv32_8h.html#aac38deeef36de0a474ab238a3054f860">neorv32.h</a></li> +<li>GPTMR_TRAP_CODE&#160;:&#160;<a class="el" href="neorv32_8h.html#a445543c36d1f78477aa8ea4841c720a1">neorv32.h</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/globals_defs_i.html b/sw/globals_defs_i.html new file mode 100644 index 0000000000..ca9679f61d --- /dev/null +++ b/sw/globals_defs_i.html @@ -0,0 +1,101 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: Globals</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +</div><!-- top --> +<div id="doc-content"> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div class="contents"> +<div class="textblock">Here is a list of all documented macros with links to the documentation:</div> + +<h3><a id="index_i" name="index_i"></a>- i -</h3><ul> +<li>IO_BASE_ADDRESS&#160;:&#160;<a class="el" href="neorv32_8h.html#a1eb0cb7fed7e154e15cb4009880a879c">neorv32.h</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/globals_defs_m.html b/sw/globals_defs_m.html new file mode 100644 index 0000000000..0dacf04755 --- /dev/null +++ b/sw/globals_defs_m.html @@ -0,0 +1,101 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: Globals</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +</div><!-- top --> +<div id="doc-content"> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div class="contents"> +<div class="textblock">Here is a list of all documented macros with links to the documentation:</div> + +<h3><a id="index_m" name="index_m"></a>- m -</h3><ul> +<li>MAX_INTENSITY&#160;:&#160;<a class="el" href="demo__neopixel_2main_8c.html#a1d1d5e7ff16f25b68fdf779befd298f7">main.c</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/globals_defs_n.html b/sw/globals_defs_n.html new file mode 100644 index 0000000000..3db3a1ff61 --- /dev/null +++ b/sw/globals_defs_n.html @@ -0,0 +1,153 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: Globals</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +</div><!-- top --> +<div id="doc-content"> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div class="contents"> +<div class="textblock">Here is a list of all documented macros with links to the documentation:</div> + +<h3><a id="index_n" name="index_n"></a>- n -</h3><ul> +<li>NEOLED_FIRQ_ENABLE&#160;:&#160;<a class="el" href="neorv32_8h.html#a8d0409818600c0b2acfe8253e8f027b8">neorv32.h</a></li> +<li>NEOLED_FIRQ_PENDING&#160;:&#160;<a class="el" href="neorv32_8h.html#aded7d7f5f4ba3a6d90f9a29e62a8cfab">neorv32.h</a></li> +<li>NEOLED_RTE_ID&#160;:&#160;<a class="el" href="neorv32_8h.html#aca6cfc3f580c4dfe1e213009ee450c58">neorv32.h</a></li> +<li>NEOLED_TRAP_CODE&#160;:&#160;<a class="el" href="neorv32_8h.html#ab4a2ac455d7426992de6877ea7325f21">neorv32.h</a></li> +<li>NEORV32_CFS&#160;:&#160;<a class="el" href="neorv32__cfs_8h.html#a6c101b306bd096f78d351e39b308d3e2">neorv32_cfs.h</a></li> +<li>NEORV32_CFS_BASE&#160;:&#160;<a class="el" href="neorv32_8h.html#a41d6f97daef61641da96b9f72f6b272f">neorv32.h</a></li> +<li>neorv32_cfu_r3_instr&#160;:&#160;<a class="el" href="neorv32__cpu__cfu_8h.html#a69d60ccd0cee950b08ce585c3f13b85c">neorv32_cpu_cfu.h</a></li> +<li>neorv32_cfu_r4_instr&#160;:&#160;<a class="el" href="neorv32__cpu__cfu_8h.html#a046a640f7f4a7b1b99a824fb325e2079">neorv32_cpu_cfu.h</a></li> +<li>neorv32_cfu_r5_instr_a&#160;:&#160;<a class="el" href="neorv32__cpu__cfu_8h.html#a65198d9caf04a5cd3a72accc2cecf870">neorv32_cpu_cfu.h</a></li> +<li>neorv32_cfu_r5_instr_b&#160;:&#160;<a class="el" href="neorv32__cpu__cfu_8h.html#ab3affefbff898567c6c02c4d10765b04">neorv32_cpu_cfu.h</a></li> +<li>NEORV32_CRC&#160;:&#160;<a class="el" href="neorv32__crc_8h.html#a110962d2b370f9d7997e459d9fd34271">neorv32_crc.h</a></li> +<li>NEORV32_CRC_BASE&#160;:&#160;<a class="el" href="neorv32_8h.html#a0e2377055bdc0f416b5ae4385610600d">neorv32.h</a></li> +<li>NEORV32_DM_BASE&#160;:&#160;<a class="el" href="neorv32_8h.html#a9bf0149681677f7d87abf8f62e2d9a3d">neorv32.h</a></li> +<li>NEORV32_DMA&#160;:&#160;<a class="el" href="neorv32__dma_8h.html#a0dcb61a0e0d2b45beb7818015adc8639">neorv32_dma.h</a></li> +<li>NEORV32_DMA_BASE&#160;:&#160;<a class="el" href="neorv32_8h.html#aa8d3a83ffad1e71f0832a5da78d62008">neorv32.h</a></li> +<li>NEORV32_GPIO&#160;:&#160;<a class="el" href="neorv32__gpio_8h.html#a1e35bbf26b9d1aa5373af0b9468eb445">neorv32_gpio.h</a></li> +<li>NEORV32_GPIO_BASE&#160;:&#160;<a class="el" href="neorv32_8h.html#a7fd1e24d4de2eed7bf9cd5391562c7f4">neorv32.h</a></li> +<li>NEORV32_GPTMR&#160;:&#160;<a class="el" href="neorv32__gptmr_8h.html#a9e047791588ff21fc4dc1b06456bdfd2">neorv32_gptmr.h</a></li> +<li>NEORV32_GPTMR_BASE&#160;:&#160;<a class="el" href="neorv32_8h.html#a0991b1a5ba1e8c3550eb9770d43589d0">neorv32.h</a></li> +<li>NEORV32_MTIME&#160;:&#160;<a class="el" href="neorv32__mtime_8h.html#a68935be182e0081039326a9f344a36b3">neorv32_mtime.h</a></li> +<li>NEORV32_MTIME_BASE&#160;:&#160;<a class="el" href="neorv32_8h.html#ab98f762df259a2bbc28d19d2acfe9e23">neorv32.h</a></li> +<li>NEORV32_NEOLED&#160;:&#160;<a class="el" href="neorv32__neoled_8h.html#a3ccc1097bc70f92235d693b612fa994a">neorv32_neoled.h</a></li> +<li>NEORV32_NEOLED_BASE&#160;:&#160;<a class="el" href="neorv32_8h.html#a559fdce92e8af5efc426c8fc48d14f99">neorv32.h</a></li> +<li>NEORV32_ONEWIRE&#160;:&#160;<a class="el" href="neorv32__onewire_8h.html#a6f119e35d7ac01f110987508ff3becc9">neorv32_onewire.h</a></li> +<li>NEORV32_ONEWIRE_BASE&#160;:&#160;<a class="el" href="neorv32_8h.html#a8d0b612e52b77395a05d4f18af6fcf00">neorv32.h</a></li> +<li>NEORV32_PWM&#160;:&#160;<a class="el" href="neorv32__pwm_8h.html#ad4cb534c29e26fa56c10bef7afab8f51">neorv32_pwm.h</a></li> +<li>NEORV32_PWM_BASE&#160;:&#160;<a class="el" href="neorv32_8h.html#afef7a6b121a788560b29e2ee2a58c725">neorv32.h</a></li> +<li>NEORV32_RTE_NUM_TRAPS&#160;:&#160;<a class="el" href="neorv32__rte_8h.html#ad14a1ca41df1e9300bfd01aef07dce59">neorv32_rte.h</a></li> +<li>NEORV32_SDI&#160;:&#160;<a class="el" href="neorv32__sdi_8h.html#afd0921633d6523d9b7235055e9bbf928">neorv32_sdi.h</a></li> +<li>NEORV32_SDI_BASE&#160;:&#160;<a class="el" href="neorv32_8h.html#a9b316ec038bd94ada42c9dab57a0a3cb">neorv32.h</a></li> +<li>NEORV32_SLINK&#160;:&#160;<a class="el" href="neorv32__slink_8h.html#a6380d894432de119a20993096db534df">neorv32_slink.h</a></li> +<li>NEORV32_SLINK_BASE&#160;:&#160;<a class="el" href="neorv32_8h.html#ab5e6dc57886cd5ed98b86f22fc37d7cc">neorv32.h</a></li> +<li>NEORV32_SPI&#160;:&#160;<a class="el" href="neorv32__spi_8h.html#a5f3afc4e268670c54d90df67fa38ca22">neorv32_spi.h</a></li> +<li>NEORV32_SPI_BASE&#160;:&#160;<a class="el" href="neorv32_8h.html#aa466dc5eace7351bd438606f0f7475a7">neorv32.h</a></li> +<li>NEORV32_SYSINFO_BASE&#160;:&#160;<a class="el" href="neorv32_8h.html#a5aa936f38782232c7ed3eab1283ee536">neorv32.h</a></li> +<li>NEORV32_TRNG&#160;:&#160;<a class="el" href="neorv32__trng_8h.html#a9794ff3746eb5321ad9c2bf522ea26dd">neorv32_trng.h</a></li> +<li>NEORV32_TRNG_BASE&#160;:&#160;<a class="el" href="neorv32_8h.html#ab4846cd153e8a23deec45d81cc8372a2">neorv32.h</a></li> +<li>NEORV32_TWI&#160;:&#160;<a class="el" href="neorv32__twi_8h.html#a2769c2fe5e0de01b12fe4a5fad029768">neorv32_twi.h</a></li> +<li>NEORV32_TWI_BASE&#160;:&#160;<a class="el" href="neorv32_8h.html#a4a741408a4bb0938e03b99555306db9c">neorv32.h</a></li> +<li>NEORV32_UART0&#160;:&#160;<a class="el" href="neorv32__uart_8h.html#a4c880a6b27e46f459e750425258b1bdb">neorv32_uart.h</a></li> +<li>NEORV32_UART0_BASE&#160;:&#160;<a class="el" href="neorv32_8h.html#a000b37f710043fe21e49b2fdbc039d94">neorv32.h</a></li> +<li>NEORV32_UART1&#160;:&#160;<a class="el" href="neorv32__uart_8h.html#aa2a9ded4523f001bf69935c80247fa2d">neorv32_uart.h</a></li> +<li>NEORV32_UART1_BASE&#160;:&#160;<a class="el" href="neorv32_8h.html#a26a1defe18ce222b8b4ed1c760344700">neorv32.h</a></li> +<li>NEORV32_WDT&#160;:&#160;<a class="el" href="neorv32__wdt_8h.html#a78615b08cd799063011606d084fef46c">neorv32_wdt.h</a></li> +<li>NEORV32_WDT_BASE&#160;:&#160;<a class="el" href="neorv32_8h.html#a3012986cdd5748ee96bcc74cd7108dea">neorv32.h</a></li> +<li>NEORV32_XIP&#160;:&#160;<a class="el" href="neorv32__xip_8h.html#a3d6f138a347c16883b51069428eb7c1e">neorv32_xip.h</a></li> +<li>NEORV32_XIP_BASE&#160;:&#160;<a class="el" href="neorv32_8h.html#ae0978315beac8399f96f520bda81c7fe">neorv32.h</a></li> +<li>NEORV32_XIRQ&#160;:&#160;<a class="el" href="neorv32__xirq_8h.html#a0c0886139e9837867202e5f6a83307c4">neorv32_xirq.h</a></li> +<li>NEORV32_XIRQ_BASE&#160;:&#160;<a class="el" href="neorv32_8h.html#a942a897be2d4ae6820bee0f7bb3a0ff1">neorv32.h</a></li> +<li>NUM_CELLS_X&#160;:&#160;<a class="el" href="game__of__life_2main_8c.html#a78c5b500f0f057bcaedf6fedeca7c537">main.c</a></li> +<li>NUM_CELLS_Y&#160;:&#160;<a class="el" href="game__of__life_2main_8c.html#aed77778557404b38bebb05b5830368b4">main.c</a></li> +<li>NUM_LEDS_24BIT&#160;:&#160;<a class="el" href="demo__neopixel_2main_8c.html#aa1dddb8d6b3b4d2f19afc3c09e2ff572">main.c</a></li> +<li>NUM_TEST_CASES&#160;:&#160;<a class="el" href="atomic__test_2main_8c.html#a83792c34853f1d2801b59ad46adc7e1e">main.c</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/globals_defs_o.html b/sw/globals_defs_o.html new file mode 100644 index 0000000000..65065395ec --- /dev/null +++ b/sw/globals_defs_o.html @@ -0,0 +1,104 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: Globals</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +</div><!-- top --> +<div id="doc-content"> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div class="contents"> +<div class="textblock">Here is a list of all documented macros with links to the documentation:</div> + +<h3><a id="index_o" name="index_o"></a>- o -</h3><ul> +<li>ONEWIRE_FIRQ_ENABLE&#160;:&#160;<a class="el" href="neorv32_8h.html#a8bb1918679e32e898af2d485cfa44afb">neorv32.h</a></li> +<li>ONEWIRE_FIRQ_PENDING&#160;:&#160;<a class="el" href="neorv32_8h.html#a3853ef999f99ca062e6025038811d0f0">neorv32.h</a></li> +<li>ONEWIRE_RTE_ID&#160;:&#160;<a class="el" href="neorv32_8h.html#a142f4a1c754edfab292706618d427b94">neorv32.h</a></li> +<li>ONEWIRE_TRAP_CODE&#160;:&#160;<a class="el" href="neorv32_8h.html#a3e7aaa405a7d1fcd71a36c4b6b5a4081">neorv32.h</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/globals_defs_p.html b/sw/globals_defs_p.html new file mode 100644 index 0000000000..7e47b67c2b --- /dev/null +++ b/sw/globals_defs_p.html @@ -0,0 +1,105 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: Globals</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +</div><!-- top --> +<div id="doc-content"> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div class="contents"> +<div class="textblock">Here is a list of all documented macros with links to the documentation:</div> + +<h3><a id="index_p" name="index_p"></a>- p -</h3><ul> +<li>PRINT_GETC&#160;:&#160;<a class="el" href="bootloader_8c.html#a999b04603115ce08b0cb33e333312480">bootloader.c</a></li> +<li>PRINT_PUTC&#160;:&#160;<a class="el" href="bootloader_8c.html#aa7afbe8348ebd1a876a4d247553292e9">bootloader.c</a></li> +<li>PRINT_TEXT&#160;:&#160;<a class="el" href="bootloader_8c.html#a0e5a66f68ecc7a6f42088f349707e852">bootloader.c</a></li> +<li>PRINT_XNUM&#160;:&#160;<a class="el" href="bootloader_8c.html#a2f5cc04cf9c85f5d2958b384e053053b">bootloader.c</a></li> +<li>PWM_MAX&#160;:&#160;<a class="el" href="demo__pwm_2main_8c.html#a391fa1e490bd712720989b58fa0d9904">main.c</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/globals_defs_r.html b/sw/globals_defs_r.html new file mode 100644 index 0000000000..a3d67b4c52 --- /dev/null +++ b/sw/globals_defs_r.html @@ -0,0 +1,111 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: Globals</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +</div><!-- top --> +<div id="doc-content"> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div class="contents"> +<div class="textblock">Here is a list of all documented macros with links to the documentation:</div> + +<h3><a id="index_r" name="index_r"></a>- r -</h3><ul> +<li>RUN_ADDSUB_TESTS&#160;:&#160;<a class="el" href="float__corner__test_2main_8c.html#a2d16b9e484b7af7897c7ae83f945ceca">main.c</a></li> +<li>RUN_CLASSIFY_TESTS&#160;:&#160;<a class="el" href="float__corner__test_2main_8c.html#a7e134923925fa24fd1090281c3a416c3">main.c</a></li> +<li>RUN_COMPARE_TESTS&#160;:&#160;<a class="el" href="float__corner__test_2main_8c.html#a4ee0f6d28896a97d2c0cad866e77b874">main.c</a></li> +<li>RUN_CONV_TESTS&#160;:&#160;<a class="el" href="float__corner__test_2main_8c.html#aa3b6c4d49be7372de9e771a0475306ac">main.c</a></li> +<li>RUN_CSR_TESTS&#160;:&#160;<a class="el" href="floating__point__test_2main_8c.html#a7ec330b668b5b24d666d7769ccecfee3">main.c</a></li> +<li>RUN_EXC_TESTS&#160;:&#160;<a class="el" href="floating__point__test_2main_8c.html#a1a1af220e72c69b03d13b2df53650e10">main.c</a></li> +<li>RUN_MINMAX_TESTS&#160;:&#160;<a class="el" href="float__corner__test_2main_8c.html#aed386f612417aeeeac8b08db27d515e4">main.c</a></li> +<li>RUN_MUL_TESTS&#160;:&#160;<a class="el" href="float__corner__test_2main_8c.html#a97323ecaf1ae85e68a736b06bc3b58f8">main.c</a></li> +<li>RUN_SGNINJ_TESTS&#160;:&#160;<a class="el" href="float__corner__test_2main_8c.html#a94f0b0908f48f383145ed61ef8eb0713">main.c</a></li> +<li>RUN_TIMING_TESTS&#160;:&#160;<a class="el" href="float__corner__test_2main_8c.html#a6969308bd3633928893a2666f1df66fc">main.c</a></li> +<li>RUN_UNAVAIL_TESTS&#160;:&#160;<a class="el" href="float__corner__test_2main_8c.html#a923de9c3e55322d85522740c0d0ff867">main.c</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/globals_defs_s.html b/sw/globals_defs_s.html new file mode 100644 index 0000000000..aa5072d4dc --- /dev/null +++ b/sw/globals_defs_s.html @@ -0,0 +1,126 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: Globals</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +</div><!-- top --> +<div id="doc-content"> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div class="contents"> +<div class="textblock">Here is a list of all documented macros with links to the documentation:</div> + +<h3><a id="index_s" name="index_s"></a>- s -</h3><ul> +<li>SDI_FIRQ_ENABLE&#160;:&#160;<a class="el" href="neorv32_8h.html#a30cf20b6d704c50cc5c46238bb43646f">neorv32.h</a></li> +<li>SDI_FIRQ_PENDING&#160;:&#160;<a class="el" href="neorv32_8h.html#a68611c0dfbe331739eff10230ac3fede">neorv32.h</a></li> +<li>SDI_RTE_ID&#160;:&#160;<a class="el" href="neorv32_8h.html#aa0ff72ea560d7e1462787dc31bd467cf">neorv32.h</a></li> +<li>SDI_TRAP_CODE&#160;:&#160;<a class="el" href="neorv32_8h.html#a68925ca3f482f148caedd36118fd8d79">neorv32.h</a></li> +<li>SILENT_MODE&#160;:&#160;<a class="el" href="atomic__test_2main_8c.html#a87f296d7594bb8178cf76f0c045b7013">main.c</a></li> +<li>SLINK_RX_FIRQ_ENABLE&#160;:&#160;<a class="el" href="neorv32_8h.html#a8680ab1f14e512f21913572b35cbbf77">neorv32.h</a></li> +<li>SLINK_RX_FIRQ_PENDING&#160;:&#160;<a class="el" href="neorv32_8h.html#a5c48d5c4effb47cdb019aa2da7c84526">neorv32.h</a></li> +<li>SLINK_RX_RTE_ID&#160;:&#160;<a class="el" href="neorv32_8h.html#a4fff18e72d10377cdcb8d2ac0a617a5d">neorv32.h</a></li> +<li>SLINK_RX_TRAP_CODE&#160;:&#160;<a class="el" href="neorv32_8h.html#ab1fdaedb2c4c8753ef3be87c82568dda">neorv32.h</a></li> +<li>SLINK_TX_FIRQ_ENABLE&#160;:&#160;<a class="el" href="neorv32_8h.html#a232fe0eb5665373b6e2b464bdc228df2">neorv32.h</a></li> +<li>SLINK_TX_FIRQ_PENDING&#160;:&#160;<a class="el" href="neorv32_8h.html#ac8e98b2af75c8e31f9815dee3dcbaf8e">neorv32.h</a></li> +<li>SLINK_TX_RTE_ID&#160;:&#160;<a class="el" href="neorv32_8h.html#a4e039d13b8d3f20453e1bb6b40512e43">neorv32.h</a></li> +<li>SLINK_TX_TRAP_CODE&#160;:&#160;<a class="el" href="neorv32_8h.html#a7fbe28901775e284d5700086f0b0bfcd">neorv32.h</a></li> +<li>SPI_BOOT_BASE_ADDR&#160;:&#160;<a class="el" href="bootloader_8c.html#a418adcf57119600c3580fd2297d28de0">bootloader.c</a></li> +<li>SPI_EN&#160;:&#160;<a class="el" href="bootloader_8c.html#aea75cf0485ce0a4ea320eba994859686">bootloader.c</a></li> +<li>SPI_FIRQ_ENABLE&#160;:&#160;<a class="el" href="neorv32_8h.html#ab8fcd3f80c373eb0f9d0fc6bf64ca626">neorv32.h</a></li> +<li>SPI_FIRQ_PENDING&#160;:&#160;<a class="el" href="neorv32_8h.html#ab2f58f746febb29a9828447c733f8043">neorv32.h</a></li> +<li>SPI_FLASH_ADDR_BYTES&#160;:&#160;<a class="el" href="bootloader_8c.html#afe60a31c8561952f2f734fd67e6f7406">bootloader.c</a></li> +<li>SPI_FLASH_CLK_PRSC&#160;:&#160;<a class="el" href="bootloader_8c.html#a709071a651213770b4efe6e6e055ec3d">bootloader.c</a></li> +<li>SPI_FLASH_CS&#160;:&#160;<a class="el" href="bootloader_8c.html#aa2132454aada86216009f3af206899b1">bootloader.c</a></li> +<li>SPI_FLASH_SECTOR_SIZE&#160;:&#160;<a class="el" href="bootloader_8c.html#a00924a8ba223b2ca0e7031259b292c84">bootloader.c</a></li> +<li>SPI_RTE_ID&#160;:&#160;<a class="el" href="neorv32_8h.html#a4c1cd9ec9f80da2080e5d0d35cc524dd">neorv32.h</a></li> +<li>SPI_TRAP_CODE&#160;:&#160;<a class="el" href="neorv32_8h.html#a83c212f1f5d8ee2a5921b3b2b19e9cc4">neorv32.h</a></li> +<li>STATUS_LED_EN&#160;:&#160;<a class="el" href="bootloader_8c.html#aa9696325b450773c7a87c991abca3a54">bootloader.c</a></li> +<li>STATUS_LED_PIN&#160;:&#160;<a class="el" href="bootloader_8c.html#a089a71f836911c71b3f73fdd3b4b890b">bootloader.c</a></li> +<li>str&#160;:&#160;<a class="el" href="bootloader_8c.html#af6cf19e40e97afb5a7c29f7b439d091d">bootloader.c</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/globals_defs_t.html b/sw/globals_defs_t.html new file mode 100644 index 0000000000..1babbe483f --- /dev/null +++ b/sw/globals_defs_t.html @@ -0,0 +1,109 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: Globals</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +</div><!-- top --> +<div id="doc-content"> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div class="contents"> +<div class="textblock">Here is a list of all documented macros with links to the documentation:</div> + +<h3><a id="index_t" name="index_t"></a>- t -</h3><ul> +<li>TESTCASES&#160;:&#160;<a class="el" href="demo__cfs_2main_8c.html#a906949f076e3e0d0082af3c3b1acb518">main.c</a></li> +<li>TRNG_FIRQ_ENABLE&#160;:&#160;<a class="el" href="neorv32_8h.html#a2896d832852c016eb85210b523642f11">neorv32.h</a></li> +<li>TRNG_FIRQ_PENDING&#160;:&#160;<a class="el" href="neorv32_8h.html#a9c387ca4e2736a27056c11819947c84a">neorv32.h</a></li> +<li>TRNG_RTE_ID&#160;:&#160;<a class="el" href="neorv32_8h.html#afaa705a674acf3fd6c8cb294eaf11c5e">neorv32.h</a></li> +<li>TRNG_TRAP_CODE&#160;:&#160;<a class="el" href="neorv32_8h.html#a11e34802c61a01fd6cba46e3f92d5ac1">neorv32.h</a></li> +<li>TWI_FIRQ_ENABLE&#160;:&#160;<a class="el" href="neorv32_8h.html#a0913144fce247e24ccd0f178b9ac32b7">neorv32.h</a></li> +<li>TWI_FIRQ_PENDING&#160;:&#160;<a class="el" href="neorv32_8h.html#a48b80113ca718fbdc50d75e1ec96a1ff">neorv32.h</a></li> +<li>TWI_RTE_ID&#160;:&#160;<a class="el" href="neorv32_8h.html#a1ac29f2f7bace5ba92b2b68a4541a60c">neorv32.h</a></li> +<li>TWI_TRAP_CODE&#160;:&#160;<a class="el" href="neorv32_8h.html#a0afc1a759116d4d73a199ef769bced47">neorv32.h</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/globals_defs_u.html b/sw/globals_defs_u.html new file mode 100644 index 0000000000..0041a9a4ff --- /dev/null +++ b/sw/globals_defs_u.html @@ -0,0 +1,119 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: Globals</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +</div><!-- top --> +<div id="doc-content"> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div class="contents"> +<div class="textblock">Here is a list of all documented macros with links to the documentation:</div> + +<h3><a id="index_u" name="index_u"></a>- u -</h3><ul> +<li>UART0_RX_FIRQ_ENABLE&#160;:&#160;<a class="el" href="neorv32_8h.html#a6b55ce6abe6b141000a6bb00949169e9">neorv32.h</a></li> +<li>UART0_RX_FIRQ_PENDING&#160;:&#160;<a class="el" href="neorv32_8h.html#a0b738b26abb2b951f1f5c5d9525d7701">neorv32.h</a></li> +<li>UART0_RX_RTE_ID&#160;:&#160;<a class="el" href="neorv32_8h.html#ae8588cca20d5e36f74c5207c376389a1">neorv32.h</a></li> +<li>UART0_RX_TRAP_CODE&#160;:&#160;<a class="el" href="neorv32_8h.html#a7a849638eff31f2e1955bdc53d4fc84d">neorv32.h</a></li> +<li>UART0_TX_FIRQ_ENABLE&#160;:&#160;<a class="el" href="neorv32_8h.html#aff756a395771f22c5f412f23f177ea7d">neorv32.h</a></li> +<li>UART0_TX_FIRQ_PENDING&#160;:&#160;<a class="el" href="neorv32_8h.html#addbe29166bb77bc045ad0e3db68e57e9">neorv32.h</a></li> +<li>UART0_TX_RTE_ID&#160;:&#160;<a class="el" href="neorv32_8h.html#a9dc37695ca169bc0eb93898e7aeeee58">neorv32.h</a></li> +<li>UART0_TX_TRAP_CODE&#160;:&#160;<a class="el" href="neorv32_8h.html#ab50df423fdba86bb83bc5d90a4c3bb20">neorv32.h</a></li> +<li>UART1_RX_FIRQ_ENABLE&#160;:&#160;<a class="el" href="neorv32_8h.html#a6c118c1784d8446360b00cde97437ca7">neorv32.h</a></li> +<li>UART1_RX_FIRQ_PENDING&#160;:&#160;<a class="el" href="neorv32_8h.html#a2e70d3a4e2973d224643813fcf315a20">neorv32.h</a></li> +<li>UART1_RX_RTE_ID&#160;:&#160;<a class="el" href="neorv32_8h.html#ab1c351f5ea19ac9ea864155be9cc0b4b">neorv32.h</a></li> +<li>UART1_RX_TRAP_CODE&#160;:&#160;<a class="el" href="neorv32_8h.html#ad0b9eb2ee1f411d7fccdf4fe263214e1">neorv32.h</a></li> +<li>UART1_TX_FIRQ_ENABLE&#160;:&#160;<a class="el" href="neorv32_8h.html#a0039bae3454a22e71d64e70d674f5d6a">neorv32.h</a></li> +<li>UART1_TX_FIRQ_PENDING&#160;:&#160;<a class="el" href="neorv32_8h.html#ac4060532b7aa390623f54720460a2680">neorv32.h</a></li> +<li>UART1_TX_RTE_ID&#160;:&#160;<a class="el" href="neorv32_8h.html#a6af270d7ae8b1cde30e44eb9142491d3">neorv32.h</a></li> +<li>UART1_TX_TRAP_CODE&#160;:&#160;<a class="el" href="neorv32_8h.html#a4cc50287c7a53982761a8116396ff7dd">neorv32.h</a></li> +<li>UART_BAUD&#160;:&#160;<a class="el" href="bootloader_8c.html#a1fac9153314479ad0ad495d752f0224a">bootloader.c</a></li> +<li>UART_EN&#160;:&#160;<a class="el" href="bootloader_8c.html#af1c2f103ac6e3183f08b39099fab2be9">bootloader.c</a></li> +<li>UART_HW_HANDSHAKE_EN&#160;:&#160;<a class="el" href="bootloader_8c.html#a20e93d623ce07939c3fdd53898f9d583">bootloader.c</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/globals_defs_w.html b/sw/globals_defs_w.html new file mode 100644 index 0000000000..e704b17d60 --- /dev/null +++ b/sw/globals_defs_w.html @@ -0,0 +1,102 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: Globals</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +</div><!-- top --> +<div id="doc-content"> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div class="contents"> +<div class="textblock">Here is a list of all documented macros with links to the documentation:</div> + +<h3><a id="index_w" name="index_w"></a>- w -</h3><ul> +<li>WDT_PASSWORD&#160;:&#160;<a class="el" href="neorv32__wdt_8h.html#af2a2bd9c74bdba1b46bd92025bd00ab6">neorv32_wdt.h</a></li> +<li>WDT_TIMEOUT_S&#160;:&#160;<a class="el" href="demo__wdt_2main_8c.html#a01af3905e60b1869f669315f4a1297f5">main.c</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/globals_defs_x.html b/sw/globals_defs_x.html new file mode 100644 index 0000000000..3062eb6379 --- /dev/null +++ b/sw/globals_defs_x.html @@ -0,0 +1,113 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: Globals</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +</div><!-- top --> +<div id="doc-content"> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div class="contents"> +<div class="textblock">Here is a list of all documented macros with links to the documentation:</div> + +<h3><a id="index_x" name="index_x"></a>- x -</h3><ul> +<li>XIP_CLK_PRSC&#160;:&#160;<a class="el" href="demo__xip_2main_8c.html#aec72efe062dbdb149ae6d4f8b1be6793">main.c</a></li> +<li>XIP_EN&#160;:&#160;<a class="el" href="bootloader_8c.html#a2cf31934b909299fb93bb5eebdbc7c9e">bootloader.c</a></li> +<li>XIP_MEM_BASE_ADDRESS&#160;:&#160;<a class="el" href="neorv32_8h.html#aa01bea676e878a9e87ca10ce2d91e51f">neorv32.h</a></li> +<li>XIRQ_FIRQ_ENABLE&#160;:&#160;<a class="el" href="neorv32_8h.html#afe0cb262d517c7da73d6b5dc78886334">neorv32.h</a></li> +<li>XIRQ_FIRQ_PENDING&#160;:&#160;<a class="el" href="neorv32_8h.html#a866768963f8648363dce40de9f34d61b">neorv32.h</a></li> +<li>XIRQ_RTE_ID&#160;:&#160;<a class="el" href="neorv32_8h.html#a95387d3482ec8e5c1d734805fdf64fa5">neorv32.h</a></li> +<li>XIRQ_TRAP_CODE&#160;:&#160;<a class="el" href="neorv32_8h.html#a16b9a7444833b5581df073661deb8f3a">neorv32.h</a></li> +<li>XIRQ_TRIGGER_EDGE_FALLING&#160;:&#160;<a class="el" href="neorv32__xirq_8h.html#a59316ffc7ee1aacf1d55d460bdca4d04">neorv32_xirq.h</a></li> +<li>XIRQ_TRIGGER_EDGE_RISING&#160;:&#160;<a class="el" href="neorv32__xirq_8h.html#ab7a05371e4dc3de3a9be11c59f5376ee">neorv32_xirq.h</a></li> +<li>XIRQ_TRIGGER_LEVEL_HIGH&#160;:&#160;<a class="el" href="neorv32__xirq_8h.html#a9b10e89b2e257e1af410bff89f29911c">neorv32_xirq.h</a></li> +<li>XIRQ_TRIGGER_LEVEL_LOW&#160;:&#160;<a class="el" href="neorv32__xirq_8h.html#a8bc89e6a47b4d0d95fb2afac4cdc9292">neorv32_xirq.h</a></li> +<li>xstr&#160;:&#160;<a class="el" href="bootloader_8c.html#aff6b53dd58cea43d24393a9a2f79e772">bootloader.c</a></li> +<li>XTEA_CYCLES&#160;:&#160;<a class="el" href="demo__cfu_2main_8c.html#a34755f457331741d24090b3819b5d416">main.c</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/globals_e.html b/sw/globals_e.html new file mode 100644 index 0000000000..b6e2ca45e3 --- /dev/null +++ b/sw/globals_e.html @@ -0,0 +1,116 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: Globals</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +</div><!-- top --> +<div id="doc-content"> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div class="contents"> +<div class="textblock">Here is a list of all documented functions, variables, defines, enums, and typedefs with links to the documentation:</div> + +<h3><a id="index_e" name="index_e"></a>- e -</h3><ul> +<li>ERROR_CHECKSUM&#160;:&#160;<a class="el" href="bootloader_8c.html#aa0c639898508ff8e4fab6290101f3088a471ebe6c0766abc6fa4e82a09bfdb985">bootloader.c</a></li> +<li>ERROR_CODES_enum&#160;:&#160;<a class="el" href="bootloader_8c.html#aa0c639898508ff8e4fab6290101f3088">bootloader.c</a></li> +<li>ERROR_FLASH&#160;:&#160;<a class="el" href="bootloader_8c.html#aa0c639898508ff8e4fab6290101f3088a684d6723fa25e7651e13d99fb249363c">bootloader.c</a></li> +<li>error_message&#160;:&#160;<a class="el" href="bootloader_8c.html#a6fea855ffe2fa0cd5ea9f98c0d5adc4d">bootloader.c</a></li> +<li>ERROR_SIGNATURE&#160;:&#160;<a class="el" href="bootloader_8c.html#aa0c639898508ff8e4fab6290101f3088ad41014563cb3ca69ab69b94d43e97caa">bootloader.c</a></li> +<li>ERROR_SIZE&#160;:&#160;<a class="el" href="bootloader_8c.html#aa0c639898508ff8e4fab6290101f3088a2d77ed1c715fb969a1faa01c71625f2d">bootloader.c</a></li> +<li>exe_available&#160;:&#160;<a class="el" href="bootloader_8c.html#a0f9fcfdf758260b9b79b6eda063dd87a">bootloader.c</a></li> +<li>EXE_BASE_ADDR&#160;:&#160;<a class="el" href="bootloader_8c.html#a18936dc79b9e5aa84df016b046a6b977">bootloader.c</a></li> +<li>EXE_OFFSET_CHECKSUM&#160;:&#160;<a class="el" href="bootloader_8c.html#a165a347c51d8aae06a564a2f297f2febabc27a855096a70dca0f8bc148a123be4">bootloader.c</a></li> +<li>EXE_OFFSET_DATA&#160;:&#160;<a class="el" href="bootloader_8c.html#a165a347c51d8aae06a564a2f297f2febaea032c54a21057710ef2021638972ce6">bootloader.c</a></li> +<li>EXE_OFFSET_SIGNATURE&#160;:&#160;<a class="el" href="bootloader_8c.html#a165a347c51d8aae06a564a2f297f2feba61100996f309c45b8b628ade2e3acc7f">bootloader.c</a></li> +<li>EXE_OFFSET_SIZE&#160;:&#160;<a class="el" href="bootloader_8c.html#a165a347c51d8aae06a564a2f297f2febacc430caa4bff2fef4568c757893fe2fe">bootloader.c</a></li> +<li>EXE_SIGNATURE&#160;:&#160;<a class="el" href="bootloader_8c.html#a0035ad41f622dbfc2412318a8ed39257">bootloader.c</a>, <a class="el" href="demo__xip_2main_8c.html#a0035ad41f622dbfc2412318a8ed39257">main.c</a></li> +<li>EXE_STREAM_FLASH&#160;:&#160;<a class="el" href="bootloader_8c.html#abcbf77626fdd0b475d245f836eab7a83a98526cd8f81d570c57d98193b32cf114">bootloader.c</a></li> +<li>EXE_STREAM_SOURCE_enum&#160;:&#160;<a class="el" href="bootloader_8c.html#abcbf77626fdd0b475d245f836eab7a83">bootloader.c</a></li> +<li>EXE_STREAM_UART&#160;:&#160;<a class="el" href="bootloader_8c.html#abcbf77626fdd0b475d245f836eab7a83ab149261ddf3f08e44e9d2538e384f58f">bootloader.c</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/globals_enum.html b/sw/globals_enum.html new file mode 100644 index 0000000000..3fdcb828f0 --- /dev/null +++ b/sw/globals_enum.html @@ -0,0 +1,152 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: Globals</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +</div><!-- top --> +<div id="doc-content"> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div class="contents"> +<div class="textblock">Here is a list of all documented enums with links to the documentation:</div> + +<h3><a id="index_e" name="index_e"></a>- e -</h3><ul> +<li>ERROR_CODES_enum&#160;:&#160;<a class="el" href="bootloader_8c.html#aa0c639898508ff8e4fab6290101f3088">bootloader.c</a></li> +<li>EXE_STREAM_SOURCE_enum&#160;:&#160;<a class="el" href="bootloader_8c.html#abcbf77626fdd0b475d245f836eab7a83">bootloader.c</a></li> +</ul> + + +<h3><a id="index_n" name="index_n"></a>- n -</h3><ul> +<li>NEORV32_CLOCK_PRSC_enum&#160;:&#160;<a class="el" href="neorv32_8h.html#a10022df4c223533b04d5aebe222e8b73">neorv32.h</a></li> +<li>NEORV32_CRC_MODE_enum&#160;:&#160;<a class="el" href="neorv32__crc_8h.html#a1ae84a58f475bafc2fc3f2c690fd6447">neorv32_crc.h</a></li> +<li>NEORV32_CSR_enum&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49">neorv32_cpu_csr.h</a></li> +<li>NEORV32_CSR_FFLAGS_enum&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#afde0761e3150d82511136f56179c204b">neorv32_cpu_csr.h</a></li> +<li>NEORV32_CSR_MCOUNTINHIBIT_enum&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfe">neorv32_cpu_csr.h</a></li> +<li>NEORV32_CSR_MIE_enum&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33">neorv32_cpu_csr.h</a></li> +<li>NEORV32_CSR_MIP_enum&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21b">neorv32_cpu_csr.h</a></li> +<li>NEORV32_CSR_MISA_enum&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830c">neorv32_cpu_csr.h</a></li> +<li>NEORV32_CSR_MSTATUS_enum&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a76b70a2334131e7589d84c1ee96de485">neorv32_cpu_csr.h</a></li> +<li>NEORV32_CSR_XISA_enum&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387">neorv32_cpu_csr.h</a></li> +<li>NEORV32_DMA_CTRL_enum&#160;:&#160;<a class="el" href="neorv32__dma_8h.html#a6716eddb145b80ad38799da3b87cb2a4">neorv32_dma.h</a></li> +<li>NEORV32_DMA_STATUS_enum&#160;:&#160;<a class="el" href="neorv32__dma_8h.html#a002cb188ea5156df0ba282e239a6e74b">neorv32_dma.h</a></li> +<li>NEORV32_DMA_TTYPE_enum&#160;:&#160;<a class="el" href="neorv32__dma_8h.html#a33187c5a074d62b46d2262e352edb8d9">neorv32_dma.h</a></li> +<li>NEORV32_EXCEPTION_CODES_enum&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1">neorv32_cpu_csr.h</a></li> +<li>NEORV32_EXECUTABLE_enum&#160;:&#160;<a class="el" href="bootloader_8c.html#a165a347c51d8aae06a564a2f297f2feb">bootloader.c</a></li> +<li>NEORV32_GPTMR_CTRL_enum&#160;:&#160;<a class="el" href="neorv32__gptmr_8h.html#a135b0750d4afed16e5867134e3843988">neorv32_gptmr.h</a></li> +<li>NEORV32_HPMCNT_EVENT_enum&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfe">neorv32_cpu_csr.h</a></li> +<li>NEORV32_NEOLED_CTRL_enum&#160;:&#160;<a class="el" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412">neorv32_neoled.h</a></li> +<li>NEORV32_ONEWIRE_CTRL_enum&#160;:&#160;<a class="el" href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831">neorv32_onewire.h</a></li> +<li>NEORV32_ONEWIRE_DATA_enum&#160;:&#160;<a class="el" href="neorv32__onewire_8h.html#ae770490afa8662fb8577065531d51368">neorv32_onewire.h</a></li> +<li>NEORV32_PMP_MODES_enum&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a8f2418fb5e2175f35ee2362469ce01f5">neorv32_cpu_csr.h</a></li> +<li>NEORV32_PMPCFG_ATTRIBUTES_enum&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#abc0e8daad1e9beda4d9950452cc930ea">neorv32_cpu_csr.h</a></li> +<li>NEORV32_PWM_CTRL_enum&#160;:&#160;<a class="el" href="neorv32__pwm_8h.html#af350f93b601a92ef56516198d1570b7d">neorv32_pwm.h</a></li> +<li>NEORV32_RTE_TRAP_enum&#160;:&#160;<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70a">neorv32_rte.h</a></li> +<li>NEORV32_SDI_CTRL_enum&#160;:&#160;<a class="el" href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6">neorv32_sdi.h</a></li> +<li>NEORV32_SLINK_CTRL_enum&#160;:&#160;<a class="el" href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1">neorv32_slink.h</a></li> +<li>NEORV32_SLINK_ROUTE_enum&#160;:&#160;<a class="el" href="neorv32__slink_8h.html#ac3e5e02fd89a357135adca6d28cd0e45">neorv32_slink.h</a></li> +<li>NEORV32_SLINK_STATUS_enum&#160;:&#160;<a class="el" href="neorv32__slink_8h.html#a84f7fe82f188bd4e68f41549587822bf">neorv32_slink.h</a></li> +<li>NEORV32_SPI_CTRL_enum&#160;:&#160;<a class="el" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3b">neorv32_spi.h</a></li> +<li>NEORV32_SPI_DATA_enum&#160;:&#160;<a class="el" href="neorv32__spi_8h.html#aab478c23898c0b06cee53a1cbda38bf8">neorv32_spi.h</a></li> +<li>NEORV32_TRNG_CTRL_enum&#160;:&#160;<a class="el" href="neorv32__trng_8h.html#a1440e1355bf5bff17760992adc156b1a">neorv32_trng.h</a></li> +<li>NEORV32_TWI_CTRL_enum&#160;:&#160;<a class="el" href="neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafa">neorv32_twi.h</a></li> +<li>NEORV32_TWI_DCMD_enum&#160;:&#160;<a class="el" href="neorv32__twi_8h.html#a3421852c63baca60fe58c990b1c653d8">neorv32_twi.h</a></li> +<li>NEORV32_UART_CTRL_enum&#160;:&#160;<a class="el" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afc">neorv32_uart.h</a></li> +<li>NEORV32_UART_DATA_enum&#160;:&#160;<a class="el" href="neorv32__uart_8h.html#adcf35350a9ea18a59c32c35f528643f2">neorv32_uart.h</a></li> +<li>NEORV32_WDT_CTRL_enum&#160;:&#160;<a class="el" href="neorv32__wdt_8h.html#a0a4cb24fd818277c5bb9b10ff519f23e">neorv32_wdt.h</a></li> +<li>NEORV32_WDT_RCAUSE_enum&#160;:&#160;<a class="el" href="neorv32__wdt_8h.html#a70098b4ee893774864536fb4100ff049">neorv32_wdt.h</a></li> +<li>NEORV32_XIP_CTRL_enum&#160;:&#160;<a class="el" href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceb">neorv32_xip.h</a></li> +</ul> + + +<h3><a id="index_s" name="index_s"></a>- s -</h3><ul> +<li>SPI_FLASH_CMD&#160;:&#160;<a class="el" href="demo__xip_2main_8c.html#af30de1c8d8502ad374612d308cfbd12e">main.c</a></li> +<li>SPI_FLASH_CMD_enum&#160;:&#160;<a class="el" href="bootloader_8c.html#aa5e5723e4cbf83805c3b1197cd401fed">bootloader.c</a></li> +<li>SPI_FLASH_SREG&#160;:&#160;<a class="el" href="demo__xip_2main_8c.html#adccf1bb8f1f203cb1350f7f2eb15a08e">main.c</a></li> +<li>SPI_FLASH_SREG_enum&#160;:&#160;<a class="el" href="bootloader_8c.html#a97299f563ebc1fca4c663b025a15136f">bootloader.c</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/globals_eval.html b/sw/globals_eval.html new file mode 100644 index 0000000000..4f4003e996 --- /dev/null +++ b/sw/globals_eval.html @@ -0,0 +1,346 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: Globals</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +</div><!-- top --> +<div id="doc-content"> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div class="contents"> +<div class="textblock">Here is a list of all documented enum values with links to the documentation:</div> + +<h3><a id="index_c" name="index_c"></a>- c -</h3><ul> +<li>CLK_PRSC_1024&#160;:&#160;<a class="el" href="neorv32_8h.html#a10022df4c223533b04d5aebe222e8b73a18aac15afd5ebd8d3a00dd6e513daf17">neorv32.h</a></li> +<li>CLK_PRSC_128&#160;:&#160;<a class="el" href="neorv32_8h.html#a10022df4c223533b04d5aebe222e8b73a933045a5405de55781d687315f42054e">neorv32.h</a></li> +<li>CLK_PRSC_2&#160;:&#160;<a class="el" href="neorv32_8h.html#a10022df4c223533b04d5aebe222e8b73ad63d40139c50d76618cf1258cbdc0d05">neorv32.h</a></li> +<li>CLK_PRSC_2048&#160;:&#160;<a class="el" href="neorv32_8h.html#a10022df4c223533b04d5aebe222e8b73aa138f0cad547028d5124f89d6dcc8c79">neorv32.h</a></li> +<li>CLK_PRSC_4&#160;:&#160;<a class="el" href="neorv32_8h.html#a10022df4c223533b04d5aebe222e8b73a648249b3ab8c2500880c1e68b98f81d1">neorv32.h</a></li> +<li>CLK_PRSC_4096&#160;:&#160;<a class="el" href="neorv32_8h.html#a10022df4c223533b04d5aebe222e8b73a0f20c29722bf9afc478b1a286a6b7eee">neorv32.h</a></li> +<li>CLK_PRSC_64&#160;:&#160;<a class="el" href="neorv32_8h.html#a10022df4c223533b04d5aebe222e8b73a5990532893f2d9606e3c02aff60ca5da">neorv32.h</a></li> +<li>CLK_PRSC_8&#160;:&#160;<a class="el" href="neorv32_8h.html#a10022df4c223533b04d5aebe222e8b73aa4e3a6a5b3cd895f63b4544f63ce22c9">neorv32.h</a></li> +<li>CRC_MODE16&#160;:&#160;<a class="el" href="neorv32__crc_8h.html#a1ae84a58f475bafc2fc3f2c690fd6447aa5cfd5d285b4cb8997c7e754491d050f">neorv32_crc.h</a></li> +<li>CRC_MODE32&#160;:&#160;<a class="el" href="neorv32__crc_8h.html#a1ae84a58f475bafc2fc3f2c690fd6447a7cf26bd4a7e8d6e45016633f650f00aa">neorv32_crc.h</a></li> +<li>CRC_MODE8&#160;:&#160;<a class="el" href="neorv32__crc_8h.html#a1ae84a58f475bafc2fc3f2c690fd6447a9409185edbae1bd0afdeda4e58aa6d1a">neorv32_crc.h</a></li> +<li>CSR_CFUREG0&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ae0e9cf0b99b8614ea0b870d38970281f">neorv32_cpu_csr.h</a></li> +<li>CSR_CFUREG1&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a382304065a6db773f925b80b9447b8a8">neorv32_cpu_csr.h</a></li> +<li>CSR_CFUREG2&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a427d7cf036b49efd46166c01f0504b68">neorv32_cpu_csr.h</a></li> +<li>CSR_CFUREG3&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aefefa1cff0cf5d01109486e5a8bebedf">neorv32_cpu_csr.h</a></li> +<li>CSR_CYCLE&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aaaf0f6b17a06d5922bcfdb47b382137e">neorv32_cpu_csr.h</a></li> +<li>CSR_CYCLEH&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aa276bedb7dab28935163397b4879f6db">neorv32_cpu_csr.h</a></li> +<li>CSR_DCSR&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a6bb3ba59a25803d6f98faad67609a9a9">neorv32_cpu_csr.h</a></li> +<li>CSR_DPC&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49af4c98d949d2eb44f2518fdf314344d3b">neorv32_cpu_csr.h</a></li> +<li>CSR_DSCRATCH0&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a0f4a1ae740efd80d14d21e90f355e9d7">neorv32_cpu_csr.h</a></li> +<li>CSR_FCSR&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a5e1abf46b4f55bd18e1d132b32696ab6">neorv32_cpu_csr.h</a></li> +<li>CSR_FFLAGS&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a625f606c14fd4d7224d7109e10508e7a">neorv32_cpu_csr.h</a></li> +<li>CSR_FFLAGS_DZ&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#afde0761e3150d82511136f56179c204ba365f3f519bca34a349907c82c873d52b">neorv32_cpu_csr.h</a></li> +<li>CSR_FFLAGS_NV&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#afde0761e3150d82511136f56179c204ba3ac330a4b03178e756c980eaa48ad165">neorv32_cpu_csr.h</a></li> +<li>CSR_FFLAGS_NX&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#afde0761e3150d82511136f56179c204ba91a314defd310786a9ed67f7ef2ef5a6">neorv32_cpu_csr.h</a></li> +<li>CSR_FFLAGS_OF&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#afde0761e3150d82511136f56179c204ba612390e07a065fa13eeaeac84af48c6e">neorv32_cpu_csr.h</a></li> +<li>CSR_FFLAGS_UF&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#afde0761e3150d82511136f56179c204babc6d405724563844569028f463885819">neorv32_cpu_csr.h</a></li> +<li>CSR_FRM&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a7f198c465959dde37b7056dd06d45812">neorv32_cpu_csr.h</a></li> +<li>CSR_HPMCOUNTER10&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aa407e701bdbb9d26f84684b811c008a9">neorv32_cpu_csr.h</a></li> +<li>CSR_HPMCOUNTER10H&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ae56e95d6d6dd63ff6f5b4192cf48c88b">neorv32_cpu_csr.h</a></li> +<li>CSR_HPMCOUNTER11&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a9fd1ff4e8a42992c0a3ec02c397dd7f8">neorv32_cpu_csr.h</a></li> +<li>CSR_HPMCOUNTER11H&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a2af8c5dcc87d92bcce392fb5b3aa065e">neorv32_cpu_csr.h</a></li> +<li>CSR_HPMCOUNTER12&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ae58f15a95aa41126819effe046ced804">neorv32_cpu_csr.h</a></li> +<li>CSR_HPMCOUNTER12H&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a74359db2583feb7119d4bcaa926242a0">neorv32_cpu_csr.h</a></li> +<li>CSR_HPMCOUNTER13&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a24d8617a6ff2c1e49c9a73853ad9e450">neorv32_cpu_csr.h</a></li> +<li>CSR_HPMCOUNTER13H&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a4fa22699e96d6da8665077e3c95891ef">neorv32_cpu_csr.h</a></li> +<li>CSR_HPMCOUNTER14&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aa47ed1a4a4f9fcabceed0d6d626d0aaf">neorv32_cpu_csr.h</a></li> +<li>CSR_HPMCOUNTER14H&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a03f29e792be2854efc9e66d710b78a1d">neorv32_cpu_csr.h</a></li> +<li>CSR_HPMCOUNTER15&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a7277a8f929a5a250f7227fbbdf545dbc">neorv32_cpu_csr.h</a></li> +<li>CSR_HPMCOUNTER15H&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a11169bd08920d40c8f94fd29e1d33eff">neorv32_cpu_csr.h</a></li> +<li>CSR_HPMCOUNTER3&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a3ee699d5b2886c54c92992f66b109b67">neorv32_cpu_csr.h</a></li> +<li>CSR_HPMCOUNTER3H&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aaa3e6a1ac8999be42d7c13891546bb50">neorv32_cpu_csr.h</a></li> +<li>CSR_HPMCOUNTER4&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a98ed49716d0d89712863e7a542d38d2a">neorv32_cpu_csr.h</a></li> +<li>CSR_HPMCOUNTER4H&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a8837ff8d2741639aa69da59659f9a080">neorv32_cpu_csr.h</a></li> +<li>CSR_HPMCOUNTER5&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ab2376c3b7c3ec0b44105ec1ed951bfb0">neorv32_cpu_csr.h</a></li> +<li>CSR_HPMCOUNTER5H&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ad489feaa5ad1feb00d3df71d3e5b0cac">neorv32_cpu_csr.h</a></li> +<li>CSR_HPMCOUNTER6&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aa2f644a4f54ba3834bafa738208c0803">neorv32_cpu_csr.h</a></li> +<li>CSR_HPMCOUNTER6H&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a438a65757b85f182dfb1f2a06c9ad520">neorv32_cpu_csr.h</a></li> +<li>CSR_HPMCOUNTER7&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a125c4d0051548dea9104808b7bee1316">neorv32_cpu_csr.h</a></li> +<li>CSR_HPMCOUNTER7H&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a6332d4ff090aa7c302d191219e846fff">neorv32_cpu_csr.h</a></li> +<li>CSR_HPMCOUNTER8&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49acac87125f8c723cc5df4d4169a82852b">neorv32_cpu_csr.h</a></li> +<li>CSR_HPMCOUNTER8H&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aa8ce8fc8a57dd82872d02b4113249a77">neorv32_cpu_csr.h</a></li> +<li>CSR_HPMCOUNTER9&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ab45ebb3bd861074a15cc2ad874756e8f">neorv32_cpu_csr.h</a></li> +<li>CSR_HPMCOUNTER9H&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49acdf793b30919e7fa1b85995abe531a20">neorv32_cpu_csr.h</a></li> +<li>CSR_INSTRET&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a8144da8cd8691ac54aa0712685865b66">neorv32_cpu_csr.h</a></li> +<li>CSR_INSTRETH&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a9b66978d76260283007d399fc735d153">neorv32_cpu_csr.h</a></li> +<li>CSR_MARCHID&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ad95cb95266533123447ff0e917f890e4">neorv32_cpu_csr.h</a></li> +<li>CSR_MCAUSE&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a2e14b57fee5376741634db7980a5005b">neorv32_cpu_csr.h</a></li> +<li>CSR_MCONFIGPTR&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a0545d0921b3f90d037dbb25bc5fcc2f9">neorv32_cpu_csr.h</a></li> +<li>CSR_MCOUNTEREN&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a1860dd9579906c67a3565063043dcf78">neorv32_cpu_csr.h</a></li> +<li>CSR_MCOUNTINHIBIT&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a3ce1dc0e2810f0df78feaa1c607a5ca6">neorv32_cpu_csr.h</a></li> +<li>CSR_MCOUNTINHIBIT_CY&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea201ac39b0eba389b0d02c3951a3311a3">neorv32_cpu_csr.h</a></li> +<li>CSR_MCOUNTINHIBIT_HPM10&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea9517cd32744c5064fa30780f911cd22e">neorv32_cpu_csr.h</a></li> +<li>CSR_MCOUNTINHIBIT_HPM11&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfeacaf997fe8b912596224e2bb632e6a806">neorv32_cpu_csr.h</a></li> +<li>CSR_MCOUNTINHIBIT_HPM12&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea8d866a4c815d8ba890a1e00ce9600486">neorv32_cpu_csr.h</a></li> +<li>CSR_MCOUNTINHIBIT_HPM13&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfead9f6c4eb4284ee82b9e8d0c79f62b3ed">neorv32_cpu_csr.h</a></li> +<li>CSR_MCOUNTINHIBIT_HPM14&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfeaa83c0688869b1c43de0c4474e940f987">neorv32_cpu_csr.h</a></li> +<li>CSR_MCOUNTINHIBIT_HPM15&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea0b547cb5876c0e7956e3d062e0784085">neorv32_cpu_csr.h</a></li> +<li>CSR_MCOUNTINHIBIT_HPM16&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea68aba71ea77aba4005fb24a945ef38e4">neorv32_cpu_csr.h</a></li> +<li>CSR_MCOUNTINHIBIT_HPM17&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea8d57acf13a086635a63bc13ccdf479b3">neorv32_cpu_csr.h</a></li> +<li>CSR_MCOUNTINHIBIT_HPM18&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfeaa680d196d2ba0e403801a860bb9d8ce0">neorv32_cpu_csr.h</a></li> +<li>CSR_MCOUNTINHIBIT_HPM19&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea3683e296caafe771b6dd57f4cf86f3dc">neorv32_cpu_csr.h</a></li> +<li>CSR_MCOUNTINHIBIT_HPM20&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfeaeb4b1b6abafd22eec0764d5503878cca">neorv32_cpu_csr.h</a></li> +<li>CSR_MCOUNTINHIBIT_HPM21&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea1dc0276a5354c805ac56fd46c5037d38">neorv32_cpu_csr.h</a></li> +<li>CSR_MCOUNTINHIBIT_HPM22&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfeaf1b6153a0c664367bfefb78b2ca8b34e">neorv32_cpu_csr.h</a></li> +<li>CSR_MCOUNTINHIBIT_HPM23&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea85c0c2b2a5101380dec72516dda1a904">neorv32_cpu_csr.h</a></li> +<li>CSR_MCOUNTINHIBIT_HPM24&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea74ec85a2e94aa0b9e8af29401ef7ecb1">neorv32_cpu_csr.h</a></li> +<li>CSR_MCOUNTINHIBIT_HPM25&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfeaee2b5a2b7bd7ac07dae45900bc2faf46">neorv32_cpu_csr.h</a></li> +<li>CSR_MCOUNTINHIBIT_HPM26&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea141a4a211c496d2af1c79d8e8e0c2a74">neorv32_cpu_csr.h</a></li> +<li>CSR_MCOUNTINHIBIT_HPM27&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea46def851d4582b4bcec1f9d8bafd58db">neorv32_cpu_csr.h</a></li> +<li>CSR_MCOUNTINHIBIT_HPM28&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea33d0fd3378ec3a2fcc3c8738c6cd2f32">neorv32_cpu_csr.h</a></li> +<li>CSR_MCOUNTINHIBIT_HPM29&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfeaa39882f7dad9b7e16b317c75bad31382">neorv32_cpu_csr.h</a></li> +<li>CSR_MCOUNTINHIBIT_HPM3&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfeaf7020159e0ba346561bfba101d22c752">neorv32_cpu_csr.h</a></li> +<li>CSR_MCOUNTINHIBIT_HPM30&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea0f45818fa4cb9033a3093987fa8515c7">neorv32_cpu_csr.h</a></li> +<li>CSR_MCOUNTINHIBIT_HPM31&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea1da1186ef2f4e7297a4fecaaccdc1d05">neorv32_cpu_csr.h</a></li> +<li>CSR_MCOUNTINHIBIT_HPM4&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea40427b799da049413c5536afa623c61d">neorv32_cpu_csr.h</a></li> +<li>CSR_MCOUNTINHIBIT_HPM5&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea2769a6e6a75f2f903523e4e95a899bb6">neorv32_cpu_csr.h</a></li> +<li>CSR_MCOUNTINHIBIT_HPM6&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfead55b6af15841617d7dca3ab4fab893db">neorv32_cpu_csr.h</a></li> +<li>CSR_MCOUNTINHIBIT_HPM7&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea3b3571fceb687da2d3807b0e59bdf7ab">neorv32_cpu_csr.h</a></li> +<li>CSR_MCOUNTINHIBIT_HPM8&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfeabd21344124eda4402523203185a58b8a">neorv32_cpu_csr.h</a></li> +<li>CSR_MCOUNTINHIBIT_HPM9&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea0f207455df0fed75fa68ba49c435889a">neorv32_cpu_csr.h</a></li> +<li>CSR_MCOUNTINHIBIT_IR&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea5f182f39f9a4b871a097a51e57865bfa">neorv32_cpu_csr.h</a></li> +<li>CSR_MCYCLE&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a32c22641ed66c6d20902306a2b1fad77">neorv32_cpu_csr.h</a></li> +<li>CSR_MCYCLEH&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a28fcfd06ca1012c19cf053e57689687b">neorv32_cpu_csr.h</a></li> +<li>CSR_MENVCFG&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a9c55619ffb05e84b7210e2d47326fa98">neorv32_cpu_csr.h</a></li> +<li>CSR_MENVCFGH&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a46b8d3c288cbbfbf5a0af6e5cd8c5bc8">neorv32_cpu_csr.h</a></li> +<li>CSR_MEPC&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a5d60a25a66754066589e8facb7d41153">neorv32_cpu_csr.h</a></li> +<li>CSR_MHARTID&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a6ba48e2306ae92f498552e1ea04d6790">neorv32_cpu_csr.h</a></li> +<li>CSR_MHPMCOUNTER10&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a575e5342d8ec304c32dbbe99d6fd6c0f">neorv32_cpu_csr.h</a></li> +<li>CSR_MHPMCOUNTER10H&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a1e41d2b27d7e8da14871852d81123cfd">neorv32_cpu_csr.h</a></li> +<li>CSR_MHPMCOUNTER11&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a8840b3d4f45453fc96813ccb369a68e5">neorv32_cpu_csr.h</a></li> +<li>CSR_MHPMCOUNTER11H&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a7fd76fcfc0d0dd47e112786bea5e4071">neorv32_cpu_csr.h</a></li> +<li>CSR_MHPMCOUNTER12&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a1328a226d36d23cc81740397bde47a4e">neorv32_cpu_csr.h</a></li> +<li>CSR_MHPMCOUNTER12H&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a332ec2b0740f8e899a1b2ec86f7ee9f2">neorv32_cpu_csr.h</a></li> +<li>CSR_MHPMCOUNTER13&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a9bdd102877ff50d38c86c3d741aeb4b0">neorv32_cpu_csr.h</a></li> +<li>CSR_MHPMCOUNTER13H&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a5de5c5a036dc594a554d37df9ccf657d">neorv32_cpu_csr.h</a></li> +<li>CSR_MHPMCOUNTER14&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49adae22d860d8162e15120051951e45229">neorv32_cpu_csr.h</a></li> +<li>CSR_MHPMCOUNTER14H&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ac65bab6fd71439600c8fc549171251fa">neorv32_cpu_csr.h</a></li> +<li>CSR_MHPMCOUNTER15&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a20400929087fabba410a098667d2d4ff">neorv32_cpu_csr.h</a></li> +<li>CSR_MHPMCOUNTER15H&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49af609807e2917f73e27e5f27b38a0fa46">neorv32_cpu_csr.h</a></li> +<li>CSR_MHPMCOUNTER3&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ae0a96f499dcde474af6ee620fbb1ebdc">neorv32_cpu_csr.h</a></li> +<li>CSR_MHPMCOUNTER3H&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a252980a4da90c1f5c1ef85d164f72f25">neorv32_cpu_csr.h</a></li> +<li>CSR_MHPMCOUNTER4&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a9b84bd948dd52a7779b5fd16beddaab9">neorv32_cpu_csr.h</a></li> +<li>CSR_MHPMCOUNTER4H&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a2e9cfbf3c2828dd4bd92d2b8a1c99f85">neorv32_cpu_csr.h</a></li> +<li>CSR_MHPMCOUNTER5&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49af15d389bb8f91c989df488d231666394">neorv32_cpu_csr.h</a></li> +<li>CSR_MHPMCOUNTER5H&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a7648dd0a47007d44a14e95ba47726599">neorv32_cpu_csr.h</a></li> +<li>CSR_MHPMCOUNTER6&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49af65b9e99b9cadb3cb8d37f97cdbfeb9d">neorv32_cpu_csr.h</a></li> +<li>CSR_MHPMCOUNTER6H&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a49b7bc2df67a6c73a68757de9b218f77">neorv32_cpu_csr.h</a></li> +<li>CSR_MHPMCOUNTER7&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a919f39b0d299feb80403b42a466de444">neorv32_cpu_csr.h</a></li> +<li>CSR_MHPMCOUNTER7H&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ac0183bb6f357ed33136493ae7ded987a">neorv32_cpu_csr.h</a></li> +<li>CSR_MHPMCOUNTER8&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a5a4cde90c547e913bddc719b3ab75e79">neorv32_cpu_csr.h</a></li> +<li>CSR_MHPMCOUNTER8H&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a9e75518df7d14a009e3a0d5588641ddc">neorv32_cpu_csr.h</a></li> +<li>CSR_MHPMCOUNTER9&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a18c2a249f1f7852f42f9e10dc59d46bb">neorv32_cpu_csr.h</a></li> +<li>CSR_MHPMCOUNTER9H&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a7341886c7a4aed6fc7d8677c016a2cb8">neorv32_cpu_csr.h</a></li> +<li>CSR_MHPMEVENT10&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a23850b1804966cde2c1e84cde752d512">neorv32_cpu_csr.h</a></li> +<li>CSR_MHPMEVENT11&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a7fb1de2019dd2b548084d5ca1630efbf">neorv32_cpu_csr.h</a></li> +<li>CSR_MHPMEVENT12&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ad648b5ece209d47e9484fd7aa83e8e5f">neorv32_cpu_csr.h</a></li> +<li>CSR_MHPMEVENT13&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a8c31899b81bb5dba9b92a0f0ca71aea6">neorv32_cpu_csr.h</a></li> +<li>CSR_MHPMEVENT14&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a964a6a50d0138447fad47e9c982a7ba4">neorv32_cpu_csr.h</a></li> +<li>CSR_MHPMEVENT15&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a06dfdeed757606529e4a99c033691b54">neorv32_cpu_csr.h</a></li> +<li>CSR_MHPMEVENT3&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a4a93ac5ab276cfd2f9cd296c8ce1bff6">neorv32_cpu_csr.h</a></li> +<li>CSR_MHPMEVENT4&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ab5f998725e002ffc2ff516ee973fe459">neorv32_cpu_csr.h</a></li> +<li>CSR_MHPMEVENT5&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a2524659ca2785af51af7acf9cd560a9d">neorv32_cpu_csr.h</a></li> +<li>CSR_MHPMEVENT6&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a1cfa1e3bc3c8a1c9a86c251a510d11cd">neorv32_cpu_csr.h</a></li> +<li>CSR_MHPMEVENT7&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a2e53e6e01ca8d1b801f6dfba602f3f59">neorv32_cpu_csr.h</a></li> +<li>CSR_MHPMEVENT8&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ad6296ca83bbe1280624f3c21adbd8a79">neorv32_cpu_csr.h</a></li> +<li>CSR_MHPMEVENT9&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49af6727a9bdd60ccf020812095b7396632">neorv32_cpu_csr.h</a></li> +<li>CSR_MIE&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49acc0f9f5f3b5702f1b57f2ba3b6b62610">neorv32_cpu_csr.h</a></li> +<li>CSR_MIE_FIRQ0E&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a99f43f8bbfb29fba6224f081c363ac7d">neorv32_cpu_csr.h</a></li> +<li>CSR_MIE_FIRQ10E&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33affcb52dc57bb8c0cb1e7d3c1392d544a">neorv32_cpu_csr.h</a></li> +<li>CSR_MIE_FIRQ11E&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33af058342854a0becd3bcc33877d9244cd">neorv32_cpu_csr.h</a></li> +<li>CSR_MIE_FIRQ12E&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a41f91a37f7e0c75c783312af6a72e943">neorv32_cpu_csr.h</a></li> +<li>CSR_MIE_FIRQ13E&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a134ed02c7293008b21b1df472be8f11f">neorv32_cpu_csr.h</a></li> +<li>CSR_MIE_FIRQ14E&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a864d135708530016cfc52a65a1e4d79b">neorv32_cpu_csr.h</a></li> +<li>CSR_MIE_FIRQ15E&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33aa2dfa1183af312de2959dadd217fddc1">neorv32_cpu_csr.h</a></li> +<li>CSR_MIE_FIRQ1E&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33ac1e1d44becec1b393f79a118ed3d8beb">neorv32_cpu_csr.h</a></li> +<li>CSR_MIE_FIRQ2E&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33afc805280e20ffface116ca61e11645f7">neorv32_cpu_csr.h</a></li> +<li>CSR_MIE_FIRQ3E&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a666066099d6cebadbef21d81c179e8db">neorv32_cpu_csr.h</a></li> +<li>CSR_MIE_FIRQ4E&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a592939f1b7d79097f7f13d6ab0c268dc">neorv32_cpu_csr.h</a></li> +<li>CSR_MIE_FIRQ5E&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a3079a8fbf3b8e376865bff76f2173698">neorv32_cpu_csr.h</a></li> +<li>CSR_MIE_FIRQ6E&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a96315d6b5b9531bcbc1e78a3c9ab166a">neorv32_cpu_csr.h</a></li> +<li>CSR_MIE_FIRQ7E&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a3d9d729940170609affbc6813054ebe8">neorv32_cpu_csr.h</a></li> +<li>CSR_MIE_FIRQ8E&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a396c6c4b425b3fff598e2f846052f98e">neorv32_cpu_csr.h</a></li> +<li>CSR_MIE_FIRQ9E&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a06fdb61dab31c3490da6c37d47914f19">neorv32_cpu_csr.h</a></li> +<li>CSR_MIE_MEIE&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33ae8e4f0ee46abbbb3361de035a57b8324">neorv32_cpu_csr.h</a></li> +<li>CSR_MIE_MSIE&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33afd2f1c78c442c8c29ab075cacee0a27a">neorv32_cpu_csr.h</a></li> +<li>CSR_MIE_MTIE&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a3658e8663e94cd8eaa7201b7a850d083">neorv32_cpu_csr.h</a></li> +<li>CSR_MIMPID&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a06d39cf0f13d6401dcf426d56149c8cd">neorv32_cpu_csr.h</a></li> +<li>CSR_MINSTRET&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a98f5e2cf2d5dbb0125a222b0065c86eb">neorv32_cpu_csr.h</a></li> +<li>CSR_MINSTRETH&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49afffb28b62b9baa127ae3bad919208988">neorv32_cpu_csr.h</a></li> +<li>CSR_MIP&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49addb485275c954d1181d5bd4e4609082c">neorv32_cpu_csr.h</a></li> +<li>CSR_MIP_FIRQ0P&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba28a85ad8bd4c30fd3a91298dfa4fdb00">neorv32_cpu_csr.h</a></li> +<li>CSR_MIP_FIRQ10P&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba2b50cfa8be461b088ea8506ce4c741ba">neorv32_cpu_csr.h</a></li> +<li>CSR_MIP_FIRQ11P&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba69ea0d3d76d4cec398f3b96959cc3544">neorv32_cpu_csr.h</a></li> +<li>CSR_MIP_FIRQ12P&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba03edd398920b817150d29107c0b40792">neorv32_cpu_csr.h</a></li> +<li>CSR_MIP_FIRQ13P&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba14da6a2a962bf82970638a948ffbc570">neorv32_cpu_csr.h</a></li> +<li>CSR_MIP_FIRQ14P&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21baad1e5e452a9c37561308765431f0260d">neorv32_cpu_csr.h</a></li> +<li>CSR_MIP_FIRQ15P&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba12da8c32d38d5a3539a0b766718bfd2d">neorv32_cpu_csr.h</a></li> +<li>CSR_MIP_FIRQ1P&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba2b577b1da1074c29ad58005af1f91d52">neorv32_cpu_csr.h</a></li> +<li>CSR_MIP_FIRQ2P&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21badf45c5a135431f958fa63574c1dfac6e">neorv32_cpu_csr.h</a></li> +<li>CSR_MIP_FIRQ3P&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba7512bb6c4841ddd477422b49ebb2a155">neorv32_cpu_csr.h</a></li> +<li>CSR_MIP_FIRQ4P&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21bab6421f242bb8a487a986346e11196eb8">neorv32_cpu_csr.h</a></li> +<li>CSR_MIP_FIRQ5P&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21baaa55d19f9a47889bc364c94bda04b677">neorv32_cpu_csr.h</a></li> +<li>CSR_MIP_FIRQ6P&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21baffa7342631aa0526aaa44c0c549b1f3e">neorv32_cpu_csr.h</a></li> +<li>CSR_MIP_FIRQ7P&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21baad691486001a68f2375dcf5793ee795a">neorv32_cpu_csr.h</a></li> +<li>CSR_MIP_FIRQ8P&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21baf5bbd23d4f311f640db42e9015f87580">neorv32_cpu_csr.h</a></li> +<li>CSR_MIP_FIRQ9P&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21bad94c9691ce59b97fcfec14d345046c3e">neorv32_cpu_csr.h</a></li> +<li>CSR_MIP_MEIP&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba1d761ef98f88c40509168ac66b7a4872">neorv32_cpu_csr.h</a></li> +<li>CSR_MIP_MSIP&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba1470cfe04f9d3ce45b7156b2a7fae159">neorv32_cpu_csr.h</a></li> +<li>CSR_MIP_MTIP&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba344943c62922561378d33ec51ac236e4">neorv32_cpu_csr.h</a></li> +<li>CSR_MISA&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ade079242596ce14ce1ba9842ed29b84c">neorv32_cpu_csr.h</a></li> +<li>CSR_MISA_A&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830ca89412df9f99d2a0ddc4665446397f1a2">neorv32_cpu_csr.h</a></li> +<li>CSR_MISA_B&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830cadd469404a928e012a298773ec46926ad">neorv32_cpu_csr.h</a></li> +<li>CSR_MISA_C&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830ca886699013158c74810598fa2fd6b07fa">neorv32_cpu_csr.h</a></li> +<li>CSR_MISA_D&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830ca1dd1be1071450f9b00a817bce19fa665">neorv32_cpu_csr.h</a></li> +<li>CSR_MISA_E&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830ca0ac798fd19cb7dbe1146afecda448fec">neorv32_cpu_csr.h</a></li> +<li>CSR_MISA_F&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830ca9ec2cae2b948de1043540a4ca1665c40">neorv32_cpu_csr.h</a></li> +<li>CSR_MISA_I&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830ca6091fd2c7ae38ad33be68a0fdfa50cca">neorv32_cpu_csr.h</a></li> +<li>CSR_MISA_M&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830ca317a631e4598532f5bffe8fb93aff94b">neorv32_cpu_csr.h</a></li> +<li>CSR_MISA_MXL_HI&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830cafb3e4b08b87f5c161468a9e58ade12cc">neorv32_cpu_csr.h</a></li> +<li>CSR_MISA_MXL_LO&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830cab5a55e97b8511f42fe68559a38f7f138">neorv32_cpu_csr.h</a></li> +<li>CSR_MISA_U&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830cacd9d71e674d3a6d04984b6df706d9deb">neorv32_cpu_csr.h</a></li> +<li>CSR_MISA_X&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830ca0b119a20be29fcae8fecf2a81c60d193">neorv32_cpu_csr.h</a></li> +<li>CSR_MSCRATCH&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ae29976bb072639975ad0cdb985c7f004">neorv32_cpu_csr.h</a></li> +<li>CSR_MSTATUS&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ad0e5de789d6390f750b8af03cdd15450">neorv32_cpu_csr.h</a></li> +<li>CSR_MSTATUS_MIE&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a76b70a2334131e7589d84c1ee96de485ae2603e365b3f1abfb46d53ed6b13dc56">neorv32_cpu_csr.h</a></li> +<li>CSR_MSTATUS_MPIE&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a76b70a2334131e7589d84c1ee96de485aaa1d482f828ac9cafc40fcfc298bec34">neorv32_cpu_csr.h</a></li> +<li>CSR_MSTATUS_MPP_H&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a76b70a2334131e7589d84c1ee96de485a8067c609c2360cab3bafa3c43e03dbf0">neorv32_cpu_csr.h</a></li> +<li>CSR_MSTATUS_MPP_L&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a76b70a2334131e7589d84c1ee96de485af0ae9aca74144aa7dbdf656f71cc5c97">neorv32_cpu_csr.h</a></li> +<li>CSR_MSTATUS_MPRV&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a76b70a2334131e7589d84c1ee96de485a75cefdbdef36b7fc248765b27c606a44">neorv32_cpu_csr.h</a></li> +<li>CSR_MSTATUS_TW&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a76b70a2334131e7589d84c1ee96de485ac94a070f3fe7962e8c49a81545cacf2d">neorv32_cpu_csr.h</a></li> +<li>CSR_MSTATUSH&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ac2541060307369b2031e9ec07bbd0067">neorv32_cpu_csr.h</a></li> +<li>CSR_MTINST&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a4f229c169ada239033a1383412ce58c8">neorv32_cpu_csr.h</a></li> +<li>CSR_MTVAL&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a76d30359e3b54197fb53f9939734cf1e">neorv32_cpu_csr.h</a></li> +<li>CSR_MTVEC&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aa632d218400268df6dc6b289ff088d21">neorv32_cpu_csr.h</a></li> +<li>CSR_MVENDORID&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49af5c5a21909aaca2b57f9a15f4bac246b">neorv32_cpu_csr.h</a></li> +<li>CSR_MXISA&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a396847bcf1634a1602ab117bfb57bdd2">neorv32_cpu_csr.h</a></li> +<li>CSR_MXISA_FASTMUL&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387a48e57689f8a5b51d9ee9d648da7efc64">neorv32_cpu_csr.h</a></li> +<li>CSR_MXISA_FASTSHIFT&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387ad5ac9e2188757e6c42c159f0c5887868">neorv32_cpu_csr.h</a></li> +<li>CSR_MXISA_IS_SIM&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387a9b121ec0ad6271b6e07658f861015f6a">neorv32_cpu_csr.h</a></li> +<li>CSR_MXISA_RFHWRST&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387a6843c660d75f33e4252c7fccd4565a2d">neorv32_cpu_csr.h</a></li> +<li>CSR_MXISA_SDEXT&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387ab6aec595e6aa5ce7c98c7806d23d7af5">neorv32_cpu_csr.h</a></li> +<li>CSR_MXISA_SDTRIG&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387a59eae4272528f589f299ef9cce45af5b">neorv32_cpu_csr.h</a></li> +<li>CSR_MXISA_SMPMP&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387a6938948290d86b0ad25923f35d6c86d3">neorv32_cpu_csr.h</a></li> +<li>CSR_MXISA_ZFINX&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387a56ec3195d0d27f362f58fadb2e037ed1">neorv32_cpu_csr.h</a></li> +<li>CSR_MXISA_ZICNTR&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387a42a3b78195741af4b6aeeb98cbea46fe">neorv32_cpu_csr.h</a></li> +<li>CSR_MXISA_ZICOND&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387ab1f289cfaa9f54f7831a2abcdf9fca2e">neorv32_cpu_csr.h</a></li> +<li>CSR_MXISA_ZICSR&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387accf1dd12be89e45df1423a5600789f2c">neorv32_cpu_csr.h</a></li> +<li>CSR_MXISA_ZIFENCEI&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387a6979d4389ed9f8605d338fc616d29f0e">neorv32_cpu_csr.h</a></li> +<li>CSR_MXISA_ZIHPM&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387ac13e6883af3a9da18057462239b9fb34">neorv32_cpu_csr.h</a></li> +<li>CSR_MXISA_ZMMUL&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387a79b2b4b20e08ad31b50724a7a27fb20f">neorv32_cpu_csr.h</a></li> +<li>CSR_MXISA_ZXCFU&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387af422ae3b5caba59e33a29b5d069597e0">neorv32_cpu_csr.h</a></li> +<li>CSR_PMPADDR0&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a8941071db6145d34fff842249c0dcb9f">neorv32_cpu_csr.h</a></li> +<li>CSR_PMPADDR1&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a6a2933f3a1fa243de02db8a795e3ca41">neorv32_cpu_csr.h</a></li> +<li>CSR_PMPADDR10&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ad97b6fe934a3bed6b02d0c8d81165d60">neorv32_cpu_csr.h</a></li> +<li>CSR_PMPADDR11&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a3e5708c0f79cf58ae761b6bb8c2a4383">neorv32_cpu_csr.h</a></li> +<li>CSR_PMPADDR12&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a23026793ee53c8d55d23f63195368a6b">neorv32_cpu_csr.h</a></li> +<li>CSR_PMPADDR13&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a30879e88b250d3e94d9d9e728ffcc2cc">neorv32_cpu_csr.h</a></li> +<li>CSR_PMPADDR14&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a91a8b5008b4e08ab34c1516e21bf0ba8">neorv32_cpu_csr.h</a></li> +<li>CSR_PMPADDR15&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a6879b4bf5d2db92d236b9091df4841f2">neorv32_cpu_csr.h</a></li> +<li>CSR_PMPADDR2&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aa0b8c0561e8a778dce9c3b86499ffc50">neorv32_cpu_csr.h</a></li> +<li>CSR_PMPADDR3&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a89bad989197e9358563557311b3c97e9">neorv32_cpu_csr.h</a></li> +<li>CSR_PMPADDR4&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ace4529c53ad2d46767f86d920eada507">neorv32_cpu_csr.h</a></li> +<li>CSR_PMPADDR5&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ad9e78f71409fd7783cc2ae7c28b5e42c">neorv32_cpu_csr.h</a></li> +<li>CSR_PMPADDR6&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49af57b5b7b57cd6e8b3489a27dfd702444">neorv32_cpu_csr.h</a></li> +<li>CSR_PMPADDR7&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ae8ea19cf3e527dbc0d36a43dfd1b7346">neorv32_cpu_csr.h</a></li> +<li>CSR_PMPADDR8&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aec68bf7e26e44170c24599f7c6a8365b">neorv32_cpu_csr.h</a></li> +<li>CSR_PMPADDR9&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a54d38c8cf364d886eb7ac64463eedf77">neorv32_cpu_csr.h</a></li> +<li>CSR_PMPCFG0&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49af1a79349e46a4829af78d2cdfd0dc44f">neorv32_cpu_csr.h</a></li> +<li>CSR_PMPCFG1&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a22eea318ec1ac72cc14e133b71ef4b16">neorv32_cpu_csr.h</a></li> +<li>CSR_PMPCFG2&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a0c9492f6b956f088847f72b28e7b1446">neorv32_cpu_csr.h</a></li> +<li>CSR_PMPCFG3&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a067ed3778590ae97dc9b16069f0ed850">neorv32_cpu_csr.h</a></li> +<li>CSR_TDATA1&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a80eab0e17f5fe41edde485044674dc57">neorv32_cpu_csr.h</a></li> +<li>CSR_TDATA2&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49acf336638697242b691b691dc56b9aadc">neorv32_cpu_csr.h</a></li> +<li>CSR_TINFO&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49af67c819c104f7e3ec34f2cbb847cf83b">neorv32_cpu_csr.h</a></li> +<li>CSR_TSELECT&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aaae2f0b2e3f5a31dff933868873f6d5d">neorv32_cpu_csr.h</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/globals_eval_d.html b/sw/globals_eval_d.html new file mode 100644 index 0000000000..92a01fd90f --- /dev/null +++ b/sw/globals_eval_d.html @@ -0,0 +1,121 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: Globals</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +</div><!-- top --> +<div id="doc-content"> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div class="contents"> +<div class="textblock">Here is a list of all documented enum values with links to the documentation:</div> + +<h3><a id="index_d" name="index_d"></a>- d -</h3><ul> +<li>DMA_CTRL_AUTO&#160;:&#160;<a class="el" href="neorv32__dma_8h.html#a6716eddb145b80ad38799da3b87cb2a4a5aeeb05d6365d94d92808df2490daa3b">neorv32_dma.h</a></li> +<li>DMA_CTRL_BUSY&#160;:&#160;<a class="el" href="neorv32__dma_8h.html#a6716eddb145b80ad38799da3b87cb2a4a8e5ff34ac48eea4b352378bb2af47bcb">neorv32_dma.h</a></li> +<li>DMA_CTRL_DONE&#160;:&#160;<a class="el" href="neorv32__dma_8h.html#a6716eddb145b80ad38799da3b87cb2a4a0d51df1bb87dc54d331891c5db787bcc">neorv32_dma.h</a></li> +<li>DMA_CTRL_EN&#160;:&#160;<a class="el" href="neorv32__dma_8h.html#a6716eddb145b80ad38799da3b87cb2a4a5f39deea0212f45423243c8100c40838">neorv32_dma.h</a></li> +<li>DMA_CTRL_ERROR_RD&#160;:&#160;<a class="el" href="neorv32__dma_8h.html#a6716eddb145b80ad38799da3b87cb2a4a539609fc4d80867b3eb98c78206f5f96">neorv32_dma.h</a></li> +<li>DMA_CTRL_ERROR_WR&#160;:&#160;<a class="el" href="neorv32__dma_8h.html#a6716eddb145b80ad38799da3b87cb2a4af7e038b0b0e3ac64f5a2c598eb9c5101">neorv32_dma.h</a></li> +<li>DMA_CTRL_FENCE&#160;:&#160;<a class="el" href="neorv32__dma_8h.html#a6716eddb145b80ad38799da3b87cb2a4ace9fdcdfa8784abad30e033c273e7d00">neorv32_dma.h</a></li> +<li>DMA_CTRL_FIRQ_SEL_LSB&#160;:&#160;<a class="el" href="neorv32__dma_8h.html#a6716eddb145b80ad38799da3b87cb2a4aaf040e663494b39b890d7171d0a584b9">neorv32_dma.h</a></li> +<li>DMA_CTRL_FIRQ_SEL_MSB&#160;:&#160;<a class="el" href="neorv32__dma_8h.html#a6716eddb145b80ad38799da3b87cb2a4a3eba1f7868f0c985effb69785ced011a">neorv32_dma.h</a></li> +<li>DMA_CTRL_FIRQ_TYPE&#160;:&#160;<a class="el" href="neorv32__dma_8h.html#a6716eddb145b80ad38799da3b87cb2a4aeaf5ee8f6a84668aa15cd3e21f076afe">neorv32_dma.h</a></li> +<li>DMA_STATUS_BUSY&#160;:&#160;<a class="el" href="neorv32__dma_8h.html#a002cb188ea5156df0ba282e239a6e74bad0f66e962296f5451d73dc1cae1fdc0d">neorv32_dma.h</a></li> +<li>DMA_STATUS_ERR_RD&#160;:&#160;<a class="el" href="neorv32__dma_8h.html#a002cb188ea5156df0ba282e239a6e74baed7242b847e3cc8cf20d7da99f9b1492">neorv32_dma.h</a></li> +<li>DMA_STATUS_ERR_WR&#160;:&#160;<a class="el" href="neorv32__dma_8h.html#a002cb188ea5156df0ba282e239a6e74ba038b6ef194c3db158cb59168f763a7b8">neorv32_dma.h</a></li> +<li>DMA_STATUS_IDLE&#160;:&#160;<a class="el" href="neorv32__dma_8h.html#a002cb188ea5156df0ba282e239a6e74bac9c380cd5729386e5f5673e20b86326f">neorv32_dma.h</a></li> +<li>DMA_TTYPE_DST_INC&#160;:&#160;<a class="el" href="neorv32__dma_8h.html#a33187c5a074d62b46d2262e352edb8d9abb1293915b076e5d37be6724b44ab0da">neorv32_dma.h</a></li> +<li>DMA_TTYPE_ENDIAN&#160;:&#160;<a class="el" href="neorv32__dma_8h.html#a33187c5a074d62b46d2262e352edb8d9a37ea8ef1e6b342db330d3885545fc802">neorv32_dma.h</a></li> +<li>DMA_TTYPE_NUM_LSB&#160;:&#160;<a class="el" href="neorv32__dma_8h.html#a33187c5a074d62b46d2262e352edb8d9a8dba4160c033c763f5102928c471e450">neorv32_dma.h</a></li> +<li>DMA_TTYPE_NUM_MSB&#160;:&#160;<a class="el" href="neorv32__dma_8h.html#a33187c5a074d62b46d2262e352edb8d9a61553eee00ed2382565bf826074c44bd">neorv32_dma.h</a></li> +<li>DMA_TTYPE_QSEL_LSB&#160;:&#160;<a class="el" href="neorv32__dma_8h.html#a33187c5a074d62b46d2262e352edb8d9afcfdedeca4c4a1def4905660811e31e2">neorv32_dma.h</a></li> +<li>DMA_TTYPE_QSEL_MSB&#160;:&#160;<a class="el" href="neorv32__dma_8h.html#a33187c5a074d62b46d2262e352edb8d9a4217c9a8ac4ccc52bb45944f30a598c5">neorv32_dma.h</a></li> +<li>DMA_TTYPE_SRC_INC&#160;:&#160;<a class="el" href="neorv32__dma_8h.html#a33187c5a074d62b46d2262e352edb8d9a4b99a30b851851f3388dd4e77effacec">neorv32_dma.h</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/globals_eval_e.html b/sw/globals_eval_e.html new file mode 100644 index 0000000000..4f7d81c13b --- /dev/null +++ b/sw/globals_eval_e.html @@ -0,0 +1,110 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: Globals</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +</div><!-- top --> +<div id="doc-content"> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div class="contents"> +<div class="textblock">Here is a list of all documented enum values with links to the documentation:</div> + +<h3><a id="index_e" name="index_e"></a>- e -</h3><ul> +<li>ERROR_CHECKSUM&#160;:&#160;<a class="el" href="bootloader_8c.html#aa0c639898508ff8e4fab6290101f3088a471ebe6c0766abc6fa4e82a09bfdb985">bootloader.c</a></li> +<li>ERROR_FLASH&#160;:&#160;<a class="el" href="bootloader_8c.html#aa0c639898508ff8e4fab6290101f3088a684d6723fa25e7651e13d99fb249363c">bootloader.c</a></li> +<li>ERROR_SIGNATURE&#160;:&#160;<a class="el" href="bootloader_8c.html#aa0c639898508ff8e4fab6290101f3088ad41014563cb3ca69ab69b94d43e97caa">bootloader.c</a></li> +<li>ERROR_SIZE&#160;:&#160;<a class="el" href="bootloader_8c.html#aa0c639898508ff8e4fab6290101f3088a2d77ed1c715fb969a1faa01c71625f2d">bootloader.c</a></li> +<li>EXE_OFFSET_CHECKSUM&#160;:&#160;<a class="el" href="bootloader_8c.html#a165a347c51d8aae06a564a2f297f2febabc27a855096a70dca0f8bc148a123be4">bootloader.c</a></li> +<li>EXE_OFFSET_DATA&#160;:&#160;<a class="el" href="bootloader_8c.html#a165a347c51d8aae06a564a2f297f2febaea032c54a21057710ef2021638972ce6">bootloader.c</a></li> +<li>EXE_OFFSET_SIGNATURE&#160;:&#160;<a class="el" href="bootloader_8c.html#a165a347c51d8aae06a564a2f297f2feba61100996f309c45b8b628ade2e3acc7f">bootloader.c</a></li> +<li>EXE_OFFSET_SIZE&#160;:&#160;<a class="el" href="bootloader_8c.html#a165a347c51d8aae06a564a2f297f2febacc430caa4bff2fef4568c757893fe2fe">bootloader.c</a></li> +<li>EXE_STREAM_FLASH&#160;:&#160;<a class="el" href="bootloader_8c.html#abcbf77626fdd0b475d245f836eab7a83a98526cd8f81d570c57d98193b32cf114">bootloader.c</a></li> +<li>EXE_STREAM_UART&#160;:&#160;<a class="el" href="bootloader_8c.html#abcbf77626fdd0b475d245f836eab7a83ab149261ddf3f08e44e9d2538e384f58f">bootloader.c</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/globals_eval_f.html b/sw/globals_eval_f.html new file mode 100644 index 0000000000..76186ccc15 --- /dev/null +++ b/sw/globals_eval_f.html @@ -0,0 +1,102 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: Globals</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +</div><!-- top --> +<div id="doc-content"> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div class="contents"> +<div class="textblock">Here is a list of all documented enum values with links to the documentation:</div> + +<h3><a id="index_f" name="index_f"></a>- f -</h3><ul> +<li>FLASH_SREG_BUSY&#160;:&#160;<a class="el" href="bootloader_8c.html#a97299f563ebc1fca4c663b025a15136fa133cd87673ce9a612da494583e03dae9">bootloader.c</a></li> +<li>FLASH_SREG_WEL&#160;:&#160;<a class="el" href="bootloader_8c.html#a97299f563ebc1fca4c663b025a15136fa22e8c983d74430ea0930e37781e88bf9">bootloader.c</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/globals_eval_g.html b/sw/globals_eval_g.html new file mode 100644 index 0000000000..7199f904d5 --- /dev/null +++ b/sw/globals_eval_g.html @@ -0,0 +1,107 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: Globals</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +</div><!-- top --> +<div id="doc-content"> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div class="contents"> +<div class="textblock">Here is a list of all documented enum values with links to the documentation:</div> + +<h3><a id="index_g" name="index_g"></a>- g -</h3><ul> +<li>GPTMR_CTRL_EN&#160;:&#160;<a class="el" href="neorv32__gptmr_8h.html#a135b0750d4afed16e5867134e3843988abbfa7abcbd80b9c47e83e23e5cefaf90">neorv32_gptmr.h</a></li> +<li>GPTMR_CTRL_IRQ_CLR&#160;:&#160;<a class="el" href="neorv32__gptmr_8h.html#a135b0750d4afed16e5867134e3843988aadb663ad9a0dfd37fc65dffc1a289b38">neorv32_gptmr.h</a></li> +<li>GPTMR_CTRL_IRQ_PND&#160;:&#160;<a class="el" href="neorv32__gptmr_8h.html#a135b0750d4afed16e5867134e3843988a3a868dc710ab9add083137e4e3fe888a">neorv32_gptmr.h</a></li> +<li>GPTMR_CTRL_MODE&#160;:&#160;<a class="el" href="neorv32__gptmr_8h.html#a135b0750d4afed16e5867134e3843988a473870880c0eca71578d6969e816af43">neorv32_gptmr.h</a></li> +<li>GPTMR_CTRL_PRSC0&#160;:&#160;<a class="el" href="neorv32__gptmr_8h.html#a135b0750d4afed16e5867134e3843988ae4716a7a9e356484a8e478f07920cde3">neorv32_gptmr.h</a></li> +<li>GPTMR_CTRL_PRSC1&#160;:&#160;<a class="el" href="neorv32__gptmr_8h.html#a135b0750d4afed16e5867134e3843988a1e1e8e516fa4918441e3c77153940298">neorv32_gptmr.h</a></li> +<li>GPTMR_CTRL_PRSC2&#160;:&#160;<a class="el" href="neorv32__gptmr_8h.html#a135b0750d4afed16e5867134e3843988a185861fbdc5f276735481237ad844833">neorv32_gptmr.h</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/globals_eval_h.html b/sw/globals_eval_h.html new file mode 100644 index 0000000000..82f7df6573 --- /dev/null +++ b/sw/globals_eval_h.html @@ -0,0 +1,112 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: Globals</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +</div><!-- top --> +<div id="doc-content"> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div class="contents"> +<div class="textblock">Here is a list of all documented enum values with links to the documentation:</div> + +<h3><a id="index_h" name="index_h"></a>- h -</h3><ul> +<li>HPMCNT_EVENT_BRANCH&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfea9e1e2b50352b2555e9c64e76776919a6">neorv32_cpu_csr.h</a></li> +<li>HPMCNT_EVENT_BRANCHED&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfea0f15c5a824cb1678423ac4ef72a5f4f5">neorv32_cpu_csr.h</a></li> +<li>HPMCNT_EVENT_COMPR&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfea685ed663611d988702ec59c254eb61dd">neorv32_cpu_csr.h</a></li> +<li>HPMCNT_EVENT_CY&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfea2b683572525adc02ce0910031cfea914">neorv32_cpu_csr.h</a></li> +<li>HPMCNT_EVENT_IR&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfeaab438295e5f00ffe4c2457a54ee9bfc4">neorv32_cpu_csr.h</a></li> +<li>HPMCNT_EVENT_LOAD&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfea1a06f216e1a12afa0b90d6e1218b3c91">neorv32_cpu_csr.h</a></li> +<li>HPMCNT_EVENT_STORE&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfea6a942852e3cd85616a63addb8e9d76f2">neorv32_cpu_csr.h</a></li> +<li>HPMCNT_EVENT_TM&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfea578ef6fc107c22b5cb7be5950f695640">neorv32_cpu_csr.h</a></li> +<li>HPMCNT_EVENT_TRAP&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfea3a4f5bf9251def87a71162dbcf9043c5">neorv32_cpu_csr.h</a></li> +<li>HPMCNT_EVENT_WAIT_ALU&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfeaffbb04d0053ebd079c6cacb4e5e7ed6b">neorv32_cpu_csr.h</a></li> +<li>HPMCNT_EVENT_WAIT_DIS&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfeabcb123b5b150b4413e5fd48475faab27">neorv32_cpu_csr.h</a></li> +<li>HPMCNT_EVENT_WAIT_LSU&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfea67a59934bc66bc7ccf82d24fe8a18a3b">neorv32_cpu_csr.h</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/globals_eval_n.html b/sw/globals_eval_n.html new file mode 100644 index 0000000000..278f165734 --- /dev/null +++ b/sw/globals_eval_n.html @@ -0,0 +1,130 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: Globals</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +</div><!-- top --> +<div id="doc-content"> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div class="contents"> +<div class="textblock">Here is a list of all documented enum values with links to the documentation:</div> + +<h3><a id="index_n" name="index_n"></a>- n -</h3><ul> +<li>NEOLED_CTRL_BUFS_0&#160;:&#160;<a class="el" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a3bb5d0d1f78cebccbc8620a0194f43b8">neorv32_neoled.h</a></li> +<li>NEOLED_CTRL_BUFS_1&#160;:&#160;<a class="el" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412aed0a878e73ad501bed3bbe6905974368">neorv32_neoled.h</a></li> +<li>NEOLED_CTRL_BUFS_2&#160;:&#160;<a class="el" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412ae7b9d45c4ef69ca15fa13aa107e68156">neorv32_neoled.h</a></li> +<li>NEOLED_CTRL_BUFS_3&#160;:&#160;<a class="el" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412ac1922a5311e91a74710eddbf86ccc1c1">neorv32_neoled.h</a></li> +<li>NEOLED_CTRL_EN&#160;:&#160;<a class="el" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412af97ab77b33a250d87025c3dd3a21fea7">neorv32_neoled.h</a></li> +<li>NEOLED_CTRL_IRQ_CONF&#160;:&#160;<a class="el" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a37421074b86a260b276534b7c4949339">neorv32_neoled.h</a></li> +<li>NEOLED_CTRL_MODE&#160;:&#160;<a class="el" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412abf6779cbeae87ab55efc9573932fc865">neorv32_neoled.h</a></li> +<li>NEOLED_CTRL_PRSC0&#160;:&#160;<a class="el" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a142ed3fd65e01f853666a1169f920ad0">neorv32_neoled.h</a></li> +<li>NEOLED_CTRL_PRSC1&#160;:&#160;<a class="el" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a0f4178d81ec6fe9a8b0e30230d318a91">neorv32_neoled.h</a></li> +<li>NEOLED_CTRL_PRSC2&#160;:&#160;<a class="el" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a3d8d54c05080fddb16df4176527bafa8">neorv32_neoled.h</a></li> +<li>NEOLED_CTRL_STROBE&#160;:&#160;<a class="el" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a436ad310b025bd3000af37986c193de5">neorv32_neoled.h</a></li> +<li>NEOLED_CTRL_T_ONE_H_0&#160;:&#160;<a class="el" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a770df505d47353f6c9289059c416d9c8">neorv32_neoled.h</a></li> +<li>NEOLED_CTRL_T_ONE_H_1&#160;:&#160;<a class="el" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412aea15666ad4bb9eb1eba5dc9ed96114a6">neorv32_neoled.h</a></li> +<li>NEOLED_CTRL_T_ONE_H_2&#160;:&#160;<a class="el" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a4d362af8c630823b5104401a9c7d734e">neorv32_neoled.h</a></li> +<li>NEOLED_CTRL_T_ONE_H_3&#160;:&#160;<a class="el" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a369f36e73783c2923d07ca333081a4a6">neorv32_neoled.h</a></li> +<li>NEOLED_CTRL_T_ONE_H_4&#160;:&#160;<a class="el" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a0c15850d0ab005b075f1a317646e18b1">neorv32_neoled.h</a></li> +<li>NEOLED_CTRL_T_TOT_0&#160;:&#160;<a class="el" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a44d8f064decabc690ed1f092be2b049b">neorv32_neoled.h</a></li> +<li>NEOLED_CTRL_T_TOT_1&#160;:&#160;<a class="el" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412addf4d6d1fd09f145d8aa497c4a7479c2">neorv32_neoled.h</a></li> +<li>NEOLED_CTRL_T_TOT_2&#160;:&#160;<a class="el" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a42d09d42d39fc0eb2697853c99f4d5b0">neorv32_neoled.h</a></li> +<li>NEOLED_CTRL_T_TOT_3&#160;:&#160;<a class="el" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412acbcd3c046b528e1900e86428da231df2">neorv32_neoled.h</a></li> +<li>NEOLED_CTRL_T_TOT_4&#160;:&#160;<a class="el" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a3f1a0ad71d9fd892829ec0246be343b3">neorv32_neoled.h</a></li> +<li>NEOLED_CTRL_T_ZERO_H_0&#160;:&#160;<a class="el" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a7285e332ec7c2b3aeb34290e3e60ded7">neorv32_neoled.h</a></li> +<li>NEOLED_CTRL_T_ZERO_H_1&#160;:&#160;<a class="el" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a1ef56b35c966786c42f2a2f800e30eae">neorv32_neoled.h</a></li> +<li>NEOLED_CTRL_T_ZERO_H_2&#160;:&#160;<a class="el" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a9d9411382d943c1659b6b761c462319b">neorv32_neoled.h</a></li> +<li>NEOLED_CTRL_T_ZERO_H_3&#160;:&#160;<a class="el" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412abf2ea111a4ff34b6cb4dd987c5692f5c">neorv32_neoled.h</a></li> +<li>NEOLED_CTRL_T_ZERO_H_4&#160;:&#160;<a class="el" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a0d5d01b8d30119bb86c1d079f7d5a9ad">neorv32_neoled.h</a></li> +<li>NEOLED_CTRL_TX_BUSY&#160;:&#160;<a class="el" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a55da98b018c7cc32cd1e80087ed9018e">neorv32_neoled.h</a></li> +<li>NEOLED_CTRL_TX_EMPTY&#160;:&#160;<a class="el" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a23937f0a728da197590e1d383507cb23">neorv32_neoled.h</a></li> +<li>NEOLED_CTRL_TX_FULL&#160;:&#160;<a class="el" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412acfac5269688b2a03794dc17b11f1b983">neorv32_neoled.h</a></li> +<li>NEOLED_CTRL_TX_HALF&#160;:&#160;<a class="el" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a16c09df2784cfb6fafffaeaf245f1b73">neorv32_neoled.h</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/globals_eval_o.html b/sw/globals_eval_o.html new file mode 100644 index 0000000000..8fa0f24397 --- /dev/null +++ b/sw/globals_eval_o.html @@ -0,0 +1,119 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: Globals</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +</div><!-- top --> +<div id="doc-content"> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div class="contents"> +<div class="textblock">Here is a list of all documented enum values with links to the documentation:</div> + +<h3><a id="index_o" name="index_o"></a>- o -</h3><ul> +<li>ONEWIRE_CTRL_BUSY&#160;:&#160;<a class="el" href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831aac8933755e80d72e1e9c293198d831b9">neorv32_onewire.h</a></li> +<li>ONEWIRE_CTRL_CLKDIV0&#160;:&#160;<a class="el" href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831acdfca08f34d7379aaf8505ba3425c6f5">neorv32_onewire.h</a></li> +<li>ONEWIRE_CTRL_CLKDIV1&#160;:&#160;<a class="el" href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831afa1476a5e04eb4eabf4d7a595eca2df9">neorv32_onewire.h</a></li> +<li>ONEWIRE_CTRL_CLKDIV2&#160;:&#160;<a class="el" href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831aec9f056072e1db747e74a5c695d2a1df">neorv32_onewire.h</a></li> +<li>ONEWIRE_CTRL_CLKDIV3&#160;:&#160;<a class="el" href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831ab8600bd09d74e39869259881b84ebfbf">neorv32_onewire.h</a></li> +<li>ONEWIRE_CTRL_CLKDIV4&#160;:&#160;<a class="el" href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831a32af8c86e7166e02e801727bd261c179">neorv32_onewire.h</a></li> +<li>ONEWIRE_CTRL_CLKDIV5&#160;:&#160;<a class="el" href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831a789d65fd9b0ab17bffd0d6de9d2e132a">neorv32_onewire.h</a></li> +<li>ONEWIRE_CTRL_CLKDIV6&#160;:&#160;<a class="el" href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831a27f040454bebc6218b490f7160ea2312">neorv32_onewire.h</a></li> +<li>ONEWIRE_CTRL_CLKDIV7&#160;:&#160;<a class="el" href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831a8b19096f72ef96a7597fda9be625ed40">neorv32_onewire.h</a></li> +<li>ONEWIRE_CTRL_EN&#160;:&#160;<a class="el" href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831ab87882c202f80185278c69e482f147da">neorv32_onewire.h</a></li> +<li>ONEWIRE_CTRL_PRESENCE&#160;:&#160;<a class="el" href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831a92e1ff9fa10319d64c8d2c6a6d61b37e">neorv32_onewire.h</a></li> +<li>ONEWIRE_CTRL_PRSC0&#160;:&#160;<a class="el" href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831abfed6417c3abd7ef94cd18a3b32c4393">neorv32_onewire.h</a></li> +<li>ONEWIRE_CTRL_PRSC1&#160;:&#160;<a class="el" href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831aee1e24261e263c70bf2e36dcafc9dc74">neorv32_onewire.h</a></li> +<li>ONEWIRE_CTRL_SENSE&#160;:&#160;<a class="el" href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831af992c94d0b9a7b7b92a5a23366b9a8c6">neorv32_onewire.h</a></li> +<li>ONEWIRE_CTRL_TRIG_BIT&#160;:&#160;<a class="el" href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831a7ecbccef9e77e68caf22ed2c416e1f77">neorv32_onewire.h</a></li> +<li>ONEWIRE_CTRL_TRIG_BYTE&#160;:&#160;<a class="el" href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831acfd8a56f668ca55dbbaa1714b1235dfe">neorv32_onewire.h</a></li> +<li>ONEWIRE_CTRL_TRIG_RST&#160;:&#160;<a class="el" href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831a98624ec944e0413a208cdf54bbbf4c75">neorv32_onewire.h</a></li> +<li>ONEWIRE_DATA_LSB&#160;:&#160;<a class="el" href="neorv32__onewire_8h.html#ae770490afa8662fb8577065531d51368a6ad35475e3f80a8c68ce0caa9c3754a5">neorv32_onewire.h</a></li> +<li>ONEWIRE_DATA_MSB&#160;:&#160;<a class="el" href="neorv32__onewire_8h.html#ae770490afa8662fb8577065531d51368af967429634efb019ada46bf75f373aa3">neorv32_onewire.h</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/globals_eval_p.html b/sw/globals_eval_p.html new file mode 100644 index 0000000000..a0e1241c69 --- /dev/null +++ b/sw/globals_eval_p.html @@ -0,0 +1,114 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: Globals</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +</div><!-- top --> +<div id="doc-content"> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div class="contents"> +<div class="textblock">Here is a list of all documented enum values with links to the documentation:</div> + +<h3><a id="index_p" name="index_p"></a>- p -</h3><ul> +<li>PMP_NA4&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a8f2418fb5e2175f35ee2362469ce01f5aae0e0c33b0d034cb50286239f955d892">neorv32_cpu_csr.h</a></li> +<li>PMP_NAPOT&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a8f2418fb5e2175f35ee2362469ce01f5ad555e9dfc0c00612bdea623617ff2820">neorv32_cpu_csr.h</a></li> +<li>PMP_OFF&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a8f2418fb5e2175f35ee2362469ce01f5a003ccfae4aae1dad4fd65d5d4c7737c4">neorv32_cpu_csr.h</a></li> +<li>PMP_TOR&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a8f2418fb5e2175f35ee2362469ce01f5a629a81a205abee94bad9d5bb5dfa26b1">neorv32_cpu_csr.h</a></li> +<li>PMPCFG_A_LSB&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#abc0e8daad1e9beda4d9950452cc930eaaae1e6440956ad6b7cbf6062aa50f43b1">neorv32_cpu_csr.h</a></li> +<li>PMPCFG_A_MSB&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#abc0e8daad1e9beda4d9950452cc930eaa67ad3243eeb74f86a01efbade76f21e4">neorv32_cpu_csr.h</a></li> +<li>PMPCFG_L&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#abc0e8daad1e9beda4d9950452cc930eaa59c294bc43d2117bb55e301eec683f14">neorv32_cpu_csr.h</a></li> +<li>PMPCFG_R&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#abc0e8daad1e9beda4d9950452cc930eaad3aca82a2ab57364e83f677d3d4f71a6">neorv32_cpu_csr.h</a></li> +<li>PMPCFG_W&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#abc0e8daad1e9beda4d9950452cc930eaa7689905760f917499b1151cced384d2f">neorv32_cpu_csr.h</a></li> +<li>PMPCFG_X&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#abc0e8daad1e9beda4d9950452cc930eaaec94712deafba09c0cf956c6fd68fa8d">neorv32_cpu_csr.h</a></li> +<li>PWM_CTRL_EN&#160;:&#160;<a class="el" href="neorv32__pwm_8h.html#af350f93b601a92ef56516198d1570b7dafb99fba508460086efdd495d4649c65a">neorv32_pwm.h</a></li> +<li>PWM_CTRL_PRSC0&#160;:&#160;<a class="el" href="neorv32__pwm_8h.html#af350f93b601a92ef56516198d1570b7da01ab6de6ac34be1ed68f22e17acbe274">neorv32_pwm.h</a></li> +<li>PWM_CTRL_PRSC1&#160;:&#160;<a class="el" href="neorv32__pwm_8h.html#af350f93b601a92ef56516198d1570b7daa6fca8a4eecfb99b8f0fa99e187e30bb">neorv32_pwm.h</a></li> +<li>PWM_CTRL_PRSC2&#160;:&#160;<a class="el" href="neorv32__pwm_8h.html#af350f93b601a92ef56516198d1570b7da0fd36a63fd4c37ef3bc4732518ebf13d">neorv32_pwm.h</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/globals_eval_r.html b/sw/globals_eval_r.html new file mode 100644 index 0000000000..7f8d66e010 --- /dev/null +++ b/sw/globals_eval_r.html @@ -0,0 +1,129 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: Globals</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +</div><!-- top --> +<div id="doc-content"> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div class="contents"> +<div class="textblock">Here is a list of all documented enum values with links to the documentation:</div> + +<h3><a id="index_r" name="index_r"></a>- r -</h3><ul> +<li>RTE_TRAP_BREAKPOINT&#160;:&#160;<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa463611404367b5910c42dd31c0a218a2">neorv32_rte.h</a></li> +<li>RTE_TRAP_FIRQ_0&#160;:&#160;<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aab36a403cd7b833439ce7f9a708c33922">neorv32_rte.h</a></li> +<li>RTE_TRAP_FIRQ_1&#160;:&#160;<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aab199b53a1458017fa5278e0aeecf41fd">neorv32_rte.h</a></li> +<li>RTE_TRAP_FIRQ_10&#160;:&#160;<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aadebcc4d91aea1364b1481111f1060c52">neorv32_rte.h</a></li> +<li>RTE_TRAP_FIRQ_11&#160;:&#160;<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aab49ff0110481f22da22a085d2633a0e0">neorv32_rte.h</a></li> +<li>RTE_TRAP_FIRQ_12&#160;:&#160;<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aaecea4f1d524a33d02324382357b2bcb9">neorv32_rte.h</a></li> +<li>RTE_TRAP_FIRQ_13&#160;:&#160;<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa609613cf25bb8f2d0e323089d6798220">neorv32_rte.h</a></li> +<li>RTE_TRAP_FIRQ_14&#160;:&#160;<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aaadd66d9b9c33a6869fa3c30e1e434313">neorv32_rte.h</a></li> +<li>RTE_TRAP_FIRQ_15&#160;:&#160;<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa1d18312227bfd5332ebcc1f74c979dbe">neorv32_rte.h</a></li> +<li>RTE_TRAP_FIRQ_2&#160;:&#160;<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa29ffa3108fadc78bf375773c3232c489">neorv32_rte.h</a></li> +<li>RTE_TRAP_FIRQ_3&#160;:&#160;<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa4a74188fd87ea17a594ac6fe8ddf71be">neorv32_rte.h</a></li> +<li>RTE_TRAP_FIRQ_4&#160;:&#160;<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa8b39868bf91da54f9ec492918e0c01ff">neorv32_rte.h</a></li> +<li>RTE_TRAP_FIRQ_5&#160;:&#160;<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa01f562418ddbbb6b84be168673deeea9">neorv32_rte.h</a></li> +<li>RTE_TRAP_FIRQ_6&#160;:&#160;<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aac9fb28ea8bafff182f12c29d2fad6998">neorv32_rte.h</a></li> +<li>RTE_TRAP_FIRQ_7&#160;:&#160;<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa73bb84f7b6c7528bec552ac1d3e9ccdb">neorv32_rte.h</a></li> +<li>RTE_TRAP_FIRQ_8&#160;:&#160;<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa3edbf47bd9a278e100bb808c8bb68308">neorv32_rte.h</a></li> +<li>RTE_TRAP_FIRQ_9&#160;:&#160;<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa2cd04189d91465dad2bc2a8852406b76">neorv32_rte.h</a></li> +<li>RTE_TRAP_I_ACCESS&#160;:&#160;<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa931a4f314b04233924b01e8245153be4">neorv32_rte.h</a></li> +<li>RTE_TRAP_I_ILLEGAL&#160;:&#160;<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa48f4d253b260784a1ffaaded508166e2">neorv32_rte.h</a></li> +<li>RTE_TRAP_I_MISALIGNED&#160;:&#160;<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aaf647ff8d55d021379202879627c91d81">neorv32_rte.h</a></li> +<li>RTE_TRAP_L_ACCESS&#160;:&#160;<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa97047b024b72807a0b312979c9359dab">neorv32_rte.h</a></li> +<li>RTE_TRAP_L_MISALIGNED&#160;:&#160;<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa8e2cc9a533ebbc0e1d29c3ec8afbe61f">neorv32_rte.h</a></li> +<li>RTE_TRAP_MEI&#160;:&#160;<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aad2a55d5586d33497fd21b1da8aa98fff">neorv32_rte.h</a></li> +<li>RTE_TRAP_MENV_CALL&#160;:&#160;<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aaea6027bf0354c3120fa61c8094dd7a1d">neorv32_rte.h</a></li> +<li>RTE_TRAP_MSI&#160;:&#160;<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aadddffa9acdfcce80dd68ad4b26725174">neorv32_rte.h</a></li> +<li>RTE_TRAP_MTI&#160;:&#160;<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aacf17d4b2454c43a1cb544e532d247fff">neorv32_rte.h</a></li> +<li>RTE_TRAP_S_ACCESS&#160;:&#160;<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aaa9b8334712ecad0500c7610a25741ec7">neorv32_rte.h</a></li> +<li>RTE_TRAP_S_MISALIGNED&#160;:&#160;<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa85934b3fd8b5268340f84810b3f67232">neorv32_rte.h</a></li> +<li>RTE_TRAP_UENV_CALL&#160;:&#160;<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa155f84a52bace69f81a99de59701decc">neorv32_rte.h</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/globals_eval_s.html b/sw/globals_eval_s.html new file mode 100644 index 0000000000..513ccce062 --- /dev/null +++ b/sw/globals_eval_s.html @@ -0,0 +1,179 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: Globals</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +</div><!-- top --> +<div id="doc-content"> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div class="contents"> +<div class="textblock">Here is a list of all documented enum values with links to the documentation:</div> + +<h3><a id="index_s" name="index_s"></a>- s -</h3><ul> +<li>SDI_CTRL_CS_ACTIVE&#160;:&#160;<a class="el" href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6ad288a52f2bdaa1ea6ddbadf7f32a3a63">neorv32_sdi.h</a></li> +<li>SDI_CTRL_EN&#160;:&#160;<a class="el" href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6af6016d120844c2d8d8da4fccc09f9809">neorv32_sdi.h</a></li> +<li>SDI_CTRL_FIFO_LSB&#160;:&#160;<a class="el" href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6a840c74518f55028608e2353ec6ce58c4">neorv32_sdi.h</a></li> +<li>SDI_CTRL_FIFO_MSB&#160;:&#160;<a class="el" href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6ab3b57f906bd3fc16242fa06601ce1716">neorv32_sdi.h</a></li> +<li>SDI_CTRL_IRQ_RX_AVAIL&#160;:&#160;<a class="el" href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6a2a611e339fd9ae7854931743802ff5c0">neorv32_sdi.h</a></li> +<li>SDI_CTRL_IRQ_RX_FULL&#160;:&#160;<a class="el" href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6a051d69f43c2b0f15c5e9e9252c906c9d">neorv32_sdi.h</a></li> +<li>SDI_CTRL_IRQ_RX_HALF&#160;:&#160;<a class="el" href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6af1e2abec3b3bc2ff9ecb2698d933a281">neorv32_sdi.h</a></li> +<li>SDI_CTRL_IRQ_TX_EMPTY&#160;:&#160;<a class="el" href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6a5df074faedb03cf3cc0cfa90eaccd210">neorv32_sdi.h</a></li> +<li>SDI_CTRL_IRQ_TX_NHALF&#160;:&#160;<a class="el" href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6a762237a6107ee690276c36108fa1c1ed">neorv32_sdi.h</a></li> +<li>SDI_CTRL_RX_AVAIL&#160;:&#160;<a class="el" href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6ae15186a46909f1a957269b21af6a14a0">neorv32_sdi.h</a></li> +<li>SDI_CTRL_RX_FULL&#160;:&#160;<a class="el" href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6a45ade3854c01dc1b14a80e3fea29417a">neorv32_sdi.h</a></li> +<li>SDI_CTRL_RX_HALF&#160;:&#160;<a class="el" href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6ac9381cffb4da427baf31cdbbeae5e1f4">neorv32_sdi.h</a></li> +<li>SDI_CTRL_TX_EMPTY&#160;:&#160;<a class="el" href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6aa9b89463a37e3a9c554195c2f87fb8d8">neorv32_sdi.h</a></li> +<li>SDI_CTRL_TX_FULL&#160;:&#160;<a class="el" href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6adb5c4613ce0a6178a01599cf8fd6984a">neorv32_sdi.h</a></li> +<li>SDI_CTRL_TX_NHALF&#160;:&#160;<a class="el" href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6aeac16a67f250cce5ea420790e80b8bb9">neorv32_sdi.h</a></li> +<li>SLINK_CTRL_EN&#160;:&#160;<a class="el" href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1a739187f413b7436dc4037187e4a9e86a">neorv32_slink.h</a></li> +<li>SLINK_CTRL_IRQ_RX_FULL&#160;:&#160;<a class="el" href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1ac8a688706aee72d2027e022b64664309">neorv32_slink.h</a></li> +<li>SLINK_CTRL_IRQ_RX_HALF&#160;:&#160;<a class="el" href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1afa9353cd824d1b2833930ce9e922e392">neorv32_slink.h</a></li> +<li>SLINK_CTRL_IRQ_RX_NEMPTY&#160;:&#160;<a class="el" href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1a5452eab0fe12d174ec804c4c72060854">neorv32_slink.h</a></li> +<li>SLINK_CTRL_IRQ_TX_EMPTY&#160;:&#160;<a class="el" href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1ae06ad5f627f8902e2368e0daff6cfa88">neorv32_slink.h</a></li> +<li>SLINK_CTRL_IRQ_TX_NFULL&#160;:&#160;<a class="el" href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1a8f994f256f57c006c88b9e38df3f54fa">neorv32_slink.h</a></li> +<li>SLINK_CTRL_IRQ_TX_NHALF&#160;:&#160;<a class="el" href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1a7bf757dbfb1fdaddceaed3a3887003cf">neorv32_slink.h</a></li> +<li>SLINK_CTRL_RX_CLR&#160;:&#160;<a class="el" href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1a156fa3209b2652af6b58b0fdfc6cab1b">neorv32_slink.h</a></li> +<li>SLINK_CTRL_RX_EMPTY&#160;:&#160;<a class="el" href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1ae78f82e54bd9d737bbcbc5c7af0e9d4b">neorv32_slink.h</a></li> +<li>SLINK_CTRL_RX_FIFO_LSB&#160;:&#160;<a class="el" href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1a9c68af961c1147846929ca55e9e4e88c">neorv32_slink.h</a></li> +<li>SLINK_CTRL_RX_FIFO_MSB&#160;:&#160;<a class="el" href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1a945e2b7eda65dc13ca38eb21c9c4f657">neorv32_slink.h</a></li> +<li>SLINK_CTRL_RX_FULL&#160;:&#160;<a class="el" href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1aa7521fbe691fef233c0dff4053e4493e">neorv32_slink.h</a></li> +<li>SLINK_CTRL_RX_HALF&#160;:&#160;<a class="el" href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1af695158b9cf5466d87c207f9bd0a688e">neorv32_slink.h</a></li> +<li>SLINK_CTRL_RX_LAST&#160;:&#160;<a class="el" href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1a624723683d247668ef44137393e576aa">neorv32_slink.h</a></li> +<li>SLINK_CTRL_TX_CLR&#160;:&#160;<a class="el" href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1ad366597a44d3dff7dbab4cde72bed82f">neorv32_slink.h</a></li> +<li>SLINK_CTRL_TX_EMPTY&#160;:&#160;<a class="el" href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1a308cf7829ecca32f7a3da1bd74339854">neorv32_slink.h</a></li> +<li>SLINK_CTRL_TX_FIFO_LSB&#160;:&#160;<a class="el" href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1aba613343fc17715fc1bb07729588a12d">neorv32_slink.h</a></li> +<li>SLINK_CTRL_TX_FIFO_MSB&#160;:&#160;<a class="el" href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1af27a9e6e50b169d3f5efd0a08ba4a943">neorv32_slink.h</a></li> +<li>SLINK_CTRL_TX_FULL&#160;:&#160;<a class="el" href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1af94314ed65c6a8d9c364d99d7ae960ee">neorv32_slink.h</a></li> +<li>SLINK_CTRL_TX_HALF&#160;:&#160;<a class="el" href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1a530b8b76301f36fbda134b330447de78">neorv32_slink.h</a></li> +<li>SLINK_FIFO_EMPTY&#160;:&#160;<a class="el" href="neorv32__slink_8h.html#a84f7fe82f188bd4e68f41549587822bfa9f24886f55b7f78ae8909ea8a573058c">neorv32_slink.h</a></li> +<li>SLINK_FIFO_FULL&#160;:&#160;<a class="el" href="neorv32__slink_8h.html#a84f7fe82f188bd4e68f41549587822bfa2f96e61f0e07ef4ecd40f14e69b69211">neorv32_slink.h</a></li> +<li>SLINK_FIFO_HALF&#160;:&#160;<a class="el" href="neorv32__slink_8h.html#a84f7fe82f188bd4e68f41549587822bfadc37988b8aee38e85626064b2c3704f9">neorv32_slink.h</a></li> +<li>SLINK_ROUTE_DST_LSB&#160;:&#160;<a class="el" href="neorv32__slink_8h.html#ac3e5e02fd89a357135adca6d28cd0e45a9a2311357bd87c85a5cc45f08b0d8f80">neorv32_slink.h</a></li> +<li>SLINK_ROUTE_DST_MSB&#160;:&#160;<a class="el" href="neorv32__slink_8h.html#ac3e5e02fd89a357135adca6d28cd0e45a7e8da208ecaf142107587033e2d63ec1">neorv32_slink.h</a></li> +<li>SLINK_ROUTE_SRC_LSB&#160;:&#160;<a class="el" href="neorv32__slink_8h.html#ac3e5e02fd89a357135adca6d28cd0e45a69942c3a7b7b0550634f4016e639b0c2">neorv32_slink.h</a></li> +<li>SLINK_ROUTE_SRC_MSB&#160;:&#160;<a class="el" href="neorv32__slink_8h.html#ac3e5e02fd89a357135adca6d28cd0e45a7b7b0b9bd4fe448cae97a3a21460f983">neorv32_slink.h</a></li> +<li>SPI_CS_ACTIVE&#160;:&#160;<a class="el" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba5e12c05349444d3d1defff49dec00580">neorv32_spi.h</a></li> +<li>SPI_CTRL_BUSY&#160;:&#160;<a class="el" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba7957cf1cf3997cd059ed81cba73a688c">neorv32_spi.h</a></li> +<li>SPI_CTRL_CDIV0&#160;:&#160;<a class="el" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3bae6db5cfa843a58d7c09783e7f29fa49f">neorv32_spi.h</a></li> +<li>SPI_CTRL_CDIV1&#160;:&#160;<a class="el" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba0b9ca202963b68b999f94baab50fbc48">neorv32_spi.h</a></li> +<li>SPI_CTRL_CDIV2&#160;:&#160;<a class="el" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba97aaa7a4ffcc6d17a00c4f992e517c46">neorv32_spi.h</a></li> +<li>SPI_CTRL_CDIV3&#160;:&#160;<a class="el" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba85164e4e00b5ccd34158f98f691bca29">neorv32_spi.h</a></li> +<li>SPI_CTRL_CPHA&#160;:&#160;<a class="el" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba4d787c993152a9417fcd50f76820c7b0">neorv32_spi.h</a></li> +<li>SPI_CTRL_CPOL&#160;:&#160;<a class="el" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba7661acb97cc8c6dd7f333be4f4a2d315">neorv32_spi.h</a></li> +<li>SPI_CTRL_EN&#160;:&#160;<a class="el" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba647a6357971f94b79b7672785c06a4ea">neorv32_spi.h</a></li> +<li>SPI_CTRL_FIFO_LSB&#160;:&#160;<a class="el" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba12f67abd206066651c1d62fc29fafcdb">neorv32_spi.h</a></li> +<li>SPI_CTRL_FIFO_MSB&#160;:&#160;<a class="el" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba8c0426f70974f0ab129481f2db7cf0ed">neorv32_spi.h</a></li> +<li>SPI_CTRL_HIGHSPEED&#160;:&#160;<a class="el" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3bac38b12af6b8fb6bf2fc6f6ff6baee91e">neorv32_spi.h</a></li> +<li>SPI_CTRL_IRQ_IDLE&#160;:&#160;<a class="el" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba3f80e9c6ef6445ad769038c955c171a2">neorv32_spi.h</a></li> +<li>SPI_CTRL_IRQ_RX_AVAIL&#160;:&#160;<a class="el" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba2cd2350ffc819b7198d1833b525c5ca0">neorv32_spi.h</a></li> +<li>SPI_CTRL_IRQ_TX_EMPTY&#160;:&#160;<a class="el" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3bafcdc17528f9f4521c02ec5c473b44622">neorv32_spi.h</a></li> +<li>SPI_CTRL_IRQ_TX_HALF&#160;:&#160;<a class="el" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba8c18d975418ad444255f80317448d26b">neorv32_spi.h</a></li> +<li>SPI_CTRL_PRSC0&#160;:&#160;<a class="el" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3babc927c4ea78433de697a9fe96f47248e">neorv32_spi.h</a></li> +<li>SPI_CTRL_PRSC1&#160;:&#160;<a class="el" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba49c38a34b95c034249a094fbc93e0a61">neorv32_spi.h</a></li> +<li>SPI_CTRL_PRSC2&#160;:&#160;<a class="el" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba7a5244e443e1fe4ff6b7a2176f90ae7a">neorv32_spi.h</a></li> +<li>SPI_CTRL_RX_AVAIL&#160;:&#160;<a class="el" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba115b097b76b3b99716f54a63c6ce5633">neorv32_spi.h</a></li> +<li>SPI_CTRL_TX_EMPTY&#160;:&#160;<a class="el" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba487b87333d33db0a05cd2a229225ffc6">neorv32_spi.h</a></li> +<li>SPI_CTRL_TX_FULL&#160;:&#160;<a class="el" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba96860d260b31ee4c232b6b0eb45f7905">neorv32_spi.h</a></li> +<li>SPI_CTRL_TX_NHALF&#160;:&#160;<a class="el" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba5efcaded20b93d2bffeaa4ea813f73b4">neorv32_spi.h</a></li> +<li>SPI_DATA_CMD&#160;:&#160;<a class="el" href="neorv32__spi_8h.html#aab478c23898c0b06cee53a1cbda38bf8a8b565083f989905b8335d9d22a14c4b6">neorv32_spi.h</a></li> +<li>SPI_DATA_CSEN&#160;:&#160;<a class="el" href="neorv32__spi_8h.html#aab478c23898c0b06cee53a1cbda38bf8a5673b6a3382dc5452e3cfcd4e8f3c8a2">neorv32_spi.h</a></li> +<li>SPI_DATA_LSB&#160;:&#160;<a class="el" href="neorv32__spi_8h.html#aab478c23898c0b06cee53a1cbda38bf8ae3c36a644c05cea0fccaefb9da90a1b4">neorv32_spi.h</a></li> +<li>SPI_DATA_MSB&#160;:&#160;<a class="el" href="neorv32__spi_8h.html#aab478c23898c0b06cee53a1cbda38bf8a0167ec9c252ee0228ab9d21f4acba600">neorv32_spi.h</a></li> +<li>SPI_FLASH_CMD_PAGE_PROGRAM&#160;:&#160;<a class="el" href="bootloader_8c.html#aa5e5723e4cbf83805c3b1197cd401feda31c8d698c551d081a0adeafb988ed49e">bootloader.c</a></li> +<li>SPI_FLASH_CMD_READ&#160;:&#160;<a class="el" href="bootloader_8c.html#aa5e5723e4cbf83805c3b1197cd401feda6c1994ba2cfd97e0c77dcdf8bbdfdfa6">bootloader.c</a>, <a class="el" href="demo__xip_2main_8c.html#af30de1c8d8502ad374612d308cfbd12ea6c1994ba2cfd97e0c77dcdf8bbdfdfa6">main.c</a></li> +<li>SPI_FLASH_CMD_READ_STATUS&#160;:&#160;<a class="el" href="bootloader_8c.html#aa5e5723e4cbf83805c3b1197cd401feda5fbc6551a10549b38e5ab4a76c38f214">bootloader.c</a>, <a class="el" href="demo__xip_2main_8c.html#af30de1c8d8502ad374612d308cfbd12ea5fbc6551a10549b38e5ab4a76c38f214">main.c</a></li> +<li>SPI_FLASH_CMD_SECTOR_ERASE&#160;:&#160;<a class="el" href="bootloader_8c.html#aa5e5723e4cbf83805c3b1197cd401fedacd62141d6331f66e31bd252e2a92b836">bootloader.c</a>, <a class="el" href="demo__xip_2main_8c.html#af30de1c8d8502ad374612d308cfbd12eacd62141d6331f66e31bd252e2a92b836">main.c</a></li> +<li>SPI_FLASH_CMD_WAKE&#160;:&#160;<a class="el" href="bootloader_8c.html#aa5e5723e4cbf83805c3b1197cd401feda25bf16cd42b1fd1d95e0957b5be137d2">bootloader.c</a></li> +<li>SPI_FLASH_CMD_WRITE&#160;:&#160;<a class="el" href="demo__xip_2main_8c.html#af30de1c8d8502ad374612d308cfbd12ea528cebc54176f6f4c0a8f7f16fb28ca1">main.c</a></li> +<li>SPI_FLASH_CMD_WRITE_DISABLE&#160;:&#160;<a class="el" href="bootloader_8c.html#aa5e5723e4cbf83805c3b1197cd401fedaa91d3c1d788b21fc798a5976c9f0da77">bootloader.c</a>, <a class="el" href="demo__xip_2main_8c.html#af30de1c8d8502ad374612d308cfbd12eaa91d3c1d788b21fc798a5976c9f0da77">main.c</a></li> +<li>SPI_FLASH_CMD_WRITE_ENABLE&#160;:&#160;<a class="el" href="bootloader_8c.html#aa5e5723e4cbf83805c3b1197cd401feda152e091e93778f217f8b766298351513">bootloader.c</a>, <a class="el" href="demo__xip_2main_8c.html#af30de1c8d8502ad374612d308cfbd12ea152e091e93778f217f8b766298351513">main.c</a></li> +<li>SPI_FLASH_SREG_WEL&#160;:&#160;<a class="el" href="demo__xip_2main_8c.html#adccf1bb8f1f203cb1350f7f2eb15a08ea90f3b76faed13819ee13e574d1bff0c1">main.c</a></li> +<li>SPI_FLASH_SREG_WIP&#160;:&#160;<a class="el" href="demo__xip_2main_8c.html#adccf1bb8f1f203cb1350f7f2eb15a08eac84de63bbea3989c71bcc92d1d01cfa4">main.c</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/globals_eval_t.html b/sw/globals_eval_t.html new file mode 100644 index 0000000000..f7f472f65d --- /dev/null +++ b/sw/globals_eval_t.html @@ -0,0 +1,157 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: Globals</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +</div><!-- top --> +<div id="doc-content"> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div class="contents"> +<div class="textblock">Here is a list of all documented enum values with links to the documentation:</div> + +<h3><a id="index_t" name="index_t"></a>- t -</h3><ul> +<li>TRAP_CODE_BREAKPOINT&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a2c9510cb7583a0144f96678fc217335e">neorv32_cpu_csr.h</a></li> +<li>TRAP_CODE_FIRQ_0&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a0cef77904935798d247d8396838297c1">neorv32_cpu_csr.h</a></li> +<li>TRAP_CODE_FIRQ_1&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1ae0b1049ae7f8cbfb6ff216e69ed5dae7">neorv32_cpu_csr.h</a></li> +<li>TRAP_CODE_FIRQ_10&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a4f6b9c6bba91fe04becb776ad22dcf42">neorv32_cpu_csr.h</a></li> +<li>TRAP_CODE_FIRQ_11&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a874dcc43cf8fbbf2e0614e7db9e38334">neorv32_cpu_csr.h</a></li> +<li>TRAP_CODE_FIRQ_12&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a151f01e5f284f876cafafc7427720e4c">neorv32_cpu_csr.h</a></li> +<li>TRAP_CODE_FIRQ_13&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a7c8e97297cc4dcd6d5a1de65a124f3e9">neorv32_cpu_csr.h</a></li> +<li>TRAP_CODE_FIRQ_14&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a821f813de47eb781ab7715f780da3b1e">neorv32_cpu_csr.h</a></li> +<li>TRAP_CODE_FIRQ_15&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1aa4eeafe2f6f59aff01e29461c664a110">neorv32_cpu_csr.h</a></li> +<li>TRAP_CODE_FIRQ_2&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1ad753d3e2563b4fd663430af9f3888dc7">neorv32_cpu_csr.h</a></li> +<li>TRAP_CODE_FIRQ_3&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a356f8485166529503d0fb246bd0aeeb0">neorv32_cpu_csr.h</a></li> +<li>TRAP_CODE_FIRQ_4&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1aaa8e7bb251852ef75a78be71eef0b547">neorv32_cpu_csr.h</a></li> +<li>TRAP_CODE_FIRQ_5&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a5789dfabd8ec265fa0734ddd94e98757">neorv32_cpu_csr.h</a></li> +<li>TRAP_CODE_FIRQ_6&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a809e997f55e83c6812c965655511d473">neorv32_cpu_csr.h</a></li> +<li>TRAP_CODE_FIRQ_7&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1aeab719bcce9e9551bd6da65a7ae08a26">neorv32_cpu_csr.h</a></li> +<li>TRAP_CODE_FIRQ_8&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1abfd21d1380dcacb9282e525da104d916">neorv32_cpu_csr.h</a></li> +<li>TRAP_CODE_FIRQ_9&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a350e762a599479fb2c6d23ccc5ee22b4">neorv32_cpu_csr.h</a></li> +<li>TRAP_CODE_I_ACCESS&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a6a0ebfce4e18f36aeb43d5a65445cfe1">neorv32_cpu_csr.h</a></li> +<li>TRAP_CODE_I_ILLEGAL&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1af1ad8f557f3b685b59a913611e1da173">neorv32_cpu_csr.h</a></li> +<li>TRAP_CODE_I_MISALIGNED&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a0a8010d7cc91b9557973a7a118828bee">neorv32_cpu_csr.h</a></li> +<li>TRAP_CODE_L_ACCESS&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a28448f0c670169140dc28b6794310cea">neorv32_cpu_csr.h</a></li> +<li>TRAP_CODE_L_MISALIGNED&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a69e68a954da0bb33d1624484a6777ff9">neorv32_cpu_csr.h</a></li> +<li>TRAP_CODE_MEI&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a1a412b9d8eefba7880555d34625d2cc0">neorv32_cpu_csr.h</a></li> +<li>TRAP_CODE_MENV_CALL&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a20e5a2680f2f5956bfa92852d5544eac">neorv32_cpu_csr.h</a></li> +<li>TRAP_CODE_MSI&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1ae0cebf99f36ef6be60e4a9d2c9f894b0">neorv32_cpu_csr.h</a></li> +<li>TRAP_CODE_MTI&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a187ae38819b81672c15808e63c3b46b7">neorv32_cpu_csr.h</a></li> +<li>TRAP_CODE_S_ACCESS&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a70bcfc75fe1056d93a3606f78c0cb887">neorv32_cpu_csr.h</a></li> +<li>TRAP_CODE_S_MISALIGNED&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a19708405f9f6300edf6b992c6d408a2d">neorv32_cpu_csr.h</a></li> +<li>TRAP_CODE_UENV_CALL&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1aa102472d6a264bb92e0581ccaa413e02">neorv32_cpu_csr.h</a></li> +<li>TRNG_CTRL_DATA_LSB&#160;:&#160;<a class="el" href="neorv32__trng_8h.html#a1440e1355bf5bff17760992adc156b1aa50bb6e10e245a977dcf29a7a138776c6">neorv32_trng.h</a></li> +<li>TRNG_CTRL_DATA_MSB&#160;:&#160;<a class="el" href="neorv32__trng_8h.html#a1440e1355bf5bff17760992adc156b1aa95620874acc9393a05d670824c0bbed2">neorv32_trng.h</a></li> +<li>TRNG_CTRL_EN&#160;:&#160;<a class="el" href="neorv32__trng_8h.html#a1440e1355bf5bff17760992adc156b1aa0bdf0194eefe95884c5c5853a2f7670d">neorv32_trng.h</a></li> +<li>TRNG_CTRL_FIFO_CLR&#160;:&#160;<a class="el" href="neorv32__trng_8h.html#a1440e1355bf5bff17760992adc156b1aabf1bb7bc3b44394c85709edd1c9f03ac">neorv32_trng.h</a></li> +<li>TRNG_CTRL_FIFO_LSB&#160;:&#160;<a class="el" href="neorv32__trng_8h.html#a1440e1355bf5bff17760992adc156b1aa8c0325eede4ffec4530cfd5dc700dc52">neorv32_trng.h</a></li> +<li>TRNG_CTRL_FIFO_MSB&#160;:&#160;<a class="el" href="neorv32__trng_8h.html#a1440e1355bf5bff17760992adc156b1aa919c3105723e4fe46e341c63cbf276f5">neorv32_trng.h</a></li> +<li>TRNG_CTRL_IRQ_SEL&#160;:&#160;<a class="el" href="neorv32__trng_8h.html#a1440e1355bf5bff17760992adc156b1aa968a770fe6b172183dd97818e09c63da">neorv32_trng.h</a></li> +<li>TRNG_CTRL_SIM_MODE&#160;:&#160;<a class="el" href="neorv32__trng_8h.html#a1440e1355bf5bff17760992adc156b1aaa6990058793ac7d96250693f935837c5">neorv32_trng.h</a></li> +<li>TRNG_CTRL_VALID&#160;:&#160;<a class="el" href="neorv32__trng_8h.html#a1440e1355bf5bff17760992adc156b1aa2e0079358668db409fb763eaccb93da9">neorv32_trng.h</a></li> +<li>TWI_CTRL_BUSY&#160;:&#160;<a class="el" href="neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaa443a2a65ee810f428d40a4f8474d8e6d">neorv32_twi.h</a></li> +<li>TWI_CTRL_CDIV0&#160;:&#160;<a class="el" href="neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaa75d3a61b5e642e5d5c1f699c35c26b31">neorv32_twi.h</a></li> +<li>TWI_CTRL_CDIV1&#160;:&#160;<a class="el" href="neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaa4473769463a0c7e4b58ed0b983610674">neorv32_twi.h</a></li> +<li>TWI_CTRL_CDIV2&#160;:&#160;<a class="el" href="neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaaa6db454861ad5be70846ed4f9eb2ea12">neorv32_twi.h</a></li> +<li>TWI_CTRL_CDIV3&#160;:&#160;<a class="el" href="neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaa99e2153a53cc1f9d7cc83d52c698cbcc">neorv32_twi.h</a></li> +<li>TWI_CTRL_CLKSTR&#160;:&#160;<a class="el" href="neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaac62d6e3c47a8195a6a9ccc79129bfe48">neorv32_twi.h</a></li> +<li>TWI_CTRL_EN&#160;:&#160;<a class="el" href="neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaa43381fe5ab9fe64ebdf76638eba5a694">neorv32_twi.h</a></li> +<li>TWI_CTRL_FIFO_LSB&#160;:&#160;<a class="el" href="neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaa74126d424719b1db61f5e1ab567489fb">neorv32_twi.h</a></li> +<li>TWI_CTRL_FIFO_MSB&#160;:&#160;<a class="el" href="neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaa183f5b9c3993d04cc9aea2a79e9a4f75">neorv32_twi.h</a></li> +<li>TWI_CTRL_PRSC0&#160;:&#160;<a class="el" href="neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaa9033ac6cc891bff0da52449aa4b6a8d9">neorv32_twi.h</a></li> +<li>TWI_CTRL_PRSC1&#160;:&#160;<a class="el" href="neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaa8b666cd2e40ca9ba3f9a635f0ed107df">neorv32_twi.h</a></li> +<li>TWI_CTRL_PRSC2&#160;:&#160;<a class="el" href="neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaa4d55ed983ca2f94fa9deac196d949b31">neorv32_twi.h</a></li> +<li>TWI_CTRL_RX_AVAIL&#160;:&#160;<a class="el" href="neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaad2798dfabf3a72e6138135e983734671">neorv32_twi.h</a></li> +<li>TWI_CTRL_TX_FULL&#160;:&#160;<a class="el" href="neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaaa0597dc9dea3f6f7a2f19dbcc7a2dabb">neorv32_twi.h</a></li> +<li>TWI_DCMD_ACK&#160;:&#160;<a class="el" href="neorv32__twi_8h.html#a3421852c63baca60fe58c990b1c653d8af64359afd3627db0a79733d00128f3a5">neorv32_twi.h</a></li> +<li>TWI_DCMD_CMD_HI&#160;:&#160;<a class="el" href="neorv32__twi_8h.html#a3421852c63baca60fe58c990b1c653d8accd7e8be435db3055c27f0a6d5e0201e">neorv32_twi.h</a></li> +<li>TWI_DCMD_CMD_LO&#160;:&#160;<a class="el" href="neorv32__twi_8h.html#a3421852c63baca60fe58c990b1c653d8ab2e20f7f5a5b131c31772341caa97e5e">neorv32_twi.h</a></li> +<li>TWI_DCMD_LSB&#160;:&#160;<a class="el" href="neorv32__twi_8h.html#a3421852c63baca60fe58c990b1c653d8adf6176c87655bbbb5c7cea9dea29ce56">neorv32_twi.h</a></li> +<li>TWI_DCMD_MSB&#160;:&#160;<a class="el" href="neorv32__twi_8h.html#a3421852c63baca60fe58c990b1c653d8ab7f53f7cef06031c1a34db04c602a50d">neorv32_twi.h</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/globals_eval_u.html b/sw/globals_eval_u.html new file mode 100644 index 0000000000..12fb231234 --- /dev/null +++ b/sw/globals_eval_u.html @@ -0,0 +1,137 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: Globals</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +</div><!-- top --> +<div id="doc-content"> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div class="contents"> +<div class="textblock">Here is a list of all documented enum values with links to the documentation:</div> + +<h3><a id="index_u" name="index_u"></a>- u -</h3><ul> +<li>UART_CTRL_BAUD0&#160;:&#160;<a class="el" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afcad38432e7e050276d4667daf92c1e3fd5">neorv32_uart.h</a></li> +<li>UART_CTRL_BAUD1&#160;:&#160;<a class="el" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca1e702002402897eca82bf398504bc439">neorv32_uart.h</a></li> +<li>UART_CTRL_BAUD2&#160;:&#160;<a class="el" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca36266026e11f22aca1584bd81cd38cd6">neorv32_uart.h</a></li> +<li>UART_CTRL_BAUD3&#160;:&#160;<a class="el" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca58190cd41c2ce69512bea10740d35276">neorv32_uart.h</a></li> +<li>UART_CTRL_BAUD4&#160;:&#160;<a class="el" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca81ea805f01b93a59664823b940c7a424">neorv32_uart.h</a></li> +<li>UART_CTRL_BAUD5&#160;:&#160;<a class="el" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca5da1d6007af0265fe48ace8469e07833">neorv32_uart.h</a></li> +<li>UART_CTRL_BAUD6&#160;:&#160;<a class="el" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca9ac3c1e23d684cb2f67060d6ebe1fa63">neorv32_uart.h</a></li> +<li>UART_CTRL_BAUD7&#160;:&#160;<a class="el" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca9c12648f7f058f444db434cd8a8d854e">neorv32_uart.h</a></li> +<li>UART_CTRL_BAUD8&#160;:&#160;<a class="el" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca09c311eb1f6b38500e6fcbb6ad9dd9ff">neorv32_uart.h</a></li> +<li>UART_CTRL_BAUD9&#160;:&#160;<a class="el" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca697321bddeaa2cac1ea034c418be540e">neorv32_uart.h</a></li> +<li>UART_CTRL_EN&#160;:&#160;<a class="el" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca38f6c0e5991f8f80159a388c1080f7c2">neorv32_uart.h</a></li> +<li>UART_CTRL_HWFC_EN&#160;:&#160;<a class="el" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afcacab78fcd440167c5a2c0f5d300c8f07c">neorv32_uart.h</a></li> +<li>UART_CTRL_IRQ_RX_FULL&#160;:&#160;<a class="el" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afcae5f01868b170d71a5f3064023c96a82a">neorv32_uart.h</a></li> +<li>UART_CTRL_IRQ_RX_HALF&#160;:&#160;<a class="el" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afcaa219ea3ed5b21f5023bbc5ffa5c5f175">neorv32_uart.h</a></li> +<li>UART_CTRL_IRQ_RX_NEMPTY&#160;:&#160;<a class="el" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca569ea830518914c5330fa14680b02851">neorv32_uart.h</a></li> +<li>UART_CTRL_IRQ_TX_EMPTY&#160;:&#160;<a class="el" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca15b9fca73877aad446a8cd338e228e2c">neorv32_uart.h</a></li> +<li>UART_CTRL_IRQ_TX_NHALF&#160;:&#160;<a class="el" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca726b73ef9c44ccc1a45a4230a8bda9d1">neorv32_uart.h</a></li> +<li>UART_CTRL_PRSC0&#160;:&#160;<a class="el" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca1ddbca448bb30c77c42499fff1312183">neorv32_uart.h</a></li> +<li>UART_CTRL_PRSC1&#160;:&#160;<a class="el" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca9c1d8e8763a653339210ff4e6e3067d2">neorv32_uart.h</a></li> +<li>UART_CTRL_PRSC2&#160;:&#160;<a class="el" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca8afd60e4bd3854fab623b91fa4f33f70">neorv32_uart.h</a></li> +<li>UART_CTRL_RX_CLR&#160;:&#160;<a class="el" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afcaefbef37247d88a7e38e1c53b8a33ed33">neorv32_uart.h</a></li> +<li>UART_CTRL_RX_FULL&#160;:&#160;<a class="el" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca47c44fa21e51401621c28019025c1166">neorv32_uart.h</a></li> +<li>UART_CTRL_RX_HALF&#160;:&#160;<a class="el" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca3fc934d0ce6b36e3e131c6682db22247">neorv32_uart.h</a></li> +<li>UART_CTRL_RX_NEMPTY&#160;:&#160;<a class="el" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca2015dd85e361aa0476e847953b62baff">neorv32_uart.h</a></li> +<li>UART_CTRL_RX_OVER&#160;:&#160;<a class="el" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca81a52e0b81018f2cf43e64d74caba632">neorv32_uart.h</a></li> +<li>UART_CTRL_SIM_MODE&#160;:&#160;<a class="el" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca42ed376220259ab22c6f837d08273ef1">neorv32_uart.h</a></li> +<li>UART_CTRL_TX_BUSY&#160;:&#160;<a class="el" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca0eb636d8b7961d7073c5c7341b5bbe25">neorv32_uart.h</a></li> +<li>UART_CTRL_TX_CLR&#160;:&#160;<a class="el" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca408412a32673cc7f6ea70682e3e61431">neorv32_uart.h</a></li> +<li>UART_CTRL_TX_EMPTY&#160;:&#160;<a class="el" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afcac5c044233b6c4162cf862f3d9831ef46">neorv32_uart.h</a></li> +<li>UART_CTRL_TX_FULL&#160;:&#160;<a class="el" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca36b4195e5d1f12e1fd1a0d30cad0e411">neorv32_uart.h</a></li> +<li>UART_CTRL_TX_NHALF&#160;:&#160;<a class="el" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca5b0e40ab30bdb198f496d09e89d2d0d9">neorv32_uart.h</a></li> +<li>UART_DATA_RTX_LSB&#160;:&#160;<a class="el" href="neorv32__uart_8h.html#adcf35350a9ea18a59c32c35f528643f2ae70e9f6cd69af724932e79ea7e7f7195">neorv32_uart.h</a></li> +<li>UART_DATA_RTX_MSB&#160;:&#160;<a class="el" href="neorv32__uart_8h.html#adcf35350a9ea18a59c32c35f528643f2a19926d013ca202645d38f2c704782ebb">neorv32_uart.h</a></li> +<li>UART_DATA_RX_FIFO_SIZE_LSB&#160;:&#160;<a class="el" href="neorv32__uart_8h.html#adcf35350a9ea18a59c32c35f528643f2a43b296e86d1f2ec7400d57655c3180ef">neorv32_uart.h</a></li> +<li>UART_DATA_RX_FIFO_SIZE_MSB&#160;:&#160;<a class="el" href="neorv32__uart_8h.html#adcf35350a9ea18a59c32c35f528643f2a81a82ac0dc5c8c8d7af21553288e3225">neorv32_uart.h</a></li> +<li>UART_DATA_TX_FIFO_SIZE_LSB&#160;:&#160;<a class="el" href="neorv32__uart_8h.html#adcf35350a9ea18a59c32c35f528643f2a6d718ad0bb82a5cb053c117cd2d6ca8e">neorv32_uart.h</a></li> +<li>UART_DATA_TX_FIFO_SIZE_MSB&#160;:&#160;<a class="el" href="neorv32__uart_8h.html#adcf35350a9ea18a59c32c35f528643f2ada92cbbe278e3e0592eba58c97699529">neorv32_uart.h</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/globals_eval_w.html b/sw/globals_eval_w.html new file mode 100644 index 0000000000..14d961c49f --- /dev/null +++ b/sw/globals_eval_w.html @@ -0,0 +1,112 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: Globals</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +</div><!-- top --> +<div id="doc-content"> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div class="contents"> +<div class="textblock">Here is a list of all documented enum values with links to the documentation:</div> + +<h3><a id="index_w" name="index_w"></a>- w -</h3><ul> +<li>WDT_CTRL_DBEN&#160;:&#160;<a class="el" href="neorv32__wdt_8h.html#a0a4cb24fd818277c5bb9b10ff519f23ea4b0d994fe5ff8d8004c7f25b621fb3a9">neorv32_wdt.h</a></li> +<li>WDT_CTRL_EN&#160;:&#160;<a class="el" href="neorv32__wdt_8h.html#a0a4cb24fd818277c5bb9b10ff519f23ea0e078b41b69bd6089acceb592e14553f">neorv32_wdt.h</a></li> +<li>WDT_CTRL_LOCK&#160;:&#160;<a class="el" href="neorv32__wdt_8h.html#a0a4cb24fd818277c5bb9b10ff519f23eadc44267502fceb8e7311dfa502fe54d3">neorv32_wdt.h</a></li> +<li>WDT_CTRL_RCAUSE_HI&#160;:&#160;<a class="el" href="neorv32__wdt_8h.html#a0a4cb24fd818277c5bb9b10ff519f23ea6012d63ea4734fc8a063c9edc6785abd">neorv32_wdt.h</a></li> +<li>WDT_CTRL_RCAUSE_LO&#160;:&#160;<a class="el" href="neorv32__wdt_8h.html#a0a4cb24fd818277c5bb9b10ff519f23ea0e7d3e97517f97042ce5606dd5247779">neorv32_wdt.h</a></li> +<li>WDT_CTRL_SEN&#160;:&#160;<a class="el" href="neorv32__wdt_8h.html#a0a4cb24fd818277c5bb9b10ff519f23ea7b7ea5bd390ecbb5ee0d9542ef124148">neorv32_wdt.h</a></li> +<li>WDT_CTRL_STRICT&#160;:&#160;<a class="el" href="neorv32__wdt_8h.html#a0a4cb24fd818277c5bb9b10ff519f23ea28dd25b66c4a50d0ea47a16c460031ac">neorv32_wdt.h</a></li> +<li>WDT_CTRL_TIMEOUT_LSB&#160;:&#160;<a class="el" href="neorv32__wdt_8h.html#a0a4cb24fd818277c5bb9b10ff519f23ea45df3c9100beb420add34bf71a0e8609">neorv32_wdt.h</a></li> +<li>WDT_CTRL_TIMEOUT_MSB&#160;:&#160;<a class="el" href="neorv32__wdt_8h.html#a0a4cb24fd818277c5bb9b10ff519f23ea25dea2104b29a3c20dcc3782c2d43dc7">neorv32_wdt.h</a></li> +<li>WDT_RCAUSE_EXT&#160;:&#160;<a class="el" href="neorv32__wdt_8h.html#a70098b4ee893774864536fb4100ff049ac5fc25cdc29c248b1a570b6095ddded0">neorv32_wdt.h</a></li> +<li>WDT_RCAUSE_OCD&#160;:&#160;<a class="el" href="neorv32__wdt_8h.html#a70098b4ee893774864536fb4100ff049a764a7797f17d82f619a6d30c0878bf1e">neorv32_wdt.h</a></li> +<li>WDT_RCAUSE_WDT&#160;:&#160;<a class="el" href="neorv32__wdt_8h.html#a70098b4ee893774864536fb4100ff049a974e73fb98b6a3591c214eba6071fd3c">neorv32_wdt.h</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/globals_eval_x.html b/sw/globals_eval_x.html new file mode 100644 index 0000000000..afae555f85 --- /dev/null +++ b/sw/globals_eval_x.html @@ -0,0 +1,122 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: Globals</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +</div><!-- top --> +<div id="doc-content"> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div class="contents"> +<div class="textblock">Here is a list of all documented enum values with links to the documentation:</div> + +<h3><a id="index_x" name="index_x"></a>- x -</h3><ul> +<li>XIP_CTRL_BURST_EN&#160;:&#160;<a class="el" href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba7ad9f81356d6923d524d1c9e39acdd2c">neorv32_xip.h</a></li> +<li>XIP_CTRL_CDIV0&#160;:&#160;<a class="el" href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483cebaf9b56aa629973ce4a9c8ff61a2c90ba3">neorv32_xip.h</a></li> +<li>XIP_CTRL_CDIV1&#160;:&#160;<a class="el" href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba68775854b8f2cfa2f32d2eb82a714073">neorv32_xip.h</a></li> +<li>XIP_CTRL_CDIV2&#160;:&#160;<a class="el" href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba43d7305e0e0398cb44c99e70dcd96445">neorv32_xip.h</a></li> +<li>XIP_CTRL_CDIV3&#160;:&#160;<a class="el" href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba61ffffe9acda5c622b48b6360e357eef">neorv32_xip.h</a></li> +<li>XIP_CTRL_CPHA&#160;:&#160;<a class="el" href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483cebad31736f4a159745be94b487079c4c14d">neorv32_xip.h</a></li> +<li>XIP_CTRL_CPOL&#160;:&#160;<a class="el" href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba95ae19cf5d5140df397ead62f151247f">neorv32_xip.h</a></li> +<li>XIP_CTRL_EN&#160;:&#160;<a class="el" href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba27658ce3cc81c9e258b73fb02d7f1045">neorv32_xip.h</a></li> +<li>XIP_CTRL_HIGHSPEED&#160;:&#160;<a class="el" href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483cebaaeb104a59215667aabb5a751632ae781">neorv32_xip.h</a></li> +<li>XIP_CTRL_PHY_BUSY&#160;:&#160;<a class="el" href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba76d2379d0e7ab09e7e686bc886888fa5">neorv32_xip.h</a></li> +<li>XIP_CTRL_PRSC0&#160;:&#160;<a class="el" href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba67a0c0483eaf92e9cd03e9076be5b50d">neorv32_xip.h</a></li> +<li>XIP_CTRL_PRSC1&#160;:&#160;<a class="el" href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483cebae47f2e1e8c023fd52e25a3dad5e332af">neorv32_xip.h</a></li> +<li>XIP_CTRL_PRSC2&#160;:&#160;<a class="el" href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba896815c075a91a8291585eb61b6e0086">neorv32_xip.h</a></li> +<li>XIP_CTRL_RD_CMD_LSB&#160;:&#160;<a class="el" href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba8287016f167727f147806aa11129e05b">neorv32_xip.h</a></li> +<li>XIP_CTRL_RD_CMD_MSB&#160;:&#160;<a class="el" href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba2c78cd2d32cfba4d89f7aab92f7939e7">neorv32_xip.h</a></li> +<li>XIP_CTRL_SPI_CSEN&#160;:&#160;<a class="el" href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba5aadb2c374d34b878b56a660baec2080">neorv32_xip.h</a></li> +<li>XIP_CTRL_SPI_NBYTES_LSB&#160;:&#160;<a class="el" href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba23be66e49d28dd12c5321e576d2f0c7a">neorv32_xip.h</a></li> +<li>XIP_CTRL_SPI_NBYTES_MSB&#160;:&#160;<a class="el" href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba5d13c4fe190fcd68dfcbbbe33d2e844c">neorv32_xip.h</a></li> +<li>XIP_CTRL_XIP_ABYTES_LSB&#160;:&#160;<a class="el" href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba603f9d8d22ae2a6abc61b666bc88a4df">neorv32_xip.h</a></li> +<li>XIP_CTRL_XIP_ABYTES_MSB&#160;:&#160;<a class="el" href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba5885ed5fcd2eed969bd921afe8dff4fc">neorv32_xip.h</a></li> +<li>XIP_CTRL_XIP_BUSY&#160;:&#160;<a class="el" href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba2c4a47f88d299782b8618b68fb87d59a">neorv32_xip.h</a></li> +<li>XIP_CTRL_XIP_EN&#160;:&#160;<a class="el" href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba3cbd45a66e05a4fcfc5ec810b8cee937">neorv32_xip.h</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/globals_f.html b/sw/globals_f.html new file mode 100644 index 0000000000..85800db8b6 --- /dev/null +++ b/sw/globals_f.html @@ -0,0 +1,104 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: Globals</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +</div><!-- top --> +<div id="doc-content"> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div class="contents"> +<div class="textblock">Here is a list of all documented functions, variables, defines, enums, and typedefs with links to the documentation:</div> + +<h3><a id="index_f" name="index_f"></a>- f -</h3><ul> +<li>FLASH_ABYTES&#160;:&#160;<a class="el" href="demo__xip_2main_8c.html#af9b3c37c806499fc435302f5bce6a122">main.c</a></li> +<li>FLASH_BASE&#160;:&#160;<a class="el" href="demo__xip_2main_8c.html#a23a9099a5f8fc9c6e253c0eecb2be8db">main.c</a></li> +<li>FLASH_SREG_BUSY&#160;:&#160;<a class="el" href="bootloader_8c.html#a97299f563ebc1fca4c663b025a15136fa133cd87673ce9a612da494583e03dae9">bootloader.c</a></li> +<li>FLASH_SREG_WEL&#160;:&#160;<a class="el" href="bootloader_8c.html#a97299f563ebc1fca4c663b025a15136fa22e8c983d74430ea0930e37781e88bf9">bootloader.c</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/globals_func.html b/sw/globals_func.html new file mode 100644 index 0000000000..0a300d21ee --- /dev/null +++ b/sw/globals_func.html @@ -0,0 +1,107 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: Globals</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +</div><!-- top --> +<div id="doc-content"> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div class="contents"> +<div class="textblock">Here is a list of all documented functions with links to the documentation:</div> + +<h3><a id="index__5F" name="index__5F"></a>- _ -</h3><ul> +<li>__neorv32_rte_core()&#160;:&#160;<a class="el" href="neorv32__rte_8c.html#a53f1e006f0bf61deb7ad018f35228873">neorv32_rte.c</a></li> +<li>__neorv32_rte_print_hex_word()&#160;:&#160;<a class="el" href="neorv32__rte_8c.html#a01bf6c01f5a8cda2132b9ac98824edc1">neorv32_rte.c</a></li> +<li>__neorv32_uart_itoa()&#160;:&#160;<a class="el" href="neorv32__uart_8c.html#a3543435827204d82755b0a23bdea1296">neorv32_uart.c</a></li> +<li>__neorv32_uart_tohex()&#160;:&#160;<a class="el" href="neorv32__uart_8c.html#aefa844cd170e50e088c42829029060f3">neorv32_uart.c</a></li> +<li>__neorv32_uart_touppercase()&#160;:&#160;<a class="el" href="neorv32__uart_8c.html#adf807d0476b475276b8b29924297cda9">neorv32_uart.c</a></li> +<li>__neorv32_xirq_core()&#160;:&#160;<a class="el" href="neorv32__xirq_8c.html#a14661d628dd31e6bfce89376c6614627">neorv32_xirq.c</a></li> +<li>__neorv32_xirq_dummy_handler()&#160;:&#160;<a class="el" href="neorv32__xirq_8c.html#ae4d9362b23a1341c595a4cd239a87091">neorv32_xirq.c</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/globals_func_a.html b/sw/globals_func_a.html new file mode 100644 index 0000000000..df6b27957b --- /dev/null +++ b/sw/globals_func_a.html @@ -0,0 +1,102 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: Globals</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +</div><!-- top --> +<div id="doc-content"> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div class="contents"> +<div class="textblock">Here is a list of all documented functions with links to the documentation:</div> + +<h3><a id="index_a" name="index_a"></a>- a -</h3><ul> +<li>adaptive_proportion_test()&#160;:&#160;<a class="el" href="demo__trng_2main_8c.html#a23a91e6fe2cc44f3c29baf0d331e05db">main.c</a></li> +<li>aux_print_hex_byte()&#160;:&#160;<a class="el" href="bus__explorer_2main_8c.html#ac582208281cd6fce4eb61c234f312ef6">main.c</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/globals_func_b.html b/sw/globals_func_b.html new file mode 100644 index 0000000000..42d8e22921 --- /dev/null +++ b/sw/globals_func_b.html @@ -0,0 +1,101 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: Globals</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +</div><!-- top --> +<div id="doc-content"> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div class="contents"> +<div class="textblock">Here is a list of all documented functions with links to the documentation:</div> + +<h3><a id="index_b" name="index_b"></a>- b -</h3><ul> +<li>bootloader_trap_handler()&#160;:&#160;<a class="el" href="bootloader_8c.html#af13b4b3d5e6597feacf331e6d16b08e9">bootloader.c</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/globals_func_c.html b/sw/globals_func_c.html new file mode 100644 index 0000000000..0a9d471f62 --- /dev/null +++ b/sw/globals_func_c.html @@ -0,0 +1,103 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: Globals</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +</div><!-- top --> +<div id="doc-content"> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div class="contents"> +<div class="textblock">Here is a list of all documented functions with links to the documentation:</div> + +<h3><a id="index_c" name="index_c"></a>- c -</h3><ul> +<li>check_result()&#160;:&#160;<a class="el" href="atomic__test_2main_8c.html#a4f4c6d8481b4100f90955ba5a70428a4">main.c</a></li> +<li>clear_universe()&#160;:&#160;<a class="el" href="game__of__life_2main_8c.html#a819f10c5b644a07eeb069b6e7f12050e">main.c</a></li> +<li>compute_rate()&#160;:&#160;<a class="el" href="demo__trng_2main_8c.html#abbde1237eed617466fb971a78c3acd1e">main.c</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/globals_func_d.html b/sw/globals_func_d.html new file mode 100644 index 0000000000..ca571c35b3 --- /dev/null +++ b/sw/globals_func_d.html @@ -0,0 +1,102 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: Globals</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +</div><!-- top --> +<div id="doc-content"> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div class="contents"> +<div class="textblock">Here is a list of all documented functions with links to the documentation:</div> + +<h3><a id="index_d" name="index_d"></a>- d -</h3><ul> +<li>dma_firq_handler()&#160;:&#160;<a class="el" href="demo__dma_2main_8c.html#aefcc5abb86a652587ff69be120a66487">main.c</a></li> +<li>dump_memory()&#160;:&#160;<a class="el" href="bus__explorer_2main_8c.html#a6405739c6012158151eb082c31c312da">main.c</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/globals_func_g.html b/sw/globals_func_g.html new file mode 100644 index 0000000000..85a377c276 --- /dev/null +++ b/sw/globals_func_g.html @@ -0,0 +1,109 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: Globals</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +</div><!-- top --> +<div id="doc-content"> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div class="contents"> +<div class="textblock">Here is a list of all documented functions with links to the documentation:</div> + +<h3><a id="index_g" name="index_g"></a>- g -</h3><ul> +<li>generate_histogram()&#160;:&#160;<a class="el" href="demo__trng_2main_8c.html#a4e49f5e3feb4bd5755f919cd3310b506">main.c</a></li> +<li>get_cell()&#160;:&#160;<a class="el" href="game__of__life_2main_8c.html#a6bd541a19c62ea9ec620eaad3f218d16">main.c</a></li> +<li>get_exe()&#160;:&#160;<a class="el" href="bootloader_8c.html#ac18819795adb6dbdd52b0587e7fbb569">bootloader.c</a></li> +<li>get_exe_word()&#160;:&#160;<a class="el" href="bootloader_8c.html#ac58d9f7dc79a549bde1cb50f619c19af">bootloader.c</a></li> +<li>get_neighborhood()&#160;:&#160;<a class="el" href="game__of__life_2main_8c.html#a977190adaa24a3f49fca1540b51d25a0">main.c</a></li> +<li>get_test_vector()&#160;:&#160;<a class="el" href="float__corner__test_2main_8c.html#a73c70bd0fb6d695cb113eaeb50923e3e">main.c</a></li> +<li>getchar()&#160;:&#160;<a class="el" href="neorv32__uart_8c.html#a3e29caa20f7cffe18f410f01278905a8">neorv32_uart.c</a></li> +<li>global_trap_handler()&#160;:&#160;<a class="el" href="processor__check_2main_8c.html#a9a64ce0ee69c4c32cecc8b2b2746604c">main.c</a></li> +<li>gptmr_firq_handler()&#160;:&#160;<a class="el" href="demo__gptmr_2main_8c.html#a2bd89412466a65329711bfd5c29199c9">main.c</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/globals_func_h.html b/sw/globals_func_h.html new file mode 100644 index 0000000000..619664b16c --- /dev/null +++ b/sw/globals_func_h.html @@ -0,0 +1,103 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: Globals</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +</div><!-- top --> +<div id="doc-content"> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div class="contents"> +<div class="textblock">Here is a list of all documented functions with links to the documentation:</div> + +<h3><a id="index_h" name="index_h"></a>- h -</h3><ul> +<li>hexdump()&#160;:&#160;<a class="el" href="bus__explorer_2main_8c.html#a02640a99db37b8d92b9edffc9720a210">main.c</a></li> +<li>hsv2rgb()&#160;:&#160;<a class="el" href="demo__neopixel_2main_8c.html#a2736ec755f9e10c80bf66f727f870ffc">main.c</a></li> +<li>hw_breakpoint_handler()&#160;:&#160;<a class="el" href="processor__check_2main_8c.html#a31d9e432f6a368e6222f5e0907eeb6f4">main.c</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/globals_func_m.html b/sw/globals_func_m.html new file mode 100644 index 0000000000..2dff08c275 --- /dev/null +++ b/sw/globals_func_m.html @@ -0,0 +1,102 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: Globals</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +</div><!-- top --> +<div id="doc-content"> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div class="contents"> +<div class="textblock">Here is a list of all documented functions with links to the documentation:</div> + +<h3><a id="index_m" name="index_m"></a>- m -</h3><ul> +<li>main()&#160;:&#160;<a class="el" href="bootloader_8c.html#a840291bc02cba5474a4cb46a9b9566fe">bootloader.c</a>, <a class="el" href="atomic__test_2main_8c.html#ae66f6b31b5ad750f1fe042a706a4e3d4">main.c</a></li> +<li>mtime_irq_handler()&#160;:&#160;<a class="el" href="demo__mtime_2main_8c.html#a329137855a7c2e098715a0771c5585d7">main.c</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/globals_func_n.html b/sw/globals_func_n.html new file mode 100644 index 0000000000..1501b2568c --- /dev/null +++ b/sw/globals_func_n.html @@ -0,0 +1,328 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: Globals</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +</div><!-- top --> +<div id="doc-content"> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div class="contents"> +<div class="textblock">Here is a list of all documented functions with links to the documentation:</div> + +<h3><a id="index_n" name="index_n"></a>- n -</h3><ul> +<li>neorv32_aux_date2unixtime()&#160;:&#160;<a class="el" href="neorv32__aux_8c.html#a94aa8369ba5f4ebdf5628fcb1ab2ba1c">neorv32_aux.c</a>, <a class="el" href="neorv32__aux_8h.html#a94aa8369ba5f4ebdf5628fcb1ab2ba1c">neorv32_aux.h</a></li> +<li>neorv32_aux_hexstr2uint64()&#160;:&#160;<a class="el" href="neorv32__aux_8c.html#aec4703f369e1567c22f140d2ec9daafc">neorv32_aux.c</a>, <a class="el" href="neorv32__aux_8h.html#aec4703f369e1567c22f140d2ec9daafc">neorv32_aux.h</a></li> +<li>neorv32_aux_unixtime2date()&#160;:&#160;<a class="el" href="neorv32__aux_8c.html#a885a81838a91b57797e849cb835c6887">neorv32_aux.c</a>, <a class="el" href="neorv32__aux_8h.html#a885a81838a91b57797e849cb835c6887">neorv32_aux.h</a></li> +<li>neorv32_aux_xorshift32()&#160;:&#160;<a class="el" href="neorv32__aux_8c.html#aff31dd983f75f70eeae331c65acaa50e">neorv32_aux.c</a>, <a class="el" href="neorv32__aux_8h.html#aff31dd983f75f70eeae331c65acaa50e">neorv32_aux.h</a></li> +<li>neorv32_cfs_available()&#160;:&#160;<a class="el" href="neorv32__cfs_8c.html#abac96dfaefe433eca1c0b93fa6183d2e">neorv32_cfs.c</a>, <a class="el" href="neorv32__cfs_8h.html#abac96dfaefe433eca1c0b93fa6183d2e">neorv32_cfs.h</a></li> +<li>neorv32_cpu_amoaddw()&#160;:&#160;<a class="el" href="neorv32__cpu__amo_8c.html#ada27ec89b2530f7b7f14de947cc82bf9">neorv32_cpu_amo.c</a>, <a class="el" href="neorv32__cpu__amo_8h.html#ada27ec89b2530f7b7f14de947cc82bf9">neorv32_cpu_amo.h</a></li> +<li>neorv32_cpu_amoandw()&#160;:&#160;<a class="el" href="neorv32__cpu__amo_8c.html#a9b4540dadbfd5da907117570d8006e36">neorv32_cpu_amo.c</a>, <a class="el" href="neorv32__cpu__amo_8h.html#a9b4540dadbfd5da907117570d8006e36">neorv32_cpu_amo.h</a></li> +<li>neorv32_cpu_amolr()&#160;:&#160;<a class="el" href="neorv32__cpu__amo_8h.html#ad4437bbc61a4e40d7d01dfe9459f6639">neorv32_cpu_amo.h</a></li> +<li>neorv32_cpu_amomaxuw()&#160;:&#160;<a class="el" href="neorv32__cpu__amo_8c.html#a31a6a3b5a33655f4a7b27d4c85b75f07">neorv32_cpu_amo.c</a>, <a class="el" href="neorv32__cpu__amo_8h.html#a31a6a3b5a33655f4a7b27d4c85b75f07">neorv32_cpu_amo.h</a></li> +<li>neorv32_cpu_amomaxw()&#160;:&#160;<a class="el" href="neorv32__cpu__amo_8c.html#a62cf36637d7a04079228acecfe8a5cf3">neorv32_cpu_amo.c</a>, <a class="el" href="neorv32__cpu__amo_8h.html#a62cf36637d7a04079228acecfe8a5cf3">neorv32_cpu_amo.h</a></li> +<li>neorv32_cpu_amominuw()&#160;:&#160;<a class="el" href="neorv32__cpu__amo_8c.html#a1281e18b95cd525073e1123c5d04e9e2">neorv32_cpu_amo.c</a>, <a class="el" href="neorv32__cpu__amo_8h.html#a1281e18b95cd525073e1123c5d04e9e2">neorv32_cpu_amo.h</a></li> +<li>neorv32_cpu_amominw()&#160;:&#160;<a class="el" href="neorv32__cpu__amo_8c.html#a8e383fb8825538b5579d5ce075830697">neorv32_cpu_amo.c</a>, <a class="el" href="neorv32__cpu__amo_8h.html#a8e383fb8825538b5579d5ce075830697">neorv32_cpu_amo.h</a></li> +<li>neorv32_cpu_amoorw()&#160;:&#160;<a class="el" href="neorv32__cpu__amo_8c.html#adc80b1f2b3a4e70fee44c0edb08fc402">neorv32_cpu_amo.c</a>, <a class="el" href="neorv32__cpu__amo_8h.html#adc80b1f2b3a4e70fee44c0edb08fc402">neorv32_cpu_amo.h</a></li> +<li>neorv32_cpu_amosc()&#160;:&#160;<a class="el" href="neorv32__cpu__amo_8h.html#a5e73eaa273c41a06972e862976fda53c">neorv32_cpu_amo.h</a></li> +<li>neorv32_cpu_amoswapw()&#160;:&#160;<a class="el" href="neorv32__cpu__amo_8c.html#aad0d96e61bacc3af13ff471dd44ca8e9">neorv32_cpu_amo.c</a>, <a class="el" href="neorv32__cpu__amo_8h.html#aad0d96e61bacc3af13ff471dd44ca8e9">neorv32_cpu_amo.h</a></li> +<li>neorv32_cpu_amoxorw()&#160;:&#160;<a class="el" href="neorv32__cpu__amo_8c.html#a65b67f48356fa9b30596485473311377">neorv32_cpu_amo.c</a>, <a class="el" href="neorv32__cpu__amo_8h.html#a65b67f48356fa9b30596485473311377">neorv32_cpu_amo.h</a></li> +<li>neorv32_cpu_cfu_available()&#160;:&#160;<a class="el" href="neorv32__cpu__cfu_8c.html#a13019b8afa1a80c0e5c24eb4d72e75c1">neorv32_cpu_cfu.c</a>, <a class="el" href="neorv32__cpu__cfu_8h.html#a13019b8afa1a80c0e5c24eb4d72e75c1">neorv32_cpu_cfu.h</a></li> +<li>neorv32_cpu_csr_clr()&#160;:&#160;<a class="el" href="neorv32__cpu_8h.html#ab8f533ddbc3a3af5e3bca2287ac10122">neorv32_cpu.h</a></li> +<li>neorv32_cpu_csr_read()&#160;:&#160;<a class="el" href="neorv32__cpu_8h.html#aab7a9f9cf608599f2b124dd499cb8418">neorv32_cpu.h</a></li> +<li>neorv32_cpu_csr_set()&#160;:&#160;<a class="el" href="neorv32__cpu_8h.html#a25a09de97229aac839ef6f74da604acf">neorv32_cpu.h</a></li> +<li>neorv32_cpu_csr_write()&#160;:&#160;<a class="el" href="neorv32__cpu_8h.html#afb5ef6e0b1a3e26570edfd8379490455">neorv32_cpu.h</a></li> +<li>neorv32_cpu_delay_ms()&#160;:&#160;<a class="el" href="neorv32__cpu_8c.html#aa9027535b13d9f9325e734997fc4a137">neorv32_cpu.c</a>, <a class="el" href="neorv32__cpu_8h.html#aa9027535b13d9f9325e734997fc4a137">neorv32_cpu.h</a></li> +<li>neorv32_cpu_get_clk_from_prsc()&#160;:&#160;<a class="el" href="neorv32__cpu_8c.html#a8346fb926f84f3d7bccbb4741105505f">neorv32_cpu.c</a>, <a class="el" href="neorv32__cpu_8h.html#a8346fb926f84f3d7bccbb4741105505f">neorv32_cpu.h</a></li> +<li>neorv32_cpu_get_cycle()&#160;:&#160;<a class="el" href="neorv32__cpu_8c.html#ac3fd7dc7cd1e0a08225c41820af27f92">neorv32_cpu.c</a>, <a class="el" href="neorv32__cpu_8h.html#ac3fd7dc7cd1e0a08225c41820af27f92">neorv32_cpu.h</a></li> +<li>neorv32_cpu_get_instret()&#160;:&#160;<a class="el" href="neorv32__cpu_8c.html#a387aa304770b05594c4acca128a60a75">neorv32_cpu.c</a>, <a class="el" href="neorv32__cpu_8h.html#a387aa304770b05594c4acca128a60a75">neorv32_cpu.h</a></li> +<li>neorv32_cpu_goto_user_mode()&#160;:&#160;<a class="el" href="neorv32__cpu_8c.html#aca49efb45d3808ad76cf65ba291f546d">neorv32_cpu.c</a>, <a class="el" href="neorv32__cpu_8h.html#aca49efb45d3808ad76cf65ba291f546d">neorv32_cpu.h</a></li> +<li>neorv32_cpu_hpm_get_num_counters()&#160;:&#160;<a class="el" href="neorv32__cpu_8c.html#a70f49b80322aa457f29f7671f94a183d">neorv32_cpu.c</a>, <a class="el" href="neorv32__cpu_8h.html#a70f49b80322aa457f29f7671f94a183d">neorv32_cpu.h</a></li> +<li>neorv32_cpu_hpm_get_size()&#160;:&#160;<a class="el" href="neorv32__cpu_8c.html#adb3ae542bbb0ddf9f562a4e42bc24d10">neorv32_cpu.c</a>, <a class="el" href="neorv32__cpu_8h.html#adb3ae542bbb0ddf9f562a4e42bc24d10">neorv32_cpu.h</a></li> +<li>neorv32_cpu_load_signed_byte()&#160;:&#160;<a class="el" href="neorv32__cpu_8h.html#a31f903596ab1bcddea79fdf608eaa666">neorv32_cpu.h</a></li> +<li>neorv32_cpu_load_signed_half()&#160;:&#160;<a class="el" href="neorv32__cpu_8h.html#ae9c8b6c681536ddea3aff0e63f30ef70">neorv32_cpu.h</a></li> +<li>neorv32_cpu_load_unsigned_byte()&#160;:&#160;<a class="el" href="neorv32__cpu_8h.html#ac54ec9b59e17c7cd9b9907abee82ce95">neorv32_cpu.h</a></li> +<li>neorv32_cpu_load_unsigned_half()&#160;:&#160;<a class="el" href="neorv32__cpu_8h.html#a32544cd652debb4affb308806a115d5b">neorv32_cpu.h</a></li> +<li>neorv32_cpu_load_unsigned_word()&#160;:&#160;<a class="el" href="neorv32__cpu_8h.html#a3b6cf445e2136486564ef3d3473c91dd">neorv32_cpu.h</a></li> +<li>neorv32_cpu_pmp_configure_region()&#160;:&#160;<a class="el" href="neorv32__cpu_8c.html#aa458a700619b2f7666cfcffe02ec2e2c">neorv32_cpu.c</a>, <a class="el" href="neorv32__cpu_8h.html#aa458a700619b2f7666cfcffe02ec2e2c">neorv32_cpu.h</a></li> +<li>neorv32_cpu_pmp_get_granularity()&#160;:&#160;<a class="el" href="neorv32__cpu_8c.html#ad4f8160f4821b6691e9682ef60c7cd7b">neorv32_cpu.c</a>, <a class="el" href="neorv32__cpu_8h.html#ad4f8160f4821b6691e9682ef60c7cd7b">neorv32_cpu.h</a></li> +<li>neorv32_cpu_pmp_get_num_regions()&#160;:&#160;<a class="el" href="neorv32__cpu_8c.html#a27dd614bc270dfa30ed73323ebda2d2d">neorv32_cpu.c</a>, <a class="el" href="neorv32__cpu_8h.html#a27dd614bc270dfa30ed73323ebda2d2d">neorv32_cpu.h</a></li> +<li>neorv32_cpu_set_mcycle()&#160;:&#160;<a class="el" href="neorv32__cpu_8c.html#a232d0290c459dc790d989fcdc4d121bf">neorv32_cpu.c</a>, <a class="el" href="neorv32__cpu_8h.html#a232d0290c459dc790d989fcdc4d121bf">neorv32_cpu.h</a></li> +<li>neorv32_cpu_set_minstret()&#160;:&#160;<a class="el" href="neorv32__cpu_8c.html#a5c3cf52498abb3cf3c14a724b287ecf0">neorv32_cpu.c</a>, <a class="el" href="neorv32__cpu_8h.html#a5c3cf52498abb3cf3c14a724b287ecf0">neorv32_cpu.h</a></li> +<li>neorv32_cpu_sleep()&#160;:&#160;<a class="el" href="neorv32__cpu_8h.html#a769ca4556213619f6fea4ff6bfb979dd">neorv32_cpu.h</a></li> +<li>neorv32_cpu_store_unsigned_byte()&#160;:&#160;<a class="el" href="neorv32__cpu_8h.html#aeec8ad2a82885c40a307346f9003483e">neorv32_cpu.h</a></li> +<li>neorv32_cpu_store_unsigned_half()&#160;:&#160;<a class="el" href="neorv32__cpu_8h.html#a31f30f6d6542758cd3073a9939b07653">neorv32_cpu.h</a></li> +<li>neorv32_cpu_store_unsigned_word()&#160;:&#160;<a class="el" href="neorv32__cpu_8h.html#a173bb06b4ae9c8964469068dafcb7b0e">neorv32_cpu.h</a></li> +<li>neorv32_crc_available()&#160;:&#160;<a class="el" href="neorv32__crc_8c.html#aa46c647317752f8bb6d5836d4876a704">neorv32_crc.c</a>, <a class="el" href="neorv32__crc_8h.html#aa46c647317752f8bb6d5836d4876a704">neorv32_crc.h</a></li> +<li>neorv32_crc_block()&#160;:&#160;<a class="el" href="neorv32__crc_8c.html#a9243006e6cc94c03450646d26a7289b2">neorv32_crc.c</a>, <a class="el" href="neorv32__crc_8h.html#a9243006e6cc94c03450646d26a7289b2">neorv32_crc.h</a></li> +<li>neorv32_crc_get()&#160;:&#160;<a class="el" href="neorv32__crc_8c.html#a444b88f1536f65acc301fb19eddcf227">neorv32_crc.c</a>, <a class="el" href="neorv32__crc_8h.html#a444b88f1536f65acc301fb19eddcf227">neorv32_crc.h</a></li> +<li>neorv32_crc_setup()&#160;:&#160;<a class="el" href="neorv32__crc_8c.html#a4ff5f7b91e9f668535ed33b6382ae623">neorv32_crc.c</a>, <a class="el" href="neorv32__crc_8h.html#a4ff5f7b91e9f668535ed33b6382ae623">neorv32_crc.h</a></li> +<li>neorv32_crc_single()&#160;:&#160;<a class="el" href="neorv32__crc_8c.html#ad9d50c76a485160667d486bce32cbeb8">neorv32_crc.c</a>, <a class="el" href="neorv32__crc_8h.html#ad9d50c76a485160667d486bce32cbeb8">neorv32_crc.h</a></li> +<li>neorv32_dma_available()&#160;:&#160;<a class="el" href="neorv32__dma_8h.html#a13260c3252f0375d8982590d270d7dfd">neorv32_dma.h</a></li> +<li>neorv32_dma_disable()&#160;:&#160;<a class="el" href="neorv32__dma_8h.html#a6df244028455cf7f8d4cf1520c4670a7">neorv32_dma.h</a></li> +<li>neorv32_dma_done()&#160;:&#160;<a class="el" href="neorv32__dma_8h.html#afc8cc32f7d80d0f5ab33b2f1ecf77956">neorv32_dma.h</a></li> +<li>neorv32_dma_enable()&#160;:&#160;<a class="el" href="neorv32__dma_8h.html#ac3b72447e8a132faf26577ac714b8284">neorv32_dma.h</a></li> +<li>neorv32_dma_fence_disable()&#160;:&#160;<a class="el" href="neorv32__dma_8h.html#a8f37adfa07050b0a1cb8430c9ce1fcc2">neorv32_dma.h</a></li> +<li>neorv32_dma_fence_enable()&#160;:&#160;<a class="el" href="neorv32__dma_8h.html#a2c7257567ccdb7a986f5ef7c74d3917c">neorv32_dma.h</a></li> +<li>neorv32_dma_status()&#160;:&#160;<a class="el" href="neorv32__dma_8h.html#aa116f9714174abbe8a3583e441fee24b">neorv32_dma.h</a></li> +<li>neorv32_dma_transfer()&#160;:&#160;<a class="el" href="neorv32__dma_8h.html#a2ce0d31e04604b2523135d52a877febf">neorv32_dma.h</a></li> +<li>neorv32_dma_transfer_auto()&#160;:&#160;<a class="el" href="neorv32__dma_8h.html#a6ebd1595ee6fa0e6cbfbd1ce7476f18e">neorv32_dma.h</a></li> +<li>neorv32_gpio_available()&#160;:&#160;<a class="el" href="neorv32__gpio_8c.html#a41d39a41ba5879eb85d3ed4481fcff81">neorv32_gpio.c</a>, <a class="el" href="neorv32__gpio_8h.html#a41d39a41ba5879eb85d3ed4481fcff81">neorv32_gpio.h</a></li> +<li>neorv32_gpio_pin_get()&#160;:&#160;<a class="el" href="neorv32__gpio_8c.html#afa3ee54aca47ff35f706b627ac66e95a">neorv32_gpio.c</a>, <a class="el" href="neorv32__gpio_8h.html#afa3ee54aca47ff35f706b627ac66e95a">neorv32_gpio.h</a></li> +<li>neorv32_gpio_pin_set()&#160;:&#160;<a class="el" href="neorv32__gpio_8c.html#a60fd0830d634f0c1f784d815384665cb">neorv32_gpio.c</a>, <a class="el" href="neorv32__gpio_8h.html#a60fd0830d634f0c1f784d815384665cb">neorv32_gpio.h</a></li> +<li>neorv32_gpio_pin_toggle()&#160;:&#160;<a class="el" href="neorv32__gpio_8c.html#a1958850fc1689eae9ddfcaa4a7513400">neorv32_gpio.c</a>, <a class="el" href="neorv32__gpio_8h.html#a1958850fc1689eae9ddfcaa4a7513400">neorv32_gpio.h</a></li> +<li>neorv32_gpio_port_get()&#160;:&#160;<a class="el" href="neorv32__gpio_8c.html#ac42379f2fb5ca0bb63850d7957852b84">neorv32_gpio.c</a>, <a class="el" href="neorv32__gpio_8h.html#ac42379f2fb5ca0bb63850d7957852b84">neorv32_gpio.h</a></li> +<li>neorv32_gpio_port_set()&#160;:&#160;<a class="el" href="neorv32__gpio_8c.html#a8dc7846945e4609fc96d81caee99ac00">neorv32_gpio.c</a>, <a class="el" href="neorv32__gpio_8h.html#a789222709485cd8467aad5eddf69d2df">neorv32_gpio.h</a></li> +<li>neorv32_gpio_port_toggle()&#160;:&#160;<a class="el" href="neorv32__gpio_8c.html#a210529f789779387d3f014e6253e803f">neorv32_gpio.c</a>, <a class="el" href="neorv32__gpio_8h.html#a210529f789779387d3f014e6253e803f">neorv32_gpio.h</a></li> +<li>neorv32_gptmr_available()&#160;:&#160;<a class="el" href="neorv32__gptmr_8c.html#ae79a08c52ad3e83f9c4393acfabf035f">neorv32_gptmr.c</a>, <a class="el" href="neorv32__gptmr_8h.html#ae79a08c52ad3e83f9c4393acfabf035f">neorv32_gptmr.h</a></li> +<li>neorv32_gptmr_disable()&#160;:&#160;<a class="el" href="neorv32__gptmr_8c.html#a7c9bc6d28ad12611b08fa2867c2db874">neorv32_gptmr.c</a>, <a class="el" href="neorv32__gptmr_8h.html#a7c9bc6d28ad12611b08fa2867c2db874">neorv32_gptmr.h</a></li> +<li>neorv32_gptmr_enable()&#160;:&#160;<a class="el" href="neorv32__gptmr_8c.html#a59e684348835772a7e83446e478d4a13">neorv32_gptmr.c</a>, <a class="el" href="neorv32__gptmr_8h.html#a59e684348835772a7e83446e478d4a13">neorv32_gptmr.h</a></li> +<li>neorv32_gptmr_irq_ack()&#160;:&#160;<a class="el" href="neorv32__gptmr_8c.html#ac73aa4e41a064abb4ca554a389888e67">neorv32_gptmr.c</a>, <a class="el" href="neorv32__gptmr_8h.html#ac73aa4e41a064abb4ca554a389888e67">neorv32_gptmr.h</a></li> +<li>neorv32_gptmr_setup()&#160;:&#160;<a class="el" href="neorv32__gptmr_8c.html#a6aa27efd2163eebf8fc49fe1c591708f">neorv32_gptmr.c</a>, <a class="el" href="neorv32__gptmr_8h.html#a6aa27efd2163eebf8fc49fe1c591708f">neorv32_gptmr.h</a></li> +<li>neorv32_mtime_available()&#160;:&#160;<a class="el" href="neorv32__mtime_8c.html#ab2b49a0594c66692aedf76ff9935581c">neorv32_mtime.c</a>, <a class="el" href="neorv32__mtime_8h.html#ab2b49a0594c66692aedf76ff9935581c">neorv32_mtime.h</a></li> +<li>neorv32_mtime_get_time()&#160;:&#160;<a class="el" href="neorv32__mtime_8c.html#adedbbdeb71c06d2d60d3af73451de01e">neorv32_mtime.c</a>, <a class="el" href="neorv32__mtime_8h.html#adedbbdeb71c06d2d60d3af73451de01e">neorv32_mtime.h</a></li> +<li>neorv32_mtime_get_timecmp()&#160;:&#160;<a class="el" href="neorv32__mtime_8c.html#acb3cc18ff8421ebd6ef471e089c23491">neorv32_mtime.c</a>, <a class="el" href="neorv32__mtime_8h.html#acb3cc18ff8421ebd6ef471e089c23491">neorv32_mtime.h</a></li> +<li>neorv32_mtime_get_unixtime()&#160;:&#160;<a class="el" href="neorv32__mtime_8c.html#a50d08fcc3d91fc2d88b9a6a80c656f1a">neorv32_mtime.c</a>, <a class="el" href="neorv32__mtime_8h.html#a50d08fcc3d91fc2d88b9a6a80c656f1a">neorv32_mtime.h</a></li> +<li>neorv32_mtime_set_time()&#160;:&#160;<a class="el" href="neorv32__mtime_8c.html#a1c30809d6e887f022a7794f720243015">neorv32_mtime.c</a>, <a class="el" href="neorv32__mtime_8h.html#a1c30809d6e887f022a7794f720243015">neorv32_mtime.h</a></li> +<li>neorv32_mtime_set_timecmp()&#160;:&#160;<a class="el" href="neorv32__mtime_8c.html#a81ff371c1aa10901264873316ee84a49">neorv32_mtime.c</a>, <a class="el" href="neorv32__mtime_8h.html#a81ff371c1aa10901264873316ee84a49">neorv32_mtime.h</a></li> +<li>neorv32_mtime_set_unixtime()&#160;:&#160;<a class="el" href="neorv32__mtime_8c.html#a022c3292c6e75095bb3ffd4c42fd4bfa">neorv32_mtime.c</a>, <a class="el" href="neorv32__mtime_8h.html#a022c3292c6e75095bb3ffd4c42fd4bfa">neorv32_mtime.h</a></li> +<li>neorv32_neoled_available()&#160;:&#160;<a class="el" href="neorv32__neoled_8c.html#a57398d92fb4fc735b33e89271726e1d6">neorv32_neoled.c</a>, <a class="el" href="neorv32__neoled_8h.html#a57398d92fb4fc735b33e89271726e1d6">neorv32_neoled.h</a></li> +<li>neorv32_neoled_disable()&#160;:&#160;<a class="el" href="neorv32__neoled_8c.html#a8daaa97a85e0eb94d4a38eb2119ea183">neorv32_neoled.c</a>, <a class="el" href="neorv32__neoled_8h.html#a8daaa97a85e0eb94d4a38eb2119ea183">neorv32_neoled.h</a></li> +<li>neorv32_neoled_enable()&#160;:&#160;<a class="el" href="neorv32__neoled_8c.html#a8181d5c1d15b7b5eecdc018341ac14fa">neorv32_neoled.c</a>, <a class="el" href="neorv32__neoled_8h.html#a8181d5c1d15b7b5eecdc018341ac14fa">neorv32_neoled.h</a></li> +<li>neorv32_neoled_get_buffer_size()&#160;:&#160;<a class="el" href="neorv32__neoled_8c.html#a81c2c49198531fb6551eb288e29c084e">neorv32_neoled.c</a>, <a class="el" href="neorv32__neoled_8h.html#a81c2c49198531fb6551eb288e29c084e">neorv32_neoled.h</a></li> +<li>neorv32_neoled_set_mode()&#160;:&#160;<a class="el" href="neorv32__neoled_8c.html#a484fcc6797b6d9cef86192e9593ec33d">neorv32_neoled.c</a>, <a class="el" href="neorv32__neoled_8h.html#a484fcc6797b6d9cef86192e9593ec33d">neorv32_neoled.h</a></li> +<li>neorv32_neoled_setup()&#160;:&#160;<a class="el" href="neorv32__neoled_8c.html#ac6e94602453779a2791bd0734465f5a3">neorv32_neoled.c</a>, <a class="el" href="neorv32__neoled_8h.html#ac6e94602453779a2791bd0734465f5a3">neorv32_neoled.h</a></li> +<li>neorv32_neoled_setup_ws2812()&#160;:&#160;<a class="el" href="neorv32__neoled_8c.html#adade69c7368c28180b9992d5f0ab6031">neorv32_neoled.c</a>, <a class="el" href="neorv32__neoled_8h.html#adade69c7368c28180b9992d5f0ab6031">neorv32_neoled.h</a></li> +<li>neorv32_neoled_strobe_blocking()&#160;:&#160;<a class="el" href="neorv32__neoled_8c.html#a5aa9eb4dd3655fa08e1b61eb0f36589c">neorv32_neoled.c</a>, <a class="el" href="neorv32__neoled_8h.html#a5aa9eb4dd3655fa08e1b61eb0f36589c">neorv32_neoled.h</a></li> +<li>neorv32_neoled_strobe_nonblocking()&#160;:&#160;<a class="el" href="neorv32__neoled_8c.html#abf7882b949373df0774fc9cc20c2bd2e">neorv32_neoled.c</a>, <a class="el" href="neorv32__neoled_8h.html#abf7882b949373df0774fc9cc20c2bd2e">neorv32_neoled.h</a></li> +<li>neorv32_neoled_write_blocking()&#160;:&#160;<a class="el" href="neorv32__neoled_8c.html#a3ee5b3602da3ae982628e2802587e451">neorv32_neoled.c</a>, <a class="el" href="neorv32__neoled_8h.html#a3ee5b3602da3ae982628e2802587e451">neorv32_neoled.h</a></li> +<li>neorv32_neoled_write_nonblocking()&#160;:&#160;<a class="el" href="neorv32__neoled_8h.html#ad2a318bd59be12de34797ced0f7743c6">neorv32_neoled.h</a></li> +<li>neorv32_onewire_available()&#160;:&#160;<a class="el" href="neorv32__onewire_8c.html#a865e5c381fd3c27c6981a589a5124d1e">neorv32_onewire.c</a>, <a class="el" href="neorv32__onewire_8h.html#a865e5c381fd3c27c6981a589a5124d1e">neorv32_onewire.h</a></li> +<li>neorv32_onewire_busy()&#160;:&#160;<a class="el" href="neorv32__onewire_8c.html#a01b6236b89c045ddbd58398361c6ee0a">neorv32_onewire.c</a>, <a class="el" href="neorv32__onewire_8h.html#a01b6236b89c045ddbd58398361c6ee0a">neorv32_onewire.h</a></li> +<li>neorv32_onewire_disable()&#160;:&#160;<a class="el" href="neorv32__onewire_8c.html#a7e329eeb1cd98301a53b271a6a102385">neorv32_onewire.c</a>, <a class="el" href="neorv32__onewire_8h.html#a7e329eeb1cd98301a53b271a6a102385">neorv32_onewire.h</a></li> +<li>neorv32_onewire_enable()&#160;:&#160;<a class="el" href="neorv32__onewire_8c.html#ae6fe766e7decf18869cfb86bba741ca4">neorv32_onewire.c</a>, <a class="el" href="neorv32__onewire_8h.html#ae6fe766e7decf18869cfb86bba741ca4">neorv32_onewire.h</a></li> +<li>neorv32_onewire_read_bit()&#160;:&#160;<a class="el" href="neorv32__onewire_8c.html#aace8398062b759256a516e6245aced83">neorv32_onewire.c</a>, <a class="el" href="neorv32__onewire_8h.html#aace8398062b759256a516e6245aced83">neorv32_onewire.h</a></li> +<li>neorv32_onewire_read_bit_blocking()&#160;:&#160;<a class="el" href="neorv32__onewire_8c.html#ace8b7cf697b068b6b51676d84dec5960">neorv32_onewire.c</a>, <a class="el" href="neorv32__onewire_8h.html#ace8b7cf697b068b6b51676d84dec5960">neorv32_onewire.h</a></li> +<li>neorv32_onewire_read_bit_get()&#160;:&#160;<a class="el" href="neorv32__onewire_8c.html#aa4a19d2d8dc3b3401307615aec201190">neorv32_onewire.c</a>, <a class="el" href="neorv32__onewire_8h.html#aa4a19d2d8dc3b3401307615aec201190">neorv32_onewire.h</a></li> +<li>neorv32_onewire_read_byte()&#160;:&#160;<a class="el" href="neorv32__onewire_8c.html#a01ddba7a9148be542b5c52e39e6f46d6">neorv32_onewire.c</a>, <a class="el" href="neorv32__onewire_8h.html#a01ddba7a9148be542b5c52e39e6f46d6">neorv32_onewire.h</a></li> +<li>neorv32_onewire_read_byte_blocking()&#160;:&#160;<a class="el" href="neorv32__onewire_8c.html#a7510e65a26aeefb40e994fd00667537e">neorv32_onewire.c</a>, <a class="el" href="neorv32__onewire_8h.html#a7510e65a26aeefb40e994fd00667537e">neorv32_onewire.h</a></li> +<li>neorv32_onewire_read_byte_get()&#160;:&#160;<a class="el" href="neorv32__onewire_8c.html#a4c7eec15c095c97c939163f631f51dab">neorv32_onewire.c</a>, <a class="el" href="neorv32__onewire_8h.html#a4c7eec15c095c97c939163f631f51dab">neorv32_onewire.h</a></li> +<li>neorv32_onewire_reset()&#160;:&#160;<a class="el" href="neorv32__onewire_8c.html#a3072f7167831edc95dee44ecfef6a0d4">neorv32_onewire.c</a>, <a class="el" href="neorv32__onewire_8h.html#a3072f7167831edc95dee44ecfef6a0d4">neorv32_onewire.h</a></li> +<li>neorv32_onewire_reset_blocking()&#160;:&#160;<a class="el" href="neorv32__onewire_8c.html#af8ca6be495176797b7da3857e2f794f9">neorv32_onewire.c</a>, <a class="el" href="neorv32__onewire_8h.html#af8ca6be495176797b7da3857e2f794f9">neorv32_onewire.h</a></li> +<li>neorv32_onewire_reset_get_presence()&#160;:&#160;<a class="el" href="neorv32__onewire_8c.html#a43eb8a08eeaa83e3d7e9aa5058a4269f">neorv32_onewire.c</a>, <a class="el" href="neorv32__onewire_8h.html#a43eb8a08eeaa83e3d7e9aa5058a4269f">neorv32_onewire.h</a></li> +<li>neorv32_onewire_sense()&#160;:&#160;<a class="el" href="neorv32__onewire_8c.html#a122531c7154126858c46d89e003d838d">neorv32_onewire.c</a>, <a class="el" href="neorv32__onewire_8h.html#a122531c7154126858c46d89e003d838d">neorv32_onewire.h</a></li> +<li>neorv32_onewire_setup()&#160;:&#160;<a class="el" href="neorv32__onewire_8c.html#a224005037387484dfa510a1355a62828">neorv32_onewire.c</a>, <a class="el" href="neorv32__onewire_8h.html#a224005037387484dfa510a1355a62828">neorv32_onewire.h</a></li> +<li>neorv32_onewire_write_bit()&#160;:&#160;<a class="el" href="neorv32__onewire_8c.html#a49d0a2a386f129fd2f4fed880bba31d4">neorv32_onewire.c</a>, <a class="el" href="neorv32__onewire_8h.html#a49d0a2a386f129fd2f4fed880bba31d4">neorv32_onewire.h</a></li> +<li>neorv32_onewire_write_bit_blocking()&#160;:&#160;<a class="el" href="neorv32__onewire_8c.html#a6f7b6690a2437e0b574a8a9a23dc0eaa">neorv32_onewire.c</a>, <a class="el" href="neorv32__onewire_8h.html#a6f7b6690a2437e0b574a8a9a23dc0eaa">neorv32_onewire.h</a></li> +<li>neorv32_onewire_write_byte()&#160;:&#160;<a class="el" href="neorv32__onewire_8c.html#a23b96b68c3214b188525eb102cafb620">neorv32_onewire.c</a>, <a class="el" href="neorv32__onewire_8h.html#a23b96b68c3214b188525eb102cafb620">neorv32_onewire.h</a></li> +<li>neorv32_onewire_write_byte_blocking()&#160;:&#160;<a class="el" href="neorv32__onewire_8c.html#ac78557c77482b59394677f42fda4fdf1">neorv32_onewire.c</a>, <a class="el" href="neorv32__onewire_8h.html#ac78557c77482b59394677f42fda4fdf1">neorv32_onewire.h</a></li> +<li>neorv32_pmw_get_num_channels()&#160;:&#160;<a class="el" href="neorv32__pwm_8c.html#a43d8a47dc79ebac24c8a7d2d8247d2a5">neorv32_pwm.c</a>, <a class="el" href="neorv32__pwm_8h.html#a43d8a47dc79ebac24c8a7d2d8247d2a5">neorv32_pwm.h</a></li> +<li>neorv32_pwm_available()&#160;:&#160;<a class="el" href="neorv32__pwm_8c.html#afb12c860b2f7fa6cd1e069ea540da41c">neorv32_pwm.c</a>, <a class="el" href="neorv32__pwm_8h.html#afb12c860b2f7fa6cd1e069ea540da41c">neorv32_pwm.h</a></li> +<li>neorv32_pwm_disable()&#160;:&#160;<a class="el" href="neorv32__pwm_8c.html#a8f16fdc6e048899305a3234f42fe272f">neorv32_pwm.c</a>, <a class="el" href="neorv32__pwm_8h.html#a8f16fdc6e048899305a3234f42fe272f">neorv32_pwm.h</a></li> +<li>neorv32_pwm_enable()&#160;:&#160;<a class="el" href="neorv32__pwm_8c.html#abc62a63dc139b185cdf53d0267501288">neorv32_pwm.c</a>, <a class="el" href="neorv32__pwm_8h.html#abc62a63dc139b185cdf53d0267501288">neorv32_pwm.h</a></li> +<li>neorv32_pwm_get()&#160;:&#160;<a class="el" href="neorv32__pwm_8c.html#a64f66ae4f9689a650a70f3c5b45802b6">neorv32_pwm.c</a>, <a class="el" href="neorv32__pwm_8h.html#a64f66ae4f9689a650a70f3c5b45802b6">neorv32_pwm.h</a></li> +<li>neorv32_pwm_set()&#160;:&#160;<a class="el" href="neorv32__pwm_8c.html#aa24bc867effa7756bfbe7818d85aface">neorv32_pwm.c</a>, <a class="el" href="neorv32__pwm_8h.html#aa24bc867effa7756bfbe7818d85aface">neorv32_pwm.h</a></li> +<li>neorv32_pwm_setup()&#160;:&#160;<a class="el" href="neorv32__pwm_8c.html#a5502d483de07d2d8c42e2388ed987069">neorv32_pwm.c</a>, <a class="el" href="neorv32__pwm_8h.html#a5502d483de07d2d8c42e2388ed987069">neorv32_pwm.h</a></li> +<li>neorv32_rte_context_get()&#160;:&#160;<a class="el" href="neorv32__rte_8c.html#a65e71acc8916b42b59dc2cf6bba30ba3">neorv32_rte.c</a>, <a class="el" href="neorv32__rte_8h.html#a65e71acc8916b42b59dc2cf6bba30ba3">neorv32_rte.h</a></li> +<li>neorv32_rte_context_put()&#160;:&#160;<a class="el" href="neorv32__rte_8c.html#ae13a9c1fd59ad71afb0d47cf9a0b303e">neorv32_rte.c</a>, <a class="el" href="neorv32__rte_8h.html#ae13a9c1fd59ad71afb0d47cf9a0b303e">neorv32_rte.h</a></li> +<li>neorv32_rte_debug_handler()&#160;:&#160;<a class="el" href="neorv32__rte_8c.html#a65422bb44f1e7bc011e9bfc5d8451ebe">neorv32_rte.c</a>, <a class="el" href="neorv32__rte_8h.html#a65422bb44f1e7bc011e9bfc5d8451ebe">neorv32_rte.h</a></li> +<li>neorv32_rte_handler_install()&#160;:&#160;<a class="el" href="neorv32__rte_8c.html#a2cf31cfa569a03a20d554b6400c4c5e2">neorv32_rte.c</a>, <a class="el" href="neorv32__rte_8h.html#a2cf31cfa569a03a20d554b6400c4c5e2">neorv32_rte.h</a></li> +<li>neorv32_rte_handler_uninstall()&#160;:&#160;<a class="el" href="neorv32__rte_8c.html#a10fde6229bf391e46148405616404a65">neorv32_rte.c</a>, <a class="el" href="neorv32__rte_8h.html#a10fde6229bf391e46148405616404a65">neorv32_rte.h</a></li> +<li>neorv32_rte_print_about()&#160;:&#160;<a class="el" href="neorv32__rte_8c.html#aa442c0e39f9156a131c3432fda587692">neorv32_rte.c</a>, <a class="el" href="neorv32__rte_8h.html#aa442c0e39f9156a131c3432fda587692">neorv32_rte.h</a></li> +<li>neorv32_rte_print_hw_config()&#160;:&#160;<a class="el" href="neorv32__rte_8c.html#a05e8304963e402d228a76aff1868771c">neorv32_rte.c</a>, <a class="el" href="neorv32__rte_8h.html#a05e8304963e402d228a76aff1868771c">neorv32_rte.h</a></li> +<li>neorv32_rte_print_hw_version()&#160;:&#160;<a class="el" href="neorv32__rte_8c.html#aad6f5256a265807c4cde163bcba8dae9">neorv32_rte.c</a>, <a class="el" href="neorv32__rte_8h.html#aad6f5256a265807c4cde163bcba8dae9">neorv32_rte.h</a></li> +<li>neorv32_rte_print_license()&#160;:&#160;<a class="el" href="neorv32__rte_8c.html#acd96aa73eebe6d4bbc9aabe1230cbabc">neorv32_rte.c</a>, <a class="el" href="neorv32__rte_8h.html#acd96aa73eebe6d4bbc9aabe1230cbabc">neorv32_rte.h</a></li> +<li>neorv32_rte_print_logo()&#160;:&#160;<a class="el" href="neorv32__rte_8c.html#a16df1b48f2e1258a51d3bb7f49531cf3">neorv32_rte.c</a>, <a class="el" href="neorv32__rte_8h.html#a16df1b48f2e1258a51d3bb7f49531cf3">neorv32_rte.h</a></li> +<li>neorv32_rte_setup()&#160;:&#160;<a class="el" href="neorv32__rte_8c.html#a343e1913bdc37db9b168fb4def0e6170">neorv32_rte.c</a>, <a class="el" href="neorv32__rte_8h.html#a343e1913bdc37db9b168fb4def0e6170">neorv32_rte.h</a></li> +<li>neorv32_sdi_available()&#160;:&#160;<a class="el" href="neorv32__sdi_8c.html#a51412722efdb18cd09667622b215e825">neorv32_sdi.c</a>, <a class="el" href="neorv32__sdi_8h.html#a51412722efdb18cd09667622b215e825">neorv32_sdi.h</a></li> +<li>neorv32_sdi_check_cs()&#160;:&#160;<a class="el" href="neorv32__sdi_8c.html#a2636cf1959ce1f3eb4b77c00ca2e2707">neorv32_sdi.c</a>, <a class="el" href="neorv32__sdi_8h.html#a2636cf1959ce1f3eb4b77c00ca2e2707">neorv32_sdi.h</a></li> +<li>neorv32_sdi_disable()&#160;:&#160;<a class="el" href="neorv32__sdi_8c.html#a8bd54bca8aea6147651c8115ee616f54">neorv32_sdi.c</a>, <a class="el" href="neorv32__sdi_8h.html#a8bd54bca8aea6147651c8115ee616f54">neorv32_sdi.h</a></li> +<li>neorv32_sdi_enable()&#160;:&#160;<a class="el" href="neorv32__sdi_8c.html#a5d68b9b1642baf3519076e55a22a8f61">neorv32_sdi.c</a>, <a class="el" href="neorv32__sdi_8h.html#a5d68b9b1642baf3519076e55a22a8f61">neorv32_sdi.h</a></li> +<li>neorv32_sdi_get()&#160;:&#160;<a class="el" href="neorv32__sdi_8c.html#a4d54ce22ec97eb83da118439576e3277">neorv32_sdi.c</a>, <a class="el" href="neorv32__sdi_8h.html#a4d54ce22ec97eb83da118439576e3277">neorv32_sdi.h</a></li> +<li>neorv32_sdi_get_fifo_depth()&#160;:&#160;<a class="el" href="neorv32__sdi_8c.html#a7390faeb01b4de3dd5ac18335736b90c">neorv32_sdi.c</a>, <a class="el" href="neorv32__sdi_8h.html#a7390faeb01b4de3dd5ac18335736b90c">neorv32_sdi.h</a></li> +<li>neorv32_sdi_put()&#160;:&#160;<a class="el" href="neorv32__sdi_8c.html#ac7a262d16c42bbac27723ff779545569">neorv32_sdi.c</a>, <a class="el" href="neorv32__sdi_8h.html#ac7a262d16c42bbac27723ff779545569">neorv32_sdi.h</a></li> +<li>neorv32_sdi_setup()&#160;:&#160;<a class="el" href="neorv32__sdi_8c.html#a3246118dc0d7e1f61bc2485bbab44149">neorv32_sdi.c</a>, <a class="el" href="neorv32__sdi_8h.html#a3246118dc0d7e1f61bc2485bbab44149">neorv32_sdi.h</a></li> +<li>neorv32_slink_available()&#160;:&#160;<a class="el" href="neorv32__slink_8c.html#aaf0f7bc96b797e819ccaae94292d9ddb">neorv32_slink.c</a>, <a class="el" href="neorv32__slink_8h.html#aaf0f7bc96b797e819ccaae94292d9ddb">neorv32_slink.h</a></li> +<li>neorv32_slink_check_last()&#160;:&#160;<a class="el" href="neorv32__slink_8c.html#a3e02c558548c1c6178c49adee9a007f7">neorv32_slink.c</a>, <a class="el" href="neorv32__slink_8h.html#a3e02c558548c1c6178c49adee9a007f7">neorv32_slink.h</a></li> +<li>neorv32_slink_get()&#160;:&#160;<a class="el" href="neorv32__slink_8c.html#ace319592c12dc6a0fe1b7dd66bdf9284">neorv32_slink.c</a>, <a class="el" href="neorv32__slink_8h.html#ace319592c12dc6a0fe1b7dd66bdf9284">neorv32_slink.h</a></li> +<li>neorv32_slink_get_rx_fifo_depth()&#160;:&#160;<a class="el" href="neorv32__slink_8c.html#a575c7663ca0bd07c95b1d45152a3ddf8">neorv32_slink.c</a>, <a class="el" href="neorv32__slink_8h.html#a575c7663ca0bd07c95b1d45152a3ddf8">neorv32_slink.h</a></li> +<li>neorv32_slink_get_src()&#160;:&#160;<a class="el" href="neorv32__slink_8c.html#a1a9269f42552a849450aecd99f7ec7a0">neorv32_slink.c</a>, <a class="el" href="neorv32__slink_8h.html#a1a9269f42552a849450aecd99f7ec7a0">neorv32_slink.h</a></li> +<li>neorv32_slink_get_tx_fifo_depth()&#160;:&#160;<a class="el" href="neorv32__slink_8c.html#aaf0d0d1b890353d4f3bf49450ec2fad2">neorv32_slink.c</a>, <a class="el" href="neorv32__slink_8h.html#aaf0d0d1b890353d4f3bf49450ec2fad2">neorv32_slink.h</a></li> +<li>neorv32_slink_put()&#160;:&#160;<a class="el" href="neorv32__slink_8c.html#aaa9fdb9cbfa7888e92790ab65431d21d">neorv32_slink.c</a>, <a class="el" href="neorv32__slink_8h.html#aaa9fdb9cbfa7888e92790ab65431d21d">neorv32_slink.h</a></li> +<li>neorv32_slink_put_last()&#160;:&#160;<a class="el" href="neorv32__slink_8c.html#a2136bc0b12ee2e6703e84a6417a1e8eb">neorv32_slink.c</a>, <a class="el" href="neorv32__slink_8h.html#a2136bc0b12ee2e6703e84a6417a1e8eb">neorv32_slink.h</a></li> +<li>neorv32_slink_rx_clear()&#160;:&#160;<a class="el" href="neorv32__slink_8c.html#ad149fea81e6d28f77450b8ba50cf706e">neorv32_slink.c</a>, <a class="el" href="neorv32__slink_8h.html#ad149fea81e6d28f77450b8ba50cf706e">neorv32_slink.h</a></li> +<li>neorv32_slink_rx_status()&#160;:&#160;<a class="el" href="neorv32__slink_8c.html#ad57fc0941fe32e8bf423ce3e57e2c10a">neorv32_slink.c</a>, <a class="el" href="neorv32__slink_8h.html#ad57fc0941fe32e8bf423ce3e57e2c10a">neorv32_slink.h</a></li> +<li>neorv32_slink_set_dst()&#160;:&#160;<a class="el" href="neorv32__slink_8c.html#ad857d7e78ca2b5eb0d0a4f2c515fe7bc">neorv32_slink.c</a>, <a class="el" href="neorv32__slink_8h.html#ad857d7e78ca2b5eb0d0a4f2c515fe7bc">neorv32_slink.h</a></li> +<li>neorv32_slink_setup()&#160;:&#160;<a class="el" href="neorv32__slink_8c.html#a8f0b4a768f53a72a5c16034e160ce321">neorv32_slink.c</a>, <a class="el" href="neorv32__slink_8h.html#a8f0b4a768f53a72a5c16034e160ce321">neorv32_slink.h</a></li> +<li>neorv32_slink_tx_clear()&#160;:&#160;<a class="el" href="neorv32__slink_8c.html#ac7484e9e3848f94efe016dd064f6a57f">neorv32_slink.c</a>, <a class="el" href="neorv32__slink_8h.html#ac7484e9e3848f94efe016dd064f6a57f">neorv32_slink.h</a></li> +<li>neorv32_slink_tx_status()&#160;:&#160;<a class="el" href="neorv32__slink_8c.html#ad0252e7ae915e5840cd17e8c52e94a1c">neorv32_slink.c</a>, <a class="el" href="neorv32__slink_8h.html#ad0252e7ae915e5840cd17e8c52e94a1c">neorv32_slink.h</a></li> +<li>neorv32_spi_available()&#160;:&#160;<a class="el" href="neorv32__spi_8c.html#a7266ee439d0ec11c5cedd4bf1a258272">neorv32_spi.c</a>, <a class="el" href="neorv32__spi_8h.html#a7266ee439d0ec11c5cedd4bf1a258272">neorv32_spi.h</a></li> +<li>neorv32_spi_busy()&#160;:&#160;<a class="el" href="neorv32__spi_8c.html#a332c7a1be511812ac0a2b102c165398a">neorv32_spi.c</a>, <a class="el" href="neorv32__spi_8h.html#a332c7a1be511812ac0a2b102c165398a">neorv32_spi.h</a></li> +<li>neorv32_spi_check_cs()&#160;:&#160;<a class="el" href="neorv32__spi_8c.html#a82bb4d4c222b2bdc57e917c348481501">neorv32_spi.c</a>, <a class="el" href="neorv32__spi_8h.html#a82bb4d4c222b2bdc57e917c348481501">neorv32_spi.h</a></li> +<li>neorv32_spi_cs_dis()&#160;:&#160;<a class="el" href="neorv32__spi_8c.html#aa10ec90ccba6325eeeebb8f6f298d30c">neorv32_spi.c</a>, <a class="el" href="neorv32__spi_8h.html#aa10ec90ccba6325eeeebb8f6f298d30c">neorv32_spi.h</a></li> +<li>neorv32_spi_cs_dis_nonblocking()&#160;:&#160;<a class="el" href="neorv32__spi_8c.html#ad8dd1b5a85a9daef4c8c21c9990884c1">neorv32_spi.c</a>, <a class="el" href="neorv32__spi_8h.html#ad8dd1b5a85a9daef4c8c21c9990884c1">neorv32_spi.h</a></li> +<li>neorv32_spi_cs_en()&#160;:&#160;<a class="el" href="neorv32__spi_8c.html#a737961d040ac09567350f89034f9e122">neorv32_spi.c</a>, <a class="el" href="neorv32__spi_8h.html#a737961d040ac09567350f89034f9e122">neorv32_spi.h</a></li> +<li>neorv32_spi_cs_en_nonblocking()&#160;:&#160;<a class="el" href="neorv32__spi_8c.html#a97b5536347a27b053f071ba49071ba6f">neorv32_spi.c</a>, <a class="el" href="neorv32__spi_8h.html#a97b5536347a27b053f071ba49071ba6f">neorv32_spi.h</a></li> +<li>neorv32_spi_disable()&#160;:&#160;<a class="el" href="neorv32__spi_8c.html#a817dd9a38bfceb2048e40874a83ba169">neorv32_spi.c</a>, <a class="el" href="neorv32__spi_8h.html#a817dd9a38bfceb2048e40874a83ba169">neorv32_spi.h</a></li> +<li>neorv32_spi_enable()&#160;:&#160;<a class="el" href="neorv32__spi_8c.html#a8fa25d144ccb20a2faf0450c8dddd16e">neorv32_spi.c</a>, <a class="el" href="neorv32__spi_8h.html#a8fa25d144ccb20a2faf0450c8dddd16e">neorv32_spi.h</a></li> +<li>neorv32_spi_get_clock_speed()&#160;:&#160;<a class="el" href="neorv32__spi_8c.html#a01c6b63d7349447e2277f2649c3c89f2">neorv32_spi.c</a>, <a class="el" href="neorv32__spi_8h.html#a01c6b63d7349447e2277f2649c3c89f2">neorv32_spi.h</a></li> +<li>neorv32_spi_get_fifo_depth()&#160;:&#160;<a class="el" href="neorv32__spi_8c.html#ae1c4da7e4dc2e42b04d7187f684f142c">neorv32_spi.c</a>, <a class="el" href="neorv32__spi_8h.html#ae1c4da7e4dc2e42b04d7187f684f142c">neorv32_spi.h</a></li> +<li>neorv32_spi_get_nonblocking()&#160;:&#160;<a class="el" href="neorv32__spi_8c.html#aad66fa8f8d1a92d4f355de7579bfbfd2">neorv32_spi.c</a>, <a class="el" href="neorv32__spi_8h.html#aad66fa8f8d1a92d4f355de7579bfbfd2">neorv32_spi.h</a></li> +<li>neorv32_spi_highspeed_disable()&#160;:&#160;<a class="el" href="neorv32__spi_8c.html#a67e9717635e272bc0e04408135a2f04d">neorv32_spi.c</a>, <a class="el" href="neorv32__spi_8h.html#a67e9717635e272bc0e04408135a2f04d">neorv32_spi.h</a></li> +<li>neorv32_spi_highspeed_enable()&#160;:&#160;<a class="el" href="neorv32__spi_8c.html#acf131faa3ad970c19a3cd8a47cb54f65">neorv32_spi.c</a>, <a class="el" href="neorv32__spi_8h.html#acf131faa3ad970c19a3cd8a47cb54f65">neorv32_spi.h</a></li> +<li>neorv32_spi_init()&#160;:&#160;<a class="el" href="neorv32__spi__irq_8c.html#a4aa4746fd210ecc0c3614089a6951ddf">neorv32_spi_irq.c</a>, <a class="el" href="neorv32__spi__irq_8h.html#a4aa4746fd210ecc0c3614089a6951ddf">neorv32_spi_irq.h</a></li> +<li>neorv32_spi_isr()&#160;:&#160;<a class="el" href="neorv32__spi__irq_8c.html#aa641816bb302df497664aa21ea69ed16">neorv32_spi_irq.c</a>, <a class="el" href="neorv32__spi__irq_8h.html#aa641816bb302df497664aa21ea69ed16">neorv32_spi_irq.h</a></li> +<li>neorv32_spi_put_nonblocking()&#160;:&#160;<a class="el" href="neorv32__spi_8c.html#aec8583e988789e846d21c2a35e6b06e7">neorv32_spi.c</a>, <a class="el" href="neorv32__spi_8h.html#aec8583e988789e846d21c2a35e6b06e7">neorv32_spi.h</a></li> +<li>neorv32_spi_rw()&#160;:&#160;<a class="el" href="neorv32__spi__irq_8c.html#a1f44ed849415d8e1d659c0485762c485">neorv32_spi_irq.c</a>, <a class="el" href="neorv32__spi__irq_8h.html#a1f44ed849415d8e1d659c0485762c485">neorv32_spi_irq.h</a></li> +<li>neorv32_spi_rw_busy()&#160;:&#160;<a class="el" href="neorv32__spi__irq_8c.html#a1863e19932bc6a79f2ca27d23eb74ef5">neorv32_spi_irq.c</a>, <a class="el" href="neorv32__spi__irq_8h.html#a1863e19932bc6a79f2ca27d23eb74ef5">neorv32_spi_irq.h</a></li> +<li>neorv32_spi_setup()&#160;:&#160;<a class="el" href="neorv32__spi_8c.html#a7d8124d986b69210081df6f1aa653552">neorv32_spi.c</a>, <a class="el" href="neorv32__spi_8h.html#a7d8124d986b69210081df6f1aa653552">neorv32_spi.h</a></li> +<li>neorv32_spi_trans()&#160;:&#160;<a class="el" href="neorv32__spi_8c.html#a7af79950eefc26e67a89bde02f255532">neorv32_spi.c</a>, <a class="el" href="neorv32__spi_8h.html#a7af79950eefc26e67a89bde02f255532">neorv32_spi.h</a></li> +<li>neorv32_trng_available()&#160;:&#160;<a class="el" href="neorv32__trng_8c.html#af0c4139ff68763623b3d658a8dd8b5ce">neorv32_trng.c</a>, <a class="el" href="neorv32__trng_8h.html#af0c4139ff68763623b3d658a8dd8b5ce">neorv32_trng.h</a></li> +<li>neorv32_trng_check_sim_mode()&#160;:&#160;<a class="el" href="neorv32__trng_8c.html#aba36f08dd88f2f3e58353ae72eaa14f7">neorv32_trng.c</a>, <a class="el" href="neorv32__trng_8h.html#aba36f08dd88f2f3e58353ae72eaa14f7">neorv32_trng.h</a></li> +<li>neorv32_trng_disable()&#160;:&#160;<a class="el" href="neorv32__trng_8c.html#ae838bc980e28c300dc2c9c3f34a46bb8">neorv32_trng.c</a>, <a class="el" href="neorv32__trng_8h.html#ae838bc980e28c300dc2c9c3f34a46bb8">neorv32_trng.h</a></li> +<li>neorv32_trng_enable()&#160;:&#160;<a class="el" href="neorv32__trng_8c.html#a8b8a1771e37a152792264561b93228fa">neorv32_trng.c</a>, <a class="el" href="neorv32__trng_8h.html#a8b8a1771e37a152792264561b93228fa">neorv32_trng.h</a></li> +<li>neorv32_trng_fifo_clear()&#160;:&#160;<a class="el" href="neorv32__trng_8c.html#a87cfe338e2ff559f96c73f729465f967">neorv32_trng.c</a>, <a class="el" href="neorv32__trng_8h.html#a87cfe338e2ff559f96c73f729465f967">neorv32_trng.h</a></li> +<li>neorv32_trng_get()&#160;:&#160;<a class="el" href="neorv32__trng_8c.html#a9148bcb6a7c448c364e78fa98aac6985">neorv32_trng.c</a>, <a class="el" href="neorv32__trng_8h.html#a9148bcb6a7c448c364e78fa98aac6985">neorv32_trng.h</a></li> +<li>neorv32_trng_get_fifo_depth()&#160;:&#160;<a class="el" href="neorv32__trng_8c.html#ad24e44372f4fd1ed29a6967dccab4fb0">neorv32_trng.c</a>, <a class="el" href="neorv32__trng_8h.html#ad24e44372f4fd1ed29a6967dccab4fb0">neorv32_trng.h</a></li> +<li>neorv32_twi_available()&#160;:&#160;<a class="el" href="neorv32__twi_8c.html#aa2e01ebbc0c82d65ed4ded351f4d8711">neorv32_twi.c</a>, <a class="el" href="neorv32__twi_8h.html#aa2e01ebbc0c82d65ed4ded351f4d8711">neorv32_twi.h</a></li> +<li>neorv32_twi_busy()&#160;:&#160;<a class="el" href="neorv32__twi_8c.html#a4fff1ddade320f6cc568c6266f2c2acd">neorv32_twi.c</a>, <a class="el" href="neorv32__twi_8h.html#a4fff1ddade320f6cc568c6266f2c2acd">neorv32_twi.h</a></li> +<li>neorv32_twi_disable()&#160;:&#160;<a class="el" href="neorv32__twi_8c.html#ae5f31e737c7a6c3c86070ff34cb0d861">neorv32_twi.c</a>, <a class="el" href="neorv32__twi_8h.html#ae5f31e737c7a6c3c86070ff34cb0d861">neorv32_twi.h</a></li> +<li>neorv32_twi_enable()&#160;:&#160;<a class="el" href="neorv32__twi_8c.html#a22717887cffff1e6830756bc73140e7b">neorv32_twi.c</a>, <a class="el" href="neorv32__twi_8h.html#a22717887cffff1e6830756bc73140e7b">neorv32_twi.h</a></li> +<li>neorv32_twi_generate_start()&#160;:&#160;<a class="el" href="neorv32__twi_8c.html#a633d460e4735eb369d74a834b03c8b78">neorv32_twi.c</a>, <a class="el" href="neorv32__twi_8h.html#a633d460e4735eb369d74a834b03c8b78">neorv32_twi.h</a></li> +<li>neorv32_twi_generate_start_nonblocking()&#160;:&#160;<a class="el" href="neorv32__twi_8c.html#adbf2eaed0c76221da5c3091665fc885e">neorv32_twi.c</a>, <a class="el" href="neorv32__twi_8h.html#adbf2eaed0c76221da5c3091665fc885e">neorv32_twi.h</a></li> +<li>neorv32_twi_generate_stop()&#160;:&#160;<a class="el" href="neorv32__twi_8c.html#ad352447adcccccabd4e20577b34fbece">neorv32_twi.c</a>, <a class="el" href="neorv32__twi_8h.html#ad352447adcccccabd4e20577b34fbece">neorv32_twi.h</a></li> +<li>neorv32_twi_generate_stop_nonblocking()&#160;:&#160;<a class="el" href="neorv32__twi_8c.html#aa22430aab0a38d88cbd2c4220c573da0">neorv32_twi.c</a>, <a class="el" href="neorv32__twi_8h.html#aa22430aab0a38d88cbd2c4220c573da0">neorv32_twi.h</a></li> +<li>neorv32_twi_get()&#160;:&#160;<a class="el" href="neorv32__twi_8c.html#a7735376d26560866b153ed205dfcb2ba">neorv32_twi.c</a>, <a class="el" href="neorv32__twi_8h.html#a7735376d26560866b153ed205dfcb2ba">neorv32_twi.h</a></li> +<li>neorv32_twi_get_fifo_depth()&#160;:&#160;<a class="el" href="neorv32__twi_8c.html#a2c8f3bc55f4a9a8bdcb111759cf56ae2">neorv32_twi.c</a>, <a class="el" href="neorv32__twi_8h.html#a2c8f3bc55f4a9a8bdcb111759cf56ae2">neorv32_twi.h</a></li> +<li>neorv32_twi_send_nonblocking()&#160;:&#160;<a class="el" href="neorv32__twi_8c.html#a28fc44cce5d28f6e8c32268b239b07d5">neorv32_twi.c</a>, <a class="el" href="neorv32__twi_8h.html#a28fc44cce5d28f6e8c32268b239b07d5">neorv32_twi.h</a></li> +<li>neorv32_twi_setup()&#160;:&#160;<a class="el" href="neorv32__twi_8c.html#a7ea6f3509a7cf622234d4b83e33afbe3">neorv32_twi.c</a>, <a class="el" href="neorv32__twi_8h.html#a7ea6f3509a7cf622234d4b83e33afbe3">neorv32_twi.h</a></li> +<li>neorv32_twi_trans()&#160;:&#160;<a class="el" href="neorv32__twi_8c.html#ac7020f3379602f11c47ca16f1bd82f2e">neorv32_twi.c</a>, <a class="el" href="neorv32__twi_8h.html#ac7020f3379602f11c47ca16f1bd82f2e">neorv32_twi.h</a></li> +<li>neorv32_uart_available()&#160;:&#160;<a class="el" href="neorv32__uart_8c.html#abef6415b0391dc055713404312196682">neorv32_uart.c</a>, <a class="el" href="neorv32__uart_8h.html#abef6415b0391dc055713404312196682">neorv32_uart.h</a></li> +<li>neorv32_uart_char_received()&#160;:&#160;<a class="el" href="neorv32__uart_8c.html#adedb0e07efb232717534017167a5be98">neorv32_uart.c</a>, <a class="el" href="neorv32__uart_8h.html#adedb0e07efb232717534017167a5be98">neorv32_uart.h</a></li> +<li>neorv32_uart_char_received_get()&#160;:&#160;<a class="el" href="neorv32__uart_8c.html#aa490df3a9bb2aa3215fa6fad34ffe7d1">neorv32_uart.c</a>, <a class="el" href="neorv32__uart_8h.html#aa490df3a9bb2aa3215fa6fad34ffe7d1">neorv32_uart.h</a></li> +<li>neorv32_uart_disable()&#160;:&#160;<a class="el" href="neorv32__uart_8c.html#ae18804ccd29ec2fd1cc06e9ce985b704">neorv32_uart.c</a>, <a class="el" href="neorv32__uart_8h.html#ae18804ccd29ec2fd1cc06e9ce985b704">neorv32_uart.h</a></li> +<li>neorv32_uart_enable()&#160;:&#160;<a class="el" href="neorv32__uart_8c.html#afa0533e81d53057c36f4997a2dbbe2bc">neorv32_uart.c</a>, <a class="el" href="neorv32__uart_8h.html#afa0533e81d53057c36f4997a2dbbe2bc">neorv32_uart.h</a></li> +<li>neorv32_uart_get_rx_fifo_depth()&#160;:&#160;<a class="el" href="neorv32__uart_8c.html#af85fb929c912d3edef3d86ffa833982a">neorv32_uart.c</a>, <a class="el" href="neorv32__uart_8h.html#af85fb929c912d3edef3d86ffa833982a">neorv32_uart.h</a></li> +<li>neorv32_uart_get_tx_fifo_depth()&#160;:&#160;<a class="el" href="neorv32__uart_8c.html#a031e3e27c8783c299623468020a22b0e">neorv32_uart.c</a>, <a class="el" href="neorv32__uart_8h.html#a031e3e27c8783c299623468020a22b0e">neorv32_uart.h</a></li> +<li>neorv32_uart_getc()&#160;:&#160;<a class="el" href="neorv32__uart_8c.html#a2efd432f63b8d36d44263d0b1f39a6dc">neorv32_uart.c</a>, <a class="el" href="neorv32__uart_8h.html#a2efd432f63b8d36d44263d0b1f39a6dc">neorv32_uart.h</a></li> +<li>neorv32_uart_printf()&#160;:&#160;<a class="el" href="neorv32__uart_8c.html#ab8c1f9f451def9126ab2749d7bbe50d9">neorv32_uart.c</a>, <a class="el" href="neorv32__uart_8h.html#ab8c1f9f451def9126ab2749d7bbe50d9">neorv32_uart.h</a></li> +<li>neorv32_uart_putc()&#160;:&#160;<a class="el" href="neorv32__uart_8c.html#a9bc7bb94a50b74e1145b78eec6094129">neorv32_uart.c</a>, <a class="el" href="neorv32__uart_8h.html#a9bc7bb94a50b74e1145b78eec6094129">neorv32_uart.h</a></li> +<li>neorv32_uart_puts()&#160;:&#160;<a class="el" href="neorv32__uart_8c.html#a45a07d5e71677162baaa1025759c67a2">neorv32_uart.c</a>, <a class="el" href="neorv32__uart_8h.html#a45a07d5e71677162baaa1025759c67a2">neorv32_uart.h</a></li> +<li>neorv32_uart_rtscts_disable()&#160;:&#160;<a class="el" href="neorv32__uart_8c.html#a7b2f924ef4554b1fa90433c38d97558d">neorv32_uart.c</a>, <a class="el" href="neorv32__uart_8h.html#a7b2f924ef4554b1fa90433c38d97558d">neorv32_uart.h</a></li> +<li>neorv32_uart_rtscts_enable()&#160;:&#160;<a class="el" href="neorv32__uart_8c.html#a734b610f4cd1b474d7763f9700a715ec">neorv32_uart.c</a>, <a class="el" href="neorv32__uart_8h.html#a734b610f4cd1b474d7763f9700a715ec">neorv32_uart.h</a></li> +<li>neorv32_uart_rx_clear()&#160;:&#160;<a class="el" href="neorv32__uart_8c.html#afe0de59c14faff1e0c890d5465be25f0">neorv32_uart.c</a>, <a class="el" href="neorv32__uart_8h.html#afe0de59c14faff1e0c890d5465be25f0">neorv32_uart.h</a></li> +<li>neorv32_uart_scan()&#160;:&#160;<a class="el" href="neorv32__uart_8c.html#ac429964878bd6deab61d9ed8659bca75">neorv32_uart.c</a>, <a class="el" href="neorv32__uart_8h.html#ac429964878bd6deab61d9ed8659bca75">neorv32_uart.h</a></li> +<li>neorv32_uart_setup()&#160;:&#160;<a class="el" href="neorv32__uart_8c.html#a9cdec36f2723c5373664022d1b68b841">neorv32_uart.c</a>, <a class="el" href="neorv32__uart_8h.html#a9cdec36f2723c5373664022d1b68b841">neorv32_uart.h</a></li> +<li>neorv32_uart_tx_busy()&#160;:&#160;<a class="el" href="neorv32__uart_8c.html#aa7bef48a58e044c246b8c4ad32864502">neorv32_uart.c</a>, <a class="el" href="neorv32__uart_8h.html#aa7bef48a58e044c246b8c4ad32864502">neorv32_uart.h</a></li> +<li>neorv32_uart_tx_clear()&#160;:&#160;<a class="el" href="neorv32__uart_8c.html#a27971954262a2fd1f21d3bf1ba27e87c">neorv32_uart.c</a>, <a class="el" href="neorv32__uart_8h.html#a27971954262a2fd1f21d3bf1ba27e87c">neorv32_uart.h</a></li> +<li>neorv32_uart_vprintf()&#160;:&#160;<a class="el" href="neorv32__uart_8c.html#a8714cdb1c04d94bec322c6215ea10238">neorv32_uart.c</a>, <a class="el" href="neorv32__uart_8h.html#a8714cdb1c04d94bec322c6215ea10238">neorv32_uart.h</a></li> +<li>neorv32_wdt_available()&#160;:&#160;<a class="el" href="neorv32__wdt_8c.html#a459a918c5a86c0167e8c748352d39827">neorv32_wdt.c</a>, <a class="el" href="neorv32__wdt_8h.html#a459a918c5a86c0167e8c748352d39827">neorv32_wdt.h</a></li> +<li>neorv32_wdt_disable()&#160;:&#160;<a class="el" href="neorv32__wdt_8c.html#aba52520582392a671e2b717715a330b2">neorv32_wdt.c</a>, <a class="el" href="neorv32__wdt_8h.html#aba52520582392a671e2b717715a330b2">neorv32_wdt.h</a></li> +<li>neorv32_wdt_feed()&#160;:&#160;<a class="el" href="neorv32__wdt_8c.html#a2e4df2b352d11c31063ef2fc16c510ad">neorv32_wdt.c</a>, <a class="el" href="neorv32__wdt_8h.html#a2e4df2b352d11c31063ef2fc16c510ad">neorv32_wdt.h</a></li> +<li>neorv32_wdt_get_cause()&#160;:&#160;<a class="el" href="neorv32__wdt_8c.html#a80fa8d178d18c9b02d32d93e815b532e">neorv32_wdt.c</a>, <a class="el" href="neorv32__wdt_8h.html#a80fa8d178d18c9b02d32d93e815b532e">neorv32_wdt.h</a></li> +<li>neorv32_wdt_setup()&#160;:&#160;<a class="el" href="neorv32__wdt_8c.html#a2aa72608191d34ef41c5f545988ff400">neorv32_wdt.c</a>, <a class="el" href="neorv32__wdt_8h.html#a2aa72608191d34ef41c5f545988ff400">neorv32_wdt.h</a></li> +<li>neorv32_xip_available()&#160;:&#160;<a class="el" href="neorv32__xip_8c.html#afe2e5682a26cafdb0585d2233bccc7c6">neorv32_xip.c</a>, <a class="el" href="neorv32__xip_8h.html#afe2e5682a26cafdb0585d2233bccc7c6">neorv32_xip.h</a></li> +<li>neorv32_xip_get_clock_speed()&#160;:&#160;<a class="el" href="neorv32__xip_8c.html#a88f728101e82939bf7f8b9ab5a904706">neorv32_xip.c</a>, <a class="el" href="neorv32__xip_8h.html#a88f728101e82939bf7f8b9ab5a904706">neorv32_xip.h</a></li> +<li>neorv32_xip_highspeed_disable()&#160;:&#160;<a class="el" href="neorv32__xip_8c.html#ad74f2842ed2251e3ae5c19e06dced0c3">neorv32_xip.c</a>, <a class="el" href="neorv32__xip_8h.html#ad74f2842ed2251e3ae5c19e06dced0c3">neorv32_xip.h</a></li> +<li>neorv32_xip_highspeed_enable()&#160;:&#160;<a class="el" href="neorv32__xip_8c.html#a6aef2ea29451ba2aa55160da777a5115">neorv32_xip.c</a>, <a class="el" href="neorv32__xip_8h.html#a6aef2ea29451ba2aa55160da777a5115">neorv32_xip.h</a></li> +<li>neorv32_xip_setup()&#160;:&#160;<a class="el" href="neorv32__xip_8c.html#a549d68abdf5a3d7484abe6d5370bb999">neorv32_xip.c</a>, <a class="el" href="neorv32__xip_8h.html#a549d68abdf5a3d7484abe6d5370bb999">neorv32_xip.h</a></li> +<li>neorv32_xip_spi_trans()&#160;:&#160;<a class="el" href="neorv32__xip_8c.html#a92f1446a3bb7fe6dee5dbed33882b223">neorv32_xip.c</a>, <a class="el" href="neorv32__xip_8h.html#a92f1446a3bb7fe6dee5dbed33882b223">neorv32_xip.h</a></li> +<li>neorv32_xip_start()&#160;:&#160;<a class="el" href="neorv32__xip_8c.html#a0ab2c36c973030a811e6d7abe0afc393">neorv32_xip.c</a>, <a class="el" href="neorv32__xip_8h.html#a0ab2c36c973030a811e6d7abe0afc393">neorv32_xip.h</a></li> +<li>neorv32_xirq_available()&#160;:&#160;<a class="el" href="neorv32__xirq_8c.html#aaf30757d526030a8d81081915ab29a76">neorv32_xirq.c</a>, <a class="el" href="neorv32__xirq_8h.html#aaf30757d526030a8d81081915ab29a76">neorv32_xirq.h</a></li> +<li>neorv32_xirq_channel_disable()&#160;:&#160;<a class="el" href="neorv32__xirq_8c.html#ae17509ad0c828aa9b36747b253cdbf0a">neorv32_xirq.c</a>, <a class="el" href="neorv32__xirq_8h.html#ae17509ad0c828aa9b36747b253cdbf0a">neorv32_xirq.h</a></li> +<li>neorv32_xirq_channel_enable()&#160;:&#160;<a class="el" href="neorv32__xirq_8c.html#abe63c0968c94b472082c8156a1a7db5c">neorv32_xirq.c</a>, <a class="el" href="neorv32__xirq_8h.html#abe63c0968c94b472082c8156a1a7db5c">neorv32_xirq.h</a></li> +<li>neorv32_xirq_clear_pending()&#160;:&#160;<a class="el" href="neorv32__xirq_8c.html#a83ecaf568a6f6bcb1e1efdb1eef6df9c">neorv32_xirq.c</a>, <a class="el" href="neorv32__xirq_8h.html#a83ecaf568a6f6bcb1e1efdb1eef6df9c">neorv32_xirq.h</a></li> +<li>neorv32_xirq_get_num()&#160;:&#160;<a class="el" href="neorv32__xirq_8c.html#a717a8e34908cc01345e68920e76f229c">neorv32_xirq.c</a>, <a class="el" href="neorv32__xirq_8h.html#a717a8e34908cc01345e68920e76f229c">neorv32_xirq.h</a></li> +<li>neorv32_xirq_global_disable()&#160;:&#160;<a class="el" href="neorv32__xirq_8c.html#ac64d3ff5619968499bccebebe6a6cab3">neorv32_xirq.c</a>, <a class="el" href="neorv32__xirq_8h.html#ac64d3ff5619968499bccebebe6a6cab3">neorv32_xirq.h</a></li> +<li>neorv32_xirq_global_enable()&#160;:&#160;<a class="el" href="neorv32__xirq_8c.html#a76468156ef52b371e06bc2ca8eddcd27">neorv32_xirq.c</a>, <a class="el" href="neorv32__xirq_8h.html#a76468156ef52b371e06bc2ca8eddcd27">neorv32_xirq.h</a></li> +<li>neorv32_xirq_install()&#160;:&#160;<a class="el" href="neorv32__xirq_8c.html#a9129984f91c02afafaa072a5d86f9876">neorv32_xirq.c</a>, <a class="el" href="neorv32__xirq_8h.html#a9129984f91c02afafaa072a5d86f9876">neorv32_xirq.h</a></li> +<li>neorv32_xirq_setup()&#160;:&#160;<a class="el" href="neorv32__xirq_8c.html#a9295997fce7114a8205325c4d75dd200">neorv32_xirq.c</a>, <a class="el" href="neorv32__xirq_8h.html#a9295997fce7114a8205325c4d75dd200">neorv32_xirq.h</a></li> +<li>neorv32_xirq_setup_trigger()&#160;:&#160;<a class="el" href="neorv32__xirq_8c.html#a0d137f09d1e7dcd31c157b856033ac42">neorv32_xirq.c</a>, <a class="el" href="neorv32__xirq_8h.html#a0d137f09d1e7dcd31c157b856033ac42">neorv32_xirq.h</a></li> +<li>neorv32_xirq_uninstall()&#160;:&#160;<a class="el" href="neorv32__xirq_8c.html#a49ae67d1d5066cd795149e96b81127f7">neorv32_xirq.c</a>, <a class="el" href="neorv32__xirq_8h.html#a49ae67d1d5066cd795149e96b81127f7">neorv32_xirq.h</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/globals_func_p.html b/sw/globals_func_p.html new file mode 100644 index 0000000000..bb30119504 --- /dev/null +++ b/sw/globals_func_p.html @@ -0,0 +1,108 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: Globals</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +</div><!-- top --> +<div id="doc-content"> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div class="contents"> +<div class="textblock">Here is a list of all documented functions with links to the documentation:</div> + +<h3><a id="index_p" name="index_p"></a>- p -</h3><ul> +<li>pop_count()&#160;:&#160;<a class="el" href="game__of__life_2main_8c.html#aac4bec7738b12f5a4b4d7a3a6cb1ab8d">main.c</a></li> +<li>print_help()&#160;:&#160;<a class="el" href="bootloader_8c.html#a402ea961bfc2ffeee61e3a7c330b1559">bootloader.c</a></li> +<li>print_hex_byte()&#160;:&#160;<a class="el" href="demo__twi_2main_8c.html#a2ebc688bc1dad328693fc0974b378fa0">main.c</a></li> +<li>print_hex_word()&#160;:&#160;<a class="el" href="bootloader_8c.html#a70b7d5c3b3ae97e4e72e84c4bc28fb8a">bootloader.c</a></li> +<li>print_random_data()&#160;:&#160;<a class="el" href="demo__trng_2main_8c.html#a64205d97b57c99dc5e95b8621827f4a4">main.c</a></li> +<li>print_report()&#160;:&#160;<a class="el" href="atomic__test_2main_8c.html#a99377a057d14aaa9b45f8cab890e8cf7">main.c</a></li> +<li>print_universe()&#160;:&#160;<a class="el" href="game__of__life_2main_8c.html#a9a455dea83a25f656fcc5217ad513dac">main.c</a></li> +<li>putchar()&#160;:&#160;<a class="el" href="neorv32__uart_8c.html#a07036e93939040c563e862a6a31b65bc">neorv32_uart.c</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/globals_func_r.html b/sw/globals_func_r.html new file mode 100644 index 0000000000..15d8caa0a1 --- /dev/null +++ b/sw/globals_func_r.html @@ -0,0 +1,148 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: Globals</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +</div><!-- top --> +<div id="doc-content"> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div class="contents"> +<div class="textblock">Here is a list of all documented functions with links to the documentation:</div> + +<h3><a id="index_r" name="index_r"></a>- r -</h3><ul> +<li>read_byte()&#160;:&#160;<a class="el" href="demo__onewire_2main_8c.html#a951a31029af34715f20856eb82432637">main.c</a></li> +<li>read_memory()&#160;:&#160;<a class="el" href="bus__explorer_2main_8c.html#afc9b1ab3db46eccf51d55c715fa2fbd4">main.c</a></li> +<li>repetition_count_test()&#160;:&#160;<a class="el" href="demo__trng_2main_8c.html#af37eae672fee5e81f00a1dbf51b7e417">main.c</a></li> +<li>riscv_emulate_fadds()&#160;:&#160;<a class="el" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a9d676567276439875c9b1a15b892b555">neorv32_zfinx_extension_intrinsics.h</a></li> +<li>riscv_emulate_fclasss()&#160;:&#160;<a class="el" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#ae41a0bf9d28c35f4d6db7177ccf8ee06">neorv32_zfinx_extension_intrinsics.h</a></li> +<li>riscv_emulate_fcvt_sw()&#160;:&#160;<a class="el" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a0f2260b7b5793a95c49670379fc89617">neorv32_zfinx_extension_intrinsics.h</a></li> +<li>riscv_emulate_fcvt_swu()&#160;:&#160;<a class="el" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a10a05bface37bff32c78ed0746845794">neorv32_zfinx_extension_intrinsics.h</a></li> +<li>riscv_emulate_fcvt_ws()&#160;:&#160;<a class="el" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a292365fe41a7a661e61ae746306ba5e9">neorv32_zfinx_extension_intrinsics.h</a></li> +<li>riscv_emulate_fcvt_wus()&#160;:&#160;<a class="el" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#aad9fc7337e09081cf8c5bff8c28776c8">neorv32_zfinx_extension_intrinsics.h</a></li> +<li>riscv_emulate_fdivs()&#160;:&#160;<a class="el" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#aeaf46a17b671278be2bf804159827a40">neorv32_zfinx_extension_intrinsics.h</a></li> +<li>riscv_emulate_feqs()&#160;:&#160;<a class="el" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a7cb3c6570b911cd1dfb7b6e798cc1d21">neorv32_zfinx_extension_intrinsics.h</a></li> +<li>riscv_emulate_fles()&#160;:&#160;<a class="el" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#ac5fdef0607602fa0bdb93b3535fd709e">neorv32_zfinx_extension_intrinsics.h</a></li> +<li>riscv_emulate_flts()&#160;:&#160;<a class="el" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a2b802122d53a2ce517b3d39fec34d7e0">neorv32_zfinx_extension_intrinsics.h</a></li> +<li>riscv_emulate_fmadds()&#160;:&#160;<a class="el" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a39212f2e2bb0f1752092a1732f93edf3">neorv32_zfinx_extension_intrinsics.h</a></li> +<li>riscv_emulate_fmaxs()&#160;:&#160;<a class="el" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#af9b16a32d2bb13c8af5a678271d74889">neorv32_zfinx_extension_intrinsics.h</a></li> +<li>riscv_emulate_fmins()&#160;:&#160;<a class="el" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a872cd30fb61190bd1ac719d25b01f5a3">neorv32_zfinx_extension_intrinsics.h</a></li> +<li>riscv_emulate_fmsubs()&#160;:&#160;<a class="el" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a05d0d5a8eb9422e93448efdeb679cabf">neorv32_zfinx_extension_intrinsics.h</a></li> +<li>riscv_emulate_fmuls()&#160;:&#160;<a class="el" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#ad43e8bdf4a6fbe229d22d24680f2be80">neorv32_zfinx_extension_intrinsics.h</a></li> +<li>riscv_emulate_fnmadds()&#160;:&#160;<a class="el" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#ac8bb4450b39854ab07839e8f3505361c">neorv32_zfinx_extension_intrinsics.h</a></li> +<li>riscv_emulate_fnmsubs()&#160;:&#160;<a class="el" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a833638b346722dfa9d7d5c8d60998ec8">neorv32_zfinx_extension_intrinsics.h</a></li> +<li>riscv_emulate_fsgnjns()&#160;:&#160;<a class="el" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a0c985e626ed1d69314f4e3a0f1f58624">neorv32_zfinx_extension_intrinsics.h</a></li> +<li>riscv_emulate_fsgnjs()&#160;:&#160;<a class="el" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a12498d635f422f607b9b83facf3050dd">neorv32_zfinx_extension_intrinsics.h</a></li> +<li>riscv_emulate_fsgnjxs()&#160;:&#160;<a class="el" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a98caf7f310820052ae96ce0f45e6cd26">neorv32_zfinx_extension_intrinsics.h</a></li> +<li>riscv_emulate_fsqrts()&#160;:&#160;<a class="el" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a1ceb3450f1e5c62d3079cd0e93c03501">neorv32_zfinx_extension_intrinsics.h</a></li> +<li>riscv_emulate_fsubs()&#160;:&#160;<a class="el" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#ace5d95b855ec1aa8eacdb5bbeea58197">neorv32_zfinx_extension_intrinsics.h</a></li> +<li>riscv_intrinsic_fadds()&#160;:&#160;<a class="el" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a4b151fcb252fc7b894f247f5af6a1809">neorv32_zfinx_extension_intrinsics.h</a></li> +<li>riscv_intrinsic_fclasss()&#160;:&#160;<a class="el" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a3064a5c57b5f45d57c4d19eb798724f6">neorv32_zfinx_extension_intrinsics.h</a></li> +<li>riscv_intrinsic_fcvt_sw()&#160;:&#160;<a class="el" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a2103eb86052f6f8e24a8a848ffc6528a">neorv32_zfinx_extension_intrinsics.h</a></li> +<li>riscv_intrinsic_fcvt_swu()&#160;:&#160;<a class="el" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a837b7330f9d568791687ae1384b8ef28">neorv32_zfinx_extension_intrinsics.h</a></li> +<li>riscv_intrinsic_fcvt_ws()&#160;:&#160;<a class="el" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a523fa0fb6f521311c7f44692c586b3ee">neorv32_zfinx_extension_intrinsics.h</a></li> +<li>riscv_intrinsic_fcvt_wus()&#160;:&#160;<a class="el" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a3bc6ee3059a7e99b187c4ea5e217715b">neorv32_zfinx_extension_intrinsics.h</a></li> +<li>riscv_intrinsic_fdivs()&#160;:&#160;<a class="el" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#ab6a9d15643e3085ff80c7883f183a42b">neorv32_zfinx_extension_intrinsics.h</a></li> +<li>riscv_intrinsic_feqs()&#160;:&#160;<a class="el" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#af4ddfae45807d4e41f758672ee14cf7b">neorv32_zfinx_extension_intrinsics.h</a></li> +<li>riscv_intrinsic_fles()&#160;:&#160;<a class="el" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#adb83fab39d91e9291da2b7b07830cf82">neorv32_zfinx_extension_intrinsics.h</a></li> +<li>riscv_intrinsic_flts()&#160;:&#160;<a class="el" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a85aa18294a58997db2c324184196669c">neorv32_zfinx_extension_intrinsics.h</a></li> +<li>riscv_intrinsic_fmadds()&#160;:&#160;<a class="el" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#abbdb403cdeef414fa2f867b702d5f6eb">neorv32_zfinx_extension_intrinsics.h</a></li> +<li>riscv_intrinsic_fmaxs()&#160;:&#160;<a class="el" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a87c1ce499e5e43554cb0f407cf0d3f7f">neorv32_zfinx_extension_intrinsics.h</a></li> +<li>riscv_intrinsic_fmins()&#160;:&#160;<a class="el" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#abf7f9e466906306d9755fd5bc7946e3c">neorv32_zfinx_extension_intrinsics.h</a></li> +<li>riscv_intrinsic_fmsubs()&#160;:&#160;<a class="el" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a03aba9c70c5286dacebaeb0ef5219cc9">neorv32_zfinx_extension_intrinsics.h</a></li> +<li>riscv_intrinsic_fmuls()&#160;:&#160;<a class="el" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a87a106e0d24a3183712e438d2bcbfa2d">neorv32_zfinx_extension_intrinsics.h</a></li> +<li>riscv_intrinsic_fnmadds()&#160;:&#160;<a class="el" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#aa6473bc2d2721b57277b83a3ae0cfdb6">neorv32_zfinx_extension_intrinsics.h</a></li> +<li>riscv_intrinsic_fnmsubs()&#160;:&#160;<a class="el" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a639fc7bd75933888540e9cceb67221a0">neorv32_zfinx_extension_intrinsics.h</a></li> +<li>riscv_intrinsic_fsgnjns()&#160;:&#160;<a class="el" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#aa4010772a986d03929ba7a43dfdcddd9">neorv32_zfinx_extension_intrinsics.h</a></li> +<li>riscv_intrinsic_fsgnjs()&#160;:&#160;<a class="el" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#aff3acd90bcfbda96945f95a0e0bae12b">neorv32_zfinx_extension_intrinsics.h</a></li> +<li>riscv_intrinsic_fsgnjxs()&#160;:&#160;<a class="el" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a2235d91cdac03bf8071003a5c59b9dd0">neorv32_zfinx_extension_intrinsics.h</a></li> +<li>riscv_intrinsic_fsqrts()&#160;:&#160;<a class="el" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a17e2b7a399c956d548a609185084ea3c">neorv32_zfinx_extension_intrinsics.h</a></li> +<li>riscv_intrinsic_fsubs()&#160;:&#160;<a class="el" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#af8473ba61abab8ae2e3ecbaf22d70e89">neorv32_zfinx_extension_intrinsics.h</a></li> +<li>rte_service_handler()&#160;:&#160;<a class="el" href="processor__check_2main_8c.html#a349743a03307abb5130a3e89d903971b">main.c</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/globals_func_s.html b/sw/globals_func_s.html new file mode 100644 index 0000000000..7880ada328 --- /dev/null +++ b/sw/globals_func_s.html @@ -0,0 +1,131 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: Globals</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +</div><!-- top --> +<div id="doc-content"> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div class="contents"> +<div class="textblock">Here is a list of all documented functions with links to the documentation:</div> + +<h3><a id="index_s" name="index_s"></a>- s -</h3><ul> +<li>save_exe()&#160;:&#160;<a class="el" href="bootloader_8c.html#ababfffe8e7036179e150ad3b9bda3a74">bootloader.c</a></li> +<li>scan_bus()&#160;:&#160;<a class="el" href="demo__onewire_2main_8c.html#ac07c9cfd80ac2e24be9dac6cf943b7de">main.c</a></li> +<li>scan_twi()&#160;:&#160;<a class="el" href="demo__twi_2main_8c.html#aace46ee34e954f9ebee5873beb0785f1">main.c</a></li> +<li>sdi_get()&#160;:&#160;<a class="el" href="demo__sdi_2main_8c.html#aa25f620a5631e862252be1d5429e8585">main.c</a></li> +<li>sdi_put()&#160;:&#160;<a class="el" href="demo__sdi_2main_8c.html#ae3dc843520a800d7ba2b5d6be03d9c3d">main.c</a></li> +<li>send_twi()&#160;:&#160;<a class="el" href="demo__twi_2main_8c.html#aa94edd4f55a3ac18913f661f4bc16fb1">main.c</a></li> +<li>set_cell()&#160;:&#160;<a class="el" href="game__of__life_2main_8c.html#a5315eb56128f1ca40d9f4d477c345dd7">main.c</a></li> +<li>set_clock()&#160;:&#160;<a class="el" href="demo__twi_2main_8c.html#acee0c1770467f85a150d072ac7e1252f">main.c</a></li> +<li>setup_access()&#160;:&#160;<a class="el" href="bus__explorer_2main_8c.html#a2b6196c2e97a7f7702c0068780304ec1">main.c</a></li> +<li>show_1wire_commands()&#160;:&#160;<a class="el" href="demo__onewire_2main_8c.html#a29d5831498c2eaf0415d6f01efb9e7ce">main.c</a></li> +<li>show_arrays()&#160;:&#160;<a class="el" href="demo__dma_2main_8c.html#a8ad0c7bfd07edb6d42d86b166347206b">main.c</a></li> +<li>show_help()&#160;:&#160;<a class="el" href="demo__onewire_2main_8c.html#af25820ed386a66a0d6bb4dcdd2204704">main.c</a></li> +<li>sim_irq_trigger()&#160;:&#160;<a class="el" href="processor__check_2main_8c.html#ada24f2cd9d2d384265517f539711de62">main.c</a></li> +<li>slink_firq_handler()&#160;:&#160;<a class="el" href="demo__slink_2main_8c.html#a48c79e20ed1d4138d61b5593bdbe537a">main.c</a></li> +<li>spi_cs()&#160;:&#160;<a class="el" href="demo__spi_2main_8c.html#a6f94991b8943a141ed4124585222470d">main.c</a></li> +<li>spi_flash_check()&#160;:&#160;<a class="el" href="bootloader_8c.html#a1919595ed2232aebb3e774b916ab1662">bootloader.c</a></li> +<li>spi_flash_erase_sector()&#160;:&#160;<a class="el" href="bootloader_8c.html#a0d877f0611dfcee32a483c8a3660eb1b">bootloader.c</a></li> +<li>spi_flash_read_byte()&#160;:&#160;<a class="el" href="bootloader_8c.html#a09e72e2debdd94929b2be4c7713d5e17">bootloader.c</a></li> +<li>spi_flash_read_status()&#160;:&#160;<a class="el" href="bootloader_8c.html#a005966cd0b32f3d5c041028c4b1c99f5">bootloader.c</a></li> +<li>spi_flash_wakeup()&#160;:&#160;<a class="el" href="bootloader_8c.html#a1fbdccc60f05756213c9f3d64bac6d47">bootloader.c</a></li> +<li>spi_flash_write_addr()&#160;:&#160;<a class="el" href="bootloader_8c.html#a6a8caddda6e729d747726471b0b0f742">bootloader.c</a></li> +<li>spi_flash_write_byte()&#160;:&#160;<a class="el" href="bootloader_8c.html#a006c27b7d80897b78ab8cd83a391331f">bootloader.c</a></li> +<li>spi_flash_write_disable()&#160;:&#160;<a class="el" href="bootloader_8c.html#a82d26a2d6293ed7fd44a5c622adfbd45">bootloader.c</a></li> +<li>spi_flash_write_enable()&#160;:&#160;<a class="el" href="bootloader_8c.html#a9642e28ef2baec5b356ad9a70970d0e6">bootloader.c</a></li> +<li>spi_flash_write_word()&#160;:&#160;<a class="el" href="bootloader_8c.html#a717c72166af7c2ff7e73bd0b47128338">bootloader.c</a></li> +<li>spi_irq_handler()&#160;:&#160;<a class="el" href="demo__spi__irq_2main_8c.html#a7e266cc5247c999948dacc2102bd184a">main.c</a></li> +<li>spi_setup()&#160;:&#160;<a class="el" href="demo__spi_2main_8c.html#a755192be6c3cf9904564b0eee99de445">main.c</a></li> +<li>spi_trans()&#160;:&#160;<a class="el" href="demo__spi_2main_8c.html#a13e10b34fbbffca6c31f0ce25b3f8432">main.c</a></li> +<li>start_app()&#160;:&#160;<a class="el" href="bootloader_8c.html#ae8de91537ac2782f0f0ebc3b2d4fb1df">bootloader.c</a></li> +<li>subnormal_flush()&#160;:&#160;<a class="el" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a791f880781a1bcea1861471be7d1a851">neorv32_zfinx_extension_intrinsics.h</a></li> +<li>system_error()&#160;:&#160;<a class="el" href="bootloader_8c.html#a3bdfe2f25b1bfb42f80624ffff22ab01">bootloader.c</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/globals_func_t.html b/sw/globals_func_t.html new file mode 100644 index 0000000000..2fc2e5a9a2 --- /dev/null +++ b/sw/globals_func_t.html @@ -0,0 +1,105 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: Globals</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +</div><!-- top --> +<div id="doc-content"> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div class="contents"> +<div class="textblock">Here is a list of all documented functions with links to the documentation:</div> + +<h3><a id="index_t" name="index_t"></a>- t -</h3><ul> +<li>test_fail()&#160;:&#160;<a class="el" href="processor__check_2main_8c.html#a1e0a5d63896fa26a6c25c0012fc6b938">main.c</a></li> +<li>test_ok()&#160;:&#160;<a class="el" href="processor__check_2main_8c.html#ae61d39109b2747429ec3a3c1b5533598">main.c</a></li> +<li>trap_handler_emulate_amo()&#160;:&#160;<a class="el" href="atomic__test_2main_8c.html#aafcbf639ae4f66e5dfe9dea511a59f9d">main.c</a></li> +<li>trap_handler_emulate_unaligned_lw()&#160;:&#160;<a class="el" href="demo__emulate__unaligned_2main_8c.html#a07da42351229525998965b219e827460">main.c</a></li> +<li>trigger_module_dummy()&#160;:&#160;<a class="el" href="processor__check_2main_8c.html#ac91bfdd45696444673dc7d6b1b644082">main.c</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/globals_func_u.html b/sw/globals_func_u.html new file mode 100644 index 0000000000..385b93b531 --- /dev/null +++ b/sw/globals_func_u.html @@ -0,0 +1,102 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: Globals</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +</div><!-- top --> +<div id="doc-content"> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div class="contents"> +<div class="textblock">Here is a list of all documented functions with links to the documentation:</div> + +<h3><a id="index_u" name="index_u"></a>- u -</h3><ul> +<li>uart_get_executable()&#160;:&#160;<a class="el" href="demo__xip_2main_8c.html#a0458656f8a108ff31f4bbbd005f029a0">main.c</a></li> +<li>uart_get_word()&#160;:&#160;<a class="el" href="demo__xip_2main_8c.html#a3043d09bdc155f57f45cd91e0cd4d15b">main.c</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/globals_func_v.html b/sw/globals_func_v.html new file mode 100644 index 0000000000..7800c82c5a --- /dev/null +++ b/sw/globals_func_v.html @@ -0,0 +1,104 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: Globals</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +</div><!-- top --> +<div id="doc-content"> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div class="contents"> +<div class="textblock">Here is a list of all documented functions with links to the documentation:</div> + +<h3><a id="index_v" name="index_v"></a>- v -</h3><ul> +<li>vectored_global_handler()&#160;:&#160;<a class="el" href="processor__check_2main_8c.html#a9504ca74fdb80711a88d2a16d4cb4cf4">main.c</a></li> +<li>vectored_irq_table()&#160;:&#160;<a class="el" href="processor__check_2main_8c.html#a0d695ebfaae3b4614ddb62640cbf8b7b">main.c</a></li> +<li>vectored_mei_handler()&#160;:&#160;<a class="el" href="processor__check_2main_8c.html#a1a455bede4ab48f32d3ed0868e398044">main.c</a></li> +<li>verify_result()&#160;:&#160;<a class="el" href="float__corner__test_2main_8c.html#a941ef8d24fd8e8fe4536626b2ce72410">main.c</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/globals_func_w.html b/sw/globals_func_w.html new file mode 100644 index 0000000000..8e83fa08d5 --- /dev/null +++ b/sw/globals_func_w.html @@ -0,0 +1,102 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: Globals</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +</div><!-- top --> +<div id="doc-content"> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div class="contents"> +<div class="textblock">Here is a list of all documented functions with links to the documentation:</div> + +<h3><a id="index_w" name="index_w"></a>- w -</h3><ul> +<li>write_byte()&#160;:&#160;<a class="el" href="demo__onewire_2main_8c.html#a28283848f09bf8feebc860a51545f487">main.c</a></li> +<li>write_memory()&#160;:&#160;<a class="el" href="bus__explorer_2main_8c.html#a96729fb5279642ac56c8e6a513789b45">main.c</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/globals_func_x.html b/sw/globals_func_x.html new file mode 100644 index 0000000000..7abf7fe85e --- /dev/null +++ b/sw/globals_func_x.html @@ -0,0 +1,111 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: Globals</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +</div><!-- top --> +<div id="doc-content"> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div class="contents"> +<div class="textblock">Here is a list of all documented functions with links to the documentation:</div> + +<h3><a id="index_x" name="index_x"></a>- x -</h3><ul> +<li>xip_flash_access_check()&#160;:&#160;<a class="el" href="demo__xip_2main_8c.html#a23bd7bd7b0808d919fd09ac0a8258498">main.c</a></li> +<li>xip_flash_erase_sector()&#160;:&#160;<a class="el" href="demo__xip_2main_8c.html#a9e0b2714126b6699ddb65485c93293e4">main.c</a></li> +<li>xip_flash_program()&#160;:&#160;<a class="el" href="demo__xip_2main_8c.html#a4ddfa8fdc072cadeef18a4a10bc8b174">main.c</a></li> +<li>xirq_handler_ch0()&#160;:&#160;<a class="el" href="demo__xirq_2main_8c.html#a8874ccfc0b56171c359b5c2ceaf2bd80">main.c</a></li> +<li>xirq_handler_ch1()&#160;:&#160;<a class="el" href="demo__xirq_2main_8c.html#abfe0c0bc47a683ba55df2aed63a12d4b">main.c</a></li> +<li>xirq_handler_ch2()&#160;:&#160;<a class="el" href="demo__xirq_2main_8c.html#ae8e3b3236aa2303c2b5e6e421b72cf73">main.c</a></li> +<li>xirq_handler_ch3()&#160;:&#160;<a class="el" href="demo__xirq_2main_8c.html#a99e9ae3088f39995c852b2c53ec21266">main.c</a></li> +<li>xirq_trap_handler0()&#160;:&#160;<a class="el" href="processor__check_2main_8c.html#aa4fe70578c4dccabe1e31fae941378cb">main.c</a></li> +<li>xirq_trap_handler1()&#160;:&#160;<a class="el" href="processor__check_2main_8c.html#a277cb06ef74e4cfe1ef783069f9b6527">main.c</a></li> +<li>xtea_sw_decipher()&#160;:&#160;<a class="el" href="demo__cfu_2main_8c.html#a0e980c5d81b1eca90b8073e54099bdb0">main.c</a></li> +<li>xtea_sw_encipher()&#160;:&#160;<a class="el" href="demo__cfu_2main_8c.html#a8dc502bf508491eed1f39c4acf040efb">main.c</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/globals_g.html b/sw/globals_g.html new file mode 100644 index 0000000000..96dda2e052 --- /dev/null +++ b/sw/globals_g.html @@ -0,0 +1,122 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: Globals</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +</div><!-- top --> +<div id="doc-content"> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div class="contents"> +<div class="textblock">Here is a list of all documented functions, variables, defines, enums, and typedefs with links to the documentation:</div> + +<h3><a id="index_g" name="index_g"></a>- g -</h3><ul> +<li>GEN_DELAY&#160;:&#160;<a class="el" href="game__of__life_2main_8c.html#a3f33bf77abbf35c245956489f8f7e3a7">main.c</a></li> +<li>generate_histogram()&#160;:&#160;<a class="el" href="demo__trng_2main_8c.html#a4e49f5e3feb4bd5755f919cd3310b506">main.c</a></li> +<li>get_cell()&#160;:&#160;<a class="el" href="game__of__life_2main_8c.html#a6bd541a19c62ea9ec620eaad3f218d16">main.c</a></li> +<li>get_exe()&#160;:&#160;<a class="el" href="bootloader_8c.html#ac18819795adb6dbdd52b0587e7fbb569">bootloader.c</a></li> +<li>get_exe_word()&#160;:&#160;<a class="el" href="bootloader_8c.html#ac58d9f7dc79a549bde1cb50f619c19af">bootloader.c</a></li> +<li>get_neighborhood()&#160;:&#160;<a class="el" href="game__of__life_2main_8c.html#a977190adaa24a3f49fca1540b51d25a0">main.c</a></li> +<li>get_test_vector()&#160;:&#160;<a class="el" href="float__corner__test_2main_8c.html#a73c70bd0fb6d695cb113eaeb50923e3e">main.c</a></li> +<li>getchar()&#160;:&#160;<a class="el" href="neorv32__uart_8c.html#a3e29caa20f7cffe18f410f01278905a8">neorv32_uart.c</a></li> +<li>getting_exe&#160;:&#160;<a class="el" href="bootloader_8c.html#a5fa6b109bf211d1768f84c9d38eef240">bootloader.c</a></li> +<li>global_trap_handler()&#160;:&#160;<a class="el" href="processor__check_2main_8c.html#a9a64ce0ee69c4c32cecc8b2b2746604c">main.c</a></li> +<li>GPTMR_CTRL_EN&#160;:&#160;<a class="el" href="neorv32__gptmr_8h.html#a135b0750d4afed16e5867134e3843988abbfa7abcbd80b9c47e83e23e5cefaf90">neorv32_gptmr.h</a></li> +<li>GPTMR_CTRL_IRQ_CLR&#160;:&#160;<a class="el" href="neorv32__gptmr_8h.html#a135b0750d4afed16e5867134e3843988aadb663ad9a0dfd37fc65dffc1a289b38">neorv32_gptmr.h</a></li> +<li>GPTMR_CTRL_IRQ_PND&#160;:&#160;<a class="el" href="neorv32__gptmr_8h.html#a135b0750d4afed16e5867134e3843988a3a868dc710ab9add083137e4e3fe888a">neorv32_gptmr.h</a></li> +<li>GPTMR_CTRL_MODE&#160;:&#160;<a class="el" href="neorv32__gptmr_8h.html#a135b0750d4afed16e5867134e3843988a473870880c0eca71578d6969e816af43">neorv32_gptmr.h</a></li> +<li>GPTMR_CTRL_PRSC0&#160;:&#160;<a class="el" href="neorv32__gptmr_8h.html#a135b0750d4afed16e5867134e3843988ae4716a7a9e356484a8e478f07920cde3">neorv32_gptmr.h</a></li> +<li>GPTMR_CTRL_PRSC1&#160;:&#160;<a class="el" href="neorv32__gptmr_8h.html#a135b0750d4afed16e5867134e3843988a1e1e8e516fa4918441e3c77153940298">neorv32_gptmr.h</a></li> +<li>GPTMR_CTRL_PRSC2&#160;:&#160;<a class="el" href="neorv32__gptmr_8h.html#a135b0750d4afed16e5867134e3843988a185861fbdc5f276735481237ad844833">neorv32_gptmr.h</a></li> +<li>GPTMR_FIRQ_ENABLE&#160;:&#160;<a class="el" href="neorv32_8h.html#a0a59186908b498cb92273b7767966e26">neorv32.h</a></li> +<li>gptmr_firq_handler()&#160;:&#160;<a class="el" href="demo__gptmr_2main_8c.html#a2bd89412466a65329711bfd5c29199c9">main.c</a></li> +<li>GPTMR_FIRQ_PENDING&#160;:&#160;<a class="el" href="neorv32_8h.html#a4a3164d123ddddd07750f868e67d82d8">neorv32.h</a></li> +<li>GPTMR_RTE_ID&#160;:&#160;<a class="el" href="neorv32_8h.html#aac38deeef36de0a474ab238a3054f860">neorv32.h</a></li> +<li>GPTMR_TRAP_CODE&#160;:&#160;<a class="el" href="neorv32_8h.html#a445543c36d1f78477aa8ea4841c720a1">neorv32.h</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/globals_h.html b/sw/globals_h.html new file mode 100644 index 0000000000..01cc8534df --- /dev/null +++ b/sw/globals_h.html @@ -0,0 +1,115 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: Globals</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +</div><!-- top --> +<div id="doc-content"> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div class="contents"> +<div class="textblock">Here is a list of all documented functions, variables, defines, enums, and typedefs with links to the documentation:</div> + +<h3><a id="index_h" name="index_h"></a>- h -</h3><ul> +<li>hexdump()&#160;:&#160;<a class="el" href="bus__explorer_2main_8c.html#a02640a99db37b8d92b9edffc9720a210">main.c</a></li> +<li>HPMCNT_EVENT_BRANCH&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfea9e1e2b50352b2555e9c64e76776919a6">neorv32_cpu_csr.h</a></li> +<li>HPMCNT_EVENT_BRANCHED&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfea0f15c5a824cb1678423ac4ef72a5f4f5">neorv32_cpu_csr.h</a></li> +<li>HPMCNT_EVENT_COMPR&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfea685ed663611d988702ec59c254eb61dd">neorv32_cpu_csr.h</a></li> +<li>HPMCNT_EVENT_CY&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfea2b683572525adc02ce0910031cfea914">neorv32_cpu_csr.h</a></li> +<li>HPMCNT_EVENT_IR&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfeaab438295e5f00ffe4c2457a54ee9bfc4">neorv32_cpu_csr.h</a></li> +<li>HPMCNT_EVENT_LOAD&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfea1a06f216e1a12afa0b90d6e1218b3c91">neorv32_cpu_csr.h</a></li> +<li>HPMCNT_EVENT_STORE&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfea6a942852e3cd85616a63addb8e9d76f2">neorv32_cpu_csr.h</a></li> +<li>HPMCNT_EVENT_TM&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfea578ef6fc107c22b5cb7be5950f695640">neorv32_cpu_csr.h</a></li> +<li>HPMCNT_EVENT_TRAP&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfea3a4f5bf9251def87a71162dbcf9043c5">neorv32_cpu_csr.h</a></li> +<li>HPMCNT_EVENT_WAIT_ALU&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfeaffbb04d0053ebd079c6cacb4e5e7ed6b">neorv32_cpu_csr.h</a></li> +<li>HPMCNT_EVENT_WAIT_DIS&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfeabcb123b5b150b4413e5fd48475faab27">neorv32_cpu_csr.h</a></li> +<li>HPMCNT_EVENT_WAIT_LSU&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfea67a59934bc66bc7ccf82d24fe8a18a3b">neorv32_cpu_csr.h</a></li> +<li>hsv2rgb()&#160;:&#160;<a class="el" href="demo__neopixel_2main_8c.html#a2736ec755f9e10c80bf66f727f870ffc">main.c</a></li> +<li>hw_breakpoint_handler()&#160;:&#160;<a class="el" href="processor__check_2main_8c.html#a31d9e432f6a368e6222f5e0907eeb6f4">main.c</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/globals_i.html b/sw/globals_i.html new file mode 100644 index 0000000000..3bc3003292 --- /dev/null +++ b/sw/globals_i.html @@ -0,0 +1,102 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: Globals</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +</div><!-- top --> +<div id="doc-content"> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div class="contents"> +<div class="textblock">Here is a list of all documented functions, variables, defines, enums, and typedefs with links to the documentation:</div> + +<h3><a id="index_i" name="index_i"></a>- i -</h3><ul> +<li>input_data&#160;:&#160;<a class="el" href="demo__cfu_2main_8c.html#a2e2ccb9136736a673dbef71f207e97a0">main.c</a></li> +<li>IO_BASE_ADDRESS&#160;:&#160;<a class="el" href="neorv32_8h.html#a1eb0cb7fed7e154e15cb4009880a879c">neorv32.h</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/globals_k.html b/sw/globals_k.html new file mode 100644 index 0000000000..8fb7a1752e --- /dev/null +++ b/sw/globals_k.html @@ -0,0 +1,101 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: Globals</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +</div><!-- top --> +<div id="doc-content"> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div class="contents"> +<div class="textblock">Here is a list of all documented functions, variables, defines, enums, and typedefs with links to the documentation:</div> + +<h3><a id="index_k" name="index_k"></a>- k -</h3><ul> +<li>key&#160;:&#160;<a class="el" href="demo__cfu_2main_8c.html#ab5c498f9da12ab2d6ddc89bf4a46dec6">main.c</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/globals_m.html b/sw/globals_m.html new file mode 100644 index 0000000000..0b5dcebb48 --- /dev/null +++ b/sw/globals_m.html @@ -0,0 +1,103 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: Globals</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +</div><!-- top --> +<div id="doc-content"> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div class="contents"> +<div class="textblock">Here is a list of all documented functions, variables, defines, enums, and typedefs with links to the documentation:</div> + +<h3><a id="index_m" name="index_m"></a>- m -</h3><ul> +<li>main()&#160;:&#160;<a class="el" href="bootloader_8c.html#a840291bc02cba5474a4cb46a9b9566fe">bootloader.c</a>, <a class="el" href="atomic__test_2main_8c.html#ae66f6b31b5ad750f1fe042a706a4e3d4">main.c</a></li> +<li>MAX_INTENSITY&#160;:&#160;<a class="el" href="demo__neopixel_2main_8c.html#a1d1d5e7ff16f25b68fdf779befd298f7">main.c</a></li> +<li>mtime_irq_handler()&#160;:&#160;<a class="el" href="demo__mtime_2main_8c.html#a329137855a7c2e098715a0771c5585d7">main.c</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/globals_n.html b/sw/globals_n.html new file mode 100644 index 0000000000..063f3c6842 --- /dev/null +++ b/sw/globals_n.html @@ -0,0 +1,449 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: Globals</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +</div><!-- top --> +<div id="doc-content"> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div class="contents"> +<div class="textblock">Here is a list of all documented functions, variables, defines, enums, and typedefs with links to the documentation:</div> + +<h3><a id="index_n" name="index_n"></a>- n -</h3><ul> +<li>NEOLED_CTRL_BUFS_0&#160;:&#160;<a class="el" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a3bb5d0d1f78cebccbc8620a0194f43b8">neorv32_neoled.h</a></li> +<li>NEOLED_CTRL_BUFS_1&#160;:&#160;<a class="el" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412aed0a878e73ad501bed3bbe6905974368">neorv32_neoled.h</a></li> +<li>NEOLED_CTRL_BUFS_2&#160;:&#160;<a class="el" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412ae7b9d45c4ef69ca15fa13aa107e68156">neorv32_neoled.h</a></li> +<li>NEOLED_CTRL_BUFS_3&#160;:&#160;<a class="el" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412ac1922a5311e91a74710eddbf86ccc1c1">neorv32_neoled.h</a></li> +<li>NEOLED_CTRL_EN&#160;:&#160;<a class="el" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412af97ab77b33a250d87025c3dd3a21fea7">neorv32_neoled.h</a></li> +<li>NEOLED_CTRL_IRQ_CONF&#160;:&#160;<a class="el" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a37421074b86a260b276534b7c4949339">neorv32_neoled.h</a></li> +<li>NEOLED_CTRL_MODE&#160;:&#160;<a class="el" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412abf6779cbeae87ab55efc9573932fc865">neorv32_neoled.h</a></li> +<li>NEOLED_CTRL_PRSC0&#160;:&#160;<a class="el" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a142ed3fd65e01f853666a1169f920ad0">neorv32_neoled.h</a></li> +<li>NEOLED_CTRL_PRSC1&#160;:&#160;<a class="el" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a0f4178d81ec6fe9a8b0e30230d318a91">neorv32_neoled.h</a></li> +<li>NEOLED_CTRL_PRSC2&#160;:&#160;<a class="el" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a3d8d54c05080fddb16df4176527bafa8">neorv32_neoled.h</a></li> +<li>NEOLED_CTRL_STROBE&#160;:&#160;<a class="el" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a436ad310b025bd3000af37986c193de5">neorv32_neoled.h</a></li> +<li>NEOLED_CTRL_T_ONE_H_0&#160;:&#160;<a class="el" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a770df505d47353f6c9289059c416d9c8">neorv32_neoled.h</a></li> +<li>NEOLED_CTRL_T_ONE_H_1&#160;:&#160;<a class="el" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412aea15666ad4bb9eb1eba5dc9ed96114a6">neorv32_neoled.h</a></li> +<li>NEOLED_CTRL_T_ONE_H_2&#160;:&#160;<a class="el" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a4d362af8c630823b5104401a9c7d734e">neorv32_neoled.h</a></li> +<li>NEOLED_CTRL_T_ONE_H_3&#160;:&#160;<a class="el" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a369f36e73783c2923d07ca333081a4a6">neorv32_neoled.h</a></li> +<li>NEOLED_CTRL_T_ONE_H_4&#160;:&#160;<a class="el" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a0c15850d0ab005b075f1a317646e18b1">neorv32_neoled.h</a></li> +<li>NEOLED_CTRL_T_TOT_0&#160;:&#160;<a class="el" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a44d8f064decabc690ed1f092be2b049b">neorv32_neoled.h</a></li> +<li>NEOLED_CTRL_T_TOT_1&#160;:&#160;<a class="el" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412addf4d6d1fd09f145d8aa497c4a7479c2">neorv32_neoled.h</a></li> +<li>NEOLED_CTRL_T_TOT_2&#160;:&#160;<a class="el" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a42d09d42d39fc0eb2697853c99f4d5b0">neorv32_neoled.h</a></li> +<li>NEOLED_CTRL_T_TOT_3&#160;:&#160;<a class="el" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412acbcd3c046b528e1900e86428da231df2">neorv32_neoled.h</a></li> +<li>NEOLED_CTRL_T_TOT_4&#160;:&#160;<a class="el" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a3f1a0ad71d9fd892829ec0246be343b3">neorv32_neoled.h</a></li> +<li>NEOLED_CTRL_T_ZERO_H_0&#160;:&#160;<a class="el" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a7285e332ec7c2b3aeb34290e3e60ded7">neorv32_neoled.h</a></li> +<li>NEOLED_CTRL_T_ZERO_H_1&#160;:&#160;<a class="el" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a1ef56b35c966786c42f2a2f800e30eae">neorv32_neoled.h</a></li> +<li>NEOLED_CTRL_T_ZERO_H_2&#160;:&#160;<a class="el" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a9d9411382d943c1659b6b761c462319b">neorv32_neoled.h</a></li> +<li>NEOLED_CTRL_T_ZERO_H_3&#160;:&#160;<a class="el" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412abf2ea111a4ff34b6cb4dd987c5692f5c">neorv32_neoled.h</a></li> +<li>NEOLED_CTRL_T_ZERO_H_4&#160;:&#160;<a class="el" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a0d5d01b8d30119bb86c1d079f7d5a9ad">neorv32_neoled.h</a></li> +<li>NEOLED_CTRL_TX_BUSY&#160;:&#160;<a class="el" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a55da98b018c7cc32cd1e80087ed9018e">neorv32_neoled.h</a></li> +<li>NEOLED_CTRL_TX_EMPTY&#160;:&#160;<a class="el" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a23937f0a728da197590e1d383507cb23">neorv32_neoled.h</a></li> +<li>NEOLED_CTRL_TX_FULL&#160;:&#160;<a class="el" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412acfac5269688b2a03794dc17b11f1b983">neorv32_neoled.h</a></li> +<li>NEOLED_CTRL_TX_HALF&#160;:&#160;<a class="el" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a16c09df2784cfb6fafffaeaf245f1b73">neorv32_neoled.h</a></li> +<li>NEOLED_FIRQ_ENABLE&#160;:&#160;<a class="el" href="neorv32_8h.html#a8d0409818600c0b2acfe8253e8f027b8">neorv32.h</a></li> +<li>NEOLED_FIRQ_PENDING&#160;:&#160;<a class="el" href="neorv32_8h.html#aded7d7f5f4ba3a6d90f9a29e62a8cfab">neorv32.h</a></li> +<li>NEOLED_RTE_ID&#160;:&#160;<a class="el" href="neorv32_8h.html#aca6cfc3f580c4dfe1e213009ee450c58">neorv32.h</a></li> +<li>NEOLED_TRAP_CODE&#160;:&#160;<a class="el" href="neorv32_8h.html#ab4a2ac455d7426992de6877ea7325f21">neorv32.h</a></li> +<li>neorv32_aux_date2unixtime()&#160;:&#160;<a class="el" href="neorv32__aux_8c.html#a94aa8369ba5f4ebdf5628fcb1ab2ba1c">neorv32_aux.c</a>, <a class="el" href="neorv32__aux_8h.html#a94aa8369ba5f4ebdf5628fcb1ab2ba1c">neorv32_aux.h</a></li> +<li>neorv32_aux_hexstr2uint64()&#160;:&#160;<a class="el" href="neorv32__aux_8c.html#aec4703f369e1567c22f140d2ec9daafc">neorv32_aux.c</a>, <a class="el" href="neorv32__aux_8h.html#aec4703f369e1567c22f140d2ec9daafc">neorv32_aux.h</a></li> +<li>neorv32_aux_unixtime2date()&#160;:&#160;<a class="el" href="neorv32__aux_8c.html#a885a81838a91b57797e849cb835c6887">neorv32_aux.c</a>, <a class="el" href="neorv32__aux_8h.html#a885a81838a91b57797e849cb835c6887">neorv32_aux.h</a></li> +<li>neorv32_aux_xorshift32()&#160;:&#160;<a class="el" href="neorv32__aux_8c.html#aff31dd983f75f70eeae331c65acaa50e">neorv32_aux.c</a>, <a class="el" href="neorv32__aux_8h.html#aff31dd983f75f70eeae331c65acaa50e">neorv32_aux.h</a></li> +<li>NEORV32_CFS&#160;:&#160;<a class="el" href="neorv32__cfs_8h.html#a6c101b306bd096f78d351e39b308d3e2">neorv32_cfs.h</a></li> +<li>neorv32_cfs_available()&#160;:&#160;<a class="el" href="neorv32__cfs_8c.html#abac96dfaefe433eca1c0b93fa6183d2e">neorv32_cfs.c</a>, <a class="el" href="neorv32__cfs_8h.html#abac96dfaefe433eca1c0b93fa6183d2e">neorv32_cfs.h</a></li> +<li>NEORV32_CFS_BASE&#160;:&#160;<a class="el" href="neorv32_8h.html#a41d6f97daef61641da96b9f72f6b272f">neorv32.h</a></li> +<li>neorv32_cfu_r3_instr&#160;:&#160;<a class="el" href="neorv32__cpu__cfu_8h.html#a69d60ccd0cee950b08ce585c3f13b85c">neorv32_cpu_cfu.h</a></li> +<li>neorv32_cfu_r4_instr&#160;:&#160;<a class="el" href="neorv32__cpu__cfu_8h.html#a046a640f7f4a7b1b99a824fb325e2079">neorv32_cpu_cfu.h</a></li> +<li>neorv32_cfu_r5_instr_a&#160;:&#160;<a class="el" href="neorv32__cpu__cfu_8h.html#a65198d9caf04a5cd3a72accc2cecf870">neorv32_cpu_cfu.h</a></li> +<li>neorv32_cfu_r5_instr_b&#160;:&#160;<a class="el" href="neorv32__cpu__cfu_8h.html#ab3affefbff898567c6c02c4d10765b04">neorv32_cpu_cfu.h</a></li> +<li>NEORV32_CLOCK_PRSC_enum&#160;:&#160;<a class="el" href="neorv32_8h.html#a10022df4c223533b04d5aebe222e8b73">neorv32.h</a></li> +<li>neorv32_cpu_amoaddw()&#160;:&#160;<a class="el" href="neorv32__cpu__amo_8c.html#ada27ec89b2530f7b7f14de947cc82bf9">neorv32_cpu_amo.c</a>, <a class="el" href="neorv32__cpu__amo_8h.html#ada27ec89b2530f7b7f14de947cc82bf9">neorv32_cpu_amo.h</a></li> +<li>neorv32_cpu_amoandw()&#160;:&#160;<a class="el" href="neorv32__cpu__amo_8c.html#a9b4540dadbfd5da907117570d8006e36">neorv32_cpu_amo.c</a>, <a class="el" href="neorv32__cpu__amo_8h.html#a9b4540dadbfd5da907117570d8006e36">neorv32_cpu_amo.h</a></li> +<li>neorv32_cpu_amolr()&#160;:&#160;<a class="el" href="neorv32__cpu__amo_8h.html#ad4437bbc61a4e40d7d01dfe9459f6639">neorv32_cpu_amo.h</a></li> +<li>neorv32_cpu_amomaxuw()&#160;:&#160;<a class="el" href="neorv32__cpu__amo_8c.html#a31a6a3b5a33655f4a7b27d4c85b75f07">neorv32_cpu_amo.c</a>, <a class="el" href="neorv32__cpu__amo_8h.html#a31a6a3b5a33655f4a7b27d4c85b75f07">neorv32_cpu_amo.h</a></li> +<li>neorv32_cpu_amomaxw()&#160;:&#160;<a class="el" href="neorv32__cpu__amo_8c.html#a62cf36637d7a04079228acecfe8a5cf3">neorv32_cpu_amo.c</a>, <a class="el" href="neorv32__cpu__amo_8h.html#a62cf36637d7a04079228acecfe8a5cf3">neorv32_cpu_amo.h</a></li> +<li>neorv32_cpu_amominuw()&#160;:&#160;<a class="el" href="neorv32__cpu__amo_8c.html#a1281e18b95cd525073e1123c5d04e9e2">neorv32_cpu_amo.c</a>, <a class="el" href="neorv32__cpu__amo_8h.html#a1281e18b95cd525073e1123c5d04e9e2">neorv32_cpu_amo.h</a></li> +<li>neorv32_cpu_amominw()&#160;:&#160;<a class="el" href="neorv32__cpu__amo_8c.html#a8e383fb8825538b5579d5ce075830697">neorv32_cpu_amo.c</a>, <a class="el" href="neorv32__cpu__amo_8h.html#a8e383fb8825538b5579d5ce075830697">neorv32_cpu_amo.h</a></li> +<li>neorv32_cpu_amoorw()&#160;:&#160;<a class="el" href="neorv32__cpu__amo_8c.html#adc80b1f2b3a4e70fee44c0edb08fc402">neorv32_cpu_amo.c</a>, <a class="el" href="neorv32__cpu__amo_8h.html#adc80b1f2b3a4e70fee44c0edb08fc402">neorv32_cpu_amo.h</a></li> +<li>neorv32_cpu_amosc()&#160;:&#160;<a class="el" href="neorv32__cpu__amo_8h.html#a5e73eaa273c41a06972e862976fda53c">neorv32_cpu_amo.h</a></li> +<li>neorv32_cpu_amoswapw()&#160;:&#160;<a class="el" href="neorv32__cpu__amo_8c.html#aad0d96e61bacc3af13ff471dd44ca8e9">neorv32_cpu_amo.c</a>, <a class="el" href="neorv32__cpu__amo_8h.html#aad0d96e61bacc3af13ff471dd44ca8e9">neorv32_cpu_amo.h</a></li> +<li>neorv32_cpu_amoxorw()&#160;:&#160;<a class="el" href="neorv32__cpu__amo_8c.html#a65b67f48356fa9b30596485473311377">neorv32_cpu_amo.c</a>, <a class="el" href="neorv32__cpu__amo_8h.html#a65b67f48356fa9b30596485473311377">neorv32_cpu_amo.h</a></li> +<li>neorv32_cpu_cfu_available()&#160;:&#160;<a class="el" href="neorv32__cpu__cfu_8c.html#a13019b8afa1a80c0e5c24eb4d72e75c1">neorv32_cpu_cfu.c</a>, <a class="el" href="neorv32__cpu__cfu_8h.html#a13019b8afa1a80c0e5c24eb4d72e75c1">neorv32_cpu_cfu.h</a></li> +<li>neorv32_cpu_csr_clr()&#160;:&#160;<a class="el" href="neorv32__cpu_8h.html#ab8f533ddbc3a3af5e3bca2287ac10122">neorv32_cpu.h</a></li> +<li>neorv32_cpu_csr_read()&#160;:&#160;<a class="el" href="neorv32__cpu_8h.html#aab7a9f9cf608599f2b124dd499cb8418">neorv32_cpu.h</a></li> +<li>neorv32_cpu_csr_set()&#160;:&#160;<a class="el" href="neorv32__cpu_8h.html#a25a09de97229aac839ef6f74da604acf">neorv32_cpu.h</a></li> +<li>neorv32_cpu_csr_write()&#160;:&#160;<a class="el" href="neorv32__cpu_8h.html#afb5ef6e0b1a3e26570edfd8379490455">neorv32_cpu.h</a></li> +<li>neorv32_cpu_delay_ms()&#160;:&#160;<a class="el" href="neorv32__cpu_8c.html#aa9027535b13d9f9325e734997fc4a137">neorv32_cpu.c</a>, <a class="el" href="neorv32__cpu_8h.html#aa9027535b13d9f9325e734997fc4a137">neorv32_cpu.h</a></li> +<li>neorv32_cpu_get_clk_from_prsc()&#160;:&#160;<a class="el" href="neorv32__cpu_8c.html#a8346fb926f84f3d7bccbb4741105505f">neorv32_cpu.c</a>, <a class="el" href="neorv32__cpu_8h.html#a8346fb926f84f3d7bccbb4741105505f">neorv32_cpu.h</a></li> +<li>neorv32_cpu_get_cycle()&#160;:&#160;<a class="el" href="neorv32__cpu_8c.html#ac3fd7dc7cd1e0a08225c41820af27f92">neorv32_cpu.c</a>, <a class="el" href="neorv32__cpu_8h.html#ac3fd7dc7cd1e0a08225c41820af27f92">neorv32_cpu.h</a></li> +<li>neorv32_cpu_get_instret()&#160;:&#160;<a class="el" href="neorv32__cpu_8c.html#a387aa304770b05594c4acca128a60a75">neorv32_cpu.c</a>, <a class="el" href="neorv32__cpu_8h.html#a387aa304770b05594c4acca128a60a75">neorv32_cpu.h</a></li> +<li>neorv32_cpu_goto_user_mode()&#160;:&#160;<a class="el" href="neorv32__cpu_8c.html#aca49efb45d3808ad76cf65ba291f546d">neorv32_cpu.c</a>, <a class="el" href="neorv32__cpu_8h.html#aca49efb45d3808ad76cf65ba291f546d">neorv32_cpu.h</a></li> +<li>neorv32_cpu_hpm_get_num_counters()&#160;:&#160;<a class="el" href="neorv32__cpu_8c.html#a70f49b80322aa457f29f7671f94a183d">neorv32_cpu.c</a>, <a class="el" href="neorv32__cpu_8h.html#a70f49b80322aa457f29f7671f94a183d">neorv32_cpu.h</a></li> +<li>neorv32_cpu_hpm_get_size()&#160;:&#160;<a class="el" href="neorv32__cpu_8c.html#adb3ae542bbb0ddf9f562a4e42bc24d10">neorv32_cpu.c</a>, <a class="el" href="neorv32__cpu_8h.html#adb3ae542bbb0ddf9f562a4e42bc24d10">neorv32_cpu.h</a></li> +<li>neorv32_cpu_load_signed_byte()&#160;:&#160;<a class="el" href="neorv32__cpu_8h.html#a31f903596ab1bcddea79fdf608eaa666">neorv32_cpu.h</a></li> +<li>neorv32_cpu_load_signed_half()&#160;:&#160;<a class="el" href="neorv32__cpu_8h.html#ae9c8b6c681536ddea3aff0e63f30ef70">neorv32_cpu.h</a></li> +<li>neorv32_cpu_load_unsigned_byte()&#160;:&#160;<a class="el" href="neorv32__cpu_8h.html#ac54ec9b59e17c7cd9b9907abee82ce95">neorv32_cpu.h</a></li> +<li>neorv32_cpu_load_unsigned_half()&#160;:&#160;<a class="el" href="neorv32__cpu_8h.html#a32544cd652debb4affb308806a115d5b">neorv32_cpu.h</a></li> +<li>neorv32_cpu_load_unsigned_word()&#160;:&#160;<a class="el" href="neorv32__cpu_8h.html#a3b6cf445e2136486564ef3d3473c91dd">neorv32_cpu.h</a></li> +<li>neorv32_cpu_pmp_configure_region()&#160;:&#160;<a class="el" href="neorv32__cpu_8c.html#aa458a700619b2f7666cfcffe02ec2e2c">neorv32_cpu.c</a>, <a class="el" href="neorv32__cpu_8h.html#aa458a700619b2f7666cfcffe02ec2e2c">neorv32_cpu.h</a></li> +<li>neorv32_cpu_pmp_get_granularity()&#160;:&#160;<a class="el" href="neorv32__cpu_8c.html#ad4f8160f4821b6691e9682ef60c7cd7b">neorv32_cpu.c</a>, <a class="el" href="neorv32__cpu_8h.html#ad4f8160f4821b6691e9682ef60c7cd7b">neorv32_cpu.h</a></li> +<li>neorv32_cpu_pmp_get_num_regions()&#160;:&#160;<a class="el" href="neorv32__cpu_8c.html#a27dd614bc270dfa30ed73323ebda2d2d">neorv32_cpu.c</a>, <a class="el" href="neorv32__cpu_8h.html#a27dd614bc270dfa30ed73323ebda2d2d">neorv32_cpu.h</a></li> +<li>neorv32_cpu_set_mcycle()&#160;:&#160;<a class="el" href="neorv32__cpu_8c.html#a232d0290c459dc790d989fcdc4d121bf">neorv32_cpu.c</a>, <a class="el" href="neorv32__cpu_8h.html#a232d0290c459dc790d989fcdc4d121bf">neorv32_cpu.h</a></li> +<li>neorv32_cpu_set_minstret()&#160;:&#160;<a class="el" href="neorv32__cpu_8c.html#a5c3cf52498abb3cf3c14a724b287ecf0">neorv32_cpu.c</a>, <a class="el" href="neorv32__cpu_8h.html#a5c3cf52498abb3cf3c14a724b287ecf0">neorv32_cpu.h</a></li> +<li>neorv32_cpu_sleep()&#160;:&#160;<a class="el" href="neorv32__cpu_8h.html#a769ca4556213619f6fea4ff6bfb979dd">neorv32_cpu.h</a></li> +<li>neorv32_cpu_store_unsigned_byte()&#160;:&#160;<a class="el" href="neorv32__cpu_8h.html#aeec8ad2a82885c40a307346f9003483e">neorv32_cpu.h</a></li> +<li>neorv32_cpu_store_unsigned_half()&#160;:&#160;<a class="el" href="neorv32__cpu_8h.html#a31f30f6d6542758cd3073a9939b07653">neorv32_cpu.h</a></li> +<li>neorv32_cpu_store_unsigned_word()&#160;:&#160;<a class="el" href="neorv32__cpu_8h.html#a173bb06b4ae9c8964469068dafcb7b0e">neorv32_cpu.h</a></li> +<li>NEORV32_CRC&#160;:&#160;<a class="el" href="neorv32__crc_8h.html#a110962d2b370f9d7997e459d9fd34271">neorv32_crc.h</a></li> +<li>neorv32_crc_available()&#160;:&#160;<a class="el" href="neorv32__crc_8c.html#aa46c647317752f8bb6d5836d4876a704">neorv32_crc.c</a>, <a class="el" href="neorv32__crc_8h.html#aa46c647317752f8bb6d5836d4876a704">neorv32_crc.h</a></li> +<li>NEORV32_CRC_BASE&#160;:&#160;<a class="el" href="neorv32_8h.html#a0e2377055bdc0f416b5ae4385610600d">neorv32.h</a></li> +<li>neorv32_crc_block()&#160;:&#160;<a class="el" href="neorv32__crc_8c.html#a9243006e6cc94c03450646d26a7289b2">neorv32_crc.c</a>, <a class="el" href="neorv32__crc_8h.html#a9243006e6cc94c03450646d26a7289b2">neorv32_crc.h</a></li> +<li>neorv32_crc_get()&#160;:&#160;<a class="el" href="neorv32__crc_8c.html#a444b88f1536f65acc301fb19eddcf227">neorv32_crc.c</a>, <a class="el" href="neorv32__crc_8h.html#a444b88f1536f65acc301fb19eddcf227">neorv32_crc.h</a></li> +<li>NEORV32_CRC_MODE_enum&#160;:&#160;<a class="el" href="neorv32__crc_8h.html#a1ae84a58f475bafc2fc3f2c690fd6447">neorv32_crc.h</a></li> +<li>neorv32_crc_setup()&#160;:&#160;<a class="el" href="neorv32__crc_8c.html#a4ff5f7b91e9f668535ed33b6382ae623">neorv32_crc.c</a>, <a class="el" href="neorv32__crc_8h.html#a4ff5f7b91e9f668535ed33b6382ae623">neorv32_crc.h</a></li> +<li>neorv32_crc_single()&#160;:&#160;<a class="el" href="neorv32__crc_8c.html#ad9d50c76a485160667d486bce32cbeb8">neorv32_crc.c</a>, <a class="el" href="neorv32__crc_8h.html#ad9d50c76a485160667d486bce32cbeb8">neorv32_crc.h</a></li> +<li>NEORV32_CSR_enum&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49">neorv32_cpu_csr.h</a></li> +<li>NEORV32_CSR_FFLAGS_enum&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#afde0761e3150d82511136f56179c204b">neorv32_cpu_csr.h</a></li> +<li>NEORV32_CSR_MCOUNTINHIBIT_enum&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfe">neorv32_cpu_csr.h</a></li> +<li>NEORV32_CSR_MIE_enum&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33">neorv32_cpu_csr.h</a></li> +<li>NEORV32_CSR_MIP_enum&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21b">neorv32_cpu_csr.h</a></li> +<li>NEORV32_CSR_MISA_enum&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830c">neorv32_cpu_csr.h</a></li> +<li>NEORV32_CSR_MSTATUS_enum&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a76b70a2334131e7589d84c1ee96de485">neorv32_cpu_csr.h</a></li> +<li>NEORV32_CSR_XISA_enum&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387">neorv32_cpu_csr.h</a></li> +<li>NEORV32_DM_BASE&#160;:&#160;<a class="el" href="neorv32_8h.html#a9bf0149681677f7d87abf8f62e2d9a3d">neorv32.h</a></li> +<li>NEORV32_DMA&#160;:&#160;<a class="el" href="neorv32__dma_8h.html#a0dcb61a0e0d2b45beb7818015adc8639">neorv32_dma.h</a></li> +<li>neorv32_dma_available()&#160;:&#160;<a class="el" href="neorv32__dma_8h.html#a13260c3252f0375d8982590d270d7dfd">neorv32_dma.h</a></li> +<li>NEORV32_DMA_BASE&#160;:&#160;<a class="el" href="neorv32_8h.html#aa8d3a83ffad1e71f0832a5da78d62008">neorv32.h</a></li> +<li>NEORV32_DMA_CTRL_enum&#160;:&#160;<a class="el" href="neorv32__dma_8h.html#a6716eddb145b80ad38799da3b87cb2a4">neorv32_dma.h</a></li> +<li>neorv32_dma_disable()&#160;:&#160;<a class="el" href="neorv32__dma_8h.html#a6df244028455cf7f8d4cf1520c4670a7">neorv32_dma.h</a></li> +<li>neorv32_dma_done()&#160;:&#160;<a class="el" href="neorv32__dma_8h.html#afc8cc32f7d80d0f5ab33b2f1ecf77956">neorv32_dma.h</a></li> +<li>neorv32_dma_enable()&#160;:&#160;<a class="el" href="neorv32__dma_8h.html#ac3b72447e8a132faf26577ac714b8284">neorv32_dma.h</a></li> +<li>neorv32_dma_fence_disable()&#160;:&#160;<a class="el" href="neorv32__dma_8h.html#a8f37adfa07050b0a1cb8430c9ce1fcc2">neorv32_dma.h</a></li> +<li>neorv32_dma_fence_enable()&#160;:&#160;<a class="el" href="neorv32__dma_8h.html#a2c7257567ccdb7a986f5ef7c74d3917c">neorv32_dma.h</a></li> +<li>neorv32_dma_status()&#160;:&#160;<a class="el" href="neorv32__dma_8h.html#aa116f9714174abbe8a3583e441fee24b">neorv32_dma.h</a></li> +<li>NEORV32_DMA_STATUS_enum&#160;:&#160;<a class="el" href="neorv32__dma_8h.html#a002cb188ea5156df0ba282e239a6e74b">neorv32_dma.h</a></li> +<li>neorv32_dma_transfer()&#160;:&#160;<a class="el" href="neorv32__dma_8h.html#a2ce0d31e04604b2523135d52a877febf">neorv32_dma.h</a></li> +<li>neorv32_dma_transfer_auto()&#160;:&#160;<a class="el" href="neorv32__dma_8h.html#a6ebd1595ee6fa0e6cbfbd1ce7476f18e">neorv32_dma.h</a></li> +<li>NEORV32_DMA_TTYPE_enum&#160;:&#160;<a class="el" href="neorv32__dma_8h.html#a33187c5a074d62b46d2262e352edb8d9">neorv32_dma.h</a></li> +<li>NEORV32_EXCEPTION_CODES_enum&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1">neorv32_cpu_csr.h</a></li> +<li>NEORV32_EXECUTABLE_enum&#160;:&#160;<a class="el" href="bootloader_8c.html#a165a347c51d8aae06a564a2f297f2feb">bootloader.c</a></li> +<li>NEORV32_GPIO&#160;:&#160;<a class="el" href="neorv32__gpio_8h.html#a1e35bbf26b9d1aa5373af0b9468eb445">neorv32_gpio.h</a></li> +<li>neorv32_gpio_available()&#160;:&#160;<a class="el" href="neorv32__gpio_8c.html#a41d39a41ba5879eb85d3ed4481fcff81">neorv32_gpio.c</a>, <a class="el" href="neorv32__gpio_8h.html#a41d39a41ba5879eb85d3ed4481fcff81">neorv32_gpio.h</a></li> +<li>NEORV32_GPIO_BASE&#160;:&#160;<a class="el" href="neorv32_8h.html#a7fd1e24d4de2eed7bf9cd5391562c7f4">neorv32.h</a></li> +<li>neorv32_gpio_pin_get()&#160;:&#160;<a class="el" href="neorv32__gpio_8c.html#afa3ee54aca47ff35f706b627ac66e95a">neorv32_gpio.c</a>, <a class="el" href="neorv32__gpio_8h.html#afa3ee54aca47ff35f706b627ac66e95a">neorv32_gpio.h</a></li> +<li>neorv32_gpio_pin_set()&#160;:&#160;<a class="el" href="neorv32__gpio_8c.html#a60fd0830d634f0c1f784d815384665cb">neorv32_gpio.c</a>, <a class="el" href="neorv32__gpio_8h.html#a60fd0830d634f0c1f784d815384665cb">neorv32_gpio.h</a></li> +<li>neorv32_gpio_pin_toggle()&#160;:&#160;<a class="el" href="neorv32__gpio_8c.html#a1958850fc1689eae9ddfcaa4a7513400">neorv32_gpio.c</a>, <a class="el" href="neorv32__gpio_8h.html#a1958850fc1689eae9ddfcaa4a7513400">neorv32_gpio.h</a></li> +<li>neorv32_gpio_port_get()&#160;:&#160;<a class="el" href="neorv32__gpio_8c.html#ac42379f2fb5ca0bb63850d7957852b84">neorv32_gpio.c</a>, <a class="el" href="neorv32__gpio_8h.html#ac42379f2fb5ca0bb63850d7957852b84">neorv32_gpio.h</a></li> +<li>neorv32_gpio_port_set()&#160;:&#160;<a class="el" href="neorv32__gpio_8c.html#a8dc7846945e4609fc96d81caee99ac00">neorv32_gpio.c</a>, <a class="el" href="neorv32__gpio_8h.html#a789222709485cd8467aad5eddf69d2df">neorv32_gpio.h</a></li> +<li>neorv32_gpio_port_toggle()&#160;:&#160;<a class="el" href="neorv32__gpio_8c.html#a210529f789779387d3f014e6253e803f">neorv32_gpio.c</a>, <a class="el" href="neorv32__gpio_8h.html#a210529f789779387d3f014e6253e803f">neorv32_gpio.h</a></li> +<li>NEORV32_GPTMR&#160;:&#160;<a class="el" href="neorv32__gptmr_8h.html#a9e047791588ff21fc4dc1b06456bdfd2">neorv32_gptmr.h</a></li> +<li>neorv32_gptmr_available()&#160;:&#160;<a class="el" href="neorv32__gptmr_8c.html#ae79a08c52ad3e83f9c4393acfabf035f">neorv32_gptmr.c</a>, <a class="el" href="neorv32__gptmr_8h.html#ae79a08c52ad3e83f9c4393acfabf035f">neorv32_gptmr.h</a></li> +<li>NEORV32_GPTMR_BASE&#160;:&#160;<a class="el" href="neorv32_8h.html#a0991b1a5ba1e8c3550eb9770d43589d0">neorv32.h</a></li> +<li>NEORV32_GPTMR_CTRL_enum&#160;:&#160;<a class="el" href="neorv32__gptmr_8h.html#a135b0750d4afed16e5867134e3843988">neorv32_gptmr.h</a></li> +<li>neorv32_gptmr_disable()&#160;:&#160;<a class="el" href="neorv32__gptmr_8c.html#a7c9bc6d28ad12611b08fa2867c2db874">neorv32_gptmr.c</a>, <a class="el" href="neorv32__gptmr_8h.html#a7c9bc6d28ad12611b08fa2867c2db874">neorv32_gptmr.h</a></li> +<li>neorv32_gptmr_enable()&#160;:&#160;<a class="el" href="neorv32__gptmr_8c.html#a59e684348835772a7e83446e478d4a13">neorv32_gptmr.c</a>, <a class="el" href="neorv32__gptmr_8h.html#a59e684348835772a7e83446e478d4a13">neorv32_gptmr.h</a></li> +<li>neorv32_gptmr_irq_ack()&#160;:&#160;<a class="el" href="neorv32__gptmr_8c.html#ac73aa4e41a064abb4ca554a389888e67">neorv32_gptmr.c</a>, <a class="el" href="neorv32__gptmr_8h.html#ac73aa4e41a064abb4ca554a389888e67">neorv32_gptmr.h</a></li> +<li>neorv32_gptmr_setup()&#160;:&#160;<a class="el" href="neorv32__gptmr_8c.html#a6aa27efd2163eebf8fc49fe1c591708f">neorv32_gptmr.c</a>, <a class="el" href="neorv32__gptmr_8h.html#a6aa27efd2163eebf8fc49fe1c591708f">neorv32_gptmr.h</a></li> +<li>NEORV32_HPMCNT_EVENT_enum&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfe">neorv32_cpu_csr.h</a></li> +<li>NEORV32_MTIME&#160;:&#160;<a class="el" href="neorv32__mtime_8h.html#a68935be182e0081039326a9f344a36b3">neorv32_mtime.h</a></li> +<li>neorv32_mtime_available()&#160;:&#160;<a class="el" href="neorv32__mtime_8c.html#ab2b49a0594c66692aedf76ff9935581c">neorv32_mtime.c</a>, <a class="el" href="neorv32__mtime_8h.html#ab2b49a0594c66692aedf76ff9935581c">neorv32_mtime.h</a></li> +<li>NEORV32_MTIME_BASE&#160;:&#160;<a class="el" href="neorv32_8h.html#ab98f762df259a2bbc28d19d2acfe9e23">neorv32.h</a></li> +<li>neorv32_mtime_get_time()&#160;:&#160;<a class="el" href="neorv32__mtime_8c.html#adedbbdeb71c06d2d60d3af73451de01e">neorv32_mtime.c</a>, <a class="el" href="neorv32__mtime_8h.html#adedbbdeb71c06d2d60d3af73451de01e">neorv32_mtime.h</a></li> +<li>neorv32_mtime_get_timecmp()&#160;:&#160;<a class="el" href="neorv32__mtime_8c.html#acb3cc18ff8421ebd6ef471e089c23491">neorv32_mtime.c</a>, <a class="el" href="neorv32__mtime_8h.html#acb3cc18ff8421ebd6ef471e089c23491">neorv32_mtime.h</a></li> +<li>neorv32_mtime_get_unixtime()&#160;:&#160;<a class="el" href="neorv32__mtime_8c.html#a50d08fcc3d91fc2d88b9a6a80c656f1a">neorv32_mtime.c</a>, <a class="el" href="neorv32__mtime_8h.html#a50d08fcc3d91fc2d88b9a6a80c656f1a">neorv32_mtime.h</a></li> +<li>neorv32_mtime_set_time()&#160;:&#160;<a class="el" href="neorv32__mtime_8c.html#a1c30809d6e887f022a7794f720243015">neorv32_mtime.c</a>, <a class="el" href="neorv32__mtime_8h.html#a1c30809d6e887f022a7794f720243015">neorv32_mtime.h</a></li> +<li>neorv32_mtime_set_timecmp()&#160;:&#160;<a class="el" href="neorv32__mtime_8c.html#a81ff371c1aa10901264873316ee84a49">neorv32_mtime.c</a>, <a class="el" href="neorv32__mtime_8h.html#a81ff371c1aa10901264873316ee84a49">neorv32_mtime.h</a></li> +<li>neorv32_mtime_set_unixtime()&#160;:&#160;<a class="el" href="neorv32__mtime_8c.html#a022c3292c6e75095bb3ffd4c42fd4bfa">neorv32_mtime.c</a>, <a class="el" href="neorv32__mtime_8h.html#a022c3292c6e75095bb3ffd4c42fd4bfa">neorv32_mtime.h</a></li> +<li>NEORV32_NEOLED&#160;:&#160;<a class="el" href="neorv32__neoled_8h.html#a3ccc1097bc70f92235d693b612fa994a">neorv32_neoled.h</a></li> +<li>neorv32_neoled_available()&#160;:&#160;<a class="el" href="neorv32__neoled_8c.html#a57398d92fb4fc735b33e89271726e1d6">neorv32_neoled.c</a>, <a class="el" href="neorv32__neoled_8h.html#a57398d92fb4fc735b33e89271726e1d6">neorv32_neoled.h</a></li> +<li>NEORV32_NEOLED_BASE&#160;:&#160;<a class="el" href="neorv32_8h.html#a559fdce92e8af5efc426c8fc48d14f99">neorv32.h</a></li> +<li>NEORV32_NEOLED_CTRL_enum&#160;:&#160;<a class="el" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412">neorv32_neoled.h</a></li> +<li>neorv32_neoled_disable()&#160;:&#160;<a class="el" href="neorv32__neoled_8c.html#a8daaa97a85e0eb94d4a38eb2119ea183">neorv32_neoled.c</a>, <a class="el" href="neorv32__neoled_8h.html#a8daaa97a85e0eb94d4a38eb2119ea183">neorv32_neoled.h</a></li> +<li>neorv32_neoled_enable()&#160;:&#160;<a class="el" href="neorv32__neoled_8c.html#a8181d5c1d15b7b5eecdc018341ac14fa">neorv32_neoled.c</a>, <a class="el" href="neorv32__neoled_8h.html#a8181d5c1d15b7b5eecdc018341ac14fa">neorv32_neoled.h</a></li> +<li>neorv32_neoled_get_buffer_size()&#160;:&#160;<a class="el" href="neorv32__neoled_8c.html#a81c2c49198531fb6551eb288e29c084e">neorv32_neoled.c</a>, <a class="el" href="neorv32__neoled_8h.html#a81c2c49198531fb6551eb288e29c084e">neorv32_neoled.h</a></li> +<li>neorv32_neoled_set_mode()&#160;:&#160;<a class="el" href="neorv32__neoled_8c.html#a484fcc6797b6d9cef86192e9593ec33d">neorv32_neoled.c</a>, <a class="el" href="neorv32__neoled_8h.html#a484fcc6797b6d9cef86192e9593ec33d">neorv32_neoled.h</a></li> +<li>neorv32_neoled_setup()&#160;:&#160;<a class="el" href="neorv32__neoled_8c.html#ac6e94602453779a2791bd0734465f5a3">neorv32_neoled.c</a>, <a class="el" href="neorv32__neoled_8h.html#ac6e94602453779a2791bd0734465f5a3">neorv32_neoled.h</a></li> +<li>neorv32_neoled_setup_ws2812()&#160;:&#160;<a class="el" href="neorv32__neoled_8c.html#adade69c7368c28180b9992d5f0ab6031">neorv32_neoled.c</a>, <a class="el" href="neorv32__neoled_8h.html#adade69c7368c28180b9992d5f0ab6031">neorv32_neoled.h</a></li> +<li>neorv32_neoled_strobe_blocking()&#160;:&#160;<a class="el" href="neorv32__neoled_8c.html#a5aa9eb4dd3655fa08e1b61eb0f36589c">neorv32_neoled.c</a>, <a class="el" href="neorv32__neoled_8h.html#a5aa9eb4dd3655fa08e1b61eb0f36589c">neorv32_neoled.h</a></li> +<li>neorv32_neoled_strobe_nonblocking()&#160;:&#160;<a class="el" href="neorv32__neoled_8c.html#abf7882b949373df0774fc9cc20c2bd2e">neorv32_neoled.c</a>, <a class="el" href="neorv32__neoled_8h.html#abf7882b949373df0774fc9cc20c2bd2e">neorv32_neoled.h</a></li> +<li>neorv32_neoled_write_blocking()&#160;:&#160;<a class="el" href="neorv32__neoled_8c.html#a3ee5b3602da3ae982628e2802587e451">neorv32_neoled.c</a>, <a class="el" href="neorv32__neoled_8h.html#a3ee5b3602da3ae982628e2802587e451">neorv32_neoled.h</a></li> +<li>neorv32_neoled_write_nonblocking()&#160;:&#160;<a class="el" href="neorv32__neoled_8h.html#ad2a318bd59be12de34797ced0f7743c6">neorv32_neoled.h</a></li> +<li>NEORV32_ONEWIRE&#160;:&#160;<a class="el" href="neorv32__onewire_8h.html#a6f119e35d7ac01f110987508ff3becc9">neorv32_onewire.h</a></li> +<li>neorv32_onewire_available()&#160;:&#160;<a class="el" href="neorv32__onewire_8c.html#a865e5c381fd3c27c6981a589a5124d1e">neorv32_onewire.c</a>, <a class="el" href="neorv32__onewire_8h.html#a865e5c381fd3c27c6981a589a5124d1e">neorv32_onewire.h</a></li> +<li>NEORV32_ONEWIRE_BASE&#160;:&#160;<a class="el" href="neorv32_8h.html#a8d0b612e52b77395a05d4f18af6fcf00">neorv32.h</a></li> +<li>neorv32_onewire_busy()&#160;:&#160;<a class="el" href="neorv32__onewire_8c.html#a01b6236b89c045ddbd58398361c6ee0a">neorv32_onewire.c</a>, <a class="el" href="neorv32__onewire_8h.html#a01b6236b89c045ddbd58398361c6ee0a">neorv32_onewire.h</a></li> +<li>NEORV32_ONEWIRE_CTRL_enum&#160;:&#160;<a class="el" href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831">neorv32_onewire.h</a></li> +<li>NEORV32_ONEWIRE_DATA_enum&#160;:&#160;<a class="el" href="neorv32__onewire_8h.html#ae770490afa8662fb8577065531d51368">neorv32_onewire.h</a></li> +<li>neorv32_onewire_disable()&#160;:&#160;<a class="el" href="neorv32__onewire_8c.html#a7e329eeb1cd98301a53b271a6a102385">neorv32_onewire.c</a>, <a class="el" href="neorv32__onewire_8h.html#a7e329eeb1cd98301a53b271a6a102385">neorv32_onewire.h</a></li> +<li>neorv32_onewire_enable()&#160;:&#160;<a class="el" href="neorv32__onewire_8c.html#ae6fe766e7decf18869cfb86bba741ca4">neorv32_onewire.c</a>, <a class="el" href="neorv32__onewire_8h.html#ae6fe766e7decf18869cfb86bba741ca4">neorv32_onewire.h</a></li> +<li>neorv32_onewire_read_bit()&#160;:&#160;<a class="el" href="neorv32__onewire_8c.html#aace8398062b759256a516e6245aced83">neorv32_onewire.c</a>, <a class="el" href="neorv32__onewire_8h.html#aace8398062b759256a516e6245aced83">neorv32_onewire.h</a></li> +<li>neorv32_onewire_read_bit_blocking()&#160;:&#160;<a class="el" href="neorv32__onewire_8c.html#ace8b7cf697b068b6b51676d84dec5960">neorv32_onewire.c</a>, <a class="el" href="neorv32__onewire_8h.html#ace8b7cf697b068b6b51676d84dec5960">neorv32_onewire.h</a></li> +<li>neorv32_onewire_read_bit_get()&#160;:&#160;<a class="el" href="neorv32__onewire_8c.html#aa4a19d2d8dc3b3401307615aec201190">neorv32_onewire.c</a>, <a class="el" href="neorv32__onewire_8h.html#aa4a19d2d8dc3b3401307615aec201190">neorv32_onewire.h</a></li> +<li>neorv32_onewire_read_byte()&#160;:&#160;<a class="el" href="neorv32__onewire_8c.html#a01ddba7a9148be542b5c52e39e6f46d6">neorv32_onewire.c</a>, <a class="el" href="neorv32__onewire_8h.html#a01ddba7a9148be542b5c52e39e6f46d6">neorv32_onewire.h</a></li> +<li>neorv32_onewire_read_byte_blocking()&#160;:&#160;<a class="el" href="neorv32__onewire_8c.html#a7510e65a26aeefb40e994fd00667537e">neorv32_onewire.c</a>, <a class="el" href="neorv32__onewire_8h.html#a7510e65a26aeefb40e994fd00667537e">neorv32_onewire.h</a></li> +<li>neorv32_onewire_read_byte_get()&#160;:&#160;<a class="el" href="neorv32__onewire_8c.html#a4c7eec15c095c97c939163f631f51dab">neorv32_onewire.c</a>, <a class="el" href="neorv32__onewire_8h.html#a4c7eec15c095c97c939163f631f51dab">neorv32_onewire.h</a></li> +<li>neorv32_onewire_reset()&#160;:&#160;<a class="el" href="neorv32__onewire_8c.html#a3072f7167831edc95dee44ecfef6a0d4">neorv32_onewire.c</a>, <a class="el" href="neorv32__onewire_8h.html#a3072f7167831edc95dee44ecfef6a0d4">neorv32_onewire.h</a></li> +<li>neorv32_onewire_reset_blocking()&#160;:&#160;<a class="el" href="neorv32__onewire_8c.html#af8ca6be495176797b7da3857e2f794f9">neorv32_onewire.c</a>, <a class="el" href="neorv32__onewire_8h.html#af8ca6be495176797b7da3857e2f794f9">neorv32_onewire.h</a></li> +<li>neorv32_onewire_reset_get_presence()&#160;:&#160;<a class="el" href="neorv32__onewire_8c.html#a43eb8a08eeaa83e3d7e9aa5058a4269f">neorv32_onewire.c</a>, <a class="el" href="neorv32__onewire_8h.html#a43eb8a08eeaa83e3d7e9aa5058a4269f">neorv32_onewire.h</a></li> +<li>neorv32_onewire_sense()&#160;:&#160;<a class="el" href="neorv32__onewire_8c.html#a122531c7154126858c46d89e003d838d">neorv32_onewire.c</a>, <a class="el" href="neorv32__onewire_8h.html#a122531c7154126858c46d89e003d838d">neorv32_onewire.h</a></li> +<li>neorv32_onewire_setup()&#160;:&#160;<a class="el" href="neorv32__onewire_8c.html#a224005037387484dfa510a1355a62828">neorv32_onewire.c</a>, <a class="el" href="neorv32__onewire_8h.html#a224005037387484dfa510a1355a62828">neorv32_onewire.h</a></li> +<li>neorv32_onewire_write_bit()&#160;:&#160;<a class="el" href="neorv32__onewire_8c.html#a49d0a2a386f129fd2f4fed880bba31d4">neorv32_onewire.c</a>, <a class="el" href="neorv32__onewire_8h.html#a49d0a2a386f129fd2f4fed880bba31d4">neorv32_onewire.h</a></li> +<li>neorv32_onewire_write_bit_blocking()&#160;:&#160;<a class="el" href="neorv32__onewire_8c.html#a6f7b6690a2437e0b574a8a9a23dc0eaa">neorv32_onewire.c</a>, <a class="el" href="neorv32__onewire_8h.html#a6f7b6690a2437e0b574a8a9a23dc0eaa">neorv32_onewire.h</a></li> +<li>neorv32_onewire_write_byte()&#160;:&#160;<a class="el" href="neorv32__onewire_8c.html#a23b96b68c3214b188525eb102cafb620">neorv32_onewire.c</a>, <a class="el" href="neorv32__onewire_8h.html#a23b96b68c3214b188525eb102cafb620">neorv32_onewire.h</a></li> +<li>neorv32_onewire_write_byte_blocking()&#160;:&#160;<a class="el" href="neorv32__onewire_8c.html#ac78557c77482b59394677f42fda4fdf1">neorv32_onewire.c</a>, <a class="el" href="neorv32__onewire_8h.html#ac78557c77482b59394677f42fda4fdf1">neorv32_onewire.h</a></li> +<li>NEORV32_PMP_MODES_enum&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a8f2418fb5e2175f35ee2362469ce01f5">neorv32_cpu_csr.h</a></li> +<li>NEORV32_PMPCFG_ATTRIBUTES_enum&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#abc0e8daad1e9beda4d9950452cc930ea">neorv32_cpu_csr.h</a></li> +<li>neorv32_pmw_get_num_channels()&#160;:&#160;<a class="el" href="neorv32__pwm_8c.html#a43d8a47dc79ebac24c8a7d2d8247d2a5">neorv32_pwm.c</a>, <a class="el" href="neorv32__pwm_8h.html#a43d8a47dc79ebac24c8a7d2d8247d2a5">neorv32_pwm.h</a></li> +<li>NEORV32_PWM&#160;:&#160;<a class="el" href="neorv32__pwm_8h.html#ad4cb534c29e26fa56c10bef7afab8f51">neorv32_pwm.h</a></li> +<li>neorv32_pwm_available()&#160;:&#160;<a class="el" href="neorv32__pwm_8c.html#afb12c860b2f7fa6cd1e069ea540da41c">neorv32_pwm.c</a>, <a class="el" href="neorv32__pwm_8h.html#afb12c860b2f7fa6cd1e069ea540da41c">neorv32_pwm.h</a></li> +<li>NEORV32_PWM_BASE&#160;:&#160;<a class="el" href="neorv32_8h.html#afef7a6b121a788560b29e2ee2a58c725">neorv32.h</a></li> +<li>NEORV32_PWM_CTRL_enum&#160;:&#160;<a class="el" href="neorv32__pwm_8h.html#af350f93b601a92ef56516198d1570b7d">neorv32_pwm.h</a></li> +<li>neorv32_pwm_disable()&#160;:&#160;<a class="el" href="neorv32__pwm_8c.html#a8f16fdc6e048899305a3234f42fe272f">neorv32_pwm.c</a>, <a class="el" href="neorv32__pwm_8h.html#a8f16fdc6e048899305a3234f42fe272f">neorv32_pwm.h</a></li> +<li>neorv32_pwm_enable()&#160;:&#160;<a class="el" href="neorv32__pwm_8c.html#abc62a63dc139b185cdf53d0267501288">neorv32_pwm.c</a>, <a class="el" href="neorv32__pwm_8h.html#abc62a63dc139b185cdf53d0267501288">neorv32_pwm.h</a></li> +<li>neorv32_pwm_get()&#160;:&#160;<a class="el" href="neorv32__pwm_8c.html#a64f66ae4f9689a650a70f3c5b45802b6">neorv32_pwm.c</a>, <a class="el" href="neorv32__pwm_8h.html#a64f66ae4f9689a650a70f3c5b45802b6">neorv32_pwm.h</a></li> +<li>neorv32_pwm_set()&#160;:&#160;<a class="el" href="neorv32__pwm_8c.html#aa24bc867effa7756bfbe7818d85aface">neorv32_pwm.c</a>, <a class="el" href="neorv32__pwm_8h.html#aa24bc867effa7756bfbe7818d85aface">neorv32_pwm.h</a></li> +<li>neorv32_pwm_setup()&#160;:&#160;<a class="el" href="neorv32__pwm_8c.html#a5502d483de07d2d8c42e2388ed987069">neorv32_pwm.c</a>, <a class="el" href="neorv32__pwm_8h.html#a5502d483de07d2d8c42e2388ed987069">neorv32_pwm.h</a></li> +<li>neorv32_rte_context_get()&#160;:&#160;<a class="el" href="neorv32__rte_8c.html#a65e71acc8916b42b59dc2cf6bba30ba3">neorv32_rte.c</a>, <a class="el" href="neorv32__rte_8h.html#a65e71acc8916b42b59dc2cf6bba30ba3">neorv32_rte.h</a></li> +<li>neorv32_rte_context_put()&#160;:&#160;<a class="el" href="neorv32__rte_8c.html#ae13a9c1fd59ad71afb0d47cf9a0b303e">neorv32_rte.c</a>, <a class="el" href="neorv32__rte_8h.html#ae13a9c1fd59ad71afb0d47cf9a0b303e">neorv32_rte.h</a></li> +<li>neorv32_rte_debug_handler()&#160;:&#160;<a class="el" href="neorv32__rte_8c.html#a65422bb44f1e7bc011e9bfc5d8451ebe">neorv32_rte.c</a>, <a class="el" href="neorv32__rte_8h.html#a65422bb44f1e7bc011e9bfc5d8451ebe">neorv32_rte.h</a></li> +<li>neorv32_rte_handler_install()&#160;:&#160;<a class="el" href="neorv32__rte_8c.html#a2cf31cfa569a03a20d554b6400c4c5e2">neorv32_rte.c</a>, <a class="el" href="neorv32__rte_8h.html#a2cf31cfa569a03a20d554b6400c4c5e2">neorv32_rte.h</a></li> +<li>neorv32_rte_handler_uninstall()&#160;:&#160;<a class="el" href="neorv32__rte_8c.html#a10fde6229bf391e46148405616404a65">neorv32_rte.c</a>, <a class="el" href="neorv32__rte_8h.html#a10fde6229bf391e46148405616404a65">neorv32_rte.h</a></li> +<li>NEORV32_RTE_NUM_TRAPS&#160;:&#160;<a class="el" href="neorv32__rte_8h.html#ad14a1ca41df1e9300bfd01aef07dce59">neorv32_rte.h</a></li> +<li>neorv32_rte_print_about()&#160;:&#160;<a class="el" href="neorv32__rte_8c.html#aa442c0e39f9156a131c3432fda587692">neorv32_rte.c</a>, <a class="el" href="neorv32__rte_8h.html#aa442c0e39f9156a131c3432fda587692">neorv32_rte.h</a></li> +<li>neorv32_rte_print_hw_config()&#160;:&#160;<a class="el" href="neorv32__rte_8c.html#a05e8304963e402d228a76aff1868771c">neorv32_rte.c</a>, <a class="el" href="neorv32__rte_8h.html#a05e8304963e402d228a76aff1868771c">neorv32_rte.h</a></li> +<li>neorv32_rte_print_hw_version()&#160;:&#160;<a class="el" href="neorv32__rte_8c.html#aad6f5256a265807c4cde163bcba8dae9">neorv32_rte.c</a>, <a class="el" href="neorv32__rte_8h.html#aad6f5256a265807c4cde163bcba8dae9">neorv32_rte.h</a></li> +<li>neorv32_rte_print_license()&#160;:&#160;<a class="el" href="neorv32__rte_8c.html#acd96aa73eebe6d4bbc9aabe1230cbabc">neorv32_rte.c</a>, <a class="el" href="neorv32__rte_8h.html#acd96aa73eebe6d4bbc9aabe1230cbabc">neorv32_rte.h</a></li> +<li>neorv32_rte_print_logo()&#160;:&#160;<a class="el" href="neorv32__rte_8c.html#a16df1b48f2e1258a51d3bb7f49531cf3">neorv32_rte.c</a>, <a class="el" href="neorv32__rte_8h.html#a16df1b48f2e1258a51d3bb7f49531cf3">neorv32_rte.h</a></li> +<li>neorv32_rte_setup()&#160;:&#160;<a class="el" href="neorv32__rte_8c.html#a343e1913bdc37db9b168fb4def0e6170">neorv32_rte.c</a>, <a class="el" href="neorv32__rte_8h.html#a343e1913bdc37db9b168fb4def0e6170">neorv32_rte.h</a></li> +<li>NEORV32_RTE_TRAP_enum&#160;:&#160;<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70a">neorv32_rte.h</a></li> +<li>NEORV32_SDI&#160;:&#160;<a class="el" href="neorv32__sdi_8h.html#afd0921633d6523d9b7235055e9bbf928">neorv32_sdi.h</a></li> +<li>neorv32_sdi_available()&#160;:&#160;<a class="el" href="neorv32__sdi_8c.html#a51412722efdb18cd09667622b215e825">neorv32_sdi.c</a>, <a class="el" href="neorv32__sdi_8h.html#a51412722efdb18cd09667622b215e825">neorv32_sdi.h</a></li> +<li>NEORV32_SDI_BASE&#160;:&#160;<a class="el" href="neorv32_8h.html#a9b316ec038bd94ada42c9dab57a0a3cb">neorv32.h</a></li> +<li>neorv32_sdi_check_cs()&#160;:&#160;<a class="el" href="neorv32__sdi_8c.html#a2636cf1959ce1f3eb4b77c00ca2e2707">neorv32_sdi.c</a>, <a class="el" href="neorv32__sdi_8h.html#a2636cf1959ce1f3eb4b77c00ca2e2707">neorv32_sdi.h</a></li> +<li>NEORV32_SDI_CTRL_enum&#160;:&#160;<a class="el" href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6">neorv32_sdi.h</a></li> +<li>neorv32_sdi_disable()&#160;:&#160;<a class="el" href="neorv32__sdi_8c.html#a8bd54bca8aea6147651c8115ee616f54">neorv32_sdi.c</a>, <a class="el" href="neorv32__sdi_8h.html#a8bd54bca8aea6147651c8115ee616f54">neorv32_sdi.h</a></li> +<li>neorv32_sdi_enable()&#160;:&#160;<a class="el" href="neorv32__sdi_8c.html#a5d68b9b1642baf3519076e55a22a8f61">neorv32_sdi.c</a>, <a class="el" href="neorv32__sdi_8h.html#a5d68b9b1642baf3519076e55a22a8f61">neorv32_sdi.h</a></li> +<li>neorv32_sdi_get()&#160;:&#160;<a class="el" href="neorv32__sdi_8c.html#a4d54ce22ec97eb83da118439576e3277">neorv32_sdi.c</a>, <a class="el" href="neorv32__sdi_8h.html#a4d54ce22ec97eb83da118439576e3277">neorv32_sdi.h</a></li> +<li>neorv32_sdi_get_fifo_depth()&#160;:&#160;<a class="el" href="neorv32__sdi_8c.html#a7390faeb01b4de3dd5ac18335736b90c">neorv32_sdi.c</a>, <a class="el" href="neorv32__sdi_8h.html#a7390faeb01b4de3dd5ac18335736b90c">neorv32_sdi.h</a></li> +<li>neorv32_sdi_put()&#160;:&#160;<a class="el" href="neorv32__sdi_8c.html#ac7a262d16c42bbac27723ff779545569">neorv32_sdi.c</a>, <a class="el" href="neorv32__sdi_8h.html#ac7a262d16c42bbac27723ff779545569">neorv32_sdi.h</a></li> +<li>neorv32_sdi_setup()&#160;:&#160;<a class="el" href="neorv32__sdi_8c.html#a3246118dc0d7e1f61bc2485bbab44149">neorv32_sdi.c</a>, <a class="el" href="neorv32__sdi_8h.html#a3246118dc0d7e1f61bc2485bbab44149">neorv32_sdi.h</a></li> +<li>NEORV32_SLINK&#160;:&#160;<a class="el" href="neorv32__slink_8h.html#a6380d894432de119a20993096db534df">neorv32_slink.h</a></li> +<li>neorv32_slink_available()&#160;:&#160;<a class="el" href="neorv32__slink_8c.html#aaf0f7bc96b797e819ccaae94292d9ddb">neorv32_slink.c</a>, <a class="el" href="neorv32__slink_8h.html#aaf0f7bc96b797e819ccaae94292d9ddb">neorv32_slink.h</a></li> +<li>NEORV32_SLINK_BASE&#160;:&#160;<a class="el" href="neorv32_8h.html#ab5e6dc57886cd5ed98b86f22fc37d7cc">neorv32.h</a></li> +<li>neorv32_slink_check_last()&#160;:&#160;<a class="el" href="neorv32__slink_8c.html#a3e02c558548c1c6178c49adee9a007f7">neorv32_slink.c</a>, <a class="el" href="neorv32__slink_8h.html#a3e02c558548c1c6178c49adee9a007f7">neorv32_slink.h</a></li> +<li>NEORV32_SLINK_CTRL_enum&#160;:&#160;<a class="el" href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1">neorv32_slink.h</a></li> +<li>neorv32_slink_get()&#160;:&#160;<a class="el" href="neorv32__slink_8c.html#ace319592c12dc6a0fe1b7dd66bdf9284">neorv32_slink.c</a>, <a class="el" href="neorv32__slink_8h.html#ace319592c12dc6a0fe1b7dd66bdf9284">neorv32_slink.h</a></li> +<li>neorv32_slink_get_rx_fifo_depth()&#160;:&#160;<a class="el" href="neorv32__slink_8c.html#a575c7663ca0bd07c95b1d45152a3ddf8">neorv32_slink.c</a>, <a class="el" href="neorv32__slink_8h.html#a575c7663ca0bd07c95b1d45152a3ddf8">neorv32_slink.h</a></li> +<li>neorv32_slink_get_src()&#160;:&#160;<a class="el" href="neorv32__slink_8c.html#a1a9269f42552a849450aecd99f7ec7a0">neorv32_slink.c</a>, <a class="el" href="neorv32__slink_8h.html#a1a9269f42552a849450aecd99f7ec7a0">neorv32_slink.h</a></li> +<li>neorv32_slink_get_tx_fifo_depth()&#160;:&#160;<a class="el" href="neorv32__slink_8c.html#aaf0d0d1b890353d4f3bf49450ec2fad2">neorv32_slink.c</a>, <a class="el" href="neorv32__slink_8h.html#aaf0d0d1b890353d4f3bf49450ec2fad2">neorv32_slink.h</a></li> +<li>neorv32_slink_put()&#160;:&#160;<a class="el" href="neorv32__slink_8c.html#aaa9fdb9cbfa7888e92790ab65431d21d">neorv32_slink.c</a>, <a class="el" href="neorv32__slink_8h.html#aaa9fdb9cbfa7888e92790ab65431d21d">neorv32_slink.h</a></li> +<li>neorv32_slink_put_last()&#160;:&#160;<a class="el" href="neorv32__slink_8c.html#a2136bc0b12ee2e6703e84a6417a1e8eb">neorv32_slink.c</a>, <a class="el" href="neorv32__slink_8h.html#a2136bc0b12ee2e6703e84a6417a1e8eb">neorv32_slink.h</a></li> +<li>NEORV32_SLINK_ROUTE_enum&#160;:&#160;<a class="el" href="neorv32__slink_8h.html#ac3e5e02fd89a357135adca6d28cd0e45">neorv32_slink.h</a></li> +<li>neorv32_slink_rx_clear()&#160;:&#160;<a class="el" href="neorv32__slink_8c.html#ad149fea81e6d28f77450b8ba50cf706e">neorv32_slink.c</a>, <a class="el" href="neorv32__slink_8h.html#ad149fea81e6d28f77450b8ba50cf706e">neorv32_slink.h</a></li> +<li>neorv32_slink_rx_status()&#160;:&#160;<a class="el" href="neorv32__slink_8c.html#ad57fc0941fe32e8bf423ce3e57e2c10a">neorv32_slink.c</a>, <a class="el" href="neorv32__slink_8h.html#ad57fc0941fe32e8bf423ce3e57e2c10a">neorv32_slink.h</a></li> +<li>neorv32_slink_set_dst()&#160;:&#160;<a class="el" href="neorv32__slink_8c.html#ad857d7e78ca2b5eb0d0a4f2c515fe7bc">neorv32_slink.c</a>, <a class="el" href="neorv32__slink_8h.html#ad857d7e78ca2b5eb0d0a4f2c515fe7bc">neorv32_slink.h</a></li> +<li>neorv32_slink_setup()&#160;:&#160;<a class="el" href="neorv32__slink_8c.html#a8f0b4a768f53a72a5c16034e160ce321">neorv32_slink.c</a>, <a class="el" href="neorv32__slink_8h.html#a8f0b4a768f53a72a5c16034e160ce321">neorv32_slink.h</a></li> +<li>NEORV32_SLINK_STATUS_enum&#160;:&#160;<a class="el" href="neorv32__slink_8h.html#a84f7fe82f188bd4e68f41549587822bf">neorv32_slink.h</a></li> +<li>neorv32_slink_tx_clear()&#160;:&#160;<a class="el" href="neorv32__slink_8c.html#ac7484e9e3848f94efe016dd064f6a57f">neorv32_slink.c</a>, <a class="el" href="neorv32__slink_8h.html#ac7484e9e3848f94efe016dd064f6a57f">neorv32_slink.h</a></li> +<li>neorv32_slink_tx_status()&#160;:&#160;<a class="el" href="neorv32__slink_8c.html#ad0252e7ae915e5840cd17e8c52e94a1c">neorv32_slink.c</a>, <a class="el" href="neorv32__slink_8h.html#ad0252e7ae915e5840cd17e8c52e94a1c">neorv32_slink.h</a></li> +<li>NEORV32_SPI&#160;:&#160;<a class="el" href="neorv32__spi_8h.html#a5f3afc4e268670c54d90df67fa38ca22">neorv32_spi.h</a></li> +<li>neorv32_spi_available()&#160;:&#160;<a class="el" href="neorv32__spi_8c.html#a7266ee439d0ec11c5cedd4bf1a258272">neorv32_spi.c</a>, <a class="el" href="neorv32__spi_8h.html#a7266ee439d0ec11c5cedd4bf1a258272">neorv32_spi.h</a></li> +<li>NEORV32_SPI_BASE&#160;:&#160;<a class="el" href="neorv32_8h.html#aa466dc5eace7351bd438606f0f7475a7">neorv32.h</a></li> +<li>neorv32_spi_busy()&#160;:&#160;<a class="el" href="neorv32__spi_8c.html#a332c7a1be511812ac0a2b102c165398a">neorv32_spi.c</a>, <a class="el" href="neorv32__spi_8h.html#a332c7a1be511812ac0a2b102c165398a">neorv32_spi.h</a></li> +<li>neorv32_spi_check_cs()&#160;:&#160;<a class="el" href="neorv32__spi_8c.html#a82bb4d4c222b2bdc57e917c348481501">neorv32_spi.c</a>, <a class="el" href="neorv32__spi_8h.html#a82bb4d4c222b2bdc57e917c348481501">neorv32_spi.h</a></li> +<li>neorv32_spi_cs_dis()&#160;:&#160;<a class="el" href="neorv32__spi_8c.html#aa10ec90ccba6325eeeebb8f6f298d30c">neorv32_spi.c</a>, <a class="el" href="neorv32__spi_8h.html#aa10ec90ccba6325eeeebb8f6f298d30c">neorv32_spi.h</a></li> +<li>neorv32_spi_cs_dis_nonblocking()&#160;:&#160;<a class="el" href="neorv32__spi_8c.html#ad8dd1b5a85a9daef4c8c21c9990884c1">neorv32_spi.c</a>, <a class="el" href="neorv32__spi_8h.html#ad8dd1b5a85a9daef4c8c21c9990884c1">neorv32_spi.h</a></li> +<li>neorv32_spi_cs_en()&#160;:&#160;<a class="el" href="neorv32__spi_8c.html#a737961d040ac09567350f89034f9e122">neorv32_spi.c</a>, <a class="el" href="neorv32__spi_8h.html#a737961d040ac09567350f89034f9e122">neorv32_spi.h</a></li> +<li>neorv32_spi_cs_en_nonblocking()&#160;:&#160;<a class="el" href="neorv32__spi_8c.html#a97b5536347a27b053f071ba49071ba6f">neorv32_spi.c</a>, <a class="el" href="neorv32__spi_8h.html#a97b5536347a27b053f071ba49071ba6f">neorv32_spi.h</a></li> +<li>NEORV32_SPI_CTRL_enum&#160;:&#160;<a class="el" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3b">neorv32_spi.h</a></li> +<li>NEORV32_SPI_DATA_enum&#160;:&#160;<a class="el" href="neorv32__spi_8h.html#aab478c23898c0b06cee53a1cbda38bf8">neorv32_spi.h</a></li> +<li>neorv32_spi_disable()&#160;:&#160;<a class="el" href="neorv32__spi_8c.html#a817dd9a38bfceb2048e40874a83ba169">neorv32_spi.c</a>, <a class="el" href="neorv32__spi_8h.html#a817dd9a38bfceb2048e40874a83ba169">neorv32_spi.h</a></li> +<li>neorv32_spi_enable()&#160;:&#160;<a class="el" href="neorv32__spi_8c.html#a8fa25d144ccb20a2faf0450c8dddd16e">neorv32_spi.c</a>, <a class="el" href="neorv32__spi_8h.html#a8fa25d144ccb20a2faf0450c8dddd16e">neorv32_spi.h</a></li> +<li>neorv32_spi_get_clock_speed()&#160;:&#160;<a class="el" href="neorv32__spi_8c.html#a01c6b63d7349447e2277f2649c3c89f2">neorv32_spi.c</a>, <a class="el" href="neorv32__spi_8h.html#a01c6b63d7349447e2277f2649c3c89f2">neorv32_spi.h</a></li> +<li>neorv32_spi_get_fifo_depth()&#160;:&#160;<a class="el" href="neorv32__spi_8c.html#ae1c4da7e4dc2e42b04d7187f684f142c">neorv32_spi.c</a>, <a class="el" href="neorv32__spi_8h.html#ae1c4da7e4dc2e42b04d7187f684f142c">neorv32_spi.h</a></li> +<li>neorv32_spi_get_nonblocking()&#160;:&#160;<a class="el" href="neorv32__spi_8c.html#aad66fa8f8d1a92d4f355de7579bfbfd2">neorv32_spi.c</a>, <a class="el" href="neorv32__spi_8h.html#aad66fa8f8d1a92d4f355de7579bfbfd2">neorv32_spi.h</a></li> +<li>neorv32_spi_highspeed_disable()&#160;:&#160;<a class="el" href="neorv32__spi_8c.html#a67e9717635e272bc0e04408135a2f04d">neorv32_spi.c</a>, <a class="el" href="neorv32__spi_8h.html#a67e9717635e272bc0e04408135a2f04d">neorv32_spi.h</a></li> +<li>neorv32_spi_highspeed_enable()&#160;:&#160;<a class="el" href="neorv32__spi_8c.html#acf131faa3ad970c19a3cd8a47cb54f65">neorv32_spi.c</a>, <a class="el" href="neorv32__spi_8h.html#acf131faa3ad970c19a3cd8a47cb54f65">neorv32_spi.h</a></li> +<li>neorv32_spi_init()&#160;:&#160;<a class="el" href="neorv32__spi__irq_8c.html#a4aa4746fd210ecc0c3614089a6951ddf">neorv32_spi_irq.c</a>, <a class="el" href="neorv32__spi__irq_8h.html#a4aa4746fd210ecc0c3614089a6951ddf">neorv32_spi_irq.h</a></li> +<li>neorv32_spi_isr()&#160;:&#160;<a class="el" href="neorv32__spi__irq_8c.html#aa641816bb302df497664aa21ea69ed16">neorv32_spi_irq.c</a>, <a class="el" href="neorv32__spi__irq_8h.html#aa641816bb302df497664aa21ea69ed16">neorv32_spi_irq.h</a></li> +<li>neorv32_spi_put_nonblocking()&#160;:&#160;<a class="el" href="neorv32__spi_8c.html#aec8583e988789e846d21c2a35e6b06e7">neorv32_spi.c</a>, <a class="el" href="neorv32__spi_8h.html#aec8583e988789e846d21c2a35e6b06e7">neorv32_spi.h</a></li> +<li>neorv32_spi_rw()&#160;:&#160;<a class="el" href="neorv32__spi__irq_8c.html#a1f44ed849415d8e1d659c0485762c485">neorv32_spi_irq.c</a>, <a class="el" href="neorv32__spi__irq_8h.html#a1f44ed849415d8e1d659c0485762c485">neorv32_spi_irq.h</a></li> +<li>neorv32_spi_rw_busy()&#160;:&#160;<a class="el" href="neorv32__spi__irq_8c.html#a1863e19932bc6a79f2ca27d23eb74ef5">neorv32_spi_irq.c</a>, <a class="el" href="neorv32__spi__irq_8h.html#a1863e19932bc6a79f2ca27d23eb74ef5">neorv32_spi_irq.h</a></li> +<li>neorv32_spi_setup()&#160;:&#160;<a class="el" href="neorv32__spi_8c.html#a7d8124d986b69210081df6f1aa653552">neorv32_spi.c</a>, <a class="el" href="neorv32__spi_8h.html#a7d8124d986b69210081df6f1aa653552">neorv32_spi.h</a></li> +<li>neorv32_spi_trans()&#160;:&#160;<a class="el" href="neorv32__spi_8c.html#a7af79950eefc26e67a89bde02f255532">neorv32_spi.c</a>, <a class="el" href="neorv32__spi_8h.html#a7af79950eefc26e67a89bde02f255532">neorv32_spi.h</a></li> +<li>NEORV32_SYSINFO_BASE&#160;:&#160;<a class="el" href="neorv32_8h.html#a5aa936f38782232c7ed3eab1283ee536">neorv32.h</a></li> +<li>NEORV32_TRNG&#160;:&#160;<a class="el" href="neorv32__trng_8h.html#a9794ff3746eb5321ad9c2bf522ea26dd">neorv32_trng.h</a></li> +<li>neorv32_trng_available()&#160;:&#160;<a class="el" href="neorv32__trng_8c.html#af0c4139ff68763623b3d658a8dd8b5ce">neorv32_trng.c</a>, <a class="el" href="neorv32__trng_8h.html#af0c4139ff68763623b3d658a8dd8b5ce">neorv32_trng.h</a></li> +<li>NEORV32_TRNG_BASE&#160;:&#160;<a class="el" href="neorv32_8h.html#ab4846cd153e8a23deec45d81cc8372a2">neorv32.h</a></li> +<li>neorv32_trng_check_sim_mode()&#160;:&#160;<a class="el" href="neorv32__trng_8c.html#aba36f08dd88f2f3e58353ae72eaa14f7">neorv32_trng.c</a>, <a class="el" href="neorv32__trng_8h.html#aba36f08dd88f2f3e58353ae72eaa14f7">neorv32_trng.h</a></li> +<li>NEORV32_TRNG_CTRL_enum&#160;:&#160;<a class="el" href="neorv32__trng_8h.html#a1440e1355bf5bff17760992adc156b1a">neorv32_trng.h</a></li> +<li>neorv32_trng_disable()&#160;:&#160;<a class="el" href="neorv32__trng_8c.html#ae838bc980e28c300dc2c9c3f34a46bb8">neorv32_trng.c</a>, <a class="el" href="neorv32__trng_8h.html#ae838bc980e28c300dc2c9c3f34a46bb8">neorv32_trng.h</a></li> +<li>neorv32_trng_enable()&#160;:&#160;<a class="el" href="neorv32__trng_8c.html#a8b8a1771e37a152792264561b93228fa">neorv32_trng.c</a>, <a class="el" href="neorv32__trng_8h.html#a8b8a1771e37a152792264561b93228fa">neorv32_trng.h</a></li> +<li>neorv32_trng_fifo_clear()&#160;:&#160;<a class="el" href="neorv32__trng_8c.html#a87cfe338e2ff559f96c73f729465f967">neorv32_trng.c</a>, <a class="el" href="neorv32__trng_8h.html#a87cfe338e2ff559f96c73f729465f967">neorv32_trng.h</a></li> +<li>neorv32_trng_get()&#160;:&#160;<a class="el" href="neorv32__trng_8c.html#a9148bcb6a7c448c364e78fa98aac6985">neorv32_trng.c</a>, <a class="el" href="neorv32__trng_8h.html#a9148bcb6a7c448c364e78fa98aac6985">neorv32_trng.h</a></li> +<li>neorv32_trng_get_fifo_depth()&#160;:&#160;<a class="el" href="neorv32__trng_8c.html#ad24e44372f4fd1ed29a6967dccab4fb0">neorv32_trng.c</a>, <a class="el" href="neorv32__trng_8h.html#ad24e44372f4fd1ed29a6967dccab4fb0">neorv32_trng.h</a></li> +<li>NEORV32_TWI&#160;:&#160;<a class="el" href="neorv32__twi_8h.html#a2769c2fe5e0de01b12fe4a5fad029768">neorv32_twi.h</a></li> +<li>neorv32_twi_available()&#160;:&#160;<a class="el" href="neorv32__twi_8c.html#aa2e01ebbc0c82d65ed4ded351f4d8711">neorv32_twi.c</a>, <a class="el" href="neorv32__twi_8h.html#aa2e01ebbc0c82d65ed4ded351f4d8711">neorv32_twi.h</a></li> +<li>NEORV32_TWI_BASE&#160;:&#160;<a class="el" href="neorv32_8h.html#a4a741408a4bb0938e03b99555306db9c">neorv32.h</a></li> +<li>neorv32_twi_busy()&#160;:&#160;<a class="el" href="neorv32__twi_8c.html#a4fff1ddade320f6cc568c6266f2c2acd">neorv32_twi.c</a>, <a class="el" href="neorv32__twi_8h.html#a4fff1ddade320f6cc568c6266f2c2acd">neorv32_twi.h</a></li> +<li>NEORV32_TWI_CTRL_enum&#160;:&#160;<a class="el" href="neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafa">neorv32_twi.h</a></li> +<li>NEORV32_TWI_DCMD_enum&#160;:&#160;<a class="el" href="neorv32__twi_8h.html#a3421852c63baca60fe58c990b1c653d8">neorv32_twi.h</a></li> +<li>neorv32_twi_disable()&#160;:&#160;<a class="el" href="neorv32__twi_8c.html#ae5f31e737c7a6c3c86070ff34cb0d861">neorv32_twi.c</a>, <a class="el" href="neorv32__twi_8h.html#ae5f31e737c7a6c3c86070ff34cb0d861">neorv32_twi.h</a></li> +<li>neorv32_twi_enable()&#160;:&#160;<a class="el" href="neorv32__twi_8c.html#a22717887cffff1e6830756bc73140e7b">neorv32_twi.c</a>, <a class="el" href="neorv32__twi_8h.html#a22717887cffff1e6830756bc73140e7b">neorv32_twi.h</a></li> +<li>neorv32_twi_generate_start()&#160;:&#160;<a class="el" href="neorv32__twi_8c.html#a633d460e4735eb369d74a834b03c8b78">neorv32_twi.c</a>, <a class="el" href="neorv32__twi_8h.html#a633d460e4735eb369d74a834b03c8b78">neorv32_twi.h</a></li> +<li>neorv32_twi_generate_start_nonblocking()&#160;:&#160;<a class="el" href="neorv32__twi_8c.html#adbf2eaed0c76221da5c3091665fc885e">neorv32_twi.c</a>, <a class="el" href="neorv32__twi_8h.html#adbf2eaed0c76221da5c3091665fc885e">neorv32_twi.h</a></li> +<li>neorv32_twi_generate_stop()&#160;:&#160;<a class="el" href="neorv32__twi_8c.html#ad352447adcccccabd4e20577b34fbece">neorv32_twi.c</a>, <a class="el" href="neorv32__twi_8h.html#ad352447adcccccabd4e20577b34fbece">neorv32_twi.h</a></li> +<li>neorv32_twi_generate_stop_nonblocking()&#160;:&#160;<a class="el" href="neorv32__twi_8c.html#aa22430aab0a38d88cbd2c4220c573da0">neorv32_twi.c</a>, <a class="el" href="neorv32__twi_8h.html#aa22430aab0a38d88cbd2c4220c573da0">neorv32_twi.h</a></li> +<li>neorv32_twi_get()&#160;:&#160;<a class="el" href="neorv32__twi_8c.html#a7735376d26560866b153ed205dfcb2ba">neorv32_twi.c</a>, <a class="el" href="neorv32__twi_8h.html#a7735376d26560866b153ed205dfcb2ba">neorv32_twi.h</a></li> +<li>neorv32_twi_get_fifo_depth()&#160;:&#160;<a class="el" href="neorv32__twi_8c.html#a2c8f3bc55f4a9a8bdcb111759cf56ae2">neorv32_twi.c</a>, <a class="el" href="neorv32__twi_8h.html#a2c8f3bc55f4a9a8bdcb111759cf56ae2">neorv32_twi.h</a></li> +<li>neorv32_twi_send_nonblocking()&#160;:&#160;<a class="el" href="neorv32__twi_8c.html#a28fc44cce5d28f6e8c32268b239b07d5">neorv32_twi.c</a>, <a class="el" href="neorv32__twi_8h.html#a28fc44cce5d28f6e8c32268b239b07d5">neorv32_twi.h</a></li> +<li>neorv32_twi_setup()&#160;:&#160;<a class="el" href="neorv32__twi_8c.html#a7ea6f3509a7cf622234d4b83e33afbe3">neorv32_twi.c</a>, <a class="el" href="neorv32__twi_8h.html#a7ea6f3509a7cf622234d4b83e33afbe3">neorv32_twi.h</a></li> +<li>neorv32_twi_trans()&#160;:&#160;<a class="el" href="neorv32__twi_8c.html#ac7020f3379602f11c47ca16f1bd82f2e">neorv32_twi.c</a>, <a class="el" href="neorv32__twi_8h.html#ac7020f3379602f11c47ca16f1bd82f2e">neorv32_twi.h</a></li> +<li>NEORV32_UART0&#160;:&#160;<a class="el" href="neorv32__uart_8h.html#a4c880a6b27e46f459e750425258b1bdb">neorv32_uart.h</a></li> +<li>NEORV32_UART0_BASE&#160;:&#160;<a class="el" href="neorv32_8h.html#a000b37f710043fe21e49b2fdbc039d94">neorv32.h</a></li> +<li>NEORV32_UART1&#160;:&#160;<a class="el" href="neorv32__uart_8h.html#aa2a9ded4523f001bf69935c80247fa2d">neorv32_uart.h</a></li> +<li>NEORV32_UART1_BASE&#160;:&#160;<a class="el" href="neorv32_8h.html#a26a1defe18ce222b8b4ed1c760344700">neorv32.h</a></li> +<li>neorv32_uart_available()&#160;:&#160;<a class="el" href="neorv32__uart_8c.html#abef6415b0391dc055713404312196682">neorv32_uart.c</a>, <a class="el" href="neorv32__uart_8h.html#abef6415b0391dc055713404312196682">neorv32_uart.h</a></li> +<li>neorv32_uart_char_received()&#160;:&#160;<a class="el" href="neorv32__uart_8c.html#adedb0e07efb232717534017167a5be98">neorv32_uart.c</a>, <a class="el" href="neorv32__uart_8h.html#adedb0e07efb232717534017167a5be98">neorv32_uart.h</a></li> +<li>neorv32_uart_char_received_get()&#160;:&#160;<a class="el" href="neorv32__uart_8c.html#aa490df3a9bb2aa3215fa6fad34ffe7d1">neorv32_uart.c</a>, <a class="el" href="neorv32__uart_8h.html#aa490df3a9bb2aa3215fa6fad34ffe7d1">neorv32_uart.h</a></li> +<li>NEORV32_UART_CTRL_enum&#160;:&#160;<a class="el" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afc">neorv32_uart.h</a></li> +<li>NEORV32_UART_DATA_enum&#160;:&#160;<a class="el" href="neorv32__uart_8h.html#adcf35350a9ea18a59c32c35f528643f2">neorv32_uart.h</a></li> +<li>neorv32_uart_disable()&#160;:&#160;<a class="el" href="neorv32__uart_8c.html#ae18804ccd29ec2fd1cc06e9ce985b704">neorv32_uart.c</a>, <a class="el" href="neorv32__uart_8h.html#ae18804ccd29ec2fd1cc06e9ce985b704">neorv32_uart.h</a></li> +<li>neorv32_uart_enable()&#160;:&#160;<a class="el" href="neorv32__uart_8c.html#afa0533e81d53057c36f4997a2dbbe2bc">neorv32_uart.c</a>, <a class="el" href="neorv32__uart_8h.html#afa0533e81d53057c36f4997a2dbbe2bc">neorv32_uart.h</a></li> +<li>neorv32_uart_get_rx_fifo_depth()&#160;:&#160;<a class="el" href="neorv32__uart_8c.html#af85fb929c912d3edef3d86ffa833982a">neorv32_uart.c</a>, <a class="el" href="neorv32__uart_8h.html#af85fb929c912d3edef3d86ffa833982a">neorv32_uart.h</a></li> +<li>neorv32_uart_get_tx_fifo_depth()&#160;:&#160;<a class="el" href="neorv32__uart_8c.html#a031e3e27c8783c299623468020a22b0e">neorv32_uart.c</a>, <a class="el" href="neorv32__uart_8h.html#a031e3e27c8783c299623468020a22b0e">neorv32_uart.h</a></li> +<li>neorv32_uart_getc()&#160;:&#160;<a class="el" href="neorv32__uart_8c.html#a2efd432f63b8d36d44263d0b1f39a6dc">neorv32_uart.c</a>, <a class="el" href="neorv32__uart_8h.html#a2efd432f63b8d36d44263d0b1f39a6dc">neorv32_uart.h</a></li> +<li>neorv32_uart_printf()&#160;:&#160;<a class="el" href="neorv32__uart_8c.html#ab8c1f9f451def9126ab2749d7bbe50d9">neorv32_uart.c</a>, <a class="el" href="neorv32__uart_8h.html#ab8c1f9f451def9126ab2749d7bbe50d9">neorv32_uart.h</a></li> +<li>neorv32_uart_putc()&#160;:&#160;<a class="el" href="neorv32__uart_8c.html#a9bc7bb94a50b74e1145b78eec6094129">neorv32_uart.c</a>, <a class="el" href="neorv32__uart_8h.html#a9bc7bb94a50b74e1145b78eec6094129">neorv32_uart.h</a></li> +<li>neorv32_uart_puts()&#160;:&#160;<a class="el" href="neorv32__uart_8c.html#a45a07d5e71677162baaa1025759c67a2">neorv32_uart.c</a>, <a class="el" href="neorv32__uart_8h.html#a45a07d5e71677162baaa1025759c67a2">neorv32_uart.h</a></li> +<li>neorv32_uart_rtscts_disable()&#160;:&#160;<a class="el" href="neorv32__uart_8c.html#a7b2f924ef4554b1fa90433c38d97558d">neorv32_uart.c</a>, <a class="el" href="neorv32__uart_8h.html#a7b2f924ef4554b1fa90433c38d97558d">neorv32_uart.h</a></li> +<li>neorv32_uart_rtscts_enable()&#160;:&#160;<a class="el" href="neorv32__uart_8c.html#a734b610f4cd1b474d7763f9700a715ec">neorv32_uart.c</a>, <a class="el" href="neorv32__uart_8h.html#a734b610f4cd1b474d7763f9700a715ec">neorv32_uart.h</a></li> +<li>neorv32_uart_rx_clear()&#160;:&#160;<a class="el" href="neorv32__uart_8c.html#afe0de59c14faff1e0c890d5465be25f0">neorv32_uart.c</a>, <a class="el" href="neorv32__uart_8h.html#afe0de59c14faff1e0c890d5465be25f0">neorv32_uart.h</a></li> +<li>neorv32_uart_scan()&#160;:&#160;<a class="el" href="neorv32__uart_8c.html#ac429964878bd6deab61d9ed8659bca75">neorv32_uart.c</a>, <a class="el" href="neorv32__uart_8h.html#ac429964878bd6deab61d9ed8659bca75">neorv32_uart.h</a></li> +<li>neorv32_uart_setup()&#160;:&#160;<a class="el" href="neorv32__uart_8c.html#a9cdec36f2723c5373664022d1b68b841">neorv32_uart.c</a>, <a class="el" href="neorv32__uart_8h.html#a9cdec36f2723c5373664022d1b68b841">neorv32_uart.h</a></li> +<li>neorv32_uart_tx_busy()&#160;:&#160;<a class="el" href="neorv32__uart_8c.html#aa7bef48a58e044c246b8c4ad32864502">neorv32_uart.c</a>, <a class="el" href="neorv32__uart_8h.html#aa7bef48a58e044c246b8c4ad32864502">neorv32_uart.h</a></li> +<li>neorv32_uart_tx_clear()&#160;:&#160;<a class="el" href="neorv32__uart_8c.html#a27971954262a2fd1f21d3bf1ba27e87c">neorv32_uart.c</a>, <a class="el" href="neorv32__uart_8h.html#a27971954262a2fd1f21d3bf1ba27e87c">neorv32_uart.h</a></li> +<li>neorv32_uart_vprintf()&#160;:&#160;<a class="el" href="neorv32__uart_8c.html#a8714cdb1c04d94bec322c6215ea10238">neorv32_uart.c</a>, <a class="el" href="neorv32__uart_8h.html#a8714cdb1c04d94bec322c6215ea10238">neorv32_uart.h</a></li> +<li>NEORV32_WDT&#160;:&#160;<a class="el" href="neorv32__wdt_8h.html#a78615b08cd799063011606d084fef46c">neorv32_wdt.h</a></li> +<li>neorv32_wdt_available()&#160;:&#160;<a class="el" href="neorv32__wdt_8c.html#a459a918c5a86c0167e8c748352d39827">neorv32_wdt.c</a>, <a class="el" href="neorv32__wdt_8h.html#a459a918c5a86c0167e8c748352d39827">neorv32_wdt.h</a></li> +<li>NEORV32_WDT_BASE&#160;:&#160;<a class="el" href="neorv32_8h.html#a3012986cdd5748ee96bcc74cd7108dea">neorv32.h</a></li> +<li>NEORV32_WDT_CTRL_enum&#160;:&#160;<a class="el" href="neorv32__wdt_8h.html#a0a4cb24fd818277c5bb9b10ff519f23e">neorv32_wdt.h</a></li> +<li>neorv32_wdt_disable()&#160;:&#160;<a class="el" href="neorv32__wdt_8c.html#aba52520582392a671e2b717715a330b2">neorv32_wdt.c</a>, <a class="el" href="neorv32__wdt_8h.html#aba52520582392a671e2b717715a330b2">neorv32_wdt.h</a></li> +<li>neorv32_wdt_feed()&#160;:&#160;<a class="el" href="neorv32__wdt_8c.html#a2e4df2b352d11c31063ef2fc16c510ad">neorv32_wdt.c</a>, <a class="el" href="neorv32__wdt_8h.html#a2e4df2b352d11c31063ef2fc16c510ad">neorv32_wdt.h</a></li> +<li>neorv32_wdt_get_cause()&#160;:&#160;<a class="el" href="neorv32__wdt_8c.html#a80fa8d178d18c9b02d32d93e815b532e">neorv32_wdt.c</a>, <a class="el" href="neorv32__wdt_8h.html#a80fa8d178d18c9b02d32d93e815b532e">neorv32_wdt.h</a></li> +<li>NEORV32_WDT_RCAUSE_enum&#160;:&#160;<a class="el" href="neorv32__wdt_8h.html#a70098b4ee893774864536fb4100ff049">neorv32_wdt.h</a></li> +<li>neorv32_wdt_setup()&#160;:&#160;<a class="el" href="neorv32__wdt_8c.html#a2aa72608191d34ef41c5f545988ff400">neorv32_wdt.c</a>, <a class="el" href="neorv32__wdt_8h.html#a2aa72608191d34ef41c5f545988ff400">neorv32_wdt.h</a></li> +<li>NEORV32_XIP&#160;:&#160;<a class="el" href="neorv32__xip_8h.html#a3d6f138a347c16883b51069428eb7c1e">neorv32_xip.h</a></li> +<li>neorv32_xip_available()&#160;:&#160;<a class="el" href="neorv32__xip_8c.html#afe2e5682a26cafdb0585d2233bccc7c6">neorv32_xip.c</a>, <a class="el" href="neorv32__xip_8h.html#afe2e5682a26cafdb0585d2233bccc7c6">neorv32_xip.h</a></li> +<li>NEORV32_XIP_BASE&#160;:&#160;<a class="el" href="neorv32_8h.html#ae0978315beac8399f96f520bda81c7fe">neorv32.h</a></li> +<li>NEORV32_XIP_CTRL_enum&#160;:&#160;<a class="el" href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceb">neorv32_xip.h</a></li> +<li>neorv32_xip_get_clock_speed()&#160;:&#160;<a class="el" href="neorv32__xip_8c.html#a88f728101e82939bf7f8b9ab5a904706">neorv32_xip.c</a>, <a class="el" href="neorv32__xip_8h.html#a88f728101e82939bf7f8b9ab5a904706">neorv32_xip.h</a></li> +<li>neorv32_xip_highspeed_disable()&#160;:&#160;<a class="el" href="neorv32__xip_8c.html#ad74f2842ed2251e3ae5c19e06dced0c3">neorv32_xip.c</a>, <a class="el" href="neorv32__xip_8h.html#ad74f2842ed2251e3ae5c19e06dced0c3">neorv32_xip.h</a></li> +<li>neorv32_xip_highspeed_enable()&#160;:&#160;<a class="el" href="neorv32__xip_8c.html#a6aef2ea29451ba2aa55160da777a5115">neorv32_xip.c</a>, <a class="el" href="neorv32__xip_8h.html#a6aef2ea29451ba2aa55160da777a5115">neorv32_xip.h</a></li> +<li>neorv32_xip_setup()&#160;:&#160;<a class="el" href="neorv32__xip_8c.html#a549d68abdf5a3d7484abe6d5370bb999">neorv32_xip.c</a>, <a class="el" href="neorv32__xip_8h.html#a549d68abdf5a3d7484abe6d5370bb999">neorv32_xip.h</a></li> +<li>neorv32_xip_spi_trans()&#160;:&#160;<a class="el" href="neorv32__xip_8c.html#a92f1446a3bb7fe6dee5dbed33882b223">neorv32_xip.c</a>, <a class="el" href="neorv32__xip_8h.html#a92f1446a3bb7fe6dee5dbed33882b223">neorv32_xip.h</a></li> +<li>neorv32_xip_start()&#160;:&#160;<a class="el" href="neorv32__xip_8c.html#a0ab2c36c973030a811e6d7abe0afc393">neorv32_xip.c</a>, <a class="el" href="neorv32__xip_8h.html#a0ab2c36c973030a811e6d7abe0afc393">neorv32_xip.h</a></li> +<li>NEORV32_XIRQ&#160;:&#160;<a class="el" href="neorv32__xirq_8h.html#a0c0886139e9837867202e5f6a83307c4">neorv32_xirq.h</a></li> +<li>neorv32_xirq_available()&#160;:&#160;<a class="el" href="neorv32__xirq_8c.html#aaf30757d526030a8d81081915ab29a76">neorv32_xirq.c</a>, <a class="el" href="neorv32__xirq_8h.html#aaf30757d526030a8d81081915ab29a76">neorv32_xirq.h</a></li> +<li>NEORV32_XIRQ_BASE&#160;:&#160;<a class="el" href="neorv32_8h.html#a942a897be2d4ae6820bee0f7bb3a0ff1">neorv32.h</a></li> +<li>neorv32_xirq_channel_disable()&#160;:&#160;<a class="el" href="neorv32__xirq_8c.html#ae17509ad0c828aa9b36747b253cdbf0a">neorv32_xirq.c</a>, <a class="el" href="neorv32__xirq_8h.html#ae17509ad0c828aa9b36747b253cdbf0a">neorv32_xirq.h</a></li> +<li>neorv32_xirq_channel_enable()&#160;:&#160;<a class="el" href="neorv32__xirq_8c.html#abe63c0968c94b472082c8156a1a7db5c">neorv32_xirq.c</a>, <a class="el" href="neorv32__xirq_8h.html#abe63c0968c94b472082c8156a1a7db5c">neorv32_xirq.h</a></li> +<li>neorv32_xirq_clear_pending()&#160;:&#160;<a class="el" href="neorv32__xirq_8c.html#a83ecaf568a6f6bcb1e1efdb1eef6df9c">neorv32_xirq.c</a>, <a class="el" href="neorv32__xirq_8h.html#a83ecaf568a6f6bcb1e1efdb1eef6df9c">neorv32_xirq.h</a></li> +<li>neorv32_xirq_get_num()&#160;:&#160;<a class="el" href="neorv32__xirq_8c.html#a717a8e34908cc01345e68920e76f229c">neorv32_xirq.c</a>, <a class="el" href="neorv32__xirq_8h.html#a717a8e34908cc01345e68920e76f229c">neorv32_xirq.h</a></li> +<li>neorv32_xirq_global_disable()&#160;:&#160;<a class="el" href="neorv32__xirq_8c.html#ac64d3ff5619968499bccebebe6a6cab3">neorv32_xirq.c</a>, <a class="el" href="neorv32__xirq_8h.html#ac64d3ff5619968499bccebebe6a6cab3">neorv32_xirq.h</a></li> +<li>neorv32_xirq_global_enable()&#160;:&#160;<a class="el" href="neorv32__xirq_8c.html#a76468156ef52b371e06bc2ca8eddcd27">neorv32_xirq.c</a>, <a class="el" href="neorv32__xirq_8h.html#a76468156ef52b371e06bc2ca8eddcd27">neorv32_xirq.h</a></li> +<li>neorv32_xirq_install()&#160;:&#160;<a class="el" href="neorv32__xirq_8c.html#a9129984f91c02afafaa072a5d86f9876">neorv32_xirq.c</a>, <a class="el" href="neorv32__xirq_8h.html#a9129984f91c02afafaa072a5d86f9876">neorv32_xirq.h</a></li> +<li>neorv32_xirq_setup()&#160;:&#160;<a class="el" href="neorv32__xirq_8c.html#a9295997fce7114a8205325c4d75dd200">neorv32_xirq.c</a>, <a class="el" href="neorv32__xirq_8h.html#a9295997fce7114a8205325c4d75dd200">neorv32_xirq.h</a></li> +<li>neorv32_xirq_setup_trigger()&#160;:&#160;<a class="el" href="neorv32__xirq_8c.html#a0d137f09d1e7dcd31c157b856033ac42">neorv32_xirq.c</a>, <a class="el" href="neorv32__xirq_8h.html#a0d137f09d1e7dcd31c157b856033ac42">neorv32_xirq.h</a></li> +<li>neorv32_xirq_uninstall()&#160;:&#160;<a class="el" href="neorv32__xirq_8c.html#a49ae67d1d5066cd795149e96b81127f7">neorv32_xirq.c</a>, <a class="el" href="neorv32__xirq_8h.html#a49ae67d1d5066cd795149e96b81127f7">neorv32_xirq.h</a></li> +<li>NUM_CELLS_X&#160;:&#160;<a class="el" href="game__of__life_2main_8c.html#a78c5b500f0f057bcaedf6fedeca7c537">main.c</a></li> +<li>NUM_CELLS_Y&#160;:&#160;<a class="el" href="game__of__life_2main_8c.html#aed77778557404b38bebb05b5830368b4">main.c</a></li> +<li>NUM_LEDS_24BIT&#160;:&#160;<a class="el" href="demo__neopixel_2main_8c.html#aa1dddb8d6b3b4d2f19afc3c09e2ff572">main.c</a></li> +<li>NUM_TEST_CASES&#160;:&#160;<a class="el" href="atomic__test_2main_8c.html#a83792c34853f1d2801b59ad46adc7e1e">main.c</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/globals_o.html b/sw/globals_o.html new file mode 100644 index 0000000000..70cdc2d171 --- /dev/null +++ b/sw/globals_o.html @@ -0,0 +1,123 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: Globals</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +</div><!-- top --> +<div id="doc-content"> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div class="contents"> +<div class="textblock">Here is a list of all documented functions, variables, defines, enums, and typedefs with links to the documentation:</div> + +<h3><a id="index_o" name="index_o"></a>- o -</h3><ul> +<li>ONEWIRE_CTRL_BUSY&#160;:&#160;<a class="el" href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831aac8933755e80d72e1e9c293198d831b9">neorv32_onewire.h</a></li> +<li>ONEWIRE_CTRL_CLKDIV0&#160;:&#160;<a class="el" href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831acdfca08f34d7379aaf8505ba3425c6f5">neorv32_onewire.h</a></li> +<li>ONEWIRE_CTRL_CLKDIV1&#160;:&#160;<a class="el" href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831afa1476a5e04eb4eabf4d7a595eca2df9">neorv32_onewire.h</a></li> +<li>ONEWIRE_CTRL_CLKDIV2&#160;:&#160;<a class="el" href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831aec9f056072e1db747e74a5c695d2a1df">neorv32_onewire.h</a></li> +<li>ONEWIRE_CTRL_CLKDIV3&#160;:&#160;<a class="el" href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831ab8600bd09d74e39869259881b84ebfbf">neorv32_onewire.h</a></li> +<li>ONEWIRE_CTRL_CLKDIV4&#160;:&#160;<a class="el" href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831a32af8c86e7166e02e801727bd261c179">neorv32_onewire.h</a></li> +<li>ONEWIRE_CTRL_CLKDIV5&#160;:&#160;<a class="el" href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831a789d65fd9b0ab17bffd0d6de9d2e132a">neorv32_onewire.h</a></li> +<li>ONEWIRE_CTRL_CLKDIV6&#160;:&#160;<a class="el" href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831a27f040454bebc6218b490f7160ea2312">neorv32_onewire.h</a></li> +<li>ONEWIRE_CTRL_CLKDIV7&#160;:&#160;<a class="el" href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831a8b19096f72ef96a7597fda9be625ed40">neorv32_onewire.h</a></li> +<li>ONEWIRE_CTRL_EN&#160;:&#160;<a class="el" href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831ab87882c202f80185278c69e482f147da">neorv32_onewire.h</a></li> +<li>ONEWIRE_CTRL_PRESENCE&#160;:&#160;<a class="el" href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831a92e1ff9fa10319d64c8d2c6a6d61b37e">neorv32_onewire.h</a></li> +<li>ONEWIRE_CTRL_PRSC0&#160;:&#160;<a class="el" href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831abfed6417c3abd7ef94cd18a3b32c4393">neorv32_onewire.h</a></li> +<li>ONEWIRE_CTRL_PRSC1&#160;:&#160;<a class="el" href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831aee1e24261e263c70bf2e36dcafc9dc74">neorv32_onewire.h</a></li> +<li>ONEWIRE_CTRL_SENSE&#160;:&#160;<a class="el" href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831af992c94d0b9a7b7b92a5a23366b9a8c6">neorv32_onewire.h</a></li> +<li>ONEWIRE_CTRL_TRIG_BIT&#160;:&#160;<a class="el" href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831a7ecbccef9e77e68caf22ed2c416e1f77">neorv32_onewire.h</a></li> +<li>ONEWIRE_CTRL_TRIG_BYTE&#160;:&#160;<a class="el" href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831acfd8a56f668ca55dbbaa1714b1235dfe">neorv32_onewire.h</a></li> +<li>ONEWIRE_CTRL_TRIG_RST&#160;:&#160;<a class="el" href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831a98624ec944e0413a208cdf54bbbf4c75">neorv32_onewire.h</a></li> +<li>ONEWIRE_DATA_LSB&#160;:&#160;<a class="el" href="neorv32__onewire_8h.html#ae770490afa8662fb8577065531d51368a6ad35475e3f80a8c68ce0caa9c3754a5">neorv32_onewire.h</a></li> +<li>ONEWIRE_DATA_MSB&#160;:&#160;<a class="el" href="neorv32__onewire_8h.html#ae770490afa8662fb8577065531d51368af967429634efb019ada46bf75f373aa3">neorv32_onewire.h</a></li> +<li>ONEWIRE_FIRQ_ENABLE&#160;:&#160;<a class="el" href="neorv32_8h.html#a8bb1918679e32e898af2d485cfa44afb">neorv32.h</a></li> +<li>ONEWIRE_FIRQ_PENDING&#160;:&#160;<a class="el" href="neorv32_8h.html#a3853ef999f99ca062e6025038811d0f0">neorv32.h</a></li> +<li>ONEWIRE_RTE_ID&#160;:&#160;<a class="el" href="neorv32_8h.html#a142f4a1c754edfab292706618d427b94">neorv32.h</a></li> +<li>ONEWIRE_TRAP_CODE&#160;:&#160;<a class="el" href="neorv32_8h.html#a3e7aaa405a7d1fcd71a36c4b6b5a4081">neorv32.h</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/globals_p.html b/sw/globals_p.html new file mode 100644 index 0000000000..ba99cd94b0 --- /dev/null +++ b/sw/globals_p.html @@ -0,0 +1,129 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: Globals</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +</div><!-- top --> +<div id="doc-content"> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div class="contents"> +<div class="textblock">Here is a list of all documented functions, variables, defines, enums, and typedefs with links to the documentation:</div> + +<h3><a id="index_p" name="index_p"></a>- p -</h3><ul> +<li>plain_data_hw&#160;:&#160;<a class="el" href="demo__cfu_2main_8c.html#aee8dde13fe2f5ac52dd6075e2fe1eab5">main.c</a></li> +<li>plain_data_sw&#160;:&#160;<a class="el" href="demo__cfu_2main_8c.html#a72ba1460776ad684028448ca51810bbe">main.c</a></li> +<li>PMP_NA4&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a8f2418fb5e2175f35ee2362469ce01f5aae0e0c33b0d034cb50286239f955d892">neorv32_cpu_csr.h</a></li> +<li>PMP_NAPOT&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a8f2418fb5e2175f35ee2362469ce01f5ad555e9dfc0c00612bdea623617ff2820">neorv32_cpu_csr.h</a></li> +<li>PMP_OFF&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a8f2418fb5e2175f35ee2362469ce01f5a003ccfae4aae1dad4fd65d5d4c7737c4">neorv32_cpu_csr.h</a></li> +<li>PMP_TOR&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a8f2418fb5e2175f35ee2362469ce01f5a629a81a205abee94bad9d5bb5dfa26b1">neorv32_cpu_csr.h</a></li> +<li>PMPCFG_A_LSB&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#abc0e8daad1e9beda4d9950452cc930eaaae1e6440956ad6b7cbf6062aa50f43b1">neorv32_cpu_csr.h</a></li> +<li>PMPCFG_A_MSB&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#abc0e8daad1e9beda4d9950452cc930eaa67ad3243eeb74f86a01efbade76f21e4">neorv32_cpu_csr.h</a></li> +<li>PMPCFG_L&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#abc0e8daad1e9beda4d9950452cc930eaa59c294bc43d2117bb55e301eec683f14">neorv32_cpu_csr.h</a></li> +<li>PMPCFG_R&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#abc0e8daad1e9beda4d9950452cc930eaad3aca82a2ab57364e83f677d3d4f71a6">neorv32_cpu_csr.h</a></li> +<li>PMPCFG_W&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#abc0e8daad1e9beda4d9950452cc930eaa7689905760f917499b1151cced384d2f">neorv32_cpu_csr.h</a></li> +<li>PMPCFG_X&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#abc0e8daad1e9beda4d9950452cc930eaaec94712deafba09c0cf956c6fd68fa8d">neorv32_cpu_csr.h</a></li> +<li>pop_count()&#160;:&#160;<a class="el" href="game__of__life_2main_8c.html#aac4bec7738b12f5a4b4d7a3a6cb1ab8d">main.c</a></li> +<li>PRINT_GETC&#160;:&#160;<a class="el" href="bootloader_8c.html#a999b04603115ce08b0cb33e333312480">bootloader.c</a></li> +<li>print_help()&#160;:&#160;<a class="el" href="bootloader_8c.html#a402ea961bfc2ffeee61e3a7c330b1559">bootloader.c</a></li> +<li>print_hex_byte()&#160;:&#160;<a class="el" href="demo__twi_2main_8c.html#a2ebc688bc1dad328693fc0974b378fa0">main.c</a></li> +<li>print_hex_word()&#160;:&#160;<a class="el" href="bootloader_8c.html#a70b7d5c3b3ae97e4e72e84c4bc28fb8a">bootloader.c</a></li> +<li>PRINT_PUTC&#160;:&#160;<a class="el" href="bootloader_8c.html#aa7afbe8348ebd1a876a4d247553292e9">bootloader.c</a></li> +<li>print_random_data()&#160;:&#160;<a class="el" href="demo__trng_2main_8c.html#a64205d97b57c99dc5e95b8621827f4a4">main.c</a></li> +<li>print_report()&#160;:&#160;<a class="el" href="atomic__test_2main_8c.html#a99377a057d14aaa9b45f8cab890e8cf7">main.c</a></li> +<li>PRINT_TEXT&#160;:&#160;<a class="el" href="bootloader_8c.html#a0e5a66f68ecc7a6f42088f349707e852">bootloader.c</a></li> +<li>print_universe()&#160;:&#160;<a class="el" href="game__of__life_2main_8c.html#a9a455dea83a25f656fcc5217ad513dac">main.c</a></li> +<li>PRINT_XNUM&#160;:&#160;<a class="el" href="bootloader_8c.html#a2f5cc04cf9c85f5d2958b384e053053b">bootloader.c</a></li> +<li>putchar()&#160;:&#160;<a class="el" href="neorv32__uart_8c.html#a07036e93939040c563e862a6a31b65bc">neorv32_uart.c</a></li> +<li>PWM_CTRL_EN&#160;:&#160;<a class="el" href="neorv32__pwm_8h.html#af350f93b601a92ef56516198d1570b7dafb99fba508460086efdd495d4649c65a">neorv32_pwm.h</a></li> +<li>PWM_CTRL_PRSC0&#160;:&#160;<a class="el" href="neorv32__pwm_8h.html#af350f93b601a92ef56516198d1570b7da01ab6de6ac34be1ed68f22e17acbe274">neorv32_pwm.h</a></li> +<li>PWM_CTRL_PRSC1&#160;:&#160;<a class="el" href="neorv32__pwm_8h.html#af350f93b601a92ef56516198d1570b7daa6fca8a4eecfb99b8f0fa99e187e30bb">neorv32_pwm.h</a></li> +<li>PWM_CTRL_PRSC2&#160;:&#160;<a class="el" href="neorv32__pwm_8h.html#af350f93b601a92ef56516198d1570b7da0fd36a63fd4c37ef3bc4732518ebf13d">neorv32_pwm.h</a></li> +<li>PWM_MAX&#160;:&#160;<a class="el" href="demo__pwm_2main_8c.html#a391fa1e490bd712720989b58fa0d9904">main.c</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/globals_r.html b/sw/globals_r.html new file mode 100644 index 0000000000..4143536277 --- /dev/null +++ b/sw/globals_r.html @@ -0,0 +1,189 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: Globals</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +</div><!-- top --> +<div id="doc-content"> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div class="contents"> +<div class="textblock">Here is a list of all documented functions, variables, defines, enums, and typedefs with links to the documentation:</div> + +<h3><a id="index_r" name="index_r"></a>- r -</h3><ul> +<li>ram_buffer&#160;:&#160;<a class="el" href="demo__xip_2main_8c.html#acc95e55a622d79c2a398397d1f9b8033">main.c</a></li> +<li>read_byte()&#160;:&#160;<a class="el" href="demo__onewire_2main_8c.html#a951a31029af34715f20856eb82432637">main.c</a></li> +<li>read_memory()&#160;:&#160;<a class="el" href="bus__explorer_2main_8c.html#afc9b1ab3db46eccf51d55c715fa2fbd4">main.c</a></li> +<li>repetition_count_test()&#160;:&#160;<a class="el" href="demo__trng_2main_8c.html#af37eae672fee5e81f00a1dbf51b7e417">main.c</a></li> +<li>riscv_emulate_fadds()&#160;:&#160;<a class="el" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a9d676567276439875c9b1a15b892b555">neorv32_zfinx_extension_intrinsics.h</a></li> +<li>riscv_emulate_fclasss()&#160;:&#160;<a class="el" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#ae41a0bf9d28c35f4d6db7177ccf8ee06">neorv32_zfinx_extension_intrinsics.h</a></li> +<li>riscv_emulate_fcvt_sw()&#160;:&#160;<a class="el" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a0f2260b7b5793a95c49670379fc89617">neorv32_zfinx_extension_intrinsics.h</a></li> +<li>riscv_emulate_fcvt_swu()&#160;:&#160;<a class="el" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a10a05bface37bff32c78ed0746845794">neorv32_zfinx_extension_intrinsics.h</a></li> +<li>riscv_emulate_fcvt_ws()&#160;:&#160;<a class="el" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a292365fe41a7a661e61ae746306ba5e9">neorv32_zfinx_extension_intrinsics.h</a></li> +<li>riscv_emulate_fcvt_wus()&#160;:&#160;<a class="el" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#aad9fc7337e09081cf8c5bff8c28776c8">neorv32_zfinx_extension_intrinsics.h</a></li> +<li>riscv_emulate_fdivs()&#160;:&#160;<a class="el" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#aeaf46a17b671278be2bf804159827a40">neorv32_zfinx_extension_intrinsics.h</a></li> +<li>riscv_emulate_feqs()&#160;:&#160;<a class="el" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a7cb3c6570b911cd1dfb7b6e798cc1d21">neorv32_zfinx_extension_intrinsics.h</a></li> +<li>riscv_emulate_fles()&#160;:&#160;<a class="el" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#ac5fdef0607602fa0bdb93b3535fd709e">neorv32_zfinx_extension_intrinsics.h</a></li> +<li>riscv_emulate_flts()&#160;:&#160;<a class="el" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a2b802122d53a2ce517b3d39fec34d7e0">neorv32_zfinx_extension_intrinsics.h</a></li> +<li>riscv_emulate_fmadds()&#160;:&#160;<a class="el" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a39212f2e2bb0f1752092a1732f93edf3">neorv32_zfinx_extension_intrinsics.h</a></li> +<li>riscv_emulate_fmaxs()&#160;:&#160;<a class="el" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#af9b16a32d2bb13c8af5a678271d74889">neorv32_zfinx_extension_intrinsics.h</a></li> +<li>riscv_emulate_fmins()&#160;:&#160;<a class="el" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a872cd30fb61190bd1ac719d25b01f5a3">neorv32_zfinx_extension_intrinsics.h</a></li> +<li>riscv_emulate_fmsubs()&#160;:&#160;<a class="el" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a05d0d5a8eb9422e93448efdeb679cabf">neorv32_zfinx_extension_intrinsics.h</a></li> +<li>riscv_emulate_fmuls()&#160;:&#160;<a class="el" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#ad43e8bdf4a6fbe229d22d24680f2be80">neorv32_zfinx_extension_intrinsics.h</a></li> +<li>riscv_emulate_fnmadds()&#160;:&#160;<a class="el" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#ac8bb4450b39854ab07839e8f3505361c">neorv32_zfinx_extension_intrinsics.h</a></li> +<li>riscv_emulate_fnmsubs()&#160;:&#160;<a class="el" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a833638b346722dfa9d7d5c8d60998ec8">neorv32_zfinx_extension_intrinsics.h</a></li> +<li>riscv_emulate_fsgnjns()&#160;:&#160;<a class="el" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a0c985e626ed1d69314f4e3a0f1f58624">neorv32_zfinx_extension_intrinsics.h</a></li> +<li>riscv_emulate_fsgnjs()&#160;:&#160;<a class="el" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a12498d635f422f607b9b83facf3050dd">neorv32_zfinx_extension_intrinsics.h</a></li> +<li>riscv_emulate_fsgnjxs()&#160;:&#160;<a class="el" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a98caf7f310820052ae96ce0f45e6cd26">neorv32_zfinx_extension_intrinsics.h</a></li> +<li>riscv_emulate_fsqrts()&#160;:&#160;<a class="el" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a1ceb3450f1e5c62d3079cd0e93c03501">neorv32_zfinx_extension_intrinsics.h</a></li> +<li>riscv_emulate_fsubs()&#160;:&#160;<a class="el" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#ace5d95b855ec1aa8eacdb5bbeea58197">neorv32_zfinx_extension_intrinsics.h</a></li> +<li>riscv_intrinsic_fadds()&#160;:&#160;<a class="el" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a4b151fcb252fc7b894f247f5af6a1809">neorv32_zfinx_extension_intrinsics.h</a></li> +<li>riscv_intrinsic_fclasss()&#160;:&#160;<a class="el" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a3064a5c57b5f45d57c4d19eb798724f6">neorv32_zfinx_extension_intrinsics.h</a></li> +<li>riscv_intrinsic_fcvt_sw()&#160;:&#160;<a class="el" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a2103eb86052f6f8e24a8a848ffc6528a">neorv32_zfinx_extension_intrinsics.h</a></li> +<li>riscv_intrinsic_fcvt_swu()&#160;:&#160;<a class="el" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a837b7330f9d568791687ae1384b8ef28">neorv32_zfinx_extension_intrinsics.h</a></li> +<li>riscv_intrinsic_fcvt_ws()&#160;:&#160;<a class="el" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a523fa0fb6f521311c7f44692c586b3ee">neorv32_zfinx_extension_intrinsics.h</a></li> +<li>riscv_intrinsic_fcvt_wus()&#160;:&#160;<a class="el" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a3bc6ee3059a7e99b187c4ea5e217715b">neorv32_zfinx_extension_intrinsics.h</a></li> +<li>riscv_intrinsic_fdivs()&#160;:&#160;<a class="el" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#ab6a9d15643e3085ff80c7883f183a42b">neorv32_zfinx_extension_intrinsics.h</a></li> +<li>riscv_intrinsic_feqs()&#160;:&#160;<a class="el" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#af4ddfae45807d4e41f758672ee14cf7b">neorv32_zfinx_extension_intrinsics.h</a></li> +<li>riscv_intrinsic_fles()&#160;:&#160;<a class="el" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#adb83fab39d91e9291da2b7b07830cf82">neorv32_zfinx_extension_intrinsics.h</a></li> +<li>riscv_intrinsic_flts()&#160;:&#160;<a class="el" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a85aa18294a58997db2c324184196669c">neorv32_zfinx_extension_intrinsics.h</a></li> +<li>riscv_intrinsic_fmadds()&#160;:&#160;<a class="el" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#abbdb403cdeef414fa2f867b702d5f6eb">neorv32_zfinx_extension_intrinsics.h</a></li> +<li>riscv_intrinsic_fmaxs()&#160;:&#160;<a class="el" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a87c1ce499e5e43554cb0f407cf0d3f7f">neorv32_zfinx_extension_intrinsics.h</a></li> +<li>riscv_intrinsic_fmins()&#160;:&#160;<a class="el" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#abf7f9e466906306d9755fd5bc7946e3c">neorv32_zfinx_extension_intrinsics.h</a></li> +<li>riscv_intrinsic_fmsubs()&#160;:&#160;<a class="el" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a03aba9c70c5286dacebaeb0ef5219cc9">neorv32_zfinx_extension_intrinsics.h</a></li> +<li>riscv_intrinsic_fmuls()&#160;:&#160;<a class="el" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a87a106e0d24a3183712e438d2bcbfa2d">neorv32_zfinx_extension_intrinsics.h</a></li> +<li>riscv_intrinsic_fnmadds()&#160;:&#160;<a class="el" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#aa6473bc2d2721b57277b83a3ae0cfdb6">neorv32_zfinx_extension_intrinsics.h</a></li> +<li>riscv_intrinsic_fnmsubs()&#160;:&#160;<a class="el" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a639fc7bd75933888540e9cceb67221a0">neorv32_zfinx_extension_intrinsics.h</a></li> +<li>riscv_intrinsic_fsgnjns()&#160;:&#160;<a class="el" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#aa4010772a986d03929ba7a43dfdcddd9">neorv32_zfinx_extension_intrinsics.h</a></li> +<li>riscv_intrinsic_fsgnjs()&#160;:&#160;<a class="el" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#aff3acd90bcfbda96945f95a0e0bae12b">neorv32_zfinx_extension_intrinsics.h</a></li> +<li>riscv_intrinsic_fsgnjxs()&#160;:&#160;<a class="el" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a2235d91cdac03bf8071003a5c59b9dd0">neorv32_zfinx_extension_intrinsics.h</a></li> +<li>riscv_intrinsic_fsqrts()&#160;:&#160;<a class="el" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a17e2b7a399c956d548a609185084ea3c">neorv32_zfinx_extension_intrinsics.h</a></li> +<li>riscv_intrinsic_fsubs()&#160;:&#160;<a class="el" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#af8473ba61abab8ae2e3ecbaf22d70e89">neorv32_zfinx_extension_intrinsics.h</a></li> +<li>rte_service_handler()&#160;:&#160;<a class="el" href="processor__check_2main_8c.html#a349743a03307abb5130a3e89d903971b">main.c</a></li> +<li>RTE_TRAP_BREAKPOINT&#160;:&#160;<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa463611404367b5910c42dd31c0a218a2">neorv32_rte.h</a></li> +<li>RTE_TRAP_FIRQ_0&#160;:&#160;<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aab36a403cd7b833439ce7f9a708c33922">neorv32_rte.h</a></li> +<li>RTE_TRAP_FIRQ_1&#160;:&#160;<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aab199b53a1458017fa5278e0aeecf41fd">neorv32_rte.h</a></li> +<li>RTE_TRAP_FIRQ_10&#160;:&#160;<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aadebcc4d91aea1364b1481111f1060c52">neorv32_rte.h</a></li> +<li>RTE_TRAP_FIRQ_11&#160;:&#160;<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aab49ff0110481f22da22a085d2633a0e0">neorv32_rte.h</a></li> +<li>RTE_TRAP_FIRQ_12&#160;:&#160;<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aaecea4f1d524a33d02324382357b2bcb9">neorv32_rte.h</a></li> +<li>RTE_TRAP_FIRQ_13&#160;:&#160;<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa609613cf25bb8f2d0e323089d6798220">neorv32_rte.h</a></li> +<li>RTE_TRAP_FIRQ_14&#160;:&#160;<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aaadd66d9b9c33a6869fa3c30e1e434313">neorv32_rte.h</a></li> +<li>RTE_TRAP_FIRQ_15&#160;:&#160;<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa1d18312227bfd5332ebcc1f74c979dbe">neorv32_rte.h</a></li> +<li>RTE_TRAP_FIRQ_2&#160;:&#160;<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa29ffa3108fadc78bf375773c3232c489">neorv32_rte.h</a></li> +<li>RTE_TRAP_FIRQ_3&#160;:&#160;<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa4a74188fd87ea17a594ac6fe8ddf71be">neorv32_rte.h</a></li> +<li>RTE_TRAP_FIRQ_4&#160;:&#160;<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa8b39868bf91da54f9ec492918e0c01ff">neorv32_rte.h</a></li> +<li>RTE_TRAP_FIRQ_5&#160;:&#160;<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa01f562418ddbbb6b84be168673deeea9">neorv32_rte.h</a></li> +<li>RTE_TRAP_FIRQ_6&#160;:&#160;<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aac9fb28ea8bafff182f12c29d2fad6998">neorv32_rte.h</a></li> +<li>RTE_TRAP_FIRQ_7&#160;:&#160;<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa73bb84f7b6c7528bec552ac1d3e9ccdb">neorv32_rte.h</a></li> +<li>RTE_TRAP_FIRQ_8&#160;:&#160;<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa3edbf47bd9a278e100bb808c8bb68308">neorv32_rte.h</a></li> +<li>RTE_TRAP_FIRQ_9&#160;:&#160;<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa2cd04189d91465dad2bc2a8852406b76">neorv32_rte.h</a></li> +<li>RTE_TRAP_I_ACCESS&#160;:&#160;<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa931a4f314b04233924b01e8245153be4">neorv32_rte.h</a></li> +<li>RTE_TRAP_I_ILLEGAL&#160;:&#160;<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa48f4d253b260784a1ffaaded508166e2">neorv32_rte.h</a></li> +<li>RTE_TRAP_I_MISALIGNED&#160;:&#160;<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aaf647ff8d55d021379202879627c91d81">neorv32_rte.h</a></li> +<li>RTE_TRAP_L_ACCESS&#160;:&#160;<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa97047b024b72807a0b312979c9359dab">neorv32_rte.h</a></li> +<li>RTE_TRAP_L_MISALIGNED&#160;:&#160;<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa8e2cc9a533ebbc0e1d29c3ec8afbe61f">neorv32_rte.h</a></li> +<li>RTE_TRAP_MEI&#160;:&#160;<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aad2a55d5586d33497fd21b1da8aa98fff">neorv32_rte.h</a></li> +<li>RTE_TRAP_MENV_CALL&#160;:&#160;<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aaea6027bf0354c3120fa61c8094dd7a1d">neorv32_rte.h</a></li> +<li>RTE_TRAP_MSI&#160;:&#160;<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aadddffa9acdfcce80dd68ad4b26725174">neorv32_rte.h</a></li> +<li>RTE_TRAP_MTI&#160;:&#160;<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aacf17d4b2454c43a1cb544e532d247fff">neorv32_rte.h</a></li> +<li>RTE_TRAP_S_ACCESS&#160;:&#160;<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aaa9b8334712ecad0500c7610a25741ec7">neorv32_rte.h</a></li> +<li>RTE_TRAP_S_MISALIGNED&#160;:&#160;<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa85934b3fd8b5268340f84810b3f67232">neorv32_rte.h</a></li> +<li>RTE_TRAP_UENV_CALL&#160;:&#160;<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa155f84a52bace69f81a99de59701decc">neorv32_rte.h</a></li> +<li>RUN_ADDSUB_TESTS&#160;:&#160;<a class="el" href="float__corner__test_2main_8c.html#a2d16b9e484b7af7897c7ae83f945ceca">main.c</a></li> +<li>RUN_CLASSIFY_TESTS&#160;:&#160;<a class="el" href="float__corner__test_2main_8c.html#a7e134923925fa24fd1090281c3a416c3">main.c</a></li> +<li>RUN_COMPARE_TESTS&#160;:&#160;<a class="el" href="float__corner__test_2main_8c.html#a4ee0f6d28896a97d2c0cad866e77b874">main.c</a></li> +<li>RUN_CONV_TESTS&#160;:&#160;<a class="el" href="float__corner__test_2main_8c.html#aa3b6c4d49be7372de9e771a0475306ac">main.c</a></li> +<li>RUN_CSR_TESTS&#160;:&#160;<a class="el" href="floating__point__test_2main_8c.html#a7ec330b668b5b24d666d7769ccecfee3">main.c</a></li> +<li>RUN_EXC_TESTS&#160;:&#160;<a class="el" href="floating__point__test_2main_8c.html#a1a1af220e72c69b03d13b2df53650e10">main.c</a></li> +<li>RUN_MINMAX_TESTS&#160;:&#160;<a class="el" href="float__corner__test_2main_8c.html#aed386f612417aeeeac8b08db27d515e4">main.c</a></li> +<li>RUN_MUL_TESTS&#160;:&#160;<a class="el" href="float__corner__test_2main_8c.html#a97323ecaf1ae85e68a736b06bc3b58f8">main.c</a></li> +<li>RUN_SGNINJ_TESTS&#160;:&#160;<a class="el" href="float__corner__test_2main_8c.html#a94f0b0908f48f383145ed61ef8eb0713">main.c</a></li> +<li>RUN_TIMING_TESTS&#160;:&#160;<a class="el" href="float__corner__test_2main_8c.html#a6969308bd3633928893a2666f1df66fc">main.c</a></li> +<li>RUN_UNAVAIL_TESTS&#160;:&#160;<a class="el" href="float__corner__test_2main_8c.html#a923de9c3e55322d85522740c0d0ff867">main.c</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/globals_s.html b/sw/globals_s.html new file mode 100644 index 0000000000..91929a0cbd --- /dev/null +++ b/sw/globals_s.html @@ -0,0 +1,240 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: Globals</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +</div><!-- top --> +<div id="doc-content"> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div class="contents"> +<div class="textblock">Here is a list of all documented functions, variables, defines, enums, and typedefs with links to the documentation:</div> + +<h3><a id="index_s" name="index_s"></a>- s -</h3><ul> +<li>save_exe()&#160;:&#160;<a class="el" href="bootloader_8c.html#ababfffe8e7036179e150ad3b9bda3a74">bootloader.c</a></li> +<li>scan_bus()&#160;:&#160;<a class="el" href="demo__onewire_2main_8c.html#ac07c9cfd80ac2e24be9dac6cf943b7de">main.c</a></li> +<li>scan_twi()&#160;:&#160;<a class="el" href="demo__twi_2main_8c.html#aace46ee34e954f9ebee5873beb0785f1">main.c</a></li> +<li>SDI_CTRL_CS_ACTIVE&#160;:&#160;<a class="el" href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6ad288a52f2bdaa1ea6ddbadf7f32a3a63">neorv32_sdi.h</a></li> +<li>SDI_CTRL_EN&#160;:&#160;<a class="el" href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6af6016d120844c2d8d8da4fccc09f9809">neorv32_sdi.h</a></li> +<li>SDI_CTRL_FIFO_LSB&#160;:&#160;<a class="el" href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6a840c74518f55028608e2353ec6ce58c4">neorv32_sdi.h</a></li> +<li>SDI_CTRL_FIFO_MSB&#160;:&#160;<a class="el" href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6ab3b57f906bd3fc16242fa06601ce1716">neorv32_sdi.h</a></li> +<li>SDI_CTRL_IRQ_RX_AVAIL&#160;:&#160;<a class="el" href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6a2a611e339fd9ae7854931743802ff5c0">neorv32_sdi.h</a></li> +<li>SDI_CTRL_IRQ_RX_FULL&#160;:&#160;<a class="el" href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6a051d69f43c2b0f15c5e9e9252c906c9d">neorv32_sdi.h</a></li> +<li>SDI_CTRL_IRQ_RX_HALF&#160;:&#160;<a class="el" href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6af1e2abec3b3bc2ff9ecb2698d933a281">neorv32_sdi.h</a></li> +<li>SDI_CTRL_IRQ_TX_EMPTY&#160;:&#160;<a class="el" href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6a5df074faedb03cf3cc0cfa90eaccd210">neorv32_sdi.h</a></li> +<li>SDI_CTRL_IRQ_TX_NHALF&#160;:&#160;<a class="el" href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6a762237a6107ee690276c36108fa1c1ed">neorv32_sdi.h</a></li> +<li>SDI_CTRL_RX_AVAIL&#160;:&#160;<a class="el" href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6ae15186a46909f1a957269b21af6a14a0">neorv32_sdi.h</a></li> +<li>SDI_CTRL_RX_FULL&#160;:&#160;<a class="el" href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6a45ade3854c01dc1b14a80e3fea29417a">neorv32_sdi.h</a></li> +<li>SDI_CTRL_RX_HALF&#160;:&#160;<a class="el" href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6ac9381cffb4da427baf31cdbbeae5e1f4">neorv32_sdi.h</a></li> +<li>SDI_CTRL_TX_EMPTY&#160;:&#160;<a class="el" href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6aa9b89463a37e3a9c554195c2f87fb8d8">neorv32_sdi.h</a></li> +<li>SDI_CTRL_TX_FULL&#160;:&#160;<a class="el" href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6adb5c4613ce0a6178a01599cf8fd6984a">neorv32_sdi.h</a></li> +<li>SDI_CTRL_TX_NHALF&#160;:&#160;<a class="el" href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6aeac16a67f250cce5ea420790e80b8bb9">neorv32_sdi.h</a></li> +<li>SDI_FIRQ_ENABLE&#160;:&#160;<a class="el" href="neorv32_8h.html#a30cf20b6d704c50cc5c46238bb43646f">neorv32.h</a></li> +<li>SDI_FIRQ_PENDING&#160;:&#160;<a class="el" href="neorv32_8h.html#a68611c0dfbe331739eff10230ac3fede">neorv32.h</a></li> +<li>sdi_get()&#160;:&#160;<a class="el" href="demo__sdi_2main_8c.html#aa25f620a5631e862252be1d5429e8585">main.c</a></li> +<li>sdi_put()&#160;:&#160;<a class="el" href="demo__sdi_2main_8c.html#ae3dc843520a800d7ba2b5d6be03d9c3d">main.c</a></li> +<li>SDI_RTE_ID&#160;:&#160;<a class="el" href="neorv32_8h.html#aa0ff72ea560d7e1462787dc31bd467cf">neorv32.h</a></li> +<li>SDI_TRAP_CODE&#160;:&#160;<a class="el" href="neorv32_8h.html#a68925ca3f482f148caedd36118fd8d79">neorv32.h</a></li> +<li>send_twi()&#160;:&#160;<a class="el" href="demo__twi_2main_8c.html#aa94edd4f55a3ac18913f661f4bc16fb1">main.c</a></li> +<li>set_cell()&#160;:&#160;<a class="el" href="game__of__life_2main_8c.html#a5315eb56128f1ca40d9f4d477c345dd7">main.c</a></li> +<li>set_clock()&#160;:&#160;<a class="el" href="demo__twi_2main_8c.html#acee0c1770467f85a150d072ac7e1252f">main.c</a></li> +<li>setup_access()&#160;:&#160;<a class="el" href="bus__explorer_2main_8c.html#a2b6196c2e97a7f7702c0068780304ec1">main.c</a></li> +<li>show_1wire_commands()&#160;:&#160;<a class="el" href="demo__onewire_2main_8c.html#a29d5831498c2eaf0415d6f01efb9e7ce">main.c</a></li> +<li>show_arrays()&#160;:&#160;<a class="el" href="demo__dma_2main_8c.html#a8ad0c7bfd07edb6d42d86b166347206b">main.c</a></li> +<li>show_help()&#160;:&#160;<a class="el" href="demo__onewire_2main_8c.html#af25820ed386a66a0d6bb4dcdd2204704">main.c</a></li> +<li>SILENT_MODE&#160;:&#160;<a class="el" href="atomic__test_2main_8c.html#a87f296d7594bb8178cf76f0c045b7013">main.c</a></li> +<li>sim_irq_trigger()&#160;:&#160;<a class="el" href="processor__check_2main_8c.html#ada24f2cd9d2d384265517f539711de62">main.c</a></li> +<li>SLINK_CTRL_EN&#160;:&#160;<a class="el" href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1a739187f413b7436dc4037187e4a9e86a">neorv32_slink.h</a></li> +<li>SLINK_CTRL_IRQ_RX_FULL&#160;:&#160;<a class="el" href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1ac8a688706aee72d2027e022b64664309">neorv32_slink.h</a></li> +<li>SLINK_CTRL_IRQ_RX_HALF&#160;:&#160;<a class="el" href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1afa9353cd824d1b2833930ce9e922e392">neorv32_slink.h</a></li> +<li>SLINK_CTRL_IRQ_RX_NEMPTY&#160;:&#160;<a class="el" href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1a5452eab0fe12d174ec804c4c72060854">neorv32_slink.h</a></li> +<li>SLINK_CTRL_IRQ_TX_EMPTY&#160;:&#160;<a class="el" href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1ae06ad5f627f8902e2368e0daff6cfa88">neorv32_slink.h</a></li> +<li>SLINK_CTRL_IRQ_TX_NFULL&#160;:&#160;<a class="el" href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1a8f994f256f57c006c88b9e38df3f54fa">neorv32_slink.h</a></li> +<li>SLINK_CTRL_IRQ_TX_NHALF&#160;:&#160;<a class="el" href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1a7bf757dbfb1fdaddceaed3a3887003cf">neorv32_slink.h</a></li> +<li>SLINK_CTRL_RX_CLR&#160;:&#160;<a class="el" href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1a156fa3209b2652af6b58b0fdfc6cab1b">neorv32_slink.h</a></li> +<li>SLINK_CTRL_RX_EMPTY&#160;:&#160;<a class="el" href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1ae78f82e54bd9d737bbcbc5c7af0e9d4b">neorv32_slink.h</a></li> +<li>SLINK_CTRL_RX_FIFO_LSB&#160;:&#160;<a class="el" href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1a9c68af961c1147846929ca55e9e4e88c">neorv32_slink.h</a></li> +<li>SLINK_CTRL_RX_FIFO_MSB&#160;:&#160;<a class="el" href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1a945e2b7eda65dc13ca38eb21c9c4f657">neorv32_slink.h</a></li> +<li>SLINK_CTRL_RX_FULL&#160;:&#160;<a class="el" href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1aa7521fbe691fef233c0dff4053e4493e">neorv32_slink.h</a></li> +<li>SLINK_CTRL_RX_HALF&#160;:&#160;<a class="el" href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1af695158b9cf5466d87c207f9bd0a688e">neorv32_slink.h</a></li> +<li>SLINK_CTRL_RX_LAST&#160;:&#160;<a class="el" href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1a624723683d247668ef44137393e576aa">neorv32_slink.h</a></li> +<li>SLINK_CTRL_TX_CLR&#160;:&#160;<a class="el" href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1ad366597a44d3dff7dbab4cde72bed82f">neorv32_slink.h</a></li> +<li>SLINK_CTRL_TX_EMPTY&#160;:&#160;<a class="el" href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1a308cf7829ecca32f7a3da1bd74339854">neorv32_slink.h</a></li> +<li>SLINK_CTRL_TX_FIFO_LSB&#160;:&#160;<a class="el" href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1aba613343fc17715fc1bb07729588a12d">neorv32_slink.h</a></li> +<li>SLINK_CTRL_TX_FIFO_MSB&#160;:&#160;<a class="el" href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1af27a9e6e50b169d3f5efd0a08ba4a943">neorv32_slink.h</a></li> +<li>SLINK_CTRL_TX_FULL&#160;:&#160;<a class="el" href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1af94314ed65c6a8d9c364d99d7ae960ee">neorv32_slink.h</a></li> +<li>SLINK_CTRL_TX_HALF&#160;:&#160;<a class="el" href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1a530b8b76301f36fbda134b330447de78">neorv32_slink.h</a></li> +<li>SLINK_FIFO_EMPTY&#160;:&#160;<a class="el" href="neorv32__slink_8h.html#a84f7fe82f188bd4e68f41549587822bfa9f24886f55b7f78ae8909ea8a573058c">neorv32_slink.h</a></li> +<li>SLINK_FIFO_FULL&#160;:&#160;<a class="el" href="neorv32__slink_8h.html#a84f7fe82f188bd4e68f41549587822bfa2f96e61f0e07ef4ecd40f14e69b69211">neorv32_slink.h</a></li> +<li>SLINK_FIFO_HALF&#160;:&#160;<a class="el" href="neorv32__slink_8h.html#a84f7fe82f188bd4e68f41549587822bfadc37988b8aee38e85626064b2c3704f9">neorv32_slink.h</a></li> +<li>slink_firq_handler()&#160;:&#160;<a class="el" href="demo__slink_2main_8c.html#a48c79e20ed1d4138d61b5593bdbe537a">main.c</a></li> +<li>SLINK_ROUTE_DST_LSB&#160;:&#160;<a class="el" href="neorv32__slink_8h.html#ac3e5e02fd89a357135adca6d28cd0e45a9a2311357bd87c85a5cc45f08b0d8f80">neorv32_slink.h</a></li> +<li>SLINK_ROUTE_DST_MSB&#160;:&#160;<a class="el" href="neorv32__slink_8h.html#ac3e5e02fd89a357135adca6d28cd0e45a7e8da208ecaf142107587033e2d63ec1">neorv32_slink.h</a></li> +<li>SLINK_ROUTE_SRC_LSB&#160;:&#160;<a class="el" href="neorv32__slink_8h.html#ac3e5e02fd89a357135adca6d28cd0e45a69942c3a7b7b0550634f4016e639b0c2">neorv32_slink.h</a></li> +<li>SLINK_ROUTE_SRC_MSB&#160;:&#160;<a class="el" href="neorv32__slink_8h.html#ac3e5e02fd89a357135adca6d28cd0e45a7b7b0b9bd4fe448cae97a3a21460f983">neorv32_slink.h</a></li> +<li>SLINK_RX_FIRQ_ENABLE&#160;:&#160;<a class="el" href="neorv32_8h.html#a8680ab1f14e512f21913572b35cbbf77">neorv32.h</a></li> +<li>SLINK_RX_FIRQ_PENDING&#160;:&#160;<a class="el" href="neorv32_8h.html#a5c48d5c4effb47cdb019aa2da7c84526">neorv32.h</a></li> +<li>SLINK_RX_RTE_ID&#160;:&#160;<a class="el" href="neorv32_8h.html#a4fff18e72d10377cdcb8d2ac0a617a5d">neorv32.h</a></li> +<li>SLINK_RX_TRAP_CODE&#160;:&#160;<a class="el" href="neorv32_8h.html#ab1fdaedb2c4c8753ef3be87c82568dda">neorv32.h</a></li> +<li>SLINK_TX_FIRQ_ENABLE&#160;:&#160;<a class="el" href="neorv32_8h.html#a232fe0eb5665373b6e2b464bdc228df2">neorv32.h</a></li> +<li>SLINK_TX_FIRQ_PENDING&#160;:&#160;<a class="el" href="neorv32_8h.html#ac8e98b2af75c8e31f9815dee3dcbaf8e">neorv32.h</a></li> +<li>SLINK_TX_RTE_ID&#160;:&#160;<a class="el" href="neorv32_8h.html#a4e039d13b8d3f20453e1bb6b40512e43">neorv32.h</a></li> +<li>SLINK_TX_TRAP_CODE&#160;:&#160;<a class="el" href="neorv32_8h.html#a7fbe28901775e284d5700086f0b0bfcd">neorv32.h</a></li> +<li>SPI_BOOT_BASE_ADDR&#160;:&#160;<a class="el" href="bootloader_8c.html#a418adcf57119600c3580fd2297d28de0">bootloader.c</a></li> +<li>spi_cs()&#160;:&#160;<a class="el" href="demo__spi_2main_8c.html#a6f94991b8943a141ed4124585222470d">main.c</a></li> +<li>SPI_CS_ACTIVE&#160;:&#160;<a class="el" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba5e12c05349444d3d1defff49dec00580">neorv32_spi.h</a></li> +<li>SPI_CTRL_BUSY&#160;:&#160;<a class="el" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba7957cf1cf3997cd059ed81cba73a688c">neorv32_spi.h</a></li> +<li>SPI_CTRL_CDIV0&#160;:&#160;<a class="el" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3bae6db5cfa843a58d7c09783e7f29fa49f">neorv32_spi.h</a></li> +<li>SPI_CTRL_CDIV1&#160;:&#160;<a class="el" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba0b9ca202963b68b999f94baab50fbc48">neorv32_spi.h</a></li> +<li>SPI_CTRL_CDIV2&#160;:&#160;<a class="el" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba97aaa7a4ffcc6d17a00c4f992e517c46">neorv32_spi.h</a></li> +<li>SPI_CTRL_CDIV3&#160;:&#160;<a class="el" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba85164e4e00b5ccd34158f98f691bca29">neorv32_spi.h</a></li> +<li>SPI_CTRL_CPHA&#160;:&#160;<a class="el" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba4d787c993152a9417fcd50f76820c7b0">neorv32_spi.h</a></li> +<li>SPI_CTRL_CPOL&#160;:&#160;<a class="el" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba7661acb97cc8c6dd7f333be4f4a2d315">neorv32_spi.h</a></li> +<li>SPI_CTRL_EN&#160;:&#160;<a class="el" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba647a6357971f94b79b7672785c06a4ea">neorv32_spi.h</a></li> +<li>SPI_CTRL_FIFO_LSB&#160;:&#160;<a class="el" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba12f67abd206066651c1d62fc29fafcdb">neorv32_spi.h</a></li> +<li>SPI_CTRL_FIFO_MSB&#160;:&#160;<a class="el" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba8c0426f70974f0ab129481f2db7cf0ed">neorv32_spi.h</a></li> +<li>SPI_CTRL_HIGHSPEED&#160;:&#160;<a class="el" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3bac38b12af6b8fb6bf2fc6f6ff6baee91e">neorv32_spi.h</a></li> +<li>SPI_CTRL_IRQ_IDLE&#160;:&#160;<a class="el" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba3f80e9c6ef6445ad769038c955c171a2">neorv32_spi.h</a></li> +<li>SPI_CTRL_IRQ_RX_AVAIL&#160;:&#160;<a class="el" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba2cd2350ffc819b7198d1833b525c5ca0">neorv32_spi.h</a></li> +<li>SPI_CTRL_IRQ_TX_EMPTY&#160;:&#160;<a class="el" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3bafcdc17528f9f4521c02ec5c473b44622">neorv32_spi.h</a></li> +<li>SPI_CTRL_IRQ_TX_HALF&#160;:&#160;<a class="el" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba8c18d975418ad444255f80317448d26b">neorv32_spi.h</a></li> +<li>SPI_CTRL_PRSC0&#160;:&#160;<a class="el" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3babc927c4ea78433de697a9fe96f47248e">neorv32_spi.h</a></li> +<li>SPI_CTRL_PRSC1&#160;:&#160;<a class="el" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba49c38a34b95c034249a094fbc93e0a61">neorv32_spi.h</a></li> +<li>SPI_CTRL_PRSC2&#160;:&#160;<a class="el" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba7a5244e443e1fe4ff6b7a2176f90ae7a">neorv32_spi.h</a></li> +<li>SPI_CTRL_RX_AVAIL&#160;:&#160;<a class="el" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba115b097b76b3b99716f54a63c6ce5633">neorv32_spi.h</a></li> +<li>SPI_CTRL_TX_EMPTY&#160;:&#160;<a class="el" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba487b87333d33db0a05cd2a229225ffc6">neorv32_spi.h</a></li> +<li>SPI_CTRL_TX_FULL&#160;:&#160;<a class="el" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba96860d260b31ee4c232b6b0eb45f7905">neorv32_spi.h</a></li> +<li>SPI_CTRL_TX_NHALF&#160;:&#160;<a class="el" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba5efcaded20b93d2bffeaa4ea813f73b4">neorv32_spi.h</a></li> +<li>SPI_DATA_CMD&#160;:&#160;<a class="el" href="neorv32__spi_8h.html#aab478c23898c0b06cee53a1cbda38bf8a8b565083f989905b8335d9d22a14c4b6">neorv32_spi.h</a></li> +<li>SPI_DATA_CSEN&#160;:&#160;<a class="el" href="neorv32__spi_8h.html#aab478c23898c0b06cee53a1cbda38bf8a5673b6a3382dc5452e3cfcd4e8f3c8a2">neorv32_spi.h</a></li> +<li>SPI_DATA_LSB&#160;:&#160;<a class="el" href="neorv32__spi_8h.html#aab478c23898c0b06cee53a1cbda38bf8ae3c36a644c05cea0fccaefb9da90a1b4">neorv32_spi.h</a></li> +<li>SPI_DATA_MSB&#160;:&#160;<a class="el" href="neorv32__spi_8h.html#aab478c23898c0b06cee53a1cbda38bf8a0167ec9c252ee0228ab9d21f4acba600">neorv32_spi.h</a></li> +<li>SPI_EN&#160;:&#160;<a class="el" href="bootloader_8c.html#aea75cf0485ce0a4ea320eba994859686">bootloader.c</a></li> +<li>SPI_FIRQ_ENABLE&#160;:&#160;<a class="el" href="neorv32_8h.html#ab8fcd3f80c373eb0f9d0fc6bf64ca626">neorv32.h</a></li> +<li>SPI_FIRQ_PENDING&#160;:&#160;<a class="el" href="neorv32_8h.html#ab2f58f746febb29a9828447c733f8043">neorv32.h</a></li> +<li>SPI_FLASH_ADDR_BYTES&#160;:&#160;<a class="el" href="bootloader_8c.html#afe60a31c8561952f2f734fd67e6f7406">bootloader.c</a></li> +<li>spi_flash_check()&#160;:&#160;<a class="el" href="bootloader_8c.html#a1919595ed2232aebb3e774b916ab1662">bootloader.c</a></li> +<li>SPI_FLASH_CLK_PRSC&#160;:&#160;<a class="el" href="bootloader_8c.html#a709071a651213770b4efe6e6e055ec3d">bootloader.c</a></li> +<li>SPI_FLASH_CMD&#160;:&#160;<a class="el" href="demo__xip_2main_8c.html#af30de1c8d8502ad374612d308cfbd12e">main.c</a></li> +<li>SPI_FLASH_CMD_enum&#160;:&#160;<a class="el" href="bootloader_8c.html#aa5e5723e4cbf83805c3b1197cd401fed">bootloader.c</a></li> +<li>SPI_FLASH_CMD_PAGE_PROGRAM&#160;:&#160;<a class="el" href="bootloader_8c.html#aa5e5723e4cbf83805c3b1197cd401feda31c8d698c551d081a0adeafb988ed49e">bootloader.c</a></li> +<li>SPI_FLASH_CMD_READ&#160;:&#160;<a class="el" href="bootloader_8c.html#aa5e5723e4cbf83805c3b1197cd401feda6c1994ba2cfd97e0c77dcdf8bbdfdfa6">bootloader.c</a>, <a class="el" href="demo__xip_2main_8c.html#af30de1c8d8502ad374612d308cfbd12ea6c1994ba2cfd97e0c77dcdf8bbdfdfa6">main.c</a></li> +<li>SPI_FLASH_CMD_READ_STATUS&#160;:&#160;<a class="el" href="bootloader_8c.html#aa5e5723e4cbf83805c3b1197cd401feda5fbc6551a10549b38e5ab4a76c38f214">bootloader.c</a>, <a class="el" href="demo__xip_2main_8c.html#af30de1c8d8502ad374612d308cfbd12ea5fbc6551a10549b38e5ab4a76c38f214">main.c</a></li> +<li>SPI_FLASH_CMD_SECTOR_ERASE&#160;:&#160;<a class="el" href="bootloader_8c.html#aa5e5723e4cbf83805c3b1197cd401fedacd62141d6331f66e31bd252e2a92b836">bootloader.c</a>, <a class="el" href="demo__xip_2main_8c.html#af30de1c8d8502ad374612d308cfbd12eacd62141d6331f66e31bd252e2a92b836">main.c</a></li> +<li>SPI_FLASH_CMD_WAKE&#160;:&#160;<a class="el" href="bootloader_8c.html#aa5e5723e4cbf83805c3b1197cd401feda25bf16cd42b1fd1d95e0957b5be137d2">bootloader.c</a></li> +<li>SPI_FLASH_CMD_WRITE&#160;:&#160;<a class="el" href="demo__xip_2main_8c.html#af30de1c8d8502ad374612d308cfbd12ea528cebc54176f6f4c0a8f7f16fb28ca1">main.c</a></li> +<li>SPI_FLASH_CMD_WRITE_DISABLE&#160;:&#160;<a class="el" href="bootloader_8c.html#aa5e5723e4cbf83805c3b1197cd401fedaa91d3c1d788b21fc798a5976c9f0da77">bootloader.c</a>, <a class="el" href="demo__xip_2main_8c.html#af30de1c8d8502ad374612d308cfbd12eaa91d3c1d788b21fc798a5976c9f0da77">main.c</a></li> +<li>SPI_FLASH_CMD_WRITE_ENABLE&#160;:&#160;<a class="el" href="bootloader_8c.html#aa5e5723e4cbf83805c3b1197cd401feda152e091e93778f217f8b766298351513">bootloader.c</a>, <a class="el" href="demo__xip_2main_8c.html#af30de1c8d8502ad374612d308cfbd12ea152e091e93778f217f8b766298351513">main.c</a></li> +<li>SPI_FLASH_CS&#160;:&#160;<a class="el" href="bootloader_8c.html#aa2132454aada86216009f3af206899b1">bootloader.c</a></li> +<li>spi_flash_erase_sector()&#160;:&#160;<a class="el" href="bootloader_8c.html#a0d877f0611dfcee32a483c8a3660eb1b">bootloader.c</a></li> +<li>spi_flash_read_byte()&#160;:&#160;<a class="el" href="bootloader_8c.html#a09e72e2debdd94929b2be4c7713d5e17">bootloader.c</a></li> +<li>spi_flash_read_status()&#160;:&#160;<a class="el" href="bootloader_8c.html#a005966cd0b32f3d5c041028c4b1c99f5">bootloader.c</a></li> +<li>SPI_FLASH_SECTOR_SIZE&#160;:&#160;<a class="el" href="bootloader_8c.html#a00924a8ba223b2ca0e7031259b292c84">bootloader.c</a></li> +<li>SPI_FLASH_SREG&#160;:&#160;<a class="el" href="demo__xip_2main_8c.html#adccf1bb8f1f203cb1350f7f2eb15a08e">main.c</a></li> +<li>SPI_FLASH_SREG_enum&#160;:&#160;<a class="el" href="bootloader_8c.html#a97299f563ebc1fca4c663b025a15136f">bootloader.c</a></li> +<li>SPI_FLASH_SREG_WEL&#160;:&#160;<a class="el" href="demo__xip_2main_8c.html#adccf1bb8f1f203cb1350f7f2eb15a08ea90f3b76faed13819ee13e574d1bff0c1">main.c</a></li> +<li>SPI_FLASH_SREG_WIP&#160;:&#160;<a class="el" href="demo__xip_2main_8c.html#adccf1bb8f1f203cb1350f7f2eb15a08eac84de63bbea3989c71bcc92d1d01cfa4">main.c</a></li> +<li>spi_flash_wakeup()&#160;:&#160;<a class="el" href="bootloader_8c.html#a1fbdccc60f05756213c9f3d64bac6d47">bootloader.c</a></li> +<li>spi_flash_write_addr()&#160;:&#160;<a class="el" href="bootloader_8c.html#a6a8caddda6e729d747726471b0b0f742">bootloader.c</a></li> +<li>spi_flash_write_byte()&#160;:&#160;<a class="el" href="bootloader_8c.html#a006c27b7d80897b78ab8cd83a391331f">bootloader.c</a></li> +<li>spi_flash_write_disable()&#160;:&#160;<a class="el" href="bootloader_8c.html#a82d26a2d6293ed7fd44a5c622adfbd45">bootloader.c</a></li> +<li>spi_flash_write_enable()&#160;:&#160;<a class="el" href="bootloader_8c.html#a9642e28ef2baec5b356ad9a70970d0e6">bootloader.c</a></li> +<li>spi_flash_write_word()&#160;:&#160;<a class="el" href="bootloader_8c.html#a717c72166af7c2ff7e73bd0b47128338">bootloader.c</a></li> +<li>spi_irq_handler()&#160;:&#160;<a class="el" href="demo__spi__irq_2main_8c.html#a7e266cc5247c999948dacc2102bd184a">main.c</a></li> +<li>SPI_RTE_ID&#160;:&#160;<a class="el" href="neorv32_8h.html#a4c1cd9ec9f80da2080e5d0d35cc524dd">neorv32.h</a></li> +<li>spi_setup()&#160;:&#160;<a class="el" href="demo__spi_2main_8c.html#a755192be6c3cf9904564b0eee99de445">main.c</a></li> +<li>spi_trans()&#160;:&#160;<a class="el" href="demo__spi_2main_8c.html#a13e10b34fbbffca6c31f0ce25b3f8432">main.c</a></li> +<li>SPI_TRAP_CODE&#160;:&#160;<a class="el" href="neorv32_8h.html#a83c212f1f5d8ee2a5921b3b2b19e9cc4">neorv32.h</a></li> +<li>start_app()&#160;:&#160;<a class="el" href="bootloader_8c.html#ae8de91537ac2782f0f0ebc3b2d4fb1df">bootloader.c</a></li> +<li>STATUS_LED_EN&#160;:&#160;<a class="el" href="bootloader_8c.html#aa9696325b450773c7a87c991abca3a54">bootloader.c</a></li> +<li>STATUS_LED_PIN&#160;:&#160;<a class="el" href="bootloader_8c.html#a089a71f836911c71b3f73fdd3b4b890b">bootloader.c</a></li> +<li>str&#160;:&#160;<a class="el" href="bootloader_8c.html#af6cf19e40e97afb5a7c29f7b439d091d">bootloader.c</a></li> +<li>subnormal_flush()&#160;:&#160;<a class="el" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a791f880781a1bcea1861471be7d1a851">neorv32_zfinx_extension_intrinsics.h</a></li> +<li>system_error()&#160;:&#160;<a class="el" href="bootloader_8c.html#a3bdfe2f25b1bfb42f80624ffff22ab01">bootloader.c</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/globals_t.html b/sw/globals_t.html new file mode 100644 index 0000000000..4fdb43f246 --- /dev/null +++ b/sw/globals_t.html @@ -0,0 +1,175 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: Globals</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +</div><!-- top --> +<div id="doc-content"> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div class="contents"> +<div class="textblock">Here is a list of all documented functions, variables, defines, enums, and typedefs with links to the documentation:</div> + +<h3><a id="index_t" name="index_t"></a>- t -</h3><ul> +<li>test_fail()&#160;:&#160;<a class="el" href="processor__check_2main_8c.html#a1e0a5d63896fa26a6c25c0012fc6b938">main.c</a></li> +<li>test_ok()&#160;:&#160;<a class="el" href="processor__check_2main_8c.html#ae61d39109b2747429ec3a3c1b5533598">main.c</a></li> +<li>TESTCASES&#160;:&#160;<a class="el" href="demo__cfs_2main_8c.html#a906949f076e3e0d0082af3c3b1acb518">main.c</a></li> +<li>time_dec_hw&#160;:&#160;<a class="el" href="demo__cfu_2main_8c.html#acb6dd9d6ab74ac94f174a11ff3ad76af">main.c</a></li> +<li>time_dec_sw&#160;:&#160;<a class="el" href="demo__cfu_2main_8c.html#a2d3853c367c3bce99e787c0df445030a">main.c</a></li> +<li>time_enc_hw&#160;:&#160;<a class="el" href="demo__cfu_2main_8c.html#a094212e3731a9aecbd278fac243de6ec">main.c</a></li> +<li>time_enc_sw&#160;:&#160;<a class="el" href="demo__cfu_2main_8c.html#ad424a26173bd8d84b8d1cae94a55f248">main.c</a></li> +<li>TRAP_CODE_BREAKPOINT&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a2c9510cb7583a0144f96678fc217335e">neorv32_cpu_csr.h</a></li> +<li>TRAP_CODE_FIRQ_0&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a0cef77904935798d247d8396838297c1">neorv32_cpu_csr.h</a></li> +<li>TRAP_CODE_FIRQ_1&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1ae0b1049ae7f8cbfb6ff216e69ed5dae7">neorv32_cpu_csr.h</a></li> +<li>TRAP_CODE_FIRQ_10&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a4f6b9c6bba91fe04becb776ad22dcf42">neorv32_cpu_csr.h</a></li> +<li>TRAP_CODE_FIRQ_11&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a874dcc43cf8fbbf2e0614e7db9e38334">neorv32_cpu_csr.h</a></li> +<li>TRAP_CODE_FIRQ_12&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a151f01e5f284f876cafafc7427720e4c">neorv32_cpu_csr.h</a></li> +<li>TRAP_CODE_FIRQ_13&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a7c8e97297cc4dcd6d5a1de65a124f3e9">neorv32_cpu_csr.h</a></li> +<li>TRAP_CODE_FIRQ_14&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a821f813de47eb781ab7715f780da3b1e">neorv32_cpu_csr.h</a></li> +<li>TRAP_CODE_FIRQ_15&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1aa4eeafe2f6f59aff01e29461c664a110">neorv32_cpu_csr.h</a></li> +<li>TRAP_CODE_FIRQ_2&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1ad753d3e2563b4fd663430af9f3888dc7">neorv32_cpu_csr.h</a></li> +<li>TRAP_CODE_FIRQ_3&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a356f8485166529503d0fb246bd0aeeb0">neorv32_cpu_csr.h</a></li> +<li>TRAP_CODE_FIRQ_4&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1aaa8e7bb251852ef75a78be71eef0b547">neorv32_cpu_csr.h</a></li> +<li>TRAP_CODE_FIRQ_5&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a5789dfabd8ec265fa0734ddd94e98757">neorv32_cpu_csr.h</a></li> +<li>TRAP_CODE_FIRQ_6&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a809e997f55e83c6812c965655511d473">neorv32_cpu_csr.h</a></li> +<li>TRAP_CODE_FIRQ_7&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1aeab719bcce9e9551bd6da65a7ae08a26">neorv32_cpu_csr.h</a></li> +<li>TRAP_CODE_FIRQ_8&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1abfd21d1380dcacb9282e525da104d916">neorv32_cpu_csr.h</a></li> +<li>TRAP_CODE_FIRQ_9&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a350e762a599479fb2c6d23ccc5ee22b4">neorv32_cpu_csr.h</a></li> +<li>TRAP_CODE_I_ACCESS&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a6a0ebfce4e18f36aeb43d5a65445cfe1">neorv32_cpu_csr.h</a></li> +<li>TRAP_CODE_I_ILLEGAL&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1af1ad8f557f3b685b59a913611e1da173">neorv32_cpu_csr.h</a></li> +<li>TRAP_CODE_I_MISALIGNED&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a0a8010d7cc91b9557973a7a118828bee">neorv32_cpu_csr.h</a></li> +<li>TRAP_CODE_L_ACCESS&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a28448f0c670169140dc28b6794310cea">neorv32_cpu_csr.h</a></li> +<li>TRAP_CODE_L_MISALIGNED&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a69e68a954da0bb33d1624484a6777ff9">neorv32_cpu_csr.h</a></li> +<li>TRAP_CODE_MEI&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a1a412b9d8eefba7880555d34625d2cc0">neorv32_cpu_csr.h</a></li> +<li>TRAP_CODE_MENV_CALL&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a20e5a2680f2f5956bfa92852d5544eac">neorv32_cpu_csr.h</a></li> +<li>TRAP_CODE_MSI&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1ae0cebf99f36ef6be60e4a9d2c9f894b0">neorv32_cpu_csr.h</a></li> +<li>TRAP_CODE_MTI&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a187ae38819b81672c15808e63c3b46b7">neorv32_cpu_csr.h</a></li> +<li>TRAP_CODE_S_ACCESS&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a70bcfc75fe1056d93a3606f78c0cb887">neorv32_cpu_csr.h</a></li> +<li>TRAP_CODE_S_MISALIGNED&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a19708405f9f6300edf6b992c6d408a2d">neorv32_cpu_csr.h</a></li> +<li>TRAP_CODE_UENV_CALL&#160;:&#160;<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1aa102472d6a264bb92e0581ccaa413e02">neorv32_cpu_csr.h</a></li> +<li>trap_handler_emulate_amo()&#160;:&#160;<a class="el" href="atomic__test_2main_8c.html#aafcbf639ae4f66e5dfe9dea511a59f9d">main.c</a></li> +<li>trap_handler_emulate_unaligned_lw()&#160;:&#160;<a class="el" href="demo__emulate__unaligned_2main_8c.html#a07da42351229525998965b219e827460">main.c</a></li> +<li>trigger_module_dummy()&#160;:&#160;<a class="el" href="processor__check_2main_8c.html#ac91bfdd45696444673dc7d6b1b644082">main.c</a></li> +<li>TRNG_CTRL_DATA_LSB&#160;:&#160;<a class="el" href="neorv32__trng_8h.html#a1440e1355bf5bff17760992adc156b1aa50bb6e10e245a977dcf29a7a138776c6">neorv32_trng.h</a></li> +<li>TRNG_CTRL_DATA_MSB&#160;:&#160;<a class="el" href="neorv32__trng_8h.html#a1440e1355bf5bff17760992adc156b1aa95620874acc9393a05d670824c0bbed2">neorv32_trng.h</a></li> +<li>TRNG_CTRL_EN&#160;:&#160;<a class="el" href="neorv32__trng_8h.html#a1440e1355bf5bff17760992adc156b1aa0bdf0194eefe95884c5c5853a2f7670d">neorv32_trng.h</a></li> +<li>TRNG_CTRL_FIFO_CLR&#160;:&#160;<a class="el" href="neorv32__trng_8h.html#a1440e1355bf5bff17760992adc156b1aabf1bb7bc3b44394c85709edd1c9f03ac">neorv32_trng.h</a></li> +<li>TRNG_CTRL_FIFO_LSB&#160;:&#160;<a class="el" href="neorv32__trng_8h.html#a1440e1355bf5bff17760992adc156b1aa8c0325eede4ffec4530cfd5dc700dc52">neorv32_trng.h</a></li> +<li>TRNG_CTRL_FIFO_MSB&#160;:&#160;<a class="el" href="neorv32__trng_8h.html#a1440e1355bf5bff17760992adc156b1aa919c3105723e4fe46e341c63cbf276f5">neorv32_trng.h</a></li> +<li>TRNG_CTRL_IRQ_SEL&#160;:&#160;<a class="el" href="neorv32__trng_8h.html#a1440e1355bf5bff17760992adc156b1aa968a770fe6b172183dd97818e09c63da">neorv32_trng.h</a></li> +<li>TRNG_CTRL_SIM_MODE&#160;:&#160;<a class="el" href="neorv32__trng_8h.html#a1440e1355bf5bff17760992adc156b1aaa6990058793ac7d96250693f935837c5">neorv32_trng.h</a></li> +<li>TRNG_CTRL_VALID&#160;:&#160;<a class="el" href="neorv32__trng_8h.html#a1440e1355bf5bff17760992adc156b1aa2e0079358668db409fb763eaccb93da9">neorv32_trng.h</a></li> +<li>TRNG_FIRQ_ENABLE&#160;:&#160;<a class="el" href="neorv32_8h.html#a2896d832852c016eb85210b523642f11">neorv32.h</a></li> +<li>TRNG_FIRQ_PENDING&#160;:&#160;<a class="el" href="neorv32_8h.html#a9c387ca4e2736a27056c11819947c84a">neorv32.h</a></li> +<li>TRNG_RTE_ID&#160;:&#160;<a class="el" href="neorv32_8h.html#afaa705a674acf3fd6c8cb294eaf11c5e">neorv32.h</a></li> +<li>TRNG_TRAP_CODE&#160;:&#160;<a class="el" href="neorv32_8h.html#a11e34802c61a01fd6cba46e3f92d5ac1">neorv32.h</a></li> +<li>TWI_CTRL_BUSY&#160;:&#160;<a class="el" href="neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaa443a2a65ee810f428d40a4f8474d8e6d">neorv32_twi.h</a></li> +<li>TWI_CTRL_CDIV0&#160;:&#160;<a class="el" href="neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaa75d3a61b5e642e5d5c1f699c35c26b31">neorv32_twi.h</a></li> +<li>TWI_CTRL_CDIV1&#160;:&#160;<a class="el" href="neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaa4473769463a0c7e4b58ed0b983610674">neorv32_twi.h</a></li> +<li>TWI_CTRL_CDIV2&#160;:&#160;<a class="el" href="neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaaa6db454861ad5be70846ed4f9eb2ea12">neorv32_twi.h</a></li> +<li>TWI_CTRL_CDIV3&#160;:&#160;<a class="el" href="neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaa99e2153a53cc1f9d7cc83d52c698cbcc">neorv32_twi.h</a></li> +<li>TWI_CTRL_CLKSTR&#160;:&#160;<a class="el" href="neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaac62d6e3c47a8195a6a9ccc79129bfe48">neorv32_twi.h</a></li> +<li>TWI_CTRL_EN&#160;:&#160;<a class="el" href="neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaa43381fe5ab9fe64ebdf76638eba5a694">neorv32_twi.h</a></li> +<li>TWI_CTRL_FIFO_LSB&#160;:&#160;<a class="el" href="neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaa74126d424719b1db61f5e1ab567489fb">neorv32_twi.h</a></li> +<li>TWI_CTRL_FIFO_MSB&#160;:&#160;<a class="el" href="neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaa183f5b9c3993d04cc9aea2a79e9a4f75">neorv32_twi.h</a></li> +<li>TWI_CTRL_PRSC0&#160;:&#160;<a class="el" href="neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaa9033ac6cc891bff0da52449aa4b6a8d9">neorv32_twi.h</a></li> +<li>TWI_CTRL_PRSC1&#160;:&#160;<a class="el" href="neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaa8b666cd2e40ca9ba3f9a635f0ed107df">neorv32_twi.h</a></li> +<li>TWI_CTRL_PRSC2&#160;:&#160;<a class="el" href="neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaa4d55ed983ca2f94fa9deac196d949b31">neorv32_twi.h</a></li> +<li>TWI_CTRL_RX_AVAIL&#160;:&#160;<a class="el" href="neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaad2798dfabf3a72e6138135e983734671">neorv32_twi.h</a></li> +<li>TWI_CTRL_TX_FULL&#160;:&#160;<a class="el" href="neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaaa0597dc9dea3f6f7a2f19dbcc7a2dabb">neorv32_twi.h</a></li> +<li>TWI_DCMD_ACK&#160;:&#160;<a class="el" href="neorv32__twi_8h.html#a3421852c63baca60fe58c990b1c653d8af64359afd3627db0a79733d00128f3a5">neorv32_twi.h</a></li> +<li>TWI_DCMD_CMD_HI&#160;:&#160;<a class="el" href="neorv32__twi_8h.html#a3421852c63baca60fe58c990b1c653d8accd7e8be435db3055c27f0a6d5e0201e">neorv32_twi.h</a></li> +<li>TWI_DCMD_CMD_LO&#160;:&#160;<a class="el" href="neorv32__twi_8h.html#a3421852c63baca60fe58c990b1c653d8ab2e20f7f5a5b131c31772341caa97e5e">neorv32_twi.h</a></li> +<li>TWI_DCMD_LSB&#160;:&#160;<a class="el" href="neorv32__twi_8h.html#a3421852c63baca60fe58c990b1c653d8adf6176c87655bbbb5c7cea9dea29ce56">neorv32_twi.h</a></li> +<li>TWI_DCMD_MSB&#160;:&#160;<a class="el" href="neorv32__twi_8h.html#a3421852c63baca60fe58c990b1c653d8ab7f53f7cef06031c1a34db04c602a50d">neorv32_twi.h</a></li> +<li>TWI_FIRQ_ENABLE&#160;:&#160;<a class="el" href="neorv32_8h.html#a0913144fce247e24ccd0f178b9ac32b7">neorv32.h</a></li> +<li>TWI_FIRQ_PENDING&#160;:&#160;<a class="el" href="neorv32_8h.html#a48b80113ca718fbdc50d75e1ec96a1ff">neorv32.h</a></li> +<li>TWI_RTE_ID&#160;:&#160;<a class="el" href="neorv32_8h.html#a1ac29f2f7bace5ba92b2b68a4541a60c">neorv32.h</a></li> +<li>TWI_TRAP_CODE&#160;:&#160;<a class="el" href="neorv32_8h.html#a0afc1a759116d4d73a199ef769bced47">neorv32.h</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/globals_u.html b/sw/globals_u.html new file mode 100644 index 0000000000..476ed2bad6 --- /dev/null +++ b/sw/globals_u.html @@ -0,0 +1,159 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: Globals</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +</div><!-- top --> +<div id="doc-content"> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div class="contents"> +<div class="textblock">Here is a list of all documented functions, variables, defines, enums, and typedefs with links to the documentation:</div> + +<h3><a id="index_u" name="index_u"></a>- u -</h3><ul> +<li>UART0_RX_FIRQ_ENABLE&#160;:&#160;<a class="el" href="neorv32_8h.html#a6b55ce6abe6b141000a6bb00949169e9">neorv32.h</a></li> +<li>UART0_RX_FIRQ_PENDING&#160;:&#160;<a class="el" href="neorv32_8h.html#a0b738b26abb2b951f1f5c5d9525d7701">neorv32.h</a></li> +<li>UART0_RX_RTE_ID&#160;:&#160;<a class="el" href="neorv32_8h.html#ae8588cca20d5e36f74c5207c376389a1">neorv32.h</a></li> +<li>UART0_RX_TRAP_CODE&#160;:&#160;<a class="el" href="neorv32_8h.html#a7a849638eff31f2e1955bdc53d4fc84d">neorv32.h</a></li> +<li>UART0_TX_FIRQ_ENABLE&#160;:&#160;<a class="el" href="neorv32_8h.html#aff756a395771f22c5f412f23f177ea7d">neorv32.h</a></li> +<li>UART0_TX_FIRQ_PENDING&#160;:&#160;<a class="el" href="neorv32_8h.html#addbe29166bb77bc045ad0e3db68e57e9">neorv32.h</a></li> +<li>UART0_TX_RTE_ID&#160;:&#160;<a class="el" href="neorv32_8h.html#a9dc37695ca169bc0eb93898e7aeeee58">neorv32.h</a></li> +<li>UART0_TX_TRAP_CODE&#160;:&#160;<a class="el" href="neorv32_8h.html#ab50df423fdba86bb83bc5d90a4c3bb20">neorv32.h</a></li> +<li>UART1_RX_FIRQ_ENABLE&#160;:&#160;<a class="el" href="neorv32_8h.html#a6c118c1784d8446360b00cde97437ca7">neorv32.h</a></li> +<li>UART1_RX_FIRQ_PENDING&#160;:&#160;<a class="el" href="neorv32_8h.html#a2e70d3a4e2973d224643813fcf315a20">neorv32.h</a></li> +<li>UART1_RX_RTE_ID&#160;:&#160;<a class="el" href="neorv32_8h.html#ab1c351f5ea19ac9ea864155be9cc0b4b">neorv32.h</a></li> +<li>UART1_RX_TRAP_CODE&#160;:&#160;<a class="el" href="neorv32_8h.html#ad0b9eb2ee1f411d7fccdf4fe263214e1">neorv32.h</a></li> +<li>UART1_TX_FIRQ_ENABLE&#160;:&#160;<a class="el" href="neorv32_8h.html#a0039bae3454a22e71d64e70d674f5d6a">neorv32.h</a></li> +<li>UART1_TX_FIRQ_PENDING&#160;:&#160;<a class="el" href="neorv32_8h.html#ac4060532b7aa390623f54720460a2680">neorv32.h</a></li> +<li>UART1_TX_RTE_ID&#160;:&#160;<a class="el" href="neorv32_8h.html#a6af270d7ae8b1cde30e44eb9142491d3">neorv32.h</a></li> +<li>UART1_TX_TRAP_CODE&#160;:&#160;<a class="el" href="neorv32_8h.html#a4cc50287c7a53982761a8116396ff7dd">neorv32.h</a></li> +<li>UART_BAUD&#160;:&#160;<a class="el" href="bootloader_8c.html#a1fac9153314479ad0ad495d752f0224a">bootloader.c</a></li> +<li>UART_CTRL_BAUD0&#160;:&#160;<a class="el" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afcad38432e7e050276d4667daf92c1e3fd5">neorv32_uart.h</a></li> +<li>UART_CTRL_BAUD1&#160;:&#160;<a class="el" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca1e702002402897eca82bf398504bc439">neorv32_uart.h</a></li> +<li>UART_CTRL_BAUD2&#160;:&#160;<a class="el" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca36266026e11f22aca1584bd81cd38cd6">neorv32_uart.h</a></li> +<li>UART_CTRL_BAUD3&#160;:&#160;<a class="el" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca58190cd41c2ce69512bea10740d35276">neorv32_uart.h</a></li> +<li>UART_CTRL_BAUD4&#160;:&#160;<a class="el" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca81ea805f01b93a59664823b940c7a424">neorv32_uart.h</a></li> +<li>UART_CTRL_BAUD5&#160;:&#160;<a class="el" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca5da1d6007af0265fe48ace8469e07833">neorv32_uart.h</a></li> +<li>UART_CTRL_BAUD6&#160;:&#160;<a class="el" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca9ac3c1e23d684cb2f67060d6ebe1fa63">neorv32_uart.h</a></li> +<li>UART_CTRL_BAUD7&#160;:&#160;<a class="el" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca9c12648f7f058f444db434cd8a8d854e">neorv32_uart.h</a></li> +<li>UART_CTRL_BAUD8&#160;:&#160;<a class="el" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca09c311eb1f6b38500e6fcbb6ad9dd9ff">neorv32_uart.h</a></li> +<li>UART_CTRL_BAUD9&#160;:&#160;<a class="el" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca697321bddeaa2cac1ea034c418be540e">neorv32_uart.h</a></li> +<li>UART_CTRL_EN&#160;:&#160;<a class="el" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca38f6c0e5991f8f80159a388c1080f7c2">neorv32_uart.h</a></li> +<li>UART_CTRL_HWFC_EN&#160;:&#160;<a class="el" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afcacab78fcd440167c5a2c0f5d300c8f07c">neorv32_uart.h</a></li> +<li>UART_CTRL_IRQ_RX_FULL&#160;:&#160;<a class="el" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afcae5f01868b170d71a5f3064023c96a82a">neorv32_uart.h</a></li> +<li>UART_CTRL_IRQ_RX_HALF&#160;:&#160;<a class="el" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afcaa219ea3ed5b21f5023bbc5ffa5c5f175">neorv32_uart.h</a></li> +<li>UART_CTRL_IRQ_RX_NEMPTY&#160;:&#160;<a class="el" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca569ea830518914c5330fa14680b02851">neorv32_uart.h</a></li> +<li>UART_CTRL_IRQ_TX_EMPTY&#160;:&#160;<a class="el" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca15b9fca73877aad446a8cd338e228e2c">neorv32_uart.h</a></li> +<li>UART_CTRL_IRQ_TX_NHALF&#160;:&#160;<a class="el" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca726b73ef9c44ccc1a45a4230a8bda9d1">neorv32_uart.h</a></li> +<li>UART_CTRL_PRSC0&#160;:&#160;<a class="el" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca1ddbca448bb30c77c42499fff1312183">neorv32_uart.h</a></li> +<li>UART_CTRL_PRSC1&#160;:&#160;<a class="el" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca9c1d8e8763a653339210ff4e6e3067d2">neorv32_uart.h</a></li> +<li>UART_CTRL_PRSC2&#160;:&#160;<a class="el" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca8afd60e4bd3854fab623b91fa4f33f70">neorv32_uart.h</a></li> +<li>UART_CTRL_RX_CLR&#160;:&#160;<a class="el" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afcaefbef37247d88a7e38e1c53b8a33ed33">neorv32_uart.h</a></li> +<li>UART_CTRL_RX_FULL&#160;:&#160;<a class="el" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca47c44fa21e51401621c28019025c1166">neorv32_uart.h</a></li> +<li>UART_CTRL_RX_HALF&#160;:&#160;<a class="el" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca3fc934d0ce6b36e3e131c6682db22247">neorv32_uart.h</a></li> +<li>UART_CTRL_RX_NEMPTY&#160;:&#160;<a class="el" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca2015dd85e361aa0476e847953b62baff">neorv32_uart.h</a></li> +<li>UART_CTRL_RX_OVER&#160;:&#160;<a class="el" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca81a52e0b81018f2cf43e64d74caba632">neorv32_uart.h</a></li> +<li>UART_CTRL_SIM_MODE&#160;:&#160;<a class="el" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca42ed376220259ab22c6f837d08273ef1">neorv32_uart.h</a></li> +<li>UART_CTRL_TX_BUSY&#160;:&#160;<a class="el" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca0eb636d8b7961d7073c5c7341b5bbe25">neorv32_uart.h</a></li> +<li>UART_CTRL_TX_CLR&#160;:&#160;<a class="el" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca408412a32673cc7f6ea70682e3e61431">neorv32_uart.h</a></li> +<li>UART_CTRL_TX_EMPTY&#160;:&#160;<a class="el" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afcac5c044233b6c4162cf862f3d9831ef46">neorv32_uart.h</a></li> +<li>UART_CTRL_TX_FULL&#160;:&#160;<a class="el" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca36b4195e5d1f12e1fd1a0d30cad0e411">neorv32_uart.h</a></li> +<li>UART_CTRL_TX_NHALF&#160;:&#160;<a class="el" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca5b0e40ab30bdb198f496d09e89d2d0d9">neorv32_uart.h</a></li> +<li>UART_DATA_RTX_LSB&#160;:&#160;<a class="el" href="neorv32__uart_8h.html#adcf35350a9ea18a59c32c35f528643f2ae70e9f6cd69af724932e79ea7e7f7195">neorv32_uart.h</a></li> +<li>UART_DATA_RTX_MSB&#160;:&#160;<a class="el" href="neorv32__uart_8h.html#adcf35350a9ea18a59c32c35f528643f2a19926d013ca202645d38f2c704782ebb">neorv32_uart.h</a></li> +<li>UART_DATA_RX_FIFO_SIZE_LSB&#160;:&#160;<a class="el" href="neorv32__uart_8h.html#adcf35350a9ea18a59c32c35f528643f2a43b296e86d1f2ec7400d57655c3180ef">neorv32_uart.h</a></li> +<li>UART_DATA_RX_FIFO_SIZE_MSB&#160;:&#160;<a class="el" href="neorv32__uart_8h.html#adcf35350a9ea18a59c32c35f528643f2a81a82ac0dc5c8c8d7af21553288e3225">neorv32_uart.h</a></li> +<li>UART_DATA_TX_FIFO_SIZE_LSB&#160;:&#160;<a class="el" href="neorv32__uart_8h.html#adcf35350a9ea18a59c32c35f528643f2a6d718ad0bb82a5cb053c117cd2d6ca8e">neorv32_uart.h</a></li> +<li>UART_DATA_TX_FIFO_SIZE_MSB&#160;:&#160;<a class="el" href="neorv32__uart_8h.html#adcf35350a9ea18a59c32c35f528643f2ada92cbbe278e3e0592eba58c97699529">neorv32_uart.h</a></li> +<li>UART_EN&#160;:&#160;<a class="el" href="bootloader_8c.html#af1c2f103ac6e3183f08b39099fab2be9">bootloader.c</a></li> +<li>uart_get_executable()&#160;:&#160;<a class="el" href="demo__xip_2main_8c.html#a0458656f8a108ff31f4bbbd005f029a0">main.c</a></li> +<li>uart_get_word()&#160;:&#160;<a class="el" href="demo__xip_2main_8c.html#a3043d09bdc155f57f45cd91e0cd4d15b">main.c</a></li> +<li>UART_HW_HANDSHAKE_EN&#160;:&#160;<a class="el" href="bootloader_8c.html#a20e93d623ce07939c3fdd53898f9d583">bootloader.c</a></li> +<li>universe&#160;:&#160;<a class="el" href="game__of__life_2main_8c.html#ae0b5214cf0cd93049e9df8a95a09d826">main.c</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/globals_v.html b/sw/globals_v.html new file mode 100644 index 0000000000..86ebfa7481 --- /dev/null +++ b/sw/globals_v.html @@ -0,0 +1,104 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: Globals</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +</div><!-- top --> +<div id="doc-content"> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div class="contents"> +<div class="textblock">Here is a list of all documented functions, variables, defines, enums, and typedefs with links to the documentation:</div> + +<h3><a id="index_v" name="index_v"></a>- v -</h3><ul> +<li>vectored_global_handler()&#160;:&#160;<a class="el" href="processor__check_2main_8c.html#a9504ca74fdb80711a88d2a16d4cb4cf4">main.c</a></li> +<li>vectored_irq_table()&#160;:&#160;<a class="el" href="processor__check_2main_8c.html#a0d695ebfaae3b4614ddb62640cbf8b7b">main.c</a></li> +<li>vectored_mei_handler()&#160;:&#160;<a class="el" href="processor__check_2main_8c.html#a1a455bede4ab48f32d3ed0868e398044">main.c</a></li> +<li>verify_result()&#160;:&#160;<a class="el" href="float__corner__test_2main_8c.html#a941ef8d24fd8e8fe4536626b2ce72410">main.c</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/globals_vars.html b/sw/globals_vars.html new file mode 100644 index 0000000000..8248cafd3f --- /dev/null +++ b/sw/globals_vars.html @@ -0,0 +1,119 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: Globals</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +</div><!-- top --> +<div id="doc-content"> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div class="contents"> +<div class="textblock">Here is a list of all documented variables with links to the documentation:</div><ul> +<li>__crt0_max_heap&#160;:&#160;<a class="el" href="demo__newlib_2main_8c.html#aaa2cb9e7075a852870fd67eff2861b18">main.c</a></li> +<li>__neorv32_rte_vector_lut&#160;:&#160;<a class="el" href="neorv32__rte_8c.html#a2c8272b4628edddb943bcfad829b561a">neorv32_rte.c</a></li> +<li>__neorv32_xirq_vector_lut&#160;:&#160;<a class="el" href="neorv32__xirq_8c.html#a76d73c3bf372989703c685a9e8d229ac">neorv32_xirq.c</a></li> +<li>amo_var&#160;:&#160;<a class="el" href="atomic__test_2main_8c.html#a9141e95a5f98420ddf8a43e6d20ff6dc">main.c</a></li> +<li>cypher_data_hw&#160;:&#160;<a class="el" href="demo__cfu_2main_8c.html#a9ad2780a4cfe0d9cb4f1a846a92063ae">main.c</a></li> +<li>cypher_data_sw&#160;:&#160;<a class="el" href="demo__cfu_2main_8c.html#a33b2d9298edf94c5961e67a59c371d00">main.c</a></li> +<li>data_block&#160;:&#160;<a class="el" href="demo__emulate__unaligned_2main_8c.html#a556f675911f865ead06c36072b1b9c3b">main.c</a></li> +<li>error_message&#160;:&#160;<a class="el" href="bootloader_8c.html#a6fea855ffe2fa0cd5ea9f98c0d5adc4d">bootloader.c</a></li> +<li>exe_available&#160;:&#160;<a class="el" href="bootloader_8c.html#a0f9fcfdf758260b9b79b6eda063dd87a">bootloader.c</a></li> +<li>getting_exe&#160;:&#160;<a class="el" href="bootloader_8c.html#a5fa6b109bf211d1768f84c9d38eef240">bootloader.c</a></li> +<li>input_data&#160;:&#160;<a class="el" href="demo__cfu_2main_8c.html#a2e2ccb9136736a673dbef71f207e97a0">main.c</a></li> +<li>key&#160;:&#160;<a class="el" href="demo__cfu_2main_8c.html#ab5c498f9da12ab2d6ddc89bf4a46dec6">main.c</a></li> +<li>plain_data_hw&#160;:&#160;<a class="el" href="demo__cfu_2main_8c.html#aee8dde13fe2f5ac52dd6075e2fe1eab5">main.c</a></li> +<li>plain_data_sw&#160;:&#160;<a class="el" href="demo__cfu_2main_8c.html#a72ba1460776ad684028448ca51810bbe">main.c</a></li> +<li>ram_buffer&#160;:&#160;<a class="el" href="demo__xip_2main_8c.html#acc95e55a622d79c2a398397d1f9b8033">main.c</a></li> +<li>time_dec_hw&#160;:&#160;<a class="el" href="demo__cfu_2main_8c.html#acb6dd9d6ab74ac94f174a11ff3ad76af">main.c</a></li> +<li>time_dec_sw&#160;:&#160;<a class="el" href="demo__cfu_2main_8c.html#a2d3853c367c3bce99e787c0df445030a">main.c</a></li> +<li>time_enc_hw&#160;:&#160;<a class="el" href="demo__cfu_2main_8c.html#a094212e3731a9aecbd278fac243de6ec">main.c</a></li> +<li>time_enc_sw&#160;:&#160;<a class="el" href="demo__cfu_2main_8c.html#ad424a26173bd8d84b8d1cae94a55f248">main.c</a></li> +<li>universe&#160;:&#160;<a class="el" href="game__of__life_2main_8c.html#ae0b5214cf0cd93049e9df8a95a09d826">main.c</a></li> +<li>xtea_delta&#160;:&#160;<a class="el" href="demo__cfu_2main_8c.html#a26da64691624f3c899f2394a427d6593">main.c</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/globals_w.html b/sw/globals_w.html new file mode 100644 index 0000000000..8b17563fc9 --- /dev/null +++ b/sw/globals_w.html @@ -0,0 +1,116 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: Globals</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +</div><!-- top --> +<div id="doc-content"> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div class="contents"> +<div class="textblock">Here is a list of all documented functions, variables, defines, enums, and typedefs with links to the documentation:</div> + +<h3><a id="index_w" name="index_w"></a>- w -</h3><ul> +<li>WDT_CTRL_DBEN&#160;:&#160;<a class="el" href="neorv32__wdt_8h.html#a0a4cb24fd818277c5bb9b10ff519f23ea4b0d994fe5ff8d8004c7f25b621fb3a9">neorv32_wdt.h</a></li> +<li>WDT_CTRL_EN&#160;:&#160;<a class="el" href="neorv32__wdt_8h.html#a0a4cb24fd818277c5bb9b10ff519f23ea0e078b41b69bd6089acceb592e14553f">neorv32_wdt.h</a></li> +<li>WDT_CTRL_LOCK&#160;:&#160;<a class="el" href="neorv32__wdt_8h.html#a0a4cb24fd818277c5bb9b10ff519f23eadc44267502fceb8e7311dfa502fe54d3">neorv32_wdt.h</a></li> +<li>WDT_CTRL_RCAUSE_HI&#160;:&#160;<a class="el" href="neorv32__wdt_8h.html#a0a4cb24fd818277c5bb9b10ff519f23ea6012d63ea4734fc8a063c9edc6785abd">neorv32_wdt.h</a></li> +<li>WDT_CTRL_RCAUSE_LO&#160;:&#160;<a class="el" href="neorv32__wdt_8h.html#a0a4cb24fd818277c5bb9b10ff519f23ea0e7d3e97517f97042ce5606dd5247779">neorv32_wdt.h</a></li> +<li>WDT_CTRL_SEN&#160;:&#160;<a class="el" href="neorv32__wdt_8h.html#a0a4cb24fd818277c5bb9b10ff519f23ea7b7ea5bd390ecbb5ee0d9542ef124148">neorv32_wdt.h</a></li> +<li>WDT_CTRL_STRICT&#160;:&#160;<a class="el" href="neorv32__wdt_8h.html#a0a4cb24fd818277c5bb9b10ff519f23ea28dd25b66c4a50d0ea47a16c460031ac">neorv32_wdt.h</a></li> +<li>WDT_CTRL_TIMEOUT_LSB&#160;:&#160;<a class="el" href="neorv32__wdt_8h.html#a0a4cb24fd818277c5bb9b10ff519f23ea45df3c9100beb420add34bf71a0e8609">neorv32_wdt.h</a></li> +<li>WDT_CTRL_TIMEOUT_MSB&#160;:&#160;<a class="el" href="neorv32__wdt_8h.html#a0a4cb24fd818277c5bb9b10ff519f23ea25dea2104b29a3c20dcc3782c2d43dc7">neorv32_wdt.h</a></li> +<li>WDT_PASSWORD&#160;:&#160;<a class="el" href="neorv32__wdt_8h.html#af2a2bd9c74bdba1b46bd92025bd00ab6">neorv32_wdt.h</a></li> +<li>WDT_RCAUSE_EXT&#160;:&#160;<a class="el" href="neorv32__wdt_8h.html#a70098b4ee893774864536fb4100ff049ac5fc25cdc29c248b1a570b6095ddded0">neorv32_wdt.h</a></li> +<li>WDT_RCAUSE_OCD&#160;:&#160;<a class="el" href="neorv32__wdt_8h.html#a70098b4ee893774864536fb4100ff049a764a7797f17d82f619a6d30c0878bf1e">neorv32_wdt.h</a></li> +<li>WDT_RCAUSE_WDT&#160;:&#160;<a class="el" href="neorv32__wdt_8h.html#a70098b4ee893774864536fb4100ff049a974e73fb98b6a3591c214eba6071fd3c">neorv32_wdt.h</a></li> +<li>WDT_TIMEOUT_S&#160;:&#160;<a class="el" href="demo__wdt_2main_8c.html#a01af3905e60b1869f669315f4a1297f5">main.c</a></li> +<li>write_byte()&#160;:&#160;<a class="el" href="demo__onewire_2main_8c.html#a28283848f09bf8feebc860a51545f487">main.c</a></li> +<li>write_memory()&#160;:&#160;<a class="el" href="bus__explorer_2main_8c.html#a96729fb5279642ac56c8e6a513789b45">main.c</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/globals_x.html b/sw/globals_x.html new file mode 100644 index 0000000000..9d6722bc01 --- /dev/null +++ b/sw/globals_x.html @@ -0,0 +1,147 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: Globals</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +</div><!-- top --> +<div id="doc-content"> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div class="contents"> +<div class="textblock">Here is a list of all documented functions, variables, defines, enums, and typedefs with links to the documentation:</div> + +<h3><a id="index_x" name="index_x"></a>- x -</h3><ul> +<li>XIP_CLK_PRSC&#160;:&#160;<a class="el" href="demo__xip_2main_8c.html#aec72efe062dbdb149ae6d4f8b1be6793">main.c</a></li> +<li>XIP_CTRL_BURST_EN&#160;:&#160;<a class="el" href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba7ad9f81356d6923d524d1c9e39acdd2c">neorv32_xip.h</a></li> +<li>XIP_CTRL_CDIV0&#160;:&#160;<a class="el" href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483cebaf9b56aa629973ce4a9c8ff61a2c90ba3">neorv32_xip.h</a></li> +<li>XIP_CTRL_CDIV1&#160;:&#160;<a class="el" href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba68775854b8f2cfa2f32d2eb82a714073">neorv32_xip.h</a></li> +<li>XIP_CTRL_CDIV2&#160;:&#160;<a class="el" href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba43d7305e0e0398cb44c99e70dcd96445">neorv32_xip.h</a></li> +<li>XIP_CTRL_CDIV3&#160;:&#160;<a class="el" href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba61ffffe9acda5c622b48b6360e357eef">neorv32_xip.h</a></li> +<li>XIP_CTRL_CPHA&#160;:&#160;<a class="el" href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483cebad31736f4a159745be94b487079c4c14d">neorv32_xip.h</a></li> +<li>XIP_CTRL_CPOL&#160;:&#160;<a class="el" href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba95ae19cf5d5140df397ead62f151247f">neorv32_xip.h</a></li> +<li>XIP_CTRL_EN&#160;:&#160;<a class="el" href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba27658ce3cc81c9e258b73fb02d7f1045">neorv32_xip.h</a></li> +<li>XIP_CTRL_HIGHSPEED&#160;:&#160;<a class="el" href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483cebaaeb104a59215667aabb5a751632ae781">neorv32_xip.h</a></li> +<li>XIP_CTRL_PHY_BUSY&#160;:&#160;<a class="el" href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba76d2379d0e7ab09e7e686bc886888fa5">neorv32_xip.h</a></li> +<li>XIP_CTRL_PRSC0&#160;:&#160;<a class="el" href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba67a0c0483eaf92e9cd03e9076be5b50d">neorv32_xip.h</a></li> +<li>XIP_CTRL_PRSC1&#160;:&#160;<a class="el" href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483cebae47f2e1e8c023fd52e25a3dad5e332af">neorv32_xip.h</a></li> +<li>XIP_CTRL_PRSC2&#160;:&#160;<a class="el" href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba896815c075a91a8291585eb61b6e0086">neorv32_xip.h</a></li> +<li>XIP_CTRL_RD_CMD_LSB&#160;:&#160;<a class="el" href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba8287016f167727f147806aa11129e05b">neorv32_xip.h</a></li> +<li>XIP_CTRL_RD_CMD_MSB&#160;:&#160;<a class="el" href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba2c78cd2d32cfba4d89f7aab92f7939e7">neorv32_xip.h</a></li> +<li>XIP_CTRL_SPI_CSEN&#160;:&#160;<a class="el" href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba5aadb2c374d34b878b56a660baec2080">neorv32_xip.h</a></li> +<li>XIP_CTRL_SPI_NBYTES_LSB&#160;:&#160;<a class="el" href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba23be66e49d28dd12c5321e576d2f0c7a">neorv32_xip.h</a></li> +<li>XIP_CTRL_SPI_NBYTES_MSB&#160;:&#160;<a class="el" href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba5d13c4fe190fcd68dfcbbbe33d2e844c">neorv32_xip.h</a></li> +<li>XIP_CTRL_XIP_ABYTES_LSB&#160;:&#160;<a class="el" href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba603f9d8d22ae2a6abc61b666bc88a4df">neorv32_xip.h</a></li> +<li>XIP_CTRL_XIP_ABYTES_MSB&#160;:&#160;<a class="el" href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba5885ed5fcd2eed969bd921afe8dff4fc">neorv32_xip.h</a></li> +<li>XIP_CTRL_XIP_BUSY&#160;:&#160;<a class="el" href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba2c4a47f88d299782b8618b68fb87d59a">neorv32_xip.h</a></li> +<li>XIP_CTRL_XIP_EN&#160;:&#160;<a class="el" href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba3cbd45a66e05a4fcfc5ec810b8cee937">neorv32_xip.h</a></li> +<li>XIP_EN&#160;:&#160;<a class="el" href="bootloader_8c.html#a2cf31934b909299fb93bb5eebdbc7c9e">bootloader.c</a></li> +<li>xip_flash_access_check()&#160;:&#160;<a class="el" href="demo__xip_2main_8c.html#a23bd7bd7b0808d919fd09ac0a8258498">main.c</a></li> +<li>xip_flash_erase_sector()&#160;:&#160;<a class="el" href="demo__xip_2main_8c.html#a9e0b2714126b6699ddb65485c93293e4">main.c</a></li> +<li>xip_flash_program()&#160;:&#160;<a class="el" href="demo__xip_2main_8c.html#a4ddfa8fdc072cadeef18a4a10bc8b174">main.c</a></li> +<li>XIP_MEM_BASE_ADDRESS&#160;:&#160;<a class="el" href="neorv32_8h.html#aa01bea676e878a9e87ca10ce2d91e51f">neorv32.h</a></li> +<li>XIRQ_FIRQ_ENABLE&#160;:&#160;<a class="el" href="neorv32_8h.html#afe0cb262d517c7da73d6b5dc78886334">neorv32.h</a></li> +<li>XIRQ_FIRQ_PENDING&#160;:&#160;<a class="el" href="neorv32_8h.html#a866768963f8648363dce40de9f34d61b">neorv32.h</a></li> +<li>xirq_handler_ch0()&#160;:&#160;<a class="el" href="demo__xirq_2main_8c.html#a8874ccfc0b56171c359b5c2ceaf2bd80">main.c</a></li> +<li>xirq_handler_ch1()&#160;:&#160;<a class="el" href="demo__xirq_2main_8c.html#abfe0c0bc47a683ba55df2aed63a12d4b">main.c</a></li> +<li>xirq_handler_ch2()&#160;:&#160;<a class="el" href="demo__xirq_2main_8c.html#ae8e3b3236aa2303c2b5e6e421b72cf73">main.c</a></li> +<li>xirq_handler_ch3()&#160;:&#160;<a class="el" href="demo__xirq_2main_8c.html#a99e9ae3088f39995c852b2c53ec21266">main.c</a></li> +<li>XIRQ_RTE_ID&#160;:&#160;<a class="el" href="neorv32_8h.html#a95387d3482ec8e5c1d734805fdf64fa5">neorv32.h</a></li> +<li>XIRQ_TRAP_CODE&#160;:&#160;<a class="el" href="neorv32_8h.html#a16b9a7444833b5581df073661deb8f3a">neorv32.h</a></li> +<li>xirq_trap_handler0()&#160;:&#160;<a class="el" href="processor__check_2main_8c.html#aa4fe70578c4dccabe1e31fae941378cb">main.c</a></li> +<li>xirq_trap_handler1()&#160;:&#160;<a class="el" href="processor__check_2main_8c.html#a277cb06ef74e4cfe1ef783069f9b6527">main.c</a></li> +<li>XIRQ_TRIGGER_EDGE_FALLING&#160;:&#160;<a class="el" href="neorv32__xirq_8h.html#a59316ffc7ee1aacf1d55d460bdca4d04">neorv32_xirq.h</a></li> +<li>XIRQ_TRIGGER_EDGE_RISING&#160;:&#160;<a class="el" href="neorv32__xirq_8h.html#ab7a05371e4dc3de3a9be11c59f5376ee">neorv32_xirq.h</a></li> +<li>XIRQ_TRIGGER_LEVEL_HIGH&#160;:&#160;<a class="el" href="neorv32__xirq_8h.html#a9b10e89b2e257e1af410bff89f29911c">neorv32_xirq.h</a></li> +<li>XIRQ_TRIGGER_LEVEL_LOW&#160;:&#160;<a class="el" href="neorv32__xirq_8h.html#a8bc89e6a47b4d0d95fb2afac4cdc9292">neorv32_xirq.h</a></li> +<li>xstr&#160;:&#160;<a class="el" href="bootloader_8c.html#aff6b53dd58cea43d24393a9a2f79e772">bootloader.c</a></li> +<li>XTEA_CYCLES&#160;:&#160;<a class="el" href="demo__cfu_2main_8c.html#a34755f457331741d24090b3819b5d416">main.c</a></li> +<li>xtea_delta&#160;:&#160;<a class="el" href="demo__cfu_2main_8c.html#a26da64691624f3c899f2394a427d6593">main.c</a></li> +<li>xtea_sw_decipher()&#160;:&#160;<a class="el" href="demo__cfu_2main_8c.html#a0e980c5d81b1eca90b8073e54099bdb0">main.c</a></li> +<li>xtea_sw_encipher()&#160;:&#160;<a class="el" href="demo__cfu_2main_8c.html#a8dc502bf508491eed1f39c4acf040efb">main.c</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/hello__world_2main_8c.html b/sw/hello__world_2main_8c.html new file mode 100644 index 0000000000..5cc6facaa9 --- /dev/null +++ b/sw/hello__world_2main_8c.html @@ -0,0 +1,161 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/example/hello_world/main.c File Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_f0f9b27afba2e8cc2da6e5fddcc1a8c9.html">example</a></li><li class="navelem"><a class="el" href="dir_d4640980cbf1943e4a4aee6e8b810c7a.html">hello_world</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#func-members">Functions</a> </div> + <div class="headertitle"><div class="title">main.c File Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p>Classic 'hello world' demo program. +<a href="#details">More...</a></p> +<div class="textblock"><code>#include &lt;<a class="el" href="neorv32_8h_source.html">neorv32.h</a>&gt;</code><br /> +</div><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="define-members" name="define-members"></a> +Macros</h2></td></tr> +<tr><td colspan="2"><div class="groupHeader">User configuration</div></td></tr> +<tr class="memitem:ad4455691936f92fdd6c37566fc58ba1f" id="r_ad4455691936f92fdd6c37566fc58ba1f"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ad4455691936f92fdd6c37566fc58ba1f">BAUD_RATE</a>&#160;&#160;&#160;19200</td></tr> +<tr class="separator:ad4455691936f92fdd6c37566fc58ba1f"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="func-members" name="func-members"></a> +Functions</h2></td></tr> +<tr class="memitem:ae66f6b31b5ad750f1fe042a706a4e3d4" id="r_ae66f6b31b5ad750f1fe042a706a4e3d4"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ae66f6b31b5ad750f1fe042a706a4e3d4">main</a> ()</td></tr> +<tr class="separator:ae66f6b31b5ad750f1fe042a706a4e3d4"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>Classic 'hello world' demo program. </p> +<dl class="section author"><dt>Author</dt><dd>Stephan Nolting </dd></dl> +</div><h2 class="groupheader">Macro Definition Documentation</h2> +<a id="ad4455691936f92fdd6c37566fc58ba1f" name="ad4455691936f92fdd6c37566fc58ba1f"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ad4455691936f92fdd6c37566fc58ba1f">&#9670;&#160;</a></span>BAUD_RATE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define BAUD_RATE&#160;&#160;&#160;19200</td> + </tr> + </table> +</div><div class="memdoc"> +<p>UART BAUD rate </p> + +</div> +</div> +<h2 class="groupheader">Function Documentation</h2> +<a id="ae66f6b31b5ad750f1fe042a706a4e3d4" name="ae66f6b31b5ad750f1fe042a706a4e3d4"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ae66f6b31b5ad750f1fe042a706a4e3d4">&#9670;&#160;</a></span>main()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int main </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Main function; prints some fancy stuff via UART.</p> +<dl class="section note"><dt>Note</dt><dd>This program requires the UART interface to be synthesized.</dd></dl> +<dl class="section return"><dt>Returns</dt><dd>0 if execution was successful </dd></dl> + +</div> +</div> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/index.html b/sw/index.html new file mode 100644 index 0000000000..5cc7ac2d69 --- /dev/null +++ b/sw/index.html @@ -0,0 +1,100 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: Main Page</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +</div><!-- top --> +<div id="doc-content"> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div class="header"> + <div class="headertitle"><div class="title">NEORV32 Software Framework Documentation Documentation</div></div> +</div><!--header--> +<div class="contents"> +<a href="doxygen_crawl.html"/> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/jquery.js b/sw/jquery.js new file mode 100644 index 0000000000..1dffb65b58 --- /dev/null +++ b/sw/jquery.js @@ -0,0 +1,34 @@ +/*! jQuery v3.6.0 | (c) OpenJS Foundation and other contributors | jquery.org/license */ +!function(e,t){"use strict";"object"==typeof module&&"object"==typeof module.exports?module.exports=e.document?t(e,!0):function(e){if(!e.document)throw new Error("jQuery requires a window with a document");return t(e)}:t(e)}("undefined"!=typeof window?window:this,function(C,e){"use strict";var t=[],r=Object.getPrototypeOf,s=t.slice,g=t.flat?function(e){return t.flat.call(e)}:function(e){return t.concat.apply([],e)},u=t.push,i=t.indexOf,n={},o=n.toString,v=n.hasOwnProperty,a=v.toString,l=a.call(Object),y={},m=function(e){return"function"==typeof e&&"number"!=typeof e.nodeType&&"function"!=typeof e.item},x=function(e){return null!=e&&e===e.window},E=C.document,c={type:!0,src:!0,nonce:!0,noModule:!0};function b(e,t,n){var r,i,o=(n=n||E).createElement("script");if(o.text=e,t)for(r in c)(i=t[r]||t.getAttribute&&t.getAttribute(r))&&o.setAttribute(r,i);n.head.appendChild(o).parentNode.removeChild(o)}function w(e){return null==e?e+"":"object"==typeof e||"function"==typeof e?n[o.call(e)]||"object":typeof e}var f="3.6.0",S=function(e,t){return new S.fn.init(e,t)};function p(e){var t=!!e&&"length"in e&&e.length,n=w(e);return!m(e)&&!x(e)&&("array"===n||0===t||"number"==typeof t&&0<t&&t-1 in e)}S.fn=S.prototype={jquery:f,constructor:S,length:0,toArray:function(){return s.call(this)},get:function(e){return null==e?s.call(this):e<0?this[e+this.length]:this[e]},pushStack:function(e){var t=S.merge(this.constructor(),e);return t.prevObject=this,t},each:function(e){return S.each(this,e)},map:function(n){return this.pushStack(S.map(this,function(e,t){return n.call(e,t,e)}))},slice:function(){return this.pushStack(s.apply(this,arguments))},first:function(){return this.eq(0)},last:function(){return this.eq(-1)},even:function(){return this.pushStack(S.grep(this,function(e,t){return(t+1)%2}))},odd:function(){return this.pushStack(S.grep(this,function(e,t){return t%2}))},eq:function(e){var t=this.length,n=+e+(e<0?t:0);return this.pushStack(0<=n&&n<t?[this[n]]:[])},end:function(){return this.prevObject||this.constructor()},push:u,sort:t.sort,splice:t.splice},S.extend=S.fn.extend=function(){var e,t,n,r,i,o,a=arguments[0]||{},s=1,u=arguments.length,l=!1;for("boolean"==typeof a&&(l=a,a=arguments[s]||{},s++),"object"==typeof a||m(a)||(a={}),s===u&&(a=this,s--);s<u;s++)if(null!=(e=arguments[s]))for(t in e)r=e[t],"__proto__"!==t&&a!==r&&(l&&r&&(S.isPlainObject(r)||(i=Array.isArray(r)))?(n=a[t],o=i&&!Array.isArray(n)?[]:i||S.isPlainObject(n)?n:{},i=!1,a[t]=S.extend(l,o,r)):void 0!==r&&(a[t]=r));return a},S.extend({expando:"jQuery"+(f+Math.random()).replace(/\D/g,""),isReady:!0,error:function(e){throw new Error(e)},noop:function(){},isPlainObject:function(e){var t,n;return!(!e||"[object Object]"!==o.call(e))&&(!(t=r(e))||"function"==typeof(n=v.call(t,"constructor")&&t.constructor)&&a.call(n)===l)},isEmptyObject:function(e){var t;for(t in e)return!1;return!0},globalEval:function(e,t,n){b(e,{nonce:t&&t.nonce},n)},each:function(e,t){var n,r=0;if(p(e)){for(n=e.length;r<n;r++)if(!1===t.call(e[r],r,e[r]))break}else for(r in e)if(!1===t.call(e[r],r,e[r]))break;return e},makeArray:function(e,t){var n=t||[];return null!=e&&(p(Object(e))?S.merge(n,"string"==typeof e?[e]:e):u.call(n,e)),n},inArray:function(e,t,n){return null==t?-1:i.call(t,e,n)},merge:function(e,t){for(var n=+t.length,r=0,i=e.length;r<n;r++)e[i++]=t[r];return e.length=i,e},grep:function(e,t,n){for(var r=[],i=0,o=e.length,a=!n;i<o;i++)!t(e[i],i)!==a&&r.push(e[i]);return r},map:function(e,t,n){var r,i,o=0,a=[];if(p(e))for(r=e.length;o<r;o++)null!=(i=t(e[o],o,n))&&a.push(i);else for(o in e)null!=(i=t(e[o],o,n))&&a.push(i);return g(a)},guid:1,support:y}),"function"==typeof Symbol&&(S.fn[Symbol.iterator]=t[Symbol.iterator]),S.each("Boolean Number String Function Array Date RegExp Object Error Symbol".split(" "),function(e,t){n["[object "+t+"]"]=t.toLowerCase()});var d=function(n){var e,d,b,o,i,h,f,g,w,u,l,T,C,a,E,v,s,c,y,S="sizzle"+1*new Date,p=n.document,k=0,r=0,m=ue(),x=ue(),A=ue(),N=ue(),j=function(e,t){return e===t&&(l=!0),0},D={}.hasOwnProperty,t=[],q=t.pop,L=t.push,H=t.push,O=t.slice,P=function(e,t){for(var n=0,r=e.length;n<r;n++)if(e[n]===t)return n;return-1},R="checked|selected|async|autofocus|autoplay|controls|defer|disabled|hidden|ismap|loop|multiple|open|readonly|required|scoped",M="[\\x20\\t\\r\\n\\f]",I="(?:\\\\[\\da-fA-F]{1,6}"+M+"?|\\\\[^\\r\\n\\f]|[\\w-]|[^\0-\\x7f])+",W="\\["+M+"*("+I+")(?:"+M+"*([*^$|!~]?=)"+M+"*(?:'((?:\\\\.|[^\\\\'])*)'|\"((?:\\\\.|[^\\\\\"])*)\"|("+I+"))|)"+M+"*\\]",F=":("+I+")(?:\\((('((?:\\\\.|[^\\\\'])*)'|\"((?:\\\\.|[^\\\\\"])*)\")|((?:\\\\.|[^\\\\()[\\]]|"+W+")*)|.*)\\)|)",B=new RegExp(M+"+","g"),$=new RegExp("^"+M+"+|((?:^|[^\\\\])(?:\\\\.)*)"+M+"+$","g"),_=new RegExp("^"+M+"*,"+M+"*"),z=new RegExp("^"+M+"*([>+~]|"+M+")"+M+"*"),U=new RegExp(M+"|>"),X=new RegExp(F),V=new RegExp("^"+I+"$"),G={ID:new RegExp("^#("+I+")"),CLASS:new RegExp("^\\.("+I+")"),TAG:new RegExp("^("+I+"|[*])"),ATTR:new RegExp("^"+W),PSEUDO:new RegExp("^"+F),CHILD:new RegExp("^:(only|first|last|nth|nth-last)-(child|of-type)(?:\\("+M+"*(even|odd|(([+-]|)(\\d*)n|)"+M+"*(?:([+-]|)"+M+"*(\\d+)|))"+M+"*\\)|)","i"),bool:new RegExp("^(?:"+R+")$","i"),needsContext:new RegExp("^"+M+"*[>+~]|:(even|odd|eq|gt|lt|nth|first|last)(?:\\("+M+"*((?:-\\d)?\\d*)"+M+"*\\)|)(?=[^-]|$)","i")},Y=/HTML$/i,Q=/^(?:input|select|textarea|button)$/i,J=/^h\d$/i,K=/^[^{]+\{\s*\[native \w/,Z=/^(?:#([\w-]+)|(\w+)|\.([\w-]+))$/,ee=/[+~]/,te=new RegExp("\\\\[\\da-fA-F]{1,6}"+M+"?|\\\\([^\\r\\n\\f])","g"),ne=function(e,t){var n="0x"+e.slice(1)-65536;return t||(n<0?String.fromCharCode(n+65536):String.fromCharCode(n>>10|55296,1023&n|56320))},re=/([\0-\x1f\x7f]|^-?\d)|^-$|[^\0-\x1f\x7f-\uFFFF\w-]/g,ie=function(e,t){return t?"\0"===e?"\ufffd":e.slice(0,-1)+"\\"+e.charCodeAt(e.length-1).toString(16)+" ":"\\"+e},oe=function(){T()},ae=be(function(e){return!0===e.disabled&&"fieldset"===e.nodeName.toLowerCase()},{dir:"parentNode",next:"legend"});try{H.apply(t=O.call(p.childNodes),p.childNodes),t[p.childNodes.length].nodeType}catch(e){H={apply:t.length?function(e,t){L.apply(e,O.call(t))}:function(e,t){var n=e.length,r=0;while(e[n++]=t[r++]);e.length=n-1}}}function se(t,e,n,r){var i,o,a,s,u,l,c,f=e&&e.ownerDocument,p=e?e.nodeType:9;if(n=n||[],"string"!=typeof t||!t||1!==p&&9!==p&&11!==p)return n;if(!r&&(T(e),e=e||C,E)){if(11!==p&&(u=Z.exec(t)))if(i=u[1]){if(9===p){if(!(a=e.getElementById(i)))return n;if(a.id===i)return n.push(a),n}else if(f&&(a=f.getElementById(i))&&y(e,a)&&a.id===i)return n.push(a),n}else{if(u[2])return H.apply(n,e.getElementsByTagName(t)),n;if((i=u[3])&&d.getElementsByClassName&&e.getElementsByClassName)return H.apply(n,e.getElementsByClassName(i)),n}if(d.qsa&&!N[t+" "]&&(!v||!v.test(t))&&(1!==p||"object"!==e.nodeName.toLowerCase())){if(c=t,f=e,1===p&&(U.test(t)||z.test(t))){(f=ee.test(t)&&ye(e.parentNode)||e)===e&&d.scope||((s=e.getAttribute("id"))?s=s.replace(re,ie):e.setAttribute("id",s=S)),o=(l=h(t)).length;while(o--)l[o]=(s?"#"+s:":scope")+" "+xe(l[o]);c=l.join(",")}try{return H.apply(n,f.querySelectorAll(c)),n}catch(e){N(t,!0)}finally{s===S&&e.removeAttribute("id")}}}return g(t.replace($,"$1"),e,n,r)}function ue(){var r=[];return function e(t,n){return r.push(t+" ")>b.cacheLength&&delete e[r.shift()],e[t+" "]=n}}function le(e){return e[S]=!0,e}function ce(e){var t=C.createElement("fieldset");try{return!!e(t)}catch(e){return!1}finally{t.parentNode&&t.parentNode.removeChild(t),t=null}}function fe(e,t){var n=e.split("|"),r=n.length;while(r--)b.attrHandle[n[r]]=t}function pe(e,t){var n=t&&e,r=n&&1===e.nodeType&&1===t.nodeType&&e.sourceIndex-t.sourceIndex;if(r)return r;if(n)while(n=n.nextSibling)if(n===t)return-1;return e?1:-1}function de(t){return function(e){return"input"===e.nodeName.toLowerCase()&&e.type===t}}function he(n){return function(e){var t=e.nodeName.toLowerCase();return("input"===t||"button"===t)&&e.type===n}}function ge(t){return function(e){return"form"in e?e.parentNode&&!1===e.disabled?"label"in e?"label"in e.parentNode?e.parentNode.disabled===t:e.disabled===t:e.isDisabled===t||e.isDisabled!==!t&&ae(e)===t:e.disabled===t:"label"in e&&e.disabled===t}}function ve(a){return le(function(o){return o=+o,le(function(e,t){var n,r=a([],e.length,o),i=r.length;while(i--)e[n=r[i]]&&(e[n]=!(t[n]=e[n]))})})}function ye(e){return e&&"undefined"!=typeof e.getElementsByTagName&&e}for(e in d=se.support={},i=se.isXML=function(e){var t=e&&e.namespaceURI,n=e&&(e.ownerDocument||e).documentElement;return!Y.test(t||n&&n.nodeName||"HTML")},T=se.setDocument=function(e){var t,n,r=e?e.ownerDocument||e:p;return r!=C&&9===r.nodeType&&r.documentElement&&(a=(C=r).documentElement,E=!i(C),p!=C&&(n=C.defaultView)&&n.top!==n&&(n.addEventListener?n.addEventListener("unload",oe,!1):n.attachEvent&&n.attachEvent("onunload",oe)),d.scope=ce(function(e){return a.appendChild(e).appendChild(C.createElement("div")),"undefined"!=typeof e.querySelectorAll&&!e.querySelectorAll(":scope fieldset div").length}),d.attributes=ce(function(e){return e.className="i",!e.getAttribute("className")}),d.getElementsByTagName=ce(function(e){return e.appendChild(C.createComment("")),!e.getElementsByTagName("*").length}),d.getElementsByClassName=K.test(C.getElementsByClassName),d.getById=ce(function(e){return a.appendChild(e).id=S,!C.getElementsByName||!C.getElementsByName(S).length}),d.getById?(b.filter.ID=function(e){var t=e.replace(te,ne);return function(e){return e.getAttribute("id")===t}},b.find.ID=function(e,t){if("undefined"!=typeof t.getElementById&&E){var n=t.getElementById(e);return n?[n]:[]}}):(b.filter.ID=function(e){var n=e.replace(te,ne);return function(e){var t="undefined"!=typeof e.getAttributeNode&&e.getAttributeNode("id");return t&&t.value===n}},b.find.ID=function(e,t){if("undefined"!=typeof t.getElementById&&E){var n,r,i,o=t.getElementById(e);if(o){if((n=o.getAttributeNode("id"))&&n.value===e)return[o];i=t.getElementsByName(e),r=0;while(o=i[r++])if((n=o.getAttributeNode("id"))&&n.value===e)return[o]}return[]}}),b.find.TAG=d.getElementsByTagName?function(e,t){return"undefined"!=typeof t.getElementsByTagName?t.getElementsByTagName(e):d.qsa?t.querySelectorAll(e):void 0}:function(e,t){var n,r=[],i=0,o=t.getElementsByTagName(e);if("*"===e){while(n=o[i++])1===n.nodeType&&r.push(n);return r}return o},b.find.CLASS=d.getElementsByClassName&&function(e,t){if("undefined"!=typeof t.getElementsByClassName&&E)return t.getElementsByClassName(e)},s=[],v=[],(d.qsa=K.test(C.querySelectorAll))&&(ce(function(e){var t;a.appendChild(e).innerHTML="<a id='"+S+"'></a><select id='"+S+"-\r\\' msallowcapture=''><option selected=''></option></select>",e.querySelectorAll("[msallowcapture^='']").length&&v.push("[*^$]="+M+"*(?:''|\"\")"),e.querySelectorAll("[selected]").length||v.push("\\["+M+"*(?:value|"+R+")"),e.querySelectorAll("[id~="+S+"-]").length||v.push("~="),(t=C.createElement("input")).setAttribute("name",""),e.appendChild(t),e.querySelectorAll("[name='']").length||v.push("\\["+M+"*name"+M+"*="+M+"*(?:''|\"\")"),e.querySelectorAll(":checked").length||v.push(":checked"),e.querySelectorAll("a#"+S+"+*").length||v.push(".#.+[+~]"),e.querySelectorAll("\\\f"),v.push("[\\r\\n\\f]")}),ce(function(e){e.innerHTML="<a href='' disabled='disabled'></a><select disabled='disabled'><option/></select>";var t=C.createElement("input");t.setAttribute("type","hidden"),e.appendChild(t).setAttribute("name","D"),e.querySelectorAll("[name=d]").length&&v.push("name"+M+"*[*^$|!~]?="),2!==e.querySelectorAll(":enabled").length&&v.push(":enabled",":disabled"),a.appendChild(e).disabled=!0,2!==e.querySelectorAll(":disabled").length&&v.push(":enabled",":disabled"),e.querySelectorAll("*,:x"),v.push(",.*:")})),(d.matchesSelector=K.test(c=a.matches||a.webkitMatchesSelector||a.mozMatchesSelector||a.oMatchesSelector||a.msMatchesSelector))&&ce(function(e){d.disconnectedMatch=c.call(e,"*"),c.call(e,"[s!='']:x"),s.push("!=",F)}),v=v.length&&new RegExp(v.join("|")),s=s.length&&new RegExp(s.join("|")),t=K.test(a.compareDocumentPosition),y=t||K.test(a.contains)?function(e,t){var n=9===e.nodeType?e.documentElement:e,r=t&&t.parentNode;return e===r||!(!r||1!==r.nodeType||!(n.contains?n.contains(r):e.compareDocumentPosition&&16&e.compareDocumentPosition(r)))}:function(e,t){if(t)while(t=t.parentNode)if(t===e)return!0;return!1},j=t?function(e,t){if(e===t)return l=!0,0;var n=!e.compareDocumentPosition-!t.compareDocumentPosition;return n||(1&(n=(e.ownerDocument||e)==(t.ownerDocument||t)?e.compareDocumentPosition(t):1)||!d.sortDetached&&t.compareDocumentPosition(e)===n?e==C||e.ownerDocument==p&&y(p,e)?-1:t==C||t.ownerDocument==p&&y(p,t)?1:u?P(u,e)-P(u,t):0:4&n?-1:1)}:function(e,t){if(e===t)return l=!0,0;var n,r=0,i=e.parentNode,o=t.parentNode,a=[e],s=[t];if(!i||!o)return e==C?-1:t==C?1:i?-1:o?1:u?P(u,e)-P(u,t):0;if(i===o)return pe(e,t);n=e;while(n=n.parentNode)a.unshift(n);n=t;while(n=n.parentNode)s.unshift(n);while(a[r]===s[r])r++;return r?pe(a[r],s[r]):a[r]==p?-1:s[r]==p?1:0}),C},se.matches=function(e,t){return se(e,null,null,t)},se.matchesSelector=function(e,t){if(T(e),d.matchesSelector&&E&&!N[t+" "]&&(!s||!s.test(t))&&(!v||!v.test(t)))try{var n=c.call(e,t);if(n||d.disconnectedMatch||e.document&&11!==e.document.nodeType)return n}catch(e){N(t,!0)}return 0<se(t,C,null,[e]).length},se.contains=function(e,t){return(e.ownerDocument||e)!=C&&T(e),y(e,t)},se.attr=function(e,t){(e.ownerDocument||e)!=C&&T(e);var n=b.attrHandle[t.toLowerCase()],r=n&&D.call(b.attrHandle,t.toLowerCase())?n(e,t,!E):void 0;return void 0!==r?r:d.attributes||!E?e.getAttribute(t):(r=e.getAttributeNode(t))&&r.specified?r.value:null},se.escape=function(e){return(e+"").replace(re,ie)},se.error=function(e){throw new Error("Syntax error, unrecognized expression: "+e)},se.uniqueSort=function(e){var t,n=[],r=0,i=0;if(l=!d.detectDuplicates,u=!d.sortStable&&e.slice(0),e.sort(j),l){while(t=e[i++])t===e[i]&&(r=n.push(i));while(r--)e.splice(n[r],1)}return u=null,e},o=se.getText=function(e){var t,n="",r=0,i=e.nodeType;if(i){if(1===i||9===i||11===i){if("string"==typeof e.textContent)return e.textContent;for(e=e.firstChild;e;e=e.nextSibling)n+=o(e)}else if(3===i||4===i)return e.nodeValue}else while(t=e[r++])n+=o(t);return n},(b=se.selectors={cacheLength:50,createPseudo:le,match:G,attrHandle:{},find:{},relative:{">":{dir:"parentNode",first:!0}," ":{dir:"parentNode"},"+":{dir:"previousSibling",first:!0},"~":{dir:"previousSibling"}},preFilter:{ATTR:function(e){return e[1]=e[1].replace(te,ne),e[3]=(e[3]||e[4]||e[5]||"").replace(te,ne),"~="===e[2]&&(e[3]=" "+e[3]+" "),e.slice(0,4)},CHILD:function(e){return e[1]=e[1].toLowerCase(),"nth"===e[1].slice(0,3)?(e[3]||se.error(e[0]),e[4]=+(e[4]?e[5]+(e[6]||1):2*("even"===e[3]||"odd"===e[3])),e[5]=+(e[7]+e[8]||"odd"===e[3])):e[3]&&se.error(e[0]),e},PSEUDO:function(e){var t,n=!e[6]&&e[2];return G.CHILD.test(e[0])?null:(e[3]?e[2]=e[4]||e[5]||"":n&&X.test(n)&&(t=h(n,!0))&&(t=n.indexOf(")",n.length-t)-n.length)&&(e[0]=e[0].slice(0,t),e[2]=n.slice(0,t)),e.slice(0,3))}},filter:{TAG:function(e){var t=e.replace(te,ne).toLowerCase();return"*"===e?function(){return!0}:function(e){return e.nodeName&&e.nodeName.toLowerCase()===t}},CLASS:function(e){var t=m[e+" "];return t||(t=new RegExp("(^|"+M+")"+e+"("+M+"|$)"))&&m(e,function(e){return t.test("string"==typeof e.className&&e.className||"undefined"!=typeof e.getAttribute&&e.getAttribute("class")||"")})},ATTR:function(n,r,i){return function(e){var t=se.attr(e,n);return null==t?"!="===r:!r||(t+="","="===r?t===i:"!="===r?t!==i:"^="===r?i&&0===t.indexOf(i):"*="===r?i&&-1<t.indexOf(i):"$="===r?i&&t.slice(-i.length)===i:"~="===r?-1<(" "+t.replace(B," ")+" ").indexOf(i):"|="===r&&(t===i||t.slice(0,i.length+1)===i+"-"))}},CHILD:function(h,e,t,g,v){var y="nth"!==h.slice(0,3),m="last"!==h.slice(-4),x="of-type"===e;return 1===g&&0===v?function(e){return!!e.parentNode}:function(e,t,n){var r,i,o,a,s,u,l=y!==m?"nextSibling":"previousSibling",c=e.parentNode,f=x&&e.nodeName.toLowerCase(),p=!n&&!x,d=!1;if(c){if(y){while(l){a=e;while(a=a[l])if(x?a.nodeName.toLowerCase()===f:1===a.nodeType)return!1;u=l="only"===h&&!u&&"nextSibling"}return!0}if(u=[m?c.firstChild:c.lastChild],m&&p){d=(s=(r=(i=(o=(a=c)[S]||(a[S]={}))[a.uniqueID]||(o[a.uniqueID]={}))[h]||[])[0]===k&&r[1])&&r[2],a=s&&c.childNodes[s];while(a=++s&&a&&a[l]||(d=s=0)||u.pop())if(1===a.nodeType&&++d&&a===e){i[h]=[k,s,d];break}}else if(p&&(d=s=(r=(i=(o=(a=e)[S]||(a[S]={}))[a.uniqueID]||(o[a.uniqueID]={}))[h]||[])[0]===k&&r[1]),!1===d)while(a=++s&&a&&a[l]||(d=s=0)||u.pop())if((x?a.nodeName.toLowerCase()===f:1===a.nodeType)&&++d&&(p&&((i=(o=a[S]||(a[S]={}))[a.uniqueID]||(o[a.uniqueID]={}))[h]=[k,d]),a===e))break;return(d-=v)===g||d%g==0&&0<=d/g}}},PSEUDO:function(e,o){var t,a=b.pseudos[e]||b.setFilters[e.toLowerCase()]||se.error("unsupported pseudo: "+e);return a[S]?a(o):1<a.length?(t=[e,e,"",o],b.setFilters.hasOwnProperty(e.toLowerCase())?le(function(e,t){var n,r=a(e,o),i=r.length;while(i--)e[n=P(e,r[i])]=!(t[n]=r[i])}):function(e){return a(e,0,t)}):a}},pseudos:{not:le(function(e){var r=[],i=[],s=f(e.replace($,"$1"));return s[S]?le(function(e,t,n,r){var i,o=s(e,null,r,[]),a=e.length;while(a--)(i=o[a])&&(e[a]=!(t[a]=i))}):function(e,t,n){return r[0]=e,s(r,null,n,i),r[0]=null,!i.pop()}}),has:le(function(t){return function(e){return 0<se(t,e).length}}),contains:le(function(t){return t=t.replace(te,ne),function(e){return-1<(e.textContent||o(e)).indexOf(t)}}),lang:le(function(n){return V.test(n||"")||se.error("unsupported lang: "+n),n=n.replace(te,ne).toLowerCase(),function(e){var t;do{if(t=E?e.lang:e.getAttribute("xml:lang")||e.getAttribute("lang"))return(t=t.toLowerCase())===n||0===t.indexOf(n+"-")}while((e=e.parentNode)&&1===e.nodeType);return!1}}),target:function(e){var t=n.location&&n.location.hash;return t&&t.slice(1)===e.id},root:function(e){return e===a},focus:function(e){return e===C.activeElement&&(!C.hasFocus||C.hasFocus())&&!!(e.type||e.href||~e.tabIndex)},enabled:ge(!1),disabled:ge(!0),checked:function(e){var t=e.nodeName.toLowerCase();return"input"===t&&!!e.checked||"option"===t&&!!e.selected},selected:function(e){return e.parentNode&&e.parentNode.selectedIndex,!0===e.selected},empty:function(e){for(e=e.firstChild;e;e=e.nextSibling)if(e.nodeType<6)return!1;return!0},parent:function(e){return!b.pseudos.empty(e)},header:function(e){return J.test(e.nodeName)},input:function(e){return Q.test(e.nodeName)},button:function(e){var t=e.nodeName.toLowerCase();return"input"===t&&"button"===e.type||"button"===t},text:function(e){var t;return"input"===e.nodeName.toLowerCase()&&"text"===e.type&&(null==(t=e.getAttribute("type"))||"text"===t.toLowerCase())},first:ve(function(){return[0]}),last:ve(function(e,t){return[t-1]}),eq:ve(function(e,t,n){return[n<0?n+t:n]}),even:ve(function(e,t){for(var n=0;n<t;n+=2)e.push(n);return e}),odd:ve(function(e,t){for(var n=1;n<t;n+=2)e.push(n);return e}),lt:ve(function(e,t,n){for(var r=n<0?n+t:t<n?t:n;0<=--r;)e.push(r);return e}),gt:ve(function(e,t,n){for(var r=n<0?n+t:n;++r<t;)e.push(r);return e})}}).pseudos.nth=b.pseudos.eq,{radio:!0,checkbox:!0,file:!0,password:!0,image:!0})b.pseudos[e]=de(e);for(e in{submit:!0,reset:!0})b.pseudos[e]=he(e);function me(){}function xe(e){for(var t=0,n=e.length,r="";t<n;t++)r+=e[t].value;return r}function be(s,e,t){var u=e.dir,l=e.next,c=l||u,f=t&&"parentNode"===c,p=r++;return e.first?function(e,t,n){while(e=e[u])if(1===e.nodeType||f)return s(e,t,n);return!1}:function(e,t,n){var r,i,o,a=[k,p];if(n){while(e=e[u])if((1===e.nodeType||f)&&s(e,t,n))return!0}else while(e=e[u])if(1===e.nodeType||f)if(i=(o=e[S]||(e[S]={}))[e.uniqueID]||(o[e.uniqueID]={}),l&&l===e.nodeName.toLowerCase())e=e[u]||e;else{if((r=i[c])&&r[0]===k&&r[1]===p)return a[2]=r[2];if((i[c]=a)[2]=s(e,t,n))return!0}return!1}}function we(i){return 1<i.length?function(e,t,n){var r=i.length;while(r--)if(!i[r](e,t,n))return!1;return!0}:i[0]}function Te(e,t,n,r,i){for(var o,a=[],s=0,u=e.length,l=null!=t;s<u;s++)(o=e[s])&&(n&&!n(o,r,i)||(a.push(o),l&&t.push(s)));return a}function Ce(d,h,g,v,y,e){return v&&!v[S]&&(v=Ce(v)),y&&!y[S]&&(y=Ce(y,e)),le(function(e,t,n,r){var i,o,a,s=[],u=[],l=t.length,c=e||function(e,t,n){for(var r=0,i=t.length;r<i;r++)se(e,t[r],n);return n}(h||"*",n.nodeType?[n]:n,[]),f=!d||!e&&h?c:Te(c,s,d,n,r),p=g?y||(e?d:l||v)?[]:t:f;if(g&&g(f,p,n,r),v){i=Te(p,u),v(i,[],n,r),o=i.length;while(o--)(a=i[o])&&(p[u[o]]=!(f[u[o]]=a))}if(e){if(y||d){if(y){i=[],o=p.length;while(o--)(a=p[o])&&i.push(f[o]=a);y(null,p=[],i,r)}o=p.length;while(o--)(a=p[o])&&-1<(i=y?P(e,a):s[o])&&(e[i]=!(t[i]=a))}}else p=Te(p===t?p.splice(l,p.length):p),y?y(null,t,p,r):H.apply(t,p)})}function Ee(e){for(var i,t,n,r=e.length,o=b.relative[e[0].type],a=o||b.relative[" "],s=o?1:0,u=be(function(e){return e===i},a,!0),l=be(function(e){return-1<P(i,e)},a,!0),c=[function(e,t,n){var r=!o&&(n||t!==w)||((i=t).nodeType?u(e,t,n):l(e,t,n));return i=null,r}];s<r;s++)if(t=b.relative[e[s].type])c=[be(we(c),t)];else{if((t=b.filter[e[s].type].apply(null,e[s].matches))[S]){for(n=++s;n<r;n++)if(b.relative[e[n].type])break;return Ce(1<s&&we(c),1<s&&xe(e.slice(0,s-1).concat({value:" "===e[s-2].type?"*":""})).replace($,"$1"),t,s<n&&Ee(e.slice(s,n)),n<r&&Ee(e=e.slice(n)),n<r&&xe(e))}c.push(t)}return we(c)}return me.prototype=b.filters=b.pseudos,b.setFilters=new me,h=se.tokenize=function(e,t){var n,r,i,o,a,s,u,l=x[e+" "];if(l)return t?0:l.slice(0);a=e,s=[],u=b.preFilter;while(a){for(o in n&&!(r=_.exec(a))||(r&&(a=a.slice(r[0].length)||a),s.push(i=[])),n=!1,(r=z.exec(a))&&(n=r.shift(),i.push({value:n,type:r[0].replace($," ")}),a=a.slice(n.length)),b.filter)!(r=G[o].exec(a))||u[o]&&!(r=u[o](r))||(n=r.shift(),i.push({value:n,type:o,matches:r}),a=a.slice(n.length));if(!n)break}return t?a.length:a?se.error(e):x(e,s).slice(0)},f=se.compile=function(e,t){var n,v,y,m,x,r,i=[],o=[],a=A[e+" "];if(!a){t||(t=h(e)),n=t.length;while(n--)(a=Ee(t[n]))[S]?i.push(a):o.push(a);(a=A(e,(v=o,m=0<(y=i).length,x=0<v.length,r=function(e,t,n,r,i){var o,a,s,u=0,l="0",c=e&&[],f=[],p=w,d=e||x&&b.find.TAG("*",i),h=k+=null==p?1:Math.random()||.1,g=d.length;for(i&&(w=t==C||t||i);l!==g&&null!=(o=d[l]);l++){if(x&&o){a=0,t||o.ownerDocument==C||(T(o),n=!E);while(s=v[a++])if(s(o,t||C,n)){r.push(o);break}i&&(k=h)}m&&((o=!s&&o)&&u--,e&&c.push(o))}if(u+=l,m&&l!==u){a=0;while(s=y[a++])s(c,f,t,n);if(e){if(0<u)while(l--)c[l]||f[l]||(f[l]=q.call(r));f=Te(f)}H.apply(r,f),i&&!e&&0<f.length&&1<u+y.length&&se.uniqueSort(r)}return i&&(k=h,w=p),c},m?le(r):r))).selector=e}return a},g=se.select=function(e,t,n,r){var i,o,a,s,u,l="function"==typeof e&&e,c=!r&&h(e=l.selector||e);if(n=n||[],1===c.length){if(2<(o=c[0]=c[0].slice(0)).length&&"ID"===(a=o[0]).type&&9===t.nodeType&&E&&b.relative[o[1].type]){if(!(t=(b.find.ID(a.matches[0].replace(te,ne),t)||[])[0]))return n;l&&(t=t.parentNode),e=e.slice(o.shift().value.length)}i=G.needsContext.test(e)?0:o.length;while(i--){if(a=o[i],b.relative[s=a.type])break;if((u=b.find[s])&&(r=u(a.matches[0].replace(te,ne),ee.test(o[0].type)&&ye(t.parentNode)||t))){if(o.splice(i,1),!(e=r.length&&xe(o)))return H.apply(n,r),n;break}}}return(l||f(e,c))(r,t,!E,n,!t||ee.test(e)&&ye(t.parentNode)||t),n},d.sortStable=S.split("").sort(j).join("")===S,d.detectDuplicates=!!l,T(),d.sortDetached=ce(function(e){return 1&e.compareDocumentPosition(C.createElement("fieldset"))}),ce(function(e){return e.innerHTML="<a href='#'></a>","#"===e.firstChild.getAttribute("href")})||fe("type|href|height|width",function(e,t,n){if(!n)return e.getAttribute(t,"type"===t.toLowerCase()?1:2)}),d.attributes&&ce(function(e){return e.innerHTML="<input/>",e.firstChild.setAttribute("value",""),""===e.firstChild.getAttribute("value")})||fe("value",function(e,t,n){if(!n&&"input"===e.nodeName.toLowerCase())return e.defaultValue}),ce(function(e){return null==e.getAttribute("disabled")})||fe(R,function(e,t,n){var r;if(!n)return!0===e[t]?t.toLowerCase():(r=e.getAttributeNode(t))&&r.specified?r.value:null}),se}(C);S.find=d,S.expr=d.selectors,S.expr[":"]=S.expr.pseudos,S.uniqueSort=S.unique=d.uniqueSort,S.text=d.getText,S.isXMLDoc=d.isXML,S.contains=d.contains,S.escapeSelector=d.escape;var h=function(e,t,n){var r=[],i=void 0!==n;while((e=e[t])&&9!==e.nodeType)if(1===e.nodeType){if(i&&S(e).is(n))break;r.push(e)}return r},T=function(e,t){for(var n=[];e;e=e.nextSibling)1===e.nodeType&&e!==t&&n.push(e);return n},k=S.expr.match.needsContext;function A(e,t){return e.nodeName&&e.nodeName.toLowerCase()===t.toLowerCase()}var N=/^<([a-z][^\/\0>:\x20\t\r\n\f]*)[\x20\t\r\n\f]*\/?>(?:<\/\1>|)$/i;function j(e,n,r){return m(n)?S.grep(e,function(e,t){return!!n.call(e,t,e)!==r}):n.nodeType?S.grep(e,function(e){return e===n!==r}):"string"!=typeof n?S.grep(e,function(e){return-1<i.call(n,e)!==r}):S.filter(n,e,r)}S.filter=function(e,t,n){var r=t[0];return n&&(e=":not("+e+")"),1===t.length&&1===r.nodeType?S.find.matchesSelector(r,e)?[r]:[]:S.find.matches(e,S.grep(t,function(e){return 1===e.nodeType}))},S.fn.extend({find:function(e){var t,n,r=this.length,i=this;if("string"!=typeof e)return this.pushStack(S(e).filter(function(){for(t=0;t<r;t++)if(S.contains(i[t],this))return!0}));for(n=this.pushStack([]),t=0;t<r;t++)S.find(e,i[t],n);return 1<r?S.uniqueSort(n):n},filter:function(e){return this.pushStack(j(this,e||[],!1))},not:function(e){return this.pushStack(j(this,e||[],!0))},is:function(e){return!!j(this,"string"==typeof e&&k.test(e)?S(e):e||[],!1).length}});var D,q=/^(?:\s*(<[\w\W]+>)[^>]*|#([\w-]+))$/;(S.fn.init=function(e,t,n){var r,i;if(!e)return this;if(n=n||D,"string"==typeof e){if(!(r="<"===e[0]&&">"===e[e.length-1]&&3<=e.length?[null,e,null]:q.exec(e))||!r[1]&&t)return!t||t.jquery?(t||n).find(e):this.constructor(t).find(e);if(r[1]){if(t=t instanceof S?t[0]:t,S.merge(this,S.parseHTML(r[1],t&&t.nodeType?t.ownerDocument||t:E,!0)),N.test(r[1])&&S.isPlainObject(t))for(r in t)m(this[r])?this[r](t[r]):this.attr(r,t[r]);return this}return(i=E.getElementById(r[2]))&&(this[0]=i,this.length=1),this}return e.nodeType?(this[0]=e,this.length=1,this):m(e)?void 0!==n.ready?n.ready(e):e(S):S.makeArray(e,this)}).prototype=S.fn,D=S(E);var L=/^(?:parents|prev(?:Until|All))/,H={children:!0,contents:!0,next:!0,prev:!0};function O(e,t){while((e=e[t])&&1!==e.nodeType);return e}S.fn.extend({has:function(e){var t=S(e,this),n=t.length;return this.filter(function(){for(var e=0;e<n;e++)if(S.contains(this,t[e]))return!0})},closest:function(e,t){var n,r=0,i=this.length,o=[],a="string"!=typeof e&&S(e);if(!k.test(e))for(;r<i;r++)for(n=this[r];n&&n!==t;n=n.parentNode)if(n.nodeType<11&&(a?-1<a.index(n):1===n.nodeType&&S.find.matchesSelector(n,e))){o.push(n);break}return this.pushStack(1<o.length?S.uniqueSort(o):o)},index:function(e){return e?"string"==typeof e?i.call(S(e),this[0]):i.call(this,e.jquery?e[0]:e):this[0]&&this[0].parentNode?this.first().prevAll().length:-1},add:function(e,t){return this.pushStack(S.uniqueSort(S.merge(this.get(),S(e,t))))},addBack:function(e){return this.add(null==e?this.prevObject:this.prevObject.filter(e))}}),S.each({parent:function(e){var t=e.parentNode;return t&&11!==t.nodeType?t:null},parents:function(e){return h(e,"parentNode")},parentsUntil:function(e,t,n){return h(e,"parentNode",n)},next:function(e){return O(e,"nextSibling")},prev:function(e){return O(e,"previousSibling")},nextAll:function(e){return h(e,"nextSibling")},prevAll:function(e){return h(e,"previousSibling")},nextUntil:function(e,t,n){return h(e,"nextSibling",n)},prevUntil:function(e,t,n){return h(e,"previousSibling",n)},siblings:function(e){return T((e.parentNode||{}).firstChild,e)},children:function(e){return T(e.firstChild)},contents:function(e){return null!=e.contentDocument&&r(e.contentDocument)?e.contentDocument:(A(e,"template")&&(e=e.content||e),S.merge([],e.childNodes))}},function(r,i){S.fn[r]=function(e,t){var n=S.map(this,i,e);return"Until"!==r.slice(-5)&&(t=e),t&&"string"==typeof t&&(n=S.filter(t,n)),1<this.length&&(H[r]||S.uniqueSort(n),L.test(r)&&n.reverse()),this.pushStack(n)}});var P=/[^\x20\t\r\n\f]+/g;function R(e){return e}function M(e){throw e}function I(e,t,n,r){var i;try{e&&m(i=e.promise)?i.call(e).done(t).fail(n):e&&m(i=e.then)?i.call(e,t,n):t.apply(void 0,[e].slice(r))}catch(e){n.apply(void 0,[e])}}S.Callbacks=function(r){var e,n;r="string"==typeof r?(e=r,n={},S.each(e.match(P)||[],function(e,t){n[t]=!0}),n):S.extend({},r);var i,t,o,a,s=[],u=[],l=-1,c=function(){for(a=a||r.once,o=i=!0;u.length;l=-1){t=u.shift();while(++l<s.length)!1===s[l].apply(t[0],t[1])&&r.stopOnFalse&&(l=s.length,t=!1)}r.memory||(t=!1),i=!1,a&&(s=t?[]:"")},f={add:function(){return s&&(t&&!i&&(l=s.length-1,u.push(t)),function n(e){S.each(e,function(e,t){m(t)?r.unique&&f.has(t)||s.push(t):t&&t.length&&"string"!==w(t)&&n(t)})}(arguments),t&&!i&&c()),this},remove:function(){return S.each(arguments,function(e,t){var n;while(-1<(n=S.inArray(t,s,n)))s.splice(n,1),n<=l&&l--}),this},has:function(e){return e?-1<S.inArray(e,s):0<s.length},empty:function(){return s&&(s=[]),this},disable:function(){return a=u=[],s=t="",this},disabled:function(){return!s},lock:function(){return a=u=[],t||i||(s=t=""),this},locked:function(){return!!a},fireWith:function(e,t){return a||(t=[e,(t=t||[]).slice?t.slice():t],u.push(t),i||c()),this},fire:function(){return f.fireWith(this,arguments),this},fired:function(){return!!o}};return f},S.extend({Deferred:function(e){var o=[["notify","progress",S.Callbacks("memory"),S.Callbacks("memory"),2],["resolve","done",S.Callbacks("once memory"),S.Callbacks("once memory"),0,"resolved"],["reject","fail",S.Callbacks("once memory"),S.Callbacks("once memory"),1,"rejected"]],i="pending",a={state:function(){return i},always:function(){return s.done(arguments).fail(arguments),this},"catch":function(e){return a.then(null,e)},pipe:function(){var i=arguments;return S.Deferred(function(r){S.each(o,function(e,t){var n=m(i[t[4]])&&i[t[4]];s[t[1]](function(){var e=n&&n.apply(this,arguments);e&&m(e.promise)?e.promise().progress(r.notify).done(r.resolve).fail(r.reject):r[t[0]+"With"](this,n?[e]:arguments)})}),i=null}).promise()},then:function(t,n,r){var u=0;function l(i,o,a,s){return function(){var n=this,r=arguments,e=function(){var e,t;if(!(i<u)){if((e=a.apply(n,r))===o.promise())throw new TypeError("Thenable self-resolution");t=e&&("object"==typeof e||"function"==typeof e)&&e.then,m(t)?s?t.call(e,l(u,o,R,s),l(u,o,M,s)):(u++,t.call(e,l(u,o,R,s),l(u,o,M,s),l(u,o,R,o.notifyWith))):(a!==R&&(n=void 0,r=[e]),(s||o.resolveWith)(n,r))}},t=s?e:function(){try{e()}catch(e){S.Deferred.exceptionHook&&S.Deferred.exceptionHook(e,t.stackTrace),u<=i+1&&(a!==M&&(n=void 0,r=[e]),o.rejectWith(n,r))}};i?t():(S.Deferred.getStackHook&&(t.stackTrace=S.Deferred.getStackHook()),C.setTimeout(t))}}return S.Deferred(function(e){o[0][3].add(l(0,e,m(r)?r:R,e.notifyWith)),o[1][3].add(l(0,e,m(t)?t:R)),o[2][3].add(l(0,e,m(n)?n:M))}).promise()},promise:function(e){return null!=e?S.extend(e,a):a}},s={};return S.each(o,function(e,t){var n=t[2],r=t[5];a[t[1]]=n.add,r&&n.add(function(){i=r},o[3-e][2].disable,o[3-e][3].disable,o[0][2].lock,o[0][3].lock),n.add(t[3].fire),s[t[0]]=function(){return s[t[0]+"With"](this===s?void 0:this,arguments),this},s[t[0]+"With"]=n.fireWith}),a.promise(s),e&&e.call(s,s),s},when:function(e){var n=arguments.length,t=n,r=Array(t),i=s.call(arguments),o=S.Deferred(),a=function(t){return function(e){r[t]=this,i[t]=1<arguments.length?s.call(arguments):e,--n||o.resolveWith(r,i)}};if(n<=1&&(I(e,o.done(a(t)).resolve,o.reject,!n),"pending"===o.state()||m(i[t]&&i[t].then)))return o.then();while(t--)I(i[t],a(t),o.reject);return o.promise()}});var W=/^(Eval|Internal|Range|Reference|Syntax|Type|URI)Error$/;S.Deferred.exceptionHook=function(e,t){C.console&&C.console.warn&&e&&W.test(e.name)&&C.console.warn("jQuery.Deferred exception: "+e.message,e.stack,t)},S.readyException=function(e){C.setTimeout(function(){throw e})};var F=S.Deferred();function B(){E.removeEventListener("DOMContentLoaded",B),C.removeEventListener("load",B),S.ready()}S.fn.ready=function(e){return F.then(e)["catch"](function(e){S.readyException(e)}),this},S.extend({isReady:!1,readyWait:1,ready:function(e){(!0===e?--S.readyWait:S.isReady)||(S.isReady=!0)!==e&&0<--S.readyWait||F.resolveWith(E,[S])}}),S.ready.then=F.then,"complete"===E.readyState||"loading"!==E.readyState&&!E.documentElement.doScroll?C.setTimeout(S.ready):(E.addEventListener("DOMContentLoaded",B),C.addEventListener("load",B));var $=function(e,t,n,r,i,o,a){var s=0,u=e.length,l=null==n;if("object"===w(n))for(s in i=!0,n)$(e,t,s,n[s],!0,o,a);else if(void 0!==r&&(i=!0,m(r)||(a=!0),l&&(a?(t.call(e,r),t=null):(l=t,t=function(e,t,n){return l.call(S(e),n)})),t))for(;s<u;s++)t(e[s],n,a?r:r.call(e[s],s,t(e[s],n)));return i?e:l?t.call(e):u?t(e[0],n):o},_=/^-ms-/,z=/-([a-z])/g;function U(e,t){return t.toUpperCase()}function X(e){return e.replace(_,"ms-").replace(z,U)}var V=function(e){return 1===e.nodeType||9===e.nodeType||!+e.nodeType};function G(){this.expando=S.expando+G.uid++}G.uid=1,G.prototype={cache:function(e){var t=e[this.expando];return t||(t={},V(e)&&(e.nodeType?e[this.expando]=t:Object.defineProperty(e,this.expando,{value:t,configurable:!0}))),t},set:function(e,t,n){var r,i=this.cache(e);if("string"==typeof t)i[X(t)]=n;else for(r in t)i[X(r)]=t[r];return i},get:function(e,t){return void 0===t?this.cache(e):e[this.expando]&&e[this.expando][X(t)]},access:function(e,t,n){return void 0===t||t&&"string"==typeof t&&void 0===n?this.get(e,t):(this.set(e,t,n),void 0!==n?n:t)},remove:function(e,t){var n,r=e[this.expando];if(void 0!==r){if(void 0!==t){n=(t=Array.isArray(t)?t.map(X):(t=X(t))in r?[t]:t.match(P)||[]).length;while(n--)delete r[t[n]]}(void 0===t||S.isEmptyObject(r))&&(e.nodeType?e[this.expando]=void 0:delete e[this.expando])}},hasData:function(e){var t=e[this.expando];return void 0!==t&&!S.isEmptyObject(t)}};var Y=new G,Q=new G,J=/^(?:\{[\w\W]*\}|\[[\w\W]*\])$/,K=/[A-Z]/g;function Z(e,t,n){var r,i;if(void 0===n&&1===e.nodeType)if(r="data-"+t.replace(K,"-$&").toLowerCase(),"string"==typeof(n=e.getAttribute(r))){try{n="true"===(i=n)||"false"!==i&&("null"===i?null:i===+i+""?+i:J.test(i)?JSON.parse(i):i)}catch(e){}Q.set(e,t,n)}else n=void 0;return n}S.extend({hasData:function(e){return Q.hasData(e)||Y.hasData(e)},data:function(e,t,n){return Q.access(e,t,n)},removeData:function(e,t){Q.remove(e,t)},_data:function(e,t,n){return Y.access(e,t,n)},_removeData:function(e,t){Y.remove(e,t)}}),S.fn.extend({data:function(n,e){var t,r,i,o=this[0],a=o&&o.attributes;if(void 0===n){if(this.length&&(i=Q.get(o),1===o.nodeType&&!Y.get(o,"hasDataAttrs"))){t=a.length;while(t--)a[t]&&0===(r=a[t].name).indexOf("data-")&&(r=X(r.slice(5)),Z(o,r,i[r]));Y.set(o,"hasDataAttrs",!0)}return i}return"object"==typeof n?this.each(function(){Q.set(this,n)}):$(this,function(e){var t;if(o&&void 0===e)return void 0!==(t=Q.get(o,n))?t:void 0!==(t=Z(o,n))?t:void 0;this.each(function(){Q.set(this,n,e)})},null,e,1<arguments.length,null,!0)},removeData:function(e){return this.each(function(){Q.remove(this,e)})}}),S.extend({queue:function(e,t,n){var r;if(e)return t=(t||"fx")+"queue",r=Y.get(e,t),n&&(!r||Array.isArray(n)?r=Y.access(e,t,S.makeArray(n)):r.push(n)),r||[]},dequeue:function(e,t){t=t||"fx";var n=S.queue(e,t),r=n.length,i=n.shift(),o=S._queueHooks(e,t);"inprogress"===i&&(i=n.shift(),r--),i&&("fx"===t&&n.unshift("inprogress"),delete o.stop,i.call(e,function(){S.dequeue(e,t)},o)),!r&&o&&o.empty.fire()},_queueHooks:function(e,t){var n=t+"queueHooks";return Y.get(e,n)||Y.access(e,n,{empty:S.Callbacks("once memory").add(function(){Y.remove(e,[t+"queue",n])})})}}),S.fn.extend({queue:function(t,n){var e=2;return"string"!=typeof t&&(n=t,t="fx",e--),arguments.length<e?S.queue(this[0],t):void 0===n?this:this.each(function(){var e=S.queue(this,t,n);S._queueHooks(this,t),"fx"===t&&"inprogress"!==e[0]&&S.dequeue(this,t)})},dequeue:function(e){return this.each(function(){S.dequeue(this,e)})},clearQueue:function(e){return this.queue(e||"fx",[])},promise:function(e,t){var n,r=1,i=S.Deferred(),o=this,a=this.length,s=function(){--r||i.resolveWith(o,[o])};"string"!=typeof e&&(t=e,e=void 0),e=e||"fx";while(a--)(n=Y.get(o[a],e+"queueHooks"))&&n.empty&&(r++,n.empty.add(s));return s(),i.promise(t)}});var ee=/[+-]?(?:\d*\.|)\d+(?:[eE][+-]?\d+|)/.source,te=new RegExp("^(?:([+-])=|)("+ee+")([a-z%]*)$","i"),ne=["Top","Right","Bottom","Left"],re=E.documentElement,ie=function(e){return S.contains(e.ownerDocument,e)},oe={composed:!0};re.getRootNode&&(ie=function(e){return S.contains(e.ownerDocument,e)||e.getRootNode(oe)===e.ownerDocument});var ae=function(e,t){return"none"===(e=t||e).style.display||""===e.style.display&&ie(e)&&"none"===S.css(e,"display")};function se(e,t,n,r){var i,o,a=20,s=r?function(){return r.cur()}:function(){return S.css(e,t,"")},u=s(),l=n&&n[3]||(S.cssNumber[t]?"":"px"),c=e.nodeType&&(S.cssNumber[t]||"px"!==l&&+u)&&te.exec(S.css(e,t));if(c&&c[3]!==l){u/=2,l=l||c[3],c=+u||1;while(a--)S.style(e,t,c+l),(1-o)*(1-(o=s()/u||.5))<=0&&(a=0),c/=o;c*=2,S.style(e,t,c+l),n=n||[]}return n&&(c=+c||+u||0,i=n[1]?c+(n[1]+1)*n[2]:+n[2],r&&(r.unit=l,r.start=c,r.end=i)),i}var ue={};function le(e,t){for(var n,r,i,o,a,s,u,l=[],c=0,f=e.length;c<f;c++)(r=e[c]).style&&(n=r.style.display,t?("none"===n&&(l[c]=Y.get(r,"display")||null,l[c]||(r.style.display="")),""===r.style.display&&ae(r)&&(l[c]=(u=a=o=void 0,a=(i=r).ownerDocument,s=i.nodeName,(u=ue[s])||(o=a.body.appendChild(a.createElement(s)),u=S.css(o,"display"),o.parentNode.removeChild(o),"none"===u&&(u="block"),ue[s]=u)))):"none"!==n&&(l[c]="none",Y.set(r,"display",n)));for(c=0;c<f;c++)null!=l[c]&&(e[c].style.display=l[c]);return e}S.fn.extend({show:function(){return le(this,!0)},hide:function(){return le(this)},toggle:function(e){return"boolean"==typeof e?e?this.show():this.hide():this.each(function(){ae(this)?S(this).show():S(this).hide()})}});var ce,fe,pe=/^(?:checkbox|radio)$/i,de=/<([a-z][^\/\0>\x20\t\r\n\f]*)/i,he=/^$|^module$|\/(?:java|ecma)script/i;ce=E.createDocumentFragment().appendChild(E.createElement("div")),(fe=E.createElement("input")).setAttribute("type","radio"),fe.setAttribute("checked","checked"),fe.setAttribute("name","t"),ce.appendChild(fe),y.checkClone=ce.cloneNode(!0).cloneNode(!0).lastChild.checked,ce.innerHTML="<textarea>x</textarea>",y.noCloneChecked=!!ce.cloneNode(!0).lastChild.defaultValue,ce.innerHTML="<option></option>",y.option=!!ce.lastChild;var ge={thead:[1,"<table>","</table>"],col:[2,"<table><colgroup>","</colgroup></table>"],tr:[2,"<table><tbody>","</tbody></table>"],td:[3,"<table><tbody><tr>","</tr></tbody></table>"],_default:[0,"",""]};function ve(e,t){var n;return n="undefined"!=typeof e.getElementsByTagName?e.getElementsByTagName(t||"*"):"undefined"!=typeof e.querySelectorAll?e.querySelectorAll(t||"*"):[],void 0===t||t&&A(e,t)?S.merge([e],n):n}function ye(e,t){for(var n=0,r=e.length;n<r;n++)Y.set(e[n],"globalEval",!t||Y.get(t[n],"globalEval"))}ge.tbody=ge.tfoot=ge.colgroup=ge.caption=ge.thead,ge.th=ge.td,y.option||(ge.optgroup=ge.option=[1,"<select multiple='multiple'>","</select>"]);var me=/<|&#?\w+;/;function xe(e,t,n,r,i){for(var o,a,s,u,l,c,f=t.createDocumentFragment(),p=[],d=0,h=e.length;d<h;d++)if((o=e[d])||0===o)if("object"===w(o))S.merge(p,o.nodeType?[o]:o);else if(me.test(o)){a=a||f.appendChild(t.createElement("div")),s=(de.exec(o)||["",""])[1].toLowerCase(),u=ge[s]||ge._default,a.innerHTML=u[1]+S.htmlPrefilter(o)+u[2],c=u[0];while(c--)a=a.lastChild;S.merge(p,a.childNodes),(a=f.firstChild).textContent=""}else p.push(t.createTextNode(o));f.textContent="",d=0;while(o=p[d++])if(r&&-1<S.inArray(o,r))i&&i.push(o);else if(l=ie(o),a=ve(f.appendChild(o),"script"),l&&ye(a),n){c=0;while(o=a[c++])he.test(o.type||"")&&n.push(o)}return f}var be=/^([^.]*)(?:\.(.+)|)/;function we(){return!0}function Te(){return!1}function Ce(e,t){return e===function(){try{return E.activeElement}catch(e){}}()==("focus"===t)}function Ee(e,t,n,r,i,o){var a,s;if("object"==typeof t){for(s in"string"!=typeof n&&(r=r||n,n=void 0),t)Ee(e,s,n,r,t[s],o);return e}if(null==r&&null==i?(i=n,r=n=void 0):null==i&&("string"==typeof n?(i=r,r=void 0):(i=r,r=n,n=void 0)),!1===i)i=Te;else if(!i)return e;return 1===o&&(a=i,(i=function(e){return S().off(e),a.apply(this,arguments)}).guid=a.guid||(a.guid=S.guid++)),e.each(function(){S.event.add(this,t,i,r,n)})}function Se(e,i,o){o?(Y.set(e,i,!1),S.event.add(e,i,{namespace:!1,handler:function(e){var t,n,r=Y.get(this,i);if(1&e.isTrigger&&this[i]){if(r.length)(S.event.special[i]||{}).delegateType&&e.stopPropagation();else if(r=s.call(arguments),Y.set(this,i,r),t=o(this,i),this[i](),r!==(n=Y.get(this,i))||t?Y.set(this,i,!1):n={},r!==n)return e.stopImmediatePropagation(),e.preventDefault(),n&&n.value}else r.length&&(Y.set(this,i,{value:S.event.trigger(S.extend(r[0],S.Event.prototype),r.slice(1),this)}),e.stopImmediatePropagation())}})):void 0===Y.get(e,i)&&S.event.add(e,i,we)}S.event={global:{},add:function(t,e,n,r,i){var o,a,s,u,l,c,f,p,d,h,g,v=Y.get(t);if(V(t)){n.handler&&(n=(o=n).handler,i=o.selector),i&&S.find.matchesSelector(re,i),n.guid||(n.guid=S.guid++),(u=v.events)||(u=v.events=Object.create(null)),(a=v.handle)||(a=v.handle=function(e){return"undefined"!=typeof S&&S.event.triggered!==e.type?S.event.dispatch.apply(t,arguments):void 0}),l=(e=(e||"").match(P)||[""]).length;while(l--)d=g=(s=be.exec(e[l])||[])[1],h=(s[2]||"").split(".").sort(),d&&(f=S.event.special[d]||{},d=(i?f.delegateType:f.bindType)||d,f=S.event.special[d]||{},c=S.extend({type:d,origType:g,data:r,handler:n,guid:n.guid,selector:i,needsContext:i&&S.expr.match.needsContext.test(i),namespace:h.join(".")},o),(p=u[d])||((p=u[d]=[]).delegateCount=0,f.setup&&!1!==f.setup.call(t,r,h,a)||t.addEventListener&&t.addEventListener(d,a)),f.add&&(f.add.call(t,c),c.handler.guid||(c.handler.guid=n.guid)),i?p.splice(p.delegateCount++,0,c):p.push(c),S.event.global[d]=!0)}},remove:function(e,t,n,r,i){var o,a,s,u,l,c,f,p,d,h,g,v=Y.hasData(e)&&Y.get(e);if(v&&(u=v.events)){l=(t=(t||"").match(P)||[""]).length;while(l--)if(d=g=(s=be.exec(t[l])||[])[1],h=(s[2]||"").split(".").sort(),d){f=S.event.special[d]||{},p=u[d=(r?f.delegateType:f.bindType)||d]||[],s=s[2]&&new RegExp("(^|\\.)"+h.join("\\.(?:.*\\.|)")+"(\\.|$)"),a=o=p.length;while(o--)c=p[o],!i&&g!==c.origType||n&&n.guid!==c.guid||s&&!s.test(c.namespace)||r&&r!==c.selector&&("**"!==r||!c.selector)||(p.splice(o,1),c.selector&&p.delegateCount--,f.remove&&f.remove.call(e,c));a&&!p.length&&(f.teardown&&!1!==f.teardown.call(e,h,v.handle)||S.removeEvent(e,d,v.handle),delete u[d])}else for(d in u)S.event.remove(e,d+t[l],n,r,!0);S.isEmptyObject(u)&&Y.remove(e,"handle events")}},dispatch:function(e){var t,n,r,i,o,a,s=new Array(arguments.length),u=S.event.fix(e),l=(Y.get(this,"events")||Object.create(null))[u.type]||[],c=S.event.special[u.type]||{};for(s[0]=u,t=1;t<arguments.length;t++)s[t]=arguments[t];if(u.delegateTarget=this,!c.preDispatch||!1!==c.preDispatch.call(this,u)){a=S.event.handlers.call(this,u,l),t=0;while((i=a[t++])&&!u.isPropagationStopped()){u.currentTarget=i.elem,n=0;while((o=i.handlers[n++])&&!u.isImmediatePropagationStopped())u.rnamespace&&!1!==o.namespace&&!u.rnamespace.test(o.namespace)||(u.handleObj=o,u.data=o.data,void 0!==(r=((S.event.special[o.origType]||{}).handle||o.handler).apply(i.elem,s))&&!1===(u.result=r)&&(u.preventDefault(),u.stopPropagation()))}return c.postDispatch&&c.postDispatch.call(this,u),u.result}},handlers:function(e,t){var n,r,i,o,a,s=[],u=t.delegateCount,l=e.target;if(u&&l.nodeType&&!("click"===e.type&&1<=e.button))for(;l!==this;l=l.parentNode||this)if(1===l.nodeType&&("click"!==e.type||!0!==l.disabled)){for(o=[],a={},n=0;n<u;n++)void 0===a[i=(r=t[n]).selector+" "]&&(a[i]=r.needsContext?-1<S(i,this).index(l):S.find(i,this,null,[l]).length),a[i]&&o.push(r);o.length&&s.push({elem:l,handlers:o})}return l=this,u<t.length&&s.push({elem:l,handlers:t.slice(u)}),s},addProp:function(t,e){Object.defineProperty(S.Event.prototype,t,{enumerable:!0,configurable:!0,get:m(e)?function(){if(this.originalEvent)return e(this.originalEvent)}:function(){if(this.originalEvent)return this.originalEvent[t]},set:function(e){Object.defineProperty(this,t,{enumerable:!0,configurable:!0,writable:!0,value:e})}})},fix:function(e){return e[S.expando]?e:new S.Event(e)},special:{load:{noBubble:!0},click:{setup:function(e){var t=this||e;return pe.test(t.type)&&t.click&&A(t,"input")&&Se(t,"click",we),!1},trigger:function(e){var t=this||e;return pe.test(t.type)&&t.click&&A(t,"input")&&Se(t,"click"),!0},_default:function(e){var t=e.target;return pe.test(t.type)&&t.click&&A(t,"input")&&Y.get(t,"click")||A(t,"a")}},beforeunload:{postDispatch:function(e){void 0!==e.result&&e.originalEvent&&(e.originalEvent.returnValue=e.result)}}}},S.removeEvent=function(e,t,n){e.removeEventListener&&e.removeEventListener(t,n)},S.Event=function(e,t){if(!(this instanceof S.Event))return new S.Event(e,t);e&&e.type?(this.originalEvent=e,this.type=e.type,this.isDefaultPrevented=e.defaultPrevented||void 0===e.defaultPrevented&&!1===e.returnValue?we:Te,this.target=e.target&&3===e.target.nodeType?e.target.parentNode:e.target,this.currentTarget=e.currentTarget,this.relatedTarget=e.relatedTarget):this.type=e,t&&S.extend(this,t),this.timeStamp=e&&e.timeStamp||Date.now(),this[S.expando]=!0},S.Event.prototype={constructor:S.Event,isDefaultPrevented:Te,isPropagationStopped:Te,isImmediatePropagationStopped:Te,isSimulated:!1,preventDefault:function(){var e=this.originalEvent;this.isDefaultPrevented=we,e&&!this.isSimulated&&e.preventDefault()},stopPropagation:function(){var e=this.originalEvent;this.isPropagationStopped=we,e&&!this.isSimulated&&e.stopPropagation()},stopImmediatePropagation:function(){var e=this.originalEvent;this.isImmediatePropagationStopped=we,e&&!this.isSimulated&&e.stopImmediatePropagation(),this.stopPropagation()}},S.each({altKey:!0,bubbles:!0,cancelable:!0,changedTouches:!0,ctrlKey:!0,detail:!0,eventPhase:!0,metaKey:!0,pageX:!0,pageY:!0,shiftKey:!0,view:!0,"char":!0,code:!0,charCode:!0,key:!0,keyCode:!0,button:!0,buttons:!0,clientX:!0,clientY:!0,offsetX:!0,offsetY:!0,pointerId:!0,pointerType:!0,screenX:!0,screenY:!0,targetTouches:!0,toElement:!0,touches:!0,which:!0},S.event.addProp),S.each({focus:"focusin",blur:"focusout"},function(e,t){S.event.special[e]={setup:function(){return Se(this,e,Ce),!1},trigger:function(){return Se(this,e),!0},_default:function(){return!0},delegateType:t}}),S.each({mouseenter:"mouseover",mouseleave:"mouseout",pointerenter:"pointerover",pointerleave:"pointerout"},function(e,i){S.event.special[e]={delegateType:i,bindType:i,handle:function(e){var t,n=e.relatedTarget,r=e.handleObj;return n&&(n===this||S.contains(this,n))||(e.type=r.origType,t=r.handler.apply(this,arguments),e.type=i),t}}}),S.fn.extend({on:function(e,t,n,r){return Ee(this,e,t,n,r)},one:function(e,t,n,r){return Ee(this,e,t,n,r,1)},off:function(e,t,n){var r,i;if(e&&e.preventDefault&&e.handleObj)return r=e.handleObj,S(e.delegateTarget).off(r.namespace?r.origType+"."+r.namespace:r.origType,r.selector,r.handler),this;if("object"==typeof e){for(i in e)this.off(i,t,e[i]);return this}return!1!==t&&"function"!=typeof t||(n=t,t=void 0),!1===n&&(n=Te),this.each(function(){S.event.remove(this,e,n,t)})}});var ke=/<script|<style|<link/i,Ae=/checked\s*(?:[^=]|=\s*.checked.)/i,Ne=/^\s*<!(?:\[CDATA\[|--)|(?:\]\]|--)>\s*$/g;function je(e,t){return A(e,"table")&&A(11!==t.nodeType?t:t.firstChild,"tr")&&S(e).children("tbody")[0]||e}function De(e){return e.type=(null!==e.getAttribute("type"))+"/"+e.type,e}function qe(e){return"true/"===(e.type||"").slice(0,5)?e.type=e.type.slice(5):e.removeAttribute("type"),e}function Le(e,t){var n,r,i,o,a,s;if(1===t.nodeType){if(Y.hasData(e)&&(s=Y.get(e).events))for(i in Y.remove(t,"handle events"),s)for(n=0,r=s[i].length;n<r;n++)S.event.add(t,i,s[i][n]);Q.hasData(e)&&(o=Q.access(e),a=S.extend({},o),Q.set(t,a))}}function He(n,r,i,o){r=g(r);var e,t,a,s,u,l,c=0,f=n.length,p=f-1,d=r[0],h=m(d);if(h||1<f&&"string"==typeof d&&!y.checkClone&&Ae.test(d))return n.each(function(e){var t=n.eq(e);h&&(r[0]=d.call(this,e,t.html())),He(t,r,i,o)});if(f&&(t=(e=xe(r,n[0].ownerDocument,!1,n,o)).firstChild,1===e.childNodes.length&&(e=t),t||o)){for(s=(a=S.map(ve(e,"script"),De)).length;c<f;c++)u=e,c!==p&&(u=S.clone(u,!0,!0),s&&S.merge(a,ve(u,"script"))),i.call(n[c],u,c);if(s)for(l=a[a.length-1].ownerDocument,S.map(a,qe),c=0;c<s;c++)u=a[c],he.test(u.type||"")&&!Y.access(u,"globalEval")&&S.contains(l,u)&&(u.src&&"module"!==(u.type||"").toLowerCase()?S._evalUrl&&!u.noModule&&S._evalUrl(u.src,{nonce:u.nonce||u.getAttribute("nonce")},l):b(u.textContent.replace(Ne,""),u,l))}return n}function Oe(e,t,n){for(var r,i=t?S.filter(t,e):e,o=0;null!=(r=i[o]);o++)n||1!==r.nodeType||S.cleanData(ve(r)),r.parentNode&&(n&&ie(r)&&ye(ve(r,"script")),r.parentNode.removeChild(r));return e}S.extend({htmlPrefilter:function(e){return e},clone:function(e,t,n){var r,i,o,a,s,u,l,c=e.cloneNode(!0),f=ie(e);if(!(y.noCloneChecked||1!==e.nodeType&&11!==e.nodeType||S.isXMLDoc(e)))for(a=ve(c),r=0,i=(o=ve(e)).length;r<i;r++)s=o[r],u=a[r],void 0,"input"===(l=u.nodeName.toLowerCase())&&pe.test(s.type)?u.checked=s.checked:"input"!==l&&"textarea"!==l||(u.defaultValue=s.defaultValue);if(t)if(n)for(o=o||ve(e),a=a||ve(c),r=0,i=o.length;r<i;r++)Le(o[r],a[r]);else Le(e,c);return 0<(a=ve(c,"script")).length&&ye(a,!f&&ve(e,"script")),c},cleanData:function(e){for(var t,n,r,i=S.event.special,o=0;void 0!==(n=e[o]);o++)if(V(n)){if(t=n[Y.expando]){if(t.events)for(r in t.events)i[r]?S.event.remove(n,r):S.removeEvent(n,r,t.handle);n[Y.expando]=void 0}n[Q.expando]&&(n[Q.expando]=void 0)}}}),S.fn.extend({detach:function(e){return Oe(this,e,!0)},remove:function(e){return Oe(this,e)},text:function(e){return $(this,function(e){return void 0===e?S.text(this):this.empty().each(function(){1!==this.nodeType&&11!==this.nodeType&&9!==this.nodeType||(this.textContent=e)})},null,e,arguments.length)},append:function(){return He(this,arguments,function(e){1!==this.nodeType&&11!==this.nodeType&&9!==this.nodeType||je(this,e).appendChild(e)})},prepend:function(){return He(this,arguments,function(e){if(1===this.nodeType||11===this.nodeType||9===this.nodeType){var t=je(this,e);t.insertBefore(e,t.firstChild)}})},before:function(){return He(this,arguments,function(e){this.parentNode&&this.parentNode.insertBefore(e,this)})},after:function(){return He(this,arguments,function(e){this.parentNode&&this.parentNode.insertBefore(e,this.nextSibling)})},empty:function(){for(var e,t=0;null!=(e=this[t]);t++)1===e.nodeType&&(S.cleanData(ve(e,!1)),e.textContent="");return this},clone:function(e,t){return e=null!=e&&e,t=null==t?e:t,this.map(function(){return S.clone(this,e,t)})},html:function(e){return $(this,function(e){var t=this[0]||{},n=0,r=this.length;if(void 0===e&&1===t.nodeType)return t.innerHTML;if("string"==typeof e&&!ke.test(e)&&!ge[(de.exec(e)||["",""])[1].toLowerCase()]){e=S.htmlPrefilter(e);try{for(;n<r;n++)1===(t=this[n]||{}).nodeType&&(S.cleanData(ve(t,!1)),t.innerHTML=e);t=0}catch(e){}}t&&this.empty().append(e)},null,e,arguments.length)},replaceWith:function(){var n=[];return He(this,arguments,function(e){var t=this.parentNode;S.inArray(this,n)<0&&(S.cleanData(ve(this)),t&&t.replaceChild(e,this))},n)}}),S.each({appendTo:"append",prependTo:"prepend",insertBefore:"before",insertAfter:"after",replaceAll:"replaceWith"},function(e,a){S.fn[e]=function(e){for(var t,n=[],r=S(e),i=r.length-1,o=0;o<=i;o++)t=o===i?this:this.clone(!0),S(r[o])[a](t),u.apply(n,t.get());return this.pushStack(n)}});var Pe=new RegExp("^("+ee+")(?!px)[a-z%]+$","i"),Re=function(e){var t=e.ownerDocument.defaultView;return t&&t.opener||(t=C),t.getComputedStyle(e)},Me=function(e,t,n){var r,i,o={};for(i in t)o[i]=e.style[i],e.style[i]=t[i];for(i in r=n.call(e),t)e.style[i]=o[i];return r},Ie=new RegExp(ne.join("|"),"i");function We(e,t,n){var r,i,o,a,s=e.style;return(n=n||Re(e))&&(""!==(a=n.getPropertyValue(t)||n[t])||ie(e)||(a=S.style(e,t)),!y.pixelBoxStyles()&&Pe.test(a)&&Ie.test(t)&&(r=s.width,i=s.minWidth,o=s.maxWidth,s.minWidth=s.maxWidth=s.width=a,a=n.width,s.width=r,s.minWidth=i,s.maxWidth=o)),void 0!==a?a+"":a}function Fe(e,t){return{get:function(){if(!e())return(this.get=t).apply(this,arguments);delete this.get}}}!function(){function e(){if(l){u.style.cssText="position:absolute;left:-11111px;width:60px;margin-top:1px;padding:0;border:0",l.style.cssText="position:relative;display:block;box-sizing:border-box;overflow:scroll;margin:auto;border:1px;padding:1px;width:60%;top:1%",re.appendChild(u).appendChild(l);var e=C.getComputedStyle(l);n="1%"!==e.top,s=12===t(e.marginLeft),l.style.right="60%",o=36===t(e.right),r=36===t(e.width),l.style.position="absolute",i=12===t(l.offsetWidth/3),re.removeChild(u),l=null}}function t(e){return Math.round(parseFloat(e))}var n,r,i,o,a,s,u=E.createElement("div"),l=E.createElement("div");l.style&&(l.style.backgroundClip="content-box",l.cloneNode(!0).style.backgroundClip="",y.clearCloneStyle="content-box"===l.style.backgroundClip,S.extend(y,{boxSizingReliable:function(){return e(),r},pixelBoxStyles:function(){return e(),o},pixelPosition:function(){return e(),n},reliableMarginLeft:function(){return e(),s},scrollboxSize:function(){return e(),i},reliableTrDimensions:function(){var e,t,n,r;return null==a&&(e=E.createElement("table"),t=E.createElement("tr"),n=E.createElement("div"),e.style.cssText="position:absolute;left:-11111px;border-collapse:separate",t.style.cssText="border:1px solid",t.style.height="1px",n.style.height="9px",n.style.display="block",re.appendChild(e).appendChild(t).appendChild(n),r=C.getComputedStyle(t),a=parseInt(r.height,10)+parseInt(r.borderTopWidth,10)+parseInt(r.borderBottomWidth,10)===t.offsetHeight,re.removeChild(e)),a}}))}();var Be=["Webkit","Moz","ms"],$e=E.createElement("div").style,_e={};function ze(e){var t=S.cssProps[e]||_e[e];return t||(e in $e?e:_e[e]=function(e){var t=e[0].toUpperCase()+e.slice(1),n=Be.length;while(n--)if((e=Be[n]+t)in $e)return e}(e)||e)}var Ue=/^(none|table(?!-c[ea]).+)/,Xe=/^--/,Ve={position:"absolute",visibility:"hidden",display:"block"},Ge={letterSpacing:"0",fontWeight:"400"};function Ye(e,t,n){var r=te.exec(t);return r?Math.max(0,r[2]-(n||0))+(r[3]||"px"):t}function Qe(e,t,n,r,i,o){var a="width"===t?1:0,s=0,u=0;if(n===(r?"border":"content"))return 0;for(;a<4;a+=2)"margin"===n&&(u+=S.css(e,n+ne[a],!0,i)),r?("content"===n&&(u-=S.css(e,"padding"+ne[a],!0,i)),"margin"!==n&&(u-=S.css(e,"border"+ne[a]+"Width",!0,i))):(u+=S.css(e,"padding"+ne[a],!0,i),"padding"!==n?u+=S.css(e,"border"+ne[a]+"Width",!0,i):s+=S.css(e,"border"+ne[a]+"Width",!0,i));return!r&&0<=o&&(u+=Math.max(0,Math.ceil(e["offset"+t[0].toUpperCase()+t.slice(1)]-o-u-s-.5))||0),u}function Je(e,t,n){var r=Re(e),i=(!y.boxSizingReliable()||n)&&"border-box"===S.css(e,"boxSizing",!1,r),o=i,a=We(e,t,r),s="offset"+t[0].toUpperCase()+t.slice(1);if(Pe.test(a)){if(!n)return a;a="auto"}return(!y.boxSizingReliable()&&i||!y.reliableTrDimensions()&&A(e,"tr")||"auto"===a||!parseFloat(a)&&"inline"===S.css(e,"display",!1,r))&&e.getClientRects().length&&(i="border-box"===S.css(e,"boxSizing",!1,r),(o=s in e)&&(a=e[s])),(a=parseFloat(a)||0)+Qe(e,t,n||(i?"border":"content"),o,r,a)+"px"}function Ke(e,t,n,r,i){return new Ke.prototype.init(e,t,n,r,i)}S.extend({cssHooks:{opacity:{get:function(e,t){if(t){var n=We(e,"opacity");return""===n?"1":n}}}},cssNumber:{animationIterationCount:!0,columnCount:!0,fillOpacity:!0,flexGrow:!0,flexShrink:!0,fontWeight:!0,gridArea:!0,gridColumn:!0,gridColumnEnd:!0,gridColumnStart:!0,gridRow:!0,gridRowEnd:!0,gridRowStart:!0,lineHeight:!0,opacity:!0,order:!0,orphans:!0,widows:!0,zIndex:!0,zoom:!0},cssProps:{},style:function(e,t,n,r){if(e&&3!==e.nodeType&&8!==e.nodeType&&e.style){var i,o,a,s=X(t),u=Xe.test(t),l=e.style;if(u||(t=ze(s)),a=S.cssHooks[t]||S.cssHooks[s],void 0===n)return a&&"get"in a&&void 0!==(i=a.get(e,!1,r))?i:l[t];"string"===(o=typeof n)&&(i=te.exec(n))&&i[1]&&(n=se(e,t,i),o="number"),null!=n&&n==n&&("number"!==o||u||(n+=i&&i[3]||(S.cssNumber[s]?"":"px")),y.clearCloneStyle||""!==n||0!==t.indexOf("background")||(l[t]="inherit"),a&&"set"in a&&void 0===(n=a.set(e,n,r))||(u?l.setProperty(t,n):l[t]=n))}},css:function(e,t,n,r){var i,o,a,s=X(t);return Xe.test(t)||(t=ze(s)),(a=S.cssHooks[t]||S.cssHooks[s])&&"get"in a&&(i=a.get(e,!0,n)),void 0===i&&(i=We(e,t,r)),"normal"===i&&t in Ge&&(i=Ge[t]),""===n||n?(o=parseFloat(i),!0===n||isFinite(o)?o||0:i):i}}),S.each(["height","width"],function(e,u){S.cssHooks[u]={get:function(e,t,n){if(t)return!Ue.test(S.css(e,"display"))||e.getClientRects().length&&e.getBoundingClientRect().width?Je(e,u,n):Me(e,Ve,function(){return Je(e,u,n)})},set:function(e,t,n){var r,i=Re(e),o=!y.scrollboxSize()&&"absolute"===i.position,a=(o||n)&&"border-box"===S.css(e,"boxSizing",!1,i),s=n?Qe(e,u,n,a,i):0;return a&&o&&(s-=Math.ceil(e["offset"+u[0].toUpperCase()+u.slice(1)]-parseFloat(i[u])-Qe(e,u,"border",!1,i)-.5)),s&&(r=te.exec(t))&&"px"!==(r[3]||"px")&&(e.style[u]=t,t=S.css(e,u)),Ye(0,t,s)}}}),S.cssHooks.marginLeft=Fe(y.reliableMarginLeft,function(e,t){if(t)return(parseFloat(We(e,"marginLeft"))||e.getBoundingClientRect().left-Me(e,{marginLeft:0},function(){return e.getBoundingClientRect().left}))+"px"}),S.each({margin:"",padding:"",border:"Width"},function(i,o){S.cssHooks[i+o]={expand:function(e){for(var t=0,n={},r="string"==typeof e?e.split(" "):[e];t<4;t++)n[i+ne[t]+o]=r[t]||r[t-2]||r[0];return n}},"margin"!==i&&(S.cssHooks[i+o].set=Ye)}),S.fn.extend({css:function(e,t){return $(this,function(e,t,n){var r,i,o={},a=0;if(Array.isArray(t)){for(r=Re(e),i=t.length;a<i;a++)o[t[a]]=S.css(e,t[a],!1,r);return o}return void 0!==n?S.style(e,t,n):S.css(e,t)},e,t,1<arguments.length)}}),((S.Tween=Ke).prototype={constructor:Ke,init:function(e,t,n,r,i,o){this.elem=e,this.prop=n,this.easing=i||S.easing._default,this.options=t,this.start=this.now=this.cur(),this.end=r,this.unit=o||(S.cssNumber[n]?"":"px")},cur:function(){var e=Ke.propHooks[this.prop];return e&&e.get?e.get(this):Ke.propHooks._default.get(this)},run:function(e){var t,n=Ke.propHooks[this.prop];return this.options.duration?this.pos=t=S.easing[this.easing](e,this.options.duration*e,0,1,this.options.duration):this.pos=t=e,this.now=(this.end-this.start)*t+this.start,this.options.step&&this.options.step.call(this.elem,this.now,this),n&&n.set?n.set(this):Ke.propHooks._default.set(this),this}}).init.prototype=Ke.prototype,(Ke.propHooks={_default:{get:function(e){var t;return 1!==e.elem.nodeType||null!=e.elem[e.prop]&&null==e.elem.style[e.prop]?e.elem[e.prop]:(t=S.css(e.elem,e.prop,""))&&"auto"!==t?t:0},set:function(e){S.fx.step[e.prop]?S.fx.step[e.prop](e):1!==e.elem.nodeType||!S.cssHooks[e.prop]&&null==e.elem.style[ze(e.prop)]?e.elem[e.prop]=e.now:S.style(e.elem,e.prop,e.now+e.unit)}}}).scrollTop=Ke.propHooks.scrollLeft={set:function(e){e.elem.nodeType&&e.elem.parentNode&&(e.elem[e.prop]=e.now)}},S.easing={linear:function(e){return e},swing:function(e){return.5-Math.cos(e*Math.PI)/2},_default:"swing"},S.fx=Ke.prototype.init,S.fx.step={};var Ze,et,tt,nt,rt=/^(?:toggle|show|hide)$/,it=/queueHooks$/;function ot(){et&&(!1===E.hidden&&C.requestAnimationFrame?C.requestAnimationFrame(ot):C.setTimeout(ot,S.fx.interval),S.fx.tick())}function at(){return C.setTimeout(function(){Ze=void 0}),Ze=Date.now()}function st(e,t){var n,r=0,i={height:e};for(t=t?1:0;r<4;r+=2-t)i["margin"+(n=ne[r])]=i["padding"+n]=e;return t&&(i.opacity=i.width=e),i}function ut(e,t,n){for(var r,i=(lt.tweeners[t]||[]).concat(lt.tweeners["*"]),o=0,a=i.length;o<a;o++)if(r=i[o].call(n,t,e))return r}function lt(o,e,t){var n,a,r=0,i=lt.prefilters.length,s=S.Deferred().always(function(){delete u.elem}),u=function(){if(a)return!1;for(var e=Ze||at(),t=Math.max(0,l.startTime+l.duration-e),n=1-(t/l.duration||0),r=0,i=l.tweens.length;r<i;r++)l.tweens[r].run(n);return s.notifyWith(o,[l,n,t]),n<1&&i?t:(i||s.notifyWith(o,[l,1,0]),s.resolveWith(o,[l]),!1)},l=s.promise({elem:o,props:S.extend({},e),opts:S.extend(!0,{specialEasing:{},easing:S.easing._default},t),originalProperties:e,originalOptions:t,startTime:Ze||at(),duration:t.duration,tweens:[],createTween:function(e,t){var n=S.Tween(o,l.opts,e,t,l.opts.specialEasing[e]||l.opts.easing);return l.tweens.push(n),n},stop:function(e){var t=0,n=e?l.tweens.length:0;if(a)return this;for(a=!0;t<n;t++)l.tweens[t].run(1);return e?(s.notifyWith(o,[l,1,0]),s.resolveWith(o,[l,e])):s.rejectWith(o,[l,e]),this}}),c=l.props;for(!function(e,t){var n,r,i,o,a;for(n in e)if(i=t[r=X(n)],o=e[n],Array.isArray(o)&&(i=o[1],o=e[n]=o[0]),n!==r&&(e[r]=o,delete e[n]),(a=S.cssHooks[r])&&"expand"in a)for(n in o=a.expand(o),delete e[r],o)n in e||(e[n]=o[n],t[n]=i);else t[r]=i}(c,l.opts.specialEasing);r<i;r++)if(n=lt.prefilters[r].call(l,o,c,l.opts))return m(n.stop)&&(S._queueHooks(l.elem,l.opts.queue).stop=n.stop.bind(n)),n;return S.map(c,ut,l),m(l.opts.start)&&l.opts.start.call(o,l),l.progress(l.opts.progress).done(l.opts.done,l.opts.complete).fail(l.opts.fail).always(l.opts.always),S.fx.timer(S.extend(u,{elem:o,anim:l,queue:l.opts.queue})),l}S.Animation=S.extend(lt,{tweeners:{"*":[function(e,t){var n=this.createTween(e,t);return se(n.elem,e,te.exec(t),n),n}]},tweener:function(e,t){m(e)?(t=e,e=["*"]):e=e.match(P);for(var n,r=0,i=e.length;r<i;r++)n=e[r],lt.tweeners[n]=lt.tweeners[n]||[],lt.tweeners[n].unshift(t)},prefilters:[function(e,t,n){var r,i,o,a,s,u,l,c,f="width"in t||"height"in t,p=this,d={},h=e.style,g=e.nodeType&&ae(e),v=Y.get(e,"fxshow");for(r in n.queue||(null==(a=S._queueHooks(e,"fx")).unqueued&&(a.unqueued=0,s=a.empty.fire,a.empty.fire=function(){a.unqueued||s()}),a.unqueued++,p.always(function(){p.always(function(){a.unqueued--,S.queue(e,"fx").length||a.empty.fire()})})),t)if(i=t[r],rt.test(i)){if(delete t[r],o=o||"toggle"===i,i===(g?"hide":"show")){if("show"!==i||!v||void 0===v[r])continue;g=!0}d[r]=v&&v[r]||S.style(e,r)}if((u=!S.isEmptyObject(t))||!S.isEmptyObject(d))for(r in f&&1===e.nodeType&&(n.overflow=[h.overflow,h.overflowX,h.overflowY],null==(l=v&&v.display)&&(l=Y.get(e,"display")),"none"===(c=S.css(e,"display"))&&(l?c=l:(le([e],!0),l=e.style.display||l,c=S.css(e,"display"),le([e]))),("inline"===c||"inline-block"===c&&null!=l)&&"none"===S.css(e,"float")&&(u||(p.done(function(){h.display=l}),null==l&&(c=h.display,l="none"===c?"":c)),h.display="inline-block")),n.overflow&&(h.overflow="hidden",p.always(function(){h.overflow=n.overflow[0],h.overflowX=n.overflow[1],h.overflowY=n.overflow[2]})),u=!1,d)u||(v?"hidden"in v&&(g=v.hidden):v=Y.access(e,"fxshow",{display:l}),o&&(v.hidden=!g),g&&le([e],!0),p.done(function(){for(r in g||le([e]),Y.remove(e,"fxshow"),d)S.style(e,r,d[r])})),u=ut(g?v[r]:0,r,p),r in v||(v[r]=u.start,g&&(u.end=u.start,u.start=0))}],prefilter:function(e,t){t?lt.prefilters.unshift(e):lt.prefilters.push(e)}}),S.speed=function(e,t,n){var r=e&&"object"==typeof e?S.extend({},e):{complete:n||!n&&t||m(e)&&e,duration:e,easing:n&&t||t&&!m(t)&&t};return S.fx.off?r.duration=0:"number"!=typeof r.duration&&(r.duration in S.fx.speeds?r.duration=S.fx.speeds[r.duration]:r.duration=S.fx.speeds._default),null!=r.queue&&!0!==r.queue||(r.queue="fx"),r.old=r.complete,r.complete=function(){m(r.old)&&r.old.call(this),r.queue&&S.dequeue(this,r.queue)},r},S.fn.extend({fadeTo:function(e,t,n,r){return this.filter(ae).css("opacity",0).show().end().animate({opacity:t},e,n,r)},animate:function(t,e,n,r){var i=S.isEmptyObject(t),o=S.speed(e,n,r),a=function(){var e=lt(this,S.extend({},t),o);(i||Y.get(this,"finish"))&&e.stop(!0)};return a.finish=a,i||!1===o.queue?this.each(a):this.queue(o.queue,a)},stop:function(i,e,o){var a=function(e){var t=e.stop;delete e.stop,t(o)};return"string"!=typeof i&&(o=e,e=i,i=void 0),e&&this.queue(i||"fx",[]),this.each(function(){var e=!0,t=null!=i&&i+"queueHooks",n=S.timers,r=Y.get(this);if(t)r[t]&&r[t].stop&&a(r[t]);else for(t in r)r[t]&&r[t].stop&&it.test(t)&&a(r[t]);for(t=n.length;t--;)n[t].elem!==this||null!=i&&n[t].queue!==i||(n[t].anim.stop(o),e=!1,n.splice(t,1));!e&&o||S.dequeue(this,i)})},finish:function(a){return!1!==a&&(a=a||"fx"),this.each(function(){var e,t=Y.get(this),n=t[a+"queue"],r=t[a+"queueHooks"],i=S.timers,o=n?n.length:0;for(t.finish=!0,S.queue(this,a,[]),r&&r.stop&&r.stop.call(this,!0),e=i.length;e--;)i[e].elem===this&&i[e].queue===a&&(i[e].anim.stop(!0),i.splice(e,1));for(e=0;e<o;e++)n[e]&&n[e].finish&&n[e].finish.call(this);delete t.finish})}}),S.each(["toggle","show","hide"],function(e,r){var i=S.fn[r];S.fn[r]=function(e,t,n){return null==e||"boolean"==typeof e?i.apply(this,arguments):this.animate(st(r,!0),e,t,n)}}),S.each({slideDown:st("show"),slideUp:st("hide"),slideToggle:st("toggle"),fadeIn:{opacity:"show"},fadeOut:{opacity:"hide"},fadeToggle:{opacity:"toggle"}},function(e,r){S.fn[e]=function(e,t,n){return this.animate(r,e,t,n)}}),S.timers=[],S.fx.tick=function(){var e,t=0,n=S.timers;for(Ze=Date.now();t<n.length;t++)(e=n[t])()||n[t]!==e||n.splice(t--,1);n.length||S.fx.stop(),Ze=void 0},S.fx.timer=function(e){S.timers.push(e),S.fx.start()},S.fx.interval=13,S.fx.start=function(){et||(et=!0,ot())},S.fx.stop=function(){et=null},S.fx.speeds={slow:600,fast:200,_default:400},S.fn.delay=function(r,e){return r=S.fx&&S.fx.speeds[r]||r,e=e||"fx",this.queue(e,function(e,t){var n=C.setTimeout(e,r);t.stop=function(){C.clearTimeout(n)}})},tt=E.createElement("input"),nt=E.createElement("select").appendChild(E.createElement("option")),tt.type="checkbox",y.checkOn=""!==tt.value,y.optSelected=nt.selected,(tt=E.createElement("input")).value="t",tt.type="radio",y.radioValue="t"===tt.value;var ct,ft=S.expr.attrHandle;S.fn.extend({attr:function(e,t){return $(this,S.attr,e,t,1<arguments.length)},removeAttr:function(e){return this.each(function(){S.removeAttr(this,e)})}}),S.extend({attr:function(e,t,n){var r,i,o=e.nodeType;if(3!==o&&8!==o&&2!==o)return"undefined"==typeof e.getAttribute?S.prop(e,t,n):(1===o&&S.isXMLDoc(e)||(i=S.attrHooks[t.toLowerCase()]||(S.expr.match.bool.test(t)?ct:void 0)),void 0!==n?null===n?void S.removeAttr(e,t):i&&"set"in i&&void 0!==(r=i.set(e,n,t))?r:(e.setAttribute(t,n+""),n):i&&"get"in i&&null!==(r=i.get(e,t))?r:null==(r=S.find.attr(e,t))?void 0:r)},attrHooks:{type:{set:function(e,t){if(!y.radioValue&&"radio"===t&&A(e,"input")){var n=e.value;return e.setAttribute("type",t),n&&(e.value=n),t}}}},removeAttr:function(e,t){var n,r=0,i=t&&t.match(P);if(i&&1===e.nodeType)while(n=i[r++])e.removeAttribute(n)}}),ct={set:function(e,t,n){return!1===t?S.removeAttr(e,n):e.setAttribute(n,n),n}},S.each(S.expr.match.bool.source.match(/\w+/g),function(e,t){var a=ft[t]||S.find.attr;ft[t]=function(e,t,n){var r,i,o=t.toLowerCase();return n||(i=ft[o],ft[o]=r,r=null!=a(e,t,n)?o:null,ft[o]=i),r}});var pt=/^(?:input|select|textarea|button)$/i,dt=/^(?:a|area)$/i;function ht(e){return(e.match(P)||[]).join(" ")}function gt(e){return e.getAttribute&&e.getAttribute("class")||""}function vt(e){return Array.isArray(e)?e:"string"==typeof e&&e.match(P)||[]}S.fn.extend({prop:function(e,t){return $(this,S.prop,e,t,1<arguments.length)},removeProp:function(e){return this.each(function(){delete this[S.propFix[e]||e]})}}),S.extend({prop:function(e,t,n){var r,i,o=e.nodeType;if(3!==o&&8!==o&&2!==o)return 1===o&&S.isXMLDoc(e)||(t=S.propFix[t]||t,i=S.propHooks[t]),void 0!==n?i&&"set"in i&&void 0!==(r=i.set(e,n,t))?r:e[t]=n:i&&"get"in i&&null!==(r=i.get(e,t))?r:e[t]},propHooks:{tabIndex:{get:function(e){var t=S.find.attr(e,"tabindex");return t?parseInt(t,10):pt.test(e.nodeName)||dt.test(e.nodeName)&&e.href?0:-1}}},propFix:{"for":"htmlFor","class":"className"}}),y.optSelected||(S.propHooks.selected={get:function(e){var t=e.parentNode;return t&&t.parentNode&&t.parentNode.selectedIndex,null},set:function(e){var t=e.parentNode;t&&(t.selectedIndex,t.parentNode&&t.parentNode.selectedIndex)}}),S.each(["tabIndex","readOnly","maxLength","cellSpacing","cellPadding","rowSpan","colSpan","useMap","frameBorder","contentEditable"],function(){S.propFix[this.toLowerCase()]=this}),S.fn.extend({addClass:function(t){var e,n,r,i,o,a,s,u=0;if(m(t))return this.each(function(e){S(this).addClass(t.call(this,e,gt(this)))});if((e=vt(t)).length)while(n=this[u++])if(i=gt(n),r=1===n.nodeType&&" "+ht(i)+" "){a=0;while(o=e[a++])r.indexOf(" "+o+" ")<0&&(r+=o+" ");i!==(s=ht(r))&&n.setAttribute("class",s)}return this},removeClass:function(t){var e,n,r,i,o,a,s,u=0;if(m(t))return this.each(function(e){S(this).removeClass(t.call(this,e,gt(this)))});if(!arguments.length)return this.attr("class","");if((e=vt(t)).length)while(n=this[u++])if(i=gt(n),r=1===n.nodeType&&" "+ht(i)+" "){a=0;while(o=e[a++])while(-1<r.indexOf(" "+o+" "))r=r.replace(" "+o+" "," ");i!==(s=ht(r))&&n.setAttribute("class",s)}return this},toggleClass:function(i,t){var o=typeof i,a="string"===o||Array.isArray(i);return"boolean"==typeof t&&a?t?this.addClass(i):this.removeClass(i):m(i)?this.each(function(e){S(this).toggleClass(i.call(this,e,gt(this),t),t)}):this.each(function(){var e,t,n,r;if(a){t=0,n=S(this),r=vt(i);while(e=r[t++])n.hasClass(e)?n.removeClass(e):n.addClass(e)}else void 0!==i&&"boolean"!==o||((e=gt(this))&&Y.set(this,"__className__",e),this.setAttribute&&this.setAttribute("class",e||!1===i?"":Y.get(this,"__className__")||""))})},hasClass:function(e){var t,n,r=0;t=" "+e+" ";while(n=this[r++])if(1===n.nodeType&&-1<(" "+ht(gt(n))+" ").indexOf(t))return!0;return!1}});var yt=/\r/g;S.fn.extend({val:function(n){var r,e,i,t=this[0];return arguments.length?(i=m(n),this.each(function(e){var t;1===this.nodeType&&(null==(t=i?n.call(this,e,S(this).val()):n)?t="":"number"==typeof t?t+="":Array.isArray(t)&&(t=S.map(t,function(e){return null==e?"":e+""})),(r=S.valHooks[this.type]||S.valHooks[this.nodeName.toLowerCase()])&&"set"in r&&void 0!==r.set(this,t,"value")||(this.value=t))})):t?(r=S.valHooks[t.type]||S.valHooks[t.nodeName.toLowerCase()])&&"get"in r&&void 0!==(e=r.get(t,"value"))?e:"string"==typeof(e=t.value)?e.replace(yt,""):null==e?"":e:void 0}}),S.extend({valHooks:{option:{get:function(e){var t=S.find.attr(e,"value");return null!=t?t:ht(S.text(e))}},select:{get:function(e){var t,n,r,i=e.options,o=e.selectedIndex,a="select-one"===e.type,s=a?null:[],u=a?o+1:i.length;for(r=o<0?u:a?o:0;r<u;r++)if(((n=i[r]).selected||r===o)&&!n.disabled&&(!n.parentNode.disabled||!A(n.parentNode,"optgroup"))){if(t=S(n).val(),a)return t;s.push(t)}return s},set:function(e,t){var n,r,i=e.options,o=S.makeArray(t),a=i.length;while(a--)((r=i[a]).selected=-1<S.inArray(S.valHooks.option.get(r),o))&&(n=!0);return n||(e.selectedIndex=-1),o}}}}),S.each(["radio","checkbox"],function(){S.valHooks[this]={set:function(e,t){if(Array.isArray(t))return e.checked=-1<S.inArray(S(e).val(),t)}},y.checkOn||(S.valHooks[this].get=function(e){return null===e.getAttribute("value")?"on":e.value})}),y.focusin="onfocusin"in C;var mt=/^(?:focusinfocus|focusoutblur)$/,xt=function(e){e.stopPropagation()};S.extend(S.event,{trigger:function(e,t,n,r){var i,o,a,s,u,l,c,f,p=[n||E],d=v.call(e,"type")?e.type:e,h=v.call(e,"namespace")?e.namespace.split("."):[];if(o=f=a=n=n||E,3!==n.nodeType&&8!==n.nodeType&&!mt.test(d+S.event.triggered)&&(-1<d.indexOf(".")&&(d=(h=d.split(".")).shift(),h.sort()),u=d.indexOf(":")<0&&"on"+d,(e=e[S.expando]?e:new S.Event(d,"object"==typeof e&&e)).isTrigger=r?2:3,e.namespace=h.join("."),e.rnamespace=e.namespace?new RegExp("(^|\\.)"+h.join("\\.(?:.*\\.|)")+"(\\.|$)"):null,e.result=void 0,e.target||(e.target=n),t=null==t?[e]:S.makeArray(t,[e]),c=S.event.special[d]||{},r||!c.trigger||!1!==c.trigger.apply(n,t))){if(!r&&!c.noBubble&&!x(n)){for(s=c.delegateType||d,mt.test(s+d)||(o=o.parentNode);o;o=o.parentNode)p.push(o),a=o;a===(n.ownerDocument||E)&&p.push(a.defaultView||a.parentWindow||C)}i=0;while((o=p[i++])&&!e.isPropagationStopped())f=o,e.type=1<i?s:c.bindType||d,(l=(Y.get(o,"events")||Object.create(null))[e.type]&&Y.get(o,"handle"))&&l.apply(o,t),(l=u&&o[u])&&l.apply&&V(o)&&(e.result=l.apply(o,t),!1===e.result&&e.preventDefault());return e.type=d,r||e.isDefaultPrevented()||c._default&&!1!==c._default.apply(p.pop(),t)||!V(n)||u&&m(n[d])&&!x(n)&&((a=n[u])&&(n[u]=null),S.event.triggered=d,e.isPropagationStopped()&&f.addEventListener(d,xt),n[d](),e.isPropagationStopped()&&f.removeEventListener(d,xt),S.event.triggered=void 0,a&&(n[u]=a)),e.result}},simulate:function(e,t,n){var r=S.extend(new S.Event,n,{type:e,isSimulated:!0});S.event.trigger(r,null,t)}}),S.fn.extend({trigger:function(e,t){return this.each(function(){S.event.trigger(e,t,this)})},triggerHandler:function(e,t){var n=this[0];if(n)return S.event.trigger(e,t,n,!0)}}),y.focusin||S.each({focus:"focusin",blur:"focusout"},function(n,r){var i=function(e){S.event.simulate(r,e.target,S.event.fix(e))};S.event.special[r]={setup:function(){var e=this.ownerDocument||this.document||this,t=Y.access(e,r);t||e.addEventListener(n,i,!0),Y.access(e,r,(t||0)+1)},teardown:function(){var e=this.ownerDocument||this.document||this,t=Y.access(e,r)-1;t?Y.access(e,r,t):(e.removeEventListener(n,i,!0),Y.remove(e,r))}}});var bt=C.location,wt={guid:Date.now()},Tt=/\?/;S.parseXML=function(e){var t,n;if(!e||"string"!=typeof e)return null;try{t=(new C.DOMParser).parseFromString(e,"text/xml")}catch(e){}return n=t&&t.getElementsByTagName("parsererror")[0],t&&!n||S.error("Invalid XML: "+(n?S.map(n.childNodes,function(e){return e.textContent}).join("\n"):e)),t};var Ct=/\[\]$/,Et=/\r?\n/g,St=/^(?:submit|button|image|reset|file)$/i,kt=/^(?:input|select|textarea|keygen)/i;function At(n,e,r,i){var t;if(Array.isArray(e))S.each(e,function(e,t){r||Ct.test(n)?i(n,t):At(n+"["+("object"==typeof t&&null!=t?e:"")+"]",t,r,i)});else if(r||"object"!==w(e))i(n,e);else for(t in e)At(n+"["+t+"]",e[t],r,i)}S.param=function(e,t){var n,r=[],i=function(e,t){var n=m(t)?t():t;r[r.length]=encodeURIComponent(e)+"="+encodeURIComponent(null==n?"":n)};if(null==e)return"";if(Array.isArray(e)||e.jquery&&!S.isPlainObject(e))S.each(e,function(){i(this.name,this.value)});else for(n in e)At(n,e[n],t,i);return r.join("&")},S.fn.extend({serialize:function(){return S.param(this.serializeArray())},serializeArray:function(){return this.map(function(){var e=S.prop(this,"elements");return e?S.makeArray(e):this}).filter(function(){var e=this.type;return this.name&&!S(this).is(":disabled")&&kt.test(this.nodeName)&&!St.test(e)&&(this.checked||!pe.test(e))}).map(function(e,t){var n=S(this).val();return null==n?null:Array.isArray(n)?S.map(n,function(e){return{name:t.name,value:e.replace(Et,"\r\n")}}):{name:t.name,value:n.replace(Et,"\r\n")}}).get()}});var Nt=/%20/g,jt=/#.*$/,Dt=/([?&])_=[^&]*/,qt=/^(.*?):[ \t]*([^\r\n]*)$/gm,Lt=/^(?:GET|HEAD)$/,Ht=/^\/\//,Ot={},Pt={},Rt="*/".concat("*"),Mt=E.createElement("a");function It(o){return function(e,t){"string"!=typeof e&&(t=e,e="*");var n,r=0,i=e.toLowerCase().match(P)||[];if(m(t))while(n=i[r++])"+"===n[0]?(n=n.slice(1)||"*",(o[n]=o[n]||[]).unshift(t)):(o[n]=o[n]||[]).push(t)}}function Wt(t,i,o,a){var s={},u=t===Pt;function l(e){var r;return s[e]=!0,S.each(t[e]||[],function(e,t){var n=t(i,o,a);return"string"!=typeof n||u||s[n]?u?!(r=n):void 0:(i.dataTypes.unshift(n),l(n),!1)}),r}return l(i.dataTypes[0])||!s["*"]&&l("*")}function Ft(e,t){var n,r,i=S.ajaxSettings.flatOptions||{};for(n in t)void 0!==t[n]&&((i[n]?e:r||(r={}))[n]=t[n]);return r&&S.extend(!0,e,r),e}Mt.href=bt.href,S.extend({active:0,lastModified:{},etag:{},ajaxSettings:{url:bt.href,type:"GET",isLocal:/^(?:about|app|app-storage|.+-extension|file|res|widget):$/.test(bt.protocol),global:!0,processData:!0,async:!0,contentType:"application/x-www-form-urlencoded; charset=UTF-8",accepts:{"*":Rt,text:"text/plain",html:"text/html",xml:"application/xml, text/xml",json:"application/json, text/javascript"},contents:{xml:/\bxml\b/,html:/\bhtml/,json:/\bjson\b/},responseFields:{xml:"responseXML",text:"responseText",json:"responseJSON"},converters:{"* text":String,"text html":!0,"text json":JSON.parse,"text xml":S.parseXML},flatOptions:{url:!0,context:!0}},ajaxSetup:function(e,t){return t?Ft(Ft(e,S.ajaxSettings),t):Ft(S.ajaxSettings,e)},ajaxPrefilter:It(Ot),ajaxTransport:It(Pt),ajax:function(e,t){"object"==typeof e&&(t=e,e=void 0),t=t||{};var c,f,p,n,d,r,h,g,i,o,v=S.ajaxSetup({},t),y=v.context||v,m=v.context&&(y.nodeType||y.jquery)?S(y):S.event,x=S.Deferred(),b=S.Callbacks("once memory"),w=v.statusCode||{},a={},s={},u="canceled",T={readyState:0,getResponseHeader:function(e){var t;if(h){if(!n){n={};while(t=qt.exec(p))n[t[1].toLowerCase()+" "]=(n[t[1].toLowerCase()+" "]||[]).concat(t[2])}t=n[e.toLowerCase()+" "]}return null==t?null:t.join(", ")},getAllResponseHeaders:function(){return h?p:null},setRequestHeader:function(e,t){return null==h&&(e=s[e.toLowerCase()]=s[e.toLowerCase()]||e,a[e]=t),this},overrideMimeType:function(e){return null==h&&(v.mimeType=e),this},statusCode:function(e){var t;if(e)if(h)T.always(e[T.status]);else for(t in e)w[t]=[w[t],e[t]];return this},abort:function(e){var t=e||u;return c&&c.abort(t),l(0,t),this}};if(x.promise(T),v.url=((e||v.url||bt.href)+"").replace(Ht,bt.protocol+"//"),v.type=t.method||t.type||v.method||v.type,v.dataTypes=(v.dataType||"*").toLowerCase().match(P)||[""],null==v.crossDomain){r=E.createElement("a");try{r.href=v.url,r.href=r.href,v.crossDomain=Mt.protocol+"//"+Mt.host!=r.protocol+"//"+r.host}catch(e){v.crossDomain=!0}}if(v.data&&v.processData&&"string"!=typeof v.data&&(v.data=S.param(v.data,v.traditional)),Wt(Ot,v,t,T),h)return T;for(i in(g=S.event&&v.global)&&0==S.active++&&S.event.trigger("ajaxStart"),v.type=v.type.toUpperCase(),v.hasContent=!Lt.test(v.type),f=v.url.replace(jt,""),v.hasContent?v.data&&v.processData&&0===(v.contentType||"").indexOf("application/x-www-form-urlencoded")&&(v.data=v.data.replace(Nt,"+")):(o=v.url.slice(f.length),v.data&&(v.processData||"string"==typeof v.data)&&(f+=(Tt.test(f)?"&":"?")+v.data,delete v.data),!1===v.cache&&(f=f.replace(Dt,"$1"),o=(Tt.test(f)?"&":"?")+"_="+wt.guid+++o),v.url=f+o),v.ifModified&&(S.lastModified[f]&&T.setRequestHeader("If-Modified-Since",S.lastModified[f]),S.etag[f]&&T.setRequestHeader("If-None-Match",S.etag[f])),(v.data&&v.hasContent&&!1!==v.contentType||t.contentType)&&T.setRequestHeader("Content-Type",v.contentType),T.setRequestHeader("Accept",v.dataTypes[0]&&v.accepts[v.dataTypes[0]]?v.accepts[v.dataTypes[0]]+("*"!==v.dataTypes[0]?", "+Rt+"; q=0.01":""):v.accepts["*"]),v.headers)T.setRequestHeader(i,v.headers[i]);if(v.beforeSend&&(!1===v.beforeSend.call(y,T,v)||h))return T.abort();if(u="abort",b.add(v.complete),T.done(v.success),T.fail(v.error),c=Wt(Pt,v,t,T)){if(T.readyState=1,g&&m.trigger("ajaxSend",[T,v]),h)return T;v.async&&0<v.timeout&&(d=C.setTimeout(function(){T.abort("timeout")},v.timeout));try{h=!1,c.send(a,l)}catch(e){if(h)throw e;l(-1,e)}}else l(-1,"No Transport");function l(e,t,n,r){var i,o,a,s,u,l=t;h||(h=!0,d&&C.clearTimeout(d),c=void 0,p=r||"",T.readyState=0<e?4:0,i=200<=e&&e<300||304===e,n&&(s=function(e,t,n){var r,i,o,a,s=e.contents,u=e.dataTypes;while("*"===u[0])u.shift(),void 0===r&&(r=e.mimeType||t.getResponseHeader("Content-Type"));if(r)for(i in s)if(s[i]&&s[i].test(r)){u.unshift(i);break}if(u[0]in n)o=u[0];else{for(i in n){if(!u[0]||e.converters[i+" "+u[0]]){o=i;break}a||(a=i)}o=o||a}if(o)return o!==u[0]&&u.unshift(o),n[o]}(v,T,n)),!i&&-1<S.inArray("script",v.dataTypes)&&S.inArray("json",v.dataTypes)<0&&(v.converters["text script"]=function(){}),s=function(e,t,n,r){var i,o,a,s,u,l={},c=e.dataTypes.slice();if(c[1])for(a in e.converters)l[a.toLowerCase()]=e.converters[a];o=c.shift();while(o)if(e.responseFields[o]&&(n[e.responseFields[o]]=t),!u&&r&&e.dataFilter&&(t=e.dataFilter(t,e.dataType)),u=o,o=c.shift())if("*"===o)o=u;else if("*"!==u&&u!==o){if(!(a=l[u+" "+o]||l["* "+o]))for(i in l)if((s=i.split(" "))[1]===o&&(a=l[u+" "+s[0]]||l["* "+s[0]])){!0===a?a=l[i]:!0!==l[i]&&(o=s[0],c.unshift(s[1]));break}if(!0!==a)if(a&&e["throws"])t=a(t);else try{t=a(t)}catch(e){return{state:"parsererror",error:a?e:"No conversion from "+u+" to "+o}}}return{state:"success",data:t}}(v,s,T,i),i?(v.ifModified&&((u=T.getResponseHeader("Last-Modified"))&&(S.lastModified[f]=u),(u=T.getResponseHeader("etag"))&&(S.etag[f]=u)),204===e||"HEAD"===v.type?l="nocontent":304===e?l="notmodified":(l=s.state,o=s.data,i=!(a=s.error))):(a=l,!e&&l||(l="error",e<0&&(e=0))),T.status=e,T.statusText=(t||l)+"",i?x.resolveWith(y,[o,l,T]):x.rejectWith(y,[T,l,a]),T.statusCode(w),w=void 0,g&&m.trigger(i?"ajaxSuccess":"ajaxError",[T,v,i?o:a]),b.fireWith(y,[T,l]),g&&(m.trigger("ajaxComplete",[T,v]),--S.active||S.event.trigger("ajaxStop")))}return T},getJSON:function(e,t,n){return S.get(e,t,n,"json")},getScript:function(e,t){return S.get(e,void 0,t,"script")}}),S.each(["get","post"],function(e,i){S[i]=function(e,t,n,r){return m(t)&&(r=r||n,n=t,t=void 0),S.ajax(S.extend({url:e,type:i,dataType:r,data:t,success:n},S.isPlainObject(e)&&e))}}),S.ajaxPrefilter(function(e){var t;for(t in e.headers)"content-type"===t.toLowerCase()&&(e.contentType=e.headers[t]||"")}),S._evalUrl=function(e,t,n){return S.ajax({url:e,type:"GET",dataType:"script",cache:!0,async:!1,global:!1,converters:{"text script":function(){}},dataFilter:function(e){S.globalEval(e,t,n)}})},S.fn.extend({wrapAll:function(e){var t;return this[0]&&(m(e)&&(e=e.call(this[0])),t=S(e,this[0].ownerDocument).eq(0).clone(!0),this[0].parentNode&&t.insertBefore(this[0]),t.map(function(){var e=this;while(e.firstElementChild)e=e.firstElementChild;return e}).append(this)),this},wrapInner:function(n){return m(n)?this.each(function(e){S(this).wrapInner(n.call(this,e))}):this.each(function(){var e=S(this),t=e.contents();t.length?t.wrapAll(n):e.append(n)})},wrap:function(t){var n=m(t);return this.each(function(e){S(this).wrapAll(n?t.call(this,e):t)})},unwrap:function(e){return this.parent(e).not("body").each(function(){S(this).replaceWith(this.childNodes)}),this}}),S.expr.pseudos.hidden=function(e){return!S.expr.pseudos.visible(e)},S.expr.pseudos.visible=function(e){return!!(e.offsetWidth||e.offsetHeight||e.getClientRects().length)},S.ajaxSettings.xhr=function(){try{return new C.XMLHttpRequest}catch(e){}};var Bt={0:200,1223:204},$t=S.ajaxSettings.xhr();y.cors=!!$t&&"withCredentials"in $t,y.ajax=$t=!!$t,S.ajaxTransport(function(i){var o,a;if(y.cors||$t&&!i.crossDomain)return{send:function(e,t){var n,r=i.xhr();if(r.open(i.type,i.url,i.async,i.username,i.password),i.xhrFields)for(n in i.xhrFields)r[n]=i.xhrFields[n];for(n in i.mimeType&&r.overrideMimeType&&r.overrideMimeType(i.mimeType),i.crossDomain||e["X-Requested-With"]||(e["X-Requested-With"]="XMLHttpRequest"),e)r.setRequestHeader(n,e[n]);o=function(e){return function(){o&&(o=a=r.onload=r.onerror=r.onabort=r.ontimeout=r.onreadystatechange=null,"abort"===e?r.abort():"error"===e?"number"!=typeof r.status?t(0,"error"):t(r.status,r.statusText):t(Bt[r.status]||r.status,r.statusText,"text"!==(r.responseType||"text")||"string"!=typeof r.responseText?{binary:r.response}:{text:r.responseText},r.getAllResponseHeaders()))}},r.onload=o(),a=r.onerror=r.ontimeout=o("error"),void 0!==r.onabort?r.onabort=a:r.onreadystatechange=function(){4===r.readyState&&C.setTimeout(function(){o&&a()})},o=o("abort");try{r.send(i.hasContent&&i.data||null)}catch(e){if(o)throw e}},abort:function(){o&&o()}}}),S.ajaxPrefilter(function(e){e.crossDomain&&(e.contents.script=!1)}),S.ajaxSetup({accepts:{script:"text/javascript, application/javascript, application/ecmascript, application/x-ecmascript"},contents:{script:/\b(?:java|ecma)script\b/},converters:{"text script":function(e){return S.globalEval(e),e}}}),S.ajaxPrefilter("script",function(e){void 0===e.cache&&(e.cache=!1),e.crossDomain&&(e.type="GET")}),S.ajaxTransport("script",function(n){var r,i;if(n.crossDomain||n.scriptAttrs)return{send:function(e,t){r=S("<script>").attr(n.scriptAttrs||{}).prop({charset:n.scriptCharset,src:n.url}).on("load error",i=function(e){r.remove(),i=null,e&&t("error"===e.type?404:200,e.type)}),E.head.appendChild(r[0])},abort:function(){i&&i()}}});var _t,zt=[],Ut=/(=)\?(?=&|$)|\?\?/;S.ajaxSetup({jsonp:"callback",jsonpCallback:function(){var e=zt.pop()||S.expando+"_"+wt.guid++;return this[e]=!0,e}}),S.ajaxPrefilter("json jsonp",function(e,t,n){var r,i,o,a=!1!==e.jsonp&&(Ut.test(e.url)?"url":"string"==typeof e.data&&0===(e.contentType||"").indexOf("application/x-www-form-urlencoded")&&Ut.test(e.data)&&"data");if(a||"jsonp"===e.dataTypes[0])return r=e.jsonpCallback=m(e.jsonpCallback)?e.jsonpCallback():e.jsonpCallback,a?e[a]=e[a].replace(Ut,"$1"+r):!1!==e.jsonp&&(e.url+=(Tt.test(e.url)?"&":"?")+e.jsonp+"="+r),e.converters["script json"]=function(){return o||S.error(r+" was not called"),o[0]},e.dataTypes[0]="json",i=C[r],C[r]=function(){o=arguments},n.always(function(){void 0===i?S(C).removeProp(r):C[r]=i,e[r]&&(e.jsonpCallback=t.jsonpCallback,zt.push(r)),o&&m(i)&&i(o[0]),o=i=void 0}),"script"}),y.createHTMLDocument=((_t=E.implementation.createHTMLDocument("").body).innerHTML="<form></form><form></form>",2===_t.childNodes.length),S.parseHTML=function(e,t,n){return"string"!=typeof e?[]:("boolean"==typeof t&&(n=t,t=!1),t||(y.createHTMLDocument?((r=(t=E.implementation.createHTMLDocument("")).createElement("base")).href=E.location.href,t.head.appendChild(r)):t=E),o=!n&&[],(i=N.exec(e))?[t.createElement(i[1])]:(i=xe([e],t,o),o&&o.length&&S(o).remove(),S.merge([],i.childNodes)));var r,i,o},S.fn.load=function(e,t,n){var r,i,o,a=this,s=e.indexOf(" ");return-1<s&&(r=ht(e.slice(s)),e=e.slice(0,s)),m(t)?(n=t,t=void 0):t&&"object"==typeof t&&(i="POST"),0<a.length&&S.ajax({url:e,type:i||"GET",dataType:"html",data:t}).done(function(e){o=arguments,a.html(r?S("<div>").append(S.parseHTML(e)).find(r):e)}).always(n&&function(e,t){a.each(function(){n.apply(this,o||[e.responseText,t,e])})}),this},S.expr.pseudos.animated=function(t){return S.grep(S.timers,function(e){return t===e.elem}).length},S.offset={setOffset:function(e,t,n){var r,i,o,a,s,u,l=S.css(e,"position"),c=S(e),f={};"static"===l&&(e.style.position="relative"),s=c.offset(),o=S.css(e,"top"),u=S.css(e,"left"),("absolute"===l||"fixed"===l)&&-1<(o+u).indexOf("auto")?(a=(r=c.position()).top,i=r.left):(a=parseFloat(o)||0,i=parseFloat(u)||0),m(t)&&(t=t.call(e,n,S.extend({},s))),null!=t.top&&(f.top=t.top-s.top+a),null!=t.left&&(f.left=t.left-s.left+i),"using"in t?t.using.call(e,f):c.css(f)}},S.fn.extend({offset:function(t){if(arguments.length)return void 0===t?this:this.each(function(e){S.offset.setOffset(this,t,e)});var e,n,r=this[0];return r?r.getClientRects().length?(e=r.getBoundingClientRect(),n=r.ownerDocument.defaultView,{top:e.top+n.pageYOffset,left:e.left+n.pageXOffset}):{top:0,left:0}:void 0},position:function(){if(this[0]){var e,t,n,r=this[0],i={top:0,left:0};if("fixed"===S.css(r,"position"))t=r.getBoundingClientRect();else{t=this.offset(),n=r.ownerDocument,e=r.offsetParent||n.documentElement;while(e&&(e===n.body||e===n.documentElement)&&"static"===S.css(e,"position"))e=e.parentNode;e&&e!==r&&1===e.nodeType&&((i=S(e).offset()).top+=S.css(e,"borderTopWidth",!0),i.left+=S.css(e,"borderLeftWidth",!0))}return{top:t.top-i.top-S.css(r,"marginTop",!0),left:t.left-i.left-S.css(r,"marginLeft",!0)}}},offsetParent:function(){return this.map(function(){var e=this.offsetParent;while(e&&"static"===S.css(e,"position"))e=e.offsetParent;return e||re})}}),S.each({scrollLeft:"pageXOffset",scrollTop:"pageYOffset"},function(t,i){var o="pageYOffset"===i;S.fn[t]=function(e){return $(this,function(e,t,n){var r;if(x(e)?r=e:9===e.nodeType&&(r=e.defaultView),void 0===n)return r?r[i]:e[t];r?r.scrollTo(o?r.pageXOffset:n,o?n:r.pageYOffset):e[t]=n},t,e,arguments.length)}}),S.each(["top","left"],function(e,n){S.cssHooks[n]=Fe(y.pixelPosition,function(e,t){if(t)return t=We(e,n),Pe.test(t)?S(e).position()[n]+"px":t})}),S.each({Height:"height",Width:"width"},function(a,s){S.each({padding:"inner"+a,content:s,"":"outer"+a},function(r,o){S.fn[o]=function(e,t){var n=arguments.length&&(r||"boolean"!=typeof e),i=r||(!0===e||!0===t?"margin":"border");return $(this,function(e,t,n){var r;return x(e)?0===o.indexOf("outer")?e["inner"+a]:e.document.documentElement["client"+a]:9===e.nodeType?(r=e.documentElement,Math.max(e.body["scroll"+a],r["scroll"+a],e.body["offset"+a],r["offset"+a],r["client"+a])):void 0===n?S.css(e,t,i):S.style(e,t,n,i)},s,n?e:void 0,n)}})}),S.each(["ajaxStart","ajaxStop","ajaxComplete","ajaxError","ajaxSuccess","ajaxSend"],function(e,t){S.fn[t]=function(e){return this.on(t,e)}}),S.fn.extend({bind:function(e,t,n){return this.on(e,null,t,n)},unbind:function(e,t){return this.off(e,null,t)},delegate:function(e,t,n,r){return this.on(t,e,n,r)},undelegate:function(e,t,n){return 1===arguments.length?this.off(e,"**"):this.off(t,e||"**",n)},hover:function(e,t){return this.mouseenter(e).mouseleave(t||e)}}),S.each("blur focus focusin focusout resize scroll click dblclick mousedown mouseup mousemove mouseover mouseout mouseenter mouseleave change select submit keydown keypress keyup contextmenu".split(" "),function(e,n){S.fn[n]=function(e,t){return 0<arguments.length?this.on(n,null,e,t):this.trigger(n)}});var Xt=/^[\s\uFEFF\xA0]+|[\s\uFEFF\xA0]+$/g;S.proxy=function(e,t){var n,r,i;if("string"==typeof t&&(n=e[t],t=e,e=n),m(e))return r=s.call(arguments,2),(i=function(){return e.apply(t||this,r.concat(s.call(arguments)))}).guid=e.guid=e.guid||S.guid++,i},S.holdReady=function(e){e?S.readyWait++:S.ready(!0)},S.isArray=Array.isArray,S.parseJSON=JSON.parse,S.nodeName=A,S.isFunction=m,S.isWindow=x,S.camelCase=X,S.type=w,S.now=Date.now,S.isNumeric=function(e){var t=S.type(e);return("number"===t||"string"===t)&&!isNaN(e-parseFloat(e))},S.trim=function(e){return null==e?"":(e+"").replace(Xt,"")},"function"==typeof define&&define.amd&&define("jquery",[],function(){return S});var Vt=C.jQuery,Gt=C.$;return S.noConflict=function(e){return C.$===S&&(C.$=Gt),e&&C.jQuery===S&&(C.jQuery=Vt),S},"undefined"==typeof e&&(C.jQuery=C.$=S),S}); +/*! jQuery UI - v1.13.2 - 2022-08-01 +* http://jqueryui.com +* Includes: widget.js, position.js, data.js, disable-selection.js, focusable.js, form-reset-mixin.js, jquery-patch.js, keycode.js, labels.js, scroll-parent.js, tabbable.js, unique-id.js, widgets/resizable.js, widgets/mouse.js +* Copyright jQuery Foundation and other contributors; Licensed MIT */ + +!function(t){"use strict";"function"==typeof define&&define.amd?define(["jquery"],t):t(jQuery)}(function(y){"use strict";y.ui=y.ui||{};y.ui.version="1.13.2";var n,i=0,h=Array.prototype.hasOwnProperty,a=Array.prototype.slice;y.cleanData=(n=y.cleanData,function(t){for(var e,i,s=0;null!=(i=t[s]);s++)(e=y._data(i,"events"))&&e.remove&&y(i).triggerHandler("remove");n(t)}),y.widget=function(t,i,e){var s,n,o,h={},a=t.split(".")[0],r=a+"-"+(t=t.split(".")[1]);return e||(e=i,i=y.Widget),Array.isArray(e)&&(e=y.extend.apply(null,[{}].concat(e))),y.expr.pseudos[r.toLowerCase()]=function(t){return!!y.data(t,r)},y[a]=y[a]||{},s=y[a][t],n=y[a][t]=function(t,e){if(!this||!this._createWidget)return new n(t,e);arguments.length&&this._createWidget(t,e)},y.extend(n,s,{version:e.version,_proto:y.extend({},e),_childConstructors:[]}),(o=new i).options=y.widget.extend({},o.options),y.each(e,function(e,s){function n(){return i.prototype[e].apply(this,arguments)}function o(t){return i.prototype[e].apply(this,t)}h[e]="function"==typeof s?function(){var t,e=this._super,i=this._superApply;return this._super=n,this._superApply=o,t=s.apply(this,arguments),this._super=e,this._superApply=i,t}:s}),n.prototype=y.widget.extend(o,{widgetEventPrefix:s&&o.widgetEventPrefix||t},h,{constructor:n,namespace:a,widgetName:t,widgetFullName:r}),s?(y.each(s._childConstructors,function(t,e){var i=e.prototype;y.widget(i.namespace+"."+i.widgetName,n,e._proto)}),delete s._childConstructors):i._childConstructors.push(n),y.widget.bridge(t,n),n},y.widget.extend=function(t){for(var e,i,s=a.call(arguments,1),n=0,o=s.length;n<o;n++)for(e in s[n])i=s[n][e],h.call(s[n],e)&&void 0!==i&&(y.isPlainObject(i)?t[e]=y.isPlainObject(t[e])?y.widget.extend({},t[e],i):y.widget.extend({},i):t[e]=i);return t},y.widget.bridge=function(o,e){var h=e.prototype.widgetFullName||o;y.fn[o]=function(i){var t="string"==typeof i,s=a.call(arguments,1),n=this;return t?this.length||"instance"!==i?this.each(function(){var t,e=y.data(this,h);return"instance"===i?(n=e,!1):e?"function"!=typeof e[i]||"_"===i.charAt(0)?y.error("no such method '"+i+"' for "+o+" widget instance"):(t=e[i].apply(e,s))!==e&&void 0!==t?(n=t&&t.jquery?n.pushStack(t.get()):t,!1):void 0:y.error("cannot call methods on "+o+" prior to initialization; attempted to call method '"+i+"'")}):n=void 0:(s.length&&(i=y.widget.extend.apply(null,[i].concat(s))),this.each(function(){var t=y.data(this,h);t?(t.option(i||{}),t._init&&t._init()):y.data(this,h,new e(i,this))})),n}},y.Widget=function(){},y.Widget._childConstructors=[],y.Widget.prototype={widgetName:"widget",widgetEventPrefix:"",defaultElement:"<div>",options:{classes:{},disabled:!1,create:null},_createWidget:function(t,e){e=y(e||this.defaultElement||this)[0],this.element=y(e),this.uuid=i++,this.eventNamespace="."+this.widgetName+this.uuid,this.bindings=y(),this.hoverable=y(),this.focusable=y(),this.classesElementLookup={},e!==this&&(y.data(e,this.widgetFullName,this),this._on(!0,this.element,{remove:function(t){t.target===e&&this.destroy()}}),this.document=y(e.style?e.ownerDocument:e.document||e),this.window=y(this.document[0].defaultView||this.document[0].parentWindow)),this.options=y.widget.extend({},this.options,this._getCreateOptions(),t),this._create(),this.options.disabled&&this._setOptionDisabled(this.options.disabled),this._trigger("create",null,this._getCreateEventData()),this._init()},_getCreateOptions:function(){return{}},_getCreateEventData:y.noop,_create:y.noop,_init:y.noop,destroy:function(){var i=this;this._destroy(),y.each(this.classesElementLookup,function(t,e){i._removeClass(e,t)}),this.element.off(this.eventNamespace).removeData(this.widgetFullName),this.widget().off(this.eventNamespace).removeAttr("aria-disabled"),this.bindings.off(this.eventNamespace)},_destroy:y.noop,widget:function(){return this.element},option:function(t,e){var i,s,n,o=t;if(0===arguments.length)return y.widget.extend({},this.options);if("string"==typeof t)if(o={},t=(i=t.split(".")).shift(),i.length){for(s=o[t]=y.widget.extend({},this.options[t]),n=0;n<i.length-1;n++)s[i[n]]=s[i[n]]||{},s=s[i[n]];if(t=i.pop(),1===arguments.length)return void 0===s[t]?null:s[t];s[t]=e}else{if(1===arguments.length)return void 0===this.options[t]?null:this.options[t];o[t]=e}return this._setOptions(o),this},_setOptions:function(t){for(var e in t)this._setOption(e,t[e]);return this},_setOption:function(t,e){return"classes"===t&&this._setOptionClasses(e),this.options[t]=e,"disabled"===t&&this._setOptionDisabled(e),this},_setOptionClasses:function(t){var e,i,s;for(e in t)s=this.classesElementLookup[e],t[e]!==this.options.classes[e]&&s&&s.length&&(i=y(s.get()),this._removeClass(s,e),i.addClass(this._classes({element:i,keys:e,classes:t,add:!0})))},_setOptionDisabled:function(t){this._toggleClass(this.widget(),this.widgetFullName+"-disabled",null,!!t),t&&(this._removeClass(this.hoverable,null,"ui-state-hover"),this._removeClass(this.focusable,null,"ui-state-focus"))},enable:function(){return this._setOptions({disabled:!1})},disable:function(){return this._setOptions({disabled:!0})},_classes:function(n){var o=[],h=this;function t(t,e){for(var i,s=0;s<t.length;s++)i=h.classesElementLookup[t[s]]||y(),i=n.add?(function(){var i=[];n.element.each(function(t,e){y.map(h.classesElementLookup,function(t){return t}).some(function(t){return t.is(e)})||i.push(e)}),h._on(y(i),{remove:"_untrackClassesElement"})}(),y(y.uniqueSort(i.get().concat(n.element.get())))):y(i.not(n.element).get()),h.classesElementLookup[t[s]]=i,o.push(t[s]),e&&n.classes[t[s]]&&o.push(n.classes[t[s]])}return(n=y.extend({element:this.element,classes:this.options.classes||{}},n)).keys&&t(n.keys.match(/\S+/g)||[],!0),n.extra&&t(n.extra.match(/\S+/g)||[]),o.join(" ")},_untrackClassesElement:function(i){var s=this;y.each(s.classesElementLookup,function(t,e){-1!==y.inArray(i.target,e)&&(s.classesElementLookup[t]=y(e.not(i.target).get()))}),this._off(y(i.target))},_removeClass:function(t,e,i){return this._toggleClass(t,e,i,!1)},_addClass:function(t,e,i){return this._toggleClass(t,e,i,!0)},_toggleClass:function(t,e,i,s){var n="string"==typeof t||null===t,i={extra:n?e:i,keys:n?t:e,element:n?this.element:t,add:s="boolean"==typeof s?s:i};return i.element.toggleClass(this._classes(i),s),this},_on:function(n,o,t){var h,a=this;"boolean"!=typeof n&&(t=o,o=n,n=!1),t?(o=h=y(o),this.bindings=this.bindings.add(o)):(t=o,o=this.element,h=this.widget()),y.each(t,function(t,e){function i(){if(n||!0!==a.options.disabled&&!y(this).hasClass("ui-state-disabled"))return("string"==typeof e?a[e]:e).apply(a,arguments)}"string"!=typeof e&&(i.guid=e.guid=e.guid||i.guid||y.guid++);var s=t.match(/^([\w:-]*)\s*(.*)$/),t=s[1]+a.eventNamespace,s=s[2];s?h.on(t,s,i):o.on(t,i)})},_off:function(t,e){e=(e||"").split(" ").join(this.eventNamespace+" ")+this.eventNamespace,t.off(e),this.bindings=y(this.bindings.not(t).get()),this.focusable=y(this.focusable.not(t).get()),this.hoverable=y(this.hoverable.not(t).get())},_delay:function(t,e){var i=this;return setTimeout(function(){return("string"==typeof t?i[t]:t).apply(i,arguments)},e||0)},_hoverable:function(t){this.hoverable=this.hoverable.add(t),this._on(t,{mouseenter:function(t){this._addClass(y(t.currentTarget),null,"ui-state-hover")},mouseleave:function(t){this._removeClass(y(t.currentTarget),null,"ui-state-hover")}})},_focusable:function(t){this.focusable=this.focusable.add(t),this._on(t,{focusin:function(t){this._addClass(y(t.currentTarget),null,"ui-state-focus")},focusout:function(t){this._removeClass(y(t.currentTarget),null,"ui-state-focus")}})},_trigger:function(t,e,i){var s,n,o=this.options[t];if(i=i||{},(e=y.Event(e)).type=(t===this.widgetEventPrefix?t:this.widgetEventPrefix+t).toLowerCase(),e.target=this.element[0],n=e.originalEvent)for(s in n)s in e||(e[s]=n[s]);return this.element.trigger(e,i),!("function"==typeof o&&!1===o.apply(this.element[0],[e].concat(i))||e.isDefaultPrevented())}},y.each({show:"fadeIn",hide:"fadeOut"},function(o,h){y.Widget.prototype["_"+o]=function(e,t,i){var s,n=(t="string"==typeof t?{effect:t}:t)?!0!==t&&"number"!=typeof t&&t.effect||h:o;"number"==typeof(t=t||{})?t={duration:t}:!0===t&&(t={}),s=!y.isEmptyObject(t),t.complete=i,t.delay&&e.delay(t.delay),s&&y.effects&&y.effects.effect[n]?e[o](t):n!==o&&e[n]?e[n](t.duration,t.easing,i):e.queue(function(t){y(this)[o](),i&&i.call(e[0]),t()})}});var s,x,D,o,r,l,u,p,W;y.widget;function E(t,e,i){return[parseFloat(t[0])*(p.test(t[0])?e/100:1),parseFloat(t[1])*(p.test(t[1])?i/100:1)]}function H(t,e){return parseInt(y.css(t,e),10)||0}function S(t){return null!=t&&t===t.window}x=Math.max,D=Math.abs,o=/left|center|right/,r=/top|center|bottom/,l=/[\+\-]\d+(\.[\d]+)?%?/,u=/^\w+/,p=/%$/,W=y.fn.position,y.position={scrollbarWidth:function(){if(void 0!==s)return s;var t,e=y("<div style='display:block;position:absolute;width:200px;height:200px;overflow:hidden;'><div style='height:300px;width:auto;'></div></div>"),i=e.children()[0];return y("body").append(e),t=i.offsetWidth,e.css("overflow","scroll"),t===(i=i.offsetWidth)&&(i=e[0].clientWidth),e.remove(),s=t-i},getScrollInfo:function(t){var e=t.isWindow||t.isDocument?"":t.element.css("overflow-x"),i=t.isWindow||t.isDocument?"":t.element.css("overflow-y"),e="scroll"===e||"auto"===e&&t.width<t.element[0].scrollWidth;return{width:"scroll"===i||"auto"===i&&t.height<t.element[0].scrollHeight?y.position.scrollbarWidth():0,height:e?y.position.scrollbarWidth():0}},getWithinInfo:function(t){var e=y(t||window),i=S(e[0]),s=!!e[0]&&9===e[0].nodeType;return{element:e,isWindow:i,isDocument:s,offset:!i&&!s?y(t).offset():{left:0,top:0},scrollLeft:e.scrollLeft(),scrollTop:e.scrollTop(),width:e.outerWidth(),height:e.outerHeight()}}},y.fn.position=function(p){if(!p||!p.of)return W.apply(this,arguments);var d,c,f,g,m,t,_="string"==typeof(p=y.extend({},p)).of?y(document).find(p.of):y(p.of),w=y.position.getWithinInfo(p.within),v=y.position.getScrollInfo(w),b=(p.collision||"flip").split(" "),z={},e=9===(t=(e=_)[0]).nodeType?{width:e.width(),height:e.height(),offset:{top:0,left:0}}:S(t)?{width:e.width(),height:e.height(),offset:{top:e.scrollTop(),left:e.scrollLeft()}}:t.preventDefault?{width:0,height:0,offset:{top:t.pageY,left:t.pageX}}:{width:e.outerWidth(),height:e.outerHeight(),offset:e.offset()};return _[0].preventDefault&&(p.at="left top"),c=e.width,f=e.height,m=y.extend({},g=e.offset),y.each(["my","at"],function(){var t,e,i=(p[this]||"").split(" ");(i=1===i.length?o.test(i[0])?i.concat(["center"]):r.test(i[0])?["center"].concat(i):["center","center"]:i)[0]=o.test(i[0])?i[0]:"center",i[1]=r.test(i[1])?i[1]:"center",t=l.exec(i[0]),e=l.exec(i[1]),z[this]=[t?t[0]:0,e?e[0]:0],p[this]=[u.exec(i[0])[0],u.exec(i[1])[0]]}),1===b.length&&(b[1]=b[0]),"right"===p.at[0]?m.left+=c:"center"===p.at[0]&&(m.left+=c/2),"bottom"===p.at[1]?m.top+=f:"center"===p.at[1]&&(m.top+=f/2),d=E(z.at,c,f),m.left+=d[0],m.top+=d[1],this.each(function(){var i,t,h=y(this),a=h.outerWidth(),r=h.outerHeight(),e=H(this,"marginLeft"),s=H(this,"marginTop"),n=a+e+H(this,"marginRight")+v.width,o=r+s+H(this,"marginBottom")+v.height,l=y.extend({},m),u=E(z.my,h.outerWidth(),h.outerHeight());"right"===p.my[0]?l.left-=a:"center"===p.my[0]&&(l.left-=a/2),"bottom"===p.my[1]?l.top-=r:"center"===p.my[1]&&(l.top-=r/2),l.left+=u[0],l.top+=u[1],i={marginLeft:e,marginTop:s},y.each(["left","top"],function(t,e){y.ui.position[b[t]]&&y.ui.position[b[t]][e](l,{targetWidth:c,targetHeight:f,elemWidth:a,elemHeight:r,collisionPosition:i,collisionWidth:n,collisionHeight:o,offset:[d[0]+u[0],d[1]+u[1]],my:p.my,at:p.at,within:w,elem:h})}),p.using&&(t=function(t){var e=g.left-l.left,i=e+c-a,s=g.top-l.top,n=s+f-r,o={target:{element:_,left:g.left,top:g.top,width:c,height:f},element:{element:h,left:l.left,top:l.top,width:a,height:r},horizontal:i<0?"left":0<e?"right":"center",vertical:n<0?"top":0<s?"bottom":"middle"};c<a&&D(e+i)<c&&(o.horizontal="center"),f<r&&D(s+n)<f&&(o.vertical="middle"),x(D(e),D(i))>x(D(s),D(n))?o.important="horizontal":o.important="vertical",p.using.call(this,t,o)}),h.offset(y.extend(l,{using:t}))})},y.ui.position={fit:{left:function(t,e){var i=e.within,s=i.isWindow?i.scrollLeft:i.offset.left,n=i.width,o=t.left-e.collisionPosition.marginLeft,h=s-o,a=o+e.collisionWidth-n-s;e.collisionWidth>n?0<h&&a<=0?(i=t.left+h+e.collisionWidth-n-s,t.left+=h-i):t.left=!(0<a&&h<=0)&&a<h?s+n-e.collisionWidth:s:0<h?t.left+=h:0<a?t.left-=a:t.left=x(t.left-o,t.left)},top:function(t,e){var i=e.within,s=i.isWindow?i.scrollTop:i.offset.top,n=e.within.height,o=t.top-e.collisionPosition.marginTop,h=s-o,a=o+e.collisionHeight-n-s;e.collisionHeight>n?0<h&&a<=0?(i=t.top+h+e.collisionHeight-n-s,t.top+=h-i):t.top=!(0<a&&h<=0)&&a<h?s+n-e.collisionHeight:s:0<h?t.top+=h:0<a?t.top-=a:t.top=x(t.top-o,t.top)}},flip:{left:function(t,e){var i=e.within,s=i.offset.left+i.scrollLeft,n=i.width,o=i.isWindow?i.scrollLeft:i.offset.left,h=t.left-e.collisionPosition.marginLeft,a=h-o,r=h+e.collisionWidth-n-o,l="left"===e.my[0]?-e.elemWidth:"right"===e.my[0]?e.elemWidth:0,i="left"===e.at[0]?e.targetWidth:"right"===e.at[0]?-e.targetWidth:0,h=-2*e.offset[0];a<0?((s=t.left+l+i+h+e.collisionWidth-n-s)<0||s<D(a))&&(t.left+=l+i+h):0<r&&(0<(o=t.left-e.collisionPosition.marginLeft+l+i+h-o)||D(o)<r)&&(t.left+=l+i+h)},top:function(t,e){var i=e.within,s=i.offset.top+i.scrollTop,n=i.height,o=i.isWindow?i.scrollTop:i.offset.top,h=t.top-e.collisionPosition.marginTop,a=h-o,r=h+e.collisionHeight-n-o,l="top"===e.my[1]?-e.elemHeight:"bottom"===e.my[1]?e.elemHeight:0,i="top"===e.at[1]?e.targetHeight:"bottom"===e.at[1]?-e.targetHeight:0,h=-2*e.offset[1];a<0?((s=t.top+l+i+h+e.collisionHeight-n-s)<0||s<D(a))&&(t.top+=l+i+h):0<r&&(0<(o=t.top-e.collisionPosition.marginTop+l+i+h-o)||D(o)<r)&&(t.top+=l+i+h)}},flipfit:{left:function(){y.ui.position.flip.left.apply(this,arguments),y.ui.position.fit.left.apply(this,arguments)},top:function(){y.ui.position.flip.top.apply(this,arguments),y.ui.position.fit.top.apply(this,arguments)}}};var t;y.ui.position,y.extend(y.expr.pseudos,{data:y.expr.createPseudo?y.expr.createPseudo(function(e){return function(t){return!!y.data(t,e)}}):function(t,e,i){return!!y.data(t,i[3])}}),y.fn.extend({disableSelection:(t="onselectstart"in document.createElement("div")?"selectstart":"mousedown",function(){return this.on(t+".ui-disableSelection",function(t){t.preventDefault()})}),enableSelection:function(){return this.off(".ui-disableSelection")}});y.ui.focusable=function(t,e){var i,s,n,o,h=t.nodeName.toLowerCase();return"area"===h?(s=(i=t.parentNode).name,!(!t.href||!s||"map"!==i.nodeName.toLowerCase())&&(0<(s=y("img[usemap='#"+s+"']")).length&&s.is(":visible"))):(/^(input|select|textarea|button|object)$/.test(h)?(n=!t.disabled)&&(o=y(t).closest("fieldset")[0])&&(n=!o.disabled):n="a"===h&&t.href||e,n&&y(t).is(":visible")&&function(t){var e=t.css("visibility");for(;"inherit"===e;)t=t.parent(),e=t.css("visibility");return"visible"===e}(y(t)))},y.extend(y.expr.pseudos,{focusable:function(t){return y.ui.focusable(t,null!=y.attr(t,"tabindex"))}});var e,d;y.ui.focusable,y.fn._form=function(){return"string"==typeof this[0].form?this.closest("form"):y(this[0].form)},y.ui.formResetMixin={_formResetHandler:function(){var e=y(this);setTimeout(function(){var t=e.data("ui-form-reset-instances");y.each(t,function(){this.refresh()})})},_bindFormResetHandler:function(){var t;this.form=this.element._form(),this.form.length&&((t=this.form.data("ui-form-reset-instances")||[]).length||this.form.on("reset.ui-form-reset",this._formResetHandler),t.push(this),this.form.data("ui-form-reset-instances",t))},_unbindFormResetHandler:function(){var t;this.form.length&&((t=this.form.data("ui-form-reset-instances")).splice(y.inArray(this,t),1),t.length?this.form.data("ui-form-reset-instances",t):this.form.removeData("ui-form-reset-instances").off("reset.ui-form-reset"))}};y.expr.pseudos||(y.expr.pseudos=y.expr[":"]),y.uniqueSort||(y.uniqueSort=y.unique),y.escapeSelector||(e=/([\0-\x1f\x7f]|^-?\d)|^-$|[^\x80-\uFFFF\w-]/g,d=function(t,e){return e?"\0"===t?"�":t.slice(0,-1)+"\\"+t.charCodeAt(t.length-1).toString(16)+" ":"\\"+t},y.escapeSelector=function(t){return(t+"").replace(e,d)}),y.fn.even&&y.fn.odd||y.fn.extend({even:function(){return this.filter(function(t){return t%2==0})},odd:function(){return this.filter(function(t){return t%2==1})}});y.ui.keyCode={BACKSPACE:8,COMMA:188,DELETE:46,DOWN:40,END:35,ENTER:13,ESCAPE:27,HOME:36,LEFT:37,PAGE_DOWN:34,PAGE_UP:33,PERIOD:190,RIGHT:39,SPACE:32,TAB:9,UP:38},y.fn.labels=function(){var t,e,i;return this.length?this[0].labels&&this[0].labels.length?this.pushStack(this[0].labels):(e=this.eq(0).parents("label"),(t=this.attr("id"))&&(i=(i=this.eq(0).parents().last()).add((i.length?i:this).siblings()),t="label[for='"+y.escapeSelector(t)+"']",e=e.add(i.find(t).addBack(t))),this.pushStack(e)):this.pushStack([])},y.fn.scrollParent=function(t){var e=this.css("position"),i="absolute"===e,s=t?/(auto|scroll|hidden)/:/(auto|scroll)/,t=this.parents().filter(function(){var t=y(this);return(!i||"static"!==t.css("position"))&&s.test(t.css("overflow")+t.css("overflow-y")+t.css("overflow-x"))}).eq(0);return"fixed"!==e&&t.length?t:y(this[0].ownerDocument||document)},y.extend(y.expr.pseudos,{tabbable:function(t){var e=y.attr(t,"tabindex"),i=null!=e;return(!i||0<=e)&&y.ui.focusable(t,i)}}),y.fn.extend({uniqueId:(c=0,function(){return this.each(function(){this.id||(this.id="ui-id-"+ ++c)})}),removeUniqueId:function(){return this.each(function(){/^ui-id-\d+$/.test(this.id)&&y(this).removeAttr("id")})}}),y.ui.ie=!!/msie [\w.]+/.exec(navigator.userAgent.toLowerCase());var c,f=!1;y(document).on("mouseup",function(){f=!1});y.widget("ui.mouse",{version:"1.13.2",options:{cancel:"input, textarea, button, select, option",distance:1,delay:0},_mouseInit:function(){var e=this;this.element.on("mousedown."+this.widgetName,function(t){return e._mouseDown(t)}).on("click."+this.widgetName,function(t){if(!0===y.data(t.target,e.widgetName+".preventClickEvent"))return y.removeData(t.target,e.widgetName+".preventClickEvent"),t.stopImmediatePropagation(),!1}),this.started=!1},_mouseDestroy:function(){this.element.off("."+this.widgetName),this._mouseMoveDelegate&&this.document.off("mousemove."+this.widgetName,this._mouseMoveDelegate).off("mouseup."+this.widgetName,this._mouseUpDelegate)},_mouseDown:function(t){if(!f){this._mouseMoved=!1,this._mouseStarted&&this._mouseUp(t),this._mouseDownEvent=t;var e=this,i=1===t.which,s=!("string"!=typeof this.options.cancel||!t.target.nodeName)&&y(t.target).closest(this.options.cancel).length;return i&&!s&&this._mouseCapture(t)?(this.mouseDelayMet=!this.options.delay,this.mouseDelayMet||(this._mouseDelayTimer=setTimeout(function(){e.mouseDelayMet=!0},this.options.delay)),this._mouseDistanceMet(t)&&this._mouseDelayMet(t)&&(this._mouseStarted=!1!==this._mouseStart(t),!this._mouseStarted)?(t.preventDefault(),!0):(!0===y.data(t.target,this.widgetName+".preventClickEvent")&&y.removeData(t.target,this.widgetName+".preventClickEvent"),this._mouseMoveDelegate=function(t){return e._mouseMove(t)},this._mouseUpDelegate=function(t){return e._mouseUp(t)},this.document.on("mousemove."+this.widgetName,this._mouseMoveDelegate).on("mouseup."+this.widgetName,this._mouseUpDelegate),t.preventDefault(),f=!0)):!0}},_mouseMove:function(t){if(this._mouseMoved){if(y.ui.ie&&(!document.documentMode||document.documentMode<9)&&!t.button)return this._mouseUp(t);if(!t.which)if(t.originalEvent.altKey||t.originalEvent.ctrlKey||t.originalEvent.metaKey||t.originalEvent.shiftKey)this.ignoreMissingWhich=!0;else if(!this.ignoreMissingWhich)return this._mouseUp(t)}return(t.which||t.button)&&(this._mouseMoved=!0),this._mouseStarted?(this._mouseDrag(t),t.preventDefault()):(this._mouseDistanceMet(t)&&this._mouseDelayMet(t)&&(this._mouseStarted=!1!==this._mouseStart(this._mouseDownEvent,t),this._mouseStarted?this._mouseDrag(t):this._mouseUp(t)),!this._mouseStarted)},_mouseUp:function(t){this.document.off("mousemove."+this.widgetName,this._mouseMoveDelegate).off("mouseup."+this.widgetName,this._mouseUpDelegate),this._mouseStarted&&(this._mouseStarted=!1,t.target===this._mouseDownEvent.target&&y.data(t.target,this.widgetName+".preventClickEvent",!0),this._mouseStop(t)),this._mouseDelayTimer&&(clearTimeout(this._mouseDelayTimer),delete this._mouseDelayTimer),this.ignoreMissingWhich=!1,f=!1,t.preventDefault()},_mouseDistanceMet:function(t){return Math.max(Math.abs(this._mouseDownEvent.pageX-t.pageX),Math.abs(this._mouseDownEvent.pageY-t.pageY))>=this.options.distance},_mouseDelayMet:function(){return this.mouseDelayMet},_mouseStart:function(){},_mouseDrag:function(){},_mouseStop:function(){},_mouseCapture:function(){return!0}}),y.ui.plugin={add:function(t,e,i){var s,n=y.ui[t].prototype;for(s in i)n.plugins[s]=n.plugins[s]||[],n.plugins[s].push([e,i[s]])},call:function(t,e,i,s){var n,o=t.plugins[e];if(o&&(s||t.element[0].parentNode&&11!==t.element[0].parentNode.nodeType))for(n=0;n<o.length;n++)t.options[o[n][0]]&&o[n][1].apply(t.element,i)}};y.widget("ui.resizable",y.ui.mouse,{version:"1.13.2",widgetEventPrefix:"resize",options:{alsoResize:!1,animate:!1,animateDuration:"slow",animateEasing:"swing",aspectRatio:!1,autoHide:!1,classes:{"ui-resizable-se":"ui-icon ui-icon-gripsmall-diagonal-se"},containment:!1,ghost:!1,grid:!1,handles:"e,s,se",helper:!1,maxHeight:null,maxWidth:null,minHeight:10,minWidth:10,zIndex:90,resize:null,start:null,stop:null},_num:function(t){return parseFloat(t)||0},_isNumber:function(t){return!isNaN(parseFloat(t))},_hasScroll:function(t,e){if("hidden"===y(t).css("overflow"))return!1;var i=e&&"left"===e?"scrollLeft":"scrollTop",e=!1;if(0<t[i])return!0;try{t[i]=1,e=0<t[i],t[i]=0}catch(t){}return e},_create:function(){var t,e=this.options,i=this;this._addClass("ui-resizable"),y.extend(this,{_aspectRatio:!!e.aspectRatio,aspectRatio:e.aspectRatio,originalElement:this.element,_proportionallyResizeElements:[],_helper:e.helper||e.ghost||e.animate?e.helper||"ui-resizable-helper":null}),this.element[0].nodeName.match(/^(canvas|textarea|input|select|button|img)$/i)&&(this.element.wrap(y("<div class='ui-wrapper'></div>").css({overflow:"hidden",position:this.element.css("position"),width:this.element.outerWidth(),height:this.element.outerHeight(),top:this.element.css("top"),left:this.element.css("left")})),this.element=this.element.parent().data("ui-resizable",this.element.resizable("instance")),this.elementIsWrapper=!0,t={marginTop:this.originalElement.css("marginTop"),marginRight:this.originalElement.css("marginRight"),marginBottom:this.originalElement.css("marginBottom"),marginLeft:this.originalElement.css("marginLeft")},this.element.css(t),this.originalElement.css("margin",0),this.originalResizeStyle=this.originalElement.css("resize"),this.originalElement.css("resize","none"),this._proportionallyResizeElements.push(this.originalElement.css({position:"static",zoom:1,display:"block"})),this.originalElement.css(t),this._proportionallyResize()),this._setupHandles(),e.autoHide&&y(this.element).on("mouseenter",function(){e.disabled||(i._removeClass("ui-resizable-autohide"),i._handles.show())}).on("mouseleave",function(){e.disabled||i.resizing||(i._addClass("ui-resizable-autohide"),i._handles.hide())}),this._mouseInit()},_destroy:function(){this._mouseDestroy(),this._addedHandles.remove();function t(t){y(t).removeData("resizable").removeData("ui-resizable").off(".resizable")}var e;return this.elementIsWrapper&&(t(this.element),e=this.element,this.originalElement.css({position:e.css("position"),width:e.outerWidth(),height:e.outerHeight(),top:e.css("top"),left:e.css("left")}).insertAfter(e),e.remove()),this.originalElement.css("resize",this.originalResizeStyle),t(this.originalElement),this},_setOption:function(t,e){switch(this._super(t,e),t){case"handles":this._removeHandles(),this._setupHandles();break;case"aspectRatio":this._aspectRatio=!!e}},_setupHandles:function(){var t,e,i,s,n,o=this.options,h=this;if(this.handles=o.handles||(y(".ui-resizable-handle",this.element).length?{n:".ui-resizable-n",e:".ui-resizable-e",s:".ui-resizable-s",w:".ui-resizable-w",se:".ui-resizable-se",sw:".ui-resizable-sw",ne:".ui-resizable-ne",nw:".ui-resizable-nw"}:"e,s,se"),this._handles=y(),this._addedHandles=y(),this.handles.constructor===String)for("all"===this.handles&&(this.handles="n,e,s,w,se,sw,ne,nw"),i=this.handles.split(","),this.handles={},e=0;e<i.length;e++)s="ui-resizable-"+(t=String.prototype.trim.call(i[e])),n=y("<div>"),this._addClass(n,"ui-resizable-handle "+s),n.css({zIndex:o.zIndex}),this.handles[t]=".ui-resizable-"+t,this.element.children(this.handles[t]).length||(this.element.append(n),this._addedHandles=this._addedHandles.add(n));this._renderAxis=function(t){var e,i,s;for(e in t=t||this.element,this.handles)this.handles[e].constructor===String?this.handles[e]=this.element.children(this.handles[e]).first().show():(this.handles[e].jquery||this.handles[e].nodeType)&&(this.handles[e]=y(this.handles[e]),this._on(this.handles[e],{mousedown:h._mouseDown})),this.elementIsWrapper&&this.originalElement[0].nodeName.match(/^(textarea|input|select|button)$/i)&&(i=y(this.handles[e],this.element),s=/sw|ne|nw|se|n|s/.test(e)?i.outerHeight():i.outerWidth(),i=["padding",/ne|nw|n/.test(e)?"Top":/se|sw|s/.test(e)?"Bottom":/^e$/.test(e)?"Right":"Left"].join(""),t.css(i,s),this._proportionallyResize()),this._handles=this._handles.add(this.handles[e])},this._renderAxis(this.element),this._handles=this._handles.add(this.element.find(".ui-resizable-handle")),this._handles.disableSelection(),this._handles.on("mouseover",function(){h.resizing||(this.className&&(n=this.className.match(/ui-resizable-(se|sw|ne|nw|n|e|s|w)/i)),h.axis=n&&n[1]?n[1]:"se")}),o.autoHide&&(this._handles.hide(),this._addClass("ui-resizable-autohide"))},_removeHandles:function(){this._addedHandles.remove()},_mouseCapture:function(t){var e,i,s=!1;for(e in this.handles)(i=y(this.handles[e])[0])!==t.target&&!y.contains(i,t.target)||(s=!0);return!this.options.disabled&&s},_mouseStart:function(t){var e,i,s=this.options,n=this.element;return this.resizing=!0,this._renderProxy(),e=this._num(this.helper.css("left")),i=this._num(this.helper.css("top")),s.containment&&(e+=y(s.containment).scrollLeft()||0,i+=y(s.containment).scrollTop()||0),this.offset=this.helper.offset(),this.position={left:e,top:i},this.size=this._helper?{width:this.helper.width(),height:this.helper.height()}:{width:n.width(),height:n.height()},this.originalSize=this._helper?{width:n.outerWidth(),height:n.outerHeight()}:{width:n.width(),height:n.height()},this.sizeDiff={width:n.outerWidth()-n.width(),height:n.outerHeight()-n.height()},this.originalPosition={left:e,top:i},this.originalMousePosition={left:t.pageX,top:t.pageY},this.aspectRatio="number"==typeof s.aspectRatio?s.aspectRatio:this.originalSize.width/this.originalSize.height||1,s=y(".ui-resizable-"+this.axis).css("cursor"),y("body").css("cursor","auto"===s?this.axis+"-resize":s),this._addClass("ui-resizable-resizing"),this._propagate("start",t),!0},_mouseDrag:function(t){var e=this.originalMousePosition,i=this.axis,s=t.pageX-e.left||0,e=t.pageY-e.top||0,i=this._change[i];return this._updatePrevProperties(),i&&(e=i.apply(this,[t,s,e]),this._updateVirtualBoundaries(t.shiftKey),(this._aspectRatio||t.shiftKey)&&(e=this._updateRatio(e,t)),e=this._respectSize(e,t),this._updateCache(e),this._propagate("resize",t),e=this._applyChanges(),!this._helper&&this._proportionallyResizeElements.length&&this._proportionallyResize(),y.isEmptyObject(e)||(this._updatePrevProperties(),this._trigger("resize",t,this.ui()),this._applyChanges())),!1},_mouseStop:function(t){this.resizing=!1;var e,i,s,n=this.options,o=this;return this._helper&&(s=(e=(i=this._proportionallyResizeElements).length&&/textarea/i.test(i[0].nodeName))&&this._hasScroll(i[0],"left")?0:o.sizeDiff.height,i=e?0:o.sizeDiff.width,e={width:o.helper.width()-i,height:o.helper.height()-s},i=parseFloat(o.element.css("left"))+(o.position.left-o.originalPosition.left)||null,s=parseFloat(o.element.css("top"))+(o.position.top-o.originalPosition.top)||null,n.animate||this.element.css(y.extend(e,{top:s,left:i})),o.helper.height(o.size.height),o.helper.width(o.size.width),this._helper&&!n.animate&&this._proportionallyResize()),y("body").css("cursor","auto"),this._removeClass("ui-resizable-resizing"),this._propagate("stop",t),this._helper&&this.helper.remove(),!1},_updatePrevProperties:function(){this.prevPosition={top:this.position.top,left:this.position.left},this.prevSize={width:this.size.width,height:this.size.height}},_applyChanges:function(){var t={};return this.position.top!==this.prevPosition.top&&(t.top=this.position.top+"px"),this.position.left!==this.prevPosition.left&&(t.left=this.position.left+"px"),this.size.width!==this.prevSize.width&&(t.width=this.size.width+"px"),this.size.height!==this.prevSize.height&&(t.height=this.size.height+"px"),this.helper.css(t),t},_updateVirtualBoundaries:function(t){var e,i,s=this.options,n={minWidth:this._isNumber(s.minWidth)?s.minWidth:0,maxWidth:this._isNumber(s.maxWidth)?s.maxWidth:1/0,minHeight:this._isNumber(s.minHeight)?s.minHeight:0,maxHeight:this._isNumber(s.maxHeight)?s.maxHeight:1/0};(this._aspectRatio||t)&&(e=n.minHeight*this.aspectRatio,i=n.minWidth/this.aspectRatio,s=n.maxHeight*this.aspectRatio,t=n.maxWidth/this.aspectRatio,e>n.minWidth&&(n.minWidth=e),i>n.minHeight&&(n.minHeight=i),s<n.maxWidth&&(n.maxWidth=s),t<n.maxHeight&&(n.maxHeight=t)),this._vBoundaries=n},_updateCache:function(t){this.offset=this.helper.offset(),this._isNumber(t.left)&&(this.position.left=t.left),this._isNumber(t.top)&&(this.position.top=t.top),this._isNumber(t.height)&&(this.size.height=t.height),this._isNumber(t.width)&&(this.size.width=t.width)},_updateRatio:function(t){var e=this.position,i=this.size,s=this.axis;return this._isNumber(t.height)?t.width=t.height*this.aspectRatio:this._isNumber(t.width)&&(t.height=t.width/this.aspectRatio),"sw"===s&&(t.left=e.left+(i.width-t.width),t.top=null),"nw"===s&&(t.top=e.top+(i.height-t.height),t.left=e.left+(i.width-t.width)),t},_respectSize:function(t){var e=this._vBoundaries,i=this.axis,s=this._isNumber(t.width)&&e.maxWidth&&e.maxWidth<t.width,n=this._isNumber(t.height)&&e.maxHeight&&e.maxHeight<t.height,o=this._isNumber(t.width)&&e.minWidth&&e.minWidth>t.width,h=this._isNumber(t.height)&&e.minHeight&&e.minHeight>t.height,a=this.originalPosition.left+this.originalSize.width,r=this.originalPosition.top+this.originalSize.height,l=/sw|nw|w/.test(i),i=/nw|ne|n/.test(i);return o&&(t.width=e.minWidth),h&&(t.height=e.minHeight),s&&(t.width=e.maxWidth),n&&(t.height=e.maxHeight),o&&l&&(t.left=a-e.minWidth),s&&l&&(t.left=a-e.maxWidth),h&&i&&(t.top=r-e.minHeight),n&&i&&(t.top=r-e.maxHeight),t.width||t.height||t.left||!t.top?t.width||t.height||t.top||!t.left||(t.left=null):t.top=null,t},_getPaddingPlusBorderDimensions:function(t){for(var e=0,i=[],s=[t.css("borderTopWidth"),t.css("borderRightWidth"),t.css("borderBottomWidth"),t.css("borderLeftWidth")],n=[t.css("paddingTop"),t.css("paddingRight"),t.css("paddingBottom"),t.css("paddingLeft")];e<4;e++)i[e]=parseFloat(s[e])||0,i[e]+=parseFloat(n[e])||0;return{height:i[0]+i[2],width:i[1]+i[3]}},_proportionallyResize:function(){if(this._proportionallyResizeElements.length)for(var t,e=0,i=this.helper||this.element;e<this._proportionallyResizeElements.length;e++)t=this._proportionallyResizeElements[e],this.outerDimensions||(this.outerDimensions=this._getPaddingPlusBorderDimensions(t)),t.css({height:i.height()-this.outerDimensions.height||0,width:i.width()-this.outerDimensions.width||0})},_renderProxy:function(){var t=this.element,e=this.options;this.elementOffset=t.offset(),this._helper?(this.helper=this.helper||y("<div></div>").css({overflow:"hidden"}),this._addClass(this.helper,this._helper),this.helper.css({width:this.element.outerWidth(),height:this.element.outerHeight(),position:"absolute",left:this.elementOffset.left+"px",top:this.elementOffset.top+"px",zIndex:++e.zIndex}),this.helper.appendTo("body").disableSelection()):this.helper=this.element},_change:{e:function(t,e){return{width:this.originalSize.width+e}},w:function(t,e){var i=this.originalSize;return{left:this.originalPosition.left+e,width:i.width-e}},n:function(t,e,i){var s=this.originalSize;return{top:this.originalPosition.top+i,height:s.height-i}},s:function(t,e,i){return{height:this.originalSize.height+i}},se:function(t,e,i){return y.extend(this._change.s.apply(this,arguments),this._change.e.apply(this,[t,e,i]))},sw:function(t,e,i){return y.extend(this._change.s.apply(this,arguments),this._change.w.apply(this,[t,e,i]))},ne:function(t,e,i){return y.extend(this._change.n.apply(this,arguments),this._change.e.apply(this,[t,e,i]))},nw:function(t,e,i){return y.extend(this._change.n.apply(this,arguments),this._change.w.apply(this,[t,e,i]))}},_propagate:function(t,e){y.ui.plugin.call(this,t,[e,this.ui()]),"resize"!==t&&this._trigger(t,e,this.ui())},plugins:{},ui:function(){return{originalElement:this.originalElement,element:this.element,helper:this.helper,position:this.position,size:this.size,originalSize:this.originalSize,originalPosition:this.originalPosition}}}),y.ui.plugin.add("resizable","animate",{stop:function(e){var i=y(this).resizable("instance"),t=i.options,s=i._proportionallyResizeElements,n=s.length&&/textarea/i.test(s[0].nodeName),o=n&&i._hasScroll(s[0],"left")?0:i.sizeDiff.height,h=n?0:i.sizeDiff.width,n={width:i.size.width-h,height:i.size.height-o},h=parseFloat(i.element.css("left"))+(i.position.left-i.originalPosition.left)||null,o=parseFloat(i.element.css("top"))+(i.position.top-i.originalPosition.top)||null;i.element.animate(y.extend(n,o&&h?{top:o,left:h}:{}),{duration:t.animateDuration,easing:t.animateEasing,step:function(){var t={width:parseFloat(i.element.css("width")),height:parseFloat(i.element.css("height")),top:parseFloat(i.element.css("top")),left:parseFloat(i.element.css("left"))};s&&s.length&&y(s[0]).css({width:t.width,height:t.height}),i._updateCache(t),i._propagate("resize",e)}})}}),y.ui.plugin.add("resizable","containment",{start:function(){var i,s,n=y(this).resizable("instance"),t=n.options,e=n.element,o=t.containment,h=o instanceof y?o.get(0):/parent/.test(o)?e.parent().get(0):o;h&&(n.containerElement=y(h),/document/.test(o)||o===document?(n.containerOffset={left:0,top:0},n.containerPosition={left:0,top:0},n.parentData={element:y(document),left:0,top:0,width:y(document).width(),height:y(document).height()||document.body.parentNode.scrollHeight}):(i=y(h),s=[],y(["Top","Right","Left","Bottom"]).each(function(t,e){s[t]=n._num(i.css("padding"+e))}),n.containerOffset=i.offset(),n.containerPosition=i.position(),n.containerSize={height:i.innerHeight()-s[3],width:i.innerWidth()-s[1]},t=n.containerOffset,e=n.containerSize.height,o=n.containerSize.width,o=n._hasScroll(h,"left")?h.scrollWidth:o,e=n._hasScroll(h)?h.scrollHeight:e,n.parentData={element:h,left:t.left,top:t.top,width:o,height:e}))},resize:function(t){var e=y(this).resizable("instance"),i=e.options,s=e.containerOffset,n=e.position,o=e._aspectRatio||t.shiftKey,h={top:0,left:0},a=e.containerElement,t=!0;a[0]!==document&&/static/.test(a.css("position"))&&(h=s),n.left<(e._helper?s.left:0)&&(e.size.width=e.size.width+(e._helper?e.position.left-s.left:e.position.left-h.left),o&&(e.size.height=e.size.width/e.aspectRatio,t=!1),e.position.left=i.helper?s.left:0),n.top<(e._helper?s.top:0)&&(e.size.height=e.size.height+(e._helper?e.position.top-s.top:e.position.top),o&&(e.size.width=e.size.height*e.aspectRatio,t=!1),e.position.top=e._helper?s.top:0),i=e.containerElement.get(0)===e.element.parent().get(0),n=/relative|absolute/.test(e.containerElement.css("position")),i&&n?(e.offset.left=e.parentData.left+e.position.left,e.offset.top=e.parentData.top+e.position.top):(e.offset.left=e.element.offset().left,e.offset.top=e.element.offset().top),n=Math.abs(e.sizeDiff.width+(e._helper?e.offset.left-h.left:e.offset.left-s.left)),s=Math.abs(e.sizeDiff.height+(e._helper?e.offset.top-h.top:e.offset.top-s.top)),n+e.size.width>=e.parentData.width&&(e.size.width=e.parentData.width-n,o&&(e.size.height=e.size.width/e.aspectRatio,t=!1)),s+e.size.height>=e.parentData.height&&(e.size.height=e.parentData.height-s,o&&(e.size.width=e.size.height*e.aspectRatio,t=!1)),t||(e.position.left=e.prevPosition.left,e.position.top=e.prevPosition.top,e.size.width=e.prevSize.width,e.size.height=e.prevSize.height)},stop:function(){var t=y(this).resizable("instance"),e=t.options,i=t.containerOffset,s=t.containerPosition,n=t.containerElement,o=y(t.helper),h=o.offset(),a=o.outerWidth()-t.sizeDiff.width,o=o.outerHeight()-t.sizeDiff.height;t._helper&&!e.animate&&/relative/.test(n.css("position"))&&y(this).css({left:h.left-s.left-i.left,width:a,height:o}),t._helper&&!e.animate&&/static/.test(n.css("position"))&&y(this).css({left:h.left-s.left-i.left,width:a,height:o})}}),y.ui.plugin.add("resizable","alsoResize",{start:function(){var t=y(this).resizable("instance").options;y(t.alsoResize).each(function(){var t=y(this);t.data("ui-resizable-alsoresize",{width:parseFloat(t.width()),height:parseFloat(t.height()),left:parseFloat(t.css("left")),top:parseFloat(t.css("top"))})})},resize:function(t,i){var e=y(this).resizable("instance"),s=e.options,n=e.originalSize,o=e.originalPosition,h={height:e.size.height-n.height||0,width:e.size.width-n.width||0,top:e.position.top-o.top||0,left:e.position.left-o.left||0};y(s.alsoResize).each(function(){var t=y(this),s=y(this).data("ui-resizable-alsoresize"),n={},e=t.parents(i.originalElement[0]).length?["width","height"]:["width","height","top","left"];y.each(e,function(t,e){var i=(s[e]||0)+(h[e]||0);i&&0<=i&&(n[e]=i||null)}),t.css(n)})},stop:function(){y(this).removeData("ui-resizable-alsoresize")}}),y.ui.plugin.add("resizable","ghost",{start:function(){var t=y(this).resizable("instance"),e=t.size;t.ghost=t.originalElement.clone(),t.ghost.css({opacity:.25,display:"block",position:"relative",height:e.height,width:e.width,margin:0,left:0,top:0}),t._addClass(t.ghost,"ui-resizable-ghost"),!1!==y.uiBackCompat&&"string"==typeof t.options.ghost&&t.ghost.addClass(this.options.ghost),t.ghost.appendTo(t.helper)},resize:function(){var t=y(this).resizable("instance");t.ghost&&t.ghost.css({position:"relative",height:t.size.height,width:t.size.width})},stop:function(){var t=y(this).resizable("instance");t.ghost&&t.helper&&t.helper.get(0).removeChild(t.ghost.get(0))}}),y.ui.plugin.add("resizable","grid",{resize:function(){var t,e=y(this).resizable("instance"),i=e.options,s=e.size,n=e.originalSize,o=e.originalPosition,h=e.axis,a="number"==typeof i.grid?[i.grid,i.grid]:i.grid,r=a[0]||1,l=a[1]||1,u=Math.round((s.width-n.width)/r)*r,p=Math.round((s.height-n.height)/l)*l,d=n.width+u,c=n.height+p,f=i.maxWidth&&i.maxWidth<d,g=i.maxHeight&&i.maxHeight<c,m=i.minWidth&&i.minWidth>d,s=i.minHeight&&i.minHeight>c;i.grid=a,m&&(d+=r),s&&(c+=l),f&&(d-=r),g&&(c-=l),/^(se|s|e)$/.test(h)?(e.size.width=d,e.size.height=c):/^(ne)$/.test(h)?(e.size.width=d,e.size.height=c,e.position.top=o.top-p):/^(sw)$/.test(h)?(e.size.width=d,e.size.height=c,e.position.left=o.left-u):((c-l<=0||d-r<=0)&&(t=e._getPaddingPlusBorderDimensions(this)),0<c-l?(e.size.height=c,e.position.top=o.top-p):(c=l-t.height,e.size.height=c,e.position.top=o.top+n.height-c),0<d-r?(e.size.width=d,e.position.left=o.left-u):(d=r-t.width,e.size.width=d,e.position.left=o.left+n.width-d))}});y.ui.resizable});/** + * Copyright (c) 2007 Ariel Flesler - aflesler ○ gmail • com | https://github.com/flesler + * Licensed under MIT + * @author Ariel Flesler + * @version 2.1.2 + */ +;(function(f){"use strict";"function"===typeof define&&define.amd?define(["jquery"],f):"undefined"!==typeof module&&module.exports?module.exports=f(require("jquery")):f(jQuery)})(function($){"use strict";function n(a){return!a.nodeName||-1!==$.inArray(a.nodeName.toLowerCase(),["iframe","#document","html","body"])}function h(a){return $.isFunction(a)||$.isPlainObject(a)?a:{top:a,left:a}}var p=$.scrollTo=function(a,d,b){return $(window).scrollTo(a,d,b)};p.defaults={axis:"xy",duration:0,limit:!0};$.fn.scrollTo=function(a,d,b){"object"=== typeof d&&(b=d,d=0);"function"===typeof b&&(b={onAfter:b});"max"===a&&(a=9E9);b=$.extend({},p.defaults,b);d=d||b.duration;var u=b.queue&&1<b.axis.length;u&&(d/=2);b.offset=h(b.offset);b.over=h(b.over);return this.each(function(){function k(a){var k=$.extend({},b,{queue:!0,duration:d,complete:a&&function(){a.call(q,e,b)}});r.animate(f,k)}if(null!==a){var l=n(this),q=l?this.contentWindow||window:this,r=$(q),e=a,f={},t;switch(typeof e){case "number":case "string":if(/^([+-]=?)?\d+(\.\d+)?(px|%)?$/.test(e)){e= h(e);break}e=l?$(e):$(e,q);case "object":if(e.length===0)return;if(e.is||e.style)t=(e=$(e)).offset()}var v=$.isFunction(b.offset)&&b.offset(q,e)||b.offset;$.each(b.axis.split(""),function(a,c){var d="x"===c?"Left":"Top",m=d.toLowerCase(),g="scroll"+d,h=r[g](),n=p.max(q,c);t?(f[g]=t[m]+(l?0:h-r.offset()[m]),b.margin&&(f[g]-=parseInt(e.css("margin"+d),10)||0,f[g]-=parseInt(e.css("border"+d+"Width"),10)||0),f[g]+=v[m]||0,b.over[m]&&(f[g]+=e["x"===c?"width":"height"]()*b.over[m])):(d=e[m],f[g]=d.slice&& "%"===d.slice(-1)?parseFloat(d)/100*n:d);b.limit&&/^\d+$/.test(f[g])&&(f[g]=0>=f[g]?0:Math.min(f[g],n));!a&&1<b.axis.length&&(h===f[g]?f={}:u&&(k(b.onAfterFirst),f={}))});k(b.onAfter)}})};p.max=function(a,d){var b="x"===d?"Width":"Height",h="scroll"+b;if(!n(a))return a[h]-$(a)[b.toLowerCase()]();var b="client"+b,k=a.ownerDocument||a.document,l=k.documentElement,k=k.body;return Math.max(l[h],k[h])-Math.min(l[b],k[b])};$.Tween.propHooks.scrollLeft=$.Tween.propHooks.scrollTop={get:function(a){return $(a.elem)[a.prop]()}, set:function(a){var d=this.get(a);if(a.options.interrupt&&a._last&&a._last!==d)return $(a.elem).stop();var b=Math.round(a.now);d!==b&&($(a.elem)[a.prop](b),a._last=this.get(a))}};return p}); +/*! + PowerTip v1.3.1 (2018-04-15) + https://stevenbenner.github.io/jquery-powertip/ + Copyright (c) 2018 Steven Benner (http://stevenbenner.com/). + Released under MIT license. + https://raw.github.com/stevenbenner/jquery-powertip/master/LICENSE.txt +*/ +(function(root,factory){if(typeof define==="function"&&define.amd){define(["jquery"],factory)}else if(typeof module==="object"&&module.exports){module.exports=factory(require("jquery"))}else{factory(root.jQuery)}})(this,function($){var $document=$(document),$window=$(window),$body=$("body");var DATA_DISPLAYCONTROLLER="displayController",DATA_HASACTIVEHOVER="hasActiveHover",DATA_FORCEDOPEN="forcedOpen",DATA_HASMOUSEMOVE="hasMouseMove",DATA_MOUSEONTOTIP="mouseOnToPopup",DATA_ORIGINALTITLE="originalTitle",DATA_POWERTIP="powertip",DATA_POWERTIPJQ="powertipjq",DATA_POWERTIPTARGET="powertiptarget",EVENT_NAMESPACE=".powertip",RAD2DEG=180/Math.PI,MOUSE_EVENTS=["click","dblclick","mousedown","mouseup","mousemove","mouseover","mouseout","mouseenter","mouseleave","contextmenu"];var session={tooltips:null,isTipOpen:false,isFixedTipOpen:false,isClosing:false,tipOpenImminent:false,activeHover:null,currentX:0,currentY:0,previousX:0,previousY:0,desyncTimeout:null,closeDelayTimeout:null,mouseTrackingActive:false,delayInProgress:false,windowWidth:0,windowHeight:0,scrollTop:0,scrollLeft:0};var Collision={none:0,top:1,bottom:2,left:4,right:8};$.fn.powerTip=function(opts,arg){var targetElements=this,options,tipController;if(!targetElements.length){return targetElements}if($.type(opts)==="string"&&$.powerTip[opts]){return $.powerTip[opts].call(targetElements,targetElements,arg)}options=$.extend({},$.fn.powerTip.defaults,opts);tipController=new TooltipController(options);initTracking();targetElements.each(function elementSetup(){var $this=$(this),dataPowertip=$this.data(DATA_POWERTIP),dataElem=$this.data(DATA_POWERTIPJQ),dataTarget=$this.data(DATA_POWERTIPTARGET),title=$this.attr("title");if(!dataPowertip&&!dataTarget&&!dataElem&&title){$this.data(DATA_POWERTIP,title);$this.data(DATA_ORIGINALTITLE,title);$this.removeAttr("title")}$this.data(DATA_DISPLAYCONTROLLER,new DisplayController($this,options,tipController))});if(!options.manual){$.each(options.openEvents,function(idx,evt){if($.inArray(evt,options.closeEvents)>-1){targetElements.on(evt+EVENT_NAMESPACE,function elementToggle(event){$.powerTip.toggle(this,event)})}else{targetElements.on(evt+EVENT_NAMESPACE,function elementOpen(event){$.powerTip.show(this,event)})}});$.each(options.closeEvents,function(idx,evt){if($.inArray(evt,options.openEvents)<0){targetElements.on(evt+EVENT_NAMESPACE,function elementClose(event){$.powerTip.hide(this,!isMouseEvent(event))})}});targetElements.on("keydown"+EVENT_NAMESPACE,function elementKeyDown(event){if(event.keyCode===27){$.powerTip.hide(this,true)}})}return targetElements};$.fn.powerTip.defaults={fadeInTime:200,fadeOutTime:100,followMouse:false,popupId:"powerTip",popupClass:null,intentSensitivity:7,intentPollInterval:100,closeDelay:100,placement:"n",smartPlacement:false,offset:10,mouseOnToPopup:false,manual:false,openEvents:["mouseenter","focus"],closeEvents:["mouseleave","blur"]};$.fn.powerTip.smartPlacementLists={n:["n","ne","nw","s"],e:["e","ne","se","w","nw","sw","n","s","e"],s:["s","se","sw","n"],w:["w","nw","sw","e","ne","se","n","s","w"],nw:["nw","w","sw","n","s","se","nw"],ne:["ne","e","se","n","s","sw","ne"],sw:["sw","w","nw","s","n","ne","sw"],se:["se","e","ne","s","n","nw","se"],"nw-alt":["nw-alt","n","ne-alt","sw-alt","s","se-alt","w","e"],"ne-alt":["ne-alt","n","nw-alt","se-alt","s","sw-alt","e","w"],"sw-alt":["sw-alt","s","se-alt","nw-alt","n","ne-alt","w","e"],"se-alt":["se-alt","s","sw-alt","ne-alt","n","nw-alt","e","w"]};$.powerTip={show:function apiShowTip(element,event){if(isMouseEvent(event)){trackMouse(event);session.previousX=event.pageX;session.previousY=event.pageY;$(element).data(DATA_DISPLAYCONTROLLER).show()}else{$(element).first().data(DATA_DISPLAYCONTROLLER).show(true,true)}return element},reposition:function apiResetPosition(element){$(element).first().data(DATA_DISPLAYCONTROLLER).resetPosition();return element},hide:function apiCloseTip(element,immediate){var displayController;immediate=element?immediate:true;if(element){displayController=$(element).first().data(DATA_DISPLAYCONTROLLER)}else if(session.activeHover){displayController=session.activeHover.data(DATA_DISPLAYCONTROLLER)}if(displayController){displayController.hide(immediate)}return element},toggle:function apiToggle(element,event){if(session.activeHover&&session.activeHover.is(element)){$.powerTip.hide(element,!isMouseEvent(event))}else{$.powerTip.show(element,event)}return element}};$.powerTip.showTip=$.powerTip.show;$.powerTip.closeTip=$.powerTip.hide;function CSSCoordinates(){var me=this;me.top="auto";me.left="auto";me.right="auto";me.bottom="auto";me.set=function(property,value){if($.isNumeric(value)){me[property]=Math.round(value)}}}function DisplayController(element,options,tipController){var hoverTimer=null,myCloseDelay=null;function openTooltip(immediate,forceOpen){cancelTimer();if(!element.data(DATA_HASACTIVEHOVER)){if(!immediate){session.tipOpenImminent=true;hoverTimer=setTimeout(function intentDelay(){hoverTimer=null;checkForIntent()},options.intentPollInterval)}else{if(forceOpen){element.data(DATA_FORCEDOPEN,true)}closeAnyDelayed();tipController.showTip(element)}}else{cancelClose()}}function closeTooltip(disableDelay){if(myCloseDelay){myCloseDelay=session.closeDelayTimeout=clearTimeout(myCloseDelay);session.delayInProgress=false}cancelTimer();session.tipOpenImminent=false;if(element.data(DATA_HASACTIVEHOVER)){element.data(DATA_FORCEDOPEN,false);if(!disableDelay){session.delayInProgress=true;session.closeDelayTimeout=setTimeout(function closeDelay(){session.closeDelayTimeout=null;tipController.hideTip(element);session.delayInProgress=false;myCloseDelay=null},options.closeDelay);myCloseDelay=session.closeDelayTimeout}else{tipController.hideTip(element)}}}function checkForIntent(){var xDifference=Math.abs(session.previousX-session.currentX),yDifference=Math.abs(session.previousY-session.currentY),totalDifference=xDifference+yDifference;if(totalDifference<options.intentSensitivity){cancelClose();closeAnyDelayed();tipController.showTip(element)}else{session.previousX=session.currentX;session.previousY=session.currentY;openTooltip()}}function cancelTimer(stopClose){hoverTimer=clearTimeout(hoverTimer);if(session.closeDelayTimeout&&myCloseDelay===session.closeDelayTimeout||stopClose){cancelClose()}}function cancelClose(){session.closeDelayTimeout=clearTimeout(session.closeDelayTimeout);session.delayInProgress=false}function closeAnyDelayed(){if(session.delayInProgress&&session.activeHover&&!session.activeHover.is(element)){session.activeHover.data(DATA_DISPLAYCONTROLLER).hide(true)}}function repositionTooltip(){tipController.resetPosition(element)}this.show=openTooltip;this.hide=closeTooltip;this.cancel=cancelTimer;this.resetPosition=repositionTooltip}function PlacementCalculator(){function computePlacementCoords(element,placement,tipWidth,tipHeight,offset){var placementBase=placement.split("-")[0],coords=new CSSCoordinates,position;if(isSvgElement(element)){position=getSvgPlacement(element,placementBase)}else{position=getHtmlPlacement(element,placementBase)}switch(placement){case"n":coords.set("left",position.left-tipWidth/2);coords.set("bottom",session.windowHeight-position.top+offset);break;case"e":coords.set("left",position.left+offset);coords.set("top",position.top-tipHeight/2);break;case"s":coords.set("left",position.left-tipWidth/2);coords.set("top",position.top+offset);break;case"w":coords.set("top",position.top-tipHeight/2);coords.set("right",session.windowWidth-position.left+offset);break;case"nw":coords.set("bottom",session.windowHeight-position.top+offset);coords.set("right",session.windowWidth-position.left-20);break;case"nw-alt":coords.set("left",position.left);coords.set("bottom",session.windowHeight-position.top+offset);break;case"ne":coords.set("left",position.left-20);coords.set("bottom",session.windowHeight-position.top+offset);break;case"ne-alt":coords.set("bottom",session.windowHeight-position.top+offset);coords.set("right",session.windowWidth-position.left);break;case"sw":coords.set("top",position.top+offset);coords.set("right",session.windowWidth-position.left-20);break;case"sw-alt":coords.set("left",position.left);coords.set("top",position.top+offset);break;case"se":coords.set("left",position.left-20);coords.set("top",position.top+offset);break;case"se-alt":coords.set("top",position.top+offset);coords.set("right",session.windowWidth-position.left);break}return coords}function getHtmlPlacement(element,placement){var objectOffset=element.offset(),objectWidth=element.outerWidth(),objectHeight=element.outerHeight(),left,top;switch(placement){case"n":left=objectOffset.left+objectWidth/2;top=objectOffset.top;break;case"e":left=objectOffset.left+objectWidth;top=objectOffset.top+objectHeight/2;break;case"s":left=objectOffset.left+objectWidth/2;top=objectOffset.top+objectHeight;break;case"w":left=objectOffset.left;top=objectOffset.top+objectHeight/2;break;case"nw":left=objectOffset.left;top=objectOffset.top;break;case"ne":left=objectOffset.left+objectWidth;top=objectOffset.top;break;case"sw":left=objectOffset.left;top=objectOffset.top+objectHeight;break;case"se":left=objectOffset.left+objectWidth;top=objectOffset.top+objectHeight;break}return{top:top,left:left}}function getSvgPlacement(element,placement){var svgElement=element.closest("svg")[0],domElement=element[0],point=svgElement.createSVGPoint(),boundingBox=domElement.getBBox(),matrix=domElement.getScreenCTM(),halfWidth=boundingBox.width/2,halfHeight=boundingBox.height/2,placements=[],placementKeys=["nw","n","ne","e","se","s","sw","w"],coords,rotation,steps,x;function pushPlacement(){placements.push(point.matrixTransform(matrix))}point.x=boundingBox.x;point.y=boundingBox.y;pushPlacement();point.x+=halfWidth;pushPlacement();point.x+=halfWidth;pushPlacement();point.y+=halfHeight;pushPlacement();point.y+=halfHeight;pushPlacement();point.x-=halfWidth;pushPlacement();point.x-=halfWidth;pushPlacement();point.y-=halfHeight;pushPlacement();if(placements[0].y!==placements[1].y||placements[0].x!==placements[7].x){rotation=Math.atan2(matrix.b,matrix.a)*RAD2DEG;steps=Math.ceil((rotation%360-22.5)/45);if(steps<1){steps+=8}while(steps--){placementKeys.push(placementKeys.shift())}}for(x=0;x<placements.length;x++){if(placementKeys[x]===placement){coords=placements[x];break}}return{top:coords.y+session.scrollTop,left:coords.x+session.scrollLeft}}this.compute=computePlacementCoords}function TooltipController(options){var placementCalculator=new PlacementCalculator,tipElement=$("#"+options.popupId);if(tipElement.length===0){tipElement=$("<div/>",{id:options.popupId});if($body.length===0){$body=$("body")}$body.append(tipElement);session.tooltips=session.tooltips?session.tooltips.add(tipElement):tipElement}if(options.followMouse){if(!tipElement.data(DATA_HASMOUSEMOVE)){$document.on("mousemove"+EVENT_NAMESPACE,positionTipOnCursor);$window.on("scroll"+EVENT_NAMESPACE,positionTipOnCursor);tipElement.data(DATA_HASMOUSEMOVE,true)}}function beginShowTip(element){element.data(DATA_HASACTIVEHOVER,true);tipElement.queue(function queueTipInit(next){showTip(element);next()})}function showTip(element){var tipContent;if(!element.data(DATA_HASACTIVEHOVER)){return}if(session.isTipOpen){if(!session.isClosing){hideTip(session.activeHover)}tipElement.delay(100).queue(function queueTipAgain(next){showTip(element);next()});return}element.trigger("powerTipPreRender");tipContent=getTooltipContent(element);if(tipContent){tipElement.empty().append(tipContent)}else{return}element.trigger("powerTipRender");session.activeHover=element;session.isTipOpen=true;tipElement.data(DATA_MOUSEONTOTIP,options.mouseOnToPopup);tipElement.addClass(options.popupClass);if(!options.followMouse||element.data(DATA_FORCEDOPEN)){positionTipOnElement(element);session.isFixedTipOpen=true}else{positionTipOnCursor()}if(!element.data(DATA_FORCEDOPEN)&&!options.followMouse){$document.on("click"+EVENT_NAMESPACE,function documentClick(event){var target=event.target;if(target!==element[0]){if(options.mouseOnToPopup){if(target!==tipElement[0]&&!$.contains(tipElement[0],target)){$.powerTip.hide()}}else{$.powerTip.hide()}}})}if(options.mouseOnToPopup&&!options.manual){tipElement.on("mouseenter"+EVENT_NAMESPACE,function tipMouseEnter(){if(session.activeHover){session.activeHover.data(DATA_DISPLAYCONTROLLER).cancel()}});tipElement.on("mouseleave"+EVENT_NAMESPACE,function tipMouseLeave(){if(session.activeHover){session.activeHover.data(DATA_DISPLAYCONTROLLER).hide()}})}tipElement.fadeIn(options.fadeInTime,function fadeInCallback(){if(!session.desyncTimeout){session.desyncTimeout=setInterval(closeDesyncedTip,500)}element.trigger("powerTipOpen")})}function hideTip(element){session.isClosing=true;session.isTipOpen=false;session.desyncTimeout=clearInterval(session.desyncTimeout);element.data(DATA_HASACTIVEHOVER,false);element.data(DATA_FORCEDOPEN,false);$document.off("click"+EVENT_NAMESPACE);tipElement.off(EVENT_NAMESPACE);tipElement.fadeOut(options.fadeOutTime,function fadeOutCallback(){var coords=new CSSCoordinates;session.activeHover=null;session.isClosing=false;session.isFixedTipOpen=false;tipElement.removeClass();coords.set("top",session.currentY+options.offset);coords.set("left",session.currentX+options.offset);tipElement.css(coords);element.trigger("powerTipClose")})}function positionTipOnCursor(){var tipWidth,tipHeight,coords,collisions,collisionCount;if(!session.isFixedTipOpen&&(session.isTipOpen||session.tipOpenImminent&&tipElement.data(DATA_HASMOUSEMOVE))){tipWidth=tipElement.outerWidth();tipHeight=tipElement.outerHeight();coords=new CSSCoordinates;coords.set("top",session.currentY+options.offset);coords.set("left",session.currentX+options.offset);collisions=getViewportCollisions(coords,tipWidth,tipHeight);if(collisions!==Collision.none){collisionCount=countFlags(collisions);if(collisionCount===1){if(collisions===Collision.right){coords.set("left",session.scrollLeft+session.windowWidth-tipWidth)}else if(collisions===Collision.bottom){coords.set("top",session.scrollTop+session.windowHeight-tipHeight)}}else{coords.set("left",session.currentX-tipWidth-options.offset);coords.set("top",session.currentY-tipHeight-options.offset)}}tipElement.css(coords)}}function positionTipOnElement(element){var priorityList,finalPlacement;if(options.smartPlacement||options.followMouse&&element.data(DATA_FORCEDOPEN)){priorityList=$.fn.powerTip.smartPlacementLists[options.placement];$.each(priorityList,function(idx,pos){var collisions=getViewportCollisions(placeTooltip(element,pos),tipElement.outerWidth(),tipElement.outerHeight());finalPlacement=pos;return collisions!==Collision.none})}else{placeTooltip(element,options.placement);finalPlacement=options.placement}tipElement.removeClass("w nw sw e ne se n s w se-alt sw-alt ne-alt nw-alt");tipElement.addClass(finalPlacement)}function placeTooltip(element,placement){var iterationCount=0,tipWidth,tipHeight,coords=new CSSCoordinates;coords.set("top",0);coords.set("left",0);tipElement.css(coords);do{tipWidth=tipElement.outerWidth();tipHeight=tipElement.outerHeight();coords=placementCalculator.compute(element,placement,tipWidth,tipHeight,options.offset);tipElement.css(coords)}while(++iterationCount<=5&&(tipWidth!==tipElement.outerWidth()||tipHeight!==tipElement.outerHeight()));return coords}function closeDesyncedTip(){var isDesynced=false,hasDesyncableCloseEvent=$.grep(["mouseleave","mouseout","blur","focusout"],function(eventType){return $.inArray(eventType,options.closeEvents)!==-1}).length>0;if(session.isTipOpen&&!session.isClosing&&!session.delayInProgress&&hasDesyncableCloseEvent){if(session.activeHover.data(DATA_HASACTIVEHOVER)===false||session.activeHover.is(":disabled")){isDesynced=true}else if(!isMouseOver(session.activeHover)&&!session.activeHover.is(":focus")&&!session.activeHover.data(DATA_FORCEDOPEN)){if(tipElement.data(DATA_MOUSEONTOTIP)){if(!isMouseOver(tipElement)){isDesynced=true}}else{isDesynced=true}}if(isDesynced){hideTip(session.activeHover)}}}this.showTip=beginShowTip;this.hideTip=hideTip;this.resetPosition=positionTipOnElement}function isSvgElement(element){return Boolean(window.SVGElement&&element[0]instanceof SVGElement)}function isMouseEvent(event){return Boolean(event&&$.inArray(event.type,MOUSE_EVENTS)>-1&&typeof event.pageX==="number")}function initTracking(){if(!session.mouseTrackingActive){session.mouseTrackingActive=true;getViewportDimensions();$(getViewportDimensions);$document.on("mousemove"+EVENT_NAMESPACE,trackMouse);$window.on("resize"+EVENT_NAMESPACE,trackResize);$window.on("scroll"+EVENT_NAMESPACE,trackScroll)}}function getViewportDimensions(){session.scrollLeft=$window.scrollLeft();session.scrollTop=$window.scrollTop();session.windowWidth=$window.width();session.windowHeight=$window.height()}function trackResize(){session.windowWidth=$window.width();session.windowHeight=$window.height()}function trackScroll(){var x=$window.scrollLeft(),y=$window.scrollTop();if(x!==session.scrollLeft){session.currentX+=x-session.scrollLeft;session.scrollLeft=x}if(y!==session.scrollTop){session.currentY+=y-session.scrollTop;session.scrollTop=y}}function trackMouse(event){session.currentX=event.pageX;session.currentY=event.pageY}function isMouseOver(element){var elementPosition=element.offset(),elementBox=element[0].getBoundingClientRect(),elementWidth=elementBox.right-elementBox.left,elementHeight=elementBox.bottom-elementBox.top;return session.currentX>=elementPosition.left&&session.currentX<=elementPosition.left+elementWidth&&session.currentY>=elementPosition.top&&session.currentY<=elementPosition.top+elementHeight}function getTooltipContent(element){var tipText=element.data(DATA_POWERTIP),tipObject=element.data(DATA_POWERTIPJQ),tipTarget=element.data(DATA_POWERTIPTARGET),targetElement,content;if(tipText){if($.isFunction(tipText)){tipText=tipText.call(element[0])}content=tipText}else if(tipObject){if($.isFunction(tipObject)){tipObject=tipObject.call(element[0])}if(tipObject.length>0){content=tipObject.clone(true,true)}}else if(tipTarget){targetElement=$("#"+tipTarget);if(targetElement.length>0){content=targetElement.html()}}return content}function getViewportCollisions(coords,elementWidth,elementHeight){var viewportTop=session.scrollTop,viewportLeft=session.scrollLeft,viewportBottom=viewportTop+session.windowHeight,viewportRight=viewportLeft+session.windowWidth,collisions=Collision.none;if(coords.top<viewportTop||Math.abs(coords.bottom-session.windowHeight)-elementHeight<viewportTop){collisions|=Collision.top}if(coords.top+elementHeight>viewportBottom||Math.abs(coords.bottom-session.windowHeight)>viewportBottom){collisions|=Collision.bottom}if(coords.left<viewportLeft||coords.right+elementWidth>viewportRight){collisions|=Collision.left}if(coords.left+elementWidth>viewportRight||coords.right<viewportLeft){collisions|=Collision.right}return collisions}function countFlags(value){var count=0;while(value){value&=value-1;count++}return count}return $.powerTip});/*! + * jQuery UI Touch Punch 0.2.3 + * + * Copyright 2011–2014, Dave Furfero + * Dual licensed under the MIT or GPL Version 2 licenses. + * + * Depends: + * jquery.ui.widget.js + * jquery.ui.mouse.js + */ +!function(a){function f(a,b){if(!(a.originalEvent.touches.length>1)){a.preventDefault();var c=a.originalEvent.changedTouches[0],d=document.createEvent("MouseEvents");d.initMouseEvent(b,!0,!0,window,1,c.screenX,c.screenY,c.clientX,c.clientY,!1,!1,!1,!1,0,null),a.target.dispatchEvent(d)}}if(a.support.touch="ontouchend"in document,a.support.touch){var e,b=a.ui.mouse.prototype,c=b._mouseInit,d=b._mouseDestroy;b._touchStart=function(a){var b=this;!e&&b._mouseCapture(a.originalEvent.changedTouches[0])&&(e=!0,b._touchMoved=!1,f(a,"mouseover"),f(a,"mousemove"),f(a,"mousedown"))},b._touchMove=function(a){e&&(this._touchMoved=!0,f(a,"mousemove"))},b._touchEnd=function(a){e&&(f(a,"mouseup"),f(a,"mouseout"),this._touchMoved||f(a,"click"),e=!1)},b._mouseInit=function(){var b=this;b.element.bind({touchstart:a.proxy(b,"_touchStart"),touchmove:a.proxy(b,"_touchMove"),touchend:a.proxy(b,"_touchEnd")}),c.call(b)},b._mouseDestroy=function(){var b=this;b.element.unbind({touchstart:a.proxy(b,"_touchStart"),touchmove:a.proxy(b,"_touchMove"),touchend:a.proxy(b,"_touchEnd")}),d.call(b)}}}(jQuery);/*! SmartMenus jQuery Plugin - v1.1.0 - September 17, 2017 + * http://www.smartmenus.org/ + * Copyright Vasil Dinkov, Vadikom Web Ltd. http://vadikom.com; Licensed MIT */(function(t){"function"==typeof define&&define.amd?define(["jquery"],t):"object"==typeof module&&"object"==typeof module.exports?module.exports=t(require("jquery")):t(jQuery)})(function($){function initMouseDetection(t){var e=".smartmenus_mouse";if(mouseDetectionEnabled||t)mouseDetectionEnabled&&t&&($(document).off(e),mouseDetectionEnabled=!1);else{var i=!0,s=null,o={mousemove:function(t){var e={x:t.pageX,y:t.pageY,timeStamp:(new Date).getTime()};if(s){var o=Math.abs(s.x-e.x),a=Math.abs(s.y-e.y);if((o>0||a>0)&&2>=o&&2>=a&&300>=e.timeStamp-s.timeStamp&&(mouse=!0,i)){var n=$(t.target).closest("a");n.is("a")&&$.each(menuTrees,function(){return $.contains(this.$root[0],n[0])?(this.itemEnter({currentTarget:n[0]}),!1):void 0}),i=!1}}s=e}};o[touchEvents?"touchstart":"pointerover pointermove pointerout MSPointerOver MSPointerMove MSPointerOut"]=function(t){isTouchEvent(t.originalEvent)&&(mouse=!1)},$(document).on(getEventsNS(o,e)),mouseDetectionEnabled=!0}}function isTouchEvent(t){return!/^(4|mouse)$/.test(t.pointerType)}function getEventsNS(t,e){e||(e="");var i={};for(var s in t)i[s.split(" ").join(e+" ")+e]=t[s];return i}var menuTrees=[],mouse=!1,touchEvents="ontouchstart"in window,mouseDetectionEnabled=!1,requestAnimationFrame=window.requestAnimationFrame||function(t){return setTimeout(t,1e3/60)},cancelAnimationFrame=window.cancelAnimationFrame||function(t){clearTimeout(t)},canAnimate=!!$.fn.animate;return $.SmartMenus=function(t,e){this.$root=$(t),this.opts=e,this.rootId="",this.accessIdPrefix="",this.$subArrow=null,this.activatedItems=[],this.visibleSubMenus=[],this.showTimeout=0,this.hideTimeout=0,this.scrollTimeout=0,this.clickActivated=!1,this.focusActivated=!1,this.zIndexInc=0,this.idInc=0,this.$firstLink=null,this.$firstSub=null,this.disabled=!1,this.$disableOverlay=null,this.$touchScrollingSub=null,this.cssTransforms3d="perspective"in t.style||"webkitPerspective"in t.style,this.wasCollapsible=!1,this.init()},$.extend($.SmartMenus,{hideAll:function(){$.each(menuTrees,function(){this.menuHideAll()})},destroy:function(){for(;menuTrees.length;)menuTrees[0].destroy();initMouseDetection(!0)},prototype:{init:function(t){var e=this;if(!t){menuTrees.push(this),this.rootId=((new Date).getTime()+Math.random()+"").replace(/\D/g,""),this.accessIdPrefix="sm-"+this.rootId+"-",this.$root.hasClass("sm-rtl")&&(this.opts.rightToLeftSubMenus=!0);var i=".smartmenus";this.$root.data("smartmenus",this).attr("data-smartmenus-id",this.rootId).dataSM("level",1).on(getEventsNS({"mouseover focusin":$.proxy(this.rootOver,this),"mouseout focusout":$.proxy(this.rootOut,this),keydown:$.proxy(this.rootKeyDown,this)},i)).on(getEventsNS({mouseenter:$.proxy(this.itemEnter,this),mouseleave:$.proxy(this.itemLeave,this),mousedown:$.proxy(this.itemDown,this),focus:$.proxy(this.itemFocus,this),blur:$.proxy(this.itemBlur,this),click:$.proxy(this.itemClick,this)},i),"a"),i+=this.rootId,this.opts.hideOnClick&&$(document).on(getEventsNS({touchstart:$.proxy(this.docTouchStart,this),touchmove:$.proxy(this.docTouchMove,this),touchend:$.proxy(this.docTouchEnd,this),click:$.proxy(this.docClick,this)},i)),$(window).on(getEventsNS({"resize orientationchange":$.proxy(this.winResize,this)},i)),this.opts.subIndicators&&(this.$subArrow=$("<span/>").addClass("sub-arrow"),this.opts.subIndicatorsText&&this.$subArrow.html(this.opts.subIndicatorsText)),initMouseDetection()}if(this.$firstSub=this.$root.find("ul").each(function(){e.menuInit($(this))}).eq(0),this.$firstLink=this.$root.find("a").eq(0),this.opts.markCurrentItem){var s=/(index|default)\.[^#\?\/]*/i,o=/#.*/,a=window.location.href.replace(s,""),n=a.replace(o,"");this.$root.find("a").each(function(){var t=this.href.replace(s,""),i=$(this);(t==a||t==n)&&(i.addClass("current"),e.opts.markCurrentTree&&i.parentsUntil("[data-smartmenus-id]","ul").each(function(){$(this).dataSM("parent-a").addClass("current")}))})}this.wasCollapsible=this.isCollapsible()},destroy:function(t){if(!t){var e=".smartmenus";this.$root.removeData("smartmenus").removeAttr("data-smartmenus-id").removeDataSM("level").off(e),e+=this.rootId,$(document).off(e),$(window).off(e),this.opts.subIndicators&&(this.$subArrow=null)}this.menuHideAll();var i=this;this.$root.find("ul").each(function(){var t=$(this);t.dataSM("scroll-arrows")&&t.dataSM("scroll-arrows").remove(),t.dataSM("shown-before")&&((i.opts.subMenusMinWidth||i.opts.subMenusMaxWidth)&&t.css({width:"",minWidth:"",maxWidth:""}).removeClass("sm-nowrap"),t.dataSM("scroll-arrows")&&t.dataSM("scroll-arrows").remove(),t.css({zIndex:"",top:"",left:"",marginLeft:"",marginTop:"",display:""})),0==(t.attr("id")||"").indexOf(i.accessIdPrefix)&&t.removeAttr("id")}).removeDataSM("in-mega").removeDataSM("shown-before").removeDataSM("scroll-arrows").removeDataSM("parent-a").removeDataSM("level").removeDataSM("beforefirstshowfired").removeAttr("role").removeAttr("aria-hidden").removeAttr("aria-labelledby").removeAttr("aria-expanded"),this.$root.find("a.has-submenu").each(function(){var t=$(this);0==t.attr("id").indexOf(i.accessIdPrefix)&&t.removeAttr("id")}).removeClass("has-submenu").removeDataSM("sub").removeAttr("aria-haspopup").removeAttr("aria-controls").removeAttr("aria-expanded").closest("li").removeDataSM("sub"),this.opts.subIndicators&&this.$root.find("span.sub-arrow").remove(),this.opts.markCurrentItem&&this.$root.find("a.current").removeClass("current"),t||(this.$root=null,this.$firstLink=null,this.$firstSub=null,this.$disableOverlay&&(this.$disableOverlay.remove(),this.$disableOverlay=null),menuTrees.splice($.inArray(this,menuTrees),1))},disable:function(t){if(!this.disabled){if(this.menuHideAll(),!t&&!this.opts.isPopup&&this.$root.is(":visible")){var e=this.$root.offset();this.$disableOverlay=$('<div class="sm-jquery-disable-overlay"/>').css({position:"absolute",top:e.top,left:e.left,width:this.$root.outerWidth(),height:this.$root.outerHeight(),zIndex:this.getStartZIndex(!0),opacity:0}).appendTo(document.body)}this.disabled=!0}},docClick:function(t){return this.$touchScrollingSub?(this.$touchScrollingSub=null,void 0):((this.visibleSubMenus.length&&!$.contains(this.$root[0],t.target)||$(t.target).closest("a").length)&&this.menuHideAll(),void 0)},docTouchEnd:function(){if(this.lastTouch){if(!(!this.visibleSubMenus.length||void 0!==this.lastTouch.x2&&this.lastTouch.x1!=this.lastTouch.x2||void 0!==this.lastTouch.y2&&this.lastTouch.y1!=this.lastTouch.y2||this.lastTouch.target&&$.contains(this.$root[0],this.lastTouch.target))){this.hideTimeout&&(clearTimeout(this.hideTimeout),this.hideTimeout=0);var t=this;this.hideTimeout=setTimeout(function(){t.menuHideAll()},350)}this.lastTouch=null}},docTouchMove:function(t){if(this.lastTouch){var e=t.originalEvent.touches[0];this.lastTouch.x2=e.pageX,this.lastTouch.y2=e.pageY}},docTouchStart:function(t){var e=t.originalEvent.touches[0];this.lastTouch={x1:e.pageX,y1:e.pageY,target:e.target}},enable:function(){this.disabled&&(this.$disableOverlay&&(this.$disableOverlay.remove(),this.$disableOverlay=null),this.disabled=!1)},getClosestMenu:function(t){for(var e=$(t).closest("ul");e.dataSM("in-mega");)e=e.parent().closest("ul");return e[0]||null},getHeight:function(t){return this.getOffset(t,!0)},getOffset:function(t,e){var i;"none"==t.css("display")&&(i={position:t[0].style.position,visibility:t[0].style.visibility},t.css({position:"absolute",visibility:"hidden"}).show());var s=t[0].getBoundingClientRect&&t[0].getBoundingClientRect(),o=s&&(e?s.height||s.bottom-s.top:s.width||s.right-s.left);return o||0===o||(o=e?t[0].offsetHeight:t[0].offsetWidth),i&&t.hide().css(i),o},getStartZIndex:function(t){var e=parseInt(this[t?"$root":"$firstSub"].css("z-index"));return!t&&isNaN(e)&&(e=parseInt(this.$root.css("z-index"))),isNaN(e)?1:e},getTouchPoint:function(t){return t.touches&&t.touches[0]||t.changedTouches&&t.changedTouches[0]||t},getViewport:function(t){var e=t?"Height":"Width",i=document.documentElement["client"+e],s=window["inner"+e];return s&&(i=Math.min(i,s)),i},getViewportHeight:function(){return this.getViewport(!0)},getViewportWidth:function(){return this.getViewport()},getWidth:function(t){return this.getOffset(t)},handleEvents:function(){return!this.disabled&&this.isCSSOn()},handleItemEvents:function(t){return this.handleEvents()&&!this.isLinkInMegaMenu(t)},isCollapsible:function(){return"static"==this.$firstSub.css("position")},isCSSOn:function(){return"inline"!=this.$firstLink.css("display")},isFixed:function(){var t="fixed"==this.$root.css("position");return t||this.$root.parentsUntil("body").each(function(){return"fixed"==$(this).css("position")?(t=!0,!1):void 0}),t},isLinkInMegaMenu:function(t){return $(this.getClosestMenu(t[0])).hasClass("mega-menu")},isTouchMode:function(){return!mouse||this.opts.noMouseOver||this.isCollapsible()},itemActivate:function(t,e){var i=t.closest("ul"),s=i.dataSM("level");if(s>1&&(!this.activatedItems[s-2]||this.activatedItems[s-2][0]!=i.dataSM("parent-a")[0])){var o=this;$(i.parentsUntil("[data-smartmenus-id]","ul").get().reverse()).add(i).each(function(){o.itemActivate($(this).dataSM("parent-a"))})}if((!this.isCollapsible()||e)&&this.menuHideSubMenus(this.activatedItems[s-1]&&this.activatedItems[s-1][0]==t[0]?s:s-1),this.activatedItems[s-1]=t,this.$root.triggerHandler("activate.smapi",t[0])!==!1){var a=t.dataSM("sub");a&&(this.isTouchMode()||!this.opts.showOnClick||this.clickActivated)&&this.menuShow(a)}},itemBlur:function(t){var e=$(t.currentTarget);this.handleItemEvents(e)&&this.$root.triggerHandler("blur.smapi",e[0])},itemClick:function(t){var e=$(t.currentTarget);if(this.handleItemEvents(e)){if(this.$touchScrollingSub&&this.$touchScrollingSub[0]==e.closest("ul")[0])return this.$touchScrollingSub=null,t.stopPropagation(),!1;if(this.$root.triggerHandler("click.smapi",e[0])===!1)return!1;var i=$(t.target).is(".sub-arrow"),s=e.dataSM("sub"),o=s?2==s.dataSM("level"):!1,a=this.isCollapsible(),n=/toggle$/.test(this.opts.collapsibleBehavior),r=/link$/.test(this.opts.collapsibleBehavior),h=/^accordion/.test(this.opts.collapsibleBehavior);if(s&&!s.is(":visible")){if((!r||!a||i)&&(this.opts.showOnClick&&o&&(this.clickActivated=!0),this.itemActivate(e,h),s.is(":visible")))return this.focusActivated=!0,!1}else if(a&&(n||i))return this.itemActivate(e,h),this.menuHide(s),n&&(this.focusActivated=!1),!1;return this.opts.showOnClick&&o||e.hasClass("disabled")||this.$root.triggerHandler("select.smapi",e[0])===!1?!1:void 0}},itemDown:function(t){var e=$(t.currentTarget);this.handleItemEvents(e)&&e.dataSM("mousedown",!0)},itemEnter:function(t){var e=$(t.currentTarget);if(this.handleItemEvents(e)){if(!this.isTouchMode()){this.showTimeout&&(clearTimeout(this.showTimeout),this.showTimeout=0);var i=this;this.showTimeout=setTimeout(function(){i.itemActivate(e)},this.opts.showOnClick&&1==e.closest("ul").dataSM("level")?1:this.opts.showTimeout)}this.$root.triggerHandler("mouseenter.smapi",e[0])}},itemFocus:function(t){var e=$(t.currentTarget);this.handleItemEvents(e)&&(!this.focusActivated||this.isTouchMode()&&e.dataSM("mousedown")||this.activatedItems.length&&this.activatedItems[this.activatedItems.length-1][0]==e[0]||this.itemActivate(e,!0),this.$root.triggerHandler("focus.smapi",e[0]))},itemLeave:function(t){var e=$(t.currentTarget);this.handleItemEvents(e)&&(this.isTouchMode()||(e[0].blur(),this.showTimeout&&(clearTimeout(this.showTimeout),this.showTimeout=0)),e.removeDataSM("mousedown"),this.$root.triggerHandler("mouseleave.smapi",e[0]))},menuHide:function(t){if(this.$root.triggerHandler("beforehide.smapi",t[0])!==!1&&(canAnimate&&t.stop(!0,!0),"none"!=t.css("display"))){var e=function(){t.css("z-index","")};this.isCollapsible()?canAnimate&&this.opts.collapsibleHideFunction?this.opts.collapsibleHideFunction.call(this,t,e):t.hide(this.opts.collapsibleHideDuration,e):canAnimate&&this.opts.hideFunction?this.opts.hideFunction.call(this,t,e):t.hide(this.opts.hideDuration,e),t.dataSM("scroll")&&(this.menuScrollStop(t),t.css({"touch-action":"","-ms-touch-action":"","-webkit-transform":"",transform:""}).off(".smartmenus_scroll").removeDataSM("scroll").dataSM("scroll-arrows").hide()),t.dataSM("parent-a").removeClass("highlighted").attr("aria-expanded","false"),t.attr({"aria-expanded":"false","aria-hidden":"true"});var i=t.dataSM("level");this.activatedItems.splice(i-1,1),this.visibleSubMenus.splice($.inArray(t,this.visibleSubMenus),1),this.$root.triggerHandler("hide.smapi",t[0])}},menuHideAll:function(){this.showTimeout&&(clearTimeout(this.showTimeout),this.showTimeout=0);for(var t=this.opts.isPopup?1:0,e=this.visibleSubMenus.length-1;e>=t;e--)this.menuHide(this.visibleSubMenus[e]);this.opts.isPopup&&(canAnimate&&this.$root.stop(!0,!0),this.$root.is(":visible")&&(canAnimate&&this.opts.hideFunction?this.opts.hideFunction.call(this,this.$root):this.$root.hide(this.opts.hideDuration))),this.activatedItems=[],this.visibleSubMenus=[],this.clickActivated=!1,this.focusActivated=!1,this.zIndexInc=0,this.$root.triggerHandler("hideAll.smapi")},menuHideSubMenus:function(t){for(var e=this.activatedItems.length-1;e>=t;e--){var i=this.activatedItems[e].dataSM("sub");i&&this.menuHide(i)}},menuInit:function(t){if(!t.dataSM("in-mega")){t.hasClass("mega-menu")&&t.find("ul").dataSM("in-mega",!0);for(var e=2,i=t[0];(i=i.parentNode.parentNode)!=this.$root[0];)e++;var s=t.prevAll("a").eq(-1);s.length||(s=t.prevAll().find("a").eq(-1)),s.addClass("has-submenu").dataSM("sub",t),t.dataSM("parent-a",s).dataSM("level",e).parent().dataSM("sub",t);var o=s.attr("id")||this.accessIdPrefix+ ++this.idInc,a=t.attr("id")||this.accessIdPrefix+ ++this.idInc;s.attr({id:o,"aria-haspopup":"true","aria-controls":a,"aria-expanded":"false"}),t.attr({id:a,role:"group","aria-hidden":"true","aria-labelledby":o,"aria-expanded":"false"}),this.opts.subIndicators&&s[this.opts.subIndicatorsPos](this.$subArrow.clone())}},menuPosition:function(t){var e,i,s=t.dataSM("parent-a"),o=s.closest("li"),a=o.parent(),n=t.dataSM("level"),r=this.getWidth(t),h=this.getHeight(t),u=s.offset(),l=u.left,c=u.top,d=this.getWidth(s),m=this.getHeight(s),p=$(window),f=p.scrollLeft(),v=p.scrollTop(),b=this.getViewportWidth(),S=this.getViewportHeight(),g=a.parent().is("[data-sm-horizontal-sub]")||2==n&&!a.hasClass("sm-vertical"),M=this.opts.rightToLeftSubMenus&&!o.is("[data-sm-reverse]")||!this.opts.rightToLeftSubMenus&&o.is("[data-sm-reverse]"),w=2==n?this.opts.mainMenuSubOffsetX:this.opts.subMenusSubOffsetX,T=2==n?this.opts.mainMenuSubOffsetY:this.opts.subMenusSubOffsetY;if(g?(e=M?d-r-w:w,i=this.opts.bottomToTopSubMenus?-h-T:m+T):(e=M?w-r:d-w,i=this.opts.bottomToTopSubMenus?m-T-h:T),this.opts.keepInViewport){var y=l+e,I=c+i;if(M&&f>y?e=g?f-y+e:d-w:!M&&y+r>f+b&&(e=g?f+b-r-y+e:w-r),g||(S>h&&I+h>v+S?i+=v+S-h-I:(h>=S||v>I)&&(i+=v-I)),g&&(I+h>v+S+.49||v>I)||!g&&h>S+.49){var x=this;t.dataSM("scroll-arrows")||t.dataSM("scroll-arrows",$([$('<span class="scroll-up"><span class="scroll-up-arrow"></span></span>')[0],$('<span class="scroll-down"><span class="scroll-down-arrow"></span></span>')[0]]).on({mouseenter:function(){t.dataSM("scroll").up=$(this).hasClass("scroll-up"),x.menuScroll(t)},mouseleave:function(e){x.menuScrollStop(t),x.menuScrollOut(t,e)},"mousewheel DOMMouseScroll":function(t){t.preventDefault()}}).insertAfter(t));var A=".smartmenus_scroll";if(t.dataSM("scroll",{y:this.cssTransforms3d?0:i-m,step:1,itemH:m,subH:h,arrowDownH:this.getHeight(t.dataSM("scroll-arrows").eq(1))}).on(getEventsNS({mouseover:function(e){x.menuScrollOver(t,e)},mouseout:function(e){x.menuScrollOut(t,e)},"mousewheel DOMMouseScroll":function(e){x.menuScrollMousewheel(t,e)}},A)).dataSM("scroll-arrows").css({top:"auto",left:"0",marginLeft:e+(parseInt(t.css("border-left-width"))||0),width:r-(parseInt(t.css("border-left-width"))||0)-(parseInt(t.css("border-right-width"))||0),zIndex:t.css("z-index")}).eq(g&&this.opts.bottomToTopSubMenus?0:1).show(),this.isFixed()){var C={};C[touchEvents?"touchstart touchmove touchend":"pointerdown pointermove pointerup MSPointerDown MSPointerMove MSPointerUp"]=function(e){x.menuScrollTouch(t,e)},t.css({"touch-action":"none","-ms-touch-action":"none"}).on(getEventsNS(C,A))}}}t.css({top:"auto",left:"0",marginLeft:e,marginTop:i-m})},menuScroll:function(t,e,i){var s,o=t.dataSM("scroll"),a=t.dataSM("scroll-arrows"),n=o.up?o.upEnd:o.downEnd;if(!e&&o.momentum){if(o.momentum*=.92,s=o.momentum,.5>s)return this.menuScrollStop(t),void 0}else s=i||(e||!this.opts.scrollAccelerate?this.opts.scrollStep:Math.floor(o.step));var r=t.dataSM("level");if(this.activatedItems[r-1]&&this.activatedItems[r-1].dataSM("sub")&&this.activatedItems[r-1].dataSM("sub").is(":visible")&&this.menuHideSubMenus(r-1),o.y=o.up&&o.y>=n||!o.up&&n>=o.y?o.y:Math.abs(n-o.y)>s?o.y+(o.up?s:-s):n,t.css(this.cssTransforms3d?{"-webkit-transform":"translate3d(0, "+o.y+"px, 0)",transform:"translate3d(0, "+o.y+"px, 0)"}:{marginTop:o.y}),mouse&&(o.up&&o.y>o.downEnd||!o.up&&o.y<o.upEnd)&&a.eq(o.up?1:0).show(),o.y==n)mouse&&a.eq(o.up?0:1).hide(),this.menuScrollStop(t);else if(!e){this.opts.scrollAccelerate&&o.step<this.opts.scrollStep&&(o.step+=.2);var h=this;this.scrollTimeout=requestAnimationFrame(function(){h.menuScroll(t)})}},menuScrollMousewheel:function(t,e){if(this.getClosestMenu(e.target)==t[0]){e=e.originalEvent;var i=(e.wheelDelta||-e.detail)>0;t.dataSM("scroll-arrows").eq(i?0:1).is(":visible")&&(t.dataSM("scroll").up=i,this.menuScroll(t,!0))}e.preventDefault()},menuScrollOut:function(t,e){mouse&&(/^scroll-(up|down)/.test((e.relatedTarget||"").className)||(t[0]==e.relatedTarget||$.contains(t[0],e.relatedTarget))&&this.getClosestMenu(e.relatedTarget)==t[0]||t.dataSM("scroll-arrows").css("visibility","hidden"))},menuScrollOver:function(t,e){if(mouse&&!/^scroll-(up|down)/.test(e.target.className)&&this.getClosestMenu(e.target)==t[0]){this.menuScrollRefreshData(t);var i=t.dataSM("scroll"),s=$(window).scrollTop()-t.dataSM("parent-a").offset().top-i.itemH;t.dataSM("scroll-arrows").eq(0).css("margin-top",s).end().eq(1).css("margin-top",s+this.getViewportHeight()-i.arrowDownH).end().css("visibility","visible")}},menuScrollRefreshData:function(t){var e=t.dataSM("scroll"),i=$(window).scrollTop()-t.dataSM("parent-a").offset().top-e.itemH;this.cssTransforms3d&&(i=-(parseFloat(t.css("margin-top"))-i)),$.extend(e,{upEnd:i,downEnd:i+this.getViewportHeight()-e.subH})},menuScrollStop:function(t){return this.scrollTimeout?(cancelAnimationFrame(this.scrollTimeout),this.scrollTimeout=0,t.dataSM("scroll").step=1,!0):void 0},menuScrollTouch:function(t,e){if(e=e.originalEvent,isTouchEvent(e)){var i=this.getTouchPoint(e);if(this.getClosestMenu(i.target)==t[0]){var s=t.dataSM("scroll");if(/(start|down)$/i.test(e.type))this.menuScrollStop(t)?(e.preventDefault(),this.$touchScrollingSub=t):this.$touchScrollingSub=null,this.menuScrollRefreshData(t),$.extend(s,{touchStartY:i.pageY,touchStartTime:e.timeStamp});else if(/move$/i.test(e.type)){var o=void 0!==s.touchY?s.touchY:s.touchStartY;if(void 0!==o&&o!=i.pageY){this.$touchScrollingSub=t;var a=i.pageY>o;void 0!==s.up&&s.up!=a&&$.extend(s,{touchStartY:i.pageY,touchStartTime:e.timeStamp}),$.extend(s,{up:a,touchY:i.pageY}),this.menuScroll(t,!0,Math.abs(i.pageY-o))}e.preventDefault()}else void 0!==s.touchY&&((s.momentum=15*Math.pow(Math.abs(i.pageY-s.touchStartY)/(e.timeStamp-s.touchStartTime),2))&&(this.menuScrollStop(t),this.menuScroll(t),e.preventDefault()),delete s.touchY)}}},menuShow:function(t){if((t.dataSM("beforefirstshowfired")||(t.dataSM("beforefirstshowfired",!0),this.$root.triggerHandler("beforefirstshow.smapi",t[0])!==!1))&&this.$root.triggerHandler("beforeshow.smapi",t[0])!==!1&&(t.dataSM("shown-before",!0),canAnimate&&t.stop(!0,!0),!t.is(":visible"))){var e=t.dataSM("parent-a"),i=this.isCollapsible();if((this.opts.keepHighlighted||i)&&e.addClass("highlighted"),i)t.removeClass("sm-nowrap").css({zIndex:"",width:"auto",minWidth:"",maxWidth:"",top:"",left:"",marginLeft:"",marginTop:""});else{if(t.css("z-index",this.zIndexInc=(this.zIndexInc||this.getStartZIndex())+1),(this.opts.subMenusMinWidth||this.opts.subMenusMaxWidth)&&(t.css({width:"auto",minWidth:"",maxWidth:""}).addClass("sm-nowrap"),this.opts.subMenusMinWidth&&t.css("min-width",this.opts.subMenusMinWidth),this.opts.subMenusMaxWidth)){var s=this.getWidth(t);t.css("max-width",this.opts.subMenusMaxWidth),s>this.getWidth(t)&&t.removeClass("sm-nowrap").css("width",this.opts.subMenusMaxWidth)}this.menuPosition(t)}var o=function(){t.css("overflow","")};i?canAnimate&&this.opts.collapsibleShowFunction?this.opts.collapsibleShowFunction.call(this,t,o):t.show(this.opts.collapsibleShowDuration,o):canAnimate&&this.opts.showFunction?this.opts.showFunction.call(this,t,o):t.show(this.opts.showDuration,o),e.attr("aria-expanded","true"),t.attr({"aria-expanded":"true","aria-hidden":"false"}),this.visibleSubMenus.push(t),this.$root.triggerHandler("show.smapi",t[0])}},popupHide:function(t){this.hideTimeout&&(clearTimeout(this.hideTimeout),this.hideTimeout=0);var e=this;this.hideTimeout=setTimeout(function(){e.menuHideAll()},t?1:this.opts.hideTimeout)},popupShow:function(t,e){if(!this.opts.isPopup)return alert('SmartMenus jQuery Error:\n\nIf you want to show this menu via the "popupShow" method, set the isPopup:true option.'),void 0;if(this.hideTimeout&&(clearTimeout(this.hideTimeout),this.hideTimeout=0),this.$root.dataSM("shown-before",!0),canAnimate&&this.$root.stop(!0,!0),!this.$root.is(":visible")){this.$root.css({left:t,top:e});var i=this,s=function(){i.$root.css("overflow","")};canAnimate&&this.opts.showFunction?this.opts.showFunction.call(this,this.$root,s):this.$root.show(this.opts.showDuration,s),this.visibleSubMenus[0]=this.$root}},refresh:function(){this.destroy(!0),this.init(!0)},rootKeyDown:function(t){if(this.handleEvents())switch(t.keyCode){case 27:var e=this.activatedItems[0];if(e){this.menuHideAll(),e[0].focus();var i=e.dataSM("sub");i&&this.menuHide(i)}break;case 32:var s=$(t.target);if(s.is("a")&&this.handleItemEvents(s)){var i=s.dataSM("sub");i&&!i.is(":visible")&&(this.itemClick({currentTarget:t.target}),t.preventDefault())}}},rootOut:function(t){if(this.handleEvents()&&!this.isTouchMode()&&t.target!=this.$root[0]&&(this.hideTimeout&&(clearTimeout(this.hideTimeout),this.hideTimeout=0),!this.opts.showOnClick||!this.opts.hideOnClick)){var e=this;this.hideTimeout=setTimeout(function(){e.menuHideAll()},this.opts.hideTimeout)}},rootOver:function(t){this.handleEvents()&&!this.isTouchMode()&&t.target!=this.$root[0]&&this.hideTimeout&&(clearTimeout(this.hideTimeout),this.hideTimeout=0)},winResize:function(t){if(this.handleEvents()){if(!("onorientationchange"in window)||"orientationchange"==t.type){var e=this.isCollapsible();this.wasCollapsible&&e||(this.activatedItems.length&&this.activatedItems[this.activatedItems.length-1][0].blur(),this.menuHideAll()),this.wasCollapsible=e}}else if(this.$disableOverlay){var i=this.$root.offset();this.$disableOverlay.css({top:i.top,left:i.left,width:this.$root.outerWidth(),height:this.$root.outerHeight()})}}}}),$.fn.dataSM=function(t,e){return e?this.data(t+"_smartmenus",e):this.data(t+"_smartmenus")},$.fn.removeDataSM=function(t){return this.removeData(t+"_smartmenus")},$.fn.smartmenus=function(options){if("string"==typeof options){var args=arguments,method=options;return Array.prototype.shift.call(args),this.each(function(){var t=$(this).data("smartmenus");t&&t[method]&&t[method].apply(t,args)})}return this.each(function(){var dataOpts=$(this).data("sm-options")||null;if(dataOpts)try{dataOpts=eval("("+dataOpts+")")}catch(e){dataOpts=null,alert('ERROR\n\nSmartMenus jQuery init:\nInvalid "data-sm-options" attribute value syntax.')}new $.SmartMenus(this,$.extend({},$.fn.smartmenus.defaults,options,dataOpts))})},$.fn.smartmenus.defaults={isPopup:!1,mainMenuSubOffsetX:0,mainMenuSubOffsetY:0,subMenusSubOffsetX:0,subMenusSubOffsetY:0,subMenusMinWidth:"10em",subMenusMaxWidth:"20em",subIndicators:!0,subIndicatorsPos:"append",subIndicatorsText:"",scrollStep:30,scrollAccelerate:!0,showTimeout:250,hideTimeout:500,showDuration:0,showFunction:null,hideDuration:0,hideFunction:function(t,e){t.fadeOut(200,e)},collapsibleShowDuration:0,collapsibleShowFunction:function(t,e){t.slideDown(200,e)},collapsibleHideDuration:0,collapsibleHideFunction:function(t,e){t.slideUp(200,e)},showOnClick:!1,hideOnClick:!0,noMouseOver:!1,keepInViewport:!0,keepHighlighted:!0,markCurrentItem:!1,markCurrentTree:!0,rightToLeftSubMenus:!1,bottomToTopSubMenus:!1,collapsibleBehavior:"default"},$}); \ No newline at end of file diff --git a/sw/md_README.html b/sw/md_README.html new file mode 100644 index 0000000000..f4c6c37fe0 --- /dev/null +++ b/sw/md_README.html @@ -0,0 +1,336 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: README</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +</div><!-- top --> +<div id="doc-content"> +<div><div class="header"> + <div class="headertitle"><div class="title">README</div></div> +</div><!--header--> +<div class="contents"> +<div class="textblock"><p><a href="https://github.com/stnolting/neorv32"><img src="docs/figures/neorv32_logo_riscv.png" alt="NEORV32" class="inline"/></a></p> +<h1><a class="anchor" id="autotoc_md0"></a> +The NEORV32 RISC-V Processor</h1> +<p><a href="https://github.com/stnolting/neorv32/releases/tag/nightly"><img src="https://img.shields.io/badge/data%20sheet-PDF-ffbd00?longCache=true&amp;style=flat-square&amp;logo=asciidoctor&amp;colorA=273274" alt="datasheet (pdf)" class="inline"/></a> <a href="https://stnolting.github.io/neorv32"><img src="https://img.shields.io/badge/-HTML-ffbd00?longCache=true&amp;style=flat-square" alt="datasheet (html)" class="inline"/></a> <a href="https://github.com/stnolting/neorv32/releases/tag/nightly"><img src="https://img.shields.io/badge/user%20guide-PDF-ffbd00?longCache=true&amp;style=flat-square&amp;logo=asciidoctor&amp;colorA=273274" alt="userguide (pdf)" class="inline"/></a> <a href="https://stnolting.github.io/neorv32/ug"><img src="https://img.shields.io/badge/-HTML-ffbd00?longCache=true&amp;style=flat-square" alt="userguide (html)" class="inline"/></a> <a href="https://stnolting.github.io/neorv32/sw/files.html"><img src="https://img.shields.io/badge/doxygen-HTML-ffbd00?longCache=true&amp;style=flat-square&amp;logo=Doxygen&amp;colorA=273274" alt="doxygen" class="inline"/></a></p> +<ol type="1"> +<li>Overview<ul> +<li>Key Features</li> +<li>Project Status</li> +</ul> +</li> +<li>Features</li> +<li>FPGA Implementation Results</li> +<li>Performance</li> +<li>**Getting Started** :rocket:</li> +</ol> +<h2><a class="anchor" id="autotoc_md1"></a> +1. Overview</h2> +<p><img src="docs/figures/neorv32_processor.png" alt="neorv32 Overview" class="inline"/></p> +<p>The NEORV32 Processor is a <b>customizable microcontroller-like system on chip (SoC)</b> built around the NEORV32 <a href="https://riscv.org/">RISC-V</a> CPU that is written in <b>platform-independent VHDL</b>. The processor is intended as auxiliary controller in larger SoC designs or as tiny and customized microcontroller that even fits into a Lattice iCE40 UltraPlus low-power &amp; low-density FPGA. The project is intended to work <em>out of the box</em> and targets FPGA / RISC-V beginners as well as advanced users.</p> +<p>Special focus is paid on <b>execution safety</b> to provide defined and predictable behavior at any time. For example, the CPU ensures <em>all</em> memory accesses are properly acknowledged and <em>all</em> invalid/malformed instructions are always detected as such. Whenever an unexpected state occurs the application software is informed via <em>precise</em> and resumable hardware exceptions.</p> +<ul> +<li>:recycle: Looking for an <b>all-Verilog</b> version? Have a look at <a href="https://github.com/stnolting/neorv32-verilog">neorv32-verilog</a>.</li> +<li>:heavy_check_mark: Continuous integration to check for regressions (including RISC-V ISA compatibility check using <b>RISCOF</b>).</li> +<li>:open_file_folder: <a href="https://github.com/stnolting/neorv32-setups">Exemplary setups</a> and <a href="https://github.com/stnolting/neorv32-setups/blob/main/README.md#Community-Projects">community projects</a> targeting various FPGA boards and toolchains to get started.</li> +<li>:package: The entire processor is also available as <a href="https://stnolting.github.io/neorv32/ug/#_packaging_the_processor_as_vivado_ip_block">Vivado IP Block</a>.</li> +<li>:kite: Support for <a href="https://github.com/stnolting/neorv32-freertos">FreeRTOS</a>, <a href="https://docs.zephyrproject.org/latest/boards/riscv/neorv32/doc/index.html">Zephyr OS</a> and <a href="https://github.com/enjoy-digital/litex/wiki/CPUs#risc-v---neorv32">LiteX</a> SoC Builder Framework.</li> +<li>:desktop_computer: Pre-configured <a href="https://stnolting.github.io/neorv32/ug/#_eclipse_ide">Eclipse project</a> for developing and debugging code using an IDE.</li> +<li>:label: The project's change log is available in <a href="https://github.com/stnolting/neorv32/blob/main/CHANGELOG.md">CHANGELOG.md</a>.</li> +<li>:rocket: Check out the quick links below and the <a href="https://stnolting.github.io/neorv32/ug/"><em>User Guide</em></a> to get started setting up <em>your</em> NEORV32 processor!</li> +<li>:books: For detailed information see the <a href="https://stnolting.github.io/neorv32/">NEORV32 online documentation</a>.</li> +<li>:interrobang: Want to know more? Check out the <a href="https://stnolting.github.io/neorv32/#_rationale">project's rationale</a>.</li> +</ul> +<p>Feel free to open a new <a href="https://github.com/stnolting/neorv32/issues">issue</a> or start a new <a href="https://github.com/stnolting/neorv32/discussions">discussion</a> if you have questions, comments, ideas, feedback or if something is not working as expected. See how to <a href="https://github.com/stnolting/neorv32/blob/main/CONTRIBUTING.md">contribute</a>.</p> +<h3><a class="anchor" id="autotoc_md2"></a> +Key Features</h3> +<ul class="check"> +<li class="checked">all-in-one package: <b>CPU</b> + <b>SoC</b> + <b>Software Framework &amp; Tooling</b></li> +</ul> +<ul class="check"> +<li class="checked">completely described in behavioral, platform-independent VHDL - <b>no</b> platform-specific primitives, macros, attributes, etc.; an all-Verilog "version" is also <a href="https://github.com/stnolting/neorv32-verilog">available</a></li> +</ul> +<ul class="check"> +<li class="checked">extensive configuration options for adapting the processor to the requirements of the application</li> +</ul> +<ul class="check"> +<li class="checked">highly <a href="https://stnolting.github.io/neorv32/ug/#_comparative_summary">extensible hardware</a> - on CPU, processor and system level</li> +</ul> +<ul class="check"> +<li class="checked">aims to be as small as possible while being as RISC-V-compliant as possible - with a reasonable area-vs-performance trade-off</li> +</ul> +<ul class="check"> +<li class="checked">FPGA friendly (e.g. <em>all</em> internal memories can be mapped to block RAM - including the CPU's register file)</li> +</ul> +<ul class="check"> +<li class="checked">optimized for high clock frequencies to ease integration / timing closure</li> +</ul> +<ul class="check"> +<li class="checked">from zero to _"hello world!"_ - completely open source and documented</li> +</ul> +<ul class="check"> +<li class="checked">easy to use even for FPGA / RISC-V starters – intended to work <em>out of the box</em></li> +</ul> +<h3><a class="anchor" id="autotoc_md3"></a> +Project Status</h3> +<p><a href="https://github.com/stnolting/neorv32/releases"><img src="https://img.shields.io/github/v/release/stnolting/neorv32?longCache=true&amp;style=flat-square&amp;logo=GitHub" alt="release" class="inline"/></a> <a href="https://github.com/stnolting/neorv32/activity"><img src="https://img.shields.io/github/commits-since/stnolting/neorv32/latest?longCache=true&amp;style=flat-square&amp;logo=GitHub" alt="commits-since-latest-release" class="inline"/></a></p> +<table class="markdownTable"> +<tr class="markdownTableHead"> +<th class="markdownTableHeadLeft">Task / Subproject </th><th class="markdownTableHeadLeft">Repository </th><th class="markdownTableHeadLeft">CI Status </th></tr> +<tr class="markdownTableRowOdd"> +<td class="markdownTableBodyLeft">GitHub pages (docs) </td><td class="markdownTableBodyLeft"><a href="https://github.com/stnolting/neorv32">neorv32</a> </td><td class="markdownTableBodyLeft"><a href="https://stnolting.github.io/neorv32"><img src="https://img.shields.io/website.svg?label=stnolting.github.io%2Fneorv32&amp;longCache=true&amp;style=flat-square&amp;url=http%3A%2F%2Fstnolting.github.io%2Fneorv32%2Findex.html&amp;logo=GitHub" alt="GitHub Pages" style="pointer-events: none;" class="inline"/></a> </td></tr> +<tr class="markdownTableRowEven"> +<td class="markdownTableBodyLeft">Build documentation </td><td class="markdownTableBodyLeft"><a href="https://github.com/stnolting/neorv32">neorv32</a> </td><td class="markdownTableBodyLeft"><a href="https://github.com/stnolting/neorv32/actions?query=workflow%3ADocumentation"><img src="https://img.shields.io/github/actions/workflow/status/stnolting/neorv32/Documentation.yml?branch=main&amp;longCache=true&amp;style=flat-square&amp;label=Documentation&amp;logo=Github%20Actions&amp;logoColor=fff" alt="Documentation" class="inline"/></a> </td></tr> +<tr class="markdownTableRowOdd"> +<td class="markdownTableBodyLeft">Processor verification </td><td class="markdownTableBodyLeft"><a href="https://github.com/stnolting/neorv32">neorv32</a> </td><td class="markdownTableBodyLeft"><a href="https://github.com/stnolting/neorv32/actions?query=workflow%3AProcessor"><img src="https://img.shields.io/github/actions/workflow/status/stnolting/neorv32/Processor.yml?branch=main&amp;longCache=true&amp;style=flat-square&amp;label=Processor%20Check&amp;logo=Github%20Actions&amp;logoColor=fff" alt="Processor" class="inline"/></a> </td></tr> +<tr class="markdownTableRowEven"> +<td class="markdownTableBodyLeft">RISCOF core verification </td><td class="markdownTableBodyLeft"><a href="https://github.com/stnolting/neorv32-riscof">neorv32-riscof</a> </td><td class="markdownTableBodyLeft"><a href="https://github.com/stnolting/neorv32-riscof/actions/workflows/main.yml"><img src="https://img.shields.io/github/actions/workflow/status/stnolting/neorv32-riscof/main.yml?branch=main&amp;longCache=true&amp;style=flat-square&amp;label=neorv32-riscof&amp;logo=Github%20Actions&amp;logoColor=fff" alt="neorv32-riscof" class="inline"/></a> </td></tr> +<tr class="markdownTableRowOdd"> +<td class="markdownTableBodyLeft">FPGA implementations </td><td class="markdownTableBodyLeft"><a href="https://github.com/stnolting/neorv32-setups">neorv32-setups</a> </td><td class="markdownTableBodyLeft"><a href="https://github.com/stnolting/neorv32-setups/actions?query=workflow%3AImplementation"><img src="https://img.shields.io/github/actions/workflow/status/stnolting/neorv32-setups/Implementation.yml?branch=main&amp;longCache=true&amp;style=flat-square&amp;label=Implementation&amp;logo=Github%20Actions&amp;logoColor=fff" alt="Implementation" class="inline"/></a> </td></tr> +<tr class="markdownTableRowEven"> +<td class="markdownTableBodyLeft">All-Verilog version </td><td class="markdownTableBodyLeft"><a href="https://github.com/stnolting/neorv32-verilog">neorv32-verilog</a> </td><td class="markdownTableBodyLeft"><a href="https://github.com/stnolting/neorv32-verilog/actions/workflows/main.yml"><img src="https://img.shields.io/github/actions/workflow/status/stnolting/neorv32-verilog/main.yml?branch=main&amp;longCache=true&amp;style=flat-square&amp;label=neorv32-verilog&amp;logo=Github%20Actions&amp;logoColor=fff" alt="neorv32-verilog" class="inline"/></a> </td></tr> +<tr class="markdownTableRowOdd"> +<td class="markdownTableBodyLeft">FreeRTOS port </td><td class="markdownTableBodyLeft"><a href="https://github.com/stnolting/neorv32-freertos">neorv32-freertos</a> </td><td class="markdownTableBodyLeft"><a href="https://github.com/stnolting/neorv32-freertos/actions/workflows/main.yml"><img src="https://img.shields.io/github/actions/workflow/status/stnolting/neorv32-freertos/main.yml?branch=main&amp;longCache=true&amp;style=flat-square&amp;label=neorv32-freertos%20sim&amp;logo=Github%20Actions&amp;logoColor=fff" alt="neorv32-freertos" class="inline"/></a> </td></tr> +<tr class="markdownTableRowEven"> +<td class="markdownTableBodyLeft">Prebuilt GCC toolchains </td><td class="markdownTableBodyLeft"><a href="https://github.com/stnolting/riscv-gcc-prebuilt">riscv-gcc-prebuilt</a> </td><td class="markdownTableBodyLeft"><a href="https://github.com/stnolting/riscv-gcc-prebuilt/actions/workflows/main.yml"><img src="https://img.shields.io/github/actions/workflow/status/stnolting/riscv-gcc-prebuilt/main.yml?branch=main&amp;longCache=true&amp;style=flat-square&amp;label=Prebuilt%20Toolchains&amp;logo=Github%20Actions&amp;logoColor=fff" alt="Prebuilt_Toolchains" class="inline"/></a> </td></tr> +</table> +<p>The processor passes the official RISC-V architecture tests to ensure compatibility with the RISC-V ISA specs., which is checked by the <a href="https://github.com/stnolting/neorv32-riscof">neorv32-riscof</a> repository. It can successfully run <em>any</em> C program (for example from the <a href="https://github.com/stnolting/neorv32/tree/main/sw/example"><code>sw/example</code></a> folder) including CoreMark and FreeRTOS and can be synthesized for <em>any</em> target technology - <a href="https://github.com/stnolting/neorv32-setups">tested</a> on Intel, AMD and Lattice FPGAs. The conversion into a plain-Verilog netlist module is automatically checked by the <a href="https://github.com/stnolting/neorv32-verilog">neorv32-verilog</a> repository.</p> +<h2><a class="anchor" id="autotoc_md4"></a> +2. Features</h2> +<p>The NEORV32 Processor provides a full-featured microcontroller-like SoC build around the NEORV32 CPU. By using generics the design is highly configurable and allows a flexible customization to tailor the setup according to your needs. Note that all of the following SoC modules are entirely <em>optional</em>.</p> +<p><b>CPU Core</b></p> +<ul> +<li><a href="https://github.com/riscv/riscv-isa-manual/blob/master/marchid.md"><img src="https://img.shields.io/badge/RISC--V%20Architecture%20ID-19-000000.svg?longCache=true&amp;style=flat-square&amp;logo=riscv&amp;colorA=273274&amp;colorB=fbb517" alt="RISCV-ARCHID" style="pointer-events: none;" class="inline"/></a></li> +<li>32-bit little-endian RISC-V single-core, pipelined/multi-cycle modified Harvard architecture</li> +<li>configurable ISA extensions: \ <code>RV32</code> [<a href="https://stnolting.github.io/neorv32/#_i_isa_extension"><code>I</code></a>/<a href="https://stnolting.github.io/neorv32/#_e_isa_extension"><code>E</code></a>] [<a href="https://stnolting.github.io/neorv32/#_m_isa_extension"><code>M</code></a>] [<a href="https://stnolting.github.io/neorv32/#_a_isa_extension"><code>A</code></a>] [<a href="https://stnolting.github.io/neorv32/#_c_isa_extension"><code>C</code></a>] [<a href="https://stnolting.github.io/neorv32/#_b_isa_extension"><code>B</code></a>] [<a href="https://stnolting.github.io/neorv32/#_u_isa_extension"><code>U</code></a>] [<a href="https://stnolting.github.io/neorv32/#_x_isa_extension"><code>X</code></a>] [<a href="https://stnolting.github.io/neorv32/#_zicsr_isa_extension"><code>Zicsr</code></a>] [<a href="https://stnolting.github.io/neorv32/#_zicntr_isa_extension"><code>Zicntr</code></a>] [<a href="https://stnolting.github.io/neorv32/#_zicond_isa_extension"><code>Zicond</code></a>] [<a href="https://stnolting.github.io/neorv32/#_zihpm_isa_extension"><code>Zihpm</code></a>] [<a href="https://stnolting.github.io/neorv32/#_zifencei_isa_extension"><code>Zifencei</code></a>] [<a href="https://stnolting.github.io/neorv32/#_zfinx_isa_extension"><code>Zfinx</code></a>] [<a href="https://stnolting.github.io/neorv32/#_zmmul_isa_extension"><code>Zmmul</code></a>] [<a href="https://stnolting.github.io/neorv32/#_zxcfu_isa_extension"><code>Zxcfu</code></a>] [<a href="https://stnolting.github.io/neorv32/#_smpmp_isa_extension"><code>Smpmp</code></a>] [<a href="https://stnolting.github.io/neorv32/#_sdext_isa_extension"><code>Sdext</code></a>] [<a href="https://stnolting.github.io/neorv32/#_sdtrig_isa_extension"><code>Sdtrig</code></a>]</li> +<li>compatible to subsets of the RISC-V <em>Unprivileged ISA Specification</em> (<a href="https://github.com/stnolting/neorv32/blob/main/docs/references/riscv-spec.pdf">pdf</a>) and <em>Privileged Architecture Specification</em> (<a href="https://github.com/stnolting/neorv32/blob/main/docs/references/riscv-privileged.pdf">pdf</a>).</li> +<li><code>machine</code> and <code>user</code> privilege modes</li> +<li>implements <b>all</b> standard RISC-V exceptions and interrupts + 16 fast interrupt request channels as NEORV32-specific extension</li> +<li>custom functions unit (<a href="https://stnolting.github.io/neorv32/#_custom_functions_unit_cfu">CFU</a> as <code>Zxcfu</code> ISA extension) for <b>custom RISC-V instructions</b>;</li> +<li><em>intrinsic</em> libraries for CPU extensions that are not yet supported by GCC</li> +</ul> +<p><b>Memories</b></p> +<ul> +<li>processor-internal data and instruction memories (<a href="https://stnolting.github.io/neorv32/#_data_memory_dmem">DMEM</a> / <a href="https://stnolting.github.io/neorv32/#_instruction_memory_imem">IMEM</a>) &amp; caches (<a href="https://stnolting.github.io/neorv32/#_processor_internal_instruction_cache_icache">iCACHE</a> and <a href="https://stnolting.github.io/neorv32/#_processor_internal_data_cache_dcache">dCACHE</a>)</li> +<li>pre-installed bootloader (<a href="https://stnolting.github.io/neorv32/#_bootloader_rom_bootrom">BOOTLDROM</a>) with serial user interface; allows booting application code via UART or from external SPI flash</li> +</ul> +<p><b>Timers and Counters</b></p> +<ul> +<li>64-bit machine timer (<a href="https://stnolting.github.io/neorv32/#_machine_system_timer_mtime">MTIME</a>), RISC-V spec. compatible</li> +<li>32-bit general purpose timer (<a href="https://stnolting.github.io/neorv32/#_general_purpose_timer_gptmr">GPTMR</a>)</li> +<li>watchdog timer (<a href="https://stnolting.github.io/neorv32/#_watchdog_timer_wdt">WDT</a>)</li> +</ul> +<p><b>Input / Output</b></p> +<ul> +<li>standard serial interfaces (<a href="https://stnolting.github.io/neorv32/#_primary_universal_asynchronous_receiver_and_transmitter_uart0">UART</a>, <a href="https://stnolting.github.io/neorv32/#_serial_peripheral_interface_controller_spi">SPI</a> (SPI host), <a href="https://stnolting.github.io/neorv32/#_serial_data_interface_controller_sdi">SDI</a> (SPI device), <a href="https://stnolting.github.io/neorv32/#_two_wire_serial_interface_controller_twi">TWI/I²C</a>, <a href="https://stnolting.github.io/neorv32/#_one_wire_serial_interface_controller_onewire">ONEWIRE/1-Wire</a>)</li> +<li>general purpose IOs (<a href="https://stnolting.github.io/neorv32/#_general_purpose_input_and_output_port_gpio">GPIO</a>) and <a href="https://stnolting.github.io/neorv32/#_pulse_width_modulation_controller_pwm">PWM</a></li> +<li>smart LED interface (<a href="https://stnolting.github.io/neorv32/#_smart_led_interface_neoled">NEOLED</a>) to directly control NeoPixel(TM) LEDs</li> +</ul> +<p><b>SoC Connectivity</b></p> +<ul> +<li>32-bit external bus interface - Wishbone b4 compatible (<a href="https://stnolting.github.io/neorv32/#_processor_external_bus_interface_xbus">XBUS</a>) with optional cache (XCACHE); <a href="https://github.com/stnolting/neorv32/blob/main/rtl/system_integration">wrappers</a> for AXI4-Lite and Avalon-MM host interfaces</li> +<li>stream link interface with independent RX and TX channels - AXI4-Stream compatible (<a href="https://stnolting.github.io/neorv32/#_stream_link_interface_slink">SLINK</a>)</li> +<li>external interrupts controller with up to 32 channels (<a href="https://stnolting.github.io/neorv32/#_external_interrupt_controller_xirq">XIRQ</a>)</li> +</ul> +<p><b>Advanced</b></p> +<ul> +<li>true-random number generator (<a href="https://stnolting.github.io/neorv32/#_true_random_number_generator_trng">TRNG</a>) based on the <a href="https://github.com/stnolting/neoTRNG">neoTRNG</a></li> +<li>execute-in-place module (<a href="https://stnolting.github.io/neorv32/#_execute_in_place_module_xip">XIP</a>) to execute code right out of a SPI flash</li> +<li>custom functions subsystem (<a href="https://stnolting.github.io/neorv32/#_custom_functions_subsystem_cfs">CFS</a>) for custom tightly-coupled co-processors, accelerators or interfaces</li> +<li>direct memory access controller (<a href="https://stnolting.github.io/neorv32/#_direct_memory_access_controller_dma">DMA</a>) for CPU-independent data transfers and conversions</li> +<li>cyclic redundancy check unit (<a href="https://stnolting.github.io/neorv32/#_cyclic_redundancy_check_crc">CRC</a>) to test data integrity (CRC8/16/32)</li> +</ul> +<p><b>Debugging</b></p> +<ul> +<li>on-chip debugger (<a href="https://stnolting.github.io/neorv32/#_on_chip_debugger_ocd">OCD</a>) accessible via standard JTAG interface</li> +<li>compatible to the "Minimal RISC-V Debug Specification Version 1.0"</li> +<li>compatible with <b>OpenOCD</b>, <b>GDB</b> and <b>Segger Embedded Studio</b></li> +<li>RISC-V <a href="https://stnolting.github.io/neorv32/#_trigger_module">trigger module</a> for hardware-assisted breakpoints</li> +</ul> +<h2><a class="anchor" id="autotoc_md5"></a> +3. FPGA Implementation Results</h2> +<p>Implementation results for <b>exemplary CPU configurations</b> generated for an Intel Cyclone IV <code>EP4CE22F17C6</code> FPGA using Intel Quartus Prime Lite 21.1 (no timing constrains, <em>balanced optimization</em>, f_max from <em>Slow 1200mV 0C Model</em>).</p> +<table class="markdownTable"> +<tr class="markdownTableHead"> +<th class="markdownTableHeadLeft">CPU Configuration (version <a href="https://github.com/stnolting/neorv32/blob/main/CHANGELOG.md">1.7.8.5</a>) </th><th class="markdownTableHeadCenter">LEs </th><th class="markdownTableHeadCenter">FFs </th><th class="markdownTableHeadCenter">Memory bits </th><th class="markdownTableHeadCenter">DSPs </th><th class="markdownTableHeadCenter">f_max </th></tr> +<tr class="markdownTableRowOdd"> +<td class="markdownTableBodyLeft"><code>rv32i_Zicsr</code> </td><td class="markdownTableBodyCenter">1223 </td><td class="markdownTableBodyCenter">607 </td><td class="markdownTableBodyCenter">1024 </td><td class="markdownTableBodyCenter">0 </td><td class="markdownTableBodyCenter">130 MHz </td></tr> +<tr class="markdownTableRowEven"> +<td class="markdownTableBodyLeft"><code>rv32i_Zicsr_Zicntr</code> </td><td class="markdownTableBodyCenter">1578 </td><td class="markdownTableBodyCenter">773 </td><td class="markdownTableBodyCenter">1024 </td><td class="markdownTableBodyCenter">0 </td><td class="markdownTableBodyCenter">130 MHz </td></tr> +<tr class="markdownTableRowOdd"> +<td class="markdownTableBodyLeft"><code>rv32imc_Zicsr_Zicntr</code> </td><td class="markdownTableBodyCenter">2338 </td><td class="markdownTableBodyCenter">992 </td><td class="markdownTableBodyCenter">1024 </td><td class="markdownTableBodyCenter">0 </td><td class="markdownTableBodyCenter">130 MHz </td></tr> +</table> +<p>An incremental list of CPU extensions and processor modules can be found in the <a href="https://stnolting.github.io/neorv32/#_fpga_implementation_results">Data Sheet: FPGA Implementation Results</a>.</p> +<h2><a class="anchor" id="autotoc_md6"></a> +4. Performance</h2> +<p>The NEORV32 CPU is based on a two-stages pipelined/multi-cycle architecture (fetch and execute). The following table shows the performance results (scores and average CPI) for exemplary CPU configurations (no caches) executing 2000 iterations of the <a href="https://github.com/stnolting/neorv32/blob/main/sw/example/coremark">CoreMark</a> CPU benchmark (using plain GCC10 rv32i built-in libraries only!).</p> +<table class="markdownTable"> +<tr class="markdownTableHead"> +<th class="markdownTableHeadLeft">CPU Configuration (version <a href="https://github.com/stnolting/neorv32/blob/main/CHANGELOG.md">1.5.7.10</a>) </th><th class="markdownTableHeadCenter">CoreMark Score </th></tr> +<tr class="markdownTableRowOdd"> +<td class="markdownTableBodyLeft"><em>small</em> (<code>rv32i_Zicsr_Zifencei</code>) </td><td class="markdownTableBodyCenter">33.89 </td></tr> +<tr class="markdownTableRowEven"> +<td class="markdownTableBodyLeft"><em>medium</em> (<code>rv32imc_Zicsr_Zifencei</code>) </td><td class="markdownTableBodyCenter">62.50 </td></tr> +<tr class="markdownTableRowOdd"> +<td class="markdownTableBodyLeft"><em>performance</em> (<code>rv32imc_Zicsr_Zifencei</code> + perf. options) </td><td class="markdownTableBodyCenter">95.23 </td></tr> +</table> +<p>More information regarding the CPU performance can be found in the <a href="https://stnolting.github.io/neorv32/#_cpu_performance">Data Sheet: CPU Performance</a>. The CPU &amp; SoC provide further "tuning" options to optimize the design for maximum performance, maximum clock speed, minimal area or minimal power consumption: <a href="https://stnolting.github.io/neorv32/ug/#_application_specific_processor_configuration">User Guide: Application-Specific Processor Configuration</a></p> +<h2><a class="anchor" id="autotoc_md7"></a> +5. Getting Started</h2> +<p>This overview provides some <em>quick links</em> to the most important sections of the <a href="https://stnolting.github.io/neorv32">online Data Sheet</a> and the <a href="https://stnolting.github.io/neorv32/ug">online User Guide</a>.</p> +<h3><a class="anchor" id="autotoc_md8"></a> +:mag: <a href="https://stnolting.github.io/neorv32/#_overview">NEORV32 Project</a> - An Introduction</h3> +<ul> +<li><a href="https://stnolting.github.io/neorv32/#_rationale">Rationale</a> - why? how come? what for?</li> +<li><a href="https://stnolting.github.io/neorv32/#_project_key_features">Key Features</a> - what makes it special</li> +<li><a href="https://stnolting.github.io/neorv32/#_project_folder_structure">Structure</a> - folders, RTL files and compile order</li> +<li><a href="https://stnolting.github.io/neorv32/#_fpga_implementation_results">Metrics</a> - FPGA implementation and performance evaluation</li> +</ul> +<h3><a class="anchor" id="autotoc_md9"></a> +:desktop_computer: <a href="https://stnolting.github.io/neorv32/#_neorv32_processor_soc">NEORV32 Processor</a> - The SoC</h3> +<ul> +<li><a href="https://stnolting.github.io/neorv32/#_processor_top_entity_signals">Top Entity - Signals</a> - how to connect to the processor</li> +<li><a href="https://stnolting.github.io/neorv32/#_processor_top_entity_generics">Top Entity - Generics</a> - processor/CPU configuration options</li> +<li><a href="https://stnolting.github.io/neorv32/#_address_space">Address Space</a> - memory layout and boot configurations</li> +<li><a href="https://stnolting.github.io/neorv32/#_processor_internal_modules">SoC Modules</a> - IO/peripheral modules and memories</li> +<li><a href="https://stnolting.github.io/neorv32/#_on_chip_debugger_ocd">On-Chip Debugger</a> - in-system debugging of the processor via JTAG</li> +</ul> +<h3><a class="anchor" id="autotoc_md10"></a> +:abacus: <a href="https://stnolting.github.io/neorv32/#_neorv32_central_processing_unit_cpu">NEORV32 CPU</a> - The Core</h3> +<ul> +<li><a href="https://stnolting.github.io/neorv32/#_risc_v_compatibility">RISC-V Compatibility</a> - what is compatible to the specs and what is not</li> +<li><a href="https://stnolting.github.io/neorv32/#_architecture">Architecture</a> - a look under the hood</li> +<li><a href="https://stnolting.github.io/neorv32/#_full_virtualization">Full Virtualization</a> - execution safety</li> +<li><a href="https://stnolting.github.io/neorv32/#_instruction_sets_and_extensions">ISA and Extensions</a> - available (RISC-V) ISA extensions</li> +<li><a href="https://stnolting.github.io/neorv32/#_control_and_status_registers_csrs">CSRs</a> - control and status registers</li> +<li><a href="https://stnolting.github.io/neorv32/#_traps_exceptions_and_interrupts">Traps</a> - interrupts and exceptions</li> +</ul> +<h3><a class="anchor" id="autotoc_md11"></a> +:floppy_disk: <a href="https://stnolting.github.io/neorv32/#_software_framework">Software Framework</a> - The Software Ecosystem</h3> +<ul> +<li><a href="https://github.com/stnolting/neorv32/tree/main/sw/example">Example Programs</a> - examples how to use the processor's IO/peripheral modules</li> +<li><a href="https://stnolting.github.io/neorv32/#_core_libraries">Core Libraries</a> - high-level functions for accessing the processor's peripherals</li> +<li><a href="https://stnolting.github.io/neorv32/sw/files.html">Software Framework Documentation</a> - <em>doxygen</em>-based</li> +<li><a href="https://stnolting.github.io/neorv32/#_application_makefile">Application Makefile</a> - turning <em>your</em> application into an executable</li> +<li><a href="https://stnolting.github.io/neorv32/#_bootloader">Bootloader</a> - the build-in NEORV32 bootloader</li> +<li><a href="https://stnolting.github.io/neorv32/#_executable_image_format">Image Generator</a> - create (FPGA) memory initialization files from your application</li> +</ul> +<h3><a class="anchor" id="autotoc_md12"></a> +:rocket: <a href="https://stnolting.github.io/neorv32/ug/">User Guide</a> - Getting Started!</h3> +<ul> +<li><a href="https://stnolting.github.io/neorv32/ug/#_software_toolchain_setup">Toolchain Setup</a> - install and setup the RISC-V GCC toolchain</li> +<li><a href="https://stnolting.github.io/neorv32/ug/#_general_hardware_setup">General Hardware Setup</a> - setup a new NEORV32 FPGA project</li> +<li><a href="https://stnolting.github.io/neorv32/ug/#_general_software_framework_setup">General Software Setup</a> - configure the software framework</li> +<li><a href="https://stnolting.github.io/neorv32/ug/#_application_program_compilation">Application Compilation</a> - compile an application using <code>make</code></li> +<li><a href="https://stnolting.github.io/neorv32/ug/#_uploading_and_starting_of_a_binary_executable_image_via_uart">Upload via Bootloader</a> - upload and execute executables</li> +<li><a href="https://stnolting.github.io/neorv32/ug/#_application_specific_processor_configuration">Application-Specific Processor Configuration</a> - tailor the processor to your needs</li> +<li><a href="https://stnolting.github.io/neorv32/ug/#_adding_custom_hardware_modules">Adding Custom Hardware Modules</a> - add <em>your</em> custom hardware</li> +<li><a href="https://stnolting.github.io/neorv32/ug/#_debugging_using_the_on_chip_debugger">Debugging via the On-Chip Debugger</a> - step through code <em>online</em> and <em>in-system</em></li> +<li><a href="https://stnolting.github.io/neorv32/ug/#_simulating_the_processor">Simulation</a> - simulate the whole SoC</li> +<li><a href="https://stnolting.github.io/neorv32/ug/#_litex_soc_builder_support">LiteX Integration</a> - build a SoC using NEORV32 + <a href="https://github.com/enjoy-digital/litex">LiteX</a></li> +<li><a href="https://stnolting.github.io/neorv32/ug/#_neorv32_in_verilog">Convert to Verilog</a> - turn the NEORV32 into an all-Verilog design</li> +<li><a href="https://stnolting.github.io/neorv32/ug/#_packaging_the_processor_as_vivado_ip_block">Package as Vivado IP block</a> - turn the entire processor into an interactive AMD Vivado IP block</li> +<li><a href="https://stnolting.github.io/neorv32/ug/#_eclipse_ide">Using Eclipse</a> - use the Eclipse IDE for developing and debugging of applications</li> +</ul> +<h3><a class="anchor" id="autotoc_md13"></a> +:copyright: Legal</h3> +<p><a href="https://github.com/stnolting/neorv32/blob/main/LICENSE"><img src="https://img.shields.io/github/license/stnolting/neorv32?longCache=true&amp;style=flat" alt="license" class="inline"/></a> <a href="https://doi.org/10.5281/zenodo.5018888"><img src="https://zenodo.org/badge/DOI/10.5281/zenodo.5018888.svg" alt="DOI" style="pointer-events: none;" class="inline"/></a></p> +<ul> +<li><a href="https://stnolting.github.io/neorv32/#_legal">Overview</a> - license, disclaimer, limitation of liability for external links, proprietary notice, etc.</li> +<li><a href="https://stnolting.github.io/neorv32/#_citing">Citing</a> - citing information</li> +</ul> +<p>This is an open-source project that is free of charge. Use this project in any way you like (as long as it complies to the permissive <a href="https://github.com/stnolting/neorv32/blob/main/LICENSE">license</a>). Please cite it appropriately. :+1:</p> +<h3><a class="anchor" id="autotoc_md14"></a> +:email: Contact</h3> +<p>Please use GitHub <a href="https://github.com/stnolting/neorv32/issues">Issues</a> and <a href="https://github.com/stnolting/neorv32/discussions">Discussions</a> for all kind of requests, issues, ideas, questions, etc. If you would like to contact <a href="https://github.com/stnolting">me</a> directly check out the <a href="https://stnolting.github.io/neorv32/#_about">About</a> section.</p> +<hr /> +<p>**:heart: A big shout-out to the community and all the <a href="https://github.com/stnolting/neorv32/graphs/contributors">contributors</a>! This project would not be where it is without them.** </p> +</div></div><!-- contents --> +</div><!-- PageDoc --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/menu.js b/sw/menu.js new file mode 100644 index 0000000000..0fd1e99013 --- /dev/null +++ b/sw/menu.js @@ -0,0 +1,134 @@ +/* + @licstart The following is the entire license notice for the JavaScript code in this file. + + The MIT License (MIT) + + Copyright (C) 1997-2020 by Dimitri van Heesch + + Permission is hereby granted, free of charge, to any person obtaining a copy of this software + and associated documentation files (the "Software"), to deal in the Software without restriction, + including without limitation the rights to use, copy, modify, merge, publish, distribute, + sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is + furnished to do so, subject to the following conditions: + + The above copyright notice and this permission notice shall be included in all copies or + substantial portions of the Software. + + THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING + BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND + NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, + DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. + + @licend The above is the entire license notice for the JavaScript code in this file + */ +function initMenu(relPath,searchEnabled,serverSide,searchPage,search,treeview) { + function makeTree(data,relPath) { + let result=''; + if ('children' in data) { + result+='<ul>'; + for (let i in data.children) { + let url; + const link = data.children[i].url; + if (link.substring(0,1)=='^') { + url = link.substring(1); + } else { + url = relPath+link; + } + result+='<li><a href="'+url+'">'+ + data.children[i].text+'</a>'+ + makeTree(data.children[i],relPath)+'</li>'; + } + result+='</ul>'; + } + return result; + } + let searchBoxHtml; + if (searchEnabled) { + if (serverSide) { + searchBoxHtml='<div id="MSearchBox" class="MSearchBoxInactive">'+ + '<div class="left">'+ + '<form id="FSearchBox" action="'+relPath+searchPage+ + '" method="get"><span id="MSearchSelectExt">&#160;</span>'+ + '<input type="text" id="MSearchField" name="query" value="" placeholder="'+search+ + '" size="20" accesskey="S" onfocus="searchBox.OnSearchFieldFocus(true)"'+ + ' onblur="searchBox.OnSearchFieldFocus(false)"/>'+ + '</form>'+ + '</div>'+ + '<div class="right"></div>'+ + '</div>'; + } else { + searchBoxHtml='<div id="MSearchBox" class="MSearchBoxInactive">'+ + '<span class="left">'+ + '<span id="MSearchSelect" onmouseover="return searchBox.OnSearchSelectShow()"'+ + ' onmouseout="return searchBox.OnSearchSelectHide()">&#160;</span>'+ + '<input type="text" id="MSearchField" value="" placeholder="'+search+ + '" accesskey="S" onfocus="searchBox.OnSearchFieldFocus(true)" '+ + 'onblur="searchBox.OnSearchFieldFocus(false)" '+ + 'onkeyup="searchBox.OnSearchFieldChange(event)"/>'+ + '</span>'+ + '<span class="right"><a id="MSearchClose" '+ + 'href="javascript:searchBox.CloseResultsWindow()">'+ + '<img id="MSearchCloseImg" border="0" src="'+relPath+ + 'search/close.svg" alt=""/></a>'+ + '</span>'+ + '</div>'; + } + } + + $('#main-nav').before('<div class="sm sm-dox"><input id="main-menu-state" type="checkbox"/>'+ + '<label class="main-menu-btn" for="main-menu-state">'+ + '<span class="main-menu-btn-icon"></span> '+ + 'Toggle main menu visibility</label>'+ + '<span id="searchBoxPos1" style="position:absolute;right:8px;top:8px;height:36px;"></span>'+ + '</div>'); + $('#main-nav').append(makeTree(menudata,relPath)); + $('#main-nav').children(':first').addClass('sm sm-dox').attr('id','main-menu'); + if (searchBoxHtml) { + $('#main-menu').append('<li id="searchBoxPos2" style="float:right"></li>'); + } + const $mainMenuState = $('#main-menu-state'); + let prevWidth = 0; + if ($mainMenuState.length) { + const initResizableIfExists = function() { + if (typeof initResizable==='function') initResizable(treeview); + } + // animate mobile menu + $mainMenuState.change(function() { + const $menu = $('#main-menu'); + let options = { duration: 250, step: initResizableIfExists }; + if (this.checked) { + options['complete'] = () => $menu.css('display', 'block'); + $menu.hide().slideDown(options); + } else { + options['complete'] = () => $menu.css('display', 'none'); + $menu.show().slideUp(options); + } + }); + // set default menu visibility + const resetState = function() { + const $menu = $('#main-menu'); + const newWidth = $(window).outerWidth(); + if (newWidth!=prevWidth) { + if ($(window).outerWidth()<768) { + $mainMenuState.prop('checked',false); $menu.hide(); + $('#searchBoxPos1').html(searchBoxHtml); + $('#searchBoxPos2').hide(); + } else { + $menu.show(); + $('#searchBoxPos1').empty(); + $('#searchBoxPos2').html(searchBoxHtml); + $('#searchBoxPos2').show(); + } + if (typeof searchBox!=='undefined') { + searchBox.CloseResultsWindow(); + } + prevWidth = newWidth; + } + } + $(window).ready(function() { resetState(); initResizableIfExists(); }); + $(window).resize(resetState); + } + $('#main-menu').smartmenus(); +} +/* @license-end */ diff --git a/sw/menudata.js b/sw/menudata.js new file mode 100644 index 0000000000..528d7cc667 --- /dev/null +++ b/sw/menudata.js @@ -0,0 +1,149 @@ +/* + @licstart The following is the entire license notice for the JavaScript code in this file. + + The MIT License (MIT) + + Copyright (C) 1997-2020 by Dimitri van Heesch + + Permission is hereby granted, free of charge, to any person obtaining a copy of this software + and associated documentation files (the "Software"), to deal in the Software without restriction, + including without limitation the rights to use, copy, modify, merge, publish, distribute, + sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is + furnished to do so, subject to the following conditions: + + The above copyright notice and this permission notice shall be included in all copies or + substantial portions of the Software. + + THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING + BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND + NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, + DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. + + @licend The above is the entire license notice for the JavaScript code in this file +*/ +var menudata={children:[ +{text:"Main Page",url:"index.html"}, +{text:"Related Pages",url:"pages.html"}, +{text:"Data Structures",url:"annotated.html",children:[ +{text:"Data Structures",url:"annotated.html"}, +{text:"Data Structure Index",url:"classes.html"}, +{text:"Data Fields",url:"functions.html",children:[ +{text:"All",url:"functions.html",children:[ +{text:"b",url:"functions.html#index_b"}, +{text:"c",url:"functions.html#index_c"}, +{text:"d",url:"functions.html#index_d"}, +{text:"e",url:"functions.html#index_e"}, +{text:"f",url:"functions.html#index_f"}, +{text:"h",url:"functions.html#index_h"}, +{text:"i",url:"functions.html#index_i"}, +{text:"m",url:"functions.html#index_m"}, +{text:"o",url:"functions.html#index_o"}, +{text:"p",url:"functions.html#index_p"}, +{text:"r",url:"functions.html#index_r"}, +{text:"s",url:"functions.html#index_s"}, +{text:"t",url:"functions.html#index_t"}, +{text:"u",url:"functions.html#index_u"}, +{text:"w",url:"functions.html#index_w"}, +{text:"y",url:"functions.html#index_y"}]}, +{text:"Variables",url:"functions_vars.html",children:[ +{text:"b",url:"functions_vars.html#index_b"}, +{text:"c",url:"functions_vars.html#index_c"}, +{text:"d",url:"functions_vars.html#index_d"}, +{text:"e",url:"functions_vars.html#index_e"}, +{text:"f",url:"functions_vars.html#index_f"}, +{text:"h",url:"functions_vars.html#index_h"}, +{text:"i",url:"functions_vars.html#index_i"}, +{text:"m",url:"functions_vars.html#index_m"}, +{text:"o",url:"functions_vars.html#index_o"}, +{text:"p",url:"functions_vars.html#index_p"}, +{text:"r",url:"functions_vars.html#index_r"}, +{text:"s",url:"functions_vars.html#index_s"}, +{text:"t",url:"functions_vars.html#index_t"}, +{text:"u",url:"functions_vars.html#index_u"}, +{text:"w",url:"functions_vars.html#index_w"}, +{text:"y",url:"functions_vars.html#index_y"}]}]}]}, +{text:"Files",url:"files.html",children:[ +{text:"File List",url:"files.html"}, +{text:"Globals",url:"globals.html",children:[ +{text:"All",url:"globals.html",children:[ +{text:"_",url:"globals.html#index__5F"}, +{text:"a",url:"globals_a.html#index_a"}, +{text:"b",url:"globals_b.html#index_b"}, +{text:"c",url:"globals_c.html#index_c"}, +{text:"d",url:"globals_d.html#index_d"}, +{text:"e",url:"globals_e.html#index_e"}, +{text:"f",url:"globals_f.html#index_f"}, +{text:"g",url:"globals_g.html#index_g"}, +{text:"h",url:"globals_h.html#index_h"}, +{text:"i",url:"globals_i.html#index_i"}, +{text:"k",url:"globals_k.html#index_k"}, +{text:"m",url:"globals_m.html#index_m"}, +{text:"n",url:"globals_n.html#index_n"}, +{text:"o",url:"globals_o.html#index_o"}, +{text:"p",url:"globals_p.html#index_p"}, +{text:"r",url:"globals_r.html#index_r"}, +{text:"s",url:"globals_s.html#index_s"}, +{text:"t",url:"globals_t.html#index_t"}, +{text:"u",url:"globals_u.html#index_u"}, +{text:"v",url:"globals_v.html#index_v"}, +{text:"w",url:"globals_w.html#index_w"}, +{text:"x",url:"globals_x.html#index_x"}]}, +{text:"Functions",url:"globals_func.html",children:[ +{text:"_",url:"globals_func.html#index__5F"}, +{text:"a",url:"globals_func_a.html#index_a"}, +{text:"b",url:"globals_func_b.html#index_b"}, +{text:"c",url:"globals_func_c.html#index_c"}, +{text:"d",url:"globals_func_d.html#index_d"}, +{text:"g",url:"globals_func_g.html#index_g"}, +{text:"h",url:"globals_func_h.html#index_h"}, +{text:"m",url:"globals_func_m.html#index_m"}, +{text:"n",url:"globals_func_n.html#index_n"}, +{text:"p",url:"globals_func_p.html#index_p"}, +{text:"r",url:"globals_func_r.html#index_r"}, +{text:"s",url:"globals_func_s.html#index_s"}, +{text:"t",url:"globals_func_t.html#index_t"}, +{text:"u",url:"globals_func_u.html#index_u"}, +{text:"v",url:"globals_func_v.html#index_v"}, +{text:"w",url:"globals_func_w.html#index_w"}, +{text:"x",url:"globals_func_x.html#index_x"}]}, +{text:"Variables",url:"globals_vars.html"}, +{text:"Enumerations",url:"globals_enum.html",children:[ +{text:"e",url:"globals_enum.html#index_e"}, +{text:"n",url:"globals_enum.html#index_n"}, +{text:"s",url:"globals_enum.html#index_s"}]}, +{text:"Enumerator",url:"globals_eval.html",children:[ +{text:"c",url:"globals_eval.html#index_c"}, +{text:"d",url:"globals_eval_d.html#index_d"}, +{text:"e",url:"globals_eval_e.html#index_e"}, +{text:"f",url:"globals_eval_f.html#index_f"}, +{text:"g",url:"globals_eval_g.html#index_g"}, +{text:"h",url:"globals_eval_h.html#index_h"}, +{text:"n",url:"globals_eval_n.html#index_n"}, +{text:"o",url:"globals_eval_o.html#index_o"}, +{text:"p",url:"globals_eval_p.html#index_p"}, +{text:"r",url:"globals_eval_r.html#index_r"}, +{text:"s",url:"globals_eval_s.html#index_s"}, +{text:"t",url:"globals_eval_t.html#index_t"}, +{text:"u",url:"globals_eval_u.html#index_u"}, +{text:"w",url:"globals_eval_w.html#index_w"}, +{text:"x",url:"globals_eval_x.html#index_x"}]}, +{text:"Macros",url:"globals_defs.html",children:[ +{text:"a",url:"globals_defs.html#index_a"}, +{text:"b",url:"globals_defs_b.html#index_b"}, +{text:"c",url:"globals_defs_c.html#index_c"}, +{text:"d",url:"globals_defs_d.html#index_d"}, +{text:"e",url:"globals_defs_e.html#index_e"}, +{text:"f",url:"globals_defs_f.html#index_f"}, +{text:"g",url:"globals_defs_g.html#index_g"}, +{text:"i",url:"globals_defs_i.html#index_i"}, +{text:"m",url:"globals_defs_m.html#index_m"}, +{text:"n",url:"globals_defs_n.html#index_n"}, +{text:"o",url:"globals_defs_o.html#index_o"}, +{text:"p",url:"globals_defs_p.html#index_p"}, +{text:"r",url:"globals_defs_r.html#index_r"}, +{text:"s",url:"globals_defs_s.html#index_s"}, +{text:"t",url:"globals_defs_t.html#index_t"}, +{text:"u",url:"globals_defs_u.html#index_u"}, +{text:"w",url:"globals_defs_w.html#index_w"}, +{text:"x",url:"globals_defs_x.html#index_x"}]}]}]}]} diff --git a/sw/minus.svg b/sw/minus.svg new file mode 100644 index 0000000000..f70d0c1a18 --- /dev/null +++ b/sw/minus.svg @@ -0,0 +1,8 @@ +<?xml version="1.0" encoding="UTF-8" standalone="no"?> +<svg width="12px" height="12px" viewBox="0 0 105.83333 105.83333" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:svg="http://www.w3.org/2000/svg"> + <g> + <rect style="fill:#808080;stroke-width:0" width="105.83333" height="105.83334" x="4.2409692e-08" y="-1.2701158e-06" ry="0" /> + <rect style="fill:#fcfcfc;stroke-width:0" width="79.375" height="79.375" x="13.229166" y="13.229166" /> + <rect style="fill:#808080;stroke-width:0" width="52.916668" height="15.874998" x="26.458332" y="44.979168" /> + </g> +</svg> diff --git a/sw/minusd.svg b/sw/minusd.svg new file mode 100644 index 0000000000..5f8e879628 --- /dev/null +++ b/sw/minusd.svg @@ -0,0 +1,8 @@ +<?xml version="1.0" encoding="UTF-8" standalone="no"?> +<svg width="12px" height="12px" viewBox="0 0 105.83333 105.83333" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:svg="http://www.w3.org/2000/svg"> + <g> + <rect style="fill:#808080;stroke-width:0" width="105.83333" height="105.83334" x="4.2409692e-08" y="-1.2701158e-06" ry="0" /> + <rect style="fill:#000000;stroke-width:0" width="79.375" height="79.375" x="13.229166" y="13.229166" /> + <rect style="fill:#808080;stroke-width:0" width="52.916668" height="15.874998" x="26.458332" y="44.979168" /> + </g> +</svg> diff --git a/sw/nav_f.png b/sw/nav_f.png new file mode 100644 index 0000000000000000000000000000000000000000..72a58a529ed3a9ed6aa0c51a79cf207e026deee2 GIT binary patch literal 153 zcmeAS@N?(olHy`uVBq!ia0vp^j6iI`!2~2XGqLUlQVE_ejv*C{Z|{2ZH7M}7UYxc) zn!W8uqtnIQ>_<lqdB{jiFDSaaN3W^xbJMH7CDK7=Q3_$6tQ&<~Cp4L6ZEndC`8;cO zrss?`_g+2sGU&M|cu~La_w1Rnf~7w`e!jQgteDwDLg6kW!`DinT@0SCelF{r5}E+Y CM>z8U literal 0 HcmV?d00001 diff --git a/sw/nav_fd.png b/sw/nav_fd.png new file mode 100644 index 0000000000000000000000000000000000000000..032fbdd4c54f54fa9a2e6423b94ef4b2ebdfaceb GIT binary patch literal 169 zcmeAS@N?(olHy`uVBq!ia0vp^j6iI`!2~2XGqLUlQU#tajv*C{Z|C~*H7f|XvG1G8 zt<j{B<-5i=y8aRCp6>7aS*L7xwMeS}!z6R#{C5tIw-s~AJ==F^i}x3XyJseHR@yF& zerFf(Zf;Dd{+(0lDIROL@Sj-Ju2JQ8&-n%4%q?>|^bShc&lR?}7HeMo@BDl5N(aHY Uj$gdr1MOz;boFyt=akR{0D!zeaR2}S literal 0 HcmV?d00001 diff --git a/sw/nav_g.png b/sw/nav_g.png new file mode 100644 index 0000000000000000000000000000000000000000..2093a237a94f6c83e19ec6e5fd42f7ddabdafa81 GIT binary patch literal 95 zcmeAS@N?(olHy`uVBq!ia0vp^j6lrB!3HFm1ilyoDK$?Q$B+ufw|5PB85lU25BhtE tr?otc=hd~V+ws&_A@j8Fiv!K<?EJwDd;c`qumW{3c)I$ztaD0e0syCC7$E=v literal 0 HcmV?d00001 diff --git a/sw/nav_h.png b/sw/nav_h.png new file mode 100644 index 0000000000000000000000000000000000000000..33389b101d9cd9b4c98ad286b5d9c46a6671f650 GIT binary patch literal 98 zcmeAS@N?(olHy`uVBq!ia0vp^j6lr8!2~3AUOE6t22D>F$B+ufw|5=67#uj90@pIL wZ=Q8~_Ju`#59=RjDrmm`tMD@M=!-l18IR?&v<Kx}xDV3h>FVdQ&MBb@0HFXL<NyEw literal 0 HcmV?d00001 diff --git a/sw/nav_hd.png b/sw/nav_hd.png new file mode 100644 index 0000000000000000000000000000000000000000..de80f18ad6488b9990303f267a76fdc83f0ffd80 GIT binary patch literal 114 zcmeAS@N?(olHy`uVBq!ia0vp^j6lr8!2~3AUOE6t21`#D$B+ufw|9379#G(63FK{W z5s<eodL#E@zbS9{Dekh>6W-eg#Jd_@e6*DPn)w;=|1H}Zvm9l6xXXB%>yL=NQU;mg M>FVdQ&MBb@0Bdt1Qvd(} literal 0 HcmV?d00001 diff --git a/sw/navtree.css b/sw/navtree.css new file mode 100644 index 0000000000..69211d4a78 --- /dev/null +++ b/sw/navtree.css @@ -0,0 +1,149 @@ +#nav-tree .children_ul { + margin:0; + padding:4px; +} + +#nav-tree ul { + list-style:none outside none; + margin:0px; + padding:0px; +} + +#nav-tree li { + white-space:nowrap; + margin:0px; + padding:0px; +} + +#nav-tree .plus { + margin:0px; +} + +#nav-tree .selected { + background-image: url('tab_a.png'); + background-repeat:repeat-x; + color: var(--nav-text-active-color); + text-shadow: var(--nav-text-active-shadow); +} + +#nav-tree .selected .arrow { + color: var(--nav-arrow-selected-color); + text-shadow: none; +} + +#nav-tree img { + margin:0px; + padding:0px; + border:0px; + vertical-align: middle; +} + +#nav-tree a { + text-decoration:none; + padding:0px; + margin:0px; +} + +#nav-tree .label { + margin:0px; + padding:0px; + font: 12px var(--font-family-nav); +} + +#nav-tree .label a { + padding:2px; +} + +#nav-tree .selected a { + text-decoration:none; + color:var(--nav-text-active-color); +} + +#nav-tree .children_ul { + margin:0px; + padding:0px; +} + +#nav-tree .item { + margin:0px; + padding:0px; +} + +#nav-tree { + padding: 0px 0px; + font-size:14px; + overflow:auto; +} + +#doc-content { + overflow:auto; + display:block; + padding:0px; + margin:0px; + -webkit-overflow-scrolling : touch; /* iOS 5+ */ +} + +#side-nav { + padding:0 6px 0 0; + margin: 0px; + display:block; + position: absolute; + left: 0px; + width: $width; + overflow : hidden; +} + +.ui-resizable .ui-resizable-handle { + display:block; +} + +.ui-resizable-e { + background-image:var(--nav-splitbar-image); + background-size:100%; + background-repeat:repeat-y; + background-attachment: scroll; + cursor:ew-resize; + height:100%; + right:0; + top:0; + width:6px; +} + +.ui-resizable-handle { + display:none; + font-size:0.1px; + position:absolute; + z-index:1; +} + +#nav-tree-contents { + margin: 6px 0px 0px 0px; +} + +#nav-tree { + background-repeat:repeat-x; + background-color: var(--nav-background-color); + -webkit-overflow-scrolling : touch; /* iOS 5+ */ +} + +#nav-sync { + position:absolute; + top:5px; + right:24px; + z-index:0; +} + +#nav-sync img { + opacity:0.3; +} + +#nav-sync img:hover { + opacity:0.9; +} + +@media print +{ + #nav-tree { display: none; } + div.ui-resizable-handle { display: none; position: relative; } +} + diff --git a/sw/neorv32_8h.html b/sw/neorv32_8h.html new file mode 100644 index 0000000000..1d7c4af441 --- /dev/null +++ b/sw/neorv32_8h.html @@ -0,0 +1,1720 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/lib/include/neorv32.h File Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_7d04193005ada6f9450f847f4adb6b5b.html">lib</a></li><li class="navelem"><a class="el" href="dir_752b1e5d3973bf735fa78bf6b4727df9.html">include</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#nested-classes">Data Structures</a> </div> + <div class="headertitle"><div class="title">neorv32.h File Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p>Main NEORV32 core library / driver / HAL include file. +<a href="#details">More...</a></p> +<div class="textblock"><code>#include &lt;stdint.h&gt;</code><br /> +<code>#include &lt;inttypes.h&gt;</code><br /> +<code>#include &lt;unistd.h&gt;</code><br /> +<code>#include &lt;stdlib.h&gt;</code><br /> +<code>#include &quot;<a class="el" href="neorv32__intrinsics_8h_source.html">neorv32_intrinsics.h</a>&quot;</code><br /> +<code>#include &quot;<a class="el" href="neorv32__aux_8h_source.html">neorv32_aux.h</a>&quot;</code><br /> +<code>#include &quot;<a class="el" href="neorv32__legacy_8h_source.html">neorv32_legacy.h</a>&quot;</code><br /> +<code>#include &quot;<a class="el" href="neorv32__cpu_8h_source.html">neorv32_cpu.h</a>&quot;</code><br /> +<code>#include &quot;<a class="el" href="neorv32__cpu__amo_8h_source.html">neorv32_cpu_amo.h</a>&quot;</code><br /> +<code>#include &quot;<a class="el" href="neorv32__cpu__csr_8h_source.html">neorv32_cpu_csr.h</a>&quot;</code><br /> +<code>#include &quot;<a class="el" href="neorv32__cpu__cfu_8h_source.html">neorv32_cpu_cfu.h</a>&quot;</code><br /> +<code>#include &quot;<a class="el" href="neorv32__rte_8h_source.html">neorv32_rte.h</a>&quot;</code><br /> +<code>#include &quot;<a class="el" href="neorv32__cfs_8h_source.html">neorv32_cfs.h</a>&quot;</code><br /> +<code>#include &quot;<a class="el" href="neorv32__crc_8h_source.html">neorv32_crc.h</a>&quot;</code><br /> +<code>#include &quot;<a class="el" href="neorv32__dma_8h_source.html">neorv32_dma.h</a>&quot;</code><br /> +<code>#include &quot;<a class="el" href="neorv32__gpio_8h_source.html">neorv32_gpio.h</a>&quot;</code><br /> +<code>#include &quot;<a class="el" href="neorv32__gptmr_8h_source.html">neorv32_gptmr.h</a>&quot;</code><br /> +<code>#include &quot;<a class="el" href="neorv32__mtime_8h_source.html">neorv32_mtime.h</a>&quot;</code><br /> +<code>#include &quot;<a class="el" href="neorv32__neoled_8h_source.html">neorv32_neoled.h</a>&quot;</code><br /> +<code>#include &quot;<a class="el" href="neorv32__onewire_8h_source.html">neorv32_onewire.h</a>&quot;</code><br /> +<code>#include &quot;<a class="el" href="neorv32__pwm_8h_source.html">neorv32_pwm.h</a>&quot;</code><br /> +<code>#include &quot;<a class="el" href="neorv32__sdi_8h_source.html">neorv32_sdi.h</a>&quot;</code><br /> +<code>#include &quot;<a class="el" href="neorv32__slink_8h_source.html">neorv32_slink.h</a>&quot;</code><br /> +<code>#include &quot;<a class="el" href="neorv32__spi_8h_source.html">neorv32_spi.h</a>&quot;</code><br /> +<code>#include &quot;neorv32_sysinfo.h&quot;</code><br /> +<code>#include &quot;<a class="el" href="neorv32__trng_8h_source.html">neorv32_trng.h</a>&quot;</code><br /> +<code>#include &quot;<a class="el" href="neorv32__twi_8h_source.html">neorv32_twi.h</a>&quot;</code><br /> +<code>#include &quot;<a class="el" href="neorv32__uart_8h_source.html">neorv32_uart.h</a>&quot;</code><br /> +<code>#include &quot;<a class="el" href="neorv32__wdt_8h_source.html">neorv32_wdt.h</a>&quot;</code><br /> +<code>#include &quot;<a class="el" href="neorv32__xip_8h_source.html">neorv32_xip.h</a>&quot;</code><br /> +<code>#include &quot;<a class="el" href="neorv32__xirq_8h_source.html">neorv32_xirq.h</a>&quot;</code><br /> +</div> +<p><a href="neorv32_8h_source.html">Go to the source code of this file.</a></p> +<table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="nested-classes" name="nested-classes"></a> +Data Structures</h2></td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">union &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="unionsubwords64__t.html">subwords64_t</a></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">union &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="unionsubwords32__t.html">subwords32_t</a></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">union &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="unionsubwords16__t.html">subwords16_t</a></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="define-members" name="define-members"></a> +Macros</h2></td></tr> +<tr><td colspan="2"><div class="groupHeader">Main Address Space Sections</div></td></tr> +<tr class="memitem:aa01bea676e878a9e87ca10ce2d91e51f" id="r_aa01bea676e878a9e87ca10ce2d91e51f"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aa01bea676e878a9e87ca10ce2d91e51f">XIP_MEM_BASE_ADDRESS</a>&#160;&#160;&#160;(0xE0000000U)</td></tr> +<tr class="separator:aa01bea676e878a9e87ca10ce2d91e51f"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:abd8c9b7d79f49de1722611b2835cde58" id="r_abd8c9b7d79f49de1722611b2835cde58"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#abd8c9b7d79f49de1722611b2835cde58">BOOTLOADER_BASE_ADDRESS</a>&#160;&#160;&#160;(0xFFFFC000U)</td></tr> +<tr class="separator:abd8c9b7d79f49de1722611b2835cde58"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a1eb0cb7fed7e154e15cb4009880a879c" id="r_a1eb0cb7fed7e154e15cb4009880a879c"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a1eb0cb7fed7e154e15cb4009880a879c">IO_BASE_ADDRESS</a>&#160;&#160;&#160;(0xFFFFE000U)</td></tr> +<tr class="separator:a1eb0cb7fed7e154e15cb4009880a879c"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr><td colspan="2"><div class="groupHeader">IO Address Space Map - Peripheral/IO Devices</div></td></tr> +<tr class="memitem:a41d6f97daef61641da96b9f72f6b272f" id="r_a41d6f97daef61641da96b9f72f6b272f"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a41d6f97daef61641da96b9f72f6b272f">NEORV32_CFS_BASE</a>&#160;&#160;&#160;(0xFFFFEB00U)</td></tr> +<tr class="separator:a41d6f97daef61641da96b9f72f6b272f"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ab5e6dc57886cd5ed98b86f22fc37d7cc" id="r_ab5e6dc57886cd5ed98b86f22fc37d7cc"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ab5e6dc57886cd5ed98b86f22fc37d7cc">NEORV32_SLINK_BASE</a>&#160;&#160;&#160;(0xFFFFEC00U)</td></tr> +<tr class="separator:ab5e6dc57886cd5ed98b86f22fc37d7cc"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aa8d3a83ffad1e71f0832a5da78d62008" id="r_aa8d3a83ffad1e71f0832a5da78d62008"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aa8d3a83ffad1e71f0832a5da78d62008">NEORV32_DMA_BASE</a>&#160;&#160;&#160;(0xFFFFED00U)</td></tr> +<tr class="separator:aa8d3a83ffad1e71f0832a5da78d62008"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a0e2377055bdc0f416b5ae4385610600d" id="r_a0e2377055bdc0f416b5ae4385610600d"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a0e2377055bdc0f416b5ae4385610600d">NEORV32_CRC_BASE</a>&#160;&#160;&#160;(0xFFFFEE00U)</td></tr> +<tr class="separator:a0e2377055bdc0f416b5ae4385610600d"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ae0978315beac8399f96f520bda81c7fe" id="r_ae0978315beac8399f96f520bda81c7fe"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ae0978315beac8399f96f520bda81c7fe">NEORV32_XIP_BASE</a>&#160;&#160;&#160;(0xFFFFEF00U)</td></tr> +<tr class="separator:ae0978315beac8399f96f520bda81c7fe"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:afef7a6b121a788560b29e2ee2a58c725" id="r_afef7a6b121a788560b29e2ee2a58c725"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#afef7a6b121a788560b29e2ee2a58c725">NEORV32_PWM_BASE</a>&#160;&#160;&#160;(0xFFFFF000U)</td></tr> +<tr class="separator:afef7a6b121a788560b29e2ee2a58c725"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a0991b1a5ba1e8c3550eb9770d43589d0" id="r_a0991b1a5ba1e8c3550eb9770d43589d0"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a0991b1a5ba1e8c3550eb9770d43589d0">NEORV32_GPTMR_BASE</a>&#160;&#160;&#160;(0xFFFFF100U)</td></tr> +<tr class="separator:a0991b1a5ba1e8c3550eb9770d43589d0"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a8d0b612e52b77395a05d4f18af6fcf00" id="r_a8d0b612e52b77395a05d4f18af6fcf00"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a8d0b612e52b77395a05d4f18af6fcf00">NEORV32_ONEWIRE_BASE</a>&#160;&#160;&#160;(0xFFFFF200U)</td></tr> +<tr class="separator:a8d0b612e52b77395a05d4f18af6fcf00"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a942a897be2d4ae6820bee0f7bb3a0ff1" id="r_a942a897be2d4ae6820bee0f7bb3a0ff1"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a942a897be2d4ae6820bee0f7bb3a0ff1">NEORV32_XIRQ_BASE</a>&#160;&#160;&#160;(0xFFFFF300U)</td></tr> +<tr class="separator:a942a897be2d4ae6820bee0f7bb3a0ff1"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ab98f762df259a2bbc28d19d2acfe9e23" id="r_ab98f762df259a2bbc28d19d2acfe9e23"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ab98f762df259a2bbc28d19d2acfe9e23">NEORV32_MTIME_BASE</a>&#160;&#160;&#160;(0xFFFFF400U)</td></tr> +<tr class="separator:ab98f762df259a2bbc28d19d2acfe9e23"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a000b37f710043fe21e49b2fdbc039d94" id="r_a000b37f710043fe21e49b2fdbc039d94"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a000b37f710043fe21e49b2fdbc039d94">NEORV32_UART0_BASE</a>&#160;&#160;&#160;(0xFFFFF500U)</td></tr> +<tr class="separator:a000b37f710043fe21e49b2fdbc039d94"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a26a1defe18ce222b8b4ed1c760344700" id="r_a26a1defe18ce222b8b4ed1c760344700"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a26a1defe18ce222b8b4ed1c760344700">NEORV32_UART1_BASE</a>&#160;&#160;&#160;(0xFFFFF600U)</td></tr> +<tr class="separator:a26a1defe18ce222b8b4ed1c760344700"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a9b316ec038bd94ada42c9dab57a0a3cb" id="r_a9b316ec038bd94ada42c9dab57a0a3cb"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a9b316ec038bd94ada42c9dab57a0a3cb">NEORV32_SDI_BASE</a>&#160;&#160;&#160;(0xFFFFF700U)</td></tr> +<tr class="separator:a9b316ec038bd94ada42c9dab57a0a3cb"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aa466dc5eace7351bd438606f0f7475a7" id="r_aa466dc5eace7351bd438606f0f7475a7"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aa466dc5eace7351bd438606f0f7475a7">NEORV32_SPI_BASE</a>&#160;&#160;&#160;(0xFFFFF800U)</td></tr> +<tr class="separator:aa466dc5eace7351bd438606f0f7475a7"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a4a741408a4bb0938e03b99555306db9c" id="r_a4a741408a4bb0938e03b99555306db9c"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a4a741408a4bb0938e03b99555306db9c">NEORV32_TWI_BASE</a>&#160;&#160;&#160;(0xFFFFF900U)</td></tr> +<tr class="separator:a4a741408a4bb0938e03b99555306db9c"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ab4846cd153e8a23deec45d81cc8372a2" id="r_ab4846cd153e8a23deec45d81cc8372a2"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ab4846cd153e8a23deec45d81cc8372a2">NEORV32_TRNG_BASE</a>&#160;&#160;&#160;(0xFFFFFA00U)</td></tr> +<tr class="separator:ab4846cd153e8a23deec45d81cc8372a2"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a3012986cdd5748ee96bcc74cd7108dea" id="r_a3012986cdd5748ee96bcc74cd7108dea"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a3012986cdd5748ee96bcc74cd7108dea">NEORV32_WDT_BASE</a>&#160;&#160;&#160;(0xFFFFFB00U)</td></tr> +<tr class="separator:a3012986cdd5748ee96bcc74cd7108dea"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a7fd1e24d4de2eed7bf9cd5391562c7f4" id="r_a7fd1e24d4de2eed7bf9cd5391562c7f4"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a7fd1e24d4de2eed7bf9cd5391562c7f4">NEORV32_GPIO_BASE</a>&#160;&#160;&#160;(0xFFFFFC00U)</td></tr> +<tr class="separator:a7fd1e24d4de2eed7bf9cd5391562c7f4"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a559fdce92e8af5efc426c8fc48d14f99" id="r_a559fdce92e8af5efc426c8fc48d14f99"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a559fdce92e8af5efc426c8fc48d14f99">NEORV32_NEOLED_BASE</a>&#160;&#160;&#160;(0xFFFFFD00U)</td></tr> +<tr class="separator:a559fdce92e8af5efc426c8fc48d14f99"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a5aa936f38782232c7ed3eab1283ee536" id="r_a5aa936f38782232c7ed3eab1283ee536"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a5aa936f38782232c7ed3eab1283ee536">NEORV32_SYSINFO_BASE</a>&#160;&#160;&#160;(0xFFFFFE00U)</td></tr> +<tr class="separator:a5aa936f38782232c7ed3eab1283ee536"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a9bf0149681677f7d87abf8f62e2d9a3d" id="r_a9bf0149681677f7d87abf8f62e2d9a3d"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a9bf0149681677f7d87abf8f62e2d9a3d">NEORV32_DM_BASE</a>&#160;&#160;&#160;(0xFFFFFF00U)</td></tr> +<tr class="separator:a9bf0149681677f7d87abf8f62e2d9a3d"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr><td colspan="2"><div class="groupHeader">True-Random Number Generator (TRNG)</div></td></tr> +<tr class="memitem:a2896d832852c016eb85210b523642f11" id="r_a2896d832852c016eb85210b523642f11"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a2896d832852c016eb85210b523642f11">TRNG_FIRQ_ENABLE</a>&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a99f43f8bbfb29fba6224f081c363ac7d">CSR_MIE_FIRQ0E</a></td></tr> +<tr class="separator:a2896d832852c016eb85210b523642f11"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a9c387ca4e2736a27056c11819947c84a" id="r_a9c387ca4e2736a27056c11819947c84a"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a9c387ca4e2736a27056c11819947c84a">TRNG_FIRQ_PENDING</a>&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba28a85ad8bd4c30fd3a91298dfa4fdb00">CSR_MIP_FIRQ0P</a></td></tr> +<tr class="separator:a9c387ca4e2736a27056c11819947c84a"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:afaa705a674acf3fd6c8cb294eaf11c5e" id="r_afaa705a674acf3fd6c8cb294eaf11c5e"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#afaa705a674acf3fd6c8cb294eaf11c5e">TRNG_RTE_ID</a>&#160;&#160;&#160;<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aab36a403cd7b833439ce7f9a708c33922">RTE_TRAP_FIRQ_0</a></td></tr> +<tr class="separator:afaa705a674acf3fd6c8cb294eaf11c5e"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a11e34802c61a01fd6cba46e3f92d5ac1" id="r_a11e34802c61a01fd6cba46e3f92d5ac1"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a11e34802c61a01fd6cba46e3f92d5ac1">TRNG_TRAP_CODE</a>&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a0cef77904935798d247d8396838297c1">TRAP_CODE_FIRQ_0</a></td></tr> +<tr class="separator:a11e34802c61a01fd6cba46e3f92d5ac1"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr><td colspan="2"><div class="groupHeader">Custom Functions Subsystem (CFS)</div></td></tr> +<tr class="memitem:ace79ee46daf3a1b689d9fe79dfcd6627" id="r_ace79ee46daf3a1b689d9fe79dfcd6627"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ace79ee46daf3a1b689d9fe79dfcd6627">CFS_FIRQ_ENABLE</a>&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33ac1e1d44becec1b393f79a118ed3d8beb">CSR_MIE_FIRQ1E</a></td></tr> +<tr class="separator:ace79ee46daf3a1b689d9fe79dfcd6627"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aae182648a2c23d070b9db0295388e001" id="r_aae182648a2c23d070b9db0295388e001"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aae182648a2c23d070b9db0295388e001">CFS_FIRQ_PENDING</a>&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba2b577b1da1074c29ad58005af1f91d52">CSR_MIP_FIRQ1P</a></td></tr> +<tr class="separator:aae182648a2c23d070b9db0295388e001"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a095f41fbefaa7acc1bfdd65cd3ce06ea" id="r_a095f41fbefaa7acc1bfdd65cd3ce06ea"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a095f41fbefaa7acc1bfdd65cd3ce06ea">CFS_RTE_ID</a>&#160;&#160;&#160;<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aab199b53a1458017fa5278e0aeecf41fd">RTE_TRAP_FIRQ_1</a></td></tr> +<tr class="separator:a095f41fbefaa7acc1bfdd65cd3ce06ea"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aae6b2ae3fba20ff80bfb59735f179c26" id="r_aae6b2ae3fba20ff80bfb59735f179c26"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aae6b2ae3fba20ff80bfb59735f179c26">CFS_TRAP_CODE</a>&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1ae0b1049ae7f8cbfb6ff216e69ed5dae7">TRAP_CODE_FIRQ_1</a></td></tr> +<tr class="separator:aae6b2ae3fba20ff80bfb59735f179c26"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr><td colspan="2"><div class="groupHeader">Primary Universal Asynchronous Receiver/Transmitter (UART0)</div></td></tr> +<tr class="memitem:a6b55ce6abe6b141000a6bb00949169e9" id="r_a6b55ce6abe6b141000a6bb00949169e9"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a6b55ce6abe6b141000a6bb00949169e9">UART0_RX_FIRQ_ENABLE</a>&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33afc805280e20ffface116ca61e11645f7">CSR_MIE_FIRQ2E</a></td></tr> +<tr class="separator:a6b55ce6abe6b141000a6bb00949169e9"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a0b738b26abb2b951f1f5c5d9525d7701" id="r_a0b738b26abb2b951f1f5c5d9525d7701"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a0b738b26abb2b951f1f5c5d9525d7701">UART0_RX_FIRQ_PENDING</a>&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21badf45c5a135431f958fa63574c1dfac6e">CSR_MIP_FIRQ2P</a></td></tr> +<tr class="separator:a0b738b26abb2b951f1f5c5d9525d7701"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ae8588cca20d5e36f74c5207c376389a1" id="r_ae8588cca20d5e36f74c5207c376389a1"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ae8588cca20d5e36f74c5207c376389a1">UART0_RX_RTE_ID</a>&#160;&#160;&#160;<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa29ffa3108fadc78bf375773c3232c489">RTE_TRAP_FIRQ_2</a></td></tr> +<tr class="separator:ae8588cca20d5e36f74c5207c376389a1"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a7a849638eff31f2e1955bdc53d4fc84d" id="r_a7a849638eff31f2e1955bdc53d4fc84d"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a7a849638eff31f2e1955bdc53d4fc84d">UART0_RX_TRAP_CODE</a>&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1ad753d3e2563b4fd663430af9f3888dc7">TRAP_CODE_FIRQ_2</a></td></tr> +<tr class="separator:a7a849638eff31f2e1955bdc53d4fc84d"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aff756a395771f22c5f412f23f177ea7d" id="r_aff756a395771f22c5f412f23f177ea7d"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aff756a395771f22c5f412f23f177ea7d">UART0_TX_FIRQ_ENABLE</a>&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a666066099d6cebadbef21d81c179e8db">CSR_MIE_FIRQ3E</a></td></tr> +<tr class="separator:aff756a395771f22c5f412f23f177ea7d"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:addbe29166bb77bc045ad0e3db68e57e9" id="r_addbe29166bb77bc045ad0e3db68e57e9"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#addbe29166bb77bc045ad0e3db68e57e9">UART0_TX_FIRQ_PENDING</a>&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba7512bb6c4841ddd477422b49ebb2a155">CSR_MIP_FIRQ3P</a></td></tr> +<tr class="separator:addbe29166bb77bc045ad0e3db68e57e9"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a9dc37695ca169bc0eb93898e7aeeee58" id="r_a9dc37695ca169bc0eb93898e7aeeee58"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a9dc37695ca169bc0eb93898e7aeeee58">UART0_TX_RTE_ID</a>&#160;&#160;&#160;<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa4a74188fd87ea17a594ac6fe8ddf71be">RTE_TRAP_FIRQ_3</a></td></tr> +<tr class="separator:a9dc37695ca169bc0eb93898e7aeeee58"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ab50df423fdba86bb83bc5d90a4c3bb20" id="r_ab50df423fdba86bb83bc5d90a4c3bb20"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ab50df423fdba86bb83bc5d90a4c3bb20">UART0_TX_TRAP_CODE</a>&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a356f8485166529503d0fb246bd0aeeb0">TRAP_CODE_FIRQ_3</a></td></tr> +<tr class="separator:ab50df423fdba86bb83bc5d90a4c3bb20"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr><td colspan="2"><div class="groupHeader">Secondary Universal Asynchronous Receiver/Transmitter (UART1)</div></td></tr> +<tr class="memitem:a6c118c1784d8446360b00cde97437ca7" id="r_a6c118c1784d8446360b00cde97437ca7"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a6c118c1784d8446360b00cde97437ca7">UART1_RX_FIRQ_ENABLE</a>&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a592939f1b7d79097f7f13d6ab0c268dc">CSR_MIE_FIRQ4E</a></td></tr> +<tr class="separator:a6c118c1784d8446360b00cde97437ca7"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a2e70d3a4e2973d224643813fcf315a20" id="r_a2e70d3a4e2973d224643813fcf315a20"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a2e70d3a4e2973d224643813fcf315a20">UART1_RX_FIRQ_PENDING</a>&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21bab6421f242bb8a487a986346e11196eb8">CSR_MIP_FIRQ4P</a></td></tr> +<tr class="separator:a2e70d3a4e2973d224643813fcf315a20"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ab1c351f5ea19ac9ea864155be9cc0b4b" id="r_ab1c351f5ea19ac9ea864155be9cc0b4b"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ab1c351f5ea19ac9ea864155be9cc0b4b">UART1_RX_RTE_ID</a>&#160;&#160;&#160;<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa8b39868bf91da54f9ec492918e0c01ff">RTE_TRAP_FIRQ_4</a></td></tr> +<tr class="separator:ab1c351f5ea19ac9ea864155be9cc0b4b"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ad0b9eb2ee1f411d7fccdf4fe263214e1" id="r_ad0b9eb2ee1f411d7fccdf4fe263214e1"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ad0b9eb2ee1f411d7fccdf4fe263214e1">UART1_RX_TRAP_CODE</a>&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1aaa8e7bb251852ef75a78be71eef0b547">TRAP_CODE_FIRQ_4</a></td></tr> +<tr class="separator:ad0b9eb2ee1f411d7fccdf4fe263214e1"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a0039bae3454a22e71d64e70d674f5d6a" id="r_a0039bae3454a22e71d64e70d674f5d6a"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a0039bae3454a22e71d64e70d674f5d6a">UART1_TX_FIRQ_ENABLE</a>&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a3079a8fbf3b8e376865bff76f2173698">CSR_MIE_FIRQ5E</a></td></tr> +<tr class="separator:a0039bae3454a22e71d64e70d674f5d6a"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ac4060532b7aa390623f54720460a2680" id="r_ac4060532b7aa390623f54720460a2680"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ac4060532b7aa390623f54720460a2680">UART1_TX_FIRQ_PENDING</a>&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21baaa55d19f9a47889bc364c94bda04b677">CSR_MIP_FIRQ5P</a></td></tr> +<tr class="separator:ac4060532b7aa390623f54720460a2680"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a6af270d7ae8b1cde30e44eb9142491d3" id="r_a6af270d7ae8b1cde30e44eb9142491d3"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a6af270d7ae8b1cde30e44eb9142491d3">UART1_TX_RTE_ID</a>&#160;&#160;&#160;<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa01f562418ddbbb6b84be168673deeea9">RTE_TRAP_FIRQ_5</a></td></tr> +<tr class="separator:a6af270d7ae8b1cde30e44eb9142491d3"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a4cc50287c7a53982761a8116396ff7dd" id="r_a4cc50287c7a53982761a8116396ff7dd"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a4cc50287c7a53982761a8116396ff7dd">UART1_TX_TRAP_CODE</a>&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a5789dfabd8ec265fa0734ddd94e98757">TRAP_CODE_FIRQ_5</a></td></tr> +<tr class="separator:a4cc50287c7a53982761a8116396ff7dd"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr><td colspan="2"><div class="groupHeader">Serial Peripheral Interface (SPI)</div></td></tr> +<tr class="memitem:ab8fcd3f80c373eb0f9d0fc6bf64ca626" id="r_ab8fcd3f80c373eb0f9d0fc6bf64ca626"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ab8fcd3f80c373eb0f9d0fc6bf64ca626">SPI_FIRQ_ENABLE</a>&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a96315d6b5b9531bcbc1e78a3c9ab166a">CSR_MIE_FIRQ6E</a></td></tr> +<tr class="separator:ab8fcd3f80c373eb0f9d0fc6bf64ca626"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ab2f58f746febb29a9828447c733f8043" id="r_ab2f58f746febb29a9828447c733f8043"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ab2f58f746febb29a9828447c733f8043">SPI_FIRQ_PENDING</a>&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21baffa7342631aa0526aaa44c0c549b1f3e">CSR_MIP_FIRQ6P</a></td></tr> +<tr class="separator:ab2f58f746febb29a9828447c733f8043"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a4c1cd9ec9f80da2080e5d0d35cc524dd" id="r_a4c1cd9ec9f80da2080e5d0d35cc524dd"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a4c1cd9ec9f80da2080e5d0d35cc524dd">SPI_RTE_ID</a>&#160;&#160;&#160;<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aac9fb28ea8bafff182f12c29d2fad6998">RTE_TRAP_FIRQ_6</a></td></tr> +<tr class="separator:a4c1cd9ec9f80da2080e5d0d35cc524dd"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a83c212f1f5d8ee2a5921b3b2b19e9cc4" id="r_a83c212f1f5d8ee2a5921b3b2b19e9cc4"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a83c212f1f5d8ee2a5921b3b2b19e9cc4">SPI_TRAP_CODE</a>&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a809e997f55e83c6812c965655511d473">TRAP_CODE_FIRQ_6</a></td></tr> +<tr class="separator:a83c212f1f5d8ee2a5921b3b2b19e9cc4"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr><td colspan="2"><div class="groupHeader">Two-Wire Interface (TWI)</div></td></tr> +<tr class="memitem:a0913144fce247e24ccd0f178b9ac32b7" id="r_a0913144fce247e24ccd0f178b9ac32b7"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a0913144fce247e24ccd0f178b9ac32b7">TWI_FIRQ_ENABLE</a>&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a3d9d729940170609affbc6813054ebe8">CSR_MIE_FIRQ7E</a></td></tr> +<tr class="separator:a0913144fce247e24ccd0f178b9ac32b7"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a48b80113ca718fbdc50d75e1ec96a1ff" id="r_a48b80113ca718fbdc50d75e1ec96a1ff"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a48b80113ca718fbdc50d75e1ec96a1ff">TWI_FIRQ_PENDING</a>&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21baad691486001a68f2375dcf5793ee795a">CSR_MIP_FIRQ7P</a></td></tr> +<tr class="separator:a48b80113ca718fbdc50d75e1ec96a1ff"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a1ac29f2f7bace5ba92b2b68a4541a60c" id="r_a1ac29f2f7bace5ba92b2b68a4541a60c"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a1ac29f2f7bace5ba92b2b68a4541a60c">TWI_RTE_ID</a>&#160;&#160;&#160;<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa73bb84f7b6c7528bec552ac1d3e9ccdb">RTE_TRAP_FIRQ_7</a></td></tr> +<tr class="separator:a1ac29f2f7bace5ba92b2b68a4541a60c"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a0afc1a759116d4d73a199ef769bced47" id="r_a0afc1a759116d4d73a199ef769bced47"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a0afc1a759116d4d73a199ef769bced47">TWI_TRAP_CODE</a>&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1aeab719bcce9e9551bd6da65a7ae08a26">TRAP_CODE_FIRQ_7</a></td></tr> +<tr class="separator:a0afc1a759116d4d73a199ef769bced47"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr><td colspan="2"><div class="groupHeader">External Interrupt Controller (XIRQ)</div></td></tr> +<tr class="memitem:afe0cb262d517c7da73d6b5dc78886334" id="r_afe0cb262d517c7da73d6b5dc78886334"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#afe0cb262d517c7da73d6b5dc78886334">XIRQ_FIRQ_ENABLE</a>&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a396c6c4b425b3fff598e2f846052f98e">CSR_MIE_FIRQ8E</a></td></tr> +<tr class="separator:afe0cb262d517c7da73d6b5dc78886334"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a866768963f8648363dce40de9f34d61b" id="r_a866768963f8648363dce40de9f34d61b"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a866768963f8648363dce40de9f34d61b">XIRQ_FIRQ_PENDING</a>&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21baf5bbd23d4f311f640db42e9015f87580">CSR_MIP_FIRQ8P</a></td></tr> +<tr class="separator:a866768963f8648363dce40de9f34d61b"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a95387d3482ec8e5c1d734805fdf64fa5" id="r_a95387d3482ec8e5c1d734805fdf64fa5"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a95387d3482ec8e5c1d734805fdf64fa5">XIRQ_RTE_ID</a>&#160;&#160;&#160;<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa3edbf47bd9a278e100bb808c8bb68308">RTE_TRAP_FIRQ_8</a></td></tr> +<tr class="separator:a95387d3482ec8e5c1d734805fdf64fa5"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a16b9a7444833b5581df073661deb8f3a" id="r_a16b9a7444833b5581df073661deb8f3a"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a16b9a7444833b5581df073661deb8f3a">XIRQ_TRAP_CODE</a>&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1abfd21d1380dcacb9282e525da104d916">TRAP_CODE_FIRQ_8</a></td></tr> +<tr class="separator:a16b9a7444833b5581df073661deb8f3a"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr><td colspan="2"><div class="groupHeader">Smart LED Controller (NEOLED)</div></td></tr> +<tr class="memitem:a8d0409818600c0b2acfe8253e8f027b8" id="r_a8d0409818600c0b2acfe8253e8f027b8"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a8d0409818600c0b2acfe8253e8f027b8">NEOLED_FIRQ_ENABLE</a>&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a06fdb61dab31c3490da6c37d47914f19">CSR_MIE_FIRQ9E</a></td></tr> +<tr class="separator:a8d0409818600c0b2acfe8253e8f027b8"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aded7d7f5f4ba3a6d90f9a29e62a8cfab" id="r_aded7d7f5f4ba3a6d90f9a29e62a8cfab"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aded7d7f5f4ba3a6d90f9a29e62a8cfab">NEOLED_FIRQ_PENDING</a>&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21bad94c9691ce59b97fcfec14d345046c3e">CSR_MIP_FIRQ9P</a></td></tr> +<tr class="separator:aded7d7f5f4ba3a6d90f9a29e62a8cfab"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aca6cfc3f580c4dfe1e213009ee450c58" id="r_aca6cfc3f580c4dfe1e213009ee450c58"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aca6cfc3f580c4dfe1e213009ee450c58">NEOLED_RTE_ID</a>&#160;&#160;&#160;<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa2cd04189d91465dad2bc2a8852406b76">RTE_TRAP_FIRQ_9</a></td></tr> +<tr class="separator:aca6cfc3f580c4dfe1e213009ee450c58"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ab4a2ac455d7426992de6877ea7325f21" id="r_ab4a2ac455d7426992de6877ea7325f21"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ab4a2ac455d7426992de6877ea7325f21">NEOLED_TRAP_CODE</a>&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a350e762a599479fb2c6d23ccc5ee22b4">TRAP_CODE_FIRQ_9</a></td></tr> +<tr class="separator:ab4a2ac455d7426992de6877ea7325f21"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr><td colspan="2"><div class="groupHeader">Direct Memory Access Controller (DMA)</div></td></tr> +<tr class="memitem:ace46f95dec73b33bf2535eb653bf8f65" id="r_ace46f95dec73b33bf2535eb653bf8f65"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ace46f95dec73b33bf2535eb653bf8f65">DMA_FIRQ_ENABLE</a>&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33affcb52dc57bb8c0cb1e7d3c1392d544a">CSR_MIE_FIRQ10E</a></td></tr> +<tr class="separator:ace46f95dec73b33bf2535eb653bf8f65"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a1fa2b25383e6d05cf26f3517091ddbbf" id="r_a1fa2b25383e6d05cf26f3517091ddbbf"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a1fa2b25383e6d05cf26f3517091ddbbf">DMA_FIRQ_PENDING</a>&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba2b50cfa8be461b088ea8506ce4c741ba">CSR_MIP_FIRQ10P</a></td></tr> +<tr class="separator:a1fa2b25383e6d05cf26f3517091ddbbf"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a568b54ba7dfdae736d8d685dc4d32113" id="r_a568b54ba7dfdae736d8d685dc4d32113"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a568b54ba7dfdae736d8d685dc4d32113">DMA_RTE_ID</a>&#160;&#160;&#160;<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aadebcc4d91aea1364b1481111f1060c52">RTE_TRAP_FIRQ_10</a></td></tr> +<tr class="separator:a568b54ba7dfdae736d8d685dc4d32113"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ad2e81443af8a4ce2db3a4e3c1a8fb784" id="r_ad2e81443af8a4ce2db3a4e3c1a8fb784"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ad2e81443af8a4ce2db3a4e3c1a8fb784">DMA_TRAP_CODE</a>&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a4f6b9c6bba91fe04becb776ad22dcf42">TRAP_CODE_FIRQ_10</a></td></tr> +<tr class="separator:ad2e81443af8a4ce2db3a4e3c1a8fb784"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr><td colspan="2"><div class="groupHeader">Serial Data Interface (SDI)</div></td></tr> +<tr class="memitem:a30cf20b6d704c50cc5c46238bb43646f" id="r_a30cf20b6d704c50cc5c46238bb43646f"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a30cf20b6d704c50cc5c46238bb43646f">SDI_FIRQ_ENABLE</a>&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33af058342854a0becd3bcc33877d9244cd">CSR_MIE_FIRQ11E</a></td></tr> +<tr class="separator:a30cf20b6d704c50cc5c46238bb43646f"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a68611c0dfbe331739eff10230ac3fede" id="r_a68611c0dfbe331739eff10230ac3fede"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a68611c0dfbe331739eff10230ac3fede">SDI_FIRQ_PENDING</a>&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba69ea0d3d76d4cec398f3b96959cc3544">CSR_MIP_FIRQ11P</a></td></tr> +<tr class="separator:a68611c0dfbe331739eff10230ac3fede"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aa0ff72ea560d7e1462787dc31bd467cf" id="r_aa0ff72ea560d7e1462787dc31bd467cf"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aa0ff72ea560d7e1462787dc31bd467cf">SDI_RTE_ID</a>&#160;&#160;&#160;<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aab49ff0110481f22da22a085d2633a0e0">RTE_TRAP_FIRQ_11</a></td></tr> +<tr class="separator:aa0ff72ea560d7e1462787dc31bd467cf"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a68925ca3f482f148caedd36118fd8d79" id="r_a68925ca3f482f148caedd36118fd8d79"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a68925ca3f482f148caedd36118fd8d79">SDI_TRAP_CODE</a>&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a874dcc43cf8fbbf2e0614e7db9e38334">TRAP_CODE_FIRQ_11</a></td></tr> +<tr class="separator:a68925ca3f482f148caedd36118fd8d79"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr><td colspan="2"><div class="groupHeader">General Purpose Timer (GPTMR)</div></td></tr> +<tr class="memitem:a0a59186908b498cb92273b7767966e26" id="r_a0a59186908b498cb92273b7767966e26"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a0a59186908b498cb92273b7767966e26">GPTMR_FIRQ_ENABLE</a>&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a41f91a37f7e0c75c783312af6a72e943">CSR_MIE_FIRQ12E</a></td></tr> +<tr class="separator:a0a59186908b498cb92273b7767966e26"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a4a3164d123ddddd07750f868e67d82d8" id="r_a4a3164d123ddddd07750f868e67d82d8"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a4a3164d123ddddd07750f868e67d82d8">GPTMR_FIRQ_PENDING</a>&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba03edd398920b817150d29107c0b40792">CSR_MIP_FIRQ12P</a></td></tr> +<tr class="separator:a4a3164d123ddddd07750f868e67d82d8"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aac38deeef36de0a474ab238a3054f860" id="r_aac38deeef36de0a474ab238a3054f860"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aac38deeef36de0a474ab238a3054f860">GPTMR_RTE_ID</a>&#160;&#160;&#160;<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aaecea4f1d524a33d02324382357b2bcb9">RTE_TRAP_FIRQ_12</a></td></tr> +<tr class="separator:aac38deeef36de0a474ab238a3054f860"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a445543c36d1f78477aa8ea4841c720a1" id="r_a445543c36d1f78477aa8ea4841c720a1"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a445543c36d1f78477aa8ea4841c720a1">GPTMR_TRAP_CODE</a>&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a151f01e5f284f876cafafc7427720e4c">TRAP_CODE_FIRQ_12</a></td></tr> +<tr class="separator:a445543c36d1f78477aa8ea4841c720a1"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr><td colspan="2"><div class="groupHeader">1-Wire Interface Controller (ONEWIRE)</div></td></tr> +<tr class="memitem:a8bb1918679e32e898af2d485cfa44afb" id="r_a8bb1918679e32e898af2d485cfa44afb"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a8bb1918679e32e898af2d485cfa44afb">ONEWIRE_FIRQ_ENABLE</a>&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a134ed02c7293008b21b1df472be8f11f">CSR_MIE_FIRQ13E</a></td></tr> +<tr class="separator:a8bb1918679e32e898af2d485cfa44afb"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a3853ef999f99ca062e6025038811d0f0" id="r_a3853ef999f99ca062e6025038811d0f0"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a3853ef999f99ca062e6025038811d0f0">ONEWIRE_FIRQ_PENDING</a>&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba14da6a2a962bf82970638a948ffbc570">CSR_MIP_FIRQ13P</a></td></tr> +<tr class="separator:a3853ef999f99ca062e6025038811d0f0"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a142f4a1c754edfab292706618d427b94" id="r_a142f4a1c754edfab292706618d427b94"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a142f4a1c754edfab292706618d427b94">ONEWIRE_RTE_ID</a>&#160;&#160;&#160;<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa609613cf25bb8f2d0e323089d6798220">RTE_TRAP_FIRQ_13</a></td></tr> +<tr class="separator:a142f4a1c754edfab292706618d427b94"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a3e7aaa405a7d1fcd71a36c4b6b5a4081" id="r_a3e7aaa405a7d1fcd71a36c4b6b5a4081"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a3e7aaa405a7d1fcd71a36c4b6b5a4081">ONEWIRE_TRAP_CODE</a>&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a7c8e97297cc4dcd6d5a1de65a124f3e9">TRAP_CODE_FIRQ_13</a></td></tr> +<tr class="separator:a3e7aaa405a7d1fcd71a36c4b6b5a4081"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr><td colspan="2"><div class="groupHeader">Stream Link Interface (SLINK)</div></td></tr> +<tr class="memitem:a8680ab1f14e512f21913572b35cbbf77" id="r_a8680ab1f14e512f21913572b35cbbf77"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a8680ab1f14e512f21913572b35cbbf77">SLINK_RX_FIRQ_ENABLE</a>&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a864d135708530016cfc52a65a1e4d79b">CSR_MIE_FIRQ14E</a></td></tr> +<tr class="separator:a8680ab1f14e512f21913572b35cbbf77"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a5c48d5c4effb47cdb019aa2da7c84526" id="r_a5c48d5c4effb47cdb019aa2da7c84526"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a5c48d5c4effb47cdb019aa2da7c84526">SLINK_RX_FIRQ_PENDING</a>&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21baad1e5e452a9c37561308765431f0260d">CSR_MIP_FIRQ14P</a></td></tr> +<tr class="separator:a5c48d5c4effb47cdb019aa2da7c84526"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a4fff18e72d10377cdcb8d2ac0a617a5d" id="r_a4fff18e72d10377cdcb8d2ac0a617a5d"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a4fff18e72d10377cdcb8d2ac0a617a5d">SLINK_RX_RTE_ID</a>&#160;&#160;&#160;<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aaadd66d9b9c33a6869fa3c30e1e434313">RTE_TRAP_FIRQ_14</a></td></tr> +<tr class="separator:a4fff18e72d10377cdcb8d2ac0a617a5d"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ab1fdaedb2c4c8753ef3be87c82568dda" id="r_ab1fdaedb2c4c8753ef3be87c82568dda"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ab1fdaedb2c4c8753ef3be87c82568dda">SLINK_RX_TRAP_CODE</a>&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a821f813de47eb781ab7715f780da3b1e">TRAP_CODE_FIRQ_14</a></td></tr> +<tr class="separator:ab1fdaedb2c4c8753ef3be87c82568dda"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a232fe0eb5665373b6e2b464bdc228df2" id="r_a232fe0eb5665373b6e2b464bdc228df2"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a232fe0eb5665373b6e2b464bdc228df2">SLINK_TX_FIRQ_ENABLE</a>&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33aa2dfa1183af312de2959dadd217fddc1">CSR_MIE_FIRQ15E</a></td></tr> +<tr class="separator:a232fe0eb5665373b6e2b464bdc228df2"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ac8e98b2af75c8e31f9815dee3dcbaf8e" id="r_ac8e98b2af75c8e31f9815dee3dcbaf8e"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ac8e98b2af75c8e31f9815dee3dcbaf8e">SLINK_TX_FIRQ_PENDING</a>&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba12da8c32d38d5a3539a0b766718bfd2d">CSR_MIP_FIRQ15P</a></td></tr> +<tr class="separator:ac8e98b2af75c8e31f9815dee3dcbaf8e"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a4e039d13b8d3f20453e1bb6b40512e43" id="r_a4e039d13b8d3f20453e1bb6b40512e43"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a4e039d13b8d3f20453e1bb6b40512e43">SLINK_TX_RTE_ID</a>&#160;&#160;&#160;<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa1d18312227bfd5332ebcc1f74c979dbe">RTE_TRAP_FIRQ_15</a></td></tr> +<tr class="separator:a4e039d13b8d3f20453e1bb6b40512e43"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a7fbe28901775e284d5700086f0b0bfcd" id="r_a7fbe28901775e284d5700086f0b0bfcd"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a7fbe28901775e284d5700086f0b0bfcd">SLINK_TX_TRAP_CODE</a>&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1aa4eeafe2f6f59aff01e29461c664a110">TRAP_CODE_FIRQ_15</a></td></tr> +<tr class="separator:a7fbe28901775e284d5700086f0b0bfcd"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="enum-members" name="enum-members"></a> +Enumerations</h2></td></tr> +<tr><td colspan="2"><div class="groupHeader"></div></td></tr> +<tr class="memitem:a10022df4c223533b04d5aebe222e8b73" id="r_a10022df4c223533b04d5aebe222e8b73"><td class="memItemLeft" align="right" valign="top">enum &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a10022df4c223533b04d5aebe222e8b73">NEORV32_CLOCK_PRSC_enum</a> { <br /> +&#160;&#160;<a class="el" href="#a10022df4c223533b04d5aebe222e8b73ad63d40139c50d76618cf1258cbdc0d05">CLK_PRSC_2</a> = 0 +, <a class="el" href="#a10022df4c223533b04d5aebe222e8b73a648249b3ab8c2500880c1e68b98f81d1">CLK_PRSC_4</a> = 1 +, <a class="el" href="#a10022df4c223533b04d5aebe222e8b73aa4e3a6a5b3cd895f63b4544f63ce22c9">CLK_PRSC_8</a> = 2 +, <a class="el" href="#a10022df4c223533b04d5aebe222e8b73a5990532893f2d9606e3c02aff60ca5da">CLK_PRSC_64</a> = 3 +, <br /> +&#160;&#160;<a class="el" href="#a10022df4c223533b04d5aebe222e8b73a933045a5405de55781d687315f42054e">CLK_PRSC_128</a> = 4 +, <a class="el" href="#a10022df4c223533b04d5aebe222e8b73a18aac15afd5ebd8d3a00dd6e513daf17">CLK_PRSC_1024</a> = 5 +, <a class="el" href="#a10022df4c223533b04d5aebe222e8b73aa138f0cad547028d5124f89d6dcc8c79">CLK_PRSC_2048</a> = 6 +, <a class="el" href="#a10022df4c223533b04d5aebe222e8b73a0f20c29722bf9afc478b1a286a6b7eee">CLK_PRSC_4096</a> = 7 +<br /> + }</td></tr> +<tr class="separator:a10022df4c223533b04d5aebe222e8b73"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>Main NEORV32 core library / driver / HAL include file. </p> +<dl class="section see"><dt>See also</dt><dd><a href="https://stnolting.github.io/neorv32/sw/files.html">https://stnolting.github.io/neorv32/sw/files.html</a> </dd></dl> +</div><h2 class="groupheader">Macro Definition Documentation</h2> +<a id="abd8c9b7d79f49de1722611b2835cde58" name="abd8c9b7d79f49de1722611b2835cde58"></a> +<h2 class="memtitle"><span class="permalink"><a href="#abd8c9b7d79f49de1722611b2835cde58">&#9670;&#160;</a></span>BOOTLOADER_BASE_ADDRESS</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define BOOTLOADER_BASE_ADDRESS&#160;&#160;&#160;(0xFFFFC000U)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>bootloader memory base address </p> + +</div> +</div> +<a id="ace79ee46daf3a1b689d9fe79dfcd6627" name="ace79ee46daf3a1b689d9fe79dfcd6627"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ace79ee46daf3a1b689d9fe79dfcd6627">&#9670;&#160;</a></span>CFS_FIRQ_ENABLE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define CFS_FIRQ_ENABLE&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33ac1e1d44becec1b393f79a118ed3d8beb">CSR_MIE_FIRQ1E</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>MIE CSR bit (<a class="el" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33">NEORV32_CSR_MIE_enum</a>) </p> + +</div> +</div> +<a id="aae182648a2c23d070b9db0295388e001" name="aae182648a2c23d070b9db0295388e001"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aae182648a2c23d070b9db0295388e001">&#9670;&#160;</a></span>CFS_FIRQ_PENDING</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define CFS_FIRQ_PENDING&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba2b577b1da1074c29ad58005af1f91d52">CSR_MIP_FIRQ1P</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>MIP CSR bit (<a class="el" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21b">NEORV32_CSR_MIP_enum</a>) </p> + +</div> +</div> +<a id="a095f41fbefaa7acc1bfdd65cd3ce06ea" name="a095f41fbefaa7acc1bfdd65cd3ce06ea"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a095f41fbefaa7acc1bfdd65cd3ce06ea">&#9670;&#160;</a></span>CFS_RTE_ID</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define CFS_RTE_ID&#160;&#160;&#160;<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aab199b53a1458017fa5278e0aeecf41fd">RTE_TRAP_FIRQ_1</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>RTE entry code (<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70a">NEORV32_RTE_TRAP_enum</a>) </p> + +</div> +</div> +<a id="aae6b2ae3fba20ff80bfb59735f179c26" name="aae6b2ae3fba20ff80bfb59735f179c26"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aae6b2ae3fba20ff80bfb59735f179c26">&#9670;&#160;</a></span>CFS_TRAP_CODE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define CFS_TRAP_CODE&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1ae0b1049ae7f8cbfb6ff216e69ed5dae7">TRAP_CODE_FIRQ_1</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>MCAUSE CSR trap code (<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1">NEORV32_EXCEPTION_CODES_enum</a>) </p> + +</div> +</div> +<a id="ace46f95dec73b33bf2535eb653bf8f65" name="ace46f95dec73b33bf2535eb653bf8f65"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ace46f95dec73b33bf2535eb653bf8f65">&#9670;&#160;</a></span>DMA_FIRQ_ENABLE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define DMA_FIRQ_ENABLE&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33affcb52dc57bb8c0cb1e7d3c1392d544a">CSR_MIE_FIRQ10E</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>MIE CSR bit (<a class="el" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33">NEORV32_CSR_MIE_enum</a>) </p> + +</div> +</div> +<a id="a1fa2b25383e6d05cf26f3517091ddbbf" name="a1fa2b25383e6d05cf26f3517091ddbbf"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a1fa2b25383e6d05cf26f3517091ddbbf">&#9670;&#160;</a></span>DMA_FIRQ_PENDING</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define DMA_FIRQ_PENDING&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba2b50cfa8be461b088ea8506ce4c741ba">CSR_MIP_FIRQ10P</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>MIP CSR bit (<a class="el" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21b">NEORV32_CSR_MIP_enum</a>) </p> + +</div> +</div> +<a id="a568b54ba7dfdae736d8d685dc4d32113" name="a568b54ba7dfdae736d8d685dc4d32113"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a568b54ba7dfdae736d8d685dc4d32113">&#9670;&#160;</a></span>DMA_RTE_ID</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define DMA_RTE_ID&#160;&#160;&#160;<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aadebcc4d91aea1364b1481111f1060c52">RTE_TRAP_FIRQ_10</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>RTE entry code (<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70a">NEORV32_RTE_TRAP_enum</a>) </p> + +</div> +</div> +<a id="ad2e81443af8a4ce2db3a4e3c1a8fb784" name="ad2e81443af8a4ce2db3a4e3c1a8fb784"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ad2e81443af8a4ce2db3a4e3c1a8fb784">&#9670;&#160;</a></span>DMA_TRAP_CODE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define DMA_TRAP_CODE&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a4f6b9c6bba91fe04becb776ad22dcf42">TRAP_CODE_FIRQ_10</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>MCAUSE CSR trap code (<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1">NEORV32_EXCEPTION_CODES_enum</a>) </p> + +</div> +</div> +<a id="a0a59186908b498cb92273b7767966e26" name="a0a59186908b498cb92273b7767966e26"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a0a59186908b498cb92273b7767966e26">&#9670;&#160;</a></span>GPTMR_FIRQ_ENABLE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define GPTMR_FIRQ_ENABLE&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a41f91a37f7e0c75c783312af6a72e943">CSR_MIE_FIRQ12E</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>MIE CSR bit (<a class="el" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33">NEORV32_CSR_MIE_enum</a>) </p> + +</div> +</div> +<a id="a4a3164d123ddddd07750f868e67d82d8" name="a4a3164d123ddddd07750f868e67d82d8"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a4a3164d123ddddd07750f868e67d82d8">&#9670;&#160;</a></span>GPTMR_FIRQ_PENDING</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define GPTMR_FIRQ_PENDING&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba03edd398920b817150d29107c0b40792">CSR_MIP_FIRQ12P</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>MIP CSR bit (<a class="el" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21b">NEORV32_CSR_MIP_enum</a>) </p> + +</div> +</div> +<a id="aac38deeef36de0a474ab238a3054f860" name="aac38deeef36de0a474ab238a3054f860"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aac38deeef36de0a474ab238a3054f860">&#9670;&#160;</a></span>GPTMR_RTE_ID</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define GPTMR_RTE_ID&#160;&#160;&#160;<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aaecea4f1d524a33d02324382357b2bcb9">RTE_TRAP_FIRQ_12</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>RTE entry code (<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70a">NEORV32_RTE_TRAP_enum</a>) </p> + +</div> +</div> +<a id="a445543c36d1f78477aa8ea4841c720a1" name="a445543c36d1f78477aa8ea4841c720a1"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a445543c36d1f78477aa8ea4841c720a1">&#9670;&#160;</a></span>GPTMR_TRAP_CODE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define GPTMR_TRAP_CODE&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a151f01e5f284f876cafafc7427720e4c">TRAP_CODE_FIRQ_12</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>MCAUSE CSR trap code (<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1">NEORV32_EXCEPTION_CODES_enum</a>) </p> + +</div> +</div> +<a id="a1eb0cb7fed7e154e15cb4009880a879c" name="a1eb0cb7fed7e154e15cb4009880a879c"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a1eb0cb7fed7e154e15cb4009880a879c">&#9670;&#160;</a></span>IO_BASE_ADDRESS</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define IO_BASE_ADDRESS&#160;&#160;&#160;(0xFFFFE000U)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>peripheral/IO devices memory base address </p> + +</div> +</div> +<a id="a8d0409818600c0b2acfe8253e8f027b8" name="a8d0409818600c0b2acfe8253e8f027b8"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a8d0409818600c0b2acfe8253e8f027b8">&#9670;&#160;</a></span>NEOLED_FIRQ_ENABLE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define NEOLED_FIRQ_ENABLE&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a06fdb61dab31c3490da6c37d47914f19">CSR_MIE_FIRQ9E</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>MIE CSR bit (<a class="el" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33">NEORV32_CSR_MIE_enum</a>) </p> + +</div> +</div> +<a id="aded7d7f5f4ba3a6d90f9a29e62a8cfab" name="aded7d7f5f4ba3a6d90f9a29e62a8cfab"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aded7d7f5f4ba3a6d90f9a29e62a8cfab">&#9670;&#160;</a></span>NEOLED_FIRQ_PENDING</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define NEOLED_FIRQ_PENDING&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21bad94c9691ce59b97fcfec14d345046c3e">CSR_MIP_FIRQ9P</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>MIP CSR bit (<a class="el" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21b">NEORV32_CSR_MIP_enum</a>) </p> + +</div> +</div> +<a id="aca6cfc3f580c4dfe1e213009ee450c58" name="aca6cfc3f580c4dfe1e213009ee450c58"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aca6cfc3f580c4dfe1e213009ee450c58">&#9670;&#160;</a></span>NEOLED_RTE_ID</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define NEOLED_RTE_ID&#160;&#160;&#160;<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa2cd04189d91465dad2bc2a8852406b76">RTE_TRAP_FIRQ_9</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>RTE entry code (<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70a">NEORV32_RTE_TRAP_enum</a>) </p> + +</div> +</div> +<a id="ab4a2ac455d7426992de6877ea7325f21" name="ab4a2ac455d7426992de6877ea7325f21"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ab4a2ac455d7426992de6877ea7325f21">&#9670;&#160;</a></span>NEOLED_TRAP_CODE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define NEOLED_TRAP_CODE&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a350e762a599479fb2c6d23ccc5ee22b4">TRAP_CODE_FIRQ_9</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>MCAUSE CSR trap code (<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1">NEORV32_EXCEPTION_CODES_enum</a>) </p> + +</div> +</div> +<a id="a41d6f97daef61641da96b9f72f6b272f" name="a41d6f97daef61641da96b9f72f6b272f"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a41d6f97daef61641da96b9f72f6b272f">&#9670;&#160;</a></span>NEORV32_CFS_BASE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define NEORV32_CFS_BASE&#160;&#160;&#160;(0xFFFFEB00U)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Custom Functions Subsystem (CFS) </p> + +</div> +</div> +<a id="a0e2377055bdc0f416b5ae4385610600d" name="a0e2377055bdc0f416b5ae4385610600d"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a0e2377055bdc0f416b5ae4385610600d">&#9670;&#160;</a></span>NEORV32_CRC_BASE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define NEORV32_CRC_BASE&#160;&#160;&#160;(0xFFFFEE00U)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Cyclic Redundancy Check Unit (DMA) </p> + +</div> +</div> +<a id="a9bf0149681677f7d87abf8f62e2d9a3d" name="a9bf0149681677f7d87abf8f62e2d9a3d"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a9bf0149681677f7d87abf8f62e2d9a3d">&#9670;&#160;</a></span>NEORV32_DM_BASE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define NEORV32_DM_BASE&#160;&#160;&#160;(0xFFFFFF00U)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>On-Chip Debugger - Debug Module (OCD) </p> + +</div> +</div> +<a id="aa8d3a83ffad1e71f0832a5da78d62008" name="aa8d3a83ffad1e71f0832a5da78d62008"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aa8d3a83ffad1e71f0832a5da78d62008">&#9670;&#160;</a></span>NEORV32_DMA_BASE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define NEORV32_DMA_BASE&#160;&#160;&#160;(0xFFFFED00U)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Direct Memory Access Controller (DMA) </p> + +</div> +</div> +<a id="a7fd1e24d4de2eed7bf9cd5391562c7f4" name="a7fd1e24d4de2eed7bf9cd5391562c7f4"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a7fd1e24d4de2eed7bf9cd5391562c7f4">&#9670;&#160;</a></span>NEORV32_GPIO_BASE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define NEORV32_GPIO_BASE&#160;&#160;&#160;(0xFFFFFC00U)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>General Purpose Input/Output Port Controller (GPIO) </p> + +</div> +</div> +<a id="a0991b1a5ba1e8c3550eb9770d43589d0" name="a0991b1a5ba1e8c3550eb9770d43589d0"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a0991b1a5ba1e8c3550eb9770d43589d0">&#9670;&#160;</a></span>NEORV32_GPTMR_BASE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define NEORV32_GPTMR_BASE&#160;&#160;&#160;(0xFFFFF100U)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>General Purpose Timer (GPTMR) </p> + +</div> +</div> +<a id="ab98f762df259a2bbc28d19d2acfe9e23" name="ab98f762df259a2bbc28d19d2acfe9e23"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ab98f762df259a2bbc28d19d2acfe9e23">&#9670;&#160;</a></span>NEORV32_MTIME_BASE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define NEORV32_MTIME_BASE&#160;&#160;&#160;(0xFFFFF400U)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Machine System Timer (MTIME) </p> + +</div> +</div> +<a id="a559fdce92e8af5efc426c8fc48d14f99" name="a559fdce92e8af5efc426c8fc48d14f99"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a559fdce92e8af5efc426c8fc48d14f99">&#9670;&#160;</a></span>NEORV32_NEOLED_BASE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define NEORV32_NEOLED_BASE&#160;&#160;&#160;(0xFFFFFD00U)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Smart LED Hardware Interface (NEOLED) </p> + +</div> +</div> +<a id="a8d0b612e52b77395a05d4f18af6fcf00" name="a8d0b612e52b77395a05d4f18af6fcf00"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a8d0b612e52b77395a05d4f18af6fcf00">&#9670;&#160;</a></span>NEORV32_ONEWIRE_BASE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define NEORV32_ONEWIRE_BASE&#160;&#160;&#160;(0xFFFFF200U)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>1-Wire Interface Controller (ONEWIRE) </p> + +</div> +</div> +<a id="afef7a6b121a788560b29e2ee2a58c725" name="afef7a6b121a788560b29e2ee2a58c725"></a> +<h2 class="memtitle"><span class="permalink"><a href="#afef7a6b121a788560b29e2ee2a58c725">&#9670;&#160;</a></span>NEORV32_PWM_BASE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define NEORV32_PWM_BASE&#160;&#160;&#160;(0xFFFFF000U)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Pulse Width Modulation Controller (PWM) </p> + +</div> +</div> +<a id="a9b316ec038bd94ada42c9dab57a0a3cb" name="a9b316ec038bd94ada42c9dab57a0a3cb"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a9b316ec038bd94ada42c9dab57a0a3cb">&#9670;&#160;</a></span>NEORV32_SDI_BASE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define NEORV32_SDI_BASE&#160;&#160;&#160;(0xFFFFF700U)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Serial Data Interface (SDI) </p> + +</div> +</div> +<a id="ab5e6dc57886cd5ed98b86f22fc37d7cc" name="ab5e6dc57886cd5ed98b86f22fc37d7cc"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ab5e6dc57886cd5ed98b86f22fc37d7cc">&#9670;&#160;</a></span>NEORV32_SLINK_BASE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define NEORV32_SLINK_BASE&#160;&#160;&#160;(0xFFFFEC00U)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Stream Link Interface (SLINK) </p> + +</div> +</div> +<a id="aa466dc5eace7351bd438606f0f7475a7" name="aa466dc5eace7351bd438606f0f7475a7"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aa466dc5eace7351bd438606f0f7475a7">&#9670;&#160;</a></span>NEORV32_SPI_BASE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define NEORV32_SPI_BASE&#160;&#160;&#160;(0xFFFFF800U)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Serial Peripheral Interface Controller (SPI) </p> + +</div> +</div> +<a id="a5aa936f38782232c7ed3eab1283ee536" name="a5aa936f38782232c7ed3eab1283ee536"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a5aa936f38782232c7ed3eab1283ee536">&#9670;&#160;</a></span>NEORV32_SYSINFO_BASE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define NEORV32_SYSINFO_BASE&#160;&#160;&#160;(0xFFFFFE00U)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>System Information Memory (SYSINFO) </p> + +</div> +</div> +<a id="ab4846cd153e8a23deec45d81cc8372a2" name="ab4846cd153e8a23deec45d81cc8372a2"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ab4846cd153e8a23deec45d81cc8372a2">&#9670;&#160;</a></span>NEORV32_TRNG_BASE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define NEORV32_TRNG_BASE&#160;&#160;&#160;(0xFFFFFA00U)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>True Random Number Generator (TRNG) </p> + +</div> +</div> +<a id="a4a741408a4bb0938e03b99555306db9c" name="a4a741408a4bb0938e03b99555306db9c"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a4a741408a4bb0938e03b99555306db9c">&#9670;&#160;</a></span>NEORV32_TWI_BASE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define NEORV32_TWI_BASE&#160;&#160;&#160;(0xFFFFF900U)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Two-Wire Interface Controller (TWI) </p> + +</div> +</div> +<a id="a000b37f710043fe21e49b2fdbc039d94" name="a000b37f710043fe21e49b2fdbc039d94"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a000b37f710043fe21e49b2fdbc039d94">&#9670;&#160;</a></span>NEORV32_UART0_BASE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define NEORV32_UART0_BASE&#160;&#160;&#160;(0xFFFFF500U)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Primary Universal Asynchronous Receiver and Transmitter (UART0) </p> + +</div> +</div> +<a id="a26a1defe18ce222b8b4ed1c760344700" name="a26a1defe18ce222b8b4ed1c760344700"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a26a1defe18ce222b8b4ed1c760344700">&#9670;&#160;</a></span>NEORV32_UART1_BASE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define NEORV32_UART1_BASE&#160;&#160;&#160;(0xFFFFF600U)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Secondary Universal Asynchronous Receiver and Transmitter (UART1) </p> + +</div> +</div> +<a id="a3012986cdd5748ee96bcc74cd7108dea" name="a3012986cdd5748ee96bcc74cd7108dea"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a3012986cdd5748ee96bcc74cd7108dea">&#9670;&#160;</a></span>NEORV32_WDT_BASE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define NEORV32_WDT_BASE&#160;&#160;&#160;(0xFFFFFB00U)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Watchdog Timer (WDT) </p> + +</div> +</div> +<a id="ae0978315beac8399f96f520bda81c7fe" name="ae0978315beac8399f96f520bda81c7fe"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ae0978315beac8399f96f520bda81c7fe">&#9670;&#160;</a></span>NEORV32_XIP_BASE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define NEORV32_XIP_BASE&#160;&#160;&#160;(0xFFFFEF00U)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Execute In Place Module (XIP) </p> + +</div> +</div> +<a id="a942a897be2d4ae6820bee0f7bb3a0ff1" name="a942a897be2d4ae6820bee0f7bb3a0ff1"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a942a897be2d4ae6820bee0f7bb3a0ff1">&#9670;&#160;</a></span>NEORV32_XIRQ_BASE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define NEORV32_XIRQ_BASE&#160;&#160;&#160;(0xFFFFF300U)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>External Interrupt Controller (XIRQ) </p> + +</div> +</div> +<a id="a8bb1918679e32e898af2d485cfa44afb" name="a8bb1918679e32e898af2d485cfa44afb"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a8bb1918679e32e898af2d485cfa44afb">&#9670;&#160;</a></span>ONEWIRE_FIRQ_ENABLE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define ONEWIRE_FIRQ_ENABLE&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a134ed02c7293008b21b1df472be8f11f">CSR_MIE_FIRQ13E</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>MIE CSR bit (<a class="el" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33">NEORV32_CSR_MIE_enum</a>) </p> + +</div> +</div> +<a id="a3853ef999f99ca062e6025038811d0f0" name="a3853ef999f99ca062e6025038811d0f0"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a3853ef999f99ca062e6025038811d0f0">&#9670;&#160;</a></span>ONEWIRE_FIRQ_PENDING</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define ONEWIRE_FIRQ_PENDING&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba14da6a2a962bf82970638a948ffbc570">CSR_MIP_FIRQ13P</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>MIP CSR bit (<a class="el" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21b">NEORV32_CSR_MIP_enum</a>) </p> + +</div> +</div> +<a id="a142f4a1c754edfab292706618d427b94" name="a142f4a1c754edfab292706618d427b94"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a142f4a1c754edfab292706618d427b94">&#9670;&#160;</a></span>ONEWIRE_RTE_ID</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define ONEWIRE_RTE_ID&#160;&#160;&#160;<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa609613cf25bb8f2d0e323089d6798220">RTE_TRAP_FIRQ_13</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>RTE entry code (<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70a">NEORV32_RTE_TRAP_enum</a>) </p> + +</div> +</div> +<a id="a3e7aaa405a7d1fcd71a36c4b6b5a4081" name="a3e7aaa405a7d1fcd71a36c4b6b5a4081"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a3e7aaa405a7d1fcd71a36c4b6b5a4081">&#9670;&#160;</a></span>ONEWIRE_TRAP_CODE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define ONEWIRE_TRAP_CODE&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a7c8e97297cc4dcd6d5a1de65a124f3e9">TRAP_CODE_FIRQ_13</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>MCAUSE CSR trap code (<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1">NEORV32_EXCEPTION_CODES_enum</a>) </p> + +</div> +</div> +<a id="a30cf20b6d704c50cc5c46238bb43646f" name="a30cf20b6d704c50cc5c46238bb43646f"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a30cf20b6d704c50cc5c46238bb43646f">&#9670;&#160;</a></span>SDI_FIRQ_ENABLE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define SDI_FIRQ_ENABLE&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33af058342854a0becd3bcc33877d9244cd">CSR_MIE_FIRQ11E</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>MIE CSR bit (<a class="el" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33">NEORV32_CSR_MIE_enum</a>) </p> + +</div> +</div> +<a id="a68611c0dfbe331739eff10230ac3fede" name="a68611c0dfbe331739eff10230ac3fede"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a68611c0dfbe331739eff10230ac3fede">&#9670;&#160;</a></span>SDI_FIRQ_PENDING</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define SDI_FIRQ_PENDING&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba69ea0d3d76d4cec398f3b96959cc3544">CSR_MIP_FIRQ11P</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>MIP CSR bit (<a class="el" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21b">NEORV32_CSR_MIP_enum</a>) </p> + +</div> +</div> +<a id="aa0ff72ea560d7e1462787dc31bd467cf" name="aa0ff72ea560d7e1462787dc31bd467cf"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aa0ff72ea560d7e1462787dc31bd467cf">&#9670;&#160;</a></span>SDI_RTE_ID</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define SDI_RTE_ID&#160;&#160;&#160;<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aab49ff0110481f22da22a085d2633a0e0">RTE_TRAP_FIRQ_11</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>RTE entry code (<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70a">NEORV32_RTE_TRAP_enum</a>) </p> + +</div> +</div> +<a id="a68925ca3f482f148caedd36118fd8d79" name="a68925ca3f482f148caedd36118fd8d79"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a68925ca3f482f148caedd36118fd8d79">&#9670;&#160;</a></span>SDI_TRAP_CODE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define SDI_TRAP_CODE&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a874dcc43cf8fbbf2e0614e7db9e38334">TRAP_CODE_FIRQ_11</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>MCAUSE CSR trap code (<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1">NEORV32_EXCEPTION_CODES_enum</a>) </p> + +</div> +</div> +<a id="a8680ab1f14e512f21913572b35cbbf77" name="a8680ab1f14e512f21913572b35cbbf77"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a8680ab1f14e512f21913572b35cbbf77">&#9670;&#160;</a></span>SLINK_RX_FIRQ_ENABLE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define SLINK_RX_FIRQ_ENABLE&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a864d135708530016cfc52a65a1e4d79b">CSR_MIE_FIRQ14E</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>MIE CSR bit (<a class="el" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33">NEORV32_CSR_MIE_enum</a>) </p> + +</div> +</div> +<a id="a5c48d5c4effb47cdb019aa2da7c84526" name="a5c48d5c4effb47cdb019aa2da7c84526"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a5c48d5c4effb47cdb019aa2da7c84526">&#9670;&#160;</a></span>SLINK_RX_FIRQ_PENDING</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define SLINK_RX_FIRQ_PENDING&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21baad1e5e452a9c37561308765431f0260d">CSR_MIP_FIRQ14P</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>MIP CSR bit (<a class="el" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21b">NEORV32_CSR_MIP_enum</a>) </p> + +</div> +</div> +<a id="a4fff18e72d10377cdcb8d2ac0a617a5d" name="a4fff18e72d10377cdcb8d2ac0a617a5d"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a4fff18e72d10377cdcb8d2ac0a617a5d">&#9670;&#160;</a></span>SLINK_RX_RTE_ID</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define SLINK_RX_RTE_ID&#160;&#160;&#160;<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aaadd66d9b9c33a6869fa3c30e1e434313">RTE_TRAP_FIRQ_14</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>RTE entry code (<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70a">NEORV32_RTE_TRAP_enum</a>) </p> + +</div> +</div> +<a id="ab1fdaedb2c4c8753ef3be87c82568dda" name="ab1fdaedb2c4c8753ef3be87c82568dda"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ab1fdaedb2c4c8753ef3be87c82568dda">&#9670;&#160;</a></span>SLINK_RX_TRAP_CODE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define SLINK_RX_TRAP_CODE&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a821f813de47eb781ab7715f780da3b1e">TRAP_CODE_FIRQ_14</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>MCAUSE CSR trap code (<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1">NEORV32_EXCEPTION_CODES_enum</a>) </p> + +</div> +</div> +<a id="a232fe0eb5665373b6e2b464bdc228df2" name="a232fe0eb5665373b6e2b464bdc228df2"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a232fe0eb5665373b6e2b464bdc228df2">&#9670;&#160;</a></span>SLINK_TX_FIRQ_ENABLE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define SLINK_TX_FIRQ_ENABLE&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33aa2dfa1183af312de2959dadd217fddc1">CSR_MIE_FIRQ15E</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>MIE CSR bit (<a class="el" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33">NEORV32_CSR_MIE_enum</a>) </p> + +</div> +</div> +<a id="ac8e98b2af75c8e31f9815dee3dcbaf8e" name="ac8e98b2af75c8e31f9815dee3dcbaf8e"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ac8e98b2af75c8e31f9815dee3dcbaf8e">&#9670;&#160;</a></span>SLINK_TX_FIRQ_PENDING</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define SLINK_TX_FIRQ_PENDING&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba12da8c32d38d5a3539a0b766718bfd2d">CSR_MIP_FIRQ15P</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>MIP CSR bit (<a class="el" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21b">NEORV32_CSR_MIP_enum</a>) </p> + +</div> +</div> +<a id="a4e039d13b8d3f20453e1bb6b40512e43" name="a4e039d13b8d3f20453e1bb6b40512e43"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a4e039d13b8d3f20453e1bb6b40512e43">&#9670;&#160;</a></span>SLINK_TX_RTE_ID</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define SLINK_TX_RTE_ID&#160;&#160;&#160;<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa1d18312227bfd5332ebcc1f74c979dbe">RTE_TRAP_FIRQ_15</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>RTE entry code (<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70a">NEORV32_RTE_TRAP_enum</a>) </p> + +</div> +</div> +<a id="a7fbe28901775e284d5700086f0b0bfcd" name="a7fbe28901775e284d5700086f0b0bfcd"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a7fbe28901775e284d5700086f0b0bfcd">&#9670;&#160;</a></span>SLINK_TX_TRAP_CODE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define SLINK_TX_TRAP_CODE&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1aa4eeafe2f6f59aff01e29461c664a110">TRAP_CODE_FIRQ_15</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>MCAUSE CSR trap code (<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1">NEORV32_EXCEPTION_CODES_enum</a>) </p> + +</div> +</div> +<a id="ab8fcd3f80c373eb0f9d0fc6bf64ca626" name="ab8fcd3f80c373eb0f9d0fc6bf64ca626"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ab8fcd3f80c373eb0f9d0fc6bf64ca626">&#9670;&#160;</a></span>SPI_FIRQ_ENABLE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define SPI_FIRQ_ENABLE&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a96315d6b5b9531bcbc1e78a3c9ab166a">CSR_MIE_FIRQ6E</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>MIE CSR bit (<a class="el" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33">NEORV32_CSR_MIE_enum</a>) </p> + +</div> +</div> +<a id="ab2f58f746febb29a9828447c733f8043" name="ab2f58f746febb29a9828447c733f8043"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ab2f58f746febb29a9828447c733f8043">&#9670;&#160;</a></span>SPI_FIRQ_PENDING</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define SPI_FIRQ_PENDING&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21baffa7342631aa0526aaa44c0c549b1f3e">CSR_MIP_FIRQ6P</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>MIP CSR bit (<a class="el" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21b">NEORV32_CSR_MIP_enum</a>) </p> + +</div> +</div> +<a id="a4c1cd9ec9f80da2080e5d0d35cc524dd" name="a4c1cd9ec9f80da2080e5d0d35cc524dd"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a4c1cd9ec9f80da2080e5d0d35cc524dd">&#9670;&#160;</a></span>SPI_RTE_ID</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define SPI_RTE_ID&#160;&#160;&#160;<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aac9fb28ea8bafff182f12c29d2fad6998">RTE_TRAP_FIRQ_6</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>RTE entry code (<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70a">NEORV32_RTE_TRAP_enum</a>) </p> + +</div> +</div> +<a id="a83c212f1f5d8ee2a5921b3b2b19e9cc4" name="a83c212f1f5d8ee2a5921b3b2b19e9cc4"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a83c212f1f5d8ee2a5921b3b2b19e9cc4">&#9670;&#160;</a></span>SPI_TRAP_CODE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define SPI_TRAP_CODE&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a809e997f55e83c6812c965655511d473">TRAP_CODE_FIRQ_6</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>MCAUSE CSR trap code (<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1">NEORV32_EXCEPTION_CODES_enum</a>) </p> + +</div> +</div> +<a id="a2896d832852c016eb85210b523642f11" name="a2896d832852c016eb85210b523642f11"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a2896d832852c016eb85210b523642f11">&#9670;&#160;</a></span>TRNG_FIRQ_ENABLE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define TRNG_FIRQ_ENABLE&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a99f43f8bbfb29fba6224f081c363ac7d">CSR_MIE_FIRQ0E</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>MIE CSR bit (<a class="el" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33">NEORV32_CSR_MIE_enum</a>) </p> + +</div> +</div> +<a id="a9c387ca4e2736a27056c11819947c84a" name="a9c387ca4e2736a27056c11819947c84a"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a9c387ca4e2736a27056c11819947c84a">&#9670;&#160;</a></span>TRNG_FIRQ_PENDING</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define TRNG_FIRQ_PENDING&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba28a85ad8bd4c30fd3a91298dfa4fdb00">CSR_MIP_FIRQ0P</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>MIP CSR bit (<a class="el" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21b">NEORV32_CSR_MIP_enum</a>) </p> + +</div> +</div> +<a id="afaa705a674acf3fd6c8cb294eaf11c5e" name="afaa705a674acf3fd6c8cb294eaf11c5e"></a> +<h2 class="memtitle"><span class="permalink"><a href="#afaa705a674acf3fd6c8cb294eaf11c5e">&#9670;&#160;</a></span>TRNG_RTE_ID</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define TRNG_RTE_ID&#160;&#160;&#160;<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aab36a403cd7b833439ce7f9a708c33922">RTE_TRAP_FIRQ_0</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>RTE entry code (<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70a">NEORV32_RTE_TRAP_enum</a>) </p> + +</div> +</div> +<a id="a11e34802c61a01fd6cba46e3f92d5ac1" name="a11e34802c61a01fd6cba46e3f92d5ac1"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a11e34802c61a01fd6cba46e3f92d5ac1">&#9670;&#160;</a></span>TRNG_TRAP_CODE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define TRNG_TRAP_CODE&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a0cef77904935798d247d8396838297c1">TRAP_CODE_FIRQ_0</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>MCAUSE CSR trap code (<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1">NEORV32_EXCEPTION_CODES_enum</a>) </p> + +</div> +</div> +<a id="a0913144fce247e24ccd0f178b9ac32b7" name="a0913144fce247e24ccd0f178b9ac32b7"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a0913144fce247e24ccd0f178b9ac32b7">&#9670;&#160;</a></span>TWI_FIRQ_ENABLE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define TWI_FIRQ_ENABLE&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a3d9d729940170609affbc6813054ebe8">CSR_MIE_FIRQ7E</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>MIE CSR bit (<a class="el" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33">NEORV32_CSR_MIE_enum</a>) </p> + +</div> +</div> +<a id="a48b80113ca718fbdc50d75e1ec96a1ff" name="a48b80113ca718fbdc50d75e1ec96a1ff"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a48b80113ca718fbdc50d75e1ec96a1ff">&#9670;&#160;</a></span>TWI_FIRQ_PENDING</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define TWI_FIRQ_PENDING&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21baad691486001a68f2375dcf5793ee795a">CSR_MIP_FIRQ7P</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>MIP CSR bit (<a class="el" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21b">NEORV32_CSR_MIP_enum</a>) </p> + +</div> +</div> +<a id="a1ac29f2f7bace5ba92b2b68a4541a60c" name="a1ac29f2f7bace5ba92b2b68a4541a60c"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a1ac29f2f7bace5ba92b2b68a4541a60c">&#9670;&#160;</a></span>TWI_RTE_ID</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define TWI_RTE_ID&#160;&#160;&#160;<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa73bb84f7b6c7528bec552ac1d3e9ccdb">RTE_TRAP_FIRQ_7</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>RTE entry code (<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70a">NEORV32_RTE_TRAP_enum</a>) </p> + +</div> +</div> +<a id="a0afc1a759116d4d73a199ef769bced47" name="a0afc1a759116d4d73a199ef769bced47"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a0afc1a759116d4d73a199ef769bced47">&#9670;&#160;</a></span>TWI_TRAP_CODE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define TWI_TRAP_CODE&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1aeab719bcce9e9551bd6da65a7ae08a26">TRAP_CODE_FIRQ_7</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>MCAUSE CSR trap code (<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1">NEORV32_EXCEPTION_CODES_enum</a>) </p> + +</div> +</div> +<a id="a6b55ce6abe6b141000a6bb00949169e9" name="a6b55ce6abe6b141000a6bb00949169e9"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a6b55ce6abe6b141000a6bb00949169e9">&#9670;&#160;</a></span>UART0_RX_FIRQ_ENABLE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define UART0_RX_FIRQ_ENABLE&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33afc805280e20ffface116ca61e11645f7">CSR_MIE_FIRQ2E</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>MIE CSR bit (<a class="el" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33">NEORV32_CSR_MIE_enum</a>) </p> + +</div> +</div> +<a id="a0b738b26abb2b951f1f5c5d9525d7701" name="a0b738b26abb2b951f1f5c5d9525d7701"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a0b738b26abb2b951f1f5c5d9525d7701">&#9670;&#160;</a></span>UART0_RX_FIRQ_PENDING</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define UART0_RX_FIRQ_PENDING&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21badf45c5a135431f958fa63574c1dfac6e">CSR_MIP_FIRQ2P</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>MIP CSR bit (<a class="el" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21b">NEORV32_CSR_MIP_enum</a>) </p> + +</div> +</div> +<a id="ae8588cca20d5e36f74c5207c376389a1" name="ae8588cca20d5e36f74c5207c376389a1"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ae8588cca20d5e36f74c5207c376389a1">&#9670;&#160;</a></span>UART0_RX_RTE_ID</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define UART0_RX_RTE_ID&#160;&#160;&#160;<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa29ffa3108fadc78bf375773c3232c489">RTE_TRAP_FIRQ_2</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>RTE entry code (<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70a">NEORV32_RTE_TRAP_enum</a>) </p> + +</div> +</div> +<a id="a7a849638eff31f2e1955bdc53d4fc84d" name="a7a849638eff31f2e1955bdc53d4fc84d"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a7a849638eff31f2e1955bdc53d4fc84d">&#9670;&#160;</a></span>UART0_RX_TRAP_CODE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define UART0_RX_TRAP_CODE&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1ad753d3e2563b4fd663430af9f3888dc7">TRAP_CODE_FIRQ_2</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>MCAUSE CSR trap code (<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1">NEORV32_EXCEPTION_CODES_enum</a>) </p> + +</div> +</div> +<a id="aff756a395771f22c5f412f23f177ea7d" name="aff756a395771f22c5f412f23f177ea7d"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aff756a395771f22c5f412f23f177ea7d">&#9670;&#160;</a></span>UART0_TX_FIRQ_ENABLE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define UART0_TX_FIRQ_ENABLE&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a666066099d6cebadbef21d81c179e8db">CSR_MIE_FIRQ3E</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>MIE CSR bit (<a class="el" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33">NEORV32_CSR_MIE_enum</a>) </p> + +</div> +</div> +<a id="addbe29166bb77bc045ad0e3db68e57e9" name="addbe29166bb77bc045ad0e3db68e57e9"></a> +<h2 class="memtitle"><span class="permalink"><a href="#addbe29166bb77bc045ad0e3db68e57e9">&#9670;&#160;</a></span>UART0_TX_FIRQ_PENDING</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define UART0_TX_FIRQ_PENDING&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba7512bb6c4841ddd477422b49ebb2a155">CSR_MIP_FIRQ3P</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>MIP CSR bit (<a class="el" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21b">NEORV32_CSR_MIP_enum</a>) </p> + +</div> +</div> +<a id="a9dc37695ca169bc0eb93898e7aeeee58" name="a9dc37695ca169bc0eb93898e7aeeee58"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a9dc37695ca169bc0eb93898e7aeeee58">&#9670;&#160;</a></span>UART0_TX_RTE_ID</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define UART0_TX_RTE_ID&#160;&#160;&#160;<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa4a74188fd87ea17a594ac6fe8ddf71be">RTE_TRAP_FIRQ_3</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>RTE entry code (<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70a">NEORV32_RTE_TRAP_enum</a>) </p> + +</div> +</div> +<a id="ab50df423fdba86bb83bc5d90a4c3bb20" name="ab50df423fdba86bb83bc5d90a4c3bb20"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ab50df423fdba86bb83bc5d90a4c3bb20">&#9670;&#160;</a></span>UART0_TX_TRAP_CODE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define UART0_TX_TRAP_CODE&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a356f8485166529503d0fb246bd0aeeb0">TRAP_CODE_FIRQ_3</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>MCAUSE CSR trap code (<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1">NEORV32_EXCEPTION_CODES_enum</a>) </p> + +</div> +</div> +<a id="a6c118c1784d8446360b00cde97437ca7" name="a6c118c1784d8446360b00cde97437ca7"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a6c118c1784d8446360b00cde97437ca7">&#9670;&#160;</a></span>UART1_RX_FIRQ_ENABLE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define UART1_RX_FIRQ_ENABLE&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a592939f1b7d79097f7f13d6ab0c268dc">CSR_MIE_FIRQ4E</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>MIE CSR bit (<a class="el" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33">NEORV32_CSR_MIE_enum</a>) </p> + +</div> +</div> +<a id="a2e70d3a4e2973d224643813fcf315a20" name="a2e70d3a4e2973d224643813fcf315a20"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a2e70d3a4e2973d224643813fcf315a20">&#9670;&#160;</a></span>UART1_RX_FIRQ_PENDING</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define UART1_RX_FIRQ_PENDING&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21bab6421f242bb8a487a986346e11196eb8">CSR_MIP_FIRQ4P</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>MIP CSR bit (<a class="el" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21b">NEORV32_CSR_MIP_enum</a>) </p> + +</div> +</div> +<a id="ab1c351f5ea19ac9ea864155be9cc0b4b" name="ab1c351f5ea19ac9ea864155be9cc0b4b"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ab1c351f5ea19ac9ea864155be9cc0b4b">&#9670;&#160;</a></span>UART1_RX_RTE_ID</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define UART1_RX_RTE_ID&#160;&#160;&#160;<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa8b39868bf91da54f9ec492918e0c01ff">RTE_TRAP_FIRQ_4</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>RTE entry code (<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70a">NEORV32_RTE_TRAP_enum</a>) </p> + +</div> +</div> +<a id="ad0b9eb2ee1f411d7fccdf4fe263214e1" name="ad0b9eb2ee1f411d7fccdf4fe263214e1"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ad0b9eb2ee1f411d7fccdf4fe263214e1">&#9670;&#160;</a></span>UART1_RX_TRAP_CODE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define UART1_RX_TRAP_CODE&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1aaa8e7bb251852ef75a78be71eef0b547">TRAP_CODE_FIRQ_4</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>MCAUSE CSR trap code (<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1">NEORV32_EXCEPTION_CODES_enum</a>) </p> + +</div> +</div> +<a id="a0039bae3454a22e71d64e70d674f5d6a" name="a0039bae3454a22e71d64e70d674f5d6a"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a0039bae3454a22e71d64e70d674f5d6a">&#9670;&#160;</a></span>UART1_TX_FIRQ_ENABLE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define UART1_TX_FIRQ_ENABLE&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a3079a8fbf3b8e376865bff76f2173698">CSR_MIE_FIRQ5E</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>MIE CSR bit (<a class="el" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33">NEORV32_CSR_MIE_enum</a>) </p> + +</div> +</div> +<a id="ac4060532b7aa390623f54720460a2680" name="ac4060532b7aa390623f54720460a2680"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ac4060532b7aa390623f54720460a2680">&#9670;&#160;</a></span>UART1_TX_FIRQ_PENDING</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define UART1_TX_FIRQ_PENDING&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21baaa55d19f9a47889bc364c94bda04b677">CSR_MIP_FIRQ5P</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>MIP CSR bit (<a class="el" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21b">NEORV32_CSR_MIP_enum</a>) </p> + +</div> +</div> +<a id="a6af270d7ae8b1cde30e44eb9142491d3" name="a6af270d7ae8b1cde30e44eb9142491d3"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a6af270d7ae8b1cde30e44eb9142491d3">&#9670;&#160;</a></span>UART1_TX_RTE_ID</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define UART1_TX_RTE_ID&#160;&#160;&#160;<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa01f562418ddbbb6b84be168673deeea9">RTE_TRAP_FIRQ_5</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>RTE entry code (<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70a">NEORV32_RTE_TRAP_enum</a>) </p> + +</div> +</div> +<a id="a4cc50287c7a53982761a8116396ff7dd" name="a4cc50287c7a53982761a8116396ff7dd"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a4cc50287c7a53982761a8116396ff7dd">&#9670;&#160;</a></span>UART1_TX_TRAP_CODE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define UART1_TX_TRAP_CODE&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a5789dfabd8ec265fa0734ddd94e98757">TRAP_CODE_FIRQ_5</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>MCAUSE CSR trap code (<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1">NEORV32_EXCEPTION_CODES_enum</a>) </p> + +</div> +</div> +<a id="aa01bea676e878a9e87ca10ce2d91e51f" name="aa01bea676e878a9e87ca10ce2d91e51f"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aa01bea676e878a9e87ca10ce2d91e51f">&#9670;&#160;</a></span>XIP_MEM_BASE_ADDRESS</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define XIP_MEM_BASE_ADDRESS&#160;&#160;&#160;(0xE0000000U)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>XIP-mapped memory base address </p> + +</div> +</div> +<a id="afe0cb262d517c7da73d6b5dc78886334" name="afe0cb262d517c7da73d6b5dc78886334"></a> +<h2 class="memtitle"><span class="permalink"><a href="#afe0cb262d517c7da73d6b5dc78886334">&#9670;&#160;</a></span>XIRQ_FIRQ_ENABLE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define XIRQ_FIRQ_ENABLE&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a396c6c4b425b3fff598e2f846052f98e">CSR_MIE_FIRQ8E</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>MIE CSR bit (<a class="el" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33">NEORV32_CSR_MIE_enum</a>) </p> + +</div> +</div> +<a id="a866768963f8648363dce40de9f34d61b" name="a866768963f8648363dce40de9f34d61b"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a866768963f8648363dce40de9f34d61b">&#9670;&#160;</a></span>XIRQ_FIRQ_PENDING</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define XIRQ_FIRQ_PENDING&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21baf5bbd23d4f311f640db42e9015f87580">CSR_MIP_FIRQ8P</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>MIP CSR bit (<a class="el" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21b">NEORV32_CSR_MIP_enum</a>) </p> + +</div> +</div> +<a id="a95387d3482ec8e5c1d734805fdf64fa5" name="a95387d3482ec8e5c1d734805fdf64fa5"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a95387d3482ec8e5c1d734805fdf64fa5">&#9670;&#160;</a></span>XIRQ_RTE_ID</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define XIRQ_RTE_ID&#160;&#160;&#160;<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa3edbf47bd9a278e100bb808c8bb68308">RTE_TRAP_FIRQ_8</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>RTE entry code (<a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70a">NEORV32_RTE_TRAP_enum</a>) </p> + +</div> +</div> +<a id="a16b9a7444833b5581df073661deb8f3a" name="a16b9a7444833b5581df073661deb8f3a"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a16b9a7444833b5581df073661deb8f3a">&#9670;&#160;</a></span>XIRQ_TRAP_CODE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define XIRQ_TRAP_CODE&#160;&#160;&#160;<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1abfd21d1380dcacb9282e525da104d916">TRAP_CODE_FIRQ_8</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>MCAUSE CSR trap code (<a class="el" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1">NEORV32_EXCEPTION_CODES_enum</a>) </p> + +</div> +</div> +<h2 class="groupheader">Enumeration Type Documentation</h2> +<a id="a10022df4c223533b04d5aebe222e8b73" name="a10022df4c223533b04d5aebe222e8b73"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a10022df4c223533b04d5aebe222e8b73">&#9670;&#160;</a></span>NEORV32_CLOCK_PRSC_enum</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">enum <a class="el" href="#a10022df4c223533b04d5aebe222e8b73">NEORV32_CLOCK_PRSC_enum</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Processor clock prescaler select (relative to processor's main clock) </p> +<table class="fieldtable"> +<tr><th colspan="2">Enumerator</th></tr><tr><td class="fieldname"><a id="a10022df4c223533b04d5aebe222e8b73ad63d40139c50d76618cf1258cbdc0d05" name="a10022df4c223533b04d5aebe222e8b73ad63d40139c50d76618cf1258cbdc0d05"></a>CLK_PRSC_2&#160;</td><td class="fielddoc"><p>CPU_CLK / 2 </p> +</td></tr> +<tr><td class="fieldname"><a id="a10022df4c223533b04d5aebe222e8b73a648249b3ab8c2500880c1e68b98f81d1" name="a10022df4c223533b04d5aebe222e8b73a648249b3ab8c2500880c1e68b98f81d1"></a>CLK_PRSC_4&#160;</td><td class="fielddoc"><p>CPU_CLK / 4 </p> +</td></tr> +<tr><td class="fieldname"><a id="a10022df4c223533b04d5aebe222e8b73aa4e3a6a5b3cd895f63b4544f63ce22c9" name="a10022df4c223533b04d5aebe222e8b73aa4e3a6a5b3cd895f63b4544f63ce22c9"></a>CLK_PRSC_8&#160;</td><td class="fielddoc"><p>CPU_CLK / 8 </p> +</td></tr> +<tr><td class="fieldname"><a id="a10022df4c223533b04d5aebe222e8b73a5990532893f2d9606e3c02aff60ca5da" name="a10022df4c223533b04d5aebe222e8b73a5990532893f2d9606e3c02aff60ca5da"></a>CLK_PRSC_64&#160;</td><td class="fielddoc"><p>CPU_CLK / 64 </p> +</td></tr> +<tr><td class="fieldname"><a id="a10022df4c223533b04d5aebe222e8b73a933045a5405de55781d687315f42054e" name="a10022df4c223533b04d5aebe222e8b73a933045a5405de55781d687315f42054e"></a>CLK_PRSC_128&#160;</td><td class="fielddoc"><p>CPU_CLK / 128 </p> +</td></tr> +<tr><td class="fieldname"><a id="a10022df4c223533b04d5aebe222e8b73a18aac15afd5ebd8d3a00dd6e513daf17" name="a10022df4c223533b04d5aebe222e8b73a18aac15afd5ebd8d3a00dd6e513daf17"></a>CLK_PRSC_1024&#160;</td><td class="fielddoc"><p>CPU_CLK / 1024 </p> +</td></tr> +<tr><td class="fieldname"><a id="a10022df4c223533b04d5aebe222e8b73aa138f0cad547028d5124f89d6dcc8c79" name="a10022df4c223533b04d5aebe222e8b73aa138f0cad547028d5124f89d6dcc8c79"></a>CLK_PRSC_2048&#160;</td><td class="fielddoc"><p>CPU_CLK / 2048 </p> +</td></tr> +<tr><td class="fieldname"><a id="a10022df4c223533b04d5aebe222e8b73a0f20c29722bf9afc478b1a286a6b7eee" name="a10022df4c223533b04d5aebe222e8b73a0f20c29722bf9afc478b1a286a6b7eee"></a>CLK_PRSC_4096&#160;</td><td class="fielddoc"><p>CPU_CLK / 4096 </p> +</td></tr> +</table> + +</div> +</div> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/neorv32_8h_source.html b/sw/neorv32_8h_source.html new file mode 100644 index 0000000000..e0623777e0 --- /dev/null +++ b/sw/neorv32_8h_source.html @@ -0,0 +1,348 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/lib/include/neorv32.h Source File</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_7d04193005ada6f9450f847f4adb6b5b.html">lib</a></li><li class="navelem"><a class="el" href="dir_752b1e5d3973bf735fa78bf6b4727df9.html">include</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="headertitle"><div class="title">neorv32.h</div></div> +</div><!--header--> +<div class="contents"> +<a href="neorv32_8h.html">Go to the documentation of this file.</a><div class="fragment"><div class="line"><a id="l00001" name="l00001"></a><span class="lineno"> 1</span><span class="comment">// ================================================================================ //</span></div> +<div class="line"><a id="l00002" name="l00002"></a><span class="lineno"> 2</span><span class="comment">// The NEORV32 RISC-V Processor - https://github.com/stnolting/neorv32 //</span></div> +<div class="line"><a id="l00003" name="l00003"></a><span class="lineno"> 3</span><span class="comment">// Copyright (c) NEORV32 contributors. //</span></div> +<div class="line"><a id="l00004" name="l00004"></a><span class="lineno"> 4</span><span class="comment">// Copyright (c) 2020 - 2024 Stephan Nolting. All rights reserved. //</span></div> +<div class="line"><a id="l00005" name="l00005"></a><span class="lineno"> 5</span><span class="comment">// Licensed under the BSD-3-Clause license, see LICENSE for details. //</span></div> +<div class="line"><a id="l00006" name="l00006"></a><span class="lineno"> 6</span><span class="comment">// SPDX-License-Identifier: BSD-3-Clause //</span></div> +<div class="line"><a id="l00007" name="l00007"></a><span class="lineno"> 7</span><span class="comment">// ================================================================================ //</span></div> +<div class="line"><a id="l00008" name="l00008"></a><span class="lineno"> 8</span> </div> +<div class="line"><a id="l00016" name="l00016"></a><span class="lineno"> 16</span><span class="preprocessor">#ifndef neorv32_h</span></div> +<div class="line"><a id="l00017" name="l00017"></a><span class="lineno"> 17</span><span class="preprocessor">#define neorv32_h</span></div> +<div class="line"><a id="l00018" name="l00018"></a><span class="lineno"> 18</span> </div> +<div class="line"><a id="l00019" name="l00019"></a><span class="lineno"> 19</span><span class="preprocessor">#ifdef __cplusplus</span></div> +<div class="line"><a id="l00020" name="l00020"></a><span class="lineno"> 20</span><span class="keyword">extern</span> <span class="stringliteral">&quot;C&quot;</span> {</div> +<div class="line"><a id="l00021" name="l00021"></a><span class="lineno"> 21</span><span class="preprocessor">#endif</span></div> +<div class="line"><a id="l00022" name="l00022"></a><span class="lineno"> 22</span> </div> +<div class="line"><a id="l00023" name="l00023"></a><span class="lineno"> 23</span><span class="comment">// Standard libraries</span></div> +<div class="line"><a id="l00024" name="l00024"></a><span class="lineno"> 24</span><span class="preprocessor">#include &lt;stdint.h&gt;</span></div> +<div class="line"><a id="l00025" name="l00025"></a><span class="lineno"> 25</span><span class="preprocessor">#include &lt;inttypes.h&gt;</span></div> +<div class="line"><a id="l00026" name="l00026"></a><span class="lineno"> 26</span><span class="preprocessor">#include &lt;unistd.h&gt;</span></div> +<div class="line"><a id="l00027" name="l00027"></a><span class="lineno"> 27</span><span class="preprocessor">#include &lt;stdlib.h&gt;</span></div> +<div class="line"><a id="l00028" name="l00028"></a><span class="lineno"> 28</span> </div> +<div class="line"><a id="l00029" name="l00029"></a><span class="lineno"> 29</span> </div> +<div class="line"><a id="l00030" name="l00030"></a><span class="lineno"> 30</span><span class="comment">/**********************************************************************/</span></div> +<div class="line"><a id="l00035" name="l00035"></a><span class="lineno"><a class="line" href="neorv32_8h.html#aa01bea676e878a9e87ca10ce2d91e51f"> 35</a></span><span class="preprocessor">#define XIP_MEM_BASE_ADDRESS (0xE0000000U)</span></div> +<div class="line"><a id="l00037" name="l00037"></a><span class="lineno"><a class="line" href="neorv32_8h.html#abd8c9b7d79f49de1722611b2835cde58"> 37</a></span><span class="preprocessor">#define BOOTLOADER_BASE_ADDRESS (0xFFFFC000U)</span></div> +<div class="line"><a id="l00039" name="l00039"></a><span class="lineno"><a class="line" href="neorv32_8h.html#a1eb0cb7fed7e154e15cb4009880a879c"> 39</a></span><span class="preprocessor">#define IO_BASE_ADDRESS (0xFFFFE000U)</span></div> +<div class="line"><a id="l00043" name="l00043"></a><span class="lineno"> 43</span><span class="comment">/**********************************************************************/</span></div> +<div class="line"><a id="l00047" name="l00047"></a><span class="lineno"> 47</span><span class="comment">//#define NEORV32_???_BASE (0xFFFFE000U) /**&lt; reserved */</span></div> +<div class="line"><a id="l00048" name="l00048"></a><span class="lineno"> 48</span><span class="comment">//#define NEORV32_???_BASE (0xFFFFE100U) /**&lt; reserved */</span></div> +<div class="line"><a id="l00049" name="l00049"></a><span class="lineno"> 49</span><span class="comment">//#define NEORV32_???_BASE (0xFFFFE200U) /**&lt; reserved */</span></div> +<div class="line"><a id="l00050" name="l00050"></a><span class="lineno"> 50</span><span class="comment">//#define NEORV32_???_BASE (0xFFFFE300U) /**&lt; reserved */</span></div> +<div class="line"><a id="l00051" name="l00051"></a><span class="lineno"> 51</span><span class="comment">//#define NEORV32_???_BASE (0xFFFFE400U) /**&lt; reserved */</span></div> +<div class="line"><a id="l00052" name="l00052"></a><span class="lineno"> 52</span><span class="comment">//#define NEORV32_???_BASE (0xFFFFE500U) /**&lt; reserved */</span></div> +<div class="line"><a id="l00053" name="l00053"></a><span class="lineno"> 53</span><span class="comment">//#define NEORV32_???_BASE (0xFFFFE600U) /**&lt; reserved */</span></div> +<div class="line"><a id="l00054" name="l00054"></a><span class="lineno"> 54</span><span class="comment">//#define NEORV32_???_BASE (0xFFFFE700U) /**&lt; reserved */</span></div> +<div class="line"><a id="l00055" name="l00055"></a><span class="lineno"> 55</span><span class="comment">//#define NEORV32_???_BASE (0xFFFFE800U) /**&lt; reserved */</span></div> +<div class="line"><a id="l00056" name="l00056"></a><span class="lineno"> 56</span><span class="comment">//#define NEORV32_???_BASE (0xFFFFE900U) /**&lt; reserved */</span></div> +<div class="line"><a id="l00057" name="l00057"></a><span class="lineno"> 57</span><span class="comment">//#define NEORV32_???_BASE (0xFFFFEA00U) /**&lt; reserved */</span></div> +<div class="line"><a id="l00058" name="l00058"></a><span class="lineno"><a class="line" href="neorv32_8h.html#a41d6f97daef61641da96b9f72f6b272f"> 58</a></span><span class="preprocessor">#define NEORV32_CFS_BASE (0xFFFFEB00U) </span></div> +<div class="line"><a id="l00059" name="l00059"></a><span class="lineno"><a class="line" href="neorv32_8h.html#ab5e6dc57886cd5ed98b86f22fc37d7cc"> 59</a></span><span class="preprocessor">#define NEORV32_SLINK_BASE (0xFFFFEC00U) </span></div> +<div class="line"><a id="l00060" name="l00060"></a><span class="lineno"><a class="line" href="neorv32_8h.html#aa8d3a83ffad1e71f0832a5da78d62008"> 60</a></span><span class="preprocessor">#define NEORV32_DMA_BASE (0xFFFFED00U) </span></div> +<div class="line"><a id="l00061" name="l00061"></a><span class="lineno"><a class="line" href="neorv32_8h.html#a0e2377055bdc0f416b5ae4385610600d"> 61</a></span><span class="preprocessor">#define NEORV32_CRC_BASE (0xFFFFEE00U) </span></div> +<div class="line"><a id="l00062" name="l00062"></a><span class="lineno"><a class="line" href="neorv32_8h.html#ae0978315beac8399f96f520bda81c7fe"> 62</a></span><span class="preprocessor">#define NEORV32_XIP_BASE (0xFFFFEF00U) </span></div> +<div class="line"><a id="l00063" name="l00063"></a><span class="lineno"><a class="line" href="neorv32_8h.html#afef7a6b121a788560b29e2ee2a58c725"> 63</a></span><span class="preprocessor">#define NEORV32_PWM_BASE (0xFFFFF000U) </span></div> +<div class="line"><a id="l00064" name="l00064"></a><span class="lineno"><a class="line" href="neorv32_8h.html#a0991b1a5ba1e8c3550eb9770d43589d0"> 64</a></span><span class="preprocessor">#define NEORV32_GPTMR_BASE (0xFFFFF100U) </span></div> +<div class="line"><a id="l00065" name="l00065"></a><span class="lineno"><a class="line" href="neorv32_8h.html#a8d0b612e52b77395a05d4f18af6fcf00"> 65</a></span><span class="preprocessor">#define NEORV32_ONEWIRE_BASE (0xFFFFF200U) </span></div> +<div class="line"><a id="l00066" name="l00066"></a><span class="lineno"><a class="line" href="neorv32_8h.html#a942a897be2d4ae6820bee0f7bb3a0ff1"> 66</a></span><span class="preprocessor">#define NEORV32_XIRQ_BASE (0xFFFFF300U) </span></div> +<div class="line"><a id="l00067" name="l00067"></a><span class="lineno"><a class="line" href="neorv32_8h.html#ab98f762df259a2bbc28d19d2acfe9e23"> 67</a></span><span class="preprocessor">#define NEORV32_MTIME_BASE (0xFFFFF400U) </span></div> +<div class="line"><a id="l00068" name="l00068"></a><span class="lineno"><a class="line" href="neorv32_8h.html#a000b37f710043fe21e49b2fdbc039d94"> 68</a></span><span class="preprocessor">#define NEORV32_UART0_BASE (0xFFFFF500U) </span></div> +<div class="line"><a id="l00069" name="l00069"></a><span class="lineno"><a class="line" href="neorv32_8h.html#a26a1defe18ce222b8b4ed1c760344700"> 69</a></span><span class="preprocessor">#define NEORV32_UART1_BASE (0xFFFFF600U) </span></div> +<div class="line"><a id="l00070" name="l00070"></a><span class="lineno"><a class="line" href="neorv32_8h.html#a9b316ec038bd94ada42c9dab57a0a3cb"> 70</a></span><span class="preprocessor">#define NEORV32_SDI_BASE (0xFFFFF700U) </span></div> +<div class="line"><a id="l00071" name="l00071"></a><span class="lineno"><a class="line" href="neorv32_8h.html#aa466dc5eace7351bd438606f0f7475a7"> 71</a></span><span class="preprocessor">#define NEORV32_SPI_BASE (0xFFFFF800U) </span></div> +<div class="line"><a id="l00072" name="l00072"></a><span class="lineno"><a class="line" href="neorv32_8h.html#a4a741408a4bb0938e03b99555306db9c"> 72</a></span><span class="preprocessor">#define NEORV32_TWI_BASE (0xFFFFF900U) </span></div> +<div class="line"><a id="l00073" name="l00073"></a><span class="lineno"><a class="line" href="neorv32_8h.html#ab4846cd153e8a23deec45d81cc8372a2"> 73</a></span><span class="preprocessor">#define NEORV32_TRNG_BASE (0xFFFFFA00U) </span></div> +<div class="line"><a id="l00074" name="l00074"></a><span class="lineno"><a class="line" href="neorv32_8h.html#a3012986cdd5748ee96bcc74cd7108dea"> 74</a></span><span class="preprocessor">#define NEORV32_WDT_BASE (0xFFFFFB00U) </span></div> +<div class="line"><a id="l00075" name="l00075"></a><span class="lineno"><a class="line" href="neorv32_8h.html#a7fd1e24d4de2eed7bf9cd5391562c7f4"> 75</a></span><span class="preprocessor">#define NEORV32_GPIO_BASE (0xFFFFFC00U) </span></div> +<div class="line"><a id="l00076" name="l00076"></a><span class="lineno"><a class="line" href="neorv32_8h.html#a559fdce92e8af5efc426c8fc48d14f99"> 76</a></span><span class="preprocessor">#define NEORV32_NEOLED_BASE (0xFFFFFD00U) </span></div> +<div class="line"><a id="l00077" name="l00077"></a><span class="lineno"><a class="line" href="neorv32_8h.html#a5aa936f38782232c7ed3eab1283ee536"> 77</a></span><span class="preprocessor">#define NEORV32_SYSINFO_BASE (0xFFFFFE00U) </span></div> +<div class="line"><a id="l00078" name="l00078"></a><span class="lineno"><a class="line" href="neorv32_8h.html#a9bf0149681677f7d87abf8f62e2d9a3d"> 78</a></span><span class="preprocessor">#define NEORV32_DM_BASE (0xFFFFFF00U) </span></div> +<div class="line"><a id="l00082" name="l00082"></a><span class="lineno"> 82</span><span class="comment">/**********************************************************************/</span></div> +<div class="line"><a id="l00088" name="l00088"></a><span class="lineno"><a class="line" href="neorv32_8h.html#a2896d832852c016eb85210b523642f11"> 88</a></span><span class="preprocessor">#define TRNG_FIRQ_ENABLE CSR_MIE_FIRQ0E </span></div> +<div class="line"><a id="l00089" name="l00089"></a><span class="lineno"><a class="line" href="neorv32_8h.html#a9c387ca4e2736a27056c11819947c84a"> 89</a></span><span class="preprocessor">#define TRNG_FIRQ_PENDING CSR_MIP_FIRQ0P </span></div> +<div class="line"><a id="l00090" name="l00090"></a><span class="lineno"><a class="line" href="neorv32_8h.html#afaa705a674acf3fd6c8cb294eaf11c5e"> 90</a></span><span class="preprocessor">#define TRNG_RTE_ID RTE_TRAP_FIRQ_0 </span></div> +<div class="line"><a id="l00091" name="l00091"></a><span class="lineno"><a class="line" href="neorv32_8h.html#a11e34802c61a01fd6cba46e3f92d5ac1"> 91</a></span><span class="preprocessor">#define TRNG_TRAP_CODE TRAP_CODE_FIRQ_0 </span></div> +<div class="line"><a id="l00095" name="l00095"></a><span class="lineno"><a class="line" href="neorv32_8h.html#ace79ee46daf3a1b689d9fe79dfcd6627"> 95</a></span><span class="preprocessor">#define CFS_FIRQ_ENABLE CSR_MIE_FIRQ1E </span></div> +<div class="line"><a id="l00096" name="l00096"></a><span class="lineno"><a class="line" href="neorv32_8h.html#aae182648a2c23d070b9db0295388e001"> 96</a></span><span class="preprocessor">#define CFS_FIRQ_PENDING CSR_MIP_FIRQ1P </span></div> +<div class="line"><a id="l00097" name="l00097"></a><span class="lineno"><a class="line" href="neorv32_8h.html#a095f41fbefaa7acc1bfdd65cd3ce06ea"> 97</a></span><span class="preprocessor">#define CFS_RTE_ID RTE_TRAP_FIRQ_1 </span></div> +<div class="line"><a id="l00098" name="l00098"></a><span class="lineno"><a class="line" href="neorv32_8h.html#aae6b2ae3fba20ff80bfb59735f179c26"> 98</a></span><span class="preprocessor">#define CFS_TRAP_CODE TRAP_CODE_FIRQ_1 </span></div> +<div class="line"><a id="l00102" name="l00102"></a><span class="lineno"><a class="line" href="neorv32_8h.html#a6b55ce6abe6b141000a6bb00949169e9"> 102</a></span><span class="preprocessor">#define UART0_RX_FIRQ_ENABLE CSR_MIE_FIRQ2E </span></div> +<div class="line"><a id="l00103" name="l00103"></a><span class="lineno"><a class="line" href="neorv32_8h.html#a0b738b26abb2b951f1f5c5d9525d7701"> 103</a></span><span class="preprocessor">#define UART0_RX_FIRQ_PENDING CSR_MIP_FIRQ2P </span></div> +<div class="line"><a id="l00104" name="l00104"></a><span class="lineno"><a class="line" href="neorv32_8h.html#ae8588cca20d5e36f74c5207c376389a1"> 104</a></span><span class="preprocessor">#define UART0_RX_RTE_ID RTE_TRAP_FIRQ_2 </span></div> +<div class="line"><a id="l00105" name="l00105"></a><span class="lineno"><a class="line" href="neorv32_8h.html#a7a849638eff31f2e1955bdc53d4fc84d"> 105</a></span><span class="preprocessor">#define UART0_RX_TRAP_CODE TRAP_CODE_FIRQ_2 </span></div> +<div class="line"><a id="l00106" name="l00106"></a><span class="lineno"><a class="line" href="neorv32_8h.html#aff756a395771f22c5f412f23f177ea7d"> 106</a></span><span class="preprocessor">#define UART0_TX_FIRQ_ENABLE CSR_MIE_FIRQ3E </span></div> +<div class="line"><a id="l00107" name="l00107"></a><span class="lineno"><a class="line" href="neorv32_8h.html#addbe29166bb77bc045ad0e3db68e57e9"> 107</a></span><span class="preprocessor">#define UART0_TX_FIRQ_PENDING CSR_MIP_FIRQ3P </span></div> +<div class="line"><a id="l00108" name="l00108"></a><span class="lineno"><a class="line" href="neorv32_8h.html#a9dc37695ca169bc0eb93898e7aeeee58"> 108</a></span><span class="preprocessor">#define UART0_TX_RTE_ID RTE_TRAP_FIRQ_3 </span></div> +<div class="line"><a id="l00109" name="l00109"></a><span class="lineno"><a class="line" href="neorv32_8h.html#ab50df423fdba86bb83bc5d90a4c3bb20"> 109</a></span><span class="preprocessor">#define UART0_TX_TRAP_CODE TRAP_CODE_FIRQ_3 </span></div> +<div class="line"><a id="l00113" name="l00113"></a><span class="lineno"><a class="line" href="neorv32_8h.html#a6c118c1784d8446360b00cde97437ca7"> 113</a></span><span class="preprocessor">#define UART1_RX_FIRQ_ENABLE CSR_MIE_FIRQ4E </span></div> +<div class="line"><a id="l00114" name="l00114"></a><span class="lineno"><a class="line" href="neorv32_8h.html#a2e70d3a4e2973d224643813fcf315a20"> 114</a></span><span class="preprocessor">#define UART1_RX_FIRQ_PENDING CSR_MIP_FIRQ4P </span></div> +<div class="line"><a id="l00115" name="l00115"></a><span class="lineno"><a class="line" href="neorv32_8h.html#ab1c351f5ea19ac9ea864155be9cc0b4b"> 115</a></span><span class="preprocessor">#define UART1_RX_RTE_ID RTE_TRAP_FIRQ_4 </span></div> +<div class="line"><a id="l00116" name="l00116"></a><span class="lineno"><a class="line" href="neorv32_8h.html#ad0b9eb2ee1f411d7fccdf4fe263214e1"> 116</a></span><span class="preprocessor">#define UART1_RX_TRAP_CODE TRAP_CODE_FIRQ_4 </span></div> +<div class="line"><a id="l00117" name="l00117"></a><span class="lineno"><a class="line" href="neorv32_8h.html#a0039bae3454a22e71d64e70d674f5d6a"> 117</a></span><span class="preprocessor">#define UART1_TX_FIRQ_ENABLE CSR_MIE_FIRQ5E </span></div> +<div class="line"><a id="l00118" name="l00118"></a><span class="lineno"><a class="line" href="neorv32_8h.html#ac4060532b7aa390623f54720460a2680"> 118</a></span><span class="preprocessor">#define UART1_TX_FIRQ_PENDING CSR_MIP_FIRQ5P </span></div> +<div class="line"><a id="l00119" name="l00119"></a><span class="lineno"><a class="line" href="neorv32_8h.html#a6af270d7ae8b1cde30e44eb9142491d3"> 119</a></span><span class="preprocessor">#define UART1_TX_RTE_ID RTE_TRAP_FIRQ_5 </span></div> +<div class="line"><a id="l00120" name="l00120"></a><span class="lineno"><a class="line" href="neorv32_8h.html#a4cc50287c7a53982761a8116396ff7dd"> 120</a></span><span class="preprocessor">#define UART1_TX_TRAP_CODE TRAP_CODE_FIRQ_5 </span></div> +<div class="line"><a id="l00124" name="l00124"></a><span class="lineno"><a class="line" href="neorv32_8h.html#ab8fcd3f80c373eb0f9d0fc6bf64ca626"> 124</a></span><span class="preprocessor">#define SPI_FIRQ_ENABLE CSR_MIE_FIRQ6E </span></div> +<div class="line"><a id="l00125" name="l00125"></a><span class="lineno"><a class="line" href="neorv32_8h.html#ab2f58f746febb29a9828447c733f8043"> 125</a></span><span class="preprocessor">#define SPI_FIRQ_PENDING CSR_MIP_FIRQ6P </span></div> +<div class="line"><a id="l00126" name="l00126"></a><span class="lineno"><a class="line" href="neorv32_8h.html#a4c1cd9ec9f80da2080e5d0d35cc524dd"> 126</a></span><span class="preprocessor">#define SPI_RTE_ID RTE_TRAP_FIRQ_6 </span></div> +<div class="line"><a id="l00127" name="l00127"></a><span class="lineno"><a class="line" href="neorv32_8h.html#a83c212f1f5d8ee2a5921b3b2b19e9cc4"> 127</a></span><span class="preprocessor">#define SPI_TRAP_CODE TRAP_CODE_FIRQ_6 </span></div> +<div class="line"><a id="l00131" name="l00131"></a><span class="lineno"><a class="line" href="neorv32_8h.html#a0913144fce247e24ccd0f178b9ac32b7"> 131</a></span><span class="preprocessor">#define TWI_FIRQ_ENABLE CSR_MIE_FIRQ7E </span></div> +<div class="line"><a id="l00132" name="l00132"></a><span class="lineno"><a class="line" href="neorv32_8h.html#a48b80113ca718fbdc50d75e1ec96a1ff"> 132</a></span><span class="preprocessor">#define TWI_FIRQ_PENDING CSR_MIP_FIRQ7P </span></div> +<div class="line"><a id="l00133" name="l00133"></a><span class="lineno"><a class="line" href="neorv32_8h.html#a1ac29f2f7bace5ba92b2b68a4541a60c"> 133</a></span><span class="preprocessor">#define TWI_RTE_ID RTE_TRAP_FIRQ_7 </span></div> +<div class="line"><a id="l00134" name="l00134"></a><span class="lineno"><a class="line" href="neorv32_8h.html#a0afc1a759116d4d73a199ef769bced47"> 134</a></span><span class="preprocessor">#define TWI_TRAP_CODE TRAP_CODE_FIRQ_7 </span></div> +<div class="line"><a id="l00138" name="l00138"></a><span class="lineno"><a class="line" href="neorv32_8h.html#afe0cb262d517c7da73d6b5dc78886334"> 138</a></span><span class="preprocessor">#define XIRQ_FIRQ_ENABLE CSR_MIE_FIRQ8E </span></div> +<div class="line"><a id="l00139" name="l00139"></a><span class="lineno"><a class="line" href="neorv32_8h.html#a866768963f8648363dce40de9f34d61b"> 139</a></span><span class="preprocessor">#define XIRQ_FIRQ_PENDING CSR_MIP_FIRQ8P </span></div> +<div class="line"><a id="l00140" name="l00140"></a><span class="lineno"><a class="line" href="neorv32_8h.html#a95387d3482ec8e5c1d734805fdf64fa5"> 140</a></span><span class="preprocessor">#define XIRQ_RTE_ID RTE_TRAP_FIRQ_8 </span></div> +<div class="line"><a id="l00141" name="l00141"></a><span class="lineno"><a class="line" href="neorv32_8h.html#a16b9a7444833b5581df073661deb8f3a"> 141</a></span><span class="preprocessor">#define XIRQ_TRAP_CODE TRAP_CODE_FIRQ_8 </span></div> +<div class="line"><a id="l00145" name="l00145"></a><span class="lineno"><a class="line" href="neorv32_8h.html#a8d0409818600c0b2acfe8253e8f027b8"> 145</a></span><span class="preprocessor">#define NEOLED_FIRQ_ENABLE CSR_MIE_FIRQ9E </span></div> +<div class="line"><a id="l00146" name="l00146"></a><span class="lineno"><a class="line" href="neorv32_8h.html#aded7d7f5f4ba3a6d90f9a29e62a8cfab"> 146</a></span><span class="preprocessor">#define NEOLED_FIRQ_PENDING CSR_MIP_FIRQ9P </span></div> +<div class="line"><a id="l00147" name="l00147"></a><span class="lineno"><a class="line" href="neorv32_8h.html#aca6cfc3f580c4dfe1e213009ee450c58"> 147</a></span><span class="preprocessor">#define NEOLED_RTE_ID RTE_TRAP_FIRQ_9 </span></div> +<div class="line"><a id="l00148" name="l00148"></a><span class="lineno"><a class="line" href="neorv32_8h.html#ab4a2ac455d7426992de6877ea7325f21"> 148</a></span><span class="preprocessor">#define NEOLED_TRAP_CODE TRAP_CODE_FIRQ_9 </span></div> +<div class="line"><a id="l00152" name="l00152"></a><span class="lineno"><a class="line" href="neorv32_8h.html#ace46f95dec73b33bf2535eb653bf8f65"> 152</a></span><span class="preprocessor">#define DMA_FIRQ_ENABLE CSR_MIE_FIRQ10E </span></div> +<div class="line"><a id="l00153" name="l00153"></a><span class="lineno"><a class="line" href="neorv32_8h.html#a1fa2b25383e6d05cf26f3517091ddbbf"> 153</a></span><span class="preprocessor">#define DMA_FIRQ_PENDING CSR_MIP_FIRQ10P </span></div> +<div class="line"><a id="l00154" name="l00154"></a><span class="lineno"><a class="line" href="neorv32_8h.html#a568b54ba7dfdae736d8d685dc4d32113"> 154</a></span><span class="preprocessor">#define DMA_RTE_ID RTE_TRAP_FIRQ_10 </span></div> +<div class="line"><a id="l00155" name="l00155"></a><span class="lineno"><a class="line" href="neorv32_8h.html#ad2e81443af8a4ce2db3a4e3c1a8fb784"> 155</a></span><span class="preprocessor">#define DMA_TRAP_CODE TRAP_CODE_FIRQ_10 </span></div> +<div class="line"><a id="l00159" name="l00159"></a><span class="lineno"><a class="line" href="neorv32_8h.html#a30cf20b6d704c50cc5c46238bb43646f"> 159</a></span><span class="preprocessor">#define SDI_FIRQ_ENABLE CSR_MIE_FIRQ11E </span></div> +<div class="line"><a id="l00160" name="l00160"></a><span class="lineno"><a class="line" href="neorv32_8h.html#a68611c0dfbe331739eff10230ac3fede"> 160</a></span><span class="preprocessor">#define SDI_FIRQ_PENDING CSR_MIP_FIRQ11P </span></div> +<div class="line"><a id="l00161" name="l00161"></a><span class="lineno"><a class="line" href="neorv32_8h.html#aa0ff72ea560d7e1462787dc31bd467cf"> 161</a></span><span class="preprocessor">#define SDI_RTE_ID RTE_TRAP_FIRQ_11 </span></div> +<div class="line"><a id="l00162" name="l00162"></a><span class="lineno"><a class="line" href="neorv32_8h.html#a68925ca3f482f148caedd36118fd8d79"> 162</a></span><span class="preprocessor">#define SDI_TRAP_CODE TRAP_CODE_FIRQ_11 </span></div> +<div class="line"><a id="l00166" name="l00166"></a><span class="lineno"><a class="line" href="neorv32_8h.html#a0a59186908b498cb92273b7767966e26"> 166</a></span><span class="preprocessor">#define GPTMR_FIRQ_ENABLE CSR_MIE_FIRQ12E </span></div> +<div class="line"><a id="l00167" name="l00167"></a><span class="lineno"><a class="line" href="neorv32_8h.html#a4a3164d123ddddd07750f868e67d82d8"> 167</a></span><span class="preprocessor">#define GPTMR_FIRQ_PENDING CSR_MIP_FIRQ12P </span></div> +<div class="line"><a id="l00168" name="l00168"></a><span class="lineno"><a class="line" href="neorv32_8h.html#aac38deeef36de0a474ab238a3054f860"> 168</a></span><span class="preprocessor">#define GPTMR_RTE_ID RTE_TRAP_FIRQ_12 </span></div> +<div class="line"><a id="l00169" name="l00169"></a><span class="lineno"><a class="line" href="neorv32_8h.html#a445543c36d1f78477aa8ea4841c720a1"> 169</a></span><span class="preprocessor">#define GPTMR_TRAP_CODE TRAP_CODE_FIRQ_12 </span></div> +<div class="line"><a id="l00173" name="l00173"></a><span class="lineno"><a class="line" href="neorv32_8h.html#a8bb1918679e32e898af2d485cfa44afb"> 173</a></span><span class="preprocessor">#define ONEWIRE_FIRQ_ENABLE CSR_MIE_FIRQ13E </span></div> +<div class="line"><a id="l00174" name="l00174"></a><span class="lineno"><a class="line" href="neorv32_8h.html#a3853ef999f99ca062e6025038811d0f0"> 174</a></span><span class="preprocessor">#define ONEWIRE_FIRQ_PENDING CSR_MIP_FIRQ13P </span></div> +<div class="line"><a id="l00175" name="l00175"></a><span class="lineno"><a class="line" href="neorv32_8h.html#a142f4a1c754edfab292706618d427b94"> 175</a></span><span class="preprocessor">#define ONEWIRE_RTE_ID RTE_TRAP_FIRQ_13 </span></div> +<div class="line"><a id="l00176" name="l00176"></a><span class="lineno"><a class="line" href="neorv32_8h.html#a3e7aaa405a7d1fcd71a36c4b6b5a4081"> 176</a></span><span class="preprocessor">#define ONEWIRE_TRAP_CODE TRAP_CODE_FIRQ_13 </span></div> +<div class="line"><a id="l00180" name="l00180"></a><span class="lineno"><a class="line" href="neorv32_8h.html#a8680ab1f14e512f21913572b35cbbf77"> 180</a></span><span class="preprocessor">#define SLINK_RX_FIRQ_ENABLE CSR_MIE_FIRQ14E </span></div> +<div class="line"><a id="l00181" name="l00181"></a><span class="lineno"><a class="line" href="neorv32_8h.html#a5c48d5c4effb47cdb019aa2da7c84526"> 181</a></span><span class="preprocessor">#define SLINK_RX_FIRQ_PENDING CSR_MIP_FIRQ14P </span></div> +<div class="line"><a id="l00182" name="l00182"></a><span class="lineno"><a class="line" href="neorv32_8h.html#a4fff18e72d10377cdcb8d2ac0a617a5d"> 182</a></span><span class="preprocessor">#define SLINK_RX_RTE_ID RTE_TRAP_FIRQ_14 </span></div> +<div class="line"><a id="l00183" name="l00183"></a><span class="lineno"><a class="line" href="neorv32_8h.html#ab1fdaedb2c4c8753ef3be87c82568dda"> 183</a></span><span class="preprocessor">#define SLINK_RX_TRAP_CODE TRAP_CODE_FIRQ_14 </span></div> +<div class="line"><a id="l00184" name="l00184"></a><span class="lineno"><a class="line" href="neorv32_8h.html#a232fe0eb5665373b6e2b464bdc228df2"> 184</a></span><span class="preprocessor">#define SLINK_TX_FIRQ_ENABLE CSR_MIE_FIRQ15E </span></div> +<div class="line"><a id="l00185" name="l00185"></a><span class="lineno"><a class="line" href="neorv32_8h.html#ac8e98b2af75c8e31f9815dee3dcbaf8e"> 185</a></span><span class="preprocessor">#define SLINK_TX_FIRQ_PENDING CSR_MIP_FIRQ15P </span></div> +<div class="line"><a id="l00186" name="l00186"></a><span class="lineno"><a class="line" href="neorv32_8h.html#a4e039d13b8d3f20453e1bb6b40512e43"> 186</a></span><span class="preprocessor">#define SLINK_TX_RTE_ID RTE_TRAP_FIRQ_15 </span></div> +<div class="line"><a id="l00187" name="l00187"></a><span class="lineno"><a class="line" href="neorv32_8h.html#a7fbe28901775e284d5700086f0b0bfcd"> 187</a></span><span class="preprocessor">#define SLINK_TX_TRAP_CODE TRAP_CODE_FIRQ_15 </span></div> +<div class="line"><a id="l00192" name="l00192"></a><span class="lineno"> 192</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen00196" data-start="{" data-end="};"> +<div class="line"><a id="l00196" name="l00196"></a><span class="lineno"><a class="line" href="neorv32_8h.html#a10022df4c223533b04d5aebe222e8b73"> 196</a></span><span class="keyword">enum</span> <a class="code hl_enumeration" href="neorv32_8h.html#a10022df4c223533b04d5aebe222e8b73">NEORV32_CLOCK_PRSC_enum</a> {</div> +<div class="line"><a id="l00197" name="l00197"></a><span class="lineno"><a class="line" href="neorv32_8h.html#a10022df4c223533b04d5aebe222e8b73ad63d40139c50d76618cf1258cbdc0d05"> 197</a></span> <a class="code hl_enumvalue" href="neorv32_8h.html#a10022df4c223533b04d5aebe222e8b73ad63d40139c50d76618cf1258cbdc0d05">CLK_PRSC_2</a> = 0, </div> +<div class="line"><a id="l00198" name="l00198"></a><span class="lineno"><a class="line" href="neorv32_8h.html#a10022df4c223533b04d5aebe222e8b73a648249b3ab8c2500880c1e68b98f81d1"> 198</a></span> <a class="code hl_enumvalue" href="neorv32_8h.html#a10022df4c223533b04d5aebe222e8b73a648249b3ab8c2500880c1e68b98f81d1">CLK_PRSC_4</a> = 1, </div> +<div class="line"><a id="l00199" name="l00199"></a><span class="lineno"><a class="line" href="neorv32_8h.html#a10022df4c223533b04d5aebe222e8b73aa4e3a6a5b3cd895f63b4544f63ce22c9"> 199</a></span> <a class="code hl_enumvalue" href="neorv32_8h.html#a10022df4c223533b04d5aebe222e8b73aa4e3a6a5b3cd895f63b4544f63ce22c9">CLK_PRSC_8</a> = 2, </div> +<div class="line"><a id="l00200" name="l00200"></a><span class="lineno"><a class="line" href="neorv32_8h.html#a10022df4c223533b04d5aebe222e8b73a5990532893f2d9606e3c02aff60ca5da"> 200</a></span> <a class="code hl_enumvalue" href="neorv32_8h.html#a10022df4c223533b04d5aebe222e8b73a5990532893f2d9606e3c02aff60ca5da">CLK_PRSC_64</a> = 3, </div> +<div class="line"><a id="l00201" name="l00201"></a><span class="lineno"><a class="line" href="neorv32_8h.html#a10022df4c223533b04d5aebe222e8b73a933045a5405de55781d687315f42054e"> 201</a></span> <a class="code hl_enumvalue" href="neorv32_8h.html#a10022df4c223533b04d5aebe222e8b73a933045a5405de55781d687315f42054e">CLK_PRSC_128</a> = 4, </div> +<div class="line"><a id="l00202" name="l00202"></a><span class="lineno"><a class="line" href="neorv32_8h.html#a10022df4c223533b04d5aebe222e8b73a18aac15afd5ebd8d3a00dd6e513daf17"> 202</a></span> <a class="code hl_enumvalue" href="neorv32_8h.html#a10022df4c223533b04d5aebe222e8b73a18aac15afd5ebd8d3a00dd6e513daf17">CLK_PRSC_1024</a> = 5, </div> +<div class="line"><a id="l00203" name="l00203"></a><span class="lineno"><a class="line" href="neorv32_8h.html#a10022df4c223533b04d5aebe222e8b73aa138f0cad547028d5124f89d6dcc8c79"> 203</a></span> <a class="code hl_enumvalue" href="neorv32_8h.html#a10022df4c223533b04d5aebe222e8b73aa138f0cad547028d5124f89d6dcc8c79">CLK_PRSC_2048</a> = 6, </div> +<div class="line"><a id="l00204" name="l00204"></a><span class="lineno"> 204</span> <a class="code hl_enumvalue" href="neorv32_8h.html#a10022df4c223533b04d5aebe222e8b73a0f20c29722bf9afc478b1a286a6b7eee">CLK_PRSC_4096</a> = 7 </div> +<div class="line"><a id="l00205" name="l00205"></a><span class="lineno"><a class="line" href="neorv32_8h.html#a10022df4c223533b04d5aebe222e8b73a0f20c29722bf9afc478b1a286a6b7eee"> 205</a></span>};</div> +</div> +<div class="line"><a id="l00209" name="l00209"></a><span class="lineno"> 209</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen00214" data-start="{" data-end="};"> +<div class="line"><a id="l00214" name="l00214"></a><span class="lineno"><a class="line" href="unionsubwords64__t.html"> 214</a></span><span class="keyword">typedef</span> <span class="keyword">union </span>{</div> +<div class="line"><a id="l00215" name="l00215"></a><span class="lineno"> 215</span> uint64_t uint64;</div> +<div class="line"><a id="l00216" name="l00216"></a><span class="lineno"> 216</span> uint32_t uint32[<span class="keyword">sizeof</span>(uint64_t)/<span class="keyword">sizeof</span>(uint32_t)];</div> +<div class="line"><a id="l00217" name="l00217"></a><span class="lineno"> 217</span> uint16_t uint16[<span class="keyword">sizeof</span>(uint64_t)/<span class="keyword">sizeof</span>(uint16_t)];</div> +<div class="line"><a id="l00218" name="l00218"></a><span class="lineno"> 218</span> uint8_t uint8[ <span class="keyword">sizeof</span>(uint64_t)/<span class="keyword">sizeof</span>(uint8_t)];</div> +<div class="line"><a id="l00219" name="l00219"></a><span class="lineno"> 219</span>} <a class="code hl_union" href="unionsubwords64__t.html">subwords64_t</a>;</div> +</div> +<div class="foldopen" id="foldopen00221" data-start="{" data-end="};"> +<div class="line"><a id="l00221" name="l00221"></a><span class="lineno"><a class="line" href="unionsubwords32__t.html"> 221</a></span><span class="keyword">typedef</span> <span class="keyword">union </span>{</div> +<div class="line"><a id="l00222" name="l00222"></a><span class="lineno"> 222</span> uint32_t uint32[<span class="keyword">sizeof</span>(uint32_t)/<span class="keyword">sizeof</span>(uint32_t)];</div> +<div class="line"><a id="l00223" name="l00223"></a><span class="lineno"> 223</span> uint16_t uint16[<span class="keyword">sizeof</span>(uint32_t)/<span class="keyword">sizeof</span>(uint16_t)];</div> +<div class="line"><a id="l00224" name="l00224"></a><span class="lineno"> 224</span> uint8_t uint8[ <span class="keyword">sizeof</span>(uint32_t)/<span class="keyword">sizeof</span>(uint8_t)];</div> +<div class="line"><a id="l00225" name="l00225"></a><span class="lineno"> 225</span>} <a class="code hl_union" href="unionsubwords32__t.html">subwords32_t</a>;</div> +</div> +<div class="foldopen" id="foldopen00227" data-start="{" data-end="};"> +<div class="line"><a id="l00227" name="l00227"></a><span class="lineno"><a class="line" href="unionsubwords16__t.html"> 227</a></span><span class="keyword">typedef</span> <span class="keyword">union </span>{</div> +<div class="line"><a id="l00228" name="l00228"></a><span class="lineno"> 228</span> uint16_t uint16[<span class="keyword">sizeof</span>(uint16_t)/<span class="keyword">sizeof</span>(uint16_t)];</div> +<div class="line"><a id="l00229" name="l00229"></a><span class="lineno"> 229</span> uint8_t uint8[ <span class="keyword">sizeof</span>(uint16_t)/<span class="keyword">sizeof</span>(uint8_t)];</div> +<div class="line"><a id="l00230" name="l00230"></a><span class="lineno"> 230</span>} <a class="code hl_union" href="unionsubwords16__t.html">subwords16_t</a>;</div> +</div> +<div class="line"><a id="l00234" name="l00234"></a><span class="lineno"> 234</span><span class="comment">// ----------------------------------------------------------------------------</span></div> +<div class="line"><a id="l00235" name="l00235"></a><span class="lineno"> 235</span><span class="comment">// Include all system header files</span></div> +<div class="line"><a id="l00236" name="l00236"></a><span class="lineno"> 236</span><span class="comment">// ----------------------------------------------------------------------------</span></div> +<div class="line"><a id="l00237" name="l00237"></a><span class="lineno"> 237</span><span class="comment">// intrinsics</span></div> +<div class="line"><a id="l00238" name="l00238"></a><span class="lineno"> 238</span><span class="preprocessor">#include &quot;<a class="code" href="neorv32__intrinsics_8h.html">neorv32_intrinsics.h</a>&quot;</span></div> +<div class="line"><a id="l00239" name="l00239"></a><span class="lineno"> 239</span> </div> +<div class="line"><a id="l00240" name="l00240"></a><span class="lineno"> 240</span><span class="comment">// helper functions</span></div> +<div class="line"><a id="l00241" name="l00241"></a><span class="lineno"> 241</span><span class="preprocessor">#include &quot;<a class="code" href="neorv32__aux_8h.html">neorv32_aux.h</a>&quot;</span></div> +<div class="line"><a id="l00242" name="l00242"></a><span class="lineno"> 242</span> </div> +<div class="line"><a id="l00243" name="l00243"></a><span class="lineno"> 243</span><span class="comment">// legacy compatibility layer</span></div> +<div class="line"><a id="l00244" name="l00244"></a><span class="lineno"> 244</span><span class="preprocessor">#include &quot;<a class="code" href="neorv32__legacy_8h.html">neorv32_legacy.h</a>&quot;</span></div> +<div class="line"><a id="l00245" name="l00245"></a><span class="lineno"> 245</span> </div> +<div class="line"><a id="l00246" name="l00246"></a><span class="lineno"> 246</span><span class="comment">// cpu core</span></div> +<div class="line"><a id="l00247" name="l00247"></a><span class="lineno"> 247</span><span class="preprocessor">#include &quot;<a class="code" href="neorv32__cpu_8h.html">neorv32_cpu.h</a>&quot;</span></div> +<div class="line"><a id="l00248" name="l00248"></a><span class="lineno"> 248</span><span class="preprocessor">#include &quot;<a class="code" href="neorv32__cpu__amo_8h.html">neorv32_cpu_amo.h</a>&quot;</span></div> +<div class="line"><a id="l00249" name="l00249"></a><span class="lineno"> 249</span><span class="preprocessor">#include &quot;<a class="code" href="neorv32__cpu__csr_8h.html">neorv32_cpu_csr.h</a>&quot;</span></div> +<div class="line"><a id="l00250" name="l00250"></a><span class="lineno"> 250</span><span class="preprocessor">#include &quot;<a class="code" href="neorv32__cpu__cfu_8h.html">neorv32_cpu_cfu.h</a>&quot;</span></div> +<div class="line"><a id="l00251" name="l00251"></a><span class="lineno"> 251</span> </div> +<div class="line"><a id="l00252" name="l00252"></a><span class="lineno"> 252</span><span class="comment">// NEORV32 runtime environment</span></div> +<div class="line"><a id="l00253" name="l00253"></a><span class="lineno"> 253</span><span class="preprocessor">#include &quot;<a class="code" href="neorv32__rte_8h.html">neorv32_rte.h</a>&quot;</span></div> +<div class="line"><a id="l00254" name="l00254"></a><span class="lineno"> 254</span> </div> +<div class="line"><a id="l00255" name="l00255"></a><span class="lineno"> 255</span><span class="comment">// IO/peripheral devices</span></div> +<div class="line"><a id="l00256" name="l00256"></a><span class="lineno"> 256</span><span class="preprocessor">#include &quot;<a class="code" href="neorv32__cfs_8h.html">neorv32_cfs.h</a>&quot;</span></div> +<div class="line"><a id="l00257" name="l00257"></a><span class="lineno"> 257</span><span class="preprocessor">#include &quot;<a class="code" href="neorv32__crc_8h.html">neorv32_crc.h</a>&quot;</span></div> +<div class="line"><a id="l00258" name="l00258"></a><span class="lineno"> 258</span><span class="preprocessor">#include &quot;<a class="code" href="neorv32__dma_8h.html">neorv32_dma.h</a>&quot;</span></div> +<div class="line"><a id="l00259" name="l00259"></a><span class="lineno"> 259</span><span class="preprocessor">#include &quot;<a class="code" href="neorv32__gpio_8h.html">neorv32_gpio.h</a>&quot;</span></div> +<div class="line"><a id="l00260" name="l00260"></a><span class="lineno"> 260</span><span class="preprocessor">#include &quot;<a class="code" href="neorv32__gptmr_8h.html">neorv32_gptmr.h</a>&quot;</span></div> +<div class="line"><a id="l00261" name="l00261"></a><span class="lineno"> 261</span><span class="preprocessor">#include &quot;<a class="code" href="neorv32__mtime_8h.html">neorv32_mtime.h</a>&quot;</span></div> +<div class="line"><a id="l00262" name="l00262"></a><span class="lineno"> 262</span><span class="preprocessor">#include &quot;<a class="code" href="neorv32__neoled_8h.html">neorv32_neoled.h</a>&quot;</span></div> +<div class="line"><a id="l00263" name="l00263"></a><span class="lineno"> 263</span><span class="preprocessor">#include &quot;<a class="code" href="neorv32__onewire_8h.html">neorv32_onewire.h</a>&quot;</span></div> +<div class="line"><a id="l00264" name="l00264"></a><span class="lineno"> 264</span><span class="preprocessor">#include &quot;<a class="code" href="neorv32__pwm_8h.html">neorv32_pwm.h</a>&quot;</span></div> +<div class="line"><a id="l00265" name="l00265"></a><span class="lineno"> 265</span><span class="preprocessor">#include &quot;<a class="code" href="neorv32__sdi_8h.html">neorv32_sdi.h</a>&quot;</span></div> +<div class="line"><a id="l00266" name="l00266"></a><span class="lineno"> 266</span><span class="preprocessor">#include &quot;<a class="code" href="neorv32__slink_8h.html">neorv32_slink.h</a>&quot;</span></div> +<div class="line"><a id="l00267" name="l00267"></a><span class="lineno"> 267</span><span class="preprocessor">#include &quot;<a class="code" href="neorv32__spi_8h.html">neorv32_spi.h</a>&quot;</span></div> +<div class="line"><a id="l00268" name="l00268"></a><span class="lineno"> 268</span><span class="preprocessor">#include &quot;neorv32_sysinfo.h&quot;</span></div> +<div class="line"><a id="l00269" name="l00269"></a><span class="lineno"> 269</span><span class="preprocessor">#include &quot;<a class="code" href="neorv32__trng_8h.html">neorv32_trng.h</a>&quot;</span></div> +<div class="line"><a id="l00270" name="l00270"></a><span class="lineno"> 270</span><span class="preprocessor">#include &quot;<a class="code" href="neorv32__twi_8h.html">neorv32_twi.h</a>&quot;</span></div> +<div class="line"><a id="l00271" name="l00271"></a><span class="lineno"> 271</span><span class="preprocessor">#include &quot;<a class="code" href="neorv32__uart_8h.html">neorv32_uart.h</a>&quot;</span></div> +<div class="line"><a id="l00272" name="l00272"></a><span class="lineno"> 272</span><span class="preprocessor">#include &quot;<a class="code" href="neorv32__wdt_8h.html">neorv32_wdt.h</a>&quot;</span></div> +<div class="line"><a id="l00273" name="l00273"></a><span class="lineno"> 273</span><span class="preprocessor">#include &quot;<a class="code" href="neorv32__xip_8h.html">neorv32_xip.h</a>&quot;</span></div> +<div class="line"><a id="l00274" name="l00274"></a><span class="lineno"> 274</span><span class="preprocessor">#include &quot;<a class="code" href="neorv32__xirq_8h.html">neorv32_xirq.h</a>&quot;</span></div> +<div class="line"><a id="l00275" name="l00275"></a><span class="lineno"> 275</span> </div> +<div class="line"><a id="l00276" name="l00276"></a><span class="lineno"> 276</span> </div> +<div class="line"><a id="l00277" name="l00277"></a><span class="lineno"> 277</span><span class="preprocessor">#ifdef __cplusplus</span></div> +<div class="line"><a id="l00278" name="l00278"></a><span class="lineno"> 278</span>}</div> +<div class="line"><a id="l00279" name="l00279"></a><span class="lineno"> 279</span><span class="preprocessor">#endif</span></div> +<div class="line"><a id="l00280" name="l00280"></a><span class="lineno"> 280</span> </div> +<div class="line"><a id="l00281" name="l00281"></a><span class="lineno"> 281</span><span class="preprocessor">#endif </span><span class="comment">// neorv32_h</span></div> +<div class="ttc" id="aneorv32_8h_html_a10022df4c223533b04d5aebe222e8b73"><div class="ttname"><a href="neorv32_8h.html#a10022df4c223533b04d5aebe222e8b73">NEORV32_CLOCK_PRSC_enum</a></div><div class="ttdeci">NEORV32_CLOCK_PRSC_enum</div><div class="ttdef"><b>Definition</b> neorv32.h:196</div></div> +<div class="ttc" id="aneorv32_8h_html_a10022df4c223533b04d5aebe222e8b73a0f20c29722bf9afc478b1a286a6b7eee"><div class="ttname"><a href="neorv32_8h.html#a10022df4c223533b04d5aebe222e8b73a0f20c29722bf9afc478b1a286a6b7eee">CLK_PRSC_4096</a></div><div class="ttdeci">@ CLK_PRSC_4096</div><div class="ttdef"><b>Definition</b> neorv32.h:204</div></div> +<div class="ttc" id="aneorv32_8h_html_a10022df4c223533b04d5aebe222e8b73a18aac15afd5ebd8d3a00dd6e513daf17"><div class="ttname"><a href="neorv32_8h.html#a10022df4c223533b04d5aebe222e8b73a18aac15afd5ebd8d3a00dd6e513daf17">CLK_PRSC_1024</a></div><div class="ttdeci">@ CLK_PRSC_1024</div><div class="ttdef"><b>Definition</b> neorv32.h:202</div></div> +<div class="ttc" id="aneorv32_8h_html_a10022df4c223533b04d5aebe222e8b73a5990532893f2d9606e3c02aff60ca5da"><div class="ttname"><a href="neorv32_8h.html#a10022df4c223533b04d5aebe222e8b73a5990532893f2d9606e3c02aff60ca5da">CLK_PRSC_64</a></div><div class="ttdeci">@ CLK_PRSC_64</div><div class="ttdef"><b>Definition</b> neorv32.h:200</div></div> +<div class="ttc" id="aneorv32_8h_html_a10022df4c223533b04d5aebe222e8b73a648249b3ab8c2500880c1e68b98f81d1"><div class="ttname"><a href="neorv32_8h.html#a10022df4c223533b04d5aebe222e8b73a648249b3ab8c2500880c1e68b98f81d1">CLK_PRSC_4</a></div><div class="ttdeci">@ CLK_PRSC_4</div><div class="ttdef"><b>Definition</b> neorv32.h:198</div></div> +<div class="ttc" id="aneorv32_8h_html_a10022df4c223533b04d5aebe222e8b73a933045a5405de55781d687315f42054e"><div class="ttname"><a href="neorv32_8h.html#a10022df4c223533b04d5aebe222e8b73a933045a5405de55781d687315f42054e">CLK_PRSC_128</a></div><div class="ttdeci">@ CLK_PRSC_128</div><div class="ttdef"><b>Definition</b> neorv32.h:201</div></div> +<div class="ttc" id="aneorv32_8h_html_a10022df4c223533b04d5aebe222e8b73aa138f0cad547028d5124f89d6dcc8c79"><div class="ttname"><a href="neorv32_8h.html#a10022df4c223533b04d5aebe222e8b73aa138f0cad547028d5124f89d6dcc8c79">CLK_PRSC_2048</a></div><div class="ttdeci">@ CLK_PRSC_2048</div><div class="ttdef"><b>Definition</b> neorv32.h:203</div></div> +<div class="ttc" id="aneorv32_8h_html_a10022df4c223533b04d5aebe222e8b73aa4e3a6a5b3cd895f63b4544f63ce22c9"><div class="ttname"><a href="neorv32_8h.html#a10022df4c223533b04d5aebe222e8b73aa4e3a6a5b3cd895f63b4544f63ce22c9">CLK_PRSC_8</a></div><div class="ttdeci">@ CLK_PRSC_8</div><div class="ttdef"><b>Definition</b> neorv32.h:199</div></div> +<div class="ttc" id="aneorv32_8h_html_a10022df4c223533b04d5aebe222e8b73ad63d40139c50d76618cf1258cbdc0d05"><div class="ttname"><a href="neorv32_8h.html#a10022df4c223533b04d5aebe222e8b73ad63d40139c50d76618cf1258cbdc0d05">CLK_PRSC_2</a></div><div class="ttdeci">@ CLK_PRSC_2</div><div class="ttdef"><b>Definition</b> neorv32.h:197</div></div> +<div class="ttc" id="aneorv32__aux_8h_html"><div class="ttname"><a href="neorv32__aux_8h.html">neorv32_aux.h</a></div><div class="ttdoc">General auxiliary functions header file.</div></div> +<div class="ttc" id="aneorv32__cfs_8h_html"><div class="ttname"><a href="neorv32__cfs_8h.html">neorv32_cfs.h</a></div><div class="ttdoc">Custom Functions Subsystem (CFS) HW driver header file.</div></div> +<div class="ttc" id="aneorv32__cpu_8h_html"><div class="ttname"><a href="neorv32__cpu_8h.html">neorv32_cpu.h</a></div><div class="ttdoc">CPU Core Functions HW driver header file.</div></div> +<div class="ttc" id="aneorv32__cpu__amo_8h_html"><div class="ttname"><a href="neorv32__cpu__amo_8h.html">neorv32_cpu_amo.h</a></div><div class="ttdoc">Atomic memory access (read-modify-write) emulation functions using LR/SC pairs - header file.</div></div> +<div class="ttc" id="aneorv32__cpu__cfu_8h_html"><div class="ttname"><a href="neorv32__cpu__cfu_8h.html">neorv32_cpu_cfu.h</a></div><div class="ttdoc">CPU Core custom functions unit HW driver header file.</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html"><div class="ttname"><a href="neorv32__cpu__csr_8h.html">neorv32_cpu_csr.h</a></div><div class="ttdoc">Control and Status Registers (CSR) definitions.</div></div> +<div class="ttc" id="aneorv32__crc_8h_html"><div class="ttname"><a href="neorv32__crc_8h.html">neorv32_crc.h</a></div><div class="ttdoc">Cyclic redundancy check unit (CRC) HW driver header file.</div></div> +<div class="ttc" id="aneorv32__dma_8h_html"><div class="ttname"><a href="neorv32__dma_8h.html">neorv32_dma.h</a></div><div class="ttdoc">Direct Memory Access Controller (DMA) HW driver header file.</div></div> +<div class="ttc" id="aneorv32__gpio_8h_html"><div class="ttname"><a href="neorv32__gpio_8h.html">neorv32_gpio.h</a></div><div class="ttdoc">General purpose input/output port unit (GPIO) HW driver header file.</div></div> +<div class="ttc" id="aneorv32__gptmr_8h_html"><div class="ttname"><a href="neorv32__gptmr_8h.html">neorv32_gptmr.h</a></div><div class="ttdoc">General purpose timer (GPTMR) HW driver header file.</div></div> +<div class="ttc" id="aneorv32__intrinsics_8h_html"><div class="ttname"><a href="neorv32__intrinsics_8h.html">neorv32_intrinsics.h</a></div><div class="ttdoc">Helper functions and macros for custom &quot;intrinsics&quot; / instructions.</div></div> +<div class="ttc" id="aneorv32__legacy_8h_html"><div class="ttname"><a href="neorv32__legacy_8h.html">neorv32_legacy.h</a></div><div class="ttdoc">Legacy compatibility layer.</div></div> +<div class="ttc" id="aneorv32__mtime_8h_html"><div class="ttname"><a href="neorv32__mtime_8h.html">neorv32_mtime.h</a></div><div class="ttdoc">Machine System Timer (MTIME) HW driver header file.</div></div> +<div class="ttc" id="aneorv32__neoled_8h_html"><div class="ttname"><a href="neorv32__neoled_8h.html">neorv32_neoled.h</a></div><div class="ttdoc">Smart LED Interface (NEOLED) HW driver header file.</div></div> +<div class="ttc" id="aneorv32__onewire_8h_html"><div class="ttname"><a href="neorv32__onewire_8h.html">neorv32_onewire.h</a></div><div class="ttdoc">1-Wire Interface Controller (ONEWIRE) HW driver header file.</div></div> +<div class="ttc" id="aneorv32__pwm_8h_html"><div class="ttname"><a href="neorv32__pwm_8h.html">neorv32_pwm.h</a></div><div class="ttdoc">Pulse-Width Modulation Controller (PWM) HW driver header file.</div></div> +<div class="ttc" id="aneorv32__rte_8h_html"><div class="ttname"><a href="neorv32__rte_8h.html">neorv32_rte.h</a></div><div class="ttdoc">NEORV32 Runtime Environment.</div></div> +<div class="ttc" id="aneorv32__sdi_8h_html"><div class="ttname"><a href="neorv32__sdi_8h.html">neorv32_sdi.h</a></div><div class="ttdoc">Serial data interface controller (SPPI) HW driver header file.</div></div> +<div class="ttc" id="aneorv32__slink_8h_html"><div class="ttname"><a href="neorv32__slink_8h.html">neorv32_slink.h</a></div><div class="ttdoc">Stream Link Interface HW driver header file.</div></div> +<div class="ttc" id="aneorv32__spi_8h_html"><div class="ttname"><a href="neorv32__spi_8h.html">neorv32_spi.h</a></div><div class="ttdoc">Serial peripheral interface controller (SPI) HW driver header file.</div></div> +<div class="ttc" id="aneorv32__trng_8h_html"><div class="ttname"><a href="neorv32__trng_8h.html">neorv32_trng.h</a></div><div class="ttdoc">True Random Number Generator (TRNG) HW driver header file.</div></div> +<div class="ttc" id="aneorv32__twi_8h_html"><div class="ttname"><a href="neorv32__twi_8h.html">neorv32_twi.h</a></div><div class="ttdoc">Two-Wire Interface Controller (TWI) HW driver header file.</div></div> +<div class="ttc" id="aneorv32__uart_8h_html"><div class="ttname"><a href="neorv32__uart_8h.html">neorv32_uart.h</a></div><div class="ttdoc">Universal asynchronous receiver/transmitter (UART0/UART1) HW driver header file.</div></div> +<div class="ttc" id="aneorv32__wdt_8h_html"><div class="ttname"><a href="neorv32__wdt_8h.html">neorv32_wdt.h</a></div><div class="ttdoc">Watchdog Timer (WDT) HW driver header file.</div></div> +<div class="ttc" id="aneorv32__xip_8h_html"><div class="ttname"><a href="neorv32__xip_8h.html">neorv32_xip.h</a></div><div class="ttdoc">Execute in place module (XIP) HW driver header file.</div></div> +<div class="ttc" id="aneorv32__xirq_8h_html"><div class="ttname"><a href="neorv32__xirq_8h.html">neorv32_xirq.h</a></div><div class="ttdoc">External Interrupt controller HW driver header file.</div></div> +<div class="ttc" id="aunionsubwords16__t_html"><div class="ttname"><a href="unionsubwords16__t.html">subwords16_t</a></div><div class="ttdef"><b>Definition</b> neorv32.h:227</div></div> +<div class="ttc" id="aunionsubwords32__t_html"><div class="ttname"><a href="unionsubwords32__t.html">subwords32_t</a></div><div class="ttdef"><b>Definition</b> neorv32.h:221</div></div> +<div class="ttc" id="aunionsubwords64__t_html"><div class="ttname"><a href="unionsubwords64__t.html">subwords64_t</a></div><div class="ttdef"><b>Definition</b> neorv32.h:214</div></div> +</div><!-- fragment --></div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/neorv32__aux_8c.html b/sw/neorv32__aux_8c.html new file mode 100644 index 0000000000..c26b5ca3f0 --- /dev/null +++ b/sw/neorv32__aux_8c.html @@ -0,0 +1,230 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/lib/source/neorv32_aux.c File Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_7d04193005ada6f9450f847f4adb6b5b.html">lib</a></li><li class="navelem"><a class="el" href="dir_0c6ac14e2254a316d41123f98feeb67b.html">source</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#func-members">Functions</a> </div> + <div class="headertitle"><div class="title">neorv32_aux.c File Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p>General auxiliary functions source file. +<a href="#details">More...</a></p> +<div class="textblock"><code>#include &quot;<a class="el" href="neorv32_8h_source.html">neorv32.h</a>&quot;</code><br /> +</div><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="func-members" name="func-members"></a> +Functions</h2></td></tr> +<tr class="memitem:a94aa8369ba5f4ebdf5628fcb1ab2ba1c" id="r_a94aa8369ba5f4ebdf5628fcb1ab2ba1c"><td class="memItemLeft" align="right" valign="top">uint64_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a94aa8369ba5f4ebdf5628fcb1ab2ba1c">neorv32_aux_date2unixtime</a> (<a class="el" href="structdate__t.html">date_t</a> *date)</td></tr> +<tr class="separator:a94aa8369ba5f4ebdf5628fcb1ab2ba1c"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a885a81838a91b57797e849cb835c6887" id="r_a885a81838a91b57797e849cb835c6887"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a885a81838a91b57797e849cb835c6887">neorv32_aux_unixtime2date</a> (uint64_t unixtime, <a class="el" href="structdate__t.html">date_t</a> *date)</td></tr> +<tr class="separator:a885a81838a91b57797e849cb835c6887"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aec4703f369e1567c22f140d2ec9daafc" id="r_aec4703f369e1567c22f140d2ec9daafc"><td class="memItemLeft" align="right" valign="top">uint64_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aec4703f369e1567c22f140d2ec9daafc">neorv32_aux_hexstr2uint64</a> (char *buffer, uint8_t length)</td></tr> +<tr class="separator:aec4703f369e1567c22f140d2ec9daafc"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aff31dd983f75f70eeae331c65acaa50e" id="r_aff31dd983f75f70eeae331c65acaa50e"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aff31dd983f75f70eeae331c65acaa50e">neorv32_aux_xorshift32</a> (void)</td></tr> +<tr class="separator:aff31dd983f75f70eeae331c65acaa50e"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>General auxiliary functions source file. </p> +<dl class="section see"><dt>See also</dt><dd><a href="https://stnolting.github.io/neorv32/sw/files.html">https://stnolting.github.io/neorv32/sw/files.html</a> </dd></dl> +</div><h2 class="groupheader">Function Documentation</h2> +<a id="a94aa8369ba5f4ebdf5628fcb1ab2ba1c" name="a94aa8369ba5f4ebdf5628fcb1ab2ba1c"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a94aa8369ba5f4ebdf5628fcb1ab2ba1c">&#9670;&#160;</a></span>neorv32_aux_date2unixtime()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint64_t neorv32_aux_date2unixtime </td> + <td>(</td> + <td class="paramtype"><a class="el" href="structdate__t.html">date_t</a> *</td> <td class="paramname"><span class="paramname"><em>date</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Convert date to Unix time stamp.</p> +<dl class="section copyright"><dt>Copyright</dt><dd>Copyright (C) 2010-2024 Oryx Embedded SARL. All rights reserved. SPDX-License-Identifier: GPL-2.0-or-later <a href="https://github.com/Oryx-Embedded/Common/blob/master/date_time.c">https://github.com/Oryx-Embedded/Common/blob/master/date_time.c</a></dd></dl> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">date</td><td>Pointer to date and time struct (<a class="el" href="structdate__t.html">date_t</a>). </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Unix time since 00:00:00 UTC, January 1, 1970 in seconds. </dd></dl> + +</div> +</div> +<a id="aec4703f369e1567c22f140d2ec9daafc" name="aec4703f369e1567c22f140d2ec9daafc"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aec4703f369e1567c22f140d2ec9daafc">&#9670;&#160;</a></span>neorv32_aux_hexstr2uint64()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint64_t neorv32_aux_hexstr2uint64 </td> + <td>(</td> + <td class="paramtype">char *</td> <td class="paramname"><span class="paramname"><em>buffer</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">uint8_t</td> <td class="paramname"><span class="paramname"><em>length</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Helper function to convert up to 16 hex chars string into uint64_t</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in,out]</td><td class="paramname">buffer</td><td>Pointer to array of chars to convert into number. </td></tr> + <tr><td class="paramdir">[in,out]</td><td class="paramname">length</td><td>Length of the conversion string. </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Converted number (uint64_t). </dd></dl> + +</div> +</div> +<a id="a885a81838a91b57797e849cb835c6887" name="a885a81838a91b57797e849cb835c6887"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a885a81838a91b57797e849cb835c6887">&#9670;&#160;</a></span>neorv32_aux_unixtime2date()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_aux_unixtime2date </td> + <td>(</td> + <td class="paramtype">uint64_t</td> <td class="paramname"><span class="paramname"><em>unixtime</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype"><a class="el" href="structdate__t.html">date_t</a> *</td> <td class="paramname"><span class="paramname"><em>date</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Convert Unix time stamp to date.</p> +<dl class="section copyright"><dt>Copyright</dt><dd>Copyright (C) 2010-2024 Oryx Embedded SARL. All rights reserved. SPDX-License-Identifier: GPL-2.0-or-later <a href="https://github.com/Oryx-Embedded/Common/blob/master/date_time.c">https://github.com/Oryx-Embedded/Common/blob/master/date_time.c</a></dd></dl> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">unixtime</td><td>Unix time since 00:00:00 UTC, January 1, 1970 in seconds. </td></tr> + <tr><td class="paramdir">[in,out]</td><td class="paramname">date</td><td>Pointer to date and time struct (<a class="el" href="structdate__t.html">date_t</a>). </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="aff31dd983f75f70eeae331c65acaa50e" name="aff31dd983f75f70eeae331c65acaa50e"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aff31dd983f75f70eeae331c65acaa50e">&#9670;&#160;</a></span>neorv32_aux_xorshift32()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_aux_xorshift32 </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>XORSHIFT pseudo random number generator.</p> +<dl class="section return"><dt>Returns</dt><dd>Random number (uint32_t). </dd></dl> + +</div> +</div> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/neorv32__aux_8h.html b/sw/neorv32__aux_8h.html new file mode 100644 index 0000000000..d4bee7c0ff --- /dev/null +++ b/sw/neorv32__aux_8h.html @@ -0,0 +1,248 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/lib/include/neorv32_aux.h File Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_7d04193005ada6f9450f847f4adb6b5b.html">lib</a></li><li class="navelem"><a class="el" href="dir_752b1e5d3973bf735fa78bf6b4727df9.html">include</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#nested-classes">Data Structures</a> </div> + <div class="headertitle"><div class="title">neorv32_aux.h File Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p>General auxiliary functions header file. +<a href="#details">More...</a></p> +<div class="textblock"><code>#include &lt;stdint.h&gt;</code><br /> +</div> +<p><a href="neorv32__aux_8h_source.html">Go to the source code of this file.</a></p> +<table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="nested-classes" name="nested-classes"></a> +Data Structures</h2></td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">struct &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structdate__t.html">date_t</a></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="define-members" name="define-members"></a> +Macros</h2></td></tr> +<tr><td colspan="2"><div class="groupHeader">Select minimum/maximum</div></td></tr> +<tr class="memitem:aa18754c48dc72c66679e024e074f0f47" id="r_aa18754c48dc72c66679e024e074f0f47"><td class="memItemLeft" align="right" valign="top"><a id="aa18754c48dc72c66679e024e074f0f47" name="aa18754c48dc72c66679e024e074f0f47"></a> +#define&#160;</td><td class="memItemRight" valign="bottom"><b>neorv32_aux_min</b>(a, b)&#160;&#160;&#160;({ __typeof__ (a) _a = (a); __typeof__ (b) _b = (b); _a &lt; _b ? _a : _b; })</td></tr> +<tr class="separator:aa18754c48dc72c66679e024e074f0f47"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a7be19d0ada72a1071a4baac9367702d1" id="r_a7be19d0ada72a1071a4baac9367702d1"><td class="memItemLeft" align="right" valign="top"><a id="a7be19d0ada72a1071a4baac9367702d1" name="a7be19d0ada72a1071a4baac9367702d1"></a> +#define&#160;</td><td class="memItemRight" valign="bottom"><b>neorv32_aux_max</b>(a, b)&#160;&#160;&#160;({ __typeof__ (a) _a = (a); __typeof__ (b) _b = (b); _a &gt; _b ? _a : _b; })</td></tr> +<tr class="separator:a7be19d0ada72a1071a4baac9367702d1"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="func-members" name="func-members"></a> +Functions</h2></td></tr> +<tr><td colspan="2"><div class="groupHeader">AUX prototypes</div></td></tr> +<tr class="memitem:a94aa8369ba5f4ebdf5628fcb1ab2ba1c" id="r_a94aa8369ba5f4ebdf5628fcb1ab2ba1c"><td class="memItemLeft" align="right" valign="top">uint64_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a94aa8369ba5f4ebdf5628fcb1ab2ba1c">neorv32_aux_date2unixtime</a> (<a class="el" href="structdate__t.html">date_t</a> *date)</td></tr> +<tr class="separator:a94aa8369ba5f4ebdf5628fcb1ab2ba1c"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a885a81838a91b57797e849cb835c6887" id="r_a885a81838a91b57797e849cb835c6887"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a885a81838a91b57797e849cb835c6887">neorv32_aux_unixtime2date</a> (uint64_t unixtime, <a class="el" href="structdate__t.html">date_t</a> *date)</td></tr> +<tr class="separator:a885a81838a91b57797e849cb835c6887"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aec4703f369e1567c22f140d2ec9daafc" id="r_aec4703f369e1567c22f140d2ec9daafc"><td class="memItemLeft" align="right" valign="top">uint64_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aec4703f369e1567c22f140d2ec9daafc">neorv32_aux_hexstr2uint64</a> (char *buffer, uint8_t length)</td></tr> +<tr class="separator:aec4703f369e1567c22f140d2ec9daafc"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aff31dd983f75f70eeae331c65acaa50e" id="r_aff31dd983f75f70eeae331c65acaa50e"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aff31dd983f75f70eeae331c65acaa50e">neorv32_aux_xorshift32</a> (void)</td></tr> +<tr class="separator:aff31dd983f75f70eeae331c65acaa50e"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>General auxiliary functions header file. </p> +<dl class="section see"><dt>See also</dt><dd><a href="https://stnolting.github.io/neorv32/sw/files.html">https://stnolting.github.io/neorv32/sw/files.html</a> </dd></dl> +</div><h2 class="groupheader">Function Documentation</h2> +<a id="a94aa8369ba5f4ebdf5628fcb1ab2ba1c" name="a94aa8369ba5f4ebdf5628fcb1ab2ba1c"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a94aa8369ba5f4ebdf5628fcb1ab2ba1c">&#9670;&#160;</a></span>neorv32_aux_date2unixtime()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint64_t neorv32_aux_date2unixtime </td> + <td>(</td> + <td class="paramtype"><a class="el" href="structdate__t.html">date_t</a> *</td> <td class="paramname"><span class="paramname"><em>date</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Convert date to Unix time stamp.</p> +<dl class="section copyright"><dt>Copyright</dt><dd>Copyright (C) 2010-2024 Oryx Embedded SARL. All rights reserved. SPDX-License-Identifier: GPL-2.0-or-later <a href="https://github.com/Oryx-Embedded/Common/blob/master/date_time.c">https://github.com/Oryx-Embedded/Common/blob/master/date_time.c</a></dd></dl> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">date</td><td>Pointer to date and time struct (<a class="el" href="structdate__t.html">date_t</a>). </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Unix time since 00:00:00 UTC, January 1, 1970 in seconds. </dd></dl> + +</div> +</div> +<a id="aec4703f369e1567c22f140d2ec9daafc" name="aec4703f369e1567c22f140d2ec9daafc"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aec4703f369e1567c22f140d2ec9daafc">&#9670;&#160;</a></span>neorv32_aux_hexstr2uint64()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint64_t neorv32_aux_hexstr2uint64 </td> + <td>(</td> + <td class="paramtype">char *</td> <td class="paramname"><span class="paramname"><em>buffer</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">uint8_t</td> <td class="paramname"><span class="paramname"><em>length</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Helper function to convert up to 16 hex chars string into uint64_t</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in,out]</td><td class="paramname">buffer</td><td>Pointer to array of chars to convert into number. </td></tr> + <tr><td class="paramdir">[in,out]</td><td class="paramname">length</td><td>Length of the conversion string. </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Converted number (uint64_t). </dd></dl> + +</div> +</div> +<a id="a885a81838a91b57797e849cb835c6887" name="a885a81838a91b57797e849cb835c6887"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a885a81838a91b57797e849cb835c6887">&#9670;&#160;</a></span>neorv32_aux_unixtime2date()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_aux_unixtime2date </td> + <td>(</td> + <td class="paramtype">uint64_t</td> <td class="paramname"><span class="paramname"><em>unixtime</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype"><a class="el" href="structdate__t.html">date_t</a> *</td> <td class="paramname"><span class="paramname"><em>date</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Convert Unix time stamp to date.</p> +<dl class="section copyright"><dt>Copyright</dt><dd>Copyright (C) 2010-2024 Oryx Embedded SARL. All rights reserved. SPDX-License-Identifier: GPL-2.0-or-later <a href="https://github.com/Oryx-Embedded/Common/blob/master/date_time.c">https://github.com/Oryx-Embedded/Common/blob/master/date_time.c</a></dd></dl> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">unixtime</td><td>Unix time since 00:00:00 UTC, January 1, 1970 in seconds. </td></tr> + <tr><td class="paramdir">[in,out]</td><td class="paramname">date</td><td>Pointer to date and time struct (<a class="el" href="structdate__t.html">date_t</a>). </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="aff31dd983f75f70eeae331c65acaa50e" name="aff31dd983f75f70eeae331c65acaa50e"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aff31dd983f75f70eeae331c65acaa50e">&#9670;&#160;</a></span>neorv32_aux_xorshift32()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_aux_xorshift32 </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>XORSHIFT pseudo random number generator.</p> +<dl class="section return"><dt>Returns</dt><dd>Random number (uint32_t). </dd></dl> + +</div> +</div> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/neorv32__aux_8h_source.html b/sw/neorv32__aux_8h_source.html new file mode 100644 index 0000000000..b66476c811 --- /dev/null +++ b/sw/neorv32__aux_8h_source.html @@ -0,0 +1,152 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/lib/include/neorv32_aux.h Source File</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_7d04193005ada6f9450f847f4adb6b5b.html">lib</a></li><li class="navelem"><a class="el" href="dir_752b1e5d3973bf735fa78bf6b4727df9.html">include</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="headertitle"><div class="title">neorv32_aux.h</div></div> +</div><!--header--> +<div class="contents"> +<a href="neorv32__aux_8h.html">Go to the documentation of this file.</a><div class="fragment"><div class="line"><a id="l00001" name="l00001"></a><span class="lineno"> 1</span><span class="comment">// ================================================================================ //</span></div> +<div class="line"><a id="l00002" name="l00002"></a><span class="lineno"> 2</span><span class="comment">// The NEORV32 RISC-V Processor - https://github.com/stnolting/neorv32 //</span></div> +<div class="line"><a id="l00003" name="l00003"></a><span class="lineno"> 3</span><span class="comment">// Copyright (c) NEORV32 contributors. //</span></div> +<div class="line"><a id="l00004" name="l00004"></a><span class="lineno"> 4</span><span class="comment">// Copyright (c) 2020 - 2024 Stephan Nolting. All rights reserved. //</span></div> +<div class="line"><a id="l00005" name="l00005"></a><span class="lineno"> 5</span><span class="comment">// Licensed under the BSD-3-Clause license, see LICENSE for details. //</span></div> +<div class="line"><a id="l00006" name="l00006"></a><span class="lineno"> 6</span><span class="comment">// SPDX-License-Identifier: BSD-3-Clause //</span></div> +<div class="line"><a id="l00007" name="l00007"></a><span class="lineno"> 7</span><span class="comment">// ================================================================================ //</span></div> +<div class="line"><a id="l00008" name="l00008"></a><span class="lineno"> 8</span> </div> +<div class="line"><a id="l00015" name="l00015"></a><span class="lineno"> 15</span><span class="preprocessor">#ifndef neorv32_aux_h</span></div> +<div class="line"><a id="l00016" name="l00016"></a><span class="lineno"> 16</span><span class="preprocessor">#define neorv32_aux_h</span></div> +<div class="line"><a id="l00017" name="l00017"></a><span class="lineno"> 17</span> </div> +<div class="line"><a id="l00018" name="l00018"></a><span class="lineno"> 18</span><span class="preprocessor">#include &lt;stdint.h&gt;</span></div> +<div class="line"><a id="l00019" name="l00019"></a><span class="lineno"> 19</span> </div> +<div class="line"><a id="l00020" name="l00020"></a><span class="lineno"> 20</span> </div> +<div class="line"><a id="l00021" name="l00021"></a><span class="lineno"> 21</span><span class="comment">/**********************************************************************/</span></div> +<div class="line"><a id="l00025" name="l00025"></a><span class="lineno"> 25</span><span class="preprocessor">#define neorv32_aux_min(a, b) ({ __typeof__ (a) _a = (a); __typeof__ (b) _b = (b); _a &lt; _b ? _a : _b; })</span></div> +<div class="line"><a id="l00026" name="l00026"></a><span class="lineno"> 26</span><span class="preprocessor">#define neorv32_aux_max(a, b) ({ __typeof__ (a) _a = (a); __typeof__ (b) _b = (b); _a &gt; _b ? _a : _b; })</span></div> +<div class="line"><a id="l00030" name="l00030"></a><span class="lineno"> 30</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen00033" data-start="{" data-end="};"> +<div class="line"><a id="l00033" name="l00033"></a><span class="lineno"><a class="line" href="structdate__t.html"> 33</a></span><span class="keyword">typedef</span> <span class="keyword">struct </span>{</div> +<div class="line"><a id="l00034" name="l00034"></a><span class="lineno"><a class="line" href="structdate__t.html#aabab1b1efd94b69bfb28b639c612dd4f"> 34</a></span> uint16_t <a class="code hl_variable" href="structdate__t.html#aabab1b1efd94b69bfb28b639c612dd4f">year</a>; </div> +<div class="line"><a id="l00035" name="l00035"></a><span class="lineno"><a class="line" href="structdate__t.html#a1a97f6a755cd4209a0880cf811d52c7b"> 35</a></span> uint8_t <a class="code hl_variable" href="structdate__t.html#a1a97f6a755cd4209a0880cf811d52c7b">month</a>; </div> +<div class="line"><a id="l00036" name="l00036"></a><span class="lineno"><a class="line" href="structdate__t.html#a482ad87226bae7841dfec63e035aeace"> 36</a></span> uint8_t <a class="code hl_variable" href="structdate__t.html#a482ad87226bae7841dfec63e035aeace">day</a>; </div> +<div class="line"><a id="l00037" name="l00037"></a><span class="lineno"><a class="line" href="structdate__t.html#a44167cd71416886e55048310af6d4e1b"> 37</a></span> uint8_t <a class="code hl_variable" href="structdate__t.html#a44167cd71416886e55048310af6d4e1b">weekday</a>; </div> +<div class="line"><a id="l00038" name="l00038"></a><span class="lineno"><a class="line" href="structdate__t.html#a39a23695634a2814d827984f4eea54eb"> 38</a></span> uint8_t <a class="code hl_variable" href="structdate__t.html#a39a23695634a2814d827984f4eea54eb">hours</a>; </div> +<div class="line"><a id="l00039" name="l00039"></a><span class="lineno"><a class="line" href="structdate__t.html#a2ab79834ebae42979e359bf30ad5f67a"> 39</a></span> uint8_t <a class="code hl_variable" href="structdate__t.html#a2ab79834ebae42979e359bf30ad5f67a">minutes</a>; </div> +<div class="line"><a id="l00040" name="l00040"></a><span class="lineno"><a class="line" href="structdate__t.html#a1071948e7754cb415da9714d59a315bf"> 40</a></span> uint8_t <a class="code hl_variable" href="structdate__t.html#a1071948e7754cb415da9714d59a315bf">seconds</a>; </div> +<div class="line"><a id="l00041" name="l00041"></a><span class="lineno"> 41</span>} <a class="code hl_struct" href="structdate__t.html">date_t</a>;</div> +</div> +<div class="line"><a id="l00042" name="l00042"></a><span class="lineno"> 42</span> </div> +<div class="line"><a id="l00043" name="l00043"></a><span class="lineno"> 43</span> </div> +<div class="line"><a id="l00044" name="l00044"></a><span class="lineno"> 44</span><span class="comment">/**********************************************************************/</span></div> +<div class="line"><a id="l00048" name="l00048"></a><span class="lineno"> 48</span>uint64_t <a class="code hl_function" href="neorv32__aux_8h.html#a94aa8369ba5f4ebdf5628fcb1ab2ba1c">neorv32_aux_date2unixtime</a>(<a class="code hl_struct" href="structdate__t.html">date_t</a>* date);</div> +<div class="line"><a id="l00049" name="l00049"></a><span class="lineno"> 49</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__aux_8h.html#a885a81838a91b57797e849cb835c6887">neorv32_aux_unixtime2date</a>(uint64_t unixtime, <a class="code hl_struct" href="structdate__t.html">date_t</a>* date);</div> +<div class="line"><a id="l00050" name="l00050"></a><span class="lineno"> 50</span>uint64_t <a class="code hl_function" href="neorv32__aux_8h.html#aec4703f369e1567c22f140d2ec9daafc">neorv32_aux_hexstr2uint64</a>(<span class="keywordtype">char</span> *buffer, uint8_t length);</div> +<div class="line"><a id="l00051" name="l00051"></a><span class="lineno"> 51</span>uint32_t <a class="code hl_function" href="neorv32__aux_8h.html#aff31dd983f75f70eeae331c65acaa50e">neorv32_aux_xorshift32</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00055" name="l00055"></a><span class="lineno"> 55</span><span class="preprocessor">#endif </span><span class="comment">// neorv32_aux_h</span></div> +<div class="ttc" id="aneorv32__aux_8h_html_a885a81838a91b57797e849cb835c6887"><div class="ttname"><a href="neorv32__aux_8h.html#a885a81838a91b57797e849cb835c6887">neorv32_aux_unixtime2date</a></div><div class="ttdeci">void neorv32_aux_unixtime2date(uint64_t unixtime, date_t *date)</div><div class="ttdef"><b>Definition</b> neorv32_aux.c:85</div></div> +<div class="ttc" id="aneorv32__aux_8h_html_a94aa8369ba5f4ebdf5628fcb1ab2ba1c"><div class="ttname"><a href="neorv32__aux_8h.html#a94aa8369ba5f4ebdf5628fcb1ab2ba1c">neorv32_aux_date2unixtime</a></div><div class="ttdeci">uint64_t neorv32_aux_date2unixtime(date_t *date)</div><div class="ttdef"><b>Definition</b> neorv32_aux.c:28</div></div> +<div class="ttc" id="aneorv32__aux_8h_html_aec4703f369e1567c22f140d2ec9daafc"><div class="ttname"><a href="neorv32__aux_8h.html#aec4703f369e1567c22f140d2ec9daafc">neorv32_aux_hexstr2uint64</a></div><div class="ttdeci">uint64_t neorv32_aux_hexstr2uint64(char *buffer, uint8_t length)</div><div class="ttdef"><b>Definition</b> neorv32_aux.c:151</div></div> +<div class="ttc" id="aneorv32__aux_8h_html_aff31dd983f75f70eeae331c65acaa50e"><div class="ttname"><a href="neorv32__aux_8h.html#aff31dd983f75f70eeae331c65acaa50e">neorv32_aux_xorshift32</a></div><div class="ttdeci">uint32_t neorv32_aux_xorshift32(void)</div><div class="ttdef"><b>Definition</b> neorv32_aux.c:190</div></div> +<div class="ttc" id="astructdate__t_html"><div class="ttname"><a href="structdate__t.html">date_t</a></div><div class="ttdef"><b>Definition</b> neorv32_aux.h:33</div></div> +<div class="ttc" id="astructdate__t_html_a1071948e7754cb415da9714d59a315bf"><div class="ttname"><a href="structdate__t.html#a1071948e7754cb415da9714d59a315bf">date_t::seconds</a></div><div class="ttdeci">uint8_t seconds</div><div class="ttdef"><b>Definition</b> neorv32_aux.h:40</div></div> +<div class="ttc" id="astructdate__t_html_a1a97f6a755cd4209a0880cf811d52c7b"><div class="ttname"><a href="structdate__t.html#a1a97f6a755cd4209a0880cf811d52c7b">date_t::month</a></div><div class="ttdeci">uint8_t month</div><div class="ttdef"><b>Definition</b> neorv32_aux.h:35</div></div> +<div class="ttc" id="astructdate__t_html_a2ab79834ebae42979e359bf30ad5f67a"><div class="ttname"><a href="structdate__t.html#a2ab79834ebae42979e359bf30ad5f67a">date_t::minutes</a></div><div class="ttdeci">uint8_t minutes</div><div class="ttdef"><b>Definition</b> neorv32_aux.h:39</div></div> +<div class="ttc" id="astructdate__t_html_a39a23695634a2814d827984f4eea54eb"><div class="ttname"><a href="structdate__t.html#a39a23695634a2814d827984f4eea54eb">date_t::hours</a></div><div class="ttdeci">uint8_t hours</div><div class="ttdef"><b>Definition</b> neorv32_aux.h:38</div></div> +<div class="ttc" id="astructdate__t_html_a44167cd71416886e55048310af6d4e1b"><div class="ttname"><a href="structdate__t.html#a44167cd71416886e55048310af6d4e1b">date_t::weekday</a></div><div class="ttdeci">uint8_t weekday</div><div class="ttdef"><b>Definition</b> neorv32_aux.h:37</div></div> +<div class="ttc" id="astructdate__t_html_a482ad87226bae7841dfec63e035aeace"><div class="ttname"><a href="structdate__t.html#a482ad87226bae7841dfec63e035aeace">date_t::day</a></div><div class="ttdeci">uint8_t day</div><div class="ttdef"><b>Definition</b> neorv32_aux.h:36</div></div> +<div class="ttc" id="astructdate__t_html_aabab1b1efd94b69bfb28b639c612dd4f"><div class="ttname"><a href="structdate__t.html#aabab1b1efd94b69bfb28b639c612dd4f">date_t::year</a></div><div class="ttdeci">uint16_t year</div><div class="ttdef"><b>Definition</b> neorv32_aux.h:34</div></div> +</div><!-- fragment --></div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/neorv32__cfs_8c.html b/sw/neorv32__cfs_8c.html new file mode 100644 index 0000000000..672fa3dbbe --- /dev/null +++ b/sw/neorv32__cfs_8c.html @@ -0,0 +1,142 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/lib/source/neorv32_cfs.c File Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_7d04193005ada6f9450f847f4adb6b5b.html">lib</a></li><li class="navelem"><a class="el" href="dir_0c6ac14e2254a316d41123f98feeb67b.html">source</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#func-members">Functions</a> </div> + <div class="headertitle"><div class="title">neorv32_cfs.c File Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p>Custom Functions Subsystem (CFS) HW driver source file. +<a href="#details">More...</a></p> +<div class="textblock"><code>#include &quot;<a class="el" href="neorv32_8h_source.html">neorv32.h</a>&quot;</code><br /> +</div><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="func-members" name="func-members"></a> +Functions</h2></td></tr> +<tr class="memitem:abac96dfaefe433eca1c0b93fa6183d2e" id="r_abac96dfaefe433eca1c0b93fa6183d2e"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#abac96dfaefe433eca1c0b93fa6183d2e">neorv32_cfs_available</a> (void)</td></tr> +<tr class="separator:abac96dfaefe433eca1c0b93fa6183d2e"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>Custom Functions Subsystem (CFS) HW driver source file. </p> +<dl class="section warning"><dt>Warning</dt><dd>There are no "real" CFS driver functions available here, because these functions are defined by the actual hardware. </dd> +<dd> +Hence, the CFS designer has to provide the actual driver functions.</dd></dl> +<dl class="section note"><dt>Note</dt><dd>These functions should only be used if the CFS was synthesized (IO_CFS_EN = true).</dd></dl> +<dl class="section see"><dt>See also</dt><dd><a href="https://stnolting.github.io/neorv32/sw/files.html">https://stnolting.github.io/neorv32/sw/files.html</a> </dd></dl> +</div><h2 class="groupheader">Function Documentation</h2> +<a id="abac96dfaefe433eca1c0b93fa6183d2e" name="abac96dfaefe433eca1c0b93fa6183d2e"></a> +<h2 class="memtitle"><span class="permalink"><a href="#abac96dfaefe433eca1c0b93fa6183d2e">&#9670;&#160;</a></span>neorv32_cfs_available()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_cfs_available </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Check if custom functions subsystem was synthesized.</p> +<dl class="section return"><dt>Returns</dt><dd>0 if CFS was not synthesized, 1 if CFS is available. </dd></dl> + +</div> +</div> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/neorv32__cfs_8h.html b/sw/neorv32__cfs_8h.html new file mode 100644 index 0000000000..c2c42ec763 --- /dev/null +++ b/sw/neorv32__cfs_8h.html @@ -0,0 +1,175 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/lib/include/neorv32_cfs.h File Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_7d04193005ada6f9450f847f4adb6b5b.html">lib</a></li><li class="navelem"><a class="el" href="dir_752b1e5d3973bf735fa78bf6b4727df9.html">include</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#nested-classes">Data Structures</a> </div> + <div class="headertitle"><div class="title">neorv32_cfs.h File Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p>Custom Functions Subsystem (CFS) HW driver header file. +<a href="#details">More...</a></p> +<div class="textblock"><code>#include &lt;stdint.h&gt;</code><br /> +</div> +<p><a href="neorv32__cfs_8h_source.html">Go to the source code of this file.</a></p> +<table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="nested-classes" name="nested-classes"></a> +Data Structures</h2></td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">struct &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structneorv32__cfs__t.html">neorv32_cfs_t</a></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="define-members" name="define-members"></a> +Macros</h2></td></tr> +<tr><td colspan="2"><div class="groupHeader">IO Device: Custom Functions Subsystem (CFS)</div></td></tr> +<tr class="memitem:a6c101b306bd096f78d351e39b308d3e2" id="r_a6c101b306bd096f78d351e39b308d3e2"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a6c101b306bd096f78d351e39b308d3e2">NEORV32_CFS</a>&#160;&#160;&#160;((<a class="el" href="structneorv32__cfs__t.html">neorv32_cfs_t</a>*) (<a class="el" href="neorv32_8h.html#a41d6f97daef61641da96b9f72f6b272f">NEORV32_CFS_BASE</a>))</td></tr> +<tr class="separator:a6c101b306bd096f78d351e39b308d3e2"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="func-members" name="func-members"></a> +Functions</h2></td></tr> +<tr><td colspan="2"><div class="groupHeader">Prototypes</div></td></tr> +<tr class="memitem:abac96dfaefe433eca1c0b93fa6183d2e" id="r_abac96dfaefe433eca1c0b93fa6183d2e"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#abac96dfaefe433eca1c0b93fa6183d2e">neorv32_cfs_available</a> (void)</td></tr> +<tr class="separator:abac96dfaefe433eca1c0b93fa6183d2e"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>Custom Functions Subsystem (CFS) HW driver header file. </p> +<p>System Configuration Information Memory (SYSINFO) HW driver header file.</p> +<dl class="section warning"><dt>Warning</dt><dd>There are no "real" CFS driver functions available here, because these functions are defined by the actual hardware. </dd> +<dd> +The CFS designer has to provide the actual driver functions.</dd></dl> +<dl class="section note"><dt>Note</dt><dd>These functions should only be used if the CFS was synthesized (IO_CFS_EN = true). </dd></dl> +<dl class="section see"><dt>See also</dt><dd><a href="https://stnolting.github.io/neorv32/sw/files.html">https://stnolting.github.io/neorv32/sw/files.html</a></dd> +<dd> +<a href="https://stnolting.github.io/neorv32/sw/files.html">https://stnolting.github.io/neorv32/sw/files.html</a> </dd></dl> +</div><h2 class="groupheader">Macro Definition Documentation</h2> +<a id="a6c101b306bd096f78d351e39b308d3e2" name="a6c101b306bd096f78d351e39b308d3e2"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a6c101b306bd096f78d351e39b308d3e2">&#9670;&#160;</a></span>NEORV32_CFS</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define NEORV32_CFS&#160;&#160;&#160;((<a class="el" href="structneorv32__cfs__t.html">neorv32_cfs_t</a>*) (<a class="el" href="neorv32_8h.html#a41d6f97daef61641da96b9f72f6b272f">NEORV32_CFS_BASE</a>))</td> + </tr> + </table> +</div><div class="memdoc"> +<p>CFS module hardware access (<a class="el" href="structneorv32__cfs__t.html">neorv32_cfs_t</a>) </p> + +</div> +</div> +<h2 class="groupheader">Function Documentation</h2> +<a id="abac96dfaefe433eca1c0b93fa6183d2e" name="abac96dfaefe433eca1c0b93fa6183d2e"></a> +<h2 class="memtitle"><span class="permalink"><a href="#abac96dfaefe433eca1c0b93fa6183d2e">&#9670;&#160;</a></span>neorv32_cfs_available()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_cfs_available </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Check if custom functions subsystem was synthesized.</p> +<dl class="section return"><dt>Returns</dt><dd>0 if CFS was not synthesized, 1 if CFS is available. </dd></dl> + +</div> +</div> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/neorv32__cfs_8h_source.html b/sw/neorv32__cfs_8h_source.html new file mode 100644 index 0000000000..d771e1cd16 --- /dev/null +++ b/sw/neorv32__cfs_8h_source.html @@ -0,0 +1,130 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/lib/include/neorv32_cfs.h Source File</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_7d04193005ada6f9450f847f4adb6b5b.html">lib</a></li><li class="navelem"><a class="el" href="dir_752b1e5d3973bf735fa78bf6b4727df9.html">include</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="headertitle"><div class="title">neorv32_cfs.h</div></div> +</div><!--header--> +<div class="contents"> +<a href="neorv32__cfs_8h.html">Go to the documentation of this file.</a><div class="fragment"><div class="line"><a id="l00001" name="l00001"></a><span class="lineno"> 1</span><span class="comment">// ================================================================================ //</span></div> +<div class="line"><a id="l00002" name="l00002"></a><span class="lineno"> 2</span><span class="comment">// The NEORV32 RISC-V Processor - https://github.com/stnolting/neorv32 //</span></div> +<div class="line"><a id="l00003" name="l00003"></a><span class="lineno"> 3</span><span class="comment">// Copyright (c) NEORV32 contributors. //</span></div> +<div class="line"><a id="l00004" name="l00004"></a><span class="lineno"> 4</span><span class="comment">// Copyright (c) 2020 - 2024 Stephan Nolting. All rights reserved. //</span></div> +<div class="line"><a id="l00005" name="l00005"></a><span class="lineno"> 5</span><span class="comment">// Licensed under the BSD-3-Clause license, see LICENSE for details. //</span></div> +<div class="line"><a id="l00006" name="l00006"></a><span class="lineno"> 6</span><span class="comment">// SPDX-License-Identifier: BSD-3-Clause //</span></div> +<div class="line"><a id="l00007" name="l00007"></a><span class="lineno"> 7</span><span class="comment">// ================================================================================ //</span></div> +<div class="line"><a id="l00008" name="l00008"></a><span class="lineno"> 8</span> </div> +<div class="line"><a id="l00020" name="l00020"></a><span class="lineno"> 20</span><span class="preprocessor">#ifndef neorv32_cfs_h</span></div> +<div class="line"><a id="l00021" name="l00021"></a><span class="lineno"> 21</span><span class="preprocessor">#define neorv32_cfs_h</span></div> +<div class="line"><a id="l00022" name="l00022"></a><span class="lineno"> 22</span> </div> +<div class="line"><a id="l00023" name="l00023"></a><span class="lineno"> 23</span><span class="preprocessor">#include &lt;stdint.h&gt;</span></div> +<div class="line"><a id="l00024" name="l00024"></a><span class="lineno"> 24</span> </div> +<div class="line"><a id="l00025" name="l00025"></a><span class="lineno"> 25</span> </div> +<div class="line"><a id="l00026" name="l00026"></a><span class="lineno"> 26</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen00031" data-start="{" data-end="};"> +<div class="line"><a id="l00031" name="l00031"></a><span class="lineno"><a class="line" href="structneorv32__cfs__t.html"> 31</a></span><span class="keyword">typedef</span> <span class="keyword">volatile</span> <span class="keyword">struct </span>__attribute__((packed,aligned(4))) {</div> +<div class="line"><a id="l00032" name="l00032"></a><span class="lineno"><a class="line" href="structneorv32__cfs__t.html#a48d3e81b207f4dcce0b0cc901583dc4d"> 32</a></span> uint32_t REG[64]; </div> +<div class="line"><a id="l00033" name="l00033"></a><span class="lineno"> 33</span>} <a class="code hl_struct" href="structneorv32__cfs__t.html">neorv32_cfs_t</a>;</div> +</div> +<div class="line"><a id="l00034" name="l00034"></a><span class="lineno"> 34</span> </div> +<div class="line"><a id="l00036" name="l00036"></a><span class="lineno"><a class="line" href="neorv32__cfs_8h.html#a6c101b306bd096f78d351e39b308d3e2"> 36</a></span><span class="preprocessor">#define NEORV32_CFS ((neorv32_cfs_t*) (NEORV32_CFS_BASE))</span></div> +<div class="line"><a id="l00040" name="l00040"></a><span class="lineno"> 40</span><span class="comment">/**********************************************************************/</span></div> +<div class="line"><a id="l00044" name="l00044"></a><span class="lineno"> 44</span><span class="keywordtype">int</span> <a class="code hl_function" href="neorv32__cfs_8h.html#abac96dfaefe433eca1c0b93fa6183d2e">neorv32_cfs_available</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00048" name="l00048"></a><span class="lineno"> 48</span><span class="preprocessor">#endif </span><span class="comment">// neorv32_cfs_h</span></div> +<div class="ttc" id="aneorv32__cfs_8h_html_abac96dfaefe433eca1c0b93fa6183d2e"><div class="ttname"><a href="neorv32__cfs_8h.html#abac96dfaefe433eca1c0b93fa6183d2e">neorv32_cfs_available</a></div><div class="ttdeci">int neorv32_cfs_available(void)</div><div class="ttdef"><b>Definition</b> neorv32_cfs.c:29</div></div> +<div class="ttc" id="astructneorv32__cfs__t_html"><div class="ttname"><a href="structneorv32__cfs__t.html">neorv32_cfs_t</a></div><div class="ttdef"><b>Definition</b> neorv32_cfs.h:31</div></div> +</div><!-- fragment --></div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/neorv32__cpu_8c.html b/sw/neorv32__cpu_8c.html new file mode 100644 index 0000000000..f7d5076b30 --- /dev/null +++ b/sw/neorv32__cpu_8c.html @@ -0,0 +1,413 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/lib/source/neorv32_cpu.c File Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_7d04193005ada6f9450f847f4adb6b5b.html">lib</a></li><li class="navelem"><a class="el" href="dir_0c6ac14e2254a316d41123f98feeb67b.html">source</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#func-members">Functions</a> </div> + <div class="headertitle"><div class="title">neorv32_cpu.c File Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p>CPU Core Functions HW driver source file. +<a href="#details">More...</a></p> +<div class="textblock"><code>#include &quot;<a class="el" href="neorv32_8h_source.html">neorv32.h</a>&quot;</code><br /> +</div><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="func-members" name="func-members"></a> +Functions</h2></td></tr> +<tr class="memitem:ac3fd7dc7cd1e0a08225c41820af27f92" id="r_ac3fd7dc7cd1e0a08225c41820af27f92"><td class="memItemLeft" align="right" valign="top">uint64_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ac3fd7dc7cd1e0a08225c41820af27f92">neorv32_cpu_get_cycle</a> (void)</td></tr> +<tr class="separator:ac3fd7dc7cd1e0a08225c41820af27f92"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a232d0290c459dc790d989fcdc4d121bf" id="r_a232d0290c459dc790d989fcdc4d121bf"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a232d0290c459dc790d989fcdc4d121bf">neorv32_cpu_set_mcycle</a> (uint64_t value)</td></tr> +<tr class="separator:a232d0290c459dc790d989fcdc4d121bf"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a387aa304770b05594c4acca128a60a75" id="r_a387aa304770b05594c4acca128a60a75"><td class="memItemLeft" align="right" valign="top">uint64_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a387aa304770b05594c4acca128a60a75">neorv32_cpu_get_instret</a> (void)</td></tr> +<tr class="separator:a387aa304770b05594c4acca128a60a75"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a5c3cf52498abb3cf3c14a724b287ecf0" id="r_a5c3cf52498abb3cf3c14a724b287ecf0"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a5c3cf52498abb3cf3c14a724b287ecf0">neorv32_cpu_set_minstret</a> (uint64_t value)</td></tr> +<tr class="separator:a5c3cf52498abb3cf3c14a724b287ecf0"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aa9027535b13d9f9325e734997fc4a137" id="r_aa9027535b13d9f9325e734997fc4a137"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aa9027535b13d9f9325e734997fc4a137">neorv32_cpu_delay_ms</a> (uint32_t time_ms)</td></tr> +<tr class="separator:aa9027535b13d9f9325e734997fc4a137"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a8346fb926f84f3d7bccbb4741105505f" id="r_a8346fb926f84f3d7bccbb4741105505f"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a8346fb926f84f3d7bccbb4741105505f">neorv32_cpu_get_clk_from_prsc</a> (int prsc)</td></tr> +<tr class="separator:a8346fb926f84f3d7bccbb4741105505f"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a27dd614bc270dfa30ed73323ebda2d2d" id="r_a27dd614bc270dfa30ed73323ebda2d2d"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a27dd614bc270dfa30ed73323ebda2d2d">neorv32_cpu_pmp_get_num_regions</a> (void)</td></tr> +<tr class="separator:a27dd614bc270dfa30ed73323ebda2d2d"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ad4f8160f4821b6691e9682ef60c7cd7b" id="r_ad4f8160f4821b6691e9682ef60c7cd7b"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ad4f8160f4821b6691e9682ef60c7cd7b">neorv32_cpu_pmp_get_granularity</a> (void)</td></tr> +<tr class="separator:ad4f8160f4821b6691e9682ef60c7cd7b"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aa458a700619b2f7666cfcffe02ec2e2c" id="r_aa458a700619b2f7666cfcffe02ec2e2c"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aa458a700619b2f7666cfcffe02ec2e2c">neorv32_cpu_pmp_configure_region</a> (int index, uint32_t addr, uint8_t config)</td></tr> +<tr class="separator:aa458a700619b2f7666cfcffe02ec2e2c"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a70f49b80322aa457f29f7671f94a183d" id="r_a70f49b80322aa457f29f7671f94a183d"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a70f49b80322aa457f29f7671f94a183d">neorv32_cpu_hpm_get_num_counters</a> (void)</td></tr> +<tr class="separator:a70f49b80322aa457f29f7671f94a183d"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:adb3ae542bbb0ddf9f562a4e42bc24d10" id="r_adb3ae542bbb0ddf9f562a4e42bc24d10"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#adb3ae542bbb0ddf9f562a4e42bc24d10">neorv32_cpu_hpm_get_size</a> (void)</td></tr> +<tr class="separator:adb3ae542bbb0ddf9f562a4e42bc24d10"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aca49efb45d3808ad76cf65ba291f546d" id="r_aca49efb45d3808ad76cf65ba291f546d"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aca49efb45d3808ad76cf65ba291f546d">neorv32_cpu_goto_user_mode</a> (void)</td></tr> +<tr class="separator:aca49efb45d3808ad76cf65ba291f546d"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>CPU Core Functions HW driver source file. </p> +<dl class="section see"><dt>See also</dt><dd><a href="https://stnolting.github.io/neorv32/sw/files.html">https://stnolting.github.io/neorv32/sw/files.html</a> </dd></dl> +</div><h2 class="groupheader">Function Documentation</h2> +<a id="aa9027535b13d9f9325e734997fc4a137" name="aa9027535b13d9f9325e734997fc4a137"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aa9027535b13d9f9325e734997fc4a137">&#9670;&#160;</a></span>neorv32_cpu_delay_ms()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_cpu_delay_ms </td> + <td>(</td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>time_ms</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Delay function using busy wait.</p> +<dl class="section note"><dt>Note</dt><dd>This function uses the cycle CPU counter if available. Otherwise the MTIME system timer is used if available. A simple loop is used as alternative fall-back (imprecise!).</dd></dl> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">time_ms</td><td>Time in ms to wait (unsigned 32-bit). </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="a8346fb926f84f3d7bccbb4741105505f" name="a8346fb926f84f3d7bccbb4741105505f"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a8346fb926f84f3d7bccbb4741105505f">&#9670;&#160;</a></span>neorv32_cpu_get_clk_from_prsc()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_cpu_get_clk_from_prsc </td> + <td>(</td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>prsc</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Get actual clocking frequency from prescaler select <a class="el" href="neorv32_8h.html#a10022df4c223533b04d5aebe222e8b73">NEORV32_CLOCK_PRSC_enum</a></p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">prsc</td><td>Prescaler select <a class="el" href="neorv32_8h.html#a10022df4c223533b04d5aebe222e8b73">NEORV32_CLOCK_PRSC_enum</a>. return Actual <em>raw</em> clock frequency in Hz. </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="ac3fd7dc7cd1e0a08225c41820af27f92" name="ac3fd7dc7cd1e0a08225c41820af27f92"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ac3fd7dc7cd1e0a08225c41820af27f92">&#9670;&#160;</a></span>neorv32_cpu_get_cycle()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint64_t neorv32_cpu_get_cycle </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Unavailable extensions warnings. Get cycle counter from cycle[h].</p> +<dl class="section return"><dt>Returns</dt><dd>Current cycle counter (64 bit). </dd></dl> + +</div> +</div> +<a id="a387aa304770b05594c4acca128a60a75" name="a387aa304770b05594c4acca128a60a75"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a387aa304770b05594c4acca128a60a75">&#9670;&#160;</a></span>neorv32_cpu_get_instret()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint64_t neorv32_cpu_get_instret </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Get retired instructions counter from instret[h].</p> +<dl class="section return"><dt>Returns</dt><dd>Current instructions counter (64 bit). </dd></dl> + +</div> +</div> +<a id="aca49efb45d3808ad76cf65ba291f546d" name="aca49efb45d3808ad76cf65ba291f546d"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aca49efb45d3808ad76cf65ba291f546d">&#9670;&#160;</a></span>neorv32_cpu_goto_user_mode()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_cpu_goto_user_mode </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Switch from privilege mode MACHINE to privilege mode USER. </p> + +</div> +</div> +<a id="a70f49b80322aa457f29f7671f94a183d" name="a70f49b80322aa457f29f7671f94a183d"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a70f49b80322aa457f29f7671f94a183d">&#9670;&#160;</a></span>neorv32_cpu_hpm_get_num_counters()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_cpu_hpm_get_num_counters </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Hardware performance monitors (HPM): Get number of available HPM counters.</p> +<dl class="section return"><dt>Returns</dt><dd>Returns number of available HPM counters. </dd></dl> + +</div> +</div> +<a id="adb3ae542bbb0ddf9f562a4e42bc24d10" name="adb3ae542bbb0ddf9f562a4e42bc24d10"></a> +<h2 class="memtitle"><span class="permalink"><a href="#adb3ae542bbb0ddf9f562a4e42bc24d10">&#9670;&#160;</a></span>neorv32_cpu_hpm_get_size()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_cpu_hpm_get_size </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Hardware performance monitors (HPM): Get total counter width</p> +<dl class="section warning"><dt>Warning</dt><dd>This function overrides the mhpmcounter3[h] CSRs.</dd></dl> +<dl class="section return"><dt>Returns</dt><dd>Size of HPM counters (1-64, 0 if not implemented at all). </dd></dl> + +</div> +</div> +<a id="aa458a700619b2f7666cfcffe02ec2e2c" name="aa458a700619b2f7666cfcffe02ec2e2c"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aa458a700619b2f7666cfcffe02ec2e2c">&#9670;&#160;</a></span>neorv32_cpu_pmp_configure_region()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_cpu_pmp_configure_region </td> + <td>(</td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>index</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>addr</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">uint8_t</td> <td class="paramname"><span class="paramname"><em>config</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Physical memory protection (PMP): Configure region.</p> +<dl class="section note"><dt>Note</dt><dd>This function requires the PMP CPU extension.</dd></dl> +<dl class="section warning"><dt>Warning</dt><dd>This function expects a WORD address!</dd></dl> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">index</td><td>Region number (index, 0..PMP_NUM_REGIONS-1). </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">addr</td><td>Region address (word address!). </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">config</td><td>Region configuration byte (see <a class="el" href="neorv32__cpu__csr_8h.html#abc0e8daad1e9beda4d9950452cc930ea">NEORV32_PMPCFG_ATTRIBUTES_enum</a>). </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Returns 0 on success, !=0 on failure. </dd></dl> + +</div> +</div> +<a id="ad4f8160f4821b6691e9682ef60c7cd7b" name="ad4f8160f4821b6691e9682ef60c7cd7b"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ad4f8160f4821b6691e9682ef60c7cd7b">&#9670;&#160;</a></span>neorv32_cpu_pmp_get_granularity()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_cpu_pmp_get_granularity </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Physical memory protection (PMP): Get minimal region size (granularity).</p> +<dl class="section warning"><dt>Warning</dt><dd>This function overrides PMPCFG0[0] and PMPADDR0 CSRs! </dd></dl> +<dl class="section note"><dt>Note</dt><dd>This function requires the PMP CPU extension.</dd></dl> +<dl class="section return"><dt>Returns</dt><dd>Returns minimal region size in bytes. Returns zero on error. </dd></dl> + +</div> +</div> +<a id="a27dd614bc270dfa30ed73323ebda2d2d" name="a27dd614bc270dfa30ed73323ebda2d2d"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a27dd614bc270dfa30ed73323ebda2d2d">&#9670;&#160;</a></span>neorv32_cpu_pmp_get_num_regions()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_cpu_pmp_get_num_regions </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Physical memory protection (PMP): Get number of available regions.</p> +<dl class="section warning"><dt>Warning</dt><dd>This function overrides all available PMPCFG* CSRs! </dd></dl> +<dl class="section note"><dt>Note</dt><dd>This function requires the PMP CPU extension.</dd></dl> +<dl class="section return"><dt>Returns</dt><dd>Returns number of available PMP regions. </dd></dl> + +</div> +</div> +<a id="a232d0290c459dc790d989fcdc4d121bf" name="a232d0290c459dc790d989fcdc4d121bf"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a232d0290c459dc790d989fcdc4d121bf">&#9670;&#160;</a></span>neorv32_cpu_set_mcycle()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_cpu_set_mcycle </td> + <td>(</td> + <td class="paramtype">uint64_t</td> <td class="paramname"><span class="paramname"><em>value</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Set machine cycle counter mcycle[h].</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">value</td><td>New value for mcycle[h] CSR (64-bit). </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="a5c3cf52498abb3cf3c14a724b287ecf0" name="a5c3cf52498abb3cf3c14a724b287ecf0"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a5c3cf52498abb3cf3c14a724b287ecf0">&#9670;&#160;</a></span>neorv32_cpu_set_minstret()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_cpu_set_minstret </td> + <td>(</td> + <td class="paramtype">uint64_t</td> <td class="paramname"><span class="paramname"><em>value</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Set machine retired instructions counter minstret[h].</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">value</td><td>New value for mcycle[h] CSR (64-bit). </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/neorv32__cpu_8h.html b/sw/neorv32__cpu_8h.html new file mode 100644 index 0000000000..796700f1dc --- /dev/null +++ b/sw/neorv32__cpu_8h.html @@ -0,0 +1,894 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/lib/include/neorv32_cpu.h File Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_7d04193005ada6f9450f847f4adb6b5b.html">lib</a></li><li class="navelem"><a class="el" href="dir_752b1e5d3973bf735fa78bf6b4727df9.html">include</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#func-members">Functions</a> </div> + <div class="headertitle"><div class="title">neorv32_cpu.h File Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p>CPU Core Functions HW driver header file. +<a href="#details">More...</a></p> +<div class="textblock"><code>#include &lt;stdint.h&gt;</code><br /> +</div> +<p><a href="neorv32__cpu_8h_source.html">Go to the source code of this file.</a></p> +<table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="func-members" name="func-members"></a> +Functions</h2></td></tr> +<tr class="memitem:a173bb06b4ae9c8964469068dafcb7b0e" id="r_a173bb06b4ae9c8964469068dafcb7b0e"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a173bb06b4ae9c8964469068dafcb7b0e">neorv32_cpu_store_unsigned_word</a> (uint32_t addr, uint32_t wdata)</td></tr> +<tr class="separator:a173bb06b4ae9c8964469068dafcb7b0e"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a31f30f6d6542758cd3073a9939b07653" id="r_a31f30f6d6542758cd3073a9939b07653"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a31f30f6d6542758cd3073a9939b07653">neorv32_cpu_store_unsigned_half</a> (uint32_t addr, uint16_t wdata)</td></tr> +<tr class="separator:a31f30f6d6542758cd3073a9939b07653"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aeec8ad2a82885c40a307346f9003483e" id="r_aeec8ad2a82885c40a307346f9003483e"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aeec8ad2a82885c40a307346f9003483e">neorv32_cpu_store_unsigned_byte</a> (uint32_t addr, uint8_t wdata)</td></tr> +<tr class="separator:aeec8ad2a82885c40a307346f9003483e"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a3b6cf445e2136486564ef3d3473c91dd" id="r_a3b6cf445e2136486564ef3d3473c91dd"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a3b6cf445e2136486564ef3d3473c91dd">neorv32_cpu_load_unsigned_word</a> (uint32_t addr)</td></tr> +<tr class="separator:a3b6cf445e2136486564ef3d3473c91dd"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a32544cd652debb4affb308806a115d5b" id="r_a32544cd652debb4affb308806a115d5b"><td class="memItemLeft" align="right" valign="top">uint16_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a32544cd652debb4affb308806a115d5b">neorv32_cpu_load_unsigned_half</a> (uint32_t addr)</td></tr> +<tr class="separator:a32544cd652debb4affb308806a115d5b"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ae9c8b6c681536ddea3aff0e63f30ef70" id="r_ae9c8b6c681536ddea3aff0e63f30ef70"><td class="memItemLeft" align="right" valign="top">int16_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ae9c8b6c681536ddea3aff0e63f30ef70">neorv32_cpu_load_signed_half</a> (uint32_t addr)</td></tr> +<tr class="separator:ae9c8b6c681536ddea3aff0e63f30ef70"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ac54ec9b59e17c7cd9b9907abee82ce95" id="r_ac54ec9b59e17c7cd9b9907abee82ce95"><td class="memItemLeft" align="right" valign="top">uint8_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ac54ec9b59e17c7cd9b9907abee82ce95">neorv32_cpu_load_unsigned_byte</a> (uint32_t addr)</td></tr> +<tr class="separator:ac54ec9b59e17c7cd9b9907abee82ce95"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a31f903596ab1bcddea79fdf608eaa666" id="r_a31f903596ab1bcddea79fdf608eaa666"><td class="memItemLeft" align="right" valign="top">int8_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a31f903596ab1bcddea79fdf608eaa666">neorv32_cpu_load_signed_byte</a> (uint32_t addr)</td></tr> +<tr class="separator:a31f903596ab1bcddea79fdf608eaa666"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aab7a9f9cf608599f2b124dd499cb8418" id="r_aab7a9f9cf608599f2b124dd499cb8418"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aab7a9f9cf608599f2b124dd499cb8418">neorv32_cpu_csr_read</a> (const int csr_id)</td></tr> +<tr class="separator:aab7a9f9cf608599f2b124dd499cb8418"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:afb5ef6e0b1a3e26570edfd8379490455" id="r_afb5ef6e0b1a3e26570edfd8379490455"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#afb5ef6e0b1a3e26570edfd8379490455">neorv32_cpu_csr_write</a> (const int csr_id, uint32_t data)</td></tr> +<tr class="separator:afb5ef6e0b1a3e26570edfd8379490455"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a25a09de97229aac839ef6f74da604acf" id="r_a25a09de97229aac839ef6f74da604acf"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a25a09de97229aac839ef6f74da604acf">neorv32_cpu_csr_set</a> (const int csr_id, uint32_t mask)</td></tr> +<tr class="separator:a25a09de97229aac839ef6f74da604acf"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ab8f533ddbc3a3af5e3bca2287ac10122" id="r_ab8f533ddbc3a3af5e3bca2287ac10122"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ab8f533ddbc3a3af5e3bca2287ac10122">neorv32_cpu_csr_clr</a> (const int csr_id, uint32_t mask)</td></tr> +<tr class="separator:ab8f533ddbc3a3af5e3bca2287ac10122"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a769ca4556213619f6fea4ff6bfb979dd" id="r_a769ca4556213619f6fea4ff6bfb979dd"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a769ca4556213619f6fea4ff6bfb979dd">neorv32_cpu_sleep</a> (void)</td></tr> +<tr class="separator:a769ca4556213619f6fea4ff6bfb979dd"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr><td colspan="2"><div class="groupHeader">Prototypes</div></td></tr> +<tr class="memitem:ac3fd7dc7cd1e0a08225c41820af27f92" id="r_ac3fd7dc7cd1e0a08225c41820af27f92"><td class="memItemLeft" align="right" valign="top">uint64_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ac3fd7dc7cd1e0a08225c41820af27f92">neorv32_cpu_get_cycle</a> (void)</td></tr> +<tr class="separator:ac3fd7dc7cd1e0a08225c41820af27f92"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a232d0290c459dc790d989fcdc4d121bf" id="r_a232d0290c459dc790d989fcdc4d121bf"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a232d0290c459dc790d989fcdc4d121bf">neorv32_cpu_set_mcycle</a> (uint64_t value)</td></tr> +<tr class="separator:a232d0290c459dc790d989fcdc4d121bf"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a387aa304770b05594c4acca128a60a75" id="r_a387aa304770b05594c4acca128a60a75"><td class="memItemLeft" align="right" valign="top">uint64_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a387aa304770b05594c4acca128a60a75">neorv32_cpu_get_instret</a> (void)</td></tr> +<tr class="separator:a387aa304770b05594c4acca128a60a75"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a5c3cf52498abb3cf3c14a724b287ecf0" id="r_a5c3cf52498abb3cf3c14a724b287ecf0"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a5c3cf52498abb3cf3c14a724b287ecf0">neorv32_cpu_set_minstret</a> (uint64_t value)</td></tr> +<tr class="separator:a5c3cf52498abb3cf3c14a724b287ecf0"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aa9027535b13d9f9325e734997fc4a137" id="r_aa9027535b13d9f9325e734997fc4a137"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aa9027535b13d9f9325e734997fc4a137">neorv32_cpu_delay_ms</a> (uint32_t time_ms)</td></tr> +<tr class="separator:aa9027535b13d9f9325e734997fc4a137"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a8346fb926f84f3d7bccbb4741105505f" id="r_a8346fb926f84f3d7bccbb4741105505f"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a8346fb926f84f3d7bccbb4741105505f">neorv32_cpu_get_clk_from_prsc</a> (int prsc)</td></tr> +<tr class="separator:a8346fb926f84f3d7bccbb4741105505f"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a27dd614bc270dfa30ed73323ebda2d2d" id="r_a27dd614bc270dfa30ed73323ebda2d2d"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a27dd614bc270dfa30ed73323ebda2d2d">neorv32_cpu_pmp_get_num_regions</a> (void)</td></tr> +<tr class="separator:a27dd614bc270dfa30ed73323ebda2d2d"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ad4f8160f4821b6691e9682ef60c7cd7b" id="r_ad4f8160f4821b6691e9682ef60c7cd7b"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ad4f8160f4821b6691e9682ef60c7cd7b">neorv32_cpu_pmp_get_granularity</a> (void)</td></tr> +<tr class="separator:ad4f8160f4821b6691e9682ef60c7cd7b"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aa458a700619b2f7666cfcffe02ec2e2c" id="r_aa458a700619b2f7666cfcffe02ec2e2c"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aa458a700619b2f7666cfcffe02ec2e2c">neorv32_cpu_pmp_configure_region</a> (int index, uint32_t addr, uint8_t config)</td></tr> +<tr class="separator:aa458a700619b2f7666cfcffe02ec2e2c"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a70f49b80322aa457f29f7671f94a183d" id="r_a70f49b80322aa457f29f7671f94a183d"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a70f49b80322aa457f29f7671f94a183d">neorv32_cpu_hpm_get_num_counters</a> (void)</td></tr> +<tr class="separator:a70f49b80322aa457f29f7671f94a183d"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:adb3ae542bbb0ddf9f562a4e42bc24d10" id="r_adb3ae542bbb0ddf9f562a4e42bc24d10"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#adb3ae542bbb0ddf9f562a4e42bc24d10">neorv32_cpu_hpm_get_size</a> (void)</td></tr> +<tr class="separator:adb3ae542bbb0ddf9f562a4e42bc24d10"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aca49efb45d3808ad76cf65ba291f546d" id="r_aca49efb45d3808ad76cf65ba291f546d"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aca49efb45d3808ad76cf65ba291f546d">neorv32_cpu_goto_user_mode</a> (void)</td></tr> +<tr class="separator:aca49efb45d3808ad76cf65ba291f546d"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>CPU Core Functions HW driver header file. </p> +<dl class="section see"><dt>See also</dt><dd><a href="https://stnolting.github.io/neorv32/sw/files.html">https://stnolting.github.io/neorv32/sw/files.html</a> </dd></dl> +</div><h2 class="groupheader">Function Documentation</h2> +<a id="ab8f533ddbc3a3af5e3bca2287ac10122" name="ab8f533ddbc3a3af5e3bca2287ac10122"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ab8f533ddbc3a3af5e3bca2287ac10122">&#9670;&#160;</a></span>neorv32_cpu_csr_clr()</h2> + +<div class="memitem"> +<div class="memproto"> +<table class="mlabels"> + <tr> + <td class="mlabels-left"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_cpu_csr_clr </td> + <td>(</td> + <td class="paramtype">const int</td> <td class="paramname"><span class="paramname"><em>csr_id</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>mask</em></span>&#160;)</td> + </tr> + </table> + </td> + <td class="mlabels-right"> +<span class="mlabels"><span class="mlabel">inline</span></span> </td> + </tr> +</table> +</div><div class="memdoc"> +<p>Clear bit(s) in CPU control and status register (CSR).</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">csr_id</td><td>ID of CSR to write. See <a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49">NEORV32_CSR_enum</a>. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">mask</td><td>Bit mask (high-active) to clear bits (uint32_t). </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="aab7a9f9cf608599f2b124dd499cb8418" name="aab7a9f9cf608599f2b124dd499cb8418"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aab7a9f9cf608599f2b124dd499cb8418">&#9670;&#160;</a></span>neorv32_cpu_csr_read()</h2> + +<div class="memitem"> +<div class="memproto"> +<table class="mlabels"> + <tr> + <td class="mlabels-left"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_cpu_csr_read </td> + <td>(</td> + <td class="paramtype">const int</td> <td class="paramname"><span class="paramname"><em>csr_id</em></span></td><td>)</td> + <td></td> + </tr> + </table> + </td> + <td class="mlabels-right"> +<span class="mlabels"><span class="mlabel">inline</span></span> </td> + </tr> +</table> +</div><div class="memdoc"> +<p>Read data from CPU control and status register (CSR).</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">csr_id</td><td>ID of CSR to read. See <a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49">NEORV32_CSR_enum</a>. </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Read data (uint32_t). </dd></dl> + +</div> +</div> +<a id="a25a09de97229aac839ef6f74da604acf" name="a25a09de97229aac839ef6f74da604acf"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a25a09de97229aac839ef6f74da604acf">&#9670;&#160;</a></span>neorv32_cpu_csr_set()</h2> + +<div class="memitem"> +<div class="memproto"> +<table class="mlabels"> + <tr> + <td class="mlabels-left"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_cpu_csr_set </td> + <td>(</td> + <td class="paramtype">const int</td> <td class="paramname"><span class="paramname"><em>csr_id</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>mask</em></span>&#160;)</td> + </tr> + </table> + </td> + <td class="mlabels-right"> +<span class="mlabels"><span class="mlabel">inline</span></span> </td> + </tr> +</table> +</div><div class="memdoc"> +<p>Set bit(s) in CPU control and status register (CSR).</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">csr_id</td><td>ID of CSR to write. See <a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49">NEORV32_CSR_enum</a>. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">mask</td><td>Bit mask (high-active) to set bits (uint32_t). </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="afb5ef6e0b1a3e26570edfd8379490455" name="afb5ef6e0b1a3e26570edfd8379490455"></a> +<h2 class="memtitle"><span class="permalink"><a href="#afb5ef6e0b1a3e26570edfd8379490455">&#9670;&#160;</a></span>neorv32_cpu_csr_write()</h2> + +<div class="memitem"> +<div class="memproto"> +<table class="mlabels"> + <tr> + <td class="mlabels-left"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_cpu_csr_write </td> + <td>(</td> + <td class="paramtype">const int</td> <td class="paramname"><span class="paramname"><em>csr_id</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>data</em></span>&#160;)</td> + </tr> + </table> + </td> + <td class="mlabels-right"> +<span class="mlabels"><span class="mlabel">inline</span></span> </td> + </tr> +</table> +</div><div class="memdoc"> +<p>Write data to CPU control and status register (CSR).</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">csr_id</td><td>ID of CSR to write. See <a class="el" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49">NEORV32_CSR_enum</a>. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">data</td><td>Data to write (uint32_t). </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="aa9027535b13d9f9325e734997fc4a137" name="aa9027535b13d9f9325e734997fc4a137"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aa9027535b13d9f9325e734997fc4a137">&#9670;&#160;</a></span>neorv32_cpu_delay_ms()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_cpu_delay_ms </td> + <td>(</td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>time_ms</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Delay function using busy wait.</p> +<dl class="section note"><dt>Note</dt><dd>This function uses the cycle CPU counter if available. Otherwise the MTIME system timer is used if available. A simple loop is used as alternative fall-back (imprecise!).</dd></dl> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">time_ms</td><td>Time in ms to wait (unsigned 32-bit). </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="a8346fb926f84f3d7bccbb4741105505f" name="a8346fb926f84f3d7bccbb4741105505f"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a8346fb926f84f3d7bccbb4741105505f">&#9670;&#160;</a></span>neorv32_cpu_get_clk_from_prsc()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_cpu_get_clk_from_prsc </td> + <td>(</td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>prsc</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Get actual clocking frequency from prescaler select <a class="el" href="neorv32_8h.html#a10022df4c223533b04d5aebe222e8b73">NEORV32_CLOCK_PRSC_enum</a></p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">prsc</td><td>Prescaler select <a class="el" href="neorv32_8h.html#a10022df4c223533b04d5aebe222e8b73">NEORV32_CLOCK_PRSC_enum</a>. return Actual <em>raw</em> clock frequency in Hz. </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="ac3fd7dc7cd1e0a08225c41820af27f92" name="ac3fd7dc7cd1e0a08225c41820af27f92"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ac3fd7dc7cd1e0a08225c41820af27f92">&#9670;&#160;</a></span>neorv32_cpu_get_cycle()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint64_t neorv32_cpu_get_cycle </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Unavailable extensions warnings. Get cycle counter from cycle[h].</p> +<dl class="section return"><dt>Returns</dt><dd>Current cycle counter (64 bit). </dd></dl> + +</div> +</div> +<a id="a387aa304770b05594c4acca128a60a75" name="a387aa304770b05594c4acca128a60a75"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a387aa304770b05594c4acca128a60a75">&#9670;&#160;</a></span>neorv32_cpu_get_instret()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint64_t neorv32_cpu_get_instret </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Get retired instructions counter from instret[h].</p> +<dl class="section return"><dt>Returns</dt><dd>Current instructions counter (64 bit). </dd></dl> + +</div> +</div> +<a id="aca49efb45d3808ad76cf65ba291f546d" name="aca49efb45d3808ad76cf65ba291f546d"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aca49efb45d3808ad76cf65ba291f546d">&#9670;&#160;</a></span>neorv32_cpu_goto_user_mode()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_cpu_goto_user_mode </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Switch from privilege mode MACHINE to privilege mode USER. </p> + +</div> +</div> +<a id="a70f49b80322aa457f29f7671f94a183d" name="a70f49b80322aa457f29f7671f94a183d"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a70f49b80322aa457f29f7671f94a183d">&#9670;&#160;</a></span>neorv32_cpu_hpm_get_num_counters()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_cpu_hpm_get_num_counters </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Hardware performance monitors (HPM): Get number of available HPM counters.</p> +<dl class="section return"><dt>Returns</dt><dd>Returns number of available HPM counters. </dd></dl> + +</div> +</div> +<a id="adb3ae542bbb0ddf9f562a4e42bc24d10" name="adb3ae542bbb0ddf9f562a4e42bc24d10"></a> +<h2 class="memtitle"><span class="permalink"><a href="#adb3ae542bbb0ddf9f562a4e42bc24d10">&#9670;&#160;</a></span>neorv32_cpu_hpm_get_size()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_cpu_hpm_get_size </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Hardware performance monitors (HPM): Get total counter width</p> +<dl class="section warning"><dt>Warning</dt><dd>This function overrides the mhpmcounter3[h] CSRs.</dd></dl> +<dl class="section return"><dt>Returns</dt><dd>Size of HPM counters (1-64, 0 if not implemented at all). </dd></dl> + +</div> +</div> +<a id="a31f903596ab1bcddea79fdf608eaa666" name="a31f903596ab1bcddea79fdf608eaa666"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a31f903596ab1bcddea79fdf608eaa666">&#9670;&#160;</a></span>neorv32_cpu_load_signed_byte()</h2> + +<div class="memitem"> +<div class="memproto"> +<table class="mlabels"> + <tr> + <td class="mlabels-left"> + <table class="memname"> + <tr> + <td class="memname">int8_t neorv32_cpu_load_signed_byte </td> + <td>(</td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>addr</em></span></td><td>)</td> + <td></td> + </tr> + </table> + </td> + <td class="mlabels-right"> +<span class="mlabels"><span class="mlabel">inline</span></span> </td> + </tr> +</table> +</div><div class="memdoc"> +<p>Load signed byte from address space.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">addr</td><td>Address (32-bit). </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Read data byte (8-bit). </dd></dl> + +</div> +</div> +<a id="ae9c8b6c681536ddea3aff0e63f30ef70" name="ae9c8b6c681536ddea3aff0e63f30ef70"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ae9c8b6c681536ddea3aff0e63f30ef70">&#9670;&#160;</a></span>neorv32_cpu_load_signed_half()</h2> + +<div class="memitem"> +<div class="memproto"> +<table class="mlabels"> + <tr> + <td class="mlabels-left"> + <table class="memname"> + <tr> + <td class="memname">int16_t neorv32_cpu_load_signed_half </td> + <td>(</td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>addr</em></span></td><td>)</td> + <td></td> + </tr> + </table> + </td> + <td class="mlabels-right"> +<span class="mlabels"><span class="mlabel">inline</span></span> </td> + </tr> +</table> +</div><div class="memdoc"> +<p>Load signed half-word from address space.</p> +<dl class="section note"><dt>Note</dt><dd>An unaligned access address will raise an alignment exception.</dd></dl> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">addr</td><td>Address (32-bit). </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Read data half-word (16-bit). </dd></dl> + +</div> +</div> +<a id="ac54ec9b59e17c7cd9b9907abee82ce95" name="ac54ec9b59e17c7cd9b9907abee82ce95"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ac54ec9b59e17c7cd9b9907abee82ce95">&#9670;&#160;</a></span>neorv32_cpu_load_unsigned_byte()</h2> + +<div class="memitem"> +<div class="memproto"> +<table class="mlabels"> + <tr> + <td class="mlabels-left"> + <table class="memname"> + <tr> + <td class="memname">uint8_t neorv32_cpu_load_unsigned_byte </td> + <td>(</td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>addr</em></span></td><td>)</td> + <td></td> + </tr> + </table> + </td> + <td class="mlabels-right"> +<span class="mlabels"><span class="mlabel">inline</span></span> </td> + </tr> +</table> +</div><div class="memdoc"> +<p>Load unsigned byte from address space.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">addr</td><td>Address (32-bit). </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Read data byte (8-bit). </dd></dl> + +</div> +</div> +<a id="a32544cd652debb4affb308806a115d5b" name="a32544cd652debb4affb308806a115d5b"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a32544cd652debb4affb308806a115d5b">&#9670;&#160;</a></span>neorv32_cpu_load_unsigned_half()</h2> + +<div class="memitem"> +<div class="memproto"> +<table class="mlabels"> + <tr> + <td class="mlabels-left"> + <table class="memname"> + <tr> + <td class="memname">uint16_t neorv32_cpu_load_unsigned_half </td> + <td>(</td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>addr</em></span></td><td>)</td> + <td></td> + </tr> + </table> + </td> + <td class="mlabels-right"> +<span class="mlabels"><span class="mlabel">inline</span></span> </td> + </tr> +</table> +</div><div class="memdoc"> +<p>Load unsigned half-word from address space.</p> +<dl class="section note"><dt>Note</dt><dd>An unaligned access address will raise an alignment exception.</dd></dl> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">addr</td><td>Address (32-bit). </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Read data half-word (16-bit). </dd></dl> + +</div> +</div> +<a id="a3b6cf445e2136486564ef3d3473c91dd" name="a3b6cf445e2136486564ef3d3473c91dd"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a3b6cf445e2136486564ef3d3473c91dd">&#9670;&#160;</a></span>neorv32_cpu_load_unsigned_word()</h2> + +<div class="memitem"> +<div class="memproto"> +<table class="mlabels"> + <tr> + <td class="mlabels-left"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_cpu_load_unsigned_word </td> + <td>(</td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>addr</em></span></td><td>)</td> + <td></td> + </tr> + </table> + </td> + <td class="mlabels-right"> +<span class="mlabels"><span class="mlabel">inline</span></span> </td> + </tr> +</table> +</div><div class="memdoc"> +<p>Load unsigned word from address space.</p> +<dl class="section note"><dt>Note</dt><dd>An unaligned access address will raise an alignment exception.</dd></dl> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">addr</td><td>Address (32-bit). </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Read data word (32-bit). </dd></dl> + +</div> +</div> +<a id="aa458a700619b2f7666cfcffe02ec2e2c" name="aa458a700619b2f7666cfcffe02ec2e2c"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aa458a700619b2f7666cfcffe02ec2e2c">&#9670;&#160;</a></span>neorv32_cpu_pmp_configure_region()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_cpu_pmp_configure_region </td> + <td>(</td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>index</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>addr</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">uint8_t</td> <td class="paramname"><span class="paramname"><em>config</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Physical memory protection (PMP): Configure region.</p> +<dl class="section note"><dt>Note</dt><dd>This function requires the PMP CPU extension.</dd></dl> +<dl class="section warning"><dt>Warning</dt><dd>This function expects a WORD address!</dd></dl> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">index</td><td>Region number (index, 0..PMP_NUM_REGIONS-1). </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">addr</td><td>Region address (word address!). </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">config</td><td>Region configuration byte (see <a class="el" href="neorv32__cpu__csr_8h.html#abc0e8daad1e9beda4d9950452cc930ea">NEORV32_PMPCFG_ATTRIBUTES_enum</a>). </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Returns 0 on success, !=0 on failure. </dd></dl> + +</div> +</div> +<a id="ad4f8160f4821b6691e9682ef60c7cd7b" name="ad4f8160f4821b6691e9682ef60c7cd7b"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ad4f8160f4821b6691e9682ef60c7cd7b">&#9670;&#160;</a></span>neorv32_cpu_pmp_get_granularity()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_cpu_pmp_get_granularity </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Physical memory protection (PMP): Get minimal region size (granularity).</p> +<dl class="section warning"><dt>Warning</dt><dd>This function overrides PMPCFG0[0] and PMPADDR0 CSRs! </dd></dl> +<dl class="section note"><dt>Note</dt><dd>This function requires the PMP CPU extension.</dd></dl> +<dl class="section return"><dt>Returns</dt><dd>Returns minimal region size in bytes. Returns zero on error. </dd></dl> + +</div> +</div> +<a id="a27dd614bc270dfa30ed73323ebda2d2d" name="a27dd614bc270dfa30ed73323ebda2d2d"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a27dd614bc270dfa30ed73323ebda2d2d">&#9670;&#160;</a></span>neorv32_cpu_pmp_get_num_regions()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_cpu_pmp_get_num_regions </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Physical memory protection (PMP): Get number of available regions.</p> +<dl class="section warning"><dt>Warning</dt><dd>This function overrides all available PMPCFG* CSRs! </dd></dl> +<dl class="section note"><dt>Note</dt><dd>This function requires the PMP CPU extension.</dd></dl> +<dl class="section return"><dt>Returns</dt><dd>Returns number of available PMP regions. </dd></dl> + +</div> +</div> +<a id="a232d0290c459dc790d989fcdc4d121bf" name="a232d0290c459dc790d989fcdc4d121bf"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a232d0290c459dc790d989fcdc4d121bf">&#9670;&#160;</a></span>neorv32_cpu_set_mcycle()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_cpu_set_mcycle </td> + <td>(</td> + <td class="paramtype">uint64_t</td> <td class="paramname"><span class="paramname"><em>value</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Set machine cycle counter mcycle[h].</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">value</td><td>New value for mcycle[h] CSR (64-bit). </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="a5c3cf52498abb3cf3c14a724b287ecf0" name="a5c3cf52498abb3cf3c14a724b287ecf0"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a5c3cf52498abb3cf3c14a724b287ecf0">&#9670;&#160;</a></span>neorv32_cpu_set_minstret()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_cpu_set_minstret </td> + <td>(</td> + <td class="paramtype">uint64_t</td> <td class="paramname"><span class="paramname"><em>value</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Set machine retired instructions counter minstret[h].</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">value</td><td>New value for mcycle[h] CSR (64-bit). </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="a769ca4556213619f6fea4ff6bfb979dd" name="a769ca4556213619f6fea4ff6bfb979dd"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a769ca4556213619f6fea4ff6bfb979dd">&#9670;&#160;</a></span>neorv32_cpu_sleep()</h2> + +<div class="memitem"> +<div class="memproto"> +<table class="mlabels"> + <tr> + <td class="mlabels-left"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_cpu_sleep </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> + </td> + <td class="mlabels-right"> +<span class="mlabels"><span class="mlabel">inline</span></span> </td> + </tr> +</table> +</div><div class="memdoc"> +<p>Put CPU into sleep / power-down mode.</p> +<dl class="section note"><dt>Note</dt><dd>The WFI (wait for interrupt) instruction will make the CPU halt until any enabled interrupt source becomes pending. </dd></dl> + +</div> +</div> +<a id="aeec8ad2a82885c40a307346f9003483e" name="aeec8ad2a82885c40a307346f9003483e"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aeec8ad2a82885c40a307346f9003483e">&#9670;&#160;</a></span>neorv32_cpu_store_unsigned_byte()</h2> + +<div class="memitem"> +<div class="memproto"> +<table class="mlabels"> + <tr> + <td class="mlabels-left"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_cpu_store_unsigned_byte </td> + <td>(</td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>addr</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">uint8_t</td> <td class="paramname"><span class="paramname"><em>wdata</em></span>&#160;)</td> + </tr> + </table> + </td> + <td class="mlabels-right"> +<span class="mlabels"><span class="mlabel">inline</span></span> </td> + </tr> +</table> +</div><div class="memdoc"> +<p>Store unsigned byte to address space.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">addr</td><td>Address (32-bit). </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">wdata</td><td>Data byte (8-bit) to store. </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="a31f30f6d6542758cd3073a9939b07653" name="a31f30f6d6542758cd3073a9939b07653"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a31f30f6d6542758cd3073a9939b07653">&#9670;&#160;</a></span>neorv32_cpu_store_unsigned_half()</h2> + +<div class="memitem"> +<div class="memproto"> +<table class="mlabels"> + <tr> + <td class="mlabels-left"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_cpu_store_unsigned_half </td> + <td>(</td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>addr</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">uint16_t</td> <td class="paramname"><span class="paramname"><em>wdata</em></span>&#160;)</td> + </tr> + </table> + </td> + <td class="mlabels-right"> +<span class="mlabels"><span class="mlabel">inline</span></span> </td> + </tr> +</table> +</div><div class="memdoc"> +<p>Store unsigned half-word to address space.</p> +<dl class="section note"><dt>Note</dt><dd>An unaligned access address will raise an alignment exception.</dd></dl> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">addr</td><td>Address (32-bit). </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">wdata</td><td>Data half-word (16-bit) to store. </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="a173bb06b4ae9c8964469068dafcb7b0e" name="a173bb06b4ae9c8964469068dafcb7b0e"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a173bb06b4ae9c8964469068dafcb7b0e">&#9670;&#160;</a></span>neorv32_cpu_store_unsigned_word()</h2> + +<div class="memitem"> +<div class="memproto"> +<table class="mlabels"> + <tr> + <td class="mlabels-left"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_cpu_store_unsigned_word </td> + <td>(</td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>addr</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>wdata</em></span>&#160;)</td> + </tr> + </table> + </td> + <td class="mlabels-right"> +<span class="mlabels"><span class="mlabel">inline</span></span> </td> + </tr> +</table> +</div><div class="memdoc"> +<p>Store unsigned word to address space.</p> +<dl class="section note"><dt>Note</dt><dd>An unaligned access address will raise an alignment exception.</dd></dl> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">addr</td><td>Address (32-bit). </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">wdata</td><td>Data word (32-bit) to store. </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/neorv32__cpu_8h_source.html b/sw/neorv32__cpu_8h_source.html new file mode 100644 index 0000000000..a12367c435 --- /dev/null +++ b/sw/neorv32__cpu_8h_source.html @@ -0,0 +1,299 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/lib/include/neorv32_cpu.h Source File</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_7d04193005ada6f9450f847f4adb6b5b.html">lib</a></li><li class="navelem"><a class="el" href="dir_752b1e5d3973bf735fa78bf6b4727df9.html">include</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="headertitle"><div class="title">neorv32_cpu.h</div></div> +</div><!--header--> +<div class="contents"> +<a href="neorv32__cpu_8h.html">Go to the documentation of this file.</a><div class="fragment"><div class="line"><a id="l00001" name="l00001"></a><span class="lineno"> 1</span><span class="comment">// ================================================================================ //</span></div> +<div class="line"><a id="l00002" name="l00002"></a><span class="lineno"> 2</span><span class="comment">// The NEORV32 RISC-V Processor - https://github.com/stnolting/neorv32 //</span></div> +<div class="line"><a id="l00003" name="l00003"></a><span class="lineno"> 3</span><span class="comment">// Copyright (c) NEORV32 contributors. //</span></div> +<div class="line"><a id="l00004" name="l00004"></a><span class="lineno"> 4</span><span class="comment">// Copyright (c) 2020 - 2024 Stephan Nolting. All rights reserved. //</span></div> +<div class="line"><a id="l00005" name="l00005"></a><span class="lineno"> 5</span><span class="comment">// Licensed under the BSD-3-Clause license, see LICENSE for details. //</span></div> +<div class="line"><a id="l00006" name="l00006"></a><span class="lineno"> 6</span><span class="comment">// SPDX-License-Identifier: BSD-3-Clause //</span></div> +<div class="line"><a id="l00007" name="l00007"></a><span class="lineno"> 7</span><span class="comment">// ================================================================================ //</span></div> +<div class="line"><a id="l00008" name="l00008"></a><span class="lineno"> 8</span> </div> +<div class="line"><a id="l00016" name="l00016"></a><span class="lineno"> 16</span><span class="preprocessor">#ifndef neorv32_cpu_h</span></div> +<div class="line"><a id="l00017" name="l00017"></a><span class="lineno"> 17</span><span class="preprocessor">#define neorv32_cpu_h</span></div> +<div class="line"><a id="l00018" name="l00018"></a><span class="lineno"> 18</span> </div> +<div class="line"><a id="l00019" name="l00019"></a><span class="lineno"> 19</span><span class="preprocessor">#include &lt;stdint.h&gt;</span></div> +<div class="line"><a id="l00020" name="l00020"></a><span class="lineno"> 20</span> </div> +<div class="line"><a id="l00021" name="l00021"></a><span class="lineno"> 21</span> </div> +<div class="line"><a id="l00022" name="l00022"></a><span class="lineno"> 22</span><span class="comment">/**********************************************************************/</span></div> +<div class="line"><a id="l00026" name="l00026"></a><span class="lineno"> 26</span>uint64_t <a class="code hl_function" href="neorv32__cpu_8h.html#ac3fd7dc7cd1e0a08225c41820af27f92">neorv32_cpu_get_cycle</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00027" name="l00027"></a><span class="lineno"> 27</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__cpu_8h.html#a232d0290c459dc790d989fcdc4d121bf">neorv32_cpu_set_mcycle</a>(uint64_t value);</div> +<div class="line"><a id="l00028" name="l00028"></a><span class="lineno"> 28</span>uint64_t <a class="code hl_function" href="neorv32__cpu_8h.html#a387aa304770b05594c4acca128a60a75">neorv32_cpu_get_instret</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00029" name="l00029"></a><span class="lineno"> 29</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__cpu_8h.html#a5c3cf52498abb3cf3c14a724b287ecf0">neorv32_cpu_set_minstret</a>(uint64_t value);</div> +<div class="line"><a id="l00030" name="l00030"></a><span class="lineno"> 30</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__cpu_8h.html#aa9027535b13d9f9325e734997fc4a137">neorv32_cpu_delay_ms</a>(uint32_t time_ms);</div> +<div class="line"><a id="l00031" name="l00031"></a><span class="lineno"> 31</span>uint32_t <a class="code hl_function" href="neorv32__cpu_8h.html#a8346fb926f84f3d7bccbb4741105505f">neorv32_cpu_get_clk_from_prsc</a>(<span class="keywordtype">int</span> prsc);</div> +<div class="line"><a id="l00032" name="l00032"></a><span class="lineno"> 32</span>uint32_t <a class="code hl_function" href="neorv32__cpu_8h.html#a27dd614bc270dfa30ed73323ebda2d2d">neorv32_cpu_pmp_get_num_regions</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00033" name="l00033"></a><span class="lineno"> 33</span>uint32_t <a class="code hl_function" href="neorv32__cpu_8h.html#ad4f8160f4821b6691e9682ef60c7cd7b">neorv32_cpu_pmp_get_granularity</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00034" name="l00034"></a><span class="lineno"> 34</span><span class="keywordtype">int</span> <a class="code hl_function" href="neorv32__cpu_8h.html#aa458a700619b2f7666cfcffe02ec2e2c">neorv32_cpu_pmp_configure_region</a>(<span class="keywordtype">int</span> index, uint32_t addr, uint8_t config);</div> +<div class="line"><a id="l00035" name="l00035"></a><span class="lineno"> 35</span>uint32_t <a class="code hl_function" href="neorv32__cpu_8h.html#a70f49b80322aa457f29f7671f94a183d">neorv32_cpu_hpm_get_num_counters</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00036" name="l00036"></a><span class="lineno"> 36</span>uint32_t <a class="code hl_function" href="neorv32__cpu_8h.html#adb3ae542bbb0ddf9f562a4e42bc24d10">neorv32_cpu_hpm_get_size</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00037" name="l00037"></a><span class="lineno"> 37</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__cpu_8h.html#aca49efb45d3808ad76cf65ba291f546d">neorv32_cpu_goto_user_mode</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00041" name="l00041"></a><span class="lineno"> 41</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen00049" data-start="{" data-end="}"> +<div class="line"><a id="l00049" name="l00049"></a><span class="lineno"><a class="line" href="neorv32__cpu_8h.html#a173bb06b4ae9c8964469068dafcb7b0e"> 49</a></span><span class="keyword">inline</span> <span class="keywordtype">void</span> __attribute__ ((always_inline)) <a class="code hl_function" href="neorv32__cpu_8h.html#a173bb06b4ae9c8964469068dafcb7b0e">neorv32_cpu_store_unsigned_word</a>(uint32_t addr, uint32_t wdata) {</div> +<div class="line"><a id="l00050" name="l00050"></a><span class="lineno"> 50</span> </div> +<div class="line"><a id="l00051" name="l00051"></a><span class="lineno"> 51</span> uint32_t reg_addr = addr;</div> +<div class="line"><a id="l00052" name="l00052"></a><span class="lineno"> 52</span> uint32_t reg_data = wdata;</div> +<div class="line"><a id="l00053" name="l00053"></a><span class="lineno"> 53</span> <span class="keyword">asm</span> <span class="keyword">volatile</span> (<span class="stringliteral">&quot;sw %[da], 0(%[ad])&quot;</span> : : [da] <span class="stringliteral">&quot;r&quot;</span> (reg_data), [ad] <span class="stringliteral">&quot;r&quot;</span> (reg_addr));</div> +<div class="line"><a id="l00054" name="l00054"></a><span class="lineno"> 54</span>}</div> +</div> +<div class="line"><a id="l00055" name="l00055"></a><span class="lineno"> 55</span> </div> +<div class="line"><a id="l00056" name="l00056"></a><span class="lineno"> 56</span> </div> +<div class="line"><a id="l00057" name="l00057"></a><span class="lineno"> 57</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen00065" data-start="{" data-end="}"> +<div class="line"><a id="l00065" name="l00065"></a><span class="lineno"><a class="line" href="neorv32__cpu_8h.html#a31f30f6d6542758cd3073a9939b07653"> 65</a></span><span class="keyword">inline</span> <span class="keywordtype">void</span> __attribute__ ((always_inline)) <a class="code hl_function" href="neorv32__cpu_8h.html#a31f30f6d6542758cd3073a9939b07653">neorv32_cpu_store_unsigned_half</a>(uint32_t addr, uint16_t wdata) {</div> +<div class="line"><a id="l00066" name="l00066"></a><span class="lineno"> 66</span> </div> +<div class="line"><a id="l00067" name="l00067"></a><span class="lineno"> 67</span> uint32_t reg_addr = addr;</div> +<div class="line"><a id="l00068" name="l00068"></a><span class="lineno"> 68</span> uint32_t reg_data = (uint32_t)wdata;</div> +<div class="line"><a id="l00069" name="l00069"></a><span class="lineno"> 69</span> <span class="keyword">asm</span> <span class="keyword">volatile</span> (<span class="stringliteral">&quot;sh %[da], 0(%[ad])&quot;</span> : : [da] <span class="stringliteral">&quot;r&quot;</span> (reg_data), [ad] <span class="stringliteral">&quot;r&quot;</span> (reg_addr));</div> +<div class="line"><a id="l00070" name="l00070"></a><span class="lineno"> 70</span>}</div> +</div> +<div class="line"><a id="l00071" name="l00071"></a><span class="lineno"> 71</span> </div> +<div class="line"><a id="l00072" name="l00072"></a><span class="lineno"> 72</span> </div> +<div class="line"><a id="l00073" name="l00073"></a><span class="lineno"> 73</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen00079" data-start="{" data-end="}"> +<div class="line"><a id="l00079" name="l00079"></a><span class="lineno"><a class="line" href="neorv32__cpu_8h.html#aeec8ad2a82885c40a307346f9003483e"> 79</a></span><span class="keyword">inline</span> <span class="keywordtype">void</span> __attribute__ ((always_inline)) <a class="code hl_function" href="neorv32__cpu_8h.html#aeec8ad2a82885c40a307346f9003483e">neorv32_cpu_store_unsigned_byte</a>(uint32_t addr, uint8_t wdata) {</div> +<div class="line"><a id="l00080" name="l00080"></a><span class="lineno"> 80</span> </div> +<div class="line"><a id="l00081" name="l00081"></a><span class="lineno"> 81</span> uint32_t reg_addr = addr;</div> +<div class="line"><a id="l00082" name="l00082"></a><span class="lineno"> 82</span> uint32_t reg_data = (uint32_t)wdata;</div> +<div class="line"><a id="l00083" name="l00083"></a><span class="lineno"> 83</span> <span class="keyword">asm</span> <span class="keyword">volatile</span> (<span class="stringliteral">&quot;sb %[da], 0(%[ad])&quot;</span> : : [da] <span class="stringliteral">&quot;r&quot;</span> (reg_data), [ad] <span class="stringliteral">&quot;r&quot;</span> (reg_addr));</div> +<div class="line"><a id="l00084" name="l00084"></a><span class="lineno"> 84</span>}</div> +</div> +<div class="line"><a id="l00085" name="l00085"></a><span class="lineno"> 85</span> </div> +<div class="line"><a id="l00086" name="l00086"></a><span class="lineno"> 86</span> </div> +<div class="line"><a id="l00087" name="l00087"></a><span class="lineno"> 87</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen00095" data-start="{" data-end="}"> +<div class="line"><a id="l00095" name="l00095"></a><span class="lineno"><a class="line" href="neorv32__cpu_8h.html#a3b6cf445e2136486564ef3d3473c91dd"> 95</a></span><span class="keyword">inline</span> uint32_t __attribute__ ((always_inline)) <a class="code hl_function" href="neorv32__cpu_8h.html#a3b6cf445e2136486564ef3d3473c91dd">neorv32_cpu_load_unsigned_word</a>(uint32_t addr) {</div> +<div class="line"><a id="l00096" name="l00096"></a><span class="lineno"> 96</span> </div> +<div class="line"><a id="l00097" name="l00097"></a><span class="lineno"> 97</span> uint32_t reg_addr = addr;</div> +<div class="line"><a id="l00098" name="l00098"></a><span class="lineno"> 98</span> uint32_t reg_data;</div> +<div class="line"><a id="l00099" name="l00099"></a><span class="lineno"> 99</span> <span class="keyword">asm</span> <span class="keyword">volatile</span> (<span class="stringliteral">&quot;lw %[da], 0(%[ad])&quot;</span> : [da] <span class="stringliteral">&quot;=r&quot;</span> (reg_data) : [ad] <span class="stringliteral">&quot;r&quot;</span> (reg_addr));</div> +<div class="line"><a id="l00100" name="l00100"></a><span class="lineno"> 100</span> <span class="keywordflow">return</span> reg_data;</div> +<div class="line"><a id="l00101" name="l00101"></a><span class="lineno"> 101</span>}</div> +</div> +<div class="line"><a id="l00102" name="l00102"></a><span class="lineno"> 102</span> </div> +<div class="line"><a id="l00103" name="l00103"></a><span class="lineno"> 103</span> </div> +<div class="line"><a id="l00104" name="l00104"></a><span class="lineno"> 104</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen00112" data-start="{" data-end="}"> +<div class="line"><a id="l00112" name="l00112"></a><span class="lineno"><a class="line" href="neorv32__cpu_8h.html#a32544cd652debb4affb308806a115d5b"> 112</a></span><span class="keyword">inline</span> uint16_t __attribute__ ((always_inline)) <a class="code hl_function" href="neorv32__cpu_8h.html#a32544cd652debb4affb308806a115d5b">neorv32_cpu_load_unsigned_half</a>(uint32_t addr) {</div> +<div class="line"><a id="l00113" name="l00113"></a><span class="lineno"> 113</span> </div> +<div class="line"><a id="l00114" name="l00114"></a><span class="lineno"> 114</span> uint32_t reg_addr = addr;</div> +<div class="line"><a id="l00115" name="l00115"></a><span class="lineno"> 115</span> uint16_t reg_data;</div> +<div class="line"><a id="l00116" name="l00116"></a><span class="lineno"> 116</span> <span class="keyword">asm</span> <span class="keyword">volatile</span> (<span class="stringliteral">&quot;lhu %[da], 0(%[ad])&quot;</span> : [da] <span class="stringliteral">&quot;=r&quot;</span> (reg_data) : [ad] <span class="stringliteral">&quot;r&quot;</span> (reg_addr));</div> +<div class="line"><a id="l00117" name="l00117"></a><span class="lineno"> 117</span> <span class="keywordflow">return</span> reg_data;</div> +<div class="line"><a id="l00118" name="l00118"></a><span class="lineno"> 118</span>}</div> +</div> +<div class="line"><a id="l00119" name="l00119"></a><span class="lineno"> 119</span> </div> +<div class="line"><a id="l00120" name="l00120"></a><span class="lineno"> 120</span> </div> +<div class="line"><a id="l00121" name="l00121"></a><span class="lineno"> 121</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen00129" data-start="{" data-end="}"> +<div class="line"><a id="l00129" name="l00129"></a><span class="lineno"><a class="line" href="neorv32__cpu_8h.html#ae9c8b6c681536ddea3aff0e63f30ef70"> 129</a></span><span class="keyword">inline</span> int16_t __attribute__ ((always_inline)) <a class="code hl_function" href="neorv32__cpu_8h.html#ae9c8b6c681536ddea3aff0e63f30ef70">neorv32_cpu_load_signed_half</a>(uint32_t addr) {</div> +<div class="line"><a id="l00130" name="l00130"></a><span class="lineno"> 130</span> </div> +<div class="line"><a id="l00131" name="l00131"></a><span class="lineno"> 131</span> uint32_t reg_addr = addr;</div> +<div class="line"><a id="l00132" name="l00132"></a><span class="lineno"> 132</span> int16_t reg_data;</div> +<div class="line"><a id="l00133" name="l00133"></a><span class="lineno"> 133</span> <span class="keyword">asm</span> <span class="keyword">volatile</span> (<span class="stringliteral">&quot;lh %[da], 0(%[ad])&quot;</span> : [da] <span class="stringliteral">&quot;=r&quot;</span> (reg_data) : [ad] <span class="stringliteral">&quot;r&quot;</span> (reg_addr));</div> +<div class="line"><a id="l00134" name="l00134"></a><span class="lineno"> 134</span> <span class="keywordflow">return</span> reg_data;</div> +<div class="line"><a id="l00135" name="l00135"></a><span class="lineno"> 135</span>}</div> +</div> +<div class="line"><a id="l00136" name="l00136"></a><span class="lineno"> 136</span> </div> +<div class="line"><a id="l00137" name="l00137"></a><span class="lineno"> 137</span> </div> +<div class="line"><a id="l00138" name="l00138"></a><span class="lineno"> 138</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen00144" data-start="{" data-end="}"> +<div class="line"><a id="l00144" name="l00144"></a><span class="lineno"><a class="line" href="neorv32__cpu_8h.html#ac54ec9b59e17c7cd9b9907abee82ce95"> 144</a></span><span class="keyword">inline</span> uint8_t __attribute__ ((always_inline)) <a class="code hl_function" href="neorv32__cpu_8h.html#ac54ec9b59e17c7cd9b9907abee82ce95">neorv32_cpu_load_unsigned_byte</a>(uint32_t addr) {</div> +<div class="line"><a id="l00145" name="l00145"></a><span class="lineno"> 145</span> </div> +<div class="line"><a id="l00146" name="l00146"></a><span class="lineno"> 146</span> uint32_t reg_addr = addr;</div> +<div class="line"><a id="l00147" name="l00147"></a><span class="lineno"> 147</span> uint8_t reg_data;</div> +<div class="line"><a id="l00148" name="l00148"></a><span class="lineno"> 148</span> <span class="keyword">asm</span> <span class="keyword">volatile</span> (<span class="stringliteral">&quot;lbu %[da], 0(%[ad])&quot;</span> : [da] <span class="stringliteral">&quot;=r&quot;</span> (reg_data) : [ad] <span class="stringliteral">&quot;r&quot;</span> (reg_addr));</div> +<div class="line"><a id="l00149" name="l00149"></a><span class="lineno"> 149</span> <span class="keywordflow">return</span> reg_data;</div> +<div class="line"><a id="l00150" name="l00150"></a><span class="lineno"> 150</span>}</div> +</div> +<div class="line"><a id="l00151" name="l00151"></a><span class="lineno"> 151</span> </div> +<div class="line"><a id="l00152" name="l00152"></a><span class="lineno"> 152</span> </div> +<div class="line"><a id="l00153" name="l00153"></a><span class="lineno"> 153</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen00159" data-start="{" data-end="}"> +<div class="line"><a id="l00159" name="l00159"></a><span class="lineno"><a class="line" href="neorv32__cpu_8h.html#a31f903596ab1bcddea79fdf608eaa666"> 159</a></span><span class="keyword">inline</span> int8_t __attribute__ ((always_inline)) <a class="code hl_function" href="neorv32__cpu_8h.html#a31f903596ab1bcddea79fdf608eaa666">neorv32_cpu_load_signed_byte</a>(uint32_t addr) {</div> +<div class="line"><a id="l00160" name="l00160"></a><span class="lineno"> 160</span> </div> +<div class="line"><a id="l00161" name="l00161"></a><span class="lineno"> 161</span> uint32_t reg_addr = addr;</div> +<div class="line"><a id="l00162" name="l00162"></a><span class="lineno"> 162</span> int8_t reg_data;</div> +<div class="line"><a id="l00163" name="l00163"></a><span class="lineno"> 163</span> <span class="keyword">asm</span> <span class="keyword">volatile</span> (<span class="stringliteral">&quot;lb %[da], 0(%[ad])&quot;</span> : [da] <span class="stringliteral">&quot;=r&quot;</span> (reg_data) : [ad] <span class="stringliteral">&quot;r&quot;</span> (reg_addr));</div> +<div class="line"><a id="l00164" name="l00164"></a><span class="lineno"> 164</span> <span class="keywordflow">return</span> reg_data;</div> +<div class="line"><a id="l00165" name="l00165"></a><span class="lineno"> 165</span>}</div> +</div> +<div class="line"><a id="l00166" name="l00166"></a><span class="lineno"> 166</span> </div> +<div class="line"><a id="l00167" name="l00167"></a><span class="lineno"> 167</span> </div> +<div class="line"><a id="l00168" name="l00168"></a><span class="lineno"> 168</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen00174" data-start="{" data-end="}"> +<div class="line"><a id="l00174" name="l00174"></a><span class="lineno"><a class="line" href="neorv32__cpu_8h.html#aab7a9f9cf608599f2b124dd499cb8418"> 174</a></span><span class="keyword">inline</span> uint32_t __attribute__ ((always_inline)) <a class="code hl_function" href="neorv32__cpu_8h.html#aab7a9f9cf608599f2b124dd499cb8418">neorv32_cpu_csr_read</a>(<span class="keyword">const</span> <span class="keywordtype">int</span> csr_id) {</div> +<div class="line"><a id="l00175" name="l00175"></a><span class="lineno"> 175</span> </div> +<div class="line"><a id="l00176" name="l00176"></a><span class="lineno"> 176</span> uint32_t csr_data;</div> +<div class="line"><a id="l00177" name="l00177"></a><span class="lineno"> 177</span> <span class="keyword">asm</span> <span class="keyword">volatile</span> (<span class="stringliteral">&quot;csrr %[result], %[input_i]&quot;</span> : [result] <span class="stringliteral">&quot;=r&quot;</span> (csr_data) : [input_i] <span class="stringliteral">&quot;i&quot;</span> (csr_id));</div> +<div class="line"><a id="l00178" name="l00178"></a><span class="lineno"> 178</span> <span class="keywordflow">return</span> csr_data;</div> +<div class="line"><a id="l00179" name="l00179"></a><span class="lineno"> 179</span>}</div> +</div> +<div class="line"><a id="l00180" name="l00180"></a><span class="lineno"> 180</span> </div> +<div class="line"><a id="l00181" name="l00181"></a><span class="lineno"> 181</span> </div> +<div class="line"><a id="l00182" name="l00182"></a><span class="lineno"> 182</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen00188" data-start="{" data-end="}"> +<div class="line"><a id="l00188" name="l00188"></a><span class="lineno"><a class="line" href="neorv32__cpu_8h.html#afb5ef6e0b1a3e26570edfd8379490455"> 188</a></span><span class="keyword">inline</span> <span class="keywordtype">void</span> __attribute__ ((always_inline)) <a class="code hl_function" href="neorv32__cpu_8h.html#afb5ef6e0b1a3e26570edfd8379490455">neorv32_cpu_csr_write</a>(<span class="keyword">const</span> <span class="keywordtype">int</span> csr_id, uint32_t data) {</div> +<div class="line"><a id="l00189" name="l00189"></a><span class="lineno"> 189</span> </div> +<div class="line"><a id="l00190" name="l00190"></a><span class="lineno"> 190</span> uint32_t csr_data = data;</div> +<div class="line"><a id="l00191" name="l00191"></a><span class="lineno"> 191</span> <span class="keyword">asm</span> <span class="keyword">volatile</span> (<span class="stringliteral">&quot;csrw %[input_i], %[input_j]&quot;</span> : : [input_i] <span class="stringliteral">&quot;i&quot;</span> (csr_id), [input_j] <span class="stringliteral">&quot;r&quot;</span> (csr_data));</div> +<div class="line"><a id="l00192" name="l00192"></a><span class="lineno"> 192</span>}</div> +</div> +<div class="line"><a id="l00193" name="l00193"></a><span class="lineno"> 193</span> </div> +<div class="line"><a id="l00194" name="l00194"></a><span class="lineno"> 194</span> </div> +<div class="line"><a id="l00195" name="l00195"></a><span class="lineno"> 195</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen00201" data-start="{" data-end="}"> +<div class="line"><a id="l00201" name="l00201"></a><span class="lineno"><a class="line" href="neorv32__cpu_8h.html#a25a09de97229aac839ef6f74da604acf"> 201</a></span><span class="keyword">inline</span> <span class="keywordtype">void</span> __attribute__ ((always_inline)) <a class="code hl_function" href="neorv32__cpu_8h.html#a25a09de97229aac839ef6f74da604acf">neorv32_cpu_csr_set</a>(<span class="keyword">const</span> <span class="keywordtype">int</span> csr_id, uint32_t mask) {</div> +<div class="line"><a id="l00202" name="l00202"></a><span class="lineno"> 202</span> </div> +<div class="line"><a id="l00203" name="l00203"></a><span class="lineno"> 203</span> uint32_t csr_data = mask;</div> +<div class="line"><a id="l00204" name="l00204"></a><span class="lineno"> 204</span> <span class="keyword">asm</span> <span class="keyword">volatile</span> (<span class="stringliteral">&quot;csrs %[input_i], %[input_j]&quot;</span> : : [input_i] <span class="stringliteral">&quot;i&quot;</span> (csr_id), [input_j] <span class="stringliteral">&quot;r&quot;</span> (csr_data));</div> +<div class="line"><a id="l00205" name="l00205"></a><span class="lineno"> 205</span>}</div> +</div> +<div class="line"><a id="l00206" name="l00206"></a><span class="lineno"> 206</span> </div> +<div class="line"><a id="l00207" name="l00207"></a><span class="lineno"> 207</span> </div> +<div class="line"><a id="l00208" name="l00208"></a><span class="lineno"> 208</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen00214" data-start="{" data-end="}"> +<div class="line"><a id="l00214" name="l00214"></a><span class="lineno"><a class="line" href="neorv32__cpu_8h.html#ab8f533ddbc3a3af5e3bca2287ac10122"> 214</a></span><span class="keyword">inline</span> <span class="keywordtype">void</span> __attribute__ ((always_inline)) <a class="code hl_function" href="neorv32__cpu_8h.html#ab8f533ddbc3a3af5e3bca2287ac10122">neorv32_cpu_csr_clr</a>(<span class="keyword">const</span> <span class="keywordtype">int</span> csr_id, uint32_t mask) {</div> +<div class="line"><a id="l00215" name="l00215"></a><span class="lineno"> 215</span> </div> +<div class="line"><a id="l00216" name="l00216"></a><span class="lineno"> 216</span> uint32_t csr_data = mask;</div> +<div class="line"><a id="l00217" name="l00217"></a><span class="lineno"> 217</span> <span class="keyword">asm</span> <span class="keyword">volatile</span> (<span class="stringliteral">&quot;csrc %[input_i], %[input_j]&quot;</span> : : [input_i] <span class="stringliteral">&quot;i&quot;</span> (csr_id), [input_j] <span class="stringliteral">&quot;r&quot;</span> (csr_data));</div> +<div class="line"><a id="l00218" name="l00218"></a><span class="lineno"> 218</span>}</div> +</div> +<div class="line"><a id="l00219" name="l00219"></a><span class="lineno"> 219</span> </div> +<div class="line"><a id="l00220" name="l00220"></a><span class="lineno"> 220</span> </div> +<div class="line"><a id="l00221" name="l00221"></a><span class="lineno"> 221</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen00227" data-start="{" data-end="}"> +<div class="line"><a id="l00227" name="l00227"></a><span class="lineno"><a class="line" href="neorv32__cpu_8h.html#a769ca4556213619f6fea4ff6bfb979dd"> 227</a></span><span class="keyword">inline</span> <span class="keywordtype">void</span> __attribute__ ((always_inline)) <a class="code hl_function" href="neorv32__cpu_8h.html#a769ca4556213619f6fea4ff6bfb979dd">neorv32_cpu_sleep</a>(<span class="keywordtype">void</span>) {</div> +<div class="line"><a id="l00228" name="l00228"></a><span class="lineno"> 228</span> </div> +<div class="line"><a id="l00229" name="l00229"></a><span class="lineno"> 229</span> <span class="keyword">asm</span> <span class="keyword">volatile</span> (<span class="stringliteral">&quot;wfi&quot;</span>);</div> +<div class="line"><a id="l00230" name="l00230"></a><span class="lineno"> 230</span>}</div> +</div> +<div class="line"><a id="l00231" name="l00231"></a><span class="lineno"> 231</span> </div> +<div class="line"><a id="l00232" name="l00232"></a><span class="lineno"> 232</span> </div> +<div class="line"><a id="l00233" name="l00233"></a><span class="lineno"> 233</span><span class="preprocessor">#endif </span><span class="comment">// neorv32_cpu_h</span></div> +<div class="ttc" id="aneorv32__cpu_8h_html_a173bb06b4ae9c8964469068dafcb7b0e"><div class="ttname"><a href="neorv32__cpu_8h.html#a173bb06b4ae9c8964469068dafcb7b0e">neorv32_cpu_store_unsigned_word</a></div><div class="ttdeci">void neorv32_cpu_store_unsigned_word(uint32_t addr, uint32_t wdata)</div><div class="ttdef"><b>Definition</b> neorv32_cpu.h:49</div></div> +<div class="ttc" id="aneorv32__cpu_8h_html_a232d0290c459dc790d989fcdc4d121bf"><div class="ttname"><a href="neorv32__cpu_8h.html#a232d0290c459dc790d989fcdc4d121bf">neorv32_cpu_set_mcycle</a></div><div class="ttdeci">void neorv32_cpu_set_mcycle(uint64_t value)</div><div class="ttdef"><b>Definition</b> neorv32_cpu.c:72</div></div> +<div class="ttc" id="aneorv32__cpu_8h_html_a25a09de97229aac839ef6f74da604acf"><div class="ttname"><a href="neorv32__cpu_8h.html#a25a09de97229aac839ef6f74da604acf">neorv32_cpu_csr_set</a></div><div class="ttdeci">void neorv32_cpu_csr_set(const int csr_id, uint32_t mask)</div><div class="ttdef"><b>Definition</b> neorv32_cpu.h:201</div></div> +<div class="ttc" id="aneorv32__cpu_8h_html_a27dd614bc270dfa30ed73323ebda2d2d"><div class="ttname"><a href="neorv32__cpu_8h.html#a27dd614bc270dfa30ed73323ebda2d2d">neorv32_cpu_pmp_get_num_regions</a></div><div class="ttdeci">uint32_t neorv32_cpu_pmp_get_num_regions(void)</div><div class="ttdef"><b>Definition</b> neorv32_cpu.c:221</div></div> +<div class="ttc" id="aneorv32__cpu_8h_html_a31f30f6d6542758cd3073a9939b07653"><div class="ttname"><a href="neorv32__cpu_8h.html#a31f30f6d6542758cd3073a9939b07653">neorv32_cpu_store_unsigned_half</a></div><div class="ttdeci">void neorv32_cpu_store_unsigned_half(uint32_t addr, uint16_t wdata)</div><div class="ttdef"><b>Definition</b> neorv32_cpu.h:65</div></div> +<div class="ttc" id="aneorv32__cpu_8h_html_a31f903596ab1bcddea79fdf608eaa666"><div class="ttname"><a href="neorv32__cpu_8h.html#a31f903596ab1bcddea79fdf608eaa666">neorv32_cpu_load_signed_byte</a></div><div class="ttdeci">int8_t neorv32_cpu_load_signed_byte(uint32_t addr)</div><div class="ttdef"><b>Definition</b> neorv32_cpu.h:159</div></div> +<div class="ttc" id="aneorv32__cpu_8h_html_a32544cd652debb4affb308806a115d5b"><div class="ttname"><a href="neorv32__cpu_8h.html#a32544cd652debb4affb308806a115d5b">neorv32_cpu_load_unsigned_half</a></div><div class="ttdeci">uint16_t neorv32_cpu_load_unsigned_half(uint32_t addr)</div><div class="ttdef"><b>Definition</b> neorv32_cpu.h:112</div></div> +<div class="ttc" id="aneorv32__cpu_8h_html_a387aa304770b05594c4acca128a60a75"><div class="ttname"><a href="neorv32__cpu_8h.html#a387aa304770b05594c4acca128a60a75">neorv32_cpu_get_instret</a></div><div class="ttdeci">uint64_t neorv32_cpu_get_instret(void)</div><div class="ttdef"><b>Definition</b> neorv32_cpu.c:90</div></div> +<div class="ttc" id="aneorv32__cpu_8h_html_a3b6cf445e2136486564ef3d3473c91dd"><div class="ttname"><a href="neorv32__cpu_8h.html#a3b6cf445e2136486564ef3d3473c91dd">neorv32_cpu_load_unsigned_word</a></div><div class="ttdeci">uint32_t neorv32_cpu_load_unsigned_word(uint32_t addr)</div><div class="ttdef"><b>Definition</b> neorv32_cpu.h:95</div></div> +<div class="ttc" id="aneorv32__cpu_8h_html_a5c3cf52498abb3cf3c14a724b287ecf0"><div class="ttname"><a href="neorv32__cpu_8h.html#a5c3cf52498abb3cf3c14a724b287ecf0">neorv32_cpu_set_minstret</a></div><div class="ttdeci">void neorv32_cpu_set_minstret(uint64_t value)</div><div class="ttdef"><b>Definition</b> neorv32_cpu.c:116</div></div> +<div class="ttc" id="aneorv32__cpu_8h_html_a70f49b80322aa457f29f7671f94a183d"><div class="ttname"><a href="neorv32__cpu_8h.html#a70f49b80322aa457f29f7671f94a183d">neorv32_cpu_hpm_get_num_counters</a></div><div class="ttdeci">uint32_t neorv32_cpu_hpm_get_num_counters(void)</div><div class="ttdef"><b>Definition</b> neorv32_cpu.c:374</div></div> +<div class="ttc" id="aneorv32__cpu_8h_html_a769ca4556213619f6fea4ff6bfb979dd"><div class="ttname"><a href="neorv32__cpu_8h.html#a769ca4556213619f6fea4ff6bfb979dd">neorv32_cpu_sleep</a></div><div class="ttdeci">void neorv32_cpu_sleep(void)</div><div class="ttdef"><b>Definition</b> neorv32_cpu.h:227</div></div> +<div class="ttc" id="aneorv32__cpu_8h_html_a8346fb926f84f3d7bccbb4741105505f"><div class="ttname"><a href="neorv32__cpu_8h.html#a8346fb926f84f3d7bccbb4741105505f">neorv32_cpu_get_clk_from_prsc</a></div><div class="ttdeci">uint32_t neorv32_cpu_get_clk_from_prsc(int prsc)</div><div class="ttdef"><b>Definition</b> neorv32_cpu.c:188</div></div> +<div class="ttc" id="aneorv32__cpu_8h_html_aa458a700619b2f7666cfcffe02ec2e2c"><div class="ttname"><a href="neorv32__cpu_8h.html#aa458a700619b2f7666cfcffe02ec2e2c">neorv32_cpu_pmp_configure_region</a></div><div class="ttdeci">int neorv32_cpu_pmp_configure_region(int index, uint32_t addr, uint8_t config)</div><div class="ttdef"><b>Definition</b> neorv32_cpu.c:308</div></div> +<div class="ttc" id="aneorv32__cpu_8h_html_aa9027535b13d9f9325e734997fc4a137"><div class="ttname"><a href="neorv32__cpu_8h.html#aa9027535b13d9f9325e734997fc4a137">neorv32_cpu_delay_ms</a></div><div class="ttdeci">void neorv32_cpu_delay_ms(uint32_t time_ms)</div><div class="ttdef"><b>Definition</b> neorv32_cpu.c:138</div></div> +<div class="ttc" id="aneorv32__cpu_8h_html_aab7a9f9cf608599f2b124dd499cb8418"><div class="ttname"><a href="neorv32__cpu_8h.html#aab7a9f9cf608599f2b124dd499cb8418">neorv32_cpu_csr_read</a></div><div class="ttdeci">uint32_t neorv32_cpu_csr_read(const int csr_id)</div><div class="ttdef"><b>Definition</b> neorv32_cpu.h:174</div></div> +<div class="ttc" id="aneorv32__cpu_8h_html_ab8f533ddbc3a3af5e3bca2287ac10122"><div class="ttname"><a href="neorv32__cpu_8h.html#ab8f533ddbc3a3af5e3bca2287ac10122">neorv32_cpu_csr_clr</a></div><div class="ttdeci">void neorv32_cpu_csr_clr(const int csr_id, uint32_t mask)</div><div class="ttdef"><b>Definition</b> neorv32_cpu.h:214</div></div> +<div class="ttc" id="aneorv32__cpu_8h_html_ac3fd7dc7cd1e0a08225c41820af27f92"><div class="ttname"><a href="neorv32__cpu_8h.html#ac3fd7dc7cd1e0a08225c41820af27f92">neorv32_cpu_get_cycle</a></div><div class="ttdeci">uint64_t neorv32_cpu_get_cycle(void)</div><div class="ttdef"><b>Definition</b> neorv32_cpu.c:46</div></div> +<div class="ttc" id="aneorv32__cpu_8h_html_ac54ec9b59e17c7cd9b9907abee82ce95"><div class="ttname"><a href="neorv32__cpu_8h.html#ac54ec9b59e17c7cd9b9907abee82ce95">neorv32_cpu_load_unsigned_byte</a></div><div class="ttdeci">uint8_t neorv32_cpu_load_unsigned_byte(uint32_t addr)</div><div class="ttdef"><b>Definition</b> neorv32_cpu.h:144</div></div> +<div class="ttc" id="aneorv32__cpu_8h_html_aca49efb45d3808ad76cf65ba291f546d"><div class="ttname"><a href="neorv32__cpu_8h.html#aca49efb45d3808ad76cf65ba291f546d">neorv32_cpu_goto_user_mode</a></div><div class="ttdeci">void neorv32_cpu_goto_user_mode(void)</div><div class="ttdef"><b>Definition</b> neorv32_cpu.c:447</div></div> +<div class="ttc" id="aneorv32__cpu_8h_html_ad4f8160f4821b6691e9682ef60c7cd7b"><div class="ttname"><a href="neorv32__cpu_8h.html#ad4f8160f4821b6691e9682ef60c7cd7b">neorv32_cpu_pmp_get_granularity</a></div><div class="ttdeci">uint32_t neorv32_cpu_pmp_get_granularity(void)</div><div class="ttdef"><b>Definition</b> neorv32_cpu.c:266</div></div> +<div class="ttc" id="aneorv32__cpu_8h_html_adb3ae542bbb0ddf9f562a4e42bc24d10"><div class="ttname"><a href="neorv32__cpu_8h.html#adb3ae542bbb0ddf9f562a4e42bc24d10">neorv32_cpu_hpm_get_size</a></div><div class="ttdeci">uint32_t neorv32_cpu_hpm_get_size(void)</div><div class="ttdef"><b>Definition</b> neorv32_cpu.c:409</div></div> +<div class="ttc" id="aneorv32__cpu_8h_html_ae9c8b6c681536ddea3aff0e63f30ef70"><div class="ttname"><a href="neorv32__cpu_8h.html#ae9c8b6c681536ddea3aff0e63f30ef70">neorv32_cpu_load_signed_half</a></div><div class="ttdeci">int16_t neorv32_cpu_load_signed_half(uint32_t addr)</div><div class="ttdef"><b>Definition</b> neorv32_cpu.h:129</div></div> +<div class="ttc" id="aneorv32__cpu_8h_html_aeec8ad2a82885c40a307346f9003483e"><div class="ttname"><a href="neorv32__cpu_8h.html#aeec8ad2a82885c40a307346f9003483e">neorv32_cpu_store_unsigned_byte</a></div><div class="ttdeci">void neorv32_cpu_store_unsigned_byte(uint32_t addr, uint8_t wdata)</div><div class="ttdef"><b>Definition</b> neorv32_cpu.h:79</div></div> +<div class="ttc" id="aneorv32__cpu_8h_html_afb5ef6e0b1a3e26570edfd8379490455"><div class="ttname"><a href="neorv32__cpu_8h.html#afb5ef6e0b1a3e26570edfd8379490455">neorv32_cpu_csr_write</a></div><div class="ttdeci">void neorv32_cpu_csr_write(const int csr_id, uint32_t data)</div><div class="ttdef"><b>Definition</b> neorv32_cpu.h:188</div></div> +</div><!-- fragment --></div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/neorv32__cpu__amo_8c.html b/sw/neorv32__cpu__amo_8c.html new file mode 100644 index 0000000000..5f14e84589 --- /dev/null +++ b/sw/neorv32__cpu__amo_8c.html @@ -0,0 +1,414 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/lib/source/neorv32_cpu_amo.c File Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_7d04193005ada6f9450f847f4adb6b5b.html">lib</a></li><li class="navelem"><a class="el" href="dir_0c6ac14e2254a316d41123f98feeb67b.html">source</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#func-members">Functions</a> </div> + <div class="headertitle"><div class="title">neorv32_cpu_amo.c File Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p>Atomic memory access (read-modify-write) emulation functions using LR/SC pairs - source file. +<a href="#details">More...</a></p> +<div class="textblock"><code>#include &quot;<a class="el" href="neorv32_8h_source.html">neorv32.h</a>&quot;</code><br /> +</div><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="func-members" name="func-members"></a> +Functions</h2></td></tr> +<tr class="memitem:aad0d96e61bacc3af13ff471dd44ca8e9" id="r_aad0d96e61bacc3af13ff471dd44ca8e9"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aad0d96e61bacc3af13ff471dd44ca8e9">neorv32_cpu_amoswapw</a> (uint32_t addr, uint32_t wdata)</td></tr> +<tr class="separator:aad0d96e61bacc3af13ff471dd44ca8e9"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ada27ec89b2530f7b7f14de947cc82bf9" id="r_ada27ec89b2530f7b7f14de947cc82bf9"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ada27ec89b2530f7b7f14de947cc82bf9">neorv32_cpu_amoaddw</a> (uint32_t addr, uint32_t wdata)</td></tr> +<tr class="separator:ada27ec89b2530f7b7f14de947cc82bf9"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a9b4540dadbfd5da907117570d8006e36" id="r_a9b4540dadbfd5da907117570d8006e36"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a9b4540dadbfd5da907117570d8006e36">neorv32_cpu_amoandw</a> (uint32_t addr, uint32_t wdata)</td></tr> +<tr class="separator:a9b4540dadbfd5da907117570d8006e36"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:adc80b1f2b3a4e70fee44c0edb08fc402" id="r_adc80b1f2b3a4e70fee44c0edb08fc402"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#adc80b1f2b3a4e70fee44c0edb08fc402">neorv32_cpu_amoorw</a> (uint32_t addr, uint32_t wdata)</td></tr> +<tr class="separator:adc80b1f2b3a4e70fee44c0edb08fc402"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a65b67f48356fa9b30596485473311377" id="r_a65b67f48356fa9b30596485473311377"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a65b67f48356fa9b30596485473311377">neorv32_cpu_amoxorw</a> (uint32_t addr, uint32_t wdata)</td></tr> +<tr class="separator:a65b67f48356fa9b30596485473311377"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a62cf36637d7a04079228acecfe8a5cf3" id="r_a62cf36637d7a04079228acecfe8a5cf3"><td class="memItemLeft" align="right" valign="top">int32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a62cf36637d7a04079228acecfe8a5cf3">neorv32_cpu_amomaxw</a> (uint32_t addr, int32_t wdata)</td></tr> +<tr class="separator:a62cf36637d7a04079228acecfe8a5cf3"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a31a6a3b5a33655f4a7b27d4c85b75f07" id="r_a31a6a3b5a33655f4a7b27d4c85b75f07"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a31a6a3b5a33655f4a7b27d4c85b75f07">neorv32_cpu_amomaxuw</a> (uint32_t addr, uint32_t wdata)</td></tr> +<tr class="separator:a31a6a3b5a33655f4a7b27d4c85b75f07"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a8e383fb8825538b5579d5ce075830697" id="r_a8e383fb8825538b5579d5ce075830697"><td class="memItemLeft" align="right" valign="top">int32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a8e383fb8825538b5579d5ce075830697">neorv32_cpu_amominw</a> (uint32_t addr, int32_t wdata)</td></tr> +<tr class="separator:a8e383fb8825538b5579d5ce075830697"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a1281e18b95cd525073e1123c5d04e9e2" id="r_a1281e18b95cd525073e1123c5d04e9e2"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a1281e18b95cd525073e1123c5d04e9e2">neorv32_cpu_amominuw</a> (uint32_t addr, uint32_t wdata)</td></tr> +<tr class="separator:a1281e18b95cd525073e1123c5d04e9e2"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>Atomic memory access (read-modify-write) emulation functions using LR/SC pairs - source file. </p> +<dl class="section see"><dt>See also</dt><dd><a href="https://stnolting.github.io/neorv32/sw/files.html">https://stnolting.github.io/neorv32/sw/files.html</a> </dd></dl> +</div><h2 class="groupheader">Function Documentation</h2> +<a id="ada27ec89b2530f7b7f14de947cc82bf9" name="ada27ec89b2530f7b7f14de947cc82bf9"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ada27ec89b2530f7b7f14de947cc82bf9">&#9670;&#160;</a></span>neorv32_cpu_amoaddw()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_cpu_amoaddw </td> + <td>(</td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>addr</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>wdata</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Atomic ADD (AMOADD.W). return &lt;= MEM[addr]; MEM[addr] &lt;= MEM[addr] + wdata</p> +<dl class="section note"><dt>Note</dt><dd>This function requires the CPU A ISA extension.</dd></dl> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">addr</td><td>32-bit memory address, word-aligned. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">wdata</td><td>Data word to be atomically added to original data at address (32-bit). </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Pre-operation data loaded from address (32-bit) </dd></dl> + +</div> +</div> +<a id="a9b4540dadbfd5da907117570d8006e36" name="a9b4540dadbfd5da907117570d8006e36"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a9b4540dadbfd5da907117570d8006e36">&#9670;&#160;</a></span>neorv32_cpu_amoandw()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_cpu_amoandw </td> + <td>(</td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>addr</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>wdata</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Atomic AND (AMOAND.W). return &lt;= MEM[addr]; MEM[addr] &lt;= MEM[addr] and wdata</p> +<dl class="section note"><dt>Note</dt><dd>This function requires the CPU A ISA extension.</dd></dl> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">addr</td><td>32-bit memory address, word-aligned. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">wdata</td><td>Data word to be atomically AND-ed with original data at address (32-bit). </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Pre-operation data loaded from address (32-bit) </dd></dl> + +</div> +</div> +<a id="a31a6a3b5a33655f4a7b27d4c85b75f07" name="a31a6a3b5a33655f4a7b27d4c85b75f07"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a31a6a3b5a33655f4a7b27d4c85b75f07">&#9670;&#160;</a></span>neorv32_cpu_amomaxuw()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_cpu_amomaxuw </td> + <td>(</td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>addr</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>wdata</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Atomic unsigned MAX (AMOMAXU.W). return &lt;= MEM[addr]; MEM[addr] &lt;= maximum_unsigned(MEM[addr], wdata)</p> +<dl class="section note"><dt>Note</dt><dd>This function requires the CPU A ISA extension.</dd></dl> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">addr</td><td>32-bit memory address, word-aligned. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">wdata</td><td>Data word to be atomically MAX-ed with original data at address (unsigned 32-bit). </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Pre-operation data loaded from address (unsigned 32-bit) </dd></dl> + +</div> +</div> +<a id="a62cf36637d7a04079228acecfe8a5cf3" name="a62cf36637d7a04079228acecfe8a5cf3"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a62cf36637d7a04079228acecfe8a5cf3">&#9670;&#160;</a></span>neorv32_cpu_amomaxw()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int32_t neorv32_cpu_amomaxw </td> + <td>(</td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>addr</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">int32_t</td> <td class="paramname"><span class="paramname"><em>wdata</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Atomic signed MAX (AMOMAX.W). return &lt;= MEM[addr]; MEM[addr] &lt;= maximum_signed(MEM[addr], wdata)</p> +<dl class="section note"><dt>Note</dt><dd>This function requires the CPU A ISA extension.</dd></dl> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">addr</td><td>32-bit memory address, word-aligned. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">wdata</td><td>Data word to be atomically MAX-ed with original data at address (signed 32-bit). </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Pre-operation data loaded from address (signed 32-bit) </dd></dl> + +</div> +</div> +<a id="a1281e18b95cd525073e1123c5d04e9e2" name="a1281e18b95cd525073e1123c5d04e9e2"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a1281e18b95cd525073e1123c5d04e9e2">&#9670;&#160;</a></span>neorv32_cpu_amominuw()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_cpu_amominuw </td> + <td>(</td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>addr</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>wdata</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Atomic unsigned MIN (AMOMINU.W). return &lt;= MEM[addr]; MEM[addr] &lt;= minimum_unsigned(MEM[addr], wdata)</p> +<dl class="section note"><dt>Note</dt><dd>This function requires the CPU A ISA extension.</dd></dl> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">addr</td><td>32-bit memory address, word-aligned. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">wdata</td><td>Data word to be atomically MIN-ed with original data at address (unsigned 32-bit). </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Pre-operation data loaded from address (unsigned 32-bit) </dd></dl> + +</div> +</div> +<a id="a8e383fb8825538b5579d5ce075830697" name="a8e383fb8825538b5579d5ce075830697"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a8e383fb8825538b5579d5ce075830697">&#9670;&#160;</a></span>neorv32_cpu_amominw()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int32_t neorv32_cpu_amominw </td> + <td>(</td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>addr</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">int32_t</td> <td class="paramname"><span class="paramname"><em>wdata</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Atomic signed MIN (AMOMIN.W). return &lt;= MEM[addr]; MEM[addr] &lt;= minimum_signed(MEM[addr], wdata)</p> +<dl class="section note"><dt>Note</dt><dd>This function requires the CPU A ISA extension.</dd></dl> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">addr</td><td>32-bit memory address, word-aligned. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">wdata</td><td>Data word to be atomically MIN-ed with original data at address (signed 32-bit). </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Pre-operation data loaded from address (signed 32-bit) </dd></dl> + +</div> +</div> +<a id="adc80b1f2b3a4e70fee44c0edb08fc402" name="adc80b1f2b3a4e70fee44c0edb08fc402"></a> +<h2 class="memtitle"><span class="permalink"><a href="#adc80b1f2b3a4e70fee44c0edb08fc402">&#9670;&#160;</a></span>neorv32_cpu_amoorw()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_cpu_amoorw </td> + <td>(</td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>addr</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>wdata</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Atomic OR (AMOOR.W). return &lt;= MEM[addr]; MEM[addr] &lt;= MEM[addr] or wdata</p> +<dl class="section note"><dt>Note</dt><dd>This function requires the CPU A ISA extension.</dd></dl> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">addr</td><td>32-bit memory address, word-aligned. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">wdata</td><td>Data word to be atomically OR-ed with original data at address (32-bit). </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Pre-operation data loaded from address (32-bit) </dd></dl> + +</div> +</div> +<a id="aad0d96e61bacc3af13ff471dd44ca8e9" name="aad0d96e61bacc3af13ff471dd44ca8e9"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aad0d96e61bacc3af13ff471dd44ca8e9">&#9670;&#160;</a></span>neorv32_cpu_amoswapw()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_cpu_amoswapw </td> + <td>(</td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>addr</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>wdata</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Atomic SWAP (AMOSWAP.W). return &lt;= MEM[addr]; MEM[addr] &lt;= wdata</p> +<dl class="section note"><dt>Note</dt><dd>This function requires the CPU A ISA extension.</dd></dl> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">addr</td><td>32-bit memory address, word-aligned. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">wdata</td><td>Data word to be atomically stored to address (32-bit). </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Pre-operation data loaded from address (32-bit) </dd></dl> + +</div> +</div> +<a id="a65b67f48356fa9b30596485473311377" name="a65b67f48356fa9b30596485473311377"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a65b67f48356fa9b30596485473311377">&#9670;&#160;</a></span>neorv32_cpu_amoxorw()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_cpu_amoxorw </td> + <td>(</td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>addr</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>wdata</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Atomic XOR (AMOXOR.W). return &lt;= MEM[addr]; MEM[addr] &lt;= MEM[addr] xor wdata</p> +<dl class="section note"><dt>Note</dt><dd>This function requires the CPU A ISA extension.</dd></dl> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">addr</td><td>32-bit memory address, word-aligned. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">wdata</td><td>Data word to be atomically XOR-ed with original data at address (32-bit). </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Pre-operation data loaded from address (32-bit) </dd></dl> + +</div> +</div> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/neorv32__cpu__amo_8h.html b/sw/neorv32__cpu__amo_8h.html new file mode 100644 index 0000000000..d2dd910606 --- /dev/null +++ b/sw/neorv32__cpu__amo_8h.html @@ -0,0 +1,496 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/lib/include/neorv32_cpu_amo.h File Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_7d04193005ada6f9450f847f4adb6b5b.html">lib</a></li><li class="navelem"><a class="el" href="dir_752b1e5d3973bf735fa78bf6b4727df9.html">include</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#func-members">Functions</a> </div> + <div class="headertitle"><div class="title">neorv32_cpu_amo.h File Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p>Atomic memory access (read-modify-write) emulation functions using LR/SC pairs - header file. +<a href="#details">More...</a></p> +<div class="textblock"><code>#include &lt;stdint.h&gt;</code><br /> +</div> +<p><a href="neorv32__cpu__amo_8h_source.html">Go to the source code of this file.</a></p> +<table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="func-members" name="func-members"></a> +Functions</h2></td></tr> +<tr class="memitem:ad4437bbc61a4e40d7d01dfe9459f6639" id="r_ad4437bbc61a4e40d7d01dfe9459f6639"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ad4437bbc61a4e40d7d01dfe9459f6639">neorv32_cpu_amolr</a> (uint32_t addr)</td></tr> +<tr class="separator:ad4437bbc61a4e40d7d01dfe9459f6639"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a5e73eaa273c41a06972e862976fda53c" id="r_a5e73eaa273c41a06972e862976fda53c"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a5e73eaa273c41a06972e862976fda53c">neorv32_cpu_amosc</a> (uint32_t addr, uint32_t wdata)</td></tr> +<tr class="separator:a5e73eaa273c41a06972e862976fda53c"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr><td colspan="2"><div class="groupHeader">Prototypes</div></td></tr> +<tr class="memitem:aad0d96e61bacc3af13ff471dd44ca8e9" id="r_aad0d96e61bacc3af13ff471dd44ca8e9"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aad0d96e61bacc3af13ff471dd44ca8e9">neorv32_cpu_amoswapw</a> (uint32_t addr, uint32_t wdata)</td></tr> +<tr class="separator:aad0d96e61bacc3af13ff471dd44ca8e9"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ada27ec89b2530f7b7f14de947cc82bf9" id="r_ada27ec89b2530f7b7f14de947cc82bf9"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ada27ec89b2530f7b7f14de947cc82bf9">neorv32_cpu_amoaddw</a> (uint32_t addr, uint32_t wdata)</td></tr> +<tr class="separator:ada27ec89b2530f7b7f14de947cc82bf9"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a9b4540dadbfd5da907117570d8006e36" id="r_a9b4540dadbfd5da907117570d8006e36"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a9b4540dadbfd5da907117570d8006e36">neorv32_cpu_amoandw</a> (uint32_t addr, uint32_t wdata)</td></tr> +<tr class="separator:a9b4540dadbfd5da907117570d8006e36"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:adc80b1f2b3a4e70fee44c0edb08fc402" id="r_adc80b1f2b3a4e70fee44c0edb08fc402"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#adc80b1f2b3a4e70fee44c0edb08fc402">neorv32_cpu_amoorw</a> (uint32_t addr, uint32_t wdata)</td></tr> +<tr class="separator:adc80b1f2b3a4e70fee44c0edb08fc402"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a65b67f48356fa9b30596485473311377" id="r_a65b67f48356fa9b30596485473311377"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a65b67f48356fa9b30596485473311377">neorv32_cpu_amoxorw</a> (uint32_t addr, uint32_t wdata)</td></tr> +<tr class="separator:a65b67f48356fa9b30596485473311377"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a62cf36637d7a04079228acecfe8a5cf3" id="r_a62cf36637d7a04079228acecfe8a5cf3"><td class="memItemLeft" align="right" valign="top">int32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a62cf36637d7a04079228acecfe8a5cf3">neorv32_cpu_amomaxw</a> (uint32_t addr, int32_t wdata)</td></tr> +<tr class="separator:a62cf36637d7a04079228acecfe8a5cf3"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a31a6a3b5a33655f4a7b27d4c85b75f07" id="r_a31a6a3b5a33655f4a7b27d4c85b75f07"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a31a6a3b5a33655f4a7b27d4c85b75f07">neorv32_cpu_amomaxuw</a> (uint32_t addr, uint32_t wdata)</td></tr> +<tr class="separator:a31a6a3b5a33655f4a7b27d4c85b75f07"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a8e383fb8825538b5579d5ce075830697" id="r_a8e383fb8825538b5579d5ce075830697"><td class="memItemLeft" align="right" valign="top">int32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a8e383fb8825538b5579d5ce075830697">neorv32_cpu_amominw</a> (uint32_t addr, int32_t wdata)</td></tr> +<tr class="separator:a8e383fb8825538b5579d5ce075830697"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a1281e18b95cd525073e1123c5d04e9e2" id="r_a1281e18b95cd525073e1123c5d04e9e2"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a1281e18b95cd525073e1123c5d04e9e2">neorv32_cpu_amominuw</a> (uint32_t addr, uint32_t wdata)</td></tr> +<tr class="separator:a1281e18b95cd525073e1123c5d04e9e2"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>Atomic memory access (read-modify-write) emulation functions using LR/SC pairs - header file. </p> +<dl class="section see"><dt>See also</dt><dd><a href="https://stnolting.github.io/neorv32/sw/files.html">https://stnolting.github.io/neorv32/sw/files.html</a> </dd></dl> +</div><h2 class="groupheader">Function Documentation</h2> +<a id="ada27ec89b2530f7b7f14de947cc82bf9" name="ada27ec89b2530f7b7f14de947cc82bf9"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ada27ec89b2530f7b7f14de947cc82bf9">&#9670;&#160;</a></span>neorv32_cpu_amoaddw()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_cpu_amoaddw </td> + <td>(</td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>addr</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>wdata</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Atomic ADD (AMOADD.W). return &lt;= MEM[addr]; MEM[addr] &lt;= MEM[addr] + wdata</p> +<dl class="section note"><dt>Note</dt><dd>This function requires the CPU A ISA extension.</dd></dl> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">addr</td><td>32-bit memory address, word-aligned. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">wdata</td><td>Data word to be atomically added to original data at address (32-bit). </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Pre-operation data loaded from address (32-bit) </dd></dl> + +</div> +</div> +<a id="a9b4540dadbfd5da907117570d8006e36" name="a9b4540dadbfd5da907117570d8006e36"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a9b4540dadbfd5da907117570d8006e36">&#9670;&#160;</a></span>neorv32_cpu_amoandw()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_cpu_amoandw </td> + <td>(</td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>addr</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>wdata</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Atomic AND (AMOAND.W). return &lt;= MEM[addr]; MEM[addr] &lt;= MEM[addr] and wdata</p> +<dl class="section note"><dt>Note</dt><dd>This function requires the CPU A ISA extension.</dd></dl> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">addr</td><td>32-bit memory address, word-aligned. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">wdata</td><td>Data word to be atomically AND-ed with original data at address (32-bit). </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Pre-operation data loaded from address (32-bit) </dd></dl> + +</div> +</div> +<a id="ad4437bbc61a4e40d7d01dfe9459f6639" name="ad4437bbc61a4e40d7d01dfe9459f6639"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ad4437bbc61a4e40d7d01dfe9459f6639">&#9670;&#160;</a></span>neorv32_cpu_amolr()</h2> + +<div class="memitem"> +<div class="memproto"> +<table class="mlabels"> + <tr> + <td class="mlabels-left"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_cpu_amolr </td> + <td>(</td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>addr</em></span></td><td>)</td> + <td></td> + </tr> + </table> + </td> + <td class="mlabels-right"> +<span class="mlabels"><span class="mlabel">inline</span></span> </td> + </tr> +</table> +</div><div class="memdoc"> +<p>Atomic memory access: load-reservate word.</p> +<dl class="section note"><dt>Note</dt><dd>The address has to be word-aligned - otherwise an alignment exception will be raised. </dd></dl> +<dl class="section warning"><dt>Warning</dt><dd>This function requires the A ISA extension.</dd></dl> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">addr</td><td>Address (32-bit). </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Read data word (32-bit). </dd></dl> + +</div> +</div> +<a id="a31a6a3b5a33655f4a7b27d4c85b75f07" name="a31a6a3b5a33655f4a7b27d4c85b75f07"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a31a6a3b5a33655f4a7b27d4c85b75f07">&#9670;&#160;</a></span>neorv32_cpu_amomaxuw()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_cpu_amomaxuw </td> + <td>(</td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>addr</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>wdata</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Atomic unsigned MAX (AMOMAXU.W). return &lt;= MEM[addr]; MEM[addr] &lt;= maximum_unsigned(MEM[addr], wdata)</p> +<dl class="section note"><dt>Note</dt><dd>This function requires the CPU A ISA extension.</dd></dl> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">addr</td><td>32-bit memory address, word-aligned. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">wdata</td><td>Data word to be atomically MAX-ed with original data at address (unsigned 32-bit). </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Pre-operation data loaded from address (unsigned 32-bit) </dd></dl> + +</div> +</div> +<a id="a62cf36637d7a04079228acecfe8a5cf3" name="a62cf36637d7a04079228acecfe8a5cf3"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a62cf36637d7a04079228acecfe8a5cf3">&#9670;&#160;</a></span>neorv32_cpu_amomaxw()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int32_t neorv32_cpu_amomaxw </td> + <td>(</td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>addr</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">int32_t</td> <td class="paramname"><span class="paramname"><em>wdata</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Atomic signed MAX (AMOMAX.W). return &lt;= MEM[addr]; MEM[addr] &lt;= maximum_signed(MEM[addr], wdata)</p> +<dl class="section note"><dt>Note</dt><dd>This function requires the CPU A ISA extension.</dd></dl> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">addr</td><td>32-bit memory address, word-aligned. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">wdata</td><td>Data word to be atomically MAX-ed with original data at address (signed 32-bit). </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Pre-operation data loaded from address (signed 32-bit) </dd></dl> + +</div> +</div> +<a id="a1281e18b95cd525073e1123c5d04e9e2" name="a1281e18b95cd525073e1123c5d04e9e2"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a1281e18b95cd525073e1123c5d04e9e2">&#9670;&#160;</a></span>neorv32_cpu_amominuw()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_cpu_amominuw </td> + <td>(</td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>addr</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>wdata</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Atomic unsigned MIN (AMOMINU.W). return &lt;= MEM[addr]; MEM[addr] &lt;= minimum_unsigned(MEM[addr], wdata)</p> +<dl class="section note"><dt>Note</dt><dd>This function requires the CPU A ISA extension.</dd></dl> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">addr</td><td>32-bit memory address, word-aligned. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">wdata</td><td>Data word to be atomically MIN-ed with original data at address (unsigned 32-bit). </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Pre-operation data loaded from address (unsigned 32-bit) </dd></dl> + +</div> +</div> +<a id="a8e383fb8825538b5579d5ce075830697" name="a8e383fb8825538b5579d5ce075830697"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a8e383fb8825538b5579d5ce075830697">&#9670;&#160;</a></span>neorv32_cpu_amominw()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int32_t neorv32_cpu_amominw </td> + <td>(</td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>addr</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">int32_t</td> <td class="paramname"><span class="paramname"><em>wdata</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Atomic signed MIN (AMOMIN.W). return &lt;= MEM[addr]; MEM[addr] &lt;= minimum_signed(MEM[addr], wdata)</p> +<dl class="section note"><dt>Note</dt><dd>This function requires the CPU A ISA extension.</dd></dl> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">addr</td><td>32-bit memory address, word-aligned. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">wdata</td><td>Data word to be atomically MIN-ed with original data at address (signed 32-bit). </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Pre-operation data loaded from address (signed 32-bit) </dd></dl> + +</div> +</div> +<a id="adc80b1f2b3a4e70fee44c0edb08fc402" name="adc80b1f2b3a4e70fee44c0edb08fc402"></a> +<h2 class="memtitle"><span class="permalink"><a href="#adc80b1f2b3a4e70fee44c0edb08fc402">&#9670;&#160;</a></span>neorv32_cpu_amoorw()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_cpu_amoorw </td> + <td>(</td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>addr</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>wdata</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Atomic OR (AMOOR.W). return &lt;= MEM[addr]; MEM[addr] &lt;= MEM[addr] or wdata</p> +<dl class="section note"><dt>Note</dt><dd>This function requires the CPU A ISA extension.</dd></dl> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">addr</td><td>32-bit memory address, word-aligned. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">wdata</td><td>Data word to be atomically OR-ed with original data at address (32-bit). </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Pre-operation data loaded from address (32-bit) </dd></dl> + +</div> +</div> +<a id="a5e73eaa273c41a06972e862976fda53c" name="a5e73eaa273c41a06972e862976fda53c"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a5e73eaa273c41a06972e862976fda53c">&#9670;&#160;</a></span>neorv32_cpu_amosc()</h2> + +<div class="memitem"> +<div class="memproto"> +<table class="mlabels"> + <tr> + <td class="mlabels-left"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_cpu_amosc </td> + <td>(</td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>addr</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>wdata</em></span>&#160;)</td> + </tr> + </table> + </td> + <td class="mlabels-right"> +<span class="mlabels"><span class="mlabel">inline</span></span> </td> + </tr> +</table> +</div><div class="memdoc"> +<p>Atomic memory access: store-conditional word.</p> +<dl class="section note"><dt>Note</dt><dd>The address has to be word-aligned - otherwise an alignment exception will be raised. </dd></dl> +<dl class="section warning"><dt>Warning</dt><dd>This function requires the A ISA extension.</dd></dl> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">addr</td><td>Address (32-bit). </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">wdata</td><td>Data word to-be-written conditionally (32-bit). </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Status: 0 = ok, 1 = failed (32-bit). </dd></dl> + +</div> +</div> +<a id="aad0d96e61bacc3af13ff471dd44ca8e9" name="aad0d96e61bacc3af13ff471dd44ca8e9"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aad0d96e61bacc3af13ff471dd44ca8e9">&#9670;&#160;</a></span>neorv32_cpu_amoswapw()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_cpu_amoswapw </td> + <td>(</td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>addr</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>wdata</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Atomic SWAP (AMOSWAP.W). return &lt;= MEM[addr]; MEM[addr] &lt;= wdata</p> +<dl class="section note"><dt>Note</dt><dd>This function requires the CPU A ISA extension.</dd></dl> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">addr</td><td>32-bit memory address, word-aligned. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">wdata</td><td>Data word to be atomically stored to address (32-bit). </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Pre-operation data loaded from address (32-bit) </dd></dl> + +</div> +</div> +<a id="a65b67f48356fa9b30596485473311377" name="a65b67f48356fa9b30596485473311377"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a65b67f48356fa9b30596485473311377">&#9670;&#160;</a></span>neorv32_cpu_amoxorw()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_cpu_amoxorw </td> + <td>(</td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>addr</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>wdata</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Atomic XOR (AMOXOR.W). return &lt;= MEM[addr]; MEM[addr] &lt;= MEM[addr] xor wdata</p> +<dl class="section note"><dt>Note</dt><dd>This function requires the CPU A ISA extension.</dd></dl> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">addr</td><td>32-bit memory address, word-aligned. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">wdata</td><td>Data word to be atomically XOR-ed with original data at address (32-bit). </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Pre-operation data loaded from address (32-bit) </dd></dl> + +</div> +</div> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/neorv32__cpu__amo_8h_source.html b/sw/neorv32__cpu__amo_8h_source.html new file mode 100644 index 0000000000..3f3bf6a8b1 --- /dev/null +++ b/sw/neorv32__cpu__amo_8h_source.html @@ -0,0 +1,181 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/lib/include/neorv32_cpu_amo.h Source File</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_7d04193005ada6f9450f847f4adb6b5b.html">lib</a></li><li class="navelem"><a class="el" href="dir_752b1e5d3973bf735fa78bf6b4727df9.html">include</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="headertitle"><div class="title">neorv32_cpu_amo.h</div></div> +</div><!--header--> +<div class="contents"> +<a href="neorv32__cpu__amo_8h.html">Go to the documentation of this file.</a><div class="fragment"><div class="line"><a id="l00001" name="l00001"></a><span class="lineno"> 1</span><span class="comment">// ================================================================================ //</span></div> +<div class="line"><a id="l00002" name="l00002"></a><span class="lineno"> 2</span><span class="comment">// The NEORV32 RISC-V Processor - https://github.com/stnolting/neorv32 //</span></div> +<div class="line"><a id="l00003" name="l00003"></a><span class="lineno"> 3</span><span class="comment">// Copyright (c) NEORV32 contributors. //</span></div> +<div class="line"><a id="l00004" name="l00004"></a><span class="lineno"> 4</span><span class="comment">// Copyright (c) 2020 - 2024 Stephan Nolting. All rights reserved. //</span></div> +<div class="line"><a id="l00005" name="l00005"></a><span class="lineno"> 5</span><span class="comment">// Licensed under the BSD-3-Clause license, see LICENSE for details. //</span></div> +<div class="line"><a id="l00006" name="l00006"></a><span class="lineno"> 6</span><span class="comment">// SPDX-License-Identifier: BSD-3-Clause //</span></div> +<div class="line"><a id="l00007" name="l00007"></a><span class="lineno"> 7</span><span class="comment">// ================================================================================ //</span></div> +<div class="line"><a id="l00008" name="l00008"></a><span class="lineno"> 8</span> </div> +<div class="line"><a id="l00016" name="l00016"></a><span class="lineno"> 16</span><span class="preprocessor">#ifndef neorv32_cpu_amo_h</span></div> +<div class="line"><a id="l00017" name="l00017"></a><span class="lineno"> 17</span><span class="preprocessor">#define neorv32_cpu_amo_h</span></div> +<div class="line"><a id="l00018" name="l00018"></a><span class="lineno"> 18</span> </div> +<div class="line"><a id="l00019" name="l00019"></a><span class="lineno"> 19</span><span class="preprocessor">#include &lt;stdint.h&gt;</span></div> +<div class="line"><a id="l00020" name="l00020"></a><span class="lineno"> 20</span> </div> +<div class="line"><a id="l00021" name="l00021"></a><span class="lineno"> 21</span> </div> +<div class="line"><a id="l00022" name="l00022"></a><span class="lineno"> 22</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen00031" data-start="{" data-end="}"> +<div class="line"><a id="l00031" name="l00031"></a><span class="lineno"><a class="line" href="neorv32__cpu__amo_8h.html#ad4437bbc61a4e40d7d01dfe9459f6639"> 31</a></span><span class="keyword">inline</span> uint32_t __attribute__ ((always_inline)) <a class="code hl_function" href="neorv32__cpu__amo_8h.html#ad4437bbc61a4e40d7d01dfe9459f6639">neorv32_cpu_amolr</a>(uint32_t addr) {</div> +<div class="line"><a id="l00032" name="l00032"></a><span class="lineno"> 32</span> </div> +<div class="line"><a id="l00033" name="l00033"></a><span class="lineno"> 33</span><span class="preprocessor">#if defined __riscv_atomic</span></div> +<div class="line"><a id="l00034" name="l00034"></a><span class="lineno"> 34</span> uint32_t amo_addr = addr;</div> +<div class="line"><a id="l00035" name="l00035"></a><span class="lineno"> 35</span> uint32_t amo_rdata;</div> +<div class="line"><a id="l00036" name="l00036"></a><span class="lineno"> 36</span> </div> +<div class="line"><a id="l00037" name="l00037"></a><span class="lineno"> 37</span> <span class="keyword">asm</span> <span class="keyword">volatile</span> (<span class="stringliteral">&quot;lr.w %[dst], 0(%[addr])&quot;</span> : [dst] <span class="stringliteral">&quot;=r&quot;</span> (amo_rdata) : [addr] <span class="stringliteral">&quot;r&quot;</span> (amo_addr));</div> +<div class="line"><a id="l00038" name="l00038"></a><span class="lineno"> 38</span> </div> +<div class="line"><a id="l00039" name="l00039"></a><span class="lineno"> 39</span> <span class="keywordflow">return</span> amo_rdata;</div> +<div class="line"><a id="l00040" name="l00040"></a><span class="lineno"> 40</span><span class="preprocessor">#else</span></div> +<div class="line"><a id="l00041" name="l00041"></a><span class="lineno"> 41</span> (void)addr;</div> +<div class="line"><a id="l00042" name="l00042"></a><span class="lineno"> 42</span> </div> +<div class="line"><a id="l00043" name="l00043"></a><span class="lineno"> 43</span> <span class="keywordflow">return</span> 0;</div> +<div class="line"><a id="l00044" name="l00044"></a><span class="lineno"> 44</span><span class="preprocessor">#endif</span></div> +<div class="line"><a id="l00045" name="l00045"></a><span class="lineno"> 45</span>}</div> +</div> +<div class="line"><a id="l00046" name="l00046"></a><span class="lineno"> 46</span> </div> +<div class="line"><a id="l00047" name="l00047"></a><span class="lineno"> 47</span> </div> +<div class="line"><a id="l00048" name="l00048"></a><span class="lineno"> 48</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen00058" data-start="{" data-end="}"> +<div class="line"><a id="l00058" name="l00058"></a><span class="lineno"><a class="line" href="neorv32__cpu__amo_8h.html#a5e73eaa273c41a06972e862976fda53c"> 58</a></span><span class="keyword">inline</span> uint32_t __attribute__ ((always_inline)) <a class="code hl_function" href="neorv32__cpu__amo_8h.html#a5e73eaa273c41a06972e862976fda53c">neorv32_cpu_amosc</a>(uint32_t addr, uint32_t wdata) {</div> +<div class="line"><a id="l00059" name="l00059"></a><span class="lineno"> 59</span> </div> +<div class="line"><a id="l00060" name="l00060"></a><span class="lineno"> 60</span><span class="preprocessor">#if defined __riscv_atomic</span></div> +<div class="line"><a id="l00061" name="l00061"></a><span class="lineno"> 61</span> uint32_t amo_addr = addr;</div> +<div class="line"><a id="l00062" name="l00062"></a><span class="lineno"> 62</span> uint32_t amo_wdata = wdata;</div> +<div class="line"><a id="l00063" name="l00063"></a><span class="lineno"> 63</span> uint32_t amo_status;</div> +<div class="line"><a id="l00064" name="l00064"></a><span class="lineno"> 64</span> </div> +<div class="line"><a id="l00065" name="l00065"></a><span class="lineno"> 65</span> <span class="keyword">asm</span> <span class="keyword">volatile</span> (<span class="stringliteral">&quot;sc.w %[dst], %[src], (%[addr])&quot;</span> : [dst] <span class="stringliteral">&quot;=r&quot;</span> (amo_status) : [src] <span class="stringliteral">&quot;r&quot;</span> (amo_wdata), [addr] <span class="stringliteral">&quot;r&quot;</span> (amo_addr));</div> +<div class="line"><a id="l00066" name="l00066"></a><span class="lineno"> 66</span> </div> +<div class="line"><a id="l00067" name="l00067"></a><span class="lineno"> 67</span> <span class="keywordflow">return</span> amo_status;</div> +<div class="line"><a id="l00068" name="l00068"></a><span class="lineno"> 68</span><span class="preprocessor">#else</span></div> +<div class="line"><a id="l00069" name="l00069"></a><span class="lineno"> 69</span> (void)addr;</div> +<div class="line"><a id="l00070" name="l00070"></a><span class="lineno"> 70</span> (void)wdata;</div> +<div class="line"><a id="l00071" name="l00071"></a><span class="lineno"> 71</span> </div> +<div class="line"><a id="l00072" name="l00072"></a><span class="lineno"> 72</span> <span class="keywordflow">return</span> 1; <span class="comment">// always fail</span></div> +<div class="line"><a id="l00073" name="l00073"></a><span class="lineno"> 73</span><span class="preprocessor">#endif</span></div> +<div class="line"><a id="l00074" name="l00074"></a><span class="lineno"> 74</span>}</div> +</div> +<div class="line"><a id="l00075" name="l00075"></a><span class="lineno"> 75</span> </div> +<div class="line"><a id="l00076" name="l00076"></a><span class="lineno"> 76</span> </div> +<div class="line"><a id="l00077" name="l00077"></a><span class="lineno"> 77</span><span class="comment">/**********************************************************************/</span></div> +<div class="line"><a id="l00081" name="l00081"></a><span class="lineno"> 81</span>uint32_t <a class="code hl_function" href="neorv32__cpu__amo_8h.html#aad0d96e61bacc3af13ff471dd44ca8e9">neorv32_cpu_amoswapw</a>(uint32_t addr, uint32_t wdata);</div> +<div class="line"><a id="l00082" name="l00082"></a><span class="lineno"> 82</span>uint32_t <a class="code hl_function" href="neorv32__cpu__amo_8h.html#ada27ec89b2530f7b7f14de947cc82bf9">neorv32_cpu_amoaddw</a>(uint32_t addr, uint32_t wdata);</div> +<div class="line"><a id="l00083" name="l00083"></a><span class="lineno"> 83</span>uint32_t <a class="code hl_function" href="neorv32__cpu__amo_8h.html#a9b4540dadbfd5da907117570d8006e36">neorv32_cpu_amoandw</a>(uint32_t addr, uint32_t wdata);</div> +<div class="line"><a id="l00084" name="l00084"></a><span class="lineno"> 84</span>uint32_t <a class="code hl_function" href="neorv32__cpu__amo_8h.html#adc80b1f2b3a4e70fee44c0edb08fc402">neorv32_cpu_amoorw</a>(uint32_t addr, uint32_t wdata);</div> +<div class="line"><a id="l00085" name="l00085"></a><span class="lineno"> 85</span>uint32_t <a class="code hl_function" href="neorv32__cpu__amo_8h.html#a65b67f48356fa9b30596485473311377">neorv32_cpu_amoxorw</a>(uint32_t addr, uint32_t wdata);</div> +<div class="line"><a id="l00086" name="l00086"></a><span class="lineno"> 86</span>int32_t <a class="code hl_function" href="neorv32__cpu__amo_8h.html#a62cf36637d7a04079228acecfe8a5cf3">neorv32_cpu_amomaxw</a>(uint32_t addr, int32_t wdata);</div> +<div class="line"><a id="l00087" name="l00087"></a><span class="lineno"> 87</span>uint32_t <a class="code hl_function" href="neorv32__cpu__amo_8h.html#a31a6a3b5a33655f4a7b27d4c85b75f07">neorv32_cpu_amomaxuw</a>(uint32_t addr, uint32_t wdata);</div> +<div class="line"><a id="l00088" name="l00088"></a><span class="lineno"> 88</span>int32_t <a class="code hl_function" href="neorv32__cpu__amo_8h.html#a8e383fb8825538b5579d5ce075830697">neorv32_cpu_amominw</a>(uint32_t addr, int32_t wdata);</div> +<div class="line"><a id="l00089" name="l00089"></a><span class="lineno"> 89</span>uint32_t <a class="code hl_function" href="neorv32__cpu__amo_8h.html#a1281e18b95cd525073e1123c5d04e9e2">neorv32_cpu_amominuw</a>(uint32_t addr, uint32_t wdata);</div> +<div class="line"><a id="l00093" name="l00093"></a><span class="lineno"> 93</span><span class="preprocessor">#endif </span><span class="comment">// neorv32_cpu_amo_h</span></div> +<div class="ttc" id="aneorv32__cpu__amo_8h_html_a1281e18b95cd525073e1123c5d04e9e2"><div class="ttname"><a href="neorv32__cpu__amo_8h.html#a1281e18b95cd525073e1123c5d04e9e2">neorv32_cpu_amominuw</a></div><div class="ttdeci">uint32_t neorv32_cpu_amominuw(uint32_t addr, uint32_t wdata)</div><div class="ttdef"><b>Definition</b> neorv32_cpu_amo.c:315</div></div> +<div class="ttc" id="aneorv32__cpu__amo_8h_html_a31a6a3b5a33655f4a7b27d4c85b75f07"><div class="ttname"><a href="neorv32__cpu__amo_8h.html#a31a6a3b5a33655f4a7b27d4c85b75f07">neorv32_cpu_amomaxuw</a></div><div class="ttdeci">uint32_t neorv32_cpu_amomaxuw(uint32_t addr, uint32_t wdata)</div><div class="ttdef"><b>Definition</b> neorv32_cpu_amo.c:243</div></div> +<div class="ttc" id="aneorv32__cpu__amo_8h_html_a5e73eaa273c41a06972e862976fda53c"><div class="ttname"><a href="neorv32__cpu__amo_8h.html#a5e73eaa273c41a06972e862976fda53c">neorv32_cpu_amosc</a></div><div class="ttdeci">uint32_t neorv32_cpu_amosc(uint32_t addr, uint32_t wdata)</div><div class="ttdef"><b>Definition</b> neorv32_cpu_amo.h:58</div></div> +<div class="ttc" id="aneorv32__cpu__amo_8h_html_a62cf36637d7a04079228acecfe8a5cf3"><div class="ttname"><a href="neorv32__cpu__amo_8h.html#a62cf36637d7a04079228acecfe8a5cf3">neorv32_cpu_amomaxw</a></div><div class="ttdeci">int32_t neorv32_cpu_amomaxw(uint32_t addr, int32_t wdata)</div><div class="ttdef"><b>Definition</b> neorv32_cpu_amo.c:207</div></div> +<div class="ttc" id="aneorv32__cpu__amo_8h_html_a65b67f48356fa9b30596485473311377"><div class="ttname"><a href="neorv32__cpu__amo_8h.html#a65b67f48356fa9b30596485473311377">neorv32_cpu_amoxorw</a></div><div class="ttdeci">uint32_t neorv32_cpu_amoxorw(uint32_t addr, uint32_t wdata)</div><div class="ttdef"><b>Definition</b> neorv32_cpu_amo.c:171</div></div> +<div class="ttc" id="aneorv32__cpu__amo_8h_html_a8e383fb8825538b5579d5ce075830697"><div class="ttname"><a href="neorv32__cpu__amo_8h.html#a8e383fb8825538b5579d5ce075830697">neorv32_cpu_amominw</a></div><div class="ttdeci">int32_t neorv32_cpu_amominw(uint32_t addr, int32_t wdata)</div><div class="ttdef"><b>Definition</b> neorv32_cpu_amo.c:279</div></div> +<div class="ttc" id="aneorv32__cpu__amo_8h_html_a9b4540dadbfd5da907117570d8006e36"><div class="ttname"><a href="neorv32__cpu__amo_8h.html#a9b4540dadbfd5da907117570d8006e36">neorv32_cpu_amoandw</a></div><div class="ttdeci">uint32_t neorv32_cpu_amoandw(uint32_t addr, uint32_t wdata)</div><div class="ttdef"><b>Definition</b> neorv32_cpu_amo.c:99</div></div> +<div class="ttc" id="aneorv32__cpu__amo_8h_html_aad0d96e61bacc3af13ff471dd44ca8e9"><div class="ttname"><a href="neorv32__cpu__amo_8h.html#aad0d96e61bacc3af13ff471dd44ca8e9">neorv32_cpu_amoswapw</a></div><div class="ttdeci">uint32_t neorv32_cpu_amoswapw(uint32_t addr, uint32_t wdata)</div><div class="ttdef"><b>Definition</b> neorv32_cpu_amo.c:29</div></div> +<div class="ttc" id="aneorv32__cpu__amo_8h_html_ad4437bbc61a4e40d7d01dfe9459f6639"><div class="ttname"><a href="neorv32__cpu__amo_8h.html#ad4437bbc61a4e40d7d01dfe9459f6639">neorv32_cpu_amolr</a></div><div class="ttdeci">uint32_t neorv32_cpu_amolr(uint32_t addr)</div><div class="ttdef"><b>Definition</b> neorv32_cpu_amo.h:31</div></div> +<div class="ttc" id="aneorv32__cpu__amo_8h_html_ada27ec89b2530f7b7f14de947cc82bf9"><div class="ttname"><a href="neorv32__cpu__amo_8h.html#ada27ec89b2530f7b7f14de947cc82bf9">neorv32_cpu_amoaddw</a></div><div class="ttdeci">uint32_t neorv32_cpu_amoaddw(uint32_t addr, uint32_t wdata)</div><div class="ttdef"><b>Definition</b> neorv32_cpu_amo.c:63</div></div> +<div class="ttc" id="aneorv32__cpu__amo_8h_html_adc80b1f2b3a4e70fee44c0edb08fc402"><div class="ttname"><a href="neorv32__cpu__amo_8h.html#adc80b1f2b3a4e70fee44c0edb08fc402">neorv32_cpu_amoorw</a></div><div class="ttdeci">uint32_t neorv32_cpu_amoorw(uint32_t addr, uint32_t wdata)</div><div class="ttdef"><b>Definition</b> neorv32_cpu_amo.c:135</div></div> +</div><!-- fragment --></div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/neorv32__cpu__cfu_8c.html b/sw/neorv32__cpu__cfu_8c.html new file mode 100644 index 0000000000..20e41b79d6 --- /dev/null +++ b/sw/neorv32__cpu__cfu_8c.html @@ -0,0 +1,138 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/lib/source/neorv32_cpu_cfu.c File Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_7d04193005ada6f9450f847f4adb6b5b.html">lib</a></li><li class="navelem"><a class="el" href="dir_0c6ac14e2254a316d41123f98feeb67b.html">source</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#func-members">Functions</a> </div> + <div class="headertitle"><div class="title">neorv32_cpu_cfu.c File Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p>CPU Core custom functions unit HW driver source file. +<a href="#details">More...</a></p> +<div class="textblock"><code>#include &quot;<a class="el" href="neorv32_8h_source.html">neorv32.h</a>&quot;</code><br /> +</div><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="func-members" name="func-members"></a> +Functions</h2></td></tr> +<tr class="memitem:a13019b8afa1a80c0e5c24eb4d72e75c1" id="r_a13019b8afa1a80c0e5c24eb4d72e75c1"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a13019b8afa1a80c0e5c24eb4d72e75c1">neorv32_cpu_cfu_available</a> (void)</td></tr> +<tr class="separator:a13019b8afa1a80c0e5c24eb4d72e75c1"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>CPU Core custom functions unit HW driver source file. </p> +<dl class="section see"><dt>See also</dt><dd><a href="https://stnolting.github.io/neorv32/sw/files.html">https://stnolting.github.io/neorv32/sw/files.html</a> </dd></dl> +</div><h2 class="groupheader">Function Documentation</h2> +<a id="a13019b8afa1a80c0e5c24eb4d72e75c1" name="a13019b8afa1a80c0e5c24eb4d72e75c1"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a13019b8afa1a80c0e5c24eb4d72e75c1">&#9670;&#160;</a></span>neorv32_cpu_cfu_available()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_cpu_cfu_available </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Check if custom functions unit was synthesized.</p> +<dl class="section return"><dt>Returns</dt><dd>0 if CFU was not synthesized, 1 if CFU is available. </dd></dl> + +</div> +</div> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/neorv32__cpu__cfu_8h.html b/sw/neorv32__cpu__cfu_8h.html new file mode 100644 index 0000000000..8f75cacbb1 --- /dev/null +++ b/sw/neorv32__cpu__cfu_8h.html @@ -0,0 +1,281 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/lib/include/neorv32_cpu_cfu.h File Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_7d04193005ada6f9450f847f4adb6b5b.html">lib</a></li><li class="navelem"><a class="el" href="dir_752b1e5d3973bf735fa78bf6b4727df9.html">include</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#func-members">Functions</a> </div> + <div class="headertitle"><div class="title">neorv32_cpu_cfu.h File Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p>CPU Core custom functions unit HW driver header file. +<a href="#details">More...</a></p> +<div class="textblock"><code>#include &lt;stdint.h&gt;</code><br /> +</div> +<p><a href="neorv32__cpu__cfu_8h_source.html">Go to the source code of this file.</a></p> +<table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="define-members" name="define-members"></a> +Macros</h2></td></tr> +<tr><td colspan="2"><div class="groupHeader">Low-level CFU custom instruction prototypes ("intrinsics")</div></td></tr> +<tr class="memitem:a69d60ccd0cee950b08ce585c3f13b85c" id="r_a69d60ccd0cee950b08ce585c3f13b85c"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a69d60ccd0cee950b08ce585c3f13b85c">neorv32_cfu_r3_instr</a>(funct7, funct3, rs1, rs2)&#160;&#160;&#160;CUSTOM_INSTR_R3_TYPE(funct7, rs2, rs1, funct3, 0b0001011)</td></tr> +<tr class="separator:a69d60ccd0cee950b08ce585c3f13b85c"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a046a640f7f4a7b1b99a824fb325e2079" id="r_a046a640f7f4a7b1b99a824fb325e2079"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a046a640f7f4a7b1b99a824fb325e2079">neorv32_cfu_r4_instr</a>(funct3, rs1, rs2, rs3)&#160;&#160;&#160;CUSTOM_INSTR_R4_TYPE(rs3, rs2, rs1, funct3, 0b0101011)</td></tr> +<tr class="separator:a046a640f7f4a7b1b99a824fb325e2079"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a65198d9caf04a5cd3a72accc2cecf870" id="r_a65198d9caf04a5cd3a72accc2cecf870"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a65198d9caf04a5cd3a72accc2cecf870">neorv32_cfu_r5_instr_a</a>(rs1, rs2, rs3, rs4)&#160;&#160;&#160;CUSTOM_INSTR_R5_TYPE(rs4, rs3, rs2, rs1, 0b1011011)</td></tr> +<tr class="separator:a65198d9caf04a5cd3a72accc2cecf870"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ab3affefbff898567c6c02c4d10765b04" id="r_ab3affefbff898567c6c02c4d10765b04"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ab3affefbff898567c6c02c4d10765b04">neorv32_cfu_r5_instr_b</a>(rs1, rs2, rs3, rs4)&#160;&#160;&#160;CUSTOM_INSTR_R5_TYPE(rs4, rs3, rs2, rs1, 0b1111011)</td></tr> +<tr class="separator:ab3affefbff898567c6c02c4d10765b04"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="func-members" name="func-members"></a> +Functions</h2></td></tr> +<tr class="memitem:a13019b8afa1a80c0e5c24eb4d72e75c1" id="r_a13019b8afa1a80c0e5c24eb4d72e75c1"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a13019b8afa1a80c0e5c24eb4d72e75c1">neorv32_cpu_cfu_available</a> (void)</td></tr> +<tr class="separator:a13019b8afa1a80c0e5c24eb4d72e75c1"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>CPU Core custom functions unit HW driver header file. </p> +<dl class="section see"><dt>See also</dt><dd><a href="https://stnolting.github.io/neorv32/sw/files.html">https://stnolting.github.io/neorv32/sw/files.html</a> </dd></dl> +</div><h2 class="groupheader">Macro Definition Documentation</h2> +<a id="a69d60ccd0cee950b08ce585c3f13b85c" name="a69d60ccd0cee950b08ce585c3f13b85c"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a69d60ccd0cee950b08ce585c3f13b85c">&#9670;&#160;</a></span>neorv32_cfu_r3_instr</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define neorv32_cfu_r3_instr</td> + <td>(</td> + <td class="paramtype"></td> <td class="paramname"><span class="paramname"><em>funct7</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype"></td> <td class="paramname"><span class="paramname"><em>funct3</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype"></td> <td class="paramname"><span class="paramname"><em>rs1</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype"></td> <td class="paramname"><span class="paramname"><em>rs2</em></span>&#160;)&#160;&#160;&#160;CUSTOM_INSTR_R3_TYPE(funct7, rs2, rs1, funct3, 0b0001011)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>R3-type CFU custom instruction (CUSTOM-0 opcode) </p> + +</div> +</div> +<a id="a046a640f7f4a7b1b99a824fb325e2079" name="a046a640f7f4a7b1b99a824fb325e2079"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a046a640f7f4a7b1b99a824fb325e2079">&#9670;&#160;</a></span>neorv32_cfu_r4_instr</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define neorv32_cfu_r4_instr</td> + <td>(</td> + <td class="paramtype"></td> <td class="paramname"><span class="paramname"><em>funct3</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype"></td> <td class="paramname"><span class="paramname"><em>rs1</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype"></td> <td class="paramname"><span class="paramname"><em>rs2</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype"></td> <td class="paramname"><span class="paramname"><em>rs3</em></span>&#160;)&#160;&#160;&#160;CUSTOM_INSTR_R4_TYPE(rs3, rs2, rs1, funct3, 0b0101011)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>R4-type CFU custom instruction (CUSTOM-1 opcode) </p> + +</div> +</div> +<a id="a65198d9caf04a5cd3a72accc2cecf870" name="a65198d9caf04a5cd3a72accc2cecf870"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a65198d9caf04a5cd3a72accc2cecf870">&#9670;&#160;</a></span>neorv32_cfu_r5_instr_a</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define neorv32_cfu_r5_instr_a</td> + <td>(</td> + <td class="paramtype"></td> <td class="paramname"><span class="paramname"><em>rs1</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype"></td> <td class="paramname"><span class="paramname"><em>rs2</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype"></td> <td class="paramname"><span class="paramname"><em>rs3</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype"></td> <td class="paramname"><span class="paramname"><em>rs4</em></span>&#160;)&#160;&#160;&#160;CUSTOM_INSTR_R5_TYPE(rs4, rs3, rs2, rs1, 0b1011011)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>R5-type CFU custom instruction A (CUSTOM-2 opcode) </p> + +</div> +</div> +<a id="ab3affefbff898567c6c02c4d10765b04" name="ab3affefbff898567c6c02c4d10765b04"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ab3affefbff898567c6c02c4d10765b04">&#9670;&#160;</a></span>neorv32_cfu_r5_instr_b</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define neorv32_cfu_r5_instr_b</td> + <td>(</td> + <td class="paramtype"></td> <td class="paramname"><span class="paramname"><em>rs1</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype"></td> <td class="paramname"><span class="paramname"><em>rs2</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype"></td> <td class="paramname"><span class="paramname"><em>rs3</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype"></td> <td class="paramname"><span class="paramname"><em>rs4</em></span>&#160;)&#160;&#160;&#160;CUSTOM_INSTR_R5_TYPE(rs4, rs3, rs2, rs1, 0b1111011)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>R5-type CFU custom instruction B (CUSTOM-3 opcode) </p> + +</div> +</div> +<h2 class="groupheader">Function Documentation</h2> +<a id="a13019b8afa1a80c0e5c24eb4d72e75c1" name="a13019b8afa1a80c0e5c24eb4d72e75c1"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a13019b8afa1a80c0e5c24eb4d72e75c1">&#9670;&#160;</a></span>neorv32_cpu_cfu_available()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_cpu_cfu_available </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Check if custom functions unit was synthesized.</p> +<dl class="section return"><dt>Returns</dt><dd>0 if CFU was not synthesized, 1 if CFU is available. </dd></dl> + +</div> +</div> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/neorv32__cpu__cfu_8h_source.html b/sw/neorv32__cpu__cfu_8h_source.html new file mode 100644 index 0000000000..7c39df43f1 --- /dev/null +++ b/sw/neorv32__cpu__cfu_8h_source.html @@ -0,0 +1,128 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/lib/include/neorv32_cpu_cfu.h Source File</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_7d04193005ada6f9450f847f4adb6b5b.html">lib</a></li><li class="navelem"><a class="el" href="dir_752b1e5d3973bf735fa78bf6b4727df9.html">include</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="headertitle"><div class="title">neorv32_cpu_cfu.h</div></div> +</div><!--header--> +<div class="contents"> +<a href="neorv32__cpu__cfu_8h.html">Go to the documentation of this file.</a><div class="fragment"><div class="line"><a id="l00001" name="l00001"></a><span class="lineno"> 1</span><span class="comment">// ================================================================================ //</span></div> +<div class="line"><a id="l00002" name="l00002"></a><span class="lineno"> 2</span><span class="comment">// The NEORV32 RISC-V Processor - https://github.com/stnolting/neorv32 //</span></div> +<div class="line"><a id="l00003" name="l00003"></a><span class="lineno"> 3</span><span class="comment">// Copyright (c) NEORV32 contributors. //</span></div> +<div class="line"><a id="l00004" name="l00004"></a><span class="lineno"> 4</span><span class="comment">// Copyright (c) 2020 - 2024 Stephan Nolting. All rights reserved. //</span></div> +<div class="line"><a id="l00005" name="l00005"></a><span class="lineno"> 5</span><span class="comment">// Licensed under the BSD-3-Clause license, see LICENSE for details. //</span></div> +<div class="line"><a id="l00006" name="l00006"></a><span class="lineno"> 6</span><span class="comment">// SPDX-License-Identifier: BSD-3-Clause //</span></div> +<div class="line"><a id="l00007" name="l00007"></a><span class="lineno"> 7</span><span class="comment">// ================================================================================ //</span></div> +<div class="line"><a id="l00008" name="l00008"></a><span class="lineno"> 8</span> </div> +<div class="line"><a id="l00016" name="l00016"></a><span class="lineno"> 16</span><span class="preprocessor">#ifndef neorv32_cpu_cfu_h</span></div> +<div class="line"><a id="l00017" name="l00017"></a><span class="lineno"> 17</span><span class="preprocessor">#define neorv32_cpu_cfu_h</span></div> +<div class="line"><a id="l00018" name="l00018"></a><span class="lineno"> 18</span> </div> +<div class="line"><a id="l00019" name="l00019"></a><span class="lineno"> 19</span><span class="preprocessor">#include &lt;stdint.h&gt;</span></div> +<div class="line"><a id="l00020" name="l00020"></a><span class="lineno"> 20</span> </div> +<div class="line"><a id="l00021" name="l00021"></a><span class="lineno"> 21</span> </div> +<div class="line"><a id="l00022" name="l00022"></a><span class="lineno"> 22</span><span class="comment">// prototypes</span></div> +<div class="line"><a id="l00023" name="l00023"></a><span class="lineno"> 23</span><span class="keywordtype">int</span> <a class="code hl_function" href="neorv32__cpu__cfu_8h.html#a13019b8afa1a80c0e5c24eb4d72e75c1">neorv32_cpu_cfu_available</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00024" name="l00024"></a><span class="lineno"> 24</span> </div> +<div class="line"><a id="l00025" name="l00025"></a><span class="lineno"> 25</span> </div> +<div class="line"><a id="l00026" name="l00026"></a><span class="lineno"> 26</span><span class="comment">/**********************************************************************/</span></div> +<div class="line"><a id="l00031" name="l00031"></a><span class="lineno"><a class="line" href="neorv32__cpu__cfu_8h.html#a69d60ccd0cee950b08ce585c3f13b85c"> 31</a></span><span class="preprocessor">#define neorv32_cfu_r3_instr(funct7, funct3, rs1, rs2) CUSTOM_INSTR_R3_TYPE(funct7, rs2, rs1, funct3, 0b0001011)</span></div> +<div class="line"><a id="l00033" name="l00033"></a><span class="lineno"><a class="line" href="neorv32__cpu__cfu_8h.html#a046a640f7f4a7b1b99a824fb325e2079"> 33</a></span><span class="preprocessor">#define neorv32_cfu_r4_instr(funct3, rs1, rs2, rs3) CUSTOM_INSTR_R4_TYPE(rs3, rs2, rs1, funct3, 0b0101011)</span></div> +<div class="line"><a id="l00035" name="l00035"></a><span class="lineno"><a class="line" href="neorv32__cpu__cfu_8h.html#a65198d9caf04a5cd3a72accc2cecf870"> 35</a></span><span class="preprocessor">#define neorv32_cfu_r5_instr_a(rs1, rs2, rs3, rs4) CUSTOM_INSTR_R5_TYPE(rs4, rs3, rs2, rs1, 0b1011011)</span></div> +<div class="line"><a id="l00037" name="l00037"></a><span class="lineno"><a class="line" href="neorv32__cpu__cfu_8h.html#ab3affefbff898567c6c02c4d10765b04"> 37</a></span><span class="preprocessor">#define neorv32_cfu_r5_instr_b(rs1, rs2, rs3, rs4) CUSTOM_INSTR_R5_TYPE(rs4, rs3, rs2, rs1, 0b1111011)</span></div> +<div class="line"><a id="l00040" name="l00040"></a><span class="lineno"> 40</span><span class="preprocessor">#endif </span><span class="comment">// neorv32_cpu_cfu_h</span></div> +<div class="ttc" id="aneorv32__cpu__cfu_8h_html_a13019b8afa1a80c0e5c24eb4d72e75c1"><div class="ttname"><a href="neorv32__cpu__cfu_8h.html#a13019b8afa1a80c0e5c24eb4d72e75c1">neorv32_cpu_cfu_available</a></div><div class="ttdeci">int neorv32_cpu_cfu_available(void)</div><div class="ttdef"><b>Definition</b> neorv32_cpu_cfu.c:24</div></div> +</div><!-- fragment --></div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/neorv32__cpu__csr_8h.html b/sw/neorv32__cpu__csr_8h.html new file mode 100644 index 0000000000..0dca2b7dac --- /dev/null +++ b/sw/neorv32__cpu__csr_8h.html @@ -0,0 +1,1297 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/lib/include/neorv32_cpu_csr.h File Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_7d04193005ada6f9450f847f4adb6b5b.html">lib</a></li><li class="navelem"><a class="el" href="dir_752b1e5d3973bf735fa78bf6b4727df9.html">include</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#enum-members">Enumerations</a> </div> + <div class="headertitle"><div class="title">neorv32_cpu_csr.h File Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p>Control and Status Registers (CSR) definitions. +<a href="#details">More...</a></p> +<div class="textblock"><code>#include &lt;stdint.h&gt;</code><br /> +</div> +<p><a href="neorv32__cpu__csr_8h_source.html">Go to the source code of this file.</a></p> +<table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="enum-members" name="enum-members"></a> +Enumerations</h2></td></tr> +<tr class="memitem:ac065a8cc32eed9a69ea1798492a69f49" id="r_ac065a8cc32eed9a69ea1798492a69f49"><td class="memItemLeft" align="right" valign="top">enum &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49">NEORV32_CSR_enum</a> { <br /> +&#160;&#160;<a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49a625f606c14fd4d7224d7109e10508e7a">CSR_FFLAGS</a> = 0x001 +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49a7f198c465959dde37b7056dd06d45812">CSR_FRM</a> = 0x002 +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49a5e1abf46b4f55bd18e1d132b32696ab6">CSR_FCSR</a> = 0x003 +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49ad0e5de789d6390f750b8af03cdd15450">CSR_MSTATUS</a> = 0x300 +, <br /> +&#160;&#160;<a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49ade079242596ce14ce1ba9842ed29b84c">CSR_MISA</a> = 0x301 +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49acc0f9f5f3b5702f1b57f2ba3b6b62610">CSR_MIE</a> = 0x304 +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49aa632d218400268df6dc6b289ff088d21">CSR_MTVEC</a> = 0x305 +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49a1860dd9579906c67a3565063043dcf78">CSR_MCOUNTEREN</a> = 0x306 +, <br /> +&#160;&#160;<a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49ac2541060307369b2031e9ec07bbd0067">CSR_MSTATUSH</a> = 0x310 +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49a3ce1dc0e2810f0df78feaa1c607a5ca6">CSR_MCOUNTINHIBIT</a> = 0x320 +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49a9c55619ffb05e84b7210e2d47326fa98">CSR_MENVCFG</a> = 0x30a +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49a46b8d3c288cbbfbf5a0af6e5cd8c5bc8">CSR_MENVCFGH</a> = 0x31a +, <br /> +&#160;&#160;<a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49a4a93ac5ab276cfd2f9cd296c8ce1bff6">CSR_MHPMEVENT3</a> = 0x323 +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49ab5f998725e002ffc2ff516ee973fe459">CSR_MHPMEVENT4</a> = 0x324 +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49a2524659ca2785af51af7acf9cd560a9d">CSR_MHPMEVENT5</a> = 0x325 +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49a1cfa1e3bc3c8a1c9a86c251a510d11cd">CSR_MHPMEVENT6</a> = 0x326 +, <br /> +&#160;&#160;<a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49a2e53e6e01ca8d1b801f6dfba602f3f59">CSR_MHPMEVENT7</a> = 0x327 +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49ad6296ca83bbe1280624f3c21adbd8a79">CSR_MHPMEVENT8</a> = 0x328 +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49af6727a9bdd60ccf020812095b7396632">CSR_MHPMEVENT9</a> = 0x329 +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49a23850b1804966cde2c1e84cde752d512">CSR_MHPMEVENT10</a> = 0x32a +, <br /> +&#160;&#160;<a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49a7fb1de2019dd2b548084d5ca1630efbf">CSR_MHPMEVENT11</a> = 0x32b +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49ad648b5ece209d47e9484fd7aa83e8e5f">CSR_MHPMEVENT12</a> = 0x32c +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49a8c31899b81bb5dba9b92a0f0ca71aea6">CSR_MHPMEVENT13</a> = 0x32d +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49a964a6a50d0138447fad47e9c982a7ba4">CSR_MHPMEVENT14</a> = 0x32e +, <br /> +&#160;&#160;<a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49a06dfdeed757606529e4a99c033691b54">CSR_MHPMEVENT15</a> = 0x32f +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49ae29976bb072639975ad0cdb985c7f004">CSR_MSCRATCH</a> = 0x340 +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49a5d60a25a66754066589e8facb7d41153">CSR_MEPC</a> = 0x341 +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49a2e14b57fee5376741634db7980a5005b">CSR_MCAUSE</a> = 0x342 +, <br /> +&#160;&#160;<a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49a76d30359e3b54197fb53f9939734cf1e">CSR_MTVAL</a> = 0x343 +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49addb485275c954d1181d5bd4e4609082c">CSR_MIP</a> = 0x344 +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49a4f229c169ada239033a1383412ce58c8">CSR_MTINST</a> = 0x34a +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49af1a79349e46a4829af78d2cdfd0dc44f">CSR_PMPCFG0</a> = 0x3a0 +, <br /> +&#160;&#160;<a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49a22eea318ec1ac72cc14e133b71ef4b16">CSR_PMPCFG1</a> = 0x3a1 +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49a0c9492f6b956f088847f72b28e7b1446">CSR_PMPCFG2</a> = 0x3a2 +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49a067ed3778590ae97dc9b16069f0ed850">CSR_PMPCFG3</a> = 0x3a3 +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49a8941071db6145d34fff842249c0dcb9f">CSR_PMPADDR0</a> = 0x3b0 +, <br /> +&#160;&#160;<a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49a6a2933f3a1fa243de02db8a795e3ca41">CSR_PMPADDR1</a> = 0x3b1 +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49aa0b8c0561e8a778dce9c3b86499ffc50">CSR_PMPADDR2</a> = 0x3b2 +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49a89bad989197e9358563557311b3c97e9">CSR_PMPADDR3</a> = 0x3b3 +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49ace4529c53ad2d46767f86d920eada507">CSR_PMPADDR4</a> = 0x3b4 +, <br /> +&#160;&#160;<a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49ad9e78f71409fd7783cc2ae7c28b5e42c">CSR_PMPADDR5</a> = 0x3b5 +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49af57b5b7b57cd6e8b3489a27dfd702444">CSR_PMPADDR6</a> = 0x3b6 +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49ae8ea19cf3e527dbc0d36a43dfd1b7346">CSR_PMPADDR7</a> = 0x3b7 +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49aec68bf7e26e44170c24599f7c6a8365b">CSR_PMPADDR8</a> = 0x3b8 +, <br /> +&#160;&#160;<a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49a54d38c8cf364d886eb7ac64463eedf77">CSR_PMPADDR9</a> = 0x3b9 +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49ad97b6fe934a3bed6b02d0c8d81165d60">CSR_PMPADDR10</a> = 0x3ba +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49a3e5708c0f79cf58ae761b6bb8c2a4383">CSR_PMPADDR11</a> = 0x3bb +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49a23026793ee53c8d55d23f63195368a6b">CSR_PMPADDR12</a> = 0x3bc +, <br /> +&#160;&#160;<a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49a30879e88b250d3e94d9d9e728ffcc2cc">CSR_PMPADDR13</a> = 0x3bd +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49a91a8b5008b4e08ab34c1516e21bf0ba8">CSR_PMPADDR14</a> = 0x3be +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49a6879b4bf5d2db92d236b9091df4841f2">CSR_PMPADDR15</a> = 0x3bf +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49aaae2f0b2e3f5a31dff933868873f6d5d">CSR_TSELECT</a> = 0x7a0 +, <br /> +&#160;&#160;<a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49a80eab0e17f5fe41edde485044674dc57">CSR_TDATA1</a> = 0x7a1 +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49acf336638697242b691b691dc56b9aadc">CSR_TDATA2</a> = 0x7a2 +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49af67c819c104f7e3ec34f2cbb847cf83b">CSR_TINFO</a> = 0x7a4 +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49a6bb3ba59a25803d6f98faad67609a9a9">CSR_DCSR</a> = 0x7b0 +, <br /> +&#160;&#160;<a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49af4c98d949d2eb44f2518fdf314344d3b">CSR_DPC</a> = 0x7b1 +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49a0f4a1ae740efd80d14d21e90f355e9d7">CSR_DSCRATCH0</a> = 0x7b2 +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49ae0e9cf0b99b8614ea0b870d38970281f">CSR_CFUREG0</a> = 0x800 +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49a382304065a6db773f925b80b9447b8a8">CSR_CFUREG1</a> = 0x801 +, <br /> +&#160;&#160;<a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49a427d7cf036b49efd46166c01f0504b68">CSR_CFUREG2</a> = 0x802 +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49aefefa1cff0cf5d01109486e5a8bebedf">CSR_CFUREG3</a> = 0x803 +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49a32c22641ed66c6d20902306a2b1fad77">CSR_MCYCLE</a> = 0xb00 +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49a98f5e2cf2d5dbb0125a222b0065c86eb">CSR_MINSTRET</a> = 0xb02 +, <br /> +&#160;&#160;<a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49ae0a96f499dcde474af6ee620fbb1ebdc">CSR_MHPMCOUNTER3</a> = 0xb03 +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49a9b84bd948dd52a7779b5fd16beddaab9">CSR_MHPMCOUNTER4</a> = 0xb04 +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49af15d389bb8f91c989df488d231666394">CSR_MHPMCOUNTER5</a> = 0xb05 +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49af65b9e99b9cadb3cb8d37f97cdbfeb9d">CSR_MHPMCOUNTER6</a> = 0xb06 +, <br /> +&#160;&#160;<a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49a919f39b0d299feb80403b42a466de444">CSR_MHPMCOUNTER7</a> = 0xb07 +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49a5a4cde90c547e913bddc719b3ab75e79">CSR_MHPMCOUNTER8</a> = 0xb08 +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49a18c2a249f1f7852f42f9e10dc59d46bb">CSR_MHPMCOUNTER9</a> = 0xb09 +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49a575e5342d8ec304c32dbbe99d6fd6c0f">CSR_MHPMCOUNTER10</a> = 0xb0a +, <br /> +&#160;&#160;<a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49a8840b3d4f45453fc96813ccb369a68e5">CSR_MHPMCOUNTER11</a> = 0xb0b +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49a1328a226d36d23cc81740397bde47a4e">CSR_MHPMCOUNTER12</a> = 0xb0c +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49a9bdd102877ff50d38c86c3d741aeb4b0">CSR_MHPMCOUNTER13</a> = 0xb0d +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49adae22d860d8162e15120051951e45229">CSR_MHPMCOUNTER14</a> = 0xb0e +, <br /> +&#160;&#160;<a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49a20400929087fabba410a098667d2d4ff">CSR_MHPMCOUNTER15</a> = 0xb0f +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49a28fcfd06ca1012c19cf053e57689687b">CSR_MCYCLEH</a> = 0xb80 +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49afffb28b62b9baa127ae3bad919208988">CSR_MINSTRETH</a> = 0xb82 +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49a252980a4da90c1f5c1ef85d164f72f25">CSR_MHPMCOUNTER3H</a> = 0xb83 +, <br /> +&#160;&#160;<a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49a2e9cfbf3c2828dd4bd92d2b8a1c99f85">CSR_MHPMCOUNTER4H</a> = 0xb84 +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49a7648dd0a47007d44a14e95ba47726599">CSR_MHPMCOUNTER5H</a> = 0xb85 +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49a49b7bc2df67a6c73a68757de9b218f77">CSR_MHPMCOUNTER6H</a> = 0xb86 +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49ac0183bb6f357ed33136493ae7ded987a">CSR_MHPMCOUNTER7H</a> = 0xb87 +, <br /> +&#160;&#160;<a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49a9e75518df7d14a009e3a0d5588641ddc">CSR_MHPMCOUNTER8H</a> = 0xb88 +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49a7341886c7a4aed6fc7d8677c016a2cb8">CSR_MHPMCOUNTER9H</a> = 0xb89 +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49a1e41d2b27d7e8da14871852d81123cfd">CSR_MHPMCOUNTER10H</a> = 0xb8a +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49a7fd76fcfc0d0dd47e112786bea5e4071">CSR_MHPMCOUNTER11H</a> = 0xb8b +, <br /> +&#160;&#160;<a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49a332ec2b0740f8e899a1b2ec86f7ee9f2">CSR_MHPMCOUNTER12H</a> = 0xb8c +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49a5de5c5a036dc594a554d37df9ccf657d">CSR_MHPMCOUNTER13H</a> = 0xb8d +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49ac65bab6fd71439600c8fc549171251fa">CSR_MHPMCOUNTER14H</a> = 0xb8e +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49af609807e2917f73e27e5f27b38a0fa46">CSR_MHPMCOUNTER15H</a> = 0xb8f +, <br /> +&#160;&#160;<a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49aaaf0f6b17a06d5922bcfdb47b382137e">CSR_CYCLE</a> = 0xc00 +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49a8144da8cd8691ac54aa0712685865b66">CSR_INSTRET</a> = 0xc02 +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49a3ee699d5b2886c54c92992f66b109b67">CSR_HPMCOUNTER3</a> = 0xc03 +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49a98ed49716d0d89712863e7a542d38d2a">CSR_HPMCOUNTER4</a> = 0xc04 +, <br /> +&#160;&#160;<a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49ab2376c3b7c3ec0b44105ec1ed951bfb0">CSR_HPMCOUNTER5</a> = 0xc05 +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49aa2f644a4f54ba3834bafa738208c0803">CSR_HPMCOUNTER6</a> = 0xc06 +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49a125c4d0051548dea9104808b7bee1316">CSR_HPMCOUNTER7</a> = 0xc07 +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49acac87125f8c723cc5df4d4169a82852b">CSR_HPMCOUNTER8</a> = 0xc08 +, <br /> +&#160;&#160;<a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49ab45ebb3bd861074a15cc2ad874756e8f">CSR_HPMCOUNTER9</a> = 0xc09 +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49aa407e701bdbb9d26f84684b811c008a9">CSR_HPMCOUNTER10</a> = 0xc0a +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49a9fd1ff4e8a42992c0a3ec02c397dd7f8">CSR_HPMCOUNTER11</a> = 0xc0b +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49ae58f15a95aa41126819effe046ced804">CSR_HPMCOUNTER12</a> = 0xc0c +, <br /> +&#160;&#160;<a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49a24d8617a6ff2c1e49c9a73853ad9e450">CSR_HPMCOUNTER13</a> = 0xc0d +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49aa47ed1a4a4f9fcabceed0d6d626d0aaf">CSR_HPMCOUNTER14</a> = 0xc0e +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49a7277a8f929a5a250f7227fbbdf545dbc">CSR_HPMCOUNTER15</a> = 0xc0f +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49aa276bedb7dab28935163397b4879f6db">CSR_CYCLEH</a> = 0xc80 +, <br /> +&#160;&#160;<a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49a9b66978d76260283007d399fc735d153">CSR_INSTRETH</a> = 0xc82 +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49aaa3e6a1ac8999be42d7c13891546bb50">CSR_HPMCOUNTER3H</a> = 0xc83 +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49a8837ff8d2741639aa69da59659f9a080">CSR_HPMCOUNTER4H</a> = 0xc84 +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49ad489feaa5ad1feb00d3df71d3e5b0cac">CSR_HPMCOUNTER5H</a> = 0xc85 +, <br /> +&#160;&#160;<a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49a438a65757b85f182dfb1f2a06c9ad520">CSR_HPMCOUNTER6H</a> = 0xc86 +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49a6332d4ff090aa7c302d191219e846fff">CSR_HPMCOUNTER7H</a> = 0xc87 +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49aa8ce8fc8a57dd82872d02b4113249a77">CSR_HPMCOUNTER8H</a> = 0xc88 +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49acdf793b30919e7fa1b85995abe531a20">CSR_HPMCOUNTER9H</a> = 0xc89 +, <br /> +&#160;&#160;<a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49ae56e95d6d6dd63ff6f5b4192cf48c88b">CSR_HPMCOUNTER10H</a> = 0xc8a +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49a2af8c5dcc87d92bcce392fb5b3aa065e">CSR_HPMCOUNTER11H</a> = 0xc8b +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49a74359db2583feb7119d4bcaa926242a0">CSR_HPMCOUNTER12H</a> = 0xc8c +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49a4fa22699e96d6da8665077e3c95891ef">CSR_HPMCOUNTER13H</a> = 0xc8d +, <br /> +&#160;&#160;<a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49a03f29e792be2854efc9e66d710b78a1d">CSR_HPMCOUNTER14H</a> = 0xc8e +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49a11169bd08920d40c8f94fd29e1d33eff">CSR_HPMCOUNTER15H</a> = 0xc8f +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49af5c5a21909aaca2b57f9a15f4bac246b">CSR_MVENDORID</a> = 0xf11 +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49ad95cb95266533123447ff0e917f890e4">CSR_MARCHID</a> = 0xf12 +, <br /> +&#160;&#160;<a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49a06d39cf0f13d6401dcf426d56149c8cd">CSR_MIMPID</a> = 0xf13 +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49a6ba48e2306ae92f498552e1ea04d6790">CSR_MHARTID</a> = 0xf14 +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49a0545d0921b3f90d037dbb25bc5fcc2f9">CSR_MCONFIGPTR</a> = 0xf15 +, <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49a396847bcf1634a1602ab117bfb57bdd2">CSR_MXISA</a> = 0xfc0 +<br /> + }</td></tr> +<tr class="separator:ac065a8cc32eed9a69ea1798492a69f49"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:afde0761e3150d82511136f56179c204b" id="r_afde0761e3150d82511136f56179c204b"><td class="memItemLeft" align="right" valign="top">enum &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#afde0761e3150d82511136f56179c204b">NEORV32_CSR_FFLAGS_enum</a> { <br /> +&#160;&#160;<a class="el" href="#afde0761e3150d82511136f56179c204ba91a314defd310786a9ed67f7ef2ef5a6">CSR_FFLAGS_NX</a> = 0 +, <a class="el" href="#afde0761e3150d82511136f56179c204babc6d405724563844569028f463885819">CSR_FFLAGS_UF</a> = 1 +, <a class="el" href="#afde0761e3150d82511136f56179c204ba612390e07a065fa13eeaeac84af48c6e">CSR_FFLAGS_OF</a> = 2 +, <a class="el" href="#afde0761e3150d82511136f56179c204ba365f3f519bca34a349907c82c873d52b">CSR_FFLAGS_DZ</a> = 3 +, <br /> +&#160;&#160;<a class="el" href="#afde0761e3150d82511136f56179c204ba3ac330a4b03178e756c980eaa48ad165">CSR_FFLAGS_NV</a> = 4 +<br /> + }</td></tr> +<tr class="separator:afde0761e3150d82511136f56179c204b"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a76b70a2334131e7589d84c1ee96de485" id="r_a76b70a2334131e7589d84c1ee96de485"><td class="memItemLeft" align="right" valign="top">enum &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a76b70a2334131e7589d84c1ee96de485">NEORV32_CSR_MSTATUS_enum</a> { <br /> +&#160;&#160;<a class="el" href="#a76b70a2334131e7589d84c1ee96de485ae2603e365b3f1abfb46d53ed6b13dc56">CSR_MSTATUS_MIE</a> = 3 +, <a class="el" href="#a76b70a2334131e7589d84c1ee96de485aaa1d482f828ac9cafc40fcfc298bec34">CSR_MSTATUS_MPIE</a> = 7 +, <a class="el" href="#a76b70a2334131e7589d84c1ee96de485af0ae9aca74144aa7dbdf656f71cc5c97">CSR_MSTATUS_MPP_L</a> = 11 +, <a class="el" href="#a76b70a2334131e7589d84c1ee96de485a8067c609c2360cab3bafa3c43e03dbf0">CSR_MSTATUS_MPP_H</a> = 12 +, <br /> +&#160;&#160;<a class="el" href="#a76b70a2334131e7589d84c1ee96de485a75cefdbdef36b7fc248765b27c606a44">CSR_MSTATUS_MPRV</a> = 17 +, <a class="el" href="#a76b70a2334131e7589d84c1ee96de485ac94a070f3fe7962e8c49a81545cacf2d">CSR_MSTATUS_TW</a> = 21 +<br /> + }</td></tr> +<tr class="separator:a76b70a2334131e7589d84c1ee96de485"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ab6886ca6858d57854495986ef9b5cbfe" id="r_ab6886ca6858d57854495986ef9b5cbfe"><td class="memItemLeft" align="right" valign="top">enum &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ab6886ca6858d57854495986ef9b5cbfe">NEORV32_CSR_MCOUNTINHIBIT_enum</a> { <br /> +&#160;&#160;<a class="el" href="#ab6886ca6858d57854495986ef9b5cbfea201ac39b0eba389b0d02c3951a3311a3">CSR_MCOUNTINHIBIT_CY</a> = 0 +, <a class="el" href="#ab6886ca6858d57854495986ef9b5cbfea5f182f39f9a4b871a097a51e57865bfa">CSR_MCOUNTINHIBIT_IR</a> = 2 +, <a class="el" href="#ab6886ca6858d57854495986ef9b5cbfeaf7020159e0ba346561bfba101d22c752">CSR_MCOUNTINHIBIT_HPM3</a> = 3 +, <a class="el" href="#ab6886ca6858d57854495986ef9b5cbfea40427b799da049413c5536afa623c61d">CSR_MCOUNTINHIBIT_HPM4</a> = 4 +, <br /> +&#160;&#160;<a class="el" href="#ab6886ca6858d57854495986ef9b5cbfea2769a6e6a75f2f903523e4e95a899bb6">CSR_MCOUNTINHIBIT_HPM5</a> = 5 +, <a class="el" href="#ab6886ca6858d57854495986ef9b5cbfead55b6af15841617d7dca3ab4fab893db">CSR_MCOUNTINHIBIT_HPM6</a> = 6 +, <a class="el" href="#ab6886ca6858d57854495986ef9b5cbfea3b3571fceb687da2d3807b0e59bdf7ab">CSR_MCOUNTINHIBIT_HPM7</a> = 7 +, <a class="el" href="#ab6886ca6858d57854495986ef9b5cbfeabd21344124eda4402523203185a58b8a">CSR_MCOUNTINHIBIT_HPM8</a> = 8 +, <br /> +&#160;&#160;<a class="el" href="#ab6886ca6858d57854495986ef9b5cbfea0f207455df0fed75fa68ba49c435889a">CSR_MCOUNTINHIBIT_HPM9</a> = 9 +, <a class="el" href="#ab6886ca6858d57854495986ef9b5cbfea9517cd32744c5064fa30780f911cd22e">CSR_MCOUNTINHIBIT_HPM10</a> = 10 +, <a class="el" href="#ab6886ca6858d57854495986ef9b5cbfeacaf997fe8b912596224e2bb632e6a806">CSR_MCOUNTINHIBIT_HPM11</a> = 11 +, <a class="el" href="#ab6886ca6858d57854495986ef9b5cbfea8d866a4c815d8ba890a1e00ce9600486">CSR_MCOUNTINHIBIT_HPM12</a> = 12 +, <br /> +&#160;&#160;<a class="el" href="#ab6886ca6858d57854495986ef9b5cbfead9f6c4eb4284ee82b9e8d0c79f62b3ed">CSR_MCOUNTINHIBIT_HPM13</a> = 13 +, <a class="el" href="#ab6886ca6858d57854495986ef9b5cbfeaa83c0688869b1c43de0c4474e940f987">CSR_MCOUNTINHIBIT_HPM14</a> = 14 +, <a class="el" href="#ab6886ca6858d57854495986ef9b5cbfea0b547cb5876c0e7956e3d062e0784085">CSR_MCOUNTINHIBIT_HPM15</a> = 15 +, <a class="el" href="#ab6886ca6858d57854495986ef9b5cbfea68aba71ea77aba4005fb24a945ef38e4">CSR_MCOUNTINHIBIT_HPM16</a> = 16 +, <br /> +&#160;&#160;<a class="el" href="#ab6886ca6858d57854495986ef9b5cbfea8d57acf13a086635a63bc13ccdf479b3">CSR_MCOUNTINHIBIT_HPM17</a> = 17 +, <a class="el" href="#ab6886ca6858d57854495986ef9b5cbfeaa680d196d2ba0e403801a860bb9d8ce0">CSR_MCOUNTINHIBIT_HPM18</a> = 18 +, <a class="el" href="#ab6886ca6858d57854495986ef9b5cbfea3683e296caafe771b6dd57f4cf86f3dc">CSR_MCOUNTINHIBIT_HPM19</a> = 19 +, <a class="el" href="#ab6886ca6858d57854495986ef9b5cbfeaeb4b1b6abafd22eec0764d5503878cca">CSR_MCOUNTINHIBIT_HPM20</a> = 20 +, <br /> +&#160;&#160;<a class="el" href="#ab6886ca6858d57854495986ef9b5cbfea1dc0276a5354c805ac56fd46c5037d38">CSR_MCOUNTINHIBIT_HPM21</a> = 21 +, <a class="el" href="#ab6886ca6858d57854495986ef9b5cbfeaf1b6153a0c664367bfefb78b2ca8b34e">CSR_MCOUNTINHIBIT_HPM22</a> = 22 +, <a class="el" href="#ab6886ca6858d57854495986ef9b5cbfea85c0c2b2a5101380dec72516dda1a904">CSR_MCOUNTINHIBIT_HPM23</a> = 23 +, <a class="el" href="#ab6886ca6858d57854495986ef9b5cbfea74ec85a2e94aa0b9e8af29401ef7ecb1">CSR_MCOUNTINHIBIT_HPM24</a> = 24 +, <br /> +&#160;&#160;<a class="el" href="#ab6886ca6858d57854495986ef9b5cbfeaee2b5a2b7bd7ac07dae45900bc2faf46">CSR_MCOUNTINHIBIT_HPM25</a> = 25 +, <a class="el" href="#ab6886ca6858d57854495986ef9b5cbfea141a4a211c496d2af1c79d8e8e0c2a74">CSR_MCOUNTINHIBIT_HPM26</a> = 26 +, <a class="el" href="#ab6886ca6858d57854495986ef9b5cbfea46def851d4582b4bcec1f9d8bafd58db">CSR_MCOUNTINHIBIT_HPM27</a> = 27 +, <a class="el" href="#ab6886ca6858d57854495986ef9b5cbfea33d0fd3378ec3a2fcc3c8738c6cd2f32">CSR_MCOUNTINHIBIT_HPM28</a> = 28 +, <br /> +&#160;&#160;<a class="el" href="#ab6886ca6858d57854495986ef9b5cbfeaa39882f7dad9b7e16b317c75bad31382">CSR_MCOUNTINHIBIT_HPM29</a> = 29 +, <a class="el" href="#ab6886ca6858d57854495986ef9b5cbfea0f45818fa4cb9033a3093987fa8515c7">CSR_MCOUNTINHIBIT_HPM30</a> = 30 +, <a class="el" href="#ab6886ca6858d57854495986ef9b5cbfea1da1186ef2f4e7297a4fecaaccdc1d05">CSR_MCOUNTINHIBIT_HPM31</a> = 31 +<br /> + }</td></tr> +<tr class="separator:ab6886ca6858d57854495986ef9b5cbfe"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a0e9714690687badee43180c3cb62be33" id="r_a0e9714690687badee43180c3cb62be33"><td class="memItemLeft" align="right" valign="top">enum &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a0e9714690687badee43180c3cb62be33">NEORV32_CSR_MIE_enum</a> { <br /> +&#160;&#160;<a class="el" href="#a0e9714690687badee43180c3cb62be33afd2f1c78c442c8c29ab075cacee0a27a">CSR_MIE_MSIE</a> = 3 +, <a class="el" href="#a0e9714690687badee43180c3cb62be33a3658e8663e94cd8eaa7201b7a850d083">CSR_MIE_MTIE</a> = 7 +, <a class="el" href="#a0e9714690687badee43180c3cb62be33ae8e4f0ee46abbbb3361de035a57b8324">CSR_MIE_MEIE</a> = 11 +, <a class="el" href="#a0e9714690687badee43180c3cb62be33a99f43f8bbfb29fba6224f081c363ac7d">CSR_MIE_FIRQ0E</a> = 16 +, <br /> +&#160;&#160;<a class="el" href="#a0e9714690687badee43180c3cb62be33ac1e1d44becec1b393f79a118ed3d8beb">CSR_MIE_FIRQ1E</a> = 17 +, <a class="el" href="#a0e9714690687badee43180c3cb62be33afc805280e20ffface116ca61e11645f7">CSR_MIE_FIRQ2E</a> = 18 +, <a class="el" href="#a0e9714690687badee43180c3cb62be33a666066099d6cebadbef21d81c179e8db">CSR_MIE_FIRQ3E</a> = 19 +, <a class="el" href="#a0e9714690687badee43180c3cb62be33a592939f1b7d79097f7f13d6ab0c268dc">CSR_MIE_FIRQ4E</a> = 20 +, <br /> +&#160;&#160;<a class="el" href="#a0e9714690687badee43180c3cb62be33a3079a8fbf3b8e376865bff76f2173698">CSR_MIE_FIRQ5E</a> = 21 +, <a class="el" href="#a0e9714690687badee43180c3cb62be33a96315d6b5b9531bcbc1e78a3c9ab166a">CSR_MIE_FIRQ6E</a> = 22 +, <a class="el" href="#a0e9714690687badee43180c3cb62be33a3d9d729940170609affbc6813054ebe8">CSR_MIE_FIRQ7E</a> = 23 +, <a class="el" href="#a0e9714690687badee43180c3cb62be33a396c6c4b425b3fff598e2f846052f98e">CSR_MIE_FIRQ8E</a> = 24 +, <br /> +&#160;&#160;<a class="el" href="#a0e9714690687badee43180c3cb62be33a06fdb61dab31c3490da6c37d47914f19">CSR_MIE_FIRQ9E</a> = 25 +, <a class="el" href="#a0e9714690687badee43180c3cb62be33affcb52dc57bb8c0cb1e7d3c1392d544a">CSR_MIE_FIRQ10E</a> = 26 +, <a class="el" href="#a0e9714690687badee43180c3cb62be33af058342854a0becd3bcc33877d9244cd">CSR_MIE_FIRQ11E</a> = 27 +, <a class="el" href="#a0e9714690687badee43180c3cb62be33a41f91a37f7e0c75c783312af6a72e943">CSR_MIE_FIRQ12E</a> = 28 +, <br /> +&#160;&#160;<a class="el" href="#a0e9714690687badee43180c3cb62be33a134ed02c7293008b21b1df472be8f11f">CSR_MIE_FIRQ13E</a> = 29 +, <a class="el" href="#a0e9714690687badee43180c3cb62be33a864d135708530016cfc52a65a1e4d79b">CSR_MIE_FIRQ14E</a> = 30 +, <a class="el" href="#a0e9714690687badee43180c3cb62be33aa2dfa1183af312de2959dadd217fddc1">CSR_MIE_FIRQ15E</a> = 31 +<br /> + }</td></tr> +<tr class="separator:a0e9714690687badee43180c3cb62be33"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a6301c554bf831b97fc28f9984a1ec21b" id="r_a6301c554bf831b97fc28f9984a1ec21b"><td class="memItemLeft" align="right" valign="top">enum &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a6301c554bf831b97fc28f9984a1ec21b">NEORV32_CSR_MIP_enum</a> { <br /> +&#160;&#160;<a class="el" href="#a6301c554bf831b97fc28f9984a1ec21ba1470cfe04f9d3ce45b7156b2a7fae159">CSR_MIP_MSIP</a> = 3 +, <a class="el" href="#a6301c554bf831b97fc28f9984a1ec21ba344943c62922561378d33ec51ac236e4">CSR_MIP_MTIP</a> = 7 +, <a class="el" href="#a6301c554bf831b97fc28f9984a1ec21ba1d761ef98f88c40509168ac66b7a4872">CSR_MIP_MEIP</a> = 11 +, <a class="el" href="#a6301c554bf831b97fc28f9984a1ec21ba28a85ad8bd4c30fd3a91298dfa4fdb00">CSR_MIP_FIRQ0P</a> = 16 +, <br /> +&#160;&#160;<a class="el" href="#a6301c554bf831b97fc28f9984a1ec21ba2b577b1da1074c29ad58005af1f91d52">CSR_MIP_FIRQ1P</a> = 17 +, <a class="el" href="#a6301c554bf831b97fc28f9984a1ec21badf45c5a135431f958fa63574c1dfac6e">CSR_MIP_FIRQ2P</a> = 18 +, <a class="el" href="#a6301c554bf831b97fc28f9984a1ec21ba7512bb6c4841ddd477422b49ebb2a155">CSR_MIP_FIRQ3P</a> = 19 +, <a class="el" href="#a6301c554bf831b97fc28f9984a1ec21bab6421f242bb8a487a986346e11196eb8">CSR_MIP_FIRQ4P</a> = 20 +, <br /> +&#160;&#160;<a class="el" href="#a6301c554bf831b97fc28f9984a1ec21baaa55d19f9a47889bc364c94bda04b677">CSR_MIP_FIRQ5P</a> = 21 +, <a class="el" href="#a6301c554bf831b97fc28f9984a1ec21baffa7342631aa0526aaa44c0c549b1f3e">CSR_MIP_FIRQ6P</a> = 22 +, <a class="el" href="#a6301c554bf831b97fc28f9984a1ec21baad691486001a68f2375dcf5793ee795a">CSR_MIP_FIRQ7P</a> = 23 +, <a class="el" href="#a6301c554bf831b97fc28f9984a1ec21baf5bbd23d4f311f640db42e9015f87580">CSR_MIP_FIRQ8P</a> = 24 +, <br /> +&#160;&#160;<a class="el" href="#a6301c554bf831b97fc28f9984a1ec21bad94c9691ce59b97fcfec14d345046c3e">CSR_MIP_FIRQ9P</a> = 25 +, <a class="el" href="#a6301c554bf831b97fc28f9984a1ec21ba2b50cfa8be461b088ea8506ce4c741ba">CSR_MIP_FIRQ10P</a> = 26 +, <a class="el" href="#a6301c554bf831b97fc28f9984a1ec21ba69ea0d3d76d4cec398f3b96959cc3544">CSR_MIP_FIRQ11P</a> = 27 +, <a class="el" href="#a6301c554bf831b97fc28f9984a1ec21ba03edd398920b817150d29107c0b40792">CSR_MIP_FIRQ12P</a> = 28 +, <br /> +&#160;&#160;<a class="el" href="#a6301c554bf831b97fc28f9984a1ec21ba14da6a2a962bf82970638a948ffbc570">CSR_MIP_FIRQ13P</a> = 29 +, <a class="el" href="#a6301c554bf831b97fc28f9984a1ec21baad1e5e452a9c37561308765431f0260d">CSR_MIP_FIRQ14P</a> = 30 +, <a class="el" href="#a6301c554bf831b97fc28f9984a1ec21ba12da8c32d38d5a3539a0b766718bfd2d">CSR_MIP_FIRQ15P</a> = 31 +<br /> + }</td></tr> +<tr class="separator:a6301c554bf831b97fc28f9984a1ec21b"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:afed7f00bbb39468f038d9ca6fbac830c" id="r_afed7f00bbb39468f038d9ca6fbac830c"><td class="memItemLeft" align="right" valign="top">enum &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#afed7f00bbb39468f038d9ca6fbac830c">NEORV32_CSR_MISA_enum</a> { <br /> +&#160;&#160;<a class="el" href="#afed7f00bbb39468f038d9ca6fbac830ca89412df9f99d2a0ddc4665446397f1a2">CSR_MISA_A</a> = 0 +, <a class="el" href="#afed7f00bbb39468f038d9ca6fbac830cadd469404a928e012a298773ec46926ad">CSR_MISA_B</a> = 1 +, <a class="el" href="#afed7f00bbb39468f038d9ca6fbac830ca886699013158c74810598fa2fd6b07fa">CSR_MISA_C</a> = 2 +, <a class="el" href="#afed7f00bbb39468f038d9ca6fbac830ca1dd1be1071450f9b00a817bce19fa665">CSR_MISA_D</a> = 3 +, <br /> +&#160;&#160;<a class="el" href="#afed7f00bbb39468f038d9ca6fbac830ca0ac798fd19cb7dbe1146afecda448fec">CSR_MISA_E</a> = 4 +, <a class="el" href="#afed7f00bbb39468f038d9ca6fbac830ca9ec2cae2b948de1043540a4ca1665c40">CSR_MISA_F</a> = 5 +, <a class="el" href="#afed7f00bbb39468f038d9ca6fbac830ca6091fd2c7ae38ad33be68a0fdfa50cca">CSR_MISA_I</a> = 8 +, <a class="el" href="#afed7f00bbb39468f038d9ca6fbac830ca317a631e4598532f5bffe8fb93aff94b">CSR_MISA_M</a> = 12 +, <br /> +&#160;&#160;<a class="el" href="#afed7f00bbb39468f038d9ca6fbac830cacd9d71e674d3a6d04984b6df706d9deb">CSR_MISA_U</a> = 20 +, <a class="el" href="#afed7f00bbb39468f038d9ca6fbac830ca0b119a20be29fcae8fecf2a81c60d193">CSR_MISA_X</a> = 23 +, <a class="el" href="#afed7f00bbb39468f038d9ca6fbac830cab5a55e97b8511f42fe68559a38f7f138">CSR_MISA_MXL_LO</a> = 30 +, <a class="el" href="#afed7f00bbb39468f038d9ca6fbac830cafb3e4b08b87f5c161468a9e58ade12cc">CSR_MISA_MXL_HI</a> = 31 +<br /> + }</td></tr> +<tr class="separator:afed7f00bbb39468f038d9ca6fbac830c"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:af05490a8af176ab4ba945d327d448387" id="r_af05490a8af176ab4ba945d327d448387"><td class="memItemLeft" align="right" valign="top">enum &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#af05490a8af176ab4ba945d327d448387">NEORV32_CSR_XISA_enum</a> { <br /> +&#160;&#160;<a class="el" href="#af05490a8af176ab4ba945d327d448387accf1dd12be89e45df1423a5600789f2c">CSR_MXISA_ZICSR</a> = 0 +, <a class="el" href="#af05490a8af176ab4ba945d327d448387a6979d4389ed9f8605d338fc616d29f0e">CSR_MXISA_ZIFENCEI</a> = 1 +, <a class="el" href="#af05490a8af176ab4ba945d327d448387a79b2b4b20e08ad31b50724a7a27fb20f">CSR_MXISA_ZMMUL</a> = 2 +, <a class="el" href="#af05490a8af176ab4ba945d327d448387af422ae3b5caba59e33a29b5d069597e0">CSR_MXISA_ZXCFU</a> = 3 +, <br /> +&#160;&#160;<a class="el" href="#af05490a8af176ab4ba945d327d448387a56ec3195d0d27f362f58fadb2e037ed1">CSR_MXISA_ZFINX</a> = 5 +, <a class="el" href="#af05490a8af176ab4ba945d327d448387ab1f289cfaa9f54f7831a2abcdf9fca2e">CSR_MXISA_ZICOND</a> = 6 +, <a class="el" href="#af05490a8af176ab4ba945d327d448387a42a3b78195741af4b6aeeb98cbea46fe">CSR_MXISA_ZICNTR</a> = 7 +, <a class="el" href="#af05490a8af176ab4ba945d327d448387a6938948290d86b0ad25923f35d6c86d3">CSR_MXISA_SMPMP</a> = 8 +, <br /> +&#160;&#160;<a class="el" href="#af05490a8af176ab4ba945d327d448387ac13e6883af3a9da18057462239b9fb34">CSR_MXISA_ZIHPM</a> = 9 +, <a class="el" href="#af05490a8af176ab4ba945d327d448387ab6aec595e6aa5ce7c98c7806d23d7af5">CSR_MXISA_SDEXT</a> = 10 +, <a class="el" href="#af05490a8af176ab4ba945d327d448387a59eae4272528f589f299ef9cce45af5b">CSR_MXISA_SDTRIG</a> = 11 +, <a class="el" href="#af05490a8af176ab4ba945d327d448387a9b121ec0ad6271b6e07658f861015f6a">CSR_MXISA_IS_SIM</a> = 20 +, <br /> +&#160;&#160;<a class="el" href="#af05490a8af176ab4ba945d327d448387a6843c660d75f33e4252c7fccd4565a2d">CSR_MXISA_RFHWRST</a> = 29 +, <a class="el" href="#af05490a8af176ab4ba945d327d448387a48e57689f8a5b51d9ee9d648da7efc64">CSR_MXISA_FASTMUL</a> = 30 +, <a class="el" href="#af05490a8af176ab4ba945d327d448387ad5ac9e2188757e6c42c159f0c5887868">CSR_MXISA_FASTSHIFT</a> = 31 +<br /> + }</td></tr> +<tr class="separator:af05490a8af176ab4ba945d327d448387"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a5cb925a3e41efd5e767bb39b3ee60cfe" id="r_a5cb925a3e41efd5e767bb39b3ee60cfe"><td class="memItemLeft" align="right" valign="top">enum &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a5cb925a3e41efd5e767bb39b3ee60cfe">NEORV32_HPMCNT_EVENT_enum</a> { <br /> +&#160;&#160;<a class="el" href="#a5cb925a3e41efd5e767bb39b3ee60cfea2b683572525adc02ce0910031cfea914">HPMCNT_EVENT_CY</a> = 0 +, <a class="el" href="#a5cb925a3e41efd5e767bb39b3ee60cfea578ef6fc107c22b5cb7be5950f695640">HPMCNT_EVENT_TM</a> = 1 +, <a class="el" href="#a5cb925a3e41efd5e767bb39b3ee60cfeaab438295e5f00ffe4c2457a54ee9bfc4">HPMCNT_EVENT_IR</a> = 2 +, <a class="el" href="#a5cb925a3e41efd5e767bb39b3ee60cfea685ed663611d988702ec59c254eb61dd">HPMCNT_EVENT_COMPR</a> = 3 +, <br /> +&#160;&#160;<a class="el" href="#a5cb925a3e41efd5e767bb39b3ee60cfeabcb123b5b150b4413e5fd48475faab27">HPMCNT_EVENT_WAIT_DIS</a> = 4 +, <a class="el" href="#a5cb925a3e41efd5e767bb39b3ee60cfeaffbb04d0053ebd079c6cacb4e5e7ed6b">HPMCNT_EVENT_WAIT_ALU</a> = 5 +, <a class="el" href="#a5cb925a3e41efd5e767bb39b3ee60cfea9e1e2b50352b2555e9c64e76776919a6">HPMCNT_EVENT_BRANCH</a> = 6 +, <a class="el" href="#a5cb925a3e41efd5e767bb39b3ee60cfea0f15c5a824cb1678423ac4ef72a5f4f5">HPMCNT_EVENT_BRANCHED</a> = 7 +, <br /> +&#160;&#160;<a class="el" href="#a5cb925a3e41efd5e767bb39b3ee60cfea1a06f216e1a12afa0b90d6e1218b3c91">HPMCNT_EVENT_LOAD</a> = 8 +, <a class="el" href="#a5cb925a3e41efd5e767bb39b3ee60cfea6a942852e3cd85616a63addb8e9d76f2">HPMCNT_EVENT_STORE</a> = 9 +, <a class="el" href="#a5cb925a3e41efd5e767bb39b3ee60cfea67a59934bc66bc7ccf82d24fe8a18a3b">HPMCNT_EVENT_WAIT_LSU</a> = 10 +, <a class="el" href="#a5cb925a3e41efd5e767bb39b3ee60cfea3a4f5bf9251def87a71162dbcf9043c5">HPMCNT_EVENT_TRAP</a> = 11 +<br /> + }</td></tr> +<tr class="separator:a5cb925a3e41efd5e767bb39b3ee60cfe"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:abc0e8daad1e9beda4d9950452cc930ea" id="r_abc0e8daad1e9beda4d9950452cc930ea"><td class="memItemLeft" align="right" valign="top">enum &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#abc0e8daad1e9beda4d9950452cc930ea">NEORV32_PMPCFG_ATTRIBUTES_enum</a> { <br /> +&#160;&#160;<a class="el" href="#abc0e8daad1e9beda4d9950452cc930eaad3aca82a2ab57364e83f677d3d4f71a6">PMPCFG_R</a> = 0 +, <a class="el" href="#abc0e8daad1e9beda4d9950452cc930eaa7689905760f917499b1151cced384d2f">PMPCFG_W</a> = 1 +, <a class="el" href="#abc0e8daad1e9beda4d9950452cc930eaaec94712deafba09c0cf956c6fd68fa8d">PMPCFG_X</a> = 2 +, <a class="el" href="#abc0e8daad1e9beda4d9950452cc930eaaae1e6440956ad6b7cbf6062aa50f43b1">PMPCFG_A_LSB</a> = 3 +, <br /> +&#160;&#160;<a class="el" href="#abc0e8daad1e9beda4d9950452cc930eaa67ad3243eeb74f86a01efbade76f21e4">PMPCFG_A_MSB</a> = 4 +, <a class="el" href="#abc0e8daad1e9beda4d9950452cc930eaa59c294bc43d2117bb55e301eec683f14">PMPCFG_L</a> = 7 +<br /> + }</td></tr> +<tr class="separator:abc0e8daad1e9beda4d9950452cc930ea"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a8f2418fb5e2175f35ee2362469ce01f5" id="r_a8f2418fb5e2175f35ee2362469ce01f5"><td class="memItemLeft" align="right" valign="top">enum &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a8f2418fb5e2175f35ee2362469ce01f5">NEORV32_PMP_MODES_enum</a> { <a class="el" href="#a8f2418fb5e2175f35ee2362469ce01f5a003ccfae4aae1dad4fd65d5d4c7737c4">PMP_OFF</a> = 0 +, <a class="el" href="#a8f2418fb5e2175f35ee2362469ce01f5a629a81a205abee94bad9d5bb5dfa26b1">PMP_TOR</a> = 1 +, <a class="el" href="#a8f2418fb5e2175f35ee2362469ce01f5aae0e0c33b0d034cb50286239f955d892">PMP_NA4</a> = 2 +, <a class="el" href="#a8f2418fb5e2175f35ee2362469ce01f5ad555e9dfc0c00612bdea623617ff2820">PMP_NAPOT</a> = 3 + }</td></tr> +<tr class="separator:a8f2418fb5e2175f35ee2362469ce01f5"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:acb0fcbc551fec4c45676ff1317be24e1" id="r_acb0fcbc551fec4c45676ff1317be24e1"><td class="memItemLeft" align="right" valign="top">enum &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#acb0fcbc551fec4c45676ff1317be24e1">NEORV32_EXCEPTION_CODES_enum</a> { <br /> +&#160;&#160;<a class="el" href="#acb0fcbc551fec4c45676ff1317be24e1a0a8010d7cc91b9557973a7a118828bee">TRAP_CODE_I_MISALIGNED</a> = 0x00000000U +, <a class="el" href="#acb0fcbc551fec4c45676ff1317be24e1a6a0ebfce4e18f36aeb43d5a65445cfe1">TRAP_CODE_I_ACCESS</a> = 0x00000001U +, <a class="el" href="#acb0fcbc551fec4c45676ff1317be24e1af1ad8f557f3b685b59a913611e1da173">TRAP_CODE_I_ILLEGAL</a> = 0x00000002U +, <a class="el" href="#acb0fcbc551fec4c45676ff1317be24e1a2c9510cb7583a0144f96678fc217335e">TRAP_CODE_BREAKPOINT</a> = 0x00000003U +, <br /> +&#160;&#160;<a class="el" href="#acb0fcbc551fec4c45676ff1317be24e1a69e68a954da0bb33d1624484a6777ff9">TRAP_CODE_L_MISALIGNED</a> = 0x00000004U +, <a class="el" href="#acb0fcbc551fec4c45676ff1317be24e1a28448f0c670169140dc28b6794310cea">TRAP_CODE_L_ACCESS</a> = 0x00000005U +, <a class="el" href="#acb0fcbc551fec4c45676ff1317be24e1a19708405f9f6300edf6b992c6d408a2d">TRAP_CODE_S_MISALIGNED</a> = 0x00000006U +, <a class="el" href="#acb0fcbc551fec4c45676ff1317be24e1a70bcfc75fe1056d93a3606f78c0cb887">TRAP_CODE_S_ACCESS</a> = 0x00000007U +, <br /> +&#160;&#160;<a class="el" href="#acb0fcbc551fec4c45676ff1317be24e1aa102472d6a264bb92e0581ccaa413e02">TRAP_CODE_UENV_CALL</a> = 0x00000008U +, <a class="el" href="#acb0fcbc551fec4c45676ff1317be24e1a20e5a2680f2f5956bfa92852d5544eac">TRAP_CODE_MENV_CALL</a> = 0x0000000bU +, <a class="el" href="#acb0fcbc551fec4c45676ff1317be24e1ae0cebf99f36ef6be60e4a9d2c9f894b0">TRAP_CODE_MSI</a> = 0x80000003U +, <a class="el" href="#acb0fcbc551fec4c45676ff1317be24e1a187ae38819b81672c15808e63c3b46b7">TRAP_CODE_MTI</a> = 0x80000007U +, <br /> +&#160;&#160;<a class="el" href="#acb0fcbc551fec4c45676ff1317be24e1a1a412b9d8eefba7880555d34625d2cc0">TRAP_CODE_MEI</a> = 0x8000000bU +, <a class="el" href="#acb0fcbc551fec4c45676ff1317be24e1a0cef77904935798d247d8396838297c1">TRAP_CODE_FIRQ_0</a> = 0x80000010U +, <a class="el" href="#acb0fcbc551fec4c45676ff1317be24e1ae0b1049ae7f8cbfb6ff216e69ed5dae7">TRAP_CODE_FIRQ_1</a> = 0x80000011U +, <a class="el" href="#acb0fcbc551fec4c45676ff1317be24e1ad753d3e2563b4fd663430af9f3888dc7">TRAP_CODE_FIRQ_2</a> = 0x80000012U +, <br /> +&#160;&#160;<a class="el" href="#acb0fcbc551fec4c45676ff1317be24e1a356f8485166529503d0fb246bd0aeeb0">TRAP_CODE_FIRQ_3</a> = 0x80000013U +, <a class="el" href="#acb0fcbc551fec4c45676ff1317be24e1aaa8e7bb251852ef75a78be71eef0b547">TRAP_CODE_FIRQ_4</a> = 0x80000014U +, <a class="el" href="#acb0fcbc551fec4c45676ff1317be24e1a5789dfabd8ec265fa0734ddd94e98757">TRAP_CODE_FIRQ_5</a> = 0x80000015U +, <a class="el" href="#acb0fcbc551fec4c45676ff1317be24e1a809e997f55e83c6812c965655511d473">TRAP_CODE_FIRQ_6</a> = 0x80000016U +, <br /> +&#160;&#160;<a class="el" href="#acb0fcbc551fec4c45676ff1317be24e1aeab719bcce9e9551bd6da65a7ae08a26">TRAP_CODE_FIRQ_7</a> = 0x80000017U +, <a class="el" href="#acb0fcbc551fec4c45676ff1317be24e1abfd21d1380dcacb9282e525da104d916">TRAP_CODE_FIRQ_8</a> = 0x80000018U +, <a class="el" href="#acb0fcbc551fec4c45676ff1317be24e1a350e762a599479fb2c6d23ccc5ee22b4">TRAP_CODE_FIRQ_9</a> = 0x80000019U +, <a class="el" href="#acb0fcbc551fec4c45676ff1317be24e1a4f6b9c6bba91fe04becb776ad22dcf42">TRAP_CODE_FIRQ_10</a> = 0x8000001aU +, <br /> +&#160;&#160;<a class="el" href="#acb0fcbc551fec4c45676ff1317be24e1a874dcc43cf8fbbf2e0614e7db9e38334">TRAP_CODE_FIRQ_11</a> = 0x8000001bU +, <a class="el" href="#acb0fcbc551fec4c45676ff1317be24e1a151f01e5f284f876cafafc7427720e4c">TRAP_CODE_FIRQ_12</a> = 0x8000001cU +, <a class="el" href="#acb0fcbc551fec4c45676ff1317be24e1a7c8e97297cc4dcd6d5a1de65a124f3e9">TRAP_CODE_FIRQ_13</a> = 0x8000001dU +, <a class="el" href="#acb0fcbc551fec4c45676ff1317be24e1a821f813de47eb781ab7715f780da3b1e">TRAP_CODE_FIRQ_14</a> = 0x8000001eU +, <br /> +&#160;&#160;<a class="el" href="#acb0fcbc551fec4c45676ff1317be24e1aa4eeafe2f6f59aff01e29461c664a110">TRAP_CODE_FIRQ_15</a> = 0x8000001fU +<br /> + }</td></tr> +<tr class="separator:acb0fcbc551fec4c45676ff1317be24e1"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>Control and Status Registers (CSR) definitions. </p> +<dl class="section see"><dt>See also</dt><dd><a href="https://stnolting.github.io/neorv32/sw/files.html">https://stnolting.github.io/neorv32/sw/files.html</a> </dd></dl> +</div><h2 class="groupheader">Enumeration Type Documentation</h2> +<a id="ac065a8cc32eed9a69ea1798492a69f49" name="ac065a8cc32eed9a69ea1798492a69f49"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ac065a8cc32eed9a69ea1798492a69f49">&#9670;&#160;</a></span>NEORV32_CSR_enum</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">enum <a class="el" href="#ac065a8cc32eed9a69ea1798492a69f49">NEORV32_CSR_enum</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Available CPU Control and Status Registers (CSRs) </p> +<table class="fieldtable"> +<tr><th colspan="2">Enumerator</th></tr><tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49a625f606c14fd4d7224d7109e10508e7a" name="ac065a8cc32eed9a69ea1798492a69f49a625f606c14fd4d7224d7109e10508e7a"></a>CSR_FFLAGS&#160;</td><td class="fielddoc"><p>0x001 - fflags: Floating-point accrued exception flags </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49a7f198c465959dde37b7056dd06d45812" name="ac065a8cc32eed9a69ea1798492a69f49a7f198c465959dde37b7056dd06d45812"></a>CSR_FRM&#160;</td><td class="fielddoc"><p>0x002 - frm: Floating-point dynamic rounding mode </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49a5e1abf46b4f55bd18e1d132b32696ab6" name="ac065a8cc32eed9a69ea1798492a69f49a5e1abf46b4f55bd18e1d132b32696ab6"></a>CSR_FCSR&#160;</td><td class="fielddoc"><p>0x003 - fcsr: Floating-point control/status register (frm + fflags) </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49ad0e5de789d6390f750b8af03cdd15450" name="ac065a8cc32eed9a69ea1798492a69f49ad0e5de789d6390f750b8af03cdd15450"></a>CSR_MSTATUS&#160;</td><td class="fielddoc"><p>0x300 - mstatus: Machine status register </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49ade079242596ce14ce1ba9842ed29b84c" name="ac065a8cc32eed9a69ea1798492a69f49ade079242596ce14ce1ba9842ed29b84c"></a>CSR_MISA&#160;</td><td class="fielddoc"><p>0x301 - misa: Machine ISA and extensions </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49acc0f9f5f3b5702f1b57f2ba3b6b62610" name="ac065a8cc32eed9a69ea1798492a69f49acc0f9f5f3b5702f1b57f2ba3b6b62610"></a>CSR_MIE&#160;</td><td class="fielddoc"><p>0x304 - mie: Machine interrupt-enable register </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49aa632d218400268df6dc6b289ff088d21" name="ac065a8cc32eed9a69ea1798492a69f49aa632d218400268df6dc6b289ff088d21"></a>CSR_MTVEC&#160;</td><td class="fielddoc"><p>0x305 - mtvec: Machine trap-handler base address </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49a1860dd9579906c67a3565063043dcf78" name="ac065a8cc32eed9a69ea1798492a69f49a1860dd9579906c67a3565063043dcf78"></a>CSR_MCOUNTEREN&#160;</td><td class="fielddoc"><p>0x305 - mcounteren: Machine counter enable register </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49ac2541060307369b2031e9ec07bbd0067" name="ac065a8cc32eed9a69ea1798492a69f49ac2541060307369b2031e9ec07bbd0067"></a>CSR_MSTATUSH&#160;</td><td class="fielddoc"><p>0x310 - mstatush: Machine status register - high word </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49a3ce1dc0e2810f0df78feaa1c607a5ca6" name="ac065a8cc32eed9a69ea1798492a69f49a3ce1dc0e2810f0df78feaa1c607a5ca6"></a>CSR_MCOUNTINHIBIT&#160;</td><td class="fielddoc"><p>0x320 - mcountinhibit: Machine counter-inhibit register </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49a9c55619ffb05e84b7210e2d47326fa98" name="ac065a8cc32eed9a69ea1798492a69f49a9c55619ffb05e84b7210e2d47326fa98"></a>CSR_MENVCFG&#160;</td><td class="fielddoc"><p>0x30a - menvcfg: Machine environment configuration register - low word </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49a46b8d3c288cbbfbf5a0af6e5cd8c5bc8" name="ac065a8cc32eed9a69ea1798492a69f49a46b8d3c288cbbfbf5a0af6e5cd8c5bc8"></a>CSR_MENVCFGH&#160;</td><td class="fielddoc"><p>0x31a - menvcfgh: Machine environment configuration register - high word </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49a4a93ac5ab276cfd2f9cd296c8ce1bff6" name="ac065a8cc32eed9a69ea1798492a69f49a4a93ac5ab276cfd2f9cd296c8ce1bff6"></a>CSR_MHPMEVENT3&#160;</td><td class="fielddoc"><p>0x323 - mhpmevent3: Machine hardware performance monitor event selector 3 <br /> + </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49ab5f998725e002ffc2ff516ee973fe459" name="ac065a8cc32eed9a69ea1798492a69f49ab5f998725e002ffc2ff516ee973fe459"></a>CSR_MHPMEVENT4&#160;</td><td class="fielddoc"><p>0x324 - mhpmevent4: Machine hardware performance monitor event selector 4 <br /> + </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49a2524659ca2785af51af7acf9cd560a9d" name="ac065a8cc32eed9a69ea1798492a69f49a2524659ca2785af51af7acf9cd560a9d"></a>CSR_MHPMEVENT5&#160;</td><td class="fielddoc"><p>0x325 - mhpmevent5: Machine hardware performance monitor event selector 5 <br /> + </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49a1cfa1e3bc3c8a1c9a86c251a510d11cd" name="ac065a8cc32eed9a69ea1798492a69f49a1cfa1e3bc3c8a1c9a86c251a510d11cd"></a>CSR_MHPMEVENT6&#160;</td><td class="fielddoc"><p>0x326 - mhpmevent6: Machine hardware performance monitor event selector 6 <br /> + </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49a2e53e6e01ca8d1b801f6dfba602f3f59" name="ac065a8cc32eed9a69ea1798492a69f49a2e53e6e01ca8d1b801f6dfba602f3f59"></a>CSR_MHPMEVENT7&#160;</td><td class="fielddoc"><p>0x327 - mhpmevent7: Machine hardware performance monitor event selector 7 <br /> + </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49ad6296ca83bbe1280624f3c21adbd8a79" name="ac065a8cc32eed9a69ea1798492a69f49ad6296ca83bbe1280624f3c21adbd8a79"></a>CSR_MHPMEVENT8&#160;</td><td class="fielddoc"><p>0x328 - mhpmevent8: Machine hardware performance monitor event selector 8 <br /> + </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49af6727a9bdd60ccf020812095b7396632" name="ac065a8cc32eed9a69ea1798492a69f49af6727a9bdd60ccf020812095b7396632"></a>CSR_MHPMEVENT9&#160;</td><td class="fielddoc"><p>0x329 - mhpmevent9: Machine hardware performance monitor event selector 9 <br /> + </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49a23850b1804966cde2c1e84cde752d512" name="ac065a8cc32eed9a69ea1798492a69f49a23850b1804966cde2c1e84cde752d512"></a>CSR_MHPMEVENT10&#160;</td><td class="fielddoc"><p>0x32a - mhpmevent10: Machine hardware performance monitor event selector 10 </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49a7fb1de2019dd2b548084d5ca1630efbf" name="ac065a8cc32eed9a69ea1798492a69f49a7fb1de2019dd2b548084d5ca1630efbf"></a>CSR_MHPMEVENT11&#160;</td><td class="fielddoc"><p>0x32b - mhpmevent11: Machine hardware performance monitor event selector 11 </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49ad648b5ece209d47e9484fd7aa83e8e5f" name="ac065a8cc32eed9a69ea1798492a69f49ad648b5ece209d47e9484fd7aa83e8e5f"></a>CSR_MHPMEVENT12&#160;</td><td class="fielddoc"><p>0x32c - mhpmevent12: Machine hardware performance monitor event selector 12 </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49a8c31899b81bb5dba9b92a0f0ca71aea6" name="ac065a8cc32eed9a69ea1798492a69f49a8c31899b81bb5dba9b92a0f0ca71aea6"></a>CSR_MHPMEVENT13&#160;</td><td class="fielddoc"><p>0x32d - mhpmevent13: Machine hardware performance monitor event selector 13 </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49a964a6a50d0138447fad47e9c982a7ba4" name="ac065a8cc32eed9a69ea1798492a69f49a964a6a50d0138447fad47e9c982a7ba4"></a>CSR_MHPMEVENT14&#160;</td><td class="fielddoc"><p>0x32e - mhpmevent14: Machine hardware performance monitor event selector 14 </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49a06dfdeed757606529e4a99c033691b54" name="ac065a8cc32eed9a69ea1798492a69f49a06dfdeed757606529e4a99c033691b54"></a>CSR_MHPMEVENT15&#160;</td><td class="fielddoc"><p>0x32f - mhpmevent15: Machine hardware performance monitor event selector 15 </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49ae29976bb072639975ad0cdb985c7f004" name="ac065a8cc32eed9a69ea1798492a69f49ae29976bb072639975ad0cdb985c7f004"></a>CSR_MSCRATCH&#160;</td><td class="fielddoc"><p>0x340 - mscratch: Machine scratch register </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49a5d60a25a66754066589e8facb7d41153" name="ac065a8cc32eed9a69ea1798492a69f49a5d60a25a66754066589e8facb7d41153"></a>CSR_MEPC&#160;</td><td class="fielddoc"><p>0x341 - mepc: Machine exception program counter </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49a2e14b57fee5376741634db7980a5005b" name="ac065a8cc32eed9a69ea1798492a69f49a2e14b57fee5376741634db7980a5005b"></a>CSR_MCAUSE&#160;</td><td class="fielddoc"><p>0x342 - mcause: Machine trap cause </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49a76d30359e3b54197fb53f9939734cf1e" name="ac065a8cc32eed9a69ea1798492a69f49a76d30359e3b54197fb53f9939734cf1e"></a>CSR_MTVAL&#160;</td><td class="fielddoc"><p>0x343 - mtval: Machine trap value </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49addb485275c954d1181d5bd4e4609082c" name="ac065a8cc32eed9a69ea1798492a69f49addb485275c954d1181d5bd4e4609082c"></a>CSR_MIP&#160;</td><td class="fielddoc"><p>0x344 - mip: Machine interrupt pending register </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49a4f229c169ada239033a1383412ce58c8" name="ac065a8cc32eed9a69ea1798492a69f49a4f229c169ada239033a1383412ce58c8"></a>CSR_MTINST&#160;</td><td class="fielddoc"><p>0x34a - mtinst: Machine trap instruction </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49af1a79349e46a4829af78d2cdfd0dc44f" name="ac065a8cc32eed9a69ea1798492a69f49af1a79349e46a4829af78d2cdfd0dc44f"></a>CSR_PMPCFG0&#160;</td><td class="fielddoc"><p>0x3a0 - pmpcfg0: Physical memory protection configuration register 0 (regions 0..3) </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49a22eea318ec1ac72cc14e133b71ef4b16" name="ac065a8cc32eed9a69ea1798492a69f49a22eea318ec1ac72cc14e133b71ef4b16"></a>CSR_PMPCFG1&#160;</td><td class="fielddoc"><p>0x3a1 - pmpcfg1: Physical memory protection configuration register 1 (regions 4..7) </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49a0c9492f6b956f088847f72b28e7b1446" name="ac065a8cc32eed9a69ea1798492a69f49a0c9492f6b956f088847f72b28e7b1446"></a>CSR_PMPCFG2&#160;</td><td class="fielddoc"><p>0x3a2 - pmpcfg2: Physical memory protection configuration register 2 (regions 8..11) </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49a067ed3778590ae97dc9b16069f0ed850" name="ac065a8cc32eed9a69ea1798492a69f49a067ed3778590ae97dc9b16069f0ed850"></a>CSR_PMPCFG3&#160;</td><td class="fielddoc"><p>0x3a3 - pmpcfg3: Physical memory protection configuration register 3 (regions 12..15) </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49a8941071db6145d34fff842249c0dcb9f" name="ac065a8cc32eed9a69ea1798492a69f49a8941071db6145d34fff842249c0dcb9f"></a>CSR_PMPADDR0&#160;</td><td class="fielddoc"><p>0x3b0 - pmpaddr0: Physical memory protection address register 0 </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49a6a2933f3a1fa243de02db8a795e3ca41" name="ac065a8cc32eed9a69ea1798492a69f49a6a2933f3a1fa243de02db8a795e3ca41"></a>CSR_PMPADDR1&#160;</td><td class="fielddoc"><p>0x3b1 - pmpaddr1: Physical memory protection address register 1 </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49aa0b8c0561e8a778dce9c3b86499ffc50" name="ac065a8cc32eed9a69ea1798492a69f49aa0b8c0561e8a778dce9c3b86499ffc50"></a>CSR_PMPADDR2&#160;</td><td class="fielddoc"><p>0x3b2 - pmpaddr2: Physical memory protection address register 2 </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49a89bad989197e9358563557311b3c97e9" name="ac065a8cc32eed9a69ea1798492a69f49a89bad989197e9358563557311b3c97e9"></a>CSR_PMPADDR3&#160;</td><td class="fielddoc"><p>0x3b3 - pmpaddr3: Physical memory protection address register 3 </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49ace4529c53ad2d46767f86d920eada507" name="ac065a8cc32eed9a69ea1798492a69f49ace4529c53ad2d46767f86d920eada507"></a>CSR_PMPADDR4&#160;</td><td class="fielddoc"><p>0x3b4 - pmpaddr4: Physical memory protection address register 4 </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49ad9e78f71409fd7783cc2ae7c28b5e42c" name="ac065a8cc32eed9a69ea1798492a69f49ad9e78f71409fd7783cc2ae7c28b5e42c"></a>CSR_PMPADDR5&#160;</td><td class="fielddoc"><p>0x3b5 - pmpaddr5: Physical memory protection address register 5 </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49af57b5b7b57cd6e8b3489a27dfd702444" name="ac065a8cc32eed9a69ea1798492a69f49af57b5b7b57cd6e8b3489a27dfd702444"></a>CSR_PMPADDR6&#160;</td><td class="fielddoc"><p>0x3b6 - pmpaddr6: Physical memory protection address register 6 </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49ae8ea19cf3e527dbc0d36a43dfd1b7346" name="ac065a8cc32eed9a69ea1798492a69f49ae8ea19cf3e527dbc0d36a43dfd1b7346"></a>CSR_PMPADDR7&#160;</td><td class="fielddoc"><p>0x3b7 - pmpaddr7: Physical memory protection address register 7 </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49aec68bf7e26e44170c24599f7c6a8365b" name="ac065a8cc32eed9a69ea1798492a69f49aec68bf7e26e44170c24599f7c6a8365b"></a>CSR_PMPADDR8&#160;</td><td class="fielddoc"><p>0x3b8 - pmpaddr8: Physical memory protection address register 8 </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49a54d38c8cf364d886eb7ac64463eedf77" name="ac065a8cc32eed9a69ea1798492a69f49a54d38c8cf364d886eb7ac64463eedf77"></a>CSR_PMPADDR9&#160;</td><td class="fielddoc"><p>0x3b9 - pmpaddr9: Physical memory protection address register 9 </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49ad97b6fe934a3bed6b02d0c8d81165d60" name="ac065a8cc32eed9a69ea1798492a69f49ad97b6fe934a3bed6b02d0c8d81165d60"></a>CSR_PMPADDR10&#160;</td><td class="fielddoc"><p>0x3ba - pmpaddr10: Physical memory protection address register 10 </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49a3e5708c0f79cf58ae761b6bb8c2a4383" name="ac065a8cc32eed9a69ea1798492a69f49a3e5708c0f79cf58ae761b6bb8c2a4383"></a>CSR_PMPADDR11&#160;</td><td class="fielddoc"><p>0x3bb - pmpaddr11: Physical memory protection address register 11 </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49a23026793ee53c8d55d23f63195368a6b" name="ac065a8cc32eed9a69ea1798492a69f49a23026793ee53c8d55d23f63195368a6b"></a>CSR_PMPADDR12&#160;</td><td class="fielddoc"><p>0x3bc - pmpaddr12: Physical memory protection address register 12 </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49a30879e88b250d3e94d9d9e728ffcc2cc" name="ac065a8cc32eed9a69ea1798492a69f49a30879e88b250d3e94d9d9e728ffcc2cc"></a>CSR_PMPADDR13&#160;</td><td class="fielddoc"><p>0x3bd - pmpaddr13: Physical memory protection address register 13 </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49a91a8b5008b4e08ab34c1516e21bf0ba8" name="ac065a8cc32eed9a69ea1798492a69f49a91a8b5008b4e08ab34c1516e21bf0ba8"></a>CSR_PMPADDR14&#160;</td><td class="fielddoc"><p>0x3be - pmpaddr14: Physical memory protection address register 14 </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49a6879b4bf5d2db92d236b9091df4841f2" name="ac065a8cc32eed9a69ea1798492a69f49a6879b4bf5d2db92d236b9091df4841f2"></a>CSR_PMPADDR15&#160;</td><td class="fielddoc"><p>0x3bf - pmpaddr15: Physical memory protection address register 15 </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49aaae2f0b2e3f5a31dff933868873f6d5d" name="ac065a8cc32eed9a69ea1798492a69f49aaae2f0b2e3f5a31dff933868873f6d5d"></a>CSR_TSELECT&#160;</td><td class="fielddoc"><p>0x7a0 - tselect: Trigger select </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49a80eab0e17f5fe41edde485044674dc57" name="ac065a8cc32eed9a69ea1798492a69f49a80eab0e17f5fe41edde485044674dc57"></a>CSR_TDATA1&#160;</td><td class="fielddoc"><p>0x7a1 - tdata1: Trigger data register 0 </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49acf336638697242b691b691dc56b9aadc" name="ac065a8cc32eed9a69ea1798492a69f49acf336638697242b691b691dc56b9aadc"></a>CSR_TDATA2&#160;</td><td class="fielddoc"><p>0x7a2 - tdata2: Trigger data register 1 </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49af67c819c104f7e3ec34f2cbb847cf83b" name="ac065a8cc32eed9a69ea1798492a69f49af67c819c104f7e3ec34f2cbb847cf83b"></a>CSR_TINFO&#160;</td><td class="fielddoc"><p>0x7a4 - tinfo: Trigger info </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49a6bb3ba59a25803d6f98faad67609a9a9" name="ac065a8cc32eed9a69ea1798492a69f49a6bb3ba59a25803d6f98faad67609a9a9"></a>CSR_DCSR&#160;</td><td class="fielddoc"><p>0x7b0 - dcsr: Debug status and control register </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49af4c98d949d2eb44f2518fdf314344d3b" name="ac065a8cc32eed9a69ea1798492a69f49af4c98d949d2eb44f2518fdf314344d3b"></a>CSR_DPC&#160;</td><td class="fielddoc"><p>0x7b1 - dpc: Debug program counter </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49a0f4a1ae740efd80d14d21e90f355e9d7" name="ac065a8cc32eed9a69ea1798492a69f49a0f4a1ae740efd80d14d21e90f355e9d7"></a>CSR_DSCRATCH0&#160;</td><td class="fielddoc"><p>0x7b2 - dscratch0: Debug scratch register </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49ae0e9cf0b99b8614ea0b870d38970281f" name="ac065a8cc32eed9a69ea1798492a69f49ae0e9cf0b99b8614ea0b870d38970281f"></a>CSR_CFUREG0&#160;</td><td class="fielddoc"><p>0x800 - cfureg0: custom CFU CSR 0 </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49a382304065a6db773f925b80b9447b8a8" name="ac065a8cc32eed9a69ea1798492a69f49a382304065a6db773f925b80b9447b8a8"></a>CSR_CFUREG1&#160;</td><td class="fielddoc"><p>0x801 - cfureg1: custom CFU CSR 1 </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49a427d7cf036b49efd46166c01f0504b68" name="ac065a8cc32eed9a69ea1798492a69f49a427d7cf036b49efd46166c01f0504b68"></a>CSR_CFUREG2&#160;</td><td class="fielddoc"><p>0x802 - cfureg2: custom CFU CSR 2 </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49aefefa1cff0cf5d01109486e5a8bebedf" name="ac065a8cc32eed9a69ea1798492a69f49aefefa1cff0cf5d01109486e5a8bebedf"></a>CSR_CFUREG3&#160;</td><td class="fielddoc"><p>0x803 - cfureg3: custom CFU CSR 3 </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49a32c22641ed66c6d20902306a2b1fad77" name="ac065a8cc32eed9a69ea1798492a69f49a32c22641ed66c6d20902306a2b1fad77"></a>CSR_MCYCLE&#160;</td><td class="fielddoc"><p>0xb00 - mcycle: Machine cycle counter low word </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49a98f5e2cf2d5dbb0125a222b0065c86eb" name="ac065a8cc32eed9a69ea1798492a69f49a98f5e2cf2d5dbb0125a222b0065c86eb"></a>CSR_MINSTRET&#160;</td><td class="fielddoc"><p>0xb02 - minstret: Machine instructions-retired counter low word </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49ae0a96f499dcde474af6ee620fbb1ebdc" name="ac065a8cc32eed9a69ea1798492a69f49ae0a96f499dcde474af6ee620fbb1ebdc"></a>CSR_MHPMCOUNTER3&#160;</td><td class="fielddoc"><p>0xb03 - mhpmcounter3: Machine hardware performance monitor 3 counter low word </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49a9b84bd948dd52a7779b5fd16beddaab9" name="ac065a8cc32eed9a69ea1798492a69f49a9b84bd948dd52a7779b5fd16beddaab9"></a>CSR_MHPMCOUNTER4&#160;</td><td class="fielddoc"><p>0xb04 - mhpmcounter4: Machine hardware performance monitor 4 counter low word </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49af15d389bb8f91c989df488d231666394" name="ac065a8cc32eed9a69ea1798492a69f49af15d389bb8f91c989df488d231666394"></a>CSR_MHPMCOUNTER5&#160;</td><td class="fielddoc"><p>0xb05 - mhpmcounter5: Machine hardware performance monitor 5 counter low word </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49af65b9e99b9cadb3cb8d37f97cdbfeb9d" name="ac065a8cc32eed9a69ea1798492a69f49af65b9e99b9cadb3cb8d37f97cdbfeb9d"></a>CSR_MHPMCOUNTER6&#160;</td><td class="fielddoc"><p>0xb06 - mhpmcounter6: Machine hardware performance monitor 6 counter low word </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49a919f39b0d299feb80403b42a466de444" name="ac065a8cc32eed9a69ea1798492a69f49a919f39b0d299feb80403b42a466de444"></a>CSR_MHPMCOUNTER7&#160;</td><td class="fielddoc"><p>0xb07 - mhpmcounter7: Machine hardware performance monitor 7 counter low word </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49a5a4cde90c547e913bddc719b3ab75e79" name="ac065a8cc32eed9a69ea1798492a69f49a5a4cde90c547e913bddc719b3ab75e79"></a>CSR_MHPMCOUNTER8&#160;</td><td class="fielddoc"><p>0xb08 - mhpmcounter8: Machine hardware performance monitor 8 counter low word </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49a18c2a249f1f7852f42f9e10dc59d46bb" name="ac065a8cc32eed9a69ea1798492a69f49a18c2a249f1f7852f42f9e10dc59d46bb"></a>CSR_MHPMCOUNTER9&#160;</td><td class="fielddoc"><p>0xb09 - mhpmcounter9: Machine hardware performance monitor 9 counter low word </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49a575e5342d8ec304c32dbbe99d6fd6c0f" name="ac065a8cc32eed9a69ea1798492a69f49a575e5342d8ec304c32dbbe99d6fd6c0f"></a>CSR_MHPMCOUNTER10&#160;</td><td class="fielddoc"><p>0xb0a - mhpmcounter10: Machine hardware performance monitor 10 counter low word </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49a8840b3d4f45453fc96813ccb369a68e5" name="ac065a8cc32eed9a69ea1798492a69f49a8840b3d4f45453fc96813ccb369a68e5"></a>CSR_MHPMCOUNTER11&#160;</td><td class="fielddoc"><p>0xb0b - mhpmcounter11: Machine hardware performance monitor 11 counter low word </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49a1328a226d36d23cc81740397bde47a4e" name="ac065a8cc32eed9a69ea1798492a69f49a1328a226d36d23cc81740397bde47a4e"></a>CSR_MHPMCOUNTER12&#160;</td><td class="fielddoc"><p>0xb0c - mhpmcounter12: Machine hardware performance monitor 12 counter low word </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49a9bdd102877ff50d38c86c3d741aeb4b0" name="ac065a8cc32eed9a69ea1798492a69f49a9bdd102877ff50d38c86c3d741aeb4b0"></a>CSR_MHPMCOUNTER13&#160;</td><td class="fielddoc"><p>0xb0d - mhpmcounter13: Machine hardware performance monitor 13 counter low word </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49adae22d860d8162e15120051951e45229" name="ac065a8cc32eed9a69ea1798492a69f49adae22d860d8162e15120051951e45229"></a>CSR_MHPMCOUNTER14&#160;</td><td class="fielddoc"><p>0xb0e - mhpmcounter14: Machine hardware performance monitor 14 counter low word </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49a20400929087fabba410a098667d2d4ff" name="ac065a8cc32eed9a69ea1798492a69f49a20400929087fabba410a098667d2d4ff"></a>CSR_MHPMCOUNTER15&#160;</td><td class="fielddoc"><p>0xb0f - mhpmcounter15: Machine hardware performance monitor 15 counter low word </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49a28fcfd06ca1012c19cf053e57689687b" name="ac065a8cc32eed9a69ea1798492a69f49a28fcfd06ca1012c19cf053e57689687b"></a>CSR_MCYCLEH&#160;</td><td class="fielddoc"><p>0xb80 - mcycleh: Machine cycle counter high word </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49afffb28b62b9baa127ae3bad919208988" name="ac065a8cc32eed9a69ea1798492a69f49afffb28b62b9baa127ae3bad919208988"></a>CSR_MINSTRETH&#160;</td><td class="fielddoc"><p>0xb82 - minstreth: Machine instructions-retired counter high word </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49a252980a4da90c1f5c1ef85d164f72f25" name="ac065a8cc32eed9a69ea1798492a69f49a252980a4da90c1f5c1ef85d164f72f25"></a>CSR_MHPMCOUNTER3H&#160;</td><td class="fielddoc"><p>0xb83 - mhpmcounter3 : Machine hardware performance monitor 3 counter high word </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49a2e9cfbf3c2828dd4bd92d2b8a1c99f85" name="ac065a8cc32eed9a69ea1798492a69f49a2e9cfbf3c2828dd4bd92d2b8a1c99f85"></a>CSR_MHPMCOUNTER4H&#160;</td><td class="fielddoc"><p>0xb84 - mhpmcounter4h: Machine hardware performance monitor 4 counter high word </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49a7648dd0a47007d44a14e95ba47726599" name="ac065a8cc32eed9a69ea1798492a69f49a7648dd0a47007d44a14e95ba47726599"></a>CSR_MHPMCOUNTER5H&#160;</td><td class="fielddoc"><p>0xb85 - mhpmcounter5h: Machine hardware performance monitor 5 counter high word </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49a49b7bc2df67a6c73a68757de9b218f77" name="ac065a8cc32eed9a69ea1798492a69f49a49b7bc2df67a6c73a68757de9b218f77"></a>CSR_MHPMCOUNTER6H&#160;</td><td class="fielddoc"><p>0xb86 - mhpmcounter6h: Machine hardware performance monitor 6 counter high word </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49ac0183bb6f357ed33136493ae7ded987a" name="ac065a8cc32eed9a69ea1798492a69f49ac0183bb6f357ed33136493ae7ded987a"></a>CSR_MHPMCOUNTER7H&#160;</td><td class="fielddoc"><p>0xb87 - mhpmcounter7h: Machine hardware performance monitor 7 counter high word </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49a9e75518df7d14a009e3a0d5588641ddc" name="ac065a8cc32eed9a69ea1798492a69f49a9e75518df7d14a009e3a0d5588641ddc"></a>CSR_MHPMCOUNTER8H&#160;</td><td class="fielddoc"><p>0xb88 - mhpmcounter8h: Machine hardware performance monitor 8 counter high word </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49a7341886c7a4aed6fc7d8677c016a2cb8" name="ac065a8cc32eed9a69ea1798492a69f49a7341886c7a4aed6fc7d8677c016a2cb8"></a>CSR_MHPMCOUNTER9H&#160;</td><td class="fielddoc"><p>0xb89 - mhpmcounter9h: Machine hardware performance monitor 9 counter high word </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49a1e41d2b27d7e8da14871852d81123cfd" name="ac065a8cc32eed9a69ea1798492a69f49a1e41d2b27d7e8da14871852d81123cfd"></a>CSR_MHPMCOUNTER10H&#160;</td><td class="fielddoc"><p>0xb8a - mhpmcounter10h: Machine hardware performance monitor 10 counter high word </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49a7fd76fcfc0d0dd47e112786bea5e4071" name="ac065a8cc32eed9a69ea1798492a69f49a7fd76fcfc0d0dd47e112786bea5e4071"></a>CSR_MHPMCOUNTER11H&#160;</td><td class="fielddoc"><p>0xb8b - mhpmcounter11h: Machine hardware performance monitor 11 counter high word </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49a332ec2b0740f8e899a1b2ec86f7ee9f2" name="ac065a8cc32eed9a69ea1798492a69f49a332ec2b0740f8e899a1b2ec86f7ee9f2"></a>CSR_MHPMCOUNTER12H&#160;</td><td class="fielddoc"><p>0xb8c - mhpmcounter12h: Machine hardware performance monitor 12 counter high word </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49a5de5c5a036dc594a554d37df9ccf657d" name="ac065a8cc32eed9a69ea1798492a69f49a5de5c5a036dc594a554d37df9ccf657d"></a>CSR_MHPMCOUNTER13H&#160;</td><td class="fielddoc"><p>0xb8d - mhpmcounter13h: Machine hardware performance monitor 13 counter high word </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49ac65bab6fd71439600c8fc549171251fa" name="ac065a8cc32eed9a69ea1798492a69f49ac65bab6fd71439600c8fc549171251fa"></a>CSR_MHPMCOUNTER14H&#160;</td><td class="fielddoc"><p>0xb8e - mhpmcounter14h: Machine hardware performance monitor 14 counter high word </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49af609807e2917f73e27e5f27b38a0fa46" name="ac065a8cc32eed9a69ea1798492a69f49af609807e2917f73e27e5f27b38a0fa46"></a>CSR_MHPMCOUNTER15H&#160;</td><td class="fielddoc"><p>0xb8f - mhpmcounter15h: Machine hardware performance monitor 15 counter high word </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49aaaf0f6b17a06d5922bcfdb47b382137e" name="ac065a8cc32eed9a69ea1798492a69f49aaaf0f6b17a06d5922bcfdb47b382137e"></a>CSR_CYCLE&#160;</td><td class="fielddoc"><p>0xc00 - cycle: User cycle counter low word </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49a8144da8cd8691ac54aa0712685865b66" name="ac065a8cc32eed9a69ea1798492a69f49a8144da8cd8691ac54aa0712685865b66"></a>CSR_INSTRET&#160;</td><td class="fielddoc"><p>0xc02 - instret: User instructions-retired counter low word </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49a3ee699d5b2886c54c92992f66b109b67" name="ac065a8cc32eed9a69ea1798492a69f49a3ee699d5b2886c54c92992f66b109b67"></a>CSR_HPMCOUNTER3&#160;</td><td class="fielddoc"><p>0xc03 - hpmcounter3: User hardware performance monitor 3 counter low word </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49a98ed49716d0d89712863e7a542d38d2a" name="ac065a8cc32eed9a69ea1798492a69f49a98ed49716d0d89712863e7a542d38d2a"></a>CSR_HPMCOUNTER4&#160;</td><td class="fielddoc"><p>0xc04 - hpmcounter4: User hardware performance monitor 4 counter low word </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49ab2376c3b7c3ec0b44105ec1ed951bfb0" name="ac065a8cc32eed9a69ea1798492a69f49ab2376c3b7c3ec0b44105ec1ed951bfb0"></a>CSR_HPMCOUNTER5&#160;</td><td class="fielddoc"><p>0xc05 - hpmcounter5: User hardware performance monitor 5 counter low word </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49aa2f644a4f54ba3834bafa738208c0803" name="ac065a8cc32eed9a69ea1798492a69f49aa2f644a4f54ba3834bafa738208c0803"></a>CSR_HPMCOUNTER6&#160;</td><td class="fielddoc"><p>0xc06 - hpmcounter6: User hardware performance monitor 6 counter low word </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49a125c4d0051548dea9104808b7bee1316" name="ac065a8cc32eed9a69ea1798492a69f49a125c4d0051548dea9104808b7bee1316"></a>CSR_HPMCOUNTER7&#160;</td><td class="fielddoc"><p>0xc07 - hpmcounter7: User hardware performance monitor 7 counter low word </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49acac87125f8c723cc5df4d4169a82852b" name="ac065a8cc32eed9a69ea1798492a69f49acac87125f8c723cc5df4d4169a82852b"></a>CSR_HPMCOUNTER8&#160;</td><td class="fielddoc"><p>0xc08 - hpmcounter8: User hardware performance monitor 8 counter low word </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49ab45ebb3bd861074a15cc2ad874756e8f" name="ac065a8cc32eed9a69ea1798492a69f49ab45ebb3bd861074a15cc2ad874756e8f"></a>CSR_HPMCOUNTER9&#160;</td><td class="fielddoc"><p>0xc09 - hpmcounter9: User hardware performance monitor 9 counter low word </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49aa407e701bdbb9d26f84684b811c008a9" name="ac065a8cc32eed9a69ea1798492a69f49aa407e701bdbb9d26f84684b811c008a9"></a>CSR_HPMCOUNTER10&#160;</td><td class="fielddoc"><p>0xc0a - hpmcounter10: User hardware performance monitor 10 counter low word </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49a9fd1ff4e8a42992c0a3ec02c397dd7f8" name="ac065a8cc32eed9a69ea1798492a69f49a9fd1ff4e8a42992c0a3ec02c397dd7f8"></a>CSR_HPMCOUNTER11&#160;</td><td class="fielddoc"><p>0xc0b - hpmcounter11: User hardware performance monitor 11 counter low word </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49ae58f15a95aa41126819effe046ced804" name="ac065a8cc32eed9a69ea1798492a69f49ae58f15a95aa41126819effe046ced804"></a>CSR_HPMCOUNTER12&#160;</td><td class="fielddoc"><p>0xc0c - hpmcounter12: User hardware performance monitor 12 counter low word </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49a24d8617a6ff2c1e49c9a73853ad9e450" name="ac065a8cc32eed9a69ea1798492a69f49a24d8617a6ff2c1e49c9a73853ad9e450"></a>CSR_HPMCOUNTER13&#160;</td><td class="fielddoc"><p>0xc0d - hpmcounter13: User hardware performance monitor 13 counter low word </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49aa47ed1a4a4f9fcabceed0d6d626d0aaf" name="ac065a8cc32eed9a69ea1798492a69f49aa47ed1a4a4f9fcabceed0d6d626d0aaf"></a>CSR_HPMCOUNTER14&#160;</td><td class="fielddoc"><p>0xc0e - hpmcounter14: User hardware performance monitor 14 counter low word </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49a7277a8f929a5a250f7227fbbdf545dbc" name="ac065a8cc32eed9a69ea1798492a69f49a7277a8f929a5a250f7227fbbdf545dbc"></a>CSR_HPMCOUNTER15&#160;</td><td class="fielddoc"><p>0xc0f - hpmcounter15: User hardware performance monitor 15 counter low word </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49aa276bedb7dab28935163397b4879f6db" name="ac065a8cc32eed9a69ea1798492a69f49aa276bedb7dab28935163397b4879f6db"></a>CSR_CYCLEH&#160;</td><td class="fielddoc"><p>0xc80 - cycleh: User cycle counter high word </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49a9b66978d76260283007d399fc735d153" name="ac065a8cc32eed9a69ea1798492a69f49a9b66978d76260283007d399fc735d153"></a>CSR_INSTRETH&#160;</td><td class="fielddoc"><p>0xc82 - instreth: User instructions-retired counter high word </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49aaa3e6a1ac8999be42d7c13891546bb50" name="ac065a8cc32eed9a69ea1798492a69f49aaa3e6a1ac8999be42d7c13891546bb50"></a>CSR_HPMCOUNTER3H&#160;</td><td class="fielddoc"><p>0xc83 - hpmcounter3h: User hardware performance monitor 3 counter high word </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49a8837ff8d2741639aa69da59659f9a080" name="ac065a8cc32eed9a69ea1798492a69f49a8837ff8d2741639aa69da59659f9a080"></a>CSR_HPMCOUNTER4H&#160;</td><td class="fielddoc"><p>0xc84 - hpmcounter4h: User hardware performance monitor 4 counter high word </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49ad489feaa5ad1feb00d3df71d3e5b0cac" name="ac065a8cc32eed9a69ea1798492a69f49ad489feaa5ad1feb00d3df71d3e5b0cac"></a>CSR_HPMCOUNTER5H&#160;</td><td class="fielddoc"><p>0xc85 - hpmcounter5h: User hardware performance monitor 5 counter high word </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49a438a65757b85f182dfb1f2a06c9ad520" name="ac065a8cc32eed9a69ea1798492a69f49a438a65757b85f182dfb1f2a06c9ad520"></a>CSR_HPMCOUNTER6H&#160;</td><td class="fielddoc"><p>0xc86 - hpmcounter6h: User hardware performance monitor 6 counter high word </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49a6332d4ff090aa7c302d191219e846fff" name="ac065a8cc32eed9a69ea1798492a69f49a6332d4ff090aa7c302d191219e846fff"></a>CSR_HPMCOUNTER7H&#160;</td><td class="fielddoc"><p>0xc87 - hpmcounter7h: User hardware performance monitor 7 counter high word </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49aa8ce8fc8a57dd82872d02b4113249a77" name="ac065a8cc32eed9a69ea1798492a69f49aa8ce8fc8a57dd82872d02b4113249a77"></a>CSR_HPMCOUNTER8H&#160;</td><td class="fielddoc"><p>0xc88 - hpmcounter8h: User hardware performance monitor 8 counter high word </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49acdf793b30919e7fa1b85995abe531a20" name="ac065a8cc32eed9a69ea1798492a69f49acdf793b30919e7fa1b85995abe531a20"></a>CSR_HPMCOUNTER9H&#160;</td><td class="fielddoc"><p>0xc89 - hpmcounter9h: User hardware performance monitor 9 counter high word </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49ae56e95d6d6dd63ff6f5b4192cf48c88b" name="ac065a8cc32eed9a69ea1798492a69f49ae56e95d6d6dd63ff6f5b4192cf48c88b"></a>CSR_HPMCOUNTER10H&#160;</td><td class="fielddoc"><p>0xc8a - hpmcounter10h: User hardware performance monitor 10 counter high word </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49a2af8c5dcc87d92bcce392fb5b3aa065e" name="ac065a8cc32eed9a69ea1798492a69f49a2af8c5dcc87d92bcce392fb5b3aa065e"></a>CSR_HPMCOUNTER11H&#160;</td><td class="fielddoc"><p>0xc8b - hpmcounter11h: User hardware performance monitor 11 counter high word </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49a74359db2583feb7119d4bcaa926242a0" name="ac065a8cc32eed9a69ea1798492a69f49a74359db2583feb7119d4bcaa926242a0"></a>CSR_HPMCOUNTER12H&#160;</td><td class="fielddoc"><p>0xc8c - hpmcounter12h: User hardware performance monitor 12 counter high word </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49a4fa22699e96d6da8665077e3c95891ef" name="ac065a8cc32eed9a69ea1798492a69f49a4fa22699e96d6da8665077e3c95891ef"></a>CSR_HPMCOUNTER13H&#160;</td><td class="fielddoc"><p>0xc8d - hpmcounter13h: User hardware performance monitor 13 counter high word </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49a03f29e792be2854efc9e66d710b78a1d" name="ac065a8cc32eed9a69ea1798492a69f49a03f29e792be2854efc9e66d710b78a1d"></a>CSR_HPMCOUNTER14H&#160;</td><td class="fielddoc"><p>0xc8e - hpmcounter14h: User hardware performance monitor 14 counter high word </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49a11169bd08920d40c8f94fd29e1d33eff" name="ac065a8cc32eed9a69ea1798492a69f49a11169bd08920d40c8f94fd29e1d33eff"></a>CSR_HPMCOUNTER15H&#160;</td><td class="fielddoc"><p>0xc8f - hpmcounter15h: User hardware performance monitor 15 counter high word </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49af5c5a21909aaca2b57f9a15f4bac246b" name="ac065a8cc32eed9a69ea1798492a69f49af5c5a21909aaca2b57f9a15f4bac246b"></a>CSR_MVENDORID&#160;</td><td class="fielddoc"><p>0xf11 - mvendorid: Machine vendor ID </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49ad95cb95266533123447ff0e917f890e4" name="ac065a8cc32eed9a69ea1798492a69f49ad95cb95266533123447ff0e917f890e4"></a>CSR_MARCHID&#160;</td><td class="fielddoc"><p>0xf12 - marchid: Machine architecture ID </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49a06d39cf0f13d6401dcf426d56149c8cd" name="ac065a8cc32eed9a69ea1798492a69f49a06d39cf0f13d6401dcf426d56149c8cd"></a>CSR_MIMPID&#160;</td><td class="fielddoc"><p>0xf13 - mimpid: Machine implementation ID </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49a6ba48e2306ae92f498552e1ea04d6790" name="ac065a8cc32eed9a69ea1798492a69f49a6ba48e2306ae92f498552e1ea04d6790"></a>CSR_MHARTID&#160;</td><td class="fielddoc"><p>0xf14 - mhartid: Machine hardware thread ID </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49a0545d0921b3f90d037dbb25bc5fcc2f9" name="ac065a8cc32eed9a69ea1798492a69f49a0545d0921b3f90d037dbb25bc5fcc2f9"></a>CSR_MCONFIGPTR&#160;</td><td class="fielddoc"><p>0xf15 - mconfigptr: Machine configuration pointer register </p> +</td></tr> +<tr><td class="fieldname"><a id="ac065a8cc32eed9a69ea1798492a69f49a396847bcf1634a1602ab117bfb57bdd2" name="ac065a8cc32eed9a69ea1798492a69f49a396847bcf1634a1602ab117bfb57bdd2"></a>CSR_MXISA&#160;</td><td class="fielddoc"><p>0xfc0 - mxisa: Machine extended ISA and extensions (NEORV32-specific) </p> +</td></tr> +</table> + +</div> +</div> +<a id="afde0761e3150d82511136f56179c204b" name="afde0761e3150d82511136f56179c204b"></a> +<h2 class="memtitle"><span class="permalink"><a href="#afde0761e3150d82511136f56179c204b">&#9670;&#160;</a></span>NEORV32_CSR_FFLAGS_enum</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">enum <a class="el" href="#afde0761e3150d82511136f56179c204b">NEORV32_CSR_FFLAGS_enum</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>CPU <b>fflags (fcsr)</b> CSR (r/w): FPU accrued exception flags </p> +<table class="fieldtable"> +<tr><th colspan="2">Enumerator</th></tr><tr><td class="fieldname"><a id="afde0761e3150d82511136f56179c204ba91a314defd310786a9ed67f7ef2ef5a6" name="afde0761e3150d82511136f56179c204ba91a314defd310786a9ed67f7ef2ef5a6"></a>CSR_FFLAGS_NX&#160;</td><td class="fielddoc"><p>CPU fflags CSR (0): NX - inexact (r/w) </p> +</td></tr> +<tr><td class="fieldname"><a id="afde0761e3150d82511136f56179c204babc6d405724563844569028f463885819" name="afde0761e3150d82511136f56179c204babc6d405724563844569028f463885819"></a>CSR_FFLAGS_UF&#160;</td><td class="fielddoc"><p>CPU fflags CSR (1): UF - underflow (r/w) </p> +</td></tr> +<tr><td class="fieldname"><a id="afde0761e3150d82511136f56179c204ba612390e07a065fa13eeaeac84af48c6e" name="afde0761e3150d82511136f56179c204ba612390e07a065fa13eeaeac84af48c6e"></a>CSR_FFLAGS_OF&#160;</td><td class="fielddoc"><p>CPU fflags CSR (2): OF - overflow (r/w) </p> +</td></tr> +<tr><td class="fieldname"><a id="afde0761e3150d82511136f56179c204ba365f3f519bca34a349907c82c873d52b" name="afde0761e3150d82511136f56179c204ba365f3f519bca34a349907c82c873d52b"></a>CSR_FFLAGS_DZ&#160;</td><td class="fielddoc"><p>CPU fflags CSR (3): DZ - divide by zero (r/w) </p> +</td></tr> +<tr><td class="fieldname"><a id="afde0761e3150d82511136f56179c204ba3ac330a4b03178e756c980eaa48ad165" name="afde0761e3150d82511136f56179c204ba3ac330a4b03178e756c980eaa48ad165"></a>CSR_FFLAGS_NV&#160;</td><td class="fielddoc"><p>CPU fflags CSR (4): NV - invalid operation (r/w) </p> +</td></tr> +</table> + +</div> +</div> +<a id="ab6886ca6858d57854495986ef9b5cbfe" name="ab6886ca6858d57854495986ef9b5cbfe"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ab6886ca6858d57854495986ef9b5cbfe">&#9670;&#160;</a></span>NEORV32_CSR_MCOUNTINHIBIT_enum</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">enum <a class="el" href="#ab6886ca6858d57854495986ef9b5cbfe">NEORV32_CSR_MCOUNTINHIBIT_enum</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>CPU <b>mcountinhibit</b> CSR (r/w): Machine counter-inhibit </p> +<table class="fieldtable"> +<tr><th colspan="2">Enumerator</th></tr><tr><td class="fieldname"><a id="ab6886ca6858d57854495986ef9b5cbfea201ac39b0eba389b0d02c3951a3311a3" name="ab6886ca6858d57854495986ef9b5cbfea201ac39b0eba389b0d02c3951a3311a3"></a>CSR_MCOUNTINHIBIT_CY&#160;</td><td class="fielddoc"><p>CPU mcountinhibit CSR (0): CY - Enable auto-increment of [m]cycle[h] CSR when set (r/w) </p> +</td></tr> +<tr><td class="fieldname"><a id="ab6886ca6858d57854495986ef9b5cbfea5f182f39f9a4b871a097a51e57865bfa" name="ab6886ca6858d57854495986ef9b5cbfea5f182f39f9a4b871a097a51e57865bfa"></a>CSR_MCOUNTINHIBIT_IR&#160;</td><td class="fielddoc"><p>CPU mcountinhibit CSR (2): IR - Enable auto-increment of [m]instret[h] CSR when set (r/w) </p> +</td></tr> +<tr><td class="fieldname"><a id="ab6886ca6858d57854495986ef9b5cbfeaf7020159e0ba346561bfba101d22c752" name="ab6886ca6858d57854495986ef9b5cbfeaf7020159e0ba346561bfba101d22c752"></a>CSR_MCOUNTINHIBIT_HPM3&#160;</td><td class="fielddoc"><p>CPU mcountinhibit CSR (3): HPM3 - Enable auto-increment of hpmcnt3[h] when set (r/w) </p> +</td></tr> +<tr><td class="fieldname"><a id="ab6886ca6858d57854495986ef9b5cbfea40427b799da049413c5536afa623c61d" name="ab6886ca6858d57854495986ef9b5cbfea40427b799da049413c5536afa623c61d"></a>CSR_MCOUNTINHIBIT_HPM4&#160;</td><td class="fielddoc"><p>CPU mcountinhibit CSR (4): HPM4 - Enable auto-increment of hpmcnt4[h] when set (r/w) </p> +</td></tr> +<tr><td class="fieldname"><a id="ab6886ca6858d57854495986ef9b5cbfea2769a6e6a75f2f903523e4e95a899bb6" name="ab6886ca6858d57854495986ef9b5cbfea2769a6e6a75f2f903523e4e95a899bb6"></a>CSR_MCOUNTINHIBIT_HPM5&#160;</td><td class="fielddoc"><p>CPU mcountinhibit CSR (5): HPM5 - Enable auto-increment of hpmcnt5[h] when set (r/w) </p> +</td></tr> +<tr><td class="fieldname"><a id="ab6886ca6858d57854495986ef9b5cbfead55b6af15841617d7dca3ab4fab893db" name="ab6886ca6858d57854495986ef9b5cbfead55b6af15841617d7dca3ab4fab893db"></a>CSR_MCOUNTINHIBIT_HPM6&#160;</td><td class="fielddoc"><p>CPU mcountinhibit CSR (6): HPM6 - Enable auto-increment of hpmcnt6[h] when set (r/w) </p> +</td></tr> +<tr><td class="fieldname"><a id="ab6886ca6858d57854495986ef9b5cbfea3b3571fceb687da2d3807b0e59bdf7ab" name="ab6886ca6858d57854495986ef9b5cbfea3b3571fceb687da2d3807b0e59bdf7ab"></a>CSR_MCOUNTINHIBIT_HPM7&#160;</td><td class="fielddoc"><p>CPU mcountinhibit CSR (7): HPM7 - Enable auto-increment of hpmcnt7[h] when set (r/w) </p> +</td></tr> +<tr><td class="fieldname"><a id="ab6886ca6858d57854495986ef9b5cbfeabd21344124eda4402523203185a58b8a" name="ab6886ca6858d57854495986ef9b5cbfeabd21344124eda4402523203185a58b8a"></a>CSR_MCOUNTINHIBIT_HPM8&#160;</td><td class="fielddoc"><p>CPU mcountinhibit CSR (8): HPM8 - Enable auto-increment of hpmcnt8[h] when set (r/w) </p> +</td></tr> +<tr><td class="fieldname"><a id="ab6886ca6858d57854495986ef9b5cbfea0f207455df0fed75fa68ba49c435889a" name="ab6886ca6858d57854495986ef9b5cbfea0f207455df0fed75fa68ba49c435889a"></a>CSR_MCOUNTINHIBIT_HPM9&#160;</td><td class="fielddoc"><p>CPU mcountinhibit CSR (9): HPM9 - Enable auto-increment of hpmcnt9[h] when set (r/w) </p> +</td></tr> +<tr><td class="fieldname"><a id="ab6886ca6858d57854495986ef9b5cbfea9517cd32744c5064fa30780f911cd22e" name="ab6886ca6858d57854495986ef9b5cbfea9517cd32744c5064fa30780f911cd22e"></a>CSR_MCOUNTINHIBIT_HPM10&#160;</td><td class="fielddoc"><p>CPU mcountinhibit CSR (10): HPM10 - Enable auto-increment of hpmcnt10[h] when set (r/w) </p> +</td></tr> +<tr><td class="fieldname"><a id="ab6886ca6858d57854495986ef9b5cbfeacaf997fe8b912596224e2bb632e6a806" name="ab6886ca6858d57854495986ef9b5cbfeacaf997fe8b912596224e2bb632e6a806"></a>CSR_MCOUNTINHIBIT_HPM11&#160;</td><td class="fielddoc"><p>CPU mcountinhibit CSR (11): HPM11 - Enable auto-increment of hpmcnt11[h] when set (r/w) </p> +</td></tr> +<tr><td class="fieldname"><a id="ab6886ca6858d57854495986ef9b5cbfea8d866a4c815d8ba890a1e00ce9600486" name="ab6886ca6858d57854495986ef9b5cbfea8d866a4c815d8ba890a1e00ce9600486"></a>CSR_MCOUNTINHIBIT_HPM12&#160;</td><td class="fielddoc"><p>CPU mcountinhibit CSR (12): HPM12 - Enable auto-increment of hpmcnt12[h] when set (r/w) </p> +</td></tr> +<tr><td class="fieldname"><a id="ab6886ca6858d57854495986ef9b5cbfead9f6c4eb4284ee82b9e8d0c79f62b3ed" name="ab6886ca6858d57854495986ef9b5cbfead9f6c4eb4284ee82b9e8d0c79f62b3ed"></a>CSR_MCOUNTINHIBIT_HPM13&#160;</td><td class="fielddoc"><p>CPU mcountinhibit CSR (13): HPM13 - Enable auto-increment of hpmcnt13[h] when set (r/w) </p> +</td></tr> +<tr><td class="fieldname"><a id="ab6886ca6858d57854495986ef9b5cbfeaa83c0688869b1c43de0c4474e940f987" name="ab6886ca6858d57854495986ef9b5cbfeaa83c0688869b1c43de0c4474e940f987"></a>CSR_MCOUNTINHIBIT_HPM14&#160;</td><td class="fielddoc"><p>CPU mcountinhibit CSR (14): HPM14 - Enable auto-increment of hpmcnt14[h] when set (r/w) </p> +</td></tr> +<tr><td class="fieldname"><a id="ab6886ca6858d57854495986ef9b5cbfea0b547cb5876c0e7956e3d062e0784085" name="ab6886ca6858d57854495986ef9b5cbfea0b547cb5876c0e7956e3d062e0784085"></a>CSR_MCOUNTINHIBIT_HPM15&#160;</td><td class="fielddoc"><p>CPU mcountinhibit CSR (15): HPM15 - Enable auto-increment of hpmcnt15[h] when set (r/w) </p> +</td></tr> +<tr><td class="fieldname"><a id="ab6886ca6858d57854495986ef9b5cbfea68aba71ea77aba4005fb24a945ef38e4" name="ab6886ca6858d57854495986ef9b5cbfea68aba71ea77aba4005fb24a945ef38e4"></a>CSR_MCOUNTINHIBIT_HPM16&#160;</td><td class="fielddoc"><p>CPU mcountinhibit CSR (16): HPM16 - Enable auto-increment of hpmcnt16[h] when set (r/w) </p> +</td></tr> +<tr><td class="fieldname"><a id="ab6886ca6858d57854495986ef9b5cbfea8d57acf13a086635a63bc13ccdf479b3" name="ab6886ca6858d57854495986ef9b5cbfea8d57acf13a086635a63bc13ccdf479b3"></a>CSR_MCOUNTINHIBIT_HPM17&#160;</td><td class="fielddoc"><p>CPU mcountinhibit CSR (17): HPM17 - Enable auto-increment of hpmcnt17[h] when set (r/w) </p> +</td></tr> +<tr><td class="fieldname"><a id="ab6886ca6858d57854495986ef9b5cbfeaa680d196d2ba0e403801a860bb9d8ce0" name="ab6886ca6858d57854495986ef9b5cbfeaa680d196d2ba0e403801a860bb9d8ce0"></a>CSR_MCOUNTINHIBIT_HPM18&#160;</td><td class="fielddoc"><p>CPU mcountinhibit CSR (18): HPM18 - Enable auto-increment of hpmcnt18[h] when set (r/w) </p> +</td></tr> +<tr><td class="fieldname"><a id="ab6886ca6858d57854495986ef9b5cbfea3683e296caafe771b6dd57f4cf86f3dc" name="ab6886ca6858d57854495986ef9b5cbfea3683e296caafe771b6dd57f4cf86f3dc"></a>CSR_MCOUNTINHIBIT_HPM19&#160;</td><td class="fielddoc"><p>CPU mcountinhibit CSR (19): HPM19 - Enable auto-increment of hpmcnt19[h] when set (r/w) </p> +</td></tr> +<tr><td class="fieldname"><a id="ab6886ca6858d57854495986ef9b5cbfeaeb4b1b6abafd22eec0764d5503878cca" name="ab6886ca6858d57854495986ef9b5cbfeaeb4b1b6abafd22eec0764d5503878cca"></a>CSR_MCOUNTINHIBIT_HPM20&#160;</td><td class="fielddoc"><p>CPU mcountinhibit CSR (20): HPM20 - Enable auto-increment of hpmcnt20[h] when set (r/w) </p> +</td></tr> +<tr><td class="fieldname"><a id="ab6886ca6858d57854495986ef9b5cbfea1dc0276a5354c805ac56fd46c5037d38" name="ab6886ca6858d57854495986ef9b5cbfea1dc0276a5354c805ac56fd46c5037d38"></a>CSR_MCOUNTINHIBIT_HPM21&#160;</td><td class="fielddoc"><p>CPU mcountinhibit CSR (21): HPM21 - Enable auto-increment of hpmcnt21[h] when set (r/w) </p> +</td></tr> +<tr><td class="fieldname"><a id="ab6886ca6858d57854495986ef9b5cbfeaf1b6153a0c664367bfefb78b2ca8b34e" name="ab6886ca6858d57854495986ef9b5cbfeaf1b6153a0c664367bfefb78b2ca8b34e"></a>CSR_MCOUNTINHIBIT_HPM22&#160;</td><td class="fielddoc"><p>CPU mcountinhibit CSR (22): HPM22 - Enable auto-increment of hpmcnt22[h] when set (r/w) </p> +</td></tr> +<tr><td class="fieldname"><a id="ab6886ca6858d57854495986ef9b5cbfea85c0c2b2a5101380dec72516dda1a904" name="ab6886ca6858d57854495986ef9b5cbfea85c0c2b2a5101380dec72516dda1a904"></a>CSR_MCOUNTINHIBIT_HPM23&#160;</td><td class="fielddoc"><p>CPU mcountinhibit CSR (23): HPM23 - Enable auto-increment of hpmcnt23[h] when set (r/w) </p> +</td></tr> +<tr><td class="fieldname"><a id="ab6886ca6858d57854495986ef9b5cbfea74ec85a2e94aa0b9e8af29401ef7ecb1" name="ab6886ca6858d57854495986ef9b5cbfea74ec85a2e94aa0b9e8af29401ef7ecb1"></a>CSR_MCOUNTINHIBIT_HPM24&#160;</td><td class="fielddoc"><p>CPU mcountinhibit CSR (24): HPM24 - Enable auto-increment of hpmcnt24[h] when set (r/w) </p> +</td></tr> +<tr><td class="fieldname"><a id="ab6886ca6858d57854495986ef9b5cbfeaee2b5a2b7bd7ac07dae45900bc2faf46" name="ab6886ca6858d57854495986ef9b5cbfeaee2b5a2b7bd7ac07dae45900bc2faf46"></a>CSR_MCOUNTINHIBIT_HPM25&#160;</td><td class="fielddoc"><p>CPU mcountinhibit CSR (25): HPM25 - Enable auto-increment of hpmcnt25[h] when set (r/w) </p> +</td></tr> +<tr><td class="fieldname"><a id="ab6886ca6858d57854495986ef9b5cbfea141a4a211c496d2af1c79d8e8e0c2a74" name="ab6886ca6858d57854495986ef9b5cbfea141a4a211c496d2af1c79d8e8e0c2a74"></a>CSR_MCOUNTINHIBIT_HPM26&#160;</td><td class="fielddoc"><p>CPU mcountinhibit CSR (26): HPM26 - Enable auto-increment of hpmcnt26[h] when set (r/w) </p> +</td></tr> +<tr><td class="fieldname"><a id="ab6886ca6858d57854495986ef9b5cbfea46def851d4582b4bcec1f9d8bafd58db" name="ab6886ca6858d57854495986ef9b5cbfea46def851d4582b4bcec1f9d8bafd58db"></a>CSR_MCOUNTINHIBIT_HPM27&#160;</td><td class="fielddoc"><p>CPU mcountinhibit CSR (27): HPM27 - Enable auto-increment of hpmcnt27[h] when set (r/w) </p> +</td></tr> +<tr><td class="fieldname"><a id="ab6886ca6858d57854495986ef9b5cbfea33d0fd3378ec3a2fcc3c8738c6cd2f32" name="ab6886ca6858d57854495986ef9b5cbfea33d0fd3378ec3a2fcc3c8738c6cd2f32"></a>CSR_MCOUNTINHIBIT_HPM28&#160;</td><td class="fielddoc"><p>CPU mcountinhibit CSR (28): HPM28 - Enable auto-increment of hpmcnt28[h] when set (r/w) </p> +</td></tr> +<tr><td class="fieldname"><a id="ab6886ca6858d57854495986ef9b5cbfeaa39882f7dad9b7e16b317c75bad31382" name="ab6886ca6858d57854495986ef9b5cbfeaa39882f7dad9b7e16b317c75bad31382"></a>CSR_MCOUNTINHIBIT_HPM29&#160;</td><td class="fielddoc"><p>CPU mcountinhibit CSR (29): HPM29 - Enable auto-increment of hpmcnt29[h] when set (r/w) </p> +</td></tr> +<tr><td class="fieldname"><a id="ab6886ca6858d57854495986ef9b5cbfea0f45818fa4cb9033a3093987fa8515c7" name="ab6886ca6858d57854495986ef9b5cbfea0f45818fa4cb9033a3093987fa8515c7"></a>CSR_MCOUNTINHIBIT_HPM30&#160;</td><td class="fielddoc"><p>CPU mcountinhibit CSR (30): HPM30 - Enable auto-increment of hpmcnt30[h] when set (r/w) </p> +</td></tr> +<tr><td class="fieldname"><a id="ab6886ca6858d57854495986ef9b5cbfea1da1186ef2f4e7297a4fecaaccdc1d05" name="ab6886ca6858d57854495986ef9b5cbfea1da1186ef2f4e7297a4fecaaccdc1d05"></a>CSR_MCOUNTINHIBIT_HPM31&#160;</td><td class="fielddoc"><p>CPU mcountinhibit CSR (31): HPM31 - Enable auto-increment of hpmcnt31[h] when set (r/w) </p> +</td></tr> +</table> + +</div> +</div> +<a id="a0e9714690687badee43180c3cb62be33" name="a0e9714690687badee43180c3cb62be33"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a0e9714690687badee43180c3cb62be33">&#9670;&#160;</a></span>NEORV32_CSR_MIE_enum</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">enum <a class="el" href="#a0e9714690687badee43180c3cb62be33">NEORV32_CSR_MIE_enum</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>CPU <b>mie</b> CSR (r/w): Machine interrupt enable </p> +<table class="fieldtable"> +<tr><th colspan="2">Enumerator</th></tr><tr><td class="fieldname"><a id="a0e9714690687badee43180c3cb62be33afd2f1c78c442c8c29ab075cacee0a27a" name="a0e9714690687badee43180c3cb62be33afd2f1c78c442c8c29ab075cacee0a27a"></a>CSR_MIE_MSIE&#160;</td><td class="fielddoc"><p>CPU mie CSR (3): MSIE - Machine software interrupt enable (r/w) </p> +</td></tr> +<tr><td class="fieldname"><a id="a0e9714690687badee43180c3cb62be33a3658e8663e94cd8eaa7201b7a850d083" name="a0e9714690687badee43180c3cb62be33a3658e8663e94cd8eaa7201b7a850d083"></a>CSR_MIE_MTIE&#160;</td><td class="fielddoc"><p>CPU mie CSR (7): MTIE - Machine timer interrupt enable bit (r/w) </p> +</td></tr> +<tr><td class="fieldname"><a id="a0e9714690687badee43180c3cb62be33ae8e4f0ee46abbbb3361de035a57b8324" name="a0e9714690687badee43180c3cb62be33ae8e4f0ee46abbbb3361de035a57b8324"></a>CSR_MIE_MEIE&#160;</td><td class="fielddoc"><p>CPU mie CSR (11): MEIE - Machine external interrupt enable bit (r/w) </p> +</td></tr> +<tr><td class="fieldname"><a id="a0e9714690687badee43180c3cb62be33a99f43f8bbfb29fba6224f081c363ac7d" name="a0e9714690687badee43180c3cb62be33a99f43f8bbfb29fba6224f081c363ac7d"></a>CSR_MIE_FIRQ0E&#160;</td><td class="fielddoc"><p>CPU mie CSR (16): FIRQ0E - Fast interrupt channel 0 enable bit (r/w) </p> +</td></tr> +<tr><td class="fieldname"><a id="a0e9714690687badee43180c3cb62be33ac1e1d44becec1b393f79a118ed3d8beb" name="a0e9714690687badee43180c3cb62be33ac1e1d44becec1b393f79a118ed3d8beb"></a>CSR_MIE_FIRQ1E&#160;</td><td class="fielddoc"><p>CPU mie CSR (17): FIRQ1E - Fast interrupt channel 1 enable bit (r/w) </p> +</td></tr> +<tr><td class="fieldname"><a id="a0e9714690687badee43180c3cb62be33afc805280e20ffface116ca61e11645f7" name="a0e9714690687badee43180c3cb62be33afc805280e20ffface116ca61e11645f7"></a>CSR_MIE_FIRQ2E&#160;</td><td class="fielddoc"><p>CPU mie CSR (18): FIRQ2E - Fast interrupt channel 2 enable bit (r/w) </p> +</td></tr> +<tr><td class="fieldname"><a id="a0e9714690687badee43180c3cb62be33a666066099d6cebadbef21d81c179e8db" name="a0e9714690687badee43180c3cb62be33a666066099d6cebadbef21d81c179e8db"></a>CSR_MIE_FIRQ3E&#160;</td><td class="fielddoc"><p>CPU mie CSR (19): FIRQ3E - Fast interrupt channel 3 enable bit (r/w) </p> +</td></tr> +<tr><td class="fieldname"><a id="a0e9714690687badee43180c3cb62be33a592939f1b7d79097f7f13d6ab0c268dc" name="a0e9714690687badee43180c3cb62be33a592939f1b7d79097f7f13d6ab0c268dc"></a>CSR_MIE_FIRQ4E&#160;</td><td class="fielddoc"><p>CPU mie CSR (20): FIRQ4E - Fast interrupt channel 4 enable bit (r/w) </p> +</td></tr> +<tr><td class="fieldname"><a id="a0e9714690687badee43180c3cb62be33a3079a8fbf3b8e376865bff76f2173698" name="a0e9714690687badee43180c3cb62be33a3079a8fbf3b8e376865bff76f2173698"></a>CSR_MIE_FIRQ5E&#160;</td><td class="fielddoc"><p>CPU mie CSR (21): FIRQ5E - Fast interrupt channel 5 enable bit (r/w) </p> +</td></tr> +<tr><td class="fieldname"><a id="a0e9714690687badee43180c3cb62be33a96315d6b5b9531bcbc1e78a3c9ab166a" name="a0e9714690687badee43180c3cb62be33a96315d6b5b9531bcbc1e78a3c9ab166a"></a>CSR_MIE_FIRQ6E&#160;</td><td class="fielddoc"><p>CPU mie CSR (22): FIRQ6E - Fast interrupt channel 6 enable bit (r/w) </p> +</td></tr> +<tr><td class="fieldname"><a id="a0e9714690687badee43180c3cb62be33a3d9d729940170609affbc6813054ebe8" name="a0e9714690687badee43180c3cb62be33a3d9d729940170609affbc6813054ebe8"></a>CSR_MIE_FIRQ7E&#160;</td><td class="fielddoc"><p>CPU mie CSR (23): FIRQ7E - Fast interrupt channel 7 enable bit (r/w) </p> +</td></tr> +<tr><td class="fieldname"><a id="a0e9714690687badee43180c3cb62be33a396c6c4b425b3fff598e2f846052f98e" name="a0e9714690687badee43180c3cb62be33a396c6c4b425b3fff598e2f846052f98e"></a>CSR_MIE_FIRQ8E&#160;</td><td class="fielddoc"><p>CPU mie CSR (24): FIRQ8E - Fast interrupt channel 8 enable bit (r/w) </p> +</td></tr> +<tr><td class="fieldname"><a id="a0e9714690687badee43180c3cb62be33a06fdb61dab31c3490da6c37d47914f19" name="a0e9714690687badee43180c3cb62be33a06fdb61dab31c3490da6c37d47914f19"></a>CSR_MIE_FIRQ9E&#160;</td><td class="fielddoc"><p>CPU mie CSR (25): FIRQ9E - Fast interrupt channel 9 enable bit (r/w) </p> +</td></tr> +<tr><td class="fieldname"><a id="a0e9714690687badee43180c3cb62be33affcb52dc57bb8c0cb1e7d3c1392d544a" name="a0e9714690687badee43180c3cb62be33affcb52dc57bb8c0cb1e7d3c1392d544a"></a>CSR_MIE_FIRQ10E&#160;</td><td class="fielddoc"><p>CPU mie CSR (26): FIRQ10E - Fast interrupt channel 10 enable bit (r/w) </p> +</td></tr> +<tr><td class="fieldname"><a id="a0e9714690687badee43180c3cb62be33af058342854a0becd3bcc33877d9244cd" name="a0e9714690687badee43180c3cb62be33af058342854a0becd3bcc33877d9244cd"></a>CSR_MIE_FIRQ11E&#160;</td><td class="fielddoc"><p>CPU mie CSR (27): FIRQ11E - Fast interrupt channel 11 enable bit (r/w) </p> +</td></tr> +<tr><td class="fieldname"><a id="a0e9714690687badee43180c3cb62be33a41f91a37f7e0c75c783312af6a72e943" name="a0e9714690687badee43180c3cb62be33a41f91a37f7e0c75c783312af6a72e943"></a>CSR_MIE_FIRQ12E&#160;</td><td class="fielddoc"><p>CPU mie CSR (28): FIRQ12E - Fast interrupt channel 12 enable bit (r/w) </p> +</td></tr> +<tr><td class="fieldname"><a id="a0e9714690687badee43180c3cb62be33a134ed02c7293008b21b1df472be8f11f" name="a0e9714690687badee43180c3cb62be33a134ed02c7293008b21b1df472be8f11f"></a>CSR_MIE_FIRQ13E&#160;</td><td class="fielddoc"><p>CPU mie CSR (29): FIRQ13E - Fast interrupt channel 13 enable bit (r/w) </p> +</td></tr> +<tr><td class="fieldname"><a id="a0e9714690687badee43180c3cb62be33a864d135708530016cfc52a65a1e4d79b" name="a0e9714690687badee43180c3cb62be33a864d135708530016cfc52a65a1e4d79b"></a>CSR_MIE_FIRQ14E&#160;</td><td class="fielddoc"><p>CPU mie CSR (30): FIRQ14E - Fast interrupt channel 14 enable bit (r/w) </p> +</td></tr> +<tr><td class="fieldname"><a id="a0e9714690687badee43180c3cb62be33aa2dfa1183af312de2959dadd217fddc1" name="a0e9714690687badee43180c3cb62be33aa2dfa1183af312de2959dadd217fddc1"></a>CSR_MIE_FIRQ15E&#160;</td><td class="fielddoc"><p>CPU mie CSR (31): FIRQ15E - Fast interrupt channel 15 enable bit (r/w) </p> +</td></tr> +</table> + +</div> +</div> +<a id="a6301c554bf831b97fc28f9984a1ec21b" name="a6301c554bf831b97fc28f9984a1ec21b"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a6301c554bf831b97fc28f9984a1ec21b">&#9670;&#160;</a></span>NEORV32_CSR_MIP_enum</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">enum <a class="el" href="#a6301c554bf831b97fc28f9984a1ec21b">NEORV32_CSR_MIP_enum</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>CPU <b>mip</b> CSR (r/-): Machine interrupt pending </p> +<table class="fieldtable"> +<tr><th colspan="2">Enumerator</th></tr><tr><td class="fieldname"><a id="a6301c554bf831b97fc28f9984a1ec21ba1470cfe04f9d3ce45b7156b2a7fae159" name="a6301c554bf831b97fc28f9984a1ec21ba1470cfe04f9d3ce45b7156b2a7fae159"></a>CSR_MIP_MSIP&#160;</td><td class="fielddoc"><p>CPU mip CSR (3): MSIP - Machine software interrupt pending (r/-) </p> +</td></tr> +<tr><td class="fieldname"><a id="a6301c554bf831b97fc28f9984a1ec21ba344943c62922561378d33ec51ac236e4" name="a6301c554bf831b97fc28f9984a1ec21ba344943c62922561378d33ec51ac236e4"></a>CSR_MIP_MTIP&#160;</td><td class="fielddoc"><p>CPU mip CSR (7): MTIP - Machine timer interrupt pending (r/-) </p> +</td></tr> +<tr><td class="fieldname"><a id="a6301c554bf831b97fc28f9984a1ec21ba1d761ef98f88c40509168ac66b7a4872" name="a6301c554bf831b97fc28f9984a1ec21ba1d761ef98f88c40509168ac66b7a4872"></a>CSR_MIP_MEIP&#160;</td><td class="fielddoc"><p>CPU mip CSR (11): MEIP - Machine external interrupt pending (r/-) </p> +</td></tr> +<tr><td class="fieldname"><a id="a6301c554bf831b97fc28f9984a1ec21ba28a85ad8bd4c30fd3a91298dfa4fdb00" name="a6301c554bf831b97fc28f9984a1ec21ba28a85ad8bd4c30fd3a91298dfa4fdb00"></a>CSR_MIP_FIRQ0P&#160;</td><td class="fielddoc"><p>CPU mip CSR (16): FIRQ0P - Fast interrupt channel 0 pending (r/-) </p> +</td></tr> +<tr><td class="fieldname"><a id="a6301c554bf831b97fc28f9984a1ec21ba2b577b1da1074c29ad58005af1f91d52" name="a6301c554bf831b97fc28f9984a1ec21ba2b577b1da1074c29ad58005af1f91d52"></a>CSR_MIP_FIRQ1P&#160;</td><td class="fielddoc"><p>CPU mip CSR (17): FIRQ1P - Fast interrupt channel 1 pending (r/-) </p> +</td></tr> +<tr><td class="fieldname"><a id="a6301c554bf831b97fc28f9984a1ec21badf45c5a135431f958fa63574c1dfac6e" name="a6301c554bf831b97fc28f9984a1ec21badf45c5a135431f958fa63574c1dfac6e"></a>CSR_MIP_FIRQ2P&#160;</td><td class="fielddoc"><p>CPU mip CSR (18): FIRQ2P - Fast interrupt channel 2 pending (r/-) </p> +</td></tr> +<tr><td class="fieldname"><a id="a6301c554bf831b97fc28f9984a1ec21ba7512bb6c4841ddd477422b49ebb2a155" name="a6301c554bf831b97fc28f9984a1ec21ba7512bb6c4841ddd477422b49ebb2a155"></a>CSR_MIP_FIRQ3P&#160;</td><td class="fielddoc"><p>CPU mip CSR (19): FIRQ3P - Fast interrupt channel 3 pending (r/-) </p> +</td></tr> +<tr><td class="fieldname"><a id="a6301c554bf831b97fc28f9984a1ec21bab6421f242bb8a487a986346e11196eb8" name="a6301c554bf831b97fc28f9984a1ec21bab6421f242bb8a487a986346e11196eb8"></a>CSR_MIP_FIRQ4P&#160;</td><td class="fielddoc"><p>CPU mip CSR (20): FIRQ4P - Fast interrupt channel 4 pending (r/-) </p> +</td></tr> +<tr><td class="fieldname"><a id="a6301c554bf831b97fc28f9984a1ec21baaa55d19f9a47889bc364c94bda04b677" name="a6301c554bf831b97fc28f9984a1ec21baaa55d19f9a47889bc364c94bda04b677"></a>CSR_MIP_FIRQ5P&#160;</td><td class="fielddoc"><p>CPU mip CSR (21): FIRQ5P - Fast interrupt channel 5 pending (r/-) </p> +</td></tr> +<tr><td class="fieldname"><a id="a6301c554bf831b97fc28f9984a1ec21baffa7342631aa0526aaa44c0c549b1f3e" name="a6301c554bf831b97fc28f9984a1ec21baffa7342631aa0526aaa44c0c549b1f3e"></a>CSR_MIP_FIRQ6P&#160;</td><td class="fielddoc"><p>CPU mip CSR (22): FIRQ6P - Fast interrupt channel 6 pending (r/-) </p> +</td></tr> +<tr><td class="fieldname"><a id="a6301c554bf831b97fc28f9984a1ec21baad691486001a68f2375dcf5793ee795a" name="a6301c554bf831b97fc28f9984a1ec21baad691486001a68f2375dcf5793ee795a"></a>CSR_MIP_FIRQ7P&#160;</td><td class="fielddoc"><p>CPU mip CSR (23): FIRQ7P - Fast interrupt channel 7 pending (r/-) </p> +</td></tr> +<tr><td class="fieldname"><a id="a6301c554bf831b97fc28f9984a1ec21baf5bbd23d4f311f640db42e9015f87580" name="a6301c554bf831b97fc28f9984a1ec21baf5bbd23d4f311f640db42e9015f87580"></a>CSR_MIP_FIRQ8P&#160;</td><td class="fielddoc"><p>CPU mip CSR (24): FIRQ8P - Fast interrupt channel 8 pending (r/-) </p> +</td></tr> +<tr><td class="fieldname"><a id="a6301c554bf831b97fc28f9984a1ec21bad94c9691ce59b97fcfec14d345046c3e" name="a6301c554bf831b97fc28f9984a1ec21bad94c9691ce59b97fcfec14d345046c3e"></a>CSR_MIP_FIRQ9P&#160;</td><td class="fielddoc"><p>CPU mip CSR (25): FIRQ9P - Fast interrupt channel 9 pending (r/-) </p> +</td></tr> +<tr><td class="fieldname"><a id="a6301c554bf831b97fc28f9984a1ec21ba2b50cfa8be461b088ea8506ce4c741ba" name="a6301c554bf831b97fc28f9984a1ec21ba2b50cfa8be461b088ea8506ce4c741ba"></a>CSR_MIP_FIRQ10P&#160;</td><td class="fielddoc"><p>CPU mip CSR (26): FIRQ10P - Fast interrupt channel 10 pending (r/-) </p> +</td></tr> +<tr><td class="fieldname"><a id="a6301c554bf831b97fc28f9984a1ec21ba69ea0d3d76d4cec398f3b96959cc3544" name="a6301c554bf831b97fc28f9984a1ec21ba69ea0d3d76d4cec398f3b96959cc3544"></a>CSR_MIP_FIRQ11P&#160;</td><td class="fielddoc"><p>CPU mip CSR (27): FIRQ11P - Fast interrupt channel 11 pending (r/-) </p> +</td></tr> +<tr><td class="fieldname"><a id="a6301c554bf831b97fc28f9984a1ec21ba03edd398920b817150d29107c0b40792" name="a6301c554bf831b97fc28f9984a1ec21ba03edd398920b817150d29107c0b40792"></a>CSR_MIP_FIRQ12P&#160;</td><td class="fielddoc"><p>CPU mip CSR (28): FIRQ12P - Fast interrupt channel 12 pending (r/-) </p> +</td></tr> +<tr><td class="fieldname"><a id="a6301c554bf831b97fc28f9984a1ec21ba14da6a2a962bf82970638a948ffbc570" name="a6301c554bf831b97fc28f9984a1ec21ba14da6a2a962bf82970638a948ffbc570"></a>CSR_MIP_FIRQ13P&#160;</td><td class="fielddoc"><p>CPU mip CSR (29): FIRQ13P - Fast interrupt channel 13 pending (r/-) </p> +</td></tr> +<tr><td class="fieldname"><a id="a6301c554bf831b97fc28f9984a1ec21baad1e5e452a9c37561308765431f0260d" name="a6301c554bf831b97fc28f9984a1ec21baad1e5e452a9c37561308765431f0260d"></a>CSR_MIP_FIRQ14P&#160;</td><td class="fielddoc"><p>CPU mip CSR (30): FIRQ14P - Fast interrupt channel 14 pending (r/-) </p> +</td></tr> +<tr><td class="fieldname"><a id="a6301c554bf831b97fc28f9984a1ec21ba12da8c32d38d5a3539a0b766718bfd2d" name="a6301c554bf831b97fc28f9984a1ec21ba12da8c32d38d5a3539a0b766718bfd2d"></a>CSR_MIP_FIRQ15P&#160;</td><td class="fielddoc"><p>CPU mip CSR (31): FIRQ15P - Fast interrupt channel 15 pending (r/-) </p> +</td></tr> +</table> + +</div> +</div> +<a id="afed7f00bbb39468f038d9ca6fbac830c" name="afed7f00bbb39468f038d9ca6fbac830c"></a> +<h2 class="memtitle"><span class="permalink"><a href="#afed7f00bbb39468f038d9ca6fbac830c">&#9670;&#160;</a></span>NEORV32_CSR_MISA_enum</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">enum <a class="el" href="#afed7f00bbb39468f038d9ca6fbac830c">NEORV32_CSR_MISA_enum</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>CPU <b>misa</b> CSR (r/-): Machine instruction set extensions </p> +<table class="fieldtable"> +<tr><th colspan="2">Enumerator</th></tr><tr><td class="fieldname"><a id="afed7f00bbb39468f038d9ca6fbac830ca89412df9f99d2a0ddc4665446397f1a2" name="afed7f00bbb39468f038d9ca6fbac830ca89412df9f99d2a0ddc4665446397f1a2"></a>CSR_MISA_A&#160;</td><td class="fielddoc"><p>CPU misa CSR (0): A: Atomic instructions CPU extension available (r/-) </p> +</td></tr> +<tr><td class="fieldname"><a id="afed7f00bbb39468f038d9ca6fbac830cadd469404a928e012a298773ec46926ad" name="afed7f00bbb39468f038d9ca6fbac830cadd469404a928e012a298773ec46926ad"></a>CSR_MISA_B&#160;</td><td class="fielddoc"><p>CPU misa CSR (1): B: Bit manipulation CPU extension available (r/-) </p> +</td></tr> +<tr><td class="fieldname"><a id="afed7f00bbb39468f038d9ca6fbac830ca886699013158c74810598fa2fd6b07fa" name="afed7f00bbb39468f038d9ca6fbac830ca886699013158c74810598fa2fd6b07fa"></a>CSR_MISA_C&#160;</td><td class="fielddoc"><p>CPU misa CSR (2): C: Compressed instructions CPU extension available (r/-) </p> +</td></tr> +<tr><td class="fieldname"><a id="afed7f00bbb39468f038d9ca6fbac830ca1dd1be1071450f9b00a817bce19fa665" name="afed7f00bbb39468f038d9ca6fbac830ca1dd1be1071450f9b00a817bce19fa665"></a>CSR_MISA_D&#160;</td><td class="fielddoc"><p>CPU misa CSR (3): D: Double-precision floating-point extension available (r/-) </p> +</td></tr> +<tr><td class="fieldname"><a id="afed7f00bbb39468f038d9ca6fbac830ca0ac798fd19cb7dbe1146afecda448fec" name="afed7f00bbb39468f038d9ca6fbac830ca0ac798fd19cb7dbe1146afecda448fec"></a>CSR_MISA_E&#160;</td><td class="fielddoc"><p>CPU misa CSR (4): E: Embedded CPU extension available (r/-) </p> +</td></tr> +<tr><td class="fieldname"><a id="afed7f00bbb39468f038d9ca6fbac830ca9ec2cae2b948de1043540a4ca1665c40" name="afed7f00bbb39468f038d9ca6fbac830ca9ec2cae2b948de1043540a4ca1665c40"></a>CSR_MISA_F&#160;</td><td class="fielddoc"><p>CPU misa CSR (5): F: Single-precision floating-point extension available (r/-) </p> +</td></tr> +<tr><td class="fieldname"><a id="afed7f00bbb39468f038d9ca6fbac830ca6091fd2c7ae38ad33be68a0fdfa50cca" name="afed7f00bbb39468f038d9ca6fbac830ca6091fd2c7ae38ad33be68a0fdfa50cca"></a>CSR_MISA_I&#160;</td><td class="fielddoc"><p>CPU misa CSR (8): I: Base integer ISA CPU extension available (r/-) </p> +</td></tr> +<tr><td class="fieldname"><a id="afed7f00bbb39468f038d9ca6fbac830ca317a631e4598532f5bffe8fb93aff94b" name="afed7f00bbb39468f038d9ca6fbac830ca317a631e4598532f5bffe8fb93aff94b"></a>CSR_MISA_M&#160;</td><td class="fielddoc"><p>CPU misa CSR (12): M: Multiplier/divider CPU extension available (r/-) </p> +</td></tr> +<tr><td class="fieldname"><a id="afed7f00bbb39468f038d9ca6fbac830cacd9d71e674d3a6d04984b6df706d9deb" name="afed7f00bbb39468f038d9ca6fbac830cacd9d71e674d3a6d04984b6df706d9deb"></a>CSR_MISA_U&#160;</td><td class="fielddoc"><p>CPU misa CSR (20): U: User mode CPU extension available (r/-) </p> +</td></tr> +<tr><td class="fieldname"><a id="afed7f00bbb39468f038d9ca6fbac830ca0b119a20be29fcae8fecf2a81c60d193" name="afed7f00bbb39468f038d9ca6fbac830ca0b119a20be29fcae8fecf2a81c60d193"></a>CSR_MISA_X&#160;</td><td class="fielddoc"><p>CPU misa CSR (23): X: Non-standard CPU extension available (r/-) </p> +</td></tr> +<tr><td class="fieldname"><a id="afed7f00bbb39468f038d9ca6fbac830cab5a55e97b8511f42fe68559a38f7f138" name="afed7f00bbb39468f038d9ca6fbac830cab5a55e97b8511f42fe68559a38f7f138"></a>CSR_MISA_MXL_LO&#160;</td><td class="fielddoc"><p>CPU misa CSR (30): MXL.lo: CPU data width (r/-) </p> +</td></tr> +<tr><td class="fieldname"><a id="afed7f00bbb39468f038d9ca6fbac830cafb3e4b08b87f5c161468a9e58ade12cc" name="afed7f00bbb39468f038d9ca6fbac830cafb3e4b08b87f5c161468a9e58ade12cc"></a>CSR_MISA_MXL_HI&#160;</td><td class="fielddoc"><p>CPU misa CSR (31): MXL.Hi: CPU data width (r/-) </p> +</td></tr> +</table> + +</div> +</div> +<a id="a76b70a2334131e7589d84c1ee96de485" name="a76b70a2334131e7589d84c1ee96de485"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a76b70a2334131e7589d84c1ee96de485">&#9670;&#160;</a></span>NEORV32_CSR_MSTATUS_enum</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">enum <a class="el" href="#a76b70a2334131e7589d84c1ee96de485">NEORV32_CSR_MSTATUS_enum</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>CPU <b>mstatus</b> CSR (r/w): Machine status </p> +<table class="fieldtable"> +<tr><th colspan="2">Enumerator</th></tr><tr><td class="fieldname"><a id="a76b70a2334131e7589d84c1ee96de485ae2603e365b3f1abfb46d53ed6b13dc56" name="a76b70a2334131e7589d84c1ee96de485ae2603e365b3f1abfb46d53ed6b13dc56"></a>CSR_MSTATUS_MIE&#160;</td><td class="fielddoc"><p>CPU mstatus CSR (3): MIE - Machine interrupt enable bit (r/w) </p> +</td></tr> +<tr><td class="fieldname"><a id="a76b70a2334131e7589d84c1ee96de485aaa1d482f828ac9cafc40fcfc298bec34" name="a76b70a2334131e7589d84c1ee96de485aaa1d482f828ac9cafc40fcfc298bec34"></a>CSR_MSTATUS_MPIE&#160;</td><td class="fielddoc"><p>CPU mstatus CSR (7): MPIE - Machine previous interrupt enable bit (r/w) </p> +</td></tr> +<tr><td class="fieldname"><a id="a76b70a2334131e7589d84c1ee96de485af0ae9aca74144aa7dbdf656f71cc5c97" name="a76b70a2334131e7589d84c1ee96de485af0ae9aca74144aa7dbdf656f71cc5c97"></a>CSR_MSTATUS_MPP_L&#160;</td><td class="fielddoc"><p>CPU mstatus CSR (11): MPP_L - Machine previous privilege mode bit low (r/w) </p> +</td></tr> +<tr><td class="fieldname"><a id="a76b70a2334131e7589d84c1ee96de485a8067c609c2360cab3bafa3c43e03dbf0" name="a76b70a2334131e7589d84c1ee96de485a8067c609c2360cab3bafa3c43e03dbf0"></a>CSR_MSTATUS_MPP_H&#160;</td><td class="fielddoc"><p>CPU mstatus CSR (12): MPP_H - Machine previous privilege mode bit high (r/w) </p> +</td></tr> +<tr><td class="fieldname"><a id="a76b70a2334131e7589d84c1ee96de485a75cefdbdef36b7fc248765b27c606a44" name="a76b70a2334131e7589d84c1ee96de485a75cefdbdef36b7fc248765b27c606a44"></a>CSR_MSTATUS_MPRV&#160;</td><td class="fielddoc"><p>CPU mstatus CSR (17): MPRV - Use MPP as effective privilege for M-mode load/stores when set (r/w) </p> +</td></tr> +<tr><td class="fieldname"><a id="a76b70a2334131e7589d84c1ee96de485ac94a070f3fe7962e8c49a81545cacf2d" name="a76b70a2334131e7589d84c1ee96de485ac94a070f3fe7962e8c49a81545cacf2d"></a>CSR_MSTATUS_TW&#160;</td><td class="fielddoc"><p>CPU mstatus CSR (21): TW - Disallow execution of wfi instruction in user mode when set (r/w) </p> +</td></tr> +</table> + +</div> +</div> +<a id="af05490a8af176ab4ba945d327d448387" name="af05490a8af176ab4ba945d327d448387"></a> +<h2 class="memtitle"><span class="permalink"><a href="#af05490a8af176ab4ba945d327d448387">&#9670;&#160;</a></span>NEORV32_CSR_XISA_enum</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">enum <a class="el" href="#af05490a8af176ab4ba945d327d448387">NEORV32_CSR_XISA_enum</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>CPU <b>mxisa</b> CSR (r/-): Machine <em>extended</em> instruction set extensions (NEORV32-specific) </p> +<table class="fieldtable"> +<tr><th colspan="2">Enumerator</th></tr><tr><td class="fieldname"><a id="af05490a8af176ab4ba945d327d448387accf1dd12be89e45df1423a5600789f2c" name="af05490a8af176ab4ba945d327d448387accf1dd12be89e45df1423a5600789f2c"></a>CSR_MXISA_ZICSR&#160;</td><td class="fielddoc"><p>CPU mxisa CSR (0): privileged architecture (r/-) </p> +</td></tr> +<tr><td class="fieldname"><a id="af05490a8af176ab4ba945d327d448387a6979d4389ed9f8605d338fc616d29f0e" name="af05490a8af176ab4ba945d327d448387a6979d4389ed9f8605d338fc616d29f0e"></a>CSR_MXISA_ZIFENCEI&#160;</td><td class="fielddoc"><p>CPU mxisa CSR (1): instruction stream sync (r/-) </p> +</td></tr> +<tr><td class="fieldname"><a id="af05490a8af176ab4ba945d327d448387a79b2b4b20e08ad31b50724a7a27fb20f" name="af05490a8af176ab4ba945d327d448387a79b2b4b20e08ad31b50724a7a27fb20f"></a>CSR_MXISA_ZMMUL&#160;</td><td class="fielddoc"><p>CPU mxisa CSR (2): hardware mul/div (r/-) </p> +</td></tr> +<tr><td class="fieldname"><a id="af05490a8af176ab4ba945d327d448387af422ae3b5caba59e33a29b5d069597e0" name="af05490a8af176ab4ba945d327d448387af422ae3b5caba59e33a29b5d069597e0"></a>CSR_MXISA_ZXCFU&#160;</td><td class="fielddoc"><p>CPU mxisa CSR (3): custom RISC-V instructions (r/-) </p> +</td></tr> +<tr><td class="fieldname"><a id="af05490a8af176ab4ba945d327d448387a56ec3195d0d27f362f58fadb2e037ed1" name="af05490a8af176ab4ba945d327d448387a56ec3195d0d27f362f58fadb2e037ed1"></a>CSR_MXISA_ZFINX&#160;</td><td class="fielddoc"><p>CPU mxisa CSR (5): FPU using x registers (r/-) </p> +</td></tr> +<tr><td class="fieldname"><a id="af05490a8af176ab4ba945d327d448387ab1f289cfaa9f54f7831a2abcdf9fca2e" name="af05490a8af176ab4ba945d327d448387ab1f289cfaa9f54f7831a2abcdf9fca2e"></a>CSR_MXISA_ZICOND&#160;</td><td class="fielddoc"><p>CPU mxisa CSR (6): integer conditional operations (r/-) </p> +</td></tr> +<tr><td class="fieldname"><a id="af05490a8af176ab4ba945d327d448387a42a3b78195741af4b6aeeb98cbea46fe" name="af05490a8af176ab4ba945d327d448387a42a3b78195741af4b6aeeb98cbea46fe"></a>CSR_MXISA_ZICNTR&#160;</td><td class="fielddoc"><p>CPU mxisa CSR (7): standard instruction, cycle and time counter CSRs (r/-) </p> +</td></tr> +<tr><td class="fieldname"><a id="af05490a8af176ab4ba945d327d448387a6938948290d86b0ad25923f35d6c86d3" name="af05490a8af176ab4ba945d327d448387a6938948290d86b0ad25923f35d6c86d3"></a>CSR_MXISA_SMPMP&#160;</td><td class="fielddoc"><p>CPU mxisa CSR (8): physical memory protection (r/-) </p> +</td></tr> +<tr><td class="fieldname"><a id="af05490a8af176ab4ba945d327d448387ac13e6883af3a9da18057462239b9fb34" name="af05490a8af176ab4ba945d327d448387ac13e6883af3a9da18057462239b9fb34"></a>CSR_MXISA_ZIHPM&#160;</td><td class="fielddoc"><p>CPU mxisa CSR (9): hardware performance monitors (r/-) </p> +</td></tr> +<tr><td class="fieldname"><a id="af05490a8af176ab4ba945d327d448387ab6aec595e6aa5ce7c98c7806d23d7af5" name="af05490a8af176ab4ba945d327d448387ab6aec595e6aa5ce7c98c7806d23d7af5"></a>CSR_MXISA_SDEXT&#160;</td><td class="fielddoc"><p>CPU mxisa CSR (10): RISC-V debug mode (r/-) </p> +</td></tr> +<tr><td class="fieldname"><a id="af05490a8af176ab4ba945d327d448387a59eae4272528f589f299ef9cce45af5b" name="af05490a8af176ab4ba945d327d448387a59eae4272528f589f299ef9cce45af5b"></a>CSR_MXISA_SDTRIG&#160;</td><td class="fielddoc"><p>CPU mxisa CSR (11): RISC-V trigger module (r/-) </p> +</td></tr> +<tr><td class="fieldname"><a id="af05490a8af176ab4ba945d327d448387a9b121ec0ad6271b6e07658f861015f6a" name="af05490a8af176ab4ba945d327d448387a9b121ec0ad6271b6e07658f861015f6a"></a>CSR_MXISA_IS_SIM&#160;</td><td class="fielddoc"><p>CPU mxisa CSR (20): this might be a simulation when set (r/-) </p> +</td></tr> +<tr><td class="fieldname"><a id="af05490a8af176ab4ba945d327d448387a6843c660d75f33e4252c7fccd4565a2d" name="af05490a8af176ab4ba945d327d448387a6843c660d75f33e4252c7fccd4565a2d"></a>CSR_MXISA_RFHWRST&#160;</td><td class="fielddoc"><p>CPU mxisa CSR (29): Register file has full hardware reset (r/-) </p> +</td></tr> +<tr><td class="fieldname"><a id="af05490a8af176ab4ba945d327d448387a48e57689f8a5b51d9ee9d648da7efc64" name="af05490a8af176ab4ba945d327d448387a48e57689f8a5b51d9ee9d648da7efc64"></a>CSR_MXISA_FASTMUL&#160;</td><td class="fielddoc"><p>CPU mxisa CSR (30): DSP-based multiplication (M extensions only) (r/-) </p> +</td></tr> +<tr><td class="fieldname"><a id="af05490a8af176ab4ba945d327d448387ad5ac9e2188757e6c42c159f0c5887868" name="af05490a8af176ab4ba945d327d448387ad5ac9e2188757e6c42c159f0c5887868"></a>CSR_MXISA_FASTSHIFT&#160;</td><td class="fielddoc"><p>CPU mxisa CSR (31): parallel logic for shifts (barrel shifters) (r/-) </p> +</td></tr> +</table> + +</div> +</div> +<a id="acb0fcbc551fec4c45676ff1317be24e1" name="acb0fcbc551fec4c45676ff1317be24e1"></a> +<h2 class="memtitle"><span class="permalink"><a href="#acb0fcbc551fec4c45676ff1317be24e1">&#9670;&#160;</a></span>NEORV32_EXCEPTION_CODES_enum</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">enum <a class="el" href="#acb0fcbc551fec4c45676ff1317be24e1">NEORV32_EXCEPTION_CODES_enum</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Trap codes from mcause CSR. </p> +<table class="fieldtable"> +<tr><th colspan="2">Enumerator</th></tr><tr><td class="fieldname"><a id="acb0fcbc551fec4c45676ff1317be24e1a0a8010d7cc91b9557973a7a118828bee" name="acb0fcbc551fec4c45676ff1317be24e1a0a8010d7cc91b9557973a7a118828bee"></a>TRAP_CODE_I_MISALIGNED&#160;</td><td class="fielddoc"><p>0.0: Instruction address misaligned </p> +</td></tr> +<tr><td class="fieldname"><a id="acb0fcbc551fec4c45676ff1317be24e1a6a0ebfce4e18f36aeb43d5a65445cfe1" name="acb0fcbc551fec4c45676ff1317be24e1a6a0ebfce4e18f36aeb43d5a65445cfe1"></a>TRAP_CODE_I_ACCESS&#160;</td><td class="fielddoc"><p>0.1: Instruction (bus) access fault </p> +</td></tr> +<tr><td class="fieldname"><a id="acb0fcbc551fec4c45676ff1317be24e1af1ad8f557f3b685b59a913611e1da173" name="acb0fcbc551fec4c45676ff1317be24e1af1ad8f557f3b685b59a913611e1da173"></a>TRAP_CODE_I_ILLEGAL&#160;</td><td class="fielddoc"><p>0.2: Illegal instruction </p> +</td></tr> +<tr><td class="fieldname"><a id="acb0fcbc551fec4c45676ff1317be24e1a2c9510cb7583a0144f96678fc217335e" name="acb0fcbc551fec4c45676ff1317be24e1a2c9510cb7583a0144f96678fc217335e"></a>TRAP_CODE_BREAKPOINT&#160;</td><td class="fielddoc"><p>0.3: Breakpoint (EBREAK instruction) </p> +</td></tr> +<tr><td class="fieldname"><a id="acb0fcbc551fec4c45676ff1317be24e1a69e68a954da0bb33d1624484a6777ff9" name="acb0fcbc551fec4c45676ff1317be24e1a69e68a954da0bb33d1624484a6777ff9"></a>TRAP_CODE_L_MISALIGNED&#160;</td><td class="fielddoc"><p>0.4: Load address misaligned </p> +</td></tr> +<tr><td class="fieldname"><a id="acb0fcbc551fec4c45676ff1317be24e1a28448f0c670169140dc28b6794310cea" name="acb0fcbc551fec4c45676ff1317be24e1a28448f0c670169140dc28b6794310cea"></a>TRAP_CODE_L_ACCESS&#160;</td><td class="fielddoc"><p>0.5: Load (bus) access fault </p> +</td></tr> +<tr><td class="fieldname"><a id="acb0fcbc551fec4c45676ff1317be24e1a19708405f9f6300edf6b992c6d408a2d" name="acb0fcbc551fec4c45676ff1317be24e1a19708405f9f6300edf6b992c6d408a2d"></a>TRAP_CODE_S_MISALIGNED&#160;</td><td class="fielddoc"><p>0.6: Store address misaligned </p> +</td></tr> +<tr><td class="fieldname"><a id="acb0fcbc551fec4c45676ff1317be24e1a70bcfc75fe1056d93a3606f78c0cb887" name="acb0fcbc551fec4c45676ff1317be24e1a70bcfc75fe1056d93a3606f78c0cb887"></a>TRAP_CODE_S_ACCESS&#160;</td><td class="fielddoc"><p>0.7: Store (bus) access fault </p> +</td></tr> +<tr><td class="fieldname"><a id="acb0fcbc551fec4c45676ff1317be24e1aa102472d6a264bb92e0581ccaa413e02" name="acb0fcbc551fec4c45676ff1317be24e1aa102472d6a264bb92e0581ccaa413e02"></a>TRAP_CODE_UENV_CALL&#160;</td><td class="fielddoc"><p>0.8: Environment call from user mode (ECALL instruction) </p> +</td></tr> +<tr><td class="fieldname"><a id="acb0fcbc551fec4c45676ff1317be24e1a20e5a2680f2f5956bfa92852d5544eac" name="acb0fcbc551fec4c45676ff1317be24e1a20e5a2680f2f5956bfa92852d5544eac"></a>TRAP_CODE_MENV_CALL&#160;</td><td class="fielddoc"><p>0.11: Environment call from machine mode (ECALL instruction) </p> +</td></tr> +<tr><td class="fieldname"><a id="acb0fcbc551fec4c45676ff1317be24e1ae0cebf99f36ef6be60e4a9d2c9f894b0" name="acb0fcbc551fec4c45676ff1317be24e1ae0cebf99f36ef6be60e4a9d2c9f894b0"></a>TRAP_CODE_MSI&#160;</td><td class="fielddoc"><p>1.3: Machine software interrupt </p> +</td></tr> +<tr><td class="fieldname"><a id="acb0fcbc551fec4c45676ff1317be24e1a187ae38819b81672c15808e63c3b46b7" name="acb0fcbc551fec4c45676ff1317be24e1a187ae38819b81672c15808e63c3b46b7"></a>TRAP_CODE_MTI&#160;</td><td class="fielddoc"><p>1.7: Machine timer interrupt </p> +</td></tr> +<tr><td class="fieldname"><a id="acb0fcbc551fec4c45676ff1317be24e1a1a412b9d8eefba7880555d34625d2cc0" name="acb0fcbc551fec4c45676ff1317be24e1a1a412b9d8eefba7880555d34625d2cc0"></a>TRAP_CODE_MEI&#160;</td><td class="fielddoc"><p>1.11: Machine external interrupt </p> +</td></tr> +<tr><td class="fieldname"><a id="acb0fcbc551fec4c45676ff1317be24e1a0cef77904935798d247d8396838297c1" name="acb0fcbc551fec4c45676ff1317be24e1a0cef77904935798d247d8396838297c1"></a>TRAP_CODE_FIRQ_0&#160;</td><td class="fielddoc"><p>1.16: Fast interrupt channel 0 </p> +</td></tr> +<tr><td class="fieldname"><a id="acb0fcbc551fec4c45676ff1317be24e1ae0b1049ae7f8cbfb6ff216e69ed5dae7" name="acb0fcbc551fec4c45676ff1317be24e1ae0b1049ae7f8cbfb6ff216e69ed5dae7"></a>TRAP_CODE_FIRQ_1&#160;</td><td class="fielddoc"><p>1.17: Fast interrupt channel 1 </p> +</td></tr> +<tr><td class="fieldname"><a id="acb0fcbc551fec4c45676ff1317be24e1ad753d3e2563b4fd663430af9f3888dc7" name="acb0fcbc551fec4c45676ff1317be24e1ad753d3e2563b4fd663430af9f3888dc7"></a>TRAP_CODE_FIRQ_2&#160;</td><td class="fielddoc"><p>1.18: Fast interrupt channel 2 </p> +</td></tr> +<tr><td class="fieldname"><a id="acb0fcbc551fec4c45676ff1317be24e1a356f8485166529503d0fb246bd0aeeb0" name="acb0fcbc551fec4c45676ff1317be24e1a356f8485166529503d0fb246bd0aeeb0"></a>TRAP_CODE_FIRQ_3&#160;</td><td class="fielddoc"><p>1.19: Fast interrupt channel 3 </p> +</td></tr> +<tr><td class="fieldname"><a id="acb0fcbc551fec4c45676ff1317be24e1aaa8e7bb251852ef75a78be71eef0b547" name="acb0fcbc551fec4c45676ff1317be24e1aaa8e7bb251852ef75a78be71eef0b547"></a>TRAP_CODE_FIRQ_4&#160;</td><td class="fielddoc"><p>1.20: Fast interrupt channel 4 </p> +</td></tr> +<tr><td class="fieldname"><a id="acb0fcbc551fec4c45676ff1317be24e1a5789dfabd8ec265fa0734ddd94e98757" name="acb0fcbc551fec4c45676ff1317be24e1a5789dfabd8ec265fa0734ddd94e98757"></a>TRAP_CODE_FIRQ_5&#160;</td><td class="fielddoc"><p>1.21: Fast interrupt channel 5 </p> +</td></tr> +<tr><td class="fieldname"><a id="acb0fcbc551fec4c45676ff1317be24e1a809e997f55e83c6812c965655511d473" name="acb0fcbc551fec4c45676ff1317be24e1a809e997f55e83c6812c965655511d473"></a>TRAP_CODE_FIRQ_6&#160;</td><td class="fielddoc"><p>1.22: Fast interrupt channel 6 </p> +</td></tr> +<tr><td class="fieldname"><a id="acb0fcbc551fec4c45676ff1317be24e1aeab719bcce9e9551bd6da65a7ae08a26" name="acb0fcbc551fec4c45676ff1317be24e1aeab719bcce9e9551bd6da65a7ae08a26"></a>TRAP_CODE_FIRQ_7&#160;</td><td class="fielddoc"><p>1.23: Fast interrupt channel 7 </p> +</td></tr> +<tr><td class="fieldname"><a id="acb0fcbc551fec4c45676ff1317be24e1abfd21d1380dcacb9282e525da104d916" name="acb0fcbc551fec4c45676ff1317be24e1abfd21d1380dcacb9282e525da104d916"></a>TRAP_CODE_FIRQ_8&#160;</td><td class="fielddoc"><p>1.24: Fast interrupt channel 8 </p> +</td></tr> +<tr><td class="fieldname"><a id="acb0fcbc551fec4c45676ff1317be24e1a350e762a599479fb2c6d23ccc5ee22b4" name="acb0fcbc551fec4c45676ff1317be24e1a350e762a599479fb2c6d23ccc5ee22b4"></a>TRAP_CODE_FIRQ_9&#160;</td><td class="fielddoc"><p>1.25: Fast interrupt channel 9 </p> +</td></tr> +<tr><td class="fieldname"><a id="acb0fcbc551fec4c45676ff1317be24e1a4f6b9c6bba91fe04becb776ad22dcf42" name="acb0fcbc551fec4c45676ff1317be24e1a4f6b9c6bba91fe04becb776ad22dcf42"></a>TRAP_CODE_FIRQ_10&#160;</td><td class="fielddoc"><p>1.26: Fast interrupt channel 10 </p> +</td></tr> +<tr><td class="fieldname"><a id="acb0fcbc551fec4c45676ff1317be24e1a874dcc43cf8fbbf2e0614e7db9e38334" name="acb0fcbc551fec4c45676ff1317be24e1a874dcc43cf8fbbf2e0614e7db9e38334"></a>TRAP_CODE_FIRQ_11&#160;</td><td class="fielddoc"><p>1.27: Fast interrupt channel 11 </p> +</td></tr> +<tr><td class="fieldname"><a id="acb0fcbc551fec4c45676ff1317be24e1a151f01e5f284f876cafafc7427720e4c" name="acb0fcbc551fec4c45676ff1317be24e1a151f01e5f284f876cafafc7427720e4c"></a>TRAP_CODE_FIRQ_12&#160;</td><td class="fielddoc"><p>1.28: Fast interrupt channel 12 </p> +</td></tr> +<tr><td class="fieldname"><a id="acb0fcbc551fec4c45676ff1317be24e1a7c8e97297cc4dcd6d5a1de65a124f3e9" name="acb0fcbc551fec4c45676ff1317be24e1a7c8e97297cc4dcd6d5a1de65a124f3e9"></a>TRAP_CODE_FIRQ_13&#160;</td><td class="fielddoc"><p>1.29: Fast interrupt channel 13 </p> +</td></tr> +<tr><td class="fieldname"><a id="acb0fcbc551fec4c45676ff1317be24e1a821f813de47eb781ab7715f780da3b1e" name="acb0fcbc551fec4c45676ff1317be24e1a821f813de47eb781ab7715f780da3b1e"></a>TRAP_CODE_FIRQ_14&#160;</td><td class="fielddoc"><p>1.30: Fast interrupt channel 14 </p> +</td></tr> +<tr><td class="fieldname"><a id="acb0fcbc551fec4c45676ff1317be24e1aa4eeafe2f6f59aff01e29461c664a110" name="acb0fcbc551fec4c45676ff1317be24e1aa4eeafe2f6f59aff01e29461c664a110"></a>TRAP_CODE_FIRQ_15&#160;</td><td class="fielddoc"><p>1.31: Fast interrupt channel 15 </p> +</td></tr> +</table> + +</div> +</div> +<a id="a5cb925a3e41efd5e767bb39b3ee60cfe" name="a5cb925a3e41efd5e767bb39b3ee60cfe"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a5cb925a3e41efd5e767bb39b3ee60cfe">&#9670;&#160;</a></span>NEORV32_HPMCNT_EVENT_enum</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">enum <a class="el" href="#a5cb925a3e41efd5e767bb39b3ee60cfe">NEORV32_HPMCNT_EVENT_enum</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>CPU <b>mhpmevent</b> hardware performance monitor events </p> +<table class="fieldtable"> +<tr><th colspan="2">Enumerator</th></tr><tr><td class="fieldname"><a id="a5cb925a3e41efd5e767bb39b3ee60cfea2b683572525adc02ce0910031cfea914" name="a5cb925a3e41efd5e767bb39b3ee60cfea2b683572525adc02ce0910031cfea914"></a>HPMCNT_EVENT_CY&#160;</td><td class="fielddoc"><p>CPU mhpmevent CSR (0): Active cycle </p> +</td></tr> +<tr><td class="fieldname"><a id="a5cb925a3e41efd5e767bb39b3ee60cfea578ef6fc107c22b5cb7be5950f695640" name="a5cb925a3e41efd5e767bb39b3ee60cfea578ef6fc107c22b5cb7be5950f695640"></a>HPMCNT_EVENT_TM&#160;</td><td class="fielddoc"><p>CPU mhpmevent CSR (1): Reserved </p> +</td></tr> +<tr><td class="fieldname"><a id="a5cb925a3e41efd5e767bb39b3ee60cfeaab438295e5f00ffe4c2457a54ee9bfc4" name="a5cb925a3e41efd5e767bb39b3ee60cfeaab438295e5f00ffe4c2457a54ee9bfc4"></a>HPMCNT_EVENT_IR&#160;</td><td class="fielddoc"><p>CPU mhpmevent CSR (2): Retired instruction </p> +</td></tr> +<tr><td class="fieldname"><a id="a5cb925a3e41efd5e767bb39b3ee60cfea685ed663611d988702ec59c254eb61dd" name="a5cb925a3e41efd5e767bb39b3ee60cfea685ed663611d988702ec59c254eb61dd"></a>HPMCNT_EVENT_COMPR&#160;</td><td class="fielddoc"><p>CPU mhpmevent CSR (3): Executed compressed instruction </p> +</td></tr> +<tr><td class="fieldname"><a id="a5cb925a3e41efd5e767bb39b3ee60cfeabcb123b5b150b4413e5fd48475faab27" name="a5cb925a3e41efd5e767bb39b3ee60cfeabcb123b5b150b4413e5fd48475faab27"></a>HPMCNT_EVENT_WAIT_DIS&#160;</td><td class="fielddoc"><p>CPU mhpmevent CSR (4): Instruction dispatch wait cycle </p> +</td></tr> +<tr><td class="fieldname"><a id="a5cb925a3e41efd5e767bb39b3ee60cfeaffbb04d0053ebd079c6cacb4e5e7ed6b" name="a5cb925a3e41efd5e767bb39b3ee60cfeaffbb04d0053ebd079c6cacb4e5e7ed6b"></a>HPMCNT_EVENT_WAIT_ALU&#160;</td><td class="fielddoc"><p>CPU mhpmevent CSR (5): Multi-cycle ALU co-processor wait cycle </p> +</td></tr> +<tr><td class="fieldname"><a id="a5cb925a3e41efd5e767bb39b3ee60cfea9e1e2b50352b2555e9c64e76776919a6" name="a5cb925a3e41efd5e767bb39b3ee60cfea9e1e2b50352b2555e9c64e76776919a6"></a>HPMCNT_EVENT_BRANCH&#160;</td><td class="fielddoc"><p>CPU mhpmevent CSR (6): Executed branch instruction </p> +</td></tr> +<tr><td class="fieldname"><a id="a5cb925a3e41efd5e767bb39b3ee60cfea0f15c5a824cb1678423ac4ef72a5f4f5" name="a5cb925a3e41efd5e767bb39b3ee60cfea0f15c5a824cb1678423ac4ef72a5f4f5"></a>HPMCNT_EVENT_BRANCHED&#160;</td><td class="fielddoc"><p>CPU mhpmevent CSR (7): Control flow transfer </p> +</td></tr> +<tr><td class="fieldname"><a id="a5cb925a3e41efd5e767bb39b3ee60cfea1a06f216e1a12afa0b90d6e1218b3c91" name="a5cb925a3e41efd5e767bb39b3ee60cfea1a06f216e1a12afa0b90d6e1218b3c91"></a>HPMCNT_EVENT_LOAD&#160;</td><td class="fielddoc"><p>CPU mhpmevent CSR (8): Executed load operation </p> +</td></tr> +<tr><td class="fieldname"><a id="a5cb925a3e41efd5e767bb39b3ee60cfea6a942852e3cd85616a63addb8e9d76f2" name="a5cb925a3e41efd5e767bb39b3ee60cfea6a942852e3cd85616a63addb8e9d76f2"></a>HPMCNT_EVENT_STORE&#160;</td><td class="fielddoc"><p>CPU mhpmevent CSR (9): Executed store operation </p> +</td></tr> +<tr><td class="fieldname"><a id="a5cb925a3e41efd5e767bb39b3ee60cfea67a59934bc66bc7ccf82d24fe8a18a3b" name="a5cb925a3e41efd5e767bb39b3ee60cfea67a59934bc66bc7ccf82d24fe8a18a3b"></a>HPMCNT_EVENT_WAIT_LSU&#160;</td><td class="fielddoc"><p>CPU mhpmevent CSR (10): Load-store unit memory wait cycle </p> +</td></tr> +<tr><td class="fieldname"><a id="a5cb925a3e41efd5e767bb39b3ee60cfea3a4f5bf9251def87a71162dbcf9043c5" name="a5cb925a3e41efd5e767bb39b3ee60cfea3a4f5bf9251def87a71162dbcf9043c5"></a>HPMCNT_EVENT_TRAP&#160;</td><td class="fielddoc"><p>CPU mhpmevent CSR (11): Entered trap </p> +</td></tr> +</table> + +</div> +</div> +<a id="a8f2418fb5e2175f35ee2362469ce01f5" name="a8f2418fb5e2175f35ee2362469ce01f5"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a8f2418fb5e2175f35ee2362469ce01f5">&#9670;&#160;</a></span>NEORV32_PMP_MODES_enum</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">enum <a class="el" href="#a8f2418fb5e2175f35ee2362469ce01f5">NEORV32_PMP_MODES_enum</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>PMP modes </p> +<table class="fieldtable"> +<tr><th colspan="2">Enumerator</th></tr><tr><td class="fieldname"><a id="a8f2418fb5e2175f35ee2362469ce01f5a003ccfae4aae1dad4fd65d5d4c7737c4" name="a8f2418fb5e2175f35ee2362469ce01f5a003ccfae4aae1dad4fd65d5d4c7737c4"></a>PMP_OFF&#160;</td><td class="fielddoc"><p>'00': entry disabled </p> +</td></tr> +<tr><td class="fieldname"><a id="a8f2418fb5e2175f35ee2362469ce01f5a629a81a205abee94bad9d5bb5dfa26b1" name="a8f2418fb5e2175f35ee2362469ce01f5a629a81a205abee94bad9d5bb5dfa26b1"></a>PMP_TOR&#160;</td><td class="fielddoc"><p>'01': TOR mode (top of region) </p> +</td></tr> +<tr><td class="fieldname"><a id="a8f2418fb5e2175f35ee2362469ce01f5aae0e0c33b0d034cb50286239f955d892" name="a8f2418fb5e2175f35ee2362469ce01f5aae0e0c33b0d034cb50286239f955d892"></a>PMP_NA4&#160;</td><td class="fielddoc"><p>'10': Naturally-aligned power of two region (4 bytes) </p> +</td></tr> +<tr><td class="fieldname"><a id="a8f2418fb5e2175f35ee2362469ce01f5ad555e9dfc0c00612bdea623617ff2820" name="a8f2418fb5e2175f35ee2362469ce01f5ad555e9dfc0c00612bdea623617ff2820"></a>PMP_NAPOT&#160;</td><td class="fielddoc"><p>'11': Naturally-aligned power of two region (greater than 4 bytes ) </p> +</td></tr> +</table> + +</div> +</div> +<a id="abc0e8daad1e9beda4d9950452cc930ea" name="abc0e8daad1e9beda4d9950452cc930ea"></a> +<h2 class="memtitle"><span class="permalink"><a href="#abc0e8daad1e9beda4d9950452cc930ea">&#9670;&#160;</a></span>NEORV32_PMPCFG_ATTRIBUTES_enum</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">enum <a class="el" href="#abc0e8daad1e9beda4d9950452cc930ea">NEORV32_PMPCFG_ATTRIBUTES_enum</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>CPU <b>pmpcfg</b> PMP configuration attributes </p> +<table class="fieldtable"> +<tr><th colspan="2">Enumerator</th></tr><tr><td class="fieldname"><a id="abc0e8daad1e9beda4d9950452cc930eaad3aca82a2ab57364e83f677d3d4f71a6" name="abc0e8daad1e9beda4d9950452cc930eaad3aca82a2ab57364e83f677d3d4f71a6"></a>PMPCFG_R&#160;</td><td class="fielddoc"><p>CPU pmpcfg attribute (0): Read </p> +</td></tr> +<tr><td class="fieldname"><a id="abc0e8daad1e9beda4d9950452cc930eaa7689905760f917499b1151cced384d2f" name="abc0e8daad1e9beda4d9950452cc930eaa7689905760f917499b1151cced384d2f"></a>PMPCFG_W&#160;</td><td class="fielddoc"><p>CPU pmpcfg attribute (1): Write </p> +</td></tr> +<tr><td class="fieldname"><a id="abc0e8daad1e9beda4d9950452cc930eaaec94712deafba09c0cf956c6fd68fa8d" name="abc0e8daad1e9beda4d9950452cc930eaaec94712deafba09c0cf956c6fd68fa8d"></a>PMPCFG_X&#160;</td><td class="fielddoc"><p>CPU pmpcfg attribute (2): Execute </p> +</td></tr> +<tr><td class="fieldname"><a id="abc0e8daad1e9beda4d9950452cc930eaaae1e6440956ad6b7cbf6062aa50f43b1" name="abc0e8daad1e9beda4d9950452cc930eaaae1e6440956ad6b7cbf6062aa50f43b1"></a>PMPCFG_A_LSB&#160;</td><td class="fielddoc"><p>CPU pmpcfg attribute (3): Mode LSB <a class="el" href="#a8f2418fb5e2175f35ee2362469ce01f5">NEORV32_PMP_MODES_enum</a> </p> +</td></tr> +<tr><td class="fieldname"><a id="abc0e8daad1e9beda4d9950452cc930eaa67ad3243eeb74f86a01efbade76f21e4" name="abc0e8daad1e9beda4d9950452cc930eaa67ad3243eeb74f86a01efbade76f21e4"></a>PMPCFG_A_MSB&#160;</td><td class="fielddoc"><p>CPU pmpcfg attribute (4): Mode MSB <a class="el" href="#a8f2418fb5e2175f35ee2362469ce01f5">NEORV32_PMP_MODES_enum</a> </p> +</td></tr> +<tr><td class="fieldname"><a id="abc0e8daad1e9beda4d9950452cc930eaa59c294bc43d2117bb55e301eec683f14" name="abc0e8daad1e9beda4d9950452cc930eaa59c294bc43d2117bb55e301eec683f14"></a>PMPCFG_L&#160;</td><td class="fielddoc"><p>CPU pmpcfg attribute (7): Locked </p> +</td></tr> +</table> + +</div> +</div> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/neorv32__cpu__csr_8h_source.html b/sw/neorv32__cpu__csr_8h_source.html new file mode 100644 index 0000000000..6ccea44610 --- /dev/null +++ b/sw/neorv32__cpu__csr_8h_source.html @@ -0,0 +1,802 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/lib/include/neorv32_cpu_csr.h Source File</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_7d04193005ada6f9450f847f4adb6b5b.html">lib</a></li><li class="navelem"><a class="el" href="dir_752b1e5d3973bf735fa78bf6b4727df9.html">include</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="headertitle"><div class="title">neorv32_cpu_csr.h</div></div> +</div><!--header--> +<div class="contents"> +<a href="neorv32__cpu__csr_8h.html">Go to the documentation of this file.</a><div class="fragment"><div class="line"><a id="l00001" name="l00001"></a><span class="lineno"> 1</span><span class="comment">// ================================================================================ //</span></div> +<div class="line"><a id="l00002" name="l00002"></a><span class="lineno"> 2</span><span class="comment">// The NEORV32 RISC-V Processor - https://github.com/stnolting/neorv32 //</span></div> +<div class="line"><a id="l00003" name="l00003"></a><span class="lineno"> 3</span><span class="comment">// Copyright (c) NEORV32 contributors. //</span></div> +<div class="line"><a id="l00004" name="l00004"></a><span class="lineno"> 4</span><span class="comment">// Copyright (c) 2020 - 2024 Stephan Nolting. All rights reserved. //</span></div> +<div class="line"><a id="l00005" name="l00005"></a><span class="lineno"> 5</span><span class="comment">// Licensed under the BSD-3-Clause license, see LICENSE for details. //</span></div> +<div class="line"><a id="l00006" name="l00006"></a><span class="lineno"> 6</span><span class="comment">// SPDX-License-Identifier: BSD-3-Clause //</span></div> +<div class="line"><a id="l00007" name="l00007"></a><span class="lineno"> 7</span><span class="comment">// ================================================================================ //</span></div> +<div class="line"><a id="l00008" name="l00008"></a><span class="lineno"> 8</span> </div> +<div class="line"><a id="l00016" name="l00016"></a><span class="lineno"> 16</span><span class="preprocessor">#ifndef neorv32_cpu_csr_h</span></div> +<div class="line"><a id="l00017" name="l00017"></a><span class="lineno"> 17</span><span class="preprocessor">#define neorv32_cpu_csr_h</span></div> +<div class="line"><a id="l00018" name="l00018"></a><span class="lineno"> 18</span> </div> +<div class="line"><a id="l00019" name="l00019"></a><span class="lineno"> 19</span><span class="preprocessor">#include &lt;stdint.h&gt;</span></div> +<div class="line"><a id="l00020" name="l00020"></a><span class="lineno"> 20</span> </div> +<div class="line"><a id="l00021" name="l00021"></a><span class="lineno"> 21</span> </div> +<div class="line"><a id="l00022" name="l00022"></a><span class="lineno"> 22</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen00025" data-start="{" data-end="};"> +<div class="line"><a id="l00025" name="l00025"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49"> 25</a></span><span class="keyword">enum</span> <a class="code hl_enumeration" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49">NEORV32_CSR_enum</a> {</div> +<div class="line"><a id="l00026" name="l00026"></a><span class="lineno"> 26</span> <span class="comment">/* floating-point unit control and status */</span></div> +<div class="line"><a id="l00027" name="l00027"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a625f606c14fd4d7224d7109e10508e7a"> 27</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a625f606c14fd4d7224d7109e10508e7a">CSR_FFLAGS</a> = 0x001, </div> +<div class="line"><a id="l00028" name="l00028"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a7f198c465959dde37b7056dd06d45812"> 28</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a7f198c465959dde37b7056dd06d45812">CSR_FRM</a> = 0x002, </div> +<div class="line"><a id="l00029" name="l00029"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a5e1abf46b4f55bd18e1d132b32696ab6"> 29</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a5e1abf46b4f55bd18e1d132b32696ab6">CSR_FCSR</a> = 0x003, </div> +<div class="line"><a id="l00031" name="l00031"></a><span class="lineno"> 31</span> <span class="comment">/* machine control and status */</span></div> +<div class="line"><a id="l00032" name="l00032"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ad0e5de789d6390f750b8af03cdd15450"> 32</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ad0e5de789d6390f750b8af03cdd15450">CSR_MSTATUS</a> = 0x300, </div> +<div class="line"><a id="l00033" name="l00033"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ade079242596ce14ce1ba9842ed29b84c"> 33</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ade079242596ce14ce1ba9842ed29b84c">CSR_MISA</a> = 0x301, </div> +<div class="line"><a id="l00034" name="l00034"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49acc0f9f5f3b5702f1b57f2ba3b6b62610"> 34</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49acc0f9f5f3b5702f1b57f2ba3b6b62610">CSR_MIE</a> = 0x304, </div> +<div class="line"><a id="l00035" name="l00035"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aa632d218400268df6dc6b289ff088d21"> 35</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aa632d218400268df6dc6b289ff088d21">CSR_MTVEC</a> = 0x305, </div> +<div class="line"><a id="l00036" name="l00036"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a1860dd9579906c67a3565063043dcf78"> 36</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a1860dd9579906c67a3565063043dcf78">CSR_MCOUNTEREN</a> = 0x306, </div> +<div class="line"><a id="l00037" name="l00037"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ac2541060307369b2031e9ec07bbd0067"> 37</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ac2541060307369b2031e9ec07bbd0067">CSR_MSTATUSH</a> = 0x310, </div> +<div class="line"><a id="l00038" name="l00038"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a3ce1dc0e2810f0df78feaa1c607a5ca6"> 38</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a3ce1dc0e2810f0df78feaa1c607a5ca6">CSR_MCOUNTINHIBIT</a> = 0x320, </div> +<div class="line"><a id="l00040" name="l00040"></a><span class="lineno"> 40</span> <span class="comment">/* machine configuration */</span></div> +<div class="line"><a id="l00041" name="l00041"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a9c55619ffb05e84b7210e2d47326fa98"> 41</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a9c55619ffb05e84b7210e2d47326fa98">CSR_MENVCFG</a> = 0x30a, </div> +<div class="line"><a id="l00042" name="l00042"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a46b8d3c288cbbfbf5a0af6e5cd8c5bc8"> 42</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a46b8d3c288cbbfbf5a0af6e5cd8c5bc8">CSR_MENVCFGH</a> = 0x31a, </div> +<div class="line"><a id="l00044" name="l00044"></a><span class="lineno"> 44</span> <span class="comment">/* hardware performance monitors - event configuration */</span></div> +<div class="line"><a id="l00045" name="l00045"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a4a93ac5ab276cfd2f9cd296c8ce1bff6"> 45</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a4a93ac5ab276cfd2f9cd296c8ce1bff6">CSR_MHPMEVENT3</a> = 0x323, </div> +<div class="line"><a id="l00046" name="l00046"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ab5f998725e002ffc2ff516ee973fe459"> 46</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ab5f998725e002ffc2ff516ee973fe459">CSR_MHPMEVENT4</a> = 0x324, </div> +<div class="line"><a id="l00047" name="l00047"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a2524659ca2785af51af7acf9cd560a9d"> 47</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a2524659ca2785af51af7acf9cd560a9d">CSR_MHPMEVENT5</a> = 0x325, </div> +<div class="line"><a id="l00048" name="l00048"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a1cfa1e3bc3c8a1c9a86c251a510d11cd"> 48</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a1cfa1e3bc3c8a1c9a86c251a510d11cd">CSR_MHPMEVENT6</a> = 0x326, </div> +<div class="line"><a id="l00049" name="l00049"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a2e53e6e01ca8d1b801f6dfba602f3f59"> 49</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a2e53e6e01ca8d1b801f6dfba602f3f59">CSR_MHPMEVENT7</a> = 0x327, </div> +<div class="line"><a id="l00050" name="l00050"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ad6296ca83bbe1280624f3c21adbd8a79"> 50</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ad6296ca83bbe1280624f3c21adbd8a79">CSR_MHPMEVENT8</a> = 0x328, </div> +<div class="line"><a id="l00051" name="l00051"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49af6727a9bdd60ccf020812095b7396632"> 51</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49af6727a9bdd60ccf020812095b7396632">CSR_MHPMEVENT9</a> = 0x329, </div> +<div class="line"><a id="l00052" name="l00052"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a23850b1804966cde2c1e84cde752d512"> 52</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a23850b1804966cde2c1e84cde752d512">CSR_MHPMEVENT10</a> = 0x32a, </div> +<div class="line"><a id="l00053" name="l00053"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a7fb1de2019dd2b548084d5ca1630efbf"> 53</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a7fb1de2019dd2b548084d5ca1630efbf">CSR_MHPMEVENT11</a> = 0x32b, </div> +<div class="line"><a id="l00054" name="l00054"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ad648b5ece209d47e9484fd7aa83e8e5f"> 54</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ad648b5ece209d47e9484fd7aa83e8e5f">CSR_MHPMEVENT12</a> = 0x32c, </div> +<div class="line"><a id="l00055" name="l00055"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a8c31899b81bb5dba9b92a0f0ca71aea6"> 55</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a8c31899b81bb5dba9b92a0f0ca71aea6">CSR_MHPMEVENT13</a> = 0x32d, </div> +<div class="line"><a id="l00056" name="l00056"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a964a6a50d0138447fad47e9c982a7ba4"> 56</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a964a6a50d0138447fad47e9c982a7ba4">CSR_MHPMEVENT14</a> = 0x32e, </div> +<div class="line"><a id="l00057" name="l00057"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a06dfdeed757606529e4a99c033691b54"> 57</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a06dfdeed757606529e4a99c033691b54">CSR_MHPMEVENT15</a> = 0x32f, </div> +<div class="line"><a id="l00059" name="l00059"></a><span class="lineno"> 59</span> <span class="comment">/* machine trap control */</span></div> +<div class="line"><a id="l00060" name="l00060"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ae29976bb072639975ad0cdb985c7f004"> 60</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ae29976bb072639975ad0cdb985c7f004">CSR_MSCRATCH</a> = 0x340, </div> +<div class="line"><a id="l00061" name="l00061"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a5d60a25a66754066589e8facb7d41153"> 61</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a5d60a25a66754066589e8facb7d41153">CSR_MEPC</a> = 0x341, </div> +<div class="line"><a id="l00062" name="l00062"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a2e14b57fee5376741634db7980a5005b"> 62</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a2e14b57fee5376741634db7980a5005b">CSR_MCAUSE</a> = 0x342, </div> +<div class="line"><a id="l00063" name="l00063"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a76d30359e3b54197fb53f9939734cf1e"> 63</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a76d30359e3b54197fb53f9939734cf1e">CSR_MTVAL</a> = 0x343, </div> +<div class="line"><a id="l00064" name="l00064"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49addb485275c954d1181d5bd4e4609082c"> 64</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49addb485275c954d1181d5bd4e4609082c">CSR_MIP</a> = 0x344, </div> +<div class="line"><a id="l00065" name="l00065"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a4f229c169ada239033a1383412ce58c8"> 65</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a4f229c169ada239033a1383412ce58c8">CSR_MTINST</a> = 0x34a, </div> +<div class="line"><a id="l00067" name="l00067"></a><span class="lineno"> 67</span> <span class="comment">/* physical memory protection */</span></div> +<div class="line"><a id="l00068" name="l00068"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49af1a79349e46a4829af78d2cdfd0dc44f"> 68</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49af1a79349e46a4829af78d2cdfd0dc44f">CSR_PMPCFG0</a> = 0x3a0, </div> +<div class="line"><a id="l00069" name="l00069"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a22eea318ec1ac72cc14e133b71ef4b16"> 69</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a22eea318ec1ac72cc14e133b71ef4b16">CSR_PMPCFG1</a> = 0x3a1, </div> +<div class="line"><a id="l00070" name="l00070"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a0c9492f6b956f088847f72b28e7b1446"> 70</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a0c9492f6b956f088847f72b28e7b1446">CSR_PMPCFG2</a> = 0x3a2, </div> +<div class="line"><a id="l00071" name="l00071"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a067ed3778590ae97dc9b16069f0ed850"> 71</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a067ed3778590ae97dc9b16069f0ed850">CSR_PMPCFG3</a> = 0x3a3, </div> +<div class="line"><a id="l00073" name="l00073"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a8941071db6145d34fff842249c0dcb9f"> 73</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a8941071db6145d34fff842249c0dcb9f">CSR_PMPADDR0</a> = 0x3b0, </div> +<div class="line"><a id="l00074" name="l00074"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a6a2933f3a1fa243de02db8a795e3ca41"> 74</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a6a2933f3a1fa243de02db8a795e3ca41">CSR_PMPADDR1</a> = 0x3b1, </div> +<div class="line"><a id="l00075" name="l00075"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aa0b8c0561e8a778dce9c3b86499ffc50"> 75</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aa0b8c0561e8a778dce9c3b86499ffc50">CSR_PMPADDR2</a> = 0x3b2, </div> +<div class="line"><a id="l00076" name="l00076"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a89bad989197e9358563557311b3c97e9"> 76</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a89bad989197e9358563557311b3c97e9">CSR_PMPADDR3</a> = 0x3b3, </div> +<div class="line"><a id="l00077" name="l00077"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ace4529c53ad2d46767f86d920eada507"> 77</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ace4529c53ad2d46767f86d920eada507">CSR_PMPADDR4</a> = 0x3b4, </div> +<div class="line"><a id="l00078" name="l00078"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ad9e78f71409fd7783cc2ae7c28b5e42c"> 78</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ad9e78f71409fd7783cc2ae7c28b5e42c">CSR_PMPADDR5</a> = 0x3b5, </div> +<div class="line"><a id="l00079" name="l00079"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49af57b5b7b57cd6e8b3489a27dfd702444"> 79</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49af57b5b7b57cd6e8b3489a27dfd702444">CSR_PMPADDR6</a> = 0x3b6, </div> +<div class="line"><a id="l00080" name="l00080"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ae8ea19cf3e527dbc0d36a43dfd1b7346"> 80</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ae8ea19cf3e527dbc0d36a43dfd1b7346">CSR_PMPADDR7</a> = 0x3b7, </div> +<div class="line"><a id="l00081" name="l00081"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aec68bf7e26e44170c24599f7c6a8365b"> 81</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aec68bf7e26e44170c24599f7c6a8365b">CSR_PMPADDR8</a> = 0x3b8, </div> +<div class="line"><a id="l00082" name="l00082"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a54d38c8cf364d886eb7ac64463eedf77"> 82</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a54d38c8cf364d886eb7ac64463eedf77">CSR_PMPADDR9</a> = 0x3b9, </div> +<div class="line"><a id="l00083" name="l00083"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ad97b6fe934a3bed6b02d0c8d81165d60"> 83</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ad97b6fe934a3bed6b02d0c8d81165d60">CSR_PMPADDR10</a> = 0x3ba, </div> +<div class="line"><a id="l00084" name="l00084"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a3e5708c0f79cf58ae761b6bb8c2a4383"> 84</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a3e5708c0f79cf58ae761b6bb8c2a4383">CSR_PMPADDR11</a> = 0x3bb, </div> +<div class="line"><a id="l00085" name="l00085"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a23026793ee53c8d55d23f63195368a6b"> 85</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a23026793ee53c8d55d23f63195368a6b">CSR_PMPADDR12</a> = 0x3bc, </div> +<div class="line"><a id="l00086" name="l00086"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a30879e88b250d3e94d9d9e728ffcc2cc"> 86</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a30879e88b250d3e94d9d9e728ffcc2cc">CSR_PMPADDR13</a> = 0x3bd, </div> +<div class="line"><a id="l00087" name="l00087"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a91a8b5008b4e08ab34c1516e21bf0ba8"> 87</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a91a8b5008b4e08ab34c1516e21bf0ba8">CSR_PMPADDR14</a> = 0x3be, </div> +<div class="line"><a id="l00088" name="l00088"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a6879b4bf5d2db92d236b9091df4841f2"> 88</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a6879b4bf5d2db92d236b9091df4841f2">CSR_PMPADDR15</a> = 0x3bf, </div> +<div class="line"><a id="l00090" name="l00090"></a><span class="lineno"> 90</span> <span class="comment">/* on-chip debugger - hardware trigger module */</span></div> +<div class="line"><a id="l00091" name="l00091"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aaae2f0b2e3f5a31dff933868873f6d5d"> 91</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aaae2f0b2e3f5a31dff933868873f6d5d">CSR_TSELECT</a> = 0x7a0, </div> +<div class="line"><a id="l00092" name="l00092"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a80eab0e17f5fe41edde485044674dc57"> 92</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a80eab0e17f5fe41edde485044674dc57">CSR_TDATA1</a> = 0x7a1, </div> +<div class="line"><a id="l00093" name="l00093"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49acf336638697242b691b691dc56b9aadc"> 93</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49acf336638697242b691b691dc56b9aadc">CSR_TDATA2</a> = 0x7a2, </div> +<div class="line"><a id="l00094" name="l00094"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49af67c819c104f7e3ec34f2cbb847cf83b"> 94</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49af67c819c104f7e3ec34f2cbb847cf83b">CSR_TINFO</a> = 0x7a4, </div> +<div class="line"><a id="l00096" name="l00096"></a><span class="lineno"> 96</span> <span class="comment">/* CPU debug mode CSRs - not accessible by software running outside of debug mode */</span></div> +<div class="line"><a id="l00097" name="l00097"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a6bb3ba59a25803d6f98faad67609a9a9"> 97</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a6bb3ba59a25803d6f98faad67609a9a9">CSR_DCSR</a> = 0x7b0, </div> +<div class="line"><a id="l00098" name="l00098"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49af4c98d949d2eb44f2518fdf314344d3b"> 98</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49af4c98d949d2eb44f2518fdf314344d3b">CSR_DPC</a> = 0x7b1, </div> +<div class="line"><a id="l00099" name="l00099"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a0f4a1ae740efd80d14d21e90f355e9d7"> 99</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a0f4a1ae740efd80d14d21e90f355e9d7">CSR_DSCRATCH0</a> = 0x7b2, </div> +<div class="line"><a id="l00101" name="l00101"></a><span class="lineno"> 101</span> <span class="comment">/* custom functions unit (CFU) registers */</span></div> +<div class="line"><a id="l00102" name="l00102"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ae0e9cf0b99b8614ea0b870d38970281f"> 102</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ae0e9cf0b99b8614ea0b870d38970281f">CSR_CFUREG0</a> = 0x800, </div> +<div class="line"><a id="l00103" name="l00103"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a382304065a6db773f925b80b9447b8a8"> 103</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a382304065a6db773f925b80b9447b8a8">CSR_CFUREG1</a> = 0x801, </div> +<div class="line"><a id="l00104" name="l00104"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a427d7cf036b49efd46166c01f0504b68"> 104</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a427d7cf036b49efd46166c01f0504b68">CSR_CFUREG2</a> = 0x802, </div> +<div class="line"><a id="l00105" name="l00105"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aefefa1cff0cf5d01109486e5a8bebedf"> 105</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aefefa1cff0cf5d01109486e5a8bebedf">CSR_CFUREG3</a> = 0x803, </div> +<div class="line"><a id="l00107" name="l00107"></a><span class="lineno"> 107</span> <span class="comment">/* machine counters and timers */</span></div> +<div class="line"><a id="l00108" name="l00108"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a32c22641ed66c6d20902306a2b1fad77"> 108</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a32c22641ed66c6d20902306a2b1fad77">CSR_MCYCLE</a> = 0xb00, </div> +<div class="line"><a id="l00109" name="l00109"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a98f5e2cf2d5dbb0125a222b0065c86eb"> 109</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a98f5e2cf2d5dbb0125a222b0065c86eb">CSR_MINSTRET</a> = 0xb02, </div> +<div class="line"><a id="l00110" name="l00110"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ae0a96f499dcde474af6ee620fbb1ebdc"> 110</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ae0a96f499dcde474af6ee620fbb1ebdc">CSR_MHPMCOUNTER3</a> = 0xb03, </div> +<div class="line"><a id="l00111" name="l00111"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a9b84bd948dd52a7779b5fd16beddaab9"> 111</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a9b84bd948dd52a7779b5fd16beddaab9">CSR_MHPMCOUNTER4</a> = 0xb04, </div> +<div class="line"><a id="l00112" name="l00112"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49af15d389bb8f91c989df488d231666394"> 112</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49af15d389bb8f91c989df488d231666394">CSR_MHPMCOUNTER5</a> = 0xb05, </div> +<div class="line"><a id="l00113" name="l00113"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49af65b9e99b9cadb3cb8d37f97cdbfeb9d"> 113</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49af65b9e99b9cadb3cb8d37f97cdbfeb9d">CSR_MHPMCOUNTER6</a> = 0xb06, </div> +<div class="line"><a id="l00114" name="l00114"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a919f39b0d299feb80403b42a466de444"> 114</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a919f39b0d299feb80403b42a466de444">CSR_MHPMCOUNTER7</a> = 0xb07, </div> +<div class="line"><a id="l00115" name="l00115"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a5a4cde90c547e913bddc719b3ab75e79"> 115</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a5a4cde90c547e913bddc719b3ab75e79">CSR_MHPMCOUNTER8</a> = 0xb08, </div> +<div class="line"><a id="l00116" name="l00116"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a18c2a249f1f7852f42f9e10dc59d46bb"> 116</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a18c2a249f1f7852f42f9e10dc59d46bb">CSR_MHPMCOUNTER9</a> = 0xb09, </div> +<div class="line"><a id="l00117" name="l00117"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a575e5342d8ec304c32dbbe99d6fd6c0f"> 117</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a575e5342d8ec304c32dbbe99d6fd6c0f">CSR_MHPMCOUNTER10</a> = 0xb0a, </div> +<div class="line"><a id="l00118" name="l00118"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a8840b3d4f45453fc96813ccb369a68e5"> 118</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a8840b3d4f45453fc96813ccb369a68e5">CSR_MHPMCOUNTER11</a> = 0xb0b, </div> +<div class="line"><a id="l00119" name="l00119"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a1328a226d36d23cc81740397bde47a4e"> 119</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a1328a226d36d23cc81740397bde47a4e">CSR_MHPMCOUNTER12</a> = 0xb0c, </div> +<div class="line"><a id="l00120" name="l00120"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a9bdd102877ff50d38c86c3d741aeb4b0"> 120</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a9bdd102877ff50d38c86c3d741aeb4b0">CSR_MHPMCOUNTER13</a> = 0xb0d, </div> +<div class="line"><a id="l00121" name="l00121"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49adae22d860d8162e15120051951e45229"> 121</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49adae22d860d8162e15120051951e45229">CSR_MHPMCOUNTER14</a> = 0xb0e, </div> +<div class="line"><a id="l00122" name="l00122"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a20400929087fabba410a098667d2d4ff"> 122</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a20400929087fabba410a098667d2d4ff">CSR_MHPMCOUNTER15</a> = 0xb0f, </div> +<div class="line"><a id="l00124" name="l00124"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a28fcfd06ca1012c19cf053e57689687b"> 124</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a28fcfd06ca1012c19cf053e57689687b">CSR_MCYCLEH</a> = 0xb80, </div> +<div class="line"><a id="l00125" name="l00125"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49afffb28b62b9baa127ae3bad919208988"> 125</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49afffb28b62b9baa127ae3bad919208988">CSR_MINSTRETH</a> = 0xb82, </div> +<div class="line"><a id="l00126" name="l00126"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a252980a4da90c1f5c1ef85d164f72f25"> 126</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a252980a4da90c1f5c1ef85d164f72f25">CSR_MHPMCOUNTER3H</a> = 0xb83, </div> +<div class="line"><a id="l00127" name="l00127"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a2e9cfbf3c2828dd4bd92d2b8a1c99f85"> 127</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a2e9cfbf3c2828dd4bd92d2b8a1c99f85">CSR_MHPMCOUNTER4H</a> = 0xb84, </div> +<div class="line"><a id="l00128" name="l00128"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a7648dd0a47007d44a14e95ba47726599"> 128</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a7648dd0a47007d44a14e95ba47726599">CSR_MHPMCOUNTER5H</a> = 0xb85, </div> +<div class="line"><a id="l00129" name="l00129"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a49b7bc2df67a6c73a68757de9b218f77"> 129</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a49b7bc2df67a6c73a68757de9b218f77">CSR_MHPMCOUNTER6H</a> = 0xb86, </div> +<div class="line"><a id="l00130" name="l00130"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ac0183bb6f357ed33136493ae7ded987a"> 130</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ac0183bb6f357ed33136493ae7ded987a">CSR_MHPMCOUNTER7H</a> = 0xb87, </div> +<div class="line"><a id="l00131" name="l00131"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a9e75518df7d14a009e3a0d5588641ddc"> 131</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a9e75518df7d14a009e3a0d5588641ddc">CSR_MHPMCOUNTER8H</a> = 0xb88, </div> +<div class="line"><a id="l00132" name="l00132"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a7341886c7a4aed6fc7d8677c016a2cb8"> 132</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a7341886c7a4aed6fc7d8677c016a2cb8">CSR_MHPMCOUNTER9H</a> = 0xb89, </div> +<div class="line"><a id="l00133" name="l00133"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a1e41d2b27d7e8da14871852d81123cfd"> 133</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a1e41d2b27d7e8da14871852d81123cfd">CSR_MHPMCOUNTER10H</a> = 0xb8a, </div> +<div class="line"><a id="l00134" name="l00134"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a7fd76fcfc0d0dd47e112786bea5e4071"> 134</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a7fd76fcfc0d0dd47e112786bea5e4071">CSR_MHPMCOUNTER11H</a> = 0xb8b, </div> +<div class="line"><a id="l00135" name="l00135"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a332ec2b0740f8e899a1b2ec86f7ee9f2"> 135</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a332ec2b0740f8e899a1b2ec86f7ee9f2">CSR_MHPMCOUNTER12H</a> = 0xb8c, </div> +<div class="line"><a id="l00136" name="l00136"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a5de5c5a036dc594a554d37df9ccf657d"> 136</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a5de5c5a036dc594a554d37df9ccf657d">CSR_MHPMCOUNTER13H</a> = 0xb8d, </div> +<div class="line"><a id="l00137" name="l00137"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ac65bab6fd71439600c8fc549171251fa"> 137</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ac65bab6fd71439600c8fc549171251fa">CSR_MHPMCOUNTER14H</a> = 0xb8e, </div> +<div class="line"><a id="l00138" name="l00138"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49af609807e2917f73e27e5f27b38a0fa46"> 138</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49af609807e2917f73e27e5f27b38a0fa46">CSR_MHPMCOUNTER15H</a> = 0xb8f, </div> +<div class="line"><a id="l00140" name="l00140"></a><span class="lineno"> 140</span> <span class="comment">/* user counters and timers */</span></div> +<div class="line"><a id="l00141" name="l00141"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aaaf0f6b17a06d5922bcfdb47b382137e"> 141</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aaaf0f6b17a06d5922bcfdb47b382137e">CSR_CYCLE</a> = 0xc00, </div> +<div class="line"><a id="l00142" name="l00142"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a8144da8cd8691ac54aa0712685865b66"> 142</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a8144da8cd8691ac54aa0712685865b66">CSR_INSTRET</a> = 0xc02, </div> +<div class="line"><a id="l00143" name="l00143"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a3ee699d5b2886c54c92992f66b109b67"> 143</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a3ee699d5b2886c54c92992f66b109b67">CSR_HPMCOUNTER3</a> = 0xc03, </div> +<div class="line"><a id="l00144" name="l00144"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a98ed49716d0d89712863e7a542d38d2a"> 144</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a98ed49716d0d89712863e7a542d38d2a">CSR_HPMCOUNTER4</a> = 0xc04, </div> +<div class="line"><a id="l00145" name="l00145"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ab2376c3b7c3ec0b44105ec1ed951bfb0"> 145</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ab2376c3b7c3ec0b44105ec1ed951bfb0">CSR_HPMCOUNTER5</a> = 0xc05, </div> +<div class="line"><a id="l00146" name="l00146"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aa2f644a4f54ba3834bafa738208c0803"> 146</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aa2f644a4f54ba3834bafa738208c0803">CSR_HPMCOUNTER6</a> = 0xc06, </div> +<div class="line"><a id="l00147" name="l00147"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a125c4d0051548dea9104808b7bee1316"> 147</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a125c4d0051548dea9104808b7bee1316">CSR_HPMCOUNTER7</a> = 0xc07, </div> +<div class="line"><a id="l00148" name="l00148"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49acac87125f8c723cc5df4d4169a82852b"> 148</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49acac87125f8c723cc5df4d4169a82852b">CSR_HPMCOUNTER8</a> = 0xc08, </div> +<div class="line"><a id="l00149" name="l00149"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ab45ebb3bd861074a15cc2ad874756e8f"> 149</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ab45ebb3bd861074a15cc2ad874756e8f">CSR_HPMCOUNTER9</a> = 0xc09, </div> +<div class="line"><a id="l00150" name="l00150"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aa407e701bdbb9d26f84684b811c008a9"> 150</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aa407e701bdbb9d26f84684b811c008a9">CSR_HPMCOUNTER10</a> = 0xc0a, </div> +<div class="line"><a id="l00151" name="l00151"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a9fd1ff4e8a42992c0a3ec02c397dd7f8"> 151</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a9fd1ff4e8a42992c0a3ec02c397dd7f8">CSR_HPMCOUNTER11</a> = 0xc0b, </div> +<div class="line"><a id="l00152" name="l00152"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ae58f15a95aa41126819effe046ced804"> 152</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ae58f15a95aa41126819effe046ced804">CSR_HPMCOUNTER12</a> = 0xc0c, </div> +<div class="line"><a id="l00153" name="l00153"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a24d8617a6ff2c1e49c9a73853ad9e450"> 153</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a24d8617a6ff2c1e49c9a73853ad9e450">CSR_HPMCOUNTER13</a> = 0xc0d, </div> +<div class="line"><a id="l00154" name="l00154"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aa47ed1a4a4f9fcabceed0d6d626d0aaf"> 154</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aa47ed1a4a4f9fcabceed0d6d626d0aaf">CSR_HPMCOUNTER14</a> = 0xc0e, </div> +<div class="line"><a id="l00155" name="l00155"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a7277a8f929a5a250f7227fbbdf545dbc"> 155</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a7277a8f929a5a250f7227fbbdf545dbc">CSR_HPMCOUNTER15</a> = 0xc0f, </div> +<div class="line"><a id="l00157" name="l00157"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aa276bedb7dab28935163397b4879f6db"> 157</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aa276bedb7dab28935163397b4879f6db">CSR_CYCLEH</a> = 0xc80, </div> +<div class="line"><a id="l00158" name="l00158"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a9b66978d76260283007d399fc735d153"> 158</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a9b66978d76260283007d399fc735d153">CSR_INSTRETH</a> = 0xc82, </div> +<div class="line"><a id="l00159" name="l00159"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aaa3e6a1ac8999be42d7c13891546bb50"> 159</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aaa3e6a1ac8999be42d7c13891546bb50">CSR_HPMCOUNTER3H</a> = 0xc83, </div> +<div class="line"><a id="l00160" name="l00160"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a8837ff8d2741639aa69da59659f9a080"> 160</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a8837ff8d2741639aa69da59659f9a080">CSR_HPMCOUNTER4H</a> = 0xc84, </div> +<div class="line"><a id="l00161" name="l00161"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ad489feaa5ad1feb00d3df71d3e5b0cac"> 161</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ad489feaa5ad1feb00d3df71d3e5b0cac">CSR_HPMCOUNTER5H</a> = 0xc85, </div> +<div class="line"><a id="l00162" name="l00162"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a438a65757b85f182dfb1f2a06c9ad520"> 162</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a438a65757b85f182dfb1f2a06c9ad520">CSR_HPMCOUNTER6H</a> = 0xc86, </div> +<div class="line"><a id="l00163" name="l00163"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a6332d4ff090aa7c302d191219e846fff"> 163</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a6332d4ff090aa7c302d191219e846fff">CSR_HPMCOUNTER7H</a> = 0xc87, </div> +<div class="line"><a id="l00164" name="l00164"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aa8ce8fc8a57dd82872d02b4113249a77"> 164</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aa8ce8fc8a57dd82872d02b4113249a77">CSR_HPMCOUNTER8H</a> = 0xc88, </div> +<div class="line"><a id="l00165" name="l00165"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49acdf793b30919e7fa1b85995abe531a20"> 165</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49acdf793b30919e7fa1b85995abe531a20">CSR_HPMCOUNTER9H</a> = 0xc89, </div> +<div class="line"><a id="l00166" name="l00166"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ae56e95d6d6dd63ff6f5b4192cf48c88b"> 166</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ae56e95d6d6dd63ff6f5b4192cf48c88b">CSR_HPMCOUNTER10H</a> = 0xc8a, </div> +<div class="line"><a id="l00167" name="l00167"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a2af8c5dcc87d92bcce392fb5b3aa065e"> 167</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a2af8c5dcc87d92bcce392fb5b3aa065e">CSR_HPMCOUNTER11H</a> = 0xc8b, </div> +<div class="line"><a id="l00168" name="l00168"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a74359db2583feb7119d4bcaa926242a0"> 168</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a74359db2583feb7119d4bcaa926242a0">CSR_HPMCOUNTER12H</a> = 0xc8c, </div> +<div class="line"><a id="l00169" name="l00169"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a4fa22699e96d6da8665077e3c95891ef"> 169</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a4fa22699e96d6da8665077e3c95891ef">CSR_HPMCOUNTER13H</a> = 0xc8d, </div> +<div class="line"><a id="l00170" name="l00170"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a03f29e792be2854efc9e66d710b78a1d"> 170</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a03f29e792be2854efc9e66d710b78a1d">CSR_HPMCOUNTER14H</a> = 0xc8e, </div> +<div class="line"><a id="l00171" name="l00171"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a11169bd08920d40c8f94fd29e1d33eff"> 171</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a11169bd08920d40c8f94fd29e1d33eff">CSR_HPMCOUNTER15H</a> = 0xc8f, </div> +<div class="line"><a id="l00173" name="l00173"></a><span class="lineno"> 173</span> <span class="comment">/* machine information registers */</span></div> +<div class="line"><a id="l00174" name="l00174"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49af5c5a21909aaca2b57f9a15f4bac246b"> 174</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49af5c5a21909aaca2b57f9a15f4bac246b">CSR_MVENDORID</a> = 0xf11, </div> +<div class="line"><a id="l00175" name="l00175"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ad95cb95266533123447ff0e917f890e4"> 175</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ad95cb95266533123447ff0e917f890e4">CSR_MARCHID</a> = 0xf12, </div> +<div class="line"><a id="l00176" name="l00176"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a06d39cf0f13d6401dcf426d56149c8cd"> 176</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a06d39cf0f13d6401dcf426d56149c8cd">CSR_MIMPID</a> = 0xf13, </div> +<div class="line"><a id="l00177" name="l00177"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a6ba48e2306ae92f498552e1ea04d6790"> 177</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a6ba48e2306ae92f498552e1ea04d6790">CSR_MHARTID</a> = 0xf14, </div> +<div class="line"><a id="l00178" name="l00178"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a0545d0921b3f90d037dbb25bc5fcc2f9"> 178</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a0545d0921b3f90d037dbb25bc5fcc2f9">CSR_MCONFIGPTR</a> = 0xf15, </div> +<div class="line"><a id="l00179" name="l00179"></a><span class="lineno"> 179</span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a396847bcf1634a1602ab117bfb57bdd2">CSR_MXISA</a> = 0xfc0 </div> +<div class="line"><a id="l00180" name="l00180"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a396847bcf1634a1602ab117bfb57bdd2"> 180</a></span>};</div> +</div> +<div class="line"><a id="l00181" name="l00181"></a><span class="lineno"> 181</span> </div> +<div class="line"><a id="l00182" name="l00182"></a><span class="lineno"> 182</span> </div> +<div class="line"><a id="l00183" name="l00183"></a><span class="lineno"> 183</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen00186" data-start="{" data-end="};"> +<div class="line"><a id="l00186" name="l00186"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#afde0761e3150d82511136f56179c204b"> 186</a></span><span class="keyword">enum</span> <a class="code hl_enumeration" href="neorv32__cpu__csr_8h.html#afde0761e3150d82511136f56179c204b">NEORV32_CSR_FFLAGS_enum</a> {</div> +<div class="line"><a id="l00187" name="l00187"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#afde0761e3150d82511136f56179c204ba91a314defd310786a9ed67f7ef2ef5a6"> 187</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#afde0761e3150d82511136f56179c204ba91a314defd310786a9ed67f7ef2ef5a6">CSR_FFLAGS_NX</a> = 0, </div> +<div class="line"><a id="l00188" name="l00188"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#afde0761e3150d82511136f56179c204babc6d405724563844569028f463885819"> 188</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#afde0761e3150d82511136f56179c204babc6d405724563844569028f463885819">CSR_FFLAGS_UF</a> = 1, </div> +<div class="line"><a id="l00189" name="l00189"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#afde0761e3150d82511136f56179c204ba612390e07a065fa13eeaeac84af48c6e"> 189</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#afde0761e3150d82511136f56179c204ba612390e07a065fa13eeaeac84af48c6e">CSR_FFLAGS_OF</a> = 2, </div> +<div class="line"><a id="l00190" name="l00190"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#afde0761e3150d82511136f56179c204ba365f3f519bca34a349907c82c873d52b"> 190</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#afde0761e3150d82511136f56179c204ba365f3f519bca34a349907c82c873d52b">CSR_FFLAGS_DZ</a> = 3, </div> +<div class="line"><a id="l00191" name="l00191"></a><span class="lineno"> 191</span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#afde0761e3150d82511136f56179c204ba3ac330a4b03178e756c980eaa48ad165">CSR_FFLAGS_NV</a> = 4 </div> +<div class="line"><a id="l00192" name="l00192"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#afde0761e3150d82511136f56179c204ba3ac330a4b03178e756c980eaa48ad165"> 192</a></span>};</div> +</div> +<div class="line"><a id="l00193" name="l00193"></a><span class="lineno"> 193</span> </div> +<div class="line"><a id="l00194" name="l00194"></a><span class="lineno"> 194</span> </div> +<div class="line"><a id="l00195" name="l00195"></a><span class="lineno"> 195</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen00198" data-start="{" data-end="};"> +<div class="line"><a id="l00198" name="l00198"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#a76b70a2334131e7589d84c1ee96de485"> 198</a></span><span class="keyword">enum</span> <a class="code hl_enumeration" href="neorv32__cpu__csr_8h.html#a76b70a2334131e7589d84c1ee96de485">NEORV32_CSR_MSTATUS_enum</a> {</div> +<div class="line"><a id="l00199" name="l00199"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#a76b70a2334131e7589d84c1ee96de485ae2603e365b3f1abfb46d53ed6b13dc56"> 199</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#a76b70a2334131e7589d84c1ee96de485ae2603e365b3f1abfb46d53ed6b13dc56">CSR_MSTATUS_MIE</a> = 3, </div> +<div class="line"><a id="l00200" name="l00200"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#a76b70a2334131e7589d84c1ee96de485aaa1d482f828ac9cafc40fcfc298bec34"> 200</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#a76b70a2334131e7589d84c1ee96de485aaa1d482f828ac9cafc40fcfc298bec34">CSR_MSTATUS_MPIE</a> = 7, </div> +<div class="line"><a id="l00201" name="l00201"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#a76b70a2334131e7589d84c1ee96de485af0ae9aca74144aa7dbdf656f71cc5c97"> 201</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#a76b70a2334131e7589d84c1ee96de485af0ae9aca74144aa7dbdf656f71cc5c97">CSR_MSTATUS_MPP_L</a> = 11, </div> +<div class="line"><a id="l00202" name="l00202"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#a76b70a2334131e7589d84c1ee96de485a8067c609c2360cab3bafa3c43e03dbf0"> 202</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#a76b70a2334131e7589d84c1ee96de485a8067c609c2360cab3bafa3c43e03dbf0">CSR_MSTATUS_MPP_H</a> = 12, </div> +<div class="line"><a id="l00203" name="l00203"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#a76b70a2334131e7589d84c1ee96de485a75cefdbdef36b7fc248765b27c606a44"> 203</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#a76b70a2334131e7589d84c1ee96de485a75cefdbdef36b7fc248765b27c606a44">CSR_MSTATUS_MPRV</a> = 17, </div> +<div class="line"><a id="l00204" name="l00204"></a><span class="lineno"> 204</span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#a76b70a2334131e7589d84c1ee96de485ac94a070f3fe7962e8c49a81545cacf2d">CSR_MSTATUS_TW</a> = 21 </div> +<div class="line"><a id="l00205" name="l00205"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#a76b70a2334131e7589d84c1ee96de485ac94a070f3fe7962e8c49a81545cacf2d"> 205</a></span>};</div> +</div> +<div class="line"><a id="l00206" name="l00206"></a><span class="lineno"> 206</span> </div> +<div class="line"><a id="l00207" name="l00207"></a><span class="lineno"> 207</span> </div> +<div class="line"><a id="l00208" name="l00208"></a><span class="lineno"> 208</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen00211" data-start="{" data-end="};"> +<div class="line"><a id="l00211" name="l00211"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfe"> 211</a></span><span class="keyword">enum</span> <a class="code hl_enumeration" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfe">NEORV32_CSR_MCOUNTINHIBIT_enum</a> {</div> +<div class="line"><a id="l00212" name="l00212"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea201ac39b0eba389b0d02c3951a3311a3"> 212</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea201ac39b0eba389b0d02c3951a3311a3">CSR_MCOUNTINHIBIT_CY</a> = 0, </div> +<div class="line"><a id="l00213" name="l00213"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea5f182f39f9a4b871a097a51e57865bfa"> 213</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea5f182f39f9a4b871a097a51e57865bfa">CSR_MCOUNTINHIBIT_IR</a> = 2, </div> +<div class="line"><a id="l00215" name="l00215"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfeaf7020159e0ba346561bfba101d22c752"> 215</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfeaf7020159e0ba346561bfba101d22c752">CSR_MCOUNTINHIBIT_HPM3</a> = 3, </div> +<div class="line"><a id="l00216" name="l00216"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea40427b799da049413c5536afa623c61d"> 216</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea40427b799da049413c5536afa623c61d">CSR_MCOUNTINHIBIT_HPM4</a> = 4, </div> +<div class="line"><a id="l00217" name="l00217"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea2769a6e6a75f2f903523e4e95a899bb6"> 217</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea2769a6e6a75f2f903523e4e95a899bb6">CSR_MCOUNTINHIBIT_HPM5</a> = 5, </div> +<div class="line"><a id="l00218" name="l00218"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfead55b6af15841617d7dca3ab4fab893db"> 218</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfead55b6af15841617d7dca3ab4fab893db">CSR_MCOUNTINHIBIT_HPM6</a> = 6, </div> +<div class="line"><a id="l00219" name="l00219"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea3b3571fceb687da2d3807b0e59bdf7ab"> 219</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea3b3571fceb687da2d3807b0e59bdf7ab">CSR_MCOUNTINHIBIT_HPM7</a> = 7, </div> +<div class="line"><a id="l00220" name="l00220"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfeabd21344124eda4402523203185a58b8a"> 220</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfeabd21344124eda4402523203185a58b8a">CSR_MCOUNTINHIBIT_HPM8</a> = 8, </div> +<div class="line"><a id="l00221" name="l00221"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea0f207455df0fed75fa68ba49c435889a"> 221</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea0f207455df0fed75fa68ba49c435889a">CSR_MCOUNTINHIBIT_HPM9</a> = 9, </div> +<div class="line"><a id="l00222" name="l00222"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea9517cd32744c5064fa30780f911cd22e"> 222</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea9517cd32744c5064fa30780f911cd22e">CSR_MCOUNTINHIBIT_HPM10</a> = 10, </div> +<div class="line"><a id="l00223" name="l00223"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfeacaf997fe8b912596224e2bb632e6a806"> 223</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfeacaf997fe8b912596224e2bb632e6a806">CSR_MCOUNTINHIBIT_HPM11</a> = 11, </div> +<div class="line"><a id="l00224" name="l00224"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea8d866a4c815d8ba890a1e00ce9600486"> 224</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea8d866a4c815d8ba890a1e00ce9600486">CSR_MCOUNTINHIBIT_HPM12</a> = 12, </div> +<div class="line"><a id="l00225" name="l00225"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfead9f6c4eb4284ee82b9e8d0c79f62b3ed"> 225</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfead9f6c4eb4284ee82b9e8d0c79f62b3ed">CSR_MCOUNTINHIBIT_HPM13</a> = 13, </div> +<div class="line"><a id="l00226" name="l00226"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfeaa83c0688869b1c43de0c4474e940f987"> 226</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfeaa83c0688869b1c43de0c4474e940f987">CSR_MCOUNTINHIBIT_HPM14</a> = 14, </div> +<div class="line"><a id="l00227" name="l00227"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea0b547cb5876c0e7956e3d062e0784085"> 227</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea0b547cb5876c0e7956e3d062e0784085">CSR_MCOUNTINHIBIT_HPM15</a> = 15, </div> +<div class="line"><a id="l00228" name="l00228"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea68aba71ea77aba4005fb24a945ef38e4"> 228</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea68aba71ea77aba4005fb24a945ef38e4">CSR_MCOUNTINHIBIT_HPM16</a> = 16, </div> +<div class="line"><a id="l00229" name="l00229"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea8d57acf13a086635a63bc13ccdf479b3"> 229</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea8d57acf13a086635a63bc13ccdf479b3">CSR_MCOUNTINHIBIT_HPM17</a> = 17, </div> +<div class="line"><a id="l00230" name="l00230"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfeaa680d196d2ba0e403801a860bb9d8ce0"> 230</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfeaa680d196d2ba0e403801a860bb9d8ce0">CSR_MCOUNTINHIBIT_HPM18</a> = 18, </div> +<div class="line"><a id="l00231" name="l00231"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea3683e296caafe771b6dd57f4cf86f3dc"> 231</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea3683e296caafe771b6dd57f4cf86f3dc">CSR_MCOUNTINHIBIT_HPM19</a> = 19, </div> +<div class="line"><a id="l00232" name="l00232"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfeaeb4b1b6abafd22eec0764d5503878cca"> 232</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfeaeb4b1b6abafd22eec0764d5503878cca">CSR_MCOUNTINHIBIT_HPM20</a> = 20, </div> +<div class="line"><a id="l00233" name="l00233"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea1dc0276a5354c805ac56fd46c5037d38"> 233</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea1dc0276a5354c805ac56fd46c5037d38">CSR_MCOUNTINHIBIT_HPM21</a> = 21, </div> +<div class="line"><a id="l00234" name="l00234"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfeaf1b6153a0c664367bfefb78b2ca8b34e"> 234</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfeaf1b6153a0c664367bfefb78b2ca8b34e">CSR_MCOUNTINHIBIT_HPM22</a> = 22, </div> +<div class="line"><a id="l00235" name="l00235"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea85c0c2b2a5101380dec72516dda1a904"> 235</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea85c0c2b2a5101380dec72516dda1a904">CSR_MCOUNTINHIBIT_HPM23</a> = 23, </div> +<div class="line"><a id="l00236" name="l00236"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea74ec85a2e94aa0b9e8af29401ef7ecb1"> 236</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea74ec85a2e94aa0b9e8af29401ef7ecb1">CSR_MCOUNTINHIBIT_HPM24</a> = 24, </div> +<div class="line"><a id="l00237" name="l00237"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfeaee2b5a2b7bd7ac07dae45900bc2faf46"> 237</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfeaee2b5a2b7bd7ac07dae45900bc2faf46">CSR_MCOUNTINHIBIT_HPM25</a> = 25, </div> +<div class="line"><a id="l00238" name="l00238"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea141a4a211c496d2af1c79d8e8e0c2a74"> 238</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea141a4a211c496d2af1c79d8e8e0c2a74">CSR_MCOUNTINHIBIT_HPM26</a> = 26, </div> +<div class="line"><a id="l00239" name="l00239"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea46def851d4582b4bcec1f9d8bafd58db"> 239</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea46def851d4582b4bcec1f9d8bafd58db">CSR_MCOUNTINHIBIT_HPM27</a> = 27, </div> +<div class="line"><a id="l00240" name="l00240"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea33d0fd3378ec3a2fcc3c8738c6cd2f32"> 240</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea33d0fd3378ec3a2fcc3c8738c6cd2f32">CSR_MCOUNTINHIBIT_HPM28</a> = 28, </div> +<div class="line"><a id="l00241" name="l00241"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfeaa39882f7dad9b7e16b317c75bad31382"> 241</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfeaa39882f7dad9b7e16b317c75bad31382">CSR_MCOUNTINHIBIT_HPM29</a> = 29, </div> +<div class="line"><a id="l00242" name="l00242"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea0f45818fa4cb9033a3093987fa8515c7"> 242</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea0f45818fa4cb9033a3093987fa8515c7">CSR_MCOUNTINHIBIT_HPM30</a> = 30, </div> +<div class="line"><a id="l00243" name="l00243"></a><span class="lineno"> 243</span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea1da1186ef2f4e7297a4fecaaccdc1d05">CSR_MCOUNTINHIBIT_HPM31</a> = 31 </div> +<div class="line"><a id="l00244" name="l00244"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea1da1186ef2f4e7297a4fecaaccdc1d05"> 244</a></span>};</div> +</div> +<div class="line"><a id="l00245" name="l00245"></a><span class="lineno"> 245</span> </div> +<div class="line"><a id="l00246" name="l00246"></a><span class="lineno"> 246</span> </div> +<div class="line"><a id="l00247" name="l00247"></a><span class="lineno"> 247</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen00250" data-start="{" data-end="};"> +<div class="line"><a id="l00250" name="l00250"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33"> 250</a></span><span class="keyword">enum</span> <a class="code hl_enumeration" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33">NEORV32_CSR_MIE_enum</a> {</div> +<div class="line"><a id="l00251" name="l00251"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33afd2f1c78c442c8c29ab075cacee0a27a"> 251</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33afd2f1c78c442c8c29ab075cacee0a27a">CSR_MIE_MSIE</a> = 3, </div> +<div class="line"><a id="l00252" name="l00252"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a3658e8663e94cd8eaa7201b7a850d083"> 252</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a3658e8663e94cd8eaa7201b7a850d083">CSR_MIE_MTIE</a> = 7, </div> +<div class="line"><a id="l00253" name="l00253"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33ae8e4f0ee46abbbb3361de035a57b8324"> 253</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33ae8e4f0ee46abbbb3361de035a57b8324">CSR_MIE_MEIE</a> = 11, </div> +<div class="line"><a id="l00255" name="l00255"></a><span class="lineno"> 255</span> <span class="comment">/* NEORV32-specific extension: Fast Interrupt Requests (FIRQ) */</span></div> +<div class="line"><a id="l00256" name="l00256"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a99f43f8bbfb29fba6224f081c363ac7d"> 256</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a99f43f8bbfb29fba6224f081c363ac7d">CSR_MIE_FIRQ0E</a> = 16, </div> +<div class="line"><a id="l00257" name="l00257"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33ac1e1d44becec1b393f79a118ed3d8beb"> 257</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33ac1e1d44becec1b393f79a118ed3d8beb">CSR_MIE_FIRQ1E</a> = 17, </div> +<div class="line"><a id="l00258" name="l00258"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33afc805280e20ffface116ca61e11645f7"> 258</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33afc805280e20ffface116ca61e11645f7">CSR_MIE_FIRQ2E</a> = 18, </div> +<div class="line"><a id="l00259" name="l00259"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a666066099d6cebadbef21d81c179e8db"> 259</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a666066099d6cebadbef21d81c179e8db">CSR_MIE_FIRQ3E</a> = 19, </div> +<div class="line"><a id="l00260" name="l00260"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a592939f1b7d79097f7f13d6ab0c268dc"> 260</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a592939f1b7d79097f7f13d6ab0c268dc">CSR_MIE_FIRQ4E</a> = 20, </div> +<div class="line"><a id="l00261" name="l00261"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a3079a8fbf3b8e376865bff76f2173698"> 261</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a3079a8fbf3b8e376865bff76f2173698">CSR_MIE_FIRQ5E</a> = 21, </div> +<div class="line"><a id="l00262" name="l00262"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a96315d6b5b9531bcbc1e78a3c9ab166a"> 262</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a96315d6b5b9531bcbc1e78a3c9ab166a">CSR_MIE_FIRQ6E</a> = 22, </div> +<div class="line"><a id="l00263" name="l00263"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a3d9d729940170609affbc6813054ebe8"> 263</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a3d9d729940170609affbc6813054ebe8">CSR_MIE_FIRQ7E</a> = 23, </div> +<div class="line"><a id="l00264" name="l00264"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a396c6c4b425b3fff598e2f846052f98e"> 264</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a396c6c4b425b3fff598e2f846052f98e">CSR_MIE_FIRQ8E</a> = 24, </div> +<div class="line"><a id="l00265" name="l00265"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a06fdb61dab31c3490da6c37d47914f19"> 265</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a06fdb61dab31c3490da6c37d47914f19">CSR_MIE_FIRQ9E</a> = 25, </div> +<div class="line"><a id="l00266" name="l00266"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33affcb52dc57bb8c0cb1e7d3c1392d544a"> 266</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33affcb52dc57bb8c0cb1e7d3c1392d544a">CSR_MIE_FIRQ10E</a> = 26, </div> +<div class="line"><a id="l00267" name="l00267"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33af058342854a0becd3bcc33877d9244cd"> 267</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33af058342854a0becd3bcc33877d9244cd">CSR_MIE_FIRQ11E</a> = 27, </div> +<div class="line"><a id="l00268" name="l00268"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a41f91a37f7e0c75c783312af6a72e943"> 268</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a41f91a37f7e0c75c783312af6a72e943">CSR_MIE_FIRQ12E</a> = 28, </div> +<div class="line"><a id="l00269" name="l00269"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a134ed02c7293008b21b1df472be8f11f"> 269</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a134ed02c7293008b21b1df472be8f11f">CSR_MIE_FIRQ13E</a> = 29, </div> +<div class="line"><a id="l00270" name="l00270"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a864d135708530016cfc52a65a1e4d79b"> 270</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a864d135708530016cfc52a65a1e4d79b">CSR_MIE_FIRQ14E</a> = 30, </div> +<div class="line"><a id="l00271" name="l00271"></a><span class="lineno"> 271</span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33aa2dfa1183af312de2959dadd217fddc1">CSR_MIE_FIRQ15E</a> = 31 </div> +<div class="line"><a id="l00272" name="l00272"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33aa2dfa1183af312de2959dadd217fddc1"> 272</a></span>};</div> +</div> +<div class="line"><a id="l00273" name="l00273"></a><span class="lineno"> 273</span> </div> +<div class="line"><a id="l00274" name="l00274"></a><span class="lineno"> 274</span> </div> +<div class="line"><a id="l00275" name="l00275"></a><span class="lineno"> 275</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen00278" data-start="{" data-end="};"> +<div class="line"><a id="l00278" name="l00278"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21b"> 278</a></span><span class="keyword">enum</span> <a class="code hl_enumeration" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21b">NEORV32_CSR_MIP_enum</a> {</div> +<div class="line"><a id="l00279" name="l00279"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba1470cfe04f9d3ce45b7156b2a7fae159"> 279</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba1470cfe04f9d3ce45b7156b2a7fae159">CSR_MIP_MSIP</a> = 3, </div> +<div class="line"><a id="l00280" name="l00280"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba344943c62922561378d33ec51ac236e4"> 280</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba344943c62922561378d33ec51ac236e4">CSR_MIP_MTIP</a> = 7, </div> +<div class="line"><a id="l00281" name="l00281"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba1d761ef98f88c40509168ac66b7a4872"> 281</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba1d761ef98f88c40509168ac66b7a4872">CSR_MIP_MEIP</a> = 11, </div> +<div class="line"><a id="l00283" name="l00283"></a><span class="lineno"> 283</span> <span class="comment">/* NEORV32-specific extension: Fast Interrupt Requests (FIRQ) */</span></div> +<div class="line"><a id="l00284" name="l00284"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba28a85ad8bd4c30fd3a91298dfa4fdb00"> 284</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba28a85ad8bd4c30fd3a91298dfa4fdb00">CSR_MIP_FIRQ0P</a> = 16, </div> +<div class="line"><a id="l00285" name="l00285"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba2b577b1da1074c29ad58005af1f91d52"> 285</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba2b577b1da1074c29ad58005af1f91d52">CSR_MIP_FIRQ1P</a> = 17, </div> +<div class="line"><a id="l00286" name="l00286"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21badf45c5a135431f958fa63574c1dfac6e"> 286</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21badf45c5a135431f958fa63574c1dfac6e">CSR_MIP_FIRQ2P</a> = 18, </div> +<div class="line"><a id="l00287" name="l00287"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba7512bb6c4841ddd477422b49ebb2a155"> 287</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba7512bb6c4841ddd477422b49ebb2a155">CSR_MIP_FIRQ3P</a> = 19, </div> +<div class="line"><a id="l00288" name="l00288"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21bab6421f242bb8a487a986346e11196eb8"> 288</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21bab6421f242bb8a487a986346e11196eb8">CSR_MIP_FIRQ4P</a> = 20, </div> +<div class="line"><a id="l00289" name="l00289"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21baaa55d19f9a47889bc364c94bda04b677"> 289</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21baaa55d19f9a47889bc364c94bda04b677">CSR_MIP_FIRQ5P</a> = 21, </div> +<div class="line"><a id="l00290" name="l00290"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21baffa7342631aa0526aaa44c0c549b1f3e"> 290</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21baffa7342631aa0526aaa44c0c549b1f3e">CSR_MIP_FIRQ6P</a> = 22, </div> +<div class="line"><a id="l00291" name="l00291"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21baad691486001a68f2375dcf5793ee795a"> 291</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21baad691486001a68f2375dcf5793ee795a">CSR_MIP_FIRQ7P</a> = 23, </div> +<div class="line"><a id="l00292" name="l00292"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21baf5bbd23d4f311f640db42e9015f87580"> 292</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21baf5bbd23d4f311f640db42e9015f87580">CSR_MIP_FIRQ8P</a> = 24, </div> +<div class="line"><a id="l00293" name="l00293"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21bad94c9691ce59b97fcfec14d345046c3e"> 293</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21bad94c9691ce59b97fcfec14d345046c3e">CSR_MIP_FIRQ9P</a> = 25, </div> +<div class="line"><a id="l00294" name="l00294"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba2b50cfa8be461b088ea8506ce4c741ba"> 294</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba2b50cfa8be461b088ea8506ce4c741ba">CSR_MIP_FIRQ10P</a> = 26, </div> +<div class="line"><a id="l00295" name="l00295"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba69ea0d3d76d4cec398f3b96959cc3544"> 295</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba69ea0d3d76d4cec398f3b96959cc3544">CSR_MIP_FIRQ11P</a> = 27, </div> +<div class="line"><a id="l00296" name="l00296"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba03edd398920b817150d29107c0b40792"> 296</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba03edd398920b817150d29107c0b40792">CSR_MIP_FIRQ12P</a> = 28, </div> +<div class="line"><a id="l00297" name="l00297"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba14da6a2a962bf82970638a948ffbc570"> 297</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba14da6a2a962bf82970638a948ffbc570">CSR_MIP_FIRQ13P</a> = 29, </div> +<div class="line"><a id="l00298" name="l00298"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21baad1e5e452a9c37561308765431f0260d"> 298</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21baad1e5e452a9c37561308765431f0260d">CSR_MIP_FIRQ14P</a> = 30, </div> +<div class="line"><a id="l00299" name="l00299"></a><span class="lineno"> 299</span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba12da8c32d38d5a3539a0b766718bfd2d">CSR_MIP_FIRQ15P</a> = 31 </div> +<div class="line"><a id="l00300" name="l00300"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba12da8c32d38d5a3539a0b766718bfd2d"> 300</a></span>};</div> +</div> +<div class="line"><a id="l00301" name="l00301"></a><span class="lineno"> 301</span> </div> +<div class="line"><a id="l00302" name="l00302"></a><span class="lineno"> 302</span> </div> +<div class="line"><a id="l00303" name="l00303"></a><span class="lineno"> 303</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen00306" data-start="{" data-end="};"> +<div class="line"><a id="l00306" name="l00306"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830c"> 306</a></span><span class="keyword">enum</span> <a class="code hl_enumeration" href="neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830c">NEORV32_CSR_MISA_enum</a> {</div> +<div class="line"><a id="l00307" name="l00307"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830ca89412df9f99d2a0ddc4665446397f1a2"> 307</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830ca89412df9f99d2a0ddc4665446397f1a2">CSR_MISA_A</a> = 0, </div> +<div class="line"><a id="l00308" name="l00308"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830cadd469404a928e012a298773ec46926ad"> 308</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830cadd469404a928e012a298773ec46926ad">CSR_MISA_B</a> = 1, </div> +<div class="line"><a id="l00309" name="l00309"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830ca886699013158c74810598fa2fd6b07fa"> 309</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830ca886699013158c74810598fa2fd6b07fa">CSR_MISA_C</a> = 2, </div> +<div class="line"><a id="l00310" name="l00310"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830ca1dd1be1071450f9b00a817bce19fa665"> 310</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830ca1dd1be1071450f9b00a817bce19fa665">CSR_MISA_D</a> = 3, </div> +<div class="line"><a id="l00311" name="l00311"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830ca0ac798fd19cb7dbe1146afecda448fec"> 311</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830ca0ac798fd19cb7dbe1146afecda448fec">CSR_MISA_E</a> = 4, </div> +<div class="line"><a id="l00312" name="l00312"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830ca9ec2cae2b948de1043540a4ca1665c40"> 312</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830ca9ec2cae2b948de1043540a4ca1665c40">CSR_MISA_F</a> = 5, </div> +<div class="line"><a id="l00313" name="l00313"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830ca6091fd2c7ae38ad33be68a0fdfa50cca"> 313</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830ca6091fd2c7ae38ad33be68a0fdfa50cca">CSR_MISA_I</a> = 8, </div> +<div class="line"><a id="l00314" name="l00314"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830ca317a631e4598532f5bffe8fb93aff94b"> 314</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830ca317a631e4598532f5bffe8fb93aff94b">CSR_MISA_M</a> = 12, </div> +<div class="line"><a id="l00315" name="l00315"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830cacd9d71e674d3a6d04984b6df706d9deb"> 315</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830cacd9d71e674d3a6d04984b6df706d9deb">CSR_MISA_U</a> = 20, </div> +<div class="line"><a id="l00316" name="l00316"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830ca0b119a20be29fcae8fecf2a81c60d193"> 316</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830ca0b119a20be29fcae8fecf2a81c60d193">CSR_MISA_X</a> = 23, </div> +<div class="line"><a id="l00317" name="l00317"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830cab5a55e97b8511f42fe68559a38f7f138"> 317</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830cab5a55e97b8511f42fe68559a38f7f138">CSR_MISA_MXL_LO</a> = 30, </div> +<div class="line"><a id="l00318" name="l00318"></a><span class="lineno"> 318</span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830cafb3e4b08b87f5c161468a9e58ade12cc">CSR_MISA_MXL_HI</a> = 31 </div> +<div class="line"><a id="l00319" name="l00319"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830cafb3e4b08b87f5c161468a9e58ade12cc"> 319</a></span>};</div> +</div> +<div class="line"><a id="l00320" name="l00320"></a><span class="lineno"> 320</span> </div> +<div class="line"><a id="l00321" name="l00321"></a><span class="lineno"> 321</span> </div> +<div class="line"><a id="l00322" name="l00322"></a><span class="lineno"> 322</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen00325" data-start="{" data-end="};"> +<div class="line"><a id="l00325" name="l00325"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387"> 325</a></span><span class="keyword">enum</span> <a class="code hl_enumeration" href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387">NEORV32_CSR_XISA_enum</a> {</div> +<div class="line"><a id="l00326" name="l00326"></a><span class="lineno"> 326</span> <span class="comment">// ISA (sub-)extensions</span></div> +<div class="line"><a id="l00327" name="l00327"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387accf1dd12be89e45df1423a5600789f2c"> 327</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387accf1dd12be89e45df1423a5600789f2c">CSR_MXISA_ZICSR</a> = 0, </div> +<div class="line"><a id="l00328" name="l00328"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387a6979d4389ed9f8605d338fc616d29f0e"> 328</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387a6979d4389ed9f8605d338fc616d29f0e">CSR_MXISA_ZIFENCEI</a> = 1, </div> +<div class="line"><a id="l00329" name="l00329"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387a79b2b4b20e08ad31b50724a7a27fb20f"> 329</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387a79b2b4b20e08ad31b50724a7a27fb20f">CSR_MXISA_ZMMUL</a> = 2, </div> +<div class="line"><a id="l00330" name="l00330"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387af422ae3b5caba59e33a29b5d069597e0"> 330</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387af422ae3b5caba59e33a29b5d069597e0">CSR_MXISA_ZXCFU</a> = 3, </div> +<div class="line"><a id="l00332" name="l00332"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387a56ec3195d0d27f362f58fadb2e037ed1"> 332</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387a56ec3195d0d27f362f58fadb2e037ed1">CSR_MXISA_ZFINX</a> = 5, </div> +<div class="line"><a id="l00333" name="l00333"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387ab1f289cfaa9f54f7831a2abcdf9fca2e"> 333</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387ab1f289cfaa9f54f7831a2abcdf9fca2e">CSR_MXISA_ZICOND</a> = 6, </div> +<div class="line"><a id="l00334" name="l00334"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387a42a3b78195741af4b6aeeb98cbea46fe"> 334</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387a42a3b78195741af4b6aeeb98cbea46fe">CSR_MXISA_ZICNTR</a> = 7, </div> +<div class="line"><a id="l00335" name="l00335"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387a6938948290d86b0ad25923f35d6c86d3"> 335</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387a6938948290d86b0ad25923f35d6c86d3">CSR_MXISA_SMPMP</a> = 8, </div> +<div class="line"><a id="l00336" name="l00336"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387ac13e6883af3a9da18057462239b9fb34"> 336</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387ac13e6883af3a9da18057462239b9fb34">CSR_MXISA_ZIHPM</a> = 9, </div> +<div class="line"><a id="l00337" name="l00337"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387ab6aec595e6aa5ce7c98c7806d23d7af5"> 337</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387ab6aec595e6aa5ce7c98c7806d23d7af5">CSR_MXISA_SDEXT</a> = 10, </div> +<div class="line"><a id="l00338" name="l00338"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387a59eae4272528f589f299ef9cce45af5b"> 338</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387a59eae4272528f589f299ef9cce45af5b">CSR_MXISA_SDTRIG</a> = 11, </div> +<div class="line"><a id="l00340" name="l00340"></a><span class="lineno"> 340</span> <span class="comment">// Misc</span></div> +<div class="line"><a id="l00341" name="l00341"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387a9b121ec0ad6271b6e07658f861015f6a"> 341</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387a9b121ec0ad6271b6e07658f861015f6a">CSR_MXISA_IS_SIM</a> = 20, </div> +<div class="line"><a id="l00343" name="l00343"></a><span class="lineno"> 343</span> <span class="comment">// Tuning options</span></div> +<div class="line"><a id="l00344" name="l00344"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387a6843c660d75f33e4252c7fccd4565a2d"> 344</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387a6843c660d75f33e4252c7fccd4565a2d">CSR_MXISA_RFHWRST</a> = 29, </div> +<div class="line"><a id="l00345" name="l00345"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387a48e57689f8a5b51d9ee9d648da7efc64"> 345</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387a48e57689f8a5b51d9ee9d648da7efc64">CSR_MXISA_FASTMUL</a> = 30, </div> +<div class="line"><a id="l00346" name="l00346"></a><span class="lineno"> 346</span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387ad5ac9e2188757e6c42c159f0c5887868">CSR_MXISA_FASTSHIFT</a> = 31 </div> +<div class="line"><a id="l00347" name="l00347"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387ad5ac9e2188757e6c42c159f0c5887868"> 347</a></span>};</div> +</div> +<div class="line"><a id="l00348" name="l00348"></a><span class="lineno"> 348</span> </div> +<div class="line"><a id="l00349" name="l00349"></a><span class="lineno"> 349</span> </div> +<div class="line"><a id="l00350" name="l00350"></a><span class="lineno"> 350</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen00353" data-start="{" data-end="};"> +<div class="line"><a id="l00353" name="l00353"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfe"> 353</a></span><span class="keyword">enum</span> <a class="code hl_enumeration" href="neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfe">NEORV32_HPMCNT_EVENT_enum</a> {</div> +<div class="line"><a id="l00354" name="l00354"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfea2b683572525adc02ce0910031cfea914"> 354</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfea2b683572525adc02ce0910031cfea914">HPMCNT_EVENT_CY</a> = 0, </div> +<div class="line"><a id="l00355" name="l00355"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfea578ef6fc107c22b5cb7be5950f695640"> 355</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfea578ef6fc107c22b5cb7be5950f695640">HPMCNT_EVENT_TM</a> = 1, </div> +<div class="line"><a id="l00356" name="l00356"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfeaab438295e5f00ffe4c2457a54ee9bfc4"> 356</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfeaab438295e5f00ffe4c2457a54ee9bfc4">HPMCNT_EVENT_IR</a> = 2, </div> +<div class="line"><a id="l00357" name="l00357"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfea685ed663611d988702ec59c254eb61dd"> 357</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfea685ed663611d988702ec59c254eb61dd">HPMCNT_EVENT_COMPR</a> = 3, </div> +<div class="line"><a id="l00358" name="l00358"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfeabcb123b5b150b4413e5fd48475faab27"> 358</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfeabcb123b5b150b4413e5fd48475faab27">HPMCNT_EVENT_WAIT_DIS</a> = 4, </div> +<div class="line"><a id="l00359" name="l00359"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfeaffbb04d0053ebd079c6cacb4e5e7ed6b"> 359</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfeaffbb04d0053ebd079c6cacb4e5e7ed6b">HPMCNT_EVENT_WAIT_ALU</a> = 5, </div> +<div class="line"><a id="l00360" name="l00360"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfea9e1e2b50352b2555e9c64e76776919a6"> 360</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfea9e1e2b50352b2555e9c64e76776919a6">HPMCNT_EVENT_BRANCH</a> = 6, </div> +<div class="line"><a id="l00361" name="l00361"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfea0f15c5a824cb1678423ac4ef72a5f4f5"> 361</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfea0f15c5a824cb1678423ac4ef72a5f4f5">HPMCNT_EVENT_BRANCHED</a> = 7, </div> +<div class="line"><a id="l00362" name="l00362"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfea1a06f216e1a12afa0b90d6e1218b3c91"> 362</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfea1a06f216e1a12afa0b90d6e1218b3c91">HPMCNT_EVENT_LOAD</a> = 8, </div> +<div class="line"><a id="l00363" name="l00363"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfea6a942852e3cd85616a63addb8e9d76f2"> 363</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfea6a942852e3cd85616a63addb8e9d76f2">HPMCNT_EVENT_STORE</a> = 9, </div> +<div class="line"><a id="l00364" name="l00364"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfea67a59934bc66bc7ccf82d24fe8a18a3b"> 364</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfea67a59934bc66bc7ccf82d24fe8a18a3b">HPMCNT_EVENT_WAIT_LSU</a> = 10, </div> +<div class="line"><a id="l00365" name="l00365"></a><span class="lineno"> 365</span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfea3a4f5bf9251def87a71162dbcf9043c5">HPMCNT_EVENT_TRAP</a> = 11 </div> +<div class="line"><a id="l00366" name="l00366"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfea3a4f5bf9251def87a71162dbcf9043c5"> 366</a></span>};</div> +</div> +<div class="line"><a id="l00367" name="l00367"></a><span class="lineno"> 367</span> </div> +<div class="line"><a id="l00368" name="l00368"></a><span class="lineno"> 368</span> </div> +<div class="line"><a id="l00369" name="l00369"></a><span class="lineno"> 369</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen00372" data-start="{" data-end="};"> +<div class="line"><a id="l00372" name="l00372"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#abc0e8daad1e9beda4d9950452cc930ea"> 372</a></span><span class="keyword">enum</span> <a class="code hl_enumeration" href="neorv32__cpu__csr_8h.html#abc0e8daad1e9beda4d9950452cc930ea">NEORV32_PMPCFG_ATTRIBUTES_enum</a> {</div> +<div class="line"><a id="l00373" name="l00373"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#abc0e8daad1e9beda4d9950452cc930eaad3aca82a2ab57364e83f677d3d4f71a6"> 373</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#abc0e8daad1e9beda4d9950452cc930eaad3aca82a2ab57364e83f677d3d4f71a6">PMPCFG_R</a> = 0, </div> +<div class="line"><a id="l00374" name="l00374"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#abc0e8daad1e9beda4d9950452cc930eaa7689905760f917499b1151cced384d2f"> 374</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#abc0e8daad1e9beda4d9950452cc930eaa7689905760f917499b1151cced384d2f">PMPCFG_W</a> = 1, </div> +<div class="line"><a id="l00375" name="l00375"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#abc0e8daad1e9beda4d9950452cc930eaaec94712deafba09c0cf956c6fd68fa8d"> 375</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#abc0e8daad1e9beda4d9950452cc930eaaec94712deafba09c0cf956c6fd68fa8d">PMPCFG_X</a> = 2, </div> +<div class="line"><a id="l00376" name="l00376"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#abc0e8daad1e9beda4d9950452cc930eaaae1e6440956ad6b7cbf6062aa50f43b1"> 376</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#abc0e8daad1e9beda4d9950452cc930eaaae1e6440956ad6b7cbf6062aa50f43b1">PMPCFG_A_LSB</a> = 3, </div> +<div class="line"><a id="l00377" name="l00377"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#abc0e8daad1e9beda4d9950452cc930eaa67ad3243eeb74f86a01efbade76f21e4"> 377</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#abc0e8daad1e9beda4d9950452cc930eaa67ad3243eeb74f86a01efbade76f21e4">PMPCFG_A_MSB</a> = 4, </div> +<div class="line"><a id="l00378" name="l00378"></a><span class="lineno"> 378</span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#abc0e8daad1e9beda4d9950452cc930eaa59c294bc43d2117bb55e301eec683f14">PMPCFG_L</a> = 7 </div> +<div class="line"><a id="l00379" name="l00379"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#abc0e8daad1e9beda4d9950452cc930eaa59c294bc43d2117bb55e301eec683f14"> 379</a></span>};</div> +</div> +<div class="line"><a id="l00380" name="l00380"></a><span class="lineno"> 380</span> </div> +<div class="line"><a id="l00381" name="l00381"></a><span class="lineno"> 381</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen00384" data-start="{" data-end="};"> +<div class="line"><a id="l00384" name="l00384"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#a8f2418fb5e2175f35ee2362469ce01f5"> 384</a></span><span class="keyword">enum</span> <a class="code hl_enumeration" href="neorv32__cpu__csr_8h.html#a8f2418fb5e2175f35ee2362469ce01f5">NEORV32_PMP_MODES_enum</a> {</div> +<div class="line"><a id="l00385" name="l00385"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#a8f2418fb5e2175f35ee2362469ce01f5a003ccfae4aae1dad4fd65d5d4c7737c4"> 385</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#a8f2418fb5e2175f35ee2362469ce01f5a003ccfae4aae1dad4fd65d5d4c7737c4">PMP_OFF</a> = 0, </div> +<div class="line"><a id="l00386" name="l00386"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#a8f2418fb5e2175f35ee2362469ce01f5a629a81a205abee94bad9d5bb5dfa26b1"> 386</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#a8f2418fb5e2175f35ee2362469ce01f5a629a81a205abee94bad9d5bb5dfa26b1">PMP_TOR</a> = 1, </div> +<div class="line"><a id="l00387" name="l00387"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#a8f2418fb5e2175f35ee2362469ce01f5aae0e0c33b0d034cb50286239f955d892"> 387</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#a8f2418fb5e2175f35ee2362469ce01f5aae0e0c33b0d034cb50286239f955d892">PMP_NA4</a> = 2, </div> +<div class="line"><a id="l00388" name="l00388"></a><span class="lineno"> 388</span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#a8f2418fb5e2175f35ee2362469ce01f5ad555e9dfc0c00612bdea623617ff2820">PMP_NAPOT</a> = 3 </div> +<div class="line"><a id="l00389" name="l00389"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#a8f2418fb5e2175f35ee2362469ce01f5ad555e9dfc0c00612bdea623617ff2820"> 389</a></span>};</div> +</div> +<div class="line"><a id="l00390" name="l00390"></a><span class="lineno"> 390</span> </div> +<div class="line"><a id="l00391" name="l00391"></a><span class="lineno"> 391</span> </div> +<div class="line"><a id="l00392" name="l00392"></a><span class="lineno"> 392</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen00395" data-start="{" data-end="};"> +<div class="line"><a id="l00395" name="l00395"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1"> 395</a></span><span class="keyword">enum</span> <a class="code hl_enumeration" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1">NEORV32_EXCEPTION_CODES_enum</a> {</div> +<div class="line"><a id="l00396" name="l00396"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a0a8010d7cc91b9557973a7a118828bee"> 396</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a0a8010d7cc91b9557973a7a118828bee">TRAP_CODE_I_MISALIGNED</a> = 0x00000000U, </div> +<div class="line"><a id="l00397" name="l00397"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a6a0ebfce4e18f36aeb43d5a65445cfe1"> 397</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a6a0ebfce4e18f36aeb43d5a65445cfe1">TRAP_CODE_I_ACCESS</a> = 0x00000001U, </div> +<div class="line"><a id="l00398" name="l00398"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1af1ad8f557f3b685b59a913611e1da173"> 398</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1af1ad8f557f3b685b59a913611e1da173">TRAP_CODE_I_ILLEGAL</a> = 0x00000002U, </div> +<div class="line"><a id="l00399" name="l00399"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a2c9510cb7583a0144f96678fc217335e"> 399</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a2c9510cb7583a0144f96678fc217335e">TRAP_CODE_BREAKPOINT</a> = 0x00000003U, </div> +<div class="line"><a id="l00400" name="l00400"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a69e68a954da0bb33d1624484a6777ff9"> 400</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a69e68a954da0bb33d1624484a6777ff9">TRAP_CODE_L_MISALIGNED</a> = 0x00000004U, </div> +<div class="line"><a id="l00401" name="l00401"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a28448f0c670169140dc28b6794310cea"> 401</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a28448f0c670169140dc28b6794310cea">TRAP_CODE_L_ACCESS</a> = 0x00000005U, </div> +<div class="line"><a id="l00402" name="l00402"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a19708405f9f6300edf6b992c6d408a2d"> 402</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a19708405f9f6300edf6b992c6d408a2d">TRAP_CODE_S_MISALIGNED</a> = 0x00000006U, </div> +<div class="line"><a id="l00403" name="l00403"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a70bcfc75fe1056d93a3606f78c0cb887"> 403</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a70bcfc75fe1056d93a3606f78c0cb887">TRAP_CODE_S_ACCESS</a> = 0x00000007U, </div> +<div class="line"><a id="l00404" name="l00404"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1aa102472d6a264bb92e0581ccaa413e02"> 404</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1aa102472d6a264bb92e0581ccaa413e02">TRAP_CODE_UENV_CALL</a> = 0x00000008U, </div> +<div class="line"><a id="l00405" name="l00405"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a20e5a2680f2f5956bfa92852d5544eac"> 405</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a20e5a2680f2f5956bfa92852d5544eac">TRAP_CODE_MENV_CALL</a> = 0x0000000bU, </div> +<div class="line"><a id="l00406" name="l00406"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1ae0cebf99f36ef6be60e4a9d2c9f894b0"> 406</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1ae0cebf99f36ef6be60e4a9d2c9f894b0">TRAP_CODE_MSI</a> = 0x80000003U, </div> +<div class="line"><a id="l00407" name="l00407"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a187ae38819b81672c15808e63c3b46b7"> 407</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a187ae38819b81672c15808e63c3b46b7">TRAP_CODE_MTI</a> = 0x80000007U, </div> +<div class="line"><a id="l00408" name="l00408"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a1a412b9d8eefba7880555d34625d2cc0"> 408</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a1a412b9d8eefba7880555d34625d2cc0">TRAP_CODE_MEI</a> = 0x8000000bU, </div> +<div class="line"><a id="l00409" name="l00409"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a0cef77904935798d247d8396838297c1"> 409</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a0cef77904935798d247d8396838297c1">TRAP_CODE_FIRQ_0</a> = 0x80000010U, </div> +<div class="line"><a id="l00410" name="l00410"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1ae0b1049ae7f8cbfb6ff216e69ed5dae7"> 410</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1ae0b1049ae7f8cbfb6ff216e69ed5dae7">TRAP_CODE_FIRQ_1</a> = 0x80000011U, </div> +<div class="line"><a id="l00411" name="l00411"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1ad753d3e2563b4fd663430af9f3888dc7"> 411</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1ad753d3e2563b4fd663430af9f3888dc7">TRAP_CODE_FIRQ_2</a> = 0x80000012U, </div> +<div class="line"><a id="l00412" name="l00412"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a356f8485166529503d0fb246bd0aeeb0"> 412</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a356f8485166529503d0fb246bd0aeeb0">TRAP_CODE_FIRQ_3</a> = 0x80000013U, </div> +<div class="line"><a id="l00413" name="l00413"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1aaa8e7bb251852ef75a78be71eef0b547"> 413</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1aaa8e7bb251852ef75a78be71eef0b547">TRAP_CODE_FIRQ_4</a> = 0x80000014U, </div> +<div class="line"><a id="l00414" name="l00414"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a5789dfabd8ec265fa0734ddd94e98757"> 414</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a5789dfabd8ec265fa0734ddd94e98757">TRAP_CODE_FIRQ_5</a> = 0x80000015U, </div> +<div class="line"><a id="l00415" name="l00415"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a809e997f55e83c6812c965655511d473"> 415</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a809e997f55e83c6812c965655511d473">TRAP_CODE_FIRQ_6</a> = 0x80000016U, </div> +<div class="line"><a id="l00416" name="l00416"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1aeab719bcce9e9551bd6da65a7ae08a26"> 416</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1aeab719bcce9e9551bd6da65a7ae08a26">TRAP_CODE_FIRQ_7</a> = 0x80000017U, </div> +<div class="line"><a id="l00417" name="l00417"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1abfd21d1380dcacb9282e525da104d916"> 417</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1abfd21d1380dcacb9282e525da104d916">TRAP_CODE_FIRQ_8</a> = 0x80000018U, </div> +<div class="line"><a id="l00418" name="l00418"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a350e762a599479fb2c6d23ccc5ee22b4"> 418</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a350e762a599479fb2c6d23ccc5ee22b4">TRAP_CODE_FIRQ_9</a> = 0x80000019U, </div> +<div class="line"><a id="l00419" name="l00419"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a4f6b9c6bba91fe04becb776ad22dcf42"> 419</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a4f6b9c6bba91fe04becb776ad22dcf42">TRAP_CODE_FIRQ_10</a> = 0x8000001aU, </div> +<div class="line"><a id="l00420" name="l00420"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a874dcc43cf8fbbf2e0614e7db9e38334"> 420</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a874dcc43cf8fbbf2e0614e7db9e38334">TRAP_CODE_FIRQ_11</a> = 0x8000001bU, </div> +<div class="line"><a id="l00421" name="l00421"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a151f01e5f284f876cafafc7427720e4c"> 421</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a151f01e5f284f876cafafc7427720e4c">TRAP_CODE_FIRQ_12</a> = 0x8000001cU, </div> +<div class="line"><a id="l00422" name="l00422"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a7c8e97297cc4dcd6d5a1de65a124f3e9"> 422</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a7c8e97297cc4dcd6d5a1de65a124f3e9">TRAP_CODE_FIRQ_13</a> = 0x8000001dU, </div> +<div class="line"><a id="l00423" name="l00423"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a821f813de47eb781ab7715f780da3b1e"> 423</a></span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a821f813de47eb781ab7715f780da3b1e">TRAP_CODE_FIRQ_14</a> = 0x8000001eU, </div> +<div class="line"><a id="l00424" name="l00424"></a><span class="lineno"> 424</span> <a class="code hl_enumvalue" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1aa4eeafe2f6f59aff01e29461c664a110">TRAP_CODE_FIRQ_15</a> = 0x8000001fU </div> +<div class="line"><a id="l00425" name="l00425"></a><span class="lineno"><a class="line" href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1aa4eeafe2f6f59aff01e29461c664a110"> 425</a></span>};</div> +</div> +<div class="line"><a id="l00426" name="l00426"></a><span class="lineno"> 426</span> </div> +<div class="line"><a id="l00427" name="l00427"></a><span class="lineno"> 427</span> </div> +<div class="line"><a id="l00428" name="l00428"></a><span class="lineno"> 428</span><span class="preprocessor">#endif </span><span class="comment">// neorv32_cpu_csr_h</span></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_a0e9714690687badee43180c3cb62be33"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33">NEORV32_CSR_MIE_enum</a></div><div class="ttdeci">NEORV32_CSR_MIE_enum</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:250</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_a0e9714690687badee43180c3cb62be33a06fdb61dab31c3490da6c37d47914f19"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a06fdb61dab31c3490da6c37d47914f19">CSR_MIE_FIRQ9E</a></div><div class="ttdeci">@ CSR_MIE_FIRQ9E</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:265</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_a0e9714690687badee43180c3cb62be33a134ed02c7293008b21b1df472be8f11f"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a134ed02c7293008b21b1df472be8f11f">CSR_MIE_FIRQ13E</a></div><div class="ttdeci">@ CSR_MIE_FIRQ13E</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:269</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_a0e9714690687badee43180c3cb62be33a3079a8fbf3b8e376865bff76f2173698"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a3079a8fbf3b8e376865bff76f2173698">CSR_MIE_FIRQ5E</a></div><div class="ttdeci">@ CSR_MIE_FIRQ5E</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:261</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_a0e9714690687badee43180c3cb62be33a3658e8663e94cd8eaa7201b7a850d083"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a3658e8663e94cd8eaa7201b7a850d083">CSR_MIE_MTIE</a></div><div class="ttdeci">@ CSR_MIE_MTIE</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:252</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_a0e9714690687badee43180c3cb62be33a396c6c4b425b3fff598e2f846052f98e"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a396c6c4b425b3fff598e2f846052f98e">CSR_MIE_FIRQ8E</a></div><div class="ttdeci">@ CSR_MIE_FIRQ8E</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:264</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_a0e9714690687badee43180c3cb62be33a3d9d729940170609affbc6813054ebe8"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a3d9d729940170609affbc6813054ebe8">CSR_MIE_FIRQ7E</a></div><div class="ttdeci">@ CSR_MIE_FIRQ7E</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:263</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_a0e9714690687badee43180c3cb62be33a41f91a37f7e0c75c783312af6a72e943"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a41f91a37f7e0c75c783312af6a72e943">CSR_MIE_FIRQ12E</a></div><div class="ttdeci">@ CSR_MIE_FIRQ12E</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:268</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_a0e9714690687badee43180c3cb62be33a592939f1b7d79097f7f13d6ab0c268dc"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a592939f1b7d79097f7f13d6ab0c268dc">CSR_MIE_FIRQ4E</a></div><div class="ttdeci">@ CSR_MIE_FIRQ4E</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:260</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_a0e9714690687badee43180c3cb62be33a666066099d6cebadbef21d81c179e8db"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a666066099d6cebadbef21d81c179e8db">CSR_MIE_FIRQ3E</a></div><div class="ttdeci">@ CSR_MIE_FIRQ3E</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:259</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_a0e9714690687badee43180c3cb62be33a864d135708530016cfc52a65a1e4d79b"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a864d135708530016cfc52a65a1e4d79b">CSR_MIE_FIRQ14E</a></div><div class="ttdeci">@ CSR_MIE_FIRQ14E</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:270</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_a0e9714690687badee43180c3cb62be33a96315d6b5b9531bcbc1e78a3c9ab166a"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a96315d6b5b9531bcbc1e78a3c9ab166a">CSR_MIE_FIRQ6E</a></div><div class="ttdeci">@ CSR_MIE_FIRQ6E</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:262</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_a0e9714690687badee43180c3cb62be33a99f43f8bbfb29fba6224f081c363ac7d"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a99f43f8bbfb29fba6224f081c363ac7d">CSR_MIE_FIRQ0E</a></div><div class="ttdeci">@ CSR_MIE_FIRQ0E</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:256</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_a0e9714690687badee43180c3cb62be33aa2dfa1183af312de2959dadd217fddc1"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33aa2dfa1183af312de2959dadd217fddc1">CSR_MIE_FIRQ15E</a></div><div class="ttdeci">@ CSR_MIE_FIRQ15E</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:271</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_a0e9714690687badee43180c3cb62be33ac1e1d44becec1b393f79a118ed3d8beb"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33ac1e1d44becec1b393f79a118ed3d8beb">CSR_MIE_FIRQ1E</a></div><div class="ttdeci">@ CSR_MIE_FIRQ1E</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:257</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_a0e9714690687badee43180c3cb62be33ae8e4f0ee46abbbb3361de035a57b8324"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33ae8e4f0ee46abbbb3361de035a57b8324">CSR_MIE_MEIE</a></div><div class="ttdeci">@ CSR_MIE_MEIE</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:253</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_a0e9714690687badee43180c3cb62be33af058342854a0becd3bcc33877d9244cd"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33af058342854a0becd3bcc33877d9244cd">CSR_MIE_FIRQ11E</a></div><div class="ttdeci">@ CSR_MIE_FIRQ11E</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:267</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_a0e9714690687badee43180c3cb62be33afc805280e20ffface116ca61e11645f7"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33afc805280e20ffface116ca61e11645f7">CSR_MIE_FIRQ2E</a></div><div class="ttdeci">@ CSR_MIE_FIRQ2E</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:258</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_a0e9714690687badee43180c3cb62be33afd2f1c78c442c8c29ab075cacee0a27a"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33afd2f1c78c442c8c29ab075cacee0a27a">CSR_MIE_MSIE</a></div><div class="ttdeci">@ CSR_MIE_MSIE</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:251</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_a0e9714690687badee43180c3cb62be33affcb52dc57bb8c0cb1e7d3c1392d544a"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33affcb52dc57bb8c0cb1e7d3c1392d544a">CSR_MIE_FIRQ10E</a></div><div class="ttdeci">@ CSR_MIE_FIRQ10E</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:266</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_a5cb925a3e41efd5e767bb39b3ee60cfe"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfe">NEORV32_HPMCNT_EVENT_enum</a></div><div class="ttdeci">NEORV32_HPMCNT_EVENT_enum</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:353</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_a5cb925a3e41efd5e767bb39b3ee60cfea0f15c5a824cb1678423ac4ef72a5f4f5"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfea0f15c5a824cb1678423ac4ef72a5f4f5">HPMCNT_EVENT_BRANCHED</a></div><div class="ttdeci">@ HPMCNT_EVENT_BRANCHED</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:361</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_a5cb925a3e41efd5e767bb39b3ee60cfea1a06f216e1a12afa0b90d6e1218b3c91"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfea1a06f216e1a12afa0b90d6e1218b3c91">HPMCNT_EVENT_LOAD</a></div><div class="ttdeci">@ HPMCNT_EVENT_LOAD</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:362</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_a5cb925a3e41efd5e767bb39b3ee60cfea2b683572525adc02ce0910031cfea914"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfea2b683572525adc02ce0910031cfea914">HPMCNT_EVENT_CY</a></div><div class="ttdeci">@ HPMCNT_EVENT_CY</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:354</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_a5cb925a3e41efd5e767bb39b3ee60cfea3a4f5bf9251def87a71162dbcf9043c5"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfea3a4f5bf9251def87a71162dbcf9043c5">HPMCNT_EVENT_TRAP</a></div><div class="ttdeci">@ HPMCNT_EVENT_TRAP</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:365</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_a5cb925a3e41efd5e767bb39b3ee60cfea578ef6fc107c22b5cb7be5950f695640"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfea578ef6fc107c22b5cb7be5950f695640">HPMCNT_EVENT_TM</a></div><div class="ttdeci">@ HPMCNT_EVENT_TM</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:355</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_a5cb925a3e41efd5e767bb39b3ee60cfea67a59934bc66bc7ccf82d24fe8a18a3b"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfea67a59934bc66bc7ccf82d24fe8a18a3b">HPMCNT_EVENT_WAIT_LSU</a></div><div class="ttdeci">@ HPMCNT_EVENT_WAIT_LSU</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:364</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_a5cb925a3e41efd5e767bb39b3ee60cfea685ed663611d988702ec59c254eb61dd"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfea685ed663611d988702ec59c254eb61dd">HPMCNT_EVENT_COMPR</a></div><div class="ttdeci">@ HPMCNT_EVENT_COMPR</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:357</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_a5cb925a3e41efd5e767bb39b3ee60cfea6a942852e3cd85616a63addb8e9d76f2"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfea6a942852e3cd85616a63addb8e9d76f2">HPMCNT_EVENT_STORE</a></div><div class="ttdeci">@ HPMCNT_EVENT_STORE</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:363</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_a5cb925a3e41efd5e767bb39b3ee60cfea9e1e2b50352b2555e9c64e76776919a6"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfea9e1e2b50352b2555e9c64e76776919a6">HPMCNT_EVENT_BRANCH</a></div><div class="ttdeci">@ HPMCNT_EVENT_BRANCH</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:360</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_a5cb925a3e41efd5e767bb39b3ee60cfeaab438295e5f00ffe4c2457a54ee9bfc4"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfeaab438295e5f00ffe4c2457a54ee9bfc4">HPMCNT_EVENT_IR</a></div><div class="ttdeci">@ HPMCNT_EVENT_IR</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:356</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_a5cb925a3e41efd5e767bb39b3ee60cfeabcb123b5b150b4413e5fd48475faab27"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfeabcb123b5b150b4413e5fd48475faab27">HPMCNT_EVENT_WAIT_DIS</a></div><div class="ttdeci">@ HPMCNT_EVENT_WAIT_DIS</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:358</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_a5cb925a3e41efd5e767bb39b3ee60cfeaffbb04d0053ebd079c6cacb4e5e7ed6b"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfeaffbb04d0053ebd079c6cacb4e5e7ed6b">HPMCNT_EVENT_WAIT_ALU</a></div><div class="ttdeci">@ HPMCNT_EVENT_WAIT_ALU</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:359</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_a6301c554bf831b97fc28f9984a1ec21b"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21b">NEORV32_CSR_MIP_enum</a></div><div class="ttdeci">NEORV32_CSR_MIP_enum</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:278</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_a6301c554bf831b97fc28f9984a1ec21ba03edd398920b817150d29107c0b40792"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba03edd398920b817150d29107c0b40792">CSR_MIP_FIRQ12P</a></div><div class="ttdeci">@ CSR_MIP_FIRQ12P</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:296</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_a6301c554bf831b97fc28f9984a1ec21ba12da8c32d38d5a3539a0b766718bfd2d"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba12da8c32d38d5a3539a0b766718bfd2d">CSR_MIP_FIRQ15P</a></div><div class="ttdeci">@ CSR_MIP_FIRQ15P</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:299</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_a6301c554bf831b97fc28f9984a1ec21ba1470cfe04f9d3ce45b7156b2a7fae159"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba1470cfe04f9d3ce45b7156b2a7fae159">CSR_MIP_MSIP</a></div><div class="ttdeci">@ CSR_MIP_MSIP</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:279</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_a6301c554bf831b97fc28f9984a1ec21ba14da6a2a962bf82970638a948ffbc570"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba14da6a2a962bf82970638a948ffbc570">CSR_MIP_FIRQ13P</a></div><div class="ttdeci">@ CSR_MIP_FIRQ13P</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:297</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_a6301c554bf831b97fc28f9984a1ec21ba1d761ef98f88c40509168ac66b7a4872"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba1d761ef98f88c40509168ac66b7a4872">CSR_MIP_MEIP</a></div><div class="ttdeci">@ CSR_MIP_MEIP</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:281</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_a6301c554bf831b97fc28f9984a1ec21ba28a85ad8bd4c30fd3a91298dfa4fdb00"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba28a85ad8bd4c30fd3a91298dfa4fdb00">CSR_MIP_FIRQ0P</a></div><div class="ttdeci">@ CSR_MIP_FIRQ0P</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:284</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_a6301c554bf831b97fc28f9984a1ec21ba2b50cfa8be461b088ea8506ce4c741ba"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba2b50cfa8be461b088ea8506ce4c741ba">CSR_MIP_FIRQ10P</a></div><div class="ttdeci">@ CSR_MIP_FIRQ10P</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:294</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_a6301c554bf831b97fc28f9984a1ec21ba2b577b1da1074c29ad58005af1f91d52"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba2b577b1da1074c29ad58005af1f91d52">CSR_MIP_FIRQ1P</a></div><div class="ttdeci">@ CSR_MIP_FIRQ1P</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:285</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_a6301c554bf831b97fc28f9984a1ec21ba344943c62922561378d33ec51ac236e4"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba344943c62922561378d33ec51ac236e4">CSR_MIP_MTIP</a></div><div class="ttdeci">@ CSR_MIP_MTIP</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:280</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_a6301c554bf831b97fc28f9984a1ec21ba69ea0d3d76d4cec398f3b96959cc3544"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba69ea0d3d76d4cec398f3b96959cc3544">CSR_MIP_FIRQ11P</a></div><div class="ttdeci">@ CSR_MIP_FIRQ11P</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:295</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_a6301c554bf831b97fc28f9984a1ec21ba7512bb6c4841ddd477422b49ebb2a155"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba7512bb6c4841ddd477422b49ebb2a155">CSR_MIP_FIRQ3P</a></div><div class="ttdeci">@ CSR_MIP_FIRQ3P</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:287</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_a6301c554bf831b97fc28f9984a1ec21baaa55d19f9a47889bc364c94bda04b677"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21baaa55d19f9a47889bc364c94bda04b677">CSR_MIP_FIRQ5P</a></div><div class="ttdeci">@ CSR_MIP_FIRQ5P</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:289</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_a6301c554bf831b97fc28f9984a1ec21baad1e5e452a9c37561308765431f0260d"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21baad1e5e452a9c37561308765431f0260d">CSR_MIP_FIRQ14P</a></div><div class="ttdeci">@ CSR_MIP_FIRQ14P</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:298</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_a6301c554bf831b97fc28f9984a1ec21baad691486001a68f2375dcf5793ee795a"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21baad691486001a68f2375dcf5793ee795a">CSR_MIP_FIRQ7P</a></div><div class="ttdeci">@ CSR_MIP_FIRQ7P</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:291</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_a6301c554bf831b97fc28f9984a1ec21bab6421f242bb8a487a986346e11196eb8"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21bab6421f242bb8a487a986346e11196eb8">CSR_MIP_FIRQ4P</a></div><div class="ttdeci">@ CSR_MIP_FIRQ4P</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:288</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_a6301c554bf831b97fc28f9984a1ec21bad94c9691ce59b97fcfec14d345046c3e"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21bad94c9691ce59b97fcfec14d345046c3e">CSR_MIP_FIRQ9P</a></div><div class="ttdeci">@ CSR_MIP_FIRQ9P</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:293</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_a6301c554bf831b97fc28f9984a1ec21badf45c5a135431f958fa63574c1dfac6e"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21badf45c5a135431f958fa63574c1dfac6e">CSR_MIP_FIRQ2P</a></div><div class="ttdeci">@ CSR_MIP_FIRQ2P</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:286</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_a6301c554bf831b97fc28f9984a1ec21baf5bbd23d4f311f640db42e9015f87580"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21baf5bbd23d4f311f640db42e9015f87580">CSR_MIP_FIRQ8P</a></div><div class="ttdeci">@ CSR_MIP_FIRQ8P</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:292</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_a6301c554bf831b97fc28f9984a1ec21baffa7342631aa0526aaa44c0c549b1f3e"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21baffa7342631aa0526aaa44c0c549b1f3e">CSR_MIP_FIRQ6P</a></div><div class="ttdeci">@ CSR_MIP_FIRQ6P</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:290</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_a76b70a2334131e7589d84c1ee96de485"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#a76b70a2334131e7589d84c1ee96de485">NEORV32_CSR_MSTATUS_enum</a></div><div class="ttdeci">NEORV32_CSR_MSTATUS_enum</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:198</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_a76b70a2334131e7589d84c1ee96de485a75cefdbdef36b7fc248765b27c606a44"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#a76b70a2334131e7589d84c1ee96de485a75cefdbdef36b7fc248765b27c606a44">CSR_MSTATUS_MPRV</a></div><div class="ttdeci">@ CSR_MSTATUS_MPRV</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:203</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_a76b70a2334131e7589d84c1ee96de485a8067c609c2360cab3bafa3c43e03dbf0"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#a76b70a2334131e7589d84c1ee96de485a8067c609c2360cab3bafa3c43e03dbf0">CSR_MSTATUS_MPP_H</a></div><div class="ttdeci">@ CSR_MSTATUS_MPP_H</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:202</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_a76b70a2334131e7589d84c1ee96de485aaa1d482f828ac9cafc40fcfc298bec34"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#a76b70a2334131e7589d84c1ee96de485aaa1d482f828ac9cafc40fcfc298bec34">CSR_MSTATUS_MPIE</a></div><div class="ttdeci">@ CSR_MSTATUS_MPIE</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:200</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_a76b70a2334131e7589d84c1ee96de485ac94a070f3fe7962e8c49a81545cacf2d"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#a76b70a2334131e7589d84c1ee96de485ac94a070f3fe7962e8c49a81545cacf2d">CSR_MSTATUS_TW</a></div><div class="ttdeci">@ CSR_MSTATUS_TW</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:204</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_a76b70a2334131e7589d84c1ee96de485ae2603e365b3f1abfb46d53ed6b13dc56"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#a76b70a2334131e7589d84c1ee96de485ae2603e365b3f1abfb46d53ed6b13dc56">CSR_MSTATUS_MIE</a></div><div class="ttdeci">@ CSR_MSTATUS_MIE</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:199</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_a76b70a2334131e7589d84c1ee96de485af0ae9aca74144aa7dbdf656f71cc5c97"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#a76b70a2334131e7589d84c1ee96de485af0ae9aca74144aa7dbdf656f71cc5c97">CSR_MSTATUS_MPP_L</a></div><div class="ttdeci">@ CSR_MSTATUS_MPP_L</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:201</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_a8f2418fb5e2175f35ee2362469ce01f5"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#a8f2418fb5e2175f35ee2362469ce01f5">NEORV32_PMP_MODES_enum</a></div><div class="ttdeci">NEORV32_PMP_MODES_enum</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:384</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_a8f2418fb5e2175f35ee2362469ce01f5a003ccfae4aae1dad4fd65d5d4c7737c4"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#a8f2418fb5e2175f35ee2362469ce01f5a003ccfae4aae1dad4fd65d5d4c7737c4">PMP_OFF</a></div><div class="ttdeci">@ PMP_OFF</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:385</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_a8f2418fb5e2175f35ee2362469ce01f5a629a81a205abee94bad9d5bb5dfa26b1"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#a8f2418fb5e2175f35ee2362469ce01f5a629a81a205abee94bad9d5bb5dfa26b1">PMP_TOR</a></div><div class="ttdeci">@ PMP_TOR</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:386</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_a8f2418fb5e2175f35ee2362469ce01f5aae0e0c33b0d034cb50286239f955d892"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#a8f2418fb5e2175f35ee2362469ce01f5aae0e0c33b0d034cb50286239f955d892">PMP_NA4</a></div><div class="ttdeci">@ PMP_NA4</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:387</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_a8f2418fb5e2175f35ee2362469ce01f5ad555e9dfc0c00612bdea623617ff2820"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#a8f2418fb5e2175f35ee2362469ce01f5ad555e9dfc0c00612bdea623617ff2820">PMP_NAPOT</a></div><div class="ttdeci">@ PMP_NAPOT</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:388</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ab6886ca6858d57854495986ef9b5cbfe"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfe">NEORV32_CSR_MCOUNTINHIBIT_enum</a></div><div class="ttdeci">NEORV32_CSR_MCOUNTINHIBIT_enum</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:211</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ab6886ca6858d57854495986ef9b5cbfea0b547cb5876c0e7956e3d062e0784085"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea0b547cb5876c0e7956e3d062e0784085">CSR_MCOUNTINHIBIT_HPM15</a></div><div class="ttdeci">@ CSR_MCOUNTINHIBIT_HPM15</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:227</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ab6886ca6858d57854495986ef9b5cbfea0f207455df0fed75fa68ba49c435889a"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea0f207455df0fed75fa68ba49c435889a">CSR_MCOUNTINHIBIT_HPM9</a></div><div class="ttdeci">@ CSR_MCOUNTINHIBIT_HPM9</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:221</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ab6886ca6858d57854495986ef9b5cbfea0f45818fa4cb9033a3093987fa8515c7"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea0f45818fa4cb9033a3093987fa8515c7">CSR_MCOUNTINHIBIT_HPM30</a></div><div class="ttdeci">@ CSR_MCOUNTINHIBIT_HPM30</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:242</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ab6886ca6858d57854495986ef9b5cbfea141a4a211c496d2af1c79d8e8e0c2a74"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea141a4a211c496d2af1c79d8e8e0c2a74">CSR_MCOUNTINHIBIT_HPM26</a></div><div class="ttdeci">@ CSR_MCOUNTINHIBIT_HPM26</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:238</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ab6886ca6858d57854495986ef9b5cbfea1da1186ef2f4e7297a4fecaaccdc1d05"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea1da1186ef2f4e7297a4fecaaccdc1d05">CSR_MCOUNTINHIBIT_HPM31</a></div><div class="ttdeci">@ CSR_MCOUNTINHIBIT_HPM31</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:243</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ab6886ca6858d57854495986ef9b5cbfea1dc0276a5354c805ac56fd46c5037d38"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea1dc0276a5354c805ac56fd46c5037d38">CSR_MCOUNTINHIBIT_HPM21</a></div><div class="ttdeci">@ CSR_MCOUNTINHIBIT_HPM21</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:233</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ab6886ca6858d57854495986ef9b5cbfea201ac39b0eba389b0d02c3951a3311a3"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea201ac39b0eba389b0d02c3951a3311a3">CSR_MCOUNTINHIBIT_CY</a></div><div class="ttdeci">@ CSR_MCOUNTINHIBIT_CY</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:212</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ab6886ca6858d57854495986ef9b5cbfea2769a6e6a75f2f903523e4e95a899bb6"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea2769a6e6a75f2f903523e4e95a899bb6">CSR_MCOUNTINHIBIT_HPM5</a></div><div class="ttdeci">@ CSR_MCOUNTINHIBIT_HPM5</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:217</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ab6886ca6858d57854495986ef9b5cbfea33d0fd3378ec3a2fcc3c8738c6cd2f32"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea33d0fd3378ec3a2fcc3c8738c6cd2f32">CSR_MCOUNTINHIBIT_HPM28</a></div><div class="ttdeci">@ CSR_MCOUNTINHIBIT_HPM28</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:240</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ab6886ca6858d57854495986ef9b5cbfea3683e296caafe771b6dd57f4cf86f3dc"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea3683e296caafe771b6dd57f4cf86f3dc">CSR_MCOUNTINHIBIT_HPM19</a></div><div class="ttdeci">@ CSR_MCOUNTINHIBIT_HPM19</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:231</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ab6886ca6858d57854495986ef9b5cbfea3b3571fceb687da2d3807b0e59bdf7ab"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea3b3571fceb687da2d3807b0e59bdf7ab">CSR_MCOUNTINHIBIT_HPM7</a></div><div class="ttdeci">@ CSR_MCOUNTINHIBIT_HPM7</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:219</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ab6886ca6858d57854495986ef9b5cbfea40427b799da049413c5536afa623c61d"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea40427b799da049413c5536afa623c61d">CSR_MCOUNTINHIBIT_HPM4</a></div><div class="ttdeci">@ CSR_MCOUNTINHIBIT_HPM4</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:216</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ab6886ca6858d57854495986ef9b5cbfea46def851d4582b4bcec1f9d8bafd58db"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea46def851d4582b4bcec1f9d8bafd58db">CSR_MCOUNTINHIBIT_HPM27</a></div><div class="ttdeci">@ CSR_MCOUNTINHIBIT_HPM27</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:239</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ab6886ca6858d57854495986ef9b5cbfea5f182f39f9a4b871a097a51e57865bfa"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea5f182f39f9a4b871a097a51e57865bfa">CSR_MCOUNTINHIBIT_IR</a></div><div class="ttdeci">@ CSR_MCOUNTINHIBIT_IR</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:213</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ab6886ca6858d57854495986ef9b5cbfea68aba71ea77aba4005fb24a945ef38e4"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea68aba71ea77aba4005fb24a945ef38e4">CSR_MCOUNTINHIBIT_HPM16</a></div><div class="ttdeci">@ CSR_MCOUNTINHIBIT_HPM16</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:228</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ab6886ca6858d57854495986ef9b5cbfea74ec85a2e94aa0b9e8af29401ef7ecb1"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea74ec85a2e94aa0b9e8af29401ef7ecb1">CSR_MCOUNTINHIBIT_HPM24</a></div><div class="ttdeci">@ CSR_MCOUNTINHIBIT_HPM24</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:236</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ab6886ca6858d57854495986ef9b5cbfea85c0c2b2a5101380dec72516dda1a904"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea85c0c2b2a5101380dec72516dda1a904">CSR_MCOUNTINHIBIT_HPM23</a></div><div class="ttdeci">@ CSR_MCOUNTINHIBIT_HPM23</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:235</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ab6886ca6858d57854495986ef9b5cbfea8d57acf13a086635a63bc13ccdf479b3"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea8d57acf13a086635a63bc13ccdf479b3">CSR_MCOUNTINHIBIT_HPM17</a></div><div class="ttdeci">@ CSR_MCOUNTINHIBIT_HPM17</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:229</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ab6886ca6858d57854495986ef9b5cbfea8d866a4c815d8ba890a1e00ce9600486"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea8d866a4c815d8ba890a1e00ce9600486">CSR_MCOUNTINHIBIT_HPM12</a></div><div class="ttdeci">@ CSR_MCOUNTINHIBIT_HPM12</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:224</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ab6886ca6858d57854495986ef9b5cbfea9517cd32744c5064fa30780f911cd22e"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea9517cd32744c5064fa30780f911cd22e">CSR_MCOUNTINHIBIT_HPM10</a></div><div class="ttdeci">@ CSR_MCOUNTINHIBIT_HPM10</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:222</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ab6886ca6858d57854495986ef9b5cbfeaa39882f7dad9b7e16b317c75bad31382"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfeaa39882f7dad9b7e16b317c75bad31382">CSR_MCOUNTINHIBIT_HPM29</a></div><div class="ttdeci">@ CSR_MCOUNTINHIBIT_HPM29</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:241</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ab6886ca6858d57854495986ef9b5cbfeaa680d196d2ba0e403801a860bb9d8ce0"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfeaa680d196d2ba0e403801a860bb9d8ce0">CSR_MCOUNTINHIBIT_HPM18</a></div><div class="ttdeci">@ CSR_MCOUNTINHIBIT_HPM18</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:230</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ab6886ca6858d57854495986ef9b5cbfeaa83c0688869b1c43de0c4474e940f987"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfeaa83c0688869b1c43de0c4474e940f987">CSR_MCOUNTINHIBIT_HPM14</a></div><div class="ttdeci">@ CSR_MCOUNTINHIBIT_HPM14</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:226</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ab6886ca6858d57854495986ef9b5cbfeabd21344124eda4402523203185a58b8a"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfeabd21344124eda4402523203185a58b8a">CSR_MCOUNTINHIBIT_HPM8</a></div><div class="ttdeci">@ CSR_MCOUNTINHIBIT_HPM8</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:220</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ab6886ca6858d57854495986ef9b5cbfeacaf997fe8b912596224e2bb632e6a806"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfeacaf997fe8b912596224e2bb632e6a806">CSR_MCOUNTINHIBIT_HPM11</a></div><div class="ttdeci">@ CSR_MCOUNTINHIBIT_HPM11</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:223</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ab6886ca6858d57854495986ef9b5cbfead55b6af15841617d7dca3ab4fab893db"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfead55b6af15841617d7dca3ab4fab893db">CSR_MCOUNTINHIBIT_HPM6</a></div><div class="ttdeci">@ CSR_MCOUNTINHIBIT_HPM6</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:218</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ab6886ca6858d57854495986ef9b5cbfead9f6c4eb4284ee82b9e8d0c79f62b3ed"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfead9f6c4eb4284ee82b9e8d0c79f62b3ed">CSR_MCOUNTINHIBIT_HPM13</a></div><div class="ttdeci">@ CSR_MCOUNTINHIBIT_HPM13</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:225</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ab6886ca6858d57854495986ef9b5cbfeaeb4b1b6abafd22eec0764d5503878cca"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfeaeb4b1b6abafd22eec0764d5503878cca">CSR_MCOUNTINHIBIT_HPM20</a></div><div class="ttdeci">@ CSR_MCOUNTINHIBIT_HPM20</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:232</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ab6886ca6858d57854495986ef9b5cbfeaee2b5a2b7bd7ac07dae45900bc2faf46"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfeaee2b5a2b7bd7ac07dae45900bc2faf46">CSR_MCOUNTINHIBIT_HPM25</a></div><div class="ttdeci">@ CSR_MCOUNTINHIBIT_HPM25</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:237</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ab6886ca6858d57854495986ef9b5cbfeaf1b6153a0c664367bfefb78b2ca8b34e"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfeaf1b6153a0c664367bfefb78b2ca8b34e">CSR_MCOUNTINHIBIT_HPM22</a></div><div class="ttdeci">@ CSR_MCOUNTINHIBIT_HPM22</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:234</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ab6886ca6858d57854495986ef9b5cbfeaf7020159e0ba346561bfba101d22c752"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfeaf7020159e0ba346561bfba101d22c752">CSR_MCOUNTINHIBIT_HPM3</a></div><div class="ttdeci">@ CSR_MCOUNTINHIBIT_HPM3</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:215</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_abc0e8daad1e9beda4d9950452cc930ea"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#abc0e8daad1e9beda4d9950452cc930ea">NEORV32_PMPCFG_ATTRIBUTES_enum</a></div><div class="ttdeci">NEORV32_PMPCFG_ATTRIBUTES_enum</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:372</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_abc0e8daad1e9beda4d9950452cc930eaa59c294bc43d2117bb55e301eec683f14"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#abc0e8daad1e9beda4d9950452cc930eaa59c294bc43d2117bb55e301eec683f14">PMPCFG_L</a></div><div class="ttdeci">@ PMPCFG_L</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:378</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_abc0e8daad1e9beda4d9950452cc930eaa67ad3243eeb74f86a01efbade76f21e4"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#abc0e8daad1e9beda4d9950452cc930eaa67ad3243eeb74f86a01efbade76f21e4">PMPCFG_A_MSB</a></div><div class="ttdeci">@ PMPCFG_A_MSB</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:377</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_abc0e8daad1e9beda4d9950452cc930eaa7689905760f917499b1151cced384d2f"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#abc0e8daad1e9beda4d9950452cc930eaa7689905760f917499b1151cced384d2f">PMPCFG_W</a></div><div class="ttdeci">@ PMPCFG_W</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:374</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_abc0e8daad1e9beda4d9950452cc930eaaae1e6440956ad6b7cbf6062aa50f43b1"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#abc0e8daad1e9beda4d9950452cc930eaaae1e6440956ad6b7cbf6062aa50f43b1">PMPCFG_A_LSB</a></div><div class="ttdeci">@ PMPCFG_A_LSB</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:376</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_abc0e8daad1e9beda4d9950452cc930eaad3aca82a2ab57364e83f677d3d4f71a6"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#abc0e8daad1e9beda4d9950452cc930eaad3aca82a2ab57364e83f677d3d4f71a6">PMPCFG_R</a></div><div class="ttdeci">@ PMPCFG_R</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:373</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_abc0e8daad1e9beda4d9950452cc930eaaec94712deafba09c0cf956c6fd68fa8d"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#abc0e8daad1e9beda4d9950452cc930eaaec94712deafba09c0cf956c6fd68fa8d">PMPCFG_X</a></div><div class="ttdeci">@ PMPCFG_X</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:375</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49">NEORV32_CSR_enum</a></div><div class="ttdeci">NEORV32_CSR_enum</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:25</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49a03f29e792be2854efc9e66d710b78a1d"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a03f29e792be2854efc9e66d710b78a1d">CSR_HPMCOUNTER14H</a></div><div class="ttdeci">@ CSR_HPMCOUNTER14H</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:170</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49a0545d0921b3f90d037dbb25bc5fcc2f9"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a0545d0921b3f90d037dbb25bc5fcc2f9">CSR_MCONFIGPTR</a></div><div class="ttdeci">@ CSR_MCONFIGPTR</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:178</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49a067ed3778590ae97dc9b16069f0ed850"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a067ed3778590ae97dc9b16069f0ed850">CSR_PMPCFG3</a></div><div class="ttdeci">@ CSR_PMPCFG3</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:71</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49a06d39cf0f13d6401dcf426d56149c8cd"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a06d39cf0f13d6401dcf426d56149c8cd">CSR_MIMPID</a></div><div class="ttdeci">@ CSR_MIMPID</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:176</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49a06dfdeed757606529e4a99c033691b54"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a06dfdeed757606529e4a99c033691b54">CSR_MHPMEVENT15</a></div><div class="ttdeci">@ CSR_MHPMEVENT15</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:57</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49a0c9492f6b956f088847f72b28e7b1446"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a0c9492f6b956f088847f72b28e7b1446">CSR_PMPCFG2</a></div><div class="ttdeci">@ CSR_PMPCFG2</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:70</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49a0f4a1ae740efd80d14d21e90f355e9d7"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a0f4a1ae740efd80d14d21e90f355e9d7">CSR_DSCRATCH0</a></div><div class="ttdeci">@ CSR_DSCRATCH0</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:99</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49a11169bd08920d40c8f94fd29e1d33eff"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a11169bd08920d40c8f94fd29e1d33eff">CSR_HPMCOUNTER15H</a></div><div class="ttdeci">@ CSR_HPMCOUNTER15H</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:171</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49a125c4d0051548dea9104808b7bee1316"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a125c4d0051548dea9104808b7bee1316">CSR_HPMCOUNTER7</a></div><div class="ttdeci">@ CSR_HPMCOUNTER7</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:147</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49a1328a226d36d23cc81740397bde47a4e"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a1328a226d36d23cc81740397bde47a4e">CSR_MHPMCOUNTER12</a></div><div class="ttdeci">@ CSR_MHPMCOUNTER12</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:119</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49a1860dd9579906c67a3565063043dcf78"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a1860dd9579906c67a3565063043dcf78">CSR_MCOUNTEREN</a></div><div class="ttdeci">@ CSR_MCOUNTEREN</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:36</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49a18c2a249f1f7852f42f9e10dc59d46bb"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a18c2a249f1f7852f42f9e10dc59d46bb">CSR_MHPMCOUNTER9</a></div><div class="ttdeci">@ CSR_MHPMCOUNTER9</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:116</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49a1cfa1e3bc3c8a1c9a86c251a510d11cd"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a1cfa1e3bc3c8a1c9a86c251a510d11cd">CSR_MHPMEVENT6</a></div><div class="ttdeci">@ CSR_MHPMEVENT6</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:48</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49a1e41d2b27d7e8da14871852d81123cfd"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a1e41d2b27d7e8da14871852d81123cfd">CSR_MHPMCOUNTER10H</a></div><div class="ttdeci">@ CSR_MHPMCOUNTER10H</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:133</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49a20400929087fabba410a098667d2d4ff"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a20400929087fabba410a098667d2d4ff">CSR_MHPMCOUNTER15</a></div><div class="ttdeci">@ CSR_MHPMCOUNTER15</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:122</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49a22eea318ec1ac72cc14e133b71ef4b16"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a22eea318ec1ac72cc14e133b71ef4b16">CSR_PMPCFG1</a></div><div class="ttdeci">@ CSR_PMPCFG1</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:69</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49a23026793ee53c8d55d23f63195368a6b"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a23026793ee53c8d55d23f63195368a6b">CSR_PMPADDR12</a></div><div class="ttdeci">@ CSR_PMPADDR12</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:85</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49a23850b1804966cde2c1e84cde752d512"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a23850b1804966cde2c1e84cde752d512">CSR_MHPMEVENT10</a></div><div class="ttdeci">@ CSR_MHPMEVENT10</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:52</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49a24d8617a6ff2c1e49c9a73853ad9e450"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a24d8617a6ff2c1e49c9a73853ad9e450">CSR_HPMCOUNTER13</a></div><div class="ttdeci">@ CSR_HPMCOUNTER13</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:153</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49a2524659ca2785af51af7acf9cd560a9d"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a2524659ca2785af51af7acf9cd560a9d">CSR_MHPMEVENT5</a></div><div class="ttdeci">@ CSR_MHPMEVENT5</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:47</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49a252980a4da90c1f5c1ef85d164f72f25"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a252980a4da90c1f5c1ef85d164f72f25">CSR_MHPMCOUNTER3H</a></div><div class="ttdeci">@ CSR_MHPMCOUNTER3H</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:126</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49a28fcfd06ca1012c19cf053e57689687b"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a28fcfd06ca1012c19cf053e57689687b">CSR_MCYCLEH</a></div><div class="ttdeci">@ CSR_MCYCLEH</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:124</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49a2af8c5dcc87d92bcce392fb5b3aa065e"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a2af8c5dcc87d92bcce392fb5b3aa065e">CSR_HPMCOUNTER11H</a></div><div class="ttdeci">@ CSR_HPMCOUNTER11H</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:167</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49a2e14b57fee5376741634db7980a5005b"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a2e14b57fee5376741634db7980a5005b">CSR_MCAUSE</a></div><div class="ttdeci">@ CSR_MCAUSE</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:62</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49a2e53e6e01ca8d1b801f6dfba602f3f59"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a2e53e6e01ca8d1b801f6dfba602f3f59">CSR_MHPMEVENT7</a></div><div class="ttdeci">@ CSR_MHPMEVENT7</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:49</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49a2e9cfbf3c2828dd4bd92d2b8a1c99f85"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a2e9cfbf3c2828dd4bd92d2b8a1c99f85">CSR_MHPMCOUNTER4H</a></div><div class="ttdeci">@ CSR_MHPMCOUNTER4H</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:127</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49a30879e88b250d3e94d9d9e728ffcc2cc"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a30879e88b250d3e94d9d9e728ffcc2cc">CSR_PMPADDR13</a></div><div class="ttdeci">@ CSR_PMPADDR13</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:86</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49a32c22641ed66c6d20902306a2b1fad77"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a32c22641ed66c6d20902306a2b1fad77">CSR_MCYCLE</a></div><div class="ttdeci">@ CSR_MCYCLE</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:108</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49a332ec2b0740f8e899a1b2ec86f7ee9f2"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a332ec2b0740f8e899a1b2ec86f7ee9f2">CSR_MHPMCOUNTER12H</a></div><div class="ttdeci">@ CSR_MHPMCOUNTER12H</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:135</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49a382304065a6db773f925b80b9447b8a8"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a382304065a6db773f925b80b9447b8a8">CSR_CFUREG1</a></div><div class="ttdeci">@ CSR_CFUREG1</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:103</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49a396847bcf1634a1602ab117bfb57bdd2"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a396847bcf1634a1602ab117bfb57bdd2">CSR_MXISA</a></div><div class="ttdeci">@ CSR_MXISA</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:179</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49a3ce1dc0e2810f0df78feaa1c607a5ca6"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a3ce1dc0e2810f0df78feaa1c607a5ca6">CSR_MCOUNTINHIBIT</a></div><div class="ttdeci">@ CSR_MCOUNTINHIBIT</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:38</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49a3e5708c0f79cf58ae761b6bb8c2a4383"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a3e5708c0f79cf58ae761b6bb8c2a4383">CSR_PMPADDR11</a></div><div class="ttdeci">@ CSR_PMPADDR11</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:84</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49a3ee699d5b2886c54c92992f66b109b67"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a3ee699d5b2886c54c92992f66b109b67">CSR_HPMCOUNTER3</a></div><div class="ttdeci">@ CSR_HPMCOUNTER3</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:143</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49a427d7cf036b49efd46166c01f0504b68"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a427d7cf036b49efd46166c01f0504b68">CSR_CFUREG2</a></div><div class="ttdeci">@ CSR_CFUREG2</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:104</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49a438a65757b85f182dfb1f2a06c9ad520"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a438a65757b85f182dfb1f2a06c9ad520">CSR_HPMCOUNTER6H</a></div><div class="ttdeci">@ CSR_HPMCOUNTER6H</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:162</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49a46b8d3c288cbbfbf5a0af6e5cd8c5bc8"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a46b8d3c288cbbfbf5a0af6e5cd8c5bc8">CSR_MENVCFGH</a></div><div class="ttdeci">@ CSR_MENVCFGH</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:42</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49a49b7bc2df67a6c73a68757de9b218f77"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a49b7bc2df67a6c73a68757de9b218f77">CSR_MHPMCOUNTER6H</a></div><div class="ttdeci">@ CSR_MHPMCOUNTER6H</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:129</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49a4a93ac5ab276cfd2f9cd296c8ce1bff6"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a4a93ac5ab276cfd2f9cd296c8ce1bff6">CSR_MHPMEVENT3</a></div><div class="ttdeci">@ CSR_MHPMEVENT3</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:45</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49a4f229c169ada239033a1383412ce58c8"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a4f229c169ada239033a1383412ce58c8">CSR_MTINST</a></div><div class="ttdeci">@ CSR_MTINST</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:65</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49a4fa22699e96d6da8665077e3c95891ef"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a4fa22699e96d6da8665077e3c95891ef">CSR_HPMCOUNTER13H</a></div><div class="ttdeci">@ CSR_HPMCOUNTER13H</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:169</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49a54d38c8cf364d886eb7ac64463eedf77"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a54d38c8cf364d886eb7ac64463eedf77">CSR_PMPADDR9</a></div><div class="ttdeci">@ CSR_PMPADDR9</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:82</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49a575e5342d8ec304c32dbbe99d6fd6c0f"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a575e5342d8ec304c32dbbe99d6fd6c0f">CSR_MHPMCOUNTER10</a></div><div class="ttdeci">@ CSR_MHPMCOUNTER10</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:117</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49a5a4cde90c547e913bddc719b3ab75e79"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a5a4cde90c547e913bddc719b3ab75e79">CSR_MHPMCOUNTER8</a></div><div class="ttdeci">@ CSR_MHPMCOUNTER8</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:115</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49a5d60a25a66754066589e8facb7d41153"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a5d60a25a66754066589e8facb7d41153">CSR_MEPC</a></div><div class="ttdeci">@ CSR_MEPC</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:61</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49a5de5c5a036dc594a554d37df9ccf657d"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a5de5c5a036dc594a554d37df9ccf657d">CSR_MHPMCOUNTER13H</a></div><div class="ttdeci">@ CSR_MHPMCOUNTER13H</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:136</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49a5e1abf46b4f55bd18e1d132b32696ab6"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a5e1abf46b4f55bd18e1d132b32696ab6">CSR_FCSR</a></div><div class="ttdeci">@ CSR_FCSR</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:29</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49a625f606c14fd4d7224d7109e10508e7a"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a625f606c14fd4d7224d7109e10508e7a">CSR_FFLAGS</a></div><div class="ttdeci">@ CSR_FFLAGS</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:27</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49a6332d4ff090aa7c302d191219e846fff"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a6332d4ff090aa7c302d191219e846fff">CSR_HPMCOUNTER7H</a></div><div class="ttdeci">@ CSR_HPMCOUNTER7H</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:163</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49a6879b4bf5d2db92d236b9091df4841f2"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a6879b4bf5d2db92d236b9091df4841f2">CSR_PMPADDR15</a></div><div class="ttdeci">@ CSR_PMPADDR15</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:88</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49a6a2933f3a1fa243de02db8a795e3ca41"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a6a2933f3a1fa243de02db8a795e3ca41">CSR_PMPADDR1</a></div><div class="ttdeci">@ CSR_PMPADDR1</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:74</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49a6ba48e2306ae92f498552e1ea04d6790"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a6ba48e2306ae92f498552e1ea04d6790">CSR_MHARTID</a></div><div class="ttdeci">@ CSR_MHARTID</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:177</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49a6bb3ba59a25803d6f98faad67609a9a9"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a6bb3ba59a25803d6f98faad67609a9a9">CSR_DCSR</a></div><div class="ttdeci">@ CSR_DCSR</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:97</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49a7277a8f929a5a250f7227fbbdf545dbc"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a7277a8f929a5a250f7227fbbdf545dbc">CSR_HPMCOUNTER15</a></div><div class="ttdeci">@ CSR_HPMCOUNTER15</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:155</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49a7341886c7a4aed6fc7d8677c016a2cb8"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a7341886c7a4aed6fc7d8677c016a2cb8">CSR_MHPMCOUNTER9H</a></div><div class="ttdeci">@ CSR_MHPMCOUNTER9H</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:132</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49a74359db2583feb7119d4bcaa926242a0"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a74359db2583feb7119d4bcaa926242a0">CSR_HPMCOUNTER12H</a></div><div class="ttdeci">@ CSR_HPMCOUNTER12H</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:168</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49a7648dd0a47007d44a14e95ba47726599"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a7648dd0a47007d44a14e95ba47726599">CSR_MHPMCOUNTER5H</a></div><div class="ttdeci">@ CSR_MHPMCOUNTER5H</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:128</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49a76d30359e3b54197fb53f9939734cf1e"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a76d30359e3b54197fb53f9939734cf1e">CSR_MTVAL</a></div><div class="ttdeci">@ CSR_MTVAL</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:63</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49a7f198c465959dde37b7056dd06d45812"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a7f198c465959dde37b7056dd06d45812">CSR_FRM</a></div><div class="ttdeci">@ CSR_FRM</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:28</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49a7fb1de2019dd2b548084d5ca1630efbf"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a7fb1de2019dd2b548084d5ca1630efbf">CSR_MHPMEVENT11</a></div><div class="ttdeci">@ CSR_MHPMEVENT11</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:53</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49a7fd76fcfc0d0dd47e112786bea5e4071"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a7fd76fcfc0d0dd47e112786bea5e4071">CSR_MHPMCOUNTER11H</a></div><div class="ttdeci">@ CSR_MHPMCOUNTER11H</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:134</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49a80eab0e17f5fe41edde485044674dc57"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a80eab0e17f5fe41edde485044674dc57">CSR_TDATA1</a></div><div class="ttdeci">@ CSR_TDATA1</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:92</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49a8144da8cd8691ac54aa0712685865b66"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a8144da8cd8691ac54aa0712685865b66">CSR_INSTRET</a></div><div class="ttdeci">@ CSR_INSTRET</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:142</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49a8837ff8d2741639aa69da59659f9a080"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a8837ff8d2741639aa69da59659f9a080">CSR_HPMCOUNTER4H</a></div><div class="ttdeci">@ CSR_HPMCOUNTER4H</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:160</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49a8840b3d4f45453fc96813ccb369a68e5"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a8840b3d4f45453fc96813ccb369a68e5">CSR_MHPMCOUNTER11</a></div><div class="ttdeci">@ CSR_MHPMCOUNTER11</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:118</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49a8941071db6145d34fff842249c0dcb9f"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a8941071db6145d34fff842249c0dcb9f">CSR_PMPADDR0</a></div><div class="ttdeci">@ CSR_PMPADDR0</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:73</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49a89bad989197e9358563557311b3c97e9"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a89bad989197e9358563557311b3c97e9">CSR_PMPADDR3</a></div><div class="ttdeci">@ CSR_PMPADDR3</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:76</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49a8c31899b81bb5dba9b92a0f0ca71aea6"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a8c31899b81bb5dba9b92a0f0ca71aea6">CSR_MHPMEVENT13</a></div><div class="ttdeci">@ CSR_MHPMEVENT13</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:55</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49a919f39b0d299feb80403b42a466de444"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a919f39b0d299feb80403b42a466de444">CSR_MHPMCOUNTER7</a></div><div class="ttdeci">@ CSR_MHPMCOUNTER7</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:114</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49a91a8b5008b4e08ab34c1516e21bf0ba8"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a91a8b5008b4e08ab34c1516e21bf0ba8">CSR_PMPADDR14</a></div><div class="ttdeci">@ CSR_PMPADDR14</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:87</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49a964a6a50d0138447fad47e9c982a7ba4"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a964a6a50d0138447fad47e9c982a7ba4">CSR_MHPMEVENT14</a></div><div class="ttdeci">@ CSR_MHPMEVENT14</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:56</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49a98ed49716d0d89712863e7a542d38d2a"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a98ed49716d0d89712863e7a542d38d2a">CSR_HPMCOUNTER4</a></div><div class="ttdeci">@ CSR_HPMCOUNTER4</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:144</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49a98f5e2cf2d5dbb0125a222b0065c86eb"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a98f5e2cf2d5dbb0125a222b0065c86eb">CSR_MINSTRET</a></div><div class="ttdeci">@ CSR_MINSTRET</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:109</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49a9b66978d76260283007d399fc735d153"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a9b66978d76260283007d399fc735d153">CSR_INSTRETH</a></div><div class="ttdeci">@ CSR_INSTRETH</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:158</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49a9b84bd948dd52a7779b5fd16beddaab9"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a9b84bd948dd52a7779b5fd16beddaab9">CSR_MHPMCOUNTER4</a></div><div class="ttdeci">@ CSR_MHPMCOUNTER4</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:111</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49a9bdd102877ff50d38c86c3d741aeb4b0"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a9bdd102877ff50d38c86c3d741aeb4b0">CSR_MHPMCOUNTER13</a></div><div class="ttdeci">@ CSR_MHPMCOUNTER13</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:120</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49a9c55619ffb05e84b7210e2d47326fa98"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a9c55619ffb05e84b7210e2d47326fa98">CSR_MENVCFG</a></div><div class="ttdeci">@ CSR_MENVCFG</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:41</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49a9e75518df7d14a009e3a0d5588641ddc"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a9e75518df7d14a009e3a0d5588641ddc">CSR_MHPMCOUNTER8H</a></div><div class="ttdeci">@ CSR_MHPMCOUNTER8H</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:131</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49a9fd1ff4e8a42992c0a3ec02c397dd7f8"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a9fd1ff4e8a42992c0a3ec02c397dd7f8">CSR_HPMCOUNTER11</a></div><div class="ttdeci">@ CSR_HPMCOUNTER11</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:151</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49aa0b8c0561e8a778dce9c3b86499ffc50"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aa0b8c0561e8a778dce9c3b86499ffc50">CSR_PMPADDR2</a></div><div class="ttdeci">@ CSR_PMPADDR2</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:75</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49aa276bedb7dab28935163397b4879f6db"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aa276bedb7dab28935163397b4879f6db">CSR_CYCLEH</a></div><div class="ttdeci">@ CSR_CYCLEH</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:157</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49aa2f644a4f54ba3834bafa738208c0803"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aa2f644a4f54ba3834bafa738208c0803">CSR_HPMCOUNTER6</a></div><div class="ttdeci">@ CSR_HPMCOUNTER6</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:146</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49aa407e701bdbb9d26f84684b811c008a9"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aa407e701bdbb9d26f84684b811c008a9">CSR_HPMCOUNTER10</a></div><div class="ttdeci">@ CSR_HPMCOUNTER10</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:150</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49aa47ed1a4a4f9fcabceed0d6d626d0aaf"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aa47ed1a4a4f9fcabceed0d6d626d0aaf">CSR_HPMCOUNTER14</a></div><div class="ttdeci">@ CSR_HPMCOUNTER14</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:154</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49aa632d218400268df6dc6b289ff088d21"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aa632d218400268df6dc6b289ff088d21">CSR_MTVEC</a></div><div class="ttdeci">@ CSR_MTVEC</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:35</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49aa8ce8fc8a57dd82872d02b4113249a77"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aa8ce8fc8a57dd82872d02b4113249a77">CSR_HPMCOUNTER8H</a></div><div class="ttdeci">@ CSR_HPMCOUNTER8H</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:164</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49aaa3e6a1ac8999be42d7c13891546bb50"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aaa3e6a1ac8999be42d7c13891546bb50">CSR_HPMCOUNTER3H</a></div><div class="ttdeci">@ CSR_HPMCOUNTER3H</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:159</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49aaae2f0b2e3f5a31dff933868873f6d5d"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aaae2f0b2e3f5a31dff933868873f6d5d">CSR_TSELECT</a></div><div class="ttdeci">@ CSR_TSELECT</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:91</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49aaaf0f6b17a06d5922bcfdb47b382137e"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aaaf0f6b17a06d5922bcfdb47b382137e">CSR_CYCLE</a></div><div class="ttdeci">@ CSR_CYCLE</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:141</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49ab2376c3b7c3ec0b44105ec1ed951bfb0"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ab2376c3b7c3ec0b44105ec1ed951bfb0">CSR_HPMCOUNTER5</a></div><div class="ttdeci">@ CSR_HPMCOUNTER5</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:145</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49ab45ebb3bd861074a15cc2ad874756e8f"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ab45ebb3bd861074a15cc2ad874756e8f">CSR_HPMCOUNTER9</a></div><div class="ttdeci">@ CSR_HPMCOUNTER9</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:149</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49ab5f998725e002ffc2ff516ee973fe459"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ab5f998725e002ffc2ff516ee973fe459">CSR_MHPMEVENT4</a></div><div class="ttdeci">@ CSR_MHPMEVENT4</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:46</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49ac0183bb6f357ed33136493ae7ded987a"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ac0183bb6f357ed33136493ae7ded987a">CSR_MHPMCOUNTER7H</a></div><div class="ttdeci">@ CSR_MHPMCOUNTER7H</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:130</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49ac2541060307369b2031e9ec07bbd0067"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ac2541060307369b2031e9ec07bbd0067">CSR_MSTATUSH</a></div><div class="ttdeci">@ CSR_MSTATUSH</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:37</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49ac65bab6fd71439600c8fc549171251fa"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ac65bab6fd71439600c8fc549171251fa">CSR_MHPMCOUNTER14H</a></div><div class="ttdeci">@ CSR_MHPMCOUNTER14H</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:137</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49acac87125f8c723cc5df4d4169a82852b"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49acac87125f8c723cc5df4d4169a82852b">CSR_HPMCOUNTER8</a></div><div class="ttdeci">@ CSR_HPMCOUNTER8</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:148</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49acc0f9f5f3b5702f1b57f2ba3b6b62610"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49acc0f9f5f3b5702f1b57f2ba3b6b62610">CSR_MIE</a></div><div class="ttdeci">@ CSR_MIE</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:34</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49acdf793b30919e7fa1b85995abe531a20"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49acdf793b30919e7fa1b85995abe531a20">CSR_HPMCOUNTER9H</a></div><div class="ttdeci">@ CSR_HPMCOUNTER9H</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:165</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49ace4529c53ad2d46767f86d920eada507"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ace4529c53ad2d46767f86d920eada507">CSR_PMPADDR4</a></div><div class="ttdeci">@ CSR_PMPADDR4</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:77</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49acf336638697242b691b691dc56b9aadc"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49acf336638697242b691b691dc56b9aadc">CSR_TDATA2</a></div><div class="ttdeci">@ CSR_TDATA2</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:93</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49ad0e5de789d6390f750b8af03cdd15450"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ad0e5de789d6390f750b8af03cdd15450">CSR_MSTATUS</a></div><div class="ttdeci">@ CSR_MSTATUS</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:32</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49ad489feaa5ad1feb00d3df71d3e5b0cac"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ad489feaa5ad1feb00d3df71d3e5b0cac">CSR_HPMCOUNTER5H</a></div><div class="ttdeci">@ CSR_HPMCOUNTER5H</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:161</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49ad6296ca83bbe1280624f3c21adbd8a79"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ad6296ca83bbe1280624f3c21adbd8a79">CSR_MHPMEVENT8</a></div><div class="ttdeci">@ CSR_MHPMEVENT8</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:50</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49ad648b5ece209d47e9484fd7aa83e8e5f"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ad648b5ece209d47e9484fd7aa83e8e5f">CSR_MHPMEVENT12</a></div><div class="ttdeci">@ CSR_MHPMEVENT12</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:54</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49ad95cb95266533123447ff0e917f890e4"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ad95cb95266533123447ff0e917f890e4">CSR_MARCHID</a></div><div class="ttdeci">@ CSR_MARCHID</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:175</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49ad97b6fe934a3bed6b02d0c8d81165d60"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ad97b6fe934a3bed6b02d0c8d81165d60">CSR_PMPADDR10</a></div><div class="ttdeci">@ CSR_PMPADDR10</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:83</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49ad9e78f71409fd7783cc2ae7c28b5e42c"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ad9e78f71409fd7783cc2ae7c28b5e42c">CSR_PMPADDR5</a></div><div class="ttdeci">@ CSR_PMPADDR5</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:78</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49adae22d860d8162e15120051951e45229"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49adae22d860d8162e15120051951e45229">CSR_MHPMCOUNTER14</a></div><div class="ttdeci">@ CSR_MHPMCOUNTER14</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:121</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49addb485275c954d1181d5bd4e4609082c"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49addb485275c954d1181d5bd4e4609082c">CSR_MIP</a></div><div class="ttdeci">@ CSR_MIP</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:64</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49ade079242596ce14ce1ba9842ed29b84c"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ade079242596ce14ce1ba9842ed29b84c">CSR_MISA</a></div><div class="ttdeci">@ CSR_MISA</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:33</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49ae0a96f499dcde474af6ee620fbb1ebdc"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ae0a96f499dcde474af6ee620fbb1ebdc">CSR_MHPMCOUNTER3</a></div><div class="ttdeci">@ CSR_MHPMCOUNTER3</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:110</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49ae0e9cf0b99b8614ea0b870d38970281f"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ae0e9cf0b99b8614ea0b870d38970281f">CSR_CFUREG0</a></div><div class="ttdeci">@ CSR_CFUREG0</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:102</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49ae29976bb072639975ad0cdb985c7f004"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ae29976bb072639975ad0cdb985c7f004">CSR_MSCRATCH</a></div><div class="ttdeci">@ CSR_MSCRATCH</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:60</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49ae56e95d6d6dd63ff6f5b4192cf48c88b"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ae56e95d6d6dd63ff6f5b4192cf48c88b">CSR_HPMCOUNTER10H</a></div><div class="ttdeci">@ CSR_HPMCOUNTER10H</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:166</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49ae58f15a95aa41126819effe046ced804"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ae58f15a95aa41126819effe046ced804">CSR_HPMCOUNTER12</a></div><div class="ttdeci">@ CSR_HPMCOUNTER12</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:152</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49ae8ea19cf3e527dbc0d36a43dfd1b7346"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ae8ea19cf3e527dbc0d36a43dfd1b7346">CSR_PMPADDR7</a></div><div class="ttdeci">@ CSR_PMPADDR7</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:80</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49aec68bf7e26e44170c24599f7c6a8365b"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aec68bf7e26e44170c24599f7c6a8365b">CSR_PMPADDR8</a></div><div class="ttdeci">@ CSR_PMPADDR8</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:81</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49aefefa1cff0cf5d01109486e5a8bebedf"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aefefa1cff0cf5d01109486e5a8bebedf">CSR_CFUREG3</a></div><div class="ttdeci">@ CSR_CFUREG3</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:105</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49af15d389bb8f91c989df488d231666394"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49af15d389bb8f91c989df488d231666394">CSR_MHPMCOUNTER5</a></div><div class="ttdeci">@ CSR_MHPMCOUNTER5</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:112</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49af1a79349e46a4829af78d2cdfd0dc44f"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49af1a79349e46a4829af78d2cdfd0dc44f">CSR_PMPCFG0</a></div><div class="ttdeci">@ CSR_PMPCFG0</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:68</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49af4c98d949d2eb44f2518fdf314344d3b"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49af4c98d949d2eb44f2518fdf314344d3b">CSR_DPC</a></div><div class="ttdeci">@ CSR_DPC</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:98</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49af57b5b7b57cd6e8b3489a27dfd702444"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49af57b5b7b57cd6e8b3489a27dfd702444">CSR_PMPADDR6</a></div><div class="ttdeci">@ CSR_PMPADDR6</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:79</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49af5c5a21909aaca2b57f9a15f4bac246b"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49af5c5a21909aaca2b57f9a15f4bac246b">CSR_MVENDORID</a></div><div class="ttdeci">@ CSR_MVENDORID</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:174</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49af609807e2917f73e27e5f27b38a0fa46"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49af609807e2917f73e27e5f27b38a0fa46">CSR_MHPMCOUNTER15H</a></div><div class="ttdeci">@ CSR_MHPMCOUNTER15H</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:138</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49af65b9e99b9cadb3cb8d37f97cdbfeb9d"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49af65b9e99b9cadb3cb8d37f97cdbfeb9d">CSR_MHPMCOUNTER6</a></div><div class="ttdeci">@ CSR_MHPMCOUNTER6</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:113</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49af6727a9bdd60ccf020812095b7396632"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49af6727a9bdd60ccf020812095b7396632">CSR_MHPMEVENT9</a></div><div class="ttdeci">@ CSR_MHPMEVENT9</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:51</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49af67c819c104f7e3ec34f2cbb847cf83b"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49af67c819c104f7e3ec34f2cbb847cf83b">CSR_TINFO</a></div><div class="ttdeci">@ CSR_TINFO</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:94</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_ac065a8cc32eed9a69ea1798492a69f49afffb28b62b9baa127ae3bad919208988"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49afffb28b62b9baa127ae3bad919208988">CSR_MINSTRETH</a></div><div class="ttdeci">@ CSR_MINSTRETH</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:125</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_acb0fcbc551fec4c45676ff1317be24e1"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1">NEORV32_EXCEPTION_CODES_enum</a></div><div class="ttdeci">NEORV32_EXCEPTION_CODES_enum</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:395</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_acb0fcbc551fec4c45676ff1317be24e1a0a8010d7cc91b9557973a7a118828bee"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a0a8010d7cc91b9557973a7a118828bee">TRAP_CODE_I_MISALIGNED</a></div><div class="ttdeci">@ TRAP_CODE_I_MISALIGNED</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:396</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_acb0fcbc551fec4c45676ff1317be24e1a0cef77904935798d247d8396838297c1"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a0cef77904935798d247d8396838297c1">TRAP_CODE_FIRQ_0</a></div><div class="ttdeci">@ TRAP_CODE_FIRQ_0</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:409</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_acb0fcbc551fec4c45676ff1317be24e1a151f01e5f284f876cafafc7427720e4c"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a151f01e5f284f876cafafc7427720e4c">TRAP_CODE_FIRQ_12</a></div><div class="ttdeci">@ TRAP_CODE_FIRQ_12</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:421</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_acb0fcbc551fec4c45676ff1317be24e1a187ae38819b81672c15808e63c3b46b7"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a187ae38819b81672c15808e63c3b46b7">TRAP_CODE_MTI</a></div><div class="ttdeci">@ TRAP_CODE_MTI</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:407</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_acb0fcbc551fec4c45676ff1317be24e1a19708405f9f6300edf6b992c6d408a2d"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a19708405f9f6300edf6b992c6d408a2d">TRAP_CODE_S_MISALIGNED</a></div><div class="ttdeci">@ TRAP_CODE_S_MISALIGNED</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:402</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_acb0fcbc551fec4c45676ff1317be24e1a1a412b9d8eefba7880555d34625d2cc0"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a1a412b9d8eefba7880555d34625d2cc0">TRAP_CODE_MEI</a></div><div class="ttdeci">@ TRAP_CODE_MEI</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:408</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_acb0fcbc551fec4c45676ff1317be24e1a20e5a2680f2f5956bfa92852d5544eac"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a20e5a2680f2f5956bfa92852d5544eac">TRAP_CODE_MENV_CALL</a></div><div class="ttdeci">@ TRAP_CODE_MENV_CALL</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:405</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_acb0fcbc551fec4c45676ff1317be24e1a28448f0c670169140dc28b6794310cea"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a28448f0c670169140dc28b6794310cea">TRAP_CODE_L_ACCESS</a></div><div class="ttdeci">@ TRAP_CODE_L_ACCESS</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:401</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_acb0fcbc551fec4c45676ff1317be24e1a2c9510cb7583a0144f96678fc217335e"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a2c9510cb7583a0144f96678fc217335e">TRAP_CODE_BREAKPOINT</a></div><div class="ttdeci">@ TRAP_CODE_BREAKPOINT</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:399</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_acb0fcbc551fec4c45676ff1317be24e1a350e762a599479fb2c6d23ccc5ee22b4"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a350e762a599479fb2c6d23ccc5ee22b4">TRAP_CODE_FIRQ_9</a></div><div class="ttdeci">@ TRAP_CODE_FIRQ_9</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:418</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_acb0fcbc551fec4c45676ff1317be24e1a356f8485166529503d0fb246bd0aeeb0"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a356f8485166529503d0fb246bd0aeeb0">TRAP_CODE_FIRQ_3</a></div><div class="ttdeci">@ TRAP_CODE_FIRQ_3</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:412</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_acb0fcbc551fec4c45676ff1317be24e1a4f6b9c6bba91fe04becb776ad22dcf42"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a4f6b9c6bba91fe04becb776ad22dcf42">TRAP_CODE_FIRQ_10</a></div><div class="ttdeci">@ TRAP_CODE_FIRQ_10</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:419</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_acb0fcbc551fec4c45676ff1317be24e1a5789dfabd8ec265fa0734ddd94e98757"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a5789dfabd8ec265fa0734ddd94e98757">TRAP_CODE_FIRQ_5</a></div><div class="ttdeci">@ TRAP_CODE_FIRQ_5</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:414</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_acb0fcbc551fec4c45676ff1317be24e1a69e68a954da0bb33d1624484a6777ff9"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a69e68a954da0bb33d1624484a6777ff9">TRAP_CODE_L_MISALIGNED</a></div><div class="ttdeci">@ TRAP_CODE_L_MISALIGNED</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:400</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_acb0fcbc551fec4c45676ff1317be24e1a6a0ebfce4e18f36aeb43d5a65445cfe1"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a6a0ebfce4e18f36aeb43d5a65445cfe1">TRAP_CODE_I_ACCESS</a></div><div class="ttdeci">@ TRAP_CODE_I_ACCESS</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:397</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_acb0fcbc551fec4c45676ff1317be24e1a70bcfc75fe1056d93a3606f78c0cb887"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a70bcfc75fe1056d93a3606f78c0cb887">TRAP_CODE_S_ACCESS</a></div><div class="ttdeci">@ TRAP_CODE_S_ACCESS</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:403</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_acb0fcbc551fec4c45676ff1317be24e1a7c8e97297cc4dcd6d5a1de65a124f3e9"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a7c8e97297cc4dcd6d5a1de65a124f3e9">TRAP_CODE_FIRQ_13</a></div><div class="ttdeci">@ TRAP_CODE_FIRQ_13</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:422</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_acb0fcbc551fec4c45676ff1317be24e1a809e997f55e83c6812c965655511d473"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a809e997f55e83c6812c965655511d473">TRAP_CODE_FIRQ_6</a></div><div class="ttdeci">@ TRAP_CODE_FIRQ_6</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:415</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_acb0fcbc551fec4c45676ff1317be24e1a821f813de47eb781ab7715f780da3b1e"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a821f813de47eb781ab7715f780da3b1e">TRAP_CODE_FIRQ_14</a></div><div class="ttdeci">@ TRAP_CODE_FIRQ_14</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:423</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_acb0fcbc551fec4c45676ff1317be24e1a874dcc43cf8fbbf2e0614e7db9e38334"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a874dcc43cf8fbbf2e0614e7db9e38334">TRAP_CODE_FIRQ_11</a></div><div class="ttdeci">@ TRAP_CODE_FIRQ_11</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:420</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_acb0fcbc551fec4c45676ff1317be24e1aa102472d6a264bb92e0581ccaa413e02"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1aa102472d6a264bb92e0581ccaa413e02">TRAP_CODE_UENV_CALL</a></div><div class="ttdeci">@ TRAP_CODE_UENV_CALL</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:404</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_acb0fcbc551fec4c45676ff1317be24e1aa4eeafe2f6f59aff01e29461c664a110"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1aa4eeafe2f6f59aff01e29461c664a110">TRAP_CODE_FIRQ_15</a></div><div class="ttdeci">@ TRAP_CODE_FIRQ_15</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:424</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_acb0fcbc551fec4c45676ff1317be24e1aaa8e7bb251852ef75a78be71eef0b547"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1aaa8e7bb251852ef75a78be71eef0b547">TRAP_CODE_FIRQ_4</a></div><div class="ttdeci">@ TRAP_CODE_FIRQ_4</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:413</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_acb0fcbc551fec4c45676ff1317be24e1abfd21d1380dcacb9282e525da104d916"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1abfd21d1380dcacb9282e525da104d916">TRAP_CODE_FIRQ_8</a></div><div class="ttdeci">@ TRAP_CODE_FIRQ_8</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:417</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_acb0fcbc551fec4c45676ff1317be24e1ad753d3e2563b4fd663430af9f3888dc7"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1ad753d3e2563b4fd663430af9f3888dc7">TRAP_CODE_FIRQ_2</a></div><div class="ttdeci">@ TRAP_CODE_FIRQ_2</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:411</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_acb0fcbc551fec4c45676ff1317be24e1ae0b1049ae7f8cbfb6ff216e69ed5dae7"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1ae0b1049ae7f8cbfb6ff216e69ed5dae7">TRAP_CODE_FIRQ_1</a></div><div class="ttdeci">@ TRAP_CODE_FIRQ_1</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:410</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_acb0fcbc551fec4c45676ff1317be24e1ae0cebf99f36ef6be60e4a9d2c9f894b0"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1ae0cebf99f36ef6be60e4a9d2c9f894b0">TRAP_CODE_MSI</a></div><div class="ttdeci">@ TRAP_CODE_MSI</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:406</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_acb0fcbc551fec4c45676ff1317be24e1aeab719bcce9e9551bd6da65a7ae08a26"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1aeab719bcce9e9551bd6da65a7ae08a26">TRAP_CODE_FIRQ_7</a></div><div class="ttdeci">@ TRAP_CODE_FIRQ_7</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:416</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_acb0fcbc551fec4c45676ff1317be24e1af1ad8f557f3b685b59a913611e1da173"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1af1ad8f557f3b685b59a913611e1da173">TRAP_CODE_I_ILLEGAL</a></div><div class="ttdeci">@ TRAP_CODE_I_ILLEGAL</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:398</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_af05490a8af176ab4ba945d327d448387"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387">NEORV32_CSR_XISA_enum</a></div><div class="ttdeci">NEORV32_CSR_XISA_enum</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:325</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_af05490a8af176ab4ba945d327d448387a42a3b78195741af4b6aeeb98cbea46fe"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387a42a3b78195741af4b6aeeb98cbea46fe">CSR_MXISA_ZICNTR</a></div><div class="ttdeci">@ CSR_MXISA_ZICNTR</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:334</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_af05490a8af176ab4ba945d327d448387a48e57689f8a5b51d9ee9d648da7efc64"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387a48e57689f8a5b51d9ee9d648da7efc64">CSR_MXISA_FASTMUL</a></div><div class="ttdeci">@ CSR_MXISA_FASTMUL</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:345</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_af05490a8af176ab4ba945d327d448387a56ec3195d0d27f362f58fadb2e037ed1"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387a56ec3195d0d27f362f58fadb2e037ed1">CSR_MXISA_ZFINX</a></div><div class="ttdeci">@ CSR_MXISA_ZFINX</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:332</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_af05490a8af176ab4ba945d327d448387a59eae4272528f589f299ef9cce45af5b"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387a59eae4272528f589f299ef9cce45af5b">CSR_MXISA_SDTRIG</a></div><div class="ttdeci">@ CSR_MXISA_SDTRIG</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:338</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_af05490a8af176ab4ba945d327d448387a6843c660d75f33e4252c7fccd4565a2d"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387a6843c660d75f33e4252c7fccd4565a2d">CSR_MXISA_RFHWRST</a></div><div class="ttdeci">@ CSR_MXISA_RFHWRST</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:344</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_af05490a8af176ab4ba945d327d448387a6938948290d86b0ad25923f35d6c86d3"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387a6938948290d86b0ad25923f35d6c86d3">CSR_MXISA_SMPMP</a></div><div class="ttdeci">@ CSR_MXISA_SMPMP</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:335</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_af05490a8af176ab4ba945d327d448387a6979d4389ed9f8605d338fc616d29f0e"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387a6979d4389ed9f8605d338fc616d29f0e">CSR_MXISA_ZIFENCEI</a></div><div class="ttdeci">@ CSR_MXISA_ZIFENCEI</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:328</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_af05490a8af176ab4ba945d327d448387a79b2b4b20e08ad31b50724a7a27fb20f"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387a79b2b4b20e08ad31b50724a7a27fb20f">CSR_MXISA_ZMMUL</a></div><div class="ttdeci">@ CSR_MXISA_ZMMUL</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:329</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_af05490a8af176ab4ba945d327d448387a9b121ec0ad6271b6e07658f861015f6a"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387a9b121ec0ad6271b6e07658f861015f6a">CSR_MXISA_IS_SIM</a></div><div class="ttdeci">@ CSR_MXISA_IS_SIM</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:341</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_af05490a8af176ab4ba945d327d448387ab1f289cfaa9f54f7831a2abcdf9fca2e"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387ab1f289cfaa9f54f7831a2abcdf9fca2e">CSR_MXISA_ZICOND</a></div><div class="ttdeci">@ CSR_MXISA_ZICOND</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:333</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_af05490a8af176ab4ba945d327d448387ab6aec595e6aa5ce7c98c7806d23d7af5"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387ab6aec595e6aa5ce7c98c7806d23d7af5">CSR_MXISA_SDEXT</a></div><div class="ttdeci">@ CSR_MXISA_SDEXT</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:337</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_af05490a8af176ab4ba945d327d448387ac13e6883af3a9da18057462239b9fb34"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387ac13e6883af3a9da18057462239b9fb34">CSR_MXISA_ZIHPM</a></div><div class="ttdeci">@ CSR_MXISA_ZIHPM</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:336</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_af05490a8af176ab4ba945d327d448387accf1dd12be89e45df1423a5600789f2c"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387accf1dd12be89e45df1423a5600789f2c">CSR_MXISA_ZICSR</a></div><div class="ttdeci">@ CSR_MXISA_ZICSR</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:327</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_af05490a8af176ab4ba945d327d448387ad5ac9e2188757e6c42c159f0c5887868"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387ad5ac9e2188757e6c42c159f0c5887868">CSR_MXISA_FASTSHIFT</a></div><div class="ttdeci">@ CSR_MXISA_FASTSHIFT</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:346</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_af05490a8af176ab4ba945d327d448387af422ae3b5caba59e33a29b5d069597e0"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387af422ae3b5caba59e33a29b5d069597e0">CSR_MXISA_ZXCFU</a></div><div class="ttdeci">@ CSR_MXISA_ZXCFU</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:330</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_afde0761e3150d82511136f56179c204b"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#afde0761e3150d82511136f56179c204b">NEORV32_CSR_FFLAGS_enum</a></div><div class="ttdeci">NEORV32_CSR_FFLAGS_enum</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:186</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_afde0761e3150d82511136f56179c204ba365f3f519bca34a349907c82c873d52b"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#afde0761e3150d82511136f56179c204ba365f3f519bca34a349907c82c873d52b">CSR_FFLAGS_DZ</a></div><div class="ttdeci">@ CSR_FFLAGS_DZ</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:190</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_afde0761e3150d82511136f56179c204ba3ac330a4b03178e756c980eaa48ad165"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#afde0761e3150d82511136f56179c204ba3ac330a4b03178e756c980eaa48ad165">CSR_FFLAGS_NV</a></div><div class="ttdeci">@ CSR_FFLAGS_NV</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:191</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_afde0761e3150d82511136f56179c204ba612390e07a065fa13eeaeac84af48c6e"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#afde0761e3150d82511136f56179c204ba612390e07a065fa13eeaeac84af48c6e">CSR_FFLAGS_OF</a></div><div class="ttdeci">@ CSR_FFLAGS_OF</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:189</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_afde0761e3150d82511136f56179c204ba91a314defd310786a9ed67f7ef2ef5a6"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#afde0761e3150d82511136f56179c204ba91a314defd310786a9ed67f7ef2ef5a6">CSR_FFLAGS_NX</a></div><div class="ttdeci">@ CSR_FFLAGS_NX</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:187</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_afde0761e3150d82511136f56179c204babc6d405724563844569028f463885819"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#afde0761e3150d82511136f56179c204babc6d405724563844569028f463885819">CSR_FFLAGS_UF</a></div><div class="ttdeci">@ CSR_FFLAGS_UF</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:188</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_afed7f00bbb39468f038d9ca6fbac830c"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830c">NEORV32_CSR_MISA_enum</a></div><div class="ttdeci">NEORV32_CSR_MISA_enum</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:306</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_afed7f00bbb39468f038d9ca6fbac830ca0ac798fd19cb7dbe1146afecda448fec"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830ca0ac798fd19cb7dbe1146afecda448fec">CSR_MISA_E</a></div><div class="ttdeci">@ CSR_MISA_E</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:311</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_afed7f00bbb39468f038d9ca6fbac830ca0b119a20be29fcae8fecf2a81c60d193"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830ca0b119a20be29fcae8fecf2a81c60d193">CSR_MISA_X</a></div><div class="ttdeci">@ CSR_MISA_X</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:316</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_afed7f00bbb39468f038d9ca6fbac830ca1dd1be1071450f9b00a817bce19fa665"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830ca1dd1be1071450f9b00a817bce19fa665">CSR_MISA_D</a></div><div class="ttdeci">@ CSR_MISA_D</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:310</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_afed7f00bbb39468f038d9ca6fbac830ca317a631e4598532f5bffe8fb93aff94b"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830ca317a631e4598532f5bffe8fb93aff94b">CSR_MISA_M</a></div><div class="ttdeci">@ CSR_MISA_M</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:314</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_afed7f00bbb39468f038d9ca6fbac830ca6091fd2c7ae38ad33be68a0fdfa50cca"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830ca6091fd2c7ae38ad33be68a0fdfa50cca">CSR_MISA_I</a></div><div class="ttdeci">@ CSR_MISA_I</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:313</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_afed7f00bbb39468f038d9ca6fbac830ca886699013158c74810598fa2fd6b07fa"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830ca886699013158c74810598fa2fd6b07fa">CSR_MISA_C</a></div><div class="ttdeci">@ CSR_MISA_C</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:309</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_afed7f00bbb39468f038d9ca6fbac830ca89412df9f99d2a0ddc4665446397f1a2"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830ca89412df9f99d2a0ddc4665446397f1a2">CSR_MISA_A</a></div><div class="ttdeci">@ CSR_MISA_A</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:307</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_afed7f00bbb39468f038d9ca6fbac830ca9ec2cae2b948de1043540a4ca1665c40"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830ca9ec2cae2b948de1043540a4ca1665c40">CSR_MISA_F</a></div><div class="ttdeci">@ CSR_MISA_F</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:312</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_afed7f00bbb39468f038d9ca6fbac830cab5a55e97b8511f42fe68559a38f7f138"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830cab5a55e97b8511f42fe68559a38f7f138">CSR_MISA_MXL_LO</a></div><div class="ttdeci">@ CSR_MISA_MXL_LO</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:317</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_afed7f00bbb39468f038d9ca6fbac830cacd9d71e674d3a6d04984b6df706d9deb"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830cacd9d71e674d3a6d04984b6df706d9deb">CSR_MISA_U</a></div><div class="ttdeci">@ CSR_MISA_U</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:315</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_afed7f00bbb39468f038d9ca6fbac830cadd469404a928e012a298773ec46926ad"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830cadd469404a928e012a298773ec46926ad">CSR_MISA_B</a></div><div class="ttdeci">@ CSR_MISA_B</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:308</div></div> +<div class="ttc" id="aneorv32__cpu__csr_8h_html_afed7f00bbb39468f038d9ca6fbac830cafb3e4b08b87f5c161468a9e58ade12cc"><div class="ttname"><a href="neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830cafb3e4b08b87f5c161468a9e58ade12cc">CSR_MISA_MXL_HI</a></div><div class="ttdeci">@ CSR_MISA_MXL_HI</div><div class="ttdef"><b>Definition</b> neorv32_cpu_csr.h:318</div></div> +</div><!-- fragment --></div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/neorv32__crc_8c.html b/sw/neorv32__crc_8c.html new file mode 100644 index 0000000000..f11426ec7f --- /dev/null +++ b/sw/neorv32__crc_8c.html @@ -0,0 +1,255 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/lib/source/neorv32_crc.c File Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_7d04193005ada6f9450f847f4adb6b5b.html">lib</a></li><li class="navelem"><a class="el" href="dir_0c6ac14e2254a316d41123f98feeb67b.html">source</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#func-members">Functions</a> </div> + <div class="headertitle"><div class="title">neorv32_crc.c File Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p>Cyclic redundancy check unit (CRC) HW driver source file. +<a href="#details">More...</a></p> +<div class="textblock"><code>#include &quot;<a class="el" href="neorv32_8h_source.html">neorv32.h</a>&quot;</code><br /> +</div><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="func-members" name="func-members"></a> +Functions</h2></td></tr> +<tr class="memitem:aa46c647317752f8bb6d5836d4876a704" id="r_aa46c647317752f8bb6d5836d4876a704"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aa46c647317752f8bb6d5836d4876a704">neorv32_crc_available</a> (void)</td></tr> +<tr class="separator:aa46c647317752f8bb6d5836d4876a704"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a4ff5f7b91e9f668535ed33b6382ae623" id="r_a4ff5f7b91e9f668535ed33b6382ae623"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a4ff5f7b91e9f668535ed33b6382ae623">neorv32_crc_setup</a> (uint32_t mode, uint32_t poly, uint32_t start)</td></tr> +<tr class="separator:a4ff5f7b91e9f668535ed33b6382ae623"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a9243006e6cc94c03450646d26a7289b2" id="r_a9243006e6cc94c03450646d26a7289b2"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a9243006e6cc94c03450646d26a7289b2">neorv32_crc_block</a> (uint8_t *byte, int length)</td></tr> +<tr class="separator:a9243006e6cc94c03450646d26a7289b2"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ad9d50c76a485160667d486bce32cbeb8" id="r_ad9d50c76a485160667d486bce32cbeb8"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ad9d50c76a485160667d486bce32cbeb8">neorv32_crc_single</a> (uint8_t byte)</td></tr> +<tr class="separator:ad9d50c76a485160667d486bce32cbeb8"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a444b88f1536f65acc301fb19eddcf227" id="r_a444b88f1536f65acc301fb19eddcf227"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a444b88f1536f65acc301fb19eddcf227">neorv32_crc_get</a> (void)</td></tr> +<tr class="separator:a444b88f1536f65acc301fb19eddcf227"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>Cyclic redundancy check unit (CRC) HW driver source file. </p> +<dl class="section note"><dt>Note</dt><dd>These functions should only be used if the CRC unit was synthesized (IO_CRC_EN = true).</dd></dl> +<dl class="section see"><dt>See also</dt><dd><a href="https://stnolting.github.io/neorv32/sw/files.html">https://stnolting.github.io/neorv32/sw/files.html</a> </dd></dl> +</div><h2 class="groupheader">Function Documentation</h2> +<a id="aa46c647317752f8bb6d5836d4876a704" name="aa46c647317752f8bb6d5836d4876a704"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aa46c647317752f8bb6d5836d4876a704">&#9670;&#160;</a></span>neorv32_crc_available()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_crc_available </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Check if CRC unit was synthesized.</p> +<dl class="section return"><dt>Returns</dt><dd>0 if CRC was not synthesized, 1 if CRC is available. </dd></dl> + +</div> +</div> +<a id="a9243006e6cc94c03450646d26a7289b2" name="a9243006e6cc94c03450646d26a7289b2"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a9243006e6cc94c03450646d26a7289b2">&#9670;&#160;</a></span>neorv32_crc_block()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_crc_block </td> + <td>(</td> + <td class="paramtype">uint8_t *</td> <td class="paramname"><span class="paramname"><em>byte</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>length</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Compute pre-configured CRC for entire data block.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">byte</td><td>Pointer to byte (uint8_t) source data array. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">length</td><td>Length of source data array. </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>32-bit CRC result. </dd></dl> + +</div> +</div> +<a id="a444b88f1536f65acc301fb19eddcf227" name="a444b88f1536f65acc301fb19eddcf227"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a444b88f1536f65acc301fb19eddcf227">&#9670;&#160;</a></span>neorv32_crc_get()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_crc_get </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Get current CRC shift register data.</p> +<dl class="section return"><dt>Returns</dt><dd>32-bit CRC result. </dd></dl> + +</div> +</div> +<a id="a4ff5f7b91e9f668535ed33b6382ae623" name="a4ff5f7b91e9f668535ed33b6382ae623"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a4ff5f7b91e9f668535ed33b6382ae623">&#9670;&#160;</a></span>neorv32_crc_setup()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_crc_setup </td> + <td>(</td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>mode</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>poly</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>start</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Setup CRC unit.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">mode</td><td>Operation mode (<a class="el" href="neorv32__crc_8h.html#a1ae84a58f475bafc2fc3f2c690fd6447">NEORV32_CRC_MODE_enum</a>). </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">poly</td><td>CRC polynomial. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">start</td><td>CRC shift register start value. </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="ad9d50c76a485160667d486bce32cbeb8" name="ad9d50c76a485160667d486bce32cbeb8"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ad9d50c76a485160667d486bce32cbeb8">&#9670;&#160;</a></span>neorv32_crc_single()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_crc_single </td> + <td>(</td> + <td class="paramtype">uint8_t</td> <td class="paramname"><span class="paramname"><em>byte</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Compute pre-configured CRC for single data byte.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">byte</td><td>Data byte (uint8_t). </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/neorv32__crc_8h.html b/sw/neorv32__crc_8h.html new file mode 100644 index 0000000000..71059677bf --- /dev/null +++ b/sw/neorv32__crc_8h.html @@ -0,0 +1,312 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/lib/include/neorv32_crc.h File Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_7d04193005ada6f9450f847f4adb6b5b.html">lib</a></li><li class="navelem"><a class="el" href="dir_752b1e5d3973bf735fa78bf6b4727df9.html">include</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#nested-classes">Data Structures</a> </div> + <div class="headertitle"><div class="title">neorv32_crc.h File Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p>Cyclic redundancy check unit (CRC) HW driver header file. +<a href="#details">More...</a></p> +<div class="textblock"><code>#include &lt;stdint.h&gt;</code><br /> +</div> +<p><a href="neorv32__crc_8h_source.html">Go to the source code of this file.</a></p> +<table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="nested-classes" name="nested-classes"></a> +Data Structures</h2></td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">struct &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structneorv32__crc__t.html">neorv32_crc_t</a></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="func-members" name="func-members"></a> +Functions</h2></td></tr> +<tr><td colspan="2"><div class="groupHeader">Prototypes</div></td></tr> +<tr class="memitem:aa46c647317752f8bb6d5836d4876a704" id="r_aa46c647317752f8bb6d5836d4876a704"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aa46c647317752f8bb6d5836d4876a704">neorv32_crc_available</a> (void)</td></tr> +<tr class="separator:aa46c647317752f8bb6d5836d4876a704"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a4ff5f7b91e9f668535ed33b6382ae623" id="r_a4ff5f7b91e9f668535ed33b6382ae623"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a4ff5f7b91e9f668535ed33b6382ae623">neorv32_crc_setup</a> (uint32_t mode, uint32_t poly, uint32_t start)</td></tr> +<tr class="separator:a4ff5f7b91e9f668535ed33b6382ae623"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a9243006e6cc94c03450646d26a7289b2" id="r_a9243006e6cc94c03450646d26a7289b2"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a9243006e6cc94c03450646d26a7289b2">neorv32_crc_block</a> (uint8_t *byte, int length)</td></tr> +<tr class="separator:a9243006e6cc94c03450646d26a7289b2"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ad9d50c76a485160667d486bce32cbeb8" id="r_ad9d50c76a485160667d486bce32cbeb8"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ad9d50c76a485160667d486bce32cbeb8">neorv32_crc_single</a> (uint8_t byte)</td></tr> +<tr class="separator:ad9d50c76a485160667d486bce32cbeb8"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a444b88f1536f65acc301fb19eddcf227" id="r_a444b88f1536f65acc301fb19eddcf227"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a444b88f1536f65acc301fb19eddcf227">neorv32_crc_get</a> (void)</td></tr> +<tr class="separator:a444b88f1536f65acc301fb19eddcf227"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader">IO Device: Cyclic Redundancy Check Unit (CRC)</h2></td></tr> +<tr class="memitem:a110962d2b370f9d7997e459d9fd34271" id="r_a110962d2b370f9d7997e459d9fd34271"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a110962d2b370f9d7997e459d9fd34271">NEORV32_CRC</a>&#160;&#160;&#160;((<a class="el" href="structneorv32__crc__t.html">neorv32_crc_t</a>*) (<a class="el" href="neorv32_8h.html#a0e2377055bdc0f416b5ae4385610600d">NEORV32_CRC_BASE</a>))</td></tr> +<tr class="separator:a110962d2b370f9d7997e459d9fd34271"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a1ae84a58f475bafc2fc3f2c690fd6447" id="r_a1ae84a58f475bafc2fc3f2c690fd6447"><td class="memItemLeft" align="right" valign="top">enum &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a1ae84a58f475bafc2fc3f2c690fd6447">NEORV32_CRC_MODE_enum</a> { <a class="el" href="#a1ae84a58f475bafc2fc3f2c690fd6447a9409185edbae1bd0afdeda4e58aa6d1a">CRC_MODE8</a> = 0b00 +, <a class="el" href="#a1ae84a58f475bafc2fc3f2c690fd6447aa5cfd5d285b4cb8997c7e754491d050f">CRC_MODE16</a> = 0b01 +, <a class="el" href="#a1ae84a58f475bafc2fc3f2c690fd6447a7cf26bd4a7e8d6e45016633f650f00aa">CRC_MODE32</a> = 0b10 + }</td></tr> +<tr class="separator:a1ae84a58f475bafc2fc3f2c690fd6447"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>Cyclic redundancy check unit (CRC) HW driver header file. </p> +<dl class="section note"><dt>Note</dt><dd>These functions should only be used if the CRC unit was synthesized (IO_CRC_EN = true).</dd></dl> +<dl class="section see"><dt>See also</dt><dd><a href="https://stnolting.github.io/neorv32/sw/files.html">https://stnolting.github.io/neorv32/sw/files.html</a> </dd></dl> +</div><h2 class="groupheader">Macro Definition Documentation</h2> +<a id="a110962d2b370f9d7997e459d9fd34271" name="a110962d2b370f9d7997e459d9fd34271"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a110962d2b370f9d7997e459d9fd34271">&#9670;&#160;</a></span>NEORV32_CRC</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define NEORV32_CRC&#160;&#160;&#160;((<a class="el" href="structneorv32__crc__t.html">neorv32_crc_t</a>*) (<a class="el" href="neorv32_8h.html#a0e2377055bdc0f416b5ae4385610600d">NEORV32_CRC_BASE</a>))</td> + </tr> + </table> +</div><div class="memdoc"> +<p>CRC module hardware access (<a class="el" href="structneorv32__crc__t.html">neorv32_crc_t</a>) </p> + +</div> +</div> +<h2 class="groupheader">Enumeration Type Documentation</h2> +<a id="a1ae84a58f475bafc2fc3f2c690fd6447" name="a1ae84a58f475bafc2fc3f2c690fd6447"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a1ae84a58f475bafc2fc3f2c690fd6447">&#9670;&#160;</a></span>NEORV32_CRC_MODE_enum</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">enum <a class="el" href="#a1ae84a58f475bafc2fc3f2c690fd6447">NEORV32_CRC_MODE_enum</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>CRC mode select </p> +<table class="fieldtable"> +<tr><th colspan="2">Enumerator</th></tr><tr><td class="fieldname"><a id="a1ae84a58f475bafc2fc3f2c690fd6447a9409185edbae1bd0afdeda4e58aa6d1a" name="a1ae84a58f475bafc2fc3f2c690fd6447a9409185edbae1bd0afdeda4e58aa6d1a"></a>CRC_MODE8&#160;</td><td class="fielddoc"><p>(0) crc8 </p> +</td></tr> +<tr><td class="fieldname"><a id="a1ae84a58f475bafc2fc3f2c690fd6447aa5cfd5d285b4cb8997c7e754491d050f" name="a1ae84a58f475bafc2fc3f2c690fd6447aa5cfd5d285b4cb8997c7e754491d050f"></a>CRC_MODE16&#160;</td><td class="fielddoc"><p>(1) crc16 </p> +</td></tr> +<tr><td class="fieldname"><a id="a1ae84a58f475bafc2fc3f2c690fd6447a7cf26bd4a7e8d6e45016633f650f00aa" name="a1ae84a58f475bafc2fc3f2c690fd6447a7cf26bd4a7e8d6e45016633f650f00aa"></a>CRC_MODE32&#160;</td><td class="fielddoc"><p>(3) crc32 </p> +</td></tr> +</table> + +</div> +</div> +<h2 class="groupheader">Function Documentation</h2> +<a id="aa46c647317752f8bb6d5836d4876a704" name="aa46c647317752f8bb6d5836d4876a704"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aa46c647317752f8bb6d5836d4876a704">&#9670;&#160;</a></span>neorv32_crc_available()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_crc_available </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Check if CRC unit was synthesized.</p> +<dl class="section return"><dt>Returns</dt><dd>0 if CRC was not synthesized, 1 if CRC is available. </dd></dl> + +</div> +</div> +<a id="a9243006e6cc94c03450646d26a7289b2" name="a9243006e6cc94c03450646d26a7289b2"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a9243006e6cc94c03450646d26a7289b2">&#9670;&#160;</a></span>neorv32_crc_block()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_crc_block </td> + <td>(</td> + <td class="paramtype">uint8_t *</td> <td class="paramname"><span class="paramname"><em>byte</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>length</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Compute pre-configured CRC for entire data block.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">byte</td><td>Pointer to byte (uint8_t) source data array. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">length</td><td>Length of source data array. </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>32-bit CRC result. </dd></dl> + +</div> +</div> +<a id="a444b88f1536f65acc301fb19eddcf227" name="a444b88f1536f65acc301fb19eddcf227"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a444b88f1536f65acc301fb19eddcf227">&#9670;&#160;</a></span>neorv32_crc_get()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_crc_get </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Get current CRC shift register data.</p> +<dl class="section return"><dt>Returns</dt><dd>32-bit CRC result. </dd></dl> + +</div> +</div> +<a id="a4ff5f7b91e9f668535ed33b6382ae623" name="a4ff5f7b91e9f668535ed33b6382ae623"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a4ff5f7b91e9f668535ed33b6382ae623">&#9670;&#160;</a></span>neorv32_crc_setup()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_crc_setup </td> + <td>(</td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>mode</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>poly</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>start</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Setup CRC unit.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">mode</td><td>Operation mode (<a class="el" href="#a1ae84a58f475bafc2fc3f2c690fd6447">NEORV32_CRC_MODE_enum</a>). </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">poly</td><td>CRC polynomial. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">start</td><td>CRC shift register start value. </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="ad9d50c76a485160667d486bce32cbeb8" name="ad9d50c76a485160667d486bce32cbeb8"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ad9d50c76a485160667d486bce32cbeb8">&#9670;&#160;</a></span>neorv32_crc_single()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_crc_single </td> + <td>(</td> + <td class="paramtype">uint8_t</td> <td class="paramname"><span class="paramname"><em>byte</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Compute pre-configured CRC for single data byte.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">byte</td><td>Data byte (uint8_t). </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/neorv32__crc_8h_source.html b/sw/neorv32__crc_8h_source.html new file mode 100644 index 0000000000..c04a702582 --- /dev/null +++ b/sw/neorv32__crc_8h_source.html @@ -0,0 +1,157 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/lib/include/neorv32_crc.h Source File</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_7d04193005ada6f9450f847f4adb6b5b.html">lib</a></li><li class="navelem"><a class="el" href="dir_752b1e5d3973bf735fa78bf6b4727df9.html">include</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="headertitle"><div class="title">neorv32_crc.h</div></div> +</div><!--header--> +<div class="contents"> +<a href="neorv32__crc_8h.html">Go to the documentation of this file.</a><div class="fragment"><div class="line"><a id="l00001" name="l00001"></a><span class="lineno"> 1</span><span class="comment">// ================================================================================ //</span></div> +<div class="line"><a id="l00002" name="l00002"></a><span class="lineno"> 2</span><span class="comment">// The NEORV32 RISC-V Processor - https://github.com/stnolting/neorv32 //</span></div> +<div class="line"><a id="l00003" name="l00003"></a><span class="lineno"> 3</span><span class="comment">// Copyright (c) NEORV32 contributors. //</span></div> +<div class="line"><a id="l00004" name="l00004"></a><span class="lineno"> 4</span><span class="comment">// Copyright (c) 2020 - 2024 Stephan Nolting. All rights reserved. //</span></div> +<div class="line"><a id="l00005" name="l00005"></a><span class="lineno"> 5</span><span class="comment">// Licensed under the BSD-3-Clause license, see LICENSE for details. //</span></div> +<div class="line"><a id="l00006" name="l00006"></a><span class="lineno"> 6</span><span class="comment">// SPDX-License-Identifier: BSD-3-Clause //</span></div> +<div class="line"><a id="l00007" name="l00007"></a><span class="lineno"> 7</span><span class="comment">// ================================================================================ //</span></div> +<div class="line"><a id="l00008" name="l00008"></a><span class="lineno"> 8</span> </div> +<div class="line"><a id="l00018" name="l00018"></a><span class="lineno"> 18</span><span class="preprocessor">#ifndef neorv32_crc_h</span></div> +<div class="line"><a id="l00019" name="l00019"></a><span class="lineno"> 19</span><span class="preprocessor">#define neorv32_crc_h</span></div> +<div class="line"><a id="l00020" name="l00020"></a><span class="lineno"> 20</span> </div> +<div class="line"><a id="l00021" name="l00021"></a><span class="lineno"> 21</span><span class="preprocessor">#include &lt;stdint.h&gt;</span></div> +<div class="line"><a id="l00022" name="l00022"></a><span class="lineno"> 22</span> </div> +<div class="line"><a id="l00023" name="l00023"></a><span class="lineno"> 23</span> </div> +<div class="line"><a id="l00024" name="l00024"></a><span class="lineno"> 24</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen00029" data-start="{" data-end="};"> +<div class="line"><a id="l00029" name="l00029"></a><span class="lineno"><a class="line" href="structneorv32__crc__t.html"> 29</a></span><span class="keyword">typedef</span> <span class="keyword">volatile</span> <span class="keyword">struct </span>__attribute__((packed,aligned(4))) {</div> +<div class="line"><a id="l00030" name="l00030"></a><span class="lineno"><a class="line" href="structneorv32__crc__t.html#ad720502701f16e6e952bbcaee980017c"> 30</a></span> uint32_t <a class="code hl_variable" href="structneorv32__crc__t.html#ad720502701f16e6e952bbcaee980017c">MODE</a>; </div> +<div class="line"><a id="l00031" name="l00031"></a><span class="lineno"><a class="line" href="structneorv32__crc__t.html#a9bbcab843ddba4f9772d07478947a661"> 31</a></span> uint32_t <a class="code hl_variable" href="structneorv32__crc__t.html#a9bbcab843ddba4f9772d07478947a661">POLY</a>; </div> +<div class="line"><a id="l00032" name="l00032"></a><span class="lineno"><a class="line" href="structneorv32__crc__t.html#a47f286612848f597859aaef0d2d5da4d"> 32</a></span> uint32_t <a class="code hl_variable" href="structneorv32__crc__t.html#a47f286612848f597859aaef0d2d5da4d">DATA</a>; </div> +<div class="line"><a id="l00033" name="l00033"></a><span class="lineno"><a class="line" href="structneorv32__crc__t.html#abf2b419f2aefdb6f2a6b81a02cb8612d"> 33</a></span> uint32_t <a class="code hl_variable" href="structneorv32__crc__t.html#abf2b419f2aefdb6f2a6b81a02cb8612d">SREG</a>; </div> +<div class="line"><a id="l00034" name="l00034"></a><span class="lineno"> 34</span>} <a class="code hl_struct" href="structneorv32__crc__t.html">neorv32_crc_t</a>;</div> +</div> +<div class="line"><a id="l00035" name="l00035"></a><span class="lineno"> 35</span> </div> +<div class="line"><a id="l00037" name="l00037"></a><span class="lineno"><a class="line" href="neorv32__crc_8h.html#a110962d2b370f9d7997e459d9fd34271"> 37</a></span><span class="preprocessor">#define NEORV32_CRC ((neorv32_crc_t*) (NEORV32_CRC_BASE))</span></div> +<div class="line"><a id="l00038" name="l00038"></a><span class="lineno"> 38</span> </div> +<div class="foldopen" id="foldopen00040" data-start="{" data-end="};"> +<div class="line"><a id="l00040" name="l00040"></a><span class="lineno"><a class="line" href="neorv32__crc_8h.html#a1ae84a58f475bafc2fc3f2c690fd6447"> 40</a></span><span class="keyword">enum</span> <a class="code hl_enumeration" href="neorv32__crc_8h.html#a1ae84a58f475bafc2fc3f2c690fd6447">NEORV32_CRC_MODE_enum</a> {</div> +<div class="line"><a id="l00041" name="l00041"></a><span class="lineno"><a class="line" href="neorv32__crc_8h.html#a1ae84a58f475bafc2fc3f2c690fd6447a9409185edbae1bd0afdeda4e58aa6d1a"> 41</a></span> <a class="code hl_enumvalue" href="neorv32__crc_8h.html#a1ae84a58f475bafc2fc3f2c690fd6447a9409185edbae1bd0afdeda4e58aa6d1a">CRC_MODE8</a> = 0b00, </div> +<div class="line"><a id="l00042" name="l00042"></a><span class="lineno"><a class="line" href="neorv32__crc_8h.html#a1ae84a58f475bafc2fc3f2c690fd6447aa5cfd5d285b4cb8997c7e754491d050f"> 42</a></span> <a class="code hl_enumvalue" href="neorv32__crc_8h.html#a1ae84a58f475bafc2fc3f2c690fd6447aa5cfd5d285b4cb8997c7e754491d050f">CRC_MODE16</a> = 0b01, </div> +<div class="line"><a id="l00043" name="l00043"></a><span class="lineno"><a class="line" href="neorv32__crc_8h.html#a1ae84a58f475bafc2fc3f2c690fd6447a7cf26bd4a7e8d6e45016633f650f00aa"> 43</a></span> <a class="code hl_enumvalue" href="neorv32__crc_8h.html#a1ae84a58f475bafc2fc3f2c690fd6447a7cf26bd4a7e8d6e45016633f650f00aa">CRC_MODE32</a> = 0b10, </div> +<div class="line"><a id="l00044" name="l00044"></a><span class="lineno"> 44</span>};</div> +</div> +<div class="line"><a id="l00048" name="l00048"></a><span class="lineno"> 48</span><span class="comment">/**********************************************************************/</span></div> +<div class="line"><a id="l00052" name="l00052"></a><span class="lineno"> 52</span><span class="keywordtype">int</span> <a class="code hl_function" href="neorv32__crc_8h.html#aa46c647317752f8bb6d5836d4876a704">neorv32_crc_available</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00053" name="l00053"></a><span class="lineno"> 53</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__crc_8h.html#a4ff5f7b91e9f668535ed33b6382ae623">neorv32_crc_setup</a>(uint32_t mode, uint32_t poly, uint32_t start);</div> +<div class="line"><a id="l00054" name="l00054"></a><span class="lineno"> 54</span>uint32_t <a class="code hl_function" href="neorv32__crc_8h.html#a9243006e6cc94c03450646d26a7289b2">neorv32_crc_block</a>(uint8_t *<span class="keywordtype">byte</span>, <span class="keywordtype">int</span> length);</div> +<div class="line"><a id="l00055" name="l00055"></a><span class="lineno"> 55</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__crc_8h.html#ad9d50c76a485160667d486bce32cbeb8">neorv32_crc_single</a>(uint8_t <span class="keywordtype">byte</span>);</div> +<div class="line"><a id="l00056" name="l00056"></a><span class="lineno"> 56</span>uint32_t <a class="code hl_function" href="neorv32__crc_8h.html#a444b88f1536f65acc301fb19eddcf227">neorv32_crc_get</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00060" name="l00060"></a><span class="lineno"> 60</span><span class="preprocessor">#endif </span><span class="comment">// neorv32_crc_h</span></div> +<div class="ttc" id="aneorv32__crc_8h_html_a1ae84a58f475bafc2fc3f2c690fd6447"><div class="ttname"><a href="neorv32__crc_8h.html#a1ae84a58f475bafc2fc3f2c690fd6447">NEORV32_CRC_MODE_enum</a></div><div class="ttdeci">NEORV32_CRC_MODE_enum</div><div class="ttdef"><b>Definition</b> neorv32_crc.h:40</div></div> +<div class="ttc" id="aneorv32__crc_8h_html_a1ae84a58f475bafc2fc3f2c690fd6447a7cf26bd4a7e8d6e45016633f650f00aa"><div class="ttname"><a href="neorv32__crc_8h.html#a1ae84a58f475bafc2fc3f2c690fd6447a7cf26bd4a7e8d6e45016633f650f00aa">CRC_MODE32</a></div><div class="ttdeci">@ CRC_MODE32</div><div class="ttdef"><b>Definition</b> neorv32_crc.h:43</div></div> +<div class="ttc" id="aneorv32__crc_8h_html_a1ae84a58f475bafc2fc3f2c690fd6447a9409185edbae1bd0afdeda4e58aa6d1a"><div class="ttname"><a href="neorv32__crc_8h.html#a1ae84a58f475bafc2fc3f2c690fd6447a9409185edbae1bd0afdeda4e58aa6d1a">CRC_MODE8</a></div><div class="ttdeci">@ CRC_MODE8</div><div class="ttdef"><b>Definition</b> neorv32_crc.h:41</div></div> +<div class="ttc" id="aneorv32__crc_8h_html_a1ae84a58f475bafc2fc3f2c690fd6447aa5cfd5d285b4cb8997c7e754491d050f"><div class="ttname"><a href="neorv32__crc_8h.html#a1ae84a58f475bafc2fc3f2c690fd6447aa5cfd5d285b4cb8997c7e754491d050f">CRC_MODE16</a></div><div class="ttdeci">@ CRC_MODE16</div><div class="ttdef"><b>Definition</b> neorv32_crc.h:42</div></div> +<div class="ttc" id="aneorv32__crc_8h_html_a444b88f1536f65acc301fb19eddcf227"><div class="ttname"><a href="neorv32__crc_8h.html#a444b88f1536f65acc301fb19eddcf227">neorv32_crc_get</a></div><div class="ttdeci">uint32_t neorv32_crc_get(void)</div><div class="ttdef"><b>Definition</b> neorv32_crc.c:86</div></div> +<div class="ttc" id="aneorv32__crc_8h_html_a4ff5f7b91e9f668535ed33b6382ae623"><div class="ttname"><a href="neorv32__crc_8h.html#a4ff5f7b91e9f668535ed33b6382ae623">neorv32_crc_setup</a></div><div class="ttdeci">void neorv32_crc_setup(uint32_t mode, uint32_t poly, uint32_t start)</div><div class="ttdef"><b>Definition</b> neorv32_crc.c:44</div></div> +<div class="ttc" id="aneorv32__crc_8h_html_a9243006e6cc94c03450646d26a7289b2"><div class="ttname"><a href="neorv32__crc_8h.html#a9243006e6cc94c03450646d26a7289b2">neorv32_crc_block</a></div><div class="ttdeci">uint32_t neorv32_crc_block(uint8_t *byte, int length)</div><div class="ttdef"><b>Definition</b> neorv32_crc.c:59</div></div> +<div class="ttc" id="aneorv32__crc_8h_html_aa46c647317752f8bb6d5836d4876a704"><div class="ttname"><a href="neorv32__crc_8h.html#aa46c647317752f8bb6d5836d4876a704">neorv32_crc_available</a></div><div class="ttdeci">int neorv32_crc_available(void)</div><div class="ttdef"><b>Definition</b> neorv32_crc.c:26</div></div> +<div class="ttc" id="aneorv32__crc_8h_html_ad9d50c76a485160667d486bce32cbeb8"><div class="ttname"><a href="neorv32__crc_8h.html#ad9d50c76a485160667d486bce32cbeb8">neorv32_crc_single</a></div><div class="ttdeci">void neorv32_crc_single(uint8_t byte)</div><div class="ttdef"><b>Definition</b> neorv32_crc.c:75</div></div> +<div class="ttc" id="astructneorv32__crc__t_html"><div class="ttname"><a href="structneorv32__crc__t.html">neorv32_crc_t</a></div><div class="ttdef"><b>Definition</b> neorv32_crc.h:29</div></div> +<div class="ttc" id="astructneorv32__crc__t_html_a47f286612848f597859aaef0d2d5da4d"><div class="ttname"><a href="structneorv32__crc__t.html#a47f286612848f597859aaef0d2d5da4d">neorv32_crc_t::DATA</a></div><div class="ttdeci">uint32_t DATA</div><div class="ttdef"><b>Definition</b> neorv32_crc.h:32</div></div> +<div class="ttc" id="astructneorv32__crc__t_html_a9bbcab843ddba4f9772d07478947a661"><div class="ttname"><a href="structneorv32__crc__t.html#a9bbcab843ddba4f9772d07478947a661">neorv32_crc_t::POLY</a></div><div class="ttdeci">uint32_t POLY</div><div class="ttdef"><b>Definition</b> neorv32_crc.h:31</div></div> +<div class="ttc" id="astructneorv32__crc__t_html_abf2b419f2aefdb6f2a6b81a02cb8612d"><div class="ttname"><a href="structneorv32__crc__t.html#abf2b419f2aefdb6f2a6b81a02cb8612d">neorv32_crc_t::SREG</a></div><div class="ttdeci">uint32_t SREG</div><div class="ttdef"><b>Definition</b> neorv32_crc.h:33</div></div> +<div class="ttc" id="astructneorv32__crc__t_html_ad720502701f16e6e952bbcaee980017c"><div class="ttname"><a href="structneorv32__crc__t.html#ad720502701f16e6e952bbcaee980017c">neorv32_crc_t::MODE</a></div><div class="ttdeci">uint32_t MODE</div><div class="ttdef"><b>Definition</b> neorv32_crc.h:30</div></div> +</div><!-- fragment --></div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/neorv32__dma_8h.html b/sw/neorv32__dma_8h.html new file mode 100644 index 0000000000..1cfaf42873 --- /dev/null +++ b/sw/neorv32__dma_8h.html @@ -0,0 +1,676 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/lib/include/neorv32_dma.h File Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_7d04193005ada6f9450f847f4adb6b5b.html">lib</a></li><li class="navelem"><a class="el" href="dir_752b1e5d3973bf735fa78bf6b4727df9.html">include</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#nested-classes">Data Structures</a> &#124; +<a href="#enum-members">Enumerations</a> </div> + <div class="headertitle"><div class="title">neorv32_dma.h File Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p>Direct Memory Access Controller (DMA) HW driver header file. +<a href="#details">More...</a></p> +<div class="textblock"><code>#include &lt;stdint.h&gt;</code><br /> +</div> +<p><a href="neorv32__dma_8h_source.html">Go to the source code of this file.</a></p> +<table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="nested-classes" name="nested-classes"></a> +Data Structures</h2></td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">struct &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structneorv32__dma__t.html">neorv32_dma_t</a></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="define-members" name="define-members"></a> +Macros</h2></td></tr> +<tr><td colspan="2"><div class="groupHeader"></div></td></tr> +<tr class="memitem:a5e01d4454c97eb8e4ecd1455090bbfa9" id="r_a5e01d4454c97eb8e4ecd1455090bbfa9"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a5e01d4454c97eb8e4ecd1455090bbfa9">DMA_CMD_B2B</a>&#160;&#160;&#160;(0b00 &lt;&lt; <a class="el" href="#a33187c5a074d62b46d2262e352edb8d9afcfdedeca4c4a1def4905660811e31e2">DMA_TTYPE_QSEL_LSB</a>)</td></tr> +<tr class="separator:a5e01d4454c97eb8e4ecd1455090bbfa9"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aeb63f99217f14d1ddde35c1f6c104e72" id="r_aeb63f99217f14d1ddde35c1f6c104e72"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aeb63f99217f14d1ddde35c1f6c104e72">DMA_CMD_B2UW</a>&#160;&#160;&#160;(0b01 &lt;&lt; <a class="el" href="#a33187c5a074d62b46d2262e352edb8d9afcfdedeca4c4a1def4905660811e31e2">DMA_TTYPE_QSEL_LSB</a>)</td></tr> +<tr class="separator:aeb63f99217f14d1ddde35c1f6c104e72"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:adfecb3debff251070e4f6eb809412129" id="r_adfecb3debff251070e4f6eb809412129"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#adfecb3debff251070e4f6eb809412129">DMA_CMD_B2SW</a>&#160;&#160;&#160;(0b10 &lt;&lt; <a class="el" href="#a33187c5a074d62b46d2262e352edb8d9afcfdedeca4c4a1def4905660811e31e2">DMA_TTYPE_QSEL_LSB</a>)</td></tr> +<tr class="separator:adfecb3debff251070e4f6eb809412129"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a13a16ba8d6daf9c82312bf4d392d15a8" id="r_a13a16ba8d6daf9c82312bf4d392d15a8"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a13a16ba8d6daf9c82312bf4d392d15a8">DMA_CMD_W2W</a>&#160;&#160;&#160;(0b11 &lt;&lt; <a class="el" href="#a33187c5a074d62b46d2262e352edb8d9afcfdedeca4c4a1def4905660811e31e2">DMA_TTYPE_QSEL_LSB</a>)</td></tr> +<tr class="separator:a13a16ba8d6daf9c82312bf4d392d15a8"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ae380022d8b8fb70da91f0892f2bc32c8" id="r_ae380022d8b8fb70da91f0892f2bc32c8"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ae380022d8b8fb70da91f0892f2bc32c8">DMA_CMD_SRC_CONST</a>&#160;&#160;&#160;(0b0 &lt;&lt; <a class="el" href="#a33187c5a074d62b46d2262e352edb8d9a4b99a30b851851f3388dd4e77effacec">DMA_TTYPE_SRC_INC</a>)</td></tr> +<tr class="separator:ae380022d8b8fb70da91f0892f2bc32c8"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:acc081d58b53d1eddd2bff35b128d7da2" id="r_acc081d58b53d1eddd2bff35b128d7da2"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#acc081d58b53d1eddd2bff35b128d7da2">DMA_CMD_SRC_INC</a>&#160;&#160;&#160;(0b1 &lt;&lt; <a class="el" href="#a33187c5a074d62b46d2262e352edb8d9a4b99a30b851851f3388dd4e77effacec">DMA_TTYPE_SRC_INC</a>)</td></tr> +<tr class="separator:acc081d58b53d1eddd2bff35b128d7da2"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a6a0ce532aad39e6489e9d52bcb6f4cd2" id="r_a6a0ce532aad39e6489e9d52bcb6f4cd2"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a6a0ce532aad39e6489e9d52bcb6f4cd2">DMA_CMD_DST_CONST</a>&#160;&#160;&#160;(0b0 &lt;&lt; <a class="el" href="#a33187c5a074d62b46d2262e352edb8d9abb1293915b076e5d37be6724b44ab0da">DMA_TTYPE_DST_INC</a>)</td></tr> +<tr class="separator:a6a0ce532aad39e6489e9d52bcb6f4cd2"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a61caa2602c6b148af55d990e3c0ae6be" id="r_a61caa2602c6b148af55d990e3c0ae6be"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a61caa2602c6b148af55d990e3c0ae6be">DMA_CMD_DST_INC</a>&#160;&#160;&#160;(0b1 &lt;&lt; <a class="el" href="#a33187c5a074d62b46d2262e352edb8d9abb1293915b076e5d37be6724b44ab0da">DMA_TTYPE_DST_INC</a>)</td></tr> +<tr class="separator:a61caa2602c6b148af55d990e3c0ae6be"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a18fb7faa0a35f562821ca854d7c648b4" id="r_a18fb7faa0a35f562821ca854d7c648b4"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a18fb7faa0a35f562821ca854d7c648b4">DMA_CMD_ENDIAN</a>&#160;&#160;&#160;(0b1 &lt;&lt; <a class="el" href="#a33187c5a074d62b46d2262e352edb8d9a37ea8ef1e6b342db330d3885545fc802">DMA_TTYPE_ENDIAN</a>)</td></tr> +<tr class="separator:a18fb7faa0a35f562821ca854d7c648b4"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="enum-members" name="enum-members"></a> +Enumerations</h2></td></tr> +<tr class="memitem:a002cb188ea5156df0ba282e239a6e74b" id="r_a002cb188ea5156df0ba282e239a6e74b"><td class="memItemLeft" align="right" valign="top">enum &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a002cb188ea5156df0ba282e239a6e74b">NEORV32_DMA_STATUS_enum</a> { <a class="el" href="#a002cb188ea5156df0ba282e239a6e74ba038b6ef194c3db158cb59168f763a7b8">DMA_STATUS_ERR_WR</a> = -2 +, <a class="el" href="#a002cb188ea5156df0ba282e239a6e74baed7242b847e3cc8cf20d7da99f9b1492">DMA_STATUS_ERR_RD</a> = -1 +, <a class="el" href="#a002cb188ea5156df0ba282e239a6e74bac9c380cd5729386e5f5673e20b86326f">DMA_STATUS_IDLE</a> = 0 +, <a class="el" href="#a002cb188ea5156df0ba282e239a6e74bad0f66e962296f5451d73dc1cae1fdc0d">DMA_STATUS_BUSY</a> = 1 + }</td></tr> +<tr class="separator:a002cb188ea5156df0ba282e239a6e74b"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="func-members" name="func-members"></a> +Functions</h2></td></tr> +<tr><td colspan="2"><div class="groupHeader">Prototypes</div></td></tr> +<tr class="memitem:a13260c3252f0375d8982590d270d7dfd" id="r_a13260c3252f0375d8982590d270d7dfd"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a13260c3252f0375d8982590d270d7dfd">neorv32_dma_available</a> (void)</td></tr> +<tr class="separator:a13260c3252f0375d8982590d270d7dfd"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ac3b72447e8a132faf26577ac714b8284" id="r_ac3b72447e8a132faf26577ac714b8284"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ac3b72447e8a132faf26577ac714b8284">neorv32_dma_enable</a> (void)</td></tr> +<tr class="separator:ac3b72447e8a132faf26577ac714b8284"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a6df244028455cf7f8d4cf1520c4670a7" id="r_a6df244028455cf7f8d4cf1520c4670a7"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a6df244028455cf7f8d4cf1520c4670a7">neorv32_dma_disable</a> (void)</td></tr> +<tr class="separator:a6df244028455cf7f8d4cf1520c4670a7"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a2c7257567ccdb7a986f5ef7c74d3917c" id="r_a2c7257567ccdb7a986f5ef7c74d3917c"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a2c7257567ccdb7a986f5ef7c74d3917c">neorv32_dma_fence_enable</a> (void)</td></tr> +<tr class="separator:a2c7257567ccdb7a986f5ef7c74d3917c"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a8f37adfa07050b0a1cb8430c9ce1fcc2" id="r_a8f37adfa07050b0a1cb8430c9ce1fcc2"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a8f37adfa07050b0a1cb8430c9ce1fcc2">neorv32_dma_fence_disable</a> (void)</td></tr> +<tr class="separator:a8f37adfa07050b0a1cb8430c9ce1fcc2"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a2ce0d31e04604b2523135d52a877febf" id="r_a2ce0d31e04604b2523135d52a877febf"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a2ce0d31e04604b2523135d52a877febf">neorv32_dma_transfer</a> (uint32_t base_src, uint32_t base_dst, uint32_t num, uint32_t config)</td></tr> +<tr class="separator:a2ce0d31e04604b2523135d52a877febf"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a6ebd1595ee6fa0e6cbfbd1ce7476f18e" id="r_a6ebd1595ee6fa0e6cbfbd1ce7476f18e"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a6ebd1595ee6fa0e6cbfbd1ce7476f18e">neorv32_dma_transfer_auto</a> (uint32_t base_src, uint32_t base_dst, uint32_t num, uint32_t config, int firq_sel, int firq_type)</td></tr> +<tr class="separator:a6ebd1595ee6fa0e6cbfbd1ce7476f18e"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aa116f9714174abbe8a3583e441fee24b" id="r_aa116f9714174abbe8a3583e441fee24b"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aa116f9714174abbe8a3583e441fee24b">neorv32_dma_status</a> (void)</td></tr> +<tr class="separator:aa116f9714174abbe8a3583e441fee24b"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:afc8cc32f7d80d0f5ab33b2f1ecf77956" id="r_afc8cc32f7d80d0f5ab33b2f1ecf77956"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#afc8cc32f7d80d0f5ab33b2f1ecf77956">neorv32_dma_done</a> (void)</td></tr> +<tr class="separator:afc8cc32f7d80d0f5ab33b2f1ecf77956"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader">IO Device: Direct Memory Access Controller (DMA)</h2></td></tr> +<tr class="memitem:a0dcb61a0e0d2b45beb7818015adc8639" id="r_a0dcb61a0e0d2b45beb7818015adc8639"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a0dcb61a0e0d2b45beb7818015adc8639">NEORV32_DMA</a>&#160;&#160;&#160;((<a class="el" href="structneorv32__dma__t.html">neorv32_dma_t</a>*) (<a class="el" href="neorv32_8h.html#aa8d3a83ffad1e71f0832a5da78d62008">NEORV32_DMA_BASE</a>))</td></tr> +<tr class="separator:a0dcb61a0e0d2b45beb7818015adc8639"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a6716eddb145b80ad38799da3b87cb2a4" id="r_a6716eddb145b80ad38799da3b87cb2a4"><td class="memItemLeft" align="right" valign="top">enum &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a6716eddb145b80ad38799da3b87cb2a4">NEORV32_DMA_CTRL_enum</a> { <br /> +&#160;&#160;<a class="el" href="#a6716eddb145b80ad38799da3b87cb2a4a5f39deea0212f45423243c8100c40838">DMA_CTRL_EN</a> = 0 +, <a class="el" href="#a6716eddb145b80ad38799da3b87cb2a4a5aeeb05d6365d94d92808df2490daa3b">DMA_CTRL_AUTO</a> = 1 +, <a class="el" href="#a6716eddb145b80ad38799da3b87cb2a4ace9fdcdfa8784abad30e033c273e7d00">DMA_CTRL_FENCE</a> = 2 +, <a class="el" href="#a6716eddb145b80ad38799da3b87cb2a4a539609fc4d80867b3eb98c78206f5f96">DMA_CTRL_ERROR_RD</a> = 8 +, <br /> +&#160;&#160;<a class="el" href="#a6716eddb145b80ad38799da3b87cb2a4af7e038b0b0e3ac64f5a2c598eb9c5101">DMA_CTRL_ERROR_WR</a> = 9 +, <a class="el" href="#a6716eddb145b80ad38799da3b87cb2a4a8e5ff34ac48eea4b352378bb2af47bcb">DMA_CTRL_BUSY</a> = 10 +, <a class="el" href="#a6716eddb145b80ad38799da3b87cb2a4a0d51df1bb87dc54d331891c5db787bcc">DMA_CTRL_DONE</a> = 11 +, <a class="el" href="#a6716eddb145b80ad38799da3b87cb2a4aeaf5ee8f6a84668aa15cd3e21f076afe">DMA_CTRL_FIRQ_TYPE</a> = 15 +, <br /> +&#160;&#160;<a class="el" href="#a6716eddb145b80ad38799da3b87cb2a4aaf040e663494b39b890d7171d0a584b9">DMA_CTRL_FIRQ_SEL_LSB</a> = 16 +, <a class="el" href="#a6716eddb145b80ad38799da3b87cb2a4a3eba1f7868f0c985effb69785ced011a">DMA_CTRL_FIRQ_SEL_MSB</a> = 19 +<br /> + }</td></tr> +<tr class="separator:a6716eddb145b80ad38799da3b87cb2a4"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a33187c5a074d62b46d2262e352edb8d9" id="r_a33187c5a074d62b46d2262e352edb8d9"><td class="memItemLeft" align="right" valign="top">enum &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a33187c5a074d62b46d2262e352edb8d9">NEORV32_DMA_TTYPE_enum</a> { <br /> +&#160;&#160;<a class="el" href="#a33187c5a074d62b46d2262e352edb8d9a8dba4160c033c763f5102928c471e450">DMA_TTYPE_NUM_LSB</a> = 0 +, <a class="el" href="#a33187c5a074d62b46d2262e352edb8d9a61553eee00ed2382565bf826074c44bd">DMA_TTYPE_NUM_MSB</a> = 23 +, <a class="el" href="#a33187c5a074d62b46d2262e352edb8d9afcfdedeca4c4a1def4905660811e31e2">DMA_TTYPE_QSEL_LSB</a> = 27 +, <a class="el" href="#a33187c5a074d62b46d2262e352edb8d9a4217c9a8ac4ccc52bb45944f30a598c5">DMA_TTYPE_QSEL_MSB</a> = 28 +, <br /> +&#160;&#160;<a class="el" href="#a33187c5a074d62b46d2262e352edb8d9a4b99a30b851851f3388dd4e77effacec">DMA_TTYPE_SRC_INC</a> = 29 +, <a class="el" href="#a33187c5a074d62b46d2262e352edb8d9abb1293915b076e5d37be6724b44ab0da">DMA_TTYPE_DST_INC</a> = 30 +, <a class="el" href="#a33187c5a074d62b46d2262e352edb8d9a37ea8ef1e6b342db330d3885545fc802">DMA_TTYPE_ENDIAN</a> = 31 +<br /> + }</td></tr> +<tr class="separator:a33187c5a074d62b46d2262e352edb8d9"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>Direct Memory Access Controller (DMA) HW driver header file. </p> +<dl class="section note"><dt>Note</dt><dd>These functions should only be used if the DMA controller was synthesized (IO_DMA_EN = true).</dd></dl> +<dl class="section see"><dt>See also</dt><dd><a href="https://stnolting.github.io/neorv32/sw/files.html">https://stnolting.github.io/neorv32/sw/files.html</a> </dd></dl> +</div><h2 class="groupheader">Macro Definition Documentation</h2> +<a id="a5e01d4454c97eb8e4ecd1455090bbfa9" name="a5e01d4454c97eb8e4ecd1455090bbfa9"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a5e01d4454c97eb8e4ecd1455090bbfa9">&#9670;&#160;</a></span>DMA_CMD_B2B</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define DMA_CMD_B2B&#160;&#160;&#160;(0b00 &lt;&lt; <a class="el" href="#a33187c5a074d62b46d2262e352edb8d9afcfdedeca4c4a1def4905660811e31e2">DMA_TTYPE_QSEL_LSB</a>)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>DMA transfer type commands </p> + +</div> +</div> +<a id="adfecb3debff251070e4f6eb809412129" name="adfecb3debff251070e4f6eb809412129"></a> +<h2 class="memtitle"><span class="permalink"><a href="#adfecb3debff251070e4f6eb809412129">&#9670;&#160;</a></span>DMA_CMD_B2SW</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define DMA_CMD_B2SW&#160;&#160;&#160;(0b10 &lt;&lt; <a class="el" href="#a33187c5a074d62b46d2262e352edb8d9afcfdedeca4c4a1def4905660811e31e2">DMA_TTYPE_QSEL_LSB</a>)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>DMA transfer type commands </p> + +</div> +</div> +<a id="aeb63f99217f14d1ddde35c1f6c104e72" name="aeb63f99217f14d1ddde35c1f6c104e72"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aeb63f99217f14d1ddde35c1f6c104e72">&#9670;&#160;</a></span>DMA_CMD_B2UW</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define DMA_CMD_B2UW&#160;&#160;&#160;(0b01 &lt;&lt; <a class="el" href="#a33187c5a074d62b46d2262e352edb8d9afcfdedeca4c4a1def4905660811e31e2">DMA_TTYPE_QSEL_LSB</a>)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>DMA transfer type commands </p> + +</div> +</div> +<a id="a6a0ce532aad39e6489e9d52bcb6f4cd2" name="a6a0ce532aad39e6489e9d52bcb6f4cd2"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a6a0ce532aad39e6489e9d52bcb6f4cd2">&#9670;&#160;</a></span>DMA_CMD_DST_CONST</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define DMA_CMD_DST_CONST&#160;&#160;&#160;(0b0 &lt;&lt; <a class="el" href="#a33187c5a074d62b46d2262e352edb8d9abb1293915b076e5d37be6724b44ab0da">DMA_TTYPE_DST_INC</a>)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>DMA transfer type commands </p> + +</div> +</div> +<a id="a61caa2602c6b148af55d990e3c0ae6be" name="a61caa2602c6b148af55d990e3c0ae6be"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a61caa2602c6b148af55d990e3c0ae6be">&#9670;&#160;</a></span>DMA_CMD_DST_INC</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define DMA_CMD_DST_INC&#160;&#160;&#160;(0b1 &lt;&lt; <a class="el" href="#a33187c5a074d62b46d2262e352edb8d9abb1293915b076e5d37be6724b44ab0da">DMA_TTYPE_DST_INC</a>)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>DMA transfer type commands </p> + +</div> +</div> +<a id="a18fb7faa0a35f562821ca854d7c648b4" name="a18fb7faa0a35f562821ca854d7c648b4"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a18fb7faa0a35f562821ca854d7c648b4">&#9670;&#160;</a></span>DMA_CMD_ENDIAN</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define DMA_CMD_ENDIAN&#160;&#160;&#160;(0b1 &lt;&lt; <a class="el" href="#a33187c5a074d62b46d2262e352edb8d9a37ea8ef1e6b342db330d3885545fc802">DMA_TTYPE_ENDIAN</a>)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>DMA transfer type commands </p> + +</div> +</div> +<a id="ae380022d8b8fb70da91f0892f2bc32c8" name="ae380022d8b8fb70da91f0892f2bc32c8"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ae380022d8b8fb70da91f0892f2bc32c8">&#9670;&#160;</a></span>DMA_CMD_SRC_CONST</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define DMA_CMD_SRC_CONST&#160;&#160;&#160;(0b0 &lt;&lt; <a class="el" href="#a33187c5a074d62b46d2262e352edb8d9a4b99a30b851851f3388dd4e77effacec">DMA_TTYPE_SRC_INC</a>)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>DMA transfer type commands </p> + +</div> +</div> +<a id="acc081d58b53d1eddd2bff35b128d7da2" name="acc081d58b53d1eddd2bff35b128d7da2"></a> +<h2 class="memtitle"><span class="permalink"><a href="#acc081d58b53d1eddd2bff35b128d7da2">&#9670;&#160;</a></span>DMA_CMD_SRC_INC</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define DMA_CMD_SRC_INC&#160;&#160;&#160;(0b1 &lt;&lt; <a class="el" href="#a33187c5a074d62b46d2262e352edb8d9a4b99a30b851851f3388dd4e77effacec">DMA_TTYPE_SRC_INC</a>)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>DMA transfer type commands </p> + +</div> +</div> +<a id="a13a16ba8d6daf9c82312bf4d392d15a8" name="a13a16ba8d6daf9c82312bf4d392d15a8"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a13a16ba8d6daf9c82312bf4d392d15a8">&#9670;&#160;</a></span>DMA_CMD_W2W</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define DMA_CMD_W2W&#160;&#160;&#160;(0b11 &lt;&lt; <a class="el" href="#a33187c5a074d62b46d2262e352edb8d9afcfdedeca4c4a1def4905660811e31e2">DMA_TTYPE_QSEL_LSB</a>)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>DMA transfer type commands </p> + +</div> +</div> +<a id="a0dcb61a0e0d2b45beb7818015adc8639" name="a0dcb61a0e0d2b45beb7818015adc8639"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a0dcb61a0e0d2b45beb7818015adc8639">&#9670;&#160;</a></span>NEORV32_DMA</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define NEORV32_DMA&#160;&#160;&#160;((<a class="el" href="structneorv32__dma__t.html">neorv32_dma_t</a>*) (<a class="el" href="neorv32_8h.html#aa8d3a83ffad1e71f0832a5da78d62008">NEORV32_DMA_BASE</a>))</td> + </tr> + </table> +</div><div class="memdoc"> +<p>DMA module hardware access (<a class="el" href="structneorv32__dma__t.html">neorv32_dma_t</a>) </p> + +</div> +</div> +<h2 class="groupheader">Enumeration Type Documentation</h2> +<a id="a6716eddb145b80ad38799da3b87cb2a4" name="a6716eddb145b80ad38799da3b87cb2a4"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a6716eddb145b80ad38799da3b87cb2a4">&#9670;&#160;</a></span>NEORV32_DMA_CTRL_enum</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">enum <a class="el" href="#a6716eddb145b80ad38799da3b87cb2a4">NEORV32_DMA_CTRL_enum</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>DMA control and status register bits </p> +<table class="fieldtable"> +<tr><th colspan="2">Enumerator</th></tr><tr><td class="fieldname"><a id="a6716eddb145b80ad38799da3b87cb2a4a5f39deea0212f45423243c8100c40838" name="a6716eddb145b80ad38799da3b87cb2a4a5f39deea0212f45423243c8100c40838"></a>DMA_CTRL_EN&#160;</td><td class="fielddoc"><p>DMA control register(0) (r/w): DMA enable </p> +</td></tr> +<tr><td class="fieldname"><a id="a6716eddb145b80ad38799da3b87cb2a4a5aeeb05d6365d94d92808df2490daa3b" name="a6716eddb145b80ad38799da3b87cb2a4a5aeeb05d6365d94d92808df2490daa3b"></a>DMA_CTRL_AUTO&#160;</td><td class="fielddoc"><p>DMA control register(1) (r/w): Automatic trigger mode enable </p> +</td></tr> +<tr><td class="fieldname"><a id="a6716eddb145b80ad38799da3b87cb2a4ace9fdcdfa8784abad30e033c273e7d00" name="a6716eddb145b80ad38799da3b87cb2a4ace9fdcdfa8784abad30e033c273e7d00"></a>DMA_CTRL_FENCE&#160;</td><td class="fielddoc"><p>DMA control register(2) (r/w): Issue FENCE downstream operation when DMA transfer is completed </p> +</td></tr> +<tr><td class="fieldname"><a id="a6716eddb145b80ad38799da3b87cb2a4a539609fc4d80867b3eb98c78206f5f96" name="a6716eddb145b80ad38799da3b87cb2a4a539609fc4d80867b3eb98c78206f5f96"></a>DMA_CTRL_ERROR_RD&#160;</td><td class="fielddoc"><p>DMA control register(8) (r/-): Error during read access; SRC_BASE shows the faulting address </p> +</td></tr> +<tr><td class="fieldname"><a id="a6716eddb145b80ad38799da3b87cb2a4af7e038b0b0e3ac64f5a2c598eb9c5101" name="a6716eddb145b80ad38799da3b87cb2a4af7e038b0b0e3ac64f5a2c598eb9c5101"></a>DMA_CTRL_ERROR_WR&#160;</td><td class="fielddoc"><p>DMA control register(9) (r/-): Error during write access; DST_BASE shows the faulting address </p> +</td></tr> +<tr><td class="fieldname"><a id="a6716eddb145b80ad38799da3b87cb2a4a8e5ff34ac48eea4b352378bb2af47bcb" name="a6716eddb145b80ad38799da3b87cb2a4a8e5ff34ac48eea4b352378bb2af47bcb"></a>DMA_CTRL_BUSY&#160;</td><td class="fielddoc"><p>DMA control register(10) (r/-): DMA busy / transfer in progress </p> +</td></tr> +<tr><td class="fieldname"><a id="a6716eddb145b80ad38799da3b87cb2a4a0d51df1bb87dc54d331891c5db787bcc" name="a6716eddb145b80ad38799da3b87cb2a4a0d51df1bb87dc54d331891c5db787bcc"></a>DMA_CTRL_DONE&#160;</td><td class="fielddoc"><p>DMA control register(11) (r/c): A transfer was executed when set </p> +</td></tr> +<tr><td class="fieldname"><a id="a6716eddb145b80ad38799da3b87cb2a4aeaf5ee8f6a84668aa15cd3e21f076afe" name="a6716eddb145b80ad38799da3b87cb2a4aeaf5ee8f6a84668aa15cd3e21f076afe"></a>DMA_CTRL_FIRQ_TYPE&#160;</td><td class="fielddoc"><p>DMA control register(15) (r/w): Trigger on FIRQ rising-edge (0) or high-level (1) </p> +</td></tr> +<tr><td class="fieldname"><a id="a6716eddb145b80ad38799da3b87cb2a4aaf040e663494b39b890d7171d0a584b9" name="a6716eddb145b80ad38799da3b87cb2a4aaf040e663494b39b890d7171d0a584b9"></a>DMA_CTRL_FIRQ_SEL_LSB&#160;</td><td class="fielddoc"><p>DMA control register(16) (r/w): FIRQ trigger select LSB </p> +</td></tr> +<tr><td class="fieldname"><a id="a6716eddb145b80ad38799da3b87cb2a4a3eba1f7868f0c985effb69785ced011a" name="a6716eddb145b80ad38799da3b87cb2a4a3eba1f7868f0c985effb69785ced011a"></a>DMA_CTRL_FIRQ_SEL_MSB&#160;</td><td class="fielddoc"><p>DMA control register(19) (r/w): FIRQ trigger select MSB </p> +</td></tr> +</table> + +</div> +</div> +<a id="a002cb188ea5156df0ba282e239a6e74b" name="a002cb188ea5156df0ba282e239a6e74b"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a002cb188ea5156df0ba282e239a6e74b">&#9670;&#160;</a></span>NEORV32_DMA_STATUS_enum</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">enum <a class="el" href="#a002cb188ea5156df0ba282e239a6e74b">NEORV32_DMA_STATUS_enum</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>DMA status </p> +<table class="fieldtable"> +<tr><th colspan="2">Enumerator</th></tr><tr><td class="fieldname"><a id="a002cb188ea5156df0ba282e239a6e74ba038b6ef194c3db158cb59168f763a7b8" name="a002cb188ea5156df0ba282e239a6e74ba038b6ef194c3db158cb59168f763a7b8"></a>DMA_STATUS_ERR_WR&#160;</td><td class="fielddoc"><p>write access error during last transfer (-2) </p> +</td></tr> +<tr><td class="fieldname"><a id="a002cb188ea5156df0ba282e239a6e74baed7242b847e3cc8cf20d7da99f9b1492" name="a002cb188ea5156df0ba282e239a6e74baed7242b847e3cc8cf20d7da99f9b1492"></a>DMA_STATUS_ERR_RD&#160;</td><td class="fielddoc"><p>read access error during last transfer (-1) </p> +</td></tr> +<tr><td class="fieldname"><a id="a002cb188ea5156df0ba282e239a6e74bac9c380cd5729386e5f5673e20b86326f" name="a002cb188ea5156df0ba282e239a6e74bac9c380cd5729386e5f5673e20b86326f"></a>DMA_STATUS_IDLE&#160;</td><td class="fielddoc"><p>DMA idle (0) </p> +</td></tr> +<tr><td class="fieldname"><a id="a002cb188ea5156df0ba282e239a6e74bad0f66e962296f5451d73dc1cae1fdc0d" name="a002cb188ea5156df0ba282e239a6e74bad0f66e962296f5451d73dc1cae1fdc0d"></a>DMA_STATUS_BUSY&#160;</td><td class="fielddoc"><p>DMA busy (1) </p> +</td></tr> +</table> + +</div> +</div> +<a id="a33187c5a074d62b46d2262e352edb8d9" name="a33187c5a074d62b46d2262e352edb8d9"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a33187c5a074d62b46d2262e352edb8d9">&#9670;&#160;</a></span>NEORV32_DMA_TTYPE_enum</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">enum <a class="el" href="#a33187c5a074d62b46d2262e352edb8d9">NEORV32_DMA_TTYPE_enum</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>DMA transfer type bits </p> +<table class="fieldtable"> +<tr><th colspan="2">Enumerator</th></tr><tr><td class="fieldname"><a id="a33187c5a074d62b46d2262e352edb8d9a8dba4160c033c763f5102928c471e450" name="a33187c5a074d62b46d2262e352edb8d9a8dba4160c033c763f5102928c471e450"></a>DMA_TTYPE_NUM_LSB&#160;</td><td class="fielddoc"><p>DMA transfer type register(0) (r/w): Number of elements to transfer, LSB </p> +</td></tr> +<tr><td class="fieldname"><a id="a33187c5a074d62b46d2262e352edb8d9a61553eee00ed2382565bf826074c44bd" name="a33187c5a074d62b46d2262e352edb8d9a61553eee00ed2382565bf826074c44bd"></a>DMA_TTYPE_NUM_MSB&#160;</td><td class="fielddoc"><p>DMA transfer type register(23) (r/w): Number of elements to transfer, MSB </p> +</td></tr> +<tr><td class="fieldname"><a id="a33187c5a074d62b46d2262e352edb8d9afcfdedeca4c4a1def4905660811e31e2" name="a33187c5a074d62b46d2262e352edb8d9afcfdedeca4c4a1def4905660811e31e2"></a>DMA_TTYPE_QSEL_LSB&#160;</td><td class="fielddoc"><p>DMA transfer type register(27) (r/w): Data quantity select, LSB </p> +</td></tr> +<tr><td class="fieldname"><a id="a33187c5a074d62b46d2262e352edb8d9a4217c9a8ac4ccc52bb45944f30a598c5" name="a33187c5a074d62b46d2262e352edb8d9a4217c9a8ac4ccc52bb45944f30a598c5"></a>DMA_TTYPE_QSEL_MSB&#160;</td><td class="fielddoc"><p>DMA transfer type register(28) (r/w): Data quantity select, MSB </p> +</td></tr> +<tr><td class="fieldname"><a id="a33187c5a074d62b46d2262e352edb8d9a4b99a30b851851f3388dd4e77effacec" name="a33187c5a074d62b46d2262e352edb8d9a4b99a30b851851f3388dd4e77effacec"></a>DMA_TTYPE_SRC_INC&#160;</td><td class="fielddoc"><p>DMA transfer type register(29) (r/w): SRC constant (0) or incrementing (1) address </p> +</td></tr> +<tr><td class="fieldname"><a id="a33187c5a074d62b46d2262e352edb8d9abb1293915b076e5d37be6724b44ab0da" name="a33187c5a074d62b46d2262e352edb8d9abb1293915b076e5d37be6724b44ab0da"></a>DMA_TTYPE_DST_INC&#160;</td><td class="fielddoc"><p>DMA transfer type register(30) (r/w): SRC constant (0) or incrementing (1) address </p> +</td></tr> +<tr><td class="fieldname"><a id="a33187c5a074d62b46d2262e352edb8d9a37ea8ef1e6b342db330d3885545fc802" name="a33187c5a074d62b46d2262e352edb8d9a37ea8ef1e6b342db330d3885545fc802"></a>DMA_TTYPE_ENDIAN&#160;</td><td class="fielddoc"><p>DMA transfer type register(31) (r/w): Convert Endianness when set </p> +</td></tr> +</table> + +</div> +</div> +<h2 class="groupheader">Function Documentation</h2> +<a id="a13260c3252f0375d8982590d270d7dfd" name="a13260c3252f0375d8982590d270d7dfd"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a13260c3252f0375d8982590d270d7dfd">&#9670;&#160;</a></span>neorv32_dma_available()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_dma_available </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Check if DMA controller was synthesized.</p> +<dl class="section return"><dt>Returns</dt><dd>0 if DMA was not synthesized, 1 if DMA is available. </dd></dl> + +</div> +</div> +<a id="a6df244028455cf7f8d4cf1520c4670a7" name="a6df244028455cf7f8d4cf1520c4670a7"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a6df244028455cf7f8d4cf1520c4670a7">&#9670;&#160;</a></span>neorv32_dma_disable()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_dma_disable </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Disable DMA. This will reset the DMA and will also terminate the current transfer. </p> + +</div> +</div> +<a id="afc8cc32f7d80d0f5ab33b2f1ecf77956" name="afc8cc32f7d80d0f5ab33b2f1ecf77956"></a> +<h2 class="memtitle"><span class="permalink"><a href="#afc8cc32f7d80d0f5ab33b2f1ecf77956">&#9670;&#160;</a></span>neorv32_dma_done()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_dma_done </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Check if a transfer has actually been executed.</p> +<dl class="section return"><dt>Returns</dt><dd>0 if no transfer was executed, 1 if a transfer has actually been executed. Use neorv32_dma_status(void) to check if there was an error during that transfer. </dd></dl> + +</div> +</div> +<a id="ac3b72447e8a132faf26577ac714b8284" name="ac3b72447e8a132faf26577ac714b8284"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ac3b72447e8a132faf26577ac714b8284">&#9670;&#160;</a></span>neorv32_dma_enable()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_dma_enable </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Enable DMA. </p> + +</div> +</div> +<a id="a8f37adfa07050b0a1cb8430c9ce1fcc2" name="a8f37adfa07050b0a1cb8430c9ce1fcc2"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a8f37adfa07050b0a1cb8430c9ce1fcc2">&#9670;&#160;</a></span>neorv32_dma_fence_disable()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_dma_fence_disable </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Disable memory barrier (fence). </p> + +</div> +</div> +<a id="a2c7257567ccdb7a986f5ef7c74d3917c" name="a2c7257567ccdb7a986f5ef7c74d3917c"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a2c7257567ccdb7a986f5ef7c74d3917c">&#9670;&#160;</a></span>neorv32_dma_fence_enable()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_dma_fence_enable </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Enable memory barrier (fence): issue a FENCE operation when DMA transfer completes without errors. </p> + +</div> +</div> +<a id="aa116f9714174abbe8a3583e441fee24b" name="aa116f9714174abbe8a3583e441fee24b"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aa116f9714174abbe8a3583e441fee24b">&#9670;&#160;</a></span>neorv32_dma_status()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_dma_status </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Get DMA status.</p> +<dl class="section return"><dt>Returns</dt><dd>Current DMA status (<a class="el" href="#a002cb188ea5156df0ba282e239a6e74b">NEORV32_DMA_STATUS_enum</a>) </dd></dl> + +</div> +</div> +<a id="a2ce0d31e04604b2523135d52a877febf" name="a2ce0d31e04604b2523135d52a877febf"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a2ce0d31e04604b2523135d52a877febf">&#9670;&#160;</a></span>neorv32_dma_transfer()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_dma_transfer </td> + <td>(</td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>base_src</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>base_dst</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>num</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>config</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Trigger manual DMA transfer.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">base_src</td><td>Source base address (has to be aligned to source data type!). </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">base_dst</td><td>Destination base address (has to be aligned to destination data type!). </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">num</td><td>Number of elements to transfer (24-bit). </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">config</td><td>Transfer type configuration/commands. </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="a6ebd1595ee6fa0e6cbfbd1ce7476f18e" name="a6ebd1595ee6fa0e6cbfbd1ce7476f18e"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a6ebd1595ee6fa0e6cbfbd1ce7476f18e">&#9670;&#160;</a></span>neorv32_dma_transfer_auto()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_dma_transfer_auto </td> + <td>(</td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>base_src</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>base_dst</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>num</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>config</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>firq_sel</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>firq_type</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Configure automatic DMA transfer (triggered by CPU FIRQ).</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">base_src</td><td>Source base address (has to be aligned to source data type!). </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">base_dst</td><td>Destination base address (has to be aligned to destination data type!). </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">num</td><td>Number of elements to transfer (24-bit). </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">config</td><td>Transfer type configuration/commands. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">firq_sel</td><td>FIRQ trigger select (<a class="el" href="neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21b">NEORV32_CSR_MIP_enum</a>); only FIRQ0..FIRQ15 = 16..31. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">firq_type</td><td>Trigger on rising-edge (0) or high-level (1) of FIRQ channel. </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/neorv32__dma_8h_source.html b/sw/neorv32__dma_8h_source.html new file mode 100644 index 0000000000..eed46c6278 --- /dev/null +++ b/sw/neorv32__dma_8h_source.html @@ -0,0 +1,228 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/lib/include/neorv32_dma.h Source File</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_7d04193005ada6f9450f847f4adb6b5b.html">lib</a></li><li class="navelem"><a class="el" href="dir_752b1e5d3973bf735fa78bf6b4727df9.html">include</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="headertitle"><div class="title">neorv32_dma.h</div></div> +</div><!--header--> +<div class="contents"> +<a href="neorv32__dma_8h.html">Go to the documentation of this file.</a><div class="fragment"><div class="line"><a id="l00001" name="l00001"></a><span class="lineno"> 1</span><span class="comment">// ================================================================================ //</span></div> +<div class="line"><a id="l00002" name="l00002"></a><span class="lineno"> 2</span><span class="comment">// The NEORV32 RISC-V Processor - https://github.com/stnolting/neorv32 //</span></div> +<div class="line"><a id="l00003" name="l00003"></a><span class="lineno"> 3</span><span class="comment">// Copyright (c) NEORV32 contributors. //</span></div> +<div class="line"><a id="l00004" name="l00004"></a><span class="lineno"> 4</span><span class="comment">// Copyright (c) 2020 - 2024 Stephan Nolting. All rights reserved. //</span></div> +<div class="line"><a id="l00005" name="l00005"></a><span class="lineno"> 5</span><span class="comment">// Licensed under the BSD-3-Clause license, see LICENSE for details. //</span></div> +<div class="line"><a id="l00006" name="l00006"></a><span class="lineno"> 6</span><span class="comment">// SPDX-License-Identifier: BSD-3-Clause //</span></div> +<div class="line"><a id="l00007" name="l00007"></a><span class="lineno"> 7</span><span class="comment">// ================================================================================ //</span></div> +<div class="line"><a id="l00008" name="l00008"></a><span class="lineno"> 8</span> </div> +<div class="line"><a id="l00018" name="l00018"></a><span class="lineno"> 18</span><span class="preprocessor">#ifndef neorv32_dma_h</span></div> +<div class="line"><a id="l00019" name="l00019"></a><span class="lineno"> 19</span><span class="preprocessor">#define neorv32_dma_h</span></div> +<div class="line"><a id="l00020" name="l00020"></a><span class="lineno"> 20</span> </div> +<div class="line"><a id="l00021" name="l00021"></a><span class="lineno"> 21</span><span class="preprocessor">#include &lt;stdint.h&gt;</span></div> +<div class="line"><a id="l00022" name="l00022"></a><span class="lineno"> 22</span> </div> +<div class="line"><a id="l00023" name="l00023"></a><span class="lineno"> 23</span> </div> +<div class="line"><a id="l00024" name="l00024"></a><span class="lineno"> 24</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen00029" data-start="{" data-end="};"> +<div class="line"><a id="l00029" name="l00029"></a><span class="lineno"><a class="line" href="structneorv32__dma__t.html"> 29</a></span><span class="keyword">typedef</span> <span class="keyword">volatile</span> <span class="keyword">struct </span>__attribute__((packed,aligned(4))) {</div> +<div class="line"><a id="l00030" name="l00030"></a><span class="lineno"><a class="line" href="structneorv32__dma__t.html#a8480d6ad3ba5063cdf21dca286711569"> 30</a></span> uint32_t <a class="code hl_variable" href="structneorv32__dma__t.html#a8480d6ad3ba5063cdf21dca286711569">CTRL</a>; </div> +<div class="line"><a id="l00031" name="l00031"></a><span class="lineno"><a class="line" href="structneorv32__dma__t.html#a3b214d1a373c7f15b374e113d7110b42"> 31</a></span> uint32_t <a class="code hl_variable" href="structneorv32__dma__t.html#a3b214d1a373c7f15b374e113d7110b42">SRC_BASE</a>; </div> +<div class="line"><a id="l00032" name="l00032"></a><span class="lineno"><a class="line" href="structneorv32__dma__t.html#aee8a6cf3cbd9fe3c5995f046ffb9a1c0"> 32</a></span> uint32_t <a class="code hl_variable" href="structneorv32__dma__t.html#aee8a6cf3cbd9fe3c5995f046ffb9a1c0">DST_BASE</a>; </div> +<div class="line"><a id="l00033" name="l00033"></a><span class="lineno"><a class="line" href="structneorv32__dma__t.html#a70c28642195765409d97b941e98f47ca"> 33</a></span> uint32_t <a class="code hl_variable" href="structneorv32__dma__t.html#a70c28642195765409d97b941e98f47ca">TTYPE</a>; </div> +<div class="line"><a id="l00034" name="l00034"></a><span class="lineno"> 34</span>} <a class="code hl_struct" href="structneorv32__dma__t.html">neorv32_dma_t</a>;</div> +</div> +<div class="line"><a id="l00035" name="l00035"></a><span class="lineno"> 35</span> </div> +<div class="line"><a id="l00037" name="l00037"></a><span class="lineno"><a class="line" href="neorv32__dma_8h.html#a0dcb61a0e0d2b45beb7818015adc8639"> 37</a></span><span class="preprocessor">#define NEORV32_DMA ((neorv32_dma_t*) (NEORV32_DMA_BASE))</span></div> +<div class="line"><a id="l00038" name="l00038"></a><span class="lineno"> 38</span> </div> +<div class="foldopen" id="foldopen00040" data-start="{" data-end="};"> +<div class="line"><a id="l00040" name="l00040"></a><span class="lineno"><a class="line" href="neorv32__dma_8h.html#a6716eddb145b80ad38799da3b87cb2a4"> 40</a></span><span class="keyword">enum</span> <a class="code hl_enumeration" href="neorv32__dma_8h.html#a6716eddb145b80ad38799da3b87cb2a4">NEORV32_DMA_CTRL_enum</a> {</div> +<div class="line"><a id="l00041" name="l00041"></a><span class="lineno"><a class="line" href="neorv32__dma_8h.html#a6716eddb145b80ad38799da3b87cb2a4a5f39deea0212f45423243c8100c40838"> 41</a></span> <a class="code hl_enumvalue" href="neorv32__dma_8h.html#a6716eddb145b80ad38799da3b87cb2a4a5f39deea0212f45423243c8100c40838">DMA_CTRL_EN</a> = 0, </div> +<div class="line"><a id="l00042" name="l00042"></a><span class="lineno"><a class="line" href="neorv32__dma_8h.html#a6716eddb145b80ad38799da3b87cb2a4a5aeeb05d6365d94d92808df2490daa3b"> 42</a></span> <a class="code hl_enumvalue" href="neorv32__dma_8h.html#a6716eddb145b80ad38799da3b87cb2a4a5aeeb05d6365d94d92808df2490daa3b">DMA_CTRL_AUTO</a> = 1, </div> +<div class="line"><a id="l00043" name="l00043"></a><span class="lineno"><a class="line" href="neorv32__dma_8h.html#a6716eddb145b80ad38799da3b87cb2a4ace9fdcdfa8784abad30e033c273e7d00"> 43</a></span> <a class="code hl_enumvalue" href="neorv32__dma_8h.html#a6716eddb145b80ad38799da3b87cb2a4ace9fdcdfa8784abad30e033c273e7d00">DMA_CTRL_FENCE</a> = 2, </div> +<div class="line"><a id="l00045" name="l00045"></a><span class="lineno"><a class="line" href="neorv32__dma_8h.html#a6716eddb145b80ad38799da3b87cb2a4a539609fc4d80867b3eb98c78206f5f96"> 45</a></span> <a class="code hl_enumvalue" href="neorv32__dma_8h.html#a6716eddb145b80ad38799da3b87cb2a4a539609fc4d80867b3eb98c78206f5f96">DMA_CTRL_ERROR_RD</a> = 8, </div> +<div class="line"><a id="l00046" name="l00046"></a><span class="lineno"><a class="line" href="neorv32__dma_8h.html#a6716eddb145b80ad38799da3b87cb2a4af7e038b0b0e3ac64f5a2c598eb9c5101"> 46</a></span> <a class="code hl_enumvalue" href="neorv32__dma_8h.html#a6716eddb145b80ad38799da3b87cb2a4af7e038b0b0e3ac64f5a2c598eb9c5101">DMA_CTRL_ERROR_WR</a> = 9, </div> +<div class="line"><a id="l00047" name="l00047"></a><span class="lineno"><a class="line" href="neorv32__dma_8h.html#a6716eddb145b80ad38799da3b87cb2a4a8e5ff34ac48eea4b352378bb2af47bcb"> 47</a></span> <a class="code hl_enumvalue" href="neorv32__dma_8h.html#a6716eddb145b80ad38799da3b87cb2a4a8e5ff34ac48eea4b352378bb2af47bcb">DMA_CTRL_BUSY</a> = 10, </div> +<div class="line"><a id="l00048" name="l00048"></a><span class="lineno"><a class="line" href="neorv32__dma_8h.html#a6716eddb145b80ad38799da3b87cb2a4a0d51df1bb87dc54d331891c5db787bcc"> 48</a></span> <a class="code hl_enumvalue" href="neorv32__dma_8h.html#a6716eddb145b80ad38799da3b87cb2a4a0d51df1bb87dc54d331891c5db787bcc">DMA_CTRL_DONE</a> = 11, </div> +<div class="line"><a id="l00050" name="l00050"></a><span class="lineno"><a class="line" href="neorv32__dma_8h.html#a6716eddb145b80ad38799da3b87cb2a4aeaf5ee8f6a84668aa15cd3e21f076afe"> 50</a></span> <a class="code hl_enumvalue" href="neorv32__dma_8h.html#a6716eddb145b80ad38799da3b87cb2a4aeaf5ee8f6a84668aa15cd3e21f076afe">DMA_CTRL_FIRQ_TYPE</a> = 15, </div> +<div class="line"><a id="l00051" name="l00051"></a><span class="lineno"><a class="line" href="neorv32__dma_8h.html#a6716eddb145b80ad38799da3b87cb2a4aaf040e663494b39b890d7171d0a584b9"> 51</a></span> <a class="code hl_enumvalue" href="neorv32__dma_8h.html#a6716eddb145b80ad38799da3b87cb2a4aaf040e663494b39b890d7171d0a584b9">DMA_CTRL_FIRQ_SEL_LSB</a> = 16, </div> +<div class="line"><a id="l00052" name="l00052"></a><span class="lineno"> 52</span> <a class="code hl_enumvalue" href="neorv32__dma_8h.html#a6716eddb145b80ad38799da3b87cb2a4a3eba1f7868f0c985effb69785ced011a">DMA_CTRL_FIRQ_SEL_MSB</a> = 19 </div> +<div class="line"><a id="l00053" name="l00053"></a><span class="lineno"><a class="line" href="neorv32__dma_8h.html#a6716eddb145b80ad38799da3b87cb2a4a3eba1f7868f0c985effb69785ced011a"> 53</a></span>};</div> +</div> +<div class="line"><a id="l00054" name="l00054"></a><span class="lineno"> 54</span> </div> +<div class="foldopen" id="foldopen00056" data-start="{" data-end="};"> +<div class="line"><a id="l00056" name="l00056"></a><span class="lineno"><a class="line" href="neorv32__dma_8h.html#a33187c5a074d62b46d2262e352edb8d9"> 56</a></span><span class="keyword">enum</span> <a class="code hl_enumeration" href="neorv32__dma_8h.html#a33187c5a074d62b46d2262e352edb8d9">NEORV32_DMA_TTYPE_enum</a> {</div> +<div class="line"><a id="l00057" name="l00057"></a><span class="lineno"><a class="line" href="neorv32__dma_8h.html#a33187c5a074d62b46d2262e352edb8d9a8dba4160c033c763f5102928c471e450"> 57</a></span> <a class="code hl_enumvalue" href="neorv32__dma_8h.html#a33187c5a074d62b46d2262e352edb8d9a8dba4160c033c763f5102928c471e450">DMA_TTYPE_NUM_LSB</a> = 0, </div> +<div class="line"><a id="l00058" name="l00058"></a><span class="lineno"><a class="line" href="neorv32__dma_8h.html#a33187c5a074d62b46d2262e352edb8d9a61553eee00ed2382565bf826074c44bd"> 58</a></span> <a class="code hl_enumvalue" href="neorv32__dma_8h.html#a33187c5a074d62b46d2262e352edb8d9a61553eee00ed2382565bf826074c44bd">DMA_TTYPE_NUM_MSB</a> = 23, </div> +<div class="line"><a id="l00060" name="l00060"></a><span class="lineno"><a class="line" href="neorv32__dma_8h.html#a33187c5a074d62b46d2262e352edb8d9afcfdedeca4c4a1def4905660811e31e2"> 60</a></span> <a class="code hl_enumvalue" href="neorv32__dma_8h.html#a33187c5a074d62b46d2262e352edb8d9afcfdedeca4c4a1def4905660811e31e2">DMA_TTYPE_QSEL_LSB</a> = 27, </div> +<div class="line"><a id="l00061" name="l00061"></a><span class="lineno"><a class="line" href="neorv32__dma_8h.html#a33187c5a074d62b46d2262e352edb8d9a4217c9a8ac4ccc52bb45944f30a598c5"> 61</a></span> <a class="code hl_enumvalue" href="neorv32__dma_8h.html#a33187c5a074d62b46d2262e352edb8d9a4217c9a8ac4ccc52bb45944f30a598c5">DMA_TTYPE_QSEL_MSB</a> = 28, </div> +<div class="line"><a id="l00062" name="l00062"></a><span class="lineno"><a class="line" href="neorv32__dma_8h.html#a33187c5a074d62b46d2262e352edb8d9a4b99a30b851851f3388dd4e77effacec"> 62</a></span> <a class="code hl_enumvalue" href="neorv32__dma_8h.html#a33187c5a074d62b46d2262e352edb8d9a4b99a30b851851f3388dd4e77effacec">DMA_TTYPE_SRC_INC</a> = 29, </div> +<div class="line"><a id="l00063" name="l00063"></a><span class="lineno"><a class="line" href="neorv32__dma_8h.html#a33187c5a074d62b46d2262e352edb8d9abb1293915b076e5d37be6724b44ab0da"> 63</a></span> <a class="code hl_enumvalue" href="neorv32__dma_8h.html#a33187c5a074d62b46d2262e352edb8d9abb1293915b076e5d37be6724b44ab0da">DMA_TTYPE_DST_INC</a> = 30, </div> +<div class="line"><a id="l00064" name="l00064"></a><span class="lineno"> 64</span> <a class="code hl_enumvalue" href="neorv32__dma_8h.html#a33187c5a074d62b46d2262e352edb8d9a37ea8ef1e6b342db330d3885545fc802">DMA_TTYPE_ENDIAN</a> = 31 </div> +<div class="line"><a id="l00065" name="l00065"></a><span class="lineno"><a class="line" href="neorv32__dma_8h.html#a33187c5a074d62b46d2262e352edb8d9a37ea8ef1e6b342db330d3885545fc802"> 65</a></span>};</div> +</div> +<div class="line"><a id="l00069" name="l00069"></a><span class="lineno"> 69</span><span class="comment">/**********************************************************************/</span></div> +<div class="line"><a id="l00073" name="l00073"></a><span class="lineno"><a class="line" href="neorv32__dma_8h.html#a5e01d4454c97eb8e4ecd1455090bbfa9"> 73</a></span><span class="preprocessor">#define DMA_CMD_B2B (0b00 &lt;&lt; DMA_TTYPE_QSEL_LSB) </span><span class="comment">// byte to byte</span></div> +<div class="line"><a id="l00074" name="l00074"></a><span class="lineno"><a class="line" href="neorv32__dma_8h.html#aeb63f99217f14d1ddde35c1f6c104e72"> 74</a></span><span class="preprocessor">#define DMA_CMD_B2UW (0b01 &lt;&lt; DMA_TTYPE_QSEL_LSB) </span><span class="comment">// byte to unsigned word</span></div> +<div class="line"><a id="l00075" name="l00075"></a><span class="lineno"><a class="line" href="neorv32__dma_8h.html#adfecb3debff251070e4f6eb809412129"> 75</a></span><span class="preprocessor">#define DMA_CMD_B2SW (0b10 &lt;&lt; DMA_TTYPE_QSEL_LSB) </span><span class="comment">// byte to signed word</span></div> +<div class="line"><a id="l00076" name="l00076"></a><span class="lineno"><a class="line" href="neorv32__dma_8h.html#a13a16ba8d6daf9c82312bf4d392d15a8"> 76</a></span><span class="preprocessor">#define DMA_CMD_W2W (0b11 &lt;&lt; DMA_TTYPE_QSEL_LSB) </span><span class="comment">// word to word</span></div> +<div class="line"><a id="l00077" name="l00077"></a><span class="lineno"> 77</span> </div> +<div class="line"><a id="l00078" name="l00078"></a><span class="lineno"><a class="line" href="neorv32__dma_8h.html#ae380022d8b8fb70da91f0892f2bc32c8"> 78</a></span><span class="preprocessor">#define DMA_CMD_SRC_CONST (0b0 &lt;&lt; DMA_TTYPE_SRC_INC) </span><span class="comment">// constant source address</span></div> +<div class="line"><a id="l00079" name="l00079"></a><span class="lineno"><a class="line" href="neorv32__dma_8h.html#acc081d58b53d1eddd2bff35b128d7da2"> 79</a></span><span class="preprocessor">#define DMA_CMD_SRC_INC (0b1 &lt;&lt; DMA_TTYPE_SRC_INC) </span><span class="comment">// incrementing source address</span></div> +<div class="line"><a id="l00080" name="l00080"></a><span class="lineno"> 80</span> </div> +<div class="line"><a id="l00081" name="l00081"></a><span class="lineno"><a class="line" href="neorv32__dma_8h.html#a6a0ce532aad39e6489e9d52bcb6f4cd2"> 81</a></span><span class="preprocessor">#define DMA_CMD_DST_CONST (0b0 &lt;&lt; DMA_TTYPE_DST_INC) </span><span class="comment">// constant destination address</span></div> +<div class="line"><a id="l00082" name="l00082"></a><span class="lineno"><a class="line" href="neorv32__dma_8h.html#a61caa2602c6b148af55d990e3c0ae6be"> 82</a></span><span class="preprocessor">#define DMA_CMD_DST_INC (0b1 &lt;&lt; DMA_TTYPE_DST_INC) </span><span class="comment">// incrementing destination address</span></div> +<div class="line"><a id="l00083" name="l00083"></a><span class="lineno"> 83</span> </div> +<div class="line"><a id="l00084" name="l00084"></a><span class="lineno"><a class="line" href="neorv32__dma_8h.html#a18fb7faa0a35f562821ca854d7c648b4"> 84</a></span><span class="preprocessor">#define DMA_CMD_ENDIAN (0b1 &lt;&lt; DMA_TTYPE_ENDIAN) </span><span class="comment">// convert endianness</span></div> +<div class="line"><a id="l00088" name="l00088"></a><span class="lineno"> 88</span><span class="comment">/**********************************************************************/</span><span class="preprocessor"></span></div> +<div class="foldopen" id="foldopen00091" data-start="{" data-end="};"> +<div class="line"><a id="l00091" name="l00091"></a><span class="lineno"><a class="line" href="neorv32__dma_8h.html#a002cb188ea5156df0ba282e239a6e74b"> 91</a></span><span class="keyword">enum</span> <a class="code hl_enumeration" href="neorv32__dma_8h.html#a002cb188ea5156df0ba282e239a6e74b">NEORV32_DMA_STATUS_enum</a> {</div> +<div class="line"><a id="l00092" name="l00092"></a><span class="lineno"><a class="line" href="neorv32__dma_8h.html#a002cb188ea5156df0ba282e239a6e74ba038b6ef194c3db158cb59168f763a7b8"> 92</a></span> <a class="code hl_enumvalue" href="neorv32__dma_8h.html#a002cb188ea5156df0ba282e239a6e74ba038b6ef194c3db158cb59168f763a7b8">DMA_STATUS_ERR_WR</a> = -2, </div> +<div class="line"><a id="l00093" name="l00093"></a><span class="lineno"><a class="line" href="neorv32__dma_8h.html#a002cb188ea5156df0ba282e239a6e74baed7242b847e3cc8cf20d7da99f9b1492"> 93</a></span> <a class="code hl_enumvalue" href="neorv32__dma_8h.html#a002cb188ea5156df0ba282e239a6e74baed7242b847e3cc8cf20d7da99f9b1492">DMA_STATUS_ERR_RD</a> = -1, </div> +<div class="line"><a id="l00094" name="l00094"></a><span class="lineno"><a class="line" href="neorv32__dma_8h.html#a002cb188ea5156df0ba282e239a6e74bac9c380cd5729386e5f5673e20b86326f"> 94</a></span> <a class="code hl_enumvalue" href="neorv32__dma_8h.html#a002cb188ea5156df0ba282e239a6e74bac9c380cd5729386e5f5673e20b86326f">DMA_STATUS_IDLE</a> = 0, </div> +<div class="line"><a id="l00095" name="l00095"></a><span class="lineno"> 95</span> <a class="code hl_enumvalue" href="neorv32__dma_8h.html#a002cb188ea5156df0ba282e239a6e74bad0f66e962296f5451d73dc1cae1fdc0d">DMA_STATUS_BUSY</a> = 1 </div> +<div class="line"><a id="l00096" name="l00096"></a><span class="lineno"><a class="line" href="neorv32__dma_8h.html#a002cb188ea5156df0ba282e239a6e74bad0f66e962296f5451d73dc1cae1fdc0d"> 96</a></span>};</div> +</div> +<div class="line"><a id="l00097" name="l00097"></a><span class="lineno"> 97</span> </div> +<div class="line"><a id="l00098" name="l00098"></a><span class="lineno"> 98</span> </div> +<div class="line"><a id="l00099" name="l00099"></a><span class="lineno"> 99</span><span class="comment">/**********************************************************************/</span></div> +<div class="line"><a id="l00103" name="l00103"></a><span class="lineno"> 103</span><span class="keywordtype">int</span> <a class="code hl_function" href="neorv32__dma_8h.html#a13260c3252f0375d8982590d270d7dfd">neorv32_dma_available</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00104" name="l00104"></a><span class="lineno"> 104</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__dma_8h.html#ac3b72447e8a132faf26577ac714b8284">neorv32_dma_enable</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00105" name="l00105"></a><span class="lineno"> 105</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__dma_8h.html#a6df244028455cf7f8d4cf1520c4670a7">neorv32_dma_disable</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00106" name="l00106"></a><span class="lineno"> 106</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__dma_8h.html#a2c7257567ccdb7a986f5ef7c74d3917c">neorv32_dma_fence_enable</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00107" name="l00107"></a><span class="lineno"> 107</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__dma_8h.html#a8f37adfa07050b0a1cb8430c9ce1fcc2">neorv32_dma_fence_disable</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00108" name="l00108"></a><span class="lineno"> 108</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__dma_8h.html#a2ce0d31e04604b2523135d52a877febf">neorv32_dma_transfer</a>(uint32_t base_src, uint32_t base_dst, uint32_t num, uint32_t config);</div> +<div class="line"><a id="l00109" name="l00109"></a><span class="lineno"> 109</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__dma_8h.html#a6ebd1595ee6fa0e6cbfbd1ce7476f18e">neorv32_dma_transfer_auto</a>(uint32_t base_src, uint32_t base_dst, uint32_t num, uint32_t config, <span class="keywordtype">int</span> firq_sel, <span class="keywordtype">int</span> firq_type);</div> +<div class="line"><a id="l00110" name="l00110"></a><span class="lineno"> 110</span><span class="keywordtype">int</span> <a class="code hl_function" href="neorv32__dma_8h.html#aa116f9714174abbe8a3583e441fee24b">neorv32_dma_status</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00111" name="l00111"></a><span class="lineno"> 111</span><span class="keywordtype">int</span> <a class="code hl_function" href="neorv32__dma_8h.html#afc8cc32f7d80d0f5ab33b2f1ecf77956">neorv32_dma_done</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00115" name="l00115"></a><span class="lineno"> 115</span><span class="preprocessor">#endif </span><span class="comment">// neorv32_dma_h</span></div> +<div class="ttc" id="aneorv32__dma_8h_html_a002cb188ea5156df0ba282e239a6e74b"><div class="ttname"><a href="neorv32__dma_8h.html#a002cb188ea5156df0ba282e239a6e74b">NEORV32_DMA_STATUS_enum</a></div><div class="ttdeci">NEORV32_DMA_STATUS_enum</div><div class="ttdef"><b>Definition</b> neorv32_dma.h:91</div></div> +<div class="ttc" id="aneorv32__dma_8h_html_a002cb188ea5156df0ba282e239a6e74ba038b6ef194c3db158cb59168f763a7b8"><div class="ttname"><a href="neorv32__dma_8h.html#a002cb188ea5156df0ba282e239a6e74ba038b6ef194c3db158cb59168f763a7b8">DMA_STATUS_ERR_WR</a></div><div class="ttdeci">@ DMA_STATUS_ERR_WR</div><div class="ttdef"><b>Definition</b> neorv32_dma.h:92</div></div> +<div class="ttc" id="aneorv32__dma_8h_html_a002cb188ea5156df0ba282e239a6e74bac9c380cd5729386e5f5673e20b86326f"><div class="ttname"><a href="neorv32__dma_8h.html#a002cb188ea5156df0ba282e239a6e74bac9c380cd5729386e5f5673e20b86326f">DMA_STATUS_IDLE</a></div><div class="ttdeci">@ DMA_STATUS_IDLE</div><div class="ttdef"><b>Definition</b> neorv32_dma.h:94</div></div> +<div class="ttc" id="aneorv32__dma_8h_html_a002cb188ea5156df0ba282e239a6e74bad0f66e962296f5451d73dc1cae1fdc0d"><div class="ttname"><a href="neorv32__dma_8h.html#a002cb188ea5156df0ba282e239a6e74bad0f66e962296f5451d73dc1cae1fdc0d">DMA_STATUS_BUSY</a></div><div class="ttdeci">@ DMA_STATUS_BUSY</div><div class="ttdef"><b>Definition</b> neorv32_dma.h:95</div></div> +<div class="ttc" id="aneorv32__dma_8h_html_a002cb188ea5156df0ba282e239a6e74baed7242b847e3cc8cf20d7da99f9b1492"><div class="ttname"><a href="neorv32__dma_8h.html#a002cb188ea5156df0ba282e239a6e74baed7242b847e3cc8cf20d7da99f9b1492">DMA_STATUS_ERR_RD</a></div><div class="ttdeci">@ DMA_STATUS_ERR_RD</div><div class="ttdef"><b>Definition</b> neorv32_dma.h:93</div></div> +<div class="ttc" id="aneorv32__dma_8h_html_a13260c3252f0375d8982590d270d7dfd"><div class="ttname"><a href="neorv32__dma_8h.html#a13260c3252f0375d8982590d270d7dfd">neorv32_dma_available</a></div><div class="ttdeci">int neorv32_dma_available(void)</div><div class="ttdef"><b>Definition</b> neorv32_dma.c:26</div></div> +<div class="ttc" id="aneorv32__dma_8h_html_a2c7257567ccdb7a986f5ef7c74d3917c"><div class="ttname"><a href="neorv32__dma_8h.html#a2c7257567ccdb7a986f5ef7c74d3917c">neorv32_dma_fence_enable</a></div><div class="ttdeci">void neorv32_dma_fence_enable(void)</div><div class="ttdef"><b>Definition</b> neorv32_dma.c:59</div></div> +<div class="ttc" id="aneorv32__dma_8h_html_a2ce0d31e04604b2523135d52a877febf"><div class="ttname"><a href="neorv32__dma_8h.html#a2ce0d31e04604b2523135d52a877febf">neorv32_dma_transfer</a></div><div class="ttdeci">void neorv32_dma_transfer(uint32_t base_src, uint32_t base_dst, uint32_t num, uint32_t config)</div><div class="ttdef"><b>Definition</b> neorv32_dma.c:82</div></div> +<div class="ttc" id="aneorv32__dma_8h_html_a33187c5a074d62b46d2262e352edb8d9"><div class="ttname"><a href="neorv32__dma_8h.html#a33187c5a074d62b46d2262e352edb8d9">NEORV32_DMA_TTYPE_enum</a></div><div class="ttdeci">NEORV32_DMA_TTYPE_enum</div><div class="ttdef"><b>Definition</b> neorv32_dma.h:56</div></div> +<div class="ttc" id="aneorv32__dma_8h_html_a33187c5a074d62b46d2262e352edb8d9a37ea8ef1e6b342db330d3885545fc802"><div class="ttname"><a href="neorv32__dma_8h.html#a33187c5a074d62b46d2262e352edb8d9a37ea8ef1e6b342db330d3885545fc802">DMA_TTYPE_ENDIAN</a></div><div class="ttdeci">@ DMA_TTYPE_ENDIAN</div><div class="ttdef"><b>Definition</b> neorv32_dma.h:64</div></div> +<div class="ttc" id="aneorv32__dma_8h_html_a33187c5a074d62b46d2262e352edb8d9a4217c9a8ac4ccc52bb45944f30a598c5"><div class="ttname"><a href="neorv32__dma_8h.html#a33187c5a074d62b46d2262e352edb8d9a4217c9a8ac4ccc52bb45944f30a598c5">DMA_TTYPE_QSEL_MSB</a></div><div class="ttdeci">@ DMA_TTYPE_QSEL_MSB</div><div class="ttdef"><b>Definition</b> neorv32_dma.h:61</div></div> +<div class="ttc" id="aneorv32__dma_8h_html_a33187c5a074d62b46d2262e352edb8d9a4b99a30b851851f3388dd4e77effacec"><div class="ttname"><a href="neorv32__dma_8h.html#a33187c5a074d62b46d2262e352edb8d9a4b99a30b851851f3388dd4e77effacec">DMA_TTYPE_SRC_INC</a></div><div class="ttdeci">@ DMA_TTYPE_SRC_INC</div><div class="ttdef"><b>Definition</b> neorv32_dma.h:62</div></div> +<div class="ttc" id="aneorv32__dma_8h_html_a33187c5a074d62b46d2262e352edb8d9a61553eee00ed2382565bf826074c44bd"><div class="ttname"><a href="neorv32__dma_8h.html#a33187c5a074d62b46d2262e352edb8d9a61553eee00ed2382565bf826074c44bd">DMA_TTYPE_NUM_MSB</a></div><div class="ttdeci">@ DMA_TTYPE_NUM_MSB</div><div class="ttdef"><b>Definition</b> neorv32_dma.h:58</div></div> +<div class="ttc" id="aneorv32__dma_8h_html_a33187c5a074d62b46d2262e352edb8d9a8dba4160c033c763f5102928c471e450"><div class="ttname"><a href="neorv32__dma_8h.html#a33187c5a074d62b46d2262e352edb8d9a8dba4160c033c763f5102928c471e450">DMA_TTYPE_NUM_LSB</a></div><div class="ttdeci">@ DMA_TTYPE_NUM_LSB</div><div class="ttdef"><b>Definition</b> neorv32_dma.h:57</div></div> +<div class="ttc" id="aneorv32__dma_8h_html_a33187c5a074d62b46d2262e352edb8d9abb1293915b076e5d37be6724b44ab0da"><div class="ttname"><a href="neorv32__dma_8h.html#a33187c5a074d62b46d2262e352edb8d9abb1293915b076e5d37be6724b44ab0da">DMA_TTYPE_DST_INC</a></div><div class="ttdeci">@ DMA_TTYPE_DST_INC</div><div class="ttdef"><b>Definition</b> neorv32_dma.h:63</div></div> +<div class="ttc" id="aneorv32__dma_8h_html_a33187c5a074d62b46d2262e352edb8d9afcfdedeca4c4a1def4905660811e31e2"><div class="ttname"><a href="neorv32__dma_8h.html#a33187c5a074d62b46d2262e352edb8d9afcfdedeca4c4a1def4905660811e31e2">DMA_TTYPE_QSEL_LSB</a></div><div class="ttdeci">@ DMA_TTYPE_QSEL_LSB</div><div class="ttdef"><b>Definition</b> neorv32_dma.h:60</div></div> +<div class="ttc" id="aneorv32__dma_8h_html_a6716eddb145b80ad38799da3b87cb2a4"><div class="ttname"><a href="neorv32__dma_8h.html#a6716eddb145b80ad38799da3b87cb2a4">NEORV32_DMA_CTRL_enum</a></div><div class="ttdeci">NEORV32_DMA_CTRL_enum</div><div class="ttdef"><b>Definition</b> neorv32_dma.h:40</div></div> +<div class="ttc" id="aneorv32__dma_8h_html_a6716eddb145b80ad38799da3b87cb2a4a0d51df1bb87dc54d331891c5db787bcc"><div class="ttname"><a href="neorv32__dma_8h.html#a6716eddb145b80ad38799da3b87cb2a4a0d51df1bb87dc54d331891c5db787bcc">DMA_CTRL_DONE</a></div><div class="ttdeci">@ DMA_CTRL_DONE</div><div class="ttdef"><b>Definition</b> neorv32_dma.h:48</div></div> +<div class="ttc" id="aneorv32__dma_8h_html_a6716eddb145b80ad38799da3b87cb2a4a3eba1f7868f0c985effb69785ced011a"><div class="ttname"><a href="neorv32__dma_8h.html#a6716eddb145b80ad38799da3b87cb2a4a3eba1f7868f0c985effb69785ced011a">DMA_CTRL_FIRQ_SEL_MSB</a></div><div class="ttdeci">@ DMA_CTRL_FIRQ_SEL_MSB</div><div class="ttdef"><b>Definition</b> neorv32_dma.h:52</div></div> +<div class="ttc" id="aneorv32__dma_8h_html_a6716eddb145b80ad38799da3b87cb2a4a539609fc4d80867b3eb98c78206f5f96"><div class="ttname"><a href="neorv32__dma_8h.html#a6716eddb145b80ad38799da3b87cb2a4a539609fc4d80867b3eb98c78206f5f96">DMA_CTRL_ERROR_RD</a></div><div class="ttdeci">@ DMA_CTRL_ERROR_RD</div><div class="ttdef"><b>Definition</b> neorv32_dma.h:45</div></div> +<div class="ttc" id="aneorv32__dma_8h_html_a6716eddb145b80ad38799da3b87cb2a4a5aeeb05d6365d94d92808df2490daa3b"><div class="ttname"><a href="neorv32__dma_8h.html#a6716eddb145b80ad38799da3b87cb2a4a5aeeb05d6365d94d92808df2490daa3b">DMA_CTRL_AUTO</a></div><div class="ttdeci">@ DMA_CTRL_AUTO</div><div class="ttdef"><b>Definition</b> neorv32_dma.h:42</div></div> +<div class="ttc" id="aneorv32__dma_8h_html_a6716eddb145b80ad38799da3b87cb2a4a5f39deea0212f45423243c8100c40838"><div class="ttname"><a href="neorv32__dma_8h.html#a6716eddb145b80ad38799da3b87cb2a4a5f39deea0212f45423243c8100c40838">DMA_CTRL_EN</a></div><div class="ttdeci">@ DMA_CTRL_EN</div><div class="ttdef"><b>Definition</b> neorv32_dma.h:41</div></div> +<div class="ttc" id="aneorv32__dma_8h_html_a6716eddb145b80ad38799da3b87cb2a4a8e5ff34ac48eea4b352378bb2af47bcb"><div class="ttname"><a href="neorv32__dma_8h.html#a6716eddb145b80ad38799da3b87cb2a4a8e5ff34ac48eea4b352378bb2af47bcb">DMA_CTRL_BUSY</a></div><div class="ttdeci">@ DMA_CTRL_BUSY</div><div class="ttdef"><b>Definition</b> neorv32_dma.h:47</div></div> +<div class="ttc" id="aneorv32__dma_8h_html_a6716eddb145b80ad38799da3b87cb2a4aaf040e663494b39b890d7171d0a584b9"><div class="ttname"><a href="neorv32__dma_8h.html#a6716eddb145b80ad38799da3b87cb2a4aaf040e663494b39b890d7171d0a584b9">DMA_CTRL_FIRQ_SEL_LSB</a></div><div class="ttdeci">@ DMA_CTRL_FIRQ_SEL_LSB</div><div class="ttdef"><b>Definition</b> neorv32_dma.h:51</div></div> +<div class="ttc" id="aneorv32__dma_8h_html_a6716eddb145b80ad38799da3b87cb2a4ace9fdcdfa8784abad30e033c273e7d00"><div class="ttname"><a href="neorv32__dma_8h.html#a6716eddb145b80ad38799da3b87cb2a4ace9fdcdfa8784abad30e033c273e7d00">DMA_CTRL_FENCE</a></div><div class="ttdeci">@ DMA_CTRL_FENCE</div><div class="ttdef"><b>Definition</b> neorv32_dma.h:43</div></div> +<div class="ttc" id="aneorv32__dma_8h_html_a6716eddb145b80ad38799da3b87cb2a4aeaf5ee8f6a84668aa15cd3e21f076afe"><div class="ttname"><a href="neorv32__dma_8h.html#a6716eddb145b80ad38799da3b87cb2a4aeaf5ee8f6a84668aa15cd3e21f076afe">DMA_CTRL_FIRQ_TYPE</a></div><div class="ttdeci">@ DMA_CTRL_FIRQ_TYPE</div><div class="ttdef"><b>Definition</b> neorv32_dma.h:50</div></div> +<div class="ttc" id="aneorv32__dma_8h_html_a6716eddb145b80ad38799da3b87cb2a4af7e038b0b0e3ac64f5a2c598eb9c5101"><div class="ttname"><a href="neorv32__dma_8h.html#a6716eddb145b80ad38799da3b87cb2a4af7e038b0b0e3ac64f5a2c598eb9c5101">DMA_CTRL_ERROR_WR</a></div><div class="ttdeci">@ DMA_CTRL_ERROR_WR</div><div class="ttdef"><b>Definition</b> neorv32_dma.h:46</div></div> +<div class="ttc" id="aneorv32__dma_8h_html_a6df244028455cf7f8d4cf1520c4670a7"><div class="ttname"><a href="neorv32__dma_8h.html#a6df244028455cf7f8d4cf1520c4670a7">neorv32_dma_disable</a></div><div class="ttdeci">void neorv32_dma_disable(void)</div><div class="ttdef"><b>Definition</b> neorv32_dma.c:49</div></div> +<div class="ttc" id="aneorv32__dma_8h_html_a6ebd1595ee6fa0e6cbfbd1ce7476f18e"><div class="ttname"><a href="neorv32__dma_8h.html#a6ebd1595ee6fa0e6cbfbd1ce7476f18e">neorv32_dma_transfer_auto</a></div><div class="ttdeci">void neorv32_dma_transfer_auto(uint32_t base_src, uint32_t base_dst, uint32_t num, uint32_t config, int firq_sel, int firq_type)</div><div class="ttdef"><b>Definition</b> neorv32_dma.c:101</div></div> +<div class="ttc" id="aneorv32__dma_8h_html_a8f37adfa07050b0a1cb8430c9ce1fcc2"><div class="ttname"><a href="neorv32__dma_8h.html#a8f37adfa07050b0a1cb8430c9ce1fcc2">neorv32_dma_fence_disable</a></div><div class="ttdeci">void neorv32_dma_fence_disable(void)</div><div class="ttdef"><b>Definition</b> neorv32_dma.c:68</div></div> +<div class="ttc" id="aneorv32__dma_8h_html_aa116f9714174abbe8a3583e441fee24b"><div class="ttname"><a href="neorv32__dma_8h.html#aa116f9714174abbe8a3583e441fee24b">neorv32_dma_status</a></div><div class="ttdeci">int neorv32_dma_status(void)</div><div class="ttdef"><b>Definition</b> neorv32_dma.c:121</div></div> +<div class="ttc" id="aneorv32__dma_8h_html_ac3b72447e8a132faf26577ac714b8284"><div class="ttname"><a href="neorv32__dma_8h.html#ac3b72447e8a132faf26577ac714b8284">neorv32_dma_enable</a></div><div class="ttdeci">void neorv32_dma_enable(void)</div><div class="ttdef"><b>Definition</b> neorv32_dma.c:40</div></div> +<div class="ttc" id="aneorv32__dma_8h_html_afc8cc32f7d80d0f5ab33b2f1ecf77956"><div class="ttname"><a href="neorv32__dma_8h.html#afc8cc32f7d80d0f5ab33b2f1ecf77956">neorv32_dma_done</a></div><div class="ttdeci">int neorv32_dma_done(void)</div><div class="ttdef"><b>Definition</b> neorv32_dma.c:146</div></div> +<div class="ttc" id="astructneorv32__dma__t_html"><div class="ttname"><a href="structneorv32__dma__t.html">neorv32_dma_t</a></div><div class="ttdef"><b>Definition</b> neorv32_dma.h:29</div></div> +<div class="ttc" id="astructneorv32__dma__t_html_a3b214d1a373c7f15b374e113d7110b42"><div class="ttname"><a href="structneorv32__dma__t.html#a3b214d1a373c7f15b374e113d7110b42">neorv32_dma_t::SRC_BASE</a></div><div class="ttdeci">uint32_t SRC_BASE</div><div class="ttdef"><b>Definition</b> neorv32_dma.h:31</div></div> +<div class="ttc" id="astructneorv32__dma__t_html_a70c28642195765409d97b941e98f47ca"><div class="ttname"><a href="structneorv32__dma__t.html#a70c28642195765409d97b941e98f47ca">neorv32_dma_t::TTYPE</a></div><div class="ttdeci">uint32_t TTYPE</div><div class="ttdef"><b>Definition</b> neorv32_dma.h:33</div></div> +<div class="ttc" id="astructneorv32__dma__t_html_a8480d6ad3ba5063cdf21dca286711569"><div class="ttname"><a href="structneorv32__dma__t.html#a8480d6ad3ba5063cdf21dca286711569">neorv32_dma_t::CTRL</a></div><div class="ttdeci">uint32_t CTRL</div><div class="ttdef"><b>Definition</b> neorv32_dma.h:30</div></div> +<div class="ttc" id="astructneorv32__dma__t_html_aee8a6cf3cbd9fe3c5995f046ffb9a1c0"><div class="ttname"><a href="structneorv32__dma__t.html#aee8a6cf3cbd9fe3c5995f046ffb9a1c0">neorv32_dma_t::DST_BASE</a></div><div class="ttdeci">uint32_t DST_BASE</div><div class="ttdef"><b>Definition</b> neorv32_dma.h:32</div></div> +</div><!-- fragment --></div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/neorv32__gpio_8c.html b/sw/neorv32__gpio_8c.html new file mode 100644 index 0000000000..eaea806e2d --- /dev/null +++ b/sw/neorv32__gpio_8c.html @@ -0,0 +1,296 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/lib/source/neorv32_gpio.c File Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_7d04193005ada6f9450f847f4adb6b5b.html">lib</a></li><li class="navelem"><a class="el" href="dir_0c6ac14e2254a316d41123f98feeb67b.html">source</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#func-members">Functions</a> </div> + <div class="headertitle"><div class="title">neorv32_gpio.c File Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p>General purpose input/output port unit (GPIO) HW driver source file. +<a href="#details">More...</a></p> +<div class="textblock"><code>#include &quot;<a class="el" href="neorv32_8h_source.html">neorv32.h</a>&quot;</code><br /> +</div><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="func-members" name="func-members"></a> +Functions</h2></td></tr> +<tr class="memitem:a41d39a41ba5879eb85d3ed4481fcff81" id="r_a41d39a41ba5879eb85d3ed4481fcff81"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a41d39a41ba5879eb85d3ed4481fcff81">neorv32_gpio_available</a> (void)</td></tr> +<tr class="separator:a41d39a41ba5879eb85d3ed4481fcff81"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a60fd0830d634f0c1f784d815384665cb" id="r_a60fd0830d634f0c1f784d815384665cb"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a60fd0830d634f0c1f784d815384665cb">neorv32_gpio_pin_set</a> (int pin, int value)</td></tr> +<tr class="separator:a60fd0830d634f0c1f784d815384665cb"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a1958850fc1689eae9ddfcaa4a7513400" id="r_a1958850fc1689eae9ddfcaa4a7513400"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a1958850fc1689eae9ddfcaa4a7513400">neorv32_gpio_pin_toggle</a> (int pin)</td></tr> +<tr class="separator:a1958850fc1689eae9ddfcaa4a7513400"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:afa3ee54aca47ff35f706b627ac66e95a" id="r_afa3ee54aca47ff35f706b627ac66e95a"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#afa3ee54aca47ff35f706b627ac66e95a">neorv32_gpio_pin_get</a> (int pin)</td></tr> +<tr class="separator:afa3ee54aca47ff35f706b627ac66e95a"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a8dc7846945e4609fc96d81caee99ac00" id="r_a8dc7846945e4609fc96d81caee99ac00"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a8dc7846945e4609fc96d81caee99ac00">neorv32_gpio_port_set</a> (uint64_t port_data)</td></tr> +<tr class="separator:a8dc7846945e4609fc96d81caee99ac00"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a210529f789779387d3f014e6253e803f" id="r_a210529f789779387d3f014e6253e803f"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a210529f789779387d3f014e6253e803f">neorv32_gpio_port_toggle</a> (uint64_t toggle)</td></tr> +<tr class="separator:a210529f789779387d3f014e6253e803f"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ac42379f2fb5ca0bb63850d7957852b84" id="r_ac42379f2fb5ca0bb63850d7957852b84"><td class="memItemLeft" align="right" valign="top">uint64_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ac42379f2fb5ca0bb63850d7957852b84">neorv32_gpio_port_get</a> (void)</td></tr> +<tr class="separator:ac42379f2fb5ca0bb63850d7957852b84"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>General purpose input/output port unit (GPIO) HW driver source file. </p> +<dl class="section note"><dt>Note</dt><dd>These functions should only be used if the GPIO unit was synthesized (IO_GPIO_EN = true).</dd></dl> +<dl class="section see"><dt>See also</dt><dd><a href="https://stnolting.github.io/neorv32/sw/files.html">https://stnolting.github.io/neorv32/sw/files.html</a> </dd></dl> +</div><h2 class="groupheader">Function Documentation</h2> +<a id="a41d39a41ba5879eb85d3ed4481fcff81" name="a41d39a41ba5879eb85d3ed4481fcff81"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a41d39a41ba5879eb85d3ed4481fcff81">&#9670;&#160;</a></span>neorv32_gpio_available()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_gpio_available </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Check if GPIO unit was synthesized.</p> +<dl class="section return"><dt>Returns</dt><dd>0 if GPIO was not synthesized, 1 if GPIO is available. </dd></dl> + +</div> +</div> +<a id="afa3ee54aca47ff35f706b627ac66e95a" name="afa3ee54aca47ff35f706b627ac66e95a"></a> +<h2 class="memtitle"><span class="permalink"><a href="#afa3ee54aca47ff35f706b627ac66e95a">&#9670;&#160;</a></span>neorv32_gpio_pin_get()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_gpio_pin_get </td> + <td>(</td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>pin</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Get single pin of GPIO's input port.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">pin</td><td>Input pin to be read (0..63). </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>=0 if pin is low, !=0 if pin is high. </dd></dl> + +</div> +</div> +<a id="a60fd0830d634f0c1f784d815384665cb" name="a60fd0830d634f0c1f784d815384665cb"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a60fd0830d634f0c1f784d815384665cb">&#9670;&#160;</a></span>neorv32_gpio_pin_set()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_gpio_pin_set </td> + <td>(</td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>pin</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>value</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Set single pin of GPIO's output port.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">pin</td><td>Output pin number to be set (0..63). </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">value</td><td>Set pint high (1) or low (0). </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="a1958850fc1689eae9ddfcaa4a7513400" name="a1958850fc1689eae9ddfcaa4a7513400"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a1958850fc1689eae9ddfcaa4a7513400">&#9670;&#160;</a></span>neorv32_gpio_pin_toggle()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_gpio_pin_toggle </td> + <td>(</td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>pin</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Toggle single pin of GPIO's output port.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">pin</td><td>Output pin number to be toggled (0..63). </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="ac42379f2fb5ca0bb63850d7957852b84" name="ac42379f2fb5ca0bb63850d7957852b84"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ac42379f2fb5ca0bb63850d7957852b84">&#9670;&#160;</a></span>neorv32_gpio_port_get()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint64_t neorv32_gpio_port_get </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Get complete GPIO input port.</p> +<dl class="section return"><dt>Returns</dt><dd>Current input port state (64-bit). </dd></dl> + +</div> +</div> +<a id="a8dc7846945e4609fc96d81caee99ac00" name="a8dc7846945e4609fc96d81caee99ac00"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a8dc7846945e4609fc96d81caee99ac00">&#9670;&#160;</a></span>neorv32_gpio_port_set()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_gpio_port_set </td> + <td>(</td> + <td class="paramtype">uint64_t</td> <td class="paramname"><span class="paramname"><em>port_data</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Set complete GPIO output port.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">port_data</td><td>New output port value (64-bit). </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="a210529f789779387d3f014e6253e803f" name="a210529f789779387d3f014e6253e803f"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a210529f789779387d3f014e6253e803f">&#9670;&#160;</a></span>neorv32_gpio_port_toggle()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_gpio_port_toggle </td> + <td>(</td> + <td class="paramtype">uint64_t</td> <td class="paramname"><span class="paramname"><em>toggle</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Toggle bit in entire GPIO output port.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">toggle</td><td>Bit mask; set bits will toggle the according output port (64-bit). </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/neorv32__gpio_8h.html b/sw/neorv32__gpio_8h.html new file mode 100644 index 0000000000..4d8f632d0f --- /dev/null +++ b/sw/neorv32__gpio_8h.html @@ -0,0 +1,326 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/lib/include/neorv32_gpio.h File Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_7d04193005ada6f9450f847f4adb6b5b.html">lib</a></li><li class="navelem"><a class="el" href="dir_752b1e5d3973bf735fa78bf6b4727df9.html">include</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#nested-classes">Data Structures</a> </div> + <div class="headertitle"><div class="title">neorv32_gpio.h File Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p>General purpose input/output port unit (GPIO) HW driver header file. +<a href="#details">More...</a></p> +<div class="textblock"><code>#include &lt;stdint.h&gt;</code><br /> +</div> +<p><a href="neorv32__gpio_8h_source.html">Go to the source code of this file.</a></p> +<table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="nested-classes" name="nested-classes"></a> +Data Structures</h2></td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">struct &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structneorv32__gpio__t.html">neorv32_gpio_t</a></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="define-members" name="define-members"></a> +Macros</h2></td></tr> +<tr><td colspan="2"><div class="groupHeader">IO Device: General Purpose Input/Output Port Unit (GPIO)</div></td></tr> +<tr class="memitem:a1e35bbf26b9d1aa5373af0b9468eb445" id="r_a1e35bbf26b9d1aa5373af0b9468eb445"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a1e35bbf26b9d1aa5373af0b9468eb445">NEORV32_GPIO</a>&#160;&#160;&#160;((<a class="el" href="structneorv32__gpio__t.html">neorv32_gpio_t</a>*) (<a class="el" href="neorv32_8h.html#a7fd1e24d4de2eed7bf9cd5391562c7f4">NEORV32_GPIO_BASE</a>))</td></tr> +<tr class="separator:a1e35bbf26b9d1aa5373af0b9468eb445"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="func-members" name="func-members"></a> +Functions</h2></td></tr> +<tr><td colspan="2"><div class="groupHeader">Prototypes</div></td></tr> +<tr class="memitem:a41d39a41ba5879eb85d3ed4481fcff81" id="r_a41d39a41ba5879eb85d3ed4481fcff81"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a41d39a41ba5879eb85d3ed4481fcff81">neorv32_gpio_available</a> (void)</td></tr> +<tr class="separator:a41d39a41ba5879eb85d3ed4481fcff81"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a60fd0830d634f0c1f784d815384665cb" id="r_a60fd0830d634f0c1f784d815384665cb"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a60fd0830d634f0c1f784d815384665cb">neorv32_gpio_pin_set</a> (int pin, int value)</td></tr> +<tr class="separator:a60fd0830d634f0c1f784d815384665cb"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a1958850fc1689eae9ddfcaa4a7513400" id="r_a1958850fc1689eae9ddfcaa4a7513400"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a1958850fc1689eae9ddfcaa4a7513400">neorv32_gpio_pin_toggle</a> (int pin)</td></tr> +<tr class="separator:a1958850fc1689eae9ddfcaa4a7513400"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:afa3ee54aca47ff35f706b627ac66e95a" id="r_afa3ee54aca47ff35f706b627ac66e95a"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#afa3ee54aca47ff35f706b627ac66e95a">neorv32_gpio_pin_get</a> (int pin)</td></tr> +<tr class="separator:afa3ee54aca47ff35f706b627ac66e95a"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a789222709485cd8467aad5eddf69d2df" id="r_a789222709485cd8467aad5eddf69d2df"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a789222709485cd8467aad5eddf69d2df">neorv32_gpio_port_set</a> (uint64_t d)</td></tr> +<tr class="separator:a789222709485cd8467aad5eddf69d2df"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a210529f789779387d3f014e6253e803f" id="r_a210529f789779387d3f014e6253e803f"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a210529f789779387d3f014e6253e803f">neorv32_gpio_port_toggle</a> (uint64_t toggle)</td></tr> +<tr class="separator:a210529f789779387d3f014e6253e803f"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ac42379f2fb5ca0bb63850d7957852b84" id="r_ac42379f2fb5ca0bb63850d7957852b84"><td class="memItemLeft" align="right" valign="top">uint64_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ac42379f2fb5ca0bb63850d7957852b84">neorv32_gpio_port_get</a> (void)</td></tr> +<tr class="separator:ac42379f2fb5ca0bb63850d7957852b84"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>General purpose input/output port unit (GPIO) HW driver header file. </p> +<dl class="section note"><dt>Note</dt><dd>These functions should only be used if the GPIO unit was synthesized (IO_GPIO_EN = true).</dd></dl> +<dl class="section see"><dt>See also</dt><dd><a href="https://stnolting.github.io/neorv32/sw/files.html">https://stnolting.github.io/neorv32/sw/files.html</a> </dd></dl> +</div><h2 class="groupheader">Macro Definition Documentation</h2> +<a id="a1e35bbf26b9d1aa5373af0b9468eb445" name="a1e35bbf26b9d1aa5373af0b9468eb445"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a1e35bbf26b9d1aa5373af0b9468eb445">&#9670;&#160;</a></span>NEORV32_GPIO</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define NEORV32_GPIO&#160;&#160;&#160;((<a class="el" href="structneorv32__gpio__t.html">neorv32_gpio_t</a>*) (<a class="el" href="neorv32_8h.html#a7fd1e24d4de2eed7bf9cd5391562c7f4">NEORV32_GPIO_BASE</a>))</td> + </tr> + </table> +</div><div class="memdoc"> +<p>GPIO module hardware access (<a class="el" href="structneorv32__gpio__t.html">neorv32_gpio_t</a>) </p> + +</div> +</div> +<h2 class="groupheader">Function Documentation</h2> +<a id="a41d39a41ba5879eb85d3ed4481fcff81" name="a41d39a41ba5879eb85d3ed4481fcff81"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a41d39a41ba5879eb85d3ed4481fcff81">&#9670;&#160;</a></span>neorv32_gpio_available()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_gpio_available </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Check if GPIO unit was synthesized.</p> +<dl class="section return"><dt>Returns</dt><dd>0 if GPIO was not synthesized, 1 if GPIO is available. </dd></dl> + +</div> +</div> +<a id="afa3ee54aca47ff35f706b627ac66e95a" name="afa3ee54aca47ff35f706b627ac66e95a"></a> +<h2 class="memtitle"><span class="permalink"><a href="#afa3ee54aca47ff35f706b627ac66e95a">&#9670;&#160;</a></span>neorv32_gpio_pin_get()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_gpio_pin_get </td> + <td>(</td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>pin</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Get single pin of GPIO's input port.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">pin</td><td>Input pin to be read (0..63). </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>=0 if pin is low, !=0 if pin is high. </dd></dl> + +</div> +</div> +<a id="a60fd0830d634f0c1f784d815384665cb" name="a60fd0830d634f0c1f784d815384665cb"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a60fd0830d634f0c1f784d815384665cb">&#9670;&#160;</a></span>neorv32_gpio_pin_set()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_gpio_pin_set </td> + <td>(</td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>pin</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>value</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Set single pin of GPIO's output port.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">pin</td><td>Output pin number to be set (0..63). </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">value</td><td>Set pint high (1) or low (0). </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="a1958850fc1689eae9ddfcaa4a7513400" name="a1958850fc1689eae9ddfcaa4a7513400"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a1958850fc1689eae9ddfcaa4a7513400">&#9670;&#160;</a></span>neorv32_gpio_pin_toggle()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_gpio_pin_toggle </td> + <td>(</td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>pin</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Toggle single pin of GPIO's output port.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">pin</td><td>Output pin number to be toggled (0..63). </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="ac42379f2fb5ca0bb63850d7957852b84" name="ac42379f2fb5ca0bb63850d7957852b84"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ac42379f2fb5ca0bb63850d7957852b84">&#9670;&#160;</a></span>neorv32_gpio_port_get()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint64_t neorv32_gpio_port_get </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Get complete GPIO input port.</p> +<dl class="section return"><dt>Returns</dt><dd>Current input port state (64-bit). </dd></dl> + +</div> +</div> +<a id="a789222709485cd8467aad5eddf69d2df" name="a789222709485cd8467aad5eddf69d2df"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a789222709485cd8467aad5eddf69d2df">&#9670;&#160;</a></span>neorv32_gpio_port_set()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_gpio_port_set </td> + <td>(</td> + <td class="paramtype">uint64_t</td> <td class="paramname"><span class="paramname"><em>port_data</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Set complete GPIO output port.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">port_data</td><td>New output port value (64-bit). </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="a210529f789779387d3f014e6253e803f" name="a210529f789779387d3f014e6253e803f"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a210529f789779387d3f014e6253e803f">&#9670;&#160;</a></span>neorv32_gpio_port_toggle()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_gpio_port_toggle </td> + <td>(</td> + <td class="paramtype">uint64_t</td> <td class="paramname"><span class="paramname"><em>toggle</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Toggle bit in entire GPIO output port.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">toggle</td><td>Bit mask; set bits will toggle the according output port (64-bit). </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/neorv32__gpio_8h_source.html b/sw/neorv32__gpio_8h_source.html new file mode 100644 index 0000000000..8de444f906 --- /dev/null +++ b/sw/neorv32__gpio_8h_source.html @@ -0,0 +1,143 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/lib/include/neorv32_gpio.h Source File</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_7d04193005ada6f9450f847f4adb6b5b.html">lib</a></li><li class="navelem"><a class="el" href="dir_752b1e5d3973bf735fa78bf6b4727df9.html">include</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="headertitle"><div class="title">neorv32_gpio.h</div></div> +</div><!--header--> +<div class="contents"> +<a href="neorv32__gpio_8h.html">Go to the documentation of this file.</a><div class="fragment"><div class="line"><a id="l00001" name="l00001"></a><span class="lineno"> 1</span><span class="comment">// ================================================================================ //</span></div> +<div class="line"><a id="l00002" name="l00002"></a><span class="lineno"> 2</span><span class="comment">// The NEORV32 RISC-V Processor - https://github.com/stnolting/neorv32 //</span></div> +<div class="line"><a id="l00003" name="l00003"></a><span class="lineno"> 3</span><span class="comment">// Copyright (c) NEORV32 contributors. //</span></div> +<div class="line"><a id="l00004" name="l00004"></a><span class="lineno"> 4</span><span class="comment">// Copyright (c) 2020 - 2024 Stephan Nolting. All rights reserved. //</span></div> +<div class="line"><a id="l00005" name="l00005"></a><span class="lineno"> 5</span><span class="comment">// Licensed under the BSD-3-Clause license, see LICENSE for details. //</span></div> +<div class="line"><a id="l00006" name="l00006"></a><span class="lineno"> 6</span><span class="comment">// SPDX-License-Identifier: BSD-3-Clause //</span></div> +<div class="line"><a id="l00007" name="l00007"></a><span class="lineno"> 7</span><span class="comment">// ================================================================================ //</span></div> +<div class="line"><a id="l00008" name="l00008"></a><span class="lineno"> 8</span> </div> +<div class="line"><a id="l00018" name="l00018"></a><span class="lineno"> 18</span><span class="preprocessor">#ifndef neorv32_gpio_h</span></div> +<div class="line"><a id="l00019" name="l00019"></a><span class="lineno"> 19</span><span class="preprocessor">#define neorv32_gpio_h</span></div> +<div class="line"><a id="l00020" name="l00020"></a><span class="lineno"> 20</span> </div> +<div class="line"><a id="l00021" name="l00021"></a><span class="lineno"> 21</span><span class="preprocessor">#include &lt;stdint.h&gt;</span></div> +<div class="line"><a id="l00022" name="l00022"></a><span class="lineno"> 22</span> </div> +<div class="line"><a id="l00023" name="l00023"></a><span class="lineno"> 23</span> </div> +<div class="line"><a id="l00024" name="l00024"></a><span class="lineno"> 24</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen00029" data-start="{" data-end="};"> +<div class="line"><a id="l00029" name="l00029"></a><span class="lineno"><a class="line" href="structneorv32__gpio__t.html"> 29</a></span><span class="keyword">typedef</span> <span class="keyword">volatile</span> <span class="keyword">struct </span>__attribute__((packed,aligned(4))) {</div> +<div class="line"><a id="l00030" name="l00030"></a><span class="lineno"><a class="line" href="structneorv32__gpio__t.html#a208ee622d43fee3574072f19a98c8808"> 30</a></span> <span class="keyword">const</span> uint32_t INPUT[2]; </div> +<div class="line"><a id="l00031" name="l00031"></a><span class="lineno"><a class="line" href="structneorv32__gpio__t.html#abaf7de4f79adfc3debcde93fa4a921bb"> 31</a></span> uint32_t OUTPUT[2]; </div> +<div class="line"><a id="l00032" name="l00032"></a><span class="lineno"> 32</span>} <a class="code hl_struct" href="structneorv32__gpio__t.html">neorv32_gpio_t</a>;</div> +</div> +<div class="line"><a id="l00033" name="l00033"></a><span class="lineno"> 33</span> </div> +<div class="line"><a id="l00035" name="l00035"></a><span class="lineno"><a class="line" href="neorv32__gpio_8h.html#a1e35bbf26b9d1aa5373af0b9468eb445"> 35</a></span><span class="preprocessor">#define NEORV32_GPIO ((neorv32_gpio_t*) (NEORV32_GPIO_BASE))</span></div> +<div class="line"><a id="l00039" name="l00039"></a><span class="lineno"> 39</span><span class="comment">/**********************************************************************/</span></div> +<div class="line"><a id="l00043" name="l00043"></a><span class="lineno"> 43</span><span class="keywordtype">int</span> <a class="code hl_function" href="neorv32__gpio_8h.html#a41d39a41ba5879eb85d3ed4481fcff81">neorv32_gpio_available</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00044" name="l00044"></a><span class="lineno"> 44</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__gpio_8h.html#a60fd0830d634f0c1f784d815384665cb">neorv32_gpio_pin_set</a>(<span class="keywordtype">int</span> pin, <span class="keywordtype">int</span> value);</div> +<div class="line"><a id="l00045" name="l00045"></a><span class="lineno"> 45</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__gpio_8h.html#a1958850fc1689eae9ddfcaa4a7513400">neorv32_gpio_pin_toggle</a>(<span class="keywordtype">int</span> pin);</div> +<div class="line"><a id="l00046" name="l00046"></a><span class="lineno"> 46</span>uint32_t <a class="code hl_function" href="neorv32__gpio_8h.html#afa3ee54aca47ff35f706b627ac66e95a">neorv32_gpio_pin_get</a>(<span class="keywordtype">int</span> pin);</div> +<div class="line"><a id="l00047" name="l00047"></a><span class="lineno"> 47</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__gpio_8h.html#a789222709485cd8467aad5eddf69d2df">neorv32_gpio_port_set</a>(uint64_t d);</div> +<div class="line"><a id="l00048" name="l00048"></a><span class="lineno"> 48</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__gpio_8h.html#a210529f789779387d3f014e6253e803f">neorv32_gpio_port_toggle</a>(uint64_t toggle);</div> +<div class="line"><a id="l00049" name="l00049"></a><span class="lineno"> 49</span>uint64_t <a class="code hl_function" href="neorv32__gpio_8h.html#ac42379f2fb5ca0bb63850d7957852b84">neorv32_gpio_port_get</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00053" name="l00053"></a><span class="lineno"> 53</span><span class="preprocessor">#endif </span><span class="comment">// neorv32_gpio_h</span></div> +<div class="ttc" id="aneorv32__gpio_8h_html_a1958850fc1689eae9ddfcaa4a7513400"><div class="ttname"><a href="neorv32__gpio_8h.html#a1958850fc1689eae9ddfcaa4a7513400">neorv32_gpio_pin_toggle</a></div><div class="ttdeci">void neorv32_gpio_pin_toggle(int pin)</div><div class="ttdef"><b>Definition</b> neorv32_gpio.c:62</div></div> +<div class="ttc" id="aneorv32__gpio_8h_html_a210529f789779387d3f014e6253e803f"><div class="ttname"><a href="neorv32__gpio_8h.html#a210529f789779387d3f014e6253e803f">neorv32_gpio_port_toggle</a></div><div class="ttdeci">void neorv32_gpio_port_toggle(uint64_t toggle)</div><div class="ttdef"><b>Definition</b> neorv32_gpio.c:104</div></div> +<div class="ttc" id="aneorv32__gpio_8h_html_a41d39a41ba5879eb85d3ed4481fcff81"><div class="ttname"><a href="neorv32__gpio_8h.html#a41d39a41ba5879eb85d3ed4481fcff81">neorv32_gpio_available</a></div><div class="ttdeci">int neorv32_gpio_available(void)</div><div class="ttdef"><b>Definition</b> neorv32_gpio.c:26</div></div> +<div class="ttc" id="aneorv32__gpio_8h_html_a60fd0830d634f0c1f784d815384665cb"><div class="ttname"><a href="neorv32__gpio_8h.html#a60fd0830d634f0c1f784d815384665cb">neorv32_gpio_pin_set</a></div><div class="ttdeci">void neorv32_gpio_pin_set(int pin, int value)</div><div class="ttdef"><b>Definition</b> neorv32_gpio.c:43</div></div> +<div class="ttc" id="aneorv32__gpio_8h_html_a789222709485cd8467aad5eddf69d2df"><div class="ttname"><a href="neorv32__gpio_8h.html#a789222709485cd8467aad5eddf69d2df">neorv32_gpio_port_set</a></div><div class="ttdeci">void neorv32_gpio_port_set(uint64_t d)</div><div class="ttdef"><b>Definition</b> neorv32_gpio.c:89</div></div> +<div class="ttc" id="aneorv32__gpio_8h_html_ac42379f2fb5ca0bb63850d7957852b84"><div class="ttname"><a href="neorv32__gpio_8h.html#ac42379f2fb5ca0bb63850d7957852b84">neorv32_gpio_port_get</a></div><div class="ttdeci">uint64_t neorv32_gpio_port_get(void)</div><div class="ttdef"><b>Definition</b> neorv32_gpio.c:119</div></div> +<div class="ttc" id="aneorv32__gpio_8h_html_afa3ee54aca47ff35f706b627ac66e95a"><div class="ttname"><a href="neorv32__gpio_8h.html#afa3ee54aca47ff35f706b627ac66e95a">neorv32_gpio_pin_get</a></div><div class="ttdeci">uint32_t neorv32_gpio_pin_get(int pin)</div><div class="ttdef"><b>Definition</b> neorv32_gpio.c:76</div></div> +<div class="ttc" id="astructneorv32__gpio__t_html"><div class="ttname"><a href="structneorv32__gpio__t.html">neorv32_gpio_t</a></div><div class="ttdef"><b>Definition</b> neorv32_gpio.h:29</div></div> +</div><!-- fragment --></div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/neorv32__gptmr_8c.html b/sw/neorv32__gptmr_8c.html new file mode 100644 index 0000000000..8688a8a2c1 --- /dev/null +++ b/sw/neorv32__gptmr_8c.html @@ -0,0 +1,236 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/lib/source/neorv32_gptmr.c File Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_7d04193005ada6f9450f847f4adb6b5b.html">lib</a></li><li class="navelem"><a class="el" href="dir_0c6ac14e2254a316d41123f98feeb67b.html">source</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#func-members">Functions</a> </div> + <div class="headertitle"><div class="title">neorv32_gptmr.c File Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p>General purpose timer (GPTMR) HW driver source file. +<a href="#details">More...</a></p> +<div class="textblock"><code>#include &quot;<a class="el" href="neorv32_8h_source.html">neorv32.h</a>&quot;</code><br /> +</div><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="func-members" name="func-members"></a> +Functions</h2></td></tr> +<tr class="memitem:ae79a08c52ad3e83f9c4393acfabf035f" id="r_ae79a08c52ad3e83f9c4393acfabf035f"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ae79a08c52ad3e83f9c4393acfabf035f">neorv32_gptmr_available</a> (void)</td></tr> +<tr class="separator:ae79a08c52ad3e83f9c4393acfabf035f"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a6aa27efd2163eebf8fc49fe1c591708f" id="r_a6aa27efd2163eebf8fc49fe1c591708f"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a6aa27efd2163eebf8fc49fe1c591708f">neorv32_gptmr_setup</a> (int prsc, uint32_t threshold, int cont_mode)</td></tr> +<tr class="separator:a6aa27efd2163eebf8fc49fe1c591708f"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a7c9bc6d28ad12611b08fa2867c2db874" id="r_a7c9bc6d28ad12611b08fa2867c2db874"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a7c9bc6d28ad12611b08fa2867c2db874">neorv32_gptmr_disable</a> (void)</td></tr> +<tr class="separator:a7c9bc6d28ad12611b08fa2867c2db874"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a59e684348835772a7e83446e478d4a13" id="r_a59e684348835772a7e83446e478d4a13"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a59e684348835772a7e83446e478d4a13">neorv32_gptmr_enable</a> (void)</td></tr> +<tr class="separator:a59e684348835772a7e83446e478d4a13"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ac73aa4e41a064abb4ca554a389888e67" id="r_ac73aa4e41a064abb4ca554a389888e67"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ac73aa4e41a064abb4ca554a389888e67">neorv32_gptmr_irq_ack</a> (void)</td></tr> +<tr class="separator:ac73aa4e41a064abb4ca554a389888e67"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>General purpose timer (GPTMR) HW driver source file. </p> +<dl class="section note"><dt>Note</dt><dd>These functions should only be used if the GPTMR unit was synthesized (IO_GPTMR_EN = true).</dd></dl> +<dl class="section see"><dt>See also</dt><dd><a href="https://stnolting.github.io/neorv32/sw/files.html">https://stnolting.github.io/neorv32/sw/files.html</a> </dd></dl> +</div><h2 class="groupheader">Function Documentation</h2> +<a id="ae79a08c52ad3e83f9c4393acfabf035f" name="ae79a08c52ad3e83f9c4393acfabf035f"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ae79a08c52ad3e83f9c4393acfabf035f">&#9670;&#160;</a></span>neorv32_gptmr_available()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_gptmr_available </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Check if general purpose timer unit was synthesized.</p> +<dl class="section return"><dt>Returns</dt><dd>0 if GPTMR was not synthesized, 1 if GPTMR is available. </dd></dl> + +</div> +</div> +<a id="a7c9bc6d28ad12611b08fa2867c2db874" name="a7c9bc6d28ad12611b08fa2867c2db874"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a7c9bc6d28ad12611b08fa2867c2db874">&#9670;&#160;</a></span>neorv32_gptmr_disable()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_gptmr_disable </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Disable general purpose timer. </p> + +</div> +</div> +<a id="a59e684348835772a7e83446e478d4a13" name="a59e684348835772a7e83446e478d4a13"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a59e684348835772a7e83446e478d4a13">&#9670;&#160;</a></span>neorv32_gptmr_enable()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_gptmr_enable </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Enable general purpose timer. </p> + +</div> +</div> +<a id="ac73aa4e41a064abb4ca554a389888e67" name="ac73aa4e41a064abb4ca554a389888e67"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ac73aa4e41a064abb4ca554a389888e67">&#9670;&#160;</a></span>neorv32_gptmr_irq_ack()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_gptmr_irq_ack </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Clear pending timer interrupt. </p> + +</div> +</div> +<a id="a6aa27efd2163eebf8fc49fe1c591708f" name="a6aa27efd2163eebf8fc49fe1c591708f"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a6aa27efd2163eebf8fc49fe1c591708f">&#9670;&#160;</a></span>neorv32_gptmr_setup()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_gptmr_setup </td> + <td>(</td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>prsc</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>threshold</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>cont_mode</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Reset, enable and configure general purpose timer.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">prsc</td><td>Clock prescaler select (0..7). See <a class="el" href="neorv32_8h.html#a10022df4c223533b04d5aebe222e8b73">NEORV32_CLOCK_PRSC_enum</a>. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">threshold</td><td>Threshold value, counter will reset to zero when reaching this. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">cont_mode</td><td>Set to operate timer in continuous mode (instead of single-shot mode). </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/neorv32__gptmr_8h.html b/sw/neorv32__gptmr_8h.html new file mode 100644 index 0000000000..48d433203e --- /dev/null +++ b/sw/neorv32__gptmr_8h.html @@ -0,0 +1,308 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/lib/include/neorv32_gptmr.h File Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_7d04193005ada6f9450f847f4adb6b5b.html">lib</a></li><li class="navelem"><a class="el" href="dir_752b1e5d3973bf735fa78bf6b4727df9.html">include</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#nested-classes">Data Structures</a> </div> + <div class="headertitle"><div class="title">neorv32_gptmr.h File Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p>General purpose timer (GPTMR) HW driver header file. +<a href="#details">More...</a></p> +<div class="textblock"><code>#include &lt;stdint.h&gt;</code><br /> +</div> +<p><a href="neorv32__gptmr_8h_source.html">Go to the source code of this file.</a></p> +<table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="nested-classes" name="nested-classes"></a> +Data Structures</h2></td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">struct &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structneorv32__gptmr__t.html">neorv32_gptmr_t</a></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="func-members" name="func-members"></a> +Functions</h2></td></tr> +<tr><td colspan="2"><div class="groupHeader">Prototypes</div></td></tr> +<tr class="memitem:ae79a08c52ad3e83f9c4393acfabf035f" id="r_ae79a08c52ad3e83f9c4393acfabf035f"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ae79a08c52ad3e83f9c4393acfabf035f">neorv32_gptmr_available</a> (void)</td></tr> +<tr class="separator:ae79a08c52ad3e83f9c4393acfabf035f"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a6aa27efd2163eebf8fc49fe1c591708f" id="r_a6aa27efd2163eebf8fc49fe1c591708f"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a6aa27efd2163eebf8fc49fe1c591708f">neorv32_gptmr_setup</a> (int prsc, uint32_t threshold, int cont_mode)</td></tr> +<tr class="separator:a6aa27efd2163eebf8fc49fe1c591708f"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a7c9bc6d28ad12611b08fa2867c2db874" id="r_a7c9bc6d28ad12611b08fa2867c2db874"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a7c9bc6d28ad12611b08fa2867c2db874">neorv32_gptmr_disable</a> (void)</td></tr> +<tr class="separator:a7c9bc6d28ad12611b08fa2867c2db874"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a59e684348835772a7e83446e478d4a13" id="r_a59e684348835772a7e83446e478d4a13"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a59e684348835772a7e83446e478d4a13">neorv32_gptmr_enable</a> (void)</td></tr> +<tr class="separator:a59e684348835772a7e83446e478d4a13"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ac73aa4e41a064abb4ca554a389888e67" id="r_ac73aa4e41a064abb4ca554a389888e67"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ac73aa4e41a064abb4ca554a389888e67">neorv32_gptmr_irq_ack</a> (void)</td></tr> +<tr class="separator:ac73aa4e41a064abb4ca554a389888e67"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader">IO Device: General Purpose Timer (GPTMR)</h2></td></tr> +<tr class="memitem:a9e047791588ff21fc4dc1b06456bdfd2" id="r_a9e047791588ff21fc4dc1b06456bdfd2"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a9e047791588ff21fc4dc1b06456bdfd2">NEORV32_GPTMR</a>&#160;&#160;&#160;((<a class="el" href="structneorv32__gptmr__t.html">neorv32_gptmr_t</a>*) (<a class="el" href="neorv32_8h.html#a0991b1a5ba1e8c3550eb9770d43589d0">NEORV32_GPTMR_BASE</a>))</td></tr> +<tr class="separator:a9e047791588ff21fc4dc1b06456bdfd2"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a135b0750d4afed16e5867134e3843988" id="r_a135b0750d4afed16e5867134e3843988"><td class="memItemLeft" align="right" valign="top">enum &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a135b0750d4afed16e5867134e3843988">NEORV32_GPTMR_CTRL_enum</a> { <br /> +&#160;&#160;<a class="el" href="#a135b0750d4afed16e5867134e3843988abbfa7abcbd80b9c47e83e23e5cefaf90">GPTMR_CTRL_EN</a> = 0 +, <a class="el" href="#a135b0750d4afed16e5867134e3843988ae4716a7a9e356484a8e478f07920cde3">GPTMR_CTRL_PRSC0</a> = 1 +, <a class="el" href="#a135b0750d4afed16e5867134e3843988a1e1e8e516fa4918441e3c77153940298">GPTMR_CTRL_PRSC1</a> = 2 +, <a class="el" href="#a135b0750d4afed16e5867134e3843988a185861fbdc5f276735481237ad844833">GPTMR_CTRL_PRSC2</a> = 3 +, <br /> +&#160;&#160;<a class="el" href="#a135b0750d4afed16e5867134e3843988a473870880c0eca71578d6969e816af43">GPTMR_CTRL_MODE</a> = 4 +, <a class="el" href="#a135b0750d4afed16e5867134e3843988aadb663ad9a0dfd37fc65dffc1a289b38">GPTMR_CTRL_IRQ_CLR</a> = 30 +, <a class="el" href="#a135b0750d4afed16e5867134e3843988a3a868dc710ab9add083137e4e3fe888a">GPTMR_CTRL_IRQ_PND</a> = 31 +<br /> + }</td></tr> +<tr class="separator:a135b0750d4afed16e5867134e3843988"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>General purpose timer (GPTMR) HW driver header file. </p> +<dl class="section note"><dt>Note</dt><dd>These functions should only be used if the GPTMR unit was synthesized (IO_GPTMR_EN = true).</dd></dl> +<dl class="section see"><dt>See also</dt><dd><a href="https://stnolting.github.io/neorv32/sw/files.html">https://stnolting.github.io/neorv32/sw/files.html</a> </dd></dl> +</div><h2 class="groupheader">Macro Definition Documentation</h2> +<a id="a9e047791588ff21fc4dc1b06456bdfd2" name="a9e047791588ff21fc4dc1b06456bdfd2"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a9e047791588ff21fc4dc1b06456bdfd2">&#9670;&#160;</a></span>NEORV32_GPTMR</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define NEORV32_GPTMR&#160;&#160;&#160;((<a class="el" href="structneorv32__gptmr__t.html">neorv32_gptmr_t</a>*) (<a class="el" href="neorv32_8h.html#a0991b1a5ba1e8c3550eb9770d43589d0">NEORV32_GPTMR_BASE</a>))</td> + </tr> + </table> +</div><div class="memdoc"> +<p>GPTMR module hardware access (<a class="el" href="structneorv32__gptmr__t.html">neorv32_gptmr_t</a>) </p> + +</div> +</div> +<h2 class="groupheader">Enumeration Type Documentation</h2> +<a id="a135b0750d4afed16e5867134e3843988" name="a135b0750d4afed16e5867134e3843988"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a135b0750d4afed16e5867134e3843988">&#9670;&#160;</a></span>NEORV32_GPTMR_CTRL_enum</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">enum <a class="el" href="#a135b0750d4afed16e5867134e3843988">NEORV32_GPTMR_CTRL_enum</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>GPTMR control register bits </p> +<table class="fieldtable"> +<tr><th colspan="2">Enumerator</th></tr><tr><td class="fieldname"><a id="a135b0750d4afed16e5867134e3843988abbfa7abcbd80b9c47e83e23e5cefaf90" name="a135b0750d4afed16e5867134e3843988abbfa7abcbd80b9c47e83e23e5cefaf90"></a>GPTMR_CTRL_EN&#160;</td><td class="fielddoc"><p>GPTMR control register(0) (r/w): GPTMR enable </p> +</td></tr> +<tr><td class="fieldname"><a id="a135b0750d4afed16e5867134e3843988ae4716a7a9e356484a8e478f07920cde3" name="a135b0750d4afed16e5867134e3843988ae4716a7a9e356484a8e478f07920cde3"></a>GPTMR_CTRL_PRSC0&#160;</td><td class="fielddoc"><p>GPTMR control register(1) (r/w): Clock prescaler select bit 0 </p> +</td></tr> +<tr><td class="fieldname"><a id="a135b0750d4afed16e5867134e3843988a1e1e8e516fa4918441e3c77153940298" name="a135b0750d4afed16e5867134e3843988a1e1e8e516fa4918441e3c77153940298"></a>GPTMR_CTRL_PRSC1&#160;</td><td class="fielddoc"><p>GPTMR control register(2) (r/w): Clock prescaler select bit 1 </p> +</td></tr> +<tr><td class="fieldname"><a id="a135b0750d4afed16e5867134e3843988a185861fbdc5f276735481237ad844833" name="a135b0750d4afed16e5867134e3843988a185861fbdc5f276735481237ad844833"></a>GPTMR_CTRL_PRSC2&#160;</td><td class="fielddoc"><p>GPTMR control register(3) (r/w): Clock prescaler select bit 2 </p> +</td></tr> +<tr><td class="fieldname"><a id="a135b0750d4afed16e5867134e3843988a473870880c0eca71578d6969e816af43" name="a135b0750d4afed16e5867134e3843988a473870880c0eca71578d6969e816af43"></a>GPTMR_CTRL_MODE&#160;</td><td class="fielddoc"><p>GPTMR control register(4) (r/w): Operation mode (0=single-shot, 1=continuous) </p> +</td></tr> +<tr><td class="fieldname"><a id="a135b0750d4afed16e5867134e3843988aadb663ad9a0dfd37fc65dffc1a289b38" name="a135b0750d4afed16e5867134e3843988aadb663ad9a0dfd37fc65dffc1a289b38"></a>GPTMR_CTRL_IRQ_CLR&#160;</td><td class="fielddoc"><p>GPTMR control register(30) (-/w): Set to clear timer-match interrupt </p> +</td></tr> +<tr><td class="fieldname"><a id="a135b0750d4afed16e5867134e3843988a3a868dc710ab9add083137e4e3fe888a" name="a135b0750d4afed16e5867134e3843988a3a868dc710ab9add083137e4e3fe888a"></a>GPTMR_CTRL_IRQ_PND&#160;</td><td class="fielddoc"><p>GPTMR control register(31) (r/-): Timer-match interrupt pending </p> +</td></tr> +</table> + +</div> +</div> +<h2 class="groupheader">Function Documentation</h2> +<a id="ae79a08c52ad3e83f9c4393acfabf035f" name="ae79a08c52ad3e83f9c4393acfabf035f"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ae79a08c52ad3e83f9c4393acfabf035f">&#9670;&#160;</a></span>neorv32_gptmr_available()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_gptmr_available </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Check if general purpose timer unit was synthesized.</p> +<dl class="section return"><dt>Returns</dt><dd>0 if GPTMR was not synthesized, 1 if GPTMR is available. </dd></dl> + +</div> +</div> +<a id="a7c9bc6d28ad12611b08fa2867c2db874" name="a7c9bc6d28ad12611b08fa2867c2db874"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a7c9bc6d28ad12611b08fa2867c2db874">&#9670;&#160;</a></span>neorv32_gptmr_disable()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_gptmr_disable </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Disable general purpose timer. </p> + +</div> +</div> +<a id="a59e684348835772a7e83446e478d4a13" name="a59e684348835772a7e83446e478d4a13"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a59e684348835772a7e83446e478d4a13">&#9670;&#160;</a></span>neorv32_gptmr_enable()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_gptmr_enable </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Enable general purpose timer. </p> + +</div> +</div> +<a id="ac73aa4e41a064abb4ca554a389888e67" name="ac73aa4e41a064abb4ca554a389888e67"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ac73aa4e41a064abb4ca554a389888e67">&#9670;&#160;</a></span>neorv32_gptmr_irq_ack()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_gptmr_irq_ack </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Clear pending timer interrupt. </p> + +</div> +</div> +<a id="a6aa27efd2163eebf8fc49fe1c591708f" name="a6aa27efd2163eebf8fc49fe1c591708f"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a6aa27efd2163eebf8fc49fe1c591708f">&#9670;&#160;</a></span>neorv32_gptmr_setup()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_gptmr_setup </td> + <td>(</td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>prsc</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>threshold</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>cont_mode</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Reset, enable and configure general purpose timer.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">prsc</td><td>Clock prescaler select (0..7). See <a class="el" href="neorv32_8h.html#a10022df4c223533b04d5aebe222e8b73">NEORV32_CLOCK_PRSC_enum</a>. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">threshold</td><td>Threshold value, counter will reset to zero when reaching this. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">cont_mode</td><td>Set to operate timer in continuous mode (instead of single-shot mode). </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/neorv32__gptmr_8h_source.html b/sw/neorv32__gptmr_8h_source.html new file mode 100644 index 0000000000..09c85886f4 --- /dev/null +++ b/sw/neorv32__gptmr_8h_source.html @@ -0,0 +1,163 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/lib/include/neorv32_gptmr.h Source File</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_7d04193005ada6f9450f847f4adb6b5b.html">lib</a></li><li class="navelem"><a class="el" href="dir_752b1e5d3973bf735fa78bf6b4727df9.html">include</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="headertitle"><div class="title">neorv32_gptmr.h</div></div> +</div><!--header--> +<div class="contents"> +<a href="neorv32__gptmr_8h.html">Go to the documentation of this file.</a><div class="fragment"><div class="line"><a id="l00001" name="l00001"></a><span class="lineno"> 1</span><span class="comment">// ================================================================================ //</span></div> +<div class="line"><a id="l00002" name="l00002"></a><span class="lineno"> 2</span><span class="comment">// The NEORV32 RISC-V Processor - https://github.com/stnolting/neorv32 //</span></div> +<div class="line"><a id="l00003" name="l00003"></a><span class="lineno"> 3</span><span class="comment">// Copyright (c) NEORV32 contributors. //</span></div> +<div class="line"><a id="l00004" name="l00004"></a><span class="lineno"> 4</span><span class="comment">// Copyright (c) 2020 - 2024 Stephan Nolting. All rights reserved. //</span></div> +<div class="line"><a id="l00005" name="l00005"></a><span class="lineno"> 5</span><span class="comment">// Licensed under the BSD-3-Clause license, see LICENSE for details. //</span></div> +<div class="line"><a id="l00006" name="l00006"></a><span class="lineno"> 6</span><span class="comment">// SPDX-License-Identifier: BSD-3-Clause //</span></div> +<div class="line"><a id="l00007" name="l00007"></a><span class="lineno"> 7</span><span class="comment">// ================================================================================ //</span></div> +<div class="line"><a id="l00008" name="l00008"></a><span class="lineno"> 8</span> </div> +<div class="line"><a id="l00018" name="l00018"></a><span class="lineno"> 18</span><span class="preprocessor">#ifndef neorv32_gptmr_h</span></div> +<div class="line"><a id="l00019" name="l00019"></a><span class="lineno"> 19</span><span class="preprocessor">#define neorv32_gptmr_h</span></div> +<div class="line"><a id="l00020" name="l00020"></a><span class="lineno"> 20</span> </div> +<div class="line"><a id="l00021" name="l00021"></a><span class="lineno"> 21</span><span class="preprocessor">#include &lt;stdint.h&gt;</span></div> +<div class="line"><a id="l00022" name="l00022"></a><span class="lineno"> 22</span> </div> +<div class="line"><a id="l00023" name="l00023"></a><span class="lineno"> 23</span> </div> +<div class="line"><a id="l00024" name="l00024"></a><span class="lineno"> 24</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen00029" data-start="{" data-end="};"> +<div class="line"><a id="l00029" name="l00029"></a><span class="lineno"><a class="line" href="structneorv32__gptmr__t.html"> 29</a></span><span class="keyword">typedef</span> <span class="keyword">volatile</span> <span class="keyword">struct </span>__attribute__((packed,aligned(4))) {</div> +<div class="line"><a id="l00030" name="l00030"></a><span class="lineno"><a class="line" href="structneorv32__gptmr__t.html#a3c477ccb24ed12122d9d90244431c7e9"> 30</a></span> uint32_t <a class="code hl_variable" href="structneorv32__gptmr__t.html#a3c477ccb24ed12122d9d90244431c7e9">CTRL</a>; </div> +<div class="line"><a id="l00031" name="l00031"></a><span class="lineno"><a class="line" href="structneorv32__gptmr__t.html#a666ebcbea13dafcf1987629f3e0092ee"> 31</a></span> uint32_t <a class="code hl_variable" href="structneorv32__gptmr__t.html#a666ebcbea13dafcf1987629f3e0092ee">THRES</a>; </div> +<div class="line"><a id="l00032" name="l00032"></a><span class="lineno"><a class="line" href="structneorv32__gptmr__t.html#a1abc5bae1dffc64006e965d4570da479"> 32</a></span> <span class="keyword">const</span> uint32_t <a class="code hl_variable" href="structneorv32__gptmr__t.html#a1abc5bae1dffc64006e965d4570da479">COUNT</a>; </div> +<div class="line"><a id="l00033" name="l00033"></a><span class="lineno"> 33</span>} <a class="code hl_struct" href="structneorv32__gptmr__t.html">neorv32_gptmr_t</a>;</div> +</div> +<div class="line"><a id="l00034" name="l00034"></a><span class="lineno"> 34</span> </div> +<div class="line"><a id="l00036" name="l00036"></a><span class="lineno"><a class="line" href="neorv32__gptmr_8h.html#a9e047791588ff21fc4dc1b06456bdfd2"> 36</a></span><span class="preprocessor">#define NEORV32_GPTMR ((neorv32_gptmr_t*) (NEORV32_GPTMR_BASE))</span></div> +<div class="line"><a id="l00037" name="l00037"></a><span class="lineno"> 37</span> </div> +<div class="foldopen" id="foldopen00039" data-start="{" data-end="};"> +<div class="line"><a id="l00039" name="l00039"></a><span class="lineno"><a class="line" href="neorv32__gptmr_8h.html#a135b0750d4afed16e5867134e3843988"> 39</a></span><span class="keyword">enum</span> <a class="code hl_enumeration" href="neorv32__gptmr_8h.html#a135b0750d4afed16e5867134e3843988">NEORV32_GPTMR_CTRL_enum</a> {</div> +<div class="line"><a id="l00040" name="l00040"></a><span class="lineno"><a class="line" href="neorv32__gptmr_8h.html#a135b0750d4afed16e5867134e3843988abbfa7abcbd80b9c47e83e23e5cefaf90"> 40</a></span> <a class="code hl_enumvalue" href="neorv32__gptmr_8h.html#a135b0750d4afed16e5867134e3843988abbfa7abcbd80b9c47e83e23e5cefaf90">GPTMR_CTRL_EN</a> = 0, </div> +<div class="line"><a id="l00041" name="l00041"></a><span class="lineno"><a class="line" href="neorv32__gptmr_8h.html#a135b0750d4afed16e5867134e3843988ae4716a7a9e356484a8e478f07920cde3"> 41</a></span> <a class="code hl_enumvalue" href="neorv32__gptmr_8h.html#a135b0750d4afed16e5867134e3843988ae4716a7a9e356484a8e478f07920cde3">GPTMR_CTRL_PRSC0</a> = 1, </div> +<div class="line"><a id="l00042" name="l00042"></a><span class="lineno"><a class="line" href="neorv32__gptmr_8h.html#a135b0750d4afed16e5867134e3843988a1e1e8e516fa4918441e3c77153940298"> 42</a></span> <a class="code hl_enumvalue" href="neorv32__gptmr_8h.html#a135b0750d4afed16e5867134e3843988a1e1e8e516fa4918441e3c77153940298">GPTMR_CTRL_PRSC1</a> = 2, </div> +<div class="line"><a id="l00043" name="l00043"></a><span class="lineno"><a class="line" href="neorv32__gptmr_8h.html#a135b0750d4afed16e5867134e3843988a185861fbdc5f276735481237ad844833"> 43</a></span> <a class="code hl_enumvalue" href="neorv32__gptmr_8h.html#a135b0750d4afed16e5867134e3843988a185861fbdc5f276735481237ad844833">GPTMR_CTRL_PRSC2</a> = 3, </div> +<div class="line"><a id="l00044" name="l00044"></a><span class="lineno"><a class="line" href="neorv32__gptmr_8h.html#a135b0750d4afed16e5867134e3843988a473870880c0eca71578d6969e816af43"> 44</a></span> <a class="code hl_enumvalue" href="neorv32__gptmr_8h.html#a135b0750d4afed16e5867134e3843988a473870880c0eca71578d6969e816af43">GPTMR_CTRL_MODE</a> = 4, </div> +<div class="line"><a id="l00046" name="l00046"></a><span class="lineno"><a class="line" href="neorv32__gptmr_8h.html#a135b0750d4afed16e5867134e3843988aadb663ad9a0dfd37fc65dffc1a289b38"> 46</a></span> <a class="code hl_enumvalue" href="neorv32__gptmr_8h.html#a135b0750d4afed16e5867134e3843988aadb663ad9a0dfd37fc65dffc1a289b38">GPTMR_CTRL_IRQ_CLR</a> = 30, </div> +<div class="line"><a id="l00047" name="l00047"></a><span class="lineno"><a class="line" href="neorv32__gptmr_8h.html#a135b0750d4afed16e5867134e3843988a3a868dc710ab9add083137e4e3fe888a"> 47</a></span> <a class="code hl_enumvalue" href="neorv32__gptmr_8h.html#a135b0750d4afed16e5867134e3843988a3a868dc710ab9add083137e4e3fe888a">GPTMR_CTRL_IRQ_PND</a> = 31, </div> +<div class="line"><a id="l00048" name="l00048"></a><span class="lineno"> 48</span>};</div> +</div> +<div class="line"><a id="l00052" name="l00052"></a><span class="lineno"> 52</span><span class="comment">/**********************************************************************/</span></div> +<div class="line"><a id="l00056" name="l00056"></a><span class="lineno"> 56</span><span class="keywordtype">int</span> <a class="code hl_function" href="neorv32__gptmr_8h.html#ae79a08c52ad3e83f9c4393acfabf035f">neorv32_gptmr_available</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00057" name="l00057"></a><span class="lineno"> 57</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__gptmr_8h.html#a6aa27efd2163eebf8fc49fe1c591708f">neorv32_gptmr_setup</a>(<span class="keywordtype">int</span> prsc, uint32_t threshold, <span class="keywordtype">int</span> cont_mode);</div> +<div class="line"><a id="l00058" name="l00058"></a><span class="lineno"> 58</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__gptmr_8h.html#a7c9bc6d28ad12611b08fa2867c2db874">neorv32_gptmr_disable</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00059" name="l00059"></a><span class="lineno"> 59</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__gptmr_8h.html#a59e684348835772a7e83446e478d4a13">neorv32_gptmr_enable</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00060" name="l00060"></a><span class="lineno"> 60</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__gptmr_8h.html#ac73aa4e41a064abb4ca554a389888e67">neorv32_gptmr_irq_ack</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00064" name="l00064"></a><span class="lineno"> 64</span><span class="preprocessor">#endif </span><span class="comment">// neorv32_gptmr_h</span></div> +<div class="ttc" id="aneorv32__gptmr_8h_html_a135b0750d4afed16e5867134e3843988"><div class="ttname"><a href="neorv32__gptmr_8h.html#a135b0750d4afed16e5867134e3843988">NEORV32_GPTMR_CTRL_enum</a></div><div class="ttdeci">NEORV32_GPTMR_CTRL_enum</div><div class="ttdef"><b>Definition</b> neorv32_gptmr.h:39</div></div> +<div class="ttc" id="aneorv32__gptmr_8h_html_a135b0750d4afed16e5867134e3843988a185861fbdc5f276735481237ad844833"><div class="ttname"><a href="neorv32__gptmr_8h.html#a135b0750d4afed16e5867134e3843988a185861fbdc5f276735481237ad844833">GPTMR_CTRL_PRSC2</a></div><div class="ttdeci">@ GPTMR_CTRL_PRSC2</div><div class="ttdef"><b>Definition</b> neorv32_gptmr.h:43</div></div> +<div class="ttc" id="aneorv32__gptmr_8h_html_a135b0750d4afed16e5867134e3843988a1e1e8e516fa4918441e3c77153940298"><div class="ttname"><a href="neorv32__gptmr_8h.html#a135b0750d4afed16e5867134e3843988a1e1e8e516fa4918441e3c77153940298">GPTMR_CTRL_PRSC1</a></div><div class="ttdeci">@ GPTMR_CTRL_PRSC1</div><div class="ttdef"><b>Definition</b> neorv32_gptmr.h:42</div></div> +<div class="ttc" id="aneorv32__gptmr_8h_html_a135b0750d4afed16e5867134e3843988a3a868dc710ab9add083137e4e3fe888a"><div class="ttname"><a href="neorv32__gptmr_8h.html#a135b0750d4afed16e5867134e3843988a3a868dc710ab9add083137e4e3fe888a">GPTMR_CTRL_IRQ_PND</a></div><div class="ttdeci">@ GPTMR_CTRL_IRQ_PND</div><div class="ttdef"><b>Definition</b> neorv32_gptmr.h:47</div></div> +<div class="ttc" id="aneorv32__gptmr_8h_html_a135b0750d4afed16e5867134e3843988a473870880c0eca71578d6969e816af43"><div class="ttname"><a href="neorv32__gptmr_8h.html#a135b0750d4afed16e5867134e3843988a473870880c0eca71578d6969e816af43">GPTMR_CTRL_MODE</a></div><div class="ttdeci">@ GPTMR_CTRL_MODE</div><div class="ttdef"><b>Definition</b> neorv32_gptmr.h:44</div></div> +<div class="ttc" id="aneorv32__gptmr_8h_html_a135b0750d4afed16e5867134e3843988aadb663ad9a0dfd37fc65dffc1a289b38"><div class="ttname"><a href="neorv32__gptmr_8h.html#a135b0750d4afed16e5867134e3843988aadb663ad9a0dfd37fc65dffc1a289b38">GPTMR_CTRL_IRQ_CLR</a></div><div class="ttdeci">@ GPTMR_CTRL_IRQ_CLR</div><div class="ttdef"><b>Definition</b> neorv32_gptmr.h:46</div></div> +<div class="ttc" id="aneorv32__gptmr_8h_html_a135b0750d4afed16e5867134e3843988abbfa7abcbd80b9c47e83e23e5cefaf90"><div class="ttname"><a href="neorv32__gptmr_8h.html#a135b0750d4afed16e5867134e3843988abbfa7abcbd80b9c47e83e23e5cefaf90">GPTMR_CTRL_EN</a></div><div class="ttdeci">@ GPTMR_CTRL_EN</div><div class="ttdef"><b>Definition</b> neorv32_gptmr.h:40</div></div> +<div class="ttc" id="aneorv32__gptmr_8h_html_a135b0750d4afed16e5867134e3843988ae4716a7a9e356484a8e478f07920cde3"><div class="ttname"><a href="neorv32__gptmr_8h.html#a135b0750d4afed16e5867134e3843988ae4716a7a9e356484a8e478f07920cde3">GPTMR_CTRL_PRSC0</a></div><div class="ttdeci">@ GPTMR_CTRL_PRSC0</div><div class="ttdef"><b>Definition</b> neorv32_gptmr.h:41</div></div> +<div class="ttc" id="aneorv32__gptmr_8h_html_a59e684348835772a7e83446e478d4a13"><div class="ttname"><a href="neorv32__gptmr_8h.html#a59e684348835772a7e83446e478d4a13">neorv32_gptmr_enable</a></div><div class="ttdeci">void neorv32_gptmr_enable(void)</div><div class="ttdef"><b>Definition</b> neorv32_gptmr.c:69</div></div> +<div class="ttc" id="aneorv32__gptmr_8h_html_a6aa27efd2163eebf8fc49fe1c591708f"><div class="ttname"><a href="neorv32__gptmr_8h.html#a6aa27efd2163eebf8fc49fe1c591708f">neorv32_gptmr_setup</a></div><div class="ttdeci">void neorv32_gptmr_setup(int prsc, uint32_t threshold, int cont_mode)</div><div class="ttdef"><b>Definition</b> neorv32_gptmr.c:44</div></div> +<div class="ttc" id="aneorv32__gptmr_8h_html_a7c9bc6d28ad12611b08fa2867c2db874"><div class="ttname"><a href="neorv32__gptmr_8h.html#a7c9bc6d28ad12611b08fa2867c2db874">neorv32_gptmr_disable</a></div><div class="ttdeci">void neorv32_gptmr_disable(void)</div><div class="ttdef"><b>Definition</b> neorv32_gptmr.c:60</div></div> +<div class="ttc" id="aneorv32__gptmr_8h_html_ac73aa4e41a064abb4ca554a389888e67"><div class="ttname"><a href="neorv32__gptmr_8h.html#ac73aa4e41a064abb4ca554a389888e67">neorv32_gptmr_irq_ack</a></div><div class="ttdeci">void neorv32_gptmr_irq_ack(void)</div><div class="ttdef"><b>Definition</b> neorv32_gptmr.c:78</div></div> +<div class="ttc" id="aneorv32__gptmr_8h_html_ae79a08c52ad3e83f9c4393acfabf035f"><div class="ttname"><a href="neorv32__gptmr_8h.html#ae79a08c52ad3e83f9c4393acfabf035f">neorv32_gptmr_available</a></div><div class="ttdeci">int neorv32_gptmr_available(void)</div><div class="ttdef"><b>Definition</b> neorv32_gptmr.c:26</div></div> +<div class="ttc" id="astructneorv32__gptmr__t_html"><div class="ttname"><a href="structneorv32__gptmr__t.html">neorv32_gptmr_t</a></div><div class="ttdef"><b>Definition</b> neorv32_gptmr.h:29</div></div> +<div class="ttc" id="astructneorv32__gptmr__t_html_a1abc5bae1dffc64006e965d4570da479"><div class="ttname"><a href="structneorv32__gptmr__t.html#a1abc5bae1dffc64006e965d4570da479">neorv32_gptmr_t::COUNT</a></div><div class="ttdeci">const uint32_t COUNT</div><div class="ttdef"><b>Definition</b> neorv32_gptmr.h:32</div></div> +<div class="ttc" id="astructneorv32__gptmr__t_html_a3c477ccb24ed12122d9d90244431c7e9"><div class="ttname"><a href="structneorv32__gptmr__t.html#a3c477ccb24ed12122d9d90244431c7e9">neorv32_gptmr_t::CTRL</a></div><div class="ttdeci">uint32_t CTRL</div><div class="ttdef"><b>Definition</b> neorv32_gptmr.h:30</div></div> +<div class="ttc" id="astructneorv32__gptmr__t_html_a666ebcbea13dafcf1987629f3e0092ee"><div class="ttname"><a href="structneorv32__gptmr__t.html#a666ebcbea13dafcf1987629f3e0092ee">neorv32_gptmr_t::THRES</a></div><div class="ttdeci">uint32_t THRES</div><div class="ttdef"><b>Definition</b> neorv32_gptmr.h:31</div></div> +</div><!-- fragment --></div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/neorv32__intrinsics_8h.html b/sw/neorv32__intrinsics_8h.html new file mode 100644 index 0000000000..b4b1e8d58d --- /dev/null +++ b/sw/neorv32__intrinsics_8h.html @@ -0,0 +1,451 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/lib/include/neorv32_intrinsics.h File Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_7d04193005ada6f9450f847f4adb6b5b.html">lib</a></li><li class="navelem"><a class="el" href="dir_752b1e5d3973bf735fa78bf6b4727df9.html">include</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="headertitle"><div class="title">neorv32_intrinsics.h File Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p>Helper functions and macros for custom "intrinsics" / instructions. +<a href="#details">More...</a></p> +<div class="textblock"><code>#include &lt;stdint.h&gt;</code><br /> +</div> +<p><a href="neorv32__intrinsics_8h_source.html">Go to the source code of this file.</a></p> +<table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="define-members" name="define-members"></a> +Macros</h2></td></tr> +<tr><td colspan="2"><div class="groupHeader">R2-type instruction format, RISC-V-standard</div></td></tr> +<tr class="memitem:affee8dbe3b5c3d9276d746f3123a1852" id="r_affee8dbe3b5c3d9276d746f3123a1852"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#affee8dbe3b5c3d9276d746f3123a1852">CUSTOM_INSTR_R2_TYPE</a>(funct7, funct5, rs1, funct3, opcode)</td></tr> +<tr class="separator:affee8dbe3b5c3d9276d746f3123a1852"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr><td colspan="2"><div class="groupHeader">R3-type instruction format, RISC-V-standard</div></td></tr> +<tr class="memitem:aaace8054623412d7799d6796a4e2b0cf" id="r_aaace8054623412d7799d6796a4e2b0cf"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aaace8054623412d7799d6796a4e2b0cf">CUSTOM_INSTR_R3_TYPE</a>(funct7, rs2, rs1, funct3, opcode)</td></tr> +<tr class="separator:aaace8054623412d7799d6796a4e2b0cf"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr><td colspan="2"><div class="groupHeader">R4-type instruction format, RISC-V-standard</div></td></tr> +<tr class="memitem:ac9c2ca822c98631d8ac29b016c679723" id="r_ac9c2ca822c98631d8ac29b016c679723"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ac9c2ca822c98631d8ac29b016c679723">CUSTOM_INSTR_R4_TYPE</a>(rs3, rs2, rs1, funct3, opcode)</td></tr> +<tr class="separator:ac9c2ca822c98631d8ac29b016c679723"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr><td colspan="2"><div class="groupHeader">R5-type instruction format</div></td></tr> +<tr><td colspan="2"><div class="groupText"><dl class="section warning"><dt>Warning</dt><dd>NOT RISC-V-standard, NEORV32-specific! </dd></dl> +</div></td></tr> +<tr class="memitem:a42cd37e1e6341d5a1142d6720c9af960" id="r_a42cd37e1e6341d5a1142d6720c9af960"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a42cd37e1e6341d5a1142d6720c9af960">CUSTOM_INSTR_R5_TYPE</a>(rs4, rs3, rs2, rs1, opcode)</td></tr> +<tr class="separator:a42cd37e1e6341d5a1142d6720c9af960"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr><td colspan="2"><div class="groupHeader">I-type instruction format, RISC-V-standard</div></td></tr> +<tr class="memitem:a840b2437cd74de8a77f573b3d9d24b06" id="r_a840b2437cd74de8a77f573b3d9d24b06"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a840b2437cd74de8a77f573b3d9d24b06">CUSTOM_INSTR_I_TYPE</a>(imm12, rs1, funct3, opcode)</td></tr> +<tr class="separator:a840b2437cd74de8a77f573b3d9d24b06"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr><td colspan="2"><div class="groupHeader">S-type instruction format, RISC-V-standard</div></td></tr> +<tr class="memitem:abb4cad44dc2648f10f0e5153325c84d2" id="r_abb4cad44dc2648f10f0e5153325c84d2"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#abb4cad44dc2648f10f0e5153325c84d2">CUSTOM_INSTR_S_TYPE</a>(imm12, rs2, rs1, funct3, opcode)</td></tr> +<tr class="separator:abb4cad44dc2648f10f0e5153325c84d2"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="func-members" name="func-members"></a> +Functions</h2></td></tr> +<tr><td colspan="2"><div class="groupHeader">Register mappings</div></td></tr> +<tr class="memitem:a71b3ab3e49017d5ba7ccd89665e0cd45" id="r_a71b3ab3e49017d5ba7ccd89665e0cd45"><td class="memItemLeft" align="right" valign="top"><a id="a71b3ab3e49017d5ba7ccd89665e0cd45" name="a71b3ab3e49017d5ba7ccd89665e0cd45"></a> +&#160;</td><td class="memItemRight" valign="bottom"><b>asm</b> (&quot;.set reg_x0, 0 \n&quot; &quot;.set reg_x1, 1 \n&quot; &quot;.set reg_x2, 2 \n&quot; &quot;.set reg_x3, 3 \n&quot; &quot;.set reg_x4, 4 \n&quot; &quot;.set reg_x5, 5 \n&quot; &quot;.set reg_x6, 6 \n&quot; &quot;.set reg_x7, 7 \n&quot; &quot;.set reg_x8, 8 \n&quot; &quot;.set reg_x9, 9 \n&quot; &quot;.set reg_x10, 10 \n&quot; &quot;.set reg_x11, 11 \n&quot; &quot;.set reg_x12, 12 \n&quot; &quot;.set reg_x13, 13 \n&quot; &quot;.set reg_x14, 14 \n&quot; &quot;.set reg_x15, 15 \n&quot; &quot;.set reg_x16, 16 \n&quot; &quot;.set reg_x17, 17 \n&quot; &quot;.set reg_x18, 18 \n&quot; &quot;.set reg_x19, 19 \n&quot; &quot;.set reg_x20, 20 \n&quot; &quot;.set reg_x21, 21 \n&quot; &quot;.set reg_x22, 22 \n&quot; &quot;.set reg_x23, 23 \n&quot; &quot;.set reg_x24, 24 \n&quot; &quot;.set reg_x25, 25 \n&quot; &quot;.set reg_x26, 26 \n&quot; &quot;.set reg_x27, 27 \n&quot; &quot;.set reg_x28, 28 \n&quot; &quot;.set reg_x29, 29 \n&quot; &quot;.set reg_x30, 30 \n&quot; &quot;.set reg_x31, 31 \n&quot; &quot;.set reg_zero, 0 \n&quot; &quot;.set reg_ra, 1 \n&quot; &quot;.set reg_sp, 2 \n&quot; &quot;.set reg_gp, 3 \n&quot; &quot;.set reg_tp, 4 \n&quot; &quot;.set reg_t0, 5 \n&quot; &quot;.set reg_t1, 6 \n&quot; &quot;.set reg_t2, 7 \n&quot; &quot;.set reg_s0, 8 \n&quot; &quot;.set reg_s1, 9 \n&quot; &quot;.set reg_a0, 10 \n&quot; &quot;.set reg_a1, 11 \n&quot; &quot;.set reg_a2, 12 \n&quot; &quot;.set reg_a3, 13 \n&quot; &quot;.set reg_a4, 14 \n&quot; &quot;.set reg_a5, 15 \n&quot; &quot;.set reg_a6, 16 \n&quot; &quot;.set reg_a7, 17 \n&quot; &quot;.set reg_s2, 18 \n&quot; &quot;.set reg_s3, 19 \n&quot; &quot;.set reg_s4, 20 \n&quot; &quot;.set reg_s5, 21 \n&quot; &quot;.set reg_s6, 22 \n&quot; &quot;.set reg_s7, 23 \n&quot; &quot;.set reg_s8, 24 \n&quot; &quot;.set reg_s9, 25 \n&quot; &quot;.set reg_s10, 26 \n&quot; &quot;.set reg_s11, 27 \n&quot; &quot;.set reg_t3, 28 \n&quot; &quot;.set reg_t4, 29 \n&quot; &quot;.set reg_t5, 30 \n&quot; &quot;.set reg_t6, 31 \n&quot;)</td></tr> +<tr class="separator:a71b3ab3e49017d5ba7ccd89665e0cd45"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>Helper functions and macros for custom "intrinsics" / instructions. </p> +<dl class="section see"><dt>See also</dt><dd><a href="https://stnolting.github.io/neorv32/sw/files.html">https://stnolting.github.io/neorv32/sw/files.html</a> </dd></dl> +</div><h2 class="groupheader">Macro Definition Documentation</h2> +<a id="a840b2437cd74de8a77f573b3d9d24b06" name="a840b2437cd74de8a77f573b3d9d24b06"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a840b2437cd74de8a77f573b3d9d24b06">&#9670;&#160;</a></span>CUSTOM_INSTR_I_TYPE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define CUSTOM_INSTR_I_TYPE</td> + <td>(</td> + <td class="paramtype"></td> <td class="paramname"><span class="paramname"><em>imm12</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype"></td> <td class="paramname"><span class="paramname"><em>rs1</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype"></td> <td class="paramname"><span class="paramname"><em>funct3</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype"></td> <td class="paramname"><span class="paramname"><em>opcode</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<b>Value:</b><div class="fragment"><div class="line">({ \</div> +<div class="line"> uint32_t __return; \</div> +<div class="line"> <span class="keyword">asm</span> <span class="keyword">volatile</span> ( \</div> +<div class="line"> <span class="stringliteral">&quot;&quot;</span> \</div> +<div class="line"> : [output] <span class="stringliteral">&quot;=r&quot;</span> (__return) \</div> +<div class="line"> : [input_i] <span class="stringliteral">&quot;r&quot;</span> (rs1) \</div> +<div class="line"> ); \</div> +<div class="line"> <span class="keyword">asm</span> <span class="keyword">volatile</span> ( \</div> +<div class="line"> <span class="stringliteral">&quot;.word ( \ (((&quot;</span> #imm12 <span class="stringliteral">&quot;) &amp; 0xfff) &lt;&lt; 20) | \ ((( reg_%1 ) &amp; 0x1f) &lt;&lt; 15) | \ (((&quot;</span> #funct3 <span class="stringliteral">&quot;) &amp; 0x07) &lt;&lt; 12) | \ ((( reg_%0 ) &amp; 0x1f) &lt;&lt; 7) | \ (((&quot;</span> #opcode <span class="stringliteral">&quot;) &amp; 0x7f) &lt;&lt; 0) \ );&quot;</span> \</div> +<div class="line"> : [rd] <span class="stringliteral">&quot;=r&quot;</span> (__return) \</div> +<div class="line"> : <span class="stringliteral">&quot;r&quot;</span> (rs1) \</div> +<div class="line"> ); \</div> +<div class="line"> __return; \</div> +<div class="line">})</div> +</div><!-- fragment --> +</div> +</div> +<a id="affee8dbe3b5c3d9276d746f3123a1852" name="affee8dbe3b5c3d9276d746f3123a1852"></a> +<h2 class="memtitle"><span class="permalink"><a href="#affee8dbe3b5c3d9276d746f3123a1852">&#9670;&#160;</a></span>CUSTOM_INSTR_R2_TYPE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define CUSTOM_INSTR_R2_TYPE</td> + <td>(</td> + <td class="paramtype"></td> <td class="paramname"><span class="paramname"><em>funct7</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype"></td> <td class="paramname"><span class="paramname"><em>funct5</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype"></td> <td class="paramname"><span class="paramname"><em>rs1</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype"></td> <td class="paramname"><span class="paramname"><em>funct3</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype"></td> <td class="paramname"><span class="paramname"><em>opcode</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<b>Value:</b><div class="fragment"><div class="line">({ \</div> +<div class="line"> uint32_t __return; \</div> +<div class="line"> <span class="keyword">asm</span> <span class="keyword">volatile</span> ( \</div> +<div class="line"> <span class="stringliteral">&quot;&quot;</span> \</div> +<div class="line"> : [output] <span class="stringliteral">&quot;=r&quot;</span> (__return) \</div> +<div class="line"> : [input_i] <span class="stringliteral">&quot;r&quot;</span> (rs1) \</div> +<div class="line"> ); \</div> +<div class="line"> <span class="keyword">asm</span> <span class="keyword">volatile</span>( \</div> +<div class="line"> <span class="stringliteral">&quot;.word ( \ (((&quot;</span> #funct7 <span class="stringliteral">&quot;) &amp; 0x7f) &lt;&lt; 25) | \ (((&quot;</span> #funct5 <span class="stringliteral">&quot;) &amp; 0x1f) &lt;&lt; 20) | \ ((( reg_%1 ) &amp; 0x1f) &lt;&lt; 15) | \ (((&quot;</span> #funct3 <span class="stringliteral">&quot;) &amp; 0x07) &lt;&lt; 12) | \ ((( reg_%0 ) &amp; 0x1f) &lt;&lt; 7) | \ (((&quot;</span> #opcode <span class="stringliteral">&quot;) &amp; 0x7f) &lt;&lt; 0) \ );&quot;</span> \</div> +<div class="line"> : [rd] <span class="stringliteral">&quot;=r&quot;</span> (__return) \</div> +<div class="line"> : <span class="stringliteral">&quot;r&quot;</span> (rs1) \</div> +<div class="line"> ); \</div> +<div class="line"> __return; \</div> +<div class="line">})</div> +</div><!-- fragment --> +</div> +</div> +<a id="aaace8054623412d7799d6796a4e2b0cf" name="aaace8054623412d7799d6796a4e2b0cf"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aaace8054623412d7799d6796a4e2b0cf">&#9670;&#160;</a></span>CUSTOM_INSTR_R3_TYPE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define CUSTOM_INSTR_R3_TYPE</td> + <td>(</td> + <td class="paramtype"></td> <td class="paramname"><span class="paramname"><em>funct7</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype"></td> <td class="paramname"><span class="paramname"><em>rs2</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype"></td> <td class="paramname"><span class="paramname"><em>rs1</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype"></td> <td class="paramname"><span class="paramname"><em>funct3</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype"></td> <td class="paramname"><span class="paramname"><em>opcode</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<b>Value:</b><div class="fragment"><div class="line">({ \</div> +<div class="line"> uint32_t __return; \</div> +<div class="line"> <span class="keyword">asm</span> <span class="keyword">volatile</span> ( \</div> +<div class="line"> <span class="stringliteral">&quot;&quot;</span> \</div> +<div class="line"> : [output] <span class="stringliteral">&quot;=r&quot;</span> (__return) \</div> +<div class="line"> : [input_i] <span class="stringliteral">&quot;r&quot;</span> (rs1), \</div> +<div class="line"> [input_j] <span class="stringliteral">&quot;r&quot;</span> (rs2) \</div> +<div class="line"> ); \</div> +<div class="line"> <span class="keyword">asm</span> <span class="keyword">volatile</span> ( \</div> +<div class="line"> <span class="stringliteral">&quot;.word ( \ (((&quot;</span> #funct7 <span class="stringliteral">&quot;) &amp; 0x7f) &lt;&lt; 25) | \ ((( reg_%2 ) &amp; 0x1f) &lt;&lt; 20) | \ ((( reg_%1 ) &amp; 0x1f) &lt;&lt; 15) | \ (((&quot;</span> #funct3 <span class="stringliteral">&quot;) &amp; 0x07) &lt;&lt; 12) | \ ((( reg_%0 ) &amp; 0x1f) &lt;&lt; 7) | \ (((&quot;</span> #opcode <span class="stringliteral">&quot;) &amp; 0x7f) &lt;&lt; 0) \ );&quot;</span> \</div> +<div class="line"> : [rd] <span class="stringliteral">&quot;=r&quot;</span> (__return) \</div> +<div class="line"> : <span class="stringliteral">&quot;r&quot;</span> (rs1), \</div> +<div class="line"> <span class="stringliteral">&quot;r&quot;</span> (rs2) \</div> +<div class="line"> ); \</div> +<div class="line"> __return; \</div> +<div class="line">})</div> +</div><!-- fragment --> +</div> +</div> +<a id="ac9c2ca822c98631d8ac29b016c679723" name="ac9c2ca822c98631d8ac29b016c679723"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ac9c2ca822c98631d8ac29b016c679723">&#9670;&#160;</a></span>CUSTOM_INSTR_R4_TYPE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define CUSTOM_INSTR_R4_TYPE</td> + <td>(</td> + <td class="paramtype"></td> <td class="paramname"><span class="paramname"><em>rs3</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype"></td> <td class="paramname"><span class="paramname"><em>rs2</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype"></td> <td class="paramname"><span class="paramname"><em>rs1</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype"></td> <td class="paramname"><span class="paramname"><em>funct3</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype"></td> <td class="paramname"><span class="paramname"><em>opcode</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<b>Value:</b><div class="fragment"><div class="line">({ \</div> +<div class="line"> uint32_t __return; \</div> +<div class="line"> <span class="keyword">asm</span> <span class="keyword">volatile</span> ( \</div> +<div class="line"> <span class="stringliteral">&quot;&quot;</span> \</div> +<div class="line"> : [output] <span class="stringliteral">&quot;=r&quot;</span> (__return) \</div> +<div class="line"> : [input_i] <span class="stringliteral">&quot;r&quot;</span> (rs1), \</div> +<div class="line"> [input_j] <span class="stringliteral">&quot;r&quot;</span> (rs2), \</div> +<div class="line"> [input_k] <span class="stringliteral">&quot;r&quot;</span> (rs3) \</div> +<div class="line"> ); \</div> +<div class="line"> <span class="keyword">asm</span> <span class="keyword">volatile</span> ( \</div> +<div class="line"> <span class="stringliteral">&quot;.word ( \ ((( reg_%3 ) &amp; 0x1f) &lt;&lt; 27) | \ ((( reg_%2 ) &amp; 0x1f) &lt;&lt; 20) | \ ((( reg_%1 ) &amp; 0x1f) &lt;&lt; 15) | \ (((&quot;</span> #funct3 <span class="stringliteral">&quot;) &amp; 0x07) &lt;&lt; 12) | \ ((( reg_%0 ) &amp; 0x1f) &lt;&lt; 7) | \ (((&quot;</span> #opcode <span class="stringliteral">&quot;) &amp; 0x7f) &lt;&lt; 0) \ );&quot;</span> \</div> +<div class="line"> : [rd] <span class="stringliteral">&quot;=r&quot;</span> (__return) \</div> +<div class="line"> : <span class="stringliteral">&quot;r&quot;</span> (rs1), \</div> +<div class="line"> <span class="stringliteral">&quot;r&quot;</span> (rs2), \</div> +<div class="line"> <span class="stringliteral">&quot;r&quot;</span> (rs3) \</div> +<div class="line"> ); \</div> +<div class="line"> __return; \</div> +<div class="line">})</div> +</div><!-- fragment --> +</div> +</div> +<a id="a42cd37e1e6341d5a1142d6720c9af960" name="a42cd37e1e6341d5a1142d6720c9af960"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a42cd37e1e6341d5a1142d6720c9af960">&#9670;&#160;</a></span>CUSTOM_INSTR_R5_TYPE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define CUSTOM_INSTR_R5_TYPE</td> + <td>(</td> + <td class="paramtype"></td> <td class="paramname"><span class="paramname"><em>rs4</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype"></td> <td class="paramname"><span class="paramname"><em>rs3</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype"></td> <td class="paramname"><span class="paramname"><em>rs2</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype"></td> <td class="paramname"><span class="paramname"><em>rs1</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype"></td> <td class="paramname"><span class="paramname"><em>opcode</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<b>Value:</b><div class="fragment"><div class="line">({ \</div> +<div class="line"> uint32_t __return; \</div> +<div class="line"> <span class="keyword">asm</span> <span class="keyword">volatile</span> ( \</div> +<div class="line"> <span class="stringliteral">&quot;&quot;</span> \</div> +<div class="line"> : [output] <span class="stringliteral">&quot;=r&quot;</span> (__return) \</div> +<div class="line"> : [input_i] <span class="stringliteral">&quot;r&quot;</span> (rs1), \</div> +<div class="line"> [input_j] <span class="stringliteral">&quot;r&quot;</span> (rs2), \</div> +<div class="line"> [input_k] <span class="stringliteral">&quot;r&quot;</span> (rs3), \</div> +<div class="line"> [input_l] <span class="stringliteral">&quot;r&quot;</span> (rs4) \</div> +<div class="line"> ); \</div> +<div class="line"> <span class="keyword">asm</span> <span class="keyword">volatile</span> ( \</div> +<div class="line"> <span class="stringliteral">&quot;.word ( \ ((( reg_%3 ) &amp; 0x1f) &lt;&lt; 27) | \ (((( reg_%4 ) &gt;&gt; 3) &amp; 0x03) &lt;&lt; 25) | \ ((( reg_%2 ) &amp; 0x1f) &lt;&lt; 20) | \ ((( reg_%1 ) &amp; 0x1f) &lt;&lt; 15) | \ ((( reg_%4 ) &amp; 0x07) &lt;&lt; 12) | \ ((( reg_%0 ) &amp; 0x1f) &lt;&lt; 7) | \ (((&quot;</span> #opcode <span class="stringliteral">&quot;) &amp; 0x7f) &lt;&lt; 0) \ );&quot;</span> \</div> +<div class="line"> : [rd] <span class="stringliteral">&quot;=r&quot;</span> (__return) \</div> +<div class="line"> : <span class="stringliteral">&quot;r&quot;</span> (rs1), \</div> +<div class="line"> <span class="stringliteral">&quot;r&quot;</span> (rs2), \</div> +<div class="line"> <span class="stringliteral">&quot;r&quot;</span> (rs3), \</div> +<div class="line"> <span class="stringliteral">&quot;r&quot;</span> (rs4) \</div> +<div class="line"> ); \</div> +<div class="line"> __return; \</div> +<div class="line">})</div> +</div><!-- fragment --> +</div> +</div> +<a id="abb4cad44dc2648f10f0e5153325c84d2" name="abb4cad44dc2648f10f0e5153325c84d2"></a> +<h2 class="memtitle"><span class="permalink"><a href="#abb4cad44dc2648f10f0e5153325c84d2">&#9670;&#160;</a></span>CUSTOM_INSTR_S_TYPE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define CUSTOM_INSTR_S_TYPE</td> + <td>(</td> + <td class="paramtype"></td> <td class="paramname"><span class="paramname"><em>imm12</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype"></td> <td class="paramname"><span class="paramname"><em>rs2</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype"></td> <td class="paramname"><span class="paramname"><em>rs1</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype"></td> <td class="paramname"><span class="paramname"><em>funct3</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype"></td> <td class="paramname"><span class="paramname"><em>opcode</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<b>Value:</b><div class="fragment"><div class="line">({ \</div> +<div class="line"> <span class="keyword">asm</span> <span class="keyword">volatile</span> ( \</div> +<div class="line"> <span class="stringliteral">&quot;&quot;</span> \</div> +<div class="line"> : \</div> +<div class="line"> : [input_i] <span class="stringliteral">&quot;r&quot;</span> (rs1), \</div> +<div class="line"> [input_j] <span class="stringliteral">&quot;r&quot;</span> (rs2) \</div> +<div class="line"> ); \</div> +<div class="line"> <span class="keyword">asm</span> <span class="keyword">volatile</span> ( \</div> +<div class="line"> <span class="stringliteral">&quot;.word ( \ ((((&quot;</span> #imm12 <span class="stringliteral">&quot;) &gt;&gt; 5) &amp; 0x7f) &lt;&lt; 25) | \ ((( reg_%1 ) &amp; 0x1f) &lt;&lt; 20) | \ ((( reg_%0 ) &amp; 0x1f) &lt;&lt; 15) | \ (((&quot;</span> #funct3 <span class="stringliteral">&quot;) &amp; 0x07) &lt;&lt; 12) | \ (((&quot;</span> #imm12 <span class="stringliteral">&quot;) &amp; 0x1f) &lt;&lt; 7) | \ (((&quot;</span> #opcode <span class="stringliteral">&quot;) &amp; 0x7f) &lt;&lt; 0) \ );&quot;</span> \</div> +<div class="line"> : \</div> +<div class="line"> : <span class="stringliteral">&quot;r&quot;</span> (rs1), \</div> +<div class="line"> <span class="stringliteral">&quot;r&quot;</span> (rs2) \</div> +<div class="line"> ); \</div> +<div class="line">})</div> +</div><!-- fragment --> +</div> +</div> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/neorv32__intrinsics_8h_source.html b/sw/neorv32__intrinsics_8h_source.html new file mode 100644 index 0000000000..62be1eaa88 --- /dev/null +++ b/sw/neorv32__intrinsics_8h_source.html @@ -0,0 +1,389 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/lib/include/neorv32_intrinsics.h Source File</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_7d04193005ada6f9450f847f4adb6b5b.html">lib</a></li><li class="navelem"><a class="el" href="dir_752b1e5d3973bf735fa78bf6b4727df9.html">include</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="headertitle"><div class="title">neorv32_intrinsics.h</div></div> +</div><!--header--> +<div class="contents"> +<a href="neorv32__intrinsics_8h.html">Go to the documentation of this file.</a><div class="fragment"><div class="line"><a id="l00001" name="l00001"></a><span class="lineno"> 1</span><span class="comment">// ================================================================================ //</span></div> +<div class="line"><a id="l00002" name="l00002"></a><span class="lineno"> 2</span><span class="comment">// The NEORV32 RISC-V Processor - https://github.com/stnolting/neorv32 //</span></div> +<div class="line"><a id="l00003" name="l00003"></a><span class="lineno"> 3</span><span class="comment">// Copyright (c) NEORV32 contributors. //</span></div> +<div class="line"><a id="l00004" name="l00004"></a><span class="lineno"> 4</span><span class="comment">// Copyright (c) 2020 - 2024 Stephan Nolting. All rights reserved. //</span></div> +<div class="line"><a id="l00005" name="l00005"></a><span class="lineno"> 5</span><span class="comment">// Licensed under the BSD-3-Clause license, see LICENSE for details. //</span></div> +<div class="line"><a id="l00006" name="l00006"></a><span class="lineno"> 6</span><span class="comment">// SPDX-License-Identifier: BSD-3-Clause //</span></div> +<div class="line"><a id="l00007" name="l00007"></a><span class="lineno"> 7</span><span class="comment">// ================================================================================ //</span></div> +<div class="line"><a id="l00008" name="l00008"></a><span class="lineno"> 8</span> </div> +<div class="line"><a id="l00016" name="l00016"></a><span class="lineno"> 16</span><span class="preprocessor">#ifndef neorv32_intrinsics_h</span></div> +<div class="line"><a id="l00017" name="l00017"></a><span class="lineno"> 17</span><span class="preprocessor">#define neorv32_intrinsics_h</span></div> +<div class="line"><a id="l00018" name="l00018"></a><span class="lineno"> 18</span> </div> +<div class="line"><a id="l00019" name="l00019"></a><span class="lineno"> 19</span><span class="preprocessor">#include &lt;stdint.h&gt;</span></div> +<div class="line"><a id="l00020" name="l00020"></a><span class="lineno"> 20</span> </div> +<div class="line"><a id="l00021" name="l00021"></a><span class="lineno"> 21</span> </div> +<div class="line"><a id="l00022" name="l00022"></a><span class="lineno"> 22</span><span class="comment">// ****************************************************************************************************************************</span></div> +<div class="line"><a id="l00023" name="l00023"></a><span class="lineno"> 23</span><span class="comment">// Custom Instruction Intrinsics</span></div> +<div class="line"><a id="l00024" name="l00024"></a><span class="lineno"> 24</span><span class="comment">// Derived from https://github.com/google/CFU-Playground/blob/dfe5c2b75a4540dab62baef1b12fd03bfa78425e/third_party/SaxonSoc/riscv.h</span></div> +<div class="line"><a id="l00025" name="l00025"></a><span class="lineno"> 25</span><span class="comment">// Original license header:</span></div> +<div class="line"><a id="l00026" name="l00026"></a><span class="lineno"> 26</span><span class="comment">//</span></div> +<div class="line"><a id="l00027" name="l00027"></a><span class="lineno"> 27</span><span class="comment">// From https://github.com/SpinalHDL/SaxonSoc/blob/dev-0.1/software/standalone/driver/riscv.h</span></div> +<div class="line"><a id="l00028" name="l00028"></a><span class="lineno"> 28</span><span class="comment">//</span></div> +<div class="line"><a id="l00029" name="l00029"></a><span class="lineno"> 29</span><span class="comment">// Copyright (c) 2019 SaxonSoc contributors</span></div> +<div class="line"><a id="l00030" name="l00030"></a><span class="lineno"> 30</span><span class="comment">//</span></div> +<div class="line"><a id="l00031" name="l00031"></a><span class="lineno"> 31</span><span class="comment">// MIT License: https://github.com/SpinalHDL/SaxonSoc/blob/dev-0.1/LICENSE</span></div> +<div class="line"><a id="l00032" name="l00032"></a><span class="lineno"> 32</span><span class="comment">//</span></div> +<div class="line"><a id="l00033" name="l00033"></a><span class="lineno"> 33</span><span class="comment">// LICENSE:</span></div> +<div class="line"><a id="l00034" name="l00034"></a><span class="lineno"> 34</span><span class="comment">// MIT License</span></div> +<div class="line"><a id="l00035" name="l00035"></a><span class="lineno"> 35</span><span class="comment">//</span></div> +<div class="line"><a id="l00036" name="l00036"></a><span class="lineno"> 36</span><span class="comment">// Copyright (c) 2019 SaxonSoc contributors</span></div> +<div class="line"><a id="l00037" name="l00037"></a><span class="lineno"> 37</span><span class="comment">//</span></div> +<div class="line"><a id="l00038" name="l00038"></a><span class="lineno"> 38</span><span class="comment">// Permission is hereby granted, free of charge, to any person obtaining a copy</span></div> +<div class="line"><a id="l00039" name="l00039"></a><span class="lineno"> 39</span><span class="comment">// of this software and associated documentation files (the &quot;Software&quot;), to deal</span></div> +<div class="line"><a id="l00040" name="l00040"></a><span class="lineno"> 40</span><span class="comment">// in the Software without restriction, including without limitation the rights</span></div> +<div class="line"><a id="l00041" name="l00041"></a><span class="lineno"> 41</span><span class="comment">// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell</span></div> +<div class="line"><a id="l00042" name="l00042"></a><span class="lineno"> 42</span><span class="comment">// copies of the Software, and to permit persons to whom the Software is</span></div> +<div class="line"><a id="l00043" name="l00043"></a><span class="lineno"> 43</span><span class="comment">// furnished to do so, subject to the following conditions:</span></div> +<div class="line"><a id="l00044" name="l00044"></a><span class="lineno"> 44</span><span class="comment">//</span></div> +<div class="line"><a id="l00045" name="l00045"></a><span class="lineno"> 45</span><span class="comment">// The above copyright notice and this permission notice shall be included in all</span></div> +<div class="line"><a id="l00046" name="l00046"></a><span class="lineno"> 46</span><span class="comment">// copies or substantial portions of the Software.</span></div> +<div class="line"><a id="l00047" name="l00047"></a><span class="lineno"> 47</span><span class="comment">//</span></div> +<div class="line"><a id="l00048" name="l00048"></a><span class="lineno"> 48</span><span class="comment">// THE SOFTWARE IS PROVIDED &quot;AS IS&quot;, WITHOUT WARRANTY OF ANY KIND, EXPRESS OR</span></div> +<div class="line"><a id="l00049" name="l00049"></a><span class="lineno"> 49</span><span class="comment">// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,</span></div> +<div class="line"><a id="l00050" name="l00050"></a><span class="lineno"> 50</span><span class="comment">// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE</span></div> +<div class="line"><a id="l00051" name="l00051"></a><span class="lineno"> 51</span><span class="comment">// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER</span></div> +<div class="line"><a id="l00052" name="l00052"></a><span class="lineno"> 52</span><span class="comment">// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,</span></div> +<div class="line"><a id="l00053" name="l00053"></a><span class="lineno"> 53</span><span class="comment">// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE</span></div> +<div class="line"><a id="l00054" name="l00054"></a><span class="lineno"> 54</span><span class="comment">// SOFTWARE.</span></div> +<div class="line"><a id="l00055" name="l00055"></a><span class="lineno"> 55</span><span class="comment">// ****************************************************************************************************************************</span></div> +<div class="line"><a id="l00056" name="l00056"></a><span class="lineno"> 56</span> </div> +<div class="line"><a id="l00057" name="l00057"></a><span class="lineno"> 57</span> </div> +<div class="line"><a id="l00058" name="l00058"></a><span class="lineno"> 58</span><span class="comment">/**********************************************************************/</span></div> +<div class="line"><a id="l00061" name="l00061"></a><span class="lineno"> 61</span><span class="keyword">asm</span> (</div> +<div class="line"><a id="l00062" name="l00062"></a><span class="lineno"> 62</span> <span class="stringliteral">&quot;.set reg_x0, 0 \n&quot;</span></div> +<div class="line"><a id="l00063" name="l00063"></a><span class="lineno"> 63</span> <span class="stringliteral">&quot;.set reg_x1, 1 \n&quot;</span></div> +<div class="line"><a id="l00064" name="l00064"></a><span class="lineno"> 64</span> <span class="stringliteral">&quot;.set reg_x2, 2 \n&quot;</span></div> +<div class="line"><a id="l00065" name="l00065"></a><span class="lineno"> 65</span> <span class="stringliteral">&quot;.set reg_x3, 3 \n&quot;</span></div> +<div class="line"><a id="l00066" name="l00066"></a><span class="lineno"> 66</span> <span class="stringliteral">&quot;.set reg_x4, 4 \n&quot;</span></div> +<div class="line"><a id="l00067" name="l00067"></a><span class="lineno"> 67</span> <span class="stringliteral">&quot;.set reg_x5, 5 \n&quot;</span></div> +<div class="line"><a id="l00068" name="l00068"></a><span class="lineno"> 68</span> <span class="stringliteral">&quot;.set reg_x6, 6 \n&quot;</span></div> +<div class="line"><a id="l00069" name="l00069"></a><span class="lineno"> 69</span> <span class="stringliteral">&quot;.set reg_x7, 7 \n&quot;</span></div> +<div class="line"><a id="l00070" name="l00070"></a><span class="lineno"> 70</span> <span class="stringliteral">&quot;.set reg_x8, 8 \n&quot;</span></div> +<div class="line"><a id="l00071" name="l00071"></a><span class="lineno"> 71</span> <span class="stringliteral">&quot;.set reg_x9, 9 \n&quot;</span></div> +<div class="line"><a id="l00072" name="l00072"></a><span class="lineno"> 72</span> <span class="stringliteral">&quot;.set reg_x10, 10 \n&quot;</span></div> +<div class="line"><a id="l00073" name="l00073"></a><span class="lineno"> 73</span> <span class="stringliteral">&quot;.set reg_x11, 11 \n&quot;</span></div> +<div class="line"><a id="l00074" name="l00074"></a><span class="lineno"> 74</span> <span class="stringliteral">&quot;.set reg_x12, 12 \n&quot;</span></div> +<div class="line"><a id="l00075" name="l00075"></a><span class="lineno"> 75</span> <span class="stringliteral">&quot;.set reg_x13, 13 \n&quot;</span></div> +<div class="line"><a id="l00076" name="l00076"></a><span class="lineno"> 76</span> <span class="stringliteral">&quot;.set reg_x14, 14 \n&quot;</span></div> +<div class="line"><a id="l00077" name="l00077"></a><span class="lineno"> 77</span> <span class="stringliteral">&quot;.set reg_x15, 15 \n&quot;</span></div> +<div class="line"><a id="l00078" name="l00078"></a><span class="lineno"> 78</span><span class="preprocessor">#ifndef __riscv_32e</span></div> +<div class="line"><a id="l00079" name="l00079"></a><span class="lineno"> 79</span> <span class="stringliteral">&quot;.set reg_x16, 16 \n&quot;</span></div> +<div class="line"><a id="l00080" name="l00080"></a><span class="lineno"> 80</span> <span class="stringliteral">&quot;.set reg_x17, 17 \n&quot;</span></div> +<div class="line"><a id="l00081" name="l00081"></a><span class="lineno"> 81</span> <span class="stringliteral">&quot;.set reg_x18, 18 \n&quot;</span></div> +<div class="line"><a id="l00082" name="l00082"></a><span class="lineno"> 82</span> <span class="stringliteral">&quot;.set reg_x19, 19 \n&quot;</span></div> +<div class="line"><a id="l00083" name="l00083"></a><span class="lineno"> 83</span> <span class="stringliteral">&quot;.set reg_x20, 20 \n&quot;</span></div> +<div class="line"><a id="l00084" name="l00084"></a><span class="lineno"> 84</span> <span class="stringliteral">&quot;.set reg_x21, 21 \n&quot;</span></div> +<div class="line"><a id="l00085" name="l00085"></a><span class="lineno"> 85</span> <span class="stringliteral">&quot;.set reg_x22, 22 \n&quot;</span></div> +<div class="line"><a id="l00086" name="l00086"></a><span class="lineno"> 86</span> <span class="stringliteral">&quot;.set reg_x23, 23 \n&quot;</span></div> +<div class="line"><a id="l00087" name="l00087"></a><span class="lineno"> 87</span> <span class="stringliteral">&quot;.set reg_x24, 24 \n&quot;</span></div> +<div class="line"><a id="l00088" name="l00088"></a><span class="lineno"> 88</span> <span class="stringliteral">&quot;.set reg_x25, 25 \n&quot;</span></div> +<div class="line"><a id="l00089" name="l00089"></a><span class="lineno"> 89</span> <span class="stringliteral">&quot;.set reg_x26, 26 \n&quot;</span></div> +<div class="line"><a id="l00090" name="l00090"></a><span class="lineno"> 90</span> <span class="stringliteral">&quot;.set reg_x27, 27 \n&quot;</span></div> +<div class="line"><a id="l00091" name="l00091"></a><span class="lineno"> 91</span> <span class="stringliteral">&quot;.set reg_x28, 28 \n&quot;</span></div> +<div class="line"><a id="l00092" name="l00092"></a><span class="lineno"> 92</span> <span class="stringliteral">&quot;.set reg_x29, 29 \n&quot;</span></div> +<div class="line"><a id="l00093" name="l00093"></a><span class="lineno"> 93</span> <span class="stringliteral">&quot;.set reg_x30, 30 \n&quot;</span></div> +<div class="line"><a id="l00094" name="l00094"></a><span class="lineno"> 94</span> <span class="stringliteral">&quot;.set reg_x31, 31 \n&quot;</span></div> +<div class="line"><a id="l00095" name="l00095"></a><span class="lineno"> 95</span><span class="preprocessor">#endif</span></div> +<div class="line"><a id="l00096" name="l00096"></a><span class="lineno"> 96</span> <span class="stringliteral">&quot;.set reg_zero, 0 \n&quot;</span></div> +<div class="line"><a id="l00097" name="l00097"></a><span class="lineno"> 97</span> <span class="stringliteral">&quot;.set reg_ra, 1 \n&quot;</span></div> +<div class="line"><a id="l00098" name="l00098"></a><span class="lineno"> 98</span> <span class="stringliteral">&quot;.set reg_sp, 2 \n&quot;</span></div> +<div class="line"><a id="l00099" name="l00099"></a><span class="lineno"> 99</span> <span class="stringliteral">&quot;.set reg_gp, 3 \n&quot;</span></div> +<div class="line"><a id="l00100" name="l00100"></a><span class="lineno"> 100</span> <span class="stringliteral">&quot;.set reg_tp, 4 \n&quot;</span></div> +<div class="line"><a id="l00101" name="l00101"></a><span class="lineno"> 101</span> <span class="stringliteral">&quot;.set reg_t0, 5 \n&quot;</span></div> +<div class="line"><a id="l00102" name="l00102"></a><span class="lineno"> 102</span> <span class="stringliteral">&quot;.set reg_t1, 6 \n&quot;</span></div> +<div class="line"><a id="l00103" name="l00103"></a><span class="lineno"> 103</span> <span class="stringliteral">&quot;.set reg_t2, 7 \n&quot;</span></div> +<div class="line"><a id="l00104" name="l00104"></a><span class="lineno"> 104</span> <span class="stringliteral">&quot;.set reg_s0, 8 \n&quot;</span></div> +<div class="line"><a id="l00105" name="l00105"></a><span class="lineno"> 105</span> <span class="stringliteral">&quot;.set reg_s1, 9 \n&quot;</span></div> +<div class="line"><a id="l00106" name="l00106"></a><span class="lineno"> 106</span> <span class="stringliteral">&quot;.set reg_a0, 10 \n&quot;</span></div> +<div class="line"><a id="l00107" name="l00107"></a><span class="lineno"> 107</span> <span class="stringliteral">&quot;.set reg_a1, 11 \n&quot;</span></div> +<div class="line"><a id="l00108" name="l00108"></a><span class="lineno"> 108</span> <span class="stringliteral">&quot;.set reg_a2, 12 \n&quot;</span></div> +<div class="line"><a id="l00109" name="l00109"></a><span class="lineno"> 109</span> <span class="stringliteral">&quot;.set reg_a3, 13 \n&quot;</span></div> +<div class="line"><a id="l00110" name="l00110"></a><span class="lineno"> 110</span> <span class="stringliteral">&quot;.set reg_a4, 14 \n&quot;</span></div> +<div class="line"><a id="l00111" name="l00111"></a><span class="lineno"> 111</span> <span class="stringliteral">&quot;.set reg_a5, 15 \n&quot;</span></div> +<div class="line"><a id="l00112" name="l00112"></a><span class="lineno"> 112</span><span class="preprocessor">#ifndef __riscv_32e</span></div> +<div class="line"><a id="l00113" name="l00113"></a><span class="lineno"> 113</span> <span class="stringliteral">&quot;.set reg_a6, 16 \n&quot;</span></div> +<div class="line"><a id="l00114" name="l00114"></a><span class="lineno"> 114</span> <span class="stringliteral">&quot;.set reg_a7, 17 \n&quot;</span></div> +<div class="line"><a id="l00115" name="l00115"></a><span class="lineno"> 115</span> <span class="stringliteral">&quot;.set reg_s2, 18 \n&quot;</span></div> +<div class="line"><a id="l00116" name="l00116"></a><span class="lineno"> 116</span> <span class="stringliteral">&quot;.set reg_s3, 19 \n&quot;</span></div> +<div class="line"><a id="l00117" name="l00117"></a><span class="lineno"> 117</span> <span class="stringliteral">&quot;.set reg_s4, 20 \n&quot;</span></div> +<div class="line"><a id="l00118" name="l00118"></a><span class="lineno"> 118</span> <span class="stringliteral">&quot;.set reg_s5, 21 \n&quot;</span></div> +<div class="line"><a id="l00119" name="l00119"></a><span class="lineno"> 119</span> <span class="stringliteral">&quot;.set reg_s6, 22 \n&quot;</span></div> +<div class="line"><a id="l00120" name="l00120"></a><span class="lineno"> 120</span> <span class="stringliteral">&quot;.set reg_s7, 23 \n&quot;</span></div> +<div class="line"><a id="l00121" name="l00121"></a><span class="lineno"> 121</span> <span class="stringliteral">&quot;.set reg_s8, 24 \n&quot;</span></div> +<div class="line"><a id="l00122" name="l00122"></a><span class="lineno"> 122</span> <span class="stringliteral">&quot;.set reg_s9, 25 \n&quot;</span></div> +<div class="line"><a id="l00123" name="l00123"></a><span class="lineno"> 123</span> <span class="stringliteral">&quot;.set reg_s10, 26 \n&quot;</span></div> +<div class="line"><a id="l00124" name="l00124"></a><span class="lineno"> 124</span> <span class="stringliteral">&quot;.set reg_s11, 27 \n&quot;</span></div> +<div class="line"><a id="l00125" name="l00125"></a><span class="lineno"> 125</span> <span class="stringliteral">&quot;.set reg_t3, 28 \n&quot;</span></div> +<div class="line"><a id="l00126" name="l00126"></a><span class="lineno"> 126</span> <span class="stringliteral">&quot;.set reg_t4, 29 \n&quot;</span></div> +<div class="line"><a id="l00127" name="l00127"></a><span class="lineno"> 127</span> <span class="stringliteral">&quot;.set reg_t5, 30 \n&quot;</span></div> +<div class="line"><a id="l00128" name="l00128"></a><span class="lineno"> 128</span> <span class="stringliteral">&quot;.set reg_t6, 31 \n&quot;</span></div> +<div class="line"><a id="l00129" name="l00129"></a><span class="lineno"> 129</span><span class="preprocessor">#endif</span></div> +<div class="line"><a id="l00130" name="l00130"></a><span class="lineno"> 130</span>);</div> +<div class="line"><a id="l00131" name="l00131"></a><span class="lineno"> 131</span> </div> +<div class="line"><a id="l00132" name="l00132"></a><span class="lineno"> 132</span> </div> +<div class="line"><a id="l00133" name="l00133"></a><span class="lineno"> 133</span><span class="comment">/**********************************************************************/</span></div> +<div class="line"><a id="l00136" name="l00136"></a><span class="lineno"> 136</span><span class="preprocessor">#define CUSTOM_INSTR_R2_TYPE(funct7, funct5, rs1, funct3, opcode) \</span></div> +<div class="line"><a id="l00137" name="l00137"></a><span class="lineno"> 137</span><span class="preprocessor">({ \</span></div> +<div class="line"><a id="l00138" name="l00138"></a><span class="lineno"> 138</span><span class="preprocessor"> uint32_t __return; \</span></div> +<div class="line"><a id="l00139" name="l00139"></a><span class="lineno"> 139</span><span class="preprocessor"> asm volatile ( \</span></div> +<div class="line"><a id="l00140" name="l00140"></a><span class="lineno"> 140</span><span class="preprocessor"> &quot;&quot; \</span></div> +<div class="line"><a id="l00141" name="l00141"></a><span class="lineno"> 141</span><span class="preprocessor"> : [output] &quot;=r&quot; (__return) \</span></div> +<div class="line"><a id="l00142" name="l00142"></a><span class="lineno"> 142</span><span class="preprocessor"> : [input_i] &quot;r&quot; (rs1) \</span></div> +<div class="line"><a id="l00143" name="l00143"></a><span class="lineno"> 143</span><span class="preprocessor"> ); \</span></div> +<div class="line"><a id="l00144" name="l00144"></a><span class="lineno"> 144</span><span class="preprocessor"> asm volatile( \</span></div> +<div class="line"><a id="l00145" name="l00145"></a><span class="lineno"> 145</span><span class="preprocessor"> &quot;.word ( \</span></div> +<div class="line"><a id="l00146" name="l00146"></a><span class="lineno"> 146</span><span class="preprocessor"> (((&quot; #funct7 &quot;) &amp; 0x7f) &lt;&lt; 25) | \</span></div> +<div class="line"><a id="l00147" name="l00147"></a><span class="lineno"> 147</span><span class="preprocessor"> (((&quot; #funct5 &quot;) &amp; 0x1f) &lt;&lt; 20) | \</span></div> +<div class="line"><a id="l00148" name="l00148"></a><span class="lineno"> 148</span><span class="preprocessor"> ((( reg_%1 ) &amp; 0x1f) &lt;&lt; 15) | \</span></div> +<div class="line"><a id="l00149" name="l00149"></a><span class="lineno"> 149</span><span class="preprocessor"> (((&quot; #funct3 &quot;) &amp; 0x07) &lt;&lt; 12) | \</span></div> +<div class="line"><a id="l00150" name="l00150"></a><span class="lineno"> 150</span><span class="preprocessor"> ((( reg_%0 ) &amp; 0x1f) &lt;&lt; 7) | \</span></div> +<div class="line"><a id="l00151" name="l00151"></a><span class="lineno"> 151</span><span class="preprocessor"> (((&quot; #opcode &quot;) &amp; 0x7f) &lt;&lt; 0) \</span></div> +<div class="line"><a id="l00152" name="l00152"></a><span class="lineno"> 152</span><span class="preprocessor"> );&quot; \</span></div> +<div class="line"><a id="l00153" name="l00153"></a><span class="lineno"> 153</span><span class="preprocessor"> : [rd] &quot;=r&quot; (__return) \</span></div> +<div class="line"><a id="l00154" name="l00154"></a><span class="lineno"> 154</span><span class="preprocessor"> : &quot;r&quot; (rs1) \</span></div> +<div class="line"><a id="l00155" name="l00155"></a><span class="lineno"> 155</span><span class="preprocessor"> ); \</span></div> +<div class="line"><a id="l00156" name="l00156"></a><span class="lineno"> 156</span><span class="preprocessor"> __return; \</span></div> +<div class="line"><a id="l00157" name="l00157"></a><span class="lineno"> 157</span><span class="preprocessor">})</span></div> +<div class="line"><a id="l00158" name="l00158"></a><span class="lineno"> 158</span> </div> +<div class="line"><a id="l00159" name="l00159"></a><span class="lineno"> 159</span> </div> +<div class="line"><a id="l00160" name="l00160"></a><span class="lineno"> 160</span><span class="comment">/**********************************************************************/</span></div> +<div class="line"><a id="l00163" name="l00163"></a><span class="lineno"> 163</span><span class="preprocessor">#define CUSTOM_INSTR_R3_TYPE(funct7, rs2, rs1, funct3, opcode) \</span></div> +<div class="line"><a id="l00164" name="l00164"></a><span class="lineno"> 164</span><span class="preprocessor">({ \</span></div> +<div class="line"><a id="l00165" name="l00165"></a><span class="lineno"> 165</span><span class="preprocessor"> uint32_t __return; \</span></div> +<div class="line"><a id="l00166" name="l00166"></a><span class="lineno"> 166</span><span class="preprocessor"> asm volatile ( \</span></div> +<div class="line"><a id="l00167" name="l00167"></a><span class="lineno"> 167</span><span class="preprocessor"> &quot;&quot; \</span></div> +<div class="line"><a id="l00168" name="l00168"></a><span class="lineno"> 168</span><span class="preprocessor"> : [output] &quot;=r&quot; (__return) \</span></div> +<div class="line"><a id="l00169" name="l00169"></a><span class="lineno"> 169</span><span class="preprocessor"> : [input_i] &quot;r&quot; (rs1), \</span></div> +<div class="line"><a id="l00170" name="l00170"></a><span class="lineno"> 170</span><span class="preprocessor"> [input_j] &quot;r&quot; (rs2) \</span></div> +<div class="line"><a id="l00171" name="l00171"></a><span class="lineno"> 171</span><span class="preprocessor"> ); \</span></div> +<div class="line"><a id="l00172" name="l00172"></a><span class="lineno"> 172</span><span class="preprocessor"> asm volatile ( \</span></div> +<div class="line"><a id="l00173" name="l00173"></a><span class="lineno"> 173</span><span class="preprocessor"> &quot;.word ( \</span></div> +<div class="line"><a id="l00174" name="l00174"></a><span class="lineno"> 174</span><span class="preprocessor"> (((&quot; #funct7 &quot;) &amp; 0x7f) &lt;&lt; 25) | \</span></div> +<div class="line"><a id="l00175" name="l00175"></a><span class="lineno"> 175</span><span class="preprocessor"> ((( reg_%2 ) &amp; 0x1f) &lt;&lt; 20) | \</span></div> +<div class="line"><a id="l00176" name="l00176"></a><span class="lineno"> 176</span><span class="preprocessor"> ((( reg_%1 ) &amp; 0x1f) &lt;&lt; 15) | \</span></div> +<div class="line"><a id="l00177" name="l00177"></a><span class="lineno"> 177</span><span class="preprocessor"> (((&quot; #funct3 &quot;) &amp; 0x07) &lt;&lt; 12) | \</span></div> +<div class="line"><a id="l00178" name="l00178"></a><span class="lineno"> 178</span><span class="preprocessor"> ((( reg_%0 ) &amp; 0x1f) &lt;&lt; 7) | \</span></div> +<div class="line"><a id="l00179" name="l00179"></a><span class="lineno"> 179</span><span class="preprocessor"> (((&quot; #opcode &quot;) &amp; 0x7f) &lt;&lt; 0) \</span></div> +<div class="line"><a id="l00180" name="l00180"></a><span class="lineno"> 180</span><span class="preprocessor"> );&quot; \</span></div> +<div class="line"><a id="l00181" name="l00181"></a><span class="lineno"> 181</span><span class="preprocessor"> : [rd] &quot;=r&quot; (__return) \</span></div> +<div class="line"><a id="l00182" name="l00182"></a><span class="lineno"> 182</span><span class="preprocessor"> : &quot;r&quot; (rs1), \</span></div> +<div class="line"><a id="l00183" name="l00183"></a><span class="lineno"> 183</span><span class="preprocessor"> &quot;r&quot; (rs2) \</span></div> +<div class="line"><a id="l00184" name="l00184"></a><span class="lineno"> 184</span><span class="preprocessor"> ); \</span></div> +<div class="line"><a id="l00185" name="l00185"></a><span class="lineno"> 185</span><span class="preprocessor"> __return; \</span></div> +<div class="line"><a id="l00186" name="l00186"></a><span class="lineno"> 186</span><span class="preprocessor">})</span></div> +<div class="line"><a id="l00187" name="l00187"></a><span class="lineno"> 187</span> </div> +<div class="line"><a id="l00188" name="l00188"></a><span class="lineno"> 188</span> </div> +<div class="line"><a id="l00189" name="l00189"></a><span class="lineno"> 189</span><span class="comment">/**********************************************************************/</span></div> +<div class="line"><a id="l00192" name="l00192"></a><span class="lineno"> 192</span><span class="preprocessor">#define CUSTOM_INSTR_R4_TYPE(rs3, rs2, rs1, funct3, opcode) \</span></div> +<div class="line"><a id="l00193" name="l00193"></a><span class="lineno"> 193</span><span class="preprocessor">({ \</span></div> +<div class="line"><a id="l00194" name="l00194"></a><span class="lineno"> 194</span><span class="preprocessor"> uint32_t __return; \</span></div> +<div class="line"><a id="l00195" name="l00195"></a><span class="lineno"> 195</span><span class="preprocessor"> asm volatile ( \</span></div> +<div class="line"><a id="l00196" name="l00196"></a><span class="lineno"> 196</span><span class="preprocessor"> &quot;&quot; \</span></div> +<div class="line"><a id="l00197" name="l00197"></a><span class="lineno"> 197</span><span class="preprocessor"> : [output] &quot;=r&quot; (__return) \</span></div> +<div class="line"><a id="l00198" name="l00198"></a><span class="lineno"> 198</span><span class="preprocessor"> : [input_i] &quot;r&quot; (rs1), \</span></div> +<div class="line"><a id="l00199" name="l00199"></a><span class="lineno"> 199</span><span class="preprocessor"> [input_j] &quot;r&quot; (rs2), \</span></div> +<div class="line"><a id="l00200" name="l00200"></a><span class="lineno"> 200</span><span class="preprocessor"> [input_k] &quot;r&quot; (rs3) \</span></div> +<div class="line"><a id="l00201" name="l00201"></a><span class="lineno"> 201</span><span class="preprocessor"> ); \</span></div> +<div class="line"><a id="l00202" name="l00202"></a><span class="lineno"> 202</span><span class="preprocessor"> asm volatile ( \</span></div> +<div class="line"><a id="l00203" name="l00203"></a><span class="lineno"> 203</span><span class="preprocessor"> &quot;.word ( \</span></div> +<div class="line"><a id="l00204" name="l00204"></a><span class="lineno"> 204</span><span class="preprocessor"> ((( reg_%3 ) &amp; 0x1f) &lt;&lt; 27) | \</span></div> +<div class="line"><a id="l00205" name="l00205"></a><span class="lineno"> 205</span><span class="preprocessor"> ((( reg_%2 ) &amp; 0x1f) &lt;&lt; 20) | \</span></div> +<div class="line"><a id="l00206" name="l00206"></a><span class="lineno"> 206</span><span class="preprocessor"> ((( reg_%1 ) &amp; 0x1f) &lt;&lt; 15) | \</span></div> +<div class="line"><a id="l00207" name="l00207"></a><span class="lineno"> 207</span><span class="preprocessor"> (((&quot; #funct3 &quot;) &amp; 0x07) &lt;&lt; 12) | \</span></div> +<div class="line"><a id="l00208" name="l00208"></a><span class="lineno"> 208</span><span class="preprocessor"> ((( reg_%0 ) &amp; 0x1f) &lt;&lt; 7) | \</span></div> +<div class="line"><a id="l00209" name="l00209"></a><span class="lineno"> 209</span><span class="preprocessor"> (((&quot; #opcode &quot;) &amp; 0x7f) &lt;&lt; 0) \</span></div> +<div class="line"><a id="l00210" name="l00210"></a><span class="lineno"> 210</span><span class="preprocessor"> );&quot; \</span></div> +<div class="line"><a id="l00211" name="l00211"></a><span class="lineno"> 211</span><span class="preprocessor"> : [rd] &quot;=r&quot; (__return) \</span></div> +<div class="line"><a id="l00212" name="l00212"></a><span class="lineno"> 212</span><span class="preprocessor"> : &quot;r&quot; (rs1), \</span></div> +<div class="line"><a id="l00213" name="l00213"></a><span class="lineno"> 213</span><span class="preprocessor"> &quot;r&quot; (rs2), \</span></div> +<div class="line"><a id="l00214" name="l00214"></a><span class="lineno"> 214</span><span class="preprocessor"> &quot;r&quot; (rs3) \</span></div> +<div class="line"><a id="l00215" name="l00215"></a><span class="lineno"> 215</span><span class="preprocessor"> ); \</span></div> +<div class="line"><a id="l00216" name="l00216"></a><span class="lineno"> 216</span><span class="preprocessor"> __return; \</span></div> +<div class="line"><a id="l00217" name="l00217"></a><span class="lineno"> 217</span><span class="preprocessor">})</span></div> +<div class="line"><a id="l00218" name="l00218"></a><span class="lineno"> 218</span> </div> +<div class="line"><a id="l00219" name="l00219"></a><span class="lineno"> 219</span> </div> +<div class="line"><a id="l00220" name="l00220"></a><span class="lineno"> 220</span><span class="comment">/**********************************************************************/</span></div> +<div class="line"><a id="l00224" name="l00224"></a><span class="lineno"> 224</span><span class="preprocessor">#define CUSTOM_INSTR_R5_TYPE(rs4, rs3, rs2, rs1, opcode) \</span></div> +<div class="line"><a id="l00225" name="l00225"></a><span class="lineno"> 225</span><span class="preprocessor">({ \</span></div> +<div class="line"><a id="l00226" name="l00226"></a><span class="lineno"> 226</span><span class="preprocessor"> uint32_t __return; \</span></div> +<div class="line"><a id="l00227" name="l00227"></a><span class="lineno"> 227</span><span class="preprocessor"> asm volatile ( \</span></div> +<div class="line"><a id="l00228" name="l00228"></a><span class="lineno"> 228</span><span class="preprocessor"> &quot;&quot; \</span></div> +<div class="line"><a id="l00229" name="l00229"></a><span class="lineno"> 229</span><span class="preprocessor"> : [output] &quot;=r&quot; (__return) \</span></div> +<div class="line"><a id="l00230" name="l00230"></a><span class="lineno"> 230</span><span class="preprocessor"> : [input_i] &quot;r&quot; (rs1), \</span></div> +<div class="line"><a id="l00231" name="l00231"></a><span class="lineno"> 231</span><span class="preprocessor"> [input_j] &quot;r&quot; (rs2), \</span></div> +<div class="line"><a id="l00232" name="l00232"></a><span class="lineno"> 232</span><span class="preprocessor"> [input_k] &quot;r&quot; (rs3), \</span></div> +<div class="line"><a id="l00233" name="l00233"></a><span class="lineno"> 233</span><span class="preprocessor"> [input_l] &quot;r&quot; (rs4) \</span></div> +<div class="line"><a id="l00234" name="l00234"></a><span class="lineno"> 234</span><span class="preprocessor"> ); \</span></div> +<div class="line"><a id="l00235" name="l00235"></a><span class="lineno"> 235</span><span class="preprocessor"> asm volatile ( \</span></div> +<div class="line"><a id="l00236" name="l00236"></a><span class="lineno"> 236</span><span class="preprocessor"> &quot;.word ( \</span></div> +<div class="line"><a id="l00237" name="l00237"></a><span class="lineno"> 237</span><span class="preprocessor"> ((( reg_%3 ) &amp; 0x1f) &lt;&lt; 27) | \</span></div> +<div class="line"><a id="l00238" name="l00238"></a><span class="lineno"> 238</span><span class="preprocessor"> (((( reg_%4 ) &gt;&gt; 3) &amp; 0x03) &lt;&lt; 25) | \</span></div> +<div class="line"><a id="l00239" name="l00239"></a><span class="lineno"> 239</span><span class="preprocessor"> ((( reg_%2 ) &amp; 0x1f) &lt;&lt; 20) | \</span></div> +<div class="line"><a id="l00240" name="l00240"></a><span class="lineno"> 240</span><span class="preprocessor"> ((( reg_%1 ) &amp; 0x1f) &lt;&lt; 15) | \</span></div> +<div class="line"><a id="l00241" name="l00241"></a><span class="lineno"> 241</span><span class="preprocessor"> ((( reg_%4 ) &amp; 0x07) &lt;&lt; 12) | \</span></div> +<div class="line"><a id="l00242" name="l00242"></a><span class="lineno"> 242</span><span class="preprocessor"> ((( reg_%0 ) &amp; 0x1f) &lt;&lt; 7) | \</span></div> +<div class="line"><a id="l00243" name="l00243"></a><span class="lineno"> 243</span><span class="preprocessor"> (((&quot; #opcode &quot;) &amp; 0x7f) &lt;&lt; 0) \</span></div> +<div class="line"><a id="l00244" name="l00244"></a><span class="lineno"> 244</span><span class="preprocessor"> );&quot; \</span></div> +<div class="line"><a id="l00245" name="l00245"></a><span class="lineno"> 245</span><span class="preprocessor"> : [rd] &quot;=r&quot; (__return) \</span></div> +<div class="line"><a id="l00246" name="l00246"></a><span class="lineno"> 246</span><span class="preprocessor"> : &quot;r&quot; (rs1), \</span></div> +<div class="line"><a id="l00247" name="l00247"></a><span class="lineno"> 247</span><span class="preprocessor"> &quot;r&quot; (rs2), \</span></div> +<div class="line"><a id="l00248" name="l00248"></a><span class="lineno"> 248</span><span class="preprocessor"> &quot;r&quot; (rs3), \</span></div> +<div class="line"><a id="l00249" name="l00249"></a><span class="lineno"> 249</span><span class="preprocessor"> &quot;r&quot; (rs4) \</span></div> +<div class="line"><a id="l00250" name="l00250"></a><span class="lineno"> 250</span><span class="preprocessor"> ); \</span></div> +<div class="line"><a id="l00251" name="l00251"></a><span class="lineno"> 251</span><span class="preprocessor"> __return; \</span></div> +<div class="line"><a id="l00252" name="l00252"></a><span class="lineno"> 252</span><span class="preprocessor">})</span></div> +<div class="line"><a id="l00253" name="l00253"></a><span class="lineno"> 253</span> </div> +<div class="line"><a id="l00254" name="l00254"></a><span class="lineno"> 254</span> </div> +<div class="line"><a id="l00255" name="l00255"></a><span class="lineno"> 255</span><span class="comment">/**********************************************************************/</span></div> +<div class="line"><a id="l00258" name="l00258"></a><span class="lineno"> 258</span><span class="preprocessor">#define CUSTOM_INSTR_I_TYPE(imm12, rs1, funct3, opcode) \</span></div> +<div class="line"><a id="l00259" name="l00259"></a><span class="lineno"> 259</span><span class="preprocessor">({ \</span></div> +<div class="line"><a id="l00260" name="l00260"></a><span class="lineno"> 260</span><span class="preprocessor"> uint32_t __return; \</span></div> +<div class="line"><a id="l00261" name="l00261"></a><span class="lineno"> 261</span><span class="preprocessor"> asm volatile ( \</span></div> +<div class="line"><a id="l00262" name="l00262"></a><span class="lineno"> 262</span><span class="preprocessor"> &quot;&quot; \</span></div> +<div class="line"><a id="l00263" name="l00263"></a><span class="lineno"> 263</span><span class="preprocessor"> : [output] &quot;=r&quot; (__return) \</span></div> +<div class="line"><a id="l00264" name="l00264"></a><span class="lineno"> 264</span><span class="preprocessor"> : [input_i] &quot;r&quot; (rs1) \</span></div> +<div class="line"><a id="l00265" name="l00265"></a><span class="lineno"> 265</span><span class="preprocessor"> ); \</span></div> +<div class="line"><a id="l00266" name="l00266"></a><span class="lineno"> 266</span><span class="preprocessor"> asm volatile ( \</span></div> +<div class="line"><a id="l00267" name="l00267"></a><span class="lineno"> 267</span><span class="preprocessor"> &quot;.word ( \</span></div> +<div class="line"><a id="l00268" name="l00268"></a><span class="lineno"> 268</span><span class="preprocessor"> (((&quot; #imm12 &quot;) &amp; 0xfff) &lt;&lt; 20) | \</span></div> +<div class="line"><a id="l00269" name="l00269"></a><span class="lineno"> 269</span><span class="preprocessor"> ((( reg_%1 ) &amp; 0x1f) &lt;&lt; 15) | \</span></div> +<div class="line"><a id="l00270" name="l00270"></a><span class="lineno"> 270</span><span class="preprocessor"> (((&quot; #funct3 &quot;) &amp; 0x07) &lt;&lt; 12) | \</span></div> +<div class="line"><a id="l00271" name="l00271"></a><span class="lineno"> 271</span><span class="preprocessor"> ((( reg_%0 ) &amp; 0x1f) &lt;&lt; 7) | \</span></div> +<div class="line"><a id="l00272" name="l00272"></a><span class="lineno"> 272</span><span class="preprocessor"> (((&quot; #opcode &quot;) &amp; 0x7f) &lt;&lt; 0) \</span></div> +<div class="line"><a id="l00273" name="l00273"></a><span class="lineno"> 273</span><span class="preprocessor"> );&quot; \</span></div> +<div class="line"><a id="l00274" name="l00274"></a><span class="lineno"> 274</span><span class="preprocessor"> : [rd] &quot;=r&quot; (__return) \</span></div> +<div class="line"><a id="l00275" name="l00275"></a><span class="lineno"> 275</span><span class="preprocessor"> : &quot;r&quot; (rs1) \</span></div> +<div class="line"><a id="l00276" name="l00276"></a><span class="lineno"> 276</span><span class="preprocessor"> ); \</span></div> +<div class="line"><a id="l00277" name="l00277"></a><span class="lineno"> 277</span><span class="preprocessor"> __return; \</span></div> +<div class="line"><a id="l00278" name="l00278"></a><span class="lineno"> 278</span><span class="preprocessor">})</span></div> +<div class="line"><a id="l00279" name="l00279"></a><span class="lineno"> 279</span> </div> +<div class="line"><a id="l00280" name="l00280"></a><span class="lineno"> 280</span> </div> +<div class="line"><a id="l00281" name="l00281"></a><span class="lineno"> 281</span><span class="comment">/**********************************************************************/</span></div> +<div class="line"><a id="l00284" name="l00284"></a><span class="lineno"> 284</span><span class="preprocessor">#define CUSTOM_INSTR_S_TYPE(imm12, rs2, rs1, funct3, opcode) \</span></div> +<div class="line"><a id="l00285" name="l00285"></a><span class="lineno"> 285</span><span class="preprocessor">({ \</span></div> +<div class="line"><a id="l00286" name="l00286"></a><span class="lineno"> 286</span><span class="preprocessor"> asm volatile ( \</span></div> +<div class="line"><a id="l00287" name="l00287"></a><span class="lineno"> 287</span><span class="preprocessor"> &quot;&quot; \</span></div> +<div class="line"><a id="l00288" name="l00288"></a><span class="lineno"> 288</span><span class="preprocessor"> : \</span></div> +<div class="line"><a id="l00289" name="l00289"></a><span class="lineno"> 289</span><span class="preprocessor"> : [input_i] &quot;r&quot; (rs1), \</span></div> +<div class="line"><a id="l00290" name="l00290"></a><span class="lineno"> 290</span><span class="preprocessor"> [input_j] &quot;r&quot; (rs2) \</span></div> +<div class="line"><a id="l00291" name="l00291"></a><span class="lineno"> 291</span><span class="preprocessor"> ); \</span></div> +<div class="line"><a id="l00292" name="l00292"></a><span class="lineno"> 292</span><span class="preprocessor"> asm volatile ( \</span></div> +<div class="line"><a id="l00293" name="l00293"></a><span class="lineno"> 293</span><span class="preprocessor"> &quot;.word ( \</span></div> +<div class="line"><a id="l00294" name="l00294"></a><span class="lineno"> 294</span><span class="preprocessor"> ((((&quot; #imm12 &quot;) &gt;&gt; 5) &amp; 0x7f) &lt;&lt; 25) | \</span></div> +<div class="line"><a id="l00295" name="l00295"></a><span class="lineno"> 295</span><span class="preprocessor"> ((( reg_%1 ) &amp; 0x1f) &lt;&lt; 20) | \</span></div> +<div class="line"><a id="l00296" name="l00296"></a><span class="lineno"> 296</span><span class="preprocessor"> ((( reg_%0 ) &amp; 0x1f) &lt;&lt; 15) | \</span></div> +<div class="line"><a id="l00297" name="l00297"></a><span class="lineno"> 297</span><span class="preprocessor"> (((&quot; #funct3 &quot;) &amp; 0x07) &lt;&lt; 12) | \</span></div> +<div class="line"><a id="l00298" name="l00298"></a><span class="lineno"> 298</span><span class="preprocessor"> (((&quot; #imm12 &quot;) &amp; 0x1f) &lt;&lt; 7) | \</span></div> +<div class="line"><a id="l00299" name="l00299"></a><span class="lineno"> 299</span><span class="preprocessor"> (((&quot; #opcode &quot;) &amp; 0x7f) &lt;&lt; 0) \</span></div> +<div class="line"><a id="l00300" name="l00300"></a><span class="lineno"> 300</span><span class="preprocessor"> );&quot; \</span></div> +<div class="line"><a id="l00301" name="l00301"></a><span class="lineno"> 301</span><span class="preprocessor"> : \</span></div> +<div class="line"><a id="l00302" name="l00302"></a><span class="lineno"> 302</span><span class="preprocessor"> : &quot;r&quot; (rs1), \</span></div> +<div class="line"><a id="l00303" name="l00303"></a><span class="lineno"> 303</span><span class="preprocessor"> &quot;r&quot; (rs2) \</span></div> +<div class="line"><a id="l00304" name="l00304"></a><span class="lineno"> 304</span><span class="preprocessor"> ); \</span></div> +<div class="line"><a id="l00305" name="l00305"></a><span class="lineno"> 305</span><span class="preprocessor">})</span></div> +<div class="line"><a id="l00306" name="l00306"></a><span class="lineno"> 306</span> </div> +<div class="line"><a id="l00307" name="l00307"></a><span class="lineno"> 307</span> </div> +<div class="line"><a id="l00308" name="l00308"></a><span class="lineno"> 308</span><span class="preprocessor">#endif </span><span class="comment">// neorv32_intrinsics_h</span></div> +</div><!-- fragment --></div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/neorv32__legacy_8h.html b/sw/neorv32__legacy_8h.html new file mode 100644 index 0000000000..ff725d29a5 --- /dev/null +++ b/sw/neorv32__legacy_8h.html @@ -0,0 +1,137 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/lib/include/neorv32_legacy.h File Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_7d04193005ada6f9450f847f4adb6b5b.html">lib</a></li><li class="navelem"><a class="el" href="dir_752b1e5d3973bf735fa78bf6b4727df9.html">include</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="headertitle"><div class="title">neorv32_legacy.h File Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p>Legacy compatibility layer. +<a href="#details">More...</a></p> +<div class="textblock"><code>#include &lt;stdint.h&gt;</code><br /> +</div> +<p><a href="neorv32__legacy_8h_source.html">Go to the source code of this file.</a></p> +<table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="define-members" name="define-members"></a> +Macros</h2></td></tr> +<tr><td colspan="2"><div class="groupHeader">GPIO aliases</div></td></tr> +<tr class="memitem:aa6756856812e72ebdbe5a1b837e13330" id="r_aa6756856812e72ebdbe5a1b837e13330"><td class="memItemLeft" align="right" valign="top"><a id="aa6756856812e72ebdbe5a1b837e13330" name="aa6756856812e72ebdbe5a1b837e13330"></a> +#define&#160;</td><td class="memItemRight" valign="bottom"><b>INPUT_LO</b>&#160;&#160;&#160;INPUT[0]</td></tr> +<tr class="separator:aa6756856812e72ebdbe5a1b837e13330"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a328faf236a6a92f47d02f68d2865e5d3" id="r_a328faf236a6a92f47d02f68d2865e5d3"><td class="memItemLeft" align="right" valign="top"><a id="a328faf236a6a92f47d02f68d2865e5d3" name="a328faf236a6a92f47d02f68d2865e5d3"></a> +#define&#160;</td><td class="memItemRight" valign="bottom"><b>INPUT_HI</b>&#160;&#160;&#160;INPUT[1]</td></tr> +<tr class="separator:a328faf236a6a92f47d02f68d2865e5d3"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a4565c54eb2281f1089b38b4fbfb23ac2" id="r_a4565c54eb2281f1089b38b4fbfb23ac2"><td class="memItemLeft" align="right" valign="top"><a id="a4565c54eb2281f1089b38b4fbfb23ac2" name="a4565c54eb2281f1089b38b4fbfb23ac2"></a> +#define&#160;</td><td class="memItemRight" valign="bottom"><b>OUTPUT_LO</b>&#160;&#160;&#160;OUTPUT[0]</td></tr> +<tr class="separator:a4565c54eb2281f1089b38b4fbfb23ac2"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ae02c208a2f93a1931c0e2e43ca51cf8c" id="r_ae02c208a2f93a1931c0e2e43ca51cf8c"><td class="memItemLeft" align="right" valign="top"><a id="ae02c208a2f93a1931c0e2e43ca51cf8c" name="ae02c208a2f93a1931c0e2e43ca51cf8c"></a> +#define&#160;</td><td class="memItemRight" valign="bottom"><b>OUTPUT_HI</b>&#160;&#160;&#160;OUTPUT[1]</td></tr> +<tr class="separator:ae02c208a2f93a1931c0e2e43ca51cf8c"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr><td colspan="2"><div class="groupHeader">Atomic LR/SC instructions</div></td></tr> +<tr class="memitem:a72a1e09e67f5ce1b522667e8e171d578" id="r_a72a1e09e67f5ce1b522667e8e171d578"><td class="memItemLeft" align="right" valign="top"><a id="a72a1e09e67f5ce1b522667e8e171d578" name="a72a1e09e67f5ce1b522667e8e171d578"></a> +#define&#160;</td><td class="memItemRight" valign="bottom"><b>neorv32_cpu_load_reservate_word</b>(addr, wdata)&#160;&#160;&#160;<a class="el" href="neorv32__cpu__amo_8h.html#ad4437bbc61a4e40d7d01dfe9459f6639">neorv32_cpu_amolr</a>(addr, wdata)</td></tr> +<tr class="separator:a72a1e09e67f5ce1b522667e8e171d578"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ac8325c90310ab06d305671b1aa169965" id="r_ac8325c90310ab06d305671b1aa169965"><td class="memItemLeft" align="right" valign="top"><a id="ac8325c90310ab06d305671b1aa169965" name="ac8325c90310ab06d305671b1aa169965"></a> +#define&#160;</td><td class="memItemRight" valign="bottom"><b>neorv32_cpu_store_conditional_word</b>(addr, wdata)&#160;&#160;&#160;<a class="el" href="neorv32__cpu__amo_8h.html#a5e73eaa273c41a06972e862976fda53c">neorv32_cpu_amosc</a>(addr, wdata)</td></tr> +<tr class="separator:ac8325c90310ab06d305671b1aa169965"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>Legacy compatibility layer. </p> +<dl class="section warning"><dt>Warning</dt><dd>Deprecated! Do not use for new designs! </dd></dl> +<dl class="section see"><dt>See also</dt><dd><a href="https://stnolting.github.io/neorv32/sw/files.html">https://stnolting.github.io/neorv32/sw/files.html</a> </dd></dl> +</div></div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/neorv32__legacy_8h_source.html b/sw/neorv32__legacy_8h_source.html new file mode 100644 index 0000000000..12d32b952a --- /dev/null +++ b/sw/neorv32__legacy_8h_source.html @@ -0,0 +1,126 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/lib/include/neorv32_legacy.h Source File</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_7d04193005ada6f9450f847f4adb6b5b.html">lib</a></li><li class="navelem"><a class="el" href="dir_752b1e5d3973bf735fa78bf6b4727df9.html">include</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="headertitle"><div class="title">neorv32_legacy.h</div></div> +</div><!--header--> +<div class="contents"> +<a href="neorv32__legacy_8h.html">Go to the documentation of this file.</a><div class="fragment"><div class="line"><a id="l00001" name="l00001"></a><span class="lineno"> 1</span><span class="comment">// ================================================================================ //</span></div> +<div class="line"><a id="l00002" name="l00002"></a><span class="lineno"> 2</span><span class="comment">// The NEORV32 RISC-V Processor - https://github.com/stnolting/neorv32 //</span></div> +<div class="line"><a id="l00003" name="l00003"></a><span class="lineno"> 3</span><span class="comment">// Copyright (c) NEORV32 contributors. //</span></div> +<div class="line"><a id="l00004" name="l00004"></a><span class="lineno"> 4</span><span class="comment">// Copyright (c) 2020 - 2024 Stephan Nolting. All rights reserved. //</span></div> +<div class="line"><a id="l00005" name="l00005"></a><span class="lineno"> 5</span><span class="comment">// Licensed under the BSD-3-Clause license, see LICENSE for details. //</span></div> +<div class="line"><a id="l00006" name="l00006"></a><span class="lineno"> 6</span><span class="comment">// SPDX-License-Identifier: BSD-3-Clause //</span></div> +<div class="line"><a id="l00007" name="l00007"></a><span class="lineno"> 7</span><span class="comment">// ================================================================================ //</span></div> +<div class="line"><a id="l00008" name="l00008"></a><span class="lineno"> 8</span> </div> +<div class="line"><a id="l00016" name="l00016"></a><span class="lineno"> 16</span><span class="preprocessor">#ifndef neorv32_legacy_h</span></div> +<div class="line"><a id="l00017" name="l00017"></a><span class="lineno"> 17</span><span class="preprocessor">#define neorv32_legacy_h</span></div> +<div class="line"><a id="l00018" name="l00018"></a><span class="lineno"> 18</span> </div> +<div class="line"><a id="l00019" name="l00019"></a><span class="lineno"> 19</span><span class="preprocessor">#include &lt;stdint.h&gt;</span></div> +<div class="line"><a id="l00020" name="l00020"></a><span class="lineno"> 20</span> </div> +<div class="line"><a id="l00021" name="l00021"></a><span class="lineno"> 21</span> </div> +<div class="line"><a id="l00022" name="l00022"></a><span class="lineno"> 22</span><span class="comment">/**********************************************************************/</span></div> +<div class="line"><a id="l00026" name="l00026"></a><span class="lineno"> 26</span><span class="preprocessor">#define INPUT_LO INPUT[0]</span></div> +<div class="line"><a id="l00027" name="l00027"></a><span class="lineno"> 27</span><span class="preprocessor">#define INPUT_HI INPUT[1]</span></div> +<div class="line"><a id="l00028" name="l00028"></a><span class="lineno"> 28</span><span class="preprocessor">#define OUTPUT_LO OUTPUT[0]</span></div> +<div class="line"><a id="l00029" name="l00029"></a><span class="lineno"> 29</span><span class="preprocessor">#define OUTPUT_HI OUTPUT[1]</span></div> +<div class="line"><a id="l00033" name="l00033"></a><span class="lineno"> 33</span><span class="comment">/**********************************************************************/</span></div> +<div class="line"><a id="l00037" name="l00037"></a><span class="lineno"> 37</span><span class="preprocessor">#define neorv32_cpu_load_reservate_word(addr, wdata) neorv32_cpu_amolr(addr, wdata)</span></div> +<div class="line"><a id="l00038" name="l00038"></a><span class="lineno"> 38</span><span class="preprocessor">#define neorv32_cpu_store_conditional_word(addr, wdata) neorv32_cpu_amosc(addr, wdata)</span></div> +<div class="line"><a id="l00042" name="l00042"></a><span class="lineno"> 42</span><span class="preprocessor">#endif </span><span class="comment">// neorv32_legacy_h</span></div> +</div><!-- fragment --></div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/neorv32__mtime_8c.html b/sw/neorv32__mtime_8c.html new file mode 100644 index 0000000000..6667f0cc3f --- /dev/null +++ b/sw/neorv32__mtime_8c.html @@ -0,0 +1,285 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/lib/source/neorv32_mtime.c File Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_7d04193005ada6f9450f847f4adb6b5b.html">lib</a></li><li class="navelem"><a class="el" href="dir_0c6ac14e2254a316d41123f98feeb67b.html">source</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#func-members">Functions</a> </div> + <div class="headertitle"><div class="title">neorv32_mtime.c File Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p>Machine System Timer (MTIME) HW driver source file. +<a href="#details">More...</a></p> +<div class="textblock"><code>#include &quot;<a class="el" href="neorv32_8h_source.html">neorv32.h</a>&quot;</code><br /> +</div><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="func-members" name="func-members"></a> +Functions</h2></td></tr> +<tr class="memitem:ab2b49a0594c66692aedf76ff9935581c" id="r_ab2b49a0594c66692aedf76ff9935581c"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ab2b49a0594c66692aedf76ff9935581c">neorv32_mtime_available</a> (void)</td></tr> +<tr class="separator:ab2b49a0594c66692aedf76ff9935581c"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a1c30809d6e887f022a7794f720243015" id="r_a1c30809d6e887f022a7794f720243015"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a1c30809d6e887f022a7794f720243015">neorv32_mtime_set_time</a> (uint64_t time)</td></tr> +<tr class="separator:a1c30809d6e887f022a7794f720243015"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:adedbbdeb71c06d2d60d3af73451de01e" id="r_adedbbdeb71c06d2d60d3af73451de01e"><td class="memItemLeft" align="right" valign="top">uint64_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#adedbbdeb71c06d2d60d3af73451de01e">neorv32_mtime_get_time</a> (void)</td></tr> +<tr class="separator:adedbbdeb71c06d2d60d3af73451de01e"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a81ff371c1aa10901264873316ee84a49" id="r_a81ff371c1aa10901264873316ee84a49"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a81ff371c1aa10901264873316ee84a49">neorv32_mtime_set_timecmp</a> (uint64_t timecmp)</td></tr> +<tr class="separator:a81ff371c1aa10901264873316ee84a49"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:acb3cc18ff8421ebd6ef471e089c23491" id="r_acb3cc18ff8421ebd6ef471e089c23491"><td class="memItemLeft" align="right" valign="top">uint64_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#acb3cc18ff8421ebd6ef471e089c23491">neorv32_mtime_get_timecmp</a> (void)</td></tr> +<tr class="separator:acb3cc18ff8421ebd6ef471e089c23491"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a022c3292c6e75095bb3ffd4c42fd4bfa" id="r_a022c3292c6e75095bb3ffd4c42fd4bfa"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a022c3292c6e75095bb3ffd4c42fd4bfa">neorv32_mtime_set_unixtime</a> (uint64_t unixtime)</td></tr> +<tr class="separator:a022c3292c6e75095bb3ffd4c42fd4bfa"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a50d08fcc3d91fc2d88b9a6a80c656f1a" id="r_a50d08fcc3d91fc2d88b9a6a80c656f1a"><td class="memItemLeft" align="right" valign="top">uint64_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a50d08fcc3d91fc2d88b9a6a80c656f1a">neorv32_mtime_get_unixtime</a> (void)</td></tr> +<tr class="separator:a50d08fcc3d91fc2d88b9a6a80c656f1a"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>Machine System Timer (MTIME) HW driver source file. </p> +<dl class="section note"><dt>Note</dt><dd>These functions should only be used if the MTIME unit was synthesized (IO_MTIME_EN = true).</dd></dl> +<dl class="section see"><dt>See also</dt><dd><a href="https://stnolting.github.io/neorv32/sw/files.html">https://stnolting.github.io/neorv32/sw/files.html</a> </dd></dl> +</div><h2 class="groupheader">Function Documentation</h2> +<a id="ab2b49a0594c66692aedf76ff9935581c" name="ab2b49a0594c66692aedf76ff9935581c"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ab2b49a0594c66692aedf76ff9935581c">&#9670;&#160;</a></span>neorv32_mtime_available()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_mtime_available </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Check if MTIME unit was synthesized.</p> +<dl class="section return"><dt>Returns</dt><dd>0 if MTIME was not synthesized, 1 if MTIME is available. </dd></dl> + +</div> +</div> +<a id="adedbbdeb71c06d2d60d3af73451de01e" name="adedbbdeb71c06d2d60d3af73451de01e"></a> +<h2 class="memtitle"><span class="permalink"><a href="#adedbbdeb71c06d2d60d3af73451de01e">&#9670;&#160;</a></span>neorv32_mtime_get_time()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint64_t neorv32_mtime_get_time </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Get current system time.</p> +<dl class="section note"><dt>Note</dt><dd>The MTIME timer increments with the primary processor clock.</dd></dl> +<dl class="section return"><dt>Returns</dt><dd>Current system time (uint64_t) </dd></dl> + +</div> +</div> +<a id="acb3cc18ff8421ebd6ef471e089c23491" name="acb3cc18ff8421ebd6ef471e089c23491"></a> +<h2 class="memtitle"><span class="permalink"><a href="#acb3cc18ff8421ebd6ef471e089c23491">&#9670;&#160;</a></span>neorv32_mtime_get_timecmp()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint64_t neorv32_mtime_get_timecmp </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Get compare time register (MTIMECMP).</p> +<dl class="section return"><dt>Returns</dt><dd>Current MTIMECMP value. </dd></dl> + +</div> +</div> +<a id="a50d08fcc3d91fc2d88b9a6a80c656f1a" name="a50d08fcc3d91fc2d88b9a6a80c656f1a"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a50d08fcc3d91fc2d88b9a6a80c656f1a">&#9670;&#160;</a></span>neorv32_mtime_get_unixtime()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint64_t neorv32_mtime_get_unixtime </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Get Unix time from TIME.</p> +<dl class="section return"><dt>Returns</dt><dd>Unix time since 00:00:00 UTC, January 1, 1970 in seconds. </dd></dl> + +</div> +</div> +<a id="a1c30809d6e887f022a7794f720243015" name="a1c30809d6e887f022a7794f720243015"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a1c30809d6e887f022a7794f720243015">&#9670;&#160;</a></span>neorv32_mtime_set_time()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_mtime_set_time </td> + <td>(</td> + <td class="paramtype">uint64_t</td> <td class="paramname"><span class="paramname"><em>time</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Set current system time.</p> +<dl class="section note"><dt>Note</dt><dd>The MTIME timer increments with the primary processor clock.</dd></dl> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">time</td><td>New system time (uint64_t) </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="a81ff371c1aa10901264873316ee84a49" name="a81ff371c1aa10901264873316ee84a49"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a81ff371c1aa10901264873316ee84a49">&#9670;&#160;</a></span>neorv32_mtime_set_timecmp()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_mtime_set_timecmp </td> + <td>(</td> + <td class="paramtype">uint64_t</td> <td class="paramname"><span class="paramname"><em>timecmp</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Set compare time register (MTIMECMP) for generating interrupts.</p> +<dl class="section note"><dt>Note</dt><dd>The interrupt is triggered when MTIME &gt;= MTIMECMP. </dd> +<dd> +Global interrupts and the timer interrupt source have to be enabled.</dd></dl> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">timecmp</td><td>System time for interrupt (uint64_t) </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="a022c3292c6e75095bb3ffd4c42fd4bfa" name="a022c3292c6e75095bb3ffd4c42fd4bfa"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a022c3292c6e75095bb3ffd4c42fd4bfa">&#9670;&#160;</a></span>neorv32_mtime_set_unixtime()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_mtime_set_unixtime </td> + <td>(</td> + <td class="paramtype">uint64_t</td> <td class="paramname"><span class="paramname"><em>unixtime</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Set TIME to Unix time.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">unixtime</td><td>Unix time since 00:00:00 UTC, January 1, 1970 in seconds. </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/neorv32__mtime_8h.html b/sw/neorv32__mtime_8h.html new file mode 100644 index 0000000000..310e245356 --- /dev/null +++ b/sw/neorv32__mtime_8h.html @@ -0,0 +1,315 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/lib/include/neorv32_mtime.h File Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_7d04193005ada6f9450f847f4adb6b5b.html">lib</a></li><li class="navelem"><a class="el" href="dir_752b1e5d3973bf735fa78bf6b4727df9.html">include</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#nested-classes">Data Structures</a> </div> + <div class="headertitle"><div class="title">neorv32_mtime.h File Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p>Machine System Timer (MTIME) HW driver header file. +<a href="#details">More...</a></p> +<div class="textblock"><code>#include &lt;stdint.h&gt;</code><br /> +</div> +<p><a href="neorv32__mtime_8h_source.html">Go to the source code of this file.</a></p> +<table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="nested-classes" name="nested-classes"></a> +Data Structures</h2></td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">struct &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structneorv32__mtime__t.html">neorv32_mtime_t</a></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="define-members" name="define-members"></a> +Macros</h2></td></tr> +<tr><td colspan="2"><div class="groupHeader">IO Device: Machine System Timer (MTIME)</div></td></tr> +<tr class="memitem:a68935be182e0081039326a9f344a36b3" id="r_a68935be182e0081039326a9f344a36b3"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a68935be182e0081039326a9f344a36b3">NEORV32_MTIME</a>&#160;&#160;&#160;((<a class="el" href="structneorv32__mtime__t.html">neorv32_mtime_t</a>*) (<a class="el" href="neorv32_8h.html#ab98f762df259a2bbc28d19d2acfe9e23">NEORV32_MTIME_BASE</a>))</td></tr> +<tr class="separator:a68935be182e0081039326a9f344a36b3"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="func-members" name="func-members"></a> +Functions</h2></td></tr> +<tr><td colspan="2"><div class="groupHeader">Prototypes</div></td></tr> +<tr class="memitem:ab2b49a0594c66692aedf76ff9935581c" id="r_ab2b49a0594c66692aedf76ff9935581c"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ab2b49a0594c66692aedf76ff9935581c">neorv32_mtime_available</a> (void)</td></tr> +<tr class="separator:ab2b49a0594c66692aedf76ff9935581c"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a1c30809d6e887f022a7794f720243015" id="r_a1c30809d6e887f022a7794f720243015"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a1c30809d6e887f022a7794f720243015">neorv32_mtime_set_time</a> (uint64_t time)</td></tr> +<tr class="separator:a1c30809d6e887f022a7794f720243015"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:adedbbdeb71c06d2d60d3af73451de01e" id="r_adedbbdeb71c06d2d60d3af73451de01e"><td class="memItemLeft" align="right" valign="top">uint64_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#adedbbdeb71c06d2d60d3af73451de01e">neorv32_mtime_get_time</a> (void)</td></tr> +<tr class="separator:adedbbdeb71c06d2d60d3af73451de01e"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a81ff371c1aa10901264873316ee84a49" id="r_a81ff371c1aa10901264873316ee84a49"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a81ff371c1aa10901264873316ee84a49">neorv32_mtime_set_timecmp</a> (uint64_t timecmp)</td></tr> +<tr class="separator:a81ff371c1aa10901264873316ee84a49"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:acb3cc18ff8421ebd6ef471e089c23491" id="r_acb3cc18ff8421ebd6ef471e089c23491"><td class="memItemLeft" align="right" valign="top">uint64_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#acb3cc18ff8421ebd6ef471e089c23491">neorv32_mtime_get_timecmp</a> (void)</td></tr> +<tr class="separator:acb3cc18ff8421ebd6ef471e089c23491"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a022c3292c6e75095bb3ffd4c42fd4bfa" id="r_a022c3292c6e75095bb3ffd4c42fd4bfa"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a022c3292c6e75095bb3ffd4c42fd4bfa">neorv32_mtime_set_unixtime</a> (uint64_t unixtime)</td></tr> +<tr class="separator:a022c3292c6e75095bb3ffd4c42fd4bfa"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a50d08fcc3d91fc2d88b9a6a80c656f1a" id="r_a50d08fcc3d91fc2d88b9a6a80c656f1a"><td class="memItemLeft" align="right" valign="top">uint64_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a50d08fcc3d91fc2d88b9a6a80c656f1a">neorv32_mtime_get_unixtime</a> (void)</td></tr> +<tr class="separator:a50d08fcc3d91fc2d88b9a6a80c656f1a"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>Machine System Timer (MTIME) HW driver header file. </p> +<dl class="section note"><dt>Note</dt><dd>These functions should only be used if the MTIME unit was synthesized (IO_MTIME_EN = true).</dd></dl> +<dl class="section see"><dt>See also</dt><dd><a href="https://stnolting.github.io/neorv32/sw/files.html">https://stnolting.github.io/neorv32/sw/files.html</a> </dd></dl> +</div><h2 class="groupheader">Macro Definition Documentation</h2> +<a id="a68935be182e0081039326a9f344a36b3" name="a68935be182e0081039326a9f344a36b3"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a68935be182e0081039326a9f344a36b3">&#9670;&#160;</a></span>NEORV32_MTIME</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define NEORV32_MTIME&#160;&#160;&#160;((<a class="el" href="structneorv32__mtime__t.html">neorv32_mtime_t</a>*) (<a class="el" href="neorv32_8h.html#ab98f762df259a2bbc28d19d2acfe9e23">NEORV32_MTIME_BASE</a>))</td> + </tr> + </table> +</div><div class="memdoc"> +<p>MTIME module hardware access (<a class="el" href="structneorv32__mtime__t.html">neorv32_mtime_t</a>) </p> + +</div> +</div> +<h2 class="groupheader">Function Documentation</h2> +<a id="ab2b49a0594c66692aedf76ff9935581c" name="ab2b49a0594c66692aedf76ff9935581c"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ab2b49a0594c66692aedf76ff9935581c">&#9670;&#160;</a></span>neorv32_mtime_available()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_mtime_available </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Check if MTIME unit was synthesized.</p> +<dl class="section return"><dt>Returns</dt><dd>0 if MTIME was not synthesized, 1 if MTIME is available. </dd></dl> + +</div> +</div> +<a id="adedbbdeb71c06d2d60d3af73451de01e" name="adedbbdeb71c06d2d60d3af73451de01e"></a> +<h2 class="memtitle"><span class="permalink"><a href="#adedbbdeb71c06d2d60d3af73451de01e">&#9670;&#160;</a></span>neorv32_mtime_get_time()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint64_t neorv32_mtime_get_time </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Get current system time.</p> +<dl class="section note"><dt>Note</dt><dd>The MTIME timer increments with the primary processor clock.</dd></dl> +<dl class="section return"><dt>Returns</dt><dd>Current system time (uint64_t) </dd></dl> + +</div> +</div> +<a id="acb3cc18ff8421ebd6ef471e089c23491" name="acb3cc18ff8421ebd6ef471e089c23491"></a> +<h2 class="memtitle"><span class="permalink"><a href="#acb3cc18ff8421ebd6ef471e089c23491">&#9670;&#160;</a></span>neorv32_mtime_get_timecmp()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint64_t neorv32_mtime_get_timecmp </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Get compare time register (MTIMECMP).</p> +<dl class="section return"><dt>Returns</dt><dd>Current MTIMECMP value. </dd></dl> + +</div> +</div> +<a id="a50d08fcc3d91fc2d88b9a6a80c656f1a" name="a50d08fcc3d91fc2d88b9a6a80c656f1a"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a50d08fcc3d91fc2d88b9a6a80c656f1a">&#9670;&#160;</a></span>neorv32_mtime_get_unixtime()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint64_t neorv32_mtime_get_unixtime </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Get Unix time from TIME.</p> +<dl class="section return"><dt>Returns</dt><dd>Unix time since 00:00:00 UTC, January 1, 1970 in seconds. </dd></dl> + +</div> +</div> +<a id="a1c30809d6e887f022a7794f720243015" name="a1c30809d6e887f022a7794f720243015"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a1c30809d6e887f022a7794f720243015">&#9670;&#160;</a></span>neorv32_mtime_set_time()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_mtime_set_time </td> + <td>(</td> + <td class="paramtype">uint64_t</td> <td class="paramname"><span class="paramname"><em>time</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Set current system time.</p> +<dl class="section note"><dt>Note</dt><dd>The MTIME timer increments with the primary processor clock.</dd></dl> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">time</td><td>New system time (uint64_t) </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="a81ff371c1aa10901264873316ee84a49" name="a81ff371c1aa10901264873316ee84a49"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a81ff371c1aa10901264873316ee84a49">&#9670;&#160;</a></span>neorv32_mtime_set_timecmp()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_mtime_set_timecmp </td> + <td>(</td> + <td class="paramtype">uint64_t</td> <td class="paramname"><span class="paramname"><em>timecmp</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Set compare time register (MTIMECMP) for generating interrupts.</p> +<dl class="section note"><dt>Note</dt><dd>The interrupt is triggered when MTIME &gt;= MTIMECMP. </dd> +<dd> +Global interrupts and the timer interrupt source have to be enabled.</dd></dl> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">timecmp</td><td>System time for interrupt (uint64_t) </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="a022c3292c6e75095bb3ffd4c42fd4bfa" name="a022c3292c6e75095bb3ffd4c42fd4bfa"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a022c3292c6e75095bb3ffd4c42fd4bfa">&#9670;&#160;</a></span>neorv32_mtime_set_unixtime()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_mtime_set_unixtime </td> + <td>(</td> + <td class="paramtype">uint64_t</td> <td class="paramname"><span class="paramname"><em>unixtime</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Set TIME to Unix time.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">unixtime</td><td>Unix time since 00:00:00 UTC, January 1, 1970 in seconds. </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/neorv32__mtime_8h_source.html b/sw/neorv32__mtime_8h_source.html new file mode 100644 index 0000000000..9af46fd99b --- /dev/null +++ b/sw/neorv32__mtime_8h_source.html @@ -0,0 +1,149 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/lib/include/neorv32_mtime.h Source File</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_7d04193005ada6f9450f847f4adb6b5b.html">lib</a></li><li class="navelem"><a class="el" href="dir_752b1e5d3973bf735fa78bf6b4727df9.html">include</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="headertitle"><div class="title">neorv32_mtime.h</div></div> +</div><!--header--> +<div class="contents"> +<a href="neorv32__mtime_8h.html">Go to the documentation of this file.</a><div class="fragment"><div class="line"><a id="l00001" name="l00001"></a><span class="lineno"> 1</span><span class="comment">// ================================================================================ //</span></div> +<div class="line"><a id="l00002" name="l00002"></a><span class="lineno"> 2</span><span class="comment">// The NEORV32 RISC-V Processor - https://github.com/stnolting/neorv32 //</span></div> +<div class="line"><a id="l00003" name="l00003"></a><span class="lineno"> 3</span><span class="comment">// Copyright (c) NEORV32 contributors. //</span></div> +<div class="line"><a id="l00004" name="l00004"></a><span class="lineno"> 4</span><span class="comment">// Copyright (c) 2020 - 2024 Stephan Nolting. All rights reserved. //</span></div> +<div class="line"><a id="l00005" name="l00005"></a><span class="lineno"> 5</span><span class="comment">// Licensed under the BSD-3-Clause license, see LICENSE for details. //</span></div> +<div class="line"><a id="l00006" name="l00006"></a><span class="lineno"> 6</span><span class="comment">// SPDX-License-Identifier: BSD-3-Clause //</span></div> +<div class="line"><a id="l00007" name="l00007"></a><span class="lineno"> 7</span><span class="comment">// ================================================================================ //</span></div> +<div class="line"><a id="l00008" name="l00008"></a><span class="lineno"> 8</span> </div> +<div class="line"><a id="l00018" name="l00018"></a><span class="lineno"> 18</span><span class="preprocessor">#ifndef neorv32_mtime_h</span></div> +<div class="line"><a id="l00019" name="l00019"></a><span class="lineno"> 19</span><span class="preprocessor">#define neorv32_mtime_h</span></div> +<div class="line"><a id="l00020" name="l00020"></a><span class="lineno"> 20</span> </div> +<div class="line"><a id="l00021" name="l00021"></a><span class="lineno"> 21</span><span class="preprocessor">#include &lt;stdint.h&gt;</span></div> +<div class="line"><a id="l00022" name="l00022"></a><span class="lineno"> 22</span> </div> +<div class="line"><a id="l00023" name="l00023"></a><span class="lineno"> 23</span> </div> +<div class="line"><a id="l00024" name="l00024"></a><span class="lineno"> 24</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen00029" data-start="{" data-end="};"> +<div class="line"><a id="l00029" name="l00029"></a><span class="lineno"><a class="line" href="structneorv32__mtime__t.html"> 29</a></span><span class="keyword">typedef</span> <span class="keyword">volatile</span> <span class="keyword">struct </span>__attribute__((packed,aligned(4))) {</div> +<div class="line"><a id="l00030" name="l00030"></a><span class="lineno"><a class="line" href="structneorv32__mtime__t.html#acccaa3dd87a57ebd5f7ae504771e904e"> 30</a></span> uint32_t <a class="code hl_variable" href="structneorv32__mtime__t.html#acccaa3dd87a57ebd5f7ae504771e904e">TIME_LO</a>; </div> +<div class="line"><a id="l00031" name="l00031"></a><span class="lineno"><a class="line" href="structneorv32__mtime__t.html#a1ffe0be2c45f5d7aa2686abf40cd1693"> 31</a></span> uint32_t <a class="code hl_variable" href="structneorv32__mtime__t.html#a1ffe0be2c45f5d7aa2686abf40cd1693">TIME_HI</a>; </div> +<div class="line"><a id="l00032" name="l00032"></a><span class="lineno"><a class="line" href="structneorv32__mtime__t.html#ab5fa56ca5c2f9d547f58d169d6da96e5"> 32</a></span> uint32_t <a class="code hl_variable" href="structneorv32__mtime__t.html#ab5fa56ca5c2f9d547f58d169d6da96e5">TIMECMP_LO</a>; </div> +<div class="line"><a id="l00033" name="l00033"></a><span class="lineno"><a class="line" href="structneorv32__mtime__t.html#af05df268c8f699401cf752e4249ba422"> 33</a></span> uint32_t <a class="code hl_variable" href="structneorv32__mtime__t.html#af05df268c8f699401cf752e4249ba422">TIMECMP_HI</a>; </div> +<div class="line"><a id="l00034" name="l00034"></a><span class="lineno"> 34</span>} <a class="code hl_struct" href="structneorv32__mtime__t.html">neorv32_mtime_t</a>;</div> +</div> +<div class="line"><a id="l00035" name="l00035"></a><span class="lineno"> 35</span> </div> +<div class="line"><a id="l00037" name="l00037"></a><span class="lineno"><a class="line" href="neorv32__mtime_8h.html#a68935be182e0081039326a9f344a36b3"> 37</a></span><span class="preprocessor">#define NEORV32_MTIME ((neorv32_mtime_t*) (NEORV32_MTIME_BASE))</span></div> +<div class="line"><a id="l00041" name="l00041"></a><span class="lineno"> 41</span><span class="comment">/**********************************************************************/</span></div> +<div class="line"><a id="l00045" name="l00045"></a><span class="lineno"> 45</span><span class="keywordtype">int</span> <a class="code hl_function" href="neorv32__mtime_8h.html#ab2b49a0594c66692aedf76ff9935581c">neorv32_mtime_available</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00046" name="l00046"></a><span class="lineno"> 46</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__mtime_8h.html#a1c30809d6e887f022a7794f720243015">neorv32_mtime_set_time</a>(uint64_t time);</div> +<div class="line"><a id="l00047" name="l00047"></a><span class="lineno"> 47</span>uint64_t <a class="code hl_function" href="neorv32__mtime_8h.html#adedbbdeb71c06d2d60d3af73451de01e">neorv32_mtime_get_time</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00048" name="l00048"></a><span class="lineno"> 48</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__mtime_8h.html#a81ff371c1aa10901264873316ee84a49">neorv32_mtime_set_timecmp</a>(uint64_t timecmp);</div> +<div class="line"><a id="l00049" name="l00049"></a><span class="lineno"> 49</span>uint64_t <a class="code hl_function" href="neorv32__mtime_8h.html#acb3cc18ff8421ebd6ef471e089c23491">neorv32_mtime_get_timecmp</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00050" name="l00050"></a><span class="lineno"> 50</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__mtime_8h.html#a022c3292c6e75095bb3ffd4c42fd4bfa">neorv32_mtime_set_unixtime</a>(uint64_t unixtime);</div> +<div class="line"><a id="l00051" name="l00051"></a><span class="lineno"> 51</span>uint64_t <a class="code hl_function" href="neorv32__mtime_8h.html#a50d08fcc3d91fc2d88b9a6a80c656f1a">neorv32_mtime_get_unixtime</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00054" name="l00054"></a><span class="lineno"> 54</span><span class="preprocessor">#endif </span><span class="comment">// neorv32_mtime_h</span></div> +<div class="ttc" id="aneorv32__mtime_8h_html_a022c3292c6e75095bb3ffd4c42fd4bfa"><div class="ttname"><a href="neorv32__mtime_8h.html#a022c3292c6e75095bb3ffd4c42fd4bfa">neorv32_mtime_set_unixtime</a></div><div class="ttdeci">void neorv32_mtime_set_unixtime(uint64_t unixtime)</div><div class="ttdef"><b>Definition</b> neorv32_mtime.c:127</div></div> +<div class="ttc" id="aneorv32__mtime_8h_html_a1c30809d6e887f022a7794f720243015"><div class="ttname"><a href="neorv32__mtime_8h.html#a1c30809d6e887f022a7794f720243015">neorv32_mtime_set_time</a></div><div class="ttdeci">void neorv32_mtime_set_time(uint64_t time)</div><div class="ttdef"><b>Definition</b> neorv32_mtime.c:44</div></div> +<div class="ttc" id="aneorv32__mtime_8h_html_a50d08fcc3d91fc2d88b9a6a80c656f1a"><div class="ttname"><a href="neorv32__mtime_8h.html#a50d08fcc3d91fc2d88b9a6a80c656f1a">neorv32_mtime_get_unixtime</a></div><div class="ttdeci">uint64_t neorv32_mtime_get_unixtime(void)</div><div class="ttdef"><b>Definition</b> neorv32_mtime.c:138</div></div> +<div class="ttc" id="aneorv32__mtime_8h_html_a81ff371c1aa10901264873316ee84a49"><div class="ttname"><a href="neorv32__mtime_8h.html#a81ff371c1aa10901264873316ee84a49">neorv32_mtime_set_timecmp</a></div><div class="ttdeci">void neorv32_mtime_set_timecmp(uint64_t timecmp)</div><div class="ttdef"><b>Definition</b> neorv32_mtime.c:93</div></div> +<div class="ttc" id="aneorv32__mtime_8h_html_ab2b49a0594c66692aedf76ff9935581c"><div class="ttname"><a href="neorv32__mtime_8h.html#ab2b49a0594c66692aedf76ff9935581c">neorv32_mtime_available</a></div><div class="ttdeci">int neorv32_mtime_available(void)</div><div class="ttdef"><b>Definition</b> neorv32_mtime.c:26</div></div> +<div class="ttc" id="aneorv32__mtime_8h_html_acb3cc18ff8421ebd6ef471e089c23491"><div class="ttname"><a href="neorv32__mtime_8h.html#acb3cc18ff8421ebd6ef471e089c23491">neorv32_mtime_get_timecmp</a></div><div class="ttdeci">uint64_t neorv32_mtime_get_timecmp(void)</div><div class="ttdef"><b>Definition</b> neorv32_mtime.c:111</div></div> +<div class="ttc" id="aneorv32__mtime_8h_html_adedbbdeb71c06d2d60d3af73451de01e"><div class="ttname"><a href="neorv32__mtime_8h.html#adedbbdeb71c06d2d60d3af73451de01e">neorv32_mtime_get_time</a></div><div class="ttdeci">uint64_t neorv32_mtime_get_time(void)</div><div class="ttdef"><b>Definition</b> neorv32_mtime.c:64</div></div> +<div class="ttc" id="astructneorv32__mtime__t_html"><div class="ttname"><a href="structneorv32__mtime__t.html">neorv32_mtime_t</a></div><div class="ttdef"><b>Definition</b> neorv32_mtime.h:29</div></div> +<div class="ttc" id="astructneorv32__mtime__t_html_a1ffe0be2c45f5d7aa2686abf40cd1693"><div class="ttname"><a href="structneorv32__mtime__t.html#a1ffe0be2c45f5d7aa2686abf40cd1693">neorv32_mtime_t::TIME_HI</a></div><div class="ttdeci">uint32_t TIME_HI</div><div class="ttdef"><b>Definition</b> neorv32_mtime.h:31</div></div> +<div class="ttc" id="astructneorv32__mtime__t_html_ab5fa56ca5c2f9d547f58d169d6da96e5"><div class="ttname"><a href="structneorv32__mtime__t.html#ab5fa56ca5c2f9d547f58d169d6da96e5">neorv32_mtime_t::TIMECMP_LO</a></div><div class="ttdeci">uint32_t TIMECMP_LO</div><div class="ttdef"><b>Definition</b> neorv32_mtime.h:32</div></div> +<div class="ttc" id="astructneorv32__mtime__t_html_acccaa3dd87a57ebd5f7ae504771e904e"><div class="ttname"><a href="structneorv32__mtime__t.html#acccaa3dd87a57ebd5f7ae504771e904e">neorv32_mtime_t::TIME_LO</a></div><div class="ttdeci">uint32_t TIME_LO</div><div class="ttdef"><b>Definition</b> neorv32_mtime.h:30</div></div> +<div class="ttc" id="astructneorv32__mtime__t_html_af05df268c8f699401cf752e4249ba422"><div class="ttname"><a href="structneorv32__mtime__t.html#af05df268c8f699401cf752e4249ba422">neorv32_mtime_t::TIMECMP_HI</a></div><div class="ttdeci">uint32_t TIMECMP_HI</div><div class="ttdef"><b>Definition</b> neorv32_mtime.h:33</div></div> +</div><!-- fragment --></div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/neorv32__neoled_8c.html b/sw/neorv32__neoled_8c.html new file mode 100644 index 0000000000..aa71c1bd0f --- /dev/null +++ b/sw/neorv32__neoled_8c.html @@ -0,0 +1,371 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/lib/source/neorv32_neoled.c File Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_7d04193005ada6f9450f847f4adb6b5b.html">lib</a></li><li class="navelem"><a class="el" href="dir_0c6ac14e2254a316d41123f98feeb67b.html">source</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#func-members">Functions</a> </div> + <div class="headertitle"><div class="title">neorv32_neoled.c File Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p>Smart LED Interface (NEOLED) HW driver source file. +<a href="#details">More...</a></p> +<div class="textblock"><code>#include &quot;<a class="el" href="neorv32_8h_source.html">neorv32.h</a>&quot;</code><br /> +</div><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="func-members" name="func-members"></a> +Functions</h2></td></tr> +<tr class="memitem:a57398d92fb4fc735b33e89271726e1d6" id="r_a57398d92fb4fc735b33e89271726e1d6"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a57398d92fb4fc735b33e89271726e1d6">neorv32_neoled_available</a> (void)</td></tr> +<tr class="separator:a57398d92fb4fc735b33e89271726e1d6"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ac6e94602453779a2791bd0734465f5a3" id="r_ac6e94602453779a2791bd0734465f5a3"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ac6e94602453779a2791bd0734465f5a3">neorv32_neoled_setup</a> (uint32_t prsc, uint32_t t_total, uint32_t t_high_zero, uint32_t t_high_one, int irq_mode)</td></tr> +<tr class="separator:ac6e94602453779a2791bd0734465f5a3"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:adade69c7368c28180b9992d5f0ab6031" id="r_adade69c7368c28180b9992d5f0ab6031"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#adade69c7368c28180b9992d5f0ab6031">neorv32_neoled_setup_ws2812</a> (int irq_mode)</td></tr> +<tr class="separator:adade69c7368c28180b9992d5f0ab6031"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a484fcc6797b6d9cef86192e9593ec33d" id="r_a484fcc6797b6d9cef86192e9593ec33d"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a484fcc6797b6d9cef86192e9593ec33d">neorv32_neoled_set_mode</a> (uint32_t mode)</td></tr> +<tr class="separator:a484fcc6797b6d9cef86192e9593ec33d"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a5aa9eb4dd3655fa08e1b61eb0f36589c" id="r_a5aa9eb4dd3655fa08e1b61eb0f36589c"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a5aa9eb4dd3655fa08e1b61eb0f36589c">neorv32_neoled_strobe_blocking</a> (void)</td></tr> +<tr class="separator:a5aa9eb4dd3655fa08e1b61eb0f36589c"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:abf7882b949373df0774fc9cc20c2bd2e" id="r_abf7882b949373df0774fc9cc20c2bd2e"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#abf7882b949373df0774fc9cc20c2bd2e">neorv32_neoled_strobe_nonblocking</a> (void)</td></tr> +<tr class="separator:abf7882b949373df0774fc9cc20c2bd2e"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a8181d5c1d15b7b5eecdc018341ac14fa" id="r_a8181d5c1d15b7b5eecdc018341ac14fa"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a8181d5c1d15b7b5eecdc018341ac14fa">neorv32_neoled_enable</a> (void)</td></tr> +<tr class="separator:a8181d5c1d15b7b5eecdc018341ac14fa"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a8daaa97a85e0eb94d4a38eb2119ea183" id="r_a8daaa97a85e0eb94d4a38eb2119ea183"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a8daaa97a85e0eb94d4a38eb2119ea183">neorv32_neoled_disable</a> (void)</td></tr> +<tr class="separator:a8daaa97a85e0eb94d4a38eb2119ea183"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a3ee5b3602da3ae982628e2802587e451" id="r_a3ee5b3602da3ae982628e2802587e451"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a3ee5b3602da3ae982628e2802587e451">neorv32_neoled_write_blocking</a> (uint32_t data)</td></tr> +<tr class="separator:a3ee5b3602da3ae982628e2802587e451"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a81c2c49198531fb6551eb288e29c084e" id="r_a81c2c49198531fb6551eb288e29c084e"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a81c2c49198531fb6551eb288e29c084e">neorv32_neoled_get_buffer_size</a> (void)</td></tr> +<tr class="separator:a81c2c49198531fb6551eb288e29c084e"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>Smart LED Interface (NEOLED) HW driver source file. </p> +<dl class="section note"><dt>Note</dt><dd>These functions should only be used if the NEOLED unit was synthesized (IO_NEOLED_EN = true).</dd></dl> +<dl class="section see"><dt>See also</dt><dd><a href="https://stnolting.github.io/neorv32/sw/files.html">https://stnolting.github.io/neorv32/sw/files.html</a> </dd></dl> +</div><h2 class="groupheader">Function Documentation</h2> +<a id="a57398d92fb4fc735b33e89271726e1d6" name="a57398d92fb4fc735b33e89271726e1d6"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a57398d92fb4fc735b33e89271726e1d6">&#9670;&#160;</a></span>neorv32_neoled_available()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_neoled_available </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Check if NEOLED unit was synthesized.</p> +<dl class="section return"><dt>Returns</dt><dd>0 if NEOLED was not synthesized, 1 if NEOLED is available. </dd></dl> + +</div> +</div> +<a id="a8daaa97a85e0eb94d4a38eb2119ea183" name="a8daaa97a85e0eb94d4a38eb2119ea183"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a8daaa97a85e0eb94d4a38eb2119ea183">&#9670;&#160;</a></span>neorv32_neoled_disable()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_neoled_disable </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Disable NEOLED controller. </p> + +</div> +</div> +<a id="a8181d5c1d15b7b5eecdc018341ac14fa" name="a8181d5c1d15b7b5eecdc018341ac14fa"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a8181d5c1d15b7b5eecdc018341ac14fa">&#9670;&#160;</a></span>neorv32_neoled_enable()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_neoled_enable </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Enable NEOLED controller. </p> + +</div> +</div> +<a id="a81c2c49198531fb6551eb288e29c084e" name="a81c2c49198531fb6551eb288e29c084e"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a81c2c49198531fb6551eb288e29c084e">&#9670;&#160;</a></span>neorv32_neoled_get_buffer_size()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_neoled_get_buffer_size </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Get NEOLED hardware buffer size.</p> +<dl class="section return"><dt>Returns</dt><dd>Number of entries in NEOLED TX buffer. </dd></dl> + +</div> +</div> +<a id="a484fcc6797b6d9cef86192e9593ec33d" name="a484fcc6797b6d9cef86192e9593ec33d"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a484fcc6797b6d9cef86192e9593ec33d">&#9670;&#160;</a></span>neorv32_neoled_set_mode()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_neoled_set_mode </td> + <td>(</td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>mode</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Set NEOLED mode (24-bit RGB / 32-bit RGBW).</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">mode</td><td>0 = 24-bit mode (RGB), 1 = 32-bit mode (RGBW) </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="ac6e94602453779a2791bd0734465f5a3" name="ac6e94602453779a2791bd0734465f5a3"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ac6e94602453779a2791bd0734465f5a3">&#9670;&#160;</a></span>neorv32_neoled_setup()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_neoled_setup </td> + <td>(</td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>prsc</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>t_total</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>t_high_zero</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>t_high_one</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>irq_mode</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Enable and configure NEOLED controller. The NEOLED control register bits are listed in <a class="el" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412">NEORV32_NEOLED_CTRL_enum</a>. This function performs a "raw" configuration (just configuring the according control register bit).</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">prsc</td><td>Clock prescaler select (0..7). See <a class="el" href="neorv32_8h.html#a10022df4c223533b04d5aebe222e8b73">NEORV32_CLOCK_PRSC_enum</a>. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">t_total</td><td>Number of pre-scaled clock ticks for total bit period (0..31). </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">t_high_zero</td><td>Number of pre-scaled clock ticks to generate high-time for sending a '0' (0..31). </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">t_high_one</td><td>Number of pre-scaled clock ticks to generate high-time for sending a '1' (0..31). </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">irq_mode</td><td>Interrupt condition (1=IRQ if FIFO is empty, 1=IRQ if FIFO is less than half-full). </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="adade69c7368c28180b9992d5f0ab6031" name="adade69c7368c28180b9992d5f0ab6031"></a> +<h2 class="memtitle"><span class="permalink"><a href="#adade69c7368c28180b9992d5f0ab6031">&#9670;&#160;</a></span>neorv32_neoled_setup_ws2812()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_neoled_setup_ws2812 </td> + <td>(</td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>irq_mode</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Configure NEOLED controller for using WS2812 LEDs (NeoPixel-compatible). This function computes all the required timings and finally calls <a class="el" href="#ac6e94602453779a2791bd0734465f5a3">neorv32_neoled_setup</a>.</p> +<dl class="section note"><dt>Note</dt><dd>WS2812 timing: T_period = 1.2us, T_high_zero = 0.4us, T_high_one = 0.8us. Change the constants if required. </dd> +<dd> +This function uses the SYSINFO_CLK value (from the SYSINFO HW module) to do the timing computations.</dd></dl> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">irq_mode</td><td>Interrupt condition (1=IRQ if FIFO is empty, 1=IRQ if FIFO is less than half-full). </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="a5aa9eb4dd3655fa08e1b61eb0f36589c" name="a5aa9eb4dd3655fa08e1b61eb0f36589c"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a5aa9eb4dd3655fa08e1b61eb0f36589c">&#9670;&#160;</a></span>neorv32_neoled_strobe_blocking()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_neoled_strobe_blocking </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Send strobe command ("RESET") - blocking. </p> + +</div> +</div> +<a id="abf7882b949373df0774fc9cc20c2bd2e" name="abf7882b949373df0774fc9cc20c2bd2e"></a> +<h2 class="memtitle"><span class="permalink"><a href="#abf7882b949373df0774fc9cc20c2bd2e">&#9670;&#160;</a></span>neorv32_neoled_strobe_nonblocking()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_neoled_strobe_nonblocking </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Send strobe command ("RESET") - non-blocking. </p> + +</div> +</div> +<a id="a3ee5b3602da3ae982628e2802587e451" name="a3ee5b3602da3ae982628e2802587e451"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a3ee5b3602da3ae982628e2802587e451">&#9670;&#160;</a></span>neorv32_neoled_write_blocking()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_neoled_write_blocking </td> + <td>(</td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>data</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Send single RGB(W) data word to NEOLED module (blocking).</p> +<dl class="section warning"><dt>Warning</dt><dd>This function is blocking as it polls the NEOLED FIFO full flag.</dd></dl> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">data</td><td>LSB-aligned 24-bit RGB or 32-bit RGBW data </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/neorv32__neoled_8h.html b/sw/neorv32__neoled_8h.html new file mode 100644 index 0000000000..bd99b6c5a6 --- /dev/null +++ b/sw/neorv32__neoled_8h.html @@ -0,0 +1,554 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/lib/include/neorv32_neoled.h File Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_7d04193005ada6f9450f847f4adb6b5b.html">lib</a></li><li class="navelem"><a class="el" href="dir_752b1e5d3973bf735fa78bf6b4727df9.html">include</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#nested-classes">Data Structures</a> &#124; +<a href="#func-members">Functions</a> </div> + <div class="headertitle"><div class="title">neorv32_neoled.h File Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p>Smart LED Interface (NEOLED) HW driver header file. +<a href="#details">More...</a></p> +<div class="textblock"><code>#include &lt;stdint.h&gt;</code><br /> +</div> +<p><a href="neorv32__neoled_8h_source.html">Go to the source code of this file.</a></p> +<table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="nested-classes" name="nested-classes"></a> +Data Structures</h2></td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">struct &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structneorv32__neoled__t.html">neorv32_neoled_t</a></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="func-members" name="func-members"></a> +Functions</h2></td></tr> +<tr class="memitem:ad2a318bd59be12de34797ced0f7743c6" id="r_ad2a318bd59be12de34797ced0f7743c6"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ad2a318bd59be12de34797ced0f7743c6">neorv32_neoled_write_nonblocking</a> (uint32_t data)</td></tr> +<tr class="separator:ad2a318bd59be12de34797ced0f7743c6"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr><td colspan="2"><div class="groupHeader">Prototypes</div></td></tr> +<tr class="memitem:a57398d92fb4fc735b33e89271726e1d6" id="r_a57398d92fb4fc735b33e89271726e1d6"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a57398d92fb4fc735b33e89271726e1d6">neorv32_neoled_available</a> (void)</td></tr> +<tr class="separator:a57398d92fb4fc735b33e89271726e1d6"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ac6e94602453779a2791bd0734465f5a3" id="r_ac6e94602453779a2791bd0734465f5a3"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ac6e94602453779a2791bd0734465f5a3">neorv32_neoled_setup</a> (uint32_t prsc, uint32_t t_total, uint32_t t_high_zero, uint32_t t_high_one, int irq_mode)</td></tr> +<tr class="separator:ac6e94602453779a2791bd0734465f5a3"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:adade69c7368c28180b9992d5f0ab6031" id="r_adade69c7368c28180b9992d5f0ab6031"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#adade69c7368c28180b9992d5f0ab6031">neorv32_neoled_setup_ws2812</a> (int irq_mode)</td></tr> +<tr class="separator:adade69c7368c28180b9992d5f0ab6031"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a484fcc6797b6d9cef86192e9593ec33d" id="r_a484fcc6797b6d9cef86192e9593ec33d"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a484fcc6797b6d9cef86192e9593ec33d">neorv32_neoled_set_mode</a> (uint32_t mode)</td></tr> +<tr class="separator:a484fcc6797b6d9cef86192e9593ec33d"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a5aa9eb4dd3655fa08e1b61eb0f36589c" id="r_a5aa9eb4dd3655fa08e1b61eb0f36589c"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a5aa9eb4dd3655fa08e1b61eb0f36589c">neorv32_neoled_strobe_blocking</a> (void)</td></tr> +<tr class="separator:a5aa9eb4dd3655fa08e1b61eb0f36589c"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:abf7882b949373df0774fc9cc20c2bd2e" id="r_abf7882b949373df0774fc9cc20c2bd2e"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#abf7882b949373df0774fc9cc20c2bd2e">neorv32_neoled_strobe_nonblocking</a> (void)</td></tr> +<tr class="separator:abf7882b949373df0774fc9cc20c2bd2e"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a8181d5c1d15b7b5eecdc018341ac14fa" id="r_a8181d5c1d15b7b5eecdc018341ac14fa"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a8181d5c1d15b7b5eecdc018341ac14fa">neorv32_neoled_enable</a> (void)</td></tr> +<tr class="separator:a8181d5c1d15b7b5eecdc018341ac14fa"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a8daaa97a85e0eb94d4a38eb2119ea183" id="r_a8daaa97a85e0eb94d4a38eb2119ea183"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a8daaa97a85e0eb94d4a38eb2119ea183">neorv32_neoled_disable</a> (void)</td></tr> +<tr class="separator:a8daaa97a85e0eb94d4a38eb2119ea183"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a3ee5b3602da3ae982628e2802587e451" id="r_a3ee5b3602da3ae982628e2802587e451"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a3ee5b3602da3ae982628e2802587e451">neorv32_neoled_write_blocking</a> (uint32_t data)</td></tr> +<tr class="separator:a3ee5b3602da3ae982628e2802587e451"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a81c2c49198531fb6551eb288e29c084e" id="r_a81c2c49198531fb6551eb288e29c084e"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a81c2c49198531fb6551eb288e29c084e">neorv32_neoled_get_buffer_size</a> (void)</td></tr> +<tr class="separator:a81c2c49198531fb6551eb288e29c084e"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader">IO Device: Smart LED Hardware Interface (NEOLED)</h2></td></tr> +<tr class="memitem:a3ccc1097bc70f92235d693b612fa994a" id="r_a3ccc1097bc70f92235d693b612fa994a"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a3ccc1097bc70f92235d693b612fa994a">NEORV32_NEOLED</a>&#160;&#160;&#160;((<a class="el" href="structneorv32__neoled__t.html">neorv32_neoled_t</a>*) (<a class="el" href="neorv32_8h.html#a559fdce92e8af5efc426c8fc48d14f99">NEORV32_NEOLED_BASE</a>))</td></tr> +<tr class="separator:a3ccc1097bc70f92235d693b612fa994a"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ab99c7fed050816eae0fa0315562e0412" id="r_ab99c7fed050816eae0fa0315562e0412"><td class="memItemLeft" align="right" valign="top">enum &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ab99c7fed050816eae0fa0315562e0412">NEORV32_NEOLED_CTRL_enum</a> { <br /> +&#160;&#160;<a class="el" href="#ab99c7fed050816eae0fa0315562e0412af97ab77b33a250d87025c3dd3a21fea7">NEOLED_CTRL_EN</a> = 0 +, <a class="el" href="#ab99c7fed050816eae0fa0315562e0412abf6779cbeae87ab55efc9573932fc865">NEOLED_CTRL_MODE</a> = 1 +, <a class="el" href="#ab99c7fed050816eae0fa0315562e0412a436ad310b025bd3000af37986c193de5">NEOLED_CTRL_STROBE</a> = 2 +, <a class="el" href="#ab99c7fed050816eae0fa0315562e0412a142ed3fd65e01f853666a1169f920ad0">NEOLED_CTRL_PRSC0</a> = 3 +, <br /> +&#160;&#160;<a class="el" href="#ab99c7fed050816eae0fa0315562e0412a0f4178d81ec6fe9a8b0e30230d318a91">NEOLED_CTRL_PRSC1</a> = 4 +, <a class="el" href="#ab99c7fed050816eae0fa0315562e0412a3d8d54c05080fddb16df4176527bafa8">NEOLED_CTRL_PRSC2</a> = 5 +, <a class="el" href="#ab99c7fed050816eae0fa0315562e0412a3bb5d0d1f78cebccbc8620a0194f43b8">NEOLED_CTRL_BUFS_0</a> = 6 +, <a class="el" href="#ab99c7fed050816eae0fa0315562e0412aed0a878e73ad501bed3bbe6905974368">NEOLED_CTRL_BUFS_1</a> = 7 +, <br /> +&#160;&#160;<a class="el" href="#ab99c7fed050816eae0fa0315562e0412ae7b9d45c4ef69ca15fa13aa107e68156">NEOLED_CTRL_BUFS_2</a> = 8 +, <a class="el" href="#ab99c7fed050816eae0fa0315562e0412ac1922a5311e91a74710eddbf86ccc1c1">NEOLED_CTRL_BUFS_3</a> = 9 +, <a class="el" href="#ab99c7fed050816eae0fa0315562e0412a44d8f064decabc690ed1f092be2b049b">NEOLED_CTRL_T_TOT_0</a> = 10 +, <a class="el" href="#ab99c7fed050816eae0fa0315562e0412addf4d6d1fd09f145d8aa497c4a7479c2">NEOLED_CTRL_T_TOT_1</a> = 11 +, <br /> +&#160;&#160;<a class="el" href="#ab99c7fed050816eae0fa0315562e0412a42d09d42d39fc0eb2697853c99f4d5b0">NEOLED_CTRL_T_TOT_2</a> = 12 +, <a class="el" href="#ab99c7fed050816eae0fa0315562e0412acbcd3c046b528e1900e86428da231df2">NEOLED_CTRL_T_TOT_3</a> = 13 +, <a class="el" href="#ab99c7fed050816eae0fa0315562e0412a3f1a0ad71d9fd892829ec0246be343b3">NEOLED_CTRL_T_TOT_4</a> = 14 +, <a class="el" href="#ab99c7fed050816eae0fa0315562e0412a7285e332ec7c2b3aeb34290e3e60ded7">NEOLED_CTRL_T_ZERO_H_0</a> = 15 +, <br /> +&#160;&#160;<a class="el" href="#ab99c7fed050816eae0fa0315562e0412a1ef56b35c966786c42f2a2f800e30eae">NEOLED_CTRL_T_ZERO_H_1</a> = 16 +, <a class="el" href="#ab99c7fed050816eae0fa0315562e0412a9d9411382d943c1659b6b761c462319b">NEOLED_CTRL_T_ZERO_H_2</a> = 17 +, <a class="el" href="#ab99c7fed050816eae0fa0315562e0412abf2ea111a4ff34b6cb4dd987c5692f5c">NEOLED_CTRL_T_ZERO_H_3</a> = 18 +, <a class="el" href="#ab99c7fed050816eae0fa0315562e0412a0d5d01b8d30119bb86c1d079f7d5a9ad">NEOLED_CTRL_T_ZERO_H_4</a> = 19 +, <br /> +&#160;&#160;<a class="el" href="#ab99c7fed050816eae0fa0315562e0412a770df505d47353f6c9289059c416d9c8">NEOLED_CTRL_T_ONE_H_0</a> = 20 +, <a class="el" href="#ab99c7fed050816eae0fa0315562e0412aea15666ad4bb9eb1eba5dc9ed96114a6">NEOLED_CTRL_T_ONE_H_1</a> = 21 +, <a class="el" href="#ab99c7fed050816eae0fa0315562e0412a4d362af8c630823b5104401a9c7d734e">NEOLED_CTRL_T_ONE_H_2</a> = 22 +, <a class="el" href="#ab99c7fed050816eae0fa0315562e0412a369f36e73783c2923d07ca333081a4a6">NEOLED_CTRL_T_ONE_H_3</a> = 23 +, <br /> +&#160;&#160;<a class="el" href="#ab99c7fed050816eae0fa0315562e0412a0c15850d0ab005b075f1a317646e18b1">NEOLED_CTRL_T_ONE_H_4</a> = 24 +, <a class="el" href="#ab99c7fed050816eae0fa0315562e0412a37421074b86a260b276534b7c4949339">NEOLED_CTRL_IRQ_CONF</a> = 27 +, <a class="el" href="#ab99c7fed050816eae0fa0315562e0412a23937f0a728da197590e1d383507cb23">NEOLED_CTRL_TX_EMPTY</a> = 28 +, <a class="el" href="#ab99c7fed050816eae0fa0315562e0412a16c09df2784cfb6fafffaeaf245f1b73">NEOLED_CTRL_TX_HALF</a> = 29 +, <br /> +&#160;&#160;<a class="el" href="#ab99c7fed050816eae0fa0315562e0412acfac5269688b2a03794dc17b11f1b983">NEOLED_CTRL_TX_FULL</a> = 30 +, <a class="el" href="#ab99c7fed050816eae0fa0315562e0412a55da98b018c7cc32cd1e80087ed9018e">NEOLED_CTRL_TX_BUSY</a> = 31 +<br /> + }</td></tr> +<tr class="separator:ab99c7fed050816eae0fa0315562e0412"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>Smart LED Interface (NEOLED) HW driver header file. </p> +<dl class="section note"><dt>Note</dt><dd>These functions should only be used if the NEOLED unit was synthesized (IO_NEOLED_EN = true).</dd></dl> +<dl class="section see"><dt>See also</dt><dd><a href="https://stnolting.github.io/neorv32/sw/files.html">https://stnolting.github.io/neorv32/sw/files.html</a> </dd></dl> +</div><h2 class="groupheader">Macro Definition Documentation</h2> +<a id="a3ccc1097bc70f92235d693b612fa994a" name="a3ccc1097bc70f92235d693b612fa994a"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a3ccc1097bc70f92235d693b612fa994a">&#9670;&#160;</a></span>NEORV32_NEOLED</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define NEORV32_NEOLED&#160;&#160;&#160;((<a class="el" href="structneorv32__neoled__t.html">neorv32_neoled_t</a>*) (<a class="el" href="neorv32_8h.html#a559fdce92e8af5efc426c8fc48d14f99">NEORV32_NEOLED_BASE</a>))</td> + </tr> + </table> +</div><div class="memdoc"> +<p>NEOLED module hardware access (<a class="el" href="structneorv32__neoled__t.html">neorv32_neoled_t</a>) </p> + +</div> +</div> +<h2 class="groupheader">Enumeration Type Documentation</h2> +<a id="ab99c7fed050816eae0fa0315562e0412" name="ab99c7fed050816eae0fa0315562e0412"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ab99c7fed050816eae0fa0315562e0412">&#9670;&#160;</a></span>NEORV32_NEOLED_CTRL_enum</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">enum <a class="el" href="#ab99c7fed050816eae0fa0315562e0412">NEORV32_NEOLED_CTRL_enum</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>NEOLED control register bits </p> +<table class="fieldtable"> +<tr><th colspan="2">Enumerator</th></tr><tr><td class="fieldname"><a id="ab99c7fed050816eae0fa0315562e0412af97ab77b33a250d87025c3dd3a21fea7" name="ab99c7fed050816eae0fa0315562e0412af97ab77b33a250d87025c3dd3a21fea7"></a>NEOLED_CTRL_EN&#160;</td><td class="fielddoc"><p>NEOLED control register(0) (r/w): NEOLED global enable </p> +</td></tr> +<tr><td class="fieldname"><a id="ab99c7fed050816eae0fa0315562e0412abf6779cbeae87ab55efc9573932fc865" name="ab99c7fed050816eae0fa0315562e0412abf6779cbeae87ab55efc9573932fc865"></a>NEOLED_CTRL_MODE&#160;</td><td class="fielddoc"><p>NEOLED control register(1) (r/w): TX mode (0=24-bit, 1=32-bit) </p> +</td></tr> +<tr><td class="fieldname"><a id="ab99c7fed050816eae0fa0315562e0412a436ad310b025bd3000af37986c193de5" name="ab99c7fed050816eae0fa0315562e0412a436ad310b025bd3000af37986c193de5"></a>NEOLED_CTRL_STROBE&#160;</td><td class="fielddoc"><p>NEOLED control register(2) (r/w): Strobe (0=send normal data, 1=send RESET command on data write) </p> +</td></tr> +<tr><td class="fieldname"><a id="ab99c7fed050816eae0fa0315562e0412a142ed3fd65e01f853666a1169f920ad0" name="ab99c7fed050816eae0fa0315562e0412a142ed3fd65e01f853666a1169f920ad0"></a>NEOLED_CTRL_PRSC0&#160;</td><td class="fielddoc"><p>NEOLED control register(3) (r/w): Clock prescaler select bit 0 (pulse-clock speed select) </p> +</td></tr> +<tr><td class="fieldname"><a id="ab99c7fed050816eae0fa0315562e0412a0f4178d81ec6fe9a8b0e30230d318a91" name="ab99c7fed050816eae0fa0315562e0412a0f4178d81ec6fe9a8b0e30230d318a91"></a>NEOLED_CTRL_PRSC1&#160;</td><td class="fielddoc"><p>NEOLED control register(4) (r/w): Clock prescaler select bit 1 (pulse-clock speed select) </p> +</td></tr> +<tr><td class="fieldname"><a id="ab99c7fed050816eae0fa0315562e0412a3d8d54c05080fddb16df4176527bafa8" name="ab99c7fed050816eae0fa0315562e0412a3d8d54c05080fddb16df4176527bafa8"></a>NEOLED_CTRL_PRSC2&#160;</td><td class="fielddoc"><p>NEOLED control register(5) (r/w): Clock prescaler select bit 2 (pulse-clock speed select) </p> +</td></tr> +<tr><td class="fieldname"><a id="ab99c7fed050816eae0fa0315562e0412a3bb5d0d1f78cebccbc8620a0194f43b8" name="ab99c7fed050816eae0fa0315562e0412a3bb5d0d1f78cebccbc8620a0194f43b8"></a>NEOLED_CTRL_BUFS_0&#160;</td><td class="fielddoc"><p>NEOLED control register(6) (r/-): log2(tx buffer size) bit 0 </p> +</td></tr> +<tr><td class="fieldname"><a id="ab99c7fed050816eae0fa0315562e0412aed0a878e73ad501bed3bbe6905974368" name="ab99c7fed050816eae0fa0315562e0412aed0a878e73ad501bed3bbe6905974368"></a>NEOLED_CTRL_BUFS_1&#160;</td><td class="fielddoc"><p>NEOLED control register(7) (r/-): log2(tx buffer size) bit 1 </p> +</td></tr> +<tr><td class="fieldname"><a id="ab99c7fed050816eae0fa0315562e0412ae7b9d45c4ef69ca15fa13aa107e68156" name="ab99c7fed050816eae0fa0315562e0412ae7b9d45c4ef69ca15fa13aa107e68156"></a>NEOLED_CTRL_BUFS_2&#160;</td><td class="fielddoc"><p>NEOLED control register(8) (r/-): log2(tx buffer size) bit 2 </p> +</td></tr> +<tr><td class="fieldname"><a id="ab99c7fed050816eae0fa0315562e0412ac1922a5311e91a74710eddbf86ccc1c1" name="ab99c7fed050816eae0fa0315562e0412ac1922a5311e91a74710eddbf86ccc1c1"></a>NEOLED_CTRL_BUFS_3&#160;</td><td class="fielddoc"><p>NEOLED control register(9) (r/-): log2(tx buffer size) bit 3 </p> +</td></tr> +<tr><td class="fieldname"><a id="ab99c7fed050816eae0fa0315562e0412a44d8f064decabc690ed1f092be2b049b" name="ab99c7fed050816eae0fa0315562e0412a44d8f064decabc690ed1f092be2b049b"></a>NEOLED_CTRL_T_TOT_0&#160;</td><td class="fielddoc"><p>NEOLED control register(10) (r/w): pulse-clock ticks per total period bit 0 </p> +</td></tr> +<tr><td class="fieldname"><a id="ab99c7fed050816eae0fa0315562e0412addf4d6d1fd09f145d8aa497c4a7479c2" name="ab99c7fed050816eae0fa0315562e0412addf4d6d1fd09f145d8aa497c4a7479c2"></a>NEOLED_CTRL_T_TOT_1&#160;</td><td class="fielddoc"><p>NEOLED control register(11) (r/w): pulse-clock ticks per total period bit 1 </p> +</td></tr> +<tr><td class="fieldname"><a id="ab99c7fed050816eae0fa0315562e0412a42d09d42d39fc0eb2697853c99f4d5b0" name="ab99c7fed050816eae0fa0315562e0412a42d09d42d39fc0eb2697853c99f4d5b0"></a>NEOLED_CTRL_T_TOT_2&#160;</td><td class="fielddoc"><p>NEOLED control register(12) (r/w): pulse-clock ticks per total period bit 2 </p> +</td></tr> +<tr><td class="fieldname"><a id="ab99c7fed050816eae0fa0315562e0412acbcd3c046b528e1900e86428da231df2" name="ab99c7fed050816eae0fa0315562e0412acbcd3c046b528e1900e86428da231df2"></a>NEOLED_CTRL_T_TOT_3&#160;</td><td class="fielddoc"><p>NEOLED control register(13) (r/w): pulse-clock ticks per total period bit 3 </p> +</td></tr> +<tr><td class="fieldname"><a id="ab99c7fed050816eae0fa0315562e0412a3f1a0ad71d9fd892829ec0246be343b3" name="ab99c7fed050816eae0fa0315562e0412a3f1a0ad71d9fd892829ec0246be343b3"></a>NEOLED_CTRL_T_TOT_4&#160;</td><td class="fielddoc"><p>NEOLED control register(14) (r/w): pulse-clock ticks per total period bit 4 </p> +</td></tr> +<tr><td class="fieldname"><a id="ab99c7fed050816eae0fa0315562e0412a7285e332ec7c2b3aeb34290e3e60ded7" name="ab99c7fed050816eae0fa0315562e0412a7285e332ec7c2b3aeb34290e3e60ded7"></a>NEOLED_CTRL_T_ZERO_H_0&#160;</td><td class="fielddoc"><p>NEOLED control register(15) (r/w): pulse-clock ticks per ZERO high-time bit 0 </p> +</td></tr> +<tr><td class="fieldname"><a id="ab99c7fed050816eae0fa0315562e0412a1ef56b35c966786c42f2a2f800e30eae" name="ab99c7fed050816eae0fa0315562e0412a1ef56b35c966786c42f2a2f800e30eae"></a>NEOLED_CTRL_T_ZERO_H_1&#160;</td><td class="fielddoc"><p>NEOLED control register(16) (r/w): pulse-clock ticks per ZERO high-time bit 1 </p> +</td></tr> +<tr><td class="fieldname"><a id="ab99c7fed050816eae0fa0315562e0412a9d9411382d943c1659b6b761c462319b" name="ab99c7fed050816eae0fa0315562e0412a9d9411382d943c1659b6b761c462319b"></a>NEOLED_CTRL_T_ZERO_H_2&#160;</td><td class="fielddoc"><p>NEOLED control register(17) (r/w): pulse-clock ticks per ZERO high-time bit 2 </p> +</td></tr> +<tr><td class="fieldname"><a id="ab99c7fed050816eae0fa0315562e0412abf2ea111a4ff34b6cb4dd987c5692f5c" name="ab99c7fed050816eae0fa0315562e0412abf2ea111a4ff34b6cb4dd987c5692f5c"></a>NEOLED_CTRL_T_ZERO_H_3&#160;</td><td class="fielddoc"><p>NEOLED control register(18) (r/w): pulse-clock ticks per ZERO high-time bit 3 </p> +</td></tr> +<tr><td class="fieldname"><a id="ab99c7fed050816eae0fa0315562e0412a0d5d01b8d30119bb86c1d079f7d5a9ad" name="ab99c7fed050816eae0fa0315562e0412a0d5d01b8d30119bb86c1d079f7d5a9ad"></a>NEOLED_CTRL_T_ZERO_H_4&#160;</td><td class="fielddoc"><p>NEOLED control register(19) (r/w): pulse-clock ticks per ZERO high-time bit 4 </p> +</td></tr> +<tr><td class="fieldname"><a id="ab99c7fed050816eae0fa0315562e0412a770df505d47353f6c9289059c416d9c8" name="ab99c7fed050816eae0fa0315562e0412a770df505d47353f6c9289059c416d9c8"></a>NEOLED_CTRL_T_ONE_H_0&#160;</td><td class="fielddoc"><p>NEOLED control register(20) (r/w): pulse-clock ticks per ONE high-time bit 0 </p> +</td></tr> +<tr><td class="fieldname"><a id="ab99c7fed050816eae0fa0315562e0412aea15666ad4bb9eb1eba5dc9ed96114a6" name="ab99c7fed050816eae0fa0315562e0412aea15666ad4bb9eb1eba5dc9ed96114a6"></a>NEOLED_CTRL_T_ONE_H_1&#160;</td><td class="fielddoc"><p>NEOLED control register(21) (r/w): pulse-clock ticks per ONE high-time bit 1 </p> +</td></tr> +<tr><td class="fieldname"><a id="ab99c7fed050816eae0fa0315562e0412a4d362af8c630823b5104401a9c7d734e" name="ab99c7fed050816eae0fa0315562e0412a4d362af8c630823b5104401a9c7d734e"></a>NEOLED_CTRL_T_ONE_H_2&#160;</td><td class="fielddoc"><p>NEOLED control register(22) (r/w): pulse-clock ticks per ONE high-time bit 2 </p> +</td></tr> +<tr><td class="fieldname"><a id="ab99c7fed050816eae0fa0315562e0412a369f36e73783c2923d07ca333081a4a6" name="ab99c7fed050816eae0fa0315562e0412a369f36e73783c2923d07ca333081a4a6"></a>NEOLED_CTRL_T_ONE_H_3&#160;</td><td class="fielddoc"><p>NEOLED control register(23) (r/w): pulse-clock ticks per ONE high-time bit 3 </p> +</td></tr> +<tr><td class="fieldname"><a id="ab99c7fed050816eae0fa0315562e0412a0c15850d0ab005b075f1a317646e18b1" name="ab99c7fed050816eae0fa0315562e0412a0c15850d0ab005b075f1a317646e18b1"></a>NEOLED_CTRL_T_ONE_H_4&#160;</td><td class="fielddoc"><p>NEOLED control register(24) (r/w): pulse-clock ticks per ONE high-time bit 4 </p> +</td></tr> +<tr><td class="fieldname"><a id="ab99c7fed050816eae0fa0315562e0412a37421074b86a260b276534b7c4949339" name="ab99c7fed050816eae0fa0315562e0412a37421074b86a260b276534b7c4949339"></a>NEOLED_CTRL_IRQ_CONF&#160;</td><td class="fielddoc"><p>NEOLED control register(27) (r/w): TX FIFO interrupt: 1=IRQ if FIFO is empty, 1=IRQ if FIFO is less than half-full </p> +</td></tr> +<tr><td class="fieldname"><a id="ab99c7fed050816eae0fa0315562e0412a23937f0a728da197590e1d383507cb23" name="ab99c7fed050816eae0fa0315562e0412a23937f0a728da197590e1d383507cb23"></a>NEOLED_CTRL_TX_EMPTY&#160;</td><td class="fielddoc"><p>NEOLED control register(28) (r/-): TX FIFO is empty </p> +</td></tr> +<tr><td class="fieldname"><a id="ab99c7fed050816eae0fa0315562e0412a16c09df2784cfb6fafffaeaf245f1b73" name="ab99c7fed050816eae0fa0315562e0412a16c09df2784cfb6fafffaeaf245f1b73"></a>NEOLED_CTRL_TX_HALF&#160;</td><td class="fielddoc"><p>NEOLED control register(29) (r/-): TX FIFO is at least half-full </p> +</td></tr> +<tr><td class="fieldname"><a id="ab99c7fed050816eae0fa0315562e0412acfac5269688b2a03794dc17b11f1b983" name="ab99c7fed050816eae0fa0315562e0412acfac5269688b2a03794dc17b11f1b983"></a>NEOLED_CTRL_TX_FULL&#160;</td><td class="fielddoc"><p>NEOLED control register(30) (r/-): TX FIFO is full </p> +</td></tr> +<tr><td class="fieldname"><a id="ab99c7fed050816eae0fa0315562e0412a55da98b018c7cc32cd1e80087ed9018e" name="ab99c7fed050816eae0fa0315562e0412a55da98b018c7cc32cd1e80087ed9018e"></a>NEOLED_CTRL_TX_BUSY&#160;</td><td class="fielddoc"><p>NEOLED control register(31) (r/-): busy flag </p> +</td></tr> +</table> + +</div> +</div> +<h2 class="groupheader">Function Documentation</h2> +<a id="a57398d92fb4fc735b33e89271726e1d6" name="a57398d92fb4fc735b33e89271726e1d6"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a57398d92fb4fc735b33e89271726e1d6">&#9670;&#160;</a></span>neorv32_neoled_available()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_neoled_available </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Check if NEOLED unit was synthesized.</p> +<dl class="section return"><dt>Returns</dt><dd>0 if NEOLED was not synthesized, 1 if NEOLED is available. </dd></dl> + +</div> +</div> +<a id="a8daaa97a85e0eb94d4a38eb2119ea183" name="a8daaa97a85e0eb94d4a38eb2119ea183"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a8daaa97a85e0eb94d4a38eb2119ea183">&#9670;&#160;</a></span>neorv32_neoled_disable()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_neoled_disable </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Disable NEOLED controller. </p> + +</div> +</div> +<a id="a8181d5c1d15b7b5eecdc018341ac14fa" name="a8181d5c1d15b7b5eecdc018341ac14fa"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a8181d5c1d15b7b5eecdc018341ac14fa">&#9670;&#160;</a></span>neorv32_neoled_enable()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_neoled_enable </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Enable NEOLED controller. </p> + +</div> +</div> +<a id="a81c2c49198531fb6551eb288e29c084e" name="a81c2c49198531fb6551eb288e29c084e"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a81c2c49198531fb6551eb288e29c084e">&#9670;&#160;</a></span>neorv32_neoled_get_buffer_size()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_neoled_get_buffer_size </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Get NEOLED hardware buffer size.</p> +<dl class="section return"><dt>Returns</dt><dd>Number of entries in NEOLED TX buffer. </dd></dl> + +</div> +</div> +<a id="a484fcc6797b6d9cef86192e9593ec33d" name="a484fcc6797b6d9cef86192e9593ec33d"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a484fcc6797b6d9cef86192e9593ec33d">&#9670;&#160;</a></span>neorv32_neoled_set_mode()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_neoled_set_mode </td> + <td>(</td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>mode</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Set NEOLED mode (24-bit RGB / 32-bit RGBW).</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">mode</td><td>0 = 24-bit mode (RGB), 1 = 32-bit mode (RGBW) </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="ac6e94602453779a2791bd0734465f5a3" name="ac6e94602453779a2791bd0734465f5a3"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ac6e94602453779a2791bd0734465f5a3">&#9670;&#160;</a></span>neorv32_neoled_setup()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_neoled_setup </td> + <td>(</td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>prsc</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>t_total</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>t_high_zero</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>t_high_one</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>irq_mode</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Enable and configure NEOLED controller. The NEOLED control register bits are listed in <a class="el" href="#ab99c7fed050816eae0fa0315562e0412">NEORV32_NEOLED_CTRL_enum</a>. This function performs a "raw" configuration (just configuring the according control register bit).</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">prsc</td><td>Clock prescaler select (0..7). See <a class="el" href="neorv32_8h.html#a10022df4c223533b04d5aebe222e8b73">NEORV32_CLOCK_PRSC_enum</a>. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">t_total</td><td>Number of pre-scaled clock ticks for total bit period (0..31). </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">t_high_zero</td><td>Number of pre-scaled clock ticks to generate high-time for sending a '0' (0..31). </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">t_high_one</td><td>Number of pre-scaled clock ticks to generate high-time for sending a '1' (0..31). </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">irq_mode</td><td>Interrupt condition (1=IRQ if FIFO is empty, 1=IRQ if FIFO is less than half-full). </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="adade69c7368c28180b9992d5f0ab6031" name="adade69c7368c28180b9992d5f0ab6031"></a> +<h2 class="memtitle"><span class="permalink"><a href="#adade69c7368c28180b9992d5f0ab6031">&#9670;&#160;</a></span>neorv32_neoled_setup_ws2812()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_neoled_setup_ws2812 </td> + <td>(</td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>irq_mode</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Configure NEOLED controller for using WS2812 LEDs (NeoPixel-compatible). This function computes all the required timings and finally calls <a class="el" href="neorv32__neoled_8c.html#ac6e94602453779a2791bd0734465f5a3">neorv32_neoled_setup</a>.</p> +<dl class="section note"><dt>Note</dt><dd>WS2812 timing: T_period = 1.2us, T_high_zero = 0.4us, T_high_one = 0.8us. Change the constants if required. </dd> +<dd> +This function uses the SYSINFO_CLK value (from the SYSINFO HW module) to do the timing computations.</dd></dl> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">irq_mode</td><td>Interrupt condition (1=IRQ if FIFO is empty, 1=IRQ if FIFO is less than half-full). </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="a5aa9eb4dd3655fa08e1b61eb0f36589c" name="a5aa9eb4dd3655fa08e1b61eb0f36589c"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a5aa9eb4dd3655fa08e1b61eb0f36589c">&#9670;&#160;</a></span>neorv32_neoled_strobe_blocking()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_neoled_strobe_blocking </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Send strobe command ("RESET") - blocking. </p> + +</div> +</div> +<a id="abf7882b949373df0774fc9cc20c2bd2e" name="abf7882b949373df0774fc9cc20c2bd2e"></a> +<h2 class="memtitle"><span class="permalink"><a href="#abf7882b949373df0774fc9cc20c2bd2e">&#9670;&#160;</a></span>neorv32_neoled_strobe_nonblocking()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_neoled_strobe_nonblocking </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Send strobe command ("RESET") - non-blocking. </p> + +</div> +</div> +<a id="a3ee5b3602da3ae982628e2802587e451" name="a3ee5b3602da3ae982628e2802587e451"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a3ee5b3602da3ae982628e2802587e451">&#9670;&#160;</a></span>neorv32_neoled_write_blocking()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_neoled_write_blocking </td> + <td>(</td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>data</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Send single RGB(W) data word to NEOLED module (blocking).</p> +<dl class="section warning"><dt>Warning</dt><dd>This function is blocking as it polls the NEOLED FIFO full flag.</dd></dl> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">data</td><td>LSB-aligned 24-bit RGB or 32-bit RGBW data </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="ad2a318bd59be12de34797ced0f7743c6" name="ad2a318bd59be12de34797ced0f7743c6"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ad2a318bd59be12de34797ced0f7743c6">&#9670;&#160;</a></span>neorv32_neoled_write_nonblocking()</h2> + +<div class="memitem"> +<div class="memproto"> +<table class="mlabels"> + <tr> + <td class="mlabels-left"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_neoled_write_nonblocking </td> + <td>(</td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>data</em></span></td><td>)</td> + <td></td> + </tr> + </table> + </td> + <td class="mlabels-right"> +<span class="mlabels"><span class="mlabel">inline</span></span> </td> + </tr> +</table> +</div><div class="memdoc"> +<p>Send single RGB(W) data word to NEOLED module (non-blocking).</p> +<dl class="section warning"><dt>Warning</dt><dd>This function uses NO busy/flag checks at all!</dd></dl> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">data</td><td>LSB-aligned 24-bit RGB or 32-bit RGBW data </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/neorv32__neoled_8h_source.html b/sw/neorv32__neoled_8h_source.html new file mode 100644 index 0000000000..02d556681a --- /dev/null +++ b/sw/neorv32__neoled_8h_source.html @@ -0,0 +1,227 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/lib/include/neorv32_neoled.h Source File</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_7d04193005ada6f9450f847f4adb6b5b.html">lib</a></li><li class="navelem"><a class="el" href="dir_752b1e5d3973bf735fa78bf6b4727df9.html">include</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="headertitle"><div class="title">neorv32_neoled.h</div></div> +</div><!--header--> +<div class="contents"> +<a href="neorv32__neoled_8h.html">Go to the documentation of this file.</a><div class="fragment"><div class="line"><a id="l00001" name="l00001"></a><span class="lineno"> 1</span><span class="comment">// ================================================================================ //</span></div> +<div class="line"><a id="l00002" name="l00002"></a><span class="lineno"> 2</span><span class="comment">// The NEORV32 RISC-V Processor - https://github.com/stnolting/neorv32 //</span></div> +<div class="line"><a id="l00003" name="l00003"></a><span class="lineno"> 3</span><span class="comment">// Copyright (c) NEORV32 contributors. //</span></div> +<div class="line"><a id="l00004" name="l00004"></a><span class="lineno"> 4</span><span class="comment">// Copyright (c) 2020 - 2024 Stephan Nolting. All rights reserved. //</span></div> +<div class="line"><a id="l00005" name="l00005"></a><span class="lineno"> 5</span><span class="comment">// Licensed under the BSD-3-Clause license, see LICENSE for details. //</span></div> +<div class="line"><a id="l00006" name="l00006"></a><span class="lineno"> 6</span><span class="comment">// SPDX-License-Identifier: BSD-3-Clause //</span></div> +<div class="line"><a id="l00007" name="l00007"></a><span class="lineno"> 7</span><span class="comment">// ================================================================================ //</span></div> +<div class="line"><a id="l00008" name="l00008"></a><span class="lineno"> 8</span> </div> +<div class="line"><a id="l00018" name="l00018"></a><span class="lineno"> 18</span><span class="preprocessor">#ifndef neorv32_neoled_h</span></div> +<div class="line"><a id="l00019" name="l00019"></a><span class="lineno"> 19</span><span class="preprocessor">#define neorv32_neoled_h</span></div> +<div class="line"><a id="l00020" name="l00020"></a><span class="lineno"> 20</span> </div> +<div class="line"><a id="l00021" name="l00021"></a><span class="lineno"> 21</span><span class="preprocessor">#include &lt;stdint.h&gt;</span></div> +<div class="line"><a id="l00022" name="l00022"></a><span class="lineno"> 22</span> </div> +<div class="line"><a id="l00023" name="l00023"></a><span class="lineno"> 23</span> </div> +<div class="line"><a id="l00024" name="l00024"></a><span class="lineno"> 24</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen00029" data-start="{" data-end="};"> +<div class="line"><a id="l00029" name="l00029"></a><span class="lineno"><a class="line" href="structneorv32__neoled__t.html"> 29</a></span><span class="keyword">typedef</span> <span class="keyword">volatile</span> <span class="keyword">struct </span>__attribute__((packed,aligned(4))) {</div> +<div class="line"><a id="l00030" name="l00030"></a><span class="lineno"><a class="line" href="structneorv32__neoled__t.html#adfe7618c002ff88dd22e65fcedfd6139"> 30</a></span> uint32_t <a class="code hl_variable" href="structneorv32__neoled__t.html#adfe7618c002ff88dd22e65fcedfd6139">CTRL</a>; </div> +<div class="line"><a id="l00031" name="l00031"></a><span class="lineno"><a class="line" href="structneorv32__neoled__t.html#a995fb1d63a9dfb3f20d715932781c1de"> 31</a></span> uint32_t <a class="code hl_variable" href="structneorv32__neoled__t.html#a995fb1d63a9dfb3f20d715932781c1de">DATA</a>; </div> +<div class="line"><a id="l00032" name="l00032"></a><span class="lineno"> 32</span>} <a class="code hl_struct" href="structneorv32__neoled__t.html">neorv32_neoled_t</a>;</div> +</div> +<div class="line"><a id="l00033" name="l00033"></a><span class="lineno"> 33</span> </div> +<div class="line"><a id="l00035" name="l00035"></a><span class="lineno"><a class="line" href="neorv32__neoled_8h.html#a3ccc1097bc70f92235d693b612fa994a"> 35</a></span><span class="preprocessor">#define NEORV32_NEOLED ((neorv32_neoled_t*) (NEORV32_NEOLED_BASE))</span></div> +<div class="line"><a id="l00036" name="l00036"></a><span class="lineno"> 36</span> </div> +<div class="foldopen" id="foldopen00038" data-start="{" data-end="};"> +<div class="line"><a id="l00038" name="l00038"></a><span class="lineno"><a class="line" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412"> 38</a></span><span class="keyword">enum</span> <a class="code hl_enumeration" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412">NEORV32_NEOLED_CTRL_enum</a> {</div> +<div class="line"><a id="l00039" name="l00039"></a><span class="lineno"><a class="line" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412af97ab77b33a250d87025c3dd3a21fea7"> 39</a></span> <a class="code hl_enumvalue" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412af97ab77b33a250d87025c3dd3a21fea7">NEOLED_CTRL_EN</a> = 0, </div> +<div class="line"><a id="l00040" name="l00040"></a><span class="lineno"><a class="line" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412abf6779cbeae87ab55efc9573932fc865"> 40</a></span> <a class="code hl_enumvalue" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412abf6779cbeae87ab55efc9573932fc865">NEOLED_CTRL_MODE</a> = 1, </div> +<div class="line"><a id="l00041" name="l00041"></a><span class="lineno"><a class="line" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a436ad310b025bd3000af37986c193de5"> 41</a></span> <a class="code hl_enumvalue" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a436ad310b025bd3000af37986c193de5">NEOLED_CTRL_STROBE</a> = 2, </div> +<div class="line"><a id="l00042" name="l00042"></a><span class="lineno"><a class="line" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a142ed3fd65e01f853666a1169f920ad0"> 42</a></span> <a class="code hl_enumvalue" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a142ed3fd65e01f853666a1169f920ad0">NEOLED_CTRL_PRSC0</a> = 3, </div> +<div class="line"><a id="l00043" name="l00043"></a><span class="lineno"><a class="line" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a0f4178d81ec6fe9a8b0e30230d318a91"> 43</a></span> <a class="code hl_enumvalue" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a0f4178d81ec6fe9a8b0e30230d318a91">NEOLED_CTRL_PRSC1</a> = 4, </div> +<div class="line"><a id="l00044" name="l00044"></a><span class="lineno"><a class="line" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a3d8d54c05080fddb16df4176527bafa8"> 44</a></span> <a class="code hl_enumvalue" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a3d8d54c05080fddb16df4176527bafa8">NEOLED_CTRL_PRSC2</a> = 5, </div> +<div class="line"><a id="l00046" name="l00046"></a><span class="lineno"><a class="line" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a3bb5d0d1f78cebccbc8620a0194f43b8"> 46</a></span> <a class="code hl_enumvalue" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a3bb5d0d1f78cebccbc8620a0194f43b8">NEOLED_CTRL_BUFS_0</a> = 6, </div> +<div class="line"><a id="l00047" name="l00047"></a><span class="lineno"><a class="line" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412aed0a878e73ad501bed3bbe6905974368"> 47</a></span> <a class="code hl_enumvalue" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412aed0a878e73ad501bed3bbe6905974368">NEOLED_CTRL_BUFS_1</a> = 7, </div> +<div class="line"><a id="l00048" name="l00048"></a><span class="lineno"><a class="line" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412ae7b9d45c4ef69ca15fa13aa107e68156"> 48</a></span> <a class="code hl_enumvalue" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412ae7b9d45c4ef69ca15fa13aa107e68156">NEOLED_CTRL_BUFS_2</a> = 8, </div> +<div class="line"><a id="l00049" name="l00049"></a><span class="lineno"><a class="line" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412ac1922a5311e91a74710eddbf86ccc1c1"> 49</a></span> <a class="code hl_enumvalue" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412ac1922a5311e91a74710eddbf86ccc1c1">NEOLED_CTRL_BUFS_3</a> = 9, </div> +<div class="line"><a id="l00051" name="l00051"></a><span class="lineno"><a class="line" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a44d8f064decabc690ed1f092be2b049b"> 51</a></span> <a class="code hl_enumvalue" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a44d8f064decabc690ed1f092be2b049b">NEOLED_CTRL_T_TOT_0</a> = 10, </div> +<div class="line"><a id="l00052" name="l00052"></a><span class="lineno"><a class="line" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412addf4d6d1fd09f145d8aa497c4a7479c2"> 52</a></span> <a class="code hl_enumvalue" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412addf4d6d1fd09f145d8aa497c4a7479c2">NEOLED_CTRL_T_TOT_1</a> = 11, </div> +<div class="line"><a id="l00053" name="l00053"></a><span class="lineno"><a class="line" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a42d09d42d39fc0eb2697853c99f4d5b0"> 53</a></span> <a class="code hl_enumvalue" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a42d09d42d39fc0eb2697853c99f4d5b0">NEOLED_CTRL_T_TOT_2</a> = 12, </div> +<div class="line"><a id="l00054" name="l00054"></a><span class="lineno"><a class="line" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412acbcd3c046b528e1900e86428da231df2"> 54</a></span> <a class="code hl_enumvalue" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412acbcd3c046b528e1900e86428da231df2">NEOLED_CTRL_T_TOT_3</a> = 13, </div> +<div class="line"><a id="l00055" name="l00055"></a><span class="lineno"><a class="line" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a3f1a0ad71d9fd892829ec0246be343b3"> 55</a></span> <a class="code hl_enumvalue" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a3f1a0ad71d9fd892829ec0246be343b3">NEOLED_CTRL_T_TOT_4</a> = 14, </div> +<div class="line"><a id="l00057" name="l00057"></a><span class="lineno"><a class="line" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a7285e332ec7c2b3aeb34290e3e60ded7"> 57</a></span> <a class="code hl_enumvalue" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a7285e332ec7c2b3aeb34290e3e60ded7">NEOLED_CTRL_T_ZERO_H_0</a> = 15, </div> +<div class="line"><a id="l00058" name="l00058"></a><span class="lineno"><a class="line" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a1ef56b35c966786c42f2a2f800e30eae"> 58</a></span> <a class="code hl_enumvalue" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a1ef56b35c966786c42f2a2f800e30eae">NEOLED_CTRL_T_ZERO_H_1</a> = 16, </div> +<div class="line"><a id="l00059" name="l00059"></a><span class="lineno"><a class="line" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a9d9411382d943c1659b6b761c462319b"> 59</a></span> <a class="code hl_enumvalue" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a9d9411382d943c1659b6b761c462319b">NEOLED_CTRL_T_ZERO_H_2</a> = 17, </div> +<div class="line"><a id="l00060" name="l00060"></a><span class="lineno"><a class="line" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412abf2ea111a4ff34b6cb4dd987c5692f5c"> 60</a></span> <a class="code hl_enumvalue" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412abf2ea111a4ff34b6cb4dd987c5692f5c">NEOLED_CTRL_T_ZERO_H_3</a> = 18, </div> +<div class="line"><a id="l00061" name="l00061"></a><span class="lineno"><a class="line" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a0d5d01b8d30119bb86c1d079f7d5a9ad"> 61</a></span> <a class="code hl_enumvalue" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a0d5d01b8d30119bb86c1d079f7d5a9ad">NEOLED_CTRL_T_ZERO_H_4</a> = 19, </div> +<div class="line"><a id="l00063" name="l00063"></a><span class="lineno"><a class="line" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a770df505d47353f6c9289059c416d9c8"> 63</a></span> <a class="code hl_enumvalue" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a770df505d47353f6c9289059c416d9c8">NEOLED_CTRL_T_ONE_H_0</a> = 20, </div> +<div class="line"><a id="l00064" name="l00064"></a><span class="lineno"><a class="line" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412aea15666ad4bb9eb1eba5dc9ed96114a6"> 64</a></span> <a class="code hl_enumvalue" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412aea15666ad4bb9eb1eba5dc9ed96114a6">NEOLED_CTRL_T_ONE_H_1</a> = 21, </div> +<div class="line"><a id="l00065" name="l00065"></a><span class="lineno"><a class="line" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a4d362af8c630823b5104401a9c7d734e"> 65</a></span> <a class="code hl_enumvalue" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a4d362af8c630823b5104401a9c7d734e">NEOLED_CTRL_T_ONE_H_2</a> = 22, </div> +<div class="line"><a id="l00066" name="l00066"></a><span class="lineno"><a class="line" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a369f36e73783c2923d07ca333081a4a6"> 66</a></span> <a class="code hl_enumvalue" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a369f36e73783c2923d07ca333081a4a6">NEOLED_CTRL_T_ONE_H_3</a> = 23, </div> +<div class="line"><a id="l00067" name="l00067"></a><span class="lineno"><a class="line" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a0c15850d0ab005b075f1a317646e18b1"> 67</a></span> <a class="code hl_enumvalue" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a0c15850d0ab005b075f1a317646e18b1">NEOLED_CTRL_T_ONE_H_4</a> = 24, </div> +<div class="line"><a id="l00069" name="l00069"></a><span class="lineno"><a class="line" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a37421074b86a260b276534b7c4949339"> 69</a></span> <a class="code hl_enumvalue" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a37421074b86a260b276534b7c4949339">NEOLED_CTRL_IRQ_CONF</a> = 27, </div> +<div class="line"><a id="l00070" name="l00070"></a><span class="lineno"><a class="line" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a23937f0a728da197590e1d383507cb23"> 70</a></span> <a class="code hl_enumvalue" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a23937f0a728da197590e1d383507cb23">NEOLED_CTRL_TX_EMPTY</a> = 28, </div> +<div class="line"><a id="l00071" name="l00071"></a><span class="lineno"><a class="line" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a16c09df2784cfb6fafffaeaf245f1b73"> 71</a></span> <a class="code hl_enumvalue" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a16c09df2784cfb6fafffaeaf245f1b73">NEOLED_CTRL_TX_HALF</a> = 29, </div> +<div class="line"><a id="l00072" name="l00072"></a><span class="lineno"><a class="line" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412acfac5269688b2a03794dc17b11f1b983"> 72</a></span> <a class="code hl_enumvalue" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412acfac5269688b2a03794dc17b11f1b983">NEOLED_CTRL_TX_FULL</a> = 30, </div> +<div class="line"><a id="l00073" name="l00073"></a><span class="lineno"> 73</span> <a class="code hl_enumvalue" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a55da98b018c7cc32cd1e80087ed9018e">NEOLED_CTRL_TX_BUSY</a> = 31 </div> +<div class="line"><a id="l00074" name="l00074"></a><span class="lineno"><a class="line" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a55da98b018c7cc32cd1e80087ed9018e"> 74</a></span>};</div> +</div> +<div class="line"><a id="l00078" name="l00078"></a><span class="lineno"> 78</span><span class="comment">/**********************************************************************/</span></div> +<div class="line"><a id="l00082" name="l00082"></a><span class="lineno"> 82</span><span class="keywordtype">int</span> <a class="code hl_function" href="neorv32__neoled_8h.html#a57398d92fb4fc735b33e89271726e1d6">neorv32_neoled_available</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00083" name="l00083"></a><span class="lineno"> 83</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__neoled_8h.html#ac6e94602453779a2791bd0734465f5a3">neorv32_neoled_setup</a>(uint32_t prsc, uint32_t t_total, uint32_t t_high_zero, uint32_t t_high_one, <span class="keywordtype">int</span> irq_mode);</div> +<div class="line"><a id="l00084" name="l00084"></a><span class="lineno"> 84</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__neoled_8h.html#adade69c7368c28180b9992d5f0ab6031">neorv32_neoled_setup_ws2812</a>(<span class="keywordtype">int</span> irq_mode);</div> +<div class="line"><a id="l00085" name="l00085"></a><span class="lineno"> 85</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__neoled_8h.html#a484fcc6797b6d9cef86192e9593ec33d">neorv32_neoled_set_mode</a>(uint32_t mode);</div> +<div class="line"><a id="l00086" name="l00086"></a><span class="lineno"> 86</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__neoled_8h.html#a5aa9eb4dd3655fa08e1b61eb0f36589c">neorv32_neoled_strobe_blocking</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00087" name="l00087"></a><span class="lineno"> 87</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__neoled_8h.html#abf7882b949373df0774fc9cc20c2bd2e">neorv32_neoled_strobe_nonblocking</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00088" name="l00088"></a><span class="lineno"> 88</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__neoled_8h.html#a8181d5c1d15b7b5eecdc018341ac14fa">neorv32_neoled_enable</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00089" name="l00089"></a><span class="lineno"> 89</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__neoled_8h.html#a8daaa97a85e0eb94d4a38eb2119ea183">neorv32_neoled_disable</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00090" name="l00090"></a><span class="lineno"> 90</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__neoled_8h.html#a3ee5b3602da3ae982628e2802587e451">neorv32_neoled_write_blocking</a>(uint32_t data);</div> +<div class="line"><a id="l00091" name="l00091"></a><span class="lineno"> 91</span>uint32_t <a class="code hl_function" href="neorv32__neoled_8h.html#a81c2c49198531fb6551eb288e29c084e">neorv32_neoled_get_buffer_size</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00095" name="l00095"></a><span class="lineno"> 95</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen00102" data-start="{" data-end="}"> +<div class="line"><a id="l00102" name="l00102"></a><span class="lineno"><a class="line" href="neorv32__neoled_8h.html#ad2a318bd59be12de34797ced0f7743c6"> 102</a></span><span class="keyword">inline</span> <span class="keywordtype">void</span> __attribute__ ((always_inline)) <a class="code hl_function" href="neorv32__neoled_8h.html#ad2a318bd59be12de34797ced0f7743c6">neorv32_neoled_write_nonblocking</a>(uint32_t data) {</div> +<div class="line"><a id="l00103" name="l00103"></a><span class="lineno"> 103</span> </div> +<div class="line"><a id="l00104" name="l00104"></a><span class="lineno"> 104</span> <a class="code hl_define" href="neorv32__neoled_8h.html#a3ccc1097bc70f92235d693b612fa994a">NEORV32_NEOLED</a>-&gt;DATA = data; <span class="comment">// send new LED data</span></div> +<div class="line"><a id="l00105" name="l00105"></a><span class="lineno"> 105</span>}</div> +</div> +<div class="line"><a id="l00106" name="l00106"></a><span class="lineno"> 106</span> </div> +<div class="line"><a id="l00107" name="l00107"></a><span class="lineno"> 107</span><span class="preprocessor">#endif </span><span class="comment">// neorv32_neoled_h</span></div> +<div class="ttc" id="aneorv32__neoled_8h_html_a3ccc1097bc70f92235d693b612fa994a"><div class="ttname"><a href="neorv32__neoled_8h.html#a3ccc1097bc70f92235d693b612fa994a">NEORV32_NEOLED</a></div><div class="ttdeci">#define NEORV32_NEOLED</div><div class="ttdef"><b>Definition</b> neorv32_neoled.h:35</div></div> +<div class="ttc" id="aneorv32__neoled_8h_html_a3ee5b3602da3ae982628e2802587e451"><div class="ttname"><a href="neorv32__neoled_8h.html#a3ee5b3602da3ae982628e2802587e451">neorv32_neoled_write_blocking</a></div><div class="ttdeci">void neorv32_neoled_write_blocking(uint32_t data)</div><div class="ttdef"><b>Definition</b> neorv32_neoled.c:193</div></div> +<div class="ttc" id="aneorv32__neoled_8h_html_a484fcc6797b6d9cef86192e9593ec33d"><div class="ttname"><a href="neorv32__neoled_8h.html#a484fcc6797b6d9cef86192e9593ec33d">neorv32_neoled_set_mode</a></div><div class="ttdeci">void neorv32_neoled_set_mode(uint32_t mode)</div><div class="ttdef"><b>Definition</b> neorv32_neoled.c:130</div></div> +<div class="ttc" id="aneorv32__neoled_8h_html_a57398d92fb4fc735b33e89271726e1d6"><div class="ttname"><a href="neorv32__neoled_8h.html#a57398d92fb4fc735b33e89271726e1d6">neorv32_neoled_available</a></div><div class="ttdeci">int neorv32_neoled_available(void)</div><div class="ttdef"><b>Definition</b> neorv32_neoled.c:26</div></div> +<div class="ttc" id="aneorv32__neoled_8h_html_a5aa9eb4dd3655fa08e1b61eb0f36589c"><div class="ttname"><a href="neorv32__neoled_8h.html#a5aa9eb4dd3655fa08e1b61eb0f36589c">neorv32_neoled_strobe_blocking</a></div><div class="ttdeci">void neorv32_neoled_strobe_blocking(void)</div><div class="ttdef"><b>Definition</b> neorv32_neoled.c:142</div></div> +<div class="ttc" id="aneorv32__neoled_8h_html_a8181d5c1d15b7b5eecdc018341ac14fa"><div class="ttname"><a href="neorv32__neoled_8h.html#a8181d5c1d15b7b5eecdc018341ac14fa">neorv32_neoled_enable</a></div><div class="ttdeci">void neorv32_neoled_enable(void)</div><div class="ttdef"><b>Definition</b> neorv32_neoled.c:171</div></div> +<div class="ttc" id="aneorv32__neoled_8h_html_a81c2c49198531fb6551eb288e29c084e"><div class="ttname"><a href="neorv32__neoled_8h.html#a81c2c49198531fb6551eb288e29c084e">neorv32_neoled_get_buffer_size</a></div><div class="ttdeci">uint32_t neorv32_neoled_get_buffer_size(void)</div><div class="ttdef"><b>Definition</b> neorv32_neoled.c:210</div></div> +<div class="ttc" id="aneorv32__neoled_8h_html_a8daaa97a85e0eb94d4a38eb2119ea183"><div class="ttname"><a href="neorv32__neoled_8h.html#a8daaa97a85e0eb94d4a38eb2119ea183">neorv32_neoled_disable</a></div><div class="ttdeci">void neorv32_neoled_disable(void)</div><div class="ttdef"><b>Definition</b> neorv32_neoled.c:180</div></div> +<div class="ttc" id="aneorv32__neoled_8h_html_ab99c7fed050816eae0fa0315562e0412"><div class="ttname"><a href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412">NEORV32_NEOLED_CTRL_enum</a></div><div class="ttdeci">NEORV32_NEOLED_CTRL_enum</div><div class="ttdef"><b>Definition</b> neorv32_neoled.h:38</div></div> +<div class="ttc" id="aneorv32__neoled_8h_html_ab99c7fed050816eae0fa0315562e0412a0c15850d0ab005b075f1a317646e18b1"><div class="ttname"><a href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a0c15850d0ab005b075f1a317646e18b1">NEOLED_CTRL_T_ONE_H_4</a></div><div class="ttdeci">@ NEOLED_CTRL_T_ONE_H_4</div><div class="ttdef"><b>Definition</b> neorv32_neoled.h:67</div></div> +<div class="ttc" id="aneorv32__neoled_8h_html_ab99c7fed050816eae0fa0315562e0412a0d5d01b8d30119bb86c1d079f7d5a9ad"><div class="ttname"><a href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a0d5d01b8d30119bb86c1d079f7d5a9ad">NEOLED_CTRL_T_ZERO_H_4</a></div><div class="ttdeci">@ NEOLED_CTRL_T_ZERO_H_4</div><div class="ttdef"><b>Definition</b> neorv32_neoled.h:61</div></div> +<div class="ttc" id="aneorv32__neoled_8h_html_ab99c7fed050816eae0fa0315562e0412a0f4178d81ec6fe9a8b0e30230d318a91"><div class="ttname"><a href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a0f4178d81ec6fe9a8b0e30230d318a91">NEOLED_CTRL_PRSC1</a></div><div class="ttdeci">@ NEOLED_CTRL_PRSC1</div><div class="ttdef"><b>Definition</b> neorv32_neoled.h:43</div></div> +<div class="ttc" id="aneorv32__neoled_8h_html_ab99c7fed050816eae0fa0315562e0412a142ed3fd65e01f853666a1169f920ad0"><div class="ttname"><a href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a142ed3fd65e01f853666a1169f920ad0">NEOLED_CTRL_PRSC0</a></div><div class="ttdeci">@ NEOLED_CTRL_PRSC0</div><div class="ttdef"><b>Definition</b> neorv32_neoled.h:42</div></div> +<div class="ttc" id="aneorv32__neoled_8h_html_ab99c7fed050816eae0fa0315562e0412a16c09df2784cfb6fafffaeaf245f1b73"><div class="ttname"><a href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a16c09df2784cfb6fafffaeaf245f1b73">NEOLED_CTRL_TX_HALF</a></div><div class="ttdeci">@ NEOLED_CTRL_TX_HALF</div><div class="ttdef"><b>Definition</b> neorv32_neoled.h:71</div></div> +<div class="ttc" id="aneorv32__neoled_8h_html_ab99c7fed050816eae0fa0315562e0412a1ef56b35c966786c42f2a2f800e30eae"><div class="ttname"><a href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a1ef56b35c966786c42f2a2f800e30eae">NEOLED_CTRL_T_ZERO_H_1</a></div><div class="ttdeci">@ NEOLED_CTRL_T_ZERO_H_1</div><div class="ttdef"><b>Definition</b> neorv32_neoled.h:58</div></div> +<div class="ttc" id="aneorv32__neoled_8h_html_ab99c7fed050816eae0fa0315562e0412a23937f0a728da197590e1d383507cb23"><div class="ttname"><a href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a23937f0a728da197590e1d383507cb23">NEOLED_CTRL_TX_EMPTY</a></div><div class="ttdeci">@ NEOLED_CTRL_TX_EMPTY</div><div class="ttdef"><b>Definition</b> neorv32_neoled.h:70</div></div> +<div class="ttc" id="aneorv32__neoled_8h_html_ab99c7fed050816eae0fa0315562e0412a369f36e73783c2923d07ca333081a4a6"><div class="ttname"><a href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a369f36e73783c2923d07ca333081a4a6">NEOLED_CTRL_T_ONE_H_3</a></div><div class="ttdeci">@ NEOLED_CTRL_T_ONE_H_3</div><div class="ttdef"><b>Definition</b> neorv32_neoled.h:66</div></div> +<div class="ttc" id="aneorv32__neoled_8h_html_ab99c7fed050816eae0fa0315562e0412a37421074b86a260b276534b7c4949339"><div class="ttname"><a href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a37421074b86a260b276534b7c4949339">NEOLED_CTRL_IRQ_CONF</a></div><div class="ttdeci">@ NEOLED_CTRL_IRQ_CONF</div><div class="ttdef"><b>Definition</b> neorv32_neoled.h:69</div></div> +<div class="ttc" id="aneorv32__neoled_8h_html_ab99c7fed050816eae0fa0315562e0412a3bb5d0d1f78cebccbc8620a0194f43b8"><div class="ttname"><a href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a3bb5d0d1f78cebccbc8620a0194f43b8">NEOLED_CTRL_BUFS_0</a></div><div class="ttdeci">@ NEOLED_CTRL_BUFS_0</div><div class="ttdef"><b>Definition</b> neorv32_neoled.h:46</div></div> +<div class="ttc" id="aneorv32__neoled_8h_html_ab99c7fed050816eae0fa0315562e0412a3d8d54c05080fddb16df4176527bafa8"><div class="ttname"><a href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a3d8d54c05080fddb16df4176527bafa8">NEOLED_CTRL_PRSC2</a></div><div class="ttdeci">@ NEOLED_CTRL_PRSC2</div><div class="ttdef"><b>Definition</b> neorv32_neoled.h:44</div></div> +<div class="ttc" id="aneorv32__neoled_8h_html_ab99c7fed050816eae0fa0315562e0412a3f1a0ad71d9fd892829ec0246be343b3"><div class="ttname"><a href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a3f1a0ad71d9fd892829ec0246be343b3">NEOLED_CTRL_T_TOT_4</a></div><div class="ttdeci">@ NEOLED_CTRL_T_TOT_4</div><div class="ttdef"><b>Definition</b> neorv32_neoled.h:55</div></div> +<div class="ttc" id="aneorv32__neoled_8h_html_ab99c7fed050816eae0fa0315562e0412a42d09d42d39fc0eb2697853c99f4d5b0"><div class="ttname"><a href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a42d09d42d39fc0eb2697853c99f4d5b0">NEOLED_CTRL_T_TOT_2</a></div><div class="ttdeci">@ NEOLED_CTRL_T_TOT_2</div><div class="ttdef"><b>Definition</b> neorv32_neoled.h:53</div></div> +<div class="ttc" id="aneorv32__neoled_8h_html_ab99c7fed050816eae0fa0315562e0412a436ad310b025bd3000af37986c193de5"><div class="ttname"><a href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a436ad310b025bd3000af37986c193de5">NEOLED_CTRL_STROBE</a></div><div class="ttdeci">@ NEOLED_CTRL_STROBE</div><div class="ttdef"><b>Definition</b> neorv32_neoled.h:41</div></div> +<div class="ttc" id="aneorv32__neoled_8h_html_ab99c7fed050816eae0fa0315562e0412a44d8f064decabc690ed1f092be2b049b"><div class="ttname"><a href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a44d8f064decabc690ed1f092be2b049b">NEOLED_CTRL_T_TOT_0</a></div><div class="ttdeci">@ NEOLED_CTRL_T_TOT_0</div><div class="ttdef"><b>Definition</b> neorv32_neoled.h:51</div></div> +<div class="ttc" id="aneorv32__neoled_8h_html_ab99c7fed050816eae0fa0315562e0412a4d362af8c630823b5104401a9c7d734e"><div class="ttname"><a href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a4d362af8c630823b5104401a9c7d734e">NEOLED_CTRL_T_ONE_H_2</a></div><div class="ttdeci">@ NEOLED_CTRL_T_ONE_H_2</div><div class="ttdef"><b>Definition</b> neorv32_neoled.h:65</div></div> +<div class="ttc" id="aneorv32__neoled_8h_html_ab99c7fed050816eae0fa0315562e0412a55da98b018c7cc32cd1e80087ed9018e"><div class="ttname"><a href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a55da98b018c7cc32cd1e80087ed9018e">NEOLED_CTRL_TX_BUSY</a></div><div class="ttdeci">@ NEOLED_CTRL_TX_BUSY</div><div class="ttdef"><b>Definition</b> neorv32_neoled.h:73</div></div> +<div class="ttc" id="aneorv32__neoled_8h_html_ab99c7fed050816eae0fa0315562e0412a7285e332ec7c2b3aeb34290e3e60ded7"><div class="ttname"><a href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a7285e332ec7c2b3aeb34290e3e60ded7">NEOLED_CTRL_T_ZERO_H_0</a></div><div class="ttdeci">@ NEOLED_CTRL_T_ZERO_H_0</div><div class="ttdef"><b>Definition</b> neorv32_neoled.h:57</div></div> +<div class="ttc" id="aneorv32__neoled_8h_html_ab99c7fed050816eae0fa0315562e0412a770df505d47353f6c9289059c416d9c8"><div class="ttname"><a href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a770df505d47353f6c9289059c416d9c8">NEOLED_CTRL_T_ONE_H_0</a></div><div class="ttdeci">@ NEOLED_CTRL_T_ONE_H_0</div><div class="ttdef"><b>Definition</b> neorv32_neoled.h:63</div></div> +<div class="ttc" id="aneorv32__neoled_8h_html_ab99c7fed050816eae0fa0315562e0412a9d9411382d943c1659b6b761c462319b"><div class="ttname"><a href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a9d9411382d943c1659b6b761c462319b">NEOLED_CTRL_T_ZERO_H_2</a></div><div class="ttdeci">@ NEOLED_CTRL_T_ZERO_H_2</div><div class="ttdef"><b>Definition</b> neorv32_neoled.h:59</div></div> +<div class="ttc" id="aneorv32__neoled_8h_html_ab99c7fed050816eae0fa0315562e0412abf2ea111a4ff34b6cb4dd987c5692f5c"><div class="ttname"><a href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412abf2ea111a4ff34b6cb4dd987c5692f5c">NEOLED_CTRL_T_ZERO_H_3</a></div><div class="ttdeci">@ NEOLED_CTRL_T_ZERO_H_3</div><div class="ttdef"><b>Definition</b> neorv32_neoled.h:60</div></div> +<div class="ttc" id="aneorv32__neoled_8h_html_ab99c7fed050816eae0fa0315562e0412abf6779cbeae87ab55efc9573932fc865"><div class="ttname"><a href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412abf6779cbeae87ab55efc9573932fc865">NEOLED_CTRL_MODE</a></div><div class="ttdeci">@ NEOLED_CTRL_MODE</div><div class="ttdef"><b>Definition</b> neorv32_neoled.h:40</div></div> +<div class="ttc" id="aneorv32__neoled_8h_html_ab99c7fed050816eae0fa0315562e0412ac1922a5311e91a74710eddbf86ccc1c1"><div class="ttname"><a href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412ac1922a5311e91a74710eddbf86ccc1c1">NEOLED_CTRL_BUFS_3</a></div><div class="ttdeci">@ NEOLED_CTRL_BUFS_3</div><div class="ttdef"><b>Definition</b> neorv32_neoled.h:49</div></div> +<div class="ttc" id="aneorv32__neoled_8h_html_ab99c7fed050816eae0fa0315562e0412acbcd3c046b528e1900e86428da231df2"><div class="ttname"><a href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412acbcd3c046b528e1900e86428da231df2">NEOLED_CTRL_T_TOT_3</a></div><div class="ttdeci">@ NEOLED_CTRL_T_TOT_3</div><div class="ttdef"><b>Definition</b> neorv32_neoled.h:54</div></div> +<div class="ttc" id="aneorv32__neoled_8h_html_ab99c7fed050816eae0fa0315562e0412acfac5269688b2a03794dc17b11f1b983"><div class="ttname"><a href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412acfac5269688b2a03794dc17b11f1b983">NEOLED_CTRL_TX_FULL</a></div><div class="ttdeci">@ NEOLED_CTRL_TX_FULL</div><div class="ttdef"><b>Definition</b> neorv32_neoled.h:72</div></div> +<div class="ttc" id="aneorv32__neoled_8h_html_ab99c7fed050816eae0fa0315562e0412addf4d6d1fd09f145d8aa497c4a7479c2"><div class="ttname"><a href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412addf4d6d1fd09f145d8aa497c4a7479c2">NEOLED_CTRL_T_TOT_1</a></div><div class="ttdeci">@ NEOLED_CTRL_T_TOT_1</div><div class="ttdef"><b>Definition</b> neorv32_neoled.h:52</div></div> +<div class="ttc" id="aneorv32__neoled_8h_html_ab99c7fed050816eae0fa0315562e0412ae7b9d45c4ef69ca15fa13aa107e68156"><div class="ttname"><a href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412ae7b9d45c4ef69ca15fa13aa107e68156">NEOLED_CTRL_BUFS_2</a></div><div class="ttdeci">@ NEOLED_CTRL_BUFS_2</div><div class="ttdef"><b>Definition</b> neorv32_neoled.h:48</div></div> +<div class="ttc" id="aneorv32__neoled_8h_html_ab99c7fed050816eae0fa0315562e0412aea15666ad4bb9eb1eba5dc9ed96114a6"><div class="ttname"><a href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412aea15666ad4bb9eb1eba5dc9ed96114a6">NEOLED_CTRL_T_ONE_H_1</a></div><div class="ttdeci">@ NEOLED_CTRL_T_ONE_H_1</div><div class="ttdef"><b>Definition</b> neorv32_neoled.h:64</div></div> +<div class="ttc" id="aneorv32__neoled_8h_html_ab99c7fed050816eae0fa0315562e0412aed0a878e73ad501bed3bbe6905974368"><div class="ttname"><a href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412aed0a878e73ad501bed3bbe6905974368">NEOLED_CTRL_BUFS_1</a></div><div class="ttdeci">@ NEOLED_CTRL_BUFS_1</div><div class="ttdef"><b>Definition</b> neorv32_neoled.h:47</div></div> +<div class="ttc" id="aneorv32__neoled_8h_html_ab99c7fed050816eae0fa0315562e0412af97ab77b33a250d87025c3dd3a21fea7"><div class="ttname"><a href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412af97ab77b33a250d87025c3dd3a21fea7">NEOLED_CTRL_EN</a></div><div class="ttdeci">@ NEOLED_CTRL_EN</div><div class="ttdef"><b>Definition</b> neorv32_neoled.h:39</div></div> +<div class="ttc" id="aneorv32__neoled_8h_html_abf7882b949373df0774fc9cc20c2bd2e"><div class="ttname"><a href="neorv32__neoled_8h.html#abf7882b949373df0774fc9cc20c2bd2e">neorv32_neoled_strobe_nonblocking</a></div><div class="ttdeci">void neorv32_neoled_strobe_nonblocking(void)</div><div class="ttdef"><b>Definition</b> neorv32_neoled.c:157</div></div> +<div class="ttc" id="aneorv32__neoled_8h_html_ac6e94602453779a2791bd0734465f5a3"><div class="ttname"><a href="neorv32__neoled_8h.html#ac6e94602453779a2791bd0734465f5a3">neorv32_neoled_setup</a></div><div class="ttdeci">void neorv32_neoled_setup(uint32_t prsc, uint32_t t_total, uint32_t t_high_zero, uint32_t t_high_one, int irq_mode)</div><div class="ttdef"><b>Definition</b> neorv32_neoled.c:47</div></div> +<div class="ttc" id="aneorv32__neoled_8h_html_ad2a318bd59be12de34797ced0f7743c6"><div class="ttname"><a href="neorv32__neoled_8h.html#ad2a318bd59be12de34797ced0f7743c6">neorv32_neoled_write_nonblocking</a></div><div class="ttdeci">void neorv32_neoled_write_nonblocking(uint32_t data)</div><div class="ttdef"><b>Definition</b> neorv32_neoled.h:102</div></div> +<div class="ttc" id="aneorv32__neoled_8h_html_adade69c7368c28180b9992d5f0ab6031"><div class="ttname"><a href="neorv32__neoled_8h.html#adade69c7368c28180b9992d5f0ab6031">neorv32_neoled_setup_ws2812</a></div><div class="ttdeci">void neorv32_neoled_setup_ws2812(int irq_mode)</div><div class="ttdef"><b>Definition</b> neorv32_neoled.c:71</div></div> +<div class="ttc" id="astructneorv32__neoled__t_html"><div class="ttname"><a href="structneorv32__neoled__t.html">neorv32_neoled_t</a></div><div class="ttdef"><b>Definition</b> neorv32_neoled.h:29</div></div> +<div class="ttc" id="astructneorv32__neoled__t_html_a995fb1d63a9dfb3f20d715932781c1de"><div class="ttname"><a href="structneorv32__neoled__t.html#a995fb1d63a9dfb3f20d715932781c1de">neorv32_neoled_t::DATA</a></div><div class="ttdeci">uint32_t DATA</div><div class="ttdef"><b>Definition</b> neorv32_neoled.h:31</div></div> +<div class="ttc" id="astructneorv32__neoled__t_html_adfe7618c002ff88dd22e65fcedfd6139"><div class="ttname"><a href="structneorv32__neoled__t.html#adfe7618c002ff88dd22e65fcedfd6139">neorv32_neoled_t::CTRL</a></div><div class="ttdeci">uint32_t CTRL</div><div class="ttdef"><b>Definition</b> neorv32_neoled.h:30</div></div> +</div><!-- fragment --></div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/neorv32__onewire_8c.html b/sw/neorv32__onewire_8c.html new file mode 100644 index 0000000000..97ccdd9a88 --- /dev/null +++ b/sw/neorv32__onewire_8c.html @@ -0,0 +1,552 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/lib/source/neorv32_onewire.c File Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_7d04193005ada6f9450f847f4adb6b5b.html">lib</a></li><li class="navelem"><a class="el" href="dir_0c6ac14e2254a316d41123f98feeb67b.html">source</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#func-members">Functions</a> </div> + <div class="headertitle"><div class="title">neorv32_onewire.c File Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p>1-Wire Interface Controller (ONEWIRE) HW driver source file. +<a href="#details">More...</a></p> +<div class="textblock"><code>#include &quot;<a class="el" href="neorv32_8h_source.html">neorv32.h</a>&quot;</code><br /> +</div><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="func-members" name="func-members"></a> +Functions</h2></td></tr> +<tr class="memitem:a865e5c381fd3c27c6981a589a5124d1e" id="r_a865e5c381fd3c27c6981a589a5124d1e"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a865e5c381fd3c27c6981a589a5124d1e">neorv32_onewire_available</a> (void)</td></tr> +<tr class="separator:a865e5c381fd3c27c6981a589a5124d1e"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a224005037387484dfa510a1355a62828" id="r_a224005037387484dfa510a1355a62828"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a224005037387484dfa510a1355a62828">neorv32_onewire_setup</a> (uint32_t t_base)</td></tr> +<tr class="separator:a224005037387484dfa510a1355a62828"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ae6fe766e7decf18869cfb86bba741ca4" id="r_ae6fe766e7decf18869cfb86bba741ca4"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ae6fe766e7decf18869cfb86bba741ca4">neorv32_onewire_enable</a> (void)</td></tr> +<tr class="separator:ae6fe766e7decf18869cfb86bba741ca4"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a7e329eeb1cd98301a53b271a6a102385" id="r_a7e329eeb1cd98301a53b271a6a102385"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a7e329eeb1cd98301a53b271a6a102385">neorv32_onewire_disable</a> (void)</td></tr> +<tr class="separator:a7e329eeb1cd98301a53b271a6a102385"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a122531c7154126858c46d89e003d838d" id="r_a122531c7154126858c46d89e003d838d"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a122531c7154126858c46d89e003d838d">neorv32_onewire_sense</a> (void)</td></tr> +<tr class="separator:a122531c7154126858c46d89e003d838d"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a01b6236b89c045ddbd58398361c6ee0a" id="r_a01b6236b89c045ddbd58398361c6ee0a"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a01b6236b89c045ddbd58398361c6ee0a">neorv32_onewire_busy</a> (void)</td></tr> +<tr class="separator:a01b6236b89c045ddbd58398361c6ee0a"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a3072f7167831edc95dee44ecfef6a0d4" id="r_a3072f7167831edc95dee44ecfef6a0d4"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a3072f7167831edc95dee44ecfef6a0d4">neorv32_onewire_reset</a> (void)</td></tr> +<tr class="separator:a3072f7167831edc95dee44ecfef6a0d4"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a43eb8a08eeaa83e3d7e9aa5058a4269f" id="r_a43eb8a08eeaa83e3d7e9aa5058a4269f"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a43eb8a08eeaa83e3d7e9aa5058a4269f">neorv32_onewire_reset_get_presence</a> (void)</td></tr> +<tr class="separator:a43eb8a08eeaa83e3d7e9aa5058a4269f"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aace8398062b759256a516e6245aced83" id="r_aace8398062b759256a516e6245aced83"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aace8398062b759256a516e6245aced83">neorv32_onewire_read_bit</a> (void)</td></tr> +<tr class="separator:aace8398062b759256a516e6245aced83"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aa4a19d2d8dc3b3401307615aec201190" id="r_aa4a19d2d8dc3b3401307615aec201190"><td class="memItemLeft" align="right" valign="top">uint8_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aa4a19d2d8dc3b3401307615aec201190">neorv32_onewire_read_bit_get</a> (void)</td></tr> +<tr class="separator:aa4a19d2d8dc3b3401307615aec201190"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a49d0a2a386f129fd2f4fed880bba31d4" id="r_a49d0a2a386f129fd2f4fed880bba31d4"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a49d0a2a386f129fd2f4fed880bba31d4">neorv32_onewire_write_bit</a> (uint8_t bit)</td></tr> +<tr class="separator:a49d0a2a386f129fd2f4fed880bba31d4"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a01ddba7a9148be542b5c52e39e6f46d6" id="r_a01ddba7a9148be542b5c52e39e6f46d6"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a01ddba7a9148be542b5c52e39e6f46d6">neorv32_onewire_read_byte</a> (void)</td></tr> +<tr class="separator:a01ddba7a9148be542b5c52e39e6f46d6"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a4c7eec15c095c97c939163f631f51dab" id="r_a4c7eec15c095c97c939163f631f51dab"><td class="memItemLeft" align="right" valign="top">uint8_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a4c7eec15c095c97c939163f631f51dab">neorv32_onewire_read_byte_get</a> (void)</td></tr> +<tr class="separator:a4c7eec15c095c97c939163f631f51dab"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a23b96b68c3214b188525eb102cafb620" id="r_a23b96b68c3214b188525eb102cafb620"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a23b96b68c3214b188525eb102cafb620">neorv32_onewire_write_byte</a> (uint8_t byte)</td></tr> +<tr class="separator:a23b96b68c3214b188525eb102cafb620"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:af8ca6be495176797b7da3857e2f794f9" id="r_af8ca6be495176797b7da3857e2f794f9"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#af8ca6be495176797b7da3857e2f794f9">neorv32_onewire_reset_blocking</a> (void)</td></tr> +<tr class="separator:af8ca6be495176797b7da3857e2f794f9"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ace8b7cf697b068b6b51676d84dec5960" id="r_ace8b7cf697b068b6b51676d84dec5960"><td class="memItemLeft" align="right" valign="top">uint8_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ace8b7cf697b068b6b51676d84dec5960">neorv32_onewire_read_bit_blocking</a> (void)</td></tr> +<tr class="separator:ace8b7cf697b068b6b51676d84dec5960"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a6f7b6690a2437e0b574a8a9a23dc0eaa" id="r_a6f7b6690a2437e0b574a8a9a23dc0eaa"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a6f7b6690a2437e0b574a8a9a23dc0eaa">neorv32_onewire_write_bit_blocking</a> (uint8_t bit)</td></tr> +<tr class="separator:a6f7b6690a2437e0b574a8a9a23dc0eaa"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a7510e65a26aeefb40e994fd00667537e" id="r_a7510e65a26aeefb40e994fd00667537e"><td class="memItemLeft" align="right" valign="top">uint8_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a7510e65a26aeefb40e994fd00667537e">neorv32_onewire_read_byte_blocking</a> (void)</td></tr> +<tr class="separator:a7510e65a26aeefb40e994fd00667537e"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ac78557c77482b59394677f42fda4fdf1" id="r_ac78557c77482b59394677f42fda4fdf1"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ac78557c77482b59394677f42fda4fdf1">neorv32_onewire_write_byte_blocking</a> (uint8_t byte)</td></tr> +<tr class="separator:ac78557c77482b59394677f42fda4fdf1"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>1-Wire Interface Controller (ONEWIRE) HW driver source file. </p> +<dl class="section note"><dt>Note</dt><dd>These functions should only be used if the ONEWIRE unit was synthesized (IO_ONEWIRE_EN = true).</dd></dl> +<dl class="section see"><dt>See also</dt><dd><a href="https://stnolting.github.io/neorv32/sw/files.html">https://stnolting.github.io/neorv32/sw/files.html</a> </dd></dl> +</div><h2 class="groupheader">Function Documentation</h2> +<a id="a865e5c381fd3c27c6981a589a5124d1e" name="a865e5c381fd3c27c6981a589a5124d1e"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a865e5c381fd3c27c6981a589a5124d1e">&#9670;&#160;</a></span>neorv32_onewire_available()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_onewire_available </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Check if ONEWIRE controller was synthesized.</p> +<dl class="section return"><dt>Returns</dt><dd>0 if ONEWIRE was not synthesized, 1 if ONEWIRE is available. </dd></dl> + +</div> +</div> +<a id="a01b6236b89c045ddbd58398361c6ee0a" name="a01b6236b89c045ddbd58398361c6ee0a"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a01b6236b89c045ddbd58398361c6ee0a">&#9670;&#160;</a></span>neorv32_onewire_busy()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_onewire_busy </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Check if ONEWIRE module is busy.</p> +<dl class="section note"><dt>Note</dt><dd>This function is non-blocking.</dd></dl> +<dl class="section return"><dt>Returns</dt><dd>0 if not busy, 1 if busy. </dd></dl> + +</div> +</div> +<a id="a7e329eeb1cd98301a53b271a6a102385" name="a7e329eeb1cd98301a53b271a6a102385"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a7e329eeb1cd98301a53b271a6a102385">&#9670;&#160;</a></span>neorv32_onewire_disable()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_onewire_disable </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Disable ONEWIRE controller. </p> + +</div> +</div> +<a id="ae6fe766e7decf18869cfb86bba741ca4" name="ae6fe766e7decf18869cfb86bba741ca4"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ae6fe766e7decf18869cfb86bba741ca4">&#9670;&#160;</a></span>neorv32_onewire_enable()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_onewire_enable </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Enable ONEWIRE controller. </p> + +</div> +</div> +<a id="aace8398062b759256a516e6245aced83" name="aace8398062b759256a516e6245aced83"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aace8398062b759256a516e6245aced83">&#9670;&#160;</a></span>neorv32_onewire_read_bit()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_onewire_read_bit </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Initiate single-bit read.</p> +<dl class="section note"><dt>Note</dt><dd>This function is non-blocking. </dd></dl> + +</div> +</div> +<a id="ace8b7cf697b068b6b51676d84dec5960" name="ace8b7cf697b068b6b51676d84dec5960"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ace8b7cf697b068b6b51676d84dec5960">&#9670;&#160;</a></span>neorv32_onewire_read_bit_blocking()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint8_t neorv32_onewire_read_bit_blocking </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Read single bit.</p> +<dl class="section warning"><dt>Warning</dt><dd>This function is blocking!</dd></dl> +<dl class="section return"><dt>Returns</dt><dd>Read bit in bit 0. </dd></dl> + +</div> +</div> +<a id="aa4a19d2d8dc3b3401307615aec201190" name="aa4a19d2d8dc3b3401307615aec201190"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aa4a19d2d8dc3b3401307615aec201190">&#9670;&#160;</a></span>neorv32_onewire_read_bit_get()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint8_t neorv32_onewire_read_bit_get </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Get bit from previous single-bit read operation</p> +<dl class="section note"><dt>Note</dt><dd>This function is non-blocking.</dd></dl> +<dl class="section return"><dt>Returns</dt><dd>Read bit in bit 0. </dd></dl> + +</div> +</div> +<a id="a01ddba7a9148be542b5c52e39e6f46d6" name="a01ddba7a9148be542b5c52e39e6f46d6"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a01ddba7a9148be542b5c52e39e6f46d6">&#9670;&#160;</a></span>neorv32_onewire_read_byte()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_onewire_read_byte </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Initiate read byte.</p> +<dl class="section note"><dt>Note</dt><dd>This function is non-blocking. </dd></dl> + +</div> +</div> +<a id="a7510e65a26aeefb40e994fd00667537e" name="a7510e65a26aeefb40e994fd00667537e"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a7510e65a26aeefb40e994fd00667537e">&#9670;&#160;</a></span>neorv32_onewire_read_byte_blocking()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint8_t neorv32_onewire_read_byte_blocking </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Read byte.</p> +<dl class="section warning"><dt>Warning</dt><dd>This function is blocking!</dd></dl> +<dl class="section return"><dt>Returns</dt><dd>Read byte. </dd></dl> + +</div> +</div> +<a id="a4c7eec15c095c97c939163f631f51dab" name="a4c7eec15c095c97c939163f631f51dab"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a4c7eec15c095c97c939163f631f51dab">&#9670;&#160;</a></span>neorv32_onewire_read_byte_get()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint8_t neorv32_onewire_read_byte_get </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Get data from previous read byte operation.</p> +<dl class="section note"><dt>Note</dt><dd>This function is non-blocking.</dd></dl> +<dl class="section return"><dt>Returns</dt><dd>Read byte. </dd></dl> + +</div> +</div> +<a id="a3072f7167831edc95dee44ecfef6a0d4" name="a3072f7167831edc95dee44ecfef6a0d4"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a3072f7167831edc95dee44ecfef6a0d4">&#9670;&#160;</a></span>neorv32_onewire_reset()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_onewire_reset </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Initiate reset pulse.</p> +<dl class="section note"><dt>Note</dt><dd>This function is non-blocking. </dd></dl> + +</div> +</div> +<a id="af8ca6be495176797b7da3857e2f794f9" name="af8ca6be495176797b7da3857e2f794f9"></a> +<h2 class="memtitle"><span class="permalink"><a href="#af8ca6be495176797b7da3857e2f794f9">&#9670;&#160;</a></span>neorv32_onewire_reset_blocking()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_onewire_reset_blocking </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Generate reset pulse and check if any bus device is present.</p> +<dl class="section warning"><dt>Warning</dt><dd>This function is blocking!</dd></dl> +<dl class="section return"><dt>Returns</dt><dd>0 if at lest one device is present, -1 otherwise </dd></dl> + +</div> +</div> +<a id="a43eb8a08eeaa83e3d7e9aa5058a4269f" name="a43eb8a08eeaa83e3d7e9aa5058a4269f"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a43eb8a08eeaa83e3d7e9aa5058a4269f">&#9670;&#160;</a></span>neorv32_onewire_reset_get_presence()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_onewire_reset_get_presence </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Get bus presence (after RESET).</p> +<dl class="section note"><dt>Note</dt><dd>This function is non-blocking.</dd></dl> +<dl class="section return"><dt>Returns</dt><dd>0 if at lest one device is present, -1 otherwise </dd></dl> + +</div> +</div> +<a id="a122531c7154126858c46d89e003d838d" name="a122531c7154126858c46d89e003d838d"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a122531c7154126858c46d89e003d838d">&#9670;&#160;</a></span>neorv32_onewire_sense()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_onewire_sense </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Get current bus state.</p> +<dl class="section return"><dt>Returns</dt><dd>1 if bus is high, 0 if bus is low. </dd></dl> + +</div> +</div> +<a id="a224005037387484dfa510a1355a62828" name="a224005037387484dfa510a1355a62828"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a224005037387484dfa510a1355a62828">&#9670;&#160;</a></span>neorv32_onewire_setup()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_onewire_setup </td> + <td>(</td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>t_base</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Reset, configure and enable ONEWIRE interface controller.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">t_base</td><td>Base tick time in ns. </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>0 if configuration failed, otherwise the actual t_base time in ns is returned. </dd></dl> + +</div> +</div> +<a id="a49d0a2a386f129fd2f4fed880bba31d4" name="a49d0a2a386f129fd2f4fed880bba31d4"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a49d0a2a386f129fd2f4fed880bba31d4">&#9670;&#160;</a></span>neorv32_onewire_write_bit()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_onewire_write_bit </td> + <td>(</td> + <td class="paramtype">uint8_t</td> <td class="paramname"><span class="paramname"><em>bit</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Initiate single-bit write.</p> +<dl class="section note"><dt>Note</dt><dd>This function is non-blocking.</dd></dl> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">bit</td><td>Bit to be send. </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="a6f7b6690a2437e0b574a8a9a23dc0eaa" name="a6f7b6690a2437e0b574a8a9a23dc0eaa"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a6f7b6690a2437e0b574a8a9a23dc0eaa">&#9670;&#160;</a></span>neorv32_onewire_write_bit_blocking()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_onewire_write_bit_blocking </td> + <td>(</td> + <td class="paramtype">uint8_t</td> <td class="paramname"><span class="paramname"><em>bit</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Write single bit.</p> +<dl class="section warning"><dt>Warning</dt><dd>This function is blocking!</dd></dl> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">bit</td><td>Bit to be send. </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="a23b96b68c3214b188525eb102cafb620" name="a23b96b68c3214b188525eb102cafb620"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a23b96b68c3214b188525eb102cafb620">&#9670;&#160;</a></span>neorv32_onewire_write_byte()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_onewire_write_byte </td> + <td>(</td> + <td class="paramtype">uint8_t</td> <td class="paramname"><span class="paramname"><em>byte</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Initiate write byte.</p> +<dl class="section note"><dt>Note</dt><dd>This function is non-blocking.</dd></dl> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">byte</td><td>Byte to be send. </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="ac78557c77482b59394677f42fda4fdf1" name="ac78557c77482b59394677f42fda4fdf1"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ac78557c77482b59394677f42fda4fdf1">&#9670;&#160;</a></span>neorv32_onewire_write_byte_blocking()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_onewire_write_byte_blocking </td> + <td>(</td> + <td class="paramtype">uint8_t</td> <td class="paramname"><span class="paramname"><em>byte</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Write byte.</p> +<dl class="section warning"><dt>Warning</dt><dd>This function is blocking!</dd></dl> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">byte</td><td>Byte to be send. </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/neorv32__onewire_8h.html b/sw/neorv32__onewire_8h.html new file mode 100644 index 0000000000..6b848b54c7 --- /dev/null +++ b/sw/neorv32__onewire_8h.html @@ -0,0 +1,682 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/lib/include/neorv32_onewire.h File Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_7d04193005ada6f9450f847f4adb6b5b.html">lib</a></li><li class="navelem"><a class="el" href="dir_752b1e5d3973bf735fa78bf6b4727df9.html">include</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#nested-classes">Data Structures</a> </div> + <div class="headertitle"><div class="title">neorv32_onewire.h File Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p>1-Wire Interface Controller (ONEWIRE) HW driver header file. +<a href="#details">More...</a></p> +<div class="textblock"><code>#include &lt;stdint.h&gt;</code><br /> +</div> +<p><a href="neorv32__onewire_8h_source.html">Go to the source code of this file.</a></p> +<table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="nested-classes" name="nested-classes"></a> +Data Structures</h2></td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">struct &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structneorv32__onewire__t.html">neorv32_onewire_t</a></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="func-members" name="func-members"></a> +Functions</h2></td></tr> +<tr><td colspan="2"><div class="groupHeader">Prototypes</div></td></tr> +<tr class="memitem:a865e5c381fd3c27c6981a589a5124d1e" id="r_a865e5c381fd3c27c6981a589a5124d1e"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a865e5c381fd3c27c6981a589a5124d1e">neorv32_onewire_available</a> (void)</td></tr> +<tr class="separator:a865e5c381fd3c27c6981a589a5124d1e"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a224005037387484dfa510a1355a62828" id="r_a224005037387484dfa510a1355a62828"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a224005037387484dfa510a1355a62828">neorv32_onewire_setup</a> (uint32_t t_base)</td></tr> +<tr class="separator:a224005037387484dfa510a1355a62828"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ae6fe766e7decf18869cfb86bba741ca4" id="r_ae6fe766e7decf18869cfb86bba741ca4"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ae6fe766e7decf18869cfb86bba741ca4">neorv32_onewire_enable</a> (void)</td></tr> +<tr class="separator:ae6fe766e7decf18869cfb86bba741ca4"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a7e329eeb1cd98301a53b271a6a102385" id="r_a7e329eeb1cd98301a53b271a6a102385"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a7e329eeb1cd98301a53b271a6a102385">neorv32_onewire_disable</a> (void)</td></tr> +<tr class="separator:a7e329eeb1cd98301a53b271a6a102385"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a122531c7154126858c46d89e003d838d" id="r_a122531c7154126858c46d89e003d838d"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a122531c7154126858c46d89e003d838d">neorv32_onewire_sense</a> (void)</td></tr> +<tr class="separator:a122531c7154126858c46d89e003d838d"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a01b6236b89c045ddbd58398361c6ee0a" id="r_a01b6236b89c045ddbd58398361c6ee0a"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a01b6236b89c045ddbd58398361c6ee0a">neorv32_onewire_busy</a> (void)</td></tr> +<tr class="separator:a01b6236b89c045ddbd58398361c6ee0a"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a3072f7167831edc95dee44ecfef6a0d4" id="r_a3072f7167831edc95dee44ecfef6a0d4"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a3072f7167831edc95dee44ecfef6a0d4">neorv32_onewire_reset</a> (void)</td></tr> +<tr class="separator:a3072f7167831edc95dee44ecfef6a0d4"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a43eb8a08eeaa83e3d7e9aa5058a4269f" id="r_a43eb8a08eeaa83e3d7e9aa5058a4269f"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a43eb8a08eeaa83e3d7e9aa5058a4269f">neorv32_onewire_reset_get_presence</a> (void)</td></tr> +<tr class="separator:a43eb8a08eeaa83e3d7e9aa5058a4269f"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aace8398062b759256a516e6245aced83" id="r_aace8398062b759256a516e6245aced83"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aace8398062b759256a516e6245aced83">neorv32_onewire_read_bit</a> (void)</td></tr> +<tr class="separator:aace8398062b759256a516e6245aced83"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aa4a19d2d8dc3b3401307615aec201190" id="r_aa4a19d2d8dc3b3401307615aec201190"><td class="memItemLeft" align="right" valign="top">uint8_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aa4a19d2d8dc3b3401307615aec201190">neorv32_onewire_read_bit_get</a> (void)</td></tr> +<tr class="separator:aa4a19d2d8dc3b3401307615aec201190"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a49d0a2a386f129fd2f4fed880bba31d4" id="r_a49d0a2a386f129fd2f4fed880bba31d4"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a49d0a2a386f129fd2f4fed880bba31d4">neorv32_onewire_write_bit</a> (uint8_t bit)</td></tr> +<tr class="separator:a49d0a2a386f129fd2f4fed880bba31d4"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a01ddba7a9148be542b5c52e39e6f46d6" id="r_a01ddba7a9148be542b5c52e39e6f46d6"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a01ddba7a9148be542b5c52e39e6f46d6">neorv32_onewire_read_byte</a> (void)</td></tr> +<tr class="separator:a01ddba7a9148be542b5c52e39e6f46d6"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a4c7eec15c095c97c939163f631f51dab" id="r_a4c7eec15c095c97c939163f631f51dab"><td class="memItemLeft" align="right" valign="top">uint8_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a4c7eec15c095c97c939163f631f51dab">neorv32_onewire_read_byte_get</a> (void)</td></tr> +<tr class="separator:a4c7eec15c095c97c939163f631f51dab"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a23b96b68c3214b188525eb102cafb620" id="r_a23b96b68c3214b188525eb102cafb620"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a23b96b68c3214b188525eb102cafb620">neorv32_onewire_write_byte</a> (uint8_t byte)</td></tr> +<tr class="separator:a23b96b68c3214b188525eb102cafb620"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:af8ca6be495176797b7da3857e2f794f9" id="r_af8ca6be495176797b7da3857e2f794f9"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#af8ca6be495176797b7da3857e2f794f9">neorv32_onewire_reset_blocking</a> (void)</td></tr> +<tr class="separator:af8ca6be495176797b7da3857e2f794f9"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ace8b7cf697b068b6b51676d84dec5960" id="r_ace8b7cf697b068b6b51676d84dec5960"><td class="memItemLeft" align="right" valign="top">uint8_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ace8b7cf697b068b6b51676d84dec5960">neorv32_onewire_read_bit_blocking</a> (void)</td></tr> +<tr class="separator:ace8b7cf697b068b6b51676d84dec5960"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a6f7b6690a2437e0b574a8a9a23dc0eaa" id="r_a6f7b6690a2437e0b574a8a9a23dc0eaa"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a6f7b6690a2437e0b574a8a9a23dc0eaa">neorv32_onewire_write_bit_blocking</a> (uint8_t bit)</td></tr> +<tr class="separator:a6f7b6690a2437e0b574a8a9a23dc0eaa"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a7510e65a26aeefb40e994fd00667537e" id="r_a7510e65a26aeefb40e994fd00667537e"><td class="memItemLeft" align="right" valign="top">uint8_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a7510e65a26aeefb40e994fd00667537e">neorv32_onewire_read_byte_blocking</a> (void)</td></tr> +<tr class="separator:a7510e65a26aeefb40e994fd00667537e"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ac78557c77482b59394677f42fda4fdf1" id="r_ac78557c77482b59394677f42fda4fdf1"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ac78557c77482b59394677f42fda4fdf1">neorv32_onewire_write_byte_blocking</a> (uint8_t byte)</td></tr> +<tr class="separator:ac78557c77482b59394677f42fda4fdf1"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader">IO Device: 1-Wire Interface Controller (ONEWIRE)</h2></td></tr> +<tr class="memitem:a6f119e35d7ac01f110987508ff3becc9" id="r_a6f119e35d7ac01f110987508ff3becc9"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a6f119e35d7ac01f110987508ff3becc9">NEORV32_ONEWIRE</a>&#160;&#160;&#160;((<a class="el" href="structneorv32__onewire__t.html">neorv32_onewire_t</a>*) (<a class="el" href="neorv32_8h.html#a8d0b612e52b77395a05d4f18af6fcf00">NEORV32_ONEWIRE_BASE</a>))</td></tr> +<tr class="separator:a6f119e35d7ac01f110987508ff3becc9"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ade1a01f533843880868ec7496d116831" id="r_ade1a01f533843880868ec7496d116831"><td class="memItemLeft" align="right" valign="top">enum &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ade1a01f533843880868ec7496d116831">NEORV32_ONEWIRE_CTRL_enum</a> { <br /> +&#160;&#160;<a class="el" href="#ade1a01f533843880868ec7496d116831ab87882c202f80185278c69e482f147da">ONEWIRE_CTRL_EN</a> = 0 +, <a class="el" href="#ade1a01f533843880868ec7496d116831abfed6417c3abd7ef94cd18a3b32c4393">ONEWIRE_CTRL_PRSC0</a> = 1 +, <a class="el" href="#ade1a01f533843880868ec7496d116831aee1e24261e263c70bf2e36dcafc9dc74">ONEWIRE_CTRL_PRSC1</a> = 2 +, <a class="el" href="#ade1a01f533843880868ec7496d116831acdfca08f34d7379aaf8505ba3425c6f5">ONEWIRE_CTRL_CLKDIV0</a> = 3 +, <br /> +&#160;&#160;<a class="el" href="#ade1a01f533843880868ec7496d116831afa1476a5e04eb4eabf4d7a595eca2df9">ONEWIRE_CTRL_CLKDIV1</a> = 4 +, <a class="el" href="#ade1a01f533843880868ec7496d116831aec9f056072e1db747e74a5c695d2a1df">ONEWIRE_CTRL_CLKDIV2</a> = 5 +, <a class="el" href="#ade1a01f533843880868ec7496d116831ab8600bd09d74e39869259881b84ebfbf">ONEWIRE_CTRL_CLKDIV3</a> = 6 +, <a class="el" href="#ade1a01f533843880868ec7496d116831a32af8c86e7166e02e801727bd261c179">ONEWIRE_CTRL_CLKDIV4</a> = 7 +, <br /> +&#160;&#160;<a class="el" href="#ade1a01f533843880868ec7496d116831a789d65fd9b0ab17bffd0d6de9d2e132a">ONEWIRE_CTRL_CLKDIV5</a> = 8 +, <a class="el" href="#ade1a01f533843880868ec7496d116831a27f040454bebc6218b490f7160ea2312">ONEWIRE_CTRL_CLKDIV6</a> = 9 +, <a class="el" href="#ade1a01f533843880868ec7496d116831a8b19096f72ef96a7597fda9be625ed40">ONEWIRE_CTRL_CLKDIV7</a> = 10 +, <a class="el" href="#ade1a01f533843880868ec7496d116831a98624ec944e0413a208cdf54bbbf4c75">ONEWIRE_CTRL_TRIG_RST</a> = 11 +, <br /> +&#160;&#160;<a class="el" href="#ade1a01f533843880868ec7496d116831a7ecbccef9e77e68caf22ed2c416e1f77">ONEWIRE_CTRL_TRIG_BIT</a> = 12 +, <a class="el" href="#ade1a01f533843880868ec7496d116831acfd8a56f668ca55dbbaa1714b1235dfe">ONEWIRE_CTRL_TRIG_BYTE</a> = 13 +, <a class="el" href="#ade1a01f533843880868ec7496d116831af992c94d0b9a7b7b92a5a23366b9a8c6">ONEWIRE_CTRL_SENSE</a> = 29 +, <a class="el" href="#ade1a01f533843880868ec7496d116831a92e1ff9fa10319d64c8d2c6a6d61b37e">ONEWIRE_CTRL_PRESENCE</a> = 30 +, <br /> +&#160;&#160;<a class="el" href="#ade1a01f533843880868ec7496d116831aac8933755e80d72e1e9c293198d831b9">ONEWIRE_CTRL_BUSY</a> = 31 +<br /> + }</td></tr> +<tr class="separator:ade1a01f533843880868ec7496d116831"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ae770490afa8662fb8577065531d51368" id="r_ae770490afa8662fb8577065531d51368"><td class="memItemLeft" align="right" valign="top">enum &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ae770490afa8662fb8577065531d51368">NEORV32_ONEWIRE_DATA_enum</a> { <a class="el" href="#ae770490afa8662fb8577065531d51368a6ad35475e3f80a8c68ce0caa9c3754a5">ONEWIRE_DATA_LSB</a> = 0 +, <a class="el" href="#ae770490afa8662fb8577065531d51368af967429634efb019ada46bf75f373aa3">ONEWIRE_DATA_MSB</a> = 7 + }</td></tr> +<tr class="separator:ae770490afa8662fb8577065531d51368"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>1-Wire Interface Controller (ONEWIRE) HW driver header file. </p> +<dl class="section note"><dt>Note</dt><dd>These functions should only be used if the ONEWIRE unit was synthesized (IO_ONEWIRE_EN = true).</dd></dl> +<dl class="section see"><dt>See also</dt><dd><a href="https://stnolting.github.io/neorv32/sw/files.html">https://stnolting.github.io/neorv32/sw/files.html</a> </dd></dl> +</div><h2 class="groupheader">Macro Definition Documentation</h2> +<a id="a6f119e35d7ac01f110987508ff3becc9" name="a6f119e35d7ac01f110987508ff3becc9"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a6f119e35d7ac01f110987508ff3becc9">&#9670;&#160;</a></span>NEORV32_ONEWIRE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define NEORV32_ONEWIRE&#160;&#160;&#160;((<a class="el" href="structneorv32__onewire__t.html">neorv32_onewire_t</a>*) (<a class="el" href="neorv32_8h.html#a8d0b612e52b77395a05d4f18af6fcf00">NEORV32_ONEWIRE_BASE</a>))</td> + </tr> + </table> +</div><div class="memdoc"> +<p>ONEWIRE module hardware access (<a class="el" href="structneorv32__onewire__t.html">neorv32_onewire_t</a>) </p> + +</div> +</div> +<h2 class="groupheader">Enumeration Type Documentation</h2> +<a id="ade1a01f533843880868ec7496d116831" name="ade1a01f533843880868ec7496d116831"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ade1a01f533843880868ec7496d116831">&#9670;&#160;</a></span>NEORV32_ONEWIRE_CTRL_enum</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">enum <a class="el" href="#ade1a01f533843880868ec7496d116831">NEORV32_ONEWIRE_CTRL_enum</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>ONEWIRE control register bits </p> +<table class="fieldtable"> +<tr><th colspan="2">Enumerator</th></tr><tr><td class="fieldname"><a id="ade1a01f533843880868ec7496d116831ab87882c202f80185278c69e482f147da" name="ade1a01f533843880868ec7496d116831ab87882c202f80185278c69e482f147da"></a>ONEWIRE_CTRL_EN&#160;</td><td class="fielddoc"><p>ONEWIRE control register(0) (r/w): ONEWIRE controller enable </p> +</td></tr> +<tr><td class="fieldname"><a id="ade1a01f533843880868ec7496d116831abfed6417c3abd7ef94cd18a3b32c4393" name="ade1a01f533843880868ec7496d116831abfed6417c3abd7ef94cd18a3b32c4393"></a>ONEWIRE_CTRL_PRSC0&#160;</td><td class="fielddoc"><p>ONEWIRE control register(1) (r/w): Clock prescaler select bit 0 </p> +</td></tr> +<tr><td class="fieldname"><a id="ade1a01f533843880868ec7496d116831aee1e24261e263c70bf2e36dcafc9dc74" name="ade1a01f533843880868ec7496d116831aee1e24261e263c70bf2e36dcafc9dc74"></a>ONEWIRE_CTRL_PRSC1&#160;</td><td class="fielddoc"><p>ONEWIRE control register(2) (r/w): Clock prescaler select bit 1 </p> +</td></tr> +<tr><td class="fieldname"><a id="ade1a01f533843880868ec7496d116831acdfca08f34d7379aaf8505ba3425c6f5" name="ade1a01f533843880868ec7496d116831acdfca08f34d7379aaf8505ba3425c6f5"></a>ONEWIRE_CTRL_CLKDIV0&#160;</td><td class="fielddoc"><p>ONEWIRE control register(3) (r/w): Clock divider bit 0 </p> +</td></tr> +<tr><td class="fieldname"><a id="ade1a01f533843880868ec7496d116831afa1476a5e04eb4eabf4d7a595eca2df9" name="ade1a01f533843880868ec7496d116831afa1476a5e04eb4eabf4d7a595eca2df9"></a>ONEWIRE_CTRL_CLKDIV1&#160;</td><td class="fielddoc"><p>ONEWIRE control register(4) (r/w): Clock divider bit 1 </p> +</td></tr> +<tr><td class="fieldname"><a id="ade1a01f533843880868ec7496d116831aec9f056072e1db747e74a5c695d2a1df" name="ade1a01f533843880868ec7496d116831aec9f056072e1db747e74a5c695d2a1df"></a>ONEWIRE_CTRL_CLKDIV2&#160;</td><td class="fielddoc"><p>ONEWIRE control register(5) (r/w): Clock divider bit 2 </p> +</td></tr> +<tr><td class="fieldname"><a id="ade1a01f533843880868ec7496d116831ab8600bd09d74e39869259881b84ebfbf" name="ade1a01f533843880868ec7496d116831ab8600bd09d74e39869259881b84ebfbf"></a>ONEWIRE_CTRL_CLKDIV3&#160;</td><td class="fielddoc"><p>ONEWIRE control register(6) (r/w): Clock divider bit 3 </p> +</td></tr> +<tr><td class="fieldname"><a id="ade1a01f533843880868ec7496d116831a32af8c86e7166e02e801727bd261c179" name="ade1a01f533843880868ec7496d116831a32af8c86e7166e02e801727bd261c179"></a>ONEWIRE_CTRL_CLKDIV4&#160;</td><td class="fielddoc"><p>ONEWIRE control register(7) (r/w): Clock divider bit 4 </p> +</td></tr> +<tr><td class="fieldname"><a id="ade1a01f533843880868ec7496d116831a789d65fd9b0ab17bffd0d6de9d2e132a" name="ade1a01f533843880868ec7496d116831a789d65fd9b0ab17bffd0d6de9d2e132a"></a>ONEWIRE_CTRL_CLKDIV5&#160;</td><td class="fielddoc"><p>ONEWIRE control register(8) (r/w): Clock divider bit 5 </p> +</td></tr> +<tr><td class="fieldname"><a id="ade1a01f533843880868ec7496d116831a27f040454bebc6218b490f7160ea2312" name="ade1a01f533843880868ec7496d116831a27f040454bebc6218b490f7160ea2312"></a>ONEWIRE_CTRL_CLKDIV6&#160;</td><td class="fielddoc"><p>ONEWIRE control register(9) (r/w): Clock divider bit 6 </p> +</td></tr> +<tr><td class="fieldname"><a id="ade1a01f533843880868ec7496d116831a8b19096f72ef96a7597fda9be625ed40" name="ade1a01f533843880868ec7496d116831a8b19096f72ef96a7597fda9be625ed40"></a>ONEWIRE_CTRL_CLKDIV7&#160;</td><td class="fielddoc"><p>ONEWIRE control register(10) (r/w): Clock divider bit 7 </p> +</td></tr> +<tr><td class="fieldname"><a id="ade1a01f533843880868ec7496d116831a98624ec944e0413a208cdf54bbbf4c75" name="ade1a01f533843880868ec7496d116831a98624ec944e0413a208cdf54bbbf4c75"></a>ONEWIRE_CTRL_TRIG_RST&#160;</td><td class="fielddoc"><p>ONEWIRE control register(11) (-/w): Trigger reset pulse, auto-clears </p> +</td></tr> +<tr><td class="fieldname"><a id="ade1a01f533843880868ec7496d116831a7ecbccef9e77e68caf22ed2c416e1f77" name="ade1a01f533843880868ec7496d116831a7ecbccef9e77e68caf22ed2c416e1f77"></a>ONEWIRE_CTRL_TRIG_BIT&#160;</td><td class="fielddoc"><p>ONEWIRE control register(12) (-/w): Trigger single-bit transmission, auto-clears </p> +</td></tr> +<tr><td class="fieldname"><a id="ade1a01f533843880868ec7496d116831acfd8a56f668ca55dbbaa1714b1235dfe" name="ade1a01f533843880868ec7496d116831acfd8a56f668ca55dbbaa1714b1235dfe"></a>ONEWIRE_CTRL_TRIG_BYTE&#160;</td><td class="fielddoc"><p>ONEWIRE control register(13) (-/w): Trigger full-byte transmission, auto-clears </p> +</td></tr> +<tr><td class="fieldname"><a id="ade1a01f533843880868ec7496d116831af992c94d0b9a7b7b92a5a23366b9a8c6" name="ade1a01f533843880868ec7496d116831af992c94d0b9a7b7b92a5a23366b9a8c6"></a>ONEWIRE_CTRL_SENSE&#160;</td><td class="fielddoc"><p>ONEWIRE control register(29) (r/-): Current state of the bus line </p> +</td></tr> +<tr><td class="fieldname"><a id="ade1a01f533843880868ec7496d116831a92e1ff9fa10319d64c8d2c6a6d61b37e" name="ade1a01f533843880868ec7496d116831a92e1ff9fa10319d64c8d2c6a6d61b37e"></a>ONEWIRE_CTRL_PRESENCE&#160;</td><td class="fielddoc"><p>ONEWIRE control register(30) (r/-): Bus presence detected </p> +</td></tr> +<tr><td class="fieldname"><a id="ade1a01f533843880868ec7496d116831aac8933755e80d72e1e9c293198d831b9" name="ade1a01f533843880868ec7496d116831aac8933755e80d72e1e9c293198d831b9"></a>ONEWIRE_CTRL_BUSY&#160;</td><td class="fielddoc"><p>ONEWIRE control register(31) (r/-): Operation in progress when set </p> +</td></tr> +</table> + +</div> +</div> +<a id="ae770490afa8662fb8577065531d51368" name="ae770490afa8662fb8577065531d51368"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ae770490afa8662fb8577065531d51368">&#9670;&#160;</a></span>NEORV32_ONEWIRE_DATA_enum</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">enum <a class="el" href="#ae770490afa8662fb8577065531d51368">NEORV32_ONEWIRE_DATA_enum</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>ONEWIRE receive/transmit data register bits </p> +<table class="fieldtable"> +<tr><th colspan="2">Enumerator</th></tr><tr><td class="fieldname"><a id="ae770490afa8662fb8577065531d51368a6ad35475e3f80a8c68ce0caa9c3754a5" name="ae770490afa8662fb8577065531d51368a6ad35475e3f80a8c68ce0caa9c3754a5"></a>ONEWIRE_DATA_LSB&#160;</td><td class="fielddoc"><p>ONEWIRE data register(0) (r/w): Receive/transmit data (8-bit) LSB </p> +</td></tr> +<tr><td class="fieldname"><a id="ae770490afa8662fb8577065531d51368af967429634efb019ada46bf75f373aa3" name="ae770490afa8662fb8577065531d51368af967429634efb019ada46bf75f373aa3"></a>ONEWIRE_DATA_MSB&#160;</td><td class="fielddoc"><p>ONEWIRE data register(7) (r/w): Receive/transmit data (8-bit) MSB </p> +</td></tr> +</table> + +</div> +</div> +<h2 class="groupheader">Function Documentation</h2> +<a id="a865e5c381fd3c27c6981a589a5124d1e" name="a865e5c381fd3c27c6981a589a5124d1e"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a865e5c381fd3c27c6981a589a5124d1e">&#9670;&#160;</a></span>neorv32_onewire_available()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_onewire_available </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Check if ONEWIRE controller was synthesized.</p> +<dl class="section return"><dt>Returns</dt><dd>0 if ONEWIRE was not synthesized, 1 if ONEWIRE is available. </dd></dl> + +</div> +</div> +<a id="a01b6236b89c045ddbd58398361c6ee0a" name="a01b6236b89c045ddbd58398361c6ee0a"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a01b6236b89c045ddbd58398361c6ee0a">&#9670;&#160;</a></span>neorv32_onewire_busy()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_onewire_busy </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Check if ONEWIRE module is busy.</p> +<dl class="section note"><dt>Note</dt><dd>This function is non-blocking.</dd></dl> +<dl class="section return"><dt>Returns</dt><dd>0 if not busy, 1 if busy. </dd></dl> + +</div> +</div> +<a id="a7e329eeb1cd98301a53b271a6a102385" name="a7e329eeb1cd98301a53b271a6a102385"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a7e329eeb1cd98301a53b271a6a102385">&#9670;&#160;</a></span>neorv32_onewire_disable()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_onewire_disable </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Disable ONEWIRE controller. </p> + +</div> +</div> +<a id="ae6fe766e7decf18869cfb86bba741ca4" name="ae6fe766e7decf18869cfb86bba741ca4"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ae6fe766e7decf18869cfb86bba741ca4">&#9670;&#160;</a></span>neorv32_onewire_enable()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_onewire_enable </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Enable ONEWIRE controller. </p> + +</div> +</div> +<a id="aace8398062b759256a516e6245aced83" name="aace8398062b759256a516e6245aced83"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aace8398062b759256a516e6245aced83">&#9670;&#160;</a></span>neorv32_onewire_read_bit()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_onewire_read_bit </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Initiate single-bit read.</p> +<dl class="section note"><dt>Note</dt><dd>This function is non-blocking. </dd></dl> + +</div> +</div> +<a id="ace8b7cf697b068b6b51676d84dec5960" name="ace8b7cf697b068b6b51676d84dec5960"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ace8b7cf697b068b6b51676d84dec5960">&#9670;&#160;</a></span>neorv32_onewire_read_bit_blocking()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint8_t neorv32_onewire_read_bit_blocking </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Read single bit.</p> +<dl class="section warning"><dt>Warning</dt><dd>This function is blocking!</dd></dl> +<dl class="section return"><dt>Returns</dt><dd>Read bit in bit 0. </dd></dl> + +</div> +</div> +<a id="aa4a19d2d8dc3b3401307615aec201190" name="aa4a19d2d8dc3b3401307615aec201190"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aa4a19d2d8dc3b3401307615aec201190">&#9670;&#160;</a></span>neorv32_onewire_read_bit_get()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint8_t neorv32_onewire_read_bit_get </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Get bit from previous single-bit read operation</p> +<dl class="section note"><dt>Note</dt><dd>This function is non-blocking.</dd></dl> +<dl class="section return"><dt>Returns</dt><dd>Read bit in bit 0. </dd></dl> + +</div> +</div> +<a id="a01ddba7a9148be542b5c52e39e6f46d6" name="a01ddba7a9148be542b5c52e39e6f46d6"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a01ddba7a9148be542b5c52e39e6f46d6">&#9670;&#160;</a></span>neorv32_onewire_read_byte()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_onewire_read_byte </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Initiate read byte.</p> +<dl class="section note"><dt>Note</dt><dd>This function is non-blocking. </dd></dl> + +</div> +</div> +<a id="a7510e65a26aeefb40e994fd00667537e" name="a7510e65a26aeefb40e994fd00667537e"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a7510e65a26aeefb40e994fd00667537e">&#9670;&#160;</a></span>neorv32_onewire_read_byte_blocking()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint8_t neorv32_onewire_read_byte_blocking </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Read byte.</p> +<dl class="section warning"><dt>Warning</dt><dd>This function is blocking!</dd></dl> +<dl class="section return"><dt>Returns</dt><dd>Read byte. </dd></dl> + +</div> +</div> +<a id="a4c7eec15c095c97c939163f631f51dab" name="a4c7eec15c095c97c939163f631f51dab"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a4c7eec15c095c97c939163f631f51dab">&#9670;&#160;</a></span>neorv32_onewire_read_byte_get()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint8_t neorv32_onewire_read_byte_get </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Get data from previous read byte operation.</p> +<dl class="section note"><dt>Note</dt><dd>This function is non-blocking.</dd></dl> +<dl class="section return"><dt>Returns</dt><dd>Read byte. </dd></dl> + +</div> +</div> +<a id="a3072f7167831edc95dee44ecfef6a0d4" name="a3072f7167831edc95dee44ecfef6a0d4"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a3072f7167831edc95dee44ecfef6a0d4">&#9670;&#160;</a></span>neorv32_onewire_reset()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_onewire_reset </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Initiate reset pulse.</p> +<dl class="section note"><dt>Note</dt><dd>This function is non-blocking. </dd></dl> + +</div> +</div> +<a id="af8ca6be495176797b7da3857e2f794f9" name="af8ca6be495176797b7da3857e2f794f9"></a> +<h2 class="memtitle"><span class="permalink"><a href="#af8ca6be495176797b7da3857e2f794f9">&#9670;&#160;</a></span>neorv32_onewire_reset_blocking()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_onewire_reset_blocking </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Generate reset pulse and check if any bus device is present.</p> +<dl class="section warning"><dt>Warning</dt><dd>This function is blocking!</dd></dl> +<dl class="section return"><dt>Returns</dt><dd>0 if at lest one device is present, -1 otherwise </dd></dl> + +</div> +</div> +<a id="a43eb8a08eeaa83e3d7e9aa5058a4269f" name="a43eb8a08eeaa83e3d7e9aa5058a4269f"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a43eb8a08eeaa83e3d7e9aa5058a4269f">&#9670;&#160;</a></span>neorv32_onewire_reset_get_presence()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_onewire_reset_get_presence </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Get bus presence (after RESET).</p> +<dl class="section note"><dt>Note</dt><dd>This function is non-blocking.</dd></dl> +<dl class="section return"><dt>Returns</dt><dd>0 if at lest one device is present, -1 otherwise </dd></dl> + +</div> +</div> +<a id="a122531c7154126858c46d89e003d838d" name="a122531c7154126858c46d89e003d838d"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a122531c7154126858c46d89e003d838d">&#9670;&#160;</a></span>neorv32_onewire_sense()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_onewire_sense </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Get current bus state.</p> +<dl class="section return"><dt>Returns</dt><dd>1 if bus is high, 0 if bus is low. </dd></dl> + +</div> +</div> +<a id="a224005037387484dfa510a1355a62828" name="a224005037387484dfa510a1355a62828"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a224005037387484dfa510a1355a62828">&#9670;&#160;</a></span>neorv32_onewire_setup()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_onewire_setup </td> + <td>(</td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>t_base</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Reset, configure and enable ONEWIRE interface controller.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">t_base</td><td>Base tick time in ns. </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>0 if configuration failed, otherwise the actual t_base time in ns is returned. </dd></dl> + +</div> +</div> +<a id="a49d0a2a386f129fd2f4fed880bba31d4" name="a49d0a2a386f129fd2f4fed880bba31d4"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a49d0a2a386f129fd2f4fed880bba31d4">&#9670;&#160;</a></span>neorv32_onewire_write_bit()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_onewire_write_bit </td> + <td>(</td> + <td class="paramtype">uint8_t</td> <td class="paramname"><span class="paramname"><em>bit</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Initiate single-bit write.</p> +<dl class="section note"><dt>Note</dt><dd>This function is non-blocking.</dd></dl> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">bit</td><td>Bit to be send. </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="a6f7b6690a2437e0b574a8a9a23dc0eaa" name="a6f7b6690a2437e0b574a8a9a23dc0eaa"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a6f7b6690a2437e0b574a8a9a23dc0eaa">&#9670;&#160;</a></span>neorv32_onewire_write_bit_blocking()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_onewire_write_bit_blocking </td> + <td>(</td> + <td class="paramtype">uint8_t</td> <td class="paramname"><span class="paramname"><em>bit</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Write single bit.</p> +<dl class="section warning"><dt>Warning</dt><dd>This function is blocking!</dd></dl> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">bit</td><td>Bit to be send. </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="a23b96b68c3214b188525eb102cafb620" name="a23b96b68c3214b188525eb102cafb620"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a23b96b68c3214b188525eb102cafb620">&#9670;&#160;</a></span>neorv32_onewire_write_byte()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_onewire_write_byte </td> + <td>(</td> + <td class="paramtype">uint8_t</td> <td class="paramname"><span class="paramname"><em>byte</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Initiate write byte.</p> +<dl class="section note"><dt>Note</dt><dd>This function is non-blocking.</dd></dl> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">byte</td><td>Byte to be send. </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="ac78557c77482b59394677f42fda4fdf1" name="ac78557c77482b59394677f42fda4fdf1"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ac78557c77482b59394677f42fda4fdf1">&#9670;&#160;</a></span>neorv32_onewire_write_byte_blocking()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_onewire_write_byte_blocking </td> + <td>(</td> + <td class="paramtype">uint8_t</td> <td class="paramname"><span class="paramname"><em>byte</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Write byte.</p> +<dl class="section warning"><dt>Warning</dt><dd>This function is blocking!</dd></dl> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">byte</td><td>Byte to be send. </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/neorv32__onewire_8h_source.html b/sw/neorv32__onewire_8h_source.html new file mode 100644 index 0000000000..31a065903f --- /dev/null +++ b/sw/neorv32__onewire_8h_source.html @@ -0,0 +1,221 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/lib/include/neorv32_onewire.h Source File</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_7d04193005ada6f9450f847f4adb6b5b.html">lib</a></li><li class="navelem"><a class="el" href="dir_752b1e5d3973bf735fa78bf6b4727df9.html">include</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="headertitle"><div class="title">neorv32_onewire.h</div></div> +</div><!--header--> +<div class="contents"> +<a href="neorv32__onewire_8h.html">Go to the documentation of this file.</a><div class="fragment"><div class="line"><a id="l00001" name="l00001"></a><span class="lineno"> 1</span><span class="comment">// ================================================================================ //</span></div> +<div class="line"><a id="l00002" name="l00002"></a><span class="lineno"> 2</span><span class="comment">// The NEORV32 RISC-V Processor - https://github.com/stnolting/neorv32 //</span></div> +<div class="line"><a id="l00003" name="l00003"></a><span class="lineno"> 3</span><span class="comment">// Copyright (c) NEORV32 contributors. //</span></div> +<div class="line"><a id="l00004" name="l00004"></a><span class="lineno"> 4</span><span class="comment">// Copyright (c) 2020 - 2024 Stephan Nolting. All rights reserved. //</span></div> +<div class="line"><a id="l00005" name="l00005"></a><span class="lineno"> 5</span><span class="comment">// Licensed under the BSD-3-Clause license, see LICENSE for details. //</span></div> +<div class="line"><a id="l00006" name="l00006"></a><span class="lineno"> 6</span><span class="comment">// SPDX-License-Identifier: BSD-3-Clause //</span></div> +<div class="line"><a id="l00007" name="l00007"></a><span class="lineno"> 7</span><span class="comment">// ================================================================================ //</span></div> +<div class="line"><a id="l00008" name="l00008"></a><span class="lineno"> 8</span> </div> +<div class="line"><a id="l00018" name="l00018"></a><span class="lineno"> 18</span><span class="preprocessor">#ifndef neorv32_onewire_h</span></div> +<div class="line"><a id="l00019" name="l00019"></a><span class="lineno"> 19</span><span class="preprocessor">#define neorv32_onewire_h</span></div> +<div class="line"><a id="l00020" name="l00020"></a><span class="lineno"> 20</span> </div> +<div class="line"><a id="l00021" name="l00021"></a><span class="lineno"> 21</span><span class="preprocessor">#include &lt;stdint.h&gt;</span></div> +<div class="line"><a id="l00022" name="l00022"></a><span class="lineno"> 22</span> </div> +<div class="line"><a id="l00023" name="l00023"></a><span class="lineno"> 23</span> </div> +<div class="line"><a id="l00024" name="l00024"></a><span class="lineno"> 24</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen00029" data-start="{" data-end="};"> +<div class="line"><a id="l00029" name="l00029"></a><span class="lineno"><a class="line" href="structneorv32__onewire__t.html"> 29</a></span><span class="keyword">typedef</span> <span class="keyword">volatile</span> <span class="keyword">struct </span>__attribute__((packed,aligned(4))) {</div> +<div class="line"><a id="l00030" name="l00030"></a><span class="lineno"><a class="line" href="structneorv32__onewire__t.html#a310df3bab43e4438417b2ff948f4712a"> 30</a></span> uint32_t <a class="code hl_variable" href="structneorv32__onewire__t.html#a310df3bab43e4438417b2ff948f4712a">CTRL</a>; </div> +<div class="line"><a id="l00031" name="l00031"></a><span class="lineno"><a class="line" href="structneorv32__onewire__t.html#a2c04aa736b901940ed65b96202c8af7a"> 31</a></span> uint32_t <a class="code hl_variable" href="structneorv32__onewire__t.html#a2c04aa736b901940ed65b96202c8af7a">DATA</a>; </div> +<div class="line"><a id="l00032" name="l00032"></a><span class="lineno"> 32</span>} <a class="code hl_struct" href="structneorv32__onewire__t.html">neorv32_onewire_t</a>;</div> +</div> +<div class="line"><a id="l00033" name="l00033"></a><span class="lineno"> 33</span> </div> +<div class="line"><a id="l00035" name="l00035"></a><span class="lineno"><a class="line" href="neorv32__onewire_8h.html#a6f119e35d7ac01f110987508ff3becc9"> 35</a></span><span class="preprocessor">#define NEORV32_ONEWIRE ((neorv32_onewire_t*) (NEORV32_ONEWIRE_BASE))</span></div> +<div class="line"><a id="l00036" name="l00036"></a><span class="lineno"> 36</span> </div> +<div class="foldopen" id="foldopen00038" data-start="{" data-end="};"> +<div class="line"><a id="l00038" name="l00038"></a><span class="lineno"><a class="line" href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831"> 38</a></span><span class="keyword">enum</span> <a class="code hl_enumeration" href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831">NEORV32_ONEWIRE_CTRL_enum</a> {</div> +<div class="line"><a id="l00039" name="l00039"></a><span class="lineno"><a class="line" href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831ab87882c202f80185278c69e482f147da"> 39</a></span> <a class="code hl_enumvalue" href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831ab87882c202f80185278c69e482f147da">ONEWIRE_CTRL_EN</a> = 0, </div> +<div class="line"><a id="l00040" name="l00040"></a><span class="lineno"><a class="line" href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831abfed6417c3abd7ef94cd18a3b32c4393"> 40</a></span> <a class="code hl_enumvalue" href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831abfed6417c3abd7ef94cd18a3b32c4393">ONEWIRE_CTRL_PRSC0</a> = 1, </div> +<div class="line"><a id="l00041" name="l00041"></a><span class="lineno"><a class="line" href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831aee1e24261e263c70bf2e36dcafc9dc74"> 41</a></span> <a class="code hl_enumvalue" href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831aee1e24261e263c70bf2e36dcafc9dc74">ONEWIRE_CTRL_PRSC1</a> = 2, </div> +<div class="line"><a id="l00042" name="l00042"></a><span class="lineno"><a class="line" href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831acdfca08f34d7379aaf8505ba3425c6f5"> 42</a></span> <a class="code hl_enumvalue" href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831acdfca08f34d7379aaf8505ba3425c6f5">ONEWIRE_CTRL_CLKDIV0</a> = 3, </div> +<div class="line"><a id="l00043" name="l00043"></a><span class="lineno"><a class="line" href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831afa1476a5e04eb4eabf4d7a595eca2df9"> 43</a></span> <a class="code hl_enumvalue" href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831afa1476a5e04eb4eabf4d7a595eca2df9">ONEWIRE_CTRL_CLKDIV1</a> = 4, </div> +<div class="line"><a id="l00044" name="l00044"></a><span class="lineno"><a class="line" href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831aec9f056072e1db747e74a5c695d2a1df"> 44</a></span> <a class="code hl_enumvalue" href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831aec9f056072e1db747e74a5c695d2a1df">ONEWIRE_CTRL_CLKDIV2</a> = 5, </div> +<div class="line"><a id="l00045" name="l00045"></a><span class="lineno"><a class="line" href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831ab8600bd09d74e39869259881b84ebfbf"> 45</a></span> <a class="code hl_enumvalue" href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831ab8600bd09d74e39869259881b84ebfbf">ONEWIRE_CTRL_CLKDIV3</a> = 6, </div> +<div class="line"><a id="l00046" name="l00046"></a><span class="lineno"><a class="line" href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831a32af8c86e7166e02e801727bd261c179"> 46</a></span> <a class="code hl_enumvalue" href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831a32af8c86e7166e02e801727bd261c179">ONEWIRE_CTRL_CLKDIV4</a> = 7, </div> +<div class="line"><a id="l00047" name="l00047"></a><span class="lineno"><a class="line" href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831a789d65fd9b0ab17bffd0d6de9d2e132a"> 47</a></span> <a class="code hl_enumvalue" href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831a789d65fd9b0ab17bffd0d6de9d2e132a">ONEWIRE_CTRL_CLKDIV5</a> = 8, </div> +<div class="line"><a id="l00048" name="l00048"></a><span class="lineno"><a class="line" href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831a27f040454bebc6218b490f7160ea2312"> 48</a></span> <a class="code hl_enumvalue" href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831a27f040454bebc6218b490f7160ea2312">ONEWIRE_CTRL_CLKDIV6</a> = 9, </div> +<div class="line"><a id="l00049" name="l00049"></a><span class="lineno"><a class="line" href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831a8b19096f72ef96a7597fda9be625ed40"> 49</a></span> <a class="code hl_enumvalue" href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831a8b19096f72ef96a7597fda9be625ed40">ONEWIRE_CTRL_CLKDIV7</a> = 10, </div> +<div class="line"><a id="l00050" name="l00050"></a><span class="lineno"><a class="line" href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831a98624ec944e0413a208cdf54bbbf4c75"> 50</a></span> <a class="code hl_enumvalue" href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831a98624ec944e0413a208cdf54bbbf4c75">ONEWIRE_CTRL_TRIG_RST</a> = 11, </div> +<div class="line"><a id="l00051" name="l00051"></a><span class="lineno"><a class="line" href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831a7ecbccef9e77e68caf22ed2c416e1f77"> 51</a></span> <a class="code hl_enumvalue" href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831a7ecbccef9e77e68caf22ed2c416e1f77">ONEWIRE_CTRL_TRIG_BIT</a> = 12, </div> +<div class="line"><a id="l00052" name="l00052"></a><span class="lineno"><a class="line" href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831acfd8a56f668ca55dbbaa1714b1235dfe"> 52</a></span> <a class="code hl_enumvalue" href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831acfd8a56f668ca55dbbaa1714b1235dfe">ONEWIRE_CTRL_TRIG_BYTE</a> = 13, </div> +<div class="line"><a id="l00054" name="l00054"></a><span class="lineno"><a class="line" href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831af992c94d0b9a7b7b92a5a23366b9a8c6"> 54</a></span> <a class="code hl_enumvalue" href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831af992c94d0b9a7b7b92a5a23366b9a8c6">ONEWIRE_CTRL_SENSE</a> = 29, </div> +<div class="line"><a id="l00055" name="l00055"></a><span class="lineno"><a class="line" href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831a92e1ff9fa10319d64c8d2c6a6d61b37e"> 55</a></span> <a class="code hl_enumvalue" href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831a92e1ff9fa10319d64c8d2c6a6d61b37e">ONEWIRE_CTRL_PRESENCE</a> = 30, </div> +<div class="line"><a id="l00056" name="l00056"></a><span class="lineno"><a class="line" href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831aac8933755e80d72e1e9c293198d831b9"> 56</a></span> <a class="code hl_enumvalue" href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831aac8933755e80d72e1e9c293198d831b9">ONEWIRE_CTRL_BUSY</a> = 31, </div> +<div class="line"><a id="l00057" name="l00057"></a><span class="lineno"> 57</span>};</div> +</div> +<div class="line"><a id="l00058" name="l00058"></a><span class="lineno"> 58</span> </div> +<div class="foldopen" id="foldopen00060" data-start="{" data-end="};"> +<div class="line"><a id="l00060" name="l00060"></a><span class="lineno"><a class="line" href="neorv32__onewire_8h.html#ae770490afa8662fb8577065531d51368"> 60</a></span><span class="keyword">enum</span> <a class="code hl_enumeration" href="neorv32__onewire_8h.html#ae770490afa8662fb8577065531d51368">NEORV32_ONEWIRE_DATA_enum</a> {</div> +<div class="line"><a id="l00061" name="l00061"></a><span class="lineno"><a class="line" href="neorv32__onewire_8h.html#ae770490afa8662fb8577065531d51368a6ad35475e3f80a8c68ce0caa9c3754a5"> 61</a></span> <a class="code hl_enumvalue" href="neorv32__onewire_8h.html#ae770490afa8662fb8577065531d51368a6ad35475e3f80a8c68ce0caa9c3754a5">ONEWIRE_DATA_LSB</a> = 0, </div> +<div class="line"><a id="l00062" name="l00062"></a><span class="lineno"> 62</span> <a class="code hl_enumvalue" href="neorv32__onewire_8h.html#ae770490afa8662fb8577065531d51368af967429634efb019ada46bf75f373aa3">ONEWIRE_DATA_MSB</a> = 7 </div> +<div class="line"><a id="l00063" name="l00063"></a><span class="lineno"><a class="line" href="neorv32__onewire_8h.html#ae770490afa8662fb8577065531d51368af967429634efb019ada46bf75f373aa3"> 63</a></span>};</div> +</div> +<div class="line"><a id="l00067" name="l00067"></a><span class="lineno"> 67</span><span class="comment">/**********************************************************************/</span></div> +<div class="line"><a id="l00071" name="l00071"></a><span class="lineno"> 71</span><span class="keywordtype">int</span> <a class="code hl_function" href="neorv32__onewire_8h.html#a865e5c381fd3c27c6981a589a5124d1e">neorv32_onewire_available</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00072" name="l00072"></a><span class="lineno"> 72</span><span class="keywordtype">int</span> <a class="code hl_function" href="neorv32__onewire_8h.html#a224005037387484dfa510a1355a62828">neorv32_onewire_setup</a>(uint32_t t_base);</div> +<div class="line"><a id="l00073" name="l00073"></a><span class="lineno"> 73</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__onewire_8h.html#ae6fe766e7decf18869cfb86bba741ca4">neorv32_onewire_enable</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00074" name="l00074"></a><span class="lineno"> 74</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__onewire_8h.html#a7e329eeb1cd98301a53b271a6a102385">neorv32_onewire_disable</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00075" name="l00075"></a><span class="lineno"> 75</span><span class="keywordtype">int</span> <a class="code hl_function" href="neorv32__onewire_8h.html#a122531c7154126858c46d89e003d838d">neorv32_onewire_sense</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00076" name="l00076"></a><span class="lineno"> 76</span> </div> +<div class="line"><a id="l00077" name="l00077"></a><span class="lineno"> 77</span><span class="keywordtype">int</span> <a class="code hl_function" href="neorv32__onewire_8h.html#a01b6236b89c045ddbd58398361c6ee0a">neorv32_onewire_busy</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00078" name="l00078"></a><span class="lineno"> 78</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__onewire_8h.html#a3072f7167831edc95dee44ecfef6a0d4">neorv32_onewire_reset</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00079" name="l00079"></a><span class="lineno"> 79</span><span class="keywordtype">int</span> <a class="code hl_function" href="neorv32__onewire_8h.html#a43eb8a08eeaa83e3d7e9aa5058a4269f">neorv32_onewire_reset_get_presence</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00080" name="l00080"></a><span class="lineno"> 80</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__onewire_8h.html#aace8398062b759256a516e6245aced83">neorv32_onewire_read_bit</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00081" name="l00081"></a><span class="lineno"> 81</span>uint8_t <a class="code hl_function" href="neorv32__onewire_8h.html#aa4a19d2d8dc3b3401307615aec201190">neorv32_onewire_read_bit_get</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00082" name="l00082"></a><span class="lineno"> 82</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__onewire_8h.html#a49d0a2a386f129fd2f4fed880bba31d4">neorv32_onewire_write_bit</a>(uint8_t bit);</div> +<div class="line"><a id="l00083" name="l00083"></a><span class="lineno"> 83</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__onewire_8h.html#a01ddba7a9148be542b5c52e39e6f46d6">neorv32_onewire_read_byte</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00084" name="l00084"></a><span class="lineno"> 84</span>uint8_t <a class="code hl_function" href="neorv32__onewire_8h.html#a4c7eec15c095c97c939163f631f51dab">neorv32_onewire_read_byte_get</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00085" name="l00085"></a><span class="lineno"> 85</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__onewire_8h.html#a23b96b68c3214b188525eb102cafb620">neorv32_onewire_write_byte</a>(uint8_t <span class="keywordtype">byte</span>);</div> +<div class="line"><a id="l00086" name="l00086"></a><span class="lineno"> 86</span> </div> +<div class="line"><a id="l00087" name="l00087"></a><span class="lineno"> 87</span><span class="keywordtype">int</span> <a class="code hl_function" href="neorv32__onewire_8h.html#af8ca6be495176797b7da3857e2f794f9">neorv32_onewire_reset_blocking</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00088" name="l00088"></a><span class="lineno"> 88</span>uint8_t <a class="code hl_function" href="neorv32__onewire_8h.html#ace8b7cf697b068b6b51676d84dec5960">neorv32_onewire_read_bit_blocking</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00089" name="l00089"></a><span class="lineno"> 89</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__onewire_8h.html#a6f7b6690a2437e0b574a8a9a23dc0eaa">neorv32_onewire_write_bit_blocking</a>(uint8_t bit);</div> +<div class="line"><a id="l00090" name="l00090"></a><span class="lineno"> 90</span>uint8_t <a class="code hl_function" href="neorv32__onewire_8h.html#a7510e65a26aeefb40e994fd00667537e">neorv32_onewire_read_byte_blocking</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00091" name="l00091"></a><span class="lineno"> 91</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__onewire_8h.html#ac78557c77482b59394677f42fda4fdf1">neorv32_onewire_write_byte_blocking</a>(uint8_t <span class="keywordtype">byte</span>);</div> +<div class="line"><a id="l00095" name="l00095"></a><span class="lineno"> 95</span><span class="preprocessor">#endif </span><span class="comment">// neorv32_onewire_h</span></div> +<div class="ttc" id="aneorv32__onewire_8h_html_a01b6236b89c045ddbd58398361c6ee0a"><div class="ttname"><a href="neorv32__onewire_8h.html#a01b6236b89c045ddbd58398361c6ee0a">neorv32_onewire_busy</a></div><div class="ttdeci">int neorv32_onewire_busy(void)</div><div class="ttdef"><b>Definition</b> neorv32_onewire.c:130</div></div> +<div class="ttc" id="aneorv32__onewire_8h_html_a01ddba7a9148be542b5c52e39e6f46d6"><div class="ttname"><a href="neorv32__onewire_8h.html#a01ddba7a9148be542b5c52e39e6f46d6">neorv32_onewire_read_byte</a></div><div class="ttdeci">void neorv32_onewire_read_byte(void)</div><div class="ttdef"><b>Definition</b> neorv32_onewire.c:234</div></div> +<div class="ttc" id="aneorv32__onewire_8h_html_a122531c7154126858c46d89e003d838d"><div class="ttname"><a href="neorv32__onewire_8h.html#a122531c7154126858c46d89e003d838d">neorv32_onewire_sense</a></div><div class="ttdeci">int neorv32_onewire_sense(void)</div><div class="ttdef"><b>Definition</b> neorv32_onewire.c:107</div></div> +<div class="ttc" id="aneorv32__onewire_8h_html_a224005037387484dfa510a1355a62828"><div class="ttname"><a href="neorv32__onewire_8h.html#a224005037387484dfa510a1355a62828">neorv32_onewire_setup</a></div><div class="ttdeci">int neorv32_onewire_setup(uint32_t t_base)</div><div class="ttdef"><b>Definition</b> neorv32_onewire.c:43</div></div> +<div class="ttc" id="aneorv32__onewire_8h_html_a23b96b68c3214b188525eb102cafb620"><div class="ttname"><a href="neorv32__onewire_8h.html#a23b96b68c3214b188525eb102cafb620">neorv32_onewire_write_byte</a></div><div class="ttdeci">void neorv32_onewire_write_byte(uint8_t byte)</div><div class="ttdef"><b>Definition</b> neorv32_onewire.c:265</div></div> +<div class="ttc" id="aneorv32__onewire_8h_html_a3072f7167831edc95dee44ecfef6a0d4"><div class="ttname"><a href="neorv32__onewire_8h.html#a3072f7167831edc95dee44ecfef6a0d4">neorv32_onewire_reset</a></div><div class="ttdeci">void neorv32_onewire_reset(void)</div><div class="ttdef"><b>Definition</b> neorv32_onewire.c:147</div></div> +<div class="ttc" id="aneorv32__onewire_8h_html_a43eb8a08eeaa83e3d7e9aa5058a4269f"><div class="ttname"><a href="neorv32__onewire_8h.html#a43eb8a08eeaa83e3d7e9aa5058a4269f">neorv32_onewire_reset_get_presence</a></div><div class="ttdeci">int neorv32_onewire_reset_get_presence(void)</div><div class="ttdef"><b>Definition</b> neorv32_onewire.c:161</div></div> +<div class="ttc" id="aneorv32__onewire_8h_html_a49d0a2a386f129fd2f4fed880bba31d4"><div class="ttname"><a href="neorv32__onewire_8h.html#a49d0a2a386f129fd2f4fed880bba31d4">neorv32_onewire_write_bit</a></div><div class="ttdeci">void neorv32_onewire_write_bit(uint8_t bit)</div><div class="ttdef"><b>Definition</b> neorv32_onewire.c:214</div></div> +<div class="ttc" id="aneorv32__onewire_8h_html_a4c7eec15c095c97c939163f631f51dab"><div class="ttname"><a href="neorv32__onewire_8h.html#a4c7eec15c095c97c939163f631f51dab">neorv32_onewire_read_byte_get</a></div><div class="ttdeci">uint8_t neorv32_onewire_read_byte_get(void)</div><div class="ttdef"><b>Definition</b> neorv32_onewire.c:251</div></div> +<div class="ttc" id="aneorv32__onewire_8h_html_a6f7b6690a2437e0b574a8a9a23dc0eaa"><div class="ttname"><a href="neorv32__onewire_8h.html#a6f7b6690a2437e0b574a8a9a23dc0eaa">neorv32_onewire_write_bit_blocking</a></div><div class="ttdeci">void neorv32_onewire_write_bit_blocking(uint8_t bit)</div><div class="ttdef"><b>Definition</b> neorv32_onewire.c:327</div></div> +<div class="ttc" id="aneorv32__onewire_8h_html_a7510e65a26aeefb40e994fd00667537e"><div class="ttname"><a href="neorv32__onewire_8h.html#a7510e65a26aeefb40e994fd00667537e">neorv32_onewire_read_byte_blocking</a></div><div class="ttdeci">uint8_t neorv32_onewire_read_byte_blocking(void)</div><div class="ttdef"><b>Definition</b> neorv32_onewire.c:344</div></div> +<div class="ttc" id="aneorv32__onewire_8h_html_a7e329eeb1cd98301a53b271a6a102385"><div class="ttname"><a href="neorv32__onewire_8h.html#a7e329eeb1cd98301a53b271a6a102385">neorv32_onewire_disable</a></div><div class="ttdeci">void neorv32_onewire_disable(void)</div><div class="ttdef"><b>Definition</b> neorv32_onewire.c:96</div></div> +<div class="ttc" id="aneorv32__onewire_8h_html_a865e5c381fd3c27c6981a589a5124d1e"><div class="ttname"><a href="neorv32__onewire_8h.html#a865e5c381fd3c27c6981a589a5124d1e">neorv32_onewire_available</a></div><div class="ttdeci">int neorv32_onewire_available(void)</div><div class="ttdef"><b>Definition</b> neorv32_onewire.c:26</div></div> +<div class="ttc" id="aneorv32__onewire_8h_html_aa4a19d2d8dc3b3401307615aec201190"><div class="ttname"><a href="neorv32__onewire_8h.html#aa4a19d2d8dc3b3401307615aec201190">neorv32_onewire_read_bit_get</a></div><div class="ttdeci">uint8_t neorv32_onewire_read_bit_get(void)</div><div class="ttdef"><b>Definition</b> neorv32_onewire.c:195</div></div> +<div class="ttc" id="aneorv32__onewire_8h_html_aace8398062b759256a516e6245aced83"><div class="ttname"><a href="neorv32__onewire_8h.html#aace8398062b759256a516e6245aced83">neorv32_onewire_read_bit</a></div><div class="ttdeci">void neorv32_onewire_read_bit(void)</div><div class="ttdef"><b>Definition</b> neorv32_onewire.c:178</div></div> +<div class="ttc" id="aneorv32__onewire_8h_html_ac78557c77482b59394677f42fda4fdf1"><div class="ttname"><a href="neorv32__onewire_8h.html#ac78557c77482b59394677f42fda4fdf1">neorv32_onewire_write_byte_blocking</a></div><div class="ttdeci">void neorv32_onewire_write_byte_blocking(uint8_t byte)</div><div class="ttdef"><b>Definition</b> neorv32_onewire.c:364</div></div> +<div class="ttc" id="aneorv32__onewire_8h_html_ace8b7cf697b068b6b51676d84dec5960"><div class="ttname"><a href="neorv32__onewire_8h.html#ace8b7cf697b068b6b51676d84dec5960">neorv32_onewire_read_bit_blocking</a></div><div class="ttdeci">uint8_t neorv32_onewire_read_bit_blocking(void)</div><div class="ttdef"><b>Definition</b> neorv32_onewire.c:307</div></div> +<div class="ttc" id="aneorv32__onewire_8h_html_ade1a01f533843880868ec7496d116831"><div class="ttname"><a href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831">NEORV32_ONEWIRE_CTRL_enum</a></div><div class="ttdeci">NEORV32_ONEWIRE_CTRL_enum</div><div class="ttdef"><b>Definition</b> neorv32_onewire.h:38</div></div> +<div class="ttc" id="aneorv32__onewire_8h_html_ade1a01f533843880868ec7496d116831a27f040454bebc6218b490f7160ea2312"><div class="ttname"><a href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831a27f040454bebc6218b490f7160ea2312">ONEWIRE_CTRL_CLKDIV6</a></div><div class="ttdeci">@ ONEWIRE_CTRL_CLKDIV6</div><div class="ttdef"><b>Definition</b> neorv32_onewire.h:48</div></div> +<div class="ttc" id="aneorv32__onewire_8h_html_ade1a01f533843880868ec7496d116831a32af8c86e7166e02e801727bd261c179"><div class="ttname"><a href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831a32af8c86e7166e02e801727bd261c179">ONEWIRE_CTRL_CLKDIV4</a></div><div class="ttdeci">@ ONEWIRE_CTRL_CLKDIV4</div><div class="ttdef"><b>Definition</b> neorv32_onewire.h:46</div></div> +<div class="ttc" id="aneorv32__onewire_8h_html_ade1a01f533843880868ec7496d116831a789d65fd9b0ab17bffd0d6de9d2e132a"><div class="ttname"><a href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831a789d65fd9b0ab17bffd0d6de9d2e132a">ONEWIRE_CTRL_CLKDIV5</a></div><div class="ttdeci">@ ONEWIRE_CTRL_CLKDIV5</div><div class="ttdef"><b>Definition</b> neorv32_onewire.h:47</div></div> +<div class="ttc" id="aneorv32__onewire_8h_html_ade1a01f533843880868ec7496d116831a7ecbccef9e77e68caf22ed2c416e1f77"><div class="ttname"><a href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831a7ecbccef9e77e68caf22ed2c416e1f77">ONEWIRE_CTRL_TRIG_BIT</a></div><div class="ttdeci">@ ONEWIRE_CTRL_TRIG_BIT</div><div class="ttdef"><b>Definition</b> neorv32_onewire.h:51</div></div> +<div class="ttc" id="aneorv32__onewire_8h_html_ade1a01f533843880868ec7496d116831a8b19096f72ef96a7597fda9be625ed40"><div class="ttname"><a href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831a8b19096f72ef96a7597fda9be625ed40">ONEWIRE_CTRL_CLKDIV7</a></div><div class="ttdeci">@ ONEWIRE_CTRL_CLKDIV7</div><div class="ttdef"><b>Definition</b> neorv32_onewire.h:49</div></div> +<div class="ttc" id="aneorv32__onewire_8h_html_ade1a01f533843880868ec7496d116831a92e1ff9fa10319d64c8d2c6a6d61b37e"><div class="ttname"><a href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831a92e1ff9fa10319d64c8d2c6a6d61b37e">ONEWIRE_CTRL_PRESENCE</a></div><div class="ttdeci">@ ONEWIRE_CTRL_PRESENCE</div><div class="ttdef"><b>Definition</b> neorv32_onewire.h:55</div></div> +<div class="ttc" id="aneorv32__onewire_8h_html_ade1a01f533843880868ec7496d116831a98624ec944e0413a208cdf54bbbf4c75"><div class="ttname"><a href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831a98624ec944e0413a208cdf54bbbf4c75">ONEWIRE_CTRL_TRIG_RST</a></div><div class="ttdeci">@ ONEWIRE_CTRL_TRIG_RST</div><div class="ttdef"><b>Definition</b> neorv32_onewire.h:50</div></div> +<div class="ttc" id="aneorv32__onewire_8h_html_ade1a01f533843880868ec7496d116831aac8933755e80d72e1e9c293198d831b9"><div class="ttname"><a href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831aac8933755e80d72e1e9c293198d831b9">ONEWIRE_CTRL_BUSY</a></div><div class="ttdeci">@ ONEWIRE_CTRL_BUSY</div><div class="ttdef"><b>Definition</b> neorv32_onewire.h:56</div></div> +<div class="ttc" id="aneorv32__onewire_8h_html_ade1a01f533843880868ec7496d116831ab8600bd09d74e39869259881b84ebfbf"><div class="ttname"><a href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831ab8600bd09d74e39869259881b84ebfbf">ONEWIRE_CTRL_CLKDIV3</a></div><div class="ttdeci">@ ONEWIRE_CTRL_CLKDIV3</div><div class="ttdef"><b>Definition</b> neorv32_onewire.h:45</div></div> +<div class="ttc" id="aneorv32__onewire_8h_html_ade1a01f533843880868ec7496d116831ab87882c202f80185278c69e482f147da"><div class="ttname"><a href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831ab87882c202f80185278c69e482f147da">ONEWIRE_CTRL_EN</a></div><div class="ttdeci">@ ONEWIRE_CTRL_EN</div><div class="ttdef"><b>Definition</b> neorv32_onewire.h:39</div></div> +<div class="ttc" id="aneorv32__onewire_8h_html_ade1a01f533843880868ec7496d116831abfed6417c3abd7ef94cd18a3b32c4393"><div class="ttname"><a href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831abfed6417c3abd7ef94cd18a3b32c4393">ONEWIRE_CTRL_PRSC0</a></div><div class="ttdeci">@ ONEWIRE_CTRL_PRSC0</div><div class="ttdef"><b>Definition</b> neorv32_onewire.h:40</div></div> +<div class="ttc" id="aneorv32__onewire_8h_html_ade1a01f533843880868ec7496d116831acdfca08f34d7379aaf8505ba3425c6f5"><div class="ttname"><a href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831acdfca08f34d7379aaf8505ba3425c6f5">ONEWIRE_CTRL_CLKDIV0</a></div><div class="ttdeci">@ ONEWIRE_CTRL_CLKDIV0</div><div class="ttdef"><b>Definition</b> neorv32_onewire.h:42</div></div> +<div class="ttc" id="aneorv32__onewire_8h_html_ade1a01f533843880868ec7496d116831acfd8a56f668ca55dbbaa1714b1235dfe"><div class="ttname"><a href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831acfd8a56f668ca55dbbaa1714b1235dfe">ONEWIRE_CTRL_TRIG_BYTE</a></div><div class="ttdeci">@ ONEWIRE_CTRL_TRIG_BYTE</div><div class="ttdef"><b>Definition</b> neorv32_onewire.h:52</div></div> +<div class="ttc" id="aneorv32__onewire_8h_html_ade1a01f533843880868ec7496d116831aec9f056072e1db747e74a5c695d2a1df"><div class="ttname"><a href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831aec9f056072e1db747e74a5c695d2a1df">ONEWIRE_CTRL_CLKDIV2</a></div><div class="ttdeci">@ ONEWIRE_CTRL_CLKDIV2</div><div class="ttdef"><b>Definition</b> neorv32_onewire.h:44</div></div> +<div class="ttc" id="aneorv32__onewire_8h_html_ade1a01f533843880868ec7496d116831aee1e24261e263c70bf2e36dcafc9dc74"><div class="ttname"><a href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831aee1e24261e263c70bf2e36dcafc9dc74">ONEWIRE_CTRL_PRSC1</a></div><div class="ttdeci">@ ONEWIRE_CTRL_PRSC1</div><div class="ttdef"><b>Definition</b> neorv32_onewire.h:41</div></div> +<div class="ttc" id="aneorv32__onewire_8h_html_ade1a01f533843880868ec7496d116831af992c94d0b9a7b7b92a5a23366b9a8c6"><div class="ttname"><a href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831af992c94d0b9a7b7b92a5a23366b9a8c6">ONEWIRE_CTRL_SENSE</a></div><div class="ttdeci">@ ONEWIRE_CTRL_SENSE</div><div class="ttdef"><b>Definition</b> neorv32_onewire.h:54</div></div> +<div class="ttc" id="aneorv32__onewire_8h_html_ade1a01f533843880868ec7496d116831afa1476a5e04eb4eabf4d7a595eca2df9"><div class="ttname"><a href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831afa1476a5e04eb4eabf4d7a595eca2df9">ONEWIRE_CTRL_CLKDIV1</a></div><div class="ttdeci">@ ONEWIRE_CTRL_CLKDIV1</div><div class="ttdef"><b>Definition</b> neorv32_onewire.h:43</div></div> +<div class="ttc" id="aneorv32__onewire_8h_html_ae6fe766e7decf18869cfb86bba741ca4"><div class="ttname"><a href="neorv32__onewire_8h.html#ae6fe766e7decf18869cfb86bba741ca4">neorv32_onewire_enable</a></div><div class="ttdeci">void neorv32_onewire_enable(void)</div><div class="ttdef"><b>Definition</b> neorv32_onewire.c:87</div></div> +<div class="ttc" id="aneorv32__onewire_8h_html_ae770490afa8662fb8577065531d51368"><div class="ttname"><a href="neorv32__onewire_8h.html#ae770490afa8662fb8577065531d51368">NEORV32_ONEWIRE_DATA_enum</a></div><div class="ttdeci">NEORV32_ONEWIRE_DATA_enum</div><div class="ttdef"><b>Definition</b> neorv32_onewire.h:60</div></div> +<div class="ttc" id="aneorv32__onewire_8h_html_ae770490afa8662fb8577065531d51368a6ad35475e3f80a8c68ce0caa9c3754a5"><div class="ttname"><a href="neorv32__onewire_8h.html#ae770490afa8662fb8577065531d51368a6ad35475e3f80a8c68ce0caa9c3754a5">ONEWIRE_DATA_LSB</a></div><div class="ttdeci">@ ONEWIRE_DATA_LSB</div><div class="ttdef"><b>Definition</b> neorv32_onewire.h:61</div></div> +<div class="ttc" id="aneorv32__onewire_8h_html_ae770490afa8662fb8577065531d51368af967429634efb019ada46bf75f373aa3"><div class="ttname"><a href="neorv32__onewire_8h.html#ae770490afa8662fb8577065531d51368af967429634efb019ada46bf75f373aa3">ONEWIRE_DATA_MSB</a></div><div class="ttdeci">@ ONEWIRE_DATA_MSB</div><div class="ttdef"><b>Definition</b> neorv32_onewire.h:62</div></div> +<div class="ttc" id="aneorv32__onewire_8h_html_af8ca6be495176797b7da3857e2f794f9"><div class="ttname"><a href="neorv32__onewire_8h.html#af8ca6be495176797b7da3857e2f794f9">neorv32_onewire_reset_blocking</a></div><div class="ttdeci">int neorv32_onewire_reset_blocking(void)</div><div class="ttdef"><b>Definition</b> neorv32_onewire.c:287</div></div> +<div class="ttc" id="astructneorv32__onewire__t_html"><div class="ttname"><a href="structneorv32__onewire__t.html">neorv32_onewire_t</a></div><div class="ttdef"><b>Definition</b> neorv32_onewire.h:29</div></div> +<div class="ttc" id="astructneorv32__onewire__t_html_a2c04aa736b901940ed65b96202c8af7a"><div class="ttname"><a href="structneorv32__onewire__t.html#a2c04aa736b901940ed65b96202c8af7a">neorv32_onewire_t::DATA</a></div><div class="ttdeci">uint32_t DATA</div><div class="ttdef"><b>Definition</b> neorv32_onewire.h:31</div></div> +<div class="ttc" id="astructneorv32__onewire__t_html_a310df3bab43e4438417b2ff948f4712a"><div class="ttname"><a href="structneorv32__onewire__t.html#a310df3bab43e4438417b2ff948f4712a">neorv32_onewire_t::CTRL</a></div><div class="ttdeci">uint32_t CTRL</div><div class="ttdef"><b>Definition</b> neorv32_onewire.h:30</div></div> +</div><!-- fragment --></div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/neorv32__pwm_8c.html b/sw/neorv32__pwm_8c.html new file mode 100644 index 0000000000..08dee5aabe --- /dev/null +++ b/sw/neorv32__pwm_8c.html @@ -0,0 +1,284 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/lib/source/neorv32_pwm.c File Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_7d04193005ada6f9450f847f4adb6b5b.html">lib</a></li><li class="navelem"><a class="el" href="dir_0c6ac14e2254a316d41123f98feeb67b.html">source</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#func-members">Functions</a> </div> + <div class="headertitle"><div class="title">neorv32_pwm.c File Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p>Pulse-Width Modulation Controller (PWM) HW driver source file. +<a href="#details">More...</a></p> +<div class="textblock"><code>#include &quot;<a class="el" href="neorv32_8h_source.html">neorv32.h</a>&quot;</code><br /> +</div><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="func-members" name="func-members"></a> +Functions</h2></td></tr> +<tr class="memitem:afb12c860b2f7fa6cd1e069ea540da41c" id="r_afb12c860b2f7fa6cd1e069ea540da41c"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#afb12c860b2f7fa6cd1e069ea540da41c">neorv32_pwm_available</a> (void)</td></tr> +<tr class="separator:afb12c860b2f7fa6cd1e069ea540da41c"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a5502d483de07d2d8c42e2388ed987069" id="r_a5502d483de07d2d8c42e2388ed987069"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a5502d483de07d2d8c42e2388ed987069">neorv32_pwm_setup</a> (int prsc)</td></tr> +<tr class="separator:a5502d483de07d2d8c42e2388ed987069"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a8f16fdc6e048899305a3234f42fe272f" id="r_a8f16fdc6e048899305a3234f42fe272f"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a8f16fdc6e048899305a3234f42fe272f">neorv32_pwm_disable</a> (void)</td></tr> +<tr class="separator:a8f16fdc6e048899305a3234f42fe272f"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:abc62a63dc139b185cdf53d0267501288" id="r_abc62a63dc139b185cdf53d0267501288"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#abc62a63dc139b185cdf53d0267501288">neorv32_pwm_enable</a> (void)</td></tr> +<tr class="separator:abc62a63dc139b185cdf53d0267501288"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a43d8a47dc79ebac24c8a7d2d8247d2a5" id="r_a43d8a47dc79ebac24c8a7d2d8247d2a5"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a43d8a47dc79ebac24c8a7d2d8247d2a5">neorv32_pmw_get_num_channels</a> (void)</td></tr> +<tr class="separator:a43d8a47dc79ebac24c8a7d2d8247d2a5"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aa24bc867effa7756bfbe7818d85aface" id="r_aa24bc867effa7756bfbe7818d85aface"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aa24bc867effa7756bfbe7818d85aface">neorv32_pwm_set</a> (int channel, uint8_t dc)</td></tr> +<tr class="separator:aa24bc867effa7756bfbe7818d85aface"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a64f66ae4f9689a650a70f3c5b45802b6" id="r_a64f66ae4f9689a650a70f3c5b45802b6"><td class="memItemLeft" align="right" valign="top">uint8_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a64f66ae4f9689a650a70f3c5b45802b6">neorv32_pwm_get</a> (int channel)</td></tr> +<tr class="separator:a64f66ae4f9689a650a70f3c5b45802b6"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>Pulse-Width Modulation Controller (PWM) HW driver source file. </p> +<dl class="section note"><dt>Note</dt><dd>These functions should only be used if the PWM unit was synthesized (IO_PWM_EN = true).</dd></dl> +<dl class="section see"><dt>See also</dt><dd><a href="https://stnolting.github.io/neorv32/sw/files.html">https://stnolting.github.io/neorv32/sw/files.html</a> </dd></dl> +</div><h2 class="groupheader">Function Documentation</h2> +<a id="a43d8a47dc79ebac24c8a7d2d8247d2a5" name="a43d8a47dc79ebac24c8a7d2d8247d2a5"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a43d8a47dc79ebac24c8a7d2d8247d2a5">&#9670;&#160;</a></span>neorv32_pmw_get_num_channels()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_pmw_get_num_channels </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Get number of implemented channels. </p><dl class="section warning"><dt>Warning</dt><dd>This function will override all duty cycle configuration registers.</dd></dl> +<dl class="section return"><dt>Returns</dt><dd>Number of implemented channels. </dd></dl> + +</div> +</div> +<a id="afb12c860b2f7fa6cd1e069ea540da41c" name="afb12c860b2f7fa6cd1e069ea540da41c"></a> +<h2 class="memtitle"><span class="permalink"><a href="#afb12c860b2f7fa6cd1e069ea540da41c">&#9670;&#160;</a></span>neorv32_pwm_available()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_pwm_available </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Check if PWM unit was synthesized.</p> +<dl class="section return"><dt>Returns</dt><dd>0 if PWM was not synthesized, 1 if PWM is available. </dd></dl> + +</div> +</div> +<a id="a8f16fdc6e048899305a3234f42fe272f" name="a8f16fdc6e048899305a3234f42fe272f"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a8f16fdc6e048899305a3234f42fe272f">&#9670;&#160;</a></span>neorv32_pwm_disable()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_pwm_disable </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Disable pulse width modulation controller. </p> + +</div> +</div> +<a id="abc62a63dc139b185cdf53d0267501288" name="abc62a63dc139b185cdf53d0267501288"></a> +<h2 class="memtitle"><span class="permalink"><a href="#abc62a63dc139b185cdf53d0267501288">&#9670;&#160;</a></span>neorv32_pwm_enable()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_pwm_enable </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Enable pulse width modulation controller. </p> + +</div> +</div> +<a id="a64f66ae4f9689a650a70f3c5b45802b6" name="a64f66ae4f9689a650a70f3c5b45802b6"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a64f66ae4f9689a650a70f3c5b45802b6">&#9670;&#160;</a></span>neorv32_pwm_get()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint8_t neorv32_pwm_get </td> + <td>(</td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>channel</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Get duty cycle from channel.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">channel</td><td>Channel select (0..11). </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Duty cycle (8-bit, LSB-aligned) of channel 'channel'. </dd></dl> + +</div> +</div> +<a id="aa24bc867effa7756bfbe7818d85aface" name="aa24bc867effa7756bfbe7818d85aface"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aa24bc867effa7756bfbe7818d85aface">&#9670;&#160;</a></span>neorv32_pwm_set()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_pwm_set </td> + <td>(</td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>channel</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">uint8_t</td> <td class="paramname"><span class="paramname"><em>dc</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Set duty cycle for channel.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">channel</td><td>Channel select (0..11). </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">dc</td><td>Duty cycle (8-bit, LSB-aligned). </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="a5502d483de07d2d8c42e2388ed987069" name="a5502d483de07d2d8c42e2388ed987069"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a5502d483de07d2d8c42e2388ed987069">&#9670;&#160;</a></span>neorv32_pwm_setup()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_pwm_setup </td> + <td>(</td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>prsc</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Enable and configure pulse width modulation controller. The PWM control register bits are listed in <a class="el" href="neorv32__pwm_8h.html#af350f93b601a92ef56516198d1570b7d">NEORV32_PWM_CTRL_enum</a>.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">prsc</td><td>Clock prescaler select (0..7). See <a class="el" href="neorv32_8h.html#a10022df4c223533b04d5aebe222e8b73">NEORV32_CLOCK_PRSC_enum</a>. </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/neorv32__pwm_8h.html b/sw/neorv32__pwm_8h.html new file mode 100644 index 0000000000..c0d3525d88 --- /dev/null +++ b/sw/neorv32__pwm_8h.html @@ -0,0 +1,344 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/lib/include/neorv32_pwm.h File Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_7d04193005ada6f9450f847f4adb6b5b.html">lib</a></li><li class="navelem"><a class="el" href="dir_752b1e5d3973bf735fa78bf6b4727df9.html">include</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#nested-classes">Data Structures</a> </div> + <div class="headertitle"><div class="title">neorv32_pwm.h File Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p>Pulse-Width Modulation Controller (PWM) HW driver header file. +<a href="#details">More...</a></p> +<div class="textblock"><code>#include &lt;stdint.h&gt;</code><br /> +</div> +<p><a href="neorv32__pwm_8h_source.html">Go to the source code of this file.</a></p> +<table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="nested-classes" name="nested-classes"></a> +Data Structures</h2></td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">struct &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structneorv32__pwm__t.html">neorv32_pwm_t</a></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="func-members" name="func-members"></a> +Functions</h2></td></tr> +<tr><td colspan="2"><div class="groupHeader">Prototypes</div></td></tr> +<tr class="memitem:afb12c860b2f7fa6cd1e069ea540da41c" id="r_afb12c860b2f7fa6cd1e069ea540da41c"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#afb12c860b2f7fa6cd1e069ea540da41c">neorv32_pwm_available</a> (void)</td></tr> +<tr class="separator:afb12c860b2f7fa6cd1e069ea540da41c"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a5502d483de07d2d8c42e2388ed987069" id="r_a5502d483de07d2d8c42e2388ed987069"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a5502d483de07d2d8c42e2388ed987069">neorv32_pwm_setup</a> (int prsc)</td></tr> +<tr class="separator:a5502d483de07d2d8c42e2388ed987069"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a8f16fdc6e048899305a3234f42fe272f" id="r_a8f16fdc6e048899305a3234f42fe272f"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a8f16fdc6e048899305a3234f42fe272f">neorv32_pwm_disable</a> (void)</td></tr> +<tr class="separator:a8f16fdc6e048899305a3234f42fe272f"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:abc62a63dc139b185cdf53d0267501288" id="r_abc62a63dc139b185cdf53d0267501288"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#abc62a63dc139b185cdf53d0267501288">neorv32_pwm_enable</a> (void)</td></tr> +<tr class="separator:abc62a63dc139b185cdf53d0267501288"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a43d8a47dc79ebac24c8a7d2d8247d2a5" id="r_a43d8a47dc79ebac24c8a7d2d8247d2a5"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a43d8a47dc79ebac24c8a7d2d8247d2a5">neorv32_pmw_get_num_channels</a> (void)</td></tr> +<tr class="separator:a43d8a47dc79ebac24c8a7d2d8247d2a5"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aa24bc867effa7756bfbe7818d85aface" id="r_aa24bc867effa7756bfbe7818d85aface"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aa24bc867effa7756bfbe7818d85aface">neorv32_pwm_set</a> (int channel, uint8_t dc)</td></tr> +<tr class="separator:aa24bc867effa7756bfbe7818d85aface"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a64f66ae4f9689a650a70f3c5b45802b6" id="r_a64f66ae4f9689a650a70f3c5b45802b6"><td class="memItemLeft" align="right" valign="top">uint8_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a64f66ae4f9689a650a70f3c5b45802b6">neorv32_pwm_get</a> (int channel)</td></tr> +<tr class="separator:a64f66ae4f9689a650a70f3c5b45802b6"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader">IO Device: Pulse Width Modulation Controller (PWM)</h2></td></tr> +<tr class="memitem:ad4cb534c29e26fa56c10bef7afab8f51" id="r_ad4cb534c29e26fa56c10bef7afab8f51"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ad4cb534c29e26fa56c10bef7afab8f51">NEORV32_PWM</a>&#160;&#160;&#160;((<a class="el" href="structneorv32__pwm__t.html">neorv32_pwm_t</a>*) (<a class="el" href="neorv32_8h.html#afef7a6b121a788560b29e2ee2a58c725">NEORV32_PWM_BASE</a>))</td></tr> +<tr class="separator:ad4cb534c29e26fa56c10bef7afab8f51"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:af350f93b601a92ef56516198d1570b7d" id="r_af350f93b601a92ef56516198d1570b7d"><td class="memItemLeft" align="right" valign="top">enum &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#af350f93b601a92ef56516198d1570b7d">NEORV32_PWM_CTRL_enum</a> { <a class="el" href="#af350f93b601a92ef56516198d1570b7dafb99fba508460086efdd495d4649c65a">PWM_CTRL_EN</a> = 0 +, <a class="el" href="#af350f93b601a92ef56516198d1570b7da01ab6de6ac34be1ed68f22e17acbe274">PWM_CTRL_PRSC0</a> = 1 +, <a class="el" href="#af350f93b601a92ef56516198d1570b7daa6fca8a4eecfb99b8f0fa99e187e30bb">PWM_CTRL_PRSC1</a> = 2 +, <a class="el" href="#af350f93b601a92ef56516198d1570b7da0fd36a63fd4c37ef3bc4732518ebf13d">PWM_CTRL_PRSC2</a> = 3 + }</td></tr> +<tr class="separator:af350f93b601a92ef56516198d1570b7d"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>Pulse-Width Modulation Controller (PWM) HW driver header file. </p> +<dl class="section note"><dt>Note</dt><dd>These functions should only be used if the PWM unit was synthesized (IO_PWM_EN = true).</dd></dl> +<dl class="section see"><dt>See also</dt><dd><a href="https://stnolting.github.io/neorv32/sw/files.html">https://stnolting.github.io/neorv32/sw/files.html</a> </dd></dl> +</div><h2 class="groupheader">Macro Definition Documentation</h2> +<a id="ad4cb534c29e26fa56c10bef7afab8f51" name="ad4cb534c29e26fa56c10bef7afab8f51"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ad4cb534c29e26fa56c10bef7afab8f51">&#9670;&#160;</a></span>NEORV32_PWM</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define NEORV32_PWM&#160;&#160;&#160;((<a class="el" href="structneorv32__pwm__t.html">neorv32_pwm_t</a>*) (<a class="el" href="neorv32_8h.html#afef7a6b121a788560b29e2ee2a58c725">NEORV32_PWM_BASE</a>))</td> + </tr> + </table> +</div><div class="memdoc"> +<p>PWM module hardware access (<a class="el" href="structneorv32__pwm__t.html">neorv32_pwm_t</a>) </p> + +</div> +</div> +<h2 class="groupheader">Enumeration Type Documentation</h2> +<a id="af350f93b601a92ef56516198d1570b7d" name="af350f93b601a92ef56516198d1570b7d"></a> +<h2 class="memtitle"><span class="permalink"><a href="#af350f93b601a92ef56516198d1570b7d">&#9670;&#160;</a></span>NEORV32_PWM_CTRL_enum</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">enum <a class="el" href="#af350f93b601a92ef56516198d1570b7d">NEORV32_PWM_CTRL_enum</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>PWM control register bits </p> +<table class="fieldtable"> +<tr><th colspan="2">Enumerator</th></tr><tr><td class="fieldname"><a id="af350f93b601a92ef56516198d1570b7dafb99fba508460086efdd495d4649c65a" name="af350f93b601a92ef56516198d1570b7dafb99fba508460086efdd495d4649c65a"></a>PWM_CTRL_EN&#160;</td><td class="fielddoc"><p>PWM control register(0) (r/w): PWM controller enable </p> +</td></tr> +<tr><td class="fieldname"><a id="af350f93b601a92ef56516198d1570b7da01ab6de6ac34be1ed68f22e17acbe274" name="af350f93b601a92ef56516198d1570b7da01ab6de6ac34be1ed68f22e17acbe274"></a>PWM_CTRL_PRSC0&#160;</td><td class="fielddoc"><p>PWM control register(1) (r/w): Clock prescaler select bit 0 </p> +</td></tr> +<tr><td class="fieldname"><a id="af350f93b601a92ef56516198d1570b7daa6fca8a4eecfb99b8f0fa99e187e30bb" name="af350f93b601a92ef56516198d1570b7daa6fca8a4eecfb99b8f0fa99e187e30bb"></a>PWM_CTRL_PRSC1&#160;</td><td class="fielddoc"><p>PWM control register(2) (r/w): Clock prescaler select bit 1 </p> +</td></tr> +<tr><td class="fieldname"><a id="af350f93b601a92ef56516198d1570b7da0fd36a63fd4c37ef3bc4732518ebf13d" name="af350f93b601a92ef56516198d1570b7da0fd36a63fd4c37ef3bc4732518ebf13d"></a>PWM_CTRL_PRSC2&#160;</td><td class="fielddoc"><p>PWM control register(3) (r/w): Clock prescaler select bit 2 </p> +</td></tr> +</table> + +</div> +</div> +<h2 class="groupheader">Function Documentation</h2> +<a id="a43d8a47dc79ebac24c8a7d2d8247d2a5" name="a43d8a47dc79ebac24c8a7d2d8247d2a5"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a43d8a47dc79ebac24c8a7d2d8247d2a5">&#9670;&#160;</a></span>neorv32_pmw_get_num_channels()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_pmw_get_num_channels </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Get number of implemented channels. </p><dl class="section warning"><dt>Warning</dt><dd>This function will override all duty cycle configuration registers.</dd></dl> +<dl class="section return"><dt>Returns</dt><dd>Number of implemented channels. </dd></dl> + +</div> +</div> +<a id="afb12c860b2f7fa6cd1e069ea540da41c" name="afb12c860b2f7fa6cd1e069ea540da41c"></a> +<h2 class="memtitle"><span class="permalink"><a href="#afb12c860b2f7fa6cd1e069ea540da41c">&#9670;&#160;</a></span>neorv32_pwm_available()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_pwm_available </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Check if PWM unit was synthesized.</p> +<dl class="section return"><dt>Returns</dt><dd>0 if PWM was not synthesized, 1 if PWM is available. </dd></dl> + +</div> +</div> +<a id="a8f16fdc6e048899305a3234f42fe272f" name="a8f16fdc6e048899305a3234f42fe272f"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a8f16fdc6e048899305a3234f42fe272f">&#9670;&#160;</a></span>neorv32_pwm_disable()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_pwm_disable </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Disable pulse width modulation controller. </p> + +</div> +</div> +<a id="abc62a63dc139b185cdf53d0267501288" name="abc62a63dc139b185cdf53d0267501288"></a> +<h2 class="memtitle"><span class="permalink"><a href="#abc62a63dc139b185cdf53d0267501288">&#9670;&#160;</a></span>neorv32_pwm_enable()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_pwm_enable </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Enable pulse width modulation controller. </p> + +</div> +</div> +<a id="a64f66ae4f9689a650a70f3c5b45802b6" name="a64f66ae4f9689a650a70f3c5b45802b6"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a64f66ae4f9689a650a70f3c5b45802b6">&#9670;&#160;</a></span>neorv32_pwm_get()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint8_t neorv32_pwm_get </td> + <td>(</td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>channel</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Get duty cycle from channel.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">channel</td><td>Channel select (0..11). </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Duty cycle (8-bit, LSB-aligned) of channel 'channel'. </dd></dl> + +</div> +</div> +<a id="aa24bc867effa7756bfbe7818d85aface" name="aa24bc867effa7756bfbe7818d85aface"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aa24bc867effa7756bfbe7818d85aface">&#9670;&#160;</a></span>neorv32_pwm_set()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_pwm_set </td> + <td>(</td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>channel</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">uint8_t</td> <td class="paramname"><span class="paramname"><em>dc</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Set duty cycle for channel.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">channel</td><td>Channel select (0..11). </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">dc</td><td>Duty cycle (8-bit, LSB-aligned). </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="a5502d483de07d2d8c42e2388ed987069" name="a5502d483de07d2d8c42e2388ed987069"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a5502d483de07d2d8c42e2388ed987069">&#9670;&#160;</a></span>neorv32_pwm_setup()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_pwm_setup </td> + <td>(</td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>prsc</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Enable and configure pulse width modulation controller. The PWM control register bits are listed in <a class="el" href="#af350f93b601a92ef56516198d1570b7d">NEORV32_PWM_CTRL_enum</a>.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">prsc</td><td>Clock prescaler select (0..7). See <a class="el" href="neorv32_8h.html#a10022df4c223533b04d5aebe222e8b73">NEORV32_CLOCK_PRSC_enum</a>. </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/neorv32__pwm_8h_source.html b/sw/neorv32__pwm_8h_source.html new file mode 100644 index 0000000000..94bef8f5ea --- /dev/null +++ b/sw/neorv32__pwm_8h_source.html @@ -0,0 +1,158 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/lib/include/neorv32_pwm.h Source File</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_7d04193005ada6f9450f847f4adb6b5b.html">lib</a></li><li class="navelem"><a class="el" href="dir_752b1e5d3973bf735fa78bf6b4727df9.html">include</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="headertitle"><div class="title">neorv32_pwm.h</div></div> +</div><!--header--> +<div class="contents"> +<a href="neorv32__pwm_8h.html">Go to the documentation of this file.</a><div class="fragment"><div class="line"><a id="l00001" name="l00001"></a><span class="lineno"> 1</span><span class="comment">// ================================================================================ //</span></div> +<div class="line"><a id="l00002" name="l00002"></a><span class="lineno"> 2</span><span class="comment">// The NEORV32 RISC-V Processor - https://github.com/stnolting/neorv32 //</span></div> +<div class="line"><a id="l00003" name="l00003"></a><span class="lineno"> 3</span><span class="comment">// Copyright (c) NEORV32 contributors. //</span></div> +<div class="line"><a id="l00004" name="l00004"></a><span class="lineno"> 4</span><span class="comment">// Copyright (c) 2020 - 2024 Stephan Nolting. All rights reserved. //</span></div> +<div class="line"><a id="l00005" name="l00005"></a><span class="lineno"> 5</span><span class="comment">// Licensed under the BSD-3-Clause license, see LICENSE for details. //</span></div> +<div class="line"><a id="l00006" name="l00006"></a><span class="lineno"> 6</span><span class="comment">// SPDX-License-Identifier: BSD-3-Clause //</span></div> +<div class="line"><a id="l00007" name="l00007"></a><span class="lineno"> 7</span><span class="comment">// ================================================================================ //</span></div> +<div class="line"><a id="l00008" name="l00008"></a><span class="lineno"> 8</span> </div> +<div class="line"><a id="l00018" name="l00018"></a><span class="lineno"> 18</span><span class="preprocessor">#ifndef neorv32_pwm_h</span></div> +<div class="line"><a id="l00019" name="l00019"></a><span class="lineno"> 19</span><span class="preprocessor">#define neorv32_pwm_h</span></div> +<div class="line"><a id="l00020" name="l00020"></a><span class="lineno"> 20</span> </div> +<div class="line"><a id="l00021" name="l00021"></a><span class="lineno"> 21</span><span class="preprocessor">#include &lt;stdint.h&gt;</span></div> +<div class="line"><a id="l00022" name="l00022"></a><span class="lineno"> 22</span> </div> +<div class="line"><a id="l00023" name="l00023"></a><span class="lineno"> 23</span> </div> +<div class="line"><a id="l00024" name="l00024"></a><span class="lineno"> 24</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen00029" data-start="{" data-end="};"> +<div class="line"><a id="l00029" name="l00029"></a><span class="lineno"><a class="line" href="structneorv32__pwm__t.html"> 29</a></span><span class="keyword">typedef</span> <span class="keyword">volatile</span> <span class="keyword">struct </span>__attribute__((packed,aligned(4))) {</div> +<div class="line"><a id="l00030" name="l00030"></a><span class="lineno"><a class="line" href="structneorv32__pwm__t.html#ab86705332ebd9c45635c3195c6b3dcc5"> 30</a></span> uint32_t <a class="code hl_variable" href="structneorv32__pwm__t.html#ab86705332ebd9c45635c3195c6b3dcc5">CTRL</a>; </div> +<div class="line"><a id="l00031" name="l00031"></a><span class="lineno"><a class="line" href="structneorv32__pwm__t.html#a6d29528ca60921a6ef8e5bcde81925e7"> 31</a></span> uint32_t DC[3]; </div> +<div class="line"><a id="l00032" name="l00032"></a><span class="lineno"> 32</span>} <a class="code hl_struct" href="structneorv32__pwm__t.html">neorv32_pwm_t</a>;</div> +</div> +<div class="line"><a id="l00033" name="l00033"></a><span class="lineno"> 33</span> </div> +<div class="line"><a id="l00035" name="l00035"></a><span class="lineno"><a class="line" href="neorv32__pwm_8h.html#ad4cb534c29e26fa56c10bef7afab8f51"> 35</a></span><span class="preprocessor">#define NEORV32_PWM ((neorv32_pwm_t*) (NEORV32_PWM_BASE))</span></div> +<div class="line"><a id="l00036" name="l00036"></a><span class="lineno"> 36</span> </div> +<div class="foldopen" id="foldopen00038" data-start="{" data-end="};"> +<div class="line"><a id="l00038" name="l00038"></a><span class="lineno"><a class="line" href="neorv32__pwm_8h.html#af350f93b601a92ef56516198d1570b7d"> 38</a></span><span class="keyword">enum</span> <a class="code hl_enumeration" href="neorv32__pwm_8h.html#af350f93b601a92ef56516198d1570b7d">NEORV32_PWM_CTRL_enum</a> {</div> +<div class="line"><a id="l00039" name="l00039"></a><span class="lineno"><a class="line" href="neorv32__pwm_8h.html#af350f93b601a92ef56516198d1570b7dafb99fba508460086efdd495d4649c65a"> 39</a></span> <a class="code hl_enumvalue" href="neorv32__pwm_8h.html#af350f93b601a92ef56516198d1570b7dafb99fba508460086efdd495d4649c65a">PWM_CTRL_EN</a> = 0, </div> +<div class="line"><a id="l00040" name="l00040"></a><span class="lineno"><a class="line" href="neorv32__pwm_8h.html#af350f93b601a92ef56516198d1570b7da01ab6de6ac34be1ed68f22e17acbe274"> 40</a></span> <a class="code hl_enumvalue" href="neorv32__pwm_8h.html#af350f93b601a92ef56516198d1570b7da01ab6de6ac34be1ed68f22e17acbe274">PWM_CTRL_PRSC0</a> = 1, </div> +<div class="line"><a id="l00041" name="l00041"></a><span class="lineno"><a class="line" href="neorv32__pwm_8h.html#af350f93b601a92ef56516198d1570b7daa6fca8a4eecfb99b8f0fa99e187e30bb"> 41</a></span> <a class="code hl_enumvalue" href="neorv32__pwm_8h.html#af350f93b601a92ef56516198d1570b7daa6fca8a4eecfb99b8f0fa99e187e30bb">PWM_CTRL_PRSC1</a> = 2, </div> +<div class="line"><a id="l00042" name="l00042"></a><span class="lineno"> 42</span> <a class="code hl_enumvalue" href="neorv32__pwm_8h.html#af350f93b601a92ef56516198d1570b7da0fd36a63fd4c37ef3bc4732518ebf13d">PWM_CTRL_PRSC2</a> = 3 </div> +<div class="line"><a id="l00043" name="l00043"></a><span class="lineno"><a class="line" href="neorv32__pwm_8h.html#af350f93b601a92ef56516198d1570b7da0fd36a63fd4c37ef3bc4732518ebf13d"> 43</a></span>};</div> +</div> +<div class="line"><a id="l00047" name="l00047"></a><span class="lineno"> 47</span><span class="comment">/**********************************************************************/</span></div> +<div class="line"><a id="l00051" name="l00051"></a><span class="lineno"> 51</span><span class="keywordtype">int</span> <a class="code hl_function" href="neorv32__pwm_8h.html#afb12c860b2f7fa6cd1e069ea540da41c">neorv32_pwm_available</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00052" name="l00052"></a><span class="lineno"> 52</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__pwm_8h.html#a5502d483de07d2d8c42e2388ed987069">neorv32_pwm_setup</a>(<span class="keywordtype">int</span> prsc);</div> +<div class="line"><a id="l00053" name="l00053"></a><span class="lineno"> 53</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__pwm_8h.html#a8f16fdc6e048899305a3234f42fe272f">neorv32_pwm_disable</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00054" name="l00054"></a><span class="lineno"> 54</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__pwm_8h.html#abc62a63dc139b185cdf53d0267501288">neorv32_pwm_enable</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00055" name="l00055"></a><span class="lineno"> 55</span><span class="keywordtype">int</span> <a class="code hl_function" href="neorv32__pwm_8h.html#a43d8a47dc79ebac24c8a7d2d8247d2a5">neorv32_pmw_get_num_channels</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00056" name="l00056"></a><span class="lineno"> 56</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__pwm_8h.html#aa24bc867effa7756bfbe7818d85aface">neorv32_pwm_set</a>(<span class="keywordtype">int</span> channel, uint8_t dc);</div> +<div class="line"><a id="l00057" name="l00057"></a><span class="lineno"> 57</span>uint8_t <a class="code hl_function" href="neorv32__pwm_8h.html#a64f66ae4f9689a650a70f3c5b45802b6">neorv32_pwm_get</a>(<span class="keywordtype">int</span> channel);</div> +<div class="line"><a id="l00060" name="l00060"></a><span class="lineno"> 60</span><span class="preprocessor">#endif </span><span class="comment">// neorv32_pwm_h</span></div> +<div class="ttc" id="aneorv32__pwm_8h_html_a43d8a47dc79ebac24c8a7d2d8247d2a5"><div class="ttname"><a href="neorv32__pwm_8h.html#a43d8a47dc79ebac24c8a7d2d8247d2a5">neorv32_pmw_get_num_channels</a></div><div class="ttdeci">int neorv32_pmw_get_num_channels(void)</div><div class="ttdef"><b>Definition</b> neorv32_pwm.c:81</div></div> +<div class="ttc" id="aneorv32__pwm_8h_html_a5502d483de07d2d8c42e2388ed987069"><div class="ttname"><a href="neorv32__pwm_8h.html#a5502d483de07d2d8c42e2388ed987069">neorv32_pwm_setup</a></div><div class="ttdeci">void neorv32_pwm_setup(int prsc)</div><div class="ttdef"><b>Definition</b> neorv32_pwm.c:43</div></div> +<div class="ttc" id="aneorv32__pwm_8h_html_a64f66ae4f9689a650a70f3c5b45802b6"><div class="ttname"><a href="neorv32__pwm_8h.html#a64f66ae4f9689a650a70f3c5b45802b6">neorv32_pwm_get</a></div><div class="ttdeci">uint8_t neorv32_pwm_get(int channel)</div><div class="ttdef"><b>Definition</b> neorv32_pwm.c:127</div></div> +<div class="ttc" id="aneorv32__pwm_8h_html_a8f16fdc6e048899305a3234f42fe272f"><div class="ttname"><a href="neorv32__pwm_8h.html#a8f16fdc6e048899305a3234f42fe272f">neorv32_pwm_disable</a></div><div class="ttdeci">void neorv32_pwm_disable(void)</div><div class="ttdef"><b>Definition</b> neorv32_pwm.c:60</div></div> +<div class="ttc" id="aneorv32__pwm_8h_html_aa24bc867effa7756bfbe7818d85aface"><div class="ttname"><a href="neorv32__pwm_8h.html#aa24bc867effa7756bfbe7818d85aface">neorv32_pwm_set</a></div><div class="ttdeci">void neorv32_pwm_set(int channel, uint8_t dc)</div><div class="ttdef"><b>Definition</b> neorv32_pwm.c:103</div></div> +<div class="ttc" id="aneorv32__pwm_8h_html_abc62a63dc139b185cdf53d0267501288"><div class="ttname"><a href="neorv32__pwm_8h.html#abc62a63dc139b185cdf53d0267501288">neorv32_pwm_enable</a></div><div class="ttdeci">void neorv32_pwm_enable(void)</div><div class="ttdef"><b>Definition</b> neorv32_pwm.c:69</div></div> +<div class="ttc" id="aneorv32__pwm_8h_html_af350f93b601a92ef56516198d1570b7d"><div class="ttname"><a href="neorv32__pwm_8h.html#af350f93b601a92ef56516198d1570b7d">NEORV32_PWM_CTRL_enum</a></div><div class="ttdeci">NEORV32_PWM_CTRL_enum</div><div class="ttdef"><b>Definition</b> neorv32_pwm.h:38</div></div> +<div class="ttc" id="aneorv32__pwm_8h_html_af350f93b601a92ef56516198d1570b7da01ab6de6ac34be1ed68f22e17acbe274"><div class="ttname"><a href="neorv32__pwm_8h.html#af350f93b601a92ef56516198d1570b7da01ab6de6ac34be1ed68f22e17acbe274">PWM_CTRL_PRSC0</a></div><div class="ttdeci">@ PWM_CTRL_PRSC0</div><div class="ttdef"><b>Definition</b> neorv32_pwm.h:40</div></div> +<div class="ttc" id="aneorv32__pwm_8h_html_af350f93b601a92ef56516198d1570b7da0fd36a63fd4c37ef3bc4732518ebf13d"><div class="ttname"><a href="neorv32__pwm_8h.html#af350f93b601a92ef56516198d1570b7da0fd36a63fd4c37ef3bc4732518ebf13d">PWM_CTRL_PRSC2</a></div><div class="ttdeci">@ PWM_CTRL_PRSC2</div><div class="ttdef"><b>Definition</b> neorv32_pwm.h:42</div></div> +<div class="ttc" id="aneorv32__pwm_8h_html_af350f93b601a92ef56516198d1570b7daa6fca8a4eecfb99b8f0fa99e187e30bb"><div class="ttname"><a href="neorv32__pwm_8h.html#af350f93b601a92ef56516198d1570b7daa6fca8a4eecfb99b8f0fa99e187e30bb">PWM_CTRL_PRSC1</a></div><div class="ttdeci">@ PWM_CTRL_PRSC1</div><div class="ttdef"><b>Definition</b> neorv32_pwm.h:41</div></div> +<div class="ttc" id="aneorv32__pwm_8h_html_af350f93b601a92ef56516198d1570b7dafb99fba508460086efdd495d4649c65a"><div class="ttname"><a href="neorv32__pwm_8h.html#af350f93b601a92ef56516198d1570b7dafb99fba508460086efdd495d4649c65a">PWM_CTRL_EN</a></div><div class="ttdeci">@ PWM_CTRL_EN</div><div class="ttdef"><b>Definition</b> neorv32_pwm.h:39</div></div> +<div class="ttc" id="aneorv32__pwm_8h_html_afb12c860b2f7fa6cd1e069ea540da41c"><div class="ttname"><a href="neorv32__pwm_8h.html#afb12c860b2f7fa6cd1e069ea540da41c">neorv32_pwm_available</a></div><div class="ttdeci">int neorv32_pwm_available(void)</div><div class="ttdef"><b>Definition</b> neorv32_pwm.c:26</div></div> +<div class="ttc" id="astructneorv32__pwm__t_html"><div class="ttname"><a href="structneorv32__pwm__t.html">neorv32_pwm_t</a></div><div class="ttdef"><b>Definition</b> neorv32_pwm.h:29</div></div> +<div class="ttc" id="astructneorv32__pwm__t_html_ab86705332ebd9c45635c3195c6b3dcc5"><div class="ttname"><a href="structneorv32__pwm__t.html#ab86705332ebd9c45635c3195c6b3dcc5">neorv32_pwm_t::CTRL</a></div><div class="ttdeci">uint32_t CTRL</div><div class="ttdef"><b>Definition</b> neorv32_pwm.h:30</div></div> +</div><!-- fragment --></div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/neorv32__rte_8c.html b/sw/neorv32__rte_8c.html new file mode 100644 index 0000000000..ac75d97d8b --- /dev/null +++ b/sw/neorv32__rte_8c.html @@ -0,0 +1,468 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/lib/source/neorv32_rte.c File Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_7d04193005ada6f9450f847f4adb6b5b.html">lib</a></li><li class="navelem"><a class="el" href="dir_0c6ac14e2254a316d41123f98feeb67b.html">source</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#func-members">Functions</a> &#124; +<a href="#var-members">Variables</a> </div> + <div class="headertitle"><div class="title">neorv32_rte.c File Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p>NEORV32 Runtime Environment. +<a href="#details">More...</a></p> +<div class="textblock"><code>#include &quot;<a class="el" href="neorv32_8h_source.html">neorv32.h</a>&quot;</code><br /> +</div><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="func-members" name="func-members"></a> +Functions</h2></td></tr> +<tr class="memitem:a53f1e006f0bf61deb7ad018f35228873" id="r_a53f1e006f0bf61deb7ad018f35228873"><td class="memItemLeft" align="right" valign="top">static void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a53f1e006f0bf61deb7ad018f35228873">__neorv32_rte_core</a> (void)</td></tr> +<tr class="separator:a53f1e006f0bf61deb7ad018f35228873"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a01bf6c01f5a8cda2132b9ac98824edc1" id="r_a01bf6c01f5a8cda2132b9ac98824edc1"><td class="memItemLeft" align="right" valign="top">static void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a01bf6c01f5a8cda2132b9ac98824edc1">__neorv32_rte_print_hex_word</a> (uint32_t num)</td></tr> +<tr class="separator:a01bf6c01f5a8cda2132b9ac98824edc1"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a343e1913bdc37db9b168fb4def0e6170" id="r_a343e1913bdc37db9b168fb4def0e6170"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a343e1913bdc37db9b168fb4def0e6170">neorv32_rte_setup</a> (void)</td></tr> +<tr class="separator:a343e1913bdc37db9b168fb4def0e6170"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a2cf31cfa569a03a20d554b6400c4c5e2" id="r_a2cf31cfa569a03a20d554b6400c4c5e2"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a2cf31cfa569a03a20d554b6400c4c5e2">neorv32_rte_handler_install</a> (int id, void(*handler)(void))</td></tr> +<tr class="separator:a2cf31cfa569a03a20d554b6400c4c5e2"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a10fde6229bf391e46148405616404a65" id="r_a10fde6229bf391e46148405616404a65"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a10fde6229bf391e46148405616404a65">neorv32_rte_handler_uninstall</a> (int id)</td></tr> +<tr class="separator:a10fde6229bf391e46148405616404a65"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a65e71acc8916b42b59dc2cf6bba30ba3" id="r_a65e71acc8916b42b59dc2cf6bba30ba3"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a65e71acc8916b42b59dc2cf6bba30ba3">neorv32_rte_context_get</a> (int x)</td></tr> +<tr class="separator:a65e71acc8916b42b59dc2cf6bba30ba3"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ae13a9c1fd59ad71afb0d47cf9a0b303e" id="r_ae13a9c1fd59ad71afb0d47cf9a0b303e"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ae13a9c1fd59ad71afb0d47cf9a0b303e">neorv32_rte_context_put</a> (int x, uint32_t data)</td></tr> +<tr class="separator:ae13a9c1fd59ad71afb0d47cf9a0b303e"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a65422bb44f1e7bc011e9bfc5d8451ebe" id="r_a65422bb44f1e7bc011e9bfc5d8451ebe"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a65422bb44f1e7bc011e9bfc5d8451ebe">neorv32_rte_debug_handler</a> (void)</td></tr> +<tr class="separator:a65422bb44f1e7bc011e9bfc5d8451ebe"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a05e8304963e402d228a76aff1868771c" id="r_a05e8304963e402d228a76aff1868771c"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a05e8304963e402d228a76aff1868771c">neorv32_rte_print_hw_config</a> (void)</td></tr> +<tr class="separator:a05e8304963e402d228a76aff1868771c"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aad6f5256a265807c4cde163bcba8dae9" id="r_aad6f5256a265807c4cde163bcba8dae9"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aad6f5256a265807c4cde163bcba8dae9">neorv32_rte_print_hw_version</a> (void)</td></tr> +<tr class="separator:aad6f5256a265807c4cde163bcba8dae9"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aa442c0e39f9156a131c3432fda587692" id="r_aa442c0e39f9156a131c3432fda587692"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aa442c0e39f9156a131c3432fda587692">neorv32_rte_print_about</a> (void)</td></tr> +<tr class="separator:aa442c0e39f9156a131c3432fda587692"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a16df1b48f2e1258a51d3bb7f49531cf3" id="r_a16df1b48f2e1258a51d3bb7f49531cf3"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a16df1b48f2e1258a51d3bb7f49531cf3">neorv32_rte_print_logo</a> (void)</td></tr> +<tr class="separator:a16df1b48f2e1258a51d3bb7f49531cf3"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:acd96aa73eebe6d4bbc9aabe1230cbabc" id="r_acd96aa73eebe6d4bbc9aabe1230cbabc"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#acd96aa73eebe6d4bbc9aabe1230cbabc">neorv32_rte_print_license</a> (void)</td></tr> +<tr class="separator:acd96aa73eebe6d4bbc9aabe1230cbabc"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="var-members" name="var-members"></a> +Variables</h2></td></tr> +<tr class="memitem:a2c8272b4628edddb943bcfad829b561a" id="r_a2c8272b4628edddb943bcfad829b561a"><td class="memItemLeft" align="right" valign="top">static uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a2c8272b4628edddb943bcfad829b561a">__neorv32_rte_vector_lut</a> [<a class="el" href="neorv32__rte_8h.html#ad14a1ca41df1e9300bfd01aef07dce59">NEORV32_RTE_NUM_TRAPS</a>]</td></tr> +<tr class="separator:a2c8272b4628edddb943bcfad829b561a"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>NEORV32 Runtime Environment. </p> +<dl class="section see"><dt>See also</dt><dd><a href="https://stnolting.github.io/neorv32/sw/files.html">https://stnolting.github.io/neorv32/sw/files.html</a> </dd></dl> +</div><h2 class="groupheader">Function Documentation</h2> +<a id="a53f1e006f0bf61deb7ad018f35228873" name="a53f1e006f0bf61deb7ad018f35228873"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a53f1e006f0bf61deb7ad018f35228873">&#9670;&#160;</a></span>__neorv32_rte_core()</h2> + +<div class="memitem"> +<div class="memproto"> +<table class="mlabels"> + <tr> + <td class="mlabels-left"> + <table class="memname"> + <tr> + <td class="memname">static void __neorv32_rte_core </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> + </td> + <td class="mlabels-right"> +<span class="mlabels"><span class="mlabel">static</span></span> </td> + </tr> +</table> +</div><div class="memdoc"> +<p>NEORV32 runtime environment (RTE): This is the core of the NEORV32 RTE (first-level trap handler, executed in machine mode). </p> + +</div> +</div> +<a id="a01bf6c01f5a8cda2132b9ac98824edc1" name="a01bf6c01f5a8cda2132b9ac98824edc1"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a01bf6c01f5a8cda2132b9ac98824edc1">&#9670;&#160;</a></span>__neorv32_rte_print_hex_word()</h2> + +<div class="memitem"> +<div class="memproto"> +<table class="mlabels"> + <tr> + <td class="mlabels-left"> + <table class="memname"> + <tr> + <td class="memname">void __neorv32_rte_print_hex_word </td> + <td>(</td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>num</em></span></td><td>)</td> + <td></td> + </tr> + </table> + </td> + <td class="mlabels-right"> +<span class="mlabels"><span class="mlabel">static</span></span> </td> + </tr> +</table> +</div><div class="memdoc"> +<p>NEORV32 runtime environment (RTE): Private function to print 32-bit number as 8-digit hexadecimal value (with "0x" suffix).</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">num</td><td>Number to print as hexadecimal via UART0. </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="a65e71acc8916b42b59dc2cf6bba30ba3" name="a65e71acc8916b42b59dc2cf6bba30ba3"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a65e71acc8916b42b59dc2cf6bba30ba3">&#9670;&#160;</a></span>neorv32_rte_context_get()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_rte_context_get </td> + <td>(</td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>x</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>NEORV32 runtime environment (RTE): Read register from application context (on stack).</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">x</td><td>Register number (0..31, corresponds to register x0..x31). </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Content of register x. </dd></dl> + +</div> +</div> +<a id="ae13a9c1fd59ad71afb0d47cf9a0b303e" name="ae13a9c1fd59ad71afb0d47cf9a0b303e"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ae13a9c1fd59ad71afb0d47cf9a0b303e">&#9670;&#160;</a></span>neorv32_rte_context_put()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_rte_context_put </td> + <td>(</td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>x</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>data</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>NEORV32 runtime environment (RTE): Write register to application context (on stack).</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">x</td><td>Register number (0..31, corresponds to register x0..x31). </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">data</td><td>Data to be written to register x. </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="a65422bb44f1e7bc011e9bfc5d8451ebe" name="a65422bb44f1e7bc011e9bfc5d8451ebe"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a65422bb44f1e7bc011e9bfc5d8451ebe">&#9670;&#160;</a></span>neorv32_rte_debug_handler()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_rte_debug_handler </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>NEORV32 runtime environment (RTE): Debug trap handler, printing information via UART0. </p> + +</div> +</div> +<a id="a2cf31cfa569a03a20d554b6400c4c5e2" name="a2cf31cfa569a03a20d554b6400c4c5e2"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a2cf31cfa569a03a20d554b6400c4c5e2">&#9670;&#160;</a></span>neorv32_rte_handler_install()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_rte_handler_install </td> + <td>(</td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>id</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">void(*</td> <td class="paramname"><span class="paramname"><em>handler&#160;</em></span>)(void)&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>NEORV32 runtime environment (RTE): Install trap handler function (second-level trap handler).</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">id</td><td>Identifier (type) of the targeted trap. See <a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70a">NEORV32_RTE_TRAP_enum</a>. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">handler</td><td>The actual handler function for the specified trap (function MUST be of type "void function(void);"). </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>0 if success, -1 if error (invalid id or targeted trap not supported). </dd></dl> + +</div> +</div> +<a id="a10fde6229bf391e46148405616404a65" name="a10fde6229bf391e46148405616404a65"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a10fde6229bf391e46148405616404a65">&#9670;&#160;</a></span>neorv32_rte_handler_uninstall()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_rte_handler_uninstall </td> + <td>(</td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>id</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>NEORV32 runtime environment (RTE): Uninstall trap handler function from NEORV32 runtime environment, which was previously installed via neorv32_rte_handler_install(uint8_t id, void (*handler)(void)).</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">id</td><td>Identifier (type) of the targeted trap. See <a class="el" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70a">NEORV32_RTE_TRAP_enum</a>. </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>0 if success, -1 if error (invalid id or targeted trap not supported). </dd></dl> + +</div> +</div> +<a id="aa442c0e39f9156a131c3432fda587692" name="aa442c0e39f9156a131c3432fda587692"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aa442c0e39f9156a131c3432fda587692">&#9670;&#160;</a></span>neorv32_rte_print_about()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_rte_print_about </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>NEORV32 runtime environment (RTE): Print project info via UART0. </p> + +</div> +</div> +<a id="a05e8304963e402d228a76aff1868771c" name="a05e8304963e402d228a76aff1868771c"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a05e8304963e402d228a76aff1868771c">&#9670;&#160;</a></span>neorv32_rte_print_hw_config()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_rte_print_hw_config </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>NEORV32 runtime environment (RTE): Print hardware configuration information via UART0.</p> +<dl class="section warning"><dt>Warning</dt><dd>This function overrides several CSR, CNT and HPM CSRs! </dd></dl> + +</div> +</div> +<a id="aad6f5256a265807c4cde163bcba8dae9" name="aad6f5256a265807c4cde163bcba8dae9"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aad6f5256a265807c4cde163bcba8dae9">&#9670;&#160;</a></span>neorv32_rte_print_hw_version()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_rte_print_hw_version </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>NEORV32 runtime environment (RTE): Print the processor version in human-readable format via UART0. </p> + +</div> +</div> +<a id="acd96aa73eebe6d4bbc9aabe1230cbabc" name="acd96aa73eebe6d4bbc9aabe1230cbabc"></a> +<h2 class="memtitle"><span class="permalink"><a href="#acd96aa73eebe6d4bbc9aabe1230cbabc">&#9670;&#160;</a></span>neorv32_rte_print_license()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_rte_print_license </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>NEORV32 runtime environment (RTE): Print project license via UART0. </p> + +</div> +</div> +<a id="a16df1b48f2e1258a51d3bb7f49531cf3" name="a16df1b48f2e1258a51d3bb7f49531cf3"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a16df1b48f2e1258a51d3bb7f49531cf3">&#9670;&#160;</a></span>neorv32_rte_print_logo()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_rte_print_logo </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>NEORV32 runtime environment (RTE): Print project logo via UART0. </p> + +</div> +</div> +<a id="a343e1913bdc37db9b168fb4def0e6170" name="a343e1913bdc37db9b168fb4def0e6170"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a343e1913bdc37db9b168fb4def0e6170">&#9670;&#160;</a></span>neorv32_rte_setup()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_rte_setup </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>NEORV32 runtime environment (RTE): Setup RTE.</p> +<dl class="section note"><dt>Note</dt><dd>This function installs a debug handler for ALL trap sources, which gives detailed information about the trap. Actual handlers can be installed afterwards via neorv32_rte_handler_install(uint8_t id, void (*handler)(void)). </dd></dl> + +</div> +</div> +<h2 class="groupheader">Variable Documentation</h2> +<a id="a2c8272b4628edddb943bcfad829b561a" name="a2c8272b4628edddb943bcfad829b561a"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a2c8272b4628edddb943bcfad829b561a">&#9670;&#160;</a></span>__neorv32_rte_vector_lut</h2> + +<div class="memitem"> +<div class="memproto"> +<table class="mlabels"> + <tr> + <td class="mlabels-left"> + <table class="memname"> + <tr> + <td class="memname">uint32_t __neorv32_rte_vector_lut[<a class="el" href="neorv32__rte_8h.html#ad14a1ca41df1e9300bfd01aef07dce59">NEORV32_RTE_NUM_TRAPS</a>]</td> + </tr> + </table> + </td> + <td class="mlabels-right"> +<span class="mlabels"><span class="mlabel">static</span></span> </td> + </tr> +</table> +</div><div class="memdoc"> +<p>NEORV32 runtime environment (RTE): The &gt;private&lt; trap vector look-up table of the NEORV32 RTE. </p> + +</div> +</div> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/neorv32__rte_8h.html b/sw/neorv32__rte_8h.html new file mode 100644 index 0000000000..f607d6b2ff --- /dev/null +++ b/sw/neorv32__rte_8h.html @@ -0,0 +1,520 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/lib/include/neorv32_rte.h File Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_7d04193005ada6f9450f847f4adb6b5b.html">lib</a></li><li class="navelem"><a class="el" href="dir_752b1e5d3973bf735fa78bf6b4727df9.html">include</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#define-members">Macros</a> &#124; +<a href="#enum-members">Enumerations</a> </div> + <div class="headertitle"><div class="title">neorv32_rte.h File Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p>NEORV32 Runtime Environment. +<a href="#details">More...</a></p> +<div class="textblock"><code>#include &lt;stdint.h&gt;</code><br /> +</div> +<p><a href="neorv32__rte_8h_source.html">Go to the source code of this file.</a></p> +<table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="define-members" name="define-members"></a> +Macros</h2></td></tr> +<tr class="memitem:ad14a1ca41df1e9300bfd01aef07dce59" id="r_ad14a1ca41df1e9300bfd01aef07dce59"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ad14a1ca41df1e9300bfd01aef07dce59">NEORV32_RTE_NUM_TRAPS</a>&#160;&#160;&#160;29</td></tr> +<tr class="separator:ad14a1ca41df1e9300bfd01aef07dce59"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="enum-members" name="enum-members"></a> +Enumerations</h2></td></tr> +<tr class="memitem:ad28f86ab02d89ade2f0bc12e0a8ca70a" id="r_ad28f86ab02d89ade2f0bc12e0a8ca70a"><td class="memItemLeft" align="right" valign="top">enum &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ad28f86ab02d89ade2f0bc12e0a8ca70a">NEORV32_RTE_TRAP_enum</a> { <br /> +&#160;&#160;<a class="el" href="#ad28f86ab02d89ade2f0bc12e0a8ca70aa931a4f314b04233924b01e8245153be4">RTE_TRAP_I_ACCESS</a> = 0 +, <a class="el" href="#ad28f86ab02d89ade2f0bc12e0a8ca70aa48f4d253b260784a1ffaaded508166e2">RTE_TRAP_I_ILLEGAL</a> = 1 +, <a class="el" href="#ad28f86ab02d89ade2f0bc12e0a8ca70aaf647ff8d55d021379202879627c91d81">RTE_TRAP_I_MISALIGNED</a> = 2 +, <a class="el" href="#ad28f86ab02d89ade2f0bc12e0a8ca70aa463611404367b5910c42dd31c0a218a2">RTE_TRAP_BREAKPOINT</a> = 3 +, <br /> +&#160;&#160;<a class="el" href="#ad28f86ab02d89ade2f0bc12e0a8ca70aa8e2cc9a533ebbc0e1d29c3ec8afbe61f">RTE_TRAP_L_MISALIGNED</a> = 4 +, <a class="el" href="#ad28f86ab02d89ade2f0bc12e0a8ca70aa97047b024b72807a0b312979c9359dab">RTE_TRAP_L_ACCESS</a> = 5 +, <a class="el" href="#ad28f86ab02d89ade2f0bc12e0a8ca70aa85934b3fd8b5268340f84810b3f67232">RTE_TRAP_S_MISALIGNED</a> = 6 +, <a class="el" href="#ad28f86ab02d89ade2f0bc12e0a8ca70aaa9b8334712ecad0500c7610a25741ec7">RTE_TRAP_S_ACCESS</a> = 7 +, <br /> +&#160;&#160;<a class="el" href="#ad28f86ab02d89ade2f0bc12e0a8ca70aa155f84a52bace69f81a99de59701decc">RTE_TRAP_UENV_CALL</a> = 8 +, <a class="el" href="#ad28f86ab02d89ade2f0bc12e0a8ca70aaea6027bf0354c3120fa61c8094dd7a1d">RTE_TRAP_MENV_CALL</a> = 9 +, <a class="el" href="#ad28f86ab02d89ade2f0bc12e0a8ca70aadddffa9acdfcce80dd68ad4b26725174">RTE_TRAP_MSI</a> = 10 +, <a class="el" href="#ad28f86ab02d89ade2f0bc12e0a8ca70aacf17d4b2454c43a1cb544e532d247fff">RTE_TRAP_MTI</a> = 11 +, <br /> +&#160;&#160;<a class="el" href="#ad28f86ab02d89ade2f0bc12e0a8ca70aad2a55d5586d33497fd21b1da8aa98fff">RTE_TRAP_MEI</a> = 12 +, <a class="el" href="#ad28f86ab02d89ade2f0bc12e0a8ca70aab36a403cd7b833439ce7f9a708c33922">RTE_TRAP_FIRQ_0</a> = 13 +, <a class="el" href="#ad28f86ab02d89ade2f0bc12e0a8ca70aab199b53a1458017fa5278e0aeecf41fd">RTE_TRAP_FIRQ_1</a> = 14 +, <a class="el" href="#ad28f86ab02d89ade2f0bc12e0a8ca70aa29ffa3108fadc78bf375773c3232c489">RTE_TRAP_FIRQ_2</a> = 15 +, <br /> +&#160;&#160;<a class="el" href="#ad28f86ab02d89ade2f0bc12e0a8ca70aa4a74188fd87ea17a594ac6fe8ddf71be">RTE_TRAP_FIRQ_3</a> = 16 +, <a class="el" href="#ad28f86ab02d89ade2f0bc12e0a8ca70aa8b39868bf91da54f9ec492918e0c01ff">RTE_TRAP_FIRQ_4</a> = 17 +, <a class="el" href="#ad28f86ab02d89ade2f0bc12e0a8ca70aa01f562418ddbbb6b84be168673deeea9">RTE_TRAP_FIRQ_5</a> = 18 +, <a class="el" href="#ad28f86ab02d89ade2f0bc12e0a8ca70aac9fb28ea8bafff182f12c29d2fad6998">RTE_TRAP_FIRQ_6</a> = 19 +, <br /> +&#160;&#160;<a class="el" href="#ad28f86ab02d89ade2f0bc12e0a8ca70aa73bb84f7b6c7528bec552ac1d3e9ccdb">RTE_TRAP_FIRQ_7</a> = 20 +, <a class="el" href="#ad28f86ab02d89ade2f0bc12e0a8ca70aa3edbf47bd9a278e100bb808c8bb68308">RTE_TRAP_FIRQ_8</a> = 21 +, <a class="el" href="#ad28f86ab02d89ade2f0bc12e0a8ca70aa2cd04189d91465dad2bc2a8852406b76">RTE_TRAP_FIRQ_9</a> = 22 +, <a class="el" href="#ad28f86ab02d89ade2f0bc12e0a8ca70aadebcc4d91aea1364b1481111f1060c52">RTE_TRAP_FIRQ_10</a> = 23 +, <br /> +&#160;&#160;<a class="el" href="#ad28f86ab02d89ade2f0bc12e0a8ca70aab49ff0110481f22da22a085d2633a0e0">RTE_TRAP_FIRQ_11</a> = 24 +, <a class="el" href="#ad28f86ab02d89ade2f0bc12e0a8ca70aaecea4f1d524a33d02324382357b2bcb9">RTE_TRAP_FIRQ_12</a> = 25 +, <a class="el" href="#ad28f86ab02d89ade2f0bc12e0a8ca70aa609613cf25bb8f2d0e323089d6798220">RTE_TRAP_FIRQ_13</a> = 26 +, <a class="el" href="#ad28f86ab02d89ade2f0bc12e0a8ca70aaadd66d9b9c33a6869fa3c30e1e434313">RTE_TRAP_FIRQ_14</a> = 27 +, <br /> +&#160;&#160;<a class="el" href="#ad28f86ab02d89ade2f0bc12e0a8ca70aa1d18312227bfd5332ebcc1f74c979dbe">RTE_TRAP_FIRQ_15</a> = 28 +<br /> + }</td></tr> +<tr class="separator:ad28f86ab02d89ade2f0bc12e0a8ca70a"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="func-members" name="func-members"></a> +Functions</h2></td></tr> +<tr><td colspan="2"><div class="groupHeader">Prototypes</div></td></tr> +<tr class="memitem:a343e1913bdc37db9b168fb4def0e6170" id="r_a343e1913bdc37db9b168fb4def0e6170"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a343e1913bdc37db9b168fb4def0e6170">neorv32_rte_setup</a> (void)</td></tr> +<tr class="separator:a343e1913bdc37db9b168fb4def0e6170"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a2cf31cfa569a03a20d554b6400c4c5e2" id="r_a2cf31cfa569a03a20d554b6400c4c5e2"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a2cf31cfa569a03a20d554b6400c4c5e2">neorv32_rte_handler_install</a> (int id, void(*handler)(void))</td></tr> +<tr class="separator:a2cf31cfa569a03a20d554b6400c4c5e2"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a10fde6229bf391e46148405616404a65" id="r_a10fde6229bf391e46148405616404a65"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a10fde6229bf391e46148405616404a65">neorv32_rte_handler_uninstall</a> (int id)</td></tr> +<tr class="separator:a10fde6229bf391e46148405616404a65"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a65422bb44f1e7bc011e9bfc5d8451ebe" id="r_a65422bb44f1e7bc011e9bfc5d8451ebe"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a65422bb44f1e7bc011e9bfc5d8451ebe">neorv32_rte_debug_handler</a> (void)</td></tr> +<tr class="separator:a65422bb44f1e7bc011e9bfc5d8451ebe"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a65e71acc8916b42b59dc2cf6bba30ba3" id="r_a65e71acc8916b42b59dc2cf6bba30ba3"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a65e71acc8916b42b59dc2cf6bba30ba3">neorv32_rte_context_get</a> (int x)</td></tr> +<tr class="separator:a65e71acc8916b42b59dc2cf6bba30ba3"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ae13a9c1fd59ad71afb0d47cf9a0b303e" id="r_ae13a9c1fd59ad71afb0d47cf9a0b303e"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ae13a9c1fd59ad71afb0d47cf9a0b303e">neorv32_rte_context_put</a> (int x, uint32_t data)</td></tr> +<tr class="separator:ae13a9c1fd59ad71afb0d47cf9a0b303e"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a05e8304963e402d228a76aff1868771c" id="r_a05e8304963e402d228a76aff1868771c"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a05e8304963e402d228a76aff1868771c">neorv32_rte_print_hw_config</a> (void)</td></tr> +<tr class="separator:a05e8304963e402d228a76aff1868771c"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aad6f5256a265807c4cde163bcba8dae9" id="r_aad6f5256a265807c4cde163bcba8dae9"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aad6f5256a265807c4cde163bcba8dae9">neorv32_rte_print_hw_version</a> (void)</td></tr> +<tr class="separator:aad6f5256a265807c4cde163bcba8dae9"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aa442c0e39f9156a131c3432fda587692" id="r_aa442c0e39f9156a131c3432fda587692"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aa442c0e39f9156a131c3432fda587692">neorv32_rte_print_about</a> (void)</td></tr> +<tr class="separator:aa442c0e39f9156a131c3432fda587692"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a16df1b48f2e1258a51d3bb7f49531cf3" id="r_a16df1b48f2e1258a51d3bb7f49531cf3"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a16df1b48f2e1258a51d3bb7f49531cf3">neorv32_rte_print_logo</a> (void)</td></tr> +<tr class="separator:a16df1b48f2e1258a51d3bb7f49531cf3"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:acd96aa73eebe6d4bbc9aabe1230cbabc" id="r_acd96aa73eebe6d4bbc9aabe1230cbabc"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#acd96aa73eebe6d4bbc9aabe1230cbabc">neorv32_rte_print_license</a> (void)</td></tr> +<tr class="separator:acd96aa73eebe6d4bbc9aabe1230cbabc"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>NEORV32 Runtime Environment. </p> +<dl class="section see"><dt>See also</dt><dd><a href="https://stnolting.github.io/neorv32/sw/files.html">https://stnolting.github.io/neorv32/sw/files.html</a> </dd></dl> +</div><h2 class="groupheader">Macro Definition Documentation</h2> +<a id="ad14a1ca41df1e9300bfd01aef07dce59" name="ad14a1ca41df1e9300bfd01aef07dce59"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ad14a1ca41df1e9300bfd01aef07dce59">&#9670;&#160;</a></span>NEORV32_RTE_NUM_TRAPS</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define NEORV32_RTE_NUM_TRAPS&#160;&#160;&#160;29</td> + </tr> + </table> +</div><div class="memdoc"> +<p>NEORV32 runtime environment: Number of available traps. </p> + +</div> +</div> +<h2 class="groupheader">Enumeration Type Documentation</h2> +<a id="ad28f86ab02d89ade2f0bc12e0a8ca70a" name="ad28f86ab02d89ade2f0bc12e0a8ca70a"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ad28f86ab02d89ade2f0bc12e0a8ca70a">&#9670;&#160;</a></span>NEORV32_RTE_TRAP_enum</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">enum <a class="el" href="#ad28f86ab02d89ade2f0bc12e0a8ca70a">NEORV32_RTE_TRAP_enum</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>NEORV32 runtime environment trap IDs. </p> +<table class="fieldtable"> +<tr><th colspan="2">Enumerator</th></tr><tr><td class="fieldname"><a id="ad28f86ab02d89ade2f0bc12e0a8ca70aa931a4f314b04233924b01e8245153be4" name="ad28f86ab02d89ade2f0bc12e0a8ca70aa931a4f314b04233924b01e8245153be4"></a>RTE_TRAP_I_ACCESS&#160;</td><td class="fielddoc"><p>Instruction access fault </p> +</td></tr> +<tr><td class="fieldname"><a id="ad28f86ab02d89ade2f0bc12e0a8ca70aa48f4d253b260784a1ffaaded508166e2" name="ad28f86ab02d89ade2f0bc12e0a8ca70aa48f4d253b260784a1ffaaded508166e2"></a>RTE_TRAP_I_ILLEGAL&#160;</td><td class="fielddoc"><p>Illegal instruction </p> +</td></tr> +<tr><td class="fieldname"><a id="ad28f86ab02d89ade2f0bc12e0a8ca70aaf647ff8d55d021379202879627c91d81" name="ad28f86ab02d89ade2f0bc12e0a8ca70aaf647ff8d55d021379202879627c91d81"></a>RTE_TRAP_I_MISALIGNED&#160;</td><td class="fielddoc"><p>Instruction address misaligned </p> +</td></tr> +<tr><td class="fieldname"><a id="ad28f86ab02d89ade2f0bc12e0a8ca70aa463611404367b5910c42dd31c0a218a2" name="ad28f86ab02d89ade2f0bc12e0a8ca70aa463611404367b5910c42dd31c0a218a2"></a>RTE_TRAP_BREAKPOINT&#160;</td><td class="fielddoc"><p>Breakpoint (EBREAK instruction) </p> +</td></tr> +<tr><td class="fieldname"><a id="ad28f86ab02d89ade2f0bc12e0a8ca70aa8e2cc9a533ebbc0e1d29c3ec8afbe61f" name="ad28f86ab02d89ade2f0bc12e0a8ca70aa8e2cc9a533ebbc0e1d29c3ec8afbe61f"></a>RTE_TRAP_L_MISALIGNED&#160;</td><td class="fielddoc"><p>Load address misaligned </p> +</td></tr> +<tr><td class="fieldname"><a id="ad28f86ab02d89ade2f0bc12e0a8ca70aa97047b024b72807a0b312979c9359dab" name="ad28f86ab02d89ade2f0bc12e0a8ca70aa97047b024b72807a0b312979c9359dab"></a>RTE_TRAP_L_ACCESS&#160;</td><td class="fielddoc"><p>Load access fault </p> +</td></tr> +<tr><td class="fieldname"><a id="ad28f86ab02d89ade2f0bc12e0a8ca70aa85934b3fd8b5268340f84810b3f67232" name="ad28f86ab02d89ade2f0bc12e0a8ca70aa85934b3fd8b5268340f84810b3f67232"></a>RTE_TRAP_S_MISALIGNED&#160;</td><td class="fielddoc"><p>Store address misaligned </p> +</td></tr> +<tr><td class="fieldname"><a id="ad28f86ab02d89ade2f0bc12e0a8ca70aaa9b8334712ecad0500c7610a25741ec7" name="ad28f86ab02d89ade2f0bc12e0a8ca70aaa9b8334712ecad0500c7610a25741ec7"></a>RTE_TRAP_S_ACCESS&#160;</td><td class="fielddoc"><p>Store access fault </p> +</td></tr> +<tr><td class="fieldname"><a id="ad28f86ab02d89ade2f0bc12e0a8ca70aa155f84a52bace69f81a99de59701decc" name="ad28f86ab02d89ade2f0bc12e0a8ca70aa155f84a52bace69f81a99de59701decc"></a>RTE_TRAP_UENV_CALL&#160;</td><td class="fielddoc"><p>Environment call from user mode (ECALL instruction) </p> +</td></tr> +<tr><td class="fieldname"><a id="ad28f86ab02d89ade2f0bc12e0a8ca70aaea6027bf0354c3120fa61c8094dd7a1d" name="ad28f86ab02d89ade2f0bc12e0a8ca70aaea6027bf0354c3120fa61c8094dd7a1d"></a>RTE_TRAP_MENV_CALL&#160;</td><td class="fielddoc"><p>Environment call from machine mode (ECALL instruction) </p> +</td></tr> +<tr><td class="fieldname"><a id="ad28f86ab02d89ade2f0bc12e0a8ca70aadddffa9acdfcce80dd68ad4b26725174" name="ad28f86ab02d89ade2f0bc12e0a8ca70aadddffa9acdfcce80dd68ad4b26725174"></a>RTE_TRAP_MSI&#160;</td><td class="fielddoc"><p>Machine software interrupt </p> +</td></tr> +<tr><td class="fieldname"><a id="ad28f86ab02d89ade2f0bc12e0a8ca70aacf17d4b2454c43a1cb544e532d247fff" name="ad28f86ab02d89ade2f0bc12e0a8ca70aacf17d4b2454c43a1cb544e532d247fff"></a>RTE_TRAP_MTI&#160;</td><td class="fielddoc"><p>Machine timer interrupt </p> +</td></tr> +<tr><td class="fieldname"><a id="ad28f86ab02d89ade2f0bc12e0a8ca70aad2a55d5586d33497fd21b1da8aa98fff" name="ad28f86ab02d89ade2f0bc12e0a8ca70aad2a55d5586d33497fd21b1da8aa98fff"></a>RTE_TRAP_MEI&#160;</td><td class="fielddoc"><p>Machine external interrupt </p> +</td></tr> +<tr><td class="fieldname"><a id="ad28f86ab02d89ade2f0bc12e0a8ca70aab36a403cd7b833439ce7f9a708c33922" name="ad28f86ab02d89ade2f0bc12e0a8ca70aab36a403cd7b833439ce7f9a708c33922"></a>RTE_TRAP_FIRQ_0&#160;</td><td class="fielddoc"><p>Fast interrupt channel 0 </p> +</td></tr> +<tr><td class="fieldname"><a id="ad28f86ab02d89ade2f0bc12e0a8ca70aab199b53a1458017fa5278e0aeecf41fd" name="ad28f86ab02d89ade2f0bc12e0a8ca70aab199b53a1458017fa5278e0aeecf41fd"></a>RTE_TRAP_FIRQ_1&#160;</td><td class="fielddoc"><p>Fast interrupt channel 1 </p> +</td></tr> +<tr><td class="fieldname"><a id="ad28f86ab02d89ade2f0bc12e0a8ca70aa29ffa3108fadc78bf375773c3232c489" name="ad28f86ab02d89ade2f0bc12e0a8ca70aa29ffa3108fadc78bf375773c3232c489"></a>RTE_TRAP_FIRQ_2&#160;</td><td class="fielddoc"><p>Fast interrupt channel 2 </p> +</td></tr> +<tr><td class="fieldname"><a id="ad28f86ab02d89ade2f0bc12e0a8ca70aa4a74188fd87ea17a594ac6fe8ddf71be" name="ad28f86ab02d89ade2f0bc12e0a8ca70aa4a74188fd87ea17a594ac6fe8ddf71be"></a>RTE_TRAP_FIRQ_3&#160;</td><td class="fielddoc"><p>Fast interrupt channel 3 </p> +</td></tr> +<tr><td class="fieldname"><a id="ad28f86ab02d89ade2f0bc12e0a8ca70aa8b39868bf91da54f9ec492918e0c01ff" name="ad28f86ab02d89ade2f0bc12e0a8ca70aa8b39868bf91da54f9ec492918e0c01ff"></a>RTE_TRAP_FIRQ_4&#160;</td><td class="fielddoc"><p>Fast interrupt channel 4 </p> +</td></tr> +<tr><td class="fieldname"><a id="ad28f86ab02d89ade2f0bc12e0a8ca70aa01f562418ddbbb6b84be168673deeea9" name="ad28f86ab02d89ade2f0bc12e0a8ca70aa01f562418ddbbb6b84be168673deeea9"></a>RTE_TRAP_FIRQ_5&#160;</td><td class="fielddoc"><p>Fast interrupt channel 5 </p> +</td></tr> +<tr><td class="fieldname"><a id="ad28f86ab02d89ade2f0bc12e0a8ca70aac9fb28ea8bafff182f12c29d2fad6998" name="ad28f86ab02d89ade2f0bc12e0a8ca70aac9fb28ea8bafff182f12c29d2fad6998"></a>RTE_TRAP_FIRQ_6&#160;</td><td class="fielddoc"><p>Fast interrupt channel 6 </p> +</td></tr> +<tr><td class="fieldname"><a id="ad28f86ab02d89ade2f0bc12e0a8ca70aa73bb84f7b6c7528bec552ac1d3e9ccdb" name="ad28f86ab02d89ade2f0bc12e0a8ca70aa73bb84f7b6c7528bec552ac1d3e9ccdb"></a>RTE_TRAP_FIRQ_7&#160;</td><td class="fielddoc"><p>Fast interrupt channel 7 </p> +</td></tr> +<tr><td class="fieldname"><a id="ad28f86ab02d89ade2f0bc12e0a8ca70aa3edbf47bd9a278e100bb808c8bb68308" name="ad28f86ab02d89ade2f0bc12e0a8ca70aa3edbf47bd9a278e100bb808c8bb68308"></a>RTE_TRAP_FIRQ_8&#160;</td><td class="fielddoc"><p>Fast interrupt channel 8 </p> +</td></tr> +<tr><td class="fieldname"><a id="ad28f86ab02d89ade2f0bc12e0a8ca70aa2cd04189d91465dad2bc2a8852406b76" name="ad28f86ab02d89ade2f0bc12e0a8ca70aa2cd04189d91465dad2bc2a8852406b76"></a>RTE_TRAP_FIRQ_9&#160;</td><td class="fielddoc"><p>Fast interrupt channel 9 </p> +</td></tr> +<tr><td class="fieldname"><a id="ad28f86ab02d89ade2f0bc12e0a8ca70aadebcc4d91aea1364b1481111f1060c52" name="ad28f86ab02d89ade2f0bc12e0a8ca70aadebcc4d91aea1364b1481111f1060c52"></a>RTE_TRAP_FIRQ_10&#160;</td><td class="fielddoc"><p>Fast interrupt channel 10 </p> +</td></tr> +<tr><td class="fieldname"><a id="ad28f86ab02d89ade2f0bc12e0a8ca70aab49ff0110481f22da22a085d2633a0e0" name="ad28f86ab02d89ade2f0bc12e0a8ca70aab49ff0110481f22da22a085d2633a0e0"></a>RTE_TRAP_FIRQ_11&#160;</td><td class="fielddoc"><p>Fast interrupt channel 11 </p> +</td></tr> +<tr><td class="fieldname"><a id="ad28f86ab02d89ade2f0bc12e0a8ca70aaecea4f1d524a33d02324382357b2bcb9" name="ad28f86ab02d89ade2f0bc12e0a8ca70aaecea4f1d524a33d02324382357b2bcb9"></a>RTE_TRAP_FIRQ_12&#160;</td><td class="fielddoc"><p>Fast interrupt channel 12 </p> +</td></tr> +<tr><td class="fieldname"><a id="ad28f86ab02d89ade2f0bc12e0a8ca70aa609613cf25bb8f2d0e323089d6798220" name="ad28f86ab02d89ade2f0bc12e0a8ca70aa609613cf25bb8f2d0e323089d6798220"></a>RTE_TRAP_FIRQ_13&#160;</td><td class="fielddoc"><p>Fast interrupt channel 13 </p> +</td></tr> +<tr><td class="fieldname"><a id="ad28f86ab02d89ade2f0bc12e0a8ca70aaadd66d9b9c33a6869fa3c30e1e434313" name="ad28f86ab02d89ade2f0bc12e0a8ca70aaadd66d9b9c33a6869fa3c30e1e434313"></a>RTE_TRAP_FIRQ_14&#160;</td><td class="fielddoc"><p>Fast interrupt channel 14 </p> +</td></tr> +<tr><td class="fieldname"><a id="ad28f86ab02d89ade2f0bc12e0a8ca70aa1d18312227bfd5332ebcc1f74c979dbe" name="ad28f86ab02d89ade2f0bc12e0a8ca70aa1d18312227bfd5332ebcc1f74c979dbe"></a>RTE_TRAP_FIRQ_15&#160;</td><td class="fielddoc"><p>Fast interrupt channel 15 </p> +</td></tr> +</table> + +</div> +</div> +<h2 class="groupheader">Function Documentation</h2> +<a id="a65e71acc8916b42b59dc2cf6bba30ba3" name="a65e71acc8916b42b59dc2cf6bba30ba3"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a65e71acc8916b42b59dc2cf6bba30ba3">&#9670;&#160;</a></span>neorv32_rte_context_get()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_rte_context_get </td> + <td>(</td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>x</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>NEORV32 runtime environment (RTE): Read register from application context (on stack).</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">x</td><td>Register number (0..31, corresponds to register x0..x31). </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Content of register x. </dd></dl> + +</div> +</div> +<a id="ae13a9c1fd59ad71afb0d47cf9a0b303e" name="ae13a9c1fd59ad71afb0d47cf9a0b303e"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ae13a9c1fd59ad71afb0d47cf9a0b303e">&#9670;&#160;</a></span>neorv32_rte_context_put()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_rte_context_put </td> + <td>(</td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>x</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>data</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>NEORV32 runtime environment (RTE): Write register to application context (on stack).</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">x</td><td>Register number (0..31, corresponds to register x0..x31). </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">data</td><td>Data to be written to register x. </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="a65422bb44f1e7bc011e9bfc5d8451ebe" name="a65422bb44f1e7bc011e9bfc5d8451ebe"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a65422bb44f1e7bc011e9bfc5d8451ebe">&#9670;&#160;</a></span>neorv32_rte_debug_handler()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_rte_debug_handler </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>NEORV32 runtime environment (RTE): Debug trap handler, printing information via UART0. </p> + +</div> +</div> +<a id="a2cf31cfa569a03a20d554b6400c4c5e2" name="a2cf31cfa569a03a20d554b6400c4c5e2"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a2cf31cfa569a03a20d554b6400c4c5e2">&#9670;&#160;</a></span>neorv32_rte_handler_install()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_rte_handler_install </td> + <td>(</td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>id</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">void(*</td> <td class="paramname"><span class="paramname"><em>handler&#160;</em></span>)(void)&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>NEORV32 runtime environment (RTE): Install trap handler function (second-level trap handler).</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">id</td><td>Identifier (type) of the targeted trap. See <a class="el" href="#ad28f86ab02d89ade2f0bc12e0a8ca70a">NEORV32_RTE_TRAP_enum</a>. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">handler</td><td>The actual handler function for the specified trap (function MUST be of type "void function(void);"). </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>0 if success, -1 if error (invalid id or targeted trap not supported). </dd></dl> + +</div> +</div> +<a id="a10fde6229bf391e46148405616404a65" name="a10fde6229bf391e46148405616404a65"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a10fde6229bf391e46148405616404a65">&#9670;&#160;</a></span>neorv32_rte_handler_uninstall()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_rte_handler_uninstall </td> + <td>(</td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>id</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>NEORV32 runtime environment (RTE): Uninstall trap handler function from NEORV32 runtime environment, which was previously installed via neorv32_rte_handler_install(uint8_t id, void (*handler)(void)).</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">id</td><td>Identifier (type) of the targeted trap. See <a class="el" href="#ad28f86ab02d89ade2f0bc12e0a8ca70a">NEORV32_RTE_TRAP_enum</a>. </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>0 if success, -1 if error (invalid id or targeted trap not supported). </dd></dl> + +</div> +</div> +<a id="aa442c0e39f9156a131c3432fda587692" name="aa442c0e39f9156a131c3432fda587692"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aa442c0e39f9156a131c3432fda587692">&#9670;&#160;</a></span>neorv32_rte_print_about()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_rte_print_about </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>NEORV32 runtime environment (RTE): Print project info via UART0. </p> + +</div> +</div> +<a id="a05e8304963e402d228a76aff1868771c" name="a05e8304963e402d228a76aff1868771c"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a05e8304963e402d228a76aff1868771c">&#9670;&#160;</a></span>neorv32_rte_print_hw_config()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_rte_print_hw_config </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>NEORV32 runtime environment (RTE): Print hardware configuration information via UART0.</p> +<dl class="section warning"><dt>Warning</dt><dd>This function overrides several CSR, CNT and HPM CSRs! </dd></dl> + +</div> +</div> +<a id="aad6f5256a265807c4cde163bcba8dae9" name="aad6f5256a265807c4cde163bcba8dae9"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aad6f5256a265807c4cde163bcba8dae9">&#9670;&#160;</a></span>neorv32_rte_print_hw_version()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_rte_print_hw_version </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>NEORV32 runtime environment (RTE): Print the processor version in human-readable format via UART0. </p> + +</div> +</div> +<a id="acd96aa73eebe6d4bbc9aabe1230cbabc" name="acd96aa73eebe6d4bbc9aabe1230cbabc"></a> +<h2 class="memtitle"><span class="permalink"><a href="#acd96aa73eebe6d4bbc9aabe1230cbabc">&#9670;&#160;</a></span>neorv32_rte_print_license()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_rte_print_license </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>NEORV32 runtime environment (RTE): Print project license via UART0. </p> + +</div> +</div> +<a id="a16df1b48f2e1258a51d3bb7f49531cf3" name="a16df1b48f2e1258a51d3bb7f49531cf3"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a16df1b48f2e1258a51d3bb7f49531cf3">&#9670;&#160;</a></span>neorv32_rte_print_logo()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_rte_print_logo </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>NEORV32 runtime environment (RTE): Print project logo via UART0. </p> + +</div> +</div> +<a id="a343e1913bdc37db9b168fb4def0e6170" name="a343e1913bdc37db9b168fb4def0e6170"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a343e1913bdc37db9b168fb4def0e6170">&#9670;&#160;</a></span>neorv32_rte_setup()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_rte_setup </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>NEORV32 runtime environment (RTE): Setup RTE.</p> +<dl class="section note"><dt>Note</dt><dd>This function installs a debug handler for ALL trap sources, which gives detailed information about the trap. Actual handlers can be installed afterwards via neorv32_rte_handler_install(uint8_t id, void (*handler)(void)). </dd></dl> + +</div> +</div> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/neorv32__rte_8h_source.html b/sw/neorv32__rte_8h_source.html new file mode 100644 index 0000000000..89dfdcf0a8 --- /dev/null +++ b/sw/neorv32__rte_8h_source.html @@ -0,0 +1,212 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/lib/include/neorv32_rte.h Source File</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_7d04193005ada6f9450f847f4adb6b5b.html">lib</a></li><li class="navelem"><a class="el" href="dir_752b1e5d3973bf735fa78bf6b4727df9.html">include</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="headertitle"><div class="title">neorv32_rte.h</div></div> +</div><!--header--> +<div class="contents"> +<a href="neorv32__rte_8h.html">Go to the documentation of this file.</a><div class="fragment"><div class="line"><a id="l00001" name="l00001"></a><span class="lineno"> 1</span><span class="comment">// ================================================================================ //</span></div> +<div class="line"><a id="l00002" name="l00002"></a><span class="lineno"> 2</span><span class="comment">// The NEORV32 RISC-V Processor - https://github.com/stnolting/neorv32 //</span></div> +<div class="line"><a id="l00003" name="l00003"></a><span class="lineno"> 3</span><span class="comment">// Copyright (c) NEORV32 contributors. //</span></div> +<div class="line"><a id="l00004" name="l00004"></a><span class="lineno"> 4</span><span class="comment">// Copyright (c) 2020 - 2024 Stephan Nolting. All rights reserved. //</span></div> +<div class="line"><a id="l00005" name="l00005"></a><span class="lineno"> 5</span><span class="comment">// Licensed under the BSD-3-Clause license, see LICENSE for details. //</span></div> +<div class="line"><a id="l00006" name="l00006"></a><span class="lineno"> 6</span><span class="comment">// SPDX-License-Identifier: BSD-3-Clause //</span></div> +<div class="line"><a id="l00007" name="l00007"></a><span class="lineno"> 7</span><span class="comment">// ================================================================================ //</span></div> +<div class="line"><a id="l00008" name="l00008"></a><span class="lineno"> 8</span> </div> +<div class="line"><a id="l00016" name="l00016"></a><span class="lineno"> 16</span><span class="preprocessor">#ifndef neorv32_rte_h</span></div> +<div class="line"><a id="l00017" name="l00017"></a><span class="lineno"> 17</span><span class="preprocessor">#define neorv32_rte_h</span></div> +<div class="line"><a id="l00018" name="l00018"></a><span class="lineno"> 18</span> </div> +<div class="line"><a id="l00019" name="l00019"></a><span class="lineno"> 19</span><span class="preprocessor">#include &lt;stdint.h&gt;</span></div> +<div class="line"><a id="l00020" name="l00020"></a><span class="lineno"> 20</span> </div> +<div class="line"><a id="l00021" name="l00021"></a><span class="lineno"> 21</span> </div> +<div class="line"><a id="l00022" name="l00022"></a><span class="lineno"> 22</span><span class="comment">/**********************************************************************/</span></div> +<div class="line"><a id="l00025" name="l00025"></a><span class="lineno"><a class="line" href="neorv32__rte_8h.html#ad14a1ca41df1e9300bfd01aef07dce59"> 25</a></span><span class="preprocessor">#define NEORV32_RTE_NUM_TRAPS 29</span></div> +<div class="line"><a id="l00026" name="l00026"></a><span class="lineno"> 26</span> </div> +<div class="line"><a id="l00027" name="l00027"></a><span class="lineno"> 27</span> </div> +<div class="line"><a id="l00028" name="l00028"></a><span class="lineno"> 28</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen00031" data-start="{" data-end="};"> +<div class="line"><a id="l00031" name="l00031"></a><span class="lineno"><a class="line" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70a"> 31</a></span><span class="keyword">enum</span> <a class="code hl_enumeration" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70a">NEORV32_RTE_TRAP_enum</a> {</div> +<div class="line"><a id="l00032" name="l00032"></a><span class="lineno"><a class="line" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa931a4f314b04233924b01e8245153be4"> 32</a></span> <a class="code hl_enumvalue" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa931a4f314b04233924b01e8245153be4">RTE_TRAP_I_ACCESS</a> = 0, </div> +<div class="line"><a id="l00033" name="l00033"></a><span class="lineno"><a class="line" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa48f4d253b260784a1ffaaded508166e2"> 33</a></span> <a class="code hl_enumvalue" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa48f4d253b260784a1ffaaded508166e2">RTE_TRAP_I_ILLEGAL</a> = 1, </div> +<div class="line"><a id="l00034" name="l00034"></a><span class="lineno"><a class="line" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aaf647ff8d55d021379202879627c91d81"> 34</a></span> <a class="code hl_enumvalue" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aaf647ff8d55d021379202879627c91d81">RTE_TRAP_I_MISALIGNED</a> = 2, </div> +<div class="line"><a id="l00035" name="l00035"></a><span class="lineno"><a class="line" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa463611404367b5910c42dd31c0a218a2"> 35</a></span> <a class="code hl_enumvalue" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa463611404367b5910c42dd31c0a218a2">RTE_TRAP_BREAKPOINT</a> = 3, </div> +<div class="line"><a id="l00036" name="l00036"></a><span class="lineno"><a class="line" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa8e2cc9a533ebbc0e1d29c3ec8afbe61f"> 36</a></span> <a class="code hl_enumvalue" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa8e2cc9a533ebbc0e1d29c3ec8afbe61f">RTE_TRAP_L_MISALIGNED</a> = 4, </div> +<div class="line"><a id="l00037" name="l00037"></a><span class="lineno"><a class="line" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa97047b024b72807a0b312979c9359dab"> 37</a></span> <a class="code hl_enumvalue" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa97047b024b72807a0b312979c9359dab">RTE_TRAP_L_ACCESS</a> = 5, </div> +<div class="line"><a id="l00038" name="l00038"></a><span class="lineno"><a class="line" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa85934b3fd8b5268340f84810b3f67232"> 38</a></span> <a class="code hl_enumvalue" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa85934b3fd8b5268340f84810b3f67232">RTE_TRAP_S_MISALIGNED</a> = 6, </div> +<div class="line"><a id="l00039" name="l00039"></a><span class="lineno"><a class="line" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aaa9b8334712ecad0500c7610a25741ec7"> 39</a></span> <a class="code hl_enumvalue" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aaa9b8334712ecad0500c7610a25741ec7">RTE_TRAP_S_ACCESS</a> = 7, </div> +<div class="line"><a id="l00040" name="l00040"></a><span class="lineno"><a class="line" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa155f84a52bace69f81a99de59701decc"> 40</a></span> <a class="code hl_enumvalue" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa155f84a52bace69f81a99de59701decc">RTE_TRAP_UENV_CALL</a> = 8, </div> +<div class="line"><a id="l00041" name="l00041"></a><span class="lineno"><a class="line" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aaea6027bf0354c3120fa61c8094dd7a1d"> 41</a></span> <a class="code hl_enumvalue" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aaea6027bf0354c3120fa61c8094dd7a1d">RTE_TRAP_MENV_CALL</a> = 9, </div> +<div class="line"><a id="l00042" name="l00042"></a><span class="lineno"><a class="line" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aadddffa9acdfcce80dd68ad4b26725174"> 42</a></span> <a class="code hl_enumvalue" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aadddffa9acdfcce80dd68ad4b26725174">RTE_TRAP_MSI</a> = 10, </div> +<div class="line"><a id="l00043" name="l00043"></a><span class="lineno"><a class="line" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aacf17d4b2454c43a1cb544e532d247fff"> 43</a></span> <a class="code hl_enumvalue" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aacf17d4b2454c43a1cb544e532d247fff">RTE_TRAP_MTI</a> = 11, </div> +<div class="line"><a id="l00044" name="l00044"></a><span class="lineno"><a class="line" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aad2a55d5586d33497fd21b1da8aa98fff"> 44</a></span> <a class="code hl_enumvalue" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aad2a55d5586d33497fd21b1da8aa98fff">RTE_TRAP_MEI</a> = 12, </div> +<div class="line"><a id="l00045" name="l00045"></a><span class="lineno"><a class="line" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aab36a403cd7b833439ce7f9a708c33922"> 45</a></span> <a class="code hl_enumvalue" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aab36a403cd7b833439ce7f9a708c33922">RTE_TRAP_FIRQ_0</a> = 13, </div> +<div class="line"><a id="l00046" name="l00046"></a><span class="lineno"><a class="line" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aab199b53a1458017fa5278e0aeecf41fd"> 46</a></span> <a class="code hl_enumvalue" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aab199b53a1458017fa5278e0aeecf41fd">RTE_TRAP_FIRQ_1</a> = 14, </div> +<div class="line"><a id="l00047" name="l00047"></a><span class="lineno"><a class="line" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa29ffa3108fadc78bf375773c3232c489"> 47</a></span> <a class="code hl_enumvalue" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa29ffa3108fadc78bf375773c3232c489">RTE_TRAP_FIRQ_2</a> = 15, </div> +<div class="line"><a id="l00048" name="l00048"></a><span class="lineno"><a class="line" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa4a74188fd87ea17a594ac6fe8ddf71be"> 48</a></span> <a class="code hl_enumvalue" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa4a74188fd87ea17a594ac6fe8ddf71be">RTE_TRAP_FIRQ_3</a> = 16, </div> +<div class="line"><a id="l00049" name="l00049"></a><span class="lineno"><a class="line" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa8b39868bf91da54f9ec492918e0c01ff"> 49</a></span> <a class="code hl_enumvalue" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa8b39868bf91da54f9ec492918e0c01ff">RTE_TRAP_FIRQ_4</a> = 17, </div> +<div class="line"><a id="l00050" name="l00050"></a><span class="lineno"><a class="line" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa01f562418ddbbb6b84be168673deeea9"> 50</a></span> <a class="code hl_enumvalue" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa01f562418ddbbb6b84be168673deeea9">RTE_TRAP_FIRQ_5</a> = 18, </div> +<div class="line"><a id="l00051" name="l00051"></a><span class="lineno"><a class="line" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aac9fb28ea8bafff182f12c29d2fad6998"> 51</a></span> <a class="code hl_enumvalue" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aac9fb28ea8bafff182f12c29d2fad6998">RTE_TRAP_FIRQ_6</a> = 19, </div> +<div class="line"><a id="l00052" name="l00052"></a><span class="lineno"><a class="line" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa73bb84f7b6c7528bec552ac1d3e9ccdb"> 52</a></span> <a class="code hl_enumvalue" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa73bb84f7b6c7528bec552ac1d3e9ccdb">RTE_TRAP_FIRQ_7</a> = 20, </div> +<div class="line"><a id="l00053" name="l00053"></a><span class="lineno"><a class="line" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa3edbf47bd9a278e100bb808c8bb68308"> 53</a></span> <a class="code hl_enumvalue" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa3edbf47bd9a278e100bb808c8bb68308">RTE_TRAP_FIRQ_8</a> = 21, </div> +<div class="line"><a id="l00054" name="l00054"></a><span class="lineno"><a class="line" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa2cd04189d91465dad2bc2a8852406b76"> 54</a></span> <a class="code hl_enumvalue" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa2cd04189d91465dad2bc2a8852406b76">RTE_TRAP_FIRQ_9</a> = 22, </div> +<div class="line"><a id="l00055" name="l00055"></a><span class="lineno"><a class="line" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aadebcc4d91aea1364b1481111f1060c52"> 55</a></span> <a class="code hl_enumvalue" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aadebcc4d91aea1364b1481111f1060c52">RTE_TRAP_FIRQ_10</a> = 23, </div> +<div class="line"><a id="l00056" name="l00056"></a><span class="lineno"><a class="line" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aab49ff0110481f22da22a085d2633a0e0"> 56</a></span> <a class="code hl_enumvalue" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aab49ff0110481f22da22a085d2633a0e0">RTE_TRAP_FIRQ_11</a> = 24, </div> +<div class="line"><a id="l00057" name="l00057"></a><span class="lineno"><a class="line" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aaecea4f1d524a33d02324382357b2bcb9"> 57</a></span> <a class="code hl_enumvalue" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aaecea4f1d524a33d02324382357b2bcb9">RTE_TRAP_FIRQ_12</a> = 25, </div> +<div class="line"><a id="l00058" name="l00058"></a><span class="lineno"><a class="line" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa609613cf25bb8f2d0e323089d6798220"> 58</a></span> <a class="code hl_enumvalue" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa609613cf25bb8f2d0e323089d6798220">RTE_TRAP_FIRQ_13</a> = 26, </div> +<div class="line"><a id="l00059" name="l00059"></a><span class="lineno"><a class="line" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aaadd66d9b9c33a6869fa3c30e1e434313"> 59</a></span> <a class="code hl_enumvalue" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aaadd66d9b9c33a6869fa3c30e1e434313">RTE_TRAP_FIRQ_14</a> = 27, </div> +<div class="line"><a id="l00060" name="l00060"></a><span class="lineno"> 60</span> <a class="code hl_enumvalue" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa1d18312227bfd5332ebcc1f74c979dbe">RTE_TRAP_FIRQ_15</a> = 28 </div> +<div class="line"><a id="l00061" name="l00061"></a><span class="lineno"><a class="line" href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa1d18312227bfd5332ebcc1f74c979dbe"> 61</a></span>};</div> +</div> +<div class="line"><a id="l00062" name="l00062"></a><span class="lineno"> 62</span> </div> +<div class="line"><a id="l00063" name="l00063"></a><span class="lineno"> 63</span> </div> +<div class="line"><a id="l00064" name="l00064"></a><span class="lineno"> 64</span><span class="comment">/**********************************************************************/</span></div> +<div class="line"><a id="l00068" name="l00068"></a><span class="lineno"> 68</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__rte_8h.html#a343e1913bdc37db9b168fb4def0e6170">neorv32_rte_setup</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00069" name="l00069"></a><span class="lineno"> 69</span><span class="keywordtype">int</span> <a class="code hl_function" href="neorv32__rte_8h.html#a2cf31cfa569a03a20d554b6400c4c5e2">neorv32_rte_handler_install</a>(<span class="keywordtype">int</span> <span class="keywordtype">id</span>, <span class="keywordtype">void</span> (*handler)(<span class="keywordtype">void</span>));</div> +<div class="line"><a id="l00070" name="l00070"></a><span class="lineno"> 70</span><span class="keywordtype">int</span> <a class="code hl_function" href="neorv32__rte_8h.html#a10fde6229bf391e46148405616404a65">neorv32_rte_handler_uninstall</a>(<span class="keywordtype">int</span> <span class="keywordtype">id</span>);</div> +<div class="line"><a id="l00071" name="l00071"></a><span class="lineno"> 71</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__rte_8h.html#a65422bb44f1e7bc011e9bfc5d8451ebe">neorv32_rte_debug_handler</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00072" name="l00072"></a><span class="lineno"> 72</span>uint32_t <a class="code hl_function" href="neorv32__rte_8h.html#a65e71acc8916b42b59dc2cf6bba30ba3">neorv32_rte_context_get</a>(<span class="keywordtype">int</span> x);</div> +<div class="line"><a id="l00073" name="l00073"></a><span class="lineno"> 73</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__rte_8h.html#ae13a9c1fd59ad71afb0d47cf9a0b303e">neorv32_rte_context_put</a>(<span class="keywordtype">int</span> x, uint32_t data);</div> +<div class="line"><a id="l00074" name="l00074"></a><span class="lineno"> 74</span> </div> +<div class="line"><a id="l00075" name="l00075"></a><span class="lineno"> 75</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__rte_8h.html#a05e8304963e402d228a76aff1868771c">neorv32_rte_print_hw_config</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00076" name="l00076"></a><span class="lineno"> 76</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__rte_8h.html#aad6f5256a265807c4cde163bcba8dae9">neorv32_rte_print_hw_version</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00077" name="l00077"></a><span class="lineno"> 77</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__rte_8h.html#aa442c0e39f9156a131c3432fda587692">neorv32_rte_print_about</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00078" name="l00078"></a><span class="lineno"> 78</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__rte_8h.html#a16df1b48f2e1258a51d3bb7f49531cf3">neorv32_rte_print_logo</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00079" name="l00079"></a><span class="lineno"> 79</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__rte_8h.html#acd96aa73eebe6d4bbc9aabe1230cbabc">neorv32_rte_print_license</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00083" name="l00083"></a><span class="lineno"> 83</span><span class="preprocessor">#endif </span><span class="comment">// neorv32_rte_h</span></div> +<div class="ttc" id="aneorv32__rte_8h_html_a05e8304963e402d228a76aff1868771c"><div class="ttname"><a href="neorv32__rte_8h.html#a05e8304963e402d228a76aff1868771c">neorv32_rte_print_hw_config</a></div><div class="ttdeci">void neorv32_rte_print_hw_config(void)</div><div class="ttdef"><b>Definition</b> neorv32_rte.c:387</div></div> +<div class="ttc" id="aneorv32__rte_8h_html_a10fde6229bf391e46148405616404a65"><div class="ttname"><a href="neorv32__rte_8h.html#a10fde6229bf391e46148405616404a65">neorv32_rte_handler_uninstall</a></div><div class="ttdeci">int neorv32_rte_handler_uninstall(int id)</div><div class="ttdef"><b>Definition</b> neorv32_rte.c:85</div></div> +<div class="ttc" id="aneorv32__rte_8h_html_a16df1b48f2e1258a51d3bb7f49531cf3"><div class="ttname"><a href="neorv32__rte_8h.html#a16df1b48f2e1258a51d3bb7f49531cf3">neorv32_rte_print_logo</a></div><div class="ttdeci">void neorv32_rte_print_logo(void)</div><div class="ttdef"><b>Definition</b> neorv32_rte.c:711</div></div> +<div class="ttc" id="aneorv32__rte_8h_html_a2cf31cfa569a03a20d554b6400c4c5e2"><div class="ttname"><a href="neorv32__rte_8h.html#a2cf31cfa569a03a20d554b6400c4c5e2">neorv32_rte_handler_install</a></div><div class="ttdeci">int neorv32_rte_handler_install(int id, void(*handler)(void))</div><div class="ttdef"><b>Definition</b> neorv32_rte.c:65</div></div> +<div class="ttc" id="aneorv32__rte_8h_html_a343e1913bdc37db9b168fb4def0e6170"><div class="ttname"><a href="neorv32__rte_8h.html#a343e1913bdc37db9b168fb4def0e6170">neorv32_rte_setup</a></div><div class="ttdeci">void neorv32_rte_setup(void)</div><div class="ttdef"><b>Definition</b> neorv32_rte.c:38</div></div> +<div class="ttc" id="aneorv32__rte_8h_html_a65422bb44f1e7bc011e9bfc5d8451ebe"><div class="ttname"><a href="neorv32__rte_8h.html#a65422bb44f1e7bc011e9bfc5d8451ebe">neorv32_rte_debug_handler</a></div><div class="ttdeci">void neorv32_rte_debug_handler(void)</div><div class="ttdef"><b>Definition</b> neorv32_rte.c:297</div></div> +<div class="ttc" id="aneorv32__rte_8h_html_a65e71acc8916b42b59dc2cf6bba30ba3"><div class="ttname"><a href="neorv32__rte_8h.html#a65e71acc8916b42b59dc2cf6bba30ba3">neorv32_rte_context_get</a></div><div class="ttdeci">uint32_t neorv32_rte_context_get(int x)</div><div class="ttdef"><b>Definition</b> neorv32_rte.c:260</div></div> +<div class="ttc" id="aneorv32__rte_8h_html_aa442c0e39f9156a131c3432fda587692"><div class="ttname"><a href="neorv32__rte_8h.html#aa442c0e39f9156a131c3432fda587692">neorv32_rte_print_about</a></div><div class="ttdeci">void neorv32_rte_print_about(void)</div><div class="ttdef"><b>Definition</b> neorv32_rte.c:696</div></div> +<div class="ttc" id="aneorv32__rte_8h_html_aad6f5256a265807c4cde163bcba8dae9"><div class="ttname"><a href="neorv32__rte_8h.html#aad6f5256a265807c4cde163bcba8dae9">neorv32_rte_print_hw_version</a></div><div class="ttdeci">void neorv32_rte_print_hw_version(void)</div><div class="ttdef"><b>Definition</b> neorv32_rte.c:663</div></div> +<div class="ttc" id="aneorv32__rte_8h_html_acd96aa73eebe6d4bbc9aabe1230cbabc"><div class="ttname"><a href="neorv32__rte_8h.html#acd96aa73eebe6d4bbc9aabe1230cbabc">neorv32_rte_print_license</a></div><div class="ttdeci">void neorv32_rte_print_license(void)</div><div class="ttdef"><b>Definition</b> neorv32_rte.c:753</div></div> +<div class="ttc" id="aneorv32__rte_8h_html_ad28f86ab02d89ade2f0bc12e0a8ca70a"><div class="ttname"><a href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70a">NEORV32_RTE_TRAP_enum</a></div><div class="ttdeci">NEORV32_RTE_TRAP_enum</div><div class="ttdef"><b>Definition</b> neorv32_rte.h:31</div></div> +<div class="ttc" id="aneorv32__rte_8h_html_ad28f86ab02d89ade2f0bc12e0a8ca70aa01f562418ddbbb6b84be168673deeea9"><div class="ttname"><a href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa01f562418ddbbb6b84be168673deeea9">RTE_TRAP_FIRQ_5</a></div><div class="ttdeci">@ RTE_TRAP_FIRQ_5</div><div class="ttdef"><b>Definition</b> neorv32_rte.h:50</div></div> +<div class="ttc" id="aneorv32__rte_8h_html_ad28f86ab02d89ade2f0bc12e0a8ca70aa155f84a52bace69f81a99de59701decc"><div class="ttname"><a href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa155f84a52bace69f81a99de59701decc">RTE_TRAP_UENV_CALL</a></div><div class="ttdeci">@ RTE_TRAP_UENV_CALL</div><div class="ttdef"><b>Definition</b> neorv32_rte.h:40</div></div> +<div class="ttc" id="aneorv32__rte_8h_html_ad28f86ab02d89ade2f0bc12e0a8ca70aa1d18312227bfd5332ebcc1f74c979dbe"><div class="ttname"><a href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa1d18312227bfd5332ebcc1f74c979dbe">RTE_TRAP_FIRQ_15</a></div><div class="ttdeci">@ RTE_TRAP_FIRQ_15</div><div class="ttdef"><b>Definition</b> neorv32_rte.h:60</div></div> +<div class="ttc" id="aneorv32__rte_8h_html_ad28f86ab02d89ade2f0bc12e0a8ca70aa29ffa3108fadc78bf375773c3232c489"><div class="ttname"><a href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa29ffa3108fadc78bf375773c3232c489">RTE_TRAP_FIRQ_2</a></div><div class="ttdeci">@ RTE_TRAP_FIRQ_2</div><div class="ttdef"><b>Definition</b> neorv32_rte.h:47</div></div> +<div class="ttc" id="aneorv32__rte_8h_html_ad28f86ab02d89ade2f0bc12e0a8ca70aa2cd04189d91465dad2bc2a8852406b76"><div class="ttname"><a href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa2cd04189d91465dad2bc2a8852406b76">RTE_TRAP_FIRQ_9</a></div><div class="ttdeci">@ RTE_TRAP_FIRQ_9</div><div class="ttdef"><b>Definition</b> neorv32_rte.h:54</div></div> +<div class="ttc" id="aneorv32__rte_8h_html_ad28f86ab02d89ade2f0bc12e0a8ca70aa3edbf47bd9a278e100bb808c8bb68308"><div class="ttname"><a href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa3edbf47bd9a278e100bb808c8bb68308">RTE_TRAP_FIRQ_8</a></div><div class="ttdeci">@ RTE_TRAP_FIRQ_8</div><div class="ttdef"><b>Definition</b> neorv32_rte.h:53</div></div> +<div class="ttc" id="aneorv32__rte_8h_html_ad28f86ab02d89ade2f0bc12e0a8ca70aa463611404367b5910c42dd31c0a218a2"><div class="ttname"><a href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa463611404367b5910c42dd31c0a218a2">RTE_TRAP_BREAKPOINT</a></div><div class="ttdeci">@ RTE_TRAP_BREAKPOINT</div><div class="ttdef"><b>Definition</b> neorv32_rte.h:35</div></div> +<div class="ttc" id="aneorv32__rte_8h_html_ad28f86ab02d89ade2f0bc12e0a8ca70aa48f4d253b260784a1ffaaded508166e2"><div class="ttname"><a href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa48f4d253b260784a1ffaaded508166e2">RTE_TRAP_I_ILLEGAL</a></div><div class="ttdeci">@ RTE_TRAP_I_ILLEGAL</div><div class="ttdef"><b>Definition</b> neorv32_rte.h:33</div></div> +<div class="ttc" id="aneorv32__rte_8h_html_ad28f86ab02d89ade2f0bc12e0a8ca70aa4a74188fd87ea17a594ac6fe8ddf71be"><div class="ttname"><a href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa4a74188fd87ea17a594ac6fe8ddf71be">RTE_TRAP_FIRQ_3</a></div><div class="ttdeci">@ RTE_TRAP_FIRQ_3</div><div class="ttdef"><b>Definition</b> neorv32_rte.h:48</div></div> +<div class="ttc" id="aneorv32__rte_8h_html_ad28f86ab02d89ade2f0bc12e0a8ca70aa609613cf25bb8f2d0e323089d6798220"><div class="ttname"><a href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa609613cf25bb8f2d0e323089d6798220">RTE_TRAP_FIRQ_13</a></div><div class="ttdeci">@ RTE_TRAP_FIRQ_13</div><div class="ttdef"><b>Definition</b> neorv32_rte.h:58</div></div> +<div class="ttc" id="aneorv32__rte_8h_html_ad28f86ab02d89ade2f0bc12e0a8ca70aa73bb84f7b6c7528bec552ac1d3e9ccdb"><div class="ttname"><a href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa73bb84f7b6c7528bec552ac1d3e9ccdb">RTE_TRAP_FIRQ_7</a></div><div class="ttdeci">@ RTE_TRAP_FIRQ_7</div><div class="ttdef"><b>Definition</b> neorv32_rte.h:52</div></div> +<div class="ttc" id="aneorv32__rte_8h_html_ad28f86ab02d89ade2f0bc12e0a8ca70aa85934b3fd8b5268340f84810b3f67232"><div class="ttname"><a href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa85934b3fd8b5268340f84810b3f67232">RTE_TRAP_S_MISALIGNED</a></div><div class="ttdeci">@ RTE_TRAP_S_MISALIGNED</div><div class="ttdef"><b>Definition</b> neorv32_rte.h:38</div></div> +<div class="ttc" id="aneorv32__rte_8h_html_ad28f86ab02d89ade2f0bc12e0a8ca70aa8b39868bf91da54f9ec492918e0c01ff"><div class="ttname"><a href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa8b39868bf91da54f9ec492918e0c01ff">RTE_TRAP_FIRQ_4</a></div><div class="ttdeci">@ RTE_TRAP_FIRQ_4</div><div class="ttdef"><b>Definition</b> neorv32_rte.h:49</div></div> +<div class="ttc" id="aneorv32__rte_8h_html_ad28f86ab02d89ade2f0bc12e0a8ca70aa8e2cc9a533ebbc0e1d29c3ec8afbe61f"><div class="ttname"><a href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa8e2cc9a533ebbc0e1d29c3ec8afbe61f">RTE_TRAP_L_MISALIGNED</a></div><div class="ttdeci">@ RTE_TRAP_L_MISALIGNED</div><div class="ttdef"><b>Definition</b> neorv32_rte.h:36</div></div> +<div class="ttc" id="aneorv32__rte_8h_html_ad28f86ab02d89ade2f0bc12e0a8ca70aa931a4f314b04233924b01e8245153be4"><div class="ttname"><a href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa931a4f314b04233924b01e8245153be4">RTE_TRAP_I_ACCESS</a></div><div class="ttdeci">@ RTE_TRAP_I_ACCESS</div><div class="ttdef"><b>Definition</b> neorv32_rte.h:32</div></div> +<div class="ttc" id="aneorv32__rte_8h_html_ad28f86ab02d89ade2f0bc12e0a8ca70aa97047b024b72807a0b312979c9359dab"><div class="ttname"><a href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa97047b024b72807a0b312979c9359dab">RTE_TRAP_L_ACCESS</a></div><div class="ttdeci">@ RTE_TRAP_L_ACCESS</div><div class="ttdef"><b>Definition</b> neorv32_rte.h:37</div></div> +<div class="ttc" id="aneorv32__rte_8h_html_ad28f86ab02d89ade2f0bc12e0a8ca70aaa9b8334712ecad0500c7610a25741ec7"><div class="ttname"><a href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aaa9b8334712ecad0500c7610a25741ec7">RTE_TRAP_S_ACCESS</a></div><div class="ttdeci">@ RTE_TRAP_S_ACCESS</div><div class="ttdef"><b>Definition</b> neorv32_rte.h:39</div></div> +<div class="ttc" id="aneorv32__rte_8h_html_ad28f86ab02d89ade2f0bc12e0a8ca70aaadd66d9b9c33a6869fa3c30e1e434313"><div class="ttname"><a href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aaadd66d9b9c33a6869fa3c30e1e434313">RTE_TRAP_FIRQ_14</a></div><div class="ttdeci">@ RTE_TRAP_FIRQ_14</div><div class="ttdef"><b>Definition</b> neorv32_rte.h:59</div></div> +<div class="ttc" id="aneorv32__rte_8h_html_ad28f86ab02d89ade2f0bc12e0a8ca70aab199b53a1458017fa5278e0aeecf41fd"><div class="ttname"><a href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aab199b53a1458017fa5278e0aeecf41fd">RTE_TRAP_FIRQ_1</a></div><div class="ttdeci">@ RTE_TRAP_FIRQ_1</div><div class="ttdef"><b>Definition</b> neorv32_rte.h:46</div></div> +<div class="ttc" id="aneorv32__rte_8h_html_ad28f86ab02d89ade2f0bc12e0a8ca70aab36a403cd7b833439ce7f9a708c33922"><div class="ttname"><a href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aab36a403cd7b833439ce7f9a708c33922">RTE_TRAP_FIRQ_0</a></div><div class="ttdeci">@ RTE_TRAP_FIRQ_0</div><div class="ttdef"><b>Definition</b> neorv32_rte.h:45</div></div> +<div class="ttc" id="aneorv32__rte_8h_html_ad28f86ab02d89ade2f0bc12e0a8ca70aab49ff0110481f22da22a085d2633a0e0"><div class="ttname"><a href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aab49ff0110481f22da22a085d2633a0e0">RTE_TRAP_FIRQ_11</a></div><div class="ttdeci">@ RTE_TRAP_FIRQ_11</div><div class="ttdef"><b>Definition</b> neorv32_rte.h:56</div></div> +<div class="ttc" id="aneorv32__rte_8h_html_ad28f86ab02d89ade2f0bc12e0a8ca70aac9fb28ea8bafff182f12c29d2fad6998"><div class="ttname"><a href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aac9fb28ea8bafff182f12c29d2fad6998">RTE_TRAP_FIRQ_6</a></div><div class="ttdeci">@ RTE_TRAP_FIRQ_6</div><div class="ttdef"><b>Definition</b> neorv32_rte.h:51</div></div> +<div class="ttc" id="aneorv32__rte_8h_html_ad28f86ab02d89ade2f0bc12e0a8ca70aacf17d4b2454c43a1cb544e532d247fff"><div class="ttname"><a href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aacf17d4b2454c43a1cb544e532d247fff">RTE_TRAP_MTI</a></div><div class="ttdeci">@ RTE_TRAP_MTI</div><div class="ttdef"><b>Definition</b> neorv32_rte.h:43</div></div> +<div class="ttc" id="aneorv32__rte_8h_html_ad28f86ab02d89ade2f0bc12e0a8ca70aad2a55d5586d33497fd21b1da8aa98fff"><div class="ttname"><a href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aad2a55d5586d33497fd21b1da8aa98fff">RTE_TRAP_MEI</a></div><div class="ttdeci">@ RTE_TRAP_MEI</div><div class="ttdef"><b>Definition</b> neorv32_rte.h:44</div></div> +<div class="ttc" id="aneorv32__rte_8h_html_ad28f86ab02d89ade2f0bc12e0a8ca70aadddffa9acdfcce80dd68ad4b26725174"><div class="ttname"><a href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aadddffa9acdfcce80dd68ad4b26725174">RTE_TRAP_MSI</a></div><div class="ttdeci">@ RTE_TRAP_MSI</div><div class="ttdef"><b>Definition</b> neorv32_rte.h:42</div></div> +<div class="ttc" id="aneorv32__rte_8h_html_ad28f86ab02d89ade2f0bc12e0a8ca70aadebcc4d91aea1364b1481111f1060c52"><div class="ttname"><a href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aadebcc4d91aea1364b1481111f1060c52">RTE_TRAP_FIRQ_10</a></div><div class="ttdeci">@ RTE_TRAP_FIRQ_10</div><div class="ttdef"><b>Definition</b> neorv32_rte.h:55</div></div> +<div class="ttc" id="aneorv32__rte_8h_html_ad28f86ab02d89ade2f0bc12e0a8ca70aaea6027bf0354c3120fa61c8094dd7a1d"><div class="ttname"><a href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aaea6027bf0354c3120fa61c8094dd7a1d">RTE_TRAP_MENV_CALL</a></div><div class="ttdeci">@ RTE_TRAP_MENV_CALL</div><div class="ttdef"><b>Definition</b> neorv32_rte.h:41</div></div> +<div class="ttc" id="aneorv32__rte_8h_html_ad28f86ab02d89ade2f0bc12e0a8ca70aaecea4f1d524a33d02324382357b2bcb9"><div class="ttname"><a href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aaecea4f1d524a33d02324382357b2bcb9">RTE_TRAP_FIRQ_12</a></div><div class="ttdeci">@ RTE_TRAP_FIRQ_12</div><div class="ttdef"><b>Definition</b> neorv32_rte.h:57</div></div> +<div class="ttc" id="aneorv32__rte_8h_html_ad28f86ab02d89ade2f0bc12e0a8ca70aaf647ff8d55d021379202879627c91d81"><div class="ttname"><a href="neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aaf647ff8d55d021379202879627c91d81">RTE_TRAP_I_MISALIGNED</a></div><div class="ttdeci">@ RTE_TRAP_I_MISALIGNED</div><div class="ttdef"><b>Definition</b> neorv32_rte.h:34</div></div> +<div class="ttc" id="aneorv32__rte_8h_html_ae13a9c1fd59ad71afb0d47cf9a0b303e"><div class="ttname"><a href="neorv32__rte_8h.html#ae13a9c1fd59ad71afb0d47cf9a0b303e">neorv32_rte_context_put</a></div><div class="ttdeci">void neorv32_rte_context_put(int x, uint32_t data)</div><div class="ttdef"><b>Definition</b> neorv32_rte.c:280</div></div> +</div><!-- fragment --></div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/neorv32__sdi_8c.html b/sw/neorv32__sdi_8c.html new file mode 100644 index 0000000000..a761fda9fd --- /dev/null +++ b/sw/neorv32__sdi_8c.html @@ -0,0 +1,301 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/lib/source/neorv32_sdi.c File Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_7d04193005ada6f9450f847f4adb6b5b.html">lib</a></li><li class="navelem"><a class="el" href="dir_0c6ac14e2254a316d41123f98feeb67b.html">source</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#func-members">Functions</a> </div> + <div class="headertitle"><div class="title">neorv32_sdi.c File Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p>Serial data interface controller (SDI) HW driver source file. +<a href="#details">More...</a></p> +<div class="textblock"><code>#include &quot;<a class="el" href="neorv32_8h_source.html">neorv32.h</a>&quot;</code><br /> +</div><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="func-members" name="func-members"></a> +Functions</h2></td></tr> +<tr class="memitem:a51412722efdb18cd09667622b215e825" id="r_a51412722efdb18cd09667622b215e825"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a51412722efdb18cd09667622b215e825">neorv32_sdi_available</a> (void)</td></tr> +<tr class="separator:a51412722efdb18cd09667622b215e825"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a3246118dc0d7e1f61bc2485bbab44149" id="r_a3246118dc0d7e1f61bc2485bbab44149"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a3246118dc0d7e1f61bc2485bbab44149">neorv32_sdi_setup</a> (uint32_t irq_mask)</td></tr> +<tr class="separator:a3246118dc0d7e1f61bc2485bbab44149"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a8bd54bca8aea6147651c8115ee616f54" id="r_a8bd54bca8aea6147651c8115ee616f54"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a8bd54bca8aea6147651c8115ee616f54">neorv32_sdi_disable</a> (void)</td></tr> +<tr class="separator:a8bd54bca8aea6147651c8115ee616f54"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a5d68b9b1642baf3519076e55a22a8f61" id="r_a5d68b9b1642baf3519076e55a22a8f61"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a5d68b9b1642baf3519076e55a22a8f61">neorv32_sdi_enable</a> (void)</td></tr> +<tr class="separator:a5d68b9b1642baf3519076e55a22a8f61"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a7390faeb01b4de3dd5ac18335736b90c" id="r_a7390faeb01b4de3dd5ac18335736b90c"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a7390faeb01b4de3dd5ac18335736b90c">neorv32_sdi_get_fifo_depth</a> (void)</td></tr> +<tr class="separator:a7390faeb01b4de3dd5ac18335736b90c"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ac7a262d16c42bbac27723ff779545569" id="r_ac7a262d16c42bbac27723ff779545569"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ac7a262d16c42bbac27723ff779545569">neorv32_sdi_put</a> (uint8_t data)</td></tr> +<tr class="separator:ac7a262d16c42bbac27723ff779545569"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a4d54ce22ec97eb83da118439576e3277" id="r_a4d54ce22ec97eb83da118439576e3277"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a4d54ce22ec97eb83da118439576e3277">neorv32_sdi_get</a> (uint8_t *data)</td></tr> +<tr class="separator:a4d54ce22ec97eb83da118439576e3277"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a2636cf1959ce1f3eb4b77c00ca2e2707" id="r_a2636cf1959ce1f3eb4b77c00ca2e2707"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a2636cf1959ce1f3eb4b77c00ca2e2707">neorv32_sdi_check_cs</a> (void)</td></tr> +<tr class="separator:a2636cf1959ce1f3eb4b77c00ca2e2707"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>Serial data interface controller (SDI) HW driver source file. </p> +<dl class="section note"><dt>Note</dt><dd>These functions should only be used if the SDI unit was synthesized (IO_SDI_EN = true).</dd></dl> +<dl class="section see"><dt>See also</dt><dd><a href="https://stnolting.github.io/neorv32/sw/files.html">https://stnolting.github.io/neorv32/sw/files.html</a> </dd></dl> +</div><h2 class="groupheader">Function Documentation</h2> +<a id="a51412722efdb18cd09667622b215e825" name="a51412722efdb18cd09667622b215e825"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a51412722efdb18cd09667622b215e825">&#9670;&#160;</a></span>neorv32_sdi_available()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_sdi_available </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Check if SDI unit was synthesized.</p> +<dl class="section return"><dt>Returns</dt><dd>0 if SDI was not synthesized, 1 if SPI is available. </dd></dl> + +</div> +</div> +<a id="a2636cf1959ce1f3eb4b77c00ca2e2707" name="a2636cf1959ce1f3eb4b77c00ca2e2707"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a2636cf1959ce1f3eb4b77c00ca2e2707">&#9670;&#160;</a></span>neorv32_sdi_check_cs()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_sdi_check_cs </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Get status of chip-select line.</p> +<dl class="section return"><dt>Returns</dt><dd>1 if chip-select line is enabled/active (driven low), 0 otherwise. </dd></dl> + +</div> +</div> +<a id="a8bd54bca8aea6147651c8115ee616f54" name="a8bd54bca8aea6147651c8115ee616f54"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a8bd54bca8aea6147651c8115ee616f54">&#9670;&#160;</a></span>neorv32_sdi_disable()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_sdi_disable </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Disable SDI controller. </p> + +</div> +</div> +<a id="a5d68b9b1642baf3519076e55a22a8f61" name="a5d68b9b1642baf3519076e55a22a8f61"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a5d68b9b1642baf3519076e55a22a8f61">&#9670;&#160;</a></span>neorv32_sdi_enable()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_sdi_enable </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Enable SDI controller. </p> + +</div> +</div> +<a id="a4d54ce22ec97eb83da118439576e3277" name="a4d54ce22ec97eb83da118439576e3277"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a4d54ce22ec97eb83da118439576e3277">&#9670;&#160;</a></span>neorv32_sdi_get()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_sdi_get </td> + <td>(</td> + <td class="paramtype">uint8_t *</td> <td class="paramname"><span class="paramname"><em>data</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Get data from SDI input FIFO.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in,out]</td><td class="paramname">Pointer</td><td>fro data byte read from RX FIFO. </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>-1 if RX FIFO is empty, 0 if success. </dd></dl> + +</div> +</div> +<a id="a7390faeb01b4de3dd5ac18335736b90c" name="a7390faeb01b4de3dd5ac18335736b90c"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a7390faeb01b4de3dd5ac18335736b90c">&#9670;&#160;</a></span>neorv32_sdi_get_fifo_depth()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_sdi_get_fifo_depth </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Get SDI FIFO depth.</p> +<dl class="section return"><dt>Returns</dt><dd>FIFO depth (number of entries), 1 if no FIFO implemented </dd></dl> + +</div> +</div> +<a id="ac7a262d16c42bbac27723ff779545569" name="ac7a262d16c42bbac27723ff779545569"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ac7a262d16c42bbac27723ff779545569">&#9670;&#160;</a></span>neorv32_sdi_put()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_sdi_put </td> + <td>(</td> + <td class="paramtype">uint8_t</td> <td class="paramname"><span class="paramname"><em>data</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Push data to SDI output FIFO.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">data</td><td>Byte to push into TX FIFO. </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>-1 if TX FIFO is full, 0 if success. </dd></dl> + +</div> +</div> +<a id="a3246118dc0d7e1f61bc2485bbab44149" name="a3246118dc0d7e1f61bc2485bbab44149"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a3246118dc0d7e1f61bc2485bbab44149">&#9670;&#160;</a></span>neorv32_sdi_setup()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_sdi_setup </td> + <td>(</td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>irq_mask</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Reset, enable and configure SDI controller. The SDI control register bits are listed in <a class="el" href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6">NEORV32_SDI_CTRL_enum</a>.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">irq_mask</td><td>Interrupt configuration mask (CTRL's irq_* bits). </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/neorv32__sdi_8h.html b/sw/neorv32__sdi_8h.html new file mode 100644 index 0000000000..99c820be8f --- /dev/null +++ b/sw/neorv32__sdi_8h.html @@ -0,0 +1,399 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/lib/include/neorv32_sdi.h File Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_7d04193005ada6f9450f847f4adb6b5b.html">lib</a></li><li class="navelem"><a class="el" href="dir_752b1e5d3973bf735fa78bf6b4727df9.html">include</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#nested-classes">Data Structures</a> </div> + <div class="headertitle"><div class="title">neorv32_sdi.h File Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p>Serial data interface controller (SPPI) HW driver header file. +<a href="#details">More...</a></p> +<div class="textblock"><code>#include &lt;stdint.h&gt;</code><br /> +</div> +<p><a href="neorv32__sdi_8h_source.html">Go to the source code of this file.</a></p> +<table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="nested-classes" name="nested-classes"></a> +Data Structures</h2></td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">struct &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structneorv32__sdi__t.html">neorv32_sdi_t</a></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="func-members" name="func-members"></a> +Functions</h2></td></tr> +<tr><td colspan="2"><div class="groupHeader">Prototypes</div></td></tr> +<tr class="memitem:a51412722efdb18cd09667622b215e825" id="r_a51412722efdb18cd09667622b215e825"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a51412722efdb18cd09667622b215e825">neorv32_sdi_available</a> (void)</td></tr> +<tr class="separator:a51412722efdb18cd09667622b215e825"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a3246118dc0d7e1f61bc2485bbab44149" id="r_a3246118dc0d7e1f61bc2485bbab44149"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a3246118dc0d7e1f61bc2485bbab44149">neorv32_sdi_setup</a> (uint32_t irq_mask)</td></tr> +<tr class="separator:a3246118dc0d7e1f61bc2485bbab44149"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a8bd54bca8aea6147651c8115ee616f54" id="r_a8bd54bca8aea6147651c8115ee616f54"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a8bd54bca8aea6147651c8115ee616f54">neorv32_sdi_disable</a> (void)</td></tr> +<tr class="separator:a8bd54bca8aea6147651c8115ee616f54"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a5d68b9b1642baf3519076e55a22a8f61" id="r_a5d68b9b1642baf3519076e55a22a8f61"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a5d68b9b1642baf3519076e55a22a8f61">neorv32_sdi_enable</a> (void)</td></tr> +<tr class="separator:a5d68b9b1642baf3519076e55a22a8f61"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a7390faeb01b4de3dd5ac18335736b90c" id="r_a7390faeb01b4de3dd5ac18335736b90c"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a7390faeb01b4de3dd5ac18335736b90c">neorv32_sdi_get_fifo_depth</a> (void)</td></tr> +<tr class="separator:a7390faeb01b4de3dd5ac18335736b90c"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ac7a262d16c42bbac27723ff779545569" id="r_ac7a262d16c42bbac27723ff779545569"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ac7a262d16c42bbac27723ff779545569">neorv32_sdi_put</a> (uint8_t data)</td></tr> +<tr class="separator:ac7a262d16c42bbac27723ff779545569"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a4d54ce22ec97eb83da118439576e3277" id="r_a4d54ce22ec97eb83da118439576e3277"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a4d54ce22ec97eb83da118439576e3277">neorv32_sdi_get</a> (uint8_t *data)</td></tr> +<tr class="separator:a4d54ce22ec97eb83da118439576e3277"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a2636cf1959ce1f3eb4b77c00ca2e2707" id="r_a2636cf1959ce1f3eb4b77c00ca2e2707"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a2636cf1959ce1f3eb4b77c00ca2e2707">neorv32_sdi_check_cs</a> (void)</td></tr> +<tr class="separator:a2636cf1959ce1f3eb4b77c00ca2e2707"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader">IO Device: Serial Data Interface (SDI)</h2></td></tr> +<tr class="memitem:afd0921633d6523d9b7235055e9bbf928" id="r_afd0921633d6523d9b7235055e9bbf928"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#afd0921633d6523d9b7235055e9bbf928">NEORV32_SDI</a>&#160;&#160;&#160;((<a class="el" href="structneorv32__sdi__t.html">neorv32_sdi_t</a>*) (<a class="el" href="neorv32_8h.html#a9b316ec038bd94ada42c9dab57a0a3cb">NEORV32_SDI_BASE</a>))</td></tr> +<tr class="separator:afd0921633d6523d9b7235055e9bbf928"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:abad9f422cbdff1b73100e98f7ab20ec6" id="r_abad9f422cbdff1b73100e98f7ab20ec6"><td class="memItemLeft" align="right" valign="top">enum &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#abad9f422cbdff1b73100e98f7ab20ec6">NEORV32_SDI_CTRL_enum</a> { <br /> +&#160;&#160;<a class="el" href="#abad9f422cbdff1b73100e98f7ab20ec6af6016d120844c2d8d8da4fccc09f9809">SDI_CTRL_EN</a> = 0 +, <a class="el" href="#abad9f422cbdff1b73100e98f7ab20ec6a840c74518f55028608e2353ec6ce58c4">SDI_CTRL_FIFO_LSB</a> = 4 +, <a class="el" href="#abad9f422cbdff1b73100e98f7ab20ec6ab3b57f906bd3fc16242fa06601ce1716">SDI_CTRL_FIFO_MSB</a> = 7 +, <a class="el" href="#abad9f422cbdff1b73100e98f7ab20ec6a2a611e339fd9ae7854931743802ff5c0">SDI_CTRL_IRQ_RX_AVAIL</a> = 15 +, <br /> +&#160;&#160;<a class="el" href="#abad9f422cbdff1b73100e98f7ab20ec6af1e2abec3b3bc2ff9ecb2698d933a281">SDI_CTRL_IRQ_RX_HALF</a> = 16 +, <a class="el" href="#abad9f422cbdff1b73100e98f7ab20ec6a051d69f43c2b0f15c5e9e9252c906c9d">SDI_CTRL_IRQ_RX_FULL</a> = 17 +, <a class="el" href="#abad9f422cbdff1b73100e98f7ab20ec6a5df074faedb03cf3cc0cfa90eaccd210">SDI_CTRL_IRQ_TX_EMPTY</a> = 18 +, <a class="el" href="#abad9f422cbdff1b73100e98f7ab20ec6a762237a6107ee690276c36108fa1c1ed">SDI_CTRL_IRQ_TX_NHALF</a> = 19 +, <br /> +&#160;&#160;<a class="el" href="#abad9f422cbdff1b73100e98f7ab20ec6ae15186a46909f1a957269b21af6a14a0">SDI_CTRL_RX_AVAIL</a> = 23 +, <a class="el" href="#abad9f422cbdff1b73100e98f7ab20ec6ac9381cffb4da427baf31cdbbeae5e1f4">SDI_CTRL_RX_HALF</a> = 24 +, <a class="el" href="#abad9f422cbdff1b73100e98f7ab20ec6a45ade3854c01dc1b14a80e3fea29417a">SDI_CTRL_RX_FULL</a> = 25 +, <a class="el" href="#abad9f422cbdff1b73100e98f7ab20ec6aa9b89463a37e3a9c554195c2f87fb8d8">SDI_CTRL_TX_EMPTY</a> = 26 +, <br /> +&#160;&#160;<a class="el" href="#abad9f422cbdff1b73100e98f7ab20ec6aeac16a67f250cce5ea420790e80b8bb9">SDI_CTRL_TX_NHALF</a> = 27 +, <a class="el" href="#abad9f422cbdff1b73100e98f7ab20ec6adb5c4613ce0a6178a01599cf8fd6984a">SDI_CTRL_TX_FULL</a> = 28 +, <a class="el" href="#abad9f422cbdff1b73100e98f7ab20ec6ad288a52f2bdaa1ea6ddbadf7f32a3a63">SDI_CTRL_CS_ACTIVE</a> = 31 +<br /> + }</td></tr> +<tr class="separator:abad9f422cbdff1b73100e98f7ab20ec6"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>Serial data interface controller (SPPI) HW driver header file. </p> +<dl class="section note"><dt>Note</dt><dd>These functions should only be used if the SDI unit was synthesized (IO_SDI_EN = true).</dd></dl> +<dl class="section see"><dt>See also</dt><dd><a href="https://stnolting.github.io/neorv32/sw/files.html">https://stnolting.github.io/neorv32/sw/files.html</a> </dd></dl> +</div><h2 class="groupheader">Macro Definition Documentation</h2> +<a id="afd0921633d6523d9b7235055e9bbf928" name="afd0921633d6523d9b7235055e9bbf928"></a> +<h2 class="memtitle"><span class="permalink"><a href="#afd0921633d6523d9b7235055e9bbf928">&#9670;&#160;</a></span>NEORV32_SDI</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define NEORV32_SDI&#160;&#160;&#160;((<a class="el" href="structneorv32__sdi__t.html">neorv32_sdi_t</a>*) (<a class="el" href="neorv32_8h.html#a9b316ec038bd94ada42c9dab57a0a3cb">NEORV32_SDI_BASE</a>))</td> + </tr> + </table> +</div><div class="memdoc"> +<p>SDI module hardware access (<a class="el" href="structneorv32__sdi__t.html">neorv32_sdi_t</a>) </p> + +</div> +</div> +<h2 class="groupheader">Enumeration Type Documentation</h2> +<a id="abad9f422cbdff1b73100e98f7ab20ec6" name="abad9f422cbdff1b73100e98f7ab20ec6"></a> +<h2 class="memtitle"><span class="permalink"><a href="#abad9f422cbdff1b73100e98f7ab20ec6">&#9670;&#160;</a></span>NEORV32_SDI_CTRL_enum</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">enum <a class="el" href="#abad9f422cbdff1b73100e98f7ab20ec6">NEORV32_SDI_CTRL_enum</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>SDI control register bits </p> +<table class="fieldtable"> +<tr><th colspan="2">Enumerator</th></tr><tr><td class="fieldname"><a id="abad9f422cbdff1b73100e98f7ab20ec6af6016d120844c2d8d8da4fccc09f9809" name="abad9f422cbdff1b73100e98f7ab20ec6af6016d120844c2d8d8da4fccc09f9809"></a>SDI_CTRL_EN&#160;</td><td class="fielddoc"><p>SDI control register(0) (r/w): SID module enable </p> +</td></tr> +<tr><td class="fieldname"><a id="abad9f422cbdff1b73100e98f7ab20ec6a840c74518f55028608e2353ec6ce58c4" name="abad9f422cbdff1b73100e98f7ab20ec6a840c74518f55028608e2353ec6ce58c4"></a>SDI_CTRL_FIFO_LSB&#160;</td><td class="fielddoc"><p>SDI control register(4) (r/-): log2 of SDI FIFO size, LSB </p> +</td></tr> +<tr><td class="fieldname"><a id="abad9f422cbdff1b73100e98f7ab20ec6ab3b57f906bd3fc16242fa06601ce1716" name="abad9f422cbdff1b73100e98f7ab20ec6ab3b57f906bd3fc16242fa06601ce1716"></a>SDI_CTRL_FIFO_MSB&#160;</td><td class="fielddoc"><p>SDI control register(7) (r/-): log2 of SDI FIFO size, MSB </p> +</td></tr> +<tr><td class="fieldname"><a id="abad9f422cbdff1b73100e98f7ab20ec6a2a611e339fd9ae7854931743802ff5c0" name="abad9f422cbdff1b73100e98f7ab20ec6a2a611e339fd9ae7854931743802ff5c0"></a>SDI_CTRL_IRQ_RX_AVAIL&#160;</td><td class="fielddoc"><p>SDI control register(15) (r/w): IRQ when RX FIFO not empty </p> +</td></tr> +<tr><td class="fieldname"><a id="abad9f422cbdff1b73100e98f7ab20ec6af1e2abec3b3bc2ff9ecb2698d933a281" name="abad9f422cbdff1b73100e98f7ab20ec6af1e2abec3b3bc2ff9ecb2698d933a281"></a>SDI_CTRL_IRQ_RX_HALF&#160;</td><td class="fielddoc"><p>SDI control register(16) (r/w): IRQ when RX FIFO at least half full </p> +</td></tr> +<tr><td class="fieldname"><a id="abad9f422cbdff1b73100e98f7ab20ec6a051d69f43c2b0f15c5e9e9252c906c9d" name="abad9f422cbdff1b73100e98f7ab20ec6a051d69f43c2b0f15c5e9e9252c906c9d"></a>SDI_CTRL_IRQ_RX_FULL&#160;</td><td class="fielddoc"><p>SDI control register(17) (r/w): IRQ when RX FIFO full </p> +</td></tr> +<tr><td class="fieldname"><a id="abad9f422cbdff1b73100e98f7ab20ec6a5df074faedb03cf3cc0cfa90eaccd210" name="abad9f422cbdff1b73100e98f7ab20ec6a5df074faedb03cf3cc0cfa90eaccd210"></a>SDI_CTRL_IRQ_TX_EMPTY&#160;</td><td class="fielddoc"><p>SDI control register(18) (r/w): IRQ when TX FIFO empty </p> +</td></tr> +<tr><td class="fieldname"><a id="abad9f422cbdff1b73100e98f7ab20ec6a762237a6107ee690276c36108fa1c1ed" name="abad9f422cbdff1b73100e98f7ab20ec6a762237a6107ee690276c36108fa1c1ed"></a>SDI_CTRL_IRQ_TX_NHALF&#160;</td><td class="fielddoc"><p>SDI control register(19) (r/w): IRQ when TX FIFO not at least half full </p> +</td></tr> +<tr><td class="fieldname"><a id="abad9f422cbdff1b73100e98f7ab20ec6ae15186a46909f1a957269b21af6a14a0" name="abad9f422cbdff1b73100e98f7ab20ec6ae15186a46909f1a957269b21af6a14a0"></a>SDI_CTRL_RX_AVAIL&#160;</td><td class="fielddoc"><p>SDI control register(23) (r/-): RX FIFO not empty </p> +</td></tr> +<tr><td class="fieldname"><a id="abad9f422cbdff1b73100e98f7ab20ec6ac9381cffb4da427baf31cdbbeae5e1f4" name="abad9f422cbdff1b73100e98f7ab20ec6ac9381cffb4da427baf31cdbbeae5e1f4"></a>SDI_CTRL_RX_HALF&#160;</td><td class="fielddoc"><p>SDI control register(24) (r/-): RX FIFO at least half full </p> +</td></tr> +<tr><td class="fieldname"><a id="abad9f422cbdff1b73100e98f7ab20ec6a45ade3854c01dc1b14a80e3fea29417a" name="abad9f422cbdff1b73100e98f7ab20ec6a45ade3854c01dc1b14a80e3fea29417a"></a>SDI_CTRL_RX_FULL&#160;</td><td class="fielddoc"><p>SDI control register(25) (r/-): RX FIFO full </p> +</td></tr> +<tr><td class="fieldname"><a id="abad9f422cbdff1b73100e98f7ab20ec6aa9b89463a37e3a9c554195c2f87fb8d8" name="abad9f422cbdff1b73100e98f7ab20ec6aa9b89463a37e3a9c554195c2f87fb8d8"></a>SDI_CTRL_TX_EMPTY&#160;</td><td class="fielddoc"><p>SDI control register(26) (r/-): TX FIFO empty </p> +</td></tr> +<tr><td class="fieldname"><a id="abad9f422cbdff1b73100e98f7ab20ec6aeac16a67f250cce5ea420790e80b8bb9" name="abad9f422cbdff1b73100e98f7ab20ec6aeac16a67f250cce5ea420790e80b8bb9"></a>SDI_CTRL_TX_NHALF&#160;</td><td class="fielddoc"><p>SDI control register(27) (r/-): TX FIFO not at least half full </p> +</td></tr> +<tr><td class="fieldname"><a id="abad9f422cbdff1b73100e98f7ab20ec6adb5c4613ce0a6178a01599cf8fd6984a" name="abad9f422cbdff1b73100e98f7ab20ec6adb5c4613ce0a6178a01599cf8fd6984a"></a>SDI_CTRL_TX_FULL&#160;</td><td class="fielddoc"><p>SDI control register(28) (r/-): TX FIFO full </p> +</td></tr> +<tr><td class="fieldname"><a id="abad9f422cbdff1b73100e98f7ab20ec6ad288a52f2bdaa1ea6ddbadf7f32a3a63" name="abad9f422cbdff1b73100e98f7ab20ec6ad288a52f2bdaa1ea6ddbadf7f32a3a63"></a>SDI_CTRL_CS_ACTIVE&#160;</td><td class="fielddoc"><p>SDI control register(31) (r/-): Chip-select is active when set </p> +</td></tr> +</table> + +</div> +</div> +<h2 class="groupheader">Function Documentation</h2> +<a id="a51412722efdb18cd09667622b215e825" name="a51412722efdb18cd09667622b215e825"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a51412722efdb18cd09667622b215e825">&#9670;&#160;</a></span>neorv32_sdi_available()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_sdi_available </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Check if SDI unit was synthesized.</p> +<dl class="section return"><dt>Returns</dt><dd>0 if SDI was not synthesized, 1 if SPI is available. </dd></dl> + +</div> +</div> +<a id="a2636cf1959ce1f3eb4b77c00ca2e2707" name="a2636cf1959ce1f3eb4b77c00ca2e2707"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a2636cf1959ce1f3eb4b77c00ca2e2707">&#9670;&#160;</a></span>neorv32_sdi_check_cs()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_sdi_check_cs </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Get status of chip-select line.</p> +<dl class="section return"><dt>Returns</dt><dd>1 if chip-select line is enabled/active (driven low), 0 otherwise. </dd></dl> + +</div> +</div> +<a id="a8bd54bca8aea6147651c8115ee616f54" name="a8bd54bca8aea6147651c8115ee616f54"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a8bd54bca8aea6147651c8115ee616f54">&#9670;&#160;</a></span>neorv32_sdi_disable()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_sdi_disable </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Disable SDI controller. </p> + +</div> +</div> +<a id="a5d68b9b1642baf3519076e55a22a8f61" name="a5d68b9b1642baf3519076e55a22a8f61"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a5d68b9b1642baf3519076e55a22a8f61">&#9670;&#160;</a></span>neorv32_sdi_enable()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_sdi_enable </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Enable SDI controller. </p> + +</div> +</div> +<a id="a4d54ce22ec97eb83da118439576e3277" name="a4d54ce22ec97eb83da118439576e3277"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a4d54ce22ec97eb83da118439576e3277">&#9670;&#160;</a></span>neorv32_sdi_get()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_sdi_get </td> + <td>(</td> + <td class="paramtype">uint8_t *</td> <td class="paramname"><span class="paramname"><em>data</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Get data from SDI input FIFO.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in,out]</td><td class="paramname">Pointer</td><td>fro data byte read from RX FIFO. </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>-1 if RX FIFO is empty, 0 if success. </dd></dl> + +</div> +</div> +<a id="a7390faeb01b4de3dd5ac18335736b90c" name="a7390faeb01b4de3dd5ac18335736b90c"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a7390faeb01b4de3dd5ac18335736b90c">&#9670;&#160;</a></span>neorv32_sdi_get_fifo_depth()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_sdi_get_fifo_depth </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Get SDI FIFO depth.</p> +<dl class="section return"><dt>Returns</dt><dd>FIFO depth (number of entries), 1 if no FIFO implemented </dd></dl> + +</div> +</div> +<a id="ac7a262d16c42bbac27723ff779545569" name="ac7a262d16c42bbac27723ff779545569"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ac7a262d16c42bbac27723ff779545569">&#9670;&#160;</a></span>neorv32_sdi_put()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_sdi_put </td> + <td>(</td> + <td class="paramtype">uint8_t</td> <td class="paramname"><span class="paramname"><em>data</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Push data to SDI output FIFO.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">data</td><td>Byte to push into TX FIFO. </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>-1 if TX FIFO is full, 0 if success. </dd></dl> + +</div> +</div> +<a id="a3246118dc0d7e1f61bc2485bbab44149" name="a3246118dc0d7e1f61bc2485bbab44149"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a3246118dc0d7e1f61bc2485bbab44149">&#9670;&#160;</a></span>neorv32_sdi_setup()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_sdi_setup </td> + <td>(</td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>irq_mask</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Reset, enable and configure SDI controller. The SDI control register bits are listed in <a class="el" href="#abad9f422cbdff1b73100e98f7ab20ec6">NEORV32_SDI_CTRL_enum</a>.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">irq_mask</td><td>Interrupt configuration mask (CTRL's irq_* bits). </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/neorv32__sdi_8h_source.html b/sw/neorv32__sdi_8h_source.html new file mode 100644 index 0000000000..1b4ad04120 --- /dev/null +++ b/sw/neorv32__sdi_8h_source.html @@ -0,0 +1,183 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/lib/include/neorv32_sdi.h Source File</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_7d04193005ada6f9450f847f4adb6b5b.html">lib</a></li><li class="navelem"><a class="el" href="dir_752b1e5d3973bf735fa78bf6b4727df9.html">include</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="headertitle"><div class="title">neorv32_sdi.h</div></div> +</div><!--header--> +<div class="contents"> +<a href="neorv32__sdi_8h.html">Go to the documentation of this file.</a><div class="fragment"><div class="line"><a id="l00001" name="l00001"></a><span class="lineno"> 1</span><span class="comment">// ================================================================================ //</span></div> +<div class="line"><a id="l00002" name="l00002"></a><span class="lineno"> 2</span><span class="comment">// The NEORV32 RISC-V Processor - https://github.com/stnolting/neorv32 //</span></div> +<div class="line"><a id="l00003" name="l00003"></a><span class="lineno"> 3</span><span class="comment">// Copyright (c) NEORV32 contributors. //</span></div> +<div class="line"><a id="l00004" name="l00004"></a><span class="lineno"> 4</span><span class="comment">// Copyright (c) 2020 - 2024 Stephan Nolting. All rights reserved. //</span></div> +<div class="line"><a id="l00005" name="l00005"></a><span class="lineno"> 5</span><span class="comment">// Licensed under the BSD-3-Clause license, see LICENSE for details. //</span></div> +<div class="line"><a id="l00006" name="l00006"></a><span class="lineno"> 6</span><span class="comment">// SPDX-License-Identifier: BSD-3-Clause //</span></div> +<div class="line"><a id="l00007" name="l00007"></a><span class="lineno"> 7</span><span class="comment">// ================================================================================ //</span></div> +<div class="line"><a id="l00008" name="l00008"></a><span class="lineno"> 8</span> </div> +<div class="line"><a id="l00018" name="l00018"></a><span class="lineno"> 18</span><span class="preprocessor">#ifndef neorv32_sdi_h</span></div> +<div class="line"><a id="l00019" name="l00019"></a><span class="lineno"> 19</span><span class="preprocessor">#define neorv32_sdi_h</span></div> +<div class="line"><a id="l00020" name="l00020"></a><span class="lineno"> 20</span> </div> +<div class="line"><a id="l00021" name="l00021"></a><span class="lineno"> 21</span><span class="preprocessor">#include &lt;stdint.h&gt;</span></div> +<div class="line"><a id="l00022" name="l00022"></a><span class="lineno"> 22</span> </div> +<div class="line"><a id="l00023" name="l00023"></a><span class="lineno"> 23</span> </div> +<div class="line"><a id="l00024" name="l00024"></a><span class="lineno"> 24</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen00029" data-start="{" data-end="};"> +<div class="line"><a id="l00029" name="l00029"></a><span class="lineno"><a class="line" href="structneorv32__sdi__t.html"> 29</a></span><span class="keyword">typedef</span> <span class="keyword">volatile</span> <span class="keyword">struct </span>__attribute__((packed,aligned(4))) {</div> +<div class="line"><a id="l00030" name="l00030"></a><span class="lineno"><a class="line" href="structneorv32__sdi__t.html#af494f25cbcd8478cf384eb868e447303"> 30</a></span> uint32_t <a class="code hl_variable" href="structneorv32__sdi__t.html#af494f25cbcd8478cf384eb868e447303">CTRL</a>; </div> +<div class="line"><a id="l00031" name="l00031"></a><span class="lineno"><a class="line" href="structneorv32__sdi__t.html#a3ea6903c0924d0a1b633b6a2b0ae44f1"> 31</a></span> uint32_t <a class="code hl_variable" href="structneorv32__sdi__t.html#a3ea6903c0924d0a1b633b6a2b0ae44f1">DATA</a>; </div> +<div class="line"><a id="l00032" name="l00032"></a><span class="lineno"> 32</span>} <a class="code hl_struct" href="structneorv32__sdi__t.html">neorv32_sdi_t</a>;</div> +</div> +<div class="line"><a id="l00033" name="l00033"></a><span class="lineno"> 33</span> </div> +<div class="line"><a id="l00035" name="l00035"></a><span class="lineno"><a class="line" href="neorv32__sdi_8h.html#afd0921633d6523d9b7235055e9bbf928"> 35</a></span><span class="preprocessor">#define NEORV32_SDI ((neorv32_sdi_t*) (NEORV32_SDI_BASE))</span></div> +<div class="line"><a id="l00036" name="l00036"></a><span class="lineno"> 36</span> </div> +<div class="foldopen" id="foldopen00038" data-start="{" data-end="};"> +<div class="line"><a id="l00038" name="l00038"></a><span class="lineno"><a class="line" href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6"> 38</a></span><span class="keyword">enum</span> <a class="code hl_enumeration" href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6">NEORV32_SDI_CTRL_enum</a> {</div> +<div class="line"><a id="l00039" name="l00039"></a><span class="lineno"><a class="line" href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6af6016d120844c2d8d8da4fccc09f9809"> 39</a></span> <a class="code hl_enumvalue" href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6af6016d120844c2d8d8da4fccc09f9809">SDI_CTRL_EN</a> = 0, </div> +<div class="line"><a id="l00041" name="l00041"></a><span class="lineno"><a class="line" href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6a840c74518f55028608e2353ec6ce58c4"> 41</a></span> <a class="code hl_enumvalue" href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6a840c74518f55028608e2353ec6ce58c4">SDI_CTRL_FIFO_LSB</a> = 4, </div> +<div class="line"><a id="l00042" name="l00042"></a><span class="lineno"><a class="line" href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6ab3b57f906bd3fc16242fa06601ce1716"> 42</a></span> <a class="code hl_enumvalue" href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6ab3b57f906bd3fc16242fa06601ce1716">SDI_CTRL_FIFO_MSB</a> = 7, </div> +<div class="line"><a id="l00044" name="l00044"></a><span class="lineno"><a class="line" href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6a2a611e339fd9ae7854931743802ff5c0"> 44</a></span> <a class="code hl_enumvalue" href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6a2a611e339fd9ae7854931743802ff5c0">SDI_CTRL_IRQ_RX_AVAIL</a> = 15, </div> +<div class="line"><a id="l00045" name="l00045"></a><span class="lineno"><a class="line" href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6af1e2abec3b3bc2ff9ecb2698d933a281"> 45</a></span> <a class="code hl_enumvalue" href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6af1e2abec3b3bc2ff9ecb2698d933a281">SDI_CTRL_IRQ_RX_HALF</a> = 16, </div> +<div class="line"><a id="l00046" name="l00046"></a><span class="lineno"><a class="line" href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6a051d69f43c2b0f15c5e9e9252c906c9d"> 46</a></span> <a class="code hl_enumvalue" href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6a051d69f43c2b0f15c5e9e9252c906c9d">SDI_CTRL_IRQ_RX_FULL</a> = 17, </div> +<div class="line"><a id="l00047" name="l00047"></a><span class="lineno"><a class="line" href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6a5df074faedb03cf3cc0cfa90eaccd210"> 47</a></span> <a class="code hl_enumvalue" href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6a5df074faedb03cf3cc0cfa90eaccd210">SDI_CTRL_IRQ_TX_EMPTY</a> = 18, </div> +<div class="line"><a id="l00048" name="l00048"></a><span class="lineno"><a class="line" href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6a762237a6107ee690276c36108fa1c1ed"> 48</a></span> <a class="code hl_enumvalue" href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6a762237a6107ee690276c36108fa1c1ed">SDI_CTRL_IRQ_TX_NHALF</a> = 19, </div> +<div class="line"><a id="l00050" name="l00050"></a><span class="lineno"><a class="line" href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6ae15186a46909f1a957269b21af6a14a0"> 50</a></span> <a class="code hl_enumvalue" href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6ae15186a46909f1a957269b21af6a14a0">SDI_CTRL_RX_AVAIL</a> = 23, </div> +<div class="line"><a id="l00051" name="l00051"></a><span class="lineno"><a class="line" href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6ac9381cffb4da427baf31cdbbeae5e1f4"> 51</a></span> <a class="code hl_enumvalue" href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6ac9381cffb4da427baf31cdbbeae5e1f4">SDI_CTRL_RX_HALF</a> = 24, </div> +<div class="line"><a id="l00052" name="l00052"></a><span class="lineno"><a class="line" href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6a45ade3854c01dc1b14a80e3fea29417a"> 52</a></span> <a class="code hl_enumvalue" href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6a45ade3854c01dc1b14a80e3fea29417a">SDI_CTRL_RX_FULL</a> = 25, </div> +<div class="line"><a id="l00053" name="l00053"></a><span class="lineno"><a class="line" href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6aa9b89463a37e3a9c554195c2f87fb8d8"> 53</a></span> <a class="code hl_enumvalue" href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6aa9b89463a37e3a9c554195c2f87fb8d8">SDI_CTRL_TX_EMPTY</a> = 26, </div> +<div class="line"><a id="l00054" name="l00054"></a><span class="lineno"><a class="line" href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6aeac16a67f250cce5ea420790e80b8bb9"> 54</a></span> <a class="code hl_enumvalue" href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6aeac16a67f250cce5ea420790e80b8bb9">SDI_CTRL_TX_NHALF</a> = 27, </div> +<div class="line"><a id="l00055" name="l00055"></a><span class="lineno"><a class="line" href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6adb5c4613ce0a6178a01599cf8fd6984a"> 55</a></span> <a class="code hl_enumvalue" href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6adb5c4613ce0a6178a01599cf8fd6984a">SDI_CTRL_TX_FULL</a> = 28, </div> +<div class="line"><a id="l00057" name="l00057"></a><span class="lineno"> 57</span> <a class="code hl_enumvalue" href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6ad288a52f2bdaa1ea6ddbadf7f32a3a63">SDI_CTRL_CS_ACTIVE</a> = 31 </div> +<div class="line"><a id="l00058" name="l00058"></a><span class="lineno"><a class="line" href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6ad288a52f2bdaa1ea6ddbadf7f32a3a63"> 58</a></span>};</div> +</div> +<div class="line"><a id="l00062" name="l00062"></a><span class="lineno"> 62</span><span class="comment">/**********************************************************************/</span></div> +<div class="line"><a id="l00066" name="l00066"></a><span class="lineno"> 66</span><span class="keywordtype">int</span> <a class="code hl_function" href="neorv32__sdi_8h.html#a51412722efdb18cd09667622b215e825">neorv32_sdi_available</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00067" name="l00067"></a><span class="lineno"> 67</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__sdi_8h.html#a3246118dc0d7e1f61bc2485bbab44149">neorv32_sdi_setup</a>(uint32_t irq_mask);</div> +<div class="line"><a id="l00068" name="l00068"></a><span class="lineno"> 68</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__sdi_8h.html#a8bd54bca8aea6147651c8115ee616f54">neorv32_sdi_disable</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00069" name="l00069"></a><span class="lineno"> 69</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__sdi_8h.html#a5d68b9b1642baf3519076e55a22a8f61">neorv32_sdi_enable</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00070" name="l00070"></a><span class="lineno"> 70</span><span class="keywordtype">int</span> <a class="code hl_function" href="neorv32__sdi_8h.html#a7390faeb01b4de3dd5ac18335736b90c">neorv32_sdi_get_fifo_depth</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00071" name="l00071"></a><span class="lineno"> 71</span><span class="keywordtype">int</span> <a class="code hl_function" href="neorv32__sdi_8h.html#ac7a262d16c42bbac27723ff779545569">neorv32_sdi_put</a>(uint8_t data);</div> +<div class="line"><a id="l00072" name="l00072"></a><span class="lineno"> 72</span><span class="keywordtype">int</span> <a class="code hl_function" href="neorv32__sdi_8h.html#a4d54ce22ec97eb83da118439576e3277">neorv32_sdi_get</a>(uint8_t* data);</div> +<div class="line"><a id="l00073" name="l00073"></a><span class="lineno"> 73</span><span class="keywordtype">int</span> <a class="code hl_function" href="neorv32__sdi_8h.html#a2636cf1959ce1f3eb4b77c00ca2e2707">neorv32_sdi_check_cs</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00077" name="l00077"></a><span class="lineno"> 77</span><span class="preprocessor">#endif </span><span class="comment">// neorv32_sdi_h</span></div> +<div class="ttc" id="aneorv32__sdi_8h_html_a2636cf1959ce1f3eb4b77c00ca2e2707"><div class="ttname"><a href="neorv32__sdi_8h.html#a2636cf1959ce1f3eb4b77c00ca2e2707">neorv32_sdi_check_cs</a></div><div class="ttdeci">int neorv32_sdi_check_cs(void)</div><div class="ttdef"><b>Definition</b> neorv32_sdi.c:126</div></div> +<div class="ttc" id="aneorv32__sdi_8h_html_a3246118dc0d7e1f61bc2485bbab44149"><div class="ttname"><a href="neorv32__sdi_8h.html#a3246118dc0d7e1f61bc2485bbab44149">neorv32_sdi_setup</a></div><div class="ttdeci">void neorv32_sdi_setup(uint32_t irq_mask)</div><div class="ttdef"><b>Definition</b> neorv32_sdi.c:43</div></div> +<div class="ttc" id="aneorv32__sdi_8h_html_a4d54ce22ec97eb83da118439576e3277"><div class="ttname"><a href="neorv32__sdi_8h.html#a4d54ce22ec97eb83da118439576e3277">neorv32_sdi_get</a></div><div class="ttdeci">int neorv32_sdi_get(uint8_t *data)</div><div class="ttdef"><b>Definition</b> neorv32_sdi.c:109</div></div> +<div class="ttc" id="aneorv32__sdi_8h_html_a51412722efdb18cd09667622b215e825"><div class="ttname"><a href="neorv32__sdi_8h.html#a51412722efdb18cd09667622b215e825">neorv32_sdi_available</a></div><div class="ttdeci">int neorv32_sdi_available(void)</div><div class="ttdef"><b>Definition</b> neorv32_sdi.c:26</div></div> +<div class="ttc" id="aneorv32__sdi_8h_html_a5d68b9b1642baf3519076e55a22a8f61"><div class="ttname"><a href="neorv32__sdi_8h.html#a5d68b9b1642baf3519076e55a22a8f61">neorv32_sdi_enable</a></div><div class="ttdeci">void neorv32_sdi_enable(void)</div><div class="ttdef"><b>Definition</b> neorv32_sdi.c:67</div></div> +<div class="ttc" id="aneorv32__sdi_8h_html_a7390faeb01b4de3dd5ac18335736b90c"><div class="ttname"><a href="neorv32__sdi_8h.html#a7390faeb01b4de3dd5ac18335736b90c">neorv32_sdi_get_fifo_depth</a></div><div class="ttdeci">int neorv32_sdi_get_fifo_depth(void)</div><div class="ttdef"><b>Definition</b> neorv32_sdi.c:78</div></div> +<div class="ttc" id="aneorv32__sdi_8h_html_a8bd54bca8aea6147651c8115ee616f54"><div class="ttname"><a href="neorv32__sdi_8h.html#a8bd54bca8aea6147651c8115ee616f54">neorv32_sdi_disable</a></div><div class="ttdeci">void neorv32_sdi_disable(void)</div><div class="ttdef"><b>Definition</b> neorv32_sdi.c:58</div></div> +<div class="ttc" id="aneorv32__sdi_8h_html_abad9f422cbdff1b73100e98f7ab20ec6"><div class="ttname"><a href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6">NEORV32_SDI_CTRL_enum</a></div><div class="ttdeci">NEORV32_SDI_CTRL_enum</div><div class="ttdef"><b>Definition</b> neorv32_sdi.h:38</div></div> +<div class="ttc" id="aneorv32__sdi_8h_html_abad9f422cbdff1b73100e98f7ab20ec6a051d69f43c2b0f15c5e9e9252c906c9d"><div class="ttname"><a href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6a051d69f43c2b0f15c5e9e9252c906c9d">SDI_CTRL_IRQ_RX_FULL</a></div><div class="ttdeci">@ SDI_CTRL_IRQ_RX_FULL</div><div class="ttdef"><b>Definition</b> neorv32_sdi.h:46</div></div> +<div class="ttc" id="aneorv32__sdi_8h_html_abad9f422cbdff1b73100e98f7ab20ec6a2a611e339fd9ae7854931743802ff5c0"><div class="ttname"><a href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6a2a611e339fd9ae7854931743802ff5c0">SDI_CTRL_IRQ_RX_AVAIL</a></div><div class="ttdeci">@ SDI_CTRL_IRQ_RX_AVAIL</div><div class="ttdef"><b>Definition</b> neorv32_sdi.h:44</div></div> +<div class="ttc" id="aneorv32__sdi_8h_html_abad9f422cbdff1b73100e98f7ab20ec6a45ade3854c01dc1b14a80e3fea29417a"><div class="ttname"><a href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6a45ade3854c01dc1b14a80e3fea29417a">SDI_CTRL_RX_FULL</a></div><div class="ttdeci">@ SDI_CTRL_RX_FULL</div><div class="ttdef"><b>Definition</b> neorv32_sdi.h:52</div></div> +<div class="ttc" id="aneorv32__sdi_8h_html_abad9f422cbdff1b73100e98f7ab20ec6a5df074faedb03cf3cc0cfa90eaccd210"><div class="ttname"><a href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6a5df074faedb03cf3cc0cfa90eaccd210">SDI_CTRL_IRQ_TX_EMPTY</a></div><div class="ttdeci">@ SDI_CTRL_IRQ_TX_EMPTY</div><div class="ttdef"><b>Definition</b> neorv32_sdi.h:47</div></div> +<div class="ttc" id="aneorv32__sdi_8h_html_abad9f422cbdff1b73100e98f7ab20ec6a762237a6107ee690276c36108fa1c1ed"><div class="ttname"><a href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6a762237a6107ee690276c36108fa1c1ed">SDI_CTRL_IRQ_TX_NHALF</a></div><div class="ttdeci">@ SDI_CTRL_IRQ_TX_NHALF</div><div class="ttdef"><b>Definition</b> neorv32_sdi.h:48</div></div> +<div class="ttc" id="aneorv32__sdi_8h_html_abad9f422cbdff1b73100e98f7ab20ec6a840c74518f55028608e2353ec6ce58c4"><div class="ttname"><a href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6a840c74518f55028608e2353ec6ce58c4">SDI_CTRL_FIFO_LSB</a></div><div class="ttdeci">@ SDI_CTRL_FIFO_LSB</div><div class="ttdef"><b>Definition</b> neorv32_sdi.h:41</div></div> +<div class="ttc" id="aneorv32__sdi_8h_html_abad9f422cbdff1b73100e98f7ab20ec6aa9b89463a37e3a9c554195c2f87fb8d8"><div class="ttname"><a href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6aa9b89463a37e3a9c554195c2f87fb8d8">SDI_CTRL_TX_EMPTY</a></div><div class="ttdeci">@ SDI_CTRL_TX_EMPTY</div><div class="ttdef"><b>Definition</b> neorv32_sdi.h:53</div></div> +<div class="ttc" id="aneorv32__sdi_8h_html_abad9f422cbdff1b73100e98f7ab20ec6ab3b57f906bd3fc16242fa06601ce1716"><div class="ttname"><a href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6ab3b57f906bd3fc16242fa06601ce1716">SDI_CTRL_FIFO_MSB</a></div><div class="ttdeci">@ SDI_CTRL_FIFO_MSB</div><div class="ttdef"><b>Definition</b> neorv32_sdi.h:42</div></div> +<div class="ttc" id="aneorv32__sdi_8h_html_abad9f422cbdff1b73100e98f7ab20ec6ac9381cffb4da427baf31cdbbeae5e1f4"><div class="ttname"><a href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6ac9381cffb4da427baf31cdbbeae5e1f4">SDI_CTRL_RX_HALF</a></div><div class="ttdeci">@ SDI_CTRL_RX_HALF</div><div class="ttdef"><b>Definition</b> neorv32_sdi.h:51</div></div> +<div class="ttc" id="aneorv32__sdi_8h_html_abad9f422cbdff1b73100e98f7ab20ec6ad288a52f2bdaa1ea6ddbadf7f32a3a63"><div class="ttname"><a href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6ad288a52f2bdaa1ea6ddbadf7f32a3a63">SDI_CTRL_CS_ACTIVE</a></div><div class="ttdeci">@ SDI_CTRL_CS_ACTIVE</div><div class="ttdef"><b>Definition</b> neorv32_sdi.h:57</div></div> +<div class="ttc" id="aneorv32__sdi_8h_html_abad9f422cbdff1b73100e98f7ab20ec6adb5c4613ce0a6178a01599cf8fd6984a"><div class="ttname"><a href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6adb5c4613ce0a6178a01599cf8fd6984a">SDI_CTRL_TX_FULL</a></div><div class="ttdeci">@ SDI_CTRL_TX_FULL</div><div class="ttdef"><b>Definition</b> neorv32_sdi.h:55</div></div> +<div class="ttc" id="aneorv32__sdi_8h_html_abad9f422cbdff1b73100e98f7ab20ec6ae15186a46909f1a957269b21af6a14a0"><div class="ttname"><a href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6ae15186a46909f1a957269b21af6a14a0">SDI_CTRL_RX_AVAIL</a></div><div class="ttdeci">@ SDI_CTRL_RX_AVAIL</div><div class="ttdef"><b>Definition</b> neorv32_sdi.h:50</div></div> +<div class="ttc" id="aneorv32__sdi_8h_html_abad9f422cbdff1b73100e98f7ab20ec6aeac16a67f250cce5ea420790e80b8bb9"><div class="ttname"><a href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6aeac16a67f250cce5ea420790e80b8bb9">SDI_CTRL_TX_NHALF</a></div><div class="ttdeci">@ SDI_CTRL_TX_NHALF</div><div class="ttdef"><b>Definition</b> neorv32_sdi.h:54</div></div> +<div class="ttc" id="aneorv32__sdi_8h_html_abad9f422cbdff1b73100e98f7ab20ec6af1e2abec3b3bc2ff9ecb2698d933a281"><div class="ttname"><a href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6af1e2abec3b3bc2ff9ecb2698d933a281">SDI_CTRL_IRQ_RX_HALF</a></div><div class="ttdeci">@ SDI_CTRL_IRQ_RX_HALF</div><div class="ttdef"><b>Definition</b> neorv32_sdi.h:45</div></div> +<div class="ttc" id="aneorv32__sdi_8h_html_abad9f422cbdff1b73100e98f7ab20ec6af6016d120844c2d8d8da4fccc09f9809"><div class="ttname"><a href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6af6016d120844c2d8d8da4fccc09f9809">SDI_CTRL_EN</a></div><div class="ttdeci">@ SDI_CTRL_EN</div><div class="ttdef"><b>Definition</b> neorv32_sdi.h:39</div></div> +<div class="ttc" id="aneorv32__sdi_8h_html_ac7a262d16c42bbac27723ff779545569"><div class="ttname"><a href="neorv32__sdi_8h.html#ac7a262d16c42bbac27723ff779545569">neorv32_sdi_put</a></div><div class="ttdeci">int neorv32_sdi_put(uint8_t data)</div><div class="ttdef"><b>Definition</b> neorv32_sdi.c:91</div></div> +<div class="ttc" id="astructneorv32__sdi__t_html"><div class="ttname"><a href="structneorv32__sdi__t.html">neorv32_sdi_t</a></div><div class="ttdef"><b>Definition</b> neorv32_sdi.h:29</div></div> +<div class="ttc" id="astructneorv32__sdi__t_html_a3ea6903c0924d0a1b633b6a2b0ae44f1"><div class="ttname"><a href="structneorv32__sdi__t.html#a3ea6903c0924d0a1b633b6a2b0ae44f1">neorv32_sdi_t::DATA</a></div><div class="ttdeci">uint32_t DATA</div><div class="ttdef"><b>Definition</b> neorv32_sdi.h:31</div></div> +<div class="ttc" id="astructneorv32__sdi__t_html_af494f25cbcd8478cf384eb868e447303"><div class="ttname"><a href="structneorv32__sdi__t.html#af494f25cbcd8478cf384eb868e447303">neorv32_sdi_t::CTRL</a></div><div class="ttdeci">uint32_t CTRL</div><div class="ttdef"><b>Definition</b> neorv32_sdi.h:30</div></div> +</div><!-- fragment --></div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/neorv32__slink_8c.html b/sw/neorv32__slink_8c.html new file mode 100644 index 0000000000..f32eca78be --- /dev/null +++ b/sw/neorv32__slink_8c.html @@ -0,0 +1,485 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/lib/source/neorv32_slink.c File Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_7d04193005ada6f9450f847f4adb6b5b.html">lib</a></li><li class="navelem"><a class="el" href="dir_0c6ac14e2254a316d41123f98feeb67b.html">source</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#func-members">Functions</a> </div> + <div class="headertitle"><div class="title">neorv32_slink.c File Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p>Stream Link Interface HW driver source file. +<a href="#details">More...</a></p> +<div class="textblock"><code>#include &quot;<a class="el" href="neorv32_8h_source.html">neorv32.h</a>&quot;</code><br /> +</div><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="func-members" name="func-members"></a> +Functions</h2></td></tr> +<tr class="memitem:aaf0f7bc96b797e819ccaae94292d9ddb" id="r_aaf0f7bc96b797e819ccaae94292d9ddb"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aaf0f7bc96b797e819ccaae94292d9ddb">neorv32_slink_available</a> (void)</td></tr> +<tr class="separator:aaf0f7bc96b797e819ccaae94292d9ddb"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a8f0b4a768f53a72a5c16034e160ce321" id="r_a8f0b4a768f53a72a5c16034e160ce321"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a8f0b4a768f53a72a5c16034e160ce321">neorv32_slink_setup</a> (uint32_t rx_irq, uint32_t tx_irq)</td></tr> +<tr class="separator:a8f0b4a768f53a72a5c16034e160ce321"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ad149fea81e6d28f77450b8ba50cf706e" id="r_ad149fea81e6d28f77450b8ba50cf706e"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ad149fea81e6d28f77450b8ba50cf706e">neorv32_slink_rx_clear</a> (void)</td></tr> +<tr class="separator:ad149fea81e6d28f77450b8ba50cf706e"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ac7484e9e3848f94efe016dd064f6a57f" id="r_ac7484e9e3848f94efe016dd064f6a57f"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ac7484e9e3848f94efe016dd064f6a57f">neorv32_slink_tx_clear</a> (void)</td></tr> +<tr class="separator:ac7484e9e3848f94efe016dd064f6a57f"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a575c7663ca0bd07c95b1d45152a3ddf8" id="r_a575c7663ca0bd07c95b1d45152a3ddf8"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a575c7663ca0bd07c95b1d45152a3ddf8">neorv32_slink_get_rx_fifo_depth</a> (void)</td></tr> +<tr class="separator:a575c7663ca0bd07c95b1d45152a3ddf8"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aaf0d0d1b890353d4f3bf49450ec2fad2" id="r_aaf0d0d1b890353d4f3bf49450ec2fad2"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aaf0d0d1b890353d4f3bf49450ec2fad2">neorv32_slink_get_tx_fifo_depth</a> (void)</td></tr> +<tr class="separator:aaf0d0d1b890353d4f3bf49450ec2fad2"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ace319592c12dc6a0fe1b7dd66bdf9284" id="r_ace319592c12dc6a0fe1b7dd66bdf9284"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ace319592c12dc6a0fe1b7dd66bdf9284">neorv32_slink_get</a> (void)</td></tr> +<tr class="separator:ace319592c12dc6a0fe1b7dd66bdf9284"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a3e02c558548c1c6178c49adee9a007f7" id="r_a3e02c558548c1c6178c49adee9a007f7"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a3e02c558548c1c6178c49adee9a007f7">neorv32_slink_check_last</a> (void)</td></tr> +<tr class="separator:a3e02c558548c1c6178c49adee9a007f7"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ad857d7e78ca2b5eb0d0a4f2c515fe7bc" id="r_ad857d7e78ca2b5eb0d0a4f2c515fe7bc"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ad857d7e78ca2b5eb0d0a4f2c515fe7bc">neorv32_slink_set_dst</a> (uint32_t dst)</td></tr> +<tr class="separator:ad857d7e78ca2b5eb0d0a4f2c515fe7bc"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a1a9269f42552a849450aecd99f7ec7a0" id="r_a1a9269f42552a849450aecd99f7ec7a0"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a1a9269f42552a849450aecd99f7ec7a0">neorv32_slink_get_src</a> (void)</td></tr> +<tr class="separator:a1a9269f42552a849450aecd99f7ec7a0"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aaa9fdb9cbfa7888e92790ab65431d21d" id="r_aaa9fdb9cbfa7888e92790ab65431d21d"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aaa9fdb9cbfa7888e92790ab65431d21d">neorv32_slink_put</a> (uint32_t tx_data)</td></tr> +<tr class="separator:aaa9fdb9cbfa7888e92790ab65431d21d"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a2136bc0b12ee2e6703e84a6417a1e8eb" id="r_a2136bc0b12ee2e6703e84a6417a1e8eb"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a2136bc0b12ee2e6703e84a6417a1e8eb">neorv32_slink_put_last</a> (uint32_t tx_data)</td></tr> +<tr class="separator:a2136bc0b12ee2e6703e84a6417a1e8eb"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ad57fc0941fe32e8bf423ce3e57e2c10a" id="r_ad57fc0941fe32e8bf423ce3e57e2c10a"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ad57fc0941fe32e8bf423ce3e57e2c10a">neorv32_slink_rx_status</a> (void)</td></tr> +<tr class="separator:ad57fc0941fe32e8bf423ce3e57e2c10a"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ad0252e7ae915e5840cd17e8c52e94a1c" id="r_ad0252e7ae915e5840cd17e8c52e94a1c"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ad0252e7ae915e5840cd17e8c52e94a1c">neorv32_slink_tx_status</a> (void)</td></tr> +<tr class="separator:ad0252e7ae915e5840cd17e8c52e94a1c"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>Stream Link Interface HW driver source file. </p> +<dl class="section note"><dt>Note</dt><dd>These functions should only be used if the SLINK unit was synthesized (IO_SLINK_EN = true).</dd></dl> +<dl class="section see"><dt>See also</dt><dd><a href="https://stnolting.github.io/neorv32/sw/files.html">https://stnolting.github.io/neorv32/sw/files.html</a> </dd></dl> +</div><h2 class="groupheader">Function Documentation</h2> +<a id="aaf0f7bc96b797e819ccaae94292d9ddb" name="aaf0f7bc96b797e819ccaae94292d9ddb"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aaf0f7bc96b797e819ccaae94292d9ddb">&#9670;&#160;</a></span>neorv32_slink_available()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_slink_available </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Check if stream link interface was synthesized.</p> +<dl class="section return"><dt>Returns</dt><dd>0 if SLINK was not synthesized, 1 if SLINK is available. </dd></dl> + +</div> +</div> +<a id="a3e02c558548c1c6178c49adee9a007f7" name="a3e02c558548c1c6178c49adee9a007f7"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a3e02c558548c1c6178c49adee9a007f7">&#9670;&#160;</a></span>neorv32_slink_check_last()</h2> + +<div class="memitem"> +<div class="memproto"> +<table class="mlabels"> + <tr> + <td class="mlabels-left"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_slink_check_last </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> + </td> + <td class="mlabels-right"> +<span class="mlabels"><span class="mlabel">inline</span></span> </td> + </tr> +</table> +</div><div class="memdoc"> +<p>Check if last RX word has "end-of-stream" delimiter.</p> +<dl class="section note"><dt>Note</dt><dd>This needs has to be called AFTER reading the actual data word using <a class="el" href="#ace319592c12dc6a0fe1b7dd66bdf9284">neorv32_slink_get(void)</a>.</dd></dl> +<dl class="section return"><dt>Returns</dt><dd>0 if not end of stream, !=0 if end of stream. </dd></dl> + +</div> +</div> +<a id="ace319592c12dc6a0fe1b7dd66bdf9284" name="ace319592c12dc6a0fe1b7dd66bdf9284"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ace319592c12dc6a0fe1b7dd66bdf9284">&#9670;&#160;</a></span>neorv32_slink_get()</h2> + +<div class="memitem"> +<div class="memproto"> +<table class="mlabels"> + <tr> + <td class="mlabels-left"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_slink_get </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> + </td> + <td class="mlabels-right"> +<span class="mlabels"><span class="mlabel">inline</span></span> </td> + </tr> +</table> +</div><div class="memdoc"> +<p>Read data from RX link (non-blocking)</p> +<dl class="section return"><dt>Returns</dt><dd>Data received from link. </dd></dl> + +</div> +</div> +<a id="a575c7663ca0bd07c95b1d45152a3ddf8" name="a575c7663ca0bd07c95b1d45152a3ddf8"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a575c7663ca0bd07c95b1d45152a3ddf8">&#9670;&#160;</a></span>neorv32_slink_get_rx_fifo_depth()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_slink_get_rx_fifo_depth </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Get FIFO depth of RX link.</p> +<dl class="section return"><dt>Returns</dt><dd>FIFO depth of RX link (1..32768). </dd></dl> + +</div> +</div> +<a id="a1a9269f42552a849450aecd99f7ec7a0" name="a1a9269f42552a849450aecd99f7ec7a0"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a1a9269f42552a849450aecd99f7ec7a0">&#9670;&#160;</a></span>neorv32_slink_get_src()</h2> + +<div class="memitem"> +<div class="memproto"> +<table class="mlabels"> + <tr> + <td class="mlabels-left"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_slink_get_src </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> + </td> + <td class="mlabels-right"> +<span class="mlabels"><span class="mlabel">inline</span></span> </td> + </tr> +</table> +</div><div class="memdoc"> +<p>Get RX link routing source</p> +<dl class="section note"><dt>Note</dt><dd>This needs has to be called AFTER reading the actual data word using <a class="el" href="#ace319592c12dc6a0fe1b7dd66bdf9284">neorv32_slink_get(void)</a>.</dd></dl> +<dl class="section return"><dt>Returns</dt><dd>4-bit source routing ID. </dd></dl> + +</div> +</div> +<a id="aaf0d0d1b890353d4f3bf49450ec2fad2" name="aaf0d0d1b890353d4f3bf49450ec2fad2"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aaf0d0d1b890353d4f3bf49450ec2fad2">&#9670;&#160;</a></span>neorv32_slink_get_tx_fifo_depth()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_slink_get_tx_fifo_depth </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Get FIFO depth of TX link.</p> +<dl class="section return"><dt>Returns</dt><dd>FIFO depth of TX link (1..32768). </dd></dl> + +</div> +</div> +<a id="aaa9fdb9cbfa7888e92790ab65431d21d" name="aaa9fdb9cbfa7888e92790ab65431d21d"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aaa9fdb9cbfa7888e92790ab65431d21d">&#9670;&#160;</a></span>neorv32_slink_put()</h2> + +<div class="memitem"> +<div class="memproto"> +<table class="mlabels"> + <tr> + <td class="mlabels-left"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_slink_put </td> + <td>(</td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>tx_data</em></span></td><td>)</td> + <td></td> + </tr> + </table> + </td> + <td class="mlabels-right"> +<span class="mlabels"><span class="mlabel">inline</span></span> </td> + </tr> +</table> +</div><div class="memdoc"> +<p>Write data to TX link (non-blocking)</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">tx_data</td><td>Data to send to link. </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="a2136bc0b12ee2e6703e84a6417a1e8eb" name="a2136bc0b12ee2e6703e84a6417a1e8eb"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a2136bc0b12ee2e6703e84a6417a1e8eb">&#9670;&#160;</a></span>neorv32_slink_put_last()</h2> + +<div class="memitem"> +<div class="memproto"> +<table class="mlabels"> + <tr> + <td class="mlabels-left"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_slink_put_last </td> + <td>(</td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>tx_data</em></span></td><td>)</td> + <td></td> + </tr> + </table> + </td> + <td class="mlabels-right"> +<span class="mlabels"><span class="mlabel">inline</span></span> </td> + </tr> +</table> +</div><div class="memdoc"> +<p>Write data to TX link (non-blocking) and set "last" (end-of-stream) delimiter.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">tx_data</td><td>Data to send to link. </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="ad149fea81e6d28f77450b8ba50cf706e" name="ad149fea81e6d28f77450b8ba50cf706e"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ad149fea81e6d28f77450b8ba50cf706e">&#9670;&#160;</a></span>neorv32_slink_rx_clear()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_slink_rx_clear </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Clear RX FIFO. </p> + +</div> +</div> +<a id="ad57fc0941fe32e8bf423ce3e57e2c10a" name="ad57fc0941fe32e8bf423ce3e57e2c10a"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ad57fc0941fe32e8bf423ce3e57e2c10a">&#9670;&#160;</a></span>neorv32_slink_rx_status()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_slink_rx_status </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Get RX link FIFO status.</p> +<dl class="section return"><dt>Returns</dt><dd>FIFO status <a class="el" href="neorv32__slink_8h.html#a84f7fe82f188bd4e68f41549587822bf">NEORV32_SLINK_STATUS_enum</a>. </dd></dl> + +</div> +</div> +<a id="ad857d7e78ca2b5eb0d0a4f2c515fe7bc" name="ad857d7e78ca2b5eb0d0a4f2c515fe7bc"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ad857d7e78ca2b5eb0d0a4f2c515fe7bc">&#9670;&#160;</a></span>neorv32_slink_set_dst()</h2> + +<div class="memitem"> +<div class="memproto"> +<table class="mlabels"> + <tr> + <td class="mlabels-left"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_slink_set_dst </td> + <td>(</td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>dst</em></span></td><td>)</td> + <td></td> + </tr> + </table> + </td> + <td class="mlabels-right"> +<span class="mlabels"><span class="mlabel">inline</span></span> </td> + </tr> +</table> +</div><div class="memdoc"> +<p>Set TX link routing destination</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">dst</td><td>Routing destination ID (4-bit, LSB-aligned). </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="a8f0b4a768f53a72a5c16034e160ce321" name="a8f0b4a768f53a72a5c16034e160ce321"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a8f0b4a768f53a72a5c16034e160ce321">&#9670;&#160;</a></span>neorv32_slink_setup()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_slink_setup </td> + <td>(</td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>rx_irq</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>tx_irq</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Reset, enable and configure SLINK.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">rx_irq</td><td>Configure RX interrupt conditions (<a class="el" href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1">NEORV32_SLINK_CTRL_enum</a>). </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">tx_irq</td><td>Configure TX interrupt conditions (<a class="el" href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1">NEORV32_SLINK_CTRL_enum</a>). </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="ac7484e9e3848f94efe016dd064f6a57f" name="ac7484e9e3848f94efe016dd064f6a57f"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ac7484e9e3848f94efe016dd064f6a57f">&#9670;&#160;</a></span>neorv32_slink_tx_clear()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_slink_tx_clear </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Clear TX FIFO. </p> + +</div> +</div> +<a id="ad0252e7ae915e5840cd17e8c52e94a1c" name="ad0252e7ae915e5840cd17e8c52e94a1c"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ad0252e7ae915e5840cd17e8c52e94a1c">&#9670;&#160;</a></span>neorv32_slink_tx_status()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_slink_tx_status </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Get TX link FIFO status.</p> +<dl class="section return"><dt>Returns</dt><dd>FIFO status <a class="el" href="neorv32__slink_8h.html#a84f7fe82f188bd4e68f41549587822bf">NEORV32_SLINK_STATUS_enum</a>. </dd></dl> + +</div> +</div> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/neorv32__slink_8h.html b/sw/neorv32__slink_8h.html new file mode 100644 index 0000000000..f4919ff054 --- /dev/null +++ b/sw/neorv32__slink_8h.html @@ -0,0 +1,657 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/lib/include/neorv32_slink.h File Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_7d04193005ada6f9450f847f4adb6b5b.html">lib</a></li><li class="navelem"><a class="el" href="dir_752b1e5d3973bf735fa78bf6b4727df9.html">include</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#nested-classes">Data Structures</a> </div> + <div class="headertitle"><div class="title">neorv32_slink.h File Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p>Stream Link Interface HW driver header file. +<a href="#details">More...</a></p> +<div class="textblock"><code>#include &lt;stdint.h&gt;</code><br /> +</div> +<p><a href="neorv32__slink_8h_source.html">Go to the source code of this file.</a></p> +<table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="nested-classes" name="nested-classes"></a> +Data Structures</h2></td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">struct &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structneorv32__slink__t.html">neorv32_slink_t</a></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="func-members" name="func-members"></a> +Functions</h2></td></tr> +<tr><td colspan="2"><div class="groupHeader">Prototypes</div></td></tr> +<tr class="memitem:aaf0f7bc96b797e819ccaae94292d9ddb" id="r_aaf0f7bc96b797e819ccaae94292d9ddb"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aaf0f7bc96b797e819ccaae94292d9ddb">neorv32_slink_available</a> (void)</td></tr> +<tr class="separator:aaf0f7bc96b797e819ccaae94292d9ddb"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a8f0b4a768f53a72a5c16034e160ce321" id="r_a8f0b4a768f53a72a5c16034e160ce321"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a8f0b4a768f53a72a5c16034e160ce321">neorv32_slink_setup</a> (uint32_t rx_irq, uint32_t tx_irq)</td></tr> +<tr class="separator:a8f0b4a768f53a72a5c16034e160ce321"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ad149fea81e6d28f77450b8ba50cf706e" id="r_ad149fea81e6d28f77450b8ba50cf706e"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ad149fea81e6d28f77450b8ba50cf706e">neorv32_slink_rx_clear</a> (void)</td></tr> +<tr class="separator:ad149fea81e6d28f77450b8ba50cf706e"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ac7484e9e3848f94efe016dd064f6a57f" id="r_ac7484e9e3848f94efe016dd064f6a57f"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ac7484e9e3848f94efe016dd064f6a57f">neorv32_slink_tx_clear</a> (void)</td></tr> +<tr class="separator:ac7484e9e3848f94efe016dd064f6a57f"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a575c7663ca0bd07c95b1d45152a3ddf8" id="r_a575c7663ca0bd07c95b1d45152a3ddf8"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a575c7663ca0bd07c95b1d45152a3ddf8">neorv32_slink_get_rx_fifo_depth</a> (void)</td></tr> +<tr class="separator:a575c7663ca0bd07c95b1d45152a3ddf8"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aaf0d0d1b890353d4f3bf49450ec2fad2" id="r_aaf0d0d1b890353d4f3bf49450ec2fad2"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aaf0d0d1b890353d4f3bf49450ec2fad2">neorv32_slink_get_tx_fifo_depth</a> (void)</td></tr> +<tr class="separator:aaf0d0d1b890353d4f3bf49450ec2fad2"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ace319592c12dc6a0fe1b7dd66bdf9284" id="r_ace319592c12dc6a0fe1b7dd66bdf9284"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ace319592c12dc6a0fe1b7dd66bdf9284">neorv32_slink_get</a> (void)</td></tr> +<tr class="separator:ace319592c12dc6a0fe1b7dd66bdf9284"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a3e02c558548c1c6178c49adee9a007f7" id="r_a3e02c558548c1c6178c49adee9a007f7"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a3e02c558548c1c6178c49adee9a007f7">neorv32_slink_check_last</a> (void)</td></tr> +<tr class="separator:a3e02c558548c1c6178c49adee9a007f7"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ad857d7e78ca2b5eb0d0a4f2c515fe7bc" id="r_ad857d7e78ca2b5eb0d0a4f2c515fe7bc"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ad857d7e78ca2b5eb0d0a4f2c515fe7bc">neorv32_slink_set_dst</a> (uint32_t dst)</td></tr> +<tr class="separator:ad857d7e78ca2b5eb0d0a4f2c515fe7bc"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a1a9269f42552a849450aecd99f7ec7a0" id="r_a1a9269f42552a849450aecd99f7ec7a0"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a1a9269f42552a849450aecd99f7ec7a0">neorv32_slink_get_src</a> (void)</td></tr> +<tr class="separator:a1a9269f42552a849450aecd99f7ec7a0"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aaa9fdb9cbfa7888e92790ab65431d21d" id="r_aaa9fdb9cbfa7888e92790ab65431d21d"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aaa9fdb9cbfa7888e92790ab65431d21d">neorv32_slink_put</a> (uint32_t tx_data)</td></tr> +<tr class="separator:aaa9fdb9cbfa7888e92790ab65431d21d"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a2136bc0b12ee2e6703e84a6417a1e8eb" id="r_a2136bc0b12ee2e6703e84a6417a1e8eb"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a2136bc0b12ee2e6703e84a6417a1e8eb">neorv32_slink_put_last</a> (uint32_t tx_data)</td></tr> +<tr class="separator:a2136bc0b12ee2e6703e84a6417a1e8eb"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ad57fc0941fe32e8bf423ce3e57e2c10a" id="r_ad57fc0941fe32e8bf423ce3e57e2c10a"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ad57fc0941fe32e8bf423ce3e57e2c10a">neorv32_slink_rx_status</a> (void)</td></tr> +<tr class="separator:ad57fc0941fe32e8bf423ce3e57e2c10a"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ad0252e7ae915e5840cd17e8c52e94a1c" id="r_ad0252e7ae915e5840cd17e8c52e94a1c"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ad0252e7ae915e5840cd17e8c52e94a1c">neorv32_slink_tx_status</a> (void)</td></tr> +<tr class="separator:ad0252e7ae915e5840cd17e8c52e94a1c"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader">IO Device: Stream Link Interface (SLINK)</h2></td></tr> +<tr class="memitem:a6380d894432de119a20993096db534df" id="r_a6380d894432de119a20993096db534df"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a6380d894432de119a20993096db534df">NEORV32_SLINK</a>&#160;&#160;&#160;((<a class="el" href="structneorv32__slink__t.html">neorv32_slink_t</a>*) (<a class="el" href="neorv32_8h.html#ab5e6dc57886cd5ed98b86f22fc37d7cc">NEORV32_SLINK_BASE</a>))</td></tr> +<tr class="separator:a6380d894432de119a20993096db534df"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ac0385a56c38315d492b3414d98235ef1" id="r_ac0385a56c38315d492b3414d98235ef1"><td class="memItemLeft" align="right" valign="top">enum &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ac0385a56c38315d492b3414d98235ef1">NEORV32_SLINK_CTRL_enum</a> { <br /> +&#160;&#160;<a class="el" href="#ac0385a56c38315d492b3414d98235ef1a739187f413b7436dc4037187e4a9e86a">SLINK_CTRL_EN</a> = 0 +, <a class="el" href="#ac0385a56c38315d492b3414d98235ef1a156fa3209b2652af6b58b0fdfc6cab1b">SLINK_CTRL_RX_CLR</a> = 1 +, <a class="el" href="#ac0385a56c38315d492b3414d98235ef1ad366597a44d3dff7dbab4cde72bed82f">SLINK_CTRL_TX_CLR</a> = 2 +, <a class="el" href="#ac0385a56c38315d492b3414d98235ef1a624723683d247668ef44137393e576aa">SLINK_CTRL_RX_LAST</a> = 4 +, <br /> +&#160;&#160;<a class="el" href="#ac0385a56c38315d492b3414d98235ef1ae78f82e54bd9d737bbcbc5c7af0e9d4b">SLINK_CTRL_RX_EMPTY</a> = 8 +, <a class="el" href="#ac0385a56c38315d492b3414d98235ef1af695158b9cf5466d87c207f9bd0a688e">SLINK_CTRL_RX_HALF</a> = 9 +, <a class="el" href="#ac0385a56c38315d492b3414d98235ef1aa7521fbe691fef233c0dff4053e4493e">SLINK_CTRL_RX_FULL</a> = 10 +, <a class="el" href="#ac0385a56c38315d492b3414d98235ef1a308cf7829ecca32f7a3da1bd74339854">SLINK_CTRL_TX_EMPTY</a> = 11 +, <br /> +&#160;&#160;<a class="el" href="#ac0385a56c38315d492b3414d98235ef1a530b8b76301f36fbda134b330447de78">SLINK_CTRL_TX_HALF</a> = 12 +, <a class="el" href="#ac0385a56c38315d492b3414d98235ef1af94314ed65c6a8d9c364d99d7ae960ee">SLINK_CTRL_TX_FULL</a> = 13 +, <a class="el" href="#ac0385a56c38315d492b3414d98235ef1a5452eab0fe12d174ec804c4c72060854">SLINK_CTRL_IRQ_RX_NEMPTY</a> = 16 +, <a class="el" href="#ac0385a56c38315d492b3414d98235ef1afa9353cd824d1b2833930ce9e922e392">SLINK_CTRL_IRQ_RX_HALF</a> = 17 +, <br /> +&#160;&#160;<a class="el" href="#ac0385a56c38315d492b3414d98235ef1ac8a688706aee72d2027e022b64664309">SLINK_CTRL_IRQ_RX_FULL</a> = 18 +, <a class="el" href="#ac0385a56c38315d492b3414d98235ef1ae06ad5f627f8902e2368e0daff6cfa88">SLINK_CTRL_IRQ_TX_EMPTY</a> = 19 +, <a class="el" href="#ac0385a56c38315d492b3414d98235ef1a7bf757dbfb1fdaddceaed3a3887003cf">SLINK_CTRL_IRQ_TX_NHALF</a> = 20 +, <a class="el" href="#ac0385a56c38315d492b3414d98235ef1a8f994f256f57c006c88b9e38df3f54fa">SLINK_CTRL_IRQ_TX_NFULL</a> = 21 +, <br /> +&#160;&#160;<a class="el" href="#ac0385a56c38315d492b3414d98235ef1a9c68af961c1147846929ca55e9e4e88c">SLINK_CTRL_RX_FIFO_LSB</a> = 24 +, <a class="el" href="#ac0385a56c38315d492b3414d98235ef1a945e2b7eda65dc13ca38eb21c9c4f657">SLINK_CTRL_RX_FIFO_MSB</a> = 27 +, <a class="el" href="#ac0385a56c38315d492b3414d98235ef1aba613343fc17715fc1bb07729588a12d">SLINK_CTRL_TX_FIFO_LSB</a> = 28 +, <a class="el" href="#ac0385a56c38315d492b3414d98235ef1af27a9e6e50b169d3f5efd0a08ba4a943">SLINK_CTRL_TX_FIFO_MSB</a> = 31 +<br /> + }</td></tr> +<tr class="separator:ac0385a56c38315d492b3414d98235ef1"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ac3e5e02fd89a357135adca6d28cd0e45" id="r_ac3e5e02fd89a357135adca6d28cd0e45"><td class="memItemLeft" align="right" valign="top">enum &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ac3e5e02fd89a357135adca6d28cd0e45">NEORV32_SLINK_ROUTE_enum</a> { <a class="el" href="#ac3e5e02fd89a357135adca6d28cd0e45a9a2311357bd87c85a5cc45f08b0d8f80">SLINK_ROUTE_DST_LSB</a> = 0 +, <a class="el" href="#ac3e5e02fd89a357135adca6d28cd0e45a7e8da208ecaf142107587033e2d63ec1">SLINK_ROUTE_DST_MSB</a> = 3 +, <a class="el" href="#ac3e5e02fd89a357135adca6d28cd0e45a69942c3a7b7b0550634f4016e639b0c2">SLINK_ROUTE_SRC_LSB</a> = 4 +, <a class="el" href="#ac3e5e02fd89a357135adca6d28cd0e45a7b7b0b9bd4fe448cae97a3a21460f983">SLINK_ROUTE_SRC_MSB</a> = 7 + }</td></tr> +<tr class="separator:ac3e5e02fd89a357135adca6d28cd0e45"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a84f7fe82f188bd4e68f41549587822bf" id="r_a84f7fe82f188bd4e68f41549587822bf"><td class="memItemLeft" align="right" valign="top">enum &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a84f7fe82f188bd4e68f41549587822bf">NEORV32_SLINK_STATUS_enum</a> { <a class="el" href="#a84f7fe82f188bd4e68f41549587822bfa9f24886f55b7f78ae8909ea8a573058c">SLINK_FIFO_EMPTY</a> = 0 +, <a class="el" href="#a84f7fe82f188bd4e68f41549587822bfadc37988b8aee38e85626064b2c3704f9">SLINK_FIFO_HALF</a> = 1 +, <a class="el" href="#a84f7fe82f188bd4e68f41549587822bfa2f96e61f0e07ef4ecd40f14e69b69211">SLINK_FIFO_FULL</a> = 2 + }</td></tr> +<tr class="separator:a84f7fe82f188bd4e68f41549587822bf"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>Stream Link Interface HW driver header file. </p> +<dl class="section see"><dt>See also</dt><dd><a href="https://stnolting.github.io/neorv32/sw/files.html">https://stnolting.github.io/neorv32/sw/files.html</a> </dd></dl> +</div><h2 class="groupheader">Macro Definition Documentation</h2> +<a id="a6380d894432de119a20993096db534df" name="a6380d894432de119a20993096db534df"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a6380d894432de119a20993096db534df">&#9670;&#160;</a></span>NEORV32_SLINK</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define NEORV32_SLINK&#160;&#160;&#160;((<a class="el" href="structneorv32__slink__t.html">neorv32_slink_t</a>*) (<a class="el" href="neorv32_8h.html#ab5e6dc57886cd5ed98b86f22fc37d7cc">NEORV32_SLINK_BASE</a>))</td> + </tr> + </table> +</div><div class="memdoc"> +<p>SLINK module hardware access (<a class="el" href="structneorv32__slink__t.html">neorv32_slink_t</a>) </p> + +</div> +</div> +<h2 class="groupheader">Enumeration Type Documentation</h2> +<a id="ac0385a56c38315d492b3414d98235ef1" name="ac0385a56c38315d492b3414d98235ef1"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ac0385a56c38315d492b3414d98235ef1">&#9670;&#160;</a></span>NEORV32_SLINK_CTRL_enum</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">enum <a class="el" href="#ac0385a56c38315d492b3414d98235ef1">NEORV32_SLINK_CTRL_enum</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>SLINK control register bits </p> +<table class="fieldtable"> +<tr><th colspan="2">Enumerator</th></tr><tr><td class="fieldname"><a id="ac0385a56c38315d492b3414d98235ef1a739187f413b7436dc4037187e4a9e86a" name="ac0385a56c38315d492b3414d98235ef1a739187f413b7436dc4037187e4a9e86a"></a>SLINK_CTRL_EN&#160;</td><td class="fielddoc"><p>SLINK control register(0) (r/w): SLINK unit enable </p> +</td></tr> +<tr><td class="fieldname"><a id="ac0385a56c38315d492b3414d98235ef1a156fa3209b2652af6b58b0fdfc6cab1b" name="ac0385a56c38315d492b3414d98235ef1a156fa3209b2652af6b58b0fdfc6cab1b"></a>SLINK_CTRL_RX_CLR&#160;</td><td class="fielddoc"><p>SLINK control register(1) (-/w): Clear RX FIFO, auto-clears </p> +</td></tr> +<tr><td class="fieldname"><a id="ac0385a56c38315d492b3414d98235ef1ad366597a44d3dff7dbab4cde72bed82f" name="ac0385a56c38315d492b3414d98235ef1ad366597a44d3dff7dbab4cde72bed82f"></a>SLINK_CTRL_TX_CLR&#160;</td><td class="fielddoc"><p>SLINK control register(2) (-/w): Clear TX FIFO, auto-clears </p> +</td></tr> +<tr><td class="fieldname"><a id="ac0385a56c38315d492b3414d98235ef1a624723683d247668ef44137393e576aa" name="ac0385a56c38315d492b3414d98235ef1a624723683d247668ef44137393e576aa"></a>SLINK_CTRL_RX_LAST&#160;</td><td class="fielddoc"><p>SLINK control register(4) (r/-): RX end-of-stream delimiter </p> +</td></tr> +<tr><td class="fieldname"><a id="ac0385a56c38315d492b3414d98235ef1ae78f82e54bd9d737bbcbc5c7af0e9d4b" name="ac0385a56c38315d492b3414d98235ef1ae78f82e54bd9d737bbcbc5c7af0e9d4b"></a>SLINK_CTRL_RX_EMPTY&#160;</td><td class="fielddoc"><p>SLINK control register(8) (r/-): RX FIFO empty </p> +</td></tr> +<tr><td class="fieldname"><a id="ac0385a56c38315d492b3414d98235ef1af695158b9cf5466d87c207f9bd0a688e" name="ac0385a56c38315d492b3414d98235ef1af695158b9cf5466d87c207f9bd0a688e"></a>SLINK_CTRL_RX_HALF&#160;</td><td class="fielddoc"><p>SLINK control register(9) (r/-): RX FIFO at least half full </p> +</td></tr> +<tr><td class="fieldname"><a id="ac0385a56c38315d492b3414d98235ef1aa7521fbe691fef233c0dff4053e4493e" name="ac0385a56c38315d492b3414d98235ef1aa7521fbe691fef233c0dff4053e4493e"></a>SLINK_CTRL_RX_FULL&#160;</td><td class="fielddoc"><p>SLINK control register(10) (r/-): RX FIFO full </p> +</td></tr> +<tr><td class="fieldname"><a id="ac0385a56c38315d492b3414d98235ef1a308cf7829ecca32f7a3da1bd74339854" name="ac0385a56c38315d492b3414d98235ef1a308cf7829ecca32f7a3da1bd74339854"></a>SLINK_CTRL_TX_EMPTY&#160;</td><td class="fielddoc"><p>SLINK control register(11) (r/-): TX FIFO empty </p> +</td></tr> +<tr><td class="fieldname"><a id="ac0385a56c38315d492b3414d98235ef1a530b8b76301f36fbda134b330447de78" name="ac0385a56c38315d492b3414d98235ef1a530b8b76301f36fbda134b330447de78"></a>SLINK_CTRL_TX_HALF&#160;</td><td class="fielddoc"><p>SLINK control register(12) (r/-): TX FIFO at least half full </p> +</td></tr> +<tr><td class="fieldname"><a id="ac0385a56c38315d492b3414d98235ef1af94314ed65c6a8d9c364d99d7ae960ee" name="ac0385a56c38315d492b3414d98235ef1af94314ed65c6a8d9c364d99d7ae960ee"></a>SLINK_CTRL_TX_FULL&#160;</td><td class="fielddoc"><p>SLINK control register(13) (r/-): TX FIFO full </p> +</td></tr> +<tr><td class="fieldname"><a id="ac0385a56c38315d492b3414d98235ef1a5452eab0fe12d174ec804c4c72060854" name="ac0385a56c38315d492b3414d98235ef1a5452eab0fe12d174ec804c4c72060854"></a>SLINK_CTRL_IRQ_RX_NEMPTY&#160;</td><td class="fielddoc"><p>SLINK control register(16) (r/w): RX interrupt if RX FIFO not empty </p> +</td></tr> +<tr><td class="fieldname"><a id="ac0385a56c38315d492b3414d98235ef1afa9353cd824d1b2833930ce9e922e392" name="ac0385a56c38315d492b3414d98235ef1afa9353cd824d1b2833930ce9e922e392"></a>SLINK_CTRL_IRQ_RX_HALF&#160;</td><td class="fielddoc"><p>SLINK control register(17) (r/w): RX interrupt if RX FIFO at least half full </p> +</td></tr> +<tr><td class="fieldname"><a id="ac0385a56c38315d492b3414d98235ef1ac8a688706aee72d2027e022b64664309" name="ac0385a56c38315d492b3414d98235ef1ac8a688706aee72d2027e022b64664309"></a>SLINK_CTRL_IRQ_RX_FULL&#160;</td><td class="fielddoc"><p>SLINK control register(18) (r/w): RX interrupt if RX FIFO full </p> +</td></tr> +<tr><td class="fieldname"><a id="ac0385a56c38315d492b3414d98235ef1ae06ad5f627f8902e2368e0daff6cfa88" name="ac0385a56c38315d492b3414d98235ef1ae06ad5f627f8902e2368e0daff6cfa88"></a>SLINK_CTRL_IRQ_TX_EMPTY&#160;</td><td class="fielddoc"><p>SLINK control register(19) (r/w): TX interrupt if TX FIFO empty </p> +</td></tr> +<tr><td class="fieldname"><a id="ac0385a56c38315d492b3414d98235ef1a7bf757dbfb1fdaddceaed3a3887003cf" name="ac0385a56c38315d492b3414d98235ef1a7bf757dbfb1fdaddceaed3a3887003cf"></a>SLINK_CTRL_IRQ_TX_NHALF&#160;</td><td class="fielddoc"><p>SLINK control register(20) (r/w): TX interrupt if TX FIFO not at least half full </p> +</td></tr> +<tr><td class="fieldname"><a id="ac0385a56c38315d492b3414d98235ef1a8f994f256f57c006c88b9e38df3f54fa" name="ac0385a56c38315d492b3414d98235ef1a8f994f256f57c006c88b9e38df3f54fa"></a>SLINK_CTRL_IRQ_TX_NFULL&#160;</td><td class="fielddoc"><p>SLINK control register(21) (r/w): TX interrupt if TX FIFO not full </p> +</td></tr> +<tr><td class="fieldname"><a id="ac0385a56c38315d492b3414d98235ef1a9c68af961c1147846929ca55e9e4e88c" name="ac0385a56c38315d492b3414d98235ef1a9c68af961c1147846929ca55e9e4e88c"></a>SLINK_CTRL_RX_FIFO_LSB&#160;</td><td class="fielddoc"><p>SLINK control register(24) (r/-): log2(RX FIFO size) LSB </p> +</td></tr> +<tr><td class="fieldname"><a id="ac0385a56c38315d492b3414d98235ef1a945e2b7eda65dc13ca38eb21c9c4f657" name="ac0385a56c38315d492b3414d98235ef1a945e2b7eda65dc13ca38eb21c9c4f657"></a>SLINK_CTRL_RX_FIFO_MSB&#160;</td><td class="fielddoc"><p>SLINK control register(27) (r/-): log2(RX FIFO size) MSB </p> +</td></tr> +<tr><td class="fieldname"><a id="ac0385a56c38315d492b3414d98235ef1aba613343fc17715fc1bb07729588a12d" name="ac0385a56c38315d492b3414d98235ef1aba613343fc17715fc1bb07729588a12d"></a>SLINK_CTRL_TX_FIFO_LSB&#160;</td><td class="fielddoc"><p>SLINK control register(28) (r/-): log2(TX FIFO size) LSB </p> +</td></tr> +<tr><td class="fieldname"><a id="ac0385a56c38315d492b3414d98235ef1af27a9e6e50b169d3f5efd0a08ba4a943" name="ac0385a56c38315d492b3414d98235ef1af27a9e6e50b169d3f5efd0a08ba4a943"></a>SLINK_CTRL_TX_FIFO_MSB&#160;</td><td class="fielddoc"><p>SLINK control register(31) (r/-): log2(TX FIFO size) MSB </p> +</td></tr> +</table> + +</div> +</div> +<a id="ac3e5e02fd89a357135adca6d28cd0e45" name="ac3e5e02fd89a357135adca6d28cd0e45"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ac3e5e02fd89a357135adca6d28cd0e45">&#9670;&#160;</a></span>NEORV32_SLINK_ROUTE_enum</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">enum <a class="el" href="#ac3e5e02fd89a357135adca6d28cd0e45">NEORV32_SLINK_ROUTE_enum</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>ROUTE register bits </p> +<table class="fieldtable"> +<tr><th colspan="2">Enumerator</th></tr><tr><td class="fieldname"><a id="ac3e5e02fd89a357135adca6d28cd0e45a9a2311357bd87c85a5cc45f08b0d8f80" name="ac3e5e02fd89a357135adca6d28cd0e45a9a2311357bd87c85a5cc45f08b0d8f80"></a>SLINK_ROUTE_DST_LSB&#160;</td><td class="fielddoc"><p>SLINK routing register(0) (r/w): Destination routing information LSB </p> +</td></tr> +<tr><td class="fieldname"><a id="ac3e5e02fd89a357135adca6d28cd0e45a7e8da208ecaf142107587033e2d63ec1" name="ac3e5e02fd89a357135adca6d28cd0e45a7e8da208ecaf142107587033e2d63ec1"></a>SLINK_ROUTE_DST_MSB&#160;</td><td class="fielddoc"><p>SLINK routing register(3) (r/w): Destination routing information MSB </p> +</td></tr> +<tr><td class="fieldname"><a id="ac3e5e02fd89a357135adca6d28cd0e45a69942c3a7b7b0550634f4016e639b0c2" name="ac3e5e02fd89a357135adca6d28cd0e45a69942c3a7b7b0550634f4016e639b0c2"></a>SLINK_ROUTE_SRC_LSB&#160;</td><td class="fielddoc"><p>SLINK routing register(4) (r/-): Source routing information LSB </p> +</td></tr> +<tr><td class="fieldname"><a id="ac3e5e02fd89a357135adca6d28cd0e45a7b7b0b9bd4fe448cae97a3a21460f983" name="ac3e5e02fd89a357135adca6d28cd0e45a7b7b0b9bd4fe448cae97a3a21460f983"></a>SLINK_ROUTE_SRC_MSB&#160;</td><td class="fielddoc"><p>SLINK routing register(7) (r/-): Source routing information MSB </p> +</td></tr> +</table> + +</div> +</div> +<a id="a84f7fe82f188bd4e68f41549587822bf" name="a84f7fe82f188bd4e68f41549587822bf"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a84f7fe82f188bd4e68f41549587822bf">&#9670;&#160;</a></span>NEORV32_SLINK_STATUS_enum</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">enum <a class="el" href="#a84f7fe82f188bd4e68f41549587822bf">NEORV32_SLINK_STATUS_enum</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>SLINK module hardware access (<a class="el" href="structneorv32__slink__t.html">neorv32_slink_t</a>) </p> +<table class="fieldtable"> +<tr><th colspan="2">Enumerator</th></tr><tr><td class="fieldname"><a id="a84f7fe82f188bd4e68f41549587822bfa9f24886f55b7f78ae8909ea8a573058c" name="a84f7fe82f188bd4e68f41549587822bfa9f24886f55b7f78ae8909ea8a573058c"></a>SLINK_FIFO_EMPTY&#160;</td><td class="fielddoc"><p>FIFO is empty </p> +</td></tr> +<tr><td class="fieldname"><a id="a84f7fe82f188bd4e68f41549587822bfadc37988b8aee38e85626064b2c3704f9" name="a84f7fe82f188bd4e68f41549587822bfadc37988b8aee38e85626064b2c3704f9"></a>SLINK_FIFO_HALF&#160;</td><td class="fielddoc"><p>FIFO is at least half full </p> +</td></tr> +<tr><td class="fieldname"><a id="a84f7fe82f188bd4e68f41549587822bfa2f96e61f0e07ef4ecd40f14e69b69211" name="a84f7fe82f188bd4e68f41549587822bfa2f96e61f0e07ef4ecd40f14e69b69211"></a>SLINK_FIFO_FULL&#160;</td><td class="fielddoc"><p>FIFO is full </p> +</td></tr> +</table> + +</div> +</div> +<h2 class="groupheader">Function Documentation</h2> +<a id="aaf0f7bc96b797e819ccaae94292d9ddb" name="aaf0f7bc96b797e819ccaae94292d9ddb"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aaf0f7bc96b797e819ccaae94292d9ddb">&#9670;&#160;</a></span>neorv32_slink_available()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_slink_available </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Check if stream link interface was synthesized.</p> +<dl class="section return"><dt>Returns</dt><dd>0 if SLINK was not synthesized, 1 if SLINK is available. </dd></dl> + +</div> +</div> +<a id="a3e02c558548c1c6178c49adee9a007f7" name="a3e02c558548c1c6178c49adee9a007f7"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a3e02c558548c1c6178c49adee9a007f7">&#9670;&#160;</a></span>neorv32_slink_check_last()</h2> + +<div class="memitem"> +<div class="memproto"> +<table class="mlabels"> + <tr> + <td class="mlabels-left"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_slink_check_last </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> + </td> + <td class="mlabels-right"> +<span class="mlabels"><span class="mlabel">inline</span></span> </td> + </tr> +</table> +</div><div class="memdoc"> +<p>Check if last RX word has "end-of-stream" delimiter.</p> +<dl class="section note"><dt>Note</dt><dd>This needs has to be called AFTER reading the actual data word using <a class="el" href="neorv32__slink_8c.html#ace319592c12dc6a0fe1b7dd66bdf9284">neorv32_slink_get(void)</a>.</dd></dl> +<dl class="section return"><dt>Returns</dt><dd>0 if not end of stream, !=0 if end of stream. </dd></dl> + +</div> +</div> +<a id="ace319592c12dc6a0fe1b7dd66bdf9284" name="ace319592c12dc6a0fe1b7dd66bdf9284"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ace319592c12dc6a0fe1b7dd66bdf9284">&#9670;&#160;</a></span>neorv32_slink_get()</h2> + +<div class="memitem"> +<div class="memproto"> +<table class="mlabels"> + <tr> + <td class="mlabels-left"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_slink_get </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> + </td> + <td class="mlabels-right"> +<span class="mlabels"><span class="mlabel">inline</span></span> </td> + </tr> +</table> +</div><div class="memdoc"> +<p>Read data from RX link (non-blocking)</p> +<dl class="section return"><dt>Returns</dt><dd>Data received from link. </dd></dl> + +</div> +</div> +<a id="a575c7663ca0bd07c95b1d45152a3ddf8" name="a575c7663ca0bd07c95b1d45152a3ddf8"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a575c7663ca0bd07c95b1d45152a3ddf8">&#9670;&#160;</a></span>neorv32_slink_get_rx_fifo_depth()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_slink_get_rx_fifo_depth </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Get FIFO depth of RX link.</p> +<dl class="section return"><dt>Returns</dt><dd>FIFO depth of RX link (1..32768). </dd></dl> + +</div> +</div> +<a id="a1a9269f42552a849450aecd99f7ec7a0" name="a1a9269f42552a849450aecd99f7ec7a0"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a1a9269f42552a849450aecd99f7ec7a0">&#9670;&#160;</a></span>neorv32_slink_get_src()</h2> + +<div class="memitem"> +<div class="memproto"> +<table class="mlabels"> + <tr> + <td class="mlabels-left"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_slink_get_src </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> + </td> + <td class="mlabels-right"> +<span class="mlabels"><span class="mlabel">inline</span></span> </td> + </tr> +</table> +</div><div class="memdoc"> +<p>Get RX link routing source</p> +<dl class="section note"><dt>Note</dt><dd>This needs has to be called AFTER reading the actual data word using <a class="el" href="neorv32__slink_8c.html#ace319592c12dc6a0fe1b7dd66bdf9284">neorv32_slink_get(void)</a>.</dd></dl> +<dl class="section return"><dt>Returns</dt><dd>4-bit source routing ID. </dd></dl> + +</div> +</div> +<a id="aaf0d0d1b890353d4f3bf49450ec2fad2" name="aaf0d0d1b890353d4f3bf49450ec2fad2"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aaf0d0d1b890353d4f3bf49450ec2fad2">&#9670;&#160;</a></span>neorv32_slink_get_tx_fifo_depth()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_slink_get_tx_fifo_depth </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Get FIFO depth of TX link.</p> +<dl class="section return"><dt>Returns</dt><dd>FIFO depth of TX link (1..32768). </dd></dl> + +</div> +</div> +<a id="aaa9fdb9cbfa7888e92790ab65431d21d" name="aaa9fdb9cbfa7888e92790ab65431d21d"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aaa9fdb9cbfa7888e92790ab65431d21d">&#9670;&#160;</a></span>neorv32_slink_put()</h2> + +<div class="memitem"> +<div class="memproto"> +<table class="mlabels"> + <tr> + <td class="mlabels-left"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_slink_put </td> + <td>(</td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>tx_data</em></span></td><td>)</td> + <td></td> + </tr> + </table> + </td> + <td class="mlabels-right"> +<span class="mlabels"><span class="mlabel">inline</span></span> </td> + </tr> +</table> +</div><div class="memdoc"> +<p>Write data to TX link (non-blocking)</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">tx_data</td><td>Data to send to link. </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="a2136bc0b12ee2e6703e84a6417a1e8eb" name="a2136bc0b12ee2e6703e84a6417a1e8eb"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a2136bc0b12ee2e6703e84a6417a1e8eb">&#9670;&#160;</a></span>neorv32_slink_put_last()</h2> + +<div class="memitem"> +<div class="memproto"> +<table class="mlabels"> + <tr> + <td class="mlabels-left"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_slink_put_last </td> + <td>(</td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>tx_data</em></span></td><td>)</td> + <td></td> + </tr> + </table> + </td> + <td class="mlabels-right"> +<span class="mlabels"><span class="mlabel">inline</span></span> </td> + </tr> +</table> +</div><div class="memdoc"> +<p>Write data to TX link (non-blocking) and set "last" (end-of-stream) delimiter.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">tx_data</td><td>Data to send to link. </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="ad149fea81e6d28f77450b8ba50cf706e" name="ad149fea81e6d28f77450b8ba50cf706e"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ad149fea81e6d28f77450b8ba50cf706e">&#9670;&#160;</a></span>neorv32_slink_rx_clear()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_slink_rx_clear </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Clear RX FIFO. </p> + +</div> +</div> +<a id="ad57fc0941fe32e8bf423ce3e57e2c10a" name="ad57fc0941fe32e8bf423ce3e57e2c10a"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ad57fc0941fe32e8bf423ce3e57e2c10a">&#9670;&#160;</a></span>neorv32_slink_rx_status()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_slink_rx_status </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Get RX link FIFO status.</p> +<dl class="section return"><dt>Returns</dt><dd>FIFO status <a class="el" href="#a84f7fe82f188bd4e68f41549587822bf">NEORV32_SLINK_STATUS_enum</a>. </dd></dl> + +</div> +</div> +<a id="ad857d7e78ca2b5eb0d0a4f2c515fe7bc" name="ad857d7e78ca2b5eb0d0a4f2c515fe7bc"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ad857d7e78ca2b5eb0d0a4f2c515fe7bc">&#9670;&#160;</a></span>neorv32_slink_set_dst()</h2> + +<div class="memitem"> +<div class="memproto"> +<table class="mlabels"> + <tr> + <td class="mlabels-left"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_slink_set_dst </td> + <td>(</td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>dst</em></span></td><td>)</td> + <td></td> + </tr> + </table> + </td> + <td class="mlabels-right"> +<span class="mlabels"><span class="mlabel">inline</span></span> </td> + </tr> +</table> +</div><div class="memdoc"> +<p>Set TX link routing destination</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">dst</td><td>Routing destination ID (4-bit, LSB-aligned). </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="a8f0b4a768f53a72a5c16034e160ce321" name="a8f0b4a768f53a72a5c16034e160ce321"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a8f0b4a768f53a72a5c16034e160ce321">&#9670;&#160;</a></span>neorv32_slink_setup()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_slink_setup </td> + <td>(</td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>rx_irq</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>tx_irq</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Reset, enable and configure SLINK.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">rx_irq</td><td>Configure RX interrupt conditions (<a class="el" href="#ac0385a56c38315d492b3414d98235ef1">NEORV32_SLINK_CTRL_enum</a>). </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">tx_irq</td><td>Configure TX interrupt conditions (<a class="el" href="#ac0385a56c38315d492b3414d98235ef1">NEORV32_SLINK_CTRL_enum</a>). </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="ac7484e9e3848f94efe016dd064f6a57f" name="ac7484e9e3848f94efe016dd064f6a57f"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ac7484e9e3848f94efe016dd064f6a57f">&#9670;&#160;</a></span>neorv32_slink_tx_clear()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_slink_tx_clear </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Clear TX FIFO. </p> + +</div> +</div> +<a id="ad0252e7ae915e5840cd17e8c52e94a1c" name="ad0252e7ae915e5840cd17e8c52e94a1c"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ad0252e7ae915e5840cd17e8c52e94a1c">&#9670;&#160;</a></span>neorv32_slink_tx_status()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_slink_tx_status </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Get TX link FIFO status.</p> +<dl class="section return"><dt>Returns</dt><dd>FIFO status <a class="el" href="#a84f7fe82f188bd4e68f41549587822bf">NEORV32_SLINK_STATUS_enum</a>. </dd></dl> + +</div> +</div> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/neorv32__slink_8h_source.html b/sw/neorv32__slink_8h_source.html new file mode 100644 index 0000000000..b57bb0668f --- /dev/null +++ b/sw/neorv32__slink_8h_source.html @@ -0,0 +1,235 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/lib/include/neorv32_slink.h Source File</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_7d04193005ada6f9450f847f4adb6b5b.html">lib</a></li><li class="navelem"><a class="el" href="dir_752b1e5d3973bf735fa78bf6b4727df9.html">include</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="headertitle"><div class="title">neorv32_slink.h</div></div> +</div><!--header--> +<div class="contents"> +<a href="neorv32__slink_8h.html">Go to the documentation of this file.</a><div class="fragment"><div class="line"><a id="l00001" name="l00001"></a><span class="lineno"> 1</span><span class="comment">// ================================================================================ //</span></div> +<div class="line"><a id="l00002" name="l00002"></a><span class="lineno"> 2</span><span class="comment">// The NEORV32 RISC-V Processor - https://github.com/stnolting/neorv32 //</span></div> +<div class="line"><a id="l00003" name="l00003"></a><span class="lineno"> 3</span><span class="comment">// Copyright (c) NEORV32 contributors. //</span></div> +<div class="line"><a id="l00004" name="l00004"></a><span class="lineno"> 4</span><span class="comment">// Copyright (c) 2020 - 2024 Stephan Nolting. All rights reserved. //</span></div> +<div class="line"><a id="l00005" name="l00005"></a><span class="lineno"> 5</span><span class="comment">// Licensed under the BSD-3-Clause license, see LICENSE for details. //</span></div> +<div class="line"><a id="l00006" name="l00006"></a><span class="lineno"> 6</span><span class="comment">// SPDX-License-Identifier: BSD-3-Clause //</span></div> +<div class="line"><a id="l00007" name="l00007"></a><span class="lineno"> 7</span><span class="comment">// ================================================================================ //</span></div> +<div class="line"><a id="l00008" name="l00008"></a><span class="lineno"> 8</span> </div> +<div class="line"><a id="l00016" name="l00016"></a><span class="lineno"> 16</span><span class="preprocessor">#ifndef neorv32_slink_h</span></div> +<div class="line"><a id="l00017" name="l00017"></a><span class="lineno"> 17</span><span class="preprocessor">#define neorv32_slink_h</span></div> +<div class="line"><a id="l00018" name="l00018"></a><span class="lineno"> 18</span> </div> +<div class="line"><a id="l00019" name="l00019"></a><span class="lineno"> 19</span><span class="preprocessor">#include &lt;stdint.h&gt;</span></div> +<div class="line"><a id="l00020" name="l00020"></a><span class="lineno"> 20</span> </div> +<div class="line"><a id="l00021" name="l00021"></a><span class="lineno"> 21</span> </div> +<div class="line"><a id="l00022" name="l00022"></a><span class="lineno"> 22</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen00027" data-start="{" data-end="};"> +<div class="line"><a id="l00027" name="l00027"></a><span class="lineno"><a class="line" href="structneorv32__slink__t.html"> 27</a></span><span class="keyword">typedef</span> <span class="keyword">volatile</span> <span class="keyword">struct </span>__attribute__((packed,aligned(4))) {</div> +<div class="line"><a id="l00028" name="l00028"></a><span class="lineno"><a class="line" href="structneorv32__slink__t.html#a39ece6aeeea6982002e164902a1e784f"> 28</a></span> uint32_t <a class="code hl_variable" href="structneorv32__slink__t.html#a39ece6aeeea6982002e164902a1e784f">CTRL</a>; </div> +<div class="line"><a id="l00029" name="l00029"></a><span class="lineno"><a class="line" href="structneorv32__slink__t.html#a0b2417a1a587da45909ce2a948f90e22"> 29</a></span> uint32_t <a class="code hl_variable" href="structneorv32__slink__t.html#a0b2417a1a587da45909ce2a948f90e22">ROUTE</a>; </div> +<div class="line"><a id="l00030" name="l00030"></a><span class="lineno"><a class="line" href="structneorv32__slink__t.html#a8af7d4ea9787cf94c599c82133c6aa74"> 30</a></span> uint32_t <a class="code hl_variable" href="structneorv32__slink__t.html#a8af7d4ea9787cf94c599c82133c6aa74">DATA</a>; </div> +<div class="line"><a id="l00031" name="l00031"></a><span class="lineno"><a class="line" href="structneorv32__slink__t.html#ada8f10141d2161b83a5a367722ed6a77"> 31</a></span> uint32_t <a class="code hl_variable" href="structneorv32__slink__t.html#ada8f10141d2161b83a5a367722ed6a77">DATA_LAST</a>; </div> +<div class="line"><a id="l00032" name="l00032"></a><span class="lineno"> 32</span>} <a class="code hl_struct" href="structneorv32__slink__t.html">neorv32_slink_t</a>;</div> +</div> +<div class="line"><a id="l00033" name="l00033"></a><span class="lineno"> 33</span> </div> +<div class="line"><a id="l00035" name="l00035"></a><span class="lineno"><a class="line" href="neorv32__slink_8h.html#a6380d894432de119a20993096db534df"> 35</a></span><span class="preprocessor">#define NEORV32_SLINK ((neorv32_slink_t*) (NEORV32_SLINK_BASE))</span></div> +<div class="line"><a id="l00036" name="l00036"></a><span class="lineno"> 36</span> </div> +<div class="foldopen" id="foldopen00038" data-start="{" data-end="};"> +<div class="line"><a id="l00038" name="l00038"></a><span class="lineno"><a class="line" href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1"> 38</a></span><span class="keyword">enum</span> <a class="code hl_enumeration" href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1">NEORV32_SLINK_CTRL_enum</a> {</div> +<div class="line"><a id="l00039" name="l00039"></a><span class="lineno"><a class="line" href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1a739187f413b7436dc4037187e4a9e86a"> 39</a></span> <a class="code hl_enumvalue" href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1a739187f413b7436dc4037187e4a9e86a">SLINK_CTRL_EN</a> = 0, </div> +<div class="line"><a id="l00040" name="l00040"></a><span class="lineno"><a class="line" href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1a156fa3209b2652af6b58b0fdfc6cab1b"> 40</a></span> <a class="code hl_enumvalue" href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1a156fa3209b2652af6b58b0fdfc6cab1b">SLINK_CTRL_RX_CLR</a> = 1, </div> +<div class="line"><a id="l00041" name="l00041"></a><span class="lineno"><a class="line" href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1ad366597a44d3dff7dbab4cde72bed82f"> 41</a></span> <a class="code hl_enumvalue" href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1ad366597a44d3dff7dbab4cde72bed82f">SLINK_CTRL_TX_CLR</a> = 2, </div> +<div class="line"><a id="l00043" name="l00043"></a><span class="lineno"><a class="line" href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1a624723683d247668ef44137393e576aa"> 43</a></span> <a class="code hl_enumvalue" href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1a624723683d247668ef44137393e576aa">SLINK_CTRL_RX_LAST</a> = 4, </div> +<div class="line"><a id="l00045" name="l00045"></a><span class="lineno"><a class="line" href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1ae78f82e54bd9d737bbcbc5c7af0e9d4b"> 45</a></span> <a class="code hl_enumvalue" href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1ae78f82e54bd9d737bbcbc5c7af0e9d4b">SLINK_CTRL_RX_EMPTY</a> = 8, </div> +<div class="line"><a id="l00046" name="l00046"></a><span class="lineno"><a class="line" href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1af695158b9cf5466d87c207f9bd0a688e"> 46</a></span> <a class="code hl_enumvalue" href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1af695158b9cf5466d87c207f9bd0a688e">SLINK_CTRL_RX_HALF</a> = 9, </div> +<div class="line"><a id="l00047" name="l00047"></a><span class="lineno"><a class="line" href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1aa7521fbe691fef233c0dff4053e4493e"> 47</a></span> <a class="code hl_enumvalue" href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1aa7521fbe691fef233c0dff4053e4493e">SLINK_CTRL_RX_FULL</a> = 10, </div> +<div class="line"><a id="l00048" name="l00048"></a><span class="lineno"><a class="line" href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1a308cf7829ecca32f7a3da1bd74339854"> 48</a></span> <a class="code hl_enumvalue" href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1a308cf7829ecca32f7a3da1bd74339854">SLINK_CTRL_TX_EMPTY</a> = 11, </div> +<div class="line"><a id="l00049" name="l00049"></a><span class="lineno"><a class="line" href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1a530b8b76301f36fbda134b330447de78"> 49</a></span> <a class="code hl_enumvalue" href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1a530b8b76301f36fbda134b330447de78">SLINK_CTRL_TX_HALF</a> = 12, </div> +<div class="line"><a id="l00050" name="l00050"></a><span class="lineno"><a class="line" href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1af94314ed65c6a8d9c364d99d7ae960ee"> 50</a></span> <a class="code hl_enumvalue" href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1af94314ed65c6a8d9c364d99d7ae960ee">SLINK_CTRL_TX_FULL</a> = 13, </div> +<div class="line"><a id="l00052" name="l00052"></a><span class="lineno"><a class="line" href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1a5452eab0fe12d174ec804c4c72060854"> 52</a></span> <a class="code hl_enumvalue" href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1a5452eab0fe12d174ec804c4c72060854">SLINK_CTRL_IRQ_RX_NEMPTY</a> = 16, </div> +<div class="line"><a id="l00053" name="l00053"></a><span class="lineno"><a class="line" href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1afa9353cd824d1b2833930ce9e922e392"> 53</a></span> <a class="code hl_enumvalue" href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1afa9353cd824d1b2833930ce9e922e392">SLINK_CTRL_IRQ_RX_HALF</a> = 17, </div> +<div class="line"><a id="l00054" name="l00054"></a><span class="lineno"><a class="line" href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1ac8a688706aee72d2027e022b64664309"> 54</a></span> <a class="code hl_enumvalue" href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1ac8a688706aee72d2027e022b64664309">SLINK_CTRL_IRQ_RX_FULL</a> = 18, </div> +<div class="line"><a id="l00055" name="l00055"></a><span class="lineno"><a class="line" href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1ae06ad5f627f8902e2368e0daff6cfa88"> 55</a></span> <a class="code hl_enumvalue" href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1ae06ad5f627f8902e2368e0daff6cfa88">SLINK_CTRL_IRQ_TX_EMPTY</a> = 19, </div> +<div class="line"><a id="l00056" name="l00056"></a><span class="lineno"><a class="line" href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1a7bf757dbfb1fdaddceaed3a3887003cf"> 56</a></span> <a class="code hl_enumvalue" href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1a7bf757dbfb1fdaddceaed3a3887003cf">SLINK_CTRL_IRQ_TX_NHALF</a> = 20, </div> +<div class="line"><a id="l00057" name="l00057"></a><span class="lineno"><a class="line" href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1a8f994f256f57c006c88b9e38df3f54fa"> 57</a></span> <a class="code hl_enumvalue" href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1a8f994f256f57c006c88b9e38df3f54fa">SLINK_CTRL_IRQ_TX_NFULL</a> = 21, </div> +<div class="line"><a id="l00059" name="l00059"></a><span class="lineno"><a class="line" href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1a9c68af961c1147846929ca55e9e4e88c"> 59</a></span> <a class="code hl_enumvalue" href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1a9c68af961c1147846929ca55e9e4e88c">SLINK_CTRL_RX_FIFO_LSB</a> = 24, </div> +<div class="line"><a id="l00060" name="l00060"></a><span class="lineno"><a class="line" href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1a945e2b7eda65dc13ca38eb21c9c4f657"> 60</a></span> <a class="code hl_enumvalue" href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1a945e2b7eda65dc13ca38eb21c9c4f657">SLINK_CTRL_RX_FIFO_MSB</a> = 27, </div> +<div class="line"><a id="l00061" name="l00061"></a><span class="lineno"><a class="line" href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1aba613343fc17715fc1bb07729588a12d"> 61</a></span> <a class="code hl_enumvalue" href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1aba613343fc17715fc1bb07729588a12d">SLINK_CTRL_TX_FIFO_LSB</a> = 28, </div> +<div class="line"><a id="l00062" name="l00062"></a><span class="lineno"> 62</span> <a class="code hl_enumvalue" href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1af27a9e6e50b169d3f5efd0a08ba4a943">SLINK_CTRL_TX_FIFO_MSB</a> = 31 </div> +<div class="line"><a id="l00063" name="l00063"></a><span class="lineno"><a class="line" href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1af27a9e6e50b169d3f5efd0a08ba4a943"> 63</a></span>};</div> +</div> +<div class="line"><a id="l00064" name="l00064"></a><span class="lineno"> 64</span> </div> +<div class="foldopen" id="foldopen00066" data-start="{" data-end="};"> +<div class="line"><a id="l00066" name="l00066"></a><span class="lineno"><a class="line" href="neorv32__slink_8h.html#ac3e5e02fd89a357135adca6d28cd0e45"> 66</a></span><span class="keyword">enum</span> <a class="code hl_enumeration" href="neorv32__slink_8h.html#ac3e5e02fd89a357135adca6d28cd0e45">NEORV32_SLINK_ROUTE_enum</a> {</div> +<div class="line"><a id="l00067" name="l00067"></a><span class="lineno"><a class="line" href="neorv32__slink_8h.html#ac3e5e02fd89a357135adca6d28cd0e45a9a2311357bd87c85a5cc45f08b0d8f80"> 67</a></span> <a class="code hl_enumvalue" href="neorv32__slink_8h.html#ac3e5e02fd89a357135adca6d28cd0e45a9a2311357bd87c85a5cc45f08b0d8f80">SLINK_ROUTE_DST_LSB</a> = 0, </div> +<div class="line"><a id="l00068" name="l00068"></a><span class="lineno"><a class="line" href="neorv32__slink_8h.html#ac3e5e02fd89a357135adca6d28cd0e45a7e8da208ecaf142107587033e2d63ec1"> 68</a></span> <a class="code hl_enumvalue" href="neorv32__slink_8h.html#ac3e5e02fd89a357135adca6d28cd0e45a7e8da208ecaf142107587033e2d63ec1">SLINK_ROUTE_DST_MSB</a> = 3, </div> +<div class="line"><a id="l00069" name="l00069"></a><span class="lineno"><a class="line" href="neorv32__slink_8h.html#ac3e5e02fd89a357135adca6d28cd0e45a69942c3a7b7b0550634f4016e639b0c2"> 69</a></span> <a class="code hl_enumvalue" href="neorv32__slink_8h.html#ac3e5e02fd89a357135adca6d28cd0e45a69942c3a7b7b0550634f4016e639b0c2">SLINK_ROUTE_SRC_LSB</a> = 4, </div> +<div class="line"><a id="l00070" name="l00070"></a><span class="lineno"> 70</span> <a class="code hl_enumvalue" href="neorv32__slink_8h.html#ac3e5e02fd89a357135adca6d28cd0e45a7b7b0b9bd4fe448cae97a3a21460f983">SLINK_ROUTE_SRC_MSB</a> = 7 </div> +<div class="line"><a id="l00071" name="l00071"></a><span class="lineno"><a class="line" href="neorv32__slink_8h.html#ac3e5e02fd89a357135adca6d28cd0e45a7b7b0b9bd4fe448cae97a3a21460f983"> 71</a></span>};</div> +</div> +<div class="line"><a id="l00072" name="l00072"></a><span class="lineno"> 72</span> </div> +<div class="foldopen" id="foldopen00073" data-start="{" data-end="};"> +<div class="line"><a id="l00073" name="l00073"></a><span class="lineno"><a class="line" href="neorv32__slink_8h.html#a84f7fe82f188bd4e68f41549587822bf"> 73</a></span><span class="keyword">enum</span> <a class="code hl_enumeration" href="neorv32__slink_8h.html#a84f7fe82f188bd4e68f41549587822bf">NEORV32_SLINK_STATUS_enum</a> {</div> +<div class="line"><a id="l00074" name="l00074"></a><span class="lineno"><a class="line" href="neorv32__slink_8h.html#a84f7fe82f188bd4e68f41549587822bfa9f24886f55b7f78ae8909ea8a573058c"> 74</a></span> <a class="code hl_enumvalue" href="neorv32__slink_8h.html#a84f7fe82f188bd4e68f41549587822bfa9f24886f55b7f78ae8909ea8a573058c">SLINK_FIFO_EMPTY</a> = 0, </div> +<div class="line"><a id="l00075" name="l00075"></a><span class="lineno"><a class="line" href="neorv32__slink_8h.html#a84f7fe82f188bd4e68f41549587822bfadc37988b8aee38e85626064b2c3704f9"> 75</a></span> <a class="code hl_enumvalue" href="neorv32__slink_8h.html#a84f7fe82f188bd4e68f41549587822bfadc37988b8aee38e85626064b2c3704f9">SLINK_FIFO_HALF</a> = 1, </div> +<div class="line"><a id="l00076" name="l00076"></a><span class="lineno"> 76</span> <a class="code hl_enumvalue" href="neorv32__slink_8h.html#a84f7fe82f188bd4e68f41549587822bfa2f96e61f0e07ef4ecd40f14e69b69211">SLINK_FIFO_FULL</a> = 2 </div> +<div class="line"><a id="l00077" name="l00077"></a><span class="lineno"><a class="line" href="neorv32__slink_8h.html#a84f7fe82f188bd4e68f41549587822bfa2f96e61f0e07ef4ecd40f14e69b69211"> 77</a></span>};</div> +</div> +<div class="line"><a id="l00081" name="l00081"></a><span class="lineno"> 81</span><span class="comment">/**********************************************************************/</span></div> +<div class="line"><a id="l00085" name="l00085"></a><span class="lineno"> 85</span><span class="keywordtype">int</span> <a class="code hl_function" href="neorv32__slink_8h.html#aaf0f7bc96b797e819ccaae94292d9ddb">neorv32_slink_available</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00086" name="l00086"></a><span class="lineno"> 86</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__slink_8h.html#a8f0b4a768f53a72a5c16034e160ce321">neorv32_slink_setup</a>(uint32_t rx_irq, uint32_t tx_irq);</div> +<div class="line"><a id="l00087" name="l00087"></a><span class="lineno"> 87</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__slink_8h.html#ad149fea81e6d28f77450b8ba50cf706e">neorv32_slink_rx_clear</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00088" name="l00088"></a><span class="lineno"> 88</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__slink_8h.html#ac7484e9e3848f94efe016dd064f6a57f">neorv32_slink_tx_clear</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00089" name="l00089"></a><span class="lineno"> 89</span><span class="keywordtype">int</span> <a class="code hl_function" href="neorv32__slink_8h.html#a575c7663ca0bd07c95b1d45152a3ddf8">neorv32_slink_get_rx_fifo_depth</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00090" name="l00090"></a><span class="lineno"> 90</span><span class="keywordtype">int</span> <a class="code hl_function" href="neorv32__slink_8h.html#aaf0d0d1b890353d4f3bf49450ec2fad2">neorv32_slink_get_tx_fifo_depth</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00091" name="l00091"></a><span class="lineno"> 91</span>uint32_t <a class="code hl_function" href="neorv32__slink_8h.html#ace319592c12dc6a0fe1b7dd66bdf9284">neorv32_slink_get</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00092" name="l00092"></a><span class="lineno"> 92</span>uint32_t <a class="code hl_function" href="neorv32__slink_8h.html#a3e02c558548c1c6178c49adee9a007f7">neorv32_slink_check_last</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00093" name="l00093"></a><span class="lineno"> 93</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__slink_8h.html#ad857d7e78ca2b5eb0d0a4f2c515fe7bc">neorv32_slink_set_dst</a>(uint32_t dst);</div> +<div class="line"><a id="l00094" name="l00094"></a><span class="lineno"> 94</span>uint32_t <a class="code hl_function" href="neorv32__slink_8h.html#a1a9269f42552a849450aecd99f7ec7a0">neorv32_slink_get_src</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00095" name="l00095"></a><span class="lineno"> 95</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__slink_8h.html#aaa9fdb9cbfa7888e92790ab65431d21d">neorv32_slink_put</a>(uint32_t tx_data);</div> +<div class="line"><a id="l00096" name="l00096"></a><span class="lineno"> 96</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__slink_8h.html#a2136bc0b12ee2e6703e84a6417a1e8eb">neorv32_slink_put_last</a>(uint32_t tx_data);</div> +<div class="line"><a id="l00097" name="l00097"></a><span class="lineno"> 97</span><span class="keywordtype">int</span> <a class="code hl_function" href="neorv32__slink_8h.html#ad57fc0941fe32e8bf423ce3e57e2c10a">neorv32_slink_rx_status</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00098" name="l00098"></a><span class="lineno"> 98</span><span class="keywordtype">int</span> <a class="code hl_function" href="neorv32__slink_8h.html#ad0252e7ae915e5840cd17e8c52e94a1c">neorv32_slink_tx_status</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00102" name="l00102"></a><span class="lineno"> 102</span><span class="preprocessor">#endif </span><span class="comment">// neorv32_slink_h</span></div> +<div class="ttc" id="aneorv32__slink_8h_html_a1a9269f42552a849450aecd99f7ec7a0"><div class="ttname"><a href="neorv32__slink_8h.html#a1a9269f42552a849450aecd99f7ec7a0">neorv32_slink_get_src</a></div><div class="ttdeci">uint32_t neorv32_slink_get_src(void)</div><div class="ttdef"><b>Definition</b> neorv32_slink.c:148</div></div> +<div class="ttc" id="aneorv32__slink_8h_html_a2136bc0b12ee2e6703e84a6417a1e8eb"><div class="ttname"><a href="neorv32__slink_8h.html#a2136bc0b12ee2e6703e84a6417a1e8eb">neorv32_slink_put_last</a></div><div class="ttdeci">void neorv32_slink_put_last(uint32_t tx_data)</div><div class="ttdef"><b>Definition</b> neorv32_slink.c:171</div></div> +<div class="ttc" id="aneorv32__slink_8h_html_a3e02c558548c1c6178c49adee9a007f7"><div class="ttname"><a href="neorv32__slink_8h.html#a3e02c558548c1c6178c49adee9a007f7">neorv32_slink_check_last</a></div><div class="ttdeci">uint32_t neorv32_slink_check_last(void)</div><div class="ttdef"><b>Definition</b> neorv32_slink.c:123</div></div> +<div class="ttc" id="aneorv32__slink_8h_html_a575c7663ca0bd07c95b1d45152a3ddf8"><div class="ttname"><a href="neorv32__slink_8h.html#a575c7663ca0bd07c95b1d45152a3ddf8">neorv32_slink_get_rx_fifo_depth</a></div><div class="ttdeci">int neorv32_slink_get_rx_fifo_depth(void)</div><div class="ttdef"><b>Definition</b> neorv32_slink.c:85</div></div> +<div class="ttc" id="aneorv32__slink_8h_html_a84f7fe82f188bd4e68f41549587822bf"><div class="ttname"><a href="neorv32__slink_8h.html#a84f7fe82f188bd4e68f41549587822bf">NEORV32_SLINK_STATUS_enum</a></div><div class="ttdeci">NEORV32_SLINK_STATUS_enum</div><div class="ttdef"><b>Definition</b> neorv32_slink.h:73</div></div> +<div class="ttc" id="aneorv32__slink_8h_html_a84f7fe82f188bd4e68f41549587822bfa2f96e61f0e07ef4ecd40f14e69b69211"><div class="ttname"><a href="neorv32__slink_8h.html#a84f7fe82f188bd4e68f41549587822bfa2f96e61f0e07ef4ecd40f14e69b69211">SLINK_FIFO_FULL</a></div><div class="ttdeci">@ SLINK_FIFO_FULL</div><div class="ttdef"><b>Definition</b> neorv32_slink.h:76</div></div> +<div class="ttc" id="aneorv32__slink_8h_html_a84f7fe82f188bd4e68f41549587822bfa9f24886f55b7f78ae8909ea8a573058c"><div class="ttname"><a href="neorv32__slink_8h.html#a84f7fe82f188bd4e68f41549587822bfa9f24886f55b7f78ae8909ea8a573058c">SLINK_FIFO_EMPTY</a></div><div class="ttdeci">@ SLINK_FIFO_EMPTY</div><div class="ttdef"><b>Definition</b> neorv32_slink.h:74</div></div> +<div class="ttc" id="aneorv32__slink_8h_html_a84f7fe82f188bd4e68f41549587822bfadc37988b8aee38e85626064b2c3704f9"><div class="ttname"><a href="neorv32__slink_8h.html#a84f7fe82f188bd4e68f41549587822bfadc37988b8aee38e85626064b2c3704f9">SLINK_FIFO_HALF</a></div><div class="ttdeci">@ SLINK_FIFO_HALF</div><div class="ttdef"><b>Definition</b> neorv32_slink.h:75</div></div> +<div class="ttc" id="aneorv32__slink_8h_html_a8f0b4a768f53a72a5c16034e160ce321"><div class="ttname"><a href="neorv32__slink_8h.html#a8f0b4a768f53a72a5c16034e160ce321">neorv32_slink_setup</a></div><div class="ttdeci">void neorv32_slink_setup(uint32_t rx_irq, uint32_t tx_irq)</div><div class="ttdef"><b>Definition</b> neorv32_slink.c:43</div></div> +<div class="ttc" id="aneorv32__slink_8h_html_aaa9fdb9cbfa7888e92790ab65431d21d"><div class="ttname"><a href="neorv32__slink_8h.html#aaa9fdb9cbfa7888e92790ab65431d21d">neorv32_slink_put</a></div><div class="ttdeci">void neorv32_slink_put(uint32_t tx_data)</div><div class="ttdef"><b>Definition</b> neorv32_slink.c:159</div></div> +<div class="ttc" id="aneorv32__slink_8h_html_aaf0d0d1b890353d4f3bf49450ec2fad2"><div class="ttname"><a href="neorv32__slink_8h.html#aaf0d0d1b890353d4f3bf49450ec2fad2">neorv32_slink_get_tx_fifo_depth</a></div><div class="ttdeci">int neorv32_slink_get_tx_fifo_depth(void)</div><div class="ttdef"><b>Definition</b> neorv32_slink.c:97</div></div> +<div class="ttc" id="aneorv32__slink_8h_html_aaf0f7bc96b797e819ccaae94292d9ddb"><div class="ttname"><a href="neorv32__slink_8h.html#aaf0f7bc96b797e819ccaae94292d9ddb">neorv32_slink_available</a></div><div class="ttdeci">int neorv32_slink_available(void)</div><div class="ttdef"><b>Definition</b> neorv32_slink.c:26</div></div> +<div class="ttc" id="aneorv32__slink_8h_html_ac0385a56c38315d492b3414d98235ef1"><div class="ttname"><a href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1">NEORV32_SLINK_CTRL_enum</a></div><div class="ttdeci">NEORV32_SLINK_CTRL_enum</div><div class="ttdef"><b>Definition</b> neorv32_slink.h:38</div></div> +<div class="ttc" id="aneorv32__slink_8h_html_ac0385a56c38315d492b3414d98235ef1a156fa3209b2652af6b58b0fdfc6cab1b"><div class="ttname"><a href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1a156fa3209b2652af6b58b0fdfc6cab1b">SLINK_CTRL_RX_CLR</a></div><div class="ttdeci">@ SLINK_CTRL_RX_CLR</div><div class="ttdef"><b>Definition</b> neorv32_slink.h:40</div></div> +<div class="ttc" id="aneorv32__slink_8h_html_ac0385a56c38315d492b3414d98235ef1a308cf7829ecca32f7a3da1bd74339854"><div class="ttname"><a href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1a308cf7829ecca32f7a3da1bd74339854">SLINK_CTRL_TX_EMPTY</a></div><div class="ttdeci">@ SLINK_CTRL_TX_EMPTY</div><div class="ttdef"><b>Definition</b> neorv32_slink.h:48</div></div> +<div class="ttc" id="aneorv32__slink_8h_html_ac0385a56c38315d492b3414d98235ef1a530b8b76301f36fbda134b330447de78"><div class="ttname"><a href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1a530b8b76301f36fbda134b330447de78">SLINK_CTRL_TX_HALF</a></div><div class="ttdeci">@ SLINK_CTRL_TX_HALF</div><div class="ttdef"><b>Definition</b> neorv32_slink.h:49</div></div> +<div class="ttc" id="aneorv32__slink_8h_html_ac0385a56c38315d492b3414d98235ef1a5452eab0fe12d174ec804c4c72060854"><div class="ttname"><a href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1a5452eab0fe12d174ec804c4c72060854">SLINK_CTRL_IRQ_RX_NEMPTY</a></div><div class="ttdeci">@ SLINK_CTRL_IRQ_RX_NEMPTY</div><div class="ttdef"><b>Definition</b> neorv32_slink.h:52</div></div> +<div class="ttc" id="aneorv32__slink_8h_html_ac0385a56c38315d492b3414d98235ef1a624723683d247668ef44137393e576aa"><div class="ttname"><a href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1a624723683d247668ef44137393e576aa">SLINK_CTRL_RX_LAST</a></div><div class="ttdeci">@ SLINK_CTRL_RX_LAST</div><div class="ttdef"><b>Definition</b> neorv32_slink.h:43</div></div> +<div class="ttc" id="aneorv32__slink_8h_html_ac0385a56c38315d492b3414d98235ef1a739187f413b7436dc4037187e4a9e86a"><div class="ttname"><a href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1a739187f413b7436dc4037187e4a9e86a">SLINK_CTRL_EN</a></div><div class="ttdeci">@ SLINK_CTRL_EN</div><div class="ttdef"><b>Definition</b> neorv32_slink.h:39</div></div> +<div class="ttc" id="aneorv32__slink_8h_html_ac0385a56c38315d492b3414d98235ef1a7bf757dbfb1fdaddceaed3a3887003cf"><div class="ttname"><a href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1a7bf757dbfb1fdaddceaed3a3887003cf">SLINK_CTRL_IRQ_TX_NHALF</a></div><div class="ttdeci">@ SLINK_CTRL_IRQ_TX_NHALF</div><div class="ttdef"><b>Definition</b> neorv32_slink.h:56</div></div> +<div class="ttc" id="aneorv32__slink_8h_html_ac0385a56c38315d492b3414d98235ef1a8f994f256f57c006c88b9e38df3f54fa"><div class="ttname"><a href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1a8f994f256f57c006c88b9e38df3f54fa">SLINK_CTRL_IRQ_TX_NFULL</a></div><div class="ttdeci">@ SLINK_CTRL_IRQ_TX_NFULL</div><div class="ttdef"><b>Definition</b> neorv32_slink.h:57</div></div> +<div class="ttc" id="aneorv32__slink_8h_html_ac0385a56c38315d492b3414d98235ef1a945e2b7eda65dc13ca38eb21c9c4f657"><div class="ttname"><a href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1a945e2b7eda65dc13ca38eb21c9c4f657">SLINK_CTRL_RX_FIFO_MSB</a></div><div class="ttdeci">@ SLINK_CTRL_RX_FIFO_MSB</div><div class="ttdef"><b>Definition</b> neorv32_slink.h:60</div></div> +<div class="ttc" id="aneorv32__slink_8h_html_ac0385a56c38315d492b3414d98235ef1a9c68af961c1147846929ca55e9e4e88c"><div class="ttname"><a href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1a9c68af961c1147846929ca55e9e4e88c">SLINK_CTRL_RX_FIFO_LSB</a></div><div class="ttdeci">@ SLINK_CTRL_RX_FIFO_LSB</div><div class="ttdef"><b>Definition</b> neorv32_slink.h:59</div></div> +<div class="ttc" id="aneorv32__slink_8h_html_ac0385a56c38315d492b3414d98235ef1aa7521fbe691fef233c0dff4053e4493e"><div class="ttname"><a href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1aa7521fbe691fef233c0dff4053e4493e">SLINK_CTRL_RX_FULL</a></div><div class="ttdeci">@ SLINK_CTRL_RX_FULL</div><div class="ttdef"><b>Definition</b> neorv32_slink.h:47</div></div> +<div class="ttc" id="aneorv32__slink_8h_html_ac0385a56c38315d492b3414d98235ef1aba613343fc17715fc1bb07729588a12d"><div class="ttname"><a href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1aba613343fc17715fc1bb07729588a12d">SLINK_CTRL_TX_FIFO_LSB</a></div><div class="ttdeci">@ SLINK_CTRL_TX_FIFO_LSB</div><div class="ttdef"><b>Definition</b> neorv32_slink.h:61</div></div> +<div class="ttc" id="aneorv32__slink_8h_html_ac0385a56c38315d492b3414d98235ef1ac8a688706aee72d2027e022b64664309"><div class="ttname"><a href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1ac8a688706aee72d2027e022b64664309">SLINK_CTRL_IRQ_RX_FULL</a></div><div class="ttdeci">@ SLINK_CTRL_IRQ_RX_FULL</div><div class="ttdef"><b>Definition</b> neorv32_slink.h:54</div></div> +<div class="ttc" id="aneorv32__slink_8h_html_ac0385a56c38315d492b3414d98235ef1ad366597a44d3dff7dbab4cde72bed82f"><div class="ttname"><a href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1ad366597a44d3dff7dbab4cde72bed82f">SLINK_CTRL_TX_CLR</a></div><div class="ttdeci">@ SLINK_CTRL_TX_CLR</div><div class="ttdef"><b>Definition</b> neorv32_slink.h:41</div></div> +<div class="ttc" id="aneorv32__slink_8h_html_ac0385a56c38315d492b3414d98235ef1ae06ad5f627f8902e2368e0daff6cfa88"><div class="ttname"><a href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1ae06ad5f627f8902e2368e0daff6cfa88">SLINK_CTRL_IRQ_TX_EMPTY</a></div><div class="ttdeci">@ SLINK_CTRL_IRQ_TX_EMPTY</div><div class="ttdef"><b>Definition</b> neorv32_slink.h:55</div></div> +<div class="ttc" id="aneorv32__slink_8h_html_ac0385a56c38315d492b3414d98235ef1ae78f82e54bd9d737bbcbc5c7af0e9d4b"><div class="ttname"><a href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1ae78f82e54bd9d737bbcbc5c7af0e9d4b">SLINK_CTRL_RX_EMPTY</a></div><div class="ttdeci">@ SLINK_CTRL_RX_EMPTY</div><div class="ttdef"><b>Definition</b> neorv32_slink.h:45</div></div> +<div class="ttc" id="aneorv32__slink_8h_html_ac0385a56c38315d492b3414d98235ef1af27a9e6e50b169d3f5efd0a08ba4a943"><div class="ttname"><a href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1af27a9e6e50b169d3f5efd0a08ba4a943">SLINK_CTRL_TX_FIFO_MSB</a></div><div class="ttdeci">@ SLINK_CTRL_TX_FIFO_MSB</div><div class="ttdef"><b>Definition</b> neorv32_slink.h:62</div></div> +<div class="ttc" id="aneorv32__slink_8h_html_ac0385a56c38315d492b3414d98235ef1af695158b9cf5466d87c207f9bd0a688e"><div class="ttname"><a href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1af695158b9cf5466d87c207f9bd0a688e">SLINK_CTRL_RX_HALF</a></div><div class="ttdeci">@ SLINK_CTRL_RX_HALF</div><div class="ttdef"><b>Definition</b> neorv32_slink.h:46</div></div> +<div class="ttc" id="aneorv32__slink_8h_html_ac0385a56c38315d492b3414d98235ef1af94314ed65c6a8d9c364d99d7ae960ee"><div class="ttname"><a href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1af94314ed65c6a8d9c364d99d7ae960ee">SLINK_CTRL_TX_FULL</a></div><div class="ttdeci">@ SLINK_CTRL_TX_FULL</div><div class="ttdef"><b>Definition</b> neorv32_slink.h:50</div></div> +<div class="ttc" id="aneorv32__slink_8h_html_ac0385a56c38315d492b3414d98235ef1afa9353cd824d1b2833930ce9e922e392"><div class="ttname"><a href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1afa9353cd824d1b2833930ce9e922e392">SLINK_CTRL_IRQ_RX_HALF</a></div><div class="ttdeci">@ SLINK_CTRL_IRQ_RX_HALF</div><div class="ttdef"><b>Definition</b> neorv32_slink.h:53</div></div> +<div class="ttc" id="aneorv32__slink_8h_html_ac3e5e02fd89a357135adca6d28cd0e45"><div class="ttname"><a href="neorv32__slink_8h.html#ac3e5e02fd89a357135adca6d28cd0e45">NEORV32_SLINK_ROUTE_enum</a></div><div class="ttdeci">NEORV32_SLINK_ROUTE_enum</div><div class="ttdef"><b>Definition</b> neorv32_slink.h:66</div></div> +<div class="ttc" id="aneorv32__slink_8h_html_ac3e5e02fd89a357135adca6d28cd0e45a69942c3a7b7b0550634f4016e639b0c2"><div class="ttname"><a href="neorv32__slink_8h.html#ac3e5e02fd89a357135adca6d28cd0e45a69942c3a7b7b0550634f4016e639b0c2">SLINK_ROUTE_SRC_LSB</a></div><div class="ttdeci">@ SLINK_ROUTE_SRC_LSB</div><div class="ttdef"><b>Definition</b> neorv32_slink.h:69</div></div> +<div class="ttc" id="aneorv32__slink_8h_html_ac3e5e02fd89a357135adca6d28cd0e45a7b7b0b9bd4fe448cae97a3a21460f983"><div class="ttname"><a href="neorv32__slink_8h.html#ac3e5e02fd89a357135adca6d28cd0e45a7b7b0b9bd4fe448cae97a3a21460f983">SLINK_ROUTE_SRC_MSB</a></div><div class="ttdeci">@ SLINK_ROUTE_SRC_MSB</div><div class="ttdef"><b>Definition</b> neorv32_slink.h:70</div></div> +<div class="ttc" id="aneorv32__slink_8h_html_ac3e5e02fd89a357135adca6d28cd0e45a7e8da208ecaf142107587033e2d63ec1"><div class="ttname"><a href="neorv32__slink_8h.html#ac3e5e02fd89a357135adca6d28cd0e45a7e8da208ecaf142107587033e2d63ec1">SLINK_ROUTE_DST_MSB</a></div><div class="ttdeci">@ SLINK_ROUTE_DST_MSB</div><div class="ttdef"><b>Definition</b> neorv32_slink.h:68</div></div> +<div class="ttc" id="aneorv32__slink_8h_html_ac3e5e02fd89a357135adca6d28cd0e45a9a2311357bd87c85a5cc45f08b0d8f80"><div class="ttname"><a href="neorv32__slink_8h.html#ac3e5e02fd89a357135adca6d28cd0e45a9a2311357bd87c85a5cc45f08b0d8f80">SLINK_ROUTE_DST_LSB</a></div><div class="ttdeci">@ SLINK_ROUTE_DST_LSB</div><div class="ttdef"><b>Definition</b> neorv32_slink.h:67</div></div> +<div class="ttc" id="aneorv32__slink_8h_html_ac7484e9e3848f94efe016dd064f6a57f"><div class="ttname"><a href="neorv32__slink_8h.html#ac7484e9e3848f94efe016dd064f6a57f">neorv32_slink_tx_clear</a></div><div class="ttdeci">void neorv32_slink_tx_clear(void)</div><div class="ttdef"><b>Definition</b> neorv32_slink.c:74</div></div> +<div class="ttc" id="aneorv32__slink_8h_html_ace319592c12dc6a0fe1b7dd66bdf9284"><div class="ttname"><a href="neorv32__slink_8h.html#ace319592c12dc6a0fe1b7dd66bdf9284">neorv32_slink_get</a></div><div class="ttdeci">uint32_t neorv32_slink_get(void)</div><div class="ttdef"><b>Definition</b> neorv32_slink.c:109</div></div> +<div class="ttc" id="aneorv32__slink_8h_html_ad0252e7ae915e5840cd17e8c52e94a1c"><div class="ttname"><a href="neorv32__slink_8h.html#ad0252e7ae915e5840cd17e8c52e94a1c">neorv32_slink_tx_status</a></div><div class="ttdeci">int neorv32_slink_tx_status(void)</div><div class="ttdef"><b>Definition</b> neorv32_slink.c:206</div></div> +<div class="ttc" id="aneorv32__slink_8h_html_ad149fea81e6d28f77450b8ba50cf706e"><div class="ttname"><a href="neorv32__slink_8h.html#ad149fea81e6d28f77450b8ba50cf706e">neorv32_slink_rx_clear</a></div><div class="ttdeci">void neorv32_slink_rx_clear(void)</div><div class="ttdef"><b>Definition</b> neorv32_slink.c:65</div></div> +<div class="ttc" id="aneorv32__slink_8h_html_ad57fc0941fe32e8bf423ce3e57e2c10a"><div class="ttname"><a href="neorv32__slink_8h.html#ad57fc0941fe32e8bf423ce3e57e2c10a">neorv32_slink_rx_status</a></div><div class="ttdeci">int neorv32_slink_rx_status(void)</div><div class="ttdef"><b>Definition</b> neorv32_slink.c:182</div></div> +<div class="ttc" id="aneorv32__slink_8h_html_ad857d7e78ca2b5eb0d0a4f2c515fe7bc"><div class="ttname"><a href="neorv32__slink_8h.html#ad857d7e78ca2b5eb0d0a4f2c515fe7bc">neorv32_slink_set_dst</a></div><div class="ttdeci">void neorv32_slink_set_dst(uint32_t dst)</div><div class="ttdef"><b>Definition</b> neorv32_slink.c:134</div></div> +<div class="ttc" id="astructneorv32__slink__t_html"><div class="ttname"><a href="structneorv32__slink__t.html">neorv32_slink_t</a></div><div class="ttdef"><b>Definition</b> neorv32_slink.h:27</div></div> +<div class="ttc" id="astructneorv32__slink__t_html_a0b2417a1a587da45909ce2a948f90e22"><div class="ttname"><a href="structneorv32__slink__t.html#a0b2417a1a587da45909ce2a948f90e22">neorv32_slink_t::ROUTE</a></div><div class="ttdeci">uint32_t ROUTE</div><div class="ttdef"><b>Definition</b> neorv32_slink.h:29</div></div> +<div class="ttc" id="astructneorv32__slink__t_html_a39ece6aeeea6982002e164902a1e784f"><div class="ttname"><a href="structneorv32__slink__t.html#a39ece6aeeea6982002e164902a1e784f">neorv32_slink_t::CTRL</a></div><div class="ttdeci">uint32_t CTRL</div><div class="ttdef"><b>Definition</b> neorv32_slink.h:28</div></div> +<div class="ttc" id="astructneorv32__slink__t_html_a8af7d4ea9787cf94c599c82133c6aa74"><div class="ttname"><a href="structneorv32__slink__t.html#a8af7d4ea9787cf94c599c82133c6aa74">neorv32_slink_t::DATA</a></div><div class="ttdeci">uint32_t DATA</div><div class="ttdef"><b>Definition</b> neorv32_slink.h:30</div></div> +<div class="ttc" id="astructneorv32__slink__t_html_ada8f10141d2161b83a5a367722ed6a77"><div class="ttname"><a href="structneorv32__slink__t.html#ada8f10141d2161b83a5a367722ed6a77">neorv32_slink_t::DATA_LAST</a></div><div class="ttdeci">uint32_t DATA_LAST</div><div class="ttdef"><b>Definition</b> neorv32_slink.h:31</div></div> +</div><!-- fragment --></div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/neorv32__spi_8c.html b/sw/neorv32__spi_8c.html new file mode 100644 index 0000000000..5b131572cb --- /dev/null +++ b/sw/neorv32__spi_8c.html @@ -0,0 +1,526 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/lib/source/neorv32_spi.c File Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_7d04193005ada6f9450f847f4adb6b5b.html">lib</a></li><li class="navelem"><a class="el" href="dir_0c6ac14e2254a316d41123f98feeb67b.html">source</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#func-members">Functions</a> </div> + <div class="headertitle"><div class="title">neorv32_spi.c File Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p>Serial peripheral interface controller (SPI) HW driver source file. +<a href="#details">More...</a></p> +<div class="textblock"><code>#include &quot;<a class="el" href="neorv32_8h_source.html">neorv32.h</a>&quot;</code><br /> +</div><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="func-members" name="func-members"></a> +Functions</h2></td></tr> +<tr class="memitem:a7266ee439d0ec11c5cedd4bf1a258272" id="r_a7266ee439d0ec11c5cedd4bf1a258272"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a7266ee439d0ec11c5cedd4bf1a258272">neorv32_spi_available</a> (void)</td></tr> +<tr class="separator:a7266ee439d0ec11c5cedd4bf1a258272"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a7d8124d986b69210081df6f1aa653552" id="r_a7d8124d986b69210081df6f1aa653552"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a7d8124d986b69210081df6f1aa653552">neorv32_spi_setup</a> (int prsc, int cdiv, int clk_phase, int clk_polarity, uint32_t irq_mask)</td></tr> +<tr class="separator:a7d8124d986b69210081df6f1aa653552"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:acf131faa3ad970c19a3cd8a47cb54f65" id="r_acf131faa3ad970c19a3cd8a47cb54f65"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#acf131faa3ad970c19a3cd8a47cb54f65">neorv32_spi_highspeed_enable</a> (void)</td></tr> +<tr class="separator:acf131faa3ad970c19a3cd8a47cb54f65"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a67e9717635e272bc0e04408135a2f04d" id="r_a67e9717635e272bc0e04408135a2f04d"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a67e9717635e272bc0e04408135a2f04d">neorv32_spi_highspeed_disable</a> (void)</td></tr> +<tr class="separator:a67e9717635e272bc0e04408135a2f04d"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a01c6b63d7349447e2277f2649c3c89f2" id="r_a01c6b63d7349447e2277f2649c3c89f2"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a01c6b63d7349447e2277f2649c3c89f2">neorv32_spi_get_clock_speed</a> (void)</td></tr> +<tr class="separator:a01c6b63d7349447e2277f2649c3c89f2"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a817dd9a38bfceb2048e40874a83ba169" id="r_a817dd9a38bfceb2048e40874a83ba169"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a817dd9a38bfceb2048e40874a83ba169">neorv32_spi_disable</a> (void)</td></tr> +<tr class="separator:a817dd9a38bfceb2048e40874a83ba169"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a8fa25d144ccb20a2faf0450c8dddd16e" id="r_a8fa25d144ccb20a2faf0450c8dddd16e"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a8fa25d144ccb20a2faf0450c8dddd16e">neorv32_spi_enable</a> (void)</td></tr> +<tr class="separator:a8fa25d144ccb20a2faf0450c8dddd16e"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ae1c4da7e4dc2e42b04d7187f684f142c" id="r_ae1c4da7e4dc2e42b04d7187f684f142c"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ae1c4da7e4dc2e42b04d7187f684f142c">neorv32_spi_get_fifo_depth</a> (void)</td></tr> +<tr class="separator:ae1c4da7e4dc2e42b04d7187f684f142c"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a737961d040ac09567350f89034f9e122" id="r_a737961d040ac09567350f89034f9e122"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a737961d040ac09567350f89034f9e122">neorv32_spi_cs_en</a> (int cs)</td></tr> +<tr class="separator:a737961d040ac09567350f89034f9e122"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aa10ec90ccba6325eeeebb8f6f298d30c" id="r_aa10ec90ccba6325eeeebb8f6f298d30c"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aa10ec90ccba6325eeeebb8f6f298d30c">neorv32_spi_cs_dis</a> (void)</td></tr> +<tr class="separator:aa10ec90ccba6325eeeebb8f6f298d30c"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a7af79950eefc26e67a89bde02f255532" id="r_a7af79950eefc26e67a89bde02f255532"><td class="memItemLeft" align="right" valign="top">uint8_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a7af79950eefc26e67a89bde02f255532">neorv32_spi_trans</a> (uint8_t tx_data)</td></tr> +<tr class="separator:a7af79950eefc26e67a89bde02f255532"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aec8583e988789e846d21c2a35e6b06e7" id="r_aec8583e988789e846d21c2a35e6b06e7"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aec8583e988789e846d21c2a35e6b06e7">neorv32_spi_put_nonblocking</a> (uint8_t tx_data)</td></tr> +<tr class="separator:aec8583e988789e846d21c2a35e6b06e7"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aad66fa8f8d1a92d4f355de7579bfbfd2" id="r_aad66fa8f8d1a92d4f355de7579bfbfd2"><td class="memItemLeft" align="right" valign="top">uint8_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aad66fa8f8d1a92d4f355de7579bfbfd2">neorv32_spi_get_nonblocking</a> (void)</td></tr> +<tr class="separator:aad66fa8f8d1a92d4f355de7579bfbfd2"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a97b5536347a27b053f071ba49071ba6f" id="r_a97b5536347a27b053f071ba49071ba6f"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a97b5536347a27b053f071ba49071ba6f">neorv32_spi_cs_en_nonblocking</a> (int cs)</td></tr> +<tr class="separator:a97b5536347a27b053f071ba49071ba6f"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ad8dd1b5a85a9daef4c8c21c9990884c1" id="r_ad8dd1b5a85a9daef4c8c21c9990884c1"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ad8dd1b5a85a9daef4c8c21c9990884c1">neorv32_spi_cs_dis_nonblocking</a> (void)</td></tr> +<tr class="separator:ad8dd1b5a85a9daef4c8c21c9990884c1"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a82bb4d4c222b2bdc57e917c348481501" id="r_a82bb4d4c222b2bdc57e917c348481501"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a82bb4d4c222b2bdc57e917c348481501">neorv32_spi_check_cs</a> (void)</td></tr> +<tr class="separator:a82bb4d4c222b2bdc57e917c348481501"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a332c7a1be511812ac0a2b102c165398a" id="r_a332c7a1be511812ac0a2b102c165398a"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a332c7a1be511812ac0a2b102c165398a">neorv32_spi_busy</a> (void)</td></tr> +<tr class="separator:a332c7a1be511812ac0a2b102c165398a"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>Serial peripheral interface controller (SPI) HW driver source file. </p> +<dl class="section note"><dt>Note</dt><dd>These functions should only be used if the SPI unit was synthesized (IO_SPI_EN = true).</dd></dl> +<dl class="section see"><dt>See also</dt><dd><a href="https://stnolting.github.io/neorv32/sw/files.html">https://stnolting.github.io/neorv32/sw/files.html</a> </dd></dl> +</div><h2 class="groupheader">Function Documentation</h2> +<a id="a7266ee439d0ec11c5cedd4bf1a258272" name="a7266ee439d0ec11c5cedd4bf1a258272"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a7266ee439d0ec11c5cedd4bf1a258272">&#9670;&#160;</a></span>neorv32_spi_available()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_spi_available </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Check if SPI unit was synthesized.</p> +<dl class="section return"><dt>Returns</dt><dd>0 if SPI was not synthesized, 1 if SPI is available. </dd></dl> + +</div> +</div> +<a id="a332c7a1be511812ac0a2b102c165398a" name="a332c7a1be511812ac0a2b102c165398a"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a332c7a1be511812ac0a2b102c165398a">&#9670;&#160;</a></span>neorv32_spi_busy()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_spi_busy </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Check if SPI transceiver is busy or TX FIFO not empty.</p> +<dl class="section return"><dt>Returns</dt><dd>0 if idle, 1 if busy </dd></dl> + +</div> +</div> +<a id="a82bb4d4c222b2bdc57e917c348481501" name="a82bb4d4c222b2bdc57e917c348481501"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a82bb4d4c222b2bdc57e917c348481501">&#9670;&#160;</a></span>neorv32_spi_check_cs()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_spi_check_cs </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Check if any chip-select line is active.</p> +<dl class="section return"><dt>Returns</dt><dd>0 if no CS lines are active, 1 if at least one CS line is active. </dd></dl> + +</div> +</div> +<a id="aa10ec90ccba6325eeeebb8f6f298d30c" name="aa10ec90ccba6325eeeebb8f6f298d30c"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aa10ec90ccba6325eeeebb8f6f298d30c">&#9670;&#160;</a></span>neorv32_spi_cs_dis()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_spi_cs_dis </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Deactivate currently active SPI chip select signal.</p> +<dl class="section note"><dt>Note</dt><dd>The SPI chip select output lines are HIGH when deactivated. </dd> +<dd> +This function is blocking. </dd></dl> + +</div> +</div> +<a id="ad8dd1b5a85a9daef4c8c21c9990884c1" name="ad8dd1b5a85a9daef4c8c21c9990884c1"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ad8dd1b5a85a9daef4c8c21c9990884c1">&#9670;&#160;</a></span>neorv32_spi_cs_dis_nonblocking()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_spi_cs_dis_nonblocking </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Deactivate currently active SPI chip select signal (non-blocking).</p> +<dl class="section note"><dt>Note</dt><dd>The SPI chip select output lines are HIGH when deactivated. </dd></dl> + +</div> +</div> +<a id="a737961d040ac09567350f89034f9e122" name="a737961d040ac09567350f89034f9e122"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a737961d040ac09567350f89034f9e122">&#9670;&#160;</a></span>neorv32_spi_cs_en()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_spi_cs_en </td> + <td>(</td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>cs</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Activate single SPI chip select signal.</p> +<dl class="section note"><dt>Note</dt><dd>The SPI chip select output lines are LOW when activated. </dd> +<dd> +This function is blocking.</dd></dl> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramname">cs</td><td>Chip select line to activate (0..7). </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="a97b5536347a27b053f071ba49071ba6f" name="a97b5536347a27b053f071ba49071ba6f"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a97b5536347a27b053f071ba49071ba6f">&#9670;&#160;</a></span>neorv32_spi_cs_en_nonblocking()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_spi_cs_en_nonblocking </td> + <td>(</td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>cs</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Activate single SPI chip select signal (non-blocking).</p> +<dl class="section note"><dt>Note</dt><dd>The SPI chip select output lines are LOW when activated.</dd></dl> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramname">cs</td><td>Chip select line to activate (0..7). </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="a817dd9a38bfceb2048e40874a83ba169" name="a817dd9a38bfceb2048e40874a83ba169"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a817dd9a38bfceb2048e40874a83ba169">&#9670;&#160;</a></span>neorv32_spi_disable()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_spi_disable </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Disable SPI controller. </p> + +</div> +</div> +<a id="a8fa25d144ccb20a2faf0450c8dddd16e" name="a8fa25d144ccb20a2faf0450c8dddd16e"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a8fa25d144ccb20a2faf0450c8dddd16e">&#9670;&#160;</a></span>neorv32_spi_enable()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_spi_enable </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Enable SPI controller. </p> + +</div> +</div> +<a id="a01c6b63d7349447e2277f2649c3c89f2" name="a01c6b63d7349447e2277f2649c3c89f2"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a01c6b63d7349447e2277f2649c3c89f2">&#9670;&#160;</a></span>neorv32_spi_get_clock_speed()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_spi_get_clock_speed </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Get configured clock speed in Hz.</p> +<dl class="section return"><dt>Returns</dt><dd>Actual configured SPI clock speed in Hz. </dd></dl> + +</div> +</div> +<a id="ae1c4da7e4dc2e42b04d7187f684f142c" name="ae1c4da7e4dc2e42b04d7187f684f142c"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ae1c4da7e4dc2e42b04d7187f684f142c">&#9670;&#160;</a></span>neorv32_spi_get_fifo_depth()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_spi_get_fifo_depth </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Get SPI FIFO depth.</p> +<dl class="section return"><dt>Returns</dt><dd>FIFO depth (number of entries), zero if no FIFO implemented </dd></dl> + +</div> +</div> +<a id="aad66fa8f8d1a92d4f355de7579bfbfd2" name="aad66fa8f8d1a92d4f355de7579bfbfd2"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aad66fa8f8d1a92d4f355de7579bfbfd2">&#9670;&#160;</a></span>neorv32_spi_get_nonblocking()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint8_t neorv32_spi_get_nonblocking </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Get SPI RX data (non-blocking).</p> +<dl class="section return"><dt>Returns</dt><dd>Receive data (8-bit, LSB-aligned). </dd></dl> + +</div> +</div> +<a id="a67e9717635e272bc0e04408135a2f04d" name="a67e9717635e272bc0e04408135a2f04d"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a67e9717635e272bc0e04408135a2f04d">&#9670;&#160;</a></span>neorv32_spi_highspeed_disable()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_spi_highspeed_disable </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Disable high-speed mode. </p> + +</div> +</div> +<a id="acf131faa3ad970c19a3cd8a47cb54f65" name="acf131faa3ad970c19a3cd8a47cb54f65"></a> +<h2 class="memtitle"><span class="permalink"><a href="#acf131faa3ad970c19a3cd8a47cb54f65">&#9670;&#160;</a></span>neorv32_spi_highspeed_enable()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_spi_highspeed_enable </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Enable high-speed mode. </p> + +</div> +</div> +<a id="aec8583e988789e846d21c2a35e6b06e7" name="aec8583e988789e846d21c2a35e6b06e7"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aec8583e988789e846d21c2a35e6b06e7">&#9670;&#160;</a></span>neorv32_spi_put_nonblocking()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_spi_put_nonblocking </td> + <td>(</td> + <td class="paramtype">uint8_t</td> <td class="paramname"><span class="paramname"><em>tx_data</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Put SPI TX data (non-blocking).</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramname">tx_data</td><td>Transmit data (8-bit, LSB-aligned). </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="a7d8124d986b69210081df6f1aa653552" name="a7d8124d986b69210081df6f1aa653552"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a7d8124d986b69210081df6f1aa653552">&#9670;&#160;</a></span>neorv32_spi_setup()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_spi_setup </td> + <td>(</td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>prsc</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>cdiv</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>clk_phase</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>clk_polarity</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>irq_mask</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Enable and configure SPI controller. The SPI control register bits are listed in <a class="el" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3b">NEORV32_SPI_CTRL_enum</a>.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">prsc</td><td>Clock prescaler select (0..7). See <a class="el" href="neorv32_8h.html#a10022df4c223533b04d5aebe222e8b73">NEORV32_CLOCK_PRSC_enum</a>. @prama[in] cdiv Clock divider (0..15). </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">clk_phase</td><td>Clock phase (0=sample on rising edge, 1=sample on falling edge). </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">clk_polarity</td><td>Clock polarity (when idle). </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">irq_mask</td><td>Interrupt configuration mask (CTRL's irq_* bits). </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="a7af79950eefc26e67a89bde02f255532" name="a7af79950eefc26e67a89bde02f255532"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a7af79950eefc26e67a89bde02f255532">&#9670;&#160;</a></span>neorv32_spi_trans()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint8_t neorv32_spi_trans </td> + <td>(</td> + <td class="paramtype">uint8_t</td> <td class="paramname"><span class="paramname"><em>tx_data</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Perform a single SPI data transfer.</p> +<dl class="section note"><dt>Note</dt><dd>This function is blocking.</dd></dl> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramname">tx_data</td><td>Transmit data (8-bit, LSB-aligned). </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Receive data (8-bit, LSB-aligned). </dd></dl> + +</div> +</div> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/neorv32__spi_8h.html b/sw/neorv32__spi_8h.html new file mode 100644 index 0000000000..469c571ebf --- /dev/null +++ b/sw/neorv32__spi_8h.html @@ -0,0 +1,681 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/lib/include/neorv32_spi.h File Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_7d04193005ada6f9450f847f4adb6b5b.html">lib</a></li><li class="navelem"><a class="el" href="dir_752b1e5d3973bf735fa78bf6b4727df9.html">include</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#nested-classes">Data Structures</a> </div> + <div class="headertitle"><div class="title">neorv32_spi.h File Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p>Serial peripheral interface controller (SPI) HW driver header file. +<a href="#details">More...</a></p> +<div class="textblock"><code>#include &lt;stdint.h&gt;</code><br /> +</div> +<p><a href="neorv32__spi_8h_source.html">Go to the source code of this file.</a></p> +<table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="nested-classes" name="nested-classes"></a> +Data Structures</h2></td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">struct &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structneorv32__spi__t.html">neorv32_spi_t</a></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="func-members" name="func-members"></a> +Functions</h2></td></tr> +<tr><td colspan="2"><div class="groupHeader">Prototypes</div></td></tr> +<tr class="memitem:a7266ee439d0ec11c5cedd4bf1a258272" id="r_a7266ee439d0ec11c5cedd4bf1a258272"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a7266ee439d0ec11c5cedd4bf1a258272">neorv32_spi_available</a> (void)</td></tr> +<tr class="separator:a7266ee439d0ec11c5cedd4bf1a258272"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a7d8124d986b69210081df6f1aa653552" id="r_a7d8124d986b69210081df6f1aa653552"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a7d8124d986b69210081df6f1aa653552">neorv32_spi_setup</a> (int prsc, int cdiv, int clk_phase, int clk_polarity, uint32_t irq_mask)</td></tr> +<tr class="separator:a7d8124d986b69210081df6f1aa653552"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:acf131faa3ad970c19a3cd8a47cb54f65" id="r_acf131faa3ad970c19a3cd8a47cb54f65"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#acf131faa3ad970c19a3cd8a47cb54f65">neorv32_spi_highspeed_enable</a> (void)</td></tr> +<tr class="separator:acf131faa3ad970c19a3cd8a47cb54f65"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a67e9717635e272bc0e04408135a2f04d" id="r_a67e9717635e272bc0e04408135a2f04d"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a67e9717635e272bc0e04408135a2f04d">neorv32_spi_highspeed_disable</a> (void)</td></tr> +<tr class="separator:a67e9717635e272bc0e04408135a2f04d"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a01c6b63d7349447e2277f2649c3c89f2" id="r_a01c6b63d7349447e2277f2649c3c89f2"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a01c6b63d7349447e2277f2649c3c89f2">neorv32_spi_get_clock_speed</a> (void)</td></tr> +<tr class="separator:a01c6b63d7349447e2277f2649c3c89f2"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a817dd9a38bfceb2048e40874a83ba169" id="r_a817dd9a38bfceb2048e40874a83ba169"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a817dd9a38bfceb2048e40874a83ba169">neorv32_spi_disable</a> (void)</td></tr> +<tr class="separator:a817dd9a38bfceb2048e40874a83ba169"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a8fa25d144ccb20a2faf0450c8dddd16e" id="r_a8fa25d144ccb20a2faf0450c8dddd16e"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a8fa25d144ccb20a2faf0450c8dddd16e">neorv32_spi_enable</a> (void)</td></tr> +<tr class="separator:a8fa25d144ccb20a2faf0450c8dddd16e"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ae1c4da7e4dc2e42b04d7187f684f142c" id="r_ae1c4da7e4dc2e42b04d7187f684f142c"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ae1c4da7e4dc2e42b04d7187f684f142c">neorv32_spi_get_fifo_depth</a> (void)</td></tr> +<tr class="separator:ae1c4da7e4dc2e42b04d7187f684f142c"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a737961d040ac09567350f89034f9e122" id="r_a737961d040ac09567350f89034f9e122"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a737961d040ac09567350f89034f9e122">neorv32_spi_cs_en</a> (int cs)</td></tr> +<tr class="separator:a737961d040ac09567350f89034f9e122"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aa10ec90ccba6325eeeebb8f6f298d30c" id="r_aa10ec90ccba6325eeeebb8f6f298d30c"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aa10ec90ccba6325eeeebb8f6f298d30c">neorv32_spi_cs_dis</a> (void)</td></tr> +<tr class="separator:aa10ec90ccba6325eeeebb8f6f298d30c"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a7af79950eefc26e67a89bde02f255532" id="r_a7af79950eefc26e67a89bde02f255532"><td class="memItemLeft" align="right" valign="top">uint8_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a7af79950eefc26e67a89bde02f255532">neorv32_spi_trans</a> (uint8_t tx_data)</td></tr> +<tr class="separator:a7af79950eefc26e67a89bde02f255532"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aec8583e988789e846d21c2a35e6b06e7" id="r_aec8583e988789e846d21c2a35e6b06e7"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aec8583e988789e846d21c2a35e6b06e7">neorv32_spi_put_nonblocking</a> (uint8_t tx_data)</td></tr> +<tr class="separator:aec8583e988789e846d21c2a35e6b06e7"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aad66fa8f8d1a92d4f355de7579bfbfd2" id="r_aad66fa8f8d1a92d4f355de7579bfbfd2"><td class="memItemLeft" align="right" valign="top">uint8_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aad66fa8f8d1a92d4f355de7579bfbfd2">neorv32_spi_get_nonblocking</a> (void)</td></tr> +<tr class="separator:aad66fa8f8d1a92d4f355de7579bfbfd2"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a97b5536347a27b053f071ba49071ba6f" id="r_a97b5536347a27b053f071ba49071ba6f"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a97b5536347a27b053f071ba49071ba6f">neorv32_spi_cs_en_nonblocking</a> (int cs)</td></tr> +<tr class="separator:a97b5536347a27b053f071ba49071ba6f"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ad8dd1b5a85a9daef4c8c21c9990884c1" id="r_ad8dd1b5a85a9daef4c8c21c9990884c1"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ad8dd1b5a85a9daef4c8c21c9990884c1">neorv32_spi_cs_dis_nonblocking</a> (void)</td></tr> +<tr class="separator:ad8dd1b5a85a9daef4c8c21c9990884c1"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a82bb4d4c222b2bdc57e917c348481501" id="r_a82bb4d4c222b2bdc57e917c348481501"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a82bb4d4c222b2bdc57e917c348481501">neorv32_spi_check_cs</a> (void)</td></tr> +<tr class="separator:a82bb4d4c222b2bdc57e917c348481501"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a332c7a1be511812ac0a2b102c165398a" id="r_a332c7a1be511812ac0a2b102c165398a"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a332c7a1be511812ac0a2b102c165398a">neorv32_spi_busy</a> (void)</td></tr> +<tr class="separator:a332c7a1be511812ac0a2b102c165398a"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader">IO Device: Serial Peripheral Interface Controller (SPI)</h2></td></tr> +<tr class="memitem:a5f3afc4e268670c54d90df67fa38ca22" id="r_a5f3afc4e268670c54d90df67fa38ca22"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a5f3afc4e268670c54d90df67fa38ca22">NEORV32_SPI</a>&#160;&#160;&#160;((<a class="el" href="structneorv32__spi__t.html">neorv32_spi_t</a>*) (<a class="el" href="neorv32_8h.html#aa466dc5eace7351bd438606f0f7475a7">NEORV32_SPI_BASE</a>))</td></tr> +<tr class="separator:a5f3afc4e268670c54d90df67fa38ca22"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ae269b2f5b2afd46ae16801762ade2c3b" id="r_ae269b2f5b2afd46ae16801762ade2c3b"><td class="memItemLeft" align="right" valign="top">enum &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ae269b2f5b2afd46ae16801762ade2c3b">NEORV32_SPI_CTRL_enum</a> { <br /> +&#160;&#160;<a class="el" href="#ae269b2f5b2afd46ae16801762ade2c3ba647a6357971f94b79b7672785c06a4ea">SPI_CTRL_EN</a> = 0 +, <a class="el" href="#ae269b2f5b2afd46ae16801762ade2c3ba4d787c993152a9417fcd50f76820c7b0">SPI_CTRL_CPHA</a> = 1 +, <a class="el" href="#ae269b2f5b2afd46ae16801762ade2c3ba7661acb97cc8c6dd7f333be4f4a2d315">SPI_CTRL_CPOL</a> = 2 +, <a class="el" href="#ae269b2f5b2afd46ae16801762ade2c3babc927c4ea78433de697a9fe96f47248e">SPI_CTRL_PRSC0</a> = 3 +, <br /> +&#160;&#160;<a class="el" href="#ae269b2f5b2afd46ae16801762ade2c3ba49c38a34b95c034249a094fbc93e0a61">SPI_CTRL_PRSC1</a> = 4 +, <a class="el" href="#ae269b2f5b2afd46ae16801762ade2c3ba7a5244e443e1fe4ff6b7a2176f90ae7a">SPI_CTRL_PRSC2</a> = 5 +, <a class="el" href="#ae269b2f5b2afd46ae16801762ade2c3bae6db5cfa843a58d7c09783e7f29fa49f">SPI_CTRL_CDIV0</a> = 6 +, <a class="el" href="#ae269b2f5b2afd46ae16801762ade2c3ba0b9ca202963b68b999f94baab50fbc48">SPI_CTRL_CDIV1</a> = 7 +, <br /> +&#160;&#160;<a class="el" href="#ae269b2f5b2afd46ae16801762ade2c3ba97aaa7a4ffcc6d17a00c4f992e517c46">SPI_CTRL_CDIV2</a> = 8 +, <a class="el" href="#ae269b2f5b2afd46ae16801762ade2c3ba85164e4e00b5ccd34158f98f691bca29">SPI_CTRL_CDIV3</a> = 9 +, <a class="el" href="#ae269b2f5b2afd46ae16801762ade2c3bac38b12af6b8fb6bf2fc6f6ff6baee91e">SPI_CTRL_HIGHSPEED</a> = 10 +, <a class="el" href="#ae269b2f5b2afd46ae16801762ade2c3ba115b097b76b3b99716f54a63c6ce5633">SPI_CTRL_RX_AVAIL</a> = 16 +, <br /> +&#160;&#160;<a class="el" href="#ae269b2f5b2afd46ae16801762ade2c3ba487b87333d33db0a05cd2a229225ffc6">SPI_CTRL_TX_EMPTY</a> = 17 +, <a class="el" href="#ae269b2f5b2afd46ae16801762ade2c3ba5efcaded20b93d2bffeaa4ea813f73b4">SPI_CTRL_TX_NHALF</a> = 18 +, <a class="el" href="#ae269b2f5b2afd46ae16801762ade2c3ba96860d260b31ee4c232b6b0eb45f7905">SPI_CTRL_TX_FULL</a> = 19 +, <a class="el" href="#ae269b2f5b2afd46ae16801762ade2c3ba2cd2350ffc819b7198d1833b525c5ca0">SPI_CTRL_IRQ_RX_AVAIL</a> = 20 +, <br /> +&#160;&#160;<a class="el" href="#ae269b2f5b2afd46ae16801762ade2c3bafcdc17528f9f4521c02ec5c473b44622">SPI_CTRL_IRQ_TX_EMPTY</a> = 21 +, <a class="el" href="#ae269b2f5b2afd46ae16801762ade2c3ba8c18d975418ad444255f80317448d26b">SPI_CTRL_IRQ_TX_HALF</a> = 22 +, <a class="el" href="#ae269b2f5b2afd46ae16801762ade2c3ba3f80e9c6ef6445ad769038c955c171a2">SPI_CTRL_IRQ_IDLE</a> = 23 +, <a class="el" href="#ae269b2f5b2afd46ae16801762ade2c3ba12f67abd206066651c1d62fc29fafcdb">SPI_CTRL_FIFO_LSB</a> = 24 +, <br /> +&#160;&#160;<a class="el" href="#ae269b2f5b2afd46ae16801762ade2c3ba8c0426f70974f0ab129481f2db7cf0ed">SPI_CTRL_FIFO_MSB</a> = 27 +, <a class="el" href="#ae269b2f5b2afd46ae16801762ade2c3ba5e12c05349444d3d1defff49dec00580">SPI_CS_ACTIVE</a> = 30 +, <a class="el" href="#ae269b2f5b2afd46ae16801762ade2c3ba7957cf1cf3997cd059ed81cba73a688c">SPI_CTRL_BUSY</a> = 31 +<br /> + }</td></tr> +<tr class="separator:ae269b2f5b2afd46ae16801762ade2c3b"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aab478c23898c0b06cee53a1cbda38bf8" id="r_aab478c23898c0b06cee53a1cbda38bf8"><td class="memItemLeft" align="right" valign="top">enum &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aab478c23898c0b06cee53a1cbda38bf8">NEORV32_SPI_DATA_enum</a> { <a class="el" href="#aab478c23898c0b06cee53a1cbda38bf8ae3c36a644c05cea0fccaefb9da90a1b4">SPI_DATA_LSB</a> = 0 +, <a class="el" href="#aab478c23898c0b06cee53a1cbda38bf8a0167ec9c252ee0228ab9d21f4acba600">SPI_DATA_MSB</a> = 1 +, <a class="el" href="#aab478c23898c0b06cee53a1cbda38bf8a5673b6a3382dc5452e3cfcd4e8f3c8a2">SPI_DATA_CSEN</a> = 3 +, <a class="el" href="#aab478c23898c0b06cee53a1cbda38bf8a8b565083f989905b8335d9d22a14c4b6">SPI_DATA_CMD</a> = 31 + }</td></tr> +<tr class="separator:aab478c23898c0b06cee53a1cbda38bf8"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>Serial peripheral interface controller (SPI) HW driver header file. </p> +<dl class="section note"><dt>Note</dt><dd>These functions should only be used if the SPI unit was synthesized (IO_SPI_EN = true).</dd></dl> +<dl class="section see"><dt>See also</dt><dd><a href="https://stnolting.github.io/neorv32/sw/files.html">https://stnolting.github.io/neorv32/sw/files.html</a> </dd></dl> +</div><h2 class="groupheader">Macro Definition Documentation</h2> +<a id="a5f3afc4e268670c54d90df67fa38ca22" name="a5f3afc4e268670c54d90df67fa38ca22"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a5f3afc4e268670c54d90df67fa38ca22">&#9670;&#160;</a></span>NEORV32_SPI</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define NEORV32_SPI&#160;&#160;&#160;((<a class="el" href="structneorv32__spi__t.html">neorv32_spi_t</a>*) (<a class="el" href="neorv32_8h.html#aa466dc5eace7351bd438606f0f7475a7">NEORV32_SPI_BASE</a>))</td> + </tr> + </table> +</div><div class="memdoc"> +<p>SPI module hardware access (<a class="el" href="structneorv32__spi__t.html">neorv32_spi_t</a>) </p> + +</div> +</div> +<h2 class="groupheader">Enumeration Type Documentation</h2> +<a id="ae269b2f5b2afd46ae16801762ade2c3b" name="ae269b2f5b2afd46ae16801762ade2c3b"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ae269b2f5b2afd46ae16801762ade2c3b">&#9670;&#160;</a></span>NEORV32_SPI_CTRL_enum</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">enum <a class="el" href="#ae269b2f5b2afd46ae16801762ade2c3b">NEORV32_SPI_CTRL_enum</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>SPI control register bits </p> +<table class="fieldtable"> +<tr><th colspan="2">Enumerator</th></tr><tr><td class="fieldname"><a id="ae269b2f5b2afd46ae16801762ade2c3ba647a6357971f94b79b7672785c06a4ea" name="ae269b2f5b2afd46ae16801762ade2c3ba647a6357971f94b79b7672785c06a4ea"></a>SPI_CTRL_EN&#160;</td><td class="fielddoc"><p>SPI control register(0) (r/w): SPI unit enable </p> +</td></tr> +<tr><td class="fieldname"><a id="ae269b2f5b2afd46ae16801762ade2c3ba4d787c993152a9417fcd50f76820c7b0" name="ae269b2f5b2afd46ae16801762ade2c3ba4d787c993152a9417fcd50f76820c7b0"></a>SPI_CTRL_CPHA&#160;</td><td class="fielddoc"><p>SPI control register(1) (r/w): Clock phase </p> +</td></tr> +<tr><td class="fieldname"><a id="ae269b2f5b2afd46ae16801762ade2c3ba7661acb97cc8c6dd7f333be4f4a2d315" name="ae269b2f5b2afd46ae16801762ade2c3ba7661acb97cc8c6dd7f333be4f4a2d315"></a>SPI_CTRL_CPOL&#160;</td><td class="fielddoc"><p>SPI control register(2) (r/w): Clock polarity </p> +</td></tr> +<tr><td class="fieldname"><a id="ae269b2f5b2afd46ae16801762ade2c3babc927c4ea78433de697a9fe96f47248e" name="ae269b2f5b2afd46ae16801762ade2c3babc927c4ea78433de697a9fe96f47248e"></a>SPI_CTRL_PRSC0&#160;</td><td class="fielddoc"><p>SPI control register(3) (r/w): Clock prescaler select bit 0 </p> +</td></tr> +<tr><td class="fieldname"><a id="ae269b2f5b2afd46ae16801762ade2c3ba49c38a34b95c034249a094fbc93e0a61" name="ae269b2f5b2afd46ae16801762ade2c3ba49c38a34b95c034249a094fbc93e0a61"></a>SPI_CTRL_PRSC1&#160;</td><td class="fielddoc"><p>SPI control register(4) (r/w): Clock prescaler select bit 1 </p> +</td></tr> +<tr><td class="fieldname"><a id="ae269b2f5b2afd46ae16801762ade2c3ba7a5244e443e1fe4ff6b7a2176f90ae7a" name="ae269b2f5b2afd46ae16801762ade2c3ba7a5244e443e1fe4ff6b7a2176f90ae7a"></a>SPI_CTRL_PRSC2&#160;</td><td class="fielddoc"><p>SPI control register(5) (r/w): Clock prescaler select bit 2 </p> +</td></tr> +<tr><td class="fieldname"><a id="ae269b2f5b2afd46ae16801762ade2c3bae6db5cfa843a58d7c09783e7f29fa49f" name="ae269b2f5b2afd46ae16801762ade2c3bae6db5cfa843a58d7c09783e7f29fa49f"></a>SPI_CTRL_CDIV0&#160;</td><td class="fielddoc"><p>SPI control register(6) (r/w): Clock divider bit 0 </p> +</td></tr> +<tr><td class="fieldname"><a id="ae269b2f5b2afd46ae16801762ade2c3ba0b9ca202963b68b999f94baab50fbc48" name="ae269b2f5b2afd46ae16801762ade2c3ba0b9ca202963b68b999f94baab50fbc48"></a>SPI_CTRL_CDIV1&#160;</td><td class="fielddoc"><p>SPI control register(7) (r/w): Clock divider bit 1 </p> +</td></tr> +<tr><td class="fieldname"><a id="ae269b2f5b2afd46ae16801762ade2c3ba97aaa7a4ffcc6d17a00c4f992e517c46" name="ae269b2f5b2afd46ae16801762ade2c3ba97aaa7a4ffcc6d17a00c4f992e517c46"></a>SPI_CTRL_CDIV2&#160;</td><td class="fielddoc"><p>SPI control register(8) (r/w): Clock divider bit 2 </p> +</td></tr> +<tr><td class="fieldname"><a id="ae269b2f5b2afd46ae16801762ade2c3ba85164e4e00b5ccd34158f98f691bca29" name="ae269b2f5b2afd46ae16801762ade2c3ba85164e4e00b5ccd34158f98f691bca29"></a>SPI_CTRL_CDIV3&#160;</td><td class="fielddoc"><p>SPI control register(9) (r/w): Clock divider bit 3 </p> +</td></tr> +<tr><td class="fieldname"><a id="ae269b2f5b2afd46ae16801762ade2c3bac38b12af6b8fb6bf2fc6f6ff6baee91e" name="ae269b2f5b2afd46ae16801762ade2c3bac38b12af6b8fb6bf2fc6f6ff6baee91e"></a>SPI_CTRL_HIGHSPEED&#160;</td><td class="fielddoc"><p>SPI control register(10) (r/w): High-speed mode </p> +</td></tr> +<tr><td class="fieldname"><a id="ae269b2f5b2afd46ae16801762ade2c3ba115b097b76b3b99716f54a63c6ce5633" name="ae269b2f5b2afd46ae16801762ade2c3ba115b097b76b3b99716f54a63c6ce5633"></a>SPI_CTRL_RX_AVAIL&#160;</td><td class="fielddoc"><p>SPI control register(16) (r/-): RX FIFO data available (RX FIFO not empty) </p> +</td></tr> +<tr><td class="fieldname"><a id="ae269b2f5b2afd46ae16801762ade2c3ba487b87333d33db0a05cd2a229225ffc6" name="ae269b2f5b2afd46ae16801762ade2c3ba487b87333d33db0a05cd2a229225ffc6"></a>SPI_CTRL_TX_EMPTY&#160;</td><td class="fielddoc"><p>SPI control register(17) (r/-): TX FIFO empty </p> +</td></tr> +<tr><td class="fieldname"><a id="ae269b2f5b2afd46ae16801762ade2c3ba5efcaded20b93d2bffeaa4ea813f73b4" name="ae269b2f5b2afd46ae16801762ade2c3ba5efcaded20b93d2bffeaa4ea813f73b4"></a>SPI_CTRL_TX_NHALF&#160;</td><td class="fielddoc"><p>SPI control register(18) (r/-): TX FIFO not at least half full </p> +</td></tr> +<tr><td class="fieldname"><a id="ae269b2f5b2afd46ae16801762ade2c3ba96860d260b31ee4c232b6b0eb45f7905" name="ae269b2f5b2afd46ae16801762ade2c3ba96860d260b31ee4c232b6b0eb45f7905"></a>SPI_CTRL_TX_FULL&#160;</td><td class="fielddoc"><p>SPI control register(19) (r/-): TX FIFO full </p> +</td></tr> +<tr><td class="fieldname"><a id="ae269b2f5b2afd46ae16801762ade2c3ba2cd2350ffc819b7198d1833b525c5ca0" name="ae269b2f5b2afd46ae16801762ade2c3ba2cd2350ffc819b7198d1833b525c5ca0"></a>SPI_CTRL_IRQ_RX_AVAIL&#160;</td><td class="fielddoc"><p>SPI control register(20) (r/w): Fire IRQ if RX FIFO data available (RX FIFO not empty) </p> +</td></tr> +<tr><td class="fieldname"><a id="ae269b2f5b2afd46ae16801762ade2c3bafcdc17528f9f4521c02ec5c473b44622" name="ae269b2f5b2afd46ae16801762ade2c3bafcdc17528f9f4521c02ec5c473b44622"></a>SPI_CTRL_IRQ_TX_EMPTY&#160;</td><td class="fielddoc"><p>SPI control register(21) (r/w): Fire IRQ if TX FIFO empty </p> +</td></tr> +<tr><td class="fieldname"><a id="ae269b2f5b2afd46ae16801762ade2c3ba8c18d975418ad444255f80317448d26b" name="ae269b2f5b2afd46ae16801762ade2c3ba8c18d975418ad444255f80317448d26b"></a>SPI_CTRL_IRQ_TX_HALF&#160;</td><td class="fielddoc"><p>SPI control register(22) (r/w): Fire IRQ if TX FIFO not at least half full </p> +</td></tr> +<tr><td class="fieldname"><a id="ae269b2f5b2afd46ae16801762ade2c3ba3f80e9c6ef6445ad769038c955c171a2" name="ae269b2f5b2afd46ae16801762ade2c3ba3f80e9c6ef6445ad769038c955c171a2"></a>SPI_CTRL_IRQ_IDLE&#160;</td><td class="fielddoc"><p>SPI control register(23) (r/w): Fire IRQ if TX FIFO is empty and SPI bus engine is idle </p> +</td></tr> +<tr><td class="fieldname"><a id="ae269b2f5b2afd46ae16801762ade2c3ba12f67abd206066651c1d62fc29fafcdb" name="ae269b2f5b2afd46ae16801762ade2c3ba12f67abd206066651c1d62fc29fafcdb"></a>SPI_CTRL_FIFO_LSB&#160;</td><td class="fielddoc"><p>SPI control register(24) (r/-): log2(FIFO size), lsb </p> +</td></tr> +<tr><td class="fieldname"><a id="ae269b2f5b2afd46ae16801762ade2c3ba8c0426f70974f0ab129481f2db7cf0ed" name="ae269b2f5b2afd46ae16801762ade2c3ba8c0426f70974f0ab129481f2db7cf0ed"></a>SPI_CTRL_FIFO_MSB&#160;</td><td class="fielddoc"><p>SPI control register(27) (r/-): log2(FIFO size), msb </p> +</td></tr> +<tr><td class="fieldname"><a id="ae269b2f5b2afd46ae16801762ade2c3ba5e12c05349444d3d1defff49dec00580" name="ae269b2f5b2afd46ae16801762ade2c3ba5e12c05349444d3d1defff49dec00580"></a>SPI_CS_ACTIVE&#160;</td><td class="fielddoc"><p>SPI control register(30) (r/-): At least one CS line is active when set </p> +</td></tr> +<tr><td class="fieldname"><a id="ae269b2f5b2afd46ae16801762ade2c3ba7957cf1cf3997cd059ed81cba73a688c" name="ae269b2f5b2afd46ae16801762ade2c3ba7957cf1cf3997cd059ed81cba73a688c"></a>SPI_CTRL_BUSY&#160;</td><td class="fielddoc"><p>SPI control register(31) (r/-): SPI busy flag </p> +</td></tr> +</table> + +</div> +</div> +<a id="aab478c23898c0b06cee53a1cbda38bf8" name="aab478c23898c0b06cee53a1cbda38bf8"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aab478c23898c0b06cee53a1cbda38bf8">&#9670;&#160;</a></span>NEORV32_SPI_DATA_enum</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">enum <a class="el" href="#aab478c23898c0b06cee53a1cbda38bf8">NEORV32_SPI_DATA_enum</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>SPI data register bits </p> +<table class="fieldtable"> +<tr><th colspan="2">Enumerator</th></tr><tr><td class="fieldname"><a id="aab478c23898c0b06cee53a1cbda38bf8ae3c36a644c05cea0fccaefb9da90a1b4" name="aab478c23898c0b06cee53a1cbda38bf8ae3c36a644c05cea0fccaefb9da90a1b4"></a>SPI_DATA_LSB&#160;</td><td class="fielddoc"><p>SPI data register(0) (r/w): Data byte LSB </p> +</td></tr> +<tr><td class="fieldname"><a id="aab478c23898c0b06cee53a1cbda38bf8a0167ec9c252ee0228ab9d21f4acba600" name="aab478c23898c0b06cee53a1cbda38bf8a0167ec9c252ee0228ab9d21f4acba600"></a>SPI_DATA_MSB&#160;</td><td class="fielddoc"><p>SPI data register(1) (r/w): Data byte LSB </p> +</td></tr> +<tr><td class="fieldname"><a id="aab478c23898c0b06cee53a1cbda38bf8a5673b6a3382dc5452e3cfcd4e8f3c8a2" name="aab478c23898c0b06cee53a1cbda38bf8a5673b6a3382dc5452e3cfcd4e8f3c8a2"></a>SPI_DATA_CSEN&#160;</td><td class="fielddoc"><p>SPI data register(3) (-/w): Chip select enable (command-mode only) </p> +</td></tr> +<tr><td class="fieldname"><a id="aab478c23898c0b06cee53a1cbda38bf8a8b565083f989905b8335d9d22a14c4b6" name="aab478c23898c0b06cee53a1cbda38bf8a8b565083f989905b8335d9d22a14c4b6"></a>SPI_DATA_CMD&#160;</td><td class="fielddoc"><p>SPI data register(31) (-/w): Command (=1) / data (=0) select </p> +</td></tr> +</table> + +</div> +</div> +<h2 class="groupheader">Function Documentation</h2> +<a id="a7266ee439d0ec11c5cedd4bf1a258272" name="a7266ee439d0ec11c5cedd4bf1a258272"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a7266ee439d0ec11c5cedd4bf1a258272">&#9670;&#160;</a></span>neorv32_spi_available()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_spi_available </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Check if SPI unit was synthesized.</p> +<dl class="section return"><dt>Returns</dt><dd>0 if SPI was not synthesized, 1 if SPI is available. </dd></dl> + +</div> +</div> +<a id="a332c7a1be511812ac0a2b102c165398a" name="a332c7a1be511812ac0a2b102c165398a"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a332c7a1be511812ac0a2b102c165398a">&#9670;&#160;</a></span>neorv32_spi_busy()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_spi_busy </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Check if SPI transceiver is busy or TX FIFO not empty.</p> +<dl class="section return"><dt>Returns</dt><dd>0 if idle, 1 if busy </dd></dl> + +</div> +</div> +<a id="a82bb4d4c222b2bdc57e917c348481501" name="a82bb4d4c222b2bdc57e917c348481501"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a82bb4d4c222b2bdc57e917c348481501">&#9670;&#160;</a></span>neorv32_spi_check_cs()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_spi_check_cs </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Check if any chip-select line is active.</p> +<dl class="section return"><dt>Returns</dt><dd>0 if no CS lines are active, 1 if at least one CS line is active. </dd></dl> + +</div> +</div> +<a id="aa10ec90ccba6325eeeebb8f6f298d30c" name="aa10ec90ccba6325eeeebb8f6f298d30c"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aa10ec90ccba6325eeeebb8f6f298d30c">&#9670;&#160;</a></span>neorv32_spi_cs_dis()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_spi_cs_dis </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Deactivate currently active SPI chip select signal.</p> +<dl class="section note"><dt>Note</dt><dd>The SPI chip select output lines are HIGH when deactivated. </dd> +<dd> +This function is blocking. </dd></dl> + +</div> +</div> +<a id="ad8dd1b5a85a9daef4c8c21c9990884c1" name="ad8dd1b5a85a9daef4c8c21c9990884c1"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ad8dd1b5a85a9daef4c8c21c9990884c1">&#9670;&#160;</a></span>neorv32_spi_cs_dis_nonblocking()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_spi_cs_dis_nonblocking </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Deactivate currently active SPI chip select signal (non-blocking).</p> +<dl class="section note"><dt>Note</dt><dd>The SPI chip select output lines are HIGH when deactivated. </dd></dl> + +</div> +</div> +<a id="a737961d040ac09567350f89034f9e122" name="a737961d040ac09567350f89034f9e122"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a737961d040ac09567350f89034f9e122">&#9670;&#160;</a></span>neorv32_spi_cs_en()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_spi_cs_en </td> + <td>(</td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>cs</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Activate single SPI chip select signal.</p> +<dl class="section note"><dt>Note</dt><dd>The SPI chip select output lines are LOW when activated. </dd> +<dd> +This function is blocking.</dd></dl> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramname">cs</td><td>Chip select line to activate (0..7). </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="a97b5536347a27b053f071ba49071ba6f" name="a97b5536347a27b053f071ba49071ba6f"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a97b5536347a27b053f071ba49071ba6f">&#9670;&#160;</a></span>neorv32_spi_cs_en_nonblocking()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_spi_cs_en_nonblocking </td> + <td>(</td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>cs</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Activate single SPI chip select signal (non-blocking).</p> +<dl class="section note"><dt>Note</dt><dd>The SPI chip select output lines are LOW when activated.</dd></dl> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramname">cs</td><td>Chip select line to activate (0..7). </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="a817dd9a38bfceb2048e40874a83ba169" name="a817dd9a38bfceb2048e40874a83ba169"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a817dd9a38bfceb2048e40874a83ba169">&#9670;&#160;</a></span>neorv32_spi_disable()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_spi_disable </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Disable SPI controller. </p> + +</div> +</div> +<a id="a8fa25d144ccb20a2faf0450c8dddd16e" name="a8fa25d144ccb20a2faf0450c8dddd16e"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a8fa25d144ccb20a2faf0450c8dddd16e">&#9670;&#160;</a></span>neorv32_spi_enable()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_spi_enable </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Enable SPI controller. </p> + +</div> +</div> +<a id="a01c6b63d7349447e2277f2649c3c89f2" name="a01c6b63d7349447e2277f2649c3c89f2"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a01c6b63d7349447e2277f2649c3c89f2">&#9670;&#160;</a></span>neorv32_spi_get_clock_speed()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_spi_get_clock_speed </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Get configured clock speed in Hz.</p> +<dl class="section return"><dt>Returns</dt><dd>Actual configured SPI clock speed in Hz. </dd></dl> + +</div> +</div> +<a id="ae1c4da7e4dc2e42b04d7187f684f142c" name="ae1c4da7e4dc2e42b04d7187f684f142c"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ae1c4da7e4dc2e42b04d7187f684f142c">&#9670;&#160;</a></span>neorv32_spi_get_fifo_depth()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_spi_get_fifo_depth </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Get SPI FIFO depth.</p> +<dl class="section return"><dt>Returns</dt><dd>FIFO depth (number of entries), zero if no FIFO implemented </dd></dl> + +</div> +</div> +<a id="aad66fa8f8d1a92d4f355de7579bfbfd2" name="aad66fa8f8d1a92d4f355de7579bfbfd2"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aad66fa8f8d1a92d4f355de7579bfbfd2">&#9670;&#160;</a></span>neorv32_spi_get_nonblocking()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint8_t neorv32_spi_get_nonblocking </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Get SPI RX data (non-blocking).</p> +<dl class="section return"><dt>Returns</dt><dd>Receive data (8-bit, LSB-aligned). </dd></dl> + +</div> +</div> +<a id="a67e9717635e272bc0e04408135a2f04d" name="a67e9717635e272bc0e04408135a2f04d"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a67e9717635e272bc0e04408135a2f04d">&#9670;&#160;</a></span>neorv32_spi_highspeed_disable()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_spi_highspeed_disable </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Disable high-speed mode. </p> + +</div> +</div> +<a id="acf131faa3ad970c19a3cd8a47cb54f65" name="acf131faa3ad970c19a3cd8a47cb54f65"></a> +<h2 class="memtitle"><span class="permalink"><a href="#acf131faa3ad970c19a3cd8a47cb54f65">&#9670;&#160;</a></span>neorv32_spi_highspeed_enable()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_spi_highspeed_enable </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Enable high-speed mode. </p> + +</div> +</div> +<a id="aec8583e988789e846d21c2a35e6b06e7" name="aec8583e988789e846d21c2a35e6b06e7"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aec8583e988789e846d21c2a35e6b06e7">&#9670;&#160;</a></span>neorv32_spi_put_nonblocking()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_spi_put_nonblocking </td> + <td>(</td> + <td class="paramtype">uint8_t</td> <td class="paramname"><span class="paramname"><em>tx_data</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Put SPI TX data (non-blocking).</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramname">tx_data</td><td>Transmit data (8-bit, LSB-aligned). </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="a7d8124d986b69210081df6f1aa653552" name="a7d8124d986b69210081df6f1aa653552"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a7d8124d986b69210081df6f1aa653552">&#9670;&#160;</a></span>neorv32_spi_setup()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_spi_setup </td> + <td>(</td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>prsc</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>cdiv</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>clk_phase</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>clk_polarity</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>irq_mask</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Enable and configure SPI controller. The SPI control register bits are listed in <a class="el" href="#ae269b2f5b2afd46ae16801762ade2c3b">NEORV32_SPI_CTRL_enum</a>.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">prsc</td><td>Clock prescaler select (0..7). See <a class="el" href="neorv32_8h.html#a10022df4c223533b04d5aebe222e8b73">NEORV32_CLOCK_PRSC_enum</a>. @prama[in] cdiv Clock divider (0..15). </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">clk_phase</td><td>Clock phase (0=sample on rising edge, 1=sample on falling edge). </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">clk_polarity</td><td>Clock polarity (when idle). </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">irq_mask</td><td>Interrupt configuration mask (CTRL's irq_* bits). </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="a7af79950eefc26e67a89bde02f255532" name="a7af79950eefc26e67a89bde02f255532"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a7af79950eefc26e67a89bde02f255532">&#9670;&#160;</a></span>neorv32_spi_trans()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint8_t neorv32_spi_trans </td> + <td>(</td> + <td class="paramtype">uint8_t</td> <td class="paramname"><span class="paramname"><em>tx_data</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Perform a single SPI data transfer.</p> +<dl class="section note"><dt>Note</dt><dd>This function is blocking.</dd></dl> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramname">tx_data</td><td>Transmit data (8-bit, LSB-aligned). </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Receive data (8-bit, LSB-aligned). </dd></dl> + +</div> +</div> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/neorv32__spi_8h_source.html b/sw/neorv32__spi_8h_source.html new file mode 100644 index 0000000000..83c93a8813 --- /dev/null +++ b/sw/neorv32__spi_8h_source.html @@ -0,0 +1,231 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/lib/include/neorv32_spi.h Source File</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_7d04193005ada6f9450f847f4adb6b5b.html">lib</a></li><li class="navelem"><a class="el" href="dir_752b1e5d3973bf735fa78bf6b4727df9.html">include</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="headertitle"><div class="title">neorv32_spi.h</div></div> +</div><!--header--> +<div class="contents"> +<a href="neorv32__spi_8h.html">Go to the documentation of this file.</a><div class="fragment"><div class="line"><a id="l00001" name="l00001"></a><span class="lineno"> 1</span><span class="comment">// ================================================================================ //</span></div> +<div class="line"><a id="l00002" name="l00002"></a><span class="lineno"> 2</span><span class="comment">// The NEORV32 RISC-V Processor - https://github.com/stnolting/neorv32 //</span></div> +<div class="line"><a id="l00003" name="l00003"></a><span class="lineno"> 3</span><span class="comment">// Copyright (c) NEORV32 contributors. //</span></div> +<div class="line"><a id="l00004" name="l00004"></a><span class="lineno"> 4</span><span class="comment">// Copyright (c) 2020 - 2024 Stephan Nolting. All rights reserved. //</span></div> +<div class="line"><a id="l00005" name="l00005"></a><span class="lineno"> 5</span><span class="comment">// Licensed under the BSD-3-Clause license, see LICENSE for details. //</span></div> +<div class="line"><a id="l00006" name="l00006"></a><span class="lineno"> 6</span><span class="comment">// SPDX-License-Identifier: BSD-3-Clause //</span></div> +<div class="line"><a id="l00007" name="l00007"></a><span class="lineno"> 7</span><span class="comment">// ================================================================================ //</span></div> +<div class="line"><a id="l00008" name="l00008"></a><span class="lineno"> 8</span> </div> +<div class="line"><a id="l00018" name="l00018"></a><span class="lineno"> 18</span><span class="preprocessor">#ifndef neorv32_spi_h</span></div> +<div class="line"><a id="l00019" name="l00019"></a><span class="lineno"> 19</span><span class="preprocessor">#define neorv32_spi_h</span></div> +<div class="line"><a id="l00020" name="l00020"></a><span class="lineno"> 20</span> </div> +<div class="line"><a id="l00021" name="l00021"></a><span class="lineno"> 21</span><span class="preprocessor">#include &lt;stdint.h&gt;</span></div> +<div class="line"><a id="l00022" name="l00022"></a><span class="lineno"> 22</span> </div> +<div class="line"><a id="l00023" name="l00023"></a><span class="lineno"> 23</span> </div> +<div class="line"><a id="l00024" name="l00024"></a><span class="lineno"> 24</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen00029" data-start="{" data-end="};"> +<div class="line"><a id="l00029" name="l00029"></a><span class="lineno"><a class="line" href="structneorv32__spi__t.html"> 29</a></span><span class="keyword">typedef</span> <span class="keyword">volatile</span> <span class="keyword">struct </span>__attribute__((packed,aligned(4))) {</div> +<div class="line"><a id="l00030" name="l00030"></a><span class="lineno"><a class="line" href="structneorv32__spi__t.html#a34fa748f0e3ceb75822c0a5553bd0420"> 30</a></span> uint32_t <a class="code hl_variable" href="structneorv32__spi__t.html#a34fa748f0e3ceb75822c0a5553bd0420">CTRL</a>; </div> +<div class="line"><a id="l00031" name="l00031"></a><span class="lineno"><a class="line" href="structneorv32__spi__t.html#a3901bad351213e34820197a33d589f1e"> 31</a></span> uint32_t <a class="code hl_variable" href="structneorv32__spi__t.html#a3901bad351213e34820197a33d589f1e">DATA</a>; </div> +<div class="line"><a id="l00032" name="l00032"></a><span class="lineno"> 32</span>} <a class="code hl_struct" href="structneorv32__spi__t.html">neorv32_spi_t</a>;</div> +</div> +<div class="line"><a id="l00033" name="l00033"></a><span class="lineno"> 33</span> </div> +<div class="line"><a id="l00035" name="l00035"></a><span class="lineno"><a class="line" href="neorv32__spi_8h.html#a5f3afc4e268670c54d90df67fa38ca22"> 35</a></span><span class="preprocessor">#define NEORV32_SPI ((neorv32_spi_t*) (NEORV32_SPI_BASE))</span></div> +<div class="line"><a id="l00036" name="l00036"></a><span class="lineno"> 36</span> </div> +<div class="foldopen" id="foldopen00038" data-start="{" data-end="};"> +<div class="line"><a id="l00038" name="l00038"></a><span class="lineno"><a class="line" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3b"> 38</a></span><span class="keyword">enum</span> <a class="code hl_enumeration" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3b">NEORV32_SPI_CTRL_enum</a> {</div> +<div class="line"><a id="l00039" name="l00039"></a><span class="lineno"><a class="line" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba647a6357971f94b79b7672785c06a4ea"> 39</a></span> <a class="code hl_enumvalue" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba647a6357971f94b79b7672785c06a4ea">SPI_CTRL_EN</a> = 0, </div> +<div class="line"><a id="l00040" name="l00040"></a><span class="lineno"><a class="line" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba4d787c993152a9417fcd50f76820c7b0"> 40</a></span> <a class="code hl_enumvalue" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba4d787c993152a9417fcd50f76820c7b0">SPI_CTRL_CPHA</a> = 1, </div> +<div class="line"><a id="l00041" name="l00041"></a><span class="lineno"><a class="line" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba7661acb97cc8c6dd7f333be4f4a2d315"> 41</a></span> <a class="code hl_enumvalue" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba7661acb97cc8c6dd7f333be4f4a2d315">SPI_CTRL_CPOL</a> = 2, </div> +<div class="line"><a id="l00042" name="l00042"></a><span class="lineno"><a class="line" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3babc927c4ea78433de697a9fe96f47248e"> 42</a></span> <a class="code hl_enumvalue" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3babc927c4ea78433de697a9fe96f47248e">SPI_CTRL_PRSC0</a> = 3, </div> +<div class="line"><a id="l00043" name="l00043"></a><span class="lineno"><a class="line" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba49c38a34b95c034249a094fbc93e0a61"> 43</a></span> <a class="code hl_enumvalue" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba49c38a34b95c034249a094fbc93e0a61">SPI_CTRL_PRSC1</a> = 4, </div> +<div class="line"><a id="l00044" name="l00044"></a><span class="lineno"><a class="line" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba7a5244e443e1fe4ff6b7a2176f90ae7a"> 44</a></span> <a class="code hl_enumvalue" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba7a5244e443e1fe4ff6b7a2176f90ae7a">SPI_CTRL_PRSC2</a> = 5, </div> +<div class="line"><a id="l00045" name="l00045"></a><span class="lineno"><a class="line" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3bae6db5cfa843a58d7c09783e7f29fa49f"> 45</a></span> <a class="code hl_enumvalue" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3bae6db5cfa843a58d7c09783e7f29fa49f">SPI_CTRL_CDIV0</a> = 6, </div> +<div class="line"><a id="l00046" name="l00046"></a><span class="lineno"><a class="line" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba0b9ca202963b68b999f94baab50fbc48"> 46</a></span> <a class="code hl_enumvalue" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba0b9ca202963b68b999f94baab50fbc48">SPI_CTRL_CDIV1</a> = 7, </div> +<div class="line"><a id="l00047" name="l00047"></a><span class="lineno"><a class="line" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba97aaa7a4ffcc6d17a00c4f992e517c46"> 47</a></span> <a class="code hl_enumvalue" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba97aaa7a4ffcc6d17a00c4f992e517c46">SPI_CTRL_CDIV2</a> = 8, </div> +<div class="line"><a id="l00048" name="l00048"></a><span class="lineno"><a class="line" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba85164e4e00b5ccd34158f98f691bca29"> 48</a></span> <a class="code hl_enumvalue" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba85164e4e00b5ccd34158f98f691bca29">SPI_CTRL_CDIV3</a> = 9, </div> +<div class="line"><a id="l00049" name="l00049"></a><span class="lineno"><a class="line" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3bac38b12af6b8fb6bf2fc6f6ff6baee91e"> 49</a></span> <a class="code hl_enumvalue" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3bac38b12af6b8fb6bf2fc6f6ff6baee91e">SPI_CTRL_HIGHSPEED</a> = 10, </div> +<div class="line"><a id="l00051" name="l00051"></a><span class="lineno"><a class="line" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba115b097b76b3b99716f54a63c6ce5633"> 51</a></span> <a class="code hl_enumvalue" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba115b097b76b3b99716f54a63c6ce5633">SPI_CTRL_RX_AVAIL</a> = 16, </div> +<div class="line"><a id="l00052" name="l00052"></a><span class="lineno"><a class="line" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba487b87333d33db0a05cd2a229225ffc6"> 52</a></span> <a class="code hl_enumvalue" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba487b87333d33db0a05cd2a229225ffc6">SPI_CTRL_TX_EMPTY</a> = 17, </div> +<div class="line"><a id="l00053" name="l00053"></a><span class="lineno"><a class="line" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba5efcaded20b93d2bffeaa4ea813f73b4"> 53</a></span> <a class="code hl_enumvalue" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba5efcaded20b93d2bffeaa4ea813f73b4">SPI_CTRL_TX_NHALF</a> = 18, </div> +<div class="line"><a id="l00054" name="l00054"></a><span class="lineno"><a class="line" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba96860d260b31ee4c232b6b0eb45f7905"> 54</a></span> <a class="code hl_enumvalue" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba96860d260b31ee4c232b6b0eb45f7905">SPI_CTRL_TX_FULL</a> = 19, </div> +<div class="line"><a id="l00056" name="l00056"></a><span class="lineno"><a class="line" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba2cd2350ffc819b7198d1833b525c5ca0"> 56</a></span> <a class="code hl_enumvalue" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba2cd2350ffc819b7198d1833b525c5ca0">SPI_CTRL_IRQ_RX_AVAIL</a> = 20, </div> +<div class="line"><a id="l00057" name="l00057"></a><span class="lineno"><a class="line" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3bafcdc17528f9f4521c02ec5c473b44622"> 57</a></span> <a class="code hl_enumvalue" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3bafcdc17528f9f4521c02ec5c473b44622">SPI_CTRL_IRQ_TX_EMPTY</a> = 21, </div> +<div class="line"><a id="l00058" name="l00058"></a><span class="lineno"><a class="line" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba8c18d975418ad444255f80317448d26b"> 58</a></span> <a class="code hl_enumvalue" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba8c18d975418ad444255f80317448d26b">SPI_CTRL_IRQ_TX_HALF</a> = 22, </div> +<div class="line"><a id="l00059" name="l00059"></a><span class="lineno"><a class="line" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba3f80e9c6ef6445ad769038c955c171a2"> 59</a></span> <a class="code hl_enumvalue" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba3f80e9c6ef6445ad769038c955c171a2">SPI_CTRL_IRQ_IDLE</a> = 23, </div> +<div class="line"><a id="l00061" name="l00061"></a><span class="lineno"><a class="line" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba12f67abd206066651c1d62fc29fafcdb"> 61</a></span> <a class="code hl_enumvalue" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba12f67abd206066651c1d62fc29fafcdb">SPI_CTRL_FIFO_LSB</a> = 24, </div> +<div class="line"><a id="l00062" name="l00062"></a><span class="lineno"><a class="line" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba8c0426f70974f0ab129481f2db7cf0ed"> 62</a></span> <a class="code hl_enumvalue" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba8c0426f70974f0ab129481f2db7cf0ed">SPI_CTRL_FIFO_MSB</a> = 27, </div> +<div class="line"><a id="l00064" name="l00064"></a><span class="lineno"><a class="line" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba5e12c05349444d3d1defff49dec00580"> 64</a></span> <a class="code hl_enumvalue" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba5e12c05349444d3d1defff49dec00580">SPI_CS_ACTIVE</a> = 30, </div> +<div class="line"><a id="l00065" name="l00065"></a><span class="lineno"> 65</span> <a class="code hl_enumvalue" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba7957cf1cf3997cd059ed81cba73a688c">SPI_CTRL_BUSY</a> = 31 </div> +<div class="line"><a id="l00066" name="l00066"></a><span class="lineno"><a class="line" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba7957cf1cf3997cd059ed81cba73a688c"> 66</a></span>};</div> +</div> +<div class="line"><a id="l00067" name="l00067"></a><span class="lineno"> 67</span> </div> +<div class="foldopen" id="foldopen00069" data-start="{" data-end="};"> +<div class="line"><a id="l00069" name="l00069"></a><span class="lineno"><a class="line" href="neorv32__spi_8h.html#aab478c23898c0b06cee53a1cbda38bf8"> 69</a></span><span class="keyword">enum</span> <a class="code hl_enumeration" href="neorv32__spi_8h.html#aab478c23898c0b06cee53a1cbda38bf8">NEORV32_SPI_DATA_enum</a> {</div> +<div class="line"><a id="l00070" name="l00070"></a><span class="lineno"><a class="line" href="neorv32__spi_8h.html#aab478c23898c0b06cee53a1cbda38bf8ae3c36a644c05cea0fccaefb9da90a1b4"> 70</a></span> <a class="code hl_enumvalue" href="neorv32__spi_8h.html#aab478c23898c0b06cee53a1cbda38bf8ae3c36a644c05cea0fccaefb9da90a1b4">SPI_DATA_LSB</a> = 0, </div> +<div class="line"><a id="l00071" name="l00071"></a><span class="lineno"><a class="line" href="neorv32__spi_8h.html#aab478c23898c0b06cee53a1cbda38bf8a0167ec9c252ee0228ab9d21f4acba600"> 71</a></span> <a class="code hl_enumvalue" href="neorv32__spi_8h.html#aab478c23898c0b06cee53a1cbda38bf8a0167ec9c252ee0228ab9d21f4acba600">SPI_DATA_MSB</a> = 1, </div> +<div class="line"><a id="l00072" name="l00072"></a><span class="lineno"><a class="line" href="neorv32__spi_8h.html#aab478c23898c0b06cee53a1cbda38bf8a5673b6a3382dc5452e3cfcd4e8f3c8a2"> 72</a></span> <a class="code hl_enumvalue" href="neorv32__spi_8h.html#aab478c23898c0b06cee53a1cbda38bf8a5673b6a3382dc5452e3cfcd4e8f3c8a2">SPI_DATA_CSEN</a> = 3, </div> +<div class="line"><a id="l00073" name="l00073"></a><span class="lineno"> 73</span> <a class="code hl_enumvalue" href="neorv32__spi_8h.html#aab478c23898c0b06cee53a1cbda38bf8a8b565083f989905b8335d9d22a14c4b6">SPI_DATA_CMD</a> = 31 </div> +<div class="line"><a id="l00074" name="l00074"></a><span class="lineno"><a class="line" href="neorv32__spi_8h.html#aab478c23898c0b06cee53a1cbda38bf8a8b565083f989905b8335d9d22a14c4b6"> 74</a></span>};</div> +</div> +<div class="line"><a id="l00078" name="l00078"></a><span class="lineno"> 78</span><span class="comment">/**********************************************************************/</span></div> +<div class="line"><a id="l00082" name="l00082"></a><span class="lineno"> 82</span><span class="keywordtype">int</span> <a class="code hl_function" href="neorv32__spi_8h.html#a7266ee439d0ec11c5cedd4bf1a258272">neorv32_spi_available</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00083" name="l00083"></a><span class="lineno"> 83</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__spi_8h.html#a7d8124d986b69210081df6f1aa653552">neorv32_spi_setup</a>(<span class="keywordtype">int</span> prsc, <span class="keywordtype">int</span> cdiv, <span class="keywordtype">int</span> clk_phase, <span class="keywordtype">int</span> clk_polarity, uint32_t irq_mask);</div> +<div class="line"><a id="l00084" name="l00084"></a><span class="lineno"> 84</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__spi_8h.html#acf131faa3ad970c19a3cd8a47cb54f65">neorv32_spi_highspeed_enable</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00085" name="l00085"></a><span class="lineno"> 85</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__spi_8h.html#a67e9717635e272bc0e04408135a2f04d">neorv32_spi_highspeed_disable</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00086" name="l00086"></a><span class="lineno"> 86</span>uint32_t <a class="code hl_function" href="neorv32__spi_8h.html#a01c6b63d7349447e2277f2649c3c89f2">neorv32_spi_get_clock_speed</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00087" name="l00087"></a><span class="lineno"> 87</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__spi_8h.html#a817dd9a38bfceb2048e40874a83ba169">neorv32_spi_disable</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00088" name="l00088"></a><span class="lineno"> 88</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__spi_8h.html#a8fa25d144ccb20a2faf0450c8dddd16e">neorv32_spi_enable</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00089" name="l00089"></a><span class="lineno"> 89</span><span class="keywordtype">int</span> <a class="code hl_function" href="neorv32__spi_8h.html#ae1c4da7e4dc2e42b04d7187f684f142c">neorv32_spi_get_fifo_depth</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00090" name="l00090"></a><span class="lineno"> 90</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__spi_8h.html#a737961d040ac09567350f89034f9e122">neorv32_spi_cs_en</a>(<span class="keywordtype">int</span> cs);</div> +<div class="line"><a id="l00091" name="l00091"></a><span class="lineno"> 91</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__spi_8h.html#aa10ec90ccba6325eeeebb8f6f298d30c">neorv32_spi_cs_dis</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00092" name="l00092"></a><span class="lineno"> 92</span>uint8_t <a class="code hl_function" href="neorv32__spi_8h.html#a7af79950eefc26e67a89bde02f255532">neorv32_spi_trans</a>(uint8_t tx_data);</div> +<div class="line"><a id="l00093" name="l00093"></a><span class="lineno"> 93</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__spi_8h.html#aec8583e988789e846d21c2a35e6b06e7">neorv32_spi_put_nonblocking</a>(uint8_t tx_data);</div> +<div class="line"><a id="l00094" name="l00094"></a><span class="lineno"> 94</span>uint8_t <a class="code hl_function" href="neorv32__spi_8h.html#aad66fa8f8d1a92d4f355de7579bfbfd2">neorv32_spi_get_nonblocking</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00095" name="l00095"></a><span class="lineno"> 95</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__spi_8h.html#a97b5536347a27b053f071ba49071ba6f">neorv32_spi_cs_en_nonblocking</a>(<span class="keywordtype">int</span> cs);</div> +<div class="line"><a id="l00096" name="l00096"></a><span class="lineno"> 96</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__spi_8h.html#ad8dd1b5a85a9daef4c8c21c9990884c1">neorv32_spi_cs_dis_nonblocking</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00097" name="l00097"></a><span class="lineno"> 97</span><span class="keywordtype">int</span> <a class="code hl_function" href="neorv32__spi_8h.html#a82bb4d4c222b2bdc57e917c348481501">neorv32_spi_check_cs</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00098" name="l00098"></a><span class="lineno"> 98</span><span class="keywordtype">int</span> <a class="code hl_function" href="neorv32__spi_8h.html#a332c7a1be511812ac0a2b102c165398a">neorv32_spi_busy</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00101" name="l00101"></a><span class="lineno"> 101</span><span class="preprocessor">#endif </span><span class="comment">// neorv32_spi_h</span></div> +<div class="ttc" id="aneorv32__spi_8h_html_a01c6b63d7349447e2277f2649c3c89f2"><div class="ttname"><a href="neorv32__spi_8h.html#a01c6b63d7349447e2277f2649c3c89f2">neorv32_spi_get_clock_speed</a></div><div class="ttdeci">uint32_t neorv32_spi_get_clock_speed(void)</div><div class="ttdef"><b>Definition</b> neorv32_spi.c:85</div></div> +<div class="ttc" id="aneorv32__spi_8h_html_a332c7a1be511812ac0a2b102c165398a"><div class="ttname"><a href="neorv32__spi_8h.html#a332c7a1be511812ac0a2b102c165398a">neorv32_spi_busy</a></div><div class="ttdeci">int neorv32_spi_busy(void)</div><div class="ttdef"><b>Definition</b> neorv32_spi.c:247</div></div> +<div class="ttc" id="aneorv32__spi_8h_html_a67e9717635e272bc0e04408135a2f04d"><div class="ttname"><a href="neorv32__spi_8h.html#a67e9717635e272bc0e04408135a2f04d">neorv32_spi_highspeed_disable</a></div><div class="ttdeci">void neorv32_spi_highspeed_disable(void)</div><div class="ttdef"><b>Definition</b> neorv32_spi.c:74</div></div> +<div class="ttc" id="aneorv32__spi_8h_html_a7266ee439d0ec11c5cedd4bf1a258272"><div class="ttname"><a href="neorv32__spi_8h.html#a7266ee439d0ec11c5cedd4bf1a258272">neorv32_spi_available</a></div><div class="ttdeci">int neorv32_spi_available(void)</div><div class="ttdef"><b>Definition</b> neorv32_spi.c:26</div></div> +<div class="ttc" id="aneorv32__spi_8h_html_a737961d040ac09567350f89034f9e122"><div class="ttname"><a href="neorv32__spi_8h.html#a737961d040ac09567350f89034f9e122">neorv32_spi_cs_en</a></div><div class="ttdeci">void neorv32_spi_cs_en(int cs)</div><div class="ttdef"><b>Definition</b> neorv32_spi.c:144</div></div> +<div class="ttc" id="aneorv32__spi_8h_html_a7af79950eefc26e67a89bde02f255532"><div class="ttname"><a href="neorv32__spi_8h.html#a7af79950eefc26e67a89bde02f255532">neorv32_spi_trans</a></div><div class="ttdeci">uint8_t neorv32_spi_trans(uint8_t tx_data)</div><div class="ttdef"><b>Definition</b> neorv32_spi.c:172</div></div> +<div class="ttc" id="aneorv32__spi_8h_html_a7d8124d986b69210081df6f1aa653552"><div class="ttname"><a href="neorv32__spi_8h.html#a7d8124d986b69210081df6f1aa653552">neorv32_spi_setup</a></div><div class="ttdeci">void neorv32_spi_setup(int prsc, int cdiv, int clk_phase, int clk_polarity, uint32_t irq_mask)</div><div class="ttdef"><b>Definition</b> neorv32_spi.c:46</div></div> +<div class="ttc" id="aneorv32__spi_8h_html_a817dd9a38bfceb2048e40874a83ba169"><div class="ttname"><a href="neorv32__spi_8h.html#a817dd9a38bfceb2048e40874a83ba169">neorv32_spi_disable</a></div><div class="ttdeci">void neorv32_spi_disable(void)</div><div class="ttdef"><b>Definition</b> neorv32_spi.c:109</div></div> +<div class="ttc" id="aneorv32__spi_8h_html_a82bb4d4c222b2bdc57e917c348481501"><div class="ttname"><a href="neorv32__spi_8h.html#a82bb4d4c222b2bdc57e917c348481501">neorv32_spi_check_cs</a></div><div class="ttdeci">int neorv32_spi_check_cs(void)</div><div class="ttdef"><b>Definition</b> neorv32_spi.c:231</div></div> +<div class="ttc" id="aneorv32__spi_8h_html_a8fa25d144ccb20a2faf0450c8dddd16e"><div class="ttname"><a href="neorv32__spi_8h.html#a8fa25d144ccb20a2faf0450c8dddd16e">neorv32_spi_enable</a></div><div class="ttdeci">void neorv32_spi_enable(void)</div><div class="ttdef"><b>Definition</b> neorv32_spi.c:118</div></div> +<div class="ttc" id="aneorv32__spi_8h_html_a97b5536347a27b053f071ba49071ba6f"><div class="ttname"><a href="neorv32__spi_8h.html#a97b5536347a27b053f071ba49071ba6f">neorv32_spi_cs_en_nonblocking</a></div><div class="ttdeci">void neorv32_spi_cs_en_nonblocking(int cs)</div><div class="ttdef"><b>Definition</b> neorv32_spi.c:209</div></div> +<div class="ttc" id="aneorv32__spi_8h_html_aa10ec90ccba6325eeeebb8f6f298d30c"><div class="ttname"><a href="neorv32__spi_8h.html#aa10ec90ccba6325eeeebb8f6f298d30c">neorv32_spi_cs_dis</a></div><div class="ttdeci">void neorv32_spi_cs_dis(void)</div><div class="ttdef"><b>Definition</b> neorv32_spi.c:157</div></div> +<div class="ttc" id="aneorv32__spi_8h_html_aab478c23898c0b06cee53a1cbda38bf8"><div class="ttname"><a href="neorv32__spi_8h.html#aab478c23898c0b06cee53a1cbda38bf8">NEORV32_SPI_DATA_enum</a></div><div class="ttdeci">NEORV32_SPI_DATA_enum</div><div class="ttdef"><b>Definition</b> neorv32_spi.h:69</div></div> +<div class="ttc" id="aneorv32__spi_8h_html_aab478c23898c0b06cee53a1cbda38bf8a0167ec9c252ee0228ab9d21f4acba600"><div class="ttname"><a href="neorv32__spi_8h.html#aab478c23898c0b06cee53a1cbda38bf8a0167ec9c252ee0228ab9d21f4acba600">SPI_DATA_MSB</a></div><div class="ttdeci">@ SPI_DATA_MSB</div><div class="ttdef"><b>Definition</b> neorv32_spi.h:71</div></div> +<div class="ttc" id="aneorv32__spi_8h_html_aab478c23898c0b06cee53a1cbda38bf8a5673b6a3382dc5452e3cfcd4e8f3c8a2"><div class="ttname"><a href="neorv32__spi_8h.html#aab478c23898c0b06cee53a1cbda38bf8a5673b6a3382dc5452e3cfcd4e8f3c8a2">SPI_DATA_CSEN</a></div><div class="ttdeci">@ SPI_DATA_CSEN</div><div class="ttdef"><b>Definition</b> neorv32_spi.h:72</div></div> +<div class="ttc" id="aneorv32__spi_8h_html_aab478c23898c0b06cee53a1cbda38bf8a8b565083f989905b8335d9d22a14c4b6"><div class="ttname"><a href="neorv32__spi_8h.html#aab478c23898c0b06cee53a1cbda38bf8a8b565083f989905b8335d9d22a14c4b6">SPI_DATA_CMD</a></div><div class="ttdeci">@ SPI_DATA_CMD</div><div class="ttdef"><b>Definition</b> neorv32_spi.h:73</div></div> +<div class="ttc" id="aneorv32__spi_8h_html_aab478c23898c0b06cee53a1cbda38bf8ae3c36a644c05cea0fccaefb9da90a1b4"><div class="ttname"><a href="neorv32__spi_8h.html#aab478c23898c0b06cee53a1cbda38bf8ae3c36a644c05cea0fccaefb9da90a1b4">SPI_DATA_LSB</a></div><div class="ttdeci">@ SPI_DATA_LSB</div><div class="ttdef"><b>Definition</b> neorv32_spi.h:70</div></div> +<div class="ttc" id="aneorv32__spi_8h_html_aad66fa8f8d1a92d4f355de7579bfbfd2"><div class="ttname"><a href="neorv32__spi_8h.html#aad66fa8f8d1a92d4f355de7579bfbfd2">neorv32_spi_get_nonblocking</a></div><div class="ttdeci">uint8_t neorv32_spi_get_nonblocking(void)</div><div class="ttdef"><b>Definition</b> neorv32_spi.c:196</div></div> +<div class="ttc" id="aneorv32__spi_8h_html_acf131faa3ad970c19a3cd8a47cb54f65"><div class="ttname"><a href="neorv32__spi_8h.html#acf131faa3ad970c19a3cd8a47cb54f65">neorv32_spi_highspeed_enable</a></div><div class="ttdeci">void neorv32_spi_highspeed_enable(void)</div><div class="ttdef"><b>Definition</b> neorv32_spi.c:65</div></div> +<div class="ttc" id="aneorv32__spi_8h_html_ad8dd1b5a85a9daef4c8c21c9990884c1"><div class="ttname"><a href="neorv32__spi_8h.html#ad8dd1b5a85a9daef4c8c21c9990884c1">neorv32_spi_cs_dis_nonblocking</a></div><div class="ttdeci">void neorv32_spi_cs_dis_nonblocking(void)</div><div class="ttdef"><b>Definition</b> neorv32_spi.c:220</div></div> +<div class="ttc" id="aneorv32__spi_8h_html_ae1c4da7e4dc2e42b04d7187f684f142c"><div class="ttname"><a href="neorv32__spi_8h.html#ae1c4da7e4dc2e42b04d7187f684f142c">neorv32_spi_get_fifo_depth</a></div><div class="ttdeci">int neorv32_spi_get_fifo_depth(void)</div><div class="ttdef"><b>Definition</b> neorv32_spi.c:129</div></div> +<div class="ttc" id="aneorv32__spi_8h_html_ae269b2f5b2afd46ae16801762ade2c3b"><div class="ttname"><a href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3b">NEORV32_SPI_CTRL_enum</a></div><div class="ttdeci">NEORV32_SPI_CTRL_enum</div><div class="ttdef"><b>Definition</b> neorv32_spi.h:38</div></div> +<div class="ttc" id="aneorv32__spi_8h_html_ae269b2f5b2afd46ae16801762ade2c3ba0b9ca202963b68b999f94baab50fbc48"><div class="ttname"><a href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba0b9ca202963b68b999f94baab50fbc48">SPI_CTRL_CDIV1</a></div><div class="ttdeci">@ SPI_CTRL_CDIV1</div><div class="ttdef"><b>Definition</b> neorv32_spi.h:46</div></div> +<div class="ttc" id="aneorv32__spi_8h_html_ae269b2f5b2afd46ae16801762ade2c3ba115b097b76b3b99716f54a63c6ce5633"><div class="ttname"><a href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba115b097b76b3b99716f54a63c6ce5633">SPI_CTRL_RX_AVAIL</a></div><div class="ttdeci">@ SPI_CTRL_RX_AVAIL</div><div class="ttdef"><b>Definition</b> neorv32_spi.h:51</div></div> +<div class="ttc" id="aneorv32__spi_8h_html_ae269b2f5b2afd46ae16801762ade2c3ba12f67abd206066651c1d62fc29fafcdb"><div class="ttname"><a href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba12f67abd206066651c1d62fc29fafcdb">SPI_CTRL_FIFO_LSB</a></div><div class="ttdeci">@ SPI_CTRL_FIFO_LSB</div><div class="ttdef"><b>Definition</b> neorv32_spi.h:61</div></div> +<div class="ttc" id="aneorv32__spi_8h_html_ae269b2f5b2afd46ae16801762ade2c3ba2cd2350ffc819b7198d1833b525c5ca0"><div class="ttname"><a href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba2cd2350ffc819b7198d1833b525c5ca0">SPI_CTRL_IRQ_RX_AVAIL</a></div><div class="ttdeci">@ SPI_CTRL_IRQ_RX_AVAIL</div><div class="ttdef"><b>Definition</b> neorv32_spi.h:56</div></div> +<div class="ttc" id="aneorv32__spi_8h_html_ae269b2f5b2afd46ae16801762ade2c3ba3f80e9c6ef6445ad769038c955c171a2"><div class="ttname"><a href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba3f80e9c6ef6445ad769038c955c171a2">SPI_CTRL_IRQ_IDLE</a></div><div class="ttdeci">@ SPI_CTRL_IRQ_IDLE</div><div class="ttdef"><b>Definition</b> neorv32_spi.h:59</div></div> +<div class="ttc" id="aneorv32__spi_8h_html_ae269b2f5b2afd46ae16801762ade2c3ba487b87333d33db0a05cd2a229225ffc6"><div class="ttname"><a href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba487b87333d33db0a05cd2a229225ffc6">SPI_CTRL_TX_EMPTY</a></div><div class="ttdeci">@ SPI_CTRL_TX_EMPTY</div><div class="ttdef"><b>Definition</b> neorv32_spi.h:52</div></div> +<div class="ttc" id="aneorv32__spi_8h_html_ae269b2f5b2afd46ae16801762ade2c3ba49c38a34b95c034249a094fbc93e0a61"><div class="ttname"><a href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba49c38a34b95c034249a094fbc93e0a61">SPI_CTRL_PRSC1</a></div><div class="ttdeci">@ SPI_CTRL_PRSC1</div><div class="ttdef"><b>Definition</b> neorv32_spi.h:43</div></div> +<div class="ttc" id="aneorv32__spi_8h_html_ae269b2f5b2afd46ae16801762ade2c3ba4d787c993152a9417fcd50f76820c7b0"><div class="ttname"><a href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba4d787c993152a9417fcd50f76820c7b0">SPI_CTRL_CPHA</a></div><div class="ttdeci">@ SPI_CTRL_CPHA</div><div class="ttdef"><b>Definition</b> neorv32_spi.h:40</div></div> +<div class="ttc" id="aneorv32__spi_8h_html_ae269b2f5b2afd46ae16801762ade2c3ba5e12c05349444d3d1defff49dec00580"><div class="ttname"><a href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba5e12c05349444d3d1defff49dec00580">SPI_CS_ACTIVE</a></div><div class="ttdeci">@ SPI_CS_ACTIVE</div><div class="ttdef"><b>Definition</b> neorv32_spi.h:64</div></div> +<div class="ttc" id="aneorv32__spi_8h_html_ae269b2f5b2afd46ae16801762ade2c3ba5efcaded20b93d2bffeaa4ea813f73b4"><div class="ttname"><a href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba5efcaded20b93d2bffeaa4ea813f73b4">SPI_CTRL_TX_NHALF</a></div><div class="ttdeci">@ SPI_CTRL_TX_NHALF</div><div class="ttdef"><b>Definition</b> neorv32_spi.h:53</div></div> +<div class="ttc" id="aneorv32__spi_8h_html_ae269b2f5b2afd46ae16801762ade2c3ba647a6357971f94b79b7672785c06a4ea"><div class="ttname"><a href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba647a6357971f94b79b7672785c06a4ea">SPI_CTRL_EN</a></div><div class="ttdeci">@ SPI_CTRL_EN</div><div class="ttdef"><b>Definition</b> neorv32_spi.h:39</div></div> +<div class="ttc" id="aneorv32__spi_8h_html_ae269b2f5b2afd46ae16801762ade2c3ba7661acb97cc8c6dd7f333be4f4a2d315"><div class="ttname"><a href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba7661acb97cc8c6dd7f333be4f4a2d315">SPI_CTRL_CPOL</a></div><div class="ttdeci">@ SPI_CTRL_CPOL</div><div class="ttdef"><b>Definition</b> neorv32_spi.h:41</div></div> +<div class="ttc" id="aneorv32__spi_8h_html_ae269b2f5b2afd46ae16801762ade2c3ba7957cf1cf3997cd059ed81cba73a688c"><div class="ttname"><a href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba7957cf1cf3997cd059ed81cba73a688c">SPI_CTRL_BUSY</a></div><div class="ttdeci">@ SPI_CTRL_BUSY</div><div class="ttdef"><b>Definition</b> neorv32_spi.h:65</div></div> +<div class="ttc" id="aneorv32__spi_8h_html_ae269b2f5b2afd46ae16801762ade2c3ba7a5244e443e1fe4ff6b7a2176f90ae7a"><div class="ttname"><a href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba7a5244e443e1fe4ff6b7a2176f90ae7a">SPI_CTRL_PRSC2</a></div><div class="ttdeci">@ SPI_CTRL_PRSC2</div><div class="ttdef"><b>Definition</b> neorv32_spi.h:44</div></div> +<div class="ttc" id="aneorv32__spi_8h_html_ae269b2f5b2afd46ae16801762ade2c3ba85164e4e00b5ccd34158f98f691bca29"><div class="ttname"><a href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba85164e4e00b5ccd34158f98f691bca29">SPI_CTRL_CDIV3</a></div><div class="ttdeci">@ SPI_CTRL_CDIV3</div><div class="ttdef"><b>Definition</b> neorv32_spi.h:48</div></div> +<div class="ttc" id="aneorv32__spi_8h_html_ae269b2f5b2afd46ae16801762ade2c3ba8c0426f70974f0ab129481f2db7cf0ed"><div class="ttname"><a href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba8c0426f70974f0ab129481f2db7cf0ed">SPI_CTRL_FIFO_MSB</a></div><div class="ttdeci">@ SPI_CTRL_FIFO_MSB</div><div class="ttdef"><b>Definition</b> neorv32_spi.h:62</div></div> +<div class="ttc" id="aneorv32__spi_8h_html_ae269b2f5b2afd46ae16801762ade2c3ba8c18d975418ad444255f80317448d26b"><div class="ttname"><a href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba8c18d975418ad444255f80317448d26b">SPI_CTRL_IRQ_TX_HALF</a></div><div class="ttdeci">@ SPI_CTRL_IRQ_TX_HALF</div><div class="ttdef"><b>Definition</b> neorv32_spi.h:58</div></div> +<div class="ttc" id="aneorv32__spi_8h_html_ae269b2f5b2afd46ae16801762ade2c3ba96860d260b31ee4c232b6b0eb45f7905"><div class="ttname"><a href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba96860d260b31ee4c232b6b0eb45f7905">SPI_CTRL_TX_FULL</a></div><div class="ttdeci">@ SPI_CTRL_TX_FULL</div><div class="ttdef"><b>Definition</b> neorv32_spi.h:54</div></div> +<div class="ttc" id="aneorv32__spi_8h_html_ae269b2f5b2afd46ae16801762ade2c3ba97aaa7a4ffcc6d17a00c4f992e517c46"><div class="ttname"><a href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba97aaa7a4ffcc6d17a00c4f992e517c46">SPI_CTRL_CDIV2</a></div><div class="ttdeci">@ SPI_CTRL_CDIV2</div><div class="ttdef"><b>Definition</b> neorv32_spi.h:47</div></div> +<div class="ttc" id="aneorv32__spi_8h_html_ae269b2f5b2afd46ae16801762ade2c3babc927c4ea78433de697a9fe96f47248e"><div class="ttname"><a href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3babc927c4ea78433de697a9fe96f47248e">SPI_CTRL_PRSC0</a></div><div class="ttdeci">@ SPI_CTRL_PRSC0</div><div class="ttdef"><b>Definition</b> neorv32_spi.h:42</div></div> +<div class="ttc" id="aneorv32__spi_8h_html_ae269b2f5b2afd46ae16801762ade2c3bac38b12af6b8fb6bf2fc6f6ff6baee91e"><div class="ttname"><a href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3bac38b12af6b8fb6bf2fc6f6ff6baee91e">SPI_CTRL_HIGHSPEED</a></div><div class="ttdeci">@ SPI_CTRL_HIGHSPEED</div><div class="ttdef"><b>Definition</b> neorv32_spi.h:49</div></div> +<div class="ttc" id="aneorv32__spi_8h_html_ae269b2f5b2afd46ae16801762ade2c3bae6db5cfa843a58d7c09783e7f29fa49f"><div class="ttname"><a href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3bae6db5cfa843a58d7c09783e7f29fa49f">SPI_CTRL_CDIV0</a></div><div class="ttdeci">@ SPI_CTRL_CDIV0</div><div class="ttdef"><b>Definition</b> neorv32_spi.h:45</div></div> +<div class="ttc" id="aneorv32__spi_8h_html_ae269b2f5b2afd46ae16801762ade2c3bafcdc17528f9f4521c02ec5c473b44622"><div class="ttname"><a href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3bafcdc17528f9f4521c02ec5c473b44622">SPI_CTRL_IRQ_TX_EMPTY</a></div><div class="ttdeci">@ SPI_CTRL_IRQ_TX_EMPTY</div><div class="ttdef"><b>Definition</b> neorv32_spi.h:57</div></div> +<div class="ttc" id="aneorv32__spi_8h_html_aec8583e988789e846d21c2a35e6b06e7"><div class="ttname"><a href="neorv32__spi_8h.html#aec8583e988789e846d21c2a35e6b06e7">neorv32_spi_put_nonblocking</a></div><div class="ttdeci">void neorv32_spi_put_nonblocking(uint8_t tx_data)</div><div class="ttdef"><b>Definition</b> neorv32_spi.c:185</div></div> +<div class="ttc" id="astructneorv32__spi__t_html"><div class="ttname"><a href="structneorv32__spi__t.html">neorv32_spi_t</a></div><div class="ttdef"><b>Definition</b> neorv32_spi.h:29</div></div> +<div class="ttc" id="astructneorv32__spi__t_html_a34fa748f0e3ceb75822c0a5553bd0420"><div class="ttname"><a href="structneorv32__spi__t.html#a34fa748f0e3ceb75822c0a5553bd0420">neorv32_spi_t::CTRL</a></div><div class="ttdeci">uint32_t CTRL</div><div class="ttdef"><b>Definition</b> neorv32_spi.h:30</div></div> +<div class="ttc" id="astructneorv32__spi__t_html_a3901bad351213e34820197a33d589f1e"><div class="ttname"><a href="structneorv32__spi__t.html#a3901bad351213e34820197a33d589f1e">neorv32_spi_t::DATA</a></div><div class="ttdeci">uint32_t DATA</div><div class="ttdef"><b>Definition</b> neorv32_spi.h:31</div></div> +</div><!-- fragment --></div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/neorv32__spi__irq_8c.html b/sw/neorv32__spi__irq_8c.html new file mode 100644 index 0000000000..9c88109ba9 --- /dev/null +++ b/sw/neorv32__spi__irq_8c.html @@ -0,0 +1,257 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/example/demo_spi_irq/drv/neorv32_spi_irq.c File Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_f0f9b27afba2e8cc2da6e5fddcc1a8c9.html">example</a></li><li class="navelem"><a class="el" href="dir_8f848e36ac87ced1c361afcc0549ca32.html">demo_spi_irq</a></li><li class="navelem"><a class="el" href="dir_9d04cdc586d6978be343bda7adcdc371.html">drv</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#func-members">Functions</a> </div> + <div class="headertitle"><div class="title">neorv32_spi_irq.c File Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p>Addition to <a class="el" href="neorv32__spi_8c.html" title="Serial peripheral interface controller (SPI) HW driver source file.">neorv32_spi.c</a>, which provides an IRQ driven data flow. +<a href="#details">More...</a></p> +<div class="textblock"><code>#include &quot;<a class="el" href="neorv32_8h_source.html">neorv32.h</a>&quot;</code><br /> +<code>#include &quot;<a class="el" href="neorv32__spi__irq_8h_source.html">neorv32_spi_irq.h</a>&quot;</code><br /> +</div><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="func-members" name="func-members"></a> +Functions</h2></td></tr> +<tr class="memitem:a4aa4746fd210ecc0c3614089a6951ddf" id="r_a4aa4746fd210ecc0c3614089a6951ddf"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a4aa4746fd210ecc0c3614089a6951ddf">neorv32_spi_init</a> (<a class="el" href="structt__neorv32__spi.html">t_neorv32_spi</a> *self)</td></tr> +<tr class="separator:a4aa4746fd210ecc0c3614089a6951ddf"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aa641816bb302df497664aa21ea69ed16" id="r_aa641816bb302df497664aa21ea69ed16"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aa641816bb302df497664aa21ea69ed16">neorv32_spi_isr</a> (<a class="el" href="structt__neorv32__spi.html">t_neorv32_spi</a> *self)</td></tr> +<tr class="separator:aa641816bb302df497664aa21ea69ed16"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a1f44ed849415d8e1d659c0485762c485" id="r_a1f44ed849415d8e1d659c0485762c485"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a1f44ed849415d8e1d659c0485762c485">neorv32_spi_rw</a> (<a class="el" href="structt__neorv32__spi.html">t_neorv32_spi</a> *self, uint8_t csn, void *spi, uint32_t len)</td></tr> +<tr class="separator:a1f44ed849415d8e1d659c0485762c485"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a1863e19932bc6a79f2ca27d23eb74ef5" id="r_a1863e19932bc6a79f2ca27d23eb74ef5"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a1863e19932bc6a79f2ca27d23eb74ef5">neorv32_spi_rw_busy</a> (<a class="el" href="structt__neorv32__spi.html">t_neorv32_spi</a> *self)</td></tr> +<tr class="separator:a1863e19932bc6a79f2ca27d23eb74ef5"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>Addition to <a class="el" href="neorv32__spi_8c.html" title="Serial peripheral interface controller (SPI) HW driver source file.">neorv32_spi.c</a>, which provides an IRQ driven data flow. </p> +<dl class="section author"><dt>Author</dt><dd>Andreas Kaeberlein </dd></dl> +<dl class="section note"><dt>Note</dt><dd>These functions should only be used if the SPI unit was synthesized (IO_SPI_EN = true). </dd></dl> +</div><h2 class="groupheader">Function Documentation</h2> +<a id="a4aa4746fd210ecc0c3614089a6951ddf" name="a4aa4746fd210ecc0c3614089a6951ddf"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a4aa4746fd210ecc0c3614089a6951ddf">&#9670;&#160;</a></span>neorv32_spi_init()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_spi_init </td> + <td>(</td> + <td class="paramtype"><a class="el" href="structt__neorv32__spi.html">t_neorv32_spi</a> *</td> <td class="paramname"><span class="paramname"><em>self</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Initializes SPI flow control handle. The data structure elements are listed in <a class="el" href="structt__neorv32__spi.html">t_neorv32_spi</a>.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in,out]</td><td class="paramname">*self</td><td>SPI driver common data handle. See <a class="el" href="structt__neorv32__spi.html">t_neorv32_spi</a>. </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="aa641816bb302df497664aa21ea69ed16" name="aa641816bb302df497664aa21ea69ed16"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aa641816bb302df497664aa21ea69ed16">&#9670;&#160;</a></span>neorv32_spi_isr()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_spi_isr </td> + <td>(</td> + <td class="paramtype"><a class="el" href="structt__neorv32__spi.html">t_neorv32_spi</a> *</td> <td class="paramname"><span class="paramname"><em>self</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>SPI interrupt service routine. The data structure elements are listed in <a class="el" href="structt__neorv32__spi.html">t_neorv32_spi</a>.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in,out]</td><td class="paramname">*self</td><td>SPI driver common data handle. See <a class="el" href="structt__neorv32__spi.html">t_neorv32_spi</a>. </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="a1f44ed849415d8e1d659c0485762c485" name="a1f44ed849415d8e1d659c0485762c485"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a1f44ed849415d8e1d659c0485762c485">&#9670;&#160;</a></span>neorv32_spi_rw()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_spi_rw </td> + <td>(</td> + <td class="paramtype"><a class="el" href="structt__neorv32__spi.html">t_neorv32_spi</a> *</td> <td class="paramname"><span class="paramname"><em>self</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">uint8_t</td> <td class="paramname"><span class="paramname"><em>csn</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">void *</td> <td class="paramname"><span class="paramname"><em>spi</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>len</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Starts ISR driven read/write SPI transfer.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in,out]</td><td class="paramname">*self</td><td>SPI driver common data handle. See <a class="el" href="structt__neorv32__spi.html">t_neorv32_spi</a>. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">csn</td><td>Used chip select index for transfer. </td></tr> + <tr><td class="paramdir">[in,out]</td><td class="paramname">*spi</td><td>write/read data buffer for SPI. Before transmission contents the write data and after the read data. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">len</td><td>number of bytes to transfer. </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>int status of function. </dd></dl> +<dl class="retval"><dt>Return values</dt><dd> + <table class="retval"> + <tr><td class="paramname">0</td><td>new transfer started. </td></tr> + <tr><td class="paramname">1</td><td>transfer active, refused request. </td></tr> + <tr><td class="paramname">2</td><td>unsupported data size, only 1/2/4 allowed. </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="a1863e19932bc6a79f2ca27d23eb74ef5" name="a1863e19932bc6a79f2ca27d23eb74ef5"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a1863e19932bc6a79f2ca27d23eb74ef5">&#9670;&#160;</a></span>neorv32_spi_rw_busy()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_spi_rw_busy </td> + <td>(</td> + <td class="paramtype"><a class="el" href="structt__neorv32__spi.html">t_neorv32_spi</a> *</td> <td class="paramname"><span class="paramname"><em>self</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Check if transfer is active. see <a class="el" href="#a1f44ed849415d8e1d659c0485762c485">neorv32_spi_rw</a></p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in,out]</td><td class="paramname">*self</td><td>SPI driver common data handle. See <a class="el" href="structt__neorv32__spi.html">t_neorv32_spi</a>. </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>int status of function. </dd></dl> +<dl class="retval"><dt>Return values</dt><dd> + <table class="retval"> + <tr><td class="paramname">0</td><td>idle. </td></tr> + <tr><td class="paramname">1</td><td>busy. </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/neorv32__spi__irq_8h.html b/sw/neorv32__spi__irq_8h.html new file mode 100644 index 0000000000..5c4679bada --- /dev/null +++ b/sw/neorv32__spi__irq_8h.html @@ -0,0 +1,301 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/example/demo_spi_irq/drv/neorv32_spi_irq.h File Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_f0f9b27afba2e8cc2da6e5fddcc1a8c9.html">example</a></li><li class="navelem"><a class="el" href="dir_8f848e36ac87ced1c361afcc0549ca32.html">demo_spi_irq</a></li><li class="navelem"><a class="el" href="dir_9d04cdc586d6978be343bda7adcdc371.html">drv</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#nested-classes">Data Structures</a> &#124; +<a href="#define-members">Macros</a> &#124; +<a href="#typedef-members">Typedefs</a> &#124; +<a href="#func-members">Functions</a> </div> + <div class="headertitle"><div class="title">neorv32_spi_irq.h File Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p>Addition to <a class="el" href="neorv32__spi_8h.html" title="Serial peripheral interface controller (SPI) HW driver header file.">neorv32_spi.h</a>, which provides an IRQ driven data flow. +<a href="#details">More...</a></p> + +<p><a href="neorv32__spi__irq_8h_source.html">Go to the source code of this file.</a></p> +<table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="nested-classes" name="nested-classes"></a> +Data Structures</h2></td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">struct &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structt__neorv32__spi.html">t_neorv32_spi</a></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="define-members" name="define-members"></a> +Macros</h2></td></tr> +<tr class="memitem:ac6afabdc09a49a433ee19d8a9486056d" id="r_ac6afabdc09a49a433ee19d8a9486056d"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ac6afabdc09a49a433ee19d8a9486056d">min</a>(a, b)</td></tr> +<tr class="separator:ac6afabdc09a49a433ee19d8a9486056d"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="typedef-members" name="typedef-members"></a> +Typedefs</h2></td></tr> +<tr class="memitem:a1bff352570118788aafc29fcc41c27f9" id="r_a1bff352570118788aafc29fcc41c27f9"><td class="memItemLeft" align="right" valign="top"><a id="a1bff352570118788aafc29fcc41c27f9" name="a1bff352570118788aafc29fcc41c27f9"></a> +typedef struct t_neorv32_spi&#160;</td><td class="memItemRight" valign="bottom"><b>t_neorv32_spi</b></td></tr> +<tr class="separator:a1bff352570118788aafc29fcc41c27f9"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="func-members" name="func-members"></a> +Functions</h2></td></tr> +<tr class="memitem:a4aa4746fd210ecc0c3614089a6951ddf" id="r_a4aa4746fd210ecc0c3614089a6951ddf"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a4aa4746fd210ecc0c3614089a6951ddf">neorv32_spi_init</a> (<a class="el" href="structt__neorv32__spi.html">t_neorv32_spi</a> *self)</td></tr> +<tr class="separator:a4aa4746fd210ecc0c3614089a6951ddf"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aa641816bb302df497664aa21ea69ed16" id="r_aa641816bb302df497664aa21ea69ed16"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aa641816bb302df497664aa21ea69ed16">neorv32_spi_isr</a> (<a class="el" href="structt__neorv32__spi.html">t_neorv32_spi</a> *self)</td></tr> +<tr class="separator:aa641816bb302df497664aa21ea69ed16"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a1f44ed849415d8e1d659c0485762c485" id="r_a1f44ed849415d8e1d659c0485762c485"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a1f44ed849415d8e1d659c0485762c485">neorv32_spi_rw</a> (<a class="el" href="structt__neorv32__spi.html">t_neorv32_spi</a> *self, uint8_t csn, void *spi, uint32_t len)</td></tr> +<tr class="separator:a1f44ed849415d8e1d659c0485762c485"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a1863e19932bc6a79f2ca27d23eb74ef5" id="r_a1863e19932bc6a79f2ca27d23eb74ef5"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a1863e19932bc6a79f2ca27d23eb74ef5">neorv32_spi_rw_busy</a> (<a class="el" href="structt__neorv32__spi.html">t_neorv32_spi</a> *self)</td></tr> +<tr class="separator:a1863e19932bc6a79f2ca27d23eb74ef5"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>Addition to <a class="el" href="neorv32__spi_8h.html" title="Serial peripheral interface controller (SPI) HW driver header file.">neorv32_spi.h</a>, which provides an IRQ driven data flow. </p> +<dl class="section author"><dt>Author</dt><dd>Andreas Kaeberlein </dd></dl> +<dl class="section note"><dt>Note</dt><dd>These functions should only be used if the SPI unit was synthesized (IO_SPI_EN = true). </dd></dl> +</div><h2 class="groupheader">Macro Definition Documentation</h2> +<a id="ac6afabdc09a49a433ee19d8a9486056d" name="ac6afabdc09a49a433ee19d8a9486056d"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ac6afabdc09a49a433ee19d8a9486056d">&#9670;&#160;</a></span>min</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define min</td> + <td>(</td> + <td class="paramtype"></td> <td class="paramname"><span class="paramname"><em>a</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype"></td> <td class="paramname"><span class="paramname"><em>b</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<b>Value:</b><div class="fragment"><div class="line"> ({ __typeof__ (a) _a = (a); \</div> +<div class="line"> __typeof__ (b) _b = (b); \</div> +<div class="line"> _a &lt; _b ? _a : _b; })</div> +</div><!-- fragment --> +</div> +</div> +<h2 class="groupheader">Function Documentation</h2> +<a id="a4aa4746fd210ecc0c3614089a6951ddf" name="a4aa4746fd210ecc0c3614089a6951ddf"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a4aa4746fd210ecc0c3614089a6951ddf">&#9670;&#160;</a></span>neorv32_spi_init()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_spi_init </td> + <td>(</td> + <td class="paramtype"><a class="el" href="structt__neorv32__spi.html">t_neorv32_spi</a> *</td> <td class="paramname"><span class="paramname"><em>self</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Initializes SPI flow control handle. The data structure elements are listed in <a class="el" href="structt__neorv32__spi.html">t_neorv32_spi</a>.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in,out]</td><td class="paramname">*self</td><td>SPI driver common data handle. See <a class="el" href="structt__neorv32__spi.html">t_neorv32_spi</a>. </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="aa641816bb302df497664aa21ea69ed16" name="aa641816bb302df497664aa21ea69ed16"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aa641816bb302df497664aa21ea69ed16">&#9670;&#160;</a></span>neorv32_spi_isr()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_spi_isr </td> + <td>(</td> + <td class="paramtype"><a class="el" href="structt__neorv32__spi.html">t_neorv32_spi</a> *</td> <td class="paramname"><span class="paramname"><em>self</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>SPI interrupt service routine. The data structure elements are listed in <a class="el" href="structt__neorv32__spi.html">t_neorv32_spi</a>.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in,out]</td><td class="paramname">*self</td><td>SPI driver common data handle. See <a class="el" href="structt__neorv32__spi.html">t_neorv32_spi</a>. </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="a1f44ed849415d8e1d659c0485762c485" name="a1f44ed849415d8e1d659c0485762c485"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a1f44ed849415d8e1d659c0485762c485">&#9670;&#160;</a></span>neorv32_spi_rw()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_spi_rw </td> + <td>(</td> + <td class="paramtype"><a class="el" href="structt__neorv32__spi.html">t_neorv32_spi</a> *</td> <td class="paramname"><span class="paramname"><em>self</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">uint8_t</td> <td class="paramname"><span class="paramname"><em>csn</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">void *</td> <td class="paramname"><span class="paramname"><em>spi</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>len</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Starts ISR driven read/write SPI transfer.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in,out]</td><td class="paramname">*self</td><td>SPI driver common data handle. See <a class="el" href="structt__neorv32__spi.html">t_neorv32_spi</a>. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">csn</td><td>Used chip select index for transfer. </td></tr> + <tr><td class="paramdir">[in,out]</td><td class="paramname">*spi</td><td>write/read data buffer for SPI. Before transmission contents the write data and after the read data. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">len</td><td>number of bytes to transfer. </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>int status of function. </dd></dl> +<dl class="retval"><dt>Return values</dt><dd> + <table class="retval"> + <tr><td class="paramname">0</td><td>new transfer started. </td></tr> + <tr><td class="paramname">1</td><td>transfer active, refused request. </td></tr> + <tr><td class="paramname">2</td><td>unsupported data size, only 1/2/4 allowed. </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="a1863e19932bc6a79f2ca27d23eb74ef5" name="a1863e19932bc6a79f2ca27d23eb74ef5"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a1863e19932bc6a79f2ca27d23eb74ef5">&#9670;&#160;</a></span>neorv32_spi_rw_busy()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_spi_rw_busy </td> + <td>(</td> + <td class="paramtype"><a class="el" href="structt__neorv32__spi.html">t_neorv32_spi</a> *</td> <td class="paramname"><span class="paramname"><em>self</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Check if transfer is active. see <a class="el" href="neorv32__spi__irq_8c.html#a1f44ed849415d8e1d659c0485762c485">neorv32_spi_rw</a></p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in,out]</td><td class="paramname">*self</td><td>SPI driver common data handle. See <a class="el" href="structt__neorv32__spi.html">t_neorv32_spi</a>. </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>int status of function. </dd></dl> +<dl class="retval"><dt>Return values</dt><dd> + <table class="retval"> + <tr><td class="paramname">0</td><td>idle. </td></tr> + <tr><td class="paramname">1</td><td>busy. </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/neorv32__spi__irq_8h_source.html b/sw/neorv32__spi__irq_8h_source.html new file mode 100644 index 0000000000..c8abc9c05e --- /dev/null +++ b/sw/neorv32__spi__irq_8h_source.html @@ -0,0 +1,183 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/example/demo_spi_irq/drv/neorv32_spi_irq.h Source File</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_f0f9b27afba2e8cc2da6e5fddcc1a8c9.html">example</a></li><li class="navelem"><a class="el" href="dir_8f848e36ac87ced1c361afcc0549ca32.html">demo_spi_irq</a></li><li class="navelem"><a class="el" href="dir_9d04cdc586d6978be343bda7adcdc371.html">drv</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="headertitle"><div class="title">neorv32_spi_irq.h</div></div> +</div><!--header--> +<div class="contents"> +<a href="neorv32__spi__irq_8h.html">Go to the documentation of this file.</a><div class="fragment"><div class="line"><a id="l00001" name="l00001"></a><span class="lineno"> 1</span><span class="comment">// #################################################################################################</span></div> +<div class="line"><a id="l00002" name="l00002"></a><span class="lineno"> 2</span><span class="comment">// # &lt;&lt; NEORV32: neorv32_spi_irq.h - IRQ driven SPI Controller HW Driver &gt;&gt; #</span></div> +<div class="line"><a id="l00003" name="l00003"></a><span class="lineno"> 3</span><span class="comment">// # ********************************************************************************************* #</span></div> +<div class="line"><a id="l00004" name="l00004"></a><span class="lineno"> 4</span><span class="comment">// # BSD 3-Clause License #</span></div> +<div class="line"><a id="l00005" name="l00005"></a><span class="lineno"> 5</span><span class="comment">// # #</span></div> +<div class="line"><a id="l00006" name="l00006"></a><span class="lineno"> 6</span><span class="comment">// # Copyright (c) 2023, Stephan Nolting. All rights reserved. #</span></div> +<div class="line"><a id="l00007" name="l00007"></a><span class="lineno"> 7</span><span class="comment">// # #</span></div> +<div class="line"><a id="l00008" name="l00008"></a><span class="lineno"> 8</span><span class="comment">// # Redistribution and use in source and binary forms, with or without modification, are #</span></div> +<div class="line"><a id="l00009" name="l00009"></a><span class="lineno"> 9</span><span class="comment">// # permitted provided that the following conditions are met: #</span></div> +<div class="line"><a id="l00010" name="l00010"></a><span class="lineno"> 10</span><span class="comment">// # #</span></div> +<div class="line"><a id="l00011" name="l00011"></a><span class="lineno"> 11</span><span class="comment">// # 1. Redistributions of source code must retain the above copyright notice, this list of #</span></div> +<div class="line"><a id="l00012" name="l00012"></a><span class="lineno"> 12</span><span class="comment">// # conditions and the following disclaimer. #</span></div> +<div class="line"><a id="l00013" name="l00013"></a><span class="lineno"> 13</span><span class="comment">// # #</span></div> +<div class="line"><a id="l00014" name="l00014"></a><span class="lineno"> 14</span><span class="comment">// # 2. Redistributions in binary form must reproduce the above copyright notice, this list of #</span></div> +<div class="line"><a id="l00015" name="l00015"></a><span class="lineno"> 15</span><span class="comment">// # conditions and the following disclaimer in the documentation and/or other materials #</span></div> +<div class="line"><a id="l00016" name="l00016"></a><span class="lineno"> 16</span><span class="comment">// # provided with the distribution. #</span></div> +<div class="line"><a id="l00017" name="l00017"></a><span class="lineno"> 17</span><span class="comment">// # #</span></div> +<div class="line"><a id="l00018" name="l00018"></a><span class="lineno"> 18</span><span class="comment">// # 3. Neither the name of the copyright holder nor the names of its contributors may be used to #</span></div> +<div class="line"><a id="l00019" name="l00019"></a><span class="lineno"> 19</span><span class="comment">// # endorse or promote products derived from this software without specific prior written #</span></div> +<div class="line"><a id="l00020" name="l00020"></a><span class="lineno"> 20</span><span class="comment">// # permission. #</span></div> +<div class="line"><a id="l00021" name="l00021"></a><span class="lineno"> 21</span><span class="comment">// # #</span></div> +<div class="line"><a id="l00022" name="l00022"></a><span class="lineno"> 22</span><span class="comment">// # THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS &quot;AS IS&quot; AND ANY EXPRESS #</span></div> +<div class="line"><a id="l00023" name="l00023"></a><span class="lineno"> 23</span><span class="comment">// # OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF #</span></div> +<div class="line"><a id="l00024" name="l00024"></a><span class="lineno"> 24</span><span class="comment">// # MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE #</span></div> +<div class="line"><a id="l00025" name="l00025"></a><span class="lineno"> 25</span><span class="comment">// # COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, #</span></div> +<div class="line"><a id="l00026" name="l00026"></a><span class="lineno"> 26</span><span class="comment">// # EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE #</span></div> +<div class="line"><a id="l00027" name="l00027"></a><span class="lineno"> 27</span><span class="comment">// # GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED #</span></div> +<div class="line"><a id="l00028" name="l00028"></a><span class="lineno"> 28</span><span class="comment">// # AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING #</span></div> +<div class="line"><a id="l00029" name="l00029"></a><span class="lineno"> 29</span><span class="comment">// # NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED #</span></div> +<div class="line"><a id="l00030" name="l00030"></a><span class="lineno"> 30</span><span class="comment">// # OF THE POSSIBILITY OF SUCH DAMAGE. #</span></div> +<div class="line"><a id="l00031" name="l00031"></a><span class="lineno"> 31</span><span class="comment">// # ********************************************************************************************* #</span></div> +<div class="line"><a id="l00032" name="l00032"></a><span class="lineno"> 32</span><span class="comment">// # The NEORV32 Processor - https://github.com/stnolting/neorv32 (c) Stephan Nolting #</span></div> +<div class="line"><a id="l00033" name="l00033"></a><span class="lineno"> 33</span><span class="comment">// #################################################################################################</span></div> +<div class="line"><a id="l00034" name="l00034"></a><span class="lineno"> 34</span> </div> +<div class="line"><a id="l00035" name="l00035"></a><span class="lineno"> 35</span> </div> +<div class="line"><a id="l00036" name="l00036"></a><span class="lineno"> 36</span><span class="comment">/**********************************************************************/</span></div> +<div class="line"><a id="l00044" name="l00044"></a><span class="lineno"> 44</span><span class="preprocessor">#ifndef neorv32_spi_irq_h</span></div> +<div class="line"><a id="l00045" name="l00045"></a><span class="lineno"> 45</span><span class="preprocessor">#define neorv32_spi_irq_h</span></div> +<div class="line"><a id="l00046" name="l00046"></a><span class="lineno"> 46</span> </div> +<div class="line"><a id="l00047" name="l00047"></a><span class="lineno"> 47</span><span class="comment">// MIN macro</span></div> +<div class="line"><a id="l00048" name="l00048"></a><span class="lineno"> 48</span><span class="comment">// https://stackoverflow.com/questions/3437404/min-and-max-in-c</span></div> +<div class="line"><a id="l00049" name="l00049"></a><span class="lineno"> 49</span><span class="preprocessor">#define min(a,b) \</span></div> +<div class="line"><a id="l00050" name="l00050"></a><span class="lineno"> 50</span><span class="preprocessor"> ({ __typeof__ (a) _a = (a); \</span></div> +<div class="line"><a id="l00051" name="l00051"></a><span class="lineno"> 51</span><span class="preprocessor"> __typeof__ (b) _b = (b); \</span></div> +<div class="line"><a id="l00052" name="l00052"></a><span class="lineno"> 52</span><span class="preprocessor"> _a &lt; _b ? _a : _b; })</span></div> +<div class="line"><a id="l00053" name="l00053"></a><span class="lineno"> 53</span> </div> +<div class="line"><a id="l00054" name="l00054"></a><span class="lineno"> 54</span><span class="comment">// data handle for ISR</span></div> +<div class="foldopen" id="foldopen00055" data-start="{" data-end="};"> +<div class="line"><a id="l00055" name="l00055"></a><span class="lineno"><a class="line" href="structt__neorv32__spi.html"> 55</a></span><span class="keyword">typedef</span> <span class="keyword">struct </span><a class="code hl_struct" href="structt__neorv32__spi.html">t_neorv32_spi</a></div> +<div class="line"><a id="l00056" name="l00056"></a><span class="lineno"> 56</span>{</div> +<div class="line"><a id="l00057" name="l00057"></a><span class="lineno"><a class="line" href="structt__neorv32__spi.html#a487a6510820871ff8d0da7699463f6d9"> 57</a></span> uint8_t* <a class="code hl_variable" href="structt__neorv32__spi.html#a487a6510820871ff8d0da7699463f6d9">ptrSpiBuf</a>; </div> +<div class="line"><a id="l00058" name="l00058"></a><span class="lineno"><a class="line" href="structt__neorv32__spi.html#a435c266758a440d32de4344472e3514a"> 58</a></span> uint8_t <a class="code hl_variable" href="structt__neorv32__spi.html#a435c266758a440d32de4344472e3514a">uint8Csn</a>; </div> +<div class="line"><a id="l00059" name="l00059"></a><span class="lineno"><a class="line" href="structt__neorv32__spi.html#a71fb3f91af197e1abdbe97d62130ad0f"> 59</a></span> uint16_t <a class="code hl_variable" href="structt__neorv32__spi.html#a71fb3f91af197e1abdbe97d62130ad0f">uint16Fifo</a>; </div> +<div class="line"><a id="l00060" name="l00060"></a><span class="lineno"><a class="line" href="structt__neorv32__spi.html#aa4d96f72e57fb6930ab43de6fb0a85ae"> 60</a></span> uint32_t <a class="code hl_variable" href="structt__neorv32__spi.html#aa4d96f72e57fb6930ab43de6fb0a85ae">uint32Total</a>; </div> +<div class="line"><a id="l00061" name="l00061"></a><span class="lineno"><a class="line" href="structt__neorv32__spi.html#aa89b7a769e54e331798e4d68d02a7b43"> 61</a></span> <span class="keyword">volatile</span> uint32_t <a class="code hl_variable" href="structt__neorv32__spi.html#aa89b7a769e54e331798e4d68d02a7b43">uint32Write</a>; </div> +<div class="line"><a id="l00062" name="l00062"></a><span class="lineno"><a class="line" href="structt__neorv32__spi.html#a5750a54f8312ec2fed349eb9fbeff323"> 62</a></span> <span class="keyword">volatile</span> uint32_t <a class="code hl_variable" href="structt__neorv32__spi.html#a5750a54f8312ec2fed349eb9fbeff323">uint32Read</a>; </div> +<div class="line"><a id="l00063" name="l00063"></a><span class="lineno"><a class="line" href="structt__neorv32__spi.html#a8ed31f9393bee5b963e08582b6c517ed"> 63</a></span> <span class="keyword">volatile</span> uint8_t <a class="code hl_variable" href="structt__neorv32__spi.html#a8ed31f9393bee5b963e08582b6c517ed">uint8IsBusy</a>; </div> +<div class="line"><a id="l00064" name="l00064"></a><span class="lineno"> 64</span>} <a class="code hl_struct" href="structt__neorv32__spi.html">t_neorv32_spi</a>;</div> +</div> +<div class="line"><a id="l00065" name="l00065"></a><span class="lineno"> 65</span> </div> +<div class="line"><a id="l00066" name="l00066"></a><span class="lineno"> 66</span> </div> +<div class="line"><a id="l00067" name="l00067"></a><span class="lineno"> 67</span><span class="comment">// prototypes</span></div> +<div class="line"><a id="l00068" name="l00068"></a><span class="lineno"> 68</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__spi__irq_8h.html#a4aa4746fd210ecc0c3614089a6951ddf">neorv32_spi_init</a>(<a class="code hl_struct" href="structt__neorv32__spi.html">t_neorv32_spi</a> *self);</div> +<div class="line"><a id="l00069" name="l00069"></a><span class="lineno"> 69</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__spi__irq_8h.html#aa641816bb302df497664aa21ea69ed16">neorv32_spi_isr</a>(<a class="code hl_struct" href="structt__neorv32__spi.html">t_neorv32_spi</a> *self);</div> +<div class="line"><a id="l00070" name="l00070"></a><span class="lineno"> 70</span><span class="keywordtype">int</span> <a class="code hl_function" href="neorv32__spi__irq_8h.html#a1f44ed849415d8e1d659c0485762c485">neorv32_spi_rw</a>(<a class="code hl_struct" href="structt__neorv32__spi.html">t_neorv32_spi</a> *self, uint8_t csn, <span class="keywordtype">void</span> *spi, uint32_t len);</div> +<div class="line"><a id="l00071" name="l00071"></a><span class="lineno"> 71</span><span class="keywordtype">int</span> <a class="code hl_function" href="neorv32__spi__irq_8h.html#a1863e19932bc6a79f2ca27d23eb74ef5">neorv32_spi_rw_busy</a>(<a class="code hl_struct" href="structt__neorv32__spi.html">t_neorv32_spi</a> *self);</div> +<div class="line"><a id="l00072" name="l00072"></a><span class="lineno"> 72</span> </div> +<div class="line"><a id="l00073" name="l00073"></a><span class="lineno"> 73</span><span class="preprocessor">#endif </span><span class="comment">// neorv32_spi_irq_h</span></div> +<div class="ttc" id="aneorv32__spi__irq_8h_html_a1863e19932bc6a79f2ca27d23eb74ef5"><div class="ttname"><a href="neorv32__spi__irq_8h.html#a1863e19932bc6a79f2ca27d23eb74ef5">neorv32_spi_rw_busy</a></div><div class="ttdeci">int neorv32_spi_rw_busy(t_neorv32_spi *self)</div><div class="ttdef"><b>Definition</b> neorv32_spi_irq.c:139</div></div> +<div class="ttc" id="aneorv32__spi__irq_8h_html_a1f44ed849415d8e1d659c0485762c485"><div class="ttname"><a href="neorv32__spi__irq_8h.html#a1f44ed849415d8e1d659c0485762c485">neorv32_spi_rw</a></div><div class="ttdeci">int neorv32_spi_rw(t_neorv32_spi *self, uint8_t csn, void *spi, uint32_t len)</div><div class="ttdef"><b>Definition</b> neorv32_spi_irq.c:109</div></div> +<div class="ttc" id="aneorv32__spi__irq_8h_html_a4aa4746fd210ecc0c3614089a6951ddf"><div class="ttname"><a href="neorv32__spi__irq_8h.html#a4aa4746fd210ecc0c3614089a6951ddf">neorv32_spi_init</a></div><div class="ttdeci">void neorv32_spi_init(t_neorv32_spi *self)</div><div class="ttdef"><b>Definition</b> neorv32_spi_irq.c:53</div></div> +<div class="ttc" id="aneorv32__spi__irq_8h_html_aa641816bb302df497664aa21ea69ed16"><div class="ttname"><a href="neorv32__spi__irq_8h.html#aa641816bb302df497664aa21ea69ed16">neorv32_spi_isr</a></div><div class="ttdeci">void neorv32_spi_isr(t_neorv32_spi *self)</div><div class="ttdef"><b>Definition</b> neorv32_spi_irq.c:69</div></div> +<div class="ttc" id="astructt__neorv32__spi_html"><div class="ttname"><a href="structt__neorv32__spi.html">t_neorv32_spi</a></div><div class="ttdef"><b>Definition</b> neorv32_spi_irq.h:56</div></div> +<div class="ttc" id="astructt__neorv32__spi_html_a435c266758a440d32de4344472e3514a"><div class="ttname"><a href="structt__neorv32__spi.html#a435c266758a440d32de4344472e3514a">t_neorv32_spi::uint8Csn</a></div><div class="ttdeci">uint8_t uint8Csn</div><div class="ttdef"><b>Definition</b> neorv32_spi_irq.h:58</div></div> +<div class="ttc" id="astructt__neorv32__spi_html_a487a6510820871ff8d0da7699463f6d9"><div class="ttname"><a href="structt__neorv32__spi.html#a487a6510820871ff8d0da7699463f6d9">t_neorv32_spi::ptrSpiBuf</a></div><div class="ttdeci">uint8_t * ptrSpiBuf</div><div class="ttdef"><b>Definition</b> neorv32_spi_irq.h:57</div></div> +<div class="ttc" id="astructt__neorv32__spi_html_a5750a54f8312ec2fed349eb9fbeff323"><div class="ttname"><a href="structt__neorv32__spi.html#a5750a54f8312ec2fed349eb9fbeff323">t_neorv32_spi::uint32Read</a></div><div class="ttdeci">volatile uint32_t uint32Read</div><div class="ttdef"><b>Definition</b> neorv32_spi_irq.h:62</div></div> +<div class="ttc" id="astructt__neorv32__spi_html_a71fb3f91af197e1abdbe97d62130ad0f"><div class="ttname"><a href="structt__neorv32__spi.html#a71fb3f91af197e1abdbe97d62130ad0f">t_neorv32_spi::uint16Fifo</a></div><div class="ttdeci">uint16_t uint16Fifo</div><div class="ttdef"><b>Definition</b> neorv32_spi_irq.h:59</div></div> +<div class="ttc" id="astructt__neorv32__spi_html_a8ed31f9393bee5b963e08582b6c517ed"><div class="ttname"><a href="structt__neorv32__spi.html#a8ed31f9393bee5b963e08582b6c517ed">t_neorv32_spi::uint8IsBusy</a></div><div class="ttdeci">volatile uint8_t uint8IsBusy</div><div class="ttdef"><b>Definition</b> neorv32_spi_irq.h:63</div></div> +<div class="ttc" id="astructt__neorv32__spi_html_aa4d96f72e57fb6930ab43de6fb0a85ae"><div class="ttname"><a href="structt__neorv32__spi.html#aa4d96f72e57fb6930ab43de6fb0a85ae">t_neorv32_spi::uint32Total</a></div><div class="ttdeci">uint32_t uint32Total</div><div class="ttdef"><b>Definition</b> neorv32_spi_irq.h:60</div></div> +<div class="ttc" id="astructt__neorv32__spi_html_aa89b7a769e54e331798e4d68d02a7b43"><div class="ttname"><a href="structt__neorv32__spi.html#aa89b7a769e54e331798e4d68d02a7b43">t_neorv32_spi::uint32Write</a></div><div class="ttdeci">volatile uint32_t uint32Write</div><div class="ttdef"><b>Definition</b> neorv32_spi_irq.h:61</div></div> +</div><!-- fragment --></div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/neorv32__sysinfo_8h_source.html b/sw/neorv32__sysinfo_8h_source.html new file mode 100644 index 0000000000..f59abe3752 --- /dev/null +++ b/sw/neorv32__sysinfo_8h_source.html @@ -0,0 +1,189 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/lib/include/neorv32_sysinfo.h Source File</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_7d04193005ada6f9450f847f4adb6b5b.html">lib</a></li><li class="navelem"><a class="el" href="dir_752b1e5d3973bf735fa78bf6b4727df9.html">include</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="headertitle"><div class="title">neorv32_sysinfo.h</div></div> +</div><!--header--> +<div class="contents"> +<div class="fragment"><div class="line"><a id="l00001" name="l00001"></a><span class="lineno"> 1</span><span class="comment">// ================================================================================ //</span></div> +<div class="line"><a id="l00002" name="l00002"></a><span class="lineno"> 2</span><span class="comment">// The NEORV32 RISC-V Processor - https://github.com/stnolting/neorv32 //</span></div> +<div class="line"><a id="l00003" name="l00003"></a><span class="lineno"> 3</span><span class="comment">// Copyright (c) NEORV32 contributors. //</span></div> +<div class="line"><a id="l00004" name="l00004"></a><span class="lineno"> 4</span><span class="comment">// Copyright (c) 2020 - 2024 Stephan Nolting. All rights reserved. //</span></div> +<div class="line"><a id="l00005" name="l00005"></a><span class="lineno"> 5</span><span class="comment">// Licensed under the BSD-3-Clause license, see LICENSE for details. //</span></div> +<div class="line"><a id="l00006" name="l00006"></a><span class="lineno"> 6</span><span class="comment">// SPDX-License-Identifier: BSD-3-Clause //</span></div> +<div class="line"><a id="l00007" name="l00007"></a><span class="lineno"> 7</span><span class="comment">// ================================================================================ //</span></div> +<div class="line"><a id="l00008" name="l00008"></a><span class="lineno"> 8</span> </div> +<div class="line"><a id="l00016" name="l00016"></a><span class="lineno"> 16</span><span class="preprocessor">#ifndef neorv32_sysinfo_h</span></div> +<div class="line"><a id="l00017" name="l00017"></a><span class="lineno"> 17</span><span class="preprocessor">#define neorv32_sysinfo_h</span></div> +<div class="line"><a id="l00018" name="l00018"></a><span class="lineno"> 18</span> </div> +<div class="line"><a id="l00019" name="l00019"></a><span class="lineno"> 19</span><span class="preprocessor">#include &lt;stdint.h&gt;</span></div> +<div class="line"><a id="l00020" name="l00020"></a><span class="lineno"> 20</span> </div> +<div class="line"><a id="l00021" name="l00021"></a><span class="lineno"> 21</span> </div> +<div class="line"><a id="l00022" name="l00022"></a><span class="lineno"> 22</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen00027" data-start="{" data-end="};"> +<div class="line"><a id="l00027" name="l00027"></a><span class="lineno"><a class="line" href="structneorv32__sysinfo__t.html"> 27</a></span><span class="keyword">typedef</span> <span class="keyword">volatile</span> <span class="keyword">struct </span>__attribute__((packed,aligned(4))) {</div> +<div class="line"><a id="l00028" name="l00028"></a><span class="lineno"><a class="line" href="structneorv32__sysinfo__t.html#afc225843ee31efff6350415b5aaae761"> 28</a></span> <span class="keyword">const</span> uint32_t <a class="code hl_variable" href="structneorv32__sysinfo__t.html#afc225843ee31efff6350415b5aaae761">CLK</a>; </div> +<div class="line"><a id="l00029" name="l00029"></a><span class="lineno"><a class="line" href="structneorv32__sysinfo__t.html#a51eee92b1824c1b19eb0a83a0a9c7d4c"> 29</a></span> <span class="keyword">const</span> uint8_t MEM[4]; </div> +<div class="line"><a id="l00030" name="l00030"></a><span class="lineno"><a class="line" href="structneorv32__sysinfo__t.html#ac43abe3b416da3a2895d1d06537a14c3"> 30</a></span> <span class="keyword">const</span> uint32_t <a class="code hl_variable" href="structneorv32__sysinfo__t.html#ac43abe3b416da3a2895d1d06537a14c3">SOC</a>; </div> +<div class="line"><a id="l00031" name="l00031"></a><span class="lineno"><a class="line" href="structneorv32__sysinfo__t.html#ada99a36ccda38b254d5b6a84883101f6"> 31</a></span> <span class="keyword">const</span> uint32_t <a class="code hl_variable" href="structneorv32__sysinfo__t.html#ada99a36ccda38b254d5b6a84883101f6">CACHE</a>; </div> +<div class="line"><a id="l00032" name="l00032"></a><span class="lineno"> 32</span>} <a class="code hl_struct" href="structneorv32__sysinfo__t.html">neorv32_sysinfo_t</a>;</div> +</div> +<div class="line"><a id="l00033" name="l00033"></a><span class="lineno"> 33</span> </div> +<div class="line"><a id="l00035" name="l00035"></a><span class="lineno"> 35</span><span class="preprocessor">#define NEORV32_SYSINFO ((neorv32_sysinfo_t*) (NEORV32_SYSINFO_BASE))</span></div> +<div class="line"><a id="l00036" name="l00036"></a><span class="lineno"> 36</span> </div> +<div class="line"><a id="l00038" name="l00038"></a><span class="lineno"> 38</span><span class="keyword">enum</span> NEORV32_SYSINFO_MEM_enum {</div> +<div class="line"><a id="l00039" name="l00039"></a><span class="lineno"> 39</span> SYSINFO_MEM_IMEM = 0, </div> +<div class="line"><a id="l00040" name="l00040"></a><span class="lineno"> 40</span> SYSINFO_MEM_DMEM = 1 </div> +<div class="line"><a id="l00041" name="l00041"></a><span class="lineno"> 41</span>};</div> +<div class="line"><a id="l00042" name="l00042"></a><span class="lineno"> 42</span> </div> +<div class="line"><a id="l00044" name="l00044"></a><span class="lineno"> 44</span><span class="keyword">enum</span> NEORV32_SYSINFO_SOC_enum {</div> +<div class="line"><a id="l00045" name="l00045"></a><span class="lineno"> 45</span> SYSINFO_SOC_BOOTLOADER = 0, </div> +<div class="line"><a id="l00046" name="l00046"></a><span class="lineno"> 46</span> SYSINFO_SOC_XBUS = 1, </div> +<div class="line"><a id="l00047" name="l00047"></a><span class="lineno"> 47</span> SYSINFO_SOC_MEM_INT_IMEM = 2, </div> +<div class="line"><a id="l00048" name="l00048"></a><span class="lineno"> 48</span> SYSINFO_SOC_MEM_INT_DMEM = 3, </div> +<div class="line"><a id="l00049" name="l00049"></a><span class="lineno"> 49</span> SYSINFO_SOC_OCD = 4, </div> +<div class="line"><a id="l00050" name="l00050"></a><span class="lineno"> 50</span> SYSINFO_SOC_ICACHE = 5, </div> +<div class="line"><a id="l00051" name="l00051"></a><span class="lineno"> 51</span> SYSINFO_SOC_DCACHE = 6, </div> +<div class="line"><a id="l00052" name="l00052"></a><span class="lineno"> 52</span> SYSINFO_SOC_CLOCK_GATING = 7, </div> +<div class="line"><a id="l00053" name="l00053"></a><span class="lineno"> 53</span> SYSINFO_SOC_XBUS_CACHE = 8, </div> +<div class="line"><a id="l00054" name="l00054"></a><span class="lineno"> 54</span> SYSINFO_SOC_XIP = 9, </div> +<div class="line"><a id="l00055" name="l00055"></a><span class="lineno"> 55</span> SYSINFO_SOC_XIP_CACHE = 10, </div> +<div class="line"><a id="l00057" name="l00057"></a><span class="lineno"> 57</span> SYSINFO_SOC_IO_DMA = 14, </div> +<div class="line"><a id="l00058" name="l00058"></a><span class="lineno"> 58</span> SYSINFO_SOC_IO_GPIO = 15, </div> +<div class="line"><a id="l00059" name="l00059"></a><span class="lineno"> 59</span> SYSINFO_SOC_IO_MTIME = 16, </div> +<div class="line"><a id="l00060" name="l00060"></a><span class="lineno"> 60</span> SYSINFO_SOC_IO_UART0 = 17, </div> +<div class="line"><a id="l00061" name="l00061"></a><span class="lineno"> 61</span> SYSINFO_SOC_IO_SPI = 18, </div> +<div class="line"><a id="l00062" name="l00062"></a><span class="lineno"> 62</span> SYSINFO_SOC_IO_TWI = 19, </div> +<div class="line"><a id="l00063" name="l00063"></a><span class="lineno"> 63</span> SYSINFO_SOC_IO_PWM = 20, </div> +<div class="line"><a id="l00064" name="l00064"></a><span class="lineno"> 64</span> SYSINFO_SOC_IO_WDT = 21, </div> +<div class="line"><a id="l00065" name="l00065"></a><span class="lineno"> 65</span> SYSINFO_SOC_IO_CFS = 22, </div> +<div class="line"><a id="l00066" name="l00066"></a><span class="lineno"> 66</span> SYSINFO_SOC_IO_TRNG = 23, </div> +<div class="line"><a id="l00067" name="l00067"></a><span class="lineno"> 67</span> SYSINFO_SOC_IO_SDI = 24, </div> +<div class="line"><a id="l00068" name="l00068"></a><span class="lineno"> 68</span> SYSINFO_SOC_IO_UART1 = 25, </div> +<div class="line"><a id="l00069" name="l00069"></a><span class="lineno"> 69</span> SYSINFO_SOC_IO_NEOLED = 26, </div> +<div class="line"><a id="l00070" name="l00070"></a><span class="lineno"> 70</span> SYSINFO_SOC_IO_XIRQ = 27, </div> +<div class="line"><a id="l00071" name="l00071"></a><span class="lineno"> 71</span> SYSINFO_SOC_IO_GPTMR = 28, </div> +<div class="line"><a id="l00072" name="l00072"></a><span class="lineno"> 72</span> SYSINFO_SOC_IO_SLINK = 29, </div> +<div class="line"><a id="l00073" name="l00073"></a><span class="lineno"> 73</span> SYSINFO_SOC_IO_ONEWIRE = 30, </div> +<div class="line"><a id="l00074" name="l00074"></a><span class="lineno"> 74</span> SYSINFO_SOC_IO_CRC = 31 </div> +<div class="line"><a id="l00075" name="l00075"></a><span class="lineno"> 75</span>};</div> +<div class="line"><a id="l00076" name="l00076"></a><span class="lineno"> 76</span> </div> +<div class="line"><a id="l00078" name="l00078"></a><span class="lineno"> 78</span> <span class="keyword">enum</span> NEORV32_SYSINFO_CACHE_enum {</div> +<div class="line"><a id="l00079" name="l00079"></a><span class="lineno"> 79</span> SYSINFO_CACHE_INST_BLOCK_SIZE_0 = 0, </div> +<div class="line"><a id="l00080" name="l00080"></a><span class="lineno"> 80</span> SYSINFO_CACHE_INST_BLOCK_SIZE_3 = 3, </div> +<div class="line"><a id="l00081" name="l00081"></a><span class="lineno"> 81</span> SYSINFO_CACHE_INST_NUM_BLOCKS_0 = 4, </div> +<div class="line"><a id="l00082" name="l00082"></a><span class="lineno"> 82</span> SYSINFO_CACHE_INST_NUM_BLOCKS_3 = 7, </div> +<div class="line"><a id="l00084" name="l00084"></a><span class="lineno"> 84</span> SYSINFO_CACHE_DATA_BLOCK_SIZE_0 = 8, </div> +<div class="line"><a id="l00085" name="l00085"></a><span class="lineno"> 85</span> SYSINFO_CACHE_DATA_BLOCK_SIZE_3 = 11, </div> +<div class="line"><a id="l00086" name="l00086"></a><span class="lineno"> 86</span> SYSINFO_CACHE_DATA_NUM_BLOCKS_0 = 12, </div> +<div class="line"><a id="l00087" name="l00087"></a><span class="lineno"> 87</span> SYSINFO_CACHE_DATA_NUM_BLOCKS_3 = 15, </div> +<div class="line"><a id="l00089" name="l00089"></a><span class="lineno"> 89</span> SYSINFO_CACHE_XIP_BLOCK_SIZE_0 = 16, </div> +<div class="line"><a id="l00090" name="l00090"></a><span class="lineno"> 90</span> SYSINFO_CACHE_XIP_BLOCK_SIZE_3 = 19, </div> +<div class="line"><a id="l00091" name="l00091"></a><span class="lineno"> 91</span> SYSINFO_CACHE_XIP_NUM_BLOCKS_0 = 20, </div> +<div class="line"><a id="l00092" name="l00092"></a><span class="lineno"> 92</span> SYSINFO_CACHE_XIP_NUM_BLOCKS_3 = 23, </div> +<div class="line"><a id="l00094" name="l00094"></a><span class="lineno"> 94</span> SYSINFO_CACHE_XBUS_BLOCK_SIZE_0 = 24, </div> +<div class="line"><a id="l00095" name="l00095"></a><span class="lineno"> 95</span> SYSINFO_CACHE_XBUS_BLOCK_SIZE_3 = 27, </div> +<div class="line"><a id="l00096" name="l00096"></a><span class="lineno"> 96</span> SYSINFO_CACHE_XBUS_NUM_BLOCKS_0 = 28, </div> +<div class="line"><a id="l00097" name="l00097"></a><span class="lineno"> 97</span> SYSINFO_CACHE_XBUS_NUM_BLOCKS_3 = 31 </div> +<div class="line"><a id="l00098" name="l00098"></a><span class="lineno"> 98</span>};</div> +<div class="line"><a id="l00102" name="l00102"></a><span class="lineno"> 102</span><span class="preprocessor">#endif </span><span class="comment">// neorv32_sysinfo_h</span></div> +<div class="ttc" id="astructneorv32__sysinfo__t_html"><div class="ttname"><a href="structneorv32__sysinfo__t.html">neorv32_sysinfo_t</a></div><div class="ttdef"><b>Definition</b> neorv32_sysinfo.h:27</div></div> +<div class="ttc" id="astructneorv32__sysinfo__t_html_ac43abe3b416da3a2895d1d06537a14c3"><div class="ttname"><a href="structneorv32__sysinfo__t.html#ac43abe3b416da3a2895d1d06537a14c3">neorv32_sysinfo_t::SOC</a></div><div class="ttdeci">const uint32_t SOC</div><div class="ttdef"><b>Definition</b> neorv32_sysinfo.h:30</div></div> +<div class="ttc" id="astructneorv32__sysinfo__t_html_ada99a36ccda38b254d5b6a84883101f6"><div class="ttname"><a href="structneorv32__sysinfo__t.html#ada99a36ccda38b254d5b6a84883101f6">neorv32_sysinfo_t::CACHE</a></div><div class="ttdeci">const uint32_t CACHE</div><div class="ttdef"><b>Definition</b> neorv32_sysinfo.h:31</div></div> +<div class="ttc" id="astructneorv32__sysinfo__t_html_afc225843ee31efff6350415b5aaae761"><div class="ttname"><a href="structneorv32__sysinfo__t.html#afc225843ee31efff6350415b5aaae761">neorv32_sysinfo_t::CLK</a></div><div class="ttdeci">const uint32_t CLK</div><div class="ttdef"><b>Definition</b> neorv32_sysinfo.h:28</div></div> +</div><!-- fragment --></div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/neorv32__trng_8c.html b/sw/neorv32__trng_8c.html new file mode 100644 index 0000000000..2c935f8e0f --- /dev/null +++ b/sw/neorv32__trng_8c.html @@ -0,0 +1,275 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/lib/source/neorv32_trng.c File Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_7d04193005ada6f9450f847f4adb6b5b.html">lib</a></li><li class="navelem"><a class="el" href="dir_0c6ac14e2254a316d41123f98feeb67b.html">source</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#func-members">Functions</a> </div> + <div class="headertitle"><div class="title">neorv32_trng.c File Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p>True Random Number Generator (TRNG) HW driver source file. +<a href="#details">More...</a></p> +<div class="textblock"><code>#include &quot;<a class="el" href="neorv32_8h_source.html">neorv32.h</a>&quot;</code><br /> +</div><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="func-members" name="func-members"></a> +Functions</h2></td></tr> +<tr class="memitem:af0c4139ff68763623b3d658a8dd8b5ce" id="r_af0c4139ff68763623b3d658a8dd8b5ce"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#af0c4139ff68763623b3d658a8dd8b5ce">neorv32_trng_available</a> (void)</td></tr> +<tr class="separator:af0c4139ff68763623b3d658a8dd8b5ce"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a8b8a1771e37a152792264561b93228fa" id="r_a8b8a1771e37a152792264561b93228fa"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a8b8a1771e37a152792264561b93228fa">neorv32_trng_enable</a> (int irq_sel)</td></tr> +<tr class="separator:a8b8a1771e37a152792264561b93228fa"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ae838bc980e28c300dc2c9c3f34a46bb8" id="r_ae838bc980e28c300dc2c9c3f34a46bb8"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ae838bc980e28c300dc2c9c3f34a46bb8">neorv32_trng_disable</a> (void)</td></tr> +<tr class="separator:ae838bc980e28c300dc2c9c3f34a46bb8"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a87cfe338e2ff559f96c73f729465f967" id="r_a87cfe338e2ff559f96c73f729465f967"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a87cfe338e2ff559f96c73f729465f967">neorv32_trng_fifo_clear</a> (void)</td></tr> +<tr class="separator:a87cfe338e2ff559f96c73f729465f967"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ad24e44372f4fd1ed29a6967dccab4fb0" id="r_ad24e44372f4fd1ed29a6967dccab4fb0"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ad24e44372f4fd1ed29a6967dccab4fb0">neorv32_trng_get_fifo_depth</a> (void)</td></tr> +<tr class="separator:ad24e44372f4fd1ed29a6967dccab4fb0"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a9148bcb6a7c448c364e78fa98aac6985" id="r_a9148bcb6a7c448c364e78fa98aac6985"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a9148bcb6a7c448c364e78fa98aac6985">neorv32_trng_get</a> (uint8_t *data)</td></tr> +<tr class="separator:a9148bcb6a7c448c364e78fa98aac6985"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aba36f08dd88f2f3e58353ae72eaa14f7" id="r_aba36f08dd88f2f3e58353ae72eaa14f7"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aba36f08dd88f2f3e58353ae72eaa14f7">neorv32_trng_check_sim_mode</a> (void)</td></tr> +<tr class="separator:aba36f08dd88f2f3e58353ae72eaa14f7"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>True Random Number Generator (TRNG) HW driver source file. </p> +<dl class="section note"><dt>Note</dt><dd>These functions should only be used if the TRNG unit was synthesized (IO_TRNG_EN = true).</dd></dl> +<dl class="section see"><dt>See also</dt><dd><a href="https://stnolting.github.io/neorv32/sw/files.html">https://stnolting.github.io/neorv32/sw/files.html</a> </dd></dl> +</div><h2 class="groupheader">Function Documentation</h2> +<a id="af0c4139ff68763623b3d658a8dd8b5ce" name="af0c4139ff68763623b3d658a8dd8b5ce"></a> +<h2 class="memtitle"><span class="permalink"><a href="#af0c4139ff68763623b3d658a8dd8b5ce">&#9670;&#160;</a></span>neorv32_trng_available()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_trng_available </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Check if TRNG unit was synthesized.</p> +<dl class="section return"><dt>Returns</dt><dd>0 if TRNG was not synthesized, 1 if TRNG is available. </dd></dl> + +</div> +</div> +<a id="aba36f08dd88f2f3e58353ae72eaa14f7" name="aba36f08dd88f2f3e58353ae72eaa14f7"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aba36f08dd88f2f3e58353ae72eaa14f7">&#9670;&#160;</a></span>neorv32_trng_check_sim_mode()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_trng_check_sim_mode </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Check if TRNG is implemented using SIMULATION mode.</p> +<dl class="section warning"><dt>Warning</dt><dd>In simulation mode the physical entropy source is replaced by a PRNG (LFSR) with very bad random quality.</dd></dl> +<dl class="section return"><dt>Returns</dt><dd>Simulation mode active when not zero. </dd></dl> + +</div> +</div> +<a id="ae838bc980e28c300dc2c9c3f34a46bb8" name="ae838bc980e28c300dc2c9c3f34a46bb8"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ae838bc980e28c300dc2c9c3f34a46bb8">&#9670;&#160;</a></span>neorv32_trng_disable()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_trng_disable </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Reset and disable TRNG. </p> + +</div> +</div> +<a id="a8b8a1771e37a152792264561b93228fa" name="a8b8a1771e37a152792264561b93228fa"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a8b8a1771e37a152792264561b93228fa">&#9670;&#160;</a></span>neorv32_trng_enable()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_trng_enable </td> + <td>(</td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>irq_sel</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Reset, configure and enable TRNG.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">irq_sel</td><td>Interrupt trigger select (0 = data available, 1 = FIFO full). </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="a87cfe338e2ff559f96c73f729465f967" name="a87cfe338e2ff559f96c73f729465f967"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a87cfe338e2ff559f96c73f729465f967">&#9670;&#160;</a></span>neorv32_trng_fifo_clear()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_trng_fifo_clear </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Flush TRNG random data FIFO. </p> + +</div> +</div> +<a id="a9148bcb6a7c448c364e78fa98aac6985" name="a9148bcb6a7c448c364e78fa98aac6985"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a9148bcb6a7c448c364e78fa98aac6985">&#9670;&#160;</a></span>neorv32_trng_get()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_trng_get </td> + <td>(</td> + <td class="paramtype">uint8_t *</td> <td class="paramname"><span class="paramname"><em>data</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Get random data byte from TRNG.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in,out]</td><td class="paramname">data</td><td>uint8_t pointer for storing random data byte. Will be set to zero if no valid data available. </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Data is valid when 0 and invalid otherwise. </dd></dl> + +</div> +</div> +<a id="ad24e44372f4fd1ed29a6967dccab4fb0" name="ad24e44372f4fd1ed29a6967dccab4fb0"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ad24e44372f4fd1ed29a6967dccab4fb0">&#9670;&#160;</a></span>neorv32_trng_get_fifo_depth()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_trng_get_fifo_depth </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Get TRNG FIFO depth.</p> +<dl class="section return"><dt>Returns</dt><dd>TRNG FIFO size (number of entries). </dd></dl> + +</div> +</div> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/neorv32__trng_8h.html b/sw/neorv32__trng_8h.html new file mode 100644 index 0000000000..97b5383ca3 --- /dev/null +++ b/sw/neorv32__trng_8h.html @@ -0,0 +1,354 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/lib/include/neorv32_trng.h File Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_7d04193005ada6f9450f847f4adb6b5b.html">lib</a></li><li class="navelem"><a class="el" href="dir_752b1e5d3973bf735fa78bf6b4727df9.html">include</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#nested-classes">Data Structures</a> </div> + <div class="headertitle"><div class="title">neorv32_trng.h File Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p>True Random Number Generator (TRNG) HW driver header file. +<a href="#details">More...</a></p> +<div class="textblock"><code>#include &lt;stdint.h&gt;</code><br /> +</div> +<p><a href="neorv32__trng_8h_source.html">Go to the source code of this file.</a></p> +<table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="nested-classes" name="nested-classes"></a> +Data Structures</h2></td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">struct &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structneorv32__trng__t.html">neorv32_trng_t</a></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="func-members" name="func-members"></a> +Functions</h2></td></tr> +<tr><td colspan="2"><div class="groupHeader">Prototypes</div></td></tr> +<tr class="memitem:af0c4139ff68763623b3d658a8dd8b5ce" id="r_af0c4139ff68763623b3d658a8dd8b5ce"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#af0c4139ff68763623b3d658a8dd8b5ce">neorv32_trng_available</a> (void)</td></tr> +<tr class="separator:af0c4139ff68763623b3d658a8dd8b5ce"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a8b8a1771e37a152792264561b93228fa" id="r_a8b8a1771e37a152792264561b93228fa"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a8b8a1771e37a152792264561b93228fa">neorv32_trng_enable</a> (int irq_sel)</td></tr> +<tr class="separator:a8b8a1771e37a152792264561b93228fa"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ae838bc980e28c300dc2c9c3f34a46bb8" id="r_ae838bc980e28c300dc2c9c3f34a46bb8"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ae838bc980e28c300dc2c9c3f34a46bb8">neorv32_trng_disable</a> (void)</td></tr> +<tr class="separator:ae838bc980e28c300dc2c9c3f34a46bb8"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a87cfe338e2ff559f96c73f729465f967" id="r_a87cfe338e2ff559f96c73f729465f967"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a87cfe338e2ff559f96c73f729465f967">neorv32_trng_fifo_clear</a> (void)</td></tr> +<tr class="separator:a87cfe338e2ff559f96c73f729465f967"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ad24e44372f4fd1ed29a6967dccab4fb0" id="r_ad24e44372f4fd1ed29a6967dccab4fb0"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ad24e44372f4fd1ed29a6967dccab4fb0">neorv32_trng_get_fifo_depth</a> (void)</td></tr> +<tr class="separator:ad24e44372f4fd1ed29a6967dccab4fb0"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a9148bcb6a7c448c364e78fa98aac6985" id="r_a9148bcb6a7c448c364e78fa98aac6985"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a9148bcb6a7c448c364e78fa98aac6985">neorv32_trng_get</a> (uint8_t *data)</td></tr> +<tr class="separator:a9148bcb6a7c448c364e78fa98aac6985"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aba36f08dd88f2f3e58353ae72eaa14f7" id="r_aba36f08dd88f2f3e58353ae72eaa14f7"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aba36f08dd88f2f3e58353ae72eaa14f7">neorv32_trng_check_sim_mode</a> (void)</td></tr> +<tr class="separator:aba36f08dd88f2f3e58353ae72eaa14f7"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader">IO Device: True Random Number Generator (TRNG)</h2></td></tr> +<tr class="memitem:a9794ff3746eb5321ad9c2bf522ea26dd" id="r_a9794ff3746eb5321ad9c2bf522ea26dd"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a9794ff3746eb5321ad9c2bf522ea26dd">NEORV32_TRNG</a>&#160;&#160;&#160;((<a class="el" href="structneorv32__trng__t.html">neorv32_trng_t</a>*) (<a class="el" href="neorv32_8h.html#ab4846cd153e8a23deec45d81cc8372a2">NEORV32_TRNG_BASE</a>))</td></tr> +<tr class="separator:a9794ff3746eb5321ad9c2bf522ea26dd"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a1440e1355bf5bff17760992adc156b1a" id="r_a1440e1355bf5bff17760992adc156b1a"><td class="memItemLeft" align="right" valign="top">enum &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a1440e1355bf5bff17760992adc156b1a">NEORV32_TRNG_CTRL_enum</a> { <br /> +&#160;&#160;<a class="el" href="#a1440e1355bf5bff17760992adc156b1aa50bb6e10e245a977dcf29a7a138776c6">TRNG_CTRL_DATA_LSB</a> = 0 +, <a class="el" href="#a1440e1355bf5bff17760992adc156b1aa95620874acc9393a05d670824c0bbed2">TRNG_CTRL_DATA_MSB</a> = 7 +, <a class="el" href="#a1440e1355bf5bff17760992adc156b1aa8c0325eede4ffec4530cfd5dc700dc52">TRNG_CTRL_FIFO_LSB</a> = 16 +, <a class="el" href="#a1440e1355bf5bff17760992adc156b1aa919c3105723e4fe46e341c63cbf276f5">TRNG_CTRL_FIFO_MSB</a> = 19 +, <br /> +&#160;&#160;<a class="el" href="#a1440e1355bf5bff17760992adc156b1aa968a770fe6b172183dd97818e09c63da">TRNG_CTRL_IRQ_SEL</a> = 27 +, <a class="el" href="#a1440e1355bf5bff17760992adc156b1aabf1bb7bc3b44394c85709edd1c9f03ac">TRNG_CTRL_FIFO_CLR</a> = 28 +, <a class="el" href="#a1440e1355bf5bff17760992adc156b1aaa6990058793ac7d96250693f935837c5">TRNG_CTRL_SIM_MODE</a> = 29 +, <a class="el" href="#a1440e1355bf5bff17760992adc156b1aa0bdf0194eefe95884c5c5853a2f7670d">TRNG_CTRL_EN</a> = 30 +, <br /> +&#160;&#160;<a class="el" href="#a1440e1355bf5bff17760992adc156b1aa2e0079358668db409fb763eaccb93da9">TRNG_CTRL_VALID</a> = 31 +<br /> + }</td></tr> +<tr class="separator:a1440e1355bf5bff17760992adc156b1a"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>True Random Number Generator (TRNG) HW driver header file. </p> +<dl class="section note"><dt>Note</dt><dd>These functions should only be used if the TRNG unit was synthesized (IO_TRNG_EN = true).</dd></dl> +<dl class="section see"><dt>See also</dt><dd><a href="https://stnolting.github.io/neorv32/sw/files.html">https://stnolting.github.io/neorv32/sw/files.html</a> </dd></dl> +</div><h2 class="groupheader">Macro Definition Documentation</h2> +<a id="a9794ff3746eb5321ad9c2bf522ea26dd" name="a9794ff3746eb5321ad9c2bf522ea26dd"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a9794ff3746eb5321ad9c2bf522ea26dd">&#9670;&#160;</a></span>NEORV32_TRNG</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define NEORV32_TRNG&#160;&#160;&#160;((<a class="el" href="structneorv32__trng__t.html">neorv32_trng_t</a>*) (<a class="el" href="neorv32_8h.html#ab4846cd153e8a23deec45d81cc8372a2">NEORV32_TRNG_BASE</a>))</td> + </tr> + </table> +</div><div class="memdoc"> +<p>TRNG module hardware access (<a class="el" href="structneorv32__trng__t.html">neorv32_trng_t</a>) </p> + +</div> +</div> +<h2 class="groupheader">Enumeration Type Documentation</h2> +<a id="a1440e1355bf5bff17760992adc156b1a" name="a1440e1355bf5bff17760992adc156b1a"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a1440e1355bf5bff17760992adc156b1a">&#9670;&#160;</a></span>NEORV32_TRNG_CTRL_enum</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">enum <a class="el" href="#a1440e1355bf5bff17760992adc156b1a">NEORV32_TRNG_CTRL_enum</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>TRNG control/data register bits </p> +<table class="fieldtable"> +<tr><th colspan="2">Enumerator</th></tr><tr><td class="fieldname"><a id="a1440e1355bf5bff17760992adc156b1aa50bb6e10e245a977dcf29a7a138776c6" name="a1440e1355bf5bff17760992adc156b1aa50bb6e10e245a977dcf29a7a138776c6"></a>TRNG_CTRL_DATA_LSB&#160;</td><td class="fielddoc"><p>TRNG data/control register(0) (r/-): Random data byte LSB </p> +</td></tr> +<tr><td class="fieldname"><a id="a1440e1355bf5bff17760992adc156b1aa95620874acc9393a05d670824c0bbed2" name="a1440e1355bf5bff17760992adc156b1aa95620874acc9393a05d670824c0bbed2"></a>TRNG_CTRL_DATA_MSB&#160;</td><td class="fielddoc"><p>TRNG data/control register(7) (r/-): Random data byte MSB </p> +</td></tr> +<tr><td class="fieldname"><a id="a1440e1355bf5bff17760992adc156b1aa8c0325eede4ffec4530cfd5dc700dc52" name="a1440e1355bf5bff17760992adc156b1aa8c0325eede4ffec4530cfd5dc700dc52"></a>TRNG_CTRL_FIFO_LSB&#160;</td><td class="fielddoc"><p>TRNG data/control register(16) (r/-): log2(FIFO size), LSB </p> +</td></tr> +<tr><td class="fieldname"><a id="a1440e1355bf5bff17760992adc156b1aa919c3105723e4fe46e341c63cbf276f5" name="a1440e1355bf5bff17760992adc156b1aa919c3105723e4fe46e341c63cbf276f5"></a>TRNG_CTRL_FIFO_MSB&#160;</td><td class="fielddoc"><p>TRNG data/control register(19) (r/-): log2(FIFO size), MSB </p> +</td></tr> +<tr><td class="fieldname"><a id="a1440e1355bf5bff17760992adc156b1aa968a770fe6b172183dd97818e09c63da" name="a1440e1355bf5bff17760992adc156b1aa968a770fe6b172183dd97818e09c63da"></a>TRNG_CTRL_IRQ_SEL&#160;</td><td class="fielddoc"><p>TRNG data/control register(27) (r/w): Interrupt trigger select (0 = data available, 1 = FIFO full) </p> +</td></tr> +<tr><td class="fieldname"><a id="a1440e1355bf5bff17760992adc156b1aabf1bb7bc3b44394c85709edd1c9f03ac" name="a1440e1355bf5bff17760992adc156b1aabf1bb7bc3b44394c85709edd1c9f03ac"></a>TRNG_CTRL_FIFO_CLR&#160;</td><td class="fielddoc"><p>TRNG data/control register(28) (-/w): Clear data FIFO (auto clears) </p> +</td></tr> +<tr><td class="fieldname"><a id="a1440e1355bf5bff17760992adc156b1aaa6990058793ac7d96250693f935837c5" name="a1440e1355bf5bff17760992adc156b1aaa6990058793ac7d96250693f935837c5"></a>TRNG_CTRL_SIM_MODE&#160;</td><td class="fielddoc"><p>TRNG data/control register(29) (r/-): PRNG mode (simulation mode) </p> +</td></tr> +<tr><td class="fieldname"><a id="a1440e1355bf5bff17760992adc156b1aa0bdf0194eefe95884c5c5853a2f7670d" name="a1440e1355bf5bff17760992adc156b1aa0bdf0194eefe95884c5c5853a2f7670d"></a>TRNG_CTRL_EN&#160;</td><td class="fielddoc"><p>TRNG data/control register(30) (r/w): TRNG enable </p> +</td></tr> +<tr><td class="fieldname"><a id="a1440e1355bf5bff17760992adc156b1aa2e0079358668db409fb763eaccb93da9" name="a1440e1355bf5bff17760992adc156b1aa2e0079358668db409fb763eaccb93da9"></a>TRNG_CTRL_VALID&#160;</td><td class="fielddoc"><p>TRNG data/control register(31) (r/-): Random data output valid </p> +</td></tr> +</table> + +</div> +</div> +<h2 class="groupheader">Function Documentation</h2> +<a id="af0c4139ff68763623b3d658a8dd8b5ce" name="af0c4139ff68763623b3d658a8dd8b5ce"></a> +<h2 class="memtitle"><span class="permalink"><a href="#af0c4139ff68763623b3d658a8dd8b5ce">&#9670;&#160;</a></span>neorv32_trng_available()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_trng_available </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Check if TRNG unit was synthesized.</p> +<dl class="section return"><dt>Returns</dt><dd>0 if TRNG was not synthesized, 1 if TRNG is available. </dd></dl> + +</div> +</div> +<a id="aba36f08dd88f2f3e58353ae72eaa14f7" name="aba36f08dd88f2f3e58353ae72eaa14f7"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aba36f08dd88f2f3e58353ae72eaa14f7">&#9670;&#160;</a></span>neorv32_trng_check_sim_mode()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_trng_check_sim_mode </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Check if TRNG is implemented using SIMULATION mode.</p> +<dl class="section warning"><dt>Warning</dt><dd>In simulation mode the physical entropy source is replaced by a PRNG (LFSR) with very bad random quality.</dd></dl> +<dl class="section return"><dt>Returns</dt><dd>Simulation mode active when not zero. </dd></dl> + +</div> +</div> +<a id="ae838bc980e28c300dc2c9c3f34a46bb8" name="ae838bc980e28c300dc2c9c3f34a46bb8"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ae838bc980e28c300dc2c9c3f34a46bb8">&#9670;&#160;</a></span>neorv32_trng_disable()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_trng_disable </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Reset and disable TRNG. </p> + +</div> +</div> +<a id="a8b8a1771e37a152792264561b93228fa" name="a8b8a1771e37a152792264561b93228fa"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a8b8a1771e37a152792264561b93228fa">&#9670;&#160;</a></span>neorv32_trng_enable()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_trng_enable </td> + <td>(</td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>irq_sel</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Reset, configure and enable TRNG.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">irq_sel</td><td>Interrupt trigger select (0 = data available, 1 = FIFO full). </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="a87cfe338e2ff559f96c73f729465f967" name="a87cfe338e2ff559f96c73f729465f967"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a87cfe338e2ff559f96c73f729465f967">&#9670;&#160;</a></span>neorv32_trng_fifo_clear()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_trng_fifo_clear </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Flush TRNG random data FIFO. </p> + +</div> +</div> +<a id="a9148bcb6a7c448c364e78fa98aac6985" name="a9148bcb6a7c448c364e78fa98aac6985"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a9148bcb6a7c448c364e78fa98aac6985">&#9670;&#160;</a></span>neorv32_trng_get()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_trng_get </td> + <td>(</td> + <td class="paramtype">uint8_t *</td> <td class="paramname"><span class="paramname"><em>data</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Get random data byte from TRNG.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in,out]</td><td class="paramname">data</td><td>uint8_t pointer for storing random data byte. Will be set to zero if no valid data available. </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Data is valid when 0 and invalid otherwise. </dd></dl> + +</div> +</div> +<a id="ad24e44372f4fd1ed29a6967dccab4fb0" name="ad24e44372f4fd1ed29a6967dccab4fb0"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ad24e44372f4fd1ed29a6967dccab4fb0">&#9670;&#160;</a></span>neorv32_trng_get_fifo_depth()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_trng_get_fifo_depth </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Get TRNG FIFO depth.</p> +<dl class="section return"><dt>Returns</dt><dd>TRNG FIFO size (number of entries). </dd></dl> + +</div> +</div> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/neorv32__trng_8h_source.html b/sw/neorv32__trng_8h_source.html new file mode 100644 index 0000000000..f0baed0421 --- /dev/null +++ b/sw/neorv32__trng_8h_source.html @@ -0,0 +1,167 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/lib/include/neorv32_trng.h Source File</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_7d04193005ada6f9450f847f4adb6b5b.html">lib</a></li><li class="navelem"><a class="el" href="dir_752b1e5d3973bf735fa78bf6b4727df9.html">include</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="headertitle"><div class="title">neorv32_trng.h</div></div> +</div><!--header--> +<div class="contents"> +<a href="neorv32__trng_8h.html">Go to the documentation of this file.</a><div class="fragment"><div class="line"><a id="l00001" name="l00001"></a><span class="lineno"> 1</span><span class="comment">// ================================================================================ //</span></div> +<div class="line"><a id="l00002" name="l00002"></a><span class="lineno"> 2</span><span class="comment">// The NEORV32 RISC-V Processor - https://github.com/stnolting/neorv32 //</span></div> +<div class="line"><a id="l00003" name="l00003"></a><span class="lineno"> 3</span><span class="comment">// Copyright (c) NEORV32 contributors. //</span></div> +<div class="line"><a id="l00004" name="l00004"></a><span class="lineno"> 4</span><span class="comment">// Copyright (c) 2020 - 2024 Stephan Nolting. All rights reserved. //</span></div> +<div class="line"><a id="l00005" name="l00005"></a><span class="lineno"> 5</span><span class="comment">// Licensed under the BSD-3-Clause license, see LICENSE for details. //</span></div> +<div class="line"><a id="l00006" name="l00006"></a><span class="lineno"> 6</span><span class="comment">// SPDX-License-Identifier: BSD-3-Clause //</span></div> +<div class="line"><a id="l00007" name="l00007"></a><span class="lineno"> 7</span><span class="comment">// ================================================================================ //</span></div> +<div class="line"><a id="l00008" name="l00008"></a><span class="lineno"> 8</span> </div> +<div class="line"><a id="l00018" name="l00018"></a><span class="lineno"> 18</span><span class="preprocessor">#ifndef neorv32_trng_h</span></div> +<div class="line"><a id="l00019" name="l00019"></a><span class="lineno"> 19</span><span class="preprocessor">#define neorv32_trng_h</span></div> +<div class="line"><a id="l00020" name="l00020"></a><span class="lineno"> 20</span> </div> +<div class="line"><a id="l00021" name="l00021"></a><span class="lineno"> 21</span><span class="preprocessor">#include &lt;stdint.h&gt;</span></div> +<div class="line"><a id="l00022" name="l00022"></a><span class="lineno"> 22</span> </div> +<div class="line"><a id="l00023" name="l00023"></a><span class="lineno"> 23</span> </div> +<div class="line"><a id="l00024" name="l00024"></a><span class="lineno"> 24</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen00029" data-start="{" data-end="};"> +<div class="line"><a id="l00029" name="l00029"></a><span class="lineno"><a class="line" href="structneorv32__trng__t.html"> 29</a></span><span class="keyword">typedef</span> <span class="keyword">volatile</span> <span class="keyword">struct </span>__attribute__((packed,aligned(4))) {</div> +<div class="line"><a id="l00030" name="l00030"></a><span class="lineno"><a class="line" href="structneorv32__trng__t.html#ae2ff37ce30fb85ef59d9012534bc7e67"> 30</a></span> uint32_t <a class="code hl_variable" href="structneorv32__trng__t.html#ae2ff37ce30fb85ef59d9012534bc7e67">CTRL</a>; </div> +<div class="line"><a id="l00031" name="l00031"></a><span class="lineno"> 31</span>} <a class="code hl_struct" href="structneorv32__trng__t.html">neorv32_trng_t</a>;</div> +</div> +<div class="line"><a id="l00032" name="l00032"></a><span class="lineno"> 32</span> </div> +<div class="line"><a id="l00034" name="l00034"></a><span class="lineno"><a class="line" href="neorv32__trng_8h.html#a9794ff3746eb5321ad9c2bf522ea26dd"> 34</a></span><span class="preprocessor">#define NEORV32_TRNG ((neorv32_trng_t*) (NEORV32_TRNG_BASE))</span></div> +<div class="line"><a id="l00035" name="l00035"></a><span class="lineno"> 35</span> </div> +<div class="foldopen" id="foldopen00037" data-start="{" data-end="};"> +<div class="line"><a id="l00037" name="l00037"></a><span class="lineno"><a class="line" href="neorv32__trng_8h.html#a1440e1355bf5bff17760992adc156b1a"> 37</a></span><span class="keyword">enum</span> <a class="code hl_enumeration" href="neorv32__trng_8h.html#a1440e1355bf5bff17760992adc156b1a">NEORV32_TRNG_CTRL_enum</a> {</div> +<div class="line"><a id="l00038" name="l00038"></a><span class="lineno"><a class="line" href="neorv32__trng_8h.html#a1440e1355bf5bff17760992adc156b1aa50bb6e10e245a977dcf29a7a138776c6"> 38</a></span> <a class="code hl_enumvalue" href="neorv32__trng_8h.html#a1440e1355bf5bff17760992adc156b1aa50bb6e10e245a977dcf29a7a138776c6">TRNG_CTRL_DATA_LSB</a> = 0, </div> +<div class="line"><a id="l00039" name="l00039"></a><span class="lineno"><a class="line" href="neorv32__trng_8h.html#a1440e1355bf5bff17760992adc156b1aa95620874acc9393a05d670824c0bbed2"> 39</a></span> <a class="code hl_enumvalue" href="neorv32__trng_8h.html#a1440e1355bf5bff17760992adc156b1aa95620874acc9393a05d670824c0bbed2">TRNG_CTRL_DATA_MSB</a> = 7, </div> +<div class="line"><a id="l00041" name="l00041"></a><span class="lineno"><a class="line" href="neorv32__trng_8h.html#a1440e1355bf5bff17760992adc156b1aa8c0325eede4ffec4530cfd5dc700dc52"> 41</a></span> <a class="code hl_enumvalue" href="neorv32__trng_8h.html#a1440e1355bf5bff17760992adc156b1aa8c0325eede4ffec4530cfd5dc700dc52">TRNG_CTRL_FIFO_LSB</a> = 16, </div> +<div class="line"><a id="l00042" name="l00042"></a><span class="lineno"><a class="line" href="neorv32__trng_8h.html#a1440e1355bf5bff17760992adc156b1aa919c3105723e4fe46e341c63cbf276f5"> 42</a></span> <a class="code hl_enumvalue" href="neorv32__trng_8h.html#a1440e1355bf5bff17760992adc156b1aa919c3105723e4fe46e341c63cbf276f5">TRNG_CTRL_FIFO_MSB</a> = 19, </div> +<div class="line"><a id="l00044" name="l00044"></a><span class="lineno"><a class="line" href="neorv32__trng_8h.html#a1440e1355bf5bff17760992adc156b1aa968a770fe6b172183dd97818e09c63da"> 44</a></span> <a class="code hl_enumvalue" href="neorv32__trng_8h.html#a1440e1355bf5bff17760992adc156b1aa968a770fe6b172183dd97818e09c63da">TRNG_CTRL_IRQ_SEL</a> = 27, </div> +<div class="line"><a id="l00045" name="l00045"></a><span class="lineno"><a class="line" href="neorv32__trng_8h.html#a1440e1355bf5bff17760992adc156b1aabf1bb7bc3b44394c85709edd1c9f03ac"> 45</a></span> <a class="code hl_enumvalue" href="neorv32__trng_8h.html#a1440e1355bf5bff17760992adc156b1aabf1bb7bc3b44394c85709edd1c9f03ac">TRNG_CTRL_FIFO_CLR</a> = 28, </div> +<div class="line"><a id="l00046" name="l00046"></a><span class="lineno"><a class="line" href="neorv32__trng_8h.html#a1440e1355bf5bff17760992adc156b1aaa6990058793ac7d96250693f935837c5"> 46</a></span> <a class="code hl_enumvalue" href="neorv32__trng_8h.html#a1440e1355bf5bff17760992adc156b1aaa6990058793ac7d96250693f935837c5">TRNG_CTRL_SIM_MODE</a> = 29, </div> +<div class="line"><a id="l00047" name="l00047"></a><span class="lineno"><a class="line" href="neorv32__trng_8h.html#a1440e1355bf5bff17760992adc156b1aa0bdf0194eefe95884c5c5853a2f7670d"> 47</a></span> <a class="code hl_enumvalue" href="neorv32__trng_8h.html#a1440e1355bf5bff17760992adc156b1aa0bdf0194eefe95884c5c5853a2f7670d">TRNG_CTRL_EN</a> = 30, </div> +<div class="line"><a id="l00048" name="l00048"></a><span class="lineno"> 48</span> <a class="code hl_enumvalue" href="neorv32__trng_8h.html#a1440e1355bf5bff17760992adc156b1aa2e0079358668db409fb763eaccb93da9">TRNG_CTRL_VALID</a> = 31 </div> +<div class="line"><a id="l00049" name="l00049"></a><span class="lineno"><a class="line" href="neorv32__trng_8h.html#a1440e1355bf5bff17760992adc156b1aa2e0079358668db409fb763eaccb93da9"> 49</a></span>};</div> +</div> +<div class="line"><a id="l00053" name="l00053"></a><span class="lineno"> 53</span><span class="comment">/**********************************************************************/</span></div> +<div class="line"><a id="l00057" name="l00057"></a><span class="lineno"> 57</span><span class="keywordtype">int</span> <a class="code hl_function" href="neorv32__trng_8h.html#af0c4139ff68763623b3d658a8dd8b5ce">neorv32_trng_available</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00058" name="l00058"></a><span class="lineno"> 58</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__trng_8h.html#a8b8a1771e37a152792264561b93228fa">neorv32_trng_enable</a>(<span class="keywordtype">int</span> irq_sel);</div> +<div class="line"><a id="l00059" name="l00059"></a><span class="lineno"> 59</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__trng_8h.html#ae838bc980e28c300dc2c9c3f34a46bb8">neorv32_trng_disable</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00060" name="l00060"></a><span class="lineno"> 60</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__trng_8h.html#a87cfe338e2ff559f96c73f729465f967">neorv32_trng_fifo_clear</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00061" name="l00061"></a><span class="lineno"> 61</span><span class="keywordtype">int</span> <a class="code hl_function" href="neorv32__trng_8h.html#ad24e44372f4fd1ed29a6967dccab4fb0">neorv32_trng_get_fifo_depth</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00062" name="l00062"></a><span class="lineno"> 62</span><span class="keywordtype">int</span> <a class="code hl_function" href="neorv32__trng_8h.html#a9148bcb6a7c448c364e78fa98aac6985">neorv32_trng_get</a>(uint8_t *data);</div> +<div class="line"><a id="l00063" name="l00063"></a><span class="lineno"> 63</span><span class="keywordtype">int</span> <a class="code hl_function" href="neorv32__trng_8h.html#aba36f08dd88f2f3e58353ae72eaa14f7">neorv32_trng_check_sim_mode</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00067" name="l00067"></a><span class="lineno"> 67</span><span class="preprocessor">#endif </span><span class="comment">// neorv32_trng_h</span></div> +<div class="ttc" id="aneorv32__trng_8h_html_a1440e1355bf5bff17760992adc156b1a"><div class="ttname"><a href="neorv32__trng_8h.html#a1440e1355bf5bff17760992adc156b1a">NEORV32_TRNG_CTRL_enum</a></div><div class="ttdeci">NEORV32_TRNG_CTRL_enum</div><div class="ttdef"><b>Definition</b> neorv32_trng.h:37</div></div> +<div class="ttc" id="aneorv32__trng_8h_html_a1440e1355bf5bff17760992adc156b1aa0bdf0194eefe95884c5c5853a2f7670d"><div class="ttname"><a href="neorv32__trng_8h.html#a1440e1355bf5bff17760992adc156b1aa0bdf0194eefe95884c5c5853a2f7670d">TRNG_CTRL_EN</a></div><div class="ttdeci">@ TRNG_CTRL_EN</div><div class="ttdef"><b>Definition</b> neorv32_trng.h:47</div></div> +<div class="ttc" id="aneorv32__trng_8h_html_a1440e1355bf5bff17760992adc156b1aa2e0079358668db409fb763eaccb93da9"><div class="ttname"><a href="neorv32__trng_8h.html#a1440e1355bf5bff17760992adc156b1aa2e0079358668db409fb763eaccb93da9">TRNG_CTRL_VALID</a></div><div class="ttdeci">@ TRNG_CTRL_VALID</div><div class="ttdef"><b>Definition</b> neorv32_trng.h:48</div></div> +<div class="ttc" id="aneorv32__trng_8h_html_a1440e1355bf5bff17760992adc156b1aa50bb6e10e245a977dcf29a7a138776c6"><div class="ttname"><a href="neorv32__trng_8h.html#a1440e1355bf5bff17760992adc156b1aa50bb6e10e245a977dcf29a7a138776c6">TRNG_CTRL_DATA_LSB</a></div><div class="ttdeci">@ TRNG_CTRL_DATA_LSB</div><div class="ttdef"><b>Definition</b> neorv32_trng.h:38</div></div> +<div class="ttc" id="aneorv32__trng_8h_html_a1440e1355bf5bff17760992adc156b1aa8c0325eede4ffec4530cfd5dc700dc52"><div class="ttname"><a href="neorv32__trng_8h.html#a1440e1355bf5bff17760992adc156b1aa8c0325eede4ffec4530cfd5dc700dc52">TRNG_CTRL_FIFO_LSB</a></div><div class="ttdeci">@ TRNG_CTRL_FIFO_LSB</div><div class="ttdef"><b>Definition</b> neorv32_trng.h:41</div></div> +<div class="ttc" id="aneorv32__trng_8h_html_a1440e1355bf5bff17760992adc156b1aa919c3105723e4fe46e341c63cbf276f5"><div class="ttname"><a href="neorv32__trng_8h.html#a1440e1355bf5bff17760992adc156b1aa919c3105723e4fe46e341c63cbf276f5">TRNG_CTRL_FIFO_MSB</a></div><div class="ttdeci">@ TRNG_CTRL_FIFO_MSB</div><div class="ttdef"><b>Definition</b> neorv32_trng.h:42</div></div> +<div class="ttc" id="aneorv32__trng_8h_html_a1440e1355bf5bff17760992adc156b1aa95620874acc9393a05d670824c0bbed2"><div class="ttname"><a href="neorv32__trng_8h.html#a1440e1355bf5bff17760992adc156b1aa95620874acc9393a05d670824c0bbed2">TRNG_CTRL_DATA_MSB</a></div><div class="ttdeci">@ TRNG_CTRL_DATA_MSB</div><div class="ttdef"><b>Definition</b> neorv32_trng.h:39</div></div> +<div class="ttc" id="aneorv32__trng_8h_html_a1440e1355bf5bff17760992adc156b1aa968a770fe6b172183dd97818e09c63da"><div class="ttname"><a href="neorv32__trng_8h.html#a1440e1355bf5bff17760992adc156b1aa968a770fe6b172183dd97818e09c63da">TRNG_CTRL_IRQ_SEL</a></div><div class="ttdeci">@ TRNG_CTRL_IRQ_SEL</div><div class="ttdef"><b>Definition</b> neorv32_trng.h:44</div></div> +<div class="ttc" id="aneorv32__trng_8h_html_a1440e1355bf5bff17760992adc156b1aaa6990058793ac7d96250693f935837c5"><div class="ttname"><a href="neorv32__trng_8h.html#a1440e1355bf5bff17760992adc156b1aaa6990058793ac7d96250693f935837c5">TRNG_CTRL_SIM_MODE</a></div><div class="ttdeci">@ TRNG_CTRL_SIM_MODE</div><div class="ttdef"><b>Definition</b> neorv32_trng.h:46</div></div> +<div class="ttc" id="aneorv32__trng_8h_html_a1440e1355bf5bff17760992adc156b1aabf1bb7bc3b44394c85709edd1c9f03ac"><div class="ttname"><a href="neorv32__trng_8h.html#a1440e1355bf5bff17760992adc156b1aabf1bb7bc3b44394c85709edd1c9f03ac">TRNG_CTRL_FIFO_CLR</a></div><div class="ttdeci">@ TRNG_CTRL_FIFO_CLR</div><div class="ttdef"><b>Definition</b> neorv32_trng.h:45</div></div> +<div class="ttc" id="aneorv32__trng_8h_html_a87cfe338e2ff559f96c73f729465f967"><div class="ttname"><a href="neorv32__trng_8h.html#a87cfe338e2ff559f96c73f729465f967">neorv32_trng_fifo_clear</a></div><div class="ttdeci">void neorv32_trng_fifo_clear(void)</div><div class="ttdef"><b>Definition</b> neorv32_trng.c:72</div></div> +<div class="ttc" id="aneorv32__trng_8h_html_a8b8a1771e37a152792264561b93228fa"><div class="ttname"><a href="neorv32__trng_8h.html#a8b8a1771e37a152792264561b93228fa">neorv32_trng_enable</a></div><div class="ttdeci">void neorv32_trng_enable(int irq_sel)</div><div class="ttdef"><b>Definition</b> neorv32_trng.c:42</div></div> +<div class="ttc" id="aneorv32__trng_8h_html_a9148bcb6a7c448c364e78fa98aac6985"><div class="ttname"><a href="neorv32__trng_8h.html#a9148bcb6a7c448c364e78fa98aac6985">neorv32_trng_get</a></div><div class="ttdeci">int neorv32_trng_get(uint8_t *data)</div><div class="ttdef"><b>Definition</b> neorv32_trng.c:96</div></div> +<div class="ttc" id="aneorv32__trng_8h_html_aba36f08dd88f2f3e58353ae72eaa14f7"><div class="ttname"><a href="neorv32__trng_8h.html#aba36f08dd88f2f3e58353ae72eaa14f7">neorv32_trng_check_sim_mode</a></div><div class="ttdeci">int neorv32_trng_check_sim_mode(void)</div><div class="ttdef"><b>Definition</b> neorv32_trng.c:117</div></div> +<div class="ttc" id="aneorv32__trng_8h_html_ad24e44372f4fd1ed29a6967dccab4fb0"><div class="ttname"><a href="neorv32__trng_8h.html#ad24e44372f4fd1ed29a6967dccab4fb0">neorv32_trng_get_fifo_depth</a></div><div class="ttdeci">int neorv32_trng_get_fifo_depth(void)</div><div class="ttdef"><b>Definition</b> neorv32_trng.c:83</div></div> +<div class="ttc" id="aneorv32__trng_8h_html_ae838bc980e28c300dc2c9c3f34a46bb8"><div class="ttname"><a href="neorv32__trng_8h.html#ae838bc980e28c300dc2c9c3f34a46bb8">neorv32_trng_disable</a></div><div class="ttdeci">void neorv32_trng_disable(void)</div><div class="ttdef"><b>Definition</b> neorv32_trng.c:63</div></div> +<div class="ttc" id="aneorv32__trng_8h_html_af0c4139ff68763623b3d658a8dd8b5ce"><div class="ttname"><a href="neorv32__trng_8h.html#af0c4139ff68763623b3d658a8dd8b5ce">neorv32_trng_available</a></div><div class="ttdeci">int neorv32_trng_available(void)</div><div class="ttdef"><b>Definition</b> neorv32_trng.c:26</div></div> +<div class="ttc" id="astructneorv32__trng__t_html"><div class="ttname"><a href="structneorv32__trng__t.html">neorv32_trng_t</a></div><div class="ttdef"><b>Definition</b> neorv32_trng.h:29</div></div> +<div class="ttc" id="astructneorv32__trng__t_html_ae2ff37ce30fb85ef59d9012534bc7e67"><div class="ttname"><a href="structneorv32__trng__t.html#ae2ff37ce30fb85ef59d9012534bc7e67">neorv32_trng_t::CTRL</a></div><div class="ttdeci">uint32_t CTRL</div><div class="ttdef"><b>Definition</b> neorv32_trng.h:30</div></div> +</div><!-- fragment --></div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/neorv32__twi_8c.html b/sw/neorv32__twi_8c.html new file mode 100644 index 0000000000..2d09048798 --- /dev/null +++ b/sw/neorv32__twi_8c.html @@ -0,0 +1,434 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/lib/source/neorv32_twi.c File Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_7d04193005ada6f9450f847f4adb6b5b.html">lib</a></li><li class="navelem"><a class="el" href="dir_0c6ac14e2254a316d41123f98feeb67b.html">source</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#func-members">Functions</a> </div> + <div class="headertitle"><div class="title">neorv32_twi.c File Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p>Two-Wire Interface Controller (TWI) HW driver source file. +<a href="#details">More...</a></p> +<div class="textblock"><code>#include &quot;<a class="el" href="neorv32_8h_source.html">neorv32.h</a>&quot;</code><br /> +</div><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="func-members" name="func-members"></a> +Functions</h2></td></tr> +<tr class="memitem:aa2e01ebbc0c82d65ed4ded351f4d8711" id="r_aa2e01ebbc0c82d65ed4ded351f4d8711"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aa2e01ebbc0c82d65ed4ded351f4d8711">neorv32_twi_available</a> (void)</td></tr> +<tr class="separator:aa2e01ebbc0c82d65ed4ded351f4d8711"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a7ea6f3509a7cf622234d4b83e33afbe3" id="r_a7ea6f3509a7cf622234d4b83e33afbe3"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a7ea6f3509a7cf622234d4b83e33afbe3">neorv32_twi_setup</a> (int prsc, int cdiv, int clkstr)</td></tr> +<tr class="separator:a7ea6f3509a7cf622234d4b83e33afbe3"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a2c8f3bc55f4a9a8bdcb111759cf56ae2" id="r_a2c8f3bc55f4a9a8bdcb111759cf56ae2"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a2c8f3bc55f4a9a8bdcb111759cf56ae2">neorv32_twi_get_fifo_depth</a> (void)</td></tr> +<tr class="separator:a2c8f3bc55f4a9a8bdcb111759cf56ae2"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ae5f31e737c7a6c3c86070ff34cb0d861" id="r_ae5f31e737c7a6c3c86070ff34cb0d861"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ae5f31e737c7a6c3c86070ff34cb0d861">neorv32_twi_disable</a> (void)</td></tr> +<tr class="separator:ae5f31e737c7a6c3c86070ff34cb0d861"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a22717887cffff1e6830756bc73140e7b" id="r_a22717887cffff1e6830756bc73140e7b"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a22717887cffff1e6830756bc73140e7b">neorv32_twi_enable</a> (void)</td></tr> +<tr class="separator:a22717887cffff1e6830756bc73140e7b"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a4fff1ddade320f6cc568c6266f2c2acd" id="r_a4fff1ddade320f6cc568c6266f2c2acd"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a4fff1ddade320f6cc568c6266f2c2acd">neorv32_twi_busy</a> (void)</td></tr> +<tr class="separator:a4fff1ddade320f6cc568c6266f2c2acd"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a7735376d26560866b153ed205dfcb2ba" id="r_a7735376d26560866b153ed205dfcb2ba"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a7735376d26560866b153ed205dfcb2ba">neorv32_twi_get</a> (uint8_t *data)</td></tr> +<tr class="separator:a7735376d26560866b153ed205dfcb2ba"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ac7020f3379602f11c47ca16f1bd82f2e" id="r_ac7020f3379602f11c47ca16f1bd82f2e"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ac7020f3379602f11c47ca16f1bd82f2e">neorv32_twi_trans</a> (uint8_t *data, int mack)</td></tr> +<tr class="separator:ac7020f3379602f11c47ca16f1bd82f2e"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ad352447adcccccabd4e20577b34fbece" id="r_ad352447adcccccabd4e20577b34fbece"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ad352447adcccccabd4e20577b34fbece">neorv32_twi_generate_stop</a> (void)</td></tr> +<tr class="separator:ad352447adcccccabd4e20577b34fbece"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a633d460e4735eb369d74a834b03c8b78" id="r_a633d460e4735eb369d74a834b03c8b78"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a633d460e4735eb369d74a834b03c8b78">neorv32_twi_generate_start</a> (void)</td></tr> +<tr class="separator:a633d460e4735eb369d74a834b03c8b78"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a28fc44cce5d28f6e8c32268b239b07d5" id="r_a28fc44cce5d28f6e8c32268b239b07d5"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a28fc44cce5d28f6e8c32268b239b07d5">neorv32_twi_send_nonblocking</a> (uint8_t data, int mack)</td></tr> +<tr class="separator:a28fc44cce5d28f6e8c32268b239b07d5"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aa22430aab0a38d88cbd2c4220c573da0" id="r_aa22430aab0a38d88cbd2c4220c573da0"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aa22430aab0a38d88cbd2c4220c573da0">neorv32_twi_generate_stop_nonblocking</a> (void)</td></tr> +<tr class="separator:aa22430aab0a38d88cbd2c4220c573da0"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:adbf2eaed0c76221da5c3091665fc885e" id="r_adbf2eaed0c76221da5c3091665fc885e"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#adbf2eaed0c76221da5c3091665fc885e">neorv32_twi_generate_start_nonblocking</a> (void)</td></tr> +<tr class="separator:adbf2eaed0c76221da5c3091665fc885e"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>Two-Wire Interface Controller (TWI) HW driver source file. </p> +<dl class="section note"><dt>Note</dt><dd>These functions should only be used if the TWI unit was synthesized (IO_TWI_EN = true).</dd></dl> +<dl class="section see"><dt>See also</dt><dd><a href="https://stnolting.github.io/neorv32/sw/files.html">https://stnolting.github.io/neorv32/sw/files.html</a> </dd></dl> +</div><h2 class="groupheader">Function Documentation</h2> +<a id="aa2e01ebbc0c82d65ed4ded351f4d8711" name="aa2e01ebbc0c82d65ed4ded351f4d8711"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aa2e01ebbc0c82d65ed4ded351f4d8711">&#9670;&#160;</a></span>neorv32_twi_available()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_twi_available </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Check if TWI unit was synthesized.</p> +<dl class="section return"><dt>Returns</dt><dd>0 if TWI was not synthesized, 1 if TWI is available. </dd></dl> + +</div> +</div> +<a id="a4fff1ddade320f6cc568c6266f2c2acd" name="a4fff1ddade320f6cc568c6266f2c2acd"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a4fff1ddade320f6cc568c6266f2c2acd">&#9670;&#160;</a></span>neorv32_twi_busy()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_twi_busy </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Check if TWI is busy (TWI bus engine busy or TX FIFO not empty).</p> +<dl class="section return"><dt>Returns</dt><dd>0 if idle, 1 if busy </dd></dl> + +</div> +</div> +<a id="ae5f31e737c7a6c3c86070ff34cb0d861" name="ae5f31e737c7a6c3c86070ff34cb0d861"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ae5f31e737c7a6c3c86070ff34cb0d861">&#9670;&#160;</a></span>neorv32_twi_disable()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_twi_disable </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Disable TWI controller. </p> + +</div> +</div> +<a id="a22717887cffff1e6830756bc73140e7b" name="a22717887cffff1e6830756bc73140e7b"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a22717887cffff1e6830756bc73140e7b">&#9670;&#160;</a></span>neorv32_twi_enable()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_twi_enable </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Enable TWI controller. </p> + +</div> +</div> +<a id="a633d460e4735eb369d74a834b03c8b78" name="a633d460e4735eb369d74a834b03c8b78"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a633d460e4735eb369d74a834b03c8b78">&#9670;&#160;</a></span>neorv32_twi_generate_start()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_twi_generate_start </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Generate START (or REPEATED-START) condition.</p> +<dl class="section note"><dt>Note</dt><dd>Blocking function. </dd></dl> + +</div> +</div> +<a id="adbf2eaed0c76221da5c3091665fc885e" name="adbf2eaed0c76221da5c3091665fc885e"></a> +<h2 class="memtitle"><span class="permalink"><a href="#adbf2eaed0c76221da5c3091665fc885e">&#9670;&#160;</a></span>neorv32_twi_generate_start_nonblocking()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_twi_generate_start_nonblocking </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Generate START (or REPEATED-START) condition.</p> +<dl class="section note"><dt>Note</dt><dd>Non-blocking function; does not check the TX FIFO. </dd></dl> + +</div> +</div> +<a id="ad352447adcccccabd4e20577b34fbece" name="ad352447adcccccabd4e20577b34fbece"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ad352447adcccccabd4e20577b34fbece">&#9670;&#160;</a></span>neorv32_twi_generate_stop()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_twi_generate_stop </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Generate STOP condition.</p> +<dl class="section note"><dt>Note</dt><dd>Blocking function. </dd></dl> + +</div> +</div> +<a id="aa22430aab0a38d88cbd2c4220c573da0" name="aa22430aab0a38d88cbd2c4220c573da0"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aa22430aab0a38d88cbd2c4220c573da0">&#9670;&#160;</a></span>neorv32_twi_generate_stop_nonblocking()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_twi_generate_stop_nonblocking </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Generate STOP condition.</p> +<dl class="section note"><dt>Note</dt><dd>Non-blocking function; does not check the TX FIFO. </dd></dl> + +</div> +</div> +<a id="a7735376d26560866b153ed205dfcb2ba" name="a7735376d26560866b153ed205dfcb2ba"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a7735376d26560866b153ed205dfcb2ba">&#9670;&#160;</a></span>neorv32_twi_get()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_twi_get </td> + <td>(</td> + <td class="paramtype">uint8_t *</td> <td class="paramname"><span class="paramname"><em>data</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Get received data + ACK/NACH from RX FIFO.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in,out]</td><td class="paramname">data</td><td>Pointer for returned data (uint8_t). </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>RX FIFO access status (-1 = no data available, 0 = ACK received, 1 = NACK received). </dd></dl> + +</div> +</div> +<a id="a2c8f3bc55f4a9a8bdcb111759cf56ae2" name="a2c8f3bc55f4a9a8bdcb111759cf56ae2"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a2c8f3bc55f4a9a8bdcb111759cf56ae2">&#9670;&#160;</a></span>neorv32_twi_get_fifo_depth()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_twi_get_fifo_depth </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Get TWI FIFO depth.</p> +<dl class="section return"><dt>Returns</dt><dd>FIFO depth (number of entries), zero if no FIFO implemented </dd></dl> + +</div> +</div> +<a id="a28fc44cce5d28f6e8c32268b239b07d5" name="a28fc44cce5d28f6e8c32268b239b07d5"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a28fc44cce5d28f6e8c32268b239b07d5">&#9670;&#160;</a></span>neorv32_twi_send_nonblocking()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_twi_send_nonblocking </td> + <td>(</td> + <td class="paramtype">uint8_t</td> <td class="paramname"><span class="paramname"><em>data</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>mack</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Send data byte (RX can be read via <a class="el" href="#a7735376d26560866b153ed205dfcb2ba">neorv32_twi_get()</a>).</p> +<dl class="section note"><dt>Note</dt><dd>Non-blocking function; does not check the TX FIFO.</dd></dl> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">data</td><td>Data byte to be send. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">mack</td><td>Generate ACK by host controller when set. </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="a7ea6f3509a7cf622234d4b83e33afbe3" name="a7ea6f3509a7cf622234d4b83e33afbe3"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a7ea6f3509a7cf622234d4b83e33afbe3">&#9670;&#160;</a></span>neorv32_twi_setup()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_twi_setup </td> + <td>(</td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>prsc</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>cdiv</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>clkstr</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Enable and configure TWI controller. The TWI control register bits are listed in <a class="el" href="neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafa">NEORV32_TWI_CTRL_enum</a>.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">prsc</td><td>Clock prescaler select (0..7). See <a class="el" href="neorv32_8h.html#a10022df4c223533b04d5aebe222e8b73">NEORV32_CLOCK_PRSC_enum</a>. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">cdiv</td><td>Clock divider (0..15). </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">clkstr</td><td>Enable (allow) clock stretching. </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="ac7020f3379602f11c47ca16f1bd82f2e" name="ac7020f3379602f11c47ca16f1bd82f2e"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ac7020f3379602f11c47ca16f1bd82f2e">&#9670;&#160;</a></span>neorv32_twi_trans()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_twi_trans </td> + <td>(</td> + <td class="paramtype">uint8_t *</td> <td class="paramname"><span class="paramname"><em>data</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>mack</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>TWI transfer: send data byte and also receive data byte.</p> +<dl class="section note"><dt>Note</dt><dd>Blocking function.</dd></dl> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in,out]</td><td class="paramname">data</td><td>Pointer for TX/RX data (uint8_t). </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">mack</td><td>Generate ACK by host controller when set. </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>0: ACK received, 1: NACK received. </dd></dl> + +</div> +</div> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/neorv32__twi_8h.html b/sw/neorv32__twi_8h.html new file mode 100644 index 0000000000..723fb1272e --- /dev/null +++ b/sw/neorv32__twi_8h.html @@ -0,0 +1,582 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/lib/include/neorv32_twi.h File Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_7d04193005ada6f9450f847f4adb6b5b.html">lib</a></li><li class="navelem"><a class="el" href="dir_752b1e5d3973bf735fa78bf6b4727df9.html">include</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#nested-classes">Data Structures</a> </div> + <div class="headertitle"><div class="title">neorv32_twi.h File Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p>Two-Wire Interface Controller (TWI) HW driver header file. +<a href="#details">More...</a></p> +<div class="textblock"><code>#include &lt;stdint.h&gt;</code><br /> +</div> +<p><a href="neorv32__twi_8h_source.html">Go to the source code of this file.</a></p> +<table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="nested-classes" name="nested-classes"></a> +Data Structures</h2></td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">struct &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structneorv32__twi__t.html">neorv32_twi_t</a></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="define-members" name="define-members"></a> +Macros</h2></td></tr> +<tr><td colspan="2"><div class="groupHeader">TWI commands</div></td></tr> +<tr class="memitem:a62866821d0aa4500114ce2a7295ffb73" id="r_a62866821d0aa4500114ce2a7295ffb73"><td class="memItemLeft" align="right" valign="top"><a id="a62866821d0aa4500114ce2a7295ffb73" name="a62866821d0aa4500114ce2a7295ffb73"></a> +#define&#160;</td><td class="memItemRight" valign="bottom"><b>TWI_CMD_NOP</b>&#160;&#160;&#160;(0b00)</td></tr> +<tr class="separator:a62866821d0aa4500114ce2a7295ffb73"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ad55273f04f6b92146f0a1c3e8e6abe5e" id="r_ad55273f04f6b92146f0a1c3e8e6abe5e"><td class="memItemLeft" align="right" valign="top"><a id="ad55273f04f6b92146f0a1c3e8e6abe5e" name="ad55273f04f6b92146f0a1c3e8e6abe5e"></a> +#define&#160;</td><td class="memItemRight" valign="bottom"><b>TWI_CMD_START</b>&#160;&#160;&#160;(0b01)</td></tr> +<tr class="separator:ad55273f04f6b92146f0a1c3e8e6abe5e"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a8b6b6c0bbeee2df9d3e246c4e49c2bd9" id="r_a8b6b6c0bbeee2df9d3e246c4e49c2bd9"><td class="memItemLeft" align="right" valign="top"><a id="a8b6b6c0bbeee2df9d3e246c4e49c2bd9" name="a8b6b6c0bbeee2df9d3e246c4e49c2bd9"></a> +#define&#160;</td><td class="memItemRight" valign="bottom"><b>TWI_CMD_STOP</b>&#160;&#160;&#160;(0b10)</td></tr> +<tr class="separator:a8b6b6c0bbeee2df9d3e246c4e49c2bd9"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a9770d78d5fa52d94606b1dfb6cefc144" id="r_a9770d78d5fa52d94606b1dfb6cefc144"><td class="memItemLeft" align="right" valign="top"><a id="a9770d78d5fa52d94606b1dfb6cefc144" name="a9770d78d5fa52d94606b1dfb6cefc144"></a> +#define&#160;</td><td class="memItemRight" valign="bottom"><b>TWI_CMD_RTX</b>&#160;&#160;&#160;(0b11)</td></tr> +<tr class="separator:a9770d78d5fa52d94606b1dfb6cefc144"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="func-members" name="func-members"></a> +Functions</h2></td></tr> +<tr><td colspan="2"><div class="groupHeader">Prototypes</div></td></tr> +<tr class="memitem:aa2e01ebbc0c82d65ed4ded351f4d8711" id="r_aa2e01ebbc0c82d65ed4ded351f4d8711"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aa2e01ebbc0c82d65ed4ded351f4d8711">neorv32_twi_available</a> (void)</td></tr> +<tr class="separator:aa2e01ebbc0c82d65ed4ded351f4d8711"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a7ea6f3509a7cf622234d4b83e33afbe3" id="r_a7ea6f3509a7cf622234d4b83e33afbe3"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a7ea6f3509a7cf622234d4b83e33afbe3">neorv32_twi_setup</a> (int prsc, int cdiv, int clkstr)</td></tr> +<tr class="separator:a7ea6f3509a7cf622234d4b83e33afbe3"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a2c8f3bc55f4a9a8bdcb111759cf56ae2" id="r_a2c8f3bc55f4a9a8bdcb111759cf56ae2"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a2c8f3bc55f4a9a8bdcb111759cf56ae2">neorv32_twi_get_fifo_depth</a> (void)</td></tr> +<tr class="separator:a2c8f3bc55f4a9a8bdcb111759cf56ae2"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ae5f31e737c7a6c3c86070ff34cb0d861" id="r_ae5f31e737c7a6c3c86070ff34cb0d861"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ae5f31e737c7a6c3c86070ff34cb0d861">neorv32_twi_disable</a> (void)</td></tr> +<tr class="separator:ae5f31e737c7a6c3c86070ff34cb0d861"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a22717887cffff1e6830756bc73140e7b" id="r_a22717887cffff1e6830756bc73140e7b"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a22717887cffff1e6830756bc73140e7b">neorv32_twi_enable</a> (void)</td></tr> +<tr class="separator:a22717887cffff1e6830756bc73140e7b"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a4fff1ddade320f6cc568c6266f2c2acd" id="r_a4fff1ddade320f6cc568c6266f2c2acd"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a4fff1ddade320f6cc568c6266f2c2acd">neorv32_twi_busy</a> (void)</td></tr> +<tr class="separator:a4fff1ddade320f6cc568c6266f2c2acd"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a7735376d26560866b153ed205dfcb2ba" id="r_a7735376d26560866b153ed205dfcb2ba"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a7735376d26560866b153ed205dfcb2ba">neorv32_twi_get</a> (uint8_t *data)</td></tr> +<tr class="separator:a7735376d26560866b153ed205dfcb2ba"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ac7020f3379602f11c47ca16f1bd82f2e" id="r_ac7020f3379602f11c47ca16f1bd82f2e"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ac7020f3379602f11c47ca16f1bd82f2e">neorv32_twi_trans</a> (uint8_t *data, int mack)</td></tr> +<tr class="separator:ac7020f3379602f11c47ca16f1bd82f2e"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ad352447adcccccabd4e20577b34fbece" id="r_ad352447adcccccabd4e20577b34fbece"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ad352447adcccccabd4e20577b34fbece">neorv32_twi_generate_stop</a> (void)</td></tr> +<tr class="separator:ad352447adcccccabd4e20577b34fbece"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a633d460e4735eb369d74a834b03c8b78" id="r_a633d460e4735eb369d74a834b03c8b78"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a633d460e4735eb369d74a834b03c8b78">neorv32_twi_generate_start</a> (void)</td></tr> +<tr class="separator:a633d460e4735eb369d74a834b03c8b78"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a28fc44cce5d28f6e8c32268b239b07d5" id="r_a28fc44cce5d28f6e8c32268b239b07d5"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a28fc44cce5d28f6e8c32268b239b07d5">neorv32_twi_send_nonblocking</a> (uint8_t data, int mack)</td></tr> +<tr class="separator:a28fc44cce5d28f6e8c32268b239b07d5"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aa22430aab0a38d88cbd2c4220c573da0" id="r_aa22430aab0a38d88cbd2c4220c573da0"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aa22430aab0a38d88cbd2c4220c573da0">neorv32_twi_generate_stop_nonblocking</a> (void)</td></tr> +<tr class="separator:aa22430aab0a38d88cbd2c4220c573da0"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:adbf2eaed0c76221da5c3091665fc885e" id="r_adbf2eaed0c76221da5c3091665fc885e"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#adbf2eaed0c76221da5c3091665fc885e">neorv32_twi_generate_start_nonblocking</a> (void)</td></tr> +<tr class="separator:adbf2eaed0c76221da5c3091665fc885e"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader">IO Device: Two-Wire Interface Controller (TWI)</h2></td></tr> +<tr class="memitem:a2769c2fe5e0de01b12fe4a5fad029768" id="r_a2769c2fe5e0de01b12fe4a5fad029768"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a2769c2fe5e0de01b12fe4a5fad029768">NEORV32_TWI</a>&#160;&#160;&#160;((<a class="el" href="structneorv32__twi__t.html">neorv32_twi_t</a>*) (<a class="el" href="neorv32_8h.html#a4a741408a4bb0938e03b99555306db9c">NEORV32_TWI_BASE</a>))</td></tr> +<tr class="separator:a2769c2fe5e0de01b12fe4a5fad029768"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a71ef393d3b34d2dd0698590994b7dafa" id="r_a71ef393d3b34d2dd0698590994b7dafa"><td class="memItemLeft" align="right" valign="top">enum &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a71ef393d3b34d2dd0698590994b7dafa">NEORV32_TWI_CTRL_enum</a> { <br /> +&#160;&#160;<a class="el" href="#a71ef393d3b34d2dd0698590994b7dafaa43381fe5ab9fe64ebdf76638eba5a694">TWI_CTRL_EN</a> = 0 +, <a class="el" href="#a71ef393d3b34d2dd0698590994b7dafaa9033ac6cc891bff0da52449aa4b6a8d9">TWI_CTRL_PRSC0</a> = 1 +, <a class="el" href="#a71ef393d3b34d2dd0698590994b7dafaa8b666cd2e40ca9ba3f9a635f0ed107df">TWI_CTRL_PRSC1</a> = 2 +, <a class="el" href="#a71ef393d3b34d2dd0698590994b7dafaa4d55ed983ca2f94fa9deac196d949b31">TWI_CTRL_PRSC2</a> = 3 +, <br /> +&#160;&#160;<a class="el" href="#a71ef393d3b34d2dd0698590994b7dafaa75d3a61b5e642e5d5c1f699c35c26b31">TWI_CTRL_CDIV0</a> = 4 +, <a class="el" href="#a71ef393d3b34d2dd0698590994b7dafaa4473769463a0c7e4b58ed0b983610674">TWI_CTRL_CDIV1</a> = 5 +, <a class="el" href="#a71ef393d3b34d2dd0698590994b7dafaaa6db454861ad5be70846ed4f9eb2ea12">TWI_CTRL_CDIV2</a> = 6 +, <a class="el" href="#a71ef393d3b34d2dd0698590994b7dafaa99e2153a53cc1f9d7cc83d52c698cbcc">TWI_CTRL_CDIV3</a> = 7 +, <br /> +&#160;&#160;<a class="el" href="#a71ef393d3b34d2dd0698590994b7dafaac62d6e3c47a8195a6a9ccc79129bfe48">TWI_CTRL_CLKSTR</a> = 8 +, <a class="el" href="#a71ef393d3b34d2dd0698590994b7dafaa74126d424719b1db61f5e1ab567489fb">TWI_CTRL_FIFO_LSB</a> = 15 +, <a class="el" href="#a71ef393d3b34d2dd0698590994b7dafaa183f5b9c3993d04cc9aea2a79e9a4f75">TWI_CTRL_FIFO_MSB</a> = 18 +, <a class="el" href="#a71ef393d3b34d2dd0698590994b7dafaaa0597dc9dea3f6f7a2f19dbcc7a2dabb">TWI_CTRL_TX_FULL</a> = 29 +, <br /> +&#160;&#160;<a class="el" href="#a71ef393d3b34d2dd0698590994b7dafaad2798dfabf3a72e6138135e983734671">TWI_CTRL_RX_AVAIL</a> = 30 +, <a class="el" href="#a71ef393d3b34d2dd0698590994b7dafaa443a2a65ee810f428d40a4f8474d8e6d">TWI_CTRL_BUSY</a> = 31 +<br /> + }</td></tr> +<tr class="separator:a71ef393d3b34d2dd0698590994b7dafa"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a3421852c63baca60fe58c990b1c653d8" id="r_a3421852c63baca60fe58c990b1c653d8"><td class="memItemLeft" align="right" valign="top">enum &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a3421852c63baca60fe58c990b1c653d8">NEORV32_TWI_DCMD_enum</a> { <br /> +&#160;&#160;<a class="el" href="#a3421852c63baca60fe58c990b1c653d8adf6176c87655bbbb5c7cea9dea29ce56">TWI_DCMD_LSB</a> = 0 +, <a class="el" href="#a3421852c63baca60fe58c990b1c653d8ab7f53f7cef06031c1a34db04c602a50d">TWI_DCMD_MSB</a> = 7 +, <a class="el" href="#a3421852c63baca60fe58c990b1c653d8af64359afd3627db0a79733d00128f3a5">TWI_DCMD_ACK</a> = 8 +, <a class="el" href="#a3421852c63baca60fe58c990b1c653d8ab2e20f7f5a5b131c31772341caa97e5e">TWI_DCMD_CMD_LO</a> = 9 +, <br /> +&#160;&#160;<a class="el" href="#a3421852c63baca60fe58c990b1c653d8accd7e8be435db3055c27f0a6d5e0201e">TWI_DCMD_CMD_HI</a> = 10 +<br /> + }</td></tr> +<tr class="separator:a3421852c63baca60fe58c990b1c653d8"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>Two-Wire Interface Controller (TWI) HW driver header file. </p> +<dl class="section note"><dt>Note</dt><dd>These functions should only be used if the TWI unit was synthesized (IO_TWI_EN = true).</dd></dl> +<dl class="section see"><dt>See also</dt><dd><a href="https://stnolting.github.io/neorv32/sw/files.html">https://stnolting.github.io/neorv32/sw/files.html</a> </dd></dl> +</div><h2 class="groupheader">Macro Definition Documentation</h2> +<a id="a2769c2fe5e0de01b12fe4a5fad029768" name="a2769c2fe5e0de01b12fe4a5fad029768"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a2769c2fe5e0de01b12fe4a5fad029768">&#9670;&#160;</a></span>NEORV32_TWI</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define NEORV32_TWI&#160;&#160;&#160;((<a class="el" href="structneorv32__twi__t.html">neorv32_twi_t</a>*) (<a class="el" href="neorv32_8h.html#a4a741408a4bb0938e03b99555306db9c">NEORV32_TWI_BASE</a>))</td> + </tr> + </table> +</div><div class="memdoc"> +<p>TWI module hardware access (<a class="el" href="structneorv32__twi__t.html">neorv32_twi_t</a>) </p> + +</div> +</div> +<h2 class="groupheader">Enumeration Type Documentation</h2> +<a id="a71ef393d3b34d2dd0698590994b7dafa" name="a71ef393d3b34d2dd0698590994b7dafa"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a71ef393d3b34d2dd0698590994b7dafa">&#9670;&#160;</a></span>NEORV32_TWI_CTRL_enum</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">enum <a class="el" href="#a71ef393d3b34d2dd0698590994b7dafa">NEORV32_TWI_CTRL_enum</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>TWI control register bits </p> +<table class="fieldtable"> +<tr><th colspan="2">Enumerator</th></tr><tr><td class="fieldname"><a id="a71ef393d3b34d2dd0698590994b7dafaa43381fe5ab9fe64ebdf76638eba5a694" name="a71ef393d3b34d2dd0698590994b7dafaa43381fe5ab9fe64ebdf76638eba5a694"></a>TWI_CTRL_EN&#160;</td><td class="fielddoc"><p>TWI control register(0) (r/w): TWI enable </p> +</td></tr> +<tr><td class="fieldname"><a id="a71ef393d3b34d2dd0698590994b7dafaa9033ac6cc891bff0da52449aa4b6a8d9" name="a71ef393d3b34d2dd0698590994b7dafaa9033ac6cc891bff0da52449aa4b6a8d9"></a>TWI_CTRL_PRSC0&#160;</td><td class="fielddoc"><p>TWI control register(1) (r/w): Clock prescaler select bit 0 </p> +</td></tr> +<tr><td class="fieldname"><a id="a71ef393d3b34d2dd0698590994b7dafaa8b666cd2e40ca9ba3f9a635f0ed107df" name="a71ef393d3b34d2dd0698590994b7dafaa8b666cd2e40ca9ba3f9a635f0ed107df"></a>TWI_CTRL_PRSC1&#160;</td><td class="fielddoc"><p>TWI control register(2) (r/w): Clock prescaler select bit 1 </p> +</td></tr> +<tr><td class="fieldname"><a id="a71ef393d3b34d2dd0698590994b7dafaa4d55ed983ca2f94fa9deac196d949b31" name="a71ef393d3b34d2dd0698590994b7dafaa4d55ed983ca2f94fa9deac196d949b31"></a>TWI_CTRL_PRSC2&#160;</td><td class="fielddoc"><p>TWI control register(3) (r/w): Clock prescaler select bit 2 </p> +</td></tr> +<tr><td class="fieldname"><a id="a71ef393d3b34d2dd0698590994b7dafaa75d3a61b5e642e5d5c1f699c35c26b31" name="a71ef393d3b34d2dd0698590994b7dafaa75d3a61b5e642e5d5c1f699c35c26b31"></a>TWI_CTRL_CDIV0&#160;</td><td class="fielddoc"><p>TWI control register(4) (r/w): Clock divider bit 0 </p> +</td></tr> +<tr><td class="fieldname"><a id="a71ef393d3b34d2dd0698590994b7dafaa4473769463a0c7e4b58ed0b983610674" name="a71ef393d3b34d2dd0698590994b7dafaa4473769463a0c7e4b58ed0b983610674"></a>TWI_CTRL_CDIV1&#160;</td><td class="fielddoc"><p>TWI control register(5) (r/w): Clock divider bit 1 </p> +</td></tr> +<tr><td class="fieldname"><a id="a71ef393d3b34d2dd0698590994b7dafaaa6db454861ad5be70846ed4f9eb2ea12" name="a71ef393d3b34d2dd0698590994b7dafaaa6db454861ad5be70846ed4f9eb2ea12"></a>TWI_CTRL_CDIV2&#160;</td><td class="fielddoc"><p>TWI control register(6) (r/w): Clock divider bit 2 </p> +</td></tr> +<tr><td class="fieldname"><a id="a71ef393d3b34d2dd0698590994b7dafaa99e2153a53cc1f9d7cc83d52c698cbcc" name="a71ef393d3b34d2dd0698590994b7dafaa99e2153a53cc1f9d7cc83d52c698cbcc"></a>TWI_CTRL_CDIV3&#160;</td><td class="fielddoc"><p>TWI control register(7) (r/w): Clock divider bit 3 </p> +</td></tr> +<tr><td class="fieldname"><a id="a71ef393d3b34d2dd0698590994b7dafaac62d6e3c47a8195a6a9ccc79129bfe48" name="a71ef393d3b34d2dd0698590994b7dafaac62d6e3c47a8195a6a9ccc79129bfe48"></a>TWI_CTRL_CLKSTR&#160;</td><td class="fielddoc"><p>TWI control register(8) (r/w): Enable/allow clock stretching </p> +</td></tr> +<tr><td class="fieldname"><a id="a71ef393d3b34d2dd0698590994b7dafaa74126d424719b1db61f5e1ab567489fb" name="a71ef393d3b34d2dd0698590994b7dafaa74126d424719b1db61f5e1ab567489fb"></a>TWI_CTRL_FIFO_LSB&#160;</td><td class="fielddoc"><p>SPI control register(15) (r/-): log2(FIFO size), lsb </p> +</td></tr> +<tr><td class="fieldname"><a id="a71ef393d3b34d2dd0698590994b7dafaa183f5b9c3993d04cc9aea2a79e9a4f75" name="a71ef393d3b34d2dd0698590994b7dafaa183f5b9c3993d04cc9aea2a79e9a4f75"></a>TWI_CTRL_FIFO_MSB&#160;</td><td class="fielddoc"><p>SPI control register(18) (r/-): log2(FIFO size), msb </p> +</td></tr> +<tr><td class="fieldname"><a id="a71ef393d3b34d2dd0698590994b7dafaaa0597dc9dea3f6f7a2f19dbcc7a2dabb" name="a71ef393d3b34d2dd0698590994b7dafaaa0597dc9dea3f6f7a2f19dbcc7a2dabb"></a>TWI_CTRL_TX_FULL&#160;</td><td class="fielddoc"><p>TWI control register(29) (r/-): TX FIFO full </p> +</td></tr> +<tr><td class="fieldname"><a id="a71ef393d3b34d2dd0698590994b7dafaad2798dfabf3a72e6138135e983734671" name="a71ef393d3b34d2dd0698590994b7dafaad2798dfabf3a72e6138135e983734671"></a>TWI_CTRL_RX_AVAIL&#160;</td><td class="fielddoc"><p>TWI control register(30) (r/-): RX FIFO data available </p> +</td></tr> +<tr><td class="fieldname"><a id="a71ef393d3b34d2dd0698590994b7dafaa443a2a65ee810f428d40a4f8474d8e6d" name="a71ef393d3b34d2dd0698590994b7dafaa443a2a65ee810f428d40a4f8474d8e6d"></a>TWI_CTRL_BUSY&#160;</td><td class="fielddoc"><p>TWI control register(31) (r/-): Bus engine busy or TX FIFO not empty </p> +</td></tr> +</table> + +</div> +</div> +<a id="a3421852c63baca60fe58c990b1c653d8" name="a3421852c63baca60fe58c990b1c653d8"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a3421852c63baca60fe58c990b1c653d8">&#9670;&#160;</a></span>NEORV32_TWI_DCMD_enum</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">enum <a class="el" href="#a3421852c63baca60fe58c990b1c653d8">NEORV32_TWI_DCMD_enum</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>TWI command/data register bits </p> +<table class="fieldtable"> +<tr><th colspan="2">Enumerator</th></tr><tr><td class="fieldname"><a id="a3421852c63baca60fe58c990b1c653d8adf6176c87655bbbb5c7cea9dea29ce56" name="a3421852c63baca60fe58c990b1c653d8adf6176c87655bbbb5c7cea9dea29ce56"></a>TWI_DCMD_LSB&#160;</td><td class="fielddoc"><p>TWI data register(0) (r/w): Receive/transmit data (8-bit) LSB </p> +</td></tr> +<tr><td class="fieldname"><a id="a3421852c63baca60fe58c990b1c653d8ab7f53f7cef06031c1a34db04c602a50d" name="a3421852c63baca60fe58c990b1c653d8ab7f53f7cef06031c1a34db04c602a50d"></a>TWI_DCMD_MSB&#160;</td><td class="fielddoc"><p>TWI data register(7) (r/w): Receive/transmit data (8-bit) MSB </p> +</td></tr> +<tr><td class="fieldname"><a id="a3421852c63baca60fe58c990b1c653d8af64359afd3627db0a79733d00128f3a5" name="a3421852c63baca60fe58c990b1c653d8af64359afd3627db0a79733d00128f3a5"></a>TWI_DCMD_ACK&#160;</td><td class="fielddoc"><p>TWI data register(8) (r/w): RX = ACK/NACK, TX = MACK </p> +</td></tr> +<tr><td class="fieldname"><a id="a3421852c63baca60fe58c990b1c653d8ab2e20f7f5a5b131c31772341caa97e5e" name="a3421852c63baca60fe58c990b1c653d8ab2e20f7f5a5b131c31772341caa97e5e"></a>TWI_DCMD_CMD_LO&#160;</td><td class="fielddoc"><p>TWI data register(9) (r/w): CMD lsb </p> +</td></tr> +<tr><td class="fieldname"><a id="a3421852c63baca60fe58c990b1c653d8accd7e8be435db3055c27f0a6d5e0201e" name="a3421852c63baca60fe58c990b1c653d8accd7e8be435db3055c27f0a6d5e0201e"></a>TWI_DCMD_CMD_HI&#160;</td><td class="fielddoc"><p>TWI data register(10) (r/w): CMD msb </p> +</td></tr> +</table> + +</div> +</div> +<h2 class="groupheader">Function Documentation</h2> +<a id="aa2e01ebbc0c82d65ed4ded351f4d8711" name="aa2e01ebbc0c82d65ed4ded351f4d8711"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aa2e01ebbc0c82d65ed4ded351f4d8711">&#9670;&#160;</a></span>neorv32_twi_available()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_twi_available </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Check if TWI unit was synthesized.</p> +<dl class="section return"><dt>Returns</dt><dd>0 if TWI was not synthesized, 1 if TWI is available. </dd></dl> + +</div> +</div> +<a id="a4fff1ddade320f6cc568c6266f2c2acd" name="a4fff1ddade320f6cc568c6266f2c2acd"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a4fff1ddade320f6cc568c6266f2c2acd">&#9670;&#160;</a></span>neorv32_twi_busy()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_twi_busy </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Check if TWI is busy (TWI bus engine busy or TX FIFO not empty).</p> +<dl class="section return"><dt>Returns</dt><dd>0 if idle, 1 if busy </dd></dl> + +</div> +</div> +<a id="ae5f31e737c7a6c3c86070ff34cb0d861" name="ae5f31e737c7a6c3c86070ff34cb0d861"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ae5f31e737c7a6c3c86070ff34cb0d861">&#9670;&#160;</a></span>neorv32_twi_disable()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_twi_disable </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Disable TWI controller. </p> + +</div> +</div> +<a id="a22717887cffff1e6830756bc73140e7b" name="a22717887cffff1e6830756bc73140e7b"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a22717887cffff1e6830756bc73140e7b">&#9670;&#160;</a></span>neorv32_twi_enable()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_twi_enable </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Enable TWI controller. </p> + +</div> +</div> +<a id="a633d460e4735eb369d74a834b03c8b78" name="a633d460e4735eb369d74a834b03c8b78"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a633d460e4735eb369d74a834b03c8b78">&#9670;&#160;</a></span>neorv32_twi_generate_start()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_twi_generate_start </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Generate START (or REPEATED-START) condition.</p> +<dl class="section note"><dt>Note</dt><dd>Blocking function. </dd></dl> + +</div> +</div> +<a id="adbf2eaed0c76221da5c3091665fc885e" name="adbf2eaed0c76221da5c3091665fc885e"></a> +<h2 class="memtitle"><span class="permalink"><a href="#adbf2eaed0c76221da5c3091665fc885e">&#9670;&#160;</a></span>neorv32_twi_generate_start_nonblocking()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_twi_generate_start_nonblocking </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Generate START (or REPEATED-START) condition.</p> +<dl class="section note"><dt>Note</dt><dd>Non-blocking function; does not check the TX FIFO. </dd></dl> + +</div> +</div> +<a id="ad352447adcccccabd4e20577b34fbece" name="ad352447adcccccabd4e20577b34fbece"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ad352447adcccccabd4e20577b34fbece">&#9670;&#160;</a></span>neorv32_twi_generate_stop()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_twi_generate_stop </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Generate STOP condition.</p> +<dl class="section note"><dt>Note</dt><dd>Blocking function. </dd></dl> + +</div> +</div> +<a id="aa22430aab0a38d88cbd2c4220c573da0" name="aa22430aab0a38d88cbd2c4220c573da0"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aa22430aab0a38d88cbd2c4220c573da0">&#9670;&#160;</a></span>neorv32_twi_generate_stop_nonblocking()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_twi_generate_stop_nonblocking </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Generate STOP condition.</p> +<dl class="section note"><dt>Note</dt><dd>Non-blocking function; does not check the TX FIFO. </dd></dl> + +</div> +</div> +<a id="a7735376d26560866b153ed205dfcb2ba" name="a7735376d26560866b153ed205dfcb2ba"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a7735376d26560866b153ed205dfcb2ba">&#9670;&#160;</a></span>neorv32_twi_get()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_twi_get </td> + <td>(</td> + <td class="paramtype">uint8_t *</td> <td class="paramname"><span class="paramname"><em>data</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Get received data + ACK/NACH from RX FIFO.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in,out]</td><td class="paramname">data</td><td>Pointer for returned data (uint8_t). </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>RX FIFO access status (-1 = no data available, 0 = ACK received, 1 = NACK received). </dd></dl> + +</div> +</div> +<a id="a2c8f3bc55f4a9a8bdcb111759cf56ae2" name="a2c8f3bc55f4a9a8bdcb111759cf56ae2"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a2c8f3bc55f4a9a8bdcb111759cf56ae2">&#9670;&#160;</a></span>neorv32_twi_get_fifo_depth()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_twi_get_fifo_depth </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Get TWI FIFO depth.</p> +<dl class="section return"><dt>Returns</dt><dd>FIFO depth (number of entries), zero if no FIFO implemented </dd></dl> + +</div> +</div> +<a id="a28fc44cce5d28f6e8c32268b239b07d5" name="a28fc44cce5d28f6e8c32268b239b07d5"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a28fc44cce5d28f6e8c32268b239b07d5">&#9670;&#160;</a></span>neorv32_twi_send_nonblocking()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_twi_send_nonblocking </td> + <td>(</td> + <td class="paramtype">uint8_t</td> <td class="paramname"><span class="paramname"><em>data</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>mack</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Send data byte (RX can be read via <a class="el" href="neorv32__twi_8c.html#a7735376d26560866b153ed205dfcb2ba">neorv32_twi_get()</a>).</p> +<dl class="section note"><dt>Note</dt><dd>Non-blocking function; does not check the TX FIFO.</dd></dl> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">data</td><td>Data byte to be send. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">mack</td><td>Generate ACK by host controller when set. </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="a7ea6f3509a7cf622234d4b83e33afbe3" name="a7ea6f3509a7cf622234d4b83e33afbe3"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a7ea6f3509a7cf622234d4b83e33afbe3">&#9670;&#160;</a></span>neorv32_twi_setup()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_twi_setup </td> + <td>(</td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>prsc</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>cdiv</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>clkstr</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Enable and configure TWI controller. The TWI control register bits are listed in <a class="el" href="#a71ef393d3b34d2dd0698590994b7dafa">NEORV32_TWI_CTRL_enum</a>.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">prsc</td><td>Clock prescaler select (0..7). See <a class="el" href="neorv32_8h.html#a10022df4c223533b04d5aebe222e8b73">NEORV32_CLOCK_PRSC_enum</a>. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">cdiv</td><td>Clock divider (0..15). </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">clkstr</td><td>Enable (allow) clock stretching. </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="ac7020f3379602f11c47ca16f1bd82f2e" name="ac7020f3379602f11c47ca16f1bd82f2e"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ac7020f3379602f11c47ca16f1bd82f2e">&#9670;&#160;</a></span>neorv32_twi_trans()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_twi_trans </td> + <td>(</td> + <td class="paramtype">uint8_t *</td> <td class="paramname"><span class="paramname"><em>data</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>mack</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>TWI transfer: send data byte and also receive data byte.</p> +<dl class="section note"><dt>Note</dt><dd>Blocking function.</dd></dl> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in,out]</td><td class="paramname">data</td><td>Pointer for TX/RX data (uint8_t). </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">mack</td><td>Generate ACK by host controller when set. </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>0: ACK received, 1: NACK received. </dd></dl> + +</div> +</div> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/neorv32__twi_8h_source.html b/sw/neorv32__twi_8h_source.html new file mode 100644 index 0000000000..cdc153f933 --- /dev/null +++ b/sw/neorv32__twi_8h_source.html @@ -0,0 +1,215 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/lib/include/neorv32_twi.h Source File</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_7d04193005ada6f9450f847f4adb6b5b.html">lib</a></li><li class="navelem"><a class="el" href="dir_752b1e5d3973bf735fa78bf6b4727df9.html">include</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="headertitle"><div class="title">neorv32_twi.h</div></div> +</div><!--header--> +<div class="contents"> +<a href="neorv32__twi_8h.html">Go to the documentation of this file.</a><div class="fragment"><div class="line"><a id="l00001" name="l00001"></a><span class="lineno"> 1</span><span class="comment">// ================================================================================ //</span></div> +<div class="line"><a id="l00002" name="l00002"></a><span class="lineno"> 2</span><span class="comment">// The NEORV32 RISC-V Processor - https://github.com/stnolting/neorv32 //</span></div> +<div class="line"><a id="l00003" name="l00003"></a><span class="lineno"> 3</span><span class="comment">// Copyright (c) NEORV32 contributors. //</span></div> +<div class="line"><a id="l00004" name="l00004"></a><span class="lineno"> 4</span><span class="comment">// Copyright (c) 2020 - 2024 Stephan Nolting. All rights reserved. //</span></div> +<div class="line"><a id="l00005" name="l00005"></a><span class="lineno"> 5</span><span class="comment">// Licensed under the BSD-3-Clause license, see LICENSE for details. //</span></div> +<div class="line"><a id="l00006" name="l00006"></a><span class="lineno"> 6</span><span class="comment">// SPDX-License-Identifier: BSD-3-Clause //</span></div> +<div class="line"><a id="l00007" name="l00007"></a><span class="lineno"> 7</span><span class="comment">// ================================================================================ //</span></div> +<div class="line"><a id="l00008" name="l00008"></a><span class="lineno"> 8</span> </div> +<div class="line"><a id="l00018" name="l00018"></a><span class="lineno"> 18</span><span class="preprocessor">#ifndef neorv32_twi_h</span></div> +<div class="line"><a id="l00019" name="l00019"></a><span class="lineno"> 19</span><span class="preprocessor">#define neorv32_twi_h</span></div> +<div class="line"><a id="l00020" name="l00020"></a><span class="lineno"> 20</span> </div> +<div class="line"><a id="l00021" name="l00021"></a><span class="lineno"> 21</span><span class="preprocessor">#include &lt;stdint.h&gt;</span></div> +<div class="line"><a id="l00022" name="l00022"></a><span class="lineno"> 22</span> </div> +<div class="line"><a id="l00023" name="l00023"></a><span class="lineno"> 23</span> </div> +<div class="line"><a id="l00024" name="l00024"></a><span class="lineno"> 24</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen00029" data-start="{" data-end="};"> +<div class="line"><a id="l00029" name="l00029"></a><span class="lineno"><a class="line" href="structneorv32__twi__t.html"> 29</a></span><span class="keyword">typedef</span> <span class="keyword">volatile</span> <span class="keyword">struct </span>__attribute__((packed,aligned(4))) {</div> +<div class="line"><a id="l00030" name="l00030"></a><span class="lineno"><a class="line" href="structneorv32__twi__t.html#a148a1c681a2632881b25ee41652b5304"> 30</a></span> uint32_t <a class="code hl_variable" href="structneorv32__twi__t.html#a148a1c681a2632881b25ee41652b5304">CTRL</a>; </div> +<div class="line"><a id="l00031" name="l00031"></a><span class="lineno"><a class="line" href="structneorv32__twi__t.html#ae311e0827bdb178c6dd8c4535b80d5cb"> 31</a></span> uint32_t <a class="code hl_variable" href="structneorv32__twi__t.html#ae311e0827bdb178c6dd8c4535b80d5cb">DCMD</a>; </div> +<div class="line"><a id="l00032" name="l00032"></a><span class="lineno"> 32</span>} <a class="code hl_struct" href="structneorv32__twi__t.html">neorv32_twi_t</a>;</div> +</div> +<div class="line"><a id="l00033" name="l00033"></a><span class="lineno"> 33</span> </div> +<div class="line"><a id="l00035" name="l00035"></a><span class="lineno"><a class="line" href="neorv32__twi_8h.html#a2769c2fe5e0de01b12fe4a5fad029768"> 35</a></span><span class="preprocessor">#define NEORV32_TWI ((neorv32_twi_t*) (NEORV32_TWI_BASE))</span></div> +<div class="line"><a id="l00036" name="l00036"></a><span class="lineno"> 36</span> </div> +<div class="foldopen" id="foldopen00038" data-start="{" data-end="};"> +<div class="line"><a id="l00038" name="l00038"></a><span class="lineno"><a class="line" href="neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafa"> 38</a></span><span class="keyword">enum</span> <a class="code hl_enumeration" href="neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafa">NEORV32_TWI_CTRL_enum</a> {</div> +<div class="line"><a id="l00039" name="l00039"></a><span class="lineno"><a class="line" href="neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaa43381fe5ab9fe64ebdf76638eba5a694"> 39</a></span> <a class="code hl_enumvalue" href="neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaa43381fe5ab9fe64ebdf76638eba5a694">TWI_CTRL_EN</a> = 0, </div> +<div class="line"><a id="l00040" name="l00040"></a><span class="lineno"><a class="line" href="neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaa9033ac6cc891bff0da52449aa4b6a8d9"> 40</a></span> <a class="code hl_enumvalue" href="neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaa9033ac6cc891bff0da52449aa4b6a8d9">TWI_CTRL_PRSC0</a> = 1, </div> +<div class="line"><a id="l00041" name="l00041"></a><span class="lineno"><a class="line" href="neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaa8b666cd2e40ca9ba3f9a635f0ed107df"> 41</a></span> <a class="code hl_enumvalue" href="neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaa8b666cd2e40ca9ba3f9a635f0ed107df">TWI_CTRL_PRSC1</a> = 2, </div> +<div class="line"><a id="l00042" name="l00042"></a><span class="lineno"><a class="line" href="neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaa4d55ed983ca2f94fa9deac196d949b31"> 42</a></span> <a class="code hl_enumvalue" href="neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaa4d55ed983ca2f94fa9deac196d949b31">TWI_CTRL_PRSC2</a> = 3, </div> +<div class="line"><a id="l00043" name="l00043"></a><span class="lineno"><a class="line" href="neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaa75d3a61b5e642e5d5c1f699c35c26b31"> 43</a></span> <a class="code hl_enumvalue" href="neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaa75d3a61b5e642e5d5c1f699c35c26b31">TWI_CTRL_CDIV0</a> = 4, </div> +<div class="line"><a id="l00044" name="l00044"></a><span class="lineno"><a class="line" href="neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaa4473769463a0c7e4b58ed0b983610674"> 44</a></span> <a class="code hl_enumvalue" href="neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaa4473769463a0c7e4b58ed0b983610674">TWI_CTRL_CDIV1</a> = 5, </div> +<div class="line"><a id="l00045" name="l00045"></a><span class="lineno"><a class="line" href="neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaaa6db454861ad5be70846ed4f9eb2ea12"> 45</a></span> <a class="code hl_enumvalue" href="neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaaa6db454861ad5be70846ed4f9eb2ea12">TWI_CTRL_CDIV2</a> = 6, </div> +<div class="line"><a id="l00046" name="l00046"></a><span class="lineno"><a class="line" href="neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaa99e2153a53cc1f9d7cc83d52c698cbcc"> 46</a></span> <a class="code hl_enumvalue" href="neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaa99e2153a53cc1f9d7cc83d52c698cbcc">TWI_CTRL_CDIV3</a> = 7, </div> +<div class="line"><a id="l00047" name="l00047"></a><span class="lineno"><a class="line" href="neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaac62d6e3c47a8195a6a9ccc79129bfe48"> 47</a></span> <a class="code hl_enumvalue" href="neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaac62d6e3c47a8195a6a9ccc79129bfe48">TWI_CTRL_CLKSTR</a> = 8, </div> +<div class="line"><a id="l00049" name="l00049"></a><span class="lineno"><a class="line" href="neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaa74126d424719b1db61f5e1ab567489fb"> 49</a></span> <a class="code hl_enumvalue" href="neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaa74126d424719b1db61f5e1ab567489fb">TWI_CTRL_FIFO_LSB</a> = 15, </div> +<div class="line"><a id="l00050" name="l00050"></a><span class="lineno"><a class="line" href="neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaa183f5b9c3993d04cc9aea2a79e9a4f75"> 50</a></span> <a class="code hl_enumvalue" href="neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaa183f5b9c3993d04cc9aea2a79e9a4f75">TWI_CTRL_FIFO_MSB</a> = 18, </div> +<div class="line"><a id="l00052" name="l00052"></a><span class="lineno"><a class="line" href="neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaaa0597dc9dea3f6f7a2f19dbcc7a2dabb"> 52</a></span> <a class="code hl_enumvalue" href="neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaaa0597dc9dea3f6f7a2f19dbcc7a2dabb">TWI_CTRL_TX_FULL</a> = 29, </div> +<div class="line"><a id="l00053" name="l00053"></a><span class="lineno"><a class="line" href="neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaad2798dfabf3a72e6138135e983734671"> 53</a></span> <a class="code hl_enumvalue" href="neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaad2798dfabf3a72e6138135e983734671">TWI_CTRL_RX_AVAIL</a> = 30, </div> +<div class="line"><a id="l00054" name="l00054"></a><span class="lineno"> 54</span> <a class="code hl_enumvalue" href="neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaa443a2a65ee810f428d40a4f8474d8e6d">TWI_CTRL_BUSY</a> = 31 </div> +<div class="line"><a id="l00055" name="l00055"></a><span class="lineno"><a class="line" href="neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaa443a2a65ee810f428d40a4f8474d8e6d"> 55</a></span>};</div> +</div> +<div class="line"><a id="l00056" name="l00056"></a><span class="lineno"> 56</span> </div> +<div class="foldopen" id="foldopen00058" data-start="{" data-end="};"> +<div class="line"><a id="l00058" name="l00058"></a><span class="lineno"><a class="line" href="neorv32__twi_8h.html#a3421852c63baca60fe58c990b1c653d8"> 58</a></span><span class="keyword">enum</span> <a class="code hl_enumeration" href="neorv32__twi_8h.html#a3421852c63baca60fe58c990b1c653d8">NEORV32_TWI_DCMD_enum</a> {</div> +<div class="line"><a id="l00059" name="l00059"></a><span class="lineno"><a class="line" href="neorv32__twi_8h.html#a3421852c63baca60fe58c990b1c653d8adf6176c87655bbbb5c7cea9dea29ce56"> 59</a></span> <a class="code hl_enumvalue" href="neorv32__twi_8h.html#a3421852c63baca60fe58c990b1c653d8adf6176c87655bbbb5c7cea9dea29ce56">TWI_DCMD_LSB</a> = 0, </div> +<div class="line"><a id="l00060" name="l00060"></a><span class="lineno"><a class="line" href="neorv32__twi_8h.html#a3421852c63baca60fe58c990b1c653d8ab7f53f7cef06031c1a34db04c602a50d"> 60</a></span> <a class="code hl_enumvalue" href="neorv32__twi_8h.html#a3421852c63baca60fe58c990b1c653d8ab7f53f7cef06031c1a34db04c602a50d">TWI_DCMD_MSB</a> = 7, </div> +<div class="line"><a id="l00061" name="l00061"></a><span class="lineno"><a class="line" href="neorv32__twi_8h.html#a3421852c63baca60fe58c990b1c653d8af64359afd3627db0a79733d00128f3a5"> 61</a></span> <a class="code hl_enumvalue" href="neorv32__twi_8h.html#a3421852c63baca60fe58c990b1c653d8af64359afd3627db0a79733d00128f3a5">TWI_DCMD_ACK</a> = 8, </div> +<div class="line"><a id="l00062" name="l00062"></a><span class="lineno"><a class="line" href="neorv32__twi_8h.html#a3421852c63baca60fe58c990b1c653d8ab2e20f7f5a5b131c31772341caa97e5e"> 62</a></span> <a class="code hl_enumvalue" href="neorv32__twi_8h.html#a3421852c63baca60fe58c990b1c653d8ab2e20f7f5a5b131c31772341caa97e5e">TWI_DCMD_CMD_LO</a> = 9, </div> +<div class="line"><a id="l00063" name="l00063"></a><span class="lineno"> 63</span> <a class="code hl_enumvalue" href="neorv32__twi_8h.html#a3421852c63baca60fe58c990b1c653d8accd7e8be435db3055c27f0a6d5e0201e">TWI_DCMD_CMD_HI</a> = 10 </div> +<div class="line"><a id="l00064" name="l00064"></a><span class="lineno"><a class="line" href="neorv32__twi_8h.html#a3421852c63baca60fe58c990b1c653d8accd7e8be435db3055c27f0a6d5e0201e"> 64</a></span>};</div> +</div> +<div class="line"><a id="l00067" name="l00067"></a><span class="lineno"> 67</span><span class="comment">/**********************************************************************/</span></div> +<div class="line"><a id="l00071" name="l00071"></a><span class="lineno"> 71</span><span class="preprocessor">#define TWI_CMD_NOP (0b00) </span><span class="comment">// no operation</span></div> +<div class="line"><a id="l00072" name="l00072"></a><span class="lineno"> 72</span><span class="preprocessor">#define TWI_CMD_START (0b01) </span><span class="comment">// generate start condition</span></div> +<div class="line"><a id="l00073" name="l00073"></a><span class="lineno"> 73</span><span class="preprocessor">#define TWI_CMD_STOP (0b10) </span><span class="comment">// generate stop condition</span></div> +<div class="line"><a id="l00074" name="l00074"></a><span class="lineno"> 74</span><span class="preprocessor">#define TWI_CMD_RTX (0b11) </span><span class="comment">// transmit+receive data byte</span></div> +<div class="line"><a id="l00078" name="l00078"></a><span class="lineno"> 78</span><span class="comment">/**********************************************************************/</span><span class="preprocessor"></span></div> +<div class="line"><a id="l00082" name="l00082"></a><span class="lineno"> 82</span><span class="keywordtype">int</span> <a class="code hl_function" href="neorv32__twi_8h.html#aa2e01ebbc0c82d65ed4ded351f4d8711">neorv32_twi_available</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00083" name="l00083"></a><span class="lineno"> 83</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__twi_8h.html#a7ea6f3509a7cf622234d4b83e33afbe3">neorv32_twi_setup</a>(<span class="keywordtype">int</span> prsc, <span class="keywordtype">int</span> cdiv, <span class="keywordtype">int</span> clkstr);</div> +<div class="line"><a id="l00084" name="l00084"></a><span class="lineno"> 84</span><span class="keywordtype">int</span> <a class="code hl_function" href="neorv32__twi_8h.html#a2c8f3bc55f4a9a8bdcb111759cf56ae2">neorv32_twi_get_fifo_depth</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00085" name="l00085"></a><span class="lineno"> 85</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__twi_8h.html#ae5f31e737c7a6c3c86070ff34cb0d861">neorv32_twi_disable</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00086" name="l00086"></a><span class="lineno"> 86</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__twi_8h.html#a22717887cffff1e6830756bc73140e7b">neorv32_twi_enable</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00087" name="l00087"></a><span class="lineno"> 87</span> </div> +<div class="line"><a id="l00088" name="l00088"></a><span class="lineno"> 88</span><span class="keywordtype">int</span> <a class="code hl_function" href="neorv32__twi_8h.html#a4fff1ddade320f6cc568c6266f2c2acd">neorv32_twi_busy</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00089" name="l00089"></a><span class="lineno"> 89</span><span class="keywordtype">int</span> <a class="code hl_function" href="neorv32__twi_8h.html#a7735376d26560866b153ed205dfcb2ba">neorv32_twi_get</a>(uint8_t *data);</div> +<div class="line"><a id="l00090" name="l00090"></a><span class="lineno"> 90</span> </div> +<div class="line"><a id="l00091" name="l00091"></a><span class="lineno"> 91</span><span class="keywordtype">int</span> <a class="code hl_function" href="neorv32__twi_8h.html#ac7020f3379602f11c47ca16f1bd82f2e">neorv32_twi_trans</a>(uint8_t *data, <span class="keywordtype">int</span> mack);</div> +<div class="line"><a id="l00092" name="l00092"></a><span class="lineno"> 92</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__twi_8h.html#ad352447adcccccabd4e20577b34fbece">neorv32_twi_generate_stop</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00093" name="l00093"></a><span class="lineno"> 93</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__twi_8h.html#a633d460e4735eb369d74a834b03c8b78">neorv32_twi_generate_start</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00094" name="l00094"></a><span class="lineno"> 94</span> </div> +<div class="line"><a id="l00095" name="l00095"></a><span class="lineno"> 95</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__twi_8h.html#a28fc44cce5d28f6e8c32268b239b07d5">neorv32_twi_send_nonblocking</a>(uint8_t data, <span class="keywordtype">int</span> mack);</div> +<div class="line"><a id="l00096" name="l00096"></a><span class="lineno"> 96</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__twi_8h.html#aa22430aab0a38d88cbd2c4220c573da0">neorv32_twi_generate_stop_nonblocking</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00097" name="l00097"></a><span class="lineno"> 97</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__twi_8h.html#adbf2eaed0c76221da5c3091665fc885e">neorv32_twi_generate_start_nonblocking</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00101" name="l00101"></a><span class="lineno"> 101</span><span class="preprocessor">#endif </span><span class="comment">// neorv32_twi_h</span></div> +<div class="ttc" id="aneorv32__twi_8h_html_a22717887cffff1e6830756bc73140e7b"><div class="ttname"><a href="neorv32__twi_8h.html#a22717887cffff1e6830756bc73140e7b">neorv32_twi_enable</a></div><div class="ttdeci">void neorv32_twi_enable(void)</div><div class="ttdef"><b>Definition</b> neorv32_twi.c:81</div></div> +<div class="ttc" id="aneorv32__twi_8h_html_a28fc44cce5d28f6e8c32268b239b07d5"><div class="ttname"><a href="neorv32__twi_8h.html#a28fc44cce5d28f6e8c32268b239b07d5">neorv32_twi_send_nonblocking</a></div><div class="ttdeci">void neorv32_twi_send_nonblocking(uint8_t data, int mack)</div><div class="ttdef"><b>Definition</b> neorv32_twi.c:182</div></div> +<div class="ttc" id="aneorv32__twi_8h_html_a2c8f3bc55f4a9a8bdcb111759cf56ae2"><div class="ttname"><a href="neorv32__twi_8h.html#a2c8f3bc55f4a9a8bdcb111759cf56ae2">neorv32_twi_get_fifo_depth</a></div><div class="ttdeci">int neorv32_twi_get_fifo_depth(void)</div><div class="ttdef"><b>Definition</b> neorv32_twi.c:62</div></div> +<div class="ttc" id="aneorv32__twi_8h_html_a3421852c63baca60fe58c990b1c653d8"><div class="ttname"><a href="neorv32__twi_8h.html#a3421852c63baca60fe58c990b1c653d8">NEORV32_TWI_DCMD_enum</a></div><div class="ttdeci">NEORV32_TWI_DCMD_enum</div><div class="ttdef"><b>Definition</b> neorv32_twi.h:58</div></div> +<div class="ttc" id="aneorv32__twi_8h_html_a3421852c63baca60fe58c990b1c653d8ab2e20f7f5a5b131c31772341caa97e5e"><div class="ttname"><a href="neorv32__twi_8h.html#a3421852c63baca60fe58c990b1c653d8ab2e20f7f5a5b131c31772341caa97e5e">TWI_DCMD_CMD_LO</a></div><div class="ttdeci">@ TWI_DCMD_CMD_LO</div><div class="ttdef"><b>Definition</b> neorv32_twi.h:62</div></div> +<div class="ttc" id="aneorv32__twi_8h_html_a3421852c63baca60fe58c990b1c653d8ab7f53f7cef06031c1a34db04c602a50d"><div class="ttname"><a href="neorv32__twi_8h.html#a3421852c63baca60fe58c990b1c653d8ab7f53f7cef06031c1a34db04c602a50d">TWI_DCMD_MSB</a></div><div class="ttdeci">@ TWI_DCMD_MSB</div><div class="ttdef"><b>Definition</b> neorv32_twi.h:60</div></div> +<div class="ttc" id="aneorv32__twi_8h_html_a3421852c63baca60fe58c990b1c653d8accd7e8be435db3055c27f0a6d5e0201e"><div class="ttname"><a href="neorv32__twi_8h.html#a3421852c63baca60fe58c990b1c653d8accd7e8be435db3055c27f0a6d5e0201e">TWI_DCMD_CMD_HI</a></div><div class="ttdeci">@ TWI_DCMD_CMD_HI</div><div class="ttdef"><b>Definition</b> neorv32_twi.h:63</div></div> +<div class="ttc" id="aneorv32__twi_8h_html_a3421852c63baca60fe58c990b1c653d8adf6176c87655bbbb5c7cea9dea29ce56"><div class="ttname"><a href="neorv32__twi_8h.html#a3421852c63baca60fe58c990b1c653d8adf6176c87655bbbb5c7cea9dea29ce56">TWI_DCMD_LSB</a></div><div class="ttdeci">@ TWI_DCMD_LSB</div><div class="ttdef"><b>Definition</b> neorv32_twi.h:59</div></div> +<div class="ttc" id="aneorv32__twi_8h_html_a3421852c63baca60fe58c990b1c653d8af64359afd3627db0a79733d00128f3a5"><div class="ttname"><a href="neorv32__twi_8h.html#a3421852c63baca60fe58c990b1c653d8af64359afd3627db0a79733d00128f3a5">TWI_DCMD_ACK</a></div><div class="ttdeci">@ TWI_DCMD_ACK</div><div class="ttdef"><b>Definition</b> neorv32_twi.h:61</div></div> +<div class="ttc" id="aneorv32__twi_8h_html_a4fff1ddade320f6cc568c6266f2c2acd"><div class="ttname"><a href="neorv32__twi_8h.html#a4fff1ddade320f6cc568c6266f2c2acd">neorv32_twi_busy</a></div><div class="ttdeci">int neorv32_twi_busy(void)</div><div class="ttdef"><b>Definition</b> neorv32_twi.c:92</div></div> +<div class="ttc" id="aneorv32__twi_8h_html_a633d460e4735eb369d74a834b03c8b78"><div class="ttname"><a href="neorv32__twi_8h.html#a633d460e4735eb369d74a834b03c8b78">neorv32_twi_generate_start</a></div><div class="ttdeci">void neorv32_twi_generate_start(void)</div><div class="ttdef"><b>Definition</b> neorv32_twi.c:166</div></div> +<div class="ttc" id="aneorv32__twi_8h_html_a71ef393d3b34d2dd0698590994b7dafa"><div class="ttname"><a href="neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafa">NEORV32_TWI_CTRL_enum</a></div><div class="ttdeci">NEORV32_TWI_CTRL_enum</div><div class="ttdef"><b>Definition</b> neorv32_twi.h:38</div></div> +<div class="ttc" id="aneorv32__twi_8h_html_a71ef393d3b34d2dd0698590994b7dafaa183f5b9c3993d04cc9aea2a79e9a4f75"><div class="ttname"><a href="neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaa183f5b9c3993d04cc9aea2a79e9a4f75">TWI_CTRL_FIFO_MSB</a></div><div class="ttdeci">@ TWI_CTRL_FIFO_MSB</div><div class="ttdef"><b>Definition</b> neorv32_twi.h:50</div></div> +<div class="ttc" id="aneorv32__twi_8h_html_a71ef393d3b34d2dd0698590994b7dafaa43381fe5ab9fe64ebdf76638eba5a694"><div class="ttname"><a href="neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaa43381fe5ab9fe64ebdf76638eba5a694">TWI_CTRL_EN</a></div><div class="ttdeci">@ TWI_CTRL_EN</div><div class="ttdef"><b>Definition</b> neorv32_twi.h:39</div></div> +<div class="ttc" id="aneorv32__twi_8h_html_a71ef393d3b34d2dd0698590994b7dafaa443a2a65ee810f428d40a4f8474d8e6d"><div class="ttname"><a href="neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaa443a2a65ee810f428d40a4f8474d8e6d">TWI_CTRL_BUSY</a></div><div class="ttdeci">@ TWI_CTRL_BUSY</div><div class="ttdef"><b>Definition</b> neorv32_twi.h:54</div></div> +<div class="ttc" id="aneorv32__twi_8h_html_a71ef393d3b34d2dd0698590994b7dafaa4473769463a0c7e4b58ed0b983610674"><div class="ttname"><a href="neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaa4473769463a0c7e4b58ed0b983610674">TWI_CTRL_CDIV1</a></div><div class="ttdeci">@ TWI_CTRL_CDIV1</div><div class="ttdef"><b>Definition</b> neorv32_twi.h:44</div></div> +<div class="ttc" id="aneorv32__twi_8h_html_a71ef393d3b34d2dd0698590994b7dafaa4d55ed983ca2f94fa9deac196d949b31"><div class="ttname"><a href="neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaa4d55ed983ca2f94fa9deac196d949b31">TWI_CTRL_PRSC2</a></div><div class="ttdeci">@ TWI_CTRL_PRSC2</div><div class="ttdef"><b>Definition</b> neorv32_twi.h:42</div></div> +<div class="ttc" id="aneorv32__twi_8h_html_a71ef393d3b34d2dd0698590994b7dafaa74126d424719b1db61f5e1ab567489fb"><div class="ttname"><a href="neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaa74126d424719b1db61f5e1ab567489fb">TWI_CTRL_FIFO_LSB</a></div><div class="ttdeci">@ TWI_CTRL_FIFO_LSB</div><div class="ttdef"><b>Definition</b> neorv32_twi.h:49</div></div> +<div class="ttc" id="aneorv32__twi_8h_html_a71ef393d3b34d2dd0698590994b7dafaa75d3a61b5e642e5d5c1f699c35c26b31"><div class="ttname"><a href="neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaa75d3a61b5e642e5d5c1f699c35c26b31">TWI_CTRL_CDIV0</a></div><div class="ttdeci">@ TWI_CTRL_CDIV0</div><div class="ttdef"><b>Definition</b> neorv32_twi.h:43</div></div> +<div class="ttc" id="aneorv32__twi_8h_html_a71ef393d3b34d2dd0698590994b7dafaa8b666cd2e40ca9ba3f9a635f0ed107df"><div class="ttname"><a href="neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaa8b666cd2e40ca9ba3f9a635f0ed107df">TWI_CTRL_PRSC1</a></div><div class="ttdeci">@ TWI_CTRL_PRSC1</div><div class="ttdef"><b>Definition</b> neorv32_twi.h:41</div></div> +<div class="ttc" id="aneorv32__twi_8h_html_a71ef393d3b34d2dd0698590994b7dafaa9033ac6cc891bff0da52449aa4b6a8d9"><div class="ttname"><a href="neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaa9033ac6cc891bff0da52449aa4b6a8d9">TWI_CTRL_PRSC0</a></div><div class="ttdeci">@ TWI_CTRL_PRSC0</div><div class="ttdef"><b>Definition</b> neorv32_twi.h:40</div></div> +<div class="ttc" id="aneorv32__twi_8h_html_a71ef393d3b34d2dd0698590994b7dafaa99e2153a53cc1f9d7cc83d52c698cbcc"><div class="ttname"><a href="neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaa99e2153a53cc1f9d7cc83d52c698cbcc">TWI_CTRL_CDIV3</a></div><div class="ttdeci">@ TWI_CTRL_CDIV3</div><div class="ttdef"><b>Definition</b> neorv32_twi.h:46</div></div> +<div class="ttc" id="aneorv32__twi_8h_html_a71ef393d3b34d2dd0698590994b7dafaaa0597dc9dea3f6f7a2f19dbcc7a2dabb"><div class="ttname"><a href="neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaaa0597dc9dea3f6f7a2f19dbcc7a2dabb">TWI_CTRL_TX_FULL</a></div><div class="ttdeci">@ TWI_CTRL_TX_FULL</div><div class="ttdef"><b>Definition</b> neorv32_twi.h:52</div></div> +<div class="ttc" id="aneorv32__twi_8h_html_a71ef393d3b34d2dd0698590994b7dafaaa6db454861ad5be70846ed4f9eb2ea12"><div class="ttname"><a href="neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaaa6db454861ad5be70846ed4f9eb2ea12">TWI_CTRL_CDIV2</a></div><div class="ttdeci">@ TWI_CTRL_CDIV2</div><div class="ttdef"><b>Definition</b> neorv32_twi.h:45</div></div> +<div class="ttc" id="aneorv32__twi_8h_html_a71ef393d3b34d2dd0698590994b7dafaac62d6e3c47a8195a6a9ccc79129bfe48"><div class="ttname"><a href="neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaac62d6e3c47a8195a6a9ccc79129bfe48">TWI_CTRL_CLKSTR</a></div><div class="ttdeci">@ TWI_CTRL_CLKSTR</div><div class="ttdef"><b>Definition</b> neorv32_twi.h:47</div></div> +<div class="ttc" id="aneorv32__twi_8h_html_a71ef393d3b34d2dd0698590994b7dafaad2798dfabf3a72e6138135e983734671"><div class="ttname"><a href="neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaad2798dfabf3a72e6138135e983734671">TWI_CTRL_RX_AVAIL</a></div><div class="ttdeci">@ TWI_CTRL_RX_AVAIL</div><div class="ttdef"><b>Definition</b> neorv32_twi.h:53</div></div> +<div class="ttc" id="aneorv32__twi_8h_html_a7735376d26560866b153ed205dfcb2ba"><div class="ttname"><a href="neorv32__twi_8h.html#a7735376d26560866b153ed205dfcb2ba">neorv32_twi_get</a></div><div class="ttdeci">int neorv32_twi_get(uint8_t *data)</div><div class="ttdef"><b>Definition</b> neorv32_twi.c:109</div></div> +<div class="ttc" id="aneorv32__twi_8h_html_a7ea6f3509a7cf622234d4b83e33afbe3"><div class="ttname"><a href="neorv32__twi_8h.html#a7ea6f3509a7cf622234d4b83e33afbe3">neorv32_twi_setup</a></div><div class="ttdeci">void neorv32_twi_setup(int prsc, int cdiv, int clkstr)</div><div class="ttdef"><b>Definition</b> neorv32_twi.c:44</div></div> +<div class="ttc" id="aneorv32__twi_8h_html_aa22430aab0a38d88cbd2c4220c573da0"><div class="ttname"><a href="neorv32__twi_8h.html#aa22430aab0a38d88cbd2c4220c573da0">neorv32_twi_generate_stop_nonblocking</a></div><div class="ttdeci">void neorv32_twi_generate_stop_nonblocking(void)</div><div class="ttdef"><b>Definition</b> neorv32_twi.c:196</div></div> +<div class="ttc" id="aneorv32__twi_8h_html_aa2e01ebbc0c82d65ed4ded351f4d8711"><div class="ttname"><a href="neorv32__twi_8h.html#aa2e01ebbc0c82d65ed4ded351f4d8711">neorv32_twi_available</a></div><div class="ttdeci">int neorv32_twi_available(void)</div><div class="ttdef"><b>Definition</b> neorv32_twi.c:26</div></div> +<div class="ttc" id="aneorv32__twi_8h_html_ac7020f3379602f11c47ca16f1bd82f2e"><div class="ttname"><a href="neorv32__twi_8h.html#ac7020f3379602f11c47ca16f1bd82f2e">neorv32_twi_trans</a></div><div class="ttdeci">int neorv32_twi_trans(uint8_t *data, int mack)</div><div class="ttdef"><b>Definition</b> neorv32_twi.c:130</div></div> +<div class="ttc" id="aneorv32__twi_8h_html_ad352447adcccccabd4e20577b34fbece"><div class="ttname"><a href="neorv32__twi_8h.html#ad352447adcccccabd4e20577b34fbece">neorv32_twi_generate_stop</a></div><div class="ttdeci">void neorv32_twi_generate_stop(void)</div><div class="ttdef"><b>Definition</b> neorv32_twi.c:153</div></div> +<div class="ttc" id="aneorv32__twi_8h_html_adbf2eaed0c76221da5c3091665fc885e"><div class="ttname"><a href="neorv32__twi_8h.html#adbf2eaed0c76221da5c3091665fc885e">neorv32_twi_generate_start_nonblocking</a></div><div class="ttdeci">void neorv32_twi_generate_start_nonblocking(void)</div><div class="ttdef"><b>Definition</b> neorv32_twi.c:207</div></div> +<div class="ttc" id="aneorv32__twi_8h_html_ae5f31e737c7a6c3c86070ff34cb0d861"><div class="ttname"><a href="neorv32__twi_8h.html#ae5f31e737c7a6c3c86070ff34cb0d861">neorv32_twi_disable</a></div><div class="ttdeci">void neorv32_twi_disable(void)</div><div class="ttdef"><b>Definition</b> neorv32_twi.c:72</div></div> +<div class="ttc" id="astructneorv32__twi__t_html"><div class="ttname"><a href="structneorv32__twi__t.html">neorv32_twi_t</a></div><div class="ttdef"><b>Definition</b> neorv32_twi.h:29</div></div> +<div class="ttc" id="astructneorv32__twi__t_html_a148a1c681a2632881b25ee41652b5304"><div class="ttname"><a href="structneorv32__twi__t.html#a148a1c681a2632881b25ee41652b5304">neorv32_twi_t::CTRL</a></div><div class="ttdeci">uint32_t CTRL</div><div class="ttdef"><b>Definition</b> neorv32_twi.h:30</div></div> +<div class="ttc" id="astructneorv32__twi__t_html_ae311e0827bdb178c6dd8c4535b80d5cb"><div class="ttname"><a href="structneorv32__twi__t.html#ae311e0827bdb178c6dd8c4535b80d5cb">neorv32_twi_t::DCMD</a></div><div class="ttdeci">uint32_t DCMD</div><div class="ttdef"><b>Definition</b> neorv32_twi.h:31</div></div> +</div><!-- fragment --></div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/neorv32__uart_8c.html b/sw/neorv32__uart_8c.html new file mode 100644 index 0000000000..97ce6b845b --- /dev/null +++ b/sw/neorv32__uart_8c.html @@ -0,0 +1,860 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/lib/source/neorv32_uart.c File Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_7d04193005ada6f9450f847f4adb6b5b.html">lib</a></li><li class="navelem"><a class="el" href="dir_0c6ac14e2254a316d41123f98feeb67b.html">source</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#func-members">Functions</a> </div> + <div class="headertitle"><div class="title">neorv32_uart.c File Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p>Universal asynchronous receiver/transmitter (UART0/UART1) HW driver source file. +<a href="#details">More...</a></p> +<div class="textblock"><code>#include &quot;<a class="el" href="neorv32_8h_source.html">neorv32.h</a>&quot;</code><br /> +<code>#include &lt;string.h&gt;</code><br /> +<code>#include &lt;stdarg.h&gt;</code><br /> +</div><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="func-members" name="func-members"></a> +Functions</h2></td></tr> +<tr class="memitem:a3543435827204d82755b0a23bdea1296" id="r_a3543435827204d82755b0a23bdea1296"><td class="memItemLeft" align="right" valign="top">static void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a3543435827204d82755b0a23bdea1296">__neorv32_uart_itoa</a> (uint32_t x, char *res)</td></tr> +<tr class="separator:a3543435827204d82755b0a23bdea1296"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aefa844cd170e50e088c42829029060f3" id="r_aefa844cd170e50e088c42829029060f3"><td class="memItemLeft" align="right" valign="top">static void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aefa844cd170e50e088c42829029060f3">__neorv32_uart_tohex</a> (uint32_t x, char *res)</td></tr> +<tr class="separator:aefa844cd170e50e088c42829029060f3"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:adf807d0476b475276b8b29924297cda9" id="r_adf807d0476b475276b8b29924297cda9"><td class="memItemLeft" align="right" valign="top">static void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#adf807d0476b475276b8b29924297cda9">__neorv32_uart_touppercase</a> (uint32_t len, char *ptr)</td></tr> +<tr class="separator:adf807d0476b475276b8b29924297cda9"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:abef6415b0391dc055713404312196682" id="r_abef6415b0391dc055713404312196682"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#abef6415b0391dc055713404312196682">neorv32_uart_available</a> (<a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a> *UARTx)</td></tr> +<tr class="separator:abef6415b0391dc055713404312196682"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a9cdec36f2723c5373664022d1b68b841" id="r_a9cdec36f2723c5373664022d1b68b841"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a9cdec36f2723c5373664022d1b68b841">neorv32_uart_setup</a> (<a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a> *UARTx, uint32_t baudrate, uint32_t irq_mask)</td></tr> +<tr class="separator:a9cdec36f2723c5373664022d1b68b841"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:af85fb929c912d3edef3d86ffa833982a" id="r_af85fb929c912d3edef3d86ffa833982a"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#af85fb929c912d3edef3d86ffa833982a">neorv32_uart_get_rx_fifo_depth</a> (<a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a> *UARTx)</td></tr> +<tr class="separator:af85fb929c912d3edef3d86ffa833982a"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a031e3e27c8783c299623468020a22b0e" id="r_a031e3e27c8783c299623468020a22b0e"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a031e3e27c8783c299623468020a22b0e">neorv32_uart_get_tx_fifo_depth</a> (<a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a> *UARTx)</td></tr> +<tr class="separator:a031e3e27c8783c299623468020a22b0e"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:afa0533e81d53057c36f4997a2dbbe2bc" id="r_afa0533e81d53057c36f4997a2dbbe2bc"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#afa0533e81d53057c36f4997a2dbbe2bc">neorv32_uart_enable</a> (<a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a> *UARTx)</td></tr> +<tr class="separator:afa0533e81d53057c36f4997a2dbbe2bc"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ae18804ccd29ec2fd1cc06e9ce985b704" id="r_ae18804ccd29ec2fd1cc06e9ce985b704"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ae18804ccd29ec2fd1cc06e9ce985b704">neorv32_uart_disable</a> (<a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a> *UARTx)</td></tr> +<tr class="separator:ae18804ccd29ec2fd1cc06e9ce985b704"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a734b610f4cd1b474d7763f9700a715ec" id="r_a734b610f4cd1b474d7763f9700a715ec"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a734b610f4cd1b474d7763f9700a715ec">neorv32_uart_rtscts_enable</a> (<a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a> *UARTx)</td></tr> +<tr class="separator:a734b610f4cd1b474d7763f9700a715ec"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a7b2f924ef4554b1fa90433c38d97558d" id="r_a7b2f924ef4554b1fa90433c38d97558d"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a7b2f924ef4554b1fa90433c38d97558d">neorv32_uart_rtscts_disable</a> (<a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a> *UARTx)</td></tr> +<tr class="separator:a7b2f924ef4554b1fa90433c38d97558d"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a9bc7bb94a50b74e1145b78eec6094129" id="r_a9bc7bb94a50b74e1145b78eec6094129"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a9bc7bb94a50b74e1145b78eec6094129">neorv32_uart_putc</a> (<a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a> *UARTx, char c)</td></tr> +<tr class="separator:a9bc7bb94a50b74e1145b78eec6094129"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:afe0de59c14faff1e0c890d5465be25f0" id="r_afe0de59c14faff1e0c890d5465be25f0"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#afe0de59c14faff1e0c890d5465be25f0">neorv32_uart_rx_clear</a> (<a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a> *UARTx)</td></tr> +<tr class="separator:afe0de59c14faff1e0c890d5465be25f0"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a27971954262a2fd1f21d3bf1ba27e87c" id="r_a27971954262a2fd1f21d3bf1ba27e87c"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a27971954262a2fd1f21d3bf1ba27e87c">neorv32_uart_tx_clear</a> (<a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a> *UARTx)</td></tr> +<tr class="separator:a27971954262a2fd1f21d3bf1ba27e87c"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aa7bef48a58e044c246b8c4ad32864502" id="r_aa7bef48a58e044c246b8c4ad32864502"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aa7bef48a58e044c246b8c4ad32864502">neorv32_uart_tx_busy</a> (<a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a> *UARTx)</td></tr> +<tr class="separator:aa7bef48a58e044c246b8c4ad32864502"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a2efd432f63b8d36d44263d0b1f39a6dc" id="r_a2efd432f63b8d36d44263d0b1f39a6dc"><td class="memItemLeft" align="right" valign="top">char&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a2efd432f63b8d36d44263d0b1f39a6dc">neorv32_uart_getc</a> (<a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a> *UARTx)</td></tr> +<tr class="separator:a2efd432f63b8d36d44263d0b1f39a6dc"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:adedb0e07efb232717534017167a5be98" id="r_adedb0e07efb232717534017167a5be98"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#adedb0e07efb232717534017167a5be98">neorv32_uart_char_received</a> (<a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a> *UARTx)</td></tr> +<tr class="separator:adedb0e07efb232717534017167a5be98"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aa490df3a9bb2aa3215fa6fad34ffe7d1" id="r_aa490df3a9bb2aa3215fa6fad34ffe7d1"><td class="memItemLeft" align="right" valign="top">char&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aa490df3a9bb2aa3215fa6fad34ffe7d1">neorv32_uart_char_received_get</a> (<a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a> *UARTx)</td></tr> +<tr class="separator:aa490df3a9bb2aa3215fa6fad34ffe7d1"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a45a07d5e71677162baaa1025759c67a2" id="r_a45a07d5e71677162baaa1025759c67a2"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a45a07d5e71677162baaa1025759c67a2">neorv32_uart_puts</a> (<a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a> *UARTx, const char *s)</td></tr> +<tr class="separator:a45a07d5e71677162baaa1025759c67a2"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a8714cdb1c04d94bec322c6215ea10238" id="r_a8714cdb1c04d94bec322c6215ea10238"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a8714cdb1c04d94bec322c6215ea10238">neorv32_uart_vprintf</a> (<a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a> *UARTx, const char *format, va_list args)</td></tr> +<tr class="separator:a8714cdb1c04d94bec322c6215ea10238"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ab8c1f9f451def9126ab2749d7bbe50d9" id="r_ab8c1f9f451def9126ab2749d7bbe50d9"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ab8c1f9f451def9126ab2749d7bbe50d9">neorv32_uart_printf</a> (<a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a> *UARTx, const char *format,...)</td></tr> +<tr class="separator:ab8c1f9f451def9126ab2749d7bbe50d9"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ac429964878bd6deab61d9ed8659bca75" id="r_ac429964878bd6deab61d9ed8659bca75"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ac429964878bd6deab61d9ed8659bca75">neorv32_uart_scan</a> (<a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a> *UARTx, char *buffer, int max_size, int echo)</td></tr> +<tr class="separator:ac429964878bd6deab61d9ed8659bca75"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a07036e93939040c563e862a6a31b65bc" id="r_a07036e93939040c563e862a6a31b65bc"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a07036e93939040c563e862a6a31b65bc">putchar</a> (int ch)</td></tr> +<tr class="separator:a07036e93939040c563e862a6a31b65bc"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a3e29caa20f7cffe18f410f01278905a8" id="r_a3e29caa20f7cffe18f410f01278905a8"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a3e29caa20f7cffe18f410f01278905a8">getchar</a> (void)</td></tr> +<tr class="separator:a3e29caa20f7cffe18f410f01278905a8"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>Universal asynchronous receiver/transmitter (UART0/UART1) HW driver source file. </p> +<dl class="section note"><dt>Note</dt><dd>These functions should only be used if the UART0/UART1 unit was synthesized.</dd></dl> +<dl class="section see"><dt>See also</dt><dd><a href="https://stnolting.github.io/neorv32/sw/files.html">https://stnolting.github.io/neorv32/sw/files.html</a> </dd></dl> +</div><h2 class="groupheader">Function Documentation</h2> +<a id="a3543435827204d82755b0a23bdea1296" name="a3543435827204d82755b0a23bdea1296"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a3543435827204d82755b0a23bdea1296">&#9670;&#160;</a></span>__neorv32_uart_itoa()</h2> + +<div class="memitem"> +<div class="memproto"> +<table class="mlabels"> + <tr> + <td class="mlabels-left"> + <table class="memname"> + <tr> + <td class="memname">static void __neorv32_uart_itoa </td> + <td>(</td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>x</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">char *</td> <td class="paramname"><span class="paramname"><em>res</em></span>&#160;)</td> + </tr> + </table> + </td> + <td class="mlabels-right"> +<span class="mlabels"><span class="mlabel">static</span></span> </td> + </tr> +</table> +</div><div class="memdoc"> +<p>Private function for 'neorv32_printf' to convert into decimal.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">x</td><td>Unsigned input number. </td></tr> + <tr><td class="paramdir">[in,out]</td><td class="paramname">res</td><td>Pointer for storing the resulting number string (11 chars). </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="aefa844cd170e50e088c42829029060f3" name="aefa844cd170e50e088c42829029060f3"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aefa844cd170e50e088c42829029060f3">&#9670;&#160;</a></span>__neorv32_uart_tohex()</h2> + +<div class="memitem"> +<div class="memproto"> +<table class="mlabels"> + <tr> + <td class="mlabels-left"> + <table class="memname"> + <tr> + <td class="memname">static void __neorv32_uart_tohex </td> + <td>(</td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>x</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">char *</td> <td class="paramname"><span class="paramname"><em>res</em></span>&#160;)</td> + </tr> + </table> + </td> + <td class="mlabels-right"> +<span class="mlabels"><span class="mlabel">static</span></span> </td> + </tr> +</table> +</div><div class="memdoc"> +<p>Private function for 'neorv32_printf' to convert into hexadecimal.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">x</td><td>Unsigned input number. </td></tr> + <tr><td class="paramdir">[in,out]</td><td class="paramname">res</td><td>Pointer for storing the resulting number string (9 chars). </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="adf807d0476b475276b8b29924297cda9" name="adf807d0476b475276b8b29924297cda9"></a> +<h2 class="memtitle"><span class="permalink"><a href="#adf807d0476b475276b8b29924297cda9">&#9670;&#160;</a></span>__neorv32_uart_touppercase()</h2> + +<div class="memitem"> +<div class="memproto"> +<table class="mlabels"> + <tr> + <td class="mlabels-left"> + <table class="memname"> + <tr> + <td class="memname">static void __neorv32_uart_touppercase </td> + <td>(</td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>len</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">char *</td> <td class="paramname"><span class="paramname"><em>ptr</em></span>&#160;)</td> + </tr> + </table> + </td> + <td class="mlabels-right"> +<span class="mlabels"><span class="mlabel">static</span></span> </td> + </tr> +</table> +</div><div class="memdoc"> +<p>Private function to cast a string to UPPERCASE.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">len</td><td>Total length of input string. </td></tr> + <tr><td class="paramdir">[in,out]</td><td class="paramname">ptr</td><td>Pointer for input/output string. </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="a3e29caa20f7cffe18f410f01278905a8" name="a3e29caa20f7cffe18f410f01278905a8"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a3e29caa20f7cffe18f410f01278905a8">&#9670;&#160;</a></span>getchar()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int getchar </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>STDIO: Read char from UART0.</p> +<dl class="section return"><dt>Returns</dt><dd>Read char. </dd></dl> + +</div> +</div> +<a id="abef6415b0391dc055713404312196682" name="abef6415b0391dc055713404312196682"></a> +<h2 class="memtitle"><span class="permalink"><a href="#abef6415b0391dc055713404312196682">&#9670;&#160;</a></span>neorv32_uart_available()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_uart_available </td> + <td>(</td> + <td class="paramtype"><a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a> *</td> <td class="paramname"><span class="paramname"><em>UARTx</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Check if UART unit was synthesized.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in,out]</td><td class="paramname">Hardware</td><td>handle to UART register struct, <a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a>. </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>0 if UART0/1 was not synthesized, 1 if UART0/1 is available. </dd></dl> + +</div> +</div> +<a id="adedb0e07efb232717534017167a5be98" name="adedb0e07efb232717534017167a5be98"></a> +<h2 class="memtitle"><span class="permalink"><a href="#adedb0e07efb232717534017167a5be98">&#9670;&#160;</a></span>neorv32_uart_char_received()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_uart_char_received </td> + <td>(</td> + <td class="paramtype"><a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a> *</td> <td class="paramname"><span class="paramname"><em>UARTx</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Check if UART has received a char.</p> +<dl class="section note"><dt>Note</dt><dd>This function is non-blocking. </dd> +<dd> +Use neorv32_uart_char_received_get(void) to get the char.</dd></dl> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in,out]</td><td class="paramname">UARTx</td><td>Hardware handle to UART register struct, <a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a>. </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>1 when a char has been received, 0 otherwise. </dd></dl> + +</div> +</div> +<a id="aa490df3a9bb2aa3215fa6fad34ffe7d1" name="aa490df3a9bb2aa3215fa6fad34ffe7d1"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aa490df3a9bb2aa3215fa6fad34ffe7d1">&#9670;&#160;</a></span>neorv32_uart_char_received_get()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">char neorv32_uart_char_received_get </td> + <td>(</td> + <td class="paramtype"><a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a> *</td> <td class="paramname"><span class="paramname"><em>UARTx</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Get a received char from UART.</p> +<dl class="section note"><dt>Note</dt><dd>This function is non-blocking. </dd> +<dd> +Should only be used in combination with neorv32_uart_char_received(void).</dd></dl> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in,out]</td><td class="paramname">UARTx</td><td>Hardware handle to UART register struct, <a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a>. </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Received char. </dd></dl> + +</div> +</div> +<a id="ae18804ccd29ec2fd1cc06e9ce985b704" name="ae18804ccd29ec2fd1cc06e9ce985b704"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ae18804ccd29ec2fd1cc06e9ce985b704">&#9670;&#160;</a></span>neorv32_uart_disable()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_uart_disable </td> + <td>(</td> + <td class="paramtype"><a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a> *</td> <td class="paramname"><span class="paramname"><em>UARTx</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Disable UART.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in,out]</td><td class="paramname">UARTx</td><td>Hardware handle to UART register struct, <a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a>. </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="afa0533e81d53057c36f4997a2dbbe2bc" name="afa0533e81d53057c36f4997a2dbbe2bc"></a> +<h2 class="memtitle"><span class="permalink"><a href="#afa0533e81d53057c36f4997a2dbbe2bc">&#9670;&#160;</a></span>neorv32_uart_enable()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_uart_enable </td> + <td>(</td> + <td class="paramtype"><a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a> *</td> <td class="paramname"><span class="paramname"><em>UARTx</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Enable UART.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in,out]</td><td class="paramname">UARTx</td><td>Hardware handle to UART register struct, <a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a>. </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="af85fb929c912d3edef3d86ffa833982a" name="af85fb929c912d3edef3d86ffa833982a"></a> +<h2 class="memtitle"><span class="permalink"><a href="#af85fb929c912d3edef3d86ffa833982a">&#9670;&#160;</a></span>neorv32_uart_get_rx_fifo_depth()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_uart_get_rx_fifo_depth </td> + <td>(</td> + <td class="paramtype"><a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a> *</td> <td class="paramname"><span class="paramname"><em>UARTx</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Get UART RX FIFO depth.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in,out]</td><td class="paramname">UARTx</td><td>Hardware handle to UART register struct, <a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a>.</td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>FIFO depth (number of entries) </dd></dl> + +</div> +</div> +<a id="a031e3e27c8783c299623468020a22b0e" name="a031e3e27c8783c299623468020a22b0e"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a031e3e27c8783c299623468020a22b0e">&#9670;&#160;</a></span>neorv32_uart_get_tx_fifo_depth()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_uart_get_tx_fifo_depth </td> + <td>(</td> + <td class="paramtype"><a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a> *</td> <td class="paramname"><span class="paramname"><em>UARTx</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Get UART TX FIFO depth.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in,out]</td><td class="paramname">UARTx</td><td>Hardware handle to UART register struct, <a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a>.</td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>FIFO depth (number of entries) </dd></dl> + +</div> +</div> +<a id="a2efd432f63b8d36d44263d0b1f39a6dc" name="a2efd432f63b8d36d44263d0b1f39a6dc"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a2efd432f63b8d36d44263d0b1f39a6dc">&#9670;&#160;</a></span>neorv32_uart_getc()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">char neorv32_uart_getc </td> + <td>(</td> + <td class="paramtype"><a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a> *</td> <td class="paramname"><span class="paramname"><em>UARTx</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Get char from UART.</p> +<dl class="section note"><dt>Note</dt><dd>This function is blocking.</dd></dl> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in,out]</td><td class="paramname">UARTx</td><td>Hardware handle to UART register struct, <a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a>. </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Received char. </dd></dl> + +</div> +</div> +<a id="ab8c1f9f451def9126ab2749d7bbe50d9" name="ab8c1f9f451def9126ab2749d7bbe50d9"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ab8c1f9f451def9126ab2749d7bbe50d9">&#9670;&#160;</a></span>neorv32_uart_printf()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_uart_printf </td> + <td>(</td> + <td class="paramtype"><a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a> *</td> <td class="paramname"><span class="paramname"><em>UARTx</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">const char *</td> <td class="paramname"><span class="paramname"><em>format</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype"></td> <td class="paramname"><span class="paramname"><em>...</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Custom version of 'printf' printing to UART.</p> +<dl class="section warning"><dt>Warning</dt><dd>: This functions only provides a minimal subset of the 'printf' formating features! </dd></dl> +<dl class="section note"><dt>Note</dt><dd>This function is blocking.</dd></dl> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in,out]</td><td class="paramname">UARTx</td><td>Hardware handle to UART register struct, <a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a>. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">format</td><td>Pointer to format string. See neorv32_uart_vprintf. </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="a9bc7bb94a50b74e1145b78eec6094129" name="a9bc7bb94a50b74e1145b78eec6094129"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a9bc7bb94a50b74e1145b78eec6094129">&#9670;&#160;</a></span>neorv32_uart_putc()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_uart_putc </td> + <td>(</td> + <td class="paramtype"><a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a> *</td> <td class="paramname"><span class="paramname"><em>UARTx</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">char</td> <td class="paramname"><span class="paramname"><em>c</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Send single char via UART.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in,out]</td><td class="paramname">UARTx</td><td>Hardware handle to UART register struct, <a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a>. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">c</td><td>Char to be send. </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="a45a07d5e71677162baaa1025759c67a2" name="a45a07d5e71677162baaa1025759c67a2"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a45a07d5e71677162baaa1025759c67a2">&#9670;&#160;</a></span>neorv32_uart_puts()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_uart_puts </td> + <td>(</td> + <td class="paramtype"><a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a> *</td> <td class="paramname"><span class="paramname"><em>UARTx</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">const char *</td> <td class="paramname"><span class="paramname"><em>s</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Print string (zero-terminated) via UART. Print full line break "\r\n" for every '<br /> +'.</p> +<dl class="section note"><dt>Note</dt><dd>This function is blocking.</dd></dl> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in,out]</td><td class="paramname">UARTx</td><td>Hardware handle to UART register struct, <a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a>. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">s</td><td>Pointer to string. </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="a7b2f924ef4554b1fa90433c38d97558d" name="a7b2f924ef4554b1fa90433c38d97558d"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a7b2f924ef4554b1fa90433c38d97558d">&#9670;&#160;</a></span>neorv32_uart_rtscts_disable()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_uart_rtscts_disable </td> + <td>(</td> + <td class="paramtype"><a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a> *</td> <td class="paramname"><span class="paramname"><em>UARTx</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Disable RTS/CTS hardware flow-control.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in,out]</td><td class="paramname">UARTx</td><td>Hardware handle to UART register struct, <a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a>. </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="a734b610f4cd1b474d7763f9700a715ec" name="a734b610f4cd1b474d7763f9700a715ec"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a734b610f4cd1b474d7763f9700a715ec">&#9670;&#160;</a></span>neorv32_uart_rtscts_enable()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_uart_rtscts_enable </td> + <td>(</td> + <td class="paramtype"><a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a> *</td> <td class="paramname"><span class="paramname"><em>UARTx</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Enable RTS/CTS hardware flow-control.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in,out]</td><td class="paramname">UARTx</td><td>Hardware handle to UART register struct, <a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a>. </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="afe0de59c14faff1e0c890d5465be25f0" name="afe0de59c14faff1e0c890d5465be25f0"></a> +<h2 class="memtitle"><span class="permalink"><a href="#afe0de59c14faff1e0c890d5465be25f0">&#9670;&#160;</a></span>neorv32_uart_rx_clear()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_uart_rx_clear </td> + <td>(</td> + <td class="paramtype"><a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a> *</td> <td class="paramname"><span class="paramname"><em>UARTx</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Clear RX FIFO.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in,out]</td><td class="paramname">UARTx</td><td>Hardware handle to UART register struct, <a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a>. </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="ac429964878bd6deab61d9ed8659bca75" name="ac429964878bd6deab61d9ed8659bca75"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ac429964878bd6deab61d9ed8659bca75">&#9670;&#160;</a></span>neorv32_uart_scan()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_uart_scan </td> + <td>(</td> + <td class="paramtype"><a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a> *</td> <td class="paramname"><span class="paramname"><em>UARTx</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">char *</td> <td class="paramname"><span class="paramname"><em>buffer</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>max_size</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>echo</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Simplified custom version of 'scanf' reading from UART.</p> +<dl class="section note"><dt>Note</dt><dd>This function is blocking.</dd></dl> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in,out]</td><td class="paramname">UARTx</td><td>Hardware handle to UART register struct, <a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a>. </td></tr> + <tr><td class="paramdir">[in,out]</td><td class="paramname">buffer</td><td>Pointer to array of chars to store string. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">max_size</td><td>Maximum number of chars to sample. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">echo</td><td>Echo UART input when 1. </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Number of chars read. </dd></dl> + +</div> +</div> +<a id="a9cdec36f2723c5373664022d1b68b841" name="a9cdec36f2723c5373664022d1b68b841"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a9cdec36f2723c5373664022d1b68b841">&#9670;&#160;</a></span>neorv32_uart_setup()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_uart_setup </td> + <td>(</td> + <td class="paramtype"><a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a> *</td> <td class="paramname"><span class="paramname"><em>UARTx</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>baudrate</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>irq_mask</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Reset, configure and enable UART.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in,out]</td><td class="paramname">UARTx</td><td>Hardware handle to UART register struct, <a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a>. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">baudrate</td><td>Targeted BAUD rate (e.g. 19200). </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">irq_mask</td><td>Interrupt configuration mask (CTRL's irq_* bits). </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="aa7bef48a58e044c246b8c4ad32864502" name="aa7bef48a58e044c246b8c4ad32864502"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aa7bef48a58e044c246b8c4ad32864502">&#9670;&#160;</a></span>neorv32_uart_tx_busy()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_uart_tx_busy </td> + <td>(</td> + <td class="paramtype"><a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a> *</td> <td class="paramname"><span class="paramname"><em>UARTx</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Check if UART TX is busy (transmitter busy or data left in TX buffer).</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in,out]</td><td class="paramname">UARTx</td><td>Hardware handle to UART register struct, <a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a>. </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>0 if idle, 1 if busy </dd></dl> + +</div> +</div> +<a id="a27971954262a2fd1f21d3bf1ba27e87c" name="a27971954262a2fd1f21d3bf1ba27e87c"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a27971954262a2fd1f21d3bf1ba27e87c">&#9670;&#160;</a></span>neorv32_uart_tx_clear()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_uart_tx_clear </td> + <td>(</td> + <td class="paramtype"><a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a> *</td> <td class="paramname"><span class="paramname"><em>UARTx</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Clear TX FIFO.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in,out]</td><td class="paramname">UARTx</td><td>Hardware handle to UART register struct, <a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a>. </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="a8714cdb1c04d94bec322c6215ea10238" name="a8714cdb1c04d94bec322c6215ea10238"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a8714cdb1c04d94bec322c6215ea10238">&#9670;&#160;</a></span>neorv32_uart_vprintf()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_uart_vprintf </td> + <td>(</td> + <td class="paramtype"><a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a> *</td> <td class="paramname"><span class="paramname"><em>UARTx</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">const char *</td> <td class="paramname"><span class="paramname"><em>format</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">va_list</td> <td class="paramname"><span class="paramname"><em>args</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Custom version of 'vprintf' printing to UART.</p> +<dl class="section warning"><dt>Warning</dt><dd>: This functions only provides a minimal subset of the 'vprintf' formating features! </dd></dl> +<dl class="section note"><dt>Note</dt><dd>This function is blocking.</dd></dl> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in,out]</td><td class="paramname">UARTx</td><td>Hardware handle to UART register struct, <a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a>. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">format</td><td>Pointer to format string. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">args</td><td>A value identifying a variable arguments list. </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="a07036e93939040c563e862a6a31b65bc" name="a07036e93939040c563e862a6a31b65bc"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a07036e93939040c563e862a6a31b65bc">&#9670;&#160;</a></span>putchar()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int putchar </td> + <td>(</td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>ch</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>STDIO: Send char via UART0</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">Char</td><td>to be send. </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Char that has been sent. </dd></dl> + +</div> +</div> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/neorv32__uart_8h.html b/sw/neorv32__uart_8h.html new file mode 100644 index 0000000000..a4133f1193 --- /dev/null +++ b/sw/neorv32__uart_8h.html @@ -0,0 +1,1012 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/lib/include/neorv32_uart.h File Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_7d04193005ada6f9450f847f4adb6b5b.html">lib</a></li><li class="navelem"><a class="el" href="dir_752b1e5d3973bf735fa78bf6b4727df9.html">include</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#nested-classes">Data Structures</a> </div> + <div class="headertitle"><div class="title">neorv32_uart.h File Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p>Universal asynchronous receiver/transmitter (UART0/UART1) HW driver header file. +<a href="#details">More...</a></p> +<div class="textblock"><code>#include &lt;stdint.h&gt;</code><br /> +<code>#include &lt;stdarg.h&gt;</code><br /> +</div> +<p><a href="neorv32__uart_8h_source.html">Go to the source code of this file.</a></p> +<table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="nested-classes" name="nested-classes"></a> +Data Structures</h2></td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">struct &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="define-members" name="define-members"></a> +Macros</h2></td></tr> +<tr><td colspan="2"><div class="groupHeader">UART wrappers for easy access</div></td></tr> +<tr class="memitem:a652d93c0e3c6d7e5dc7c25c2465070e5" id="r_a652d93c0e3c6d7e5dc7c25c2465070e5"><td class="memItemLeft" align="right" valign="top"><a id="a652d93c0e3c6d7e5dc7c25c2465070e5" name="a652d93c0e3c6d7e5dc7c25c2465070e5"></a> +#define&#160;</td><td class="memItemRight" valign="bottom"><b>neorv32_uart0_available</b>()&#160;&#160;&#160;<a class="el" href="neorv32__uart_8c.html#abef6415b0391dc055713404312196682">neorv32_uart_available</a>(<a class="el" href="#a4c880a6b27e46f459e750425258b1bdb">NEORV32_UART0</a>)</td></tr> +<tr class="separator:a652d93c0e3c6d7e5dc7c25c2465070e5"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aa5c803f757ecc14cdfdad521d4bf7c18" id="r_aa5c803f757ecc14cdfdad521d4bf7c18"><td class="memItemLeft" align="right" valign="top"><a id="aa5c803f757ecc14cdfdad521d4bf7c18" name="aa5c803f757ecc14cdfdad521d4bf7c18"></a> +#define&#160;</td><td class="memItemRight" valign="bottom"><b>neorv32_uart0_get_rx_fifo_depth</b>()&#160;&#160;&#160;<a class="el" href="neorv32__uart_8c.html#af85fb929c912d3edef3d86ffa833982a">neorv32_uart_get_rx_fifo_depth</a>(<a class="el" href="#a4c880a6b27e46f459e750425258b1bdb">NEORV32_UART0</a>)</td></tr> +<tr class="separator:aa5c803f757ecc14cdfdad521d4bf7c18"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:af6068949ae9ed923eac69350347273dc" id="r_af6068949ae9ed923eac69350347273dc"><td class="memItemLeft" align="right" valign="top"><a id="af6068949ae9ed923eac69350347273dc" name="af6068949ae9ed923eac69350347273dc"></a> +#define&#160;</td><td class="memItemRight" valign="bottom"><b>neorv32_uart0_get_tx_fifo_depth</b>()&#160;&#160;&#160;<a class="el" href="neorv32__uart_8c.html#a031e3e27c8783c299623468020a22b0e">neorv32_uart_get_tx_fifo_depth</a>(<a class="el" href="#a4c880a6b27e46f459e750425258b1bdb">NEORV32_UART0</a>)</td></tr> +<tr class="separator:af6068949ae9ed923eac69350347273dc"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a27e92f501ceda8e34652781901e6db33" id="r_a27e92f501ceda8e34652781901e6db33"><td class="memItemLeft" align="right" valign="top"><a id="a27e92f501ceda8e34652781901e6db33" name="a27e92f501ceda8e34652781901e6db33"></a> +#define&#160;</td><td class="memItemRight" valign="bottom"><b>neorv32_uart0_setup</b>(baudrate, irq_mask)&#160;&#160;&#160;<a class="el" href="neorv32__uart_8c.html#a9cdec36f2723c5373664022d1b68b841">neorv32_uart_setup</a>(<a class="el" href="#a4c880a6b27e46f459e750425258b1bdb">NEORV32_UART0</a>, baudrate, irq_mask)</td></tr> +<tr class="separator:a27e92f501ceda8e34652781901e6db33"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:af99ce6ccc40fec039264da66e8f67ba7" id="r_af99ce6ccc40fec039264da66e8f67ba7"><td class="memItemLeft" align="right" valign="top"><a id="af99ce6ccc40fec039264da66e8f67ba7" name="af99ce6ccc40fec039264da66e8f67ba7"></a> +#define&#160;</td><td class="memItemRight" valign="bottom"><b>neorv32_uart0_disable</b>()&#160;&#160;&#160;<a class="el" href="neorv32__uart_8c.html#ae18804ccd29ec2fd1cc06e9ce985b704">neorv32_uart_disable</a>(<a class="el" href="#a4c880a6b27e46f459e750425258b1bdb">NEORV32_UART0</a>)</td></tr> +<tr class="separator:af99ce6ccc40fec039264da66e8f67ba7"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a4cc0ea2ee22b379fc9a7f45e30bc118f" id="r_a4cc0ea2ee22b379fc9a7f45e30bc118f"><td class="memItemLeft" align="right" valign="top"><a id="a4cc0ea2ee22b379fc9a7f45e30bc118f" name="a4cc0ea2ee22b379fc9a7f45e30bc118f"></a> +#define&#160;</td><td class="memItemRight" valign="bottom"><b>neorv32_uart0_enable</b>()&#160;&#160;&#160;<a class="el" href="neorv32__uart_8c.html#afa0533e81d53057c36f4997a2dbbe2bc">neorv32_uart_enable</a>(<a class="el" href="#a4c880a6b27e46f459e750425258b1bdb">NEORV32_UART0</a>)</td></tr> +<tr class="separator:a4cc0ea2ee22b379fc9a7f45e30bc118f"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a3cdd0db72d7cffe25c9f2f90a39fc2f7" id="r_a3cdd0db72d7cffe25c9f2f90a39fc2f7"><td class="memItemLeft" align="right" valign="top"><a id="a3cdd0db72d7cffe25c9f2f90a39fc2f7" name="a3cdd0db72d7cffe25c9f2f90a39fc2f7"></a> +#define&#160;</td><td class="memItemRight" valign="bottom"><b>neorv32_uart0_rtscts_disable</b>()&#160;&#160;&#160;<a class="el" href="neorv32__uart_8c.html#a7b2f924ef4554b1fa90433c38d97558d">neorv32_uart_rtscts_disable</a>(<a class="el" href="#a4c880a6b27e46f459e750425258b1bdb">NEORV32_UART0</a>)</td></tr> +<tr class="separator:a3cdd0db72d7cffe25c9f2f90a39fc2f7"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a53734cc693bdfa11458a62df5b609264" id="r_a53734cc693bdfa11458a62df5b609264"><td class="memItemLeft" align="right" valign="top"><a id="a53734cc693bdfa11458a62df5b609264" name="a53734cc693bdfa11458a62df5b609264"></a> +#define&#160;</td><td class="memItemRight" valign="bottom"><b>neorv32_uart0_rtscts_enable</b>()&#160;&#160;&#160;<a class="el" href="neorv32__uart_8c.html#a734b610f4cd1b474d7763f9700a715ec">neorv32_uart_rtscts_enable</a>(<a class="el" href="#a4c880a6b27e46f459e750425258b1bdb">NEORV32_UART0</a>)</td></tr> +<tr class="separator:a53734cc693bdfa11458a62df5b609264"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a2dc207fedc80aa9021a4e5b7abd667a7" id="r_a2dc207fedc80aa9021a4e5b7abd667a7"><td class="memItemLeft" align="right" valign="top"><a id="a2dc207fedc80aa9021a4e5b7abd667a7" name="a2dc207fedc80aa9021a4e5b7abd667a7"></a> +#define&#160;</td><td class="memItemRight" valign="bottom"><b>neorv32_uart0_putc</b>(c)&#160;&#160;&#160;<a class="el" href="neorv32__uart_8c.html#a9bc7bb94a50b74e1145b78eec6094129">neorv32_uart_putc</a>(<a class="el" href="#a4c880a6b27e46f459e750425258b1bdb">NEORV32_UART0</a>, c)</td></tr> +<tr class="separator:a2dc207fedc80aa9021a4e5b7abd667a7"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ab576f613cf952dadb8c1a352d8bdf4b5" id="r_ab576f613cf952dadb8c1a352d8bdf4b5"><td class="memItemLeft" align="right" valign="top"><a id="ab576f613cf952dadb8c1a352d8bdf4b5" name="ab576f613cf952dadb8c1a352d8bdf4b5"></a> +#define&#160;</td><td class="memItemRight" valign="bottom"><b>neorv32_uart0_rx_clear</b>()&#160;&#160;&#160;<a class="el" href="neorv32__uart_8c.html#afe0de59c14faff1e0c890d5465be25f0">neorv32_uart_rx_clear</a>(<a class="el" href="#a4c880a6b27e46f459e750425258b1bdb">NEORV32_UART0</a>)</td></tr> +<tr class="separator:ab576f613cf952dadb8c1a352d8bdf4b5"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:af4fd1601d10c6eeca0f4e8b6fe076a7f" id="r_af4fd1601d10c6eeca0f4e8b6fe076a7f"><td class="memItemLeft" align="right" valign="top"><a id="af4fd1601d10c6eeca0f4e8b6fe076a7f" name="af4fd1601d10c6eeca0f4e8b6fe076a7f"></a> +#define&#160;</td><td class="memItemRight" valign="bottom"><b>neorv32_uart0_tx_clear</b>()&#160;&#160;&#160;<a class="el" href="neorv32__uart_8c.html#a27971954262a2fd1f21d3bf1ba27e87c">neorv32_uart_tx_clear</a>(<a class="el" href="#a4c880a6b27e46f459e750425258b1bdb">NEORV32_UART0</a>)</td></tr> +<tr class="separator:af4fd1601d10c6eeca0f4e8b6fe076a7f"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a80c68d3af417085da2d18a82081124ba" id="r_a80c68d3af417085da2d18a82081124ba"><td class="memItemLeft" align="right" valign="top"><a id="a80c68d3af417085da2d18a82081124ba" name="a80c68d3af417085da2d18a82081124ba"></a> +#define&#160;</td><td class="memItemRight" valign="bottom"><b>neorv32_uart0_tx_busy</b>()&#160;&#160;&#160;<a class="el" href="neorv32__uart_8c.html#aa7bef48a58e044c246b8c4ad32864502">neorv32_uart_tx_busy</a>(<a class="el" href="#a4c880a6b27e46f459e750425258b1bdb">NEORV32_UART0</a>)</td></tr> +<tr class="separator:a80c68d3af417085da2d18a82081124ba"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a248d40034ce64ca3325c00b9ae0c5208" id="r_a248d40034ce64ca3325c00b9ae0c5208"><td class="memItemLeft" align="right" valign="top"><a id="a248d40034ce64ca3325c00b9ae0c5208" name="a248d40034ce64ca3325c00b9ae0c5208"></a> +#define&#160;</td><td class="memItemRight" valign="bottom"><b>neorv32_uart0_getc</b>()&#160;&#160;&#160;<a class="el" href="neorv32__uart_8c.html#a2efd432f63b8d36d44263d0b1f39a6dc">neorv32_uart_getc</a>(<a class="el" href="#a4c880a6b27e46f459e750425258b1bdb">NEORV32_UART0</a>)</td></tr> +<tr class="separator:a248d40034ce64ca3325c00b9ae0c5208"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aa29a2aeeee4faeb35b19165a9af31ac7" id="r_aa29a2aeeee4faeb35b19165a9af31ac7"><td class="memItemLeft" align="right" valign="top"><a id="aa29a2aeeee4faeb35b19165a9af31ac7" name="aa29a2aeeee4faeb35b19165a9af31ac7"></a> +#define&#160;</td><td class="memItemRight" valign="bottom"><b>neorv32_uart0_char_received</b>()&#160;&#160;&#160;<a class="el" href="neorv32__uart_8c.html#adedb0e07efb232717534017167a5be98">neorv32_uart_char_received</a>(<a class="el" href="#a4c880a6b27e46f459e750425258b1bdb">NEORV32_UART0</a>)</td></tr> +<tr class="separator:aa29a2aeeee4faeb35b19165a9af31ac7"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a68aee77039a3c7450ec78e0f868889f1" id="r_a68aee77039a3c7450ec78e0f868889f1"><td class="memItemLeft" align="right" valign="top"><a id="a68aee77039a3c7450ec78e0f868889f1" name="a68aee77039a3c7450ec78e0f868889f1"></a> +#define&#160;</td><td class="memItemRight" valign="bottom"><b>neorv32_uart0_char_received_get</b>()&#160;&#160;&#160;<a class="el" href="neorv32__uart_8c.html#aa490df3a9bb2aa3215fa6fad34ffe7d1">neorv32_uart_char_received_get</a>(<a class="el" href="#a4c880a6b27e46f459e750425258b1bdb">NEORV32_UART0</a>)</td></tr> +<tr class="separator:a68aee77039a3c7450ec78e0f868889f1"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:adc688c900d03a0538dbd6461c56f00cd" id="r_adc688c900d03a0538dbd6461c56f00cd"><td class="memItemLeft" align="right" valign="top"><a id="adc688c900d03a0538dbd6461c56f00cd" name="adc688c900d03a0538dbd6461c56f00cd"></a> +#define&#160;</td><td class="memItemRight" valign="bottom"><b>neorv32_uart0_puts</b>(s)&#160;&#160;&#160;<a class="el" href="neorv32__uart_8c.html#a45a07d5e71677162baaa1025759c67a2">neorv32_uart_puts</a>(<a class="el" href="#a4c880a6b27e46f459e750425258b1bdb">NEORV32_UART0</a>, s)</td></tr> +<tr class="separator:adc688c900d03a0538dbd6461c56f00cd"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a6927bfe22016655a19b906d867006896" id="r_a6927bfe22016655a19b906d867006896"><td class="memItemLeft" align="right" valign="top"><a id="a6927bfe22016655a19b906d867006896" name="a6927bfe22016655a19b906d867006896"></a> +#define&#160;</td><td class="memItemRight" valign="bottom"><b>neorv32_uart0_printf</b>(...)&#160;&#160;&#160;<a class="el" href="neorv32__uart_8c.html#ab8c1f9f451def9126ab2749d7bbe50d9">neorv32_uart_printf</a>(<a class="el" href="#a4c880a6b27e46f459e750425258b1bdb">NEORV32_UART0</a>, __VA_ARGS__)</td></tr> +<tr class="separator:a6927bfe22016655a19b906d867006896"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aa8cd95c962154cf55fb4b9d5008c858f" id="r_aa8cd95c962154cf55fb4b9d5008c858f"><td class="memItemLeft" align="right" valign="top"><a id="aa8cd95c962154cf55fb4b9d5008c858f" name="aa8cd95c962154cf55fb4b9d5008c858f"></a> +#define&#160;</td><td class="memItemRight" valign="bottom"><b>neorv32_uart0_scan</b>(buffer, max_size, echo)&#160;&#160;&#160;<a class="el" href="neorv32__uart_8c.html#ac429964878bd6deab61d9ed8659bca75">neorv32_uart_scan</a>(<a class="el" href="#a4c880a6b27e46f459e750425258b1bdb">NEORV32_UART0</a>, buffer, max_size, echo)</td></tr> +<tr class="separator:aa8cd95c962154cf55fb4b9d5008c858f"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a969f991e166e72a32aaee174ddef5962" id="r_a969f991e166e72a32aaee174ddef5962"><td class="memItemLeft" align="right" valign="top"><a id="a969f991e166e72a32aaee174ddef5962" name="a969f991e166e72a32aaee174ddef5962"></a> +#define&#160;</td><td class="memItemRight" valign="bottom"><b>neorv32_uart1_available</b>()&#160;&#160;&#160;<a class="el" href="neorv32__uart_8c.html#abef6415b0391dc055713404312196682">neorv32_uart_available</a>(<a class="el" href="#aa2a9ded4523f001bf69935c80247fa2d">NEORV32_UART1</a>)</td></tr> +<tr class="separator:a969f991e166e72a32aaee174ddef5962"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a8a00c086c47e0cffbc586155228060df" id="r_a8a00c086c47e0cffbc586155228060df"><td class="memItemLeft" align="right" valign="top"><a id="a8a00c086c47e0cffbc586155228060df" name="a8a00c086c47e0cffbc586155228060df"></a> +#define&#160;</td><td class="memItemRight" valign="bottom"><b>neorv32_uart1_get_rx_fifo_depth</b>()&#160;&#160;&#160;<a class="el" href="neorv32__uart_8c.html#af85fb929c912d3edef3d86ffa833982a">neorv32_uart_get_rx_fifo_depth</a>(<a class="el" href="#aa2a9ded4523f001bf69935c80247fa2d">NEORV32_UART1</a>)</td></tr> +<tr class="separator:a8a00c086c47e0cffbc586155228060df"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a27f16aaf0b15f5417c335804cfebbe54" id="r_a27f16aaf0b15f5417c335804cfebbe54"><td class="memItemLeft" align="right" valign="top"><a id="a27f16aaf0b15f5417c335804cfebbe54" name="a27f16aaf0b15f5417c335804cfebbe54"></a> +#define&#160;</td><td class="memItemRight" valign="bottom"><b>neorv32_uart1_get_tx_fifo_depth</b>()&#160;&#160;&#160;<a class="el" href="neorv32__uart_8c.html#a031e3e27c8783c299623468020a22b0e">neorv32_uart_get_tx_fifo_depth</a>(<a class="el" href="#aa2a9ded4523f001bf69935c80247fa2d">NEORV32_UART1</a>)</td></tr> +<tr class="separator:a27f16aaf0b15f5417c335804cfebbe54"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a5d94cc37807bdac20fcd782df138d480" id="r_a5d94cc37807bdac20fcd782df138d480"><td class="memItemLeft" align="right" valign="top"><a id="a5d94cc37807bdac20fcd782df138d480" name="a5d94cc37807bdac20fcd782df138d480"></a> +#define&#160;</td><td class="memItemRight" valign="bottom"><b>neorv32_uart1_setup</b>(baudrate, irq_mask)&#160;&#160;&#160;<a class="el" href="neorv32__uart_8c.html#a9cdec36f2723c5373664022d1b68b841">neorv32_uart_setup</a>(<a class="el" href="#aa2a9ded4523f001bf69935c80247fa2d">NEORV32_UART1</a>, baudrate, irq_mask)</td></tr> +<tr class="separator:a5d94cc37807bdac20fcd782df138d480"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a244073e58d04a364446f50e4708f3b36" id="r_a244073e58d04a364446f50e4708f3b36"><td class="memItemLeft" align="right" valign="top"><a id="a244073e58d04a364446f50e4708f3b36" name="a244073e58d04a364446f50e4708f3b36"></a> +#define&#160;</td><td class="memItemRight" valign="bottom"><b>neorv32_uart1_disable</b>()&#160;&#160;&#160;<a class="el" href="neorv32__uart_8c.html#ae18804ccd29ec2fd1cc06e9ce985b704">neorv32_uart_disable</a>(<a class="el" href="#aa2a9ded4523f001bf69935c80247fa2d">NEORV32_UART1</a>)</td></tr> +<tr class="separator:a244073e58d04a364446f50e4708f3b36"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ad36be396ae9e9ea21cf4a5f3247d7a8d" id="r_ad36be396ae9e9ea21cf4a5f3247d7a8d"><td class="memItemLeft" align="right" valign="top"><a id="ad36be396ae9e9ea21cf4a5f3247d7a8d" name="ad36be396ae9e9ea21cf4a5f3247d7a8d"></a> +#define&#160;</td><td class="memItemRight" valign="bottom"><b>neorv32_uart1_enable</b>()&#160;&#160;&#160;<a class="el" href="neorv32__uart_8c.html#afa0533e81d53057c36f4997a2dbbe2bc">neorv32_uart_enable</a>(<a class="el" href="#aa2a9ded4523f001bf69935c80247fa2d">NEORV32_UART1</a>)</td></tr> +<tr class="separator:ad36be396ae9e9ea21cf4a5f3247d7a8d"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a49c5158b6fa31f1c59660ed8744f2a3a" id="r_a49c5158b6fa31f1c59660ed8744f2a3a"><td class="memItemLeft" align="right" valign="top"><a id="a49c5158b6fa31f1c59660ed8744f2a3a" name="a49c5158b6fa31f1c59660ed8744f2a3a"></a> +#define&#160;</td><td class="memItemRight" valign="bottom"><b>neorv32_uart1_rtscts_disable</b>()&#160;&#160;&#160;<a class="el" href="neorv32__uart_8c.html#a7b2f924ef4554b1fa90433c38d97558d">neorv32_uart_rtscts_disable</a>(<a class="el" href="#aa2a9ded4523f001bf69935c80247fa2d">NEORV32_UART1</a>)</td></tr> +<tr class="separator:a49c5158b6fa31f1c59660ed8744f2a3a"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a64979d4d47678ca3e81a3b1d2eab52e7" id="r_a64979d4d47678ca3e81a3b1d2eab52e7"><td class="memItemLeft" align="right" valign="top"><a id="a64979d4d47678ca3e81a3b1d2eab52e7" name="a64979d4d47678ca3e81a3b1d2eab52e7"></a> +#define&#160;</td><td class="memItemRight" valign="bottom"><b>neorv32_uart1_rtscts_enable</b>()&#160;&#160;&#160;<a class="el" href="neorv32__uart_8c.html#a734b610f4cd1b474d7763f9700a715ec">neorv32_uart_rtscts_enable</a>(<a class="el" href="#aa2a9ded4523f001bf69935c80247fa2d">NEORV32_UART1</a>)</td></tr> +<tr class="separator:a64979d4d47678ca3e81a3b1d2eab52e7"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:acb41a23b9a1cbc4032d89455461c32be" id="r_acb41a23b9a1cbc4032d89455461c32be"><td class="memItemLeft" align="right" valign="top"><a id="acb41a23b9a1cbc4032d89455461c32be" name="acb41a23b9a1cbc4032d89455461c32be"></a> +#define&#160;</td><td class="memItemRight" valign="bottom"><b>neorv32_uart1_putc</b>(c)&#160;&#160;&#160;<a class="el" href="neorv32__uart_8c.html#a9bc7bb94a50b74e1145b78eec6094129">neorv32_uart_putc</a>(<a class="el" href="#aa2a9ded4523f001bf69935c80247fa2d">NEORV32_UART1</a>, c)</td></tr> +<tr class="separator:acb41a23b9a1cbc4032d89455461c32be"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a43be76025c2b90c3868315eacb0ee865" id="r_a43be76025c2b90c3868315eacb0ee865"><td class="memItemLeft" align="right" valign="top"><a id="a43be76025c2b90c3868315eacb0ee865" name="a43be76025c2b90c3868315eacb0ee865"></a> +#define&#160;</td><td class="memItemRight" valign="bottom"><b>neorv32_uart1_rx_clear</b>()&#160;&#160;&#160;<a class="el" href="neorv32__uart_8c.html#afe0de59c14faff1e0c890d5465be25f0">neorv32_uart_rx_clear</a>(<a class="el" href="#aa2a9ded4523f001bf69935c80247fa2d">NEORV32_UART1</a>)</td></tr> +<tr class="separator:a43be76025c2b90c3868315eacb0ee865"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a4705c6caea4b5064f51d37b40a156080" id="r_a4705c6caea4b5064f51d37b40a156080"><td class="memItemLeft" align="right" valign="top"><a id="a4705c6caea4b5064f51d37b40a156080" name="a4705c6caea4b5064f51d37b40a156080"></a> +#define&#160;</td><td class="memItemRight" valign="bottom"><b>neorv32_uart1_tx_clear</b>()&#160;&#160;&#160;<a class="el" href="neorv32__uart_8c.html#a27971954262a2fd1f21d3bf1ba27e87c">neorv32_uart_tx_clear</a>(<a class="el" href="#aa2a9ded4523f001bf69935c80247fa2d">NEORV32_UART1</a>)</td></tr> +<tr class="separator:a4705c6caea4b5064f51d37b40a156080"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a4fbbc6737f0d5e44eb775f5f6d724b02" id="r_a4fbbc6737f0d5e44eb775f5f6d724b02"><td class="memItemLeft" align="right" valign="top"><a id="a4fbbc6737f0d5e44eb775f5f6d724b02" name="a4fbbc6737f0d5e44eb775f5f6d724b02"></a> +#define&#160;</td><td class="memItemRight" valign="bottom"><b>neorv32_uart1_tx_busy</b>()&#160;&#160;&#160;<a class="el" href="neorv32__uart_8c.html#aa7bef48a58e044c246b8c4ad32864502">neorv32_uart_tx_busy</a>(<a class="el" href="#aa2a9ded4523f001bf69935c80247fa2d">NEORV32_UART1</a>)</td></tr> +<tr class="separator:a4fbbc6737f0d5e44eb775f5f6d724b02"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a1d8a289bcd2d4c33769dcc670678a573" id="r_a1d8a289bcd2d4c33769dcc670678a573"><td class="memItemLeft" align="right" valign="top"><a id="a1d8a289bcd2d4c33769dcc670678a573" name="a1d8a289bcd2d4c33769dcc670678a573"></a> +#define&#160;</td><td class="memItemRight" valign="bottom"><b>neorv32_uart1_getc</b>()&#160;&#160;&#160;<a class="el" href="neorv32__uart_8c.html#a2efd432f63b8d36d44263d0b1f39a6dc">neorv32_uart_getc</a>(<a class="el" href="#aa2a9ded4523f001bf69935c80247fa2d">NEORV32_UART1</a>)</td></tr> +<tr class="separator:a1d8a289bcd2d4c33769dcc670678a573"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a8b862c864010a574b856a7f5d3f6020b" id="r_a8b862c864010a574b856a7f5d3f6020b"><td class="memItemLeft" align="right" valign="top"><a id="a8b862c864010a574b856a7f5d3f6020b" name="a8b862c864010a574b856a7f5d3f6020b"></a> +#define&#160;</td><td class="memItemRight" valign="bottom"><b>neorv32_uart1_char_received</b>()&#160;&#160;&#160;<a class="el" href="neorv32__uart_8c.html#adedb0e07efb232717534017167a5be98">neorv32_uart_char_received</a>(<a class="el" href="#aa2a9ded4523f001bf69935c80247fa2d">NEORV32_UART1</a>)</td></tr> +<tr class="separator:a8b862c864010a574b856a7f5d3f6020b"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a25006186655175f0bbfe739750ebcec6" id="r_a25006186655175f0bbfe739750ebcec6"><td class="memItemLeft" align="right" valign="top"><a id="a25006186655175f0bbfe739750ebcec6" name="a25006186655175f0bbfe739750ebcec6"></a> +#define&#160;</td><td class="memItemRight" valign="bottom"><b>neorv32_uart1_char_received_get</b>()&#160;&#160;&#160;<a class="el" href="neorv32__uart_8c.html#aa490df3a9bb2aa3215fa6fad34ffe7d1">neorv32_uart_char_received_get</a>(<a class="el" href="#aa2a9ded4523f001bf69935c80247fa2d">NEORV32_UART1</a>)</td></tr> +<tr class="separator:a25006186655175f0bbfe739750ebcec6"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aa44dc625701ebbffe94508aa2e23dedf" id="r_aa44dc625701ebbffe94508aa2e23dedf"><td class="memItemLeft" align="right" valign="top"><a id="aa44dc625701ebbffe94508aa2e23dedf" name="aa44dc625701ebbffe94508aa2e23dedf"></a> +#define&#160;</td><td class="memItemRight" valign="bottom"><b>neorv32_uart1_puts</b>(s)&#160;&#160;&#160;<a class="el" href="neorv32__uart_8c.html#a45a07d5e71677162baaa1025759c67a2">neorv32_uart_puts</a>(<a class="el" href="#aa2a9ded4523f001bf69935c80247fa2d">NEORV32_UART1</a>, s)</td></tr> +<tr class="separator:aa44dc625701ebbffe94508aa2e23dedf"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a5992006547f020a7ba5ab914266358c6" id="r_a5992006547f020a7ba5ab914266358c6"><td class="memItemLeft" align="right" valign="top"><a id="a5992006547f020a7ba5ab914266358c6" name="a5992006547f020a7ba5ab914266358c6"></a> +#define&#160;</td><td class="memItemRight" valign="bottom"><b>neorv32_uart1_printf</b>(...)&#160;&#160;&#160;<a class="el" href="neorv32__uart_8c.html#ab8c1f9f451def9126ab2749d7bbe50d9">neorv32_uart_printf</a>(<a class="el" href="#aa2a9ded4523f001bf69935c80247fa2d">NEORV32_UART1</a>, __VA_ARGS__)</td></tr> +<tr class="separator:a5992006547f020a7ba5ab914266358c6"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a22a000e915c62c5d7da0af8ca4922710" id="r_a22a000e915c62c5d7da0af8ca4922710"><td class="memItemLeft" align="right" valign="top"><a id="a22a000e915c62c5d7da0af8ca4922710" name="a22a000e915c62c5d7da0af8ca4922710"></a> +#define&#160;</td><td class="memItemRight" valign="bottom"><b>neorv32_uart1_scan</b>(buffer, max_size, echo)&#160;&#160;&#160;<a class="el" href="neorv32__uart_8c.html#ac429964878bd6deab61d9ed8659bca75">neorv32_uart_scan</a>(<a class="el" href="#aa2a9ded4523f001bf69935c80247fa2d">NEORV32_UART1</a>, buffer, max_size, echo)</td></tr> +<tr class="separator:a22a000e915c62c5d7da0af8ca4922710"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="func-members" name="func-members"></a> +Functions</h2></td></tr> +<tr><td colspan="2"><div class="groupHeader">Prototypes</div></td></tr> +<tr class="memitem:abef6415b0391dc055713404312196682" id="r_abef6415b0391dc055713404312196682"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#abef6415b0391dc055713404312196682">neorv32_uart_available</a> (<a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a> *UARTx)</td></tr> +<tr class="separator:abef6415b0391dc055713404312196682"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:af85fb929c912d3edef3d86ffa833982a" id="r_af85fb929c912d3edef3d86ffa833982a"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#af85fb929c912d3edef3d86ffa833982a">neorv32_uart_get_rx_fifo_depth</a> (<a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a> *UARTx)</td></tr> +<tr class="separator:af85fb929c912d3edef3d86ffa833982a"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a031e3e27c8783c299623468020a22b0e" id="r_a031e3e27c8783c299623468020a22b0e"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a031e3e27c8783c299623468020a22b0e">neorv32_uart_get_tx_fifo_depth</a> (<a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a> *UARTx)</td></tr> +<tr class="separator:a031e3e27c8783c299623468020a22b0e"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a9cdec36f2723c5373664022d1b68b841" id="r_a9cdec36f2723c5373664022d1b68b841"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a9cdec36f2723c5373664022d1b68b841">neorv32_uart_setup</a> (<a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a> *UARTx, uint32_t baudrate, uint32_t irq_mask)</td></tr> +<tr class="separator:a9cdec36f2723c5373664022d1b68b841"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:afa0533e81d53057c36f4997a2dbbe2bc" id="r_afa0533e81d53057c36f4997a2dbbe2bc"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#afa0533e81d53057c36f4997a2dbbe2bc">neorv32_uart_enable</a> (<a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a> *UARTx)</td></tr> +<tr class="separator:afa0533e81d53057c36f4997a2dbbe2bc"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ae18804ccd29ec2fd1cc06e9ce985b704" id="r_ae18804ccd29ec2fd1cc06e9ce985b704"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ae18804ccd29ec2fd1cc06e9ce985b704">neorv32_uart_disable</a> (<a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a> *UARTx)</td></tr> +<tr class="separator:ae18804ccd29ec2fd1cc06e9ce985b704"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a734b610f4cd1b474d7763f9700a715ec" id="r_a734b610f4cd1b474d7763f9700a715ec"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a734b610f4cd1b474d7763f9700a715ec">neorv32_uart_rtscts_enable</a> (<a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a> *UARTx)</td></tr> +<tr class="separator:a734b610f4cd1b474d7763f9700a715ec"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a7b2f924ef4554b1fa90433c38d97558d" id="r_a7b2f924ef4554b1fa90433c38d97558d"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a7b2f924ef4554b1fa90433c38d97558d">neorv32_uart_rtscts_disable</a> (<a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a> *UARTx)</td></tr> +<tr class="separator:a7b2f924ef4554b1fa90433c38d97558d"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a9bc7bb94a50b74e1145b78eec6094129" id="r_a9bc7bb94a50b74e1145b78eec6094129"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a9bc7bb94a50b74e1145b78eec6094129">neorv32_uart_putc</a> (<a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a> *UARTx, char c)</td></tr> +<tr class="separator:a9bc7bb94a50b74e1145b78eec6094129"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:afe0de59c14faff1e0c890d5465be25f0" id="r_afe0de59c14faff1e0c890d5465be25f0"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#afe0de59c14faff1e0c890d5465be25f0">neorv32_uart_rx_clear</a> (<a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a> *UARTx)</td></tr> +<tr class="separator:afe0de59c14faff1e0c890d5465be25f0"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a27971954262a2fd1f21d3bf1ba27e87c" id="r_a27971954262a2fd1f21d3bf1ba27e87c"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a27971954262a2fd1f21d3bf1ba27e87c">neorv32_uart_tx_clear</a> (<a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a> *UARTx)</td></tr> +<tr class="separator:a27971954262a2fd1f21d3bf1ba27e87c"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aa7bef48a58e044c246b8c4ad32864502" id="r_aa7bef48a58e044c246b8c4ad32864502"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aa7bef48a58e044c246b8c4ad32864502">neorv32_uart_tx_busy</a> (<a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a> *UARTx)</td></tr> +<tr class="separator:aa7bef48a58e044c246b8c4ad32864502"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a2efd432f63b8d36d44263d0b1f39a6dc" id="r_a2efd432f63b8d36d44263d0b1f39a6dc"><td class="memItemLeft" align="right" valign="top">char&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a2efd432f63b8d36d44263d0b1f39a6dc">neorv32_uart_getc</a> (<a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a> *UARTx)</td></tr> +<tr class="separator:a2efd432f63b8d36d44263d0b1f39a6dc"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:adedb0e07efb232717534017167a5be98" id="r_adedb0e07efb232717534017167a5be98"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#adedb0e07efb232717534017167a5be98">neorv32_uart_char_received</a> (<a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a> *UARTx)</td></tr> +<tr class="separator:adedb0e07efb232717534017167a5be98"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aa490df3a9bb2aa3215fa6fad34ffe7d1" id="r_aa490df3a9bb2aa3215fa6fad34ffe7d1"><td class="memItemLeft" align="right" valign="top">char&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aa490df3a9bb2aa3215fa6fad34ffe7d1">neorv32_uart_char_received_get</a> (<a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a> *UARTx)</td></tr> +<tr class="separator:aa490df3a9bb2aa3215fa6fad34ffe7d1"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a45a07d5e71677162baaa1025759c67a2" id="r_a45a07d5e71677162baaa1025759c67a2"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a45a07d5e71677162baaa1025759c67a2">neorv32_uart_puts</a> (<a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a> *UARTx, const char *s)</td></tr> +<tr class="separator:a45a07d5e71677162baaa1025759c67a2"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a8714cdb1c04d94bec322c6215ea10238" id="r_a8714cdb1c04d94bec322c6215ea10238"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a8714cdb1c04d94bec322c6215ea10238">neorv32_uart_vprintf</a> (<a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a> *UARTx, const char *format, va_list args)</td></tr> +<tr class="separator:a8714cdb1c04d94bec322c6215ea10238"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ab8c1f9f451def9126ab2749d7bbe50d9" id="r_ab8c1f9f451def9126ab2749d7bbe50d9"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ab8c1f9f451def9126ab2749d7bbe50d9">neorv32_uart_printf</a> (<a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a> *UARTx, const char *format,...)</td></tr> +<tr class="separator:ab8c1f9f451def9126ab2749d7bbe50d9"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ac429964878bd6deab61d9ed8659bca75" id="r_ac429964878bd6deab61d9ed8659bca75"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ac429964878bd6deab61d9ed8659bca75">neorv32_uart_scan</a> (<a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a> *UARTx, char *buffer, int max_size, int echo)</td></tr> +<tr class="separator:ac429964878bd6deab61d9ed8659bca75"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader">IO Device: Primary/Secondary Universal Asynchronous Receiver and Transmitter (UART0 / UART1)</h2></td></tr> +<tr class="memitem:a4c880a6b27e46f459e750425258b1bdb" id="r_a4c880a6b27e46f459e750425258b1bdb"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a4c880a6b27e46f459e750425258b1bdb">NEORV32_UART0</a>&#160;&#160;&#160;((<a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a>*) (<a class="el" href="neorv32_8h.html#a000b37f710043fe21e49b2fdbc039d94">NEORV32_UART0_BASE</a>))</td></tr> +<tr class="separator:a4c880a6b27e46f459e750425258b1bdb"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aa2a9ded4523f001bf69935c80247fa2d" id="r_aa2a9ded4523f001bf69935c80247fa2d"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aa2a9ded4523f001bf69935c80247fa2d">NEORV32_UART1</a>&#160;&#160;&#160;((<a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a>*) (<a class="el" href="neorv32_8h.html#a26a1defe18ce222b8b4ed1c760344700">NEORV32_UART1_BASE</a>))</td></tr> +<tr class="separator:aa2a9ded4523f001bf69935c80247fa2d"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ad9f75f453beca1619344bb4213352afc" id="r_ad9f75f453beca1619344bb4213352afc"><td class="memItemLeft" align="right" valign="top">enum &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ad9f75f453beca1619344bb4213352afc">NEORV32_UART_CTRL_enum</a> { <br /> +&#160;&#160;<a class="el" href="#ad9f75f453beca1619344bb4213352afca38f6c0e5991f8f80159a388c1080f7c2">UART_CTRL_EN</a> = 0 +, <a class="el" href="#ad9f75f453beca1619344bb4213352afca42ed376220259ab22c6f837d08273ef1">UART_CTRL_SIM_MODE</a> = 1 +, <a class="el" href="#ad9f75f453beca1619344bb4213352afcacab78fcd440167c5a2c0f5d300c8f07c">UART_CTRL_HWFC_EN</a> = 2 +, <a class="el" href="#ad9f75f453beca1619344bb4213352afca1ddbca448bb30c77c42499fff1312183">UART_CTRL_PRSC0</a> = 3 +, <br /> +&#160;&#160;<a class="el" href="#ad9f75f453beca1619344bb4213352afca9c1d8e8763a653339210ff4e6e3067d2">UART_CTRL_PRSC1</a> = 4 +, <a class="el" href="#ad9f75f453beca1619344bb4213352afca8afd60e4bd3854fab623b91fa4f33f70">UART_CTRL_PRSC2</a> = 5 +, <a class="el" href="#ad9f75f453beca1619344bb4213352afcad38432e7e050276d4667daf92c1e3fd5">UART_CTRL_BAUD0</a> = 6 +, <a class="el" href="#ad9f75f453beca1619344bb4213352afca1e702002402897eca82bf398504bc439">UART_CTRL_BAUD1</a> = 7 +, <br /> +&#160;&#160;<a class="el" href="#ad9f75f453beca1619344bb4213352afca36266026e11f22aca1584bd81cd38cd6">UART_CTRL_BAUD2</a> = 8 +, <a class="el" href="#ad9f75f453beca1619344bb4213352afca58190cd41c2ce69512bea10740d35276">UART_CTRL_BAUD3</a> = 9 +, <a class="el" href="#ad9f75f453beca1619344bb4213352afca81ea805f01b93a59664823b940c7a424">UART_CTRL_BAUD4</a> = 10 +, <a class="el" href="#ad9f75f453beca1619344bb4213352afca5da1d6007af0265fe48ace8469e07833">UART_CTRL_BAUD5</a> = 11 +, <br /> +&#160;&#160;<a class="el" href="#ad9f75f453beca1619344bb4213352afca9ac3c1e23d684cb2f67060d6ebe1fa63">UART_CTRL_BAUD6</a> = 12 +, <a class="el" href="#ad9f75f453beca1619344bb4213352afca9c12648f7f058f444db434cd8a8d854e">UART_CTRL_BAUD7</a> = 13 +, <a class="el" href="#ad9f75f453beca1619344bb4213352afca09c311eb1f6b38500e6fcbb6ad9dd9ff">UART_CTRL_BAUD8</a> = 14 +, <a class="el" href="#ad9f75f453beca1619344bb4213352afca697321bddeaa2cac1ea034c418be540e">UART_CTRL_BAUD9</a> = 15 +, <br /> +&#160;&#160;<a class="el" href="#ad9f75f453beca1619344bb4213352afca2015dd85e361aa0476e847953b62baff">UART_CTRL_RX_NEMPTY</a> = 16 +, <a class="el" href="#ad9f75f453beca1619344bb4213352afca3fc934d0ce6b36e3e131c6682db22247">UART_CTRL_RX_HALF</a> = 17 +, <a class="el" href="#ad9f75f453beca1619344bb4213352afca47c44fa21e51401621c28019025c1166">UART_CTRL_RX_FULL</a> = 18 +, <a class="el" href="#ad9f75f453beca1619344bb4213352afcac5c044233b6c4162cf862f3d9831ef46">UART_CTRL_TX_EMPTY</a> = 19 +, <br /> +&#160;&#160;<a class="el" href="#ad9f75f453beca1619344bb4213352afca5b0e40ab30bdb198f496d09e89d2d0d9">UART_CTRL_TX_NHALF</a> = 20 +, <a class="el" href="#ad9f75f453beca1619344bb4213352afca36b4195e5d1f12e1fd1a0d30cad0e411">UART_CTRL_TX_FULL</a> = 21 +, <a class="el" href="#ad9f75f453beca1619344bb4213352afca569ea830518914c5330fa14680b02851">UART_CTRL_IRQ_RX_NEMPTY</a> = 22 +, <a class="el" href="#ad9f75f453beca1619344bb4213352afcaa219ea3ed5b21f5023bbc5ffa5c5f175">UART_CTRL_IRQ_RX_HALF</a> = 23 +, <br /> +&#160;&#160;<a class="el" href="#ad9f75f453beca1619344bb4213352afcae5f01868b170d71a5f3064023c96a82a">UART_CTRL_IRQ_RX_FULL</a> = 24 +, <a class="el" href="#ad9f75f453beca1619344bb4213352afca15b9fca73877aad446a8cd338e228e2c">UART_CTRL_IRQ_TX_EMPTY</a> = 25 +, <a class="el" href="#ad9f75f453beca1619344bb4213352afca726b73ef9c44ccc1a45a4230a8bda9d1">UART_CTRL_IRQ_TX_NHALF</a> = 26 +, <a class="el" href="#ad9f75f453beca1619344bb4213352afcaefbef37247d88a7e38e1c53b8a33ed33">UART_CTRL_RX_CLR</a> = 28 +, <br /> +&#160;&#160;<a class="el" href="#ad9f75f453beca1619344bb4213352afca408412a32673cc7f6ea70682e3e61431">UART_CTRL_TX_CLR</a> = 29 +, <a class="el" href="#ad9f75f453beca1619344bb4213352afca81a52e0b81018f2cf43e64d74caba632">UART_CTRL_RX_OVER</a> = 30 +, <a class="el" href="#ad9f75f453beca1619344bb4213352afca0eb636d8b7961d7073c5c7341b5bbe25">UART_CTRL_TX_BUSY</a> = 31 +<br /> + }</td></tr> +<tr class="separator:ad9f75f453beca1619344bb4213352afc"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:adcf35350a9ea18a59c32c35f528643f2" id="r_adcf35350a9ea18a59c32c35f528643f2"><td class="memItemLeft" align="right" valign="top">enum &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#adcf35350a9ea18a59c32c35f528643f2">NEORV32_UART_DATA_enum</a> { <br /> +&#160;&#160;<a class="el" href="#adcf35350a9ea18a59c32c35f528643f2ae70e9f6cd69af724932e79ea7e7f7195">UART_DATA_RTX_LSB</a> = 0 +, <a class="el" href="#adcf35350a9ea18a59c32c35f528643f2a19926d013ca202645d38f2c704782ebb">UART_DATA_RTX_MSB</a> = 7 +, <a class="el" href="#adcf35350a9ea18a59c32c35f528643f2a43b296e86d1f2ec7400d57655c3180ef">UART_DATA_RX_FIFO_SIZE_LSB</a> = 8 +, <a class="el" href="#adcf35350a9ea18a59c32c35f528643f2a81a82ac0dc5c8c8d7af21553288e3225">UART_DATA_RX_FIFO_SIZE_MSB</a> = 11 +, <br /> +&#160;&#160;<a class="el" href="#adcf35350a9ea18a59c32c35f528643f2a6d718ad0bb82a5cb053c117cd2d6ca8e">UART_DATA_TX_FIFO_SIZE_LSB</a> = 12 +, <a class="el" href="#adcf35350a9ea18a59c32c35f528643f2ada92cbbe278e3e0592eba58c97699529">UART_DATA_TX_FIFO_SIZE_MSB</a> = 15 +<br /> + }</td></tr> +<tr class="separator:adcf35350a9ea18a59c32c35f528643f2"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>Universal asynchronous receiver/transmitter (UART0/UART1) HW driver header file. </p> +<dl class="section see"><dt>See also</dt><dd><a href="https://stnolting.github.io/neorv32/sw/files.html">https://stnolting.github.io/neorv32/sw/files.html</a> </dd></dl> +</div><h2 class="groupheader">Macro Definition Documentation</h2> +<a id="a4c880a6b27e46f459e750425258b1bdb" name="a4c880a6b27e46f459e750425258b1bdb"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a4c880a6b27e46f459e750425258b1bdb">&#9670;&#160;</a></span>NEORV32_UART0</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define NEORV32_UART0&#160;&#160;&#160;((<a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a>*) (<a class="el" href="neorv32_8h.html#a000b37f710043fe21e49b2fdbc039d94">NEORV32_UART0_BASE</a>))</td> + </tr> + </table> +</div><div class="memdoc"> +<p>UART0 module hardware access (<a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a>) </p> + +</div> +</div> +<a id="aa2a9ded4523f001bf69935c80247fa2d" name="aa2a9ded4523f001bf69935c80247fa2d"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aa2a9ded4523f001bf69935c80247fa2d">&#9670;&#160;</a></span>NEORV32_UART1</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define NEORV32_UART1&#160;&#160;&#160;((<a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a>*) (<a class="el" href="neorv32_8h.html#a26a1defe18ce222b8b4ed1c760344700">NEORV32_UART1_BASE</a>))</td> + </tr> + </table> +</div><div class="memdoc"> +<p>UART1 module hardware access (<a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a>) </p> + +</div> +</div> +<h2 class="groupheader">Enumeration Type Documentation</h2> +<a id="ad9f75f453beca1619344bb4213352afc" name="ad9f75f453beca1619344bb4213352afc"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ad9f75f453beca1619344bb4213352afc">&#9670;&#160;</a></span>NEORV32_UART_CTRL_enum</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">enum <a class="el" href="#ad9f75f453beca1619344bb4213352afc">NEORV32_UART_CTRL_enum</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>UART control register bits </p> +<table class="fieldtable"> +<tr><th colspan="2">Enumerator</th></tr><tr><td class="fieldname"><a id="ad9f75f453beca1619344bb4213352afca38f6c0e5991f8f80159a388c1080f7c2" name="ad9f75f453beca1619344bb4213352afca38f6c0e5991f8f80159a388c1080f7c2"></a>UART_CTRL_EN&#160;</td><td class="fielddoc"><p>UART control register(0) (r/w): UART global enable </p> +</td></tr> +<tr><td class="fieldname"><a id="ad9f75f453beca1619344bb4213352afca42ed376220259ab22c6f837d08273ef1" name="ad9f75f453beca1619344bb4213352afca42ed376220259ab22c6f837d08273ef1"></a>UART_CTRL_SIM_MODE&#160;</td><td class="fielddoc"><p>UART control register(1) (r/w): Simulation output override enable </p> +</td></tr> +<tr><td class="fieldname"><a id="ad9f75f453beca1619344bb4213352afcacab78fcd440167c5a2c0f5d300c8f07c" name="ad9f75f453beca1619344bb4213352afcacab78fcd440167c5a2c0f5d300c8f07c"></a>UART_CTRL_HWFC_EN&#160;</td><td class="fielddoc"><p>UART control register(2) (r/w): Enable RTS/CTS hardware flow-control </p> +</td></tr> +<tr><td class="fieldname"><a id="ad9f75f453beca1619344bb4213352afca1ddbca448bb30c77c42499fff1312183" name="ad9f75f453beca1619344bb4213352afca1ddbca448bb30c77c42499fff1312183"></a>UART_CTRL_PRSC0&#160;</td><td class="fielddoc"><p>UART control register(3) (r/w): clock prescaler select bit 0 </p> +</td></tr> +<tr><td class="fieldname"><a id="ad9f75f453beca1619344bb4213352afca9c1d8e8763a653339210ff4e6e3067d2" name="ad9f75f453beca1619344bb4213352afca9c1d8e8763a653339210ff4e6e3067d2"></a>UART_CTRL_PRSC1&#160;</td><td class="fielddoc"><p>UART control register(4) (r/w): clock prescaler select bit 1 </p> +</td></tr> +<tr><td class="fieldname"><a id="ad9f75f453beca1619344bb4213352afca8afd60e4bd3854fab623b91fa4f33f70" name="ad9f75f453beca1619344bb4213352afca8afd60e4bd3854fab623b91fa4f33f70"></a>UART_CTRL_PRSC2&#160;</td><td class="fielddoc"><p>UART control register(5) (r/w): clock prescaler select bit 2 </p> +</td></tr> +<tr><td class="fieldname"><a id="ad9f75f453beca1619344bb4213352afcad38432e7e050276d4667daf92c1e3fd5" name="ad9f75f453beca1619344bb4213352afcad38432e7e050276d4667daf92c1e3fd5"></a>UART_CTRL_BAUD0&#160;</td><td class="fielddoc"><p>UART control register(6) (r/w): BAUD rate divisor, bit 0 </p> +</td></tr> +<tr><td class="fieldname"><a id="ad9f75f453beca1619344bb4213352afca1e702002402897eca82bf398504bc439" name="ad9f75f453beca1619344bb4213352afca1e702002402897eca82bf398504bc439"></a>UART_CTRL_BAUD1&#160;</td><td class="fielddoc"><p>UART control register(7) (r/w): BAUD rate divisor, bit 1 </p> +</td></tr> +<tr><td class="fieldname"><a id="ad9f75f453beca1619344bb4213352afca36266026e11f22aca1584bd81cd38cd6" name="ad9f75f453beca1619344bb4213352afca36266026e11f22aca1584bd81cd38cd6"></a>UART_CTRL_BAUD2&#160;</td><td class="fielddoc"><p>UART control register(8) (r/w): BAUD rate divisor, bit 2 </p> +</td></tr> +<tr><td class="fieldname"><a id="ad9f75f453beca1619344bb4213352afca58190cd41c2ce69512bea10740d35276" name="ad9f75f453beca1619344bb4213352afca58190cd41c2ce69512bea10740d35276"></a>UART_CTRL_BAUD3&#160;</td><td class="fielddoc"><p>UART control register(9) (r/w): BAUD rate divisor, bit 3 </p> +</td></tr> +<tr><td class="fieldname"><a id="ad9f75f453beca1619344bb4213352afca81ea805f01b93a59664823b940c7a424" name="ad9f75f453beca1619344bb4213352afca81ea805f01b93a59664823b940c7a424"></a>UART_CTRL_BAUD4&#160;</td><td class="fielddoc"><p>UART control register(10) (r/w): BAUD rate divisor, bit 4 </p> +</td></tr> +<tr><td class="fieldname"><a id="ad9f75f453beca1619344bb4213352afca5da1d6007af0265fe48ace8469e07833" name="ad9f75f453beca1619344bb4213352afca5da1d6007af0265fe48ace8469e07833"></a>UART_CTRL_BAUD5&#160;</td><td class="fielddoc"><p>UART control register(11) (r/w): BAUD rate divisor, bit 5 </p> +</td></tr> +<tr><td class="fieldname"><a id="ad9f75f453beca1619344bb4213352afca9ac3c1e23d684cb2f67060d6ebe1fa63" name="ad9f75f453beca1619344bb4213352afca9ac3c1e23d684cb2f67060d6ebe1fa63"></a>UART_CTRL_BAUD6&#160;</td><td class="fielddoc"><p>UART control register(12) (r/w): BAUD rate divisor, bit 6 </p> +</td></tr> +<tr><td class="fieldname"><a id="ad9f75f453beca1619344bb4213352afca9c12648f7f058f444db434cd8a8d854e" name="ad9f75f453beca1619344bb4213352afca9c12648f7f058f444db434cd8a8d854e"></a>UART_CTRL_BAUD7&#160;</td><td class="fielddoc"><p>UART control register(13) (r/w): BAUD rate divisor, bit 7 </p> +</td></tr> +<tr><td class="fieldname"><a id="ad9f75f453beca1619344bb4213352afca09c311eb1f6b38500e6fcbb6ad9dd9ff" name="ad9f75f453beca1619344bb4213352afca09c311eb1f6b38500e6fcbb6ad9dd9ff"></a>UART_CTRL_BAUD8&#160;</td><td class="fielddoc"><p>UART control register(14) (r/w): BAUD rate divisor, bit 8 </p> +</td></tr> +<tr><td class="fieldname"><a id="ad9f75f453beca1619344bb4213352afca697321bddeaa2cac1ea034c418be540e" name="ad9f75f453beca1619344bb4213352afca697321bddeaa2cac1ea034c418be540e"></a>UART_CTRL_BAUD9&#160;</td><td class="fielddoc"><p>UART control register(15) (r/w): BAUD rate divisor, bit 9 </p> +</td></tr> +<tr><td class="fieldname"><a id="ad9f75f453beca1619344bb4213352afca2015dd85e361aa0476e847953b62baff" name="ad9f75f453beca1619344bb4213352afca2015dd85e361aa0476e847953b62baff"></a>UART_CTRL_RX_NEMPTY&#160;</td><td class="fielddoc"><p>UART control register(16) (r/-): RX FIFO not empty </p> +</td></tr> +<tr><td class="fieldname"><a id="ad9f75f453beca1619344bb4213352afca3fc934d0ce6b36e3e131c6682db22247" name="ad9f75f453beca1619344bb4213352afca3fc934d0ce6b36e3e131c6682db22247"></a>UART_CTRL_RX_HALF&#160;</td><td class="fielddoc"><p>UART control register(17) (r/-): RX FIFO at least half-full </p> +</td></tr> +<tr><td class="fieldname"><a id="ad9f75f453beca1619344bb4213352afca47c44fa21e51401621c28019025c1166" name="ad9f75f453beca1619344bb4213352afca47c44fa21e51401621c28019025c1166"></a>UART_CTRL_RX_FULL&#160;</td><td class="fielddoc"><p>UART control register(18) (r/-): RX FIFO full </p> +</td></tr> +<tr><td class="fieldname"><a id="ad9f75f453beca1619344bb4213352afcac5c044233b6c4162cf862f3d9831ef46" name="ad9f75f453beca1619344bb4213352afcac5c044233b6c4162cf862f3d9831ef46"></a>UART_CTRL_TX_EMPTY&#160;</td><td class="fielddoc"><p>UART control register(19) (r/-): TX FIFO empty </p> +</td></tr> +<tr><td class="fieldname"><a id="ad9f75f453beca1619344bb4213352afca5b0e40ab30bdb198f496d09e89d2d0d9" name="ad9f75f453beca1619344bb4213352afca5b0e40ab30bdb198f496d09e89d2d0d9"></a>UART_CTRL_TX_NHALF&#160;</td><td class="fielddoc"><p>UART control register(20) (r/-): TX FIFO not at least half-full </p> +</td></tr> +<tr><td class="fieldname"><a id="ad9f75f453beca1619344bb4213352afca36b4195e5d1f12e1fd1a0d30cad0e411" name="ad9f75f453beca1619344bb4213352afca36b4195e5d1f12e1fd1a0d30cad0e411"></a>UART_CTRL_TX_FULL&#160;</td><td class="fielddoc"><p>UART control register(21) (r/-): TX FIFO full </p> +</td></tr> +<tr><td class="fieldname"><a id="ad9f75f453beca1619344bb4213352afca569ea830518914c5330fa14680b02851" name="ad9f75f453beca1619344bb4213352afca569ea830518914c5330fa14680b02851"></a>UART_CTRL_IRQ_RX_NEMPTY&#160;</td><td class="fielddoc"><p>UART control register(22) (r/w): Fire IRQ if RX FIFO not empty </p> +</td></tr> +<tr><td class="fieldname"><a id="ad9f75f453beca1619344bb4213352afcaa219ea3ed5b21f5023bbc5ffa5c5f175" name="ad9f75f453beca1619344bb4213352afcaa219ea3ed5b21f5023bbc5ffa5c5f175"></a>UART_CTRL_IRQ_RX_HALF&#160;</td><td class="fielddoc"><p>UART control register(23) (r/w): Fire IRQ if RX FIFO at least half-full </p> +</td></tr> +<tr><td class="fieldname"><a id="ad9f75f453beca1619344bb4213352afcae5f01868b170d71a5f3064023c96a82a" name="ad9f75f453beca1619344bb4213352afcae5f01868b170d71a5f3064023c96a82a"></a>UART_CTRL_IRQ_RX_FULL&#160;</td><td class="fielddoc"><p>UART control register(24) (r/w): Fire IRQ if RX FIFO full </p> +</td></tr> +<tr><td class="fieldname"><a id="ad9f75f453beca1619344bb4213352afca15b9fca73877aad446a8cd338e228e2c" name="ad9f75f453beca1619344bb4213352afca15b9fca73877aad446a8cd338e228e2c"></a>UART_CTRL_IRQ_TX_EMPTY&#160;</td><td class="fielddoc"><p>UART control register(25) (r/w): Fire IRQ if TX FIFO empty </p> +</td></tr> +<tr><td class="fieldname"><a id="ad9f75f453beca1619344bb4213352afca726b73ef9c44ccc1a45a4230a8bda9d1" name="ad9f75f453beca1619344bb4213352afca726b73ef9c44ccc1a45a4230a8bda9d1"></a>UART_CTRL_IRQ_TX_NHALF&#160;</td><td class="fielddoc"><p>UART control register(26) (r/w): Fire IRQ if TX FIFO not at least half-full </p> +</td></tr> +<tr><td class="fieldname"><a id="ad9f75f453beca1619344bb4213352afcaefbef37247d88a7e38e1c53b8a33ed33" name="ad9f75f453beca1619344bb4213352afcaefbef37247d88a7e38e1c53b8a33ed33"></a>UART_CTRL_RX_CLR&#160;</td><td class="fielddoc"><p>UART control register(28) (r/w): Clear RX FIFO, flag auto-clears </p> +</td></tr> +<tr><td class="fieldname"><a id="ad9f75f453beca1619344bb4213352afca408412a32673cc7f6ea70682e3e61431" name="ad9f75f453beca1619344bb4213352afca408412a32673cc7f6ea70682e3e61431"></a>UART_CTRL_TX_CLR&#160;</td><td class="fielddoc"><p>UART control register(29) (r/w): Clear TX FIFO, flag auto-clears </p> +</td></tr> +<tr><td class="fieldname"><a id="ad9f75f453beca1619344bb4213352afca81a52e0b81018f2cf43e64d74caba632" name="ad9f75f453beca1619344bb4213352afca81a52e0b81018f2cf43e64d74caba632"></a>UART_CTRL_RX_OVER&#160;</td><td class="fielddoc"><p>UART control register(30) (r/-): RX FIFO overflow </p> +</td></tr> +<tr><td class="fieldname"><a id="ad9f75f453beca1619344bb4213352afca0eb636d8b7961d7073c5c7341b5bbe25" name="ad9f75f453beca1619344bb4213352afca0eb636d8b7961d7073c5c7341b5bbe25"></a>UART_CTRL_TX_BUSY&#160;</td><td class="fielddoc"><p>UART control register(31) (r/-): Transmitter busy or TX FIFO not empty </p> +</td></tr> +</table> + +</div> +</div> +<a id="adcf35350a9ea18a59c32c35f528643f2" name="adcf35350a9ea18a59c32c35f528643f2"></a> +<h2 class="memtitle"><span class="permalink"><a href="#adcf35350a9ea18a59c32c35f528643f2">&#9670;&#160;</a></span>NEORV32_UART_DATA_enum</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">enum <a class="el" href="#adcf35350a9ea18a59c32c35f528643f2">NEORV32_UART_DATA_enum</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>UART data register bits </p> +<table class="fieldtable"> +<tr><th colspan="2">Enumerator</th></tr><tr><td class="fieldname"><a id="adcf35350a9ea18a59c32c35f528643f2ae70e9f6cd69af724932e79ea7e7f7195" name="adcf35350a9ea18a59c32c35f528643f2ae70e9f6cd69af724932e79ea7e7f7195"></a>UART_DATA_RTX_LSB&#160;</td><td class="fielddoc"><p>UART data register(0) (r/w): UART receive/transmit data, LSB </p> +</td></tr> +<tr><td class="fieldname"><a id="adcf35350a9ea18a59c32c35f528643f2a19926d013ca202645d38f2c704782ebb" name="adcf35350a9ea18a59c32c35f528643f2a19926d013ca202645d38f2c704782ebb"></a>UART_DATA_RTX_MSB&#160;</td><td class="fielddoc"><p>UART data register(7) (r/w): UART receive/transmit data, MSB </p> +</td></tr> +<tr><td class="fieldname"><a id="adcf35350a9ea18a59c32c35f528643f2a43b296e86d1f2ec7400d57655c3180ef" name="adcf35350a9ea18a59c32c35f528643f2a43b296e86d1f2ec7400d57655c3180ef"></a>UART_DATA_RX_FIFO_SIZE_LSB&#160;</td><td class="fielddoc"><p>UART data register(8) (r/-): log2(RX FIFO size), LSB </p> +</td></tr> +<tr><td class="fieldname"><a id="adcf35350a9ea18a59c32c35f528643f2a81a82ac0dc5c8c8d7af21553288e3225" name="adcf35350a9ea18a59c32c35f528643f2a81a82ac0dc5c8c8d7af21553288e3225"></a>UART_DATA_RX_FIFO_SIZE_MSB&#160;</td><td class="fielddoc"><p>UART data register(11) (r/-): log2(RX FIFO size), MSB </p> +</td></tr> +<tr><td class="fieldname"><a id="adcf35350a9ea18a59c32c35f528643f2a6d718ad0bb82a5cb053c117cd2d6ca8e" name="adcf35350a9ea18a59c32c35f528643f2a6d718ad0bb82a5cb053c117cd2d6ca8e"></a>UART_DATA_TX_FIFO_SIZE_LSB&#160;</td><td class="fielddoc"><p>UART data register(12) (r/-): log2(RX FIFO size), LSB </p> +</td></tr> +<tr><td class="fieldname"><a id="adcf35350a9ea18a59c32c35f528643f2ada92cbbe278e3e0592eba58c97699529" name="adcf35350a9ea18a59c32c35f528643f2ada92cbbe278e3e0592eba58c97699529"></a>UART_DATA_TX_FIFO_SIZE_MSB&#160;</td><td class="fielddoc"><p>UART data register(15) (r/-): log2(RX FIFO size), MSB </p> +</td></tr> +</table> + +</div> +</div> +<h2 class="groupheader">Function Documentation</h2> +<a id="abef6415b0391dc055713404312196682" name="abef6415b0391dc055713404312196682"></a> +<h2 class="memtitle"><span class="permalink"><a href="#abef6415b0391dc055713404312196682">&#9670;&#160;</a></span>neorv32_uart_available()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_uart_available </td> + <td>(</td> + <td class="paramtype"><a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a> *</td> <td class="paramname"><span class="paramname"><em>UARTx</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Check if UART unit was synthesized.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in,out]</td><td class="paramname">Hardware</td><td>handle to UART register struct, <a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a>. </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>0 if UART0/1 was not synthesized, 1 if UART0/1 is available. </dd></dl> + +</div> +</div> +<a id="adedb0e07efb232717534017167a5be98" name="adedb0e07efb232717534017167a5be98"></a> +<h2 class="memtitle"><span class="permalink"><a href="#adedb0e07efb232717534017167a5be98">&#9670;&#160;</a></span>neorv32_uart_char_received()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_uart_char_received </td> + <td>(</td> + <td class="paramtype"><a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a> *</td> <td class="paramname"><span class="paramname"><em>UARTx</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Check if UART has received a char.</p> +<dl class="section note"><dt>Note</dt><dd>This function is non-blocking. </dd> +<dd> +Use neorv32_uart_char_received_get(void) to get the char.</dd></dl> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in,out]</td><td class="paramname">UARTx</td><td>Hardware handle to UART register struct, <a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a>. </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>1 when a char has been received, 0 otherwise. </dd></dl> + +</div> +</div> +<a id="aa490df3a9bb2aa3215fa6fad34ffe7d1" name="aa490df3a9bb2aa3215fa6fad34ffe7d1"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aa490df3a9bb2aa3215fa6fad34ffe7d1">&#9670;&#160;</a></span>neorv32_uart_char_received_get()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">char neorv32_uart_char_received_get </td> + <td>(</td> + <td class="paramtype"><a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a> *</td> <td class="paramname"><span class="paramname"><em>UARTx</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Get a received char from UART.</p> +<dl class="section note"><dt>Note</dt><dd>This function is non-blocking. </dd> +<dd> +Should only be used in combination with neorv32_uart_char_received(void).</dd></dl> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in,out]</td><td class="paramname">UARTx</td><td>Hardware handle to UART register struct, <a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a>. </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Received char. </dd></dl> + +</div> +</div> +<a id="ae18804ccd29ec2fd1cc06e9ce985b704" name="ae18804ccd29ec2fd1cc06e9ce985b704"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ae18804ccd29ec2fd1cc06e9ce985b704">&#9670;&#160;</a></span>neorv32_uart_disable()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_uart_disable </td> + <td>(</td> + <td class="paramtype"><a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a> *</td> <td class="paramname"><span class="paramname"><em>UARTx</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Disable UART.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in,out]</td><td class="paramname">UARTx</td><td>Hardware handle to UART register struct, <a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a>. </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="afa0533e81d53057c36f4997a2dbbe2bc" name="afa0533e81d53057c36f4997a2dbbe2bc"></a> +<h2 class="memtitle"><span class="permalink"><a href="#afa0533e81d53057c36f4997a2dbbe2bc">&#9670;&#160;</a></span>neorv32_uart_enable()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_uart_enable </td> + <td>(</td> + <td class="paramtype"><a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a> *</td> <td class="paramname"><span class="paramname"><em>UARTx</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Enable UART.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in,out]</td><td class="paramname">UARTx</td><td>Hardware handle to UART register struct, <a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a>. </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="af85fb929c912d3edef3d86ffa833982a" name="af85fb929c912d3edef3d86ffa833982a"></a> +<h2 class="memtitle"><span class="permalink"><a href="#af85fb929c912d3edef3d86ffa833982a">&#9670;&#160;</a></span>neorv32_uart_get_rx_fifo_depth()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_uart_get_rx_fifo_depth </td> + <td>(</td> + <td class="paramtype"><a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a> *</td> <td class="paramname"><span class="paramname"><em>UARTx</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Get UART RX FIFO depth.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in,out]</td><td class="paramname">UARTx</td><td>Hardware handle to UART register struct, <a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a>.</td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>FIFO depth (number of entries) </dd></dl> + +</div> +</div> +<a id="a031e3e27c8783c299623468020a22b0e" name="a031e3e27c8783c299623468020a22b0e"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a031e3e27c8783c299623468020a22b0e">&#9670;&#160;</a></span>neorv32_uart_get_tx_fifo_depth()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_uart_get_tx_fifo_depth </td> + <td>(</td> + <td class="paramtype"><a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a> *</td> <td class="paramname"><span class="paramname"><em>UARTx</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Get UART TX FIFO depth.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in,out]</td><td class="paramname">UARTx</td><td>Hardware handle to UART register struct, <a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a>.</td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>FIFO depth (number of entries) </dd></dl> + +</div> +</div> +<a id="a2efd432f63b8d36d44263d0b1f39a6dc" name="a2efd432f63b8d36d44263d0b1f39a6dc"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a2efd432f63b8d36d44263d0b1f39a6dc">&#9670;&#160;</a></span>neorv32_uart_getc()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">char neorv32_uart_getc </td> + <td>(</td> + <td class="paramtype"><a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a> *</td> <td class="paramname"><span class="paramname"><em>UARTx</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Get char from UART.</p> +<dl class="section note"><dt>Note</dt><dd>This function is blocking.</dd></dl> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in,out]</td><td class="paramname">UARTx</td><td>Hardware handle to UART register struct, <a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a>. </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Received char. </dd></dl> + +</div> +</div> +<a id="ab8c1f9f451def9126ab2749d7bbe50d9" name="ab8c1f9f451def9126ab2749d7bbe50d9"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ab8c1f9f451def9126ab2749d7bbe50d9">&#9670;&#160;</a></span>neorv32_uart_printf()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_uart_printf </td> + <td>(</td> + <td class="paramtype"><a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a> *</td> <td class="paramname"><span class="paramname"><em>UARTx</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">const char *</td> <td class="paramname"><span class="paramname"><em>format</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype"></td> <td class="paramname"><span class="paramname"><em>...</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Custom version of 'printf' printing to UART.</p> +<dl class="section warning"><dt>Warning</dt><dd>: This functions only provides a minimal subset of the 'printf' formating features! </dd></dl> +<dl class="section note"><dt>Note</dt><dd>This function is blocking.</dd></dl> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in,out]</td><td class="paramname">UARTx</td><td>Hardware handle to UART register struct, <a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a>. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">format</td><td>Pointer to format string. See neorv32_uart_vprintf. </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="a9bc7bb94a50b74e1145b78eec6094129" name="a9bc7bb94a50b74e1145b78eec6094129"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a9bc7bb94a50b74e1145b78eec6094129">&#9670;&#160;</a></span>neorv32_uart_putc()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_uart_putc </td> + <td>(</td> + <td class="paramtype"><a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a> *</td> <td class="paramname"><span class="paramname"><em>UARTx</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">char</td> <td class="paramname"><span class="paramname"><em>c</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Send single char via UART.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in,out]</td><td class="paramname">UARTx</td><td>Hardware handle to UART register struct, <a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a>. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">c</td><td>Char to be send. </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="a45a07d5e71677162baaa1025759c67a2" name="a45a07d5e71677162baaa1025759c67a2"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a45a07d5e71677162baaa1025759c67a2">&#9670;&#160;</a></span>neorv32_uart_puts()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_uart_puts </td> + <td>(</td> + <td class="paramtype"><a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a> *</td> <td class="paramname"><span class="paramname"><em>UARTx</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">const char *</td> <td class="paramname"><span class="paramname"><em>s</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Print string (zero-terminated) via UART. Print full line break "\r\n" for every '<br /> +'.</p> +<dl class="section note"><dt>Note</dt><dd>This function is blocking.</dd></dl> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in,out]</td><td class="paramname">UARTx</td><td>Hardware handle to UART register struct, <a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a>. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">s</td><td>Pointer to string. </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="a7b2f924ef4554b1fa90433c38d97558d" name="a7b2f924ef4554b1fa90433c38d97558d"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a7b2f924ef4554b1fa90433c38d97558d">&#9670;&#160;</a></span>neorv32_uart_rtscts_disable()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_uart_rtscts_disable </td> + <td>(</td> + <td class="paramtype"><a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a> *</td> <td class="paramname"><span class="paramname"><em>UARTx</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Disable RTS/CTS hardware flow-control.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in,out]</td><td class="paramname">UARTx</td><td>Hardware handle to UART register struct, <a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a>. </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="a734b610f4cd1b474d7763f9700a715ec" name="a734b610f4cd1b474d7763f9700a715ec"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a734b610f4cd1b474d7763f9700a715ec">&#9670;&#160;</a></span>neorv32_uart_rtscts_enable()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_uart_rtscts_enable </td> + <td>(</td> + <td class="paramtype"><a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a> *</td> <td class="paramname"><span class="paramname"><em>UARTx</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Enable RTS/CTS hardware flow-control.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in,out]</td><td class="paramname">UARTx</td><td>Hardware handle to UART register struct, <a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a>. </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="afe0de59c14faff1e0c890d5465be25f0" name="afe0de59c14faff1e0c890d5465be25f0"></a> +<h2 class="memtitle"><span class="permalink"><a href="#afe0de59c14faff1e0c890d5465be25f0">&#9670;&#160;</a></span>neorv32_uart_rx_clear()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_uart_rx_clear </td> + <td>(</td> + <td class="paramtype"><a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a> *</td> <td class="paramname"><span class="paramname"><em>UARTx</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Clear RX FIFO.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in,out]</td><td class="paramname">UARTx</td><td>Hardware handle to UART register struct, <a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a>. </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="ac429964878bd6deab61d9ed8659bca75" name="ac429964878bd6deab61d9ed8659bca75"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ac429964878bd6deab61d9ed8659bca75">&#9670;&#160;</a></span>neorv32_uart_scan()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_uart_scan </td> + <td>(</td> + <td class="paramtype"><a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a> *</td> <td class="paramname"><span class="paramname"><em>UARTx</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">char *</td> <td class="paramname"><span class="paramname"><em>buffer</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>max_size</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>echo</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Simplified custom version of 'scanf' reading from UART.</p> +<dl class="section note"><dt>Note</dt><dd>This function is blocking.</dd></dl> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in,out]</td><td class="paramname">UARTx</td><td>Hardware handle to UART register struct, <a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a>. </td></tr> + <tr><td class="paramdir">[in,out]</td><td class="paramname">buffer</td><td>Pointer to array of chars to store string. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">max_size</td><td>Maximum number of chars to sample. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">echo</td><td>Echo UART input when 1. </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>Number of chars read. </dd></dl> + +</div> +</div> +<a id="a9cdec36f2723c5373664022d1b68b841" name="a9cdec36f2723c5373664022d1b68b841"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a9cdec36f2723c5373664022d1b68b841">&#9670;&#160;</a></span>neorv32_uart_setup()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_uart_setup </td> + <td>(</td> + <td class="paramtype"><a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a> *</td> <td class="paramname"><span class="paramname"><em>UARTx</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>baudrate</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>irq_mask</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Reset, configure and enable UART.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in,out]</td><td class="paramname">UARTx</td><td>Hardware handle to UART register struct, <a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a>. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">baudrate</td><td>Targeted BAUD rate (e.g. 19200). </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">irq_mask</td><td>Interrupt configuration mask (CTRL's irq_* bits). </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="aa7bef48a58e044c246b8c4ad32864502" name="aa7bef48a58e044c246b8c4ad32864502"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aa7bef48a58e044c246b8c4ad32864502">&#9670;&#160;</a></span>neorv32_uart_tx_busy()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_uart_tx_busy </td> + <td>(</td> + <td class="paramtype"><a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a> *</td> <td class="paramname"><span class="paramname"><em>UARTx</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Check if UART TX is busy (transmitter busy or data left in TX buffer).</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in,out]</td><td class="paramname">UARTx</td><td>Hardware handle to UART register struct, <a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a>. </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>0 if idle, 1 if busy </dd></dl> + +</div> +</div> +<a id="a27971954262a2fd1f21d3bf1ba27e87c" name="a27971954262a2fd1f21d3bf1ba27e87c"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a27971954262a2fd1f21d3bf1ba27e87c">&#9670;&#160;</a></span>neorv32_uart_tx_clear()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_uart_tx_clear </td> + <td>(</td> + <td class="paramtype"><a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a> *</td> <td class="paramname"><span class="paramname"><em>UARTx</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Clear TX FIFO.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in,out]</td><td class="paramname">UARTx</td><td>Hardware handle to UART register struct, <a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a>. </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="a8714cdb1c04d94bec322c6215ea10238" name="a8714cdb1c04d94bec322c6215ea10238"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a8714cdb1c04d94bec322c6215ea10238">&#9670;&#160;</a></span>neorv32_uart_vprintf()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_uart_vprintf </td> + <td>(</td> + <td class="paramtype"><a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a> *</td> <td class="paramname"><span class="paramname"><em>UARTx</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">const char *</td> <td class="paramname"><span class="paramname"><em>format</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">va_list</td> <td class="paramname"><span class="paramname"><em>args</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Custom version of 'vprintf' printing to UART.</p> +<dl class="section warning"><dt>Warning</dt><dd>: This functions only provides a minimal subset of the 'vprintf' formating features! </dd></dl> +<dl class="section note"><dt>Note</dt><dd>This function is blocking.</dd></dl> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in,out]</td><td class="paramname">UARTx</td><td>Hardware handle to UART register struct, <a class="el" href="structneorv32__uart__t.html">neorv32_uart_t</a>. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">format</td><td>Pointer to format string. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">args</td><td>A value identifying a variable arguments list. </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/neorv32__uart_8h_source.html b/sw/neorv32__uart_8h_source.html new file mode 100644 index 0000000000..626d32d65d --- /dev/null +++ b/sw/neorv32__uart_8h_source.html @@ -0,0 +1,296 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/lib/include/neorv32_uart.h Source File</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_7d04193005ada6f9450f847f4adb6b5b.html">lib</a></li><li class="navelem"><a class="el" href="dir_752b1e5d3973bf735fa78bf6b4727df9.html">include</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="headertitle"><div class="title">neorv32_uart.h</div></div> +</div><!--header--> +<div class="contents"> +<a href="neorv32__uart_8h.html">Go to the documentation of this file.</a><div class="fragment"><div class="line"><a id="l00001" name="l00001"></a><span class="lineno"> 1</span><span class="comment">// ================================================================================ //</span></div> +<div class="line"><a id="l00002" name="l00002"></a><span class="lineno"> 2</span><span class="comment">// The NEORV32 RISC-V Processor - https://github.com/stnolting/neorv32 //</span></div> +<div class="line"><a id="l00003" name="l00003"></a><span class="lineno"> 3</span><span class="comment">// Copyright (c) NEORV32 contributors. //</span></div> +<div class="line"><a id="l00004" name="l00004"></a><span class="lineno"> 4</span><span class="comment">// Copyright (c) 2020 - 2024 Stephan Nolting. All rights reserved. //</span></div> +<div class="line"><a id="l00005" name="l00005"></a><span class="lineno"> 5</span><span class="comment">// Licensed under the BSD-3-Clause license, see LICENSE for details. //</span></div> +<div class="line"><a id="l00006" name="l00006"></a><span class="lineno"> 6</span><span class="comment">// SPDX-License-Identifier: BSD-3-Clause //</span></div> +<div class="line"><a id="l00007" name="l00007"></a><span class="lineno"> 7</span><span class="comment">// ================================================================================ //</span></div> +<div class="line"><a id="l00008" name="l00008"></a><span class="lineno"> 8</span> </div> +<div class="line"><a id="l00016" name="l00016"></a><span class="lineno"> 16</span><span class="preprocessor">#ifndef neorv32_uart_h</span></div> +<div class="line"><a id="l00017" name="l00017"></a><span class="lineno"> 17</span><span class="preprocessor">#define neorv32_uart_h</span></div> +<div class="line"><a id="l00018" name="l00018"></a><span class="lineno"> 18</span> </div> +<div class="line"><a id="l00019" name="l00019"></a><span class="lineno"> 19</span><span class="preprocessor">#include &lt;stdint.h&gt;</span></div> +<div class="line"><a id="l00020" name="l00020"></a><span class="lineno"> 20</span><span class="preprocessor">#include &lt;stdarg.h&gt;</span></div> +<div class="line"><a id="l00021" name="l00021"></a><span class="lineno"> 21</span> </div> +<div class="line"><a id="l00022" name="l00022"></a><span class="lineno"> 22</span> </div> +<div class="line"><a id="l00023" name="l00023"></a><span class="lineno"> 23</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen00028" data-start="{" data-end="};"> +<div class="line"><a id="l00028" name="l00028"></a><span class="lineno"><a class="line" href="structneorv32__uart__t.html"> 28</a></span><span class="keyword">typedef</span> <span class="keyword">volatile</span> <span class="keyword">struct </span>__attribute__((packed,aligned(4))) {</div> +<div class="line"><a id="l00029" name="l00029"></a><span class="lineno"><a class="line" href="structneorv32__uart__t.html#a0a6227aeea38335d2b9a9da46b35451b"> 29</a></span> uint32_t <a class="code hl_variable" href="structneorv32__uart__t.html#a0a6227aeea38335d2b9a9da46b35451b">CTRL</a>; </div> +<div class="line"><a id="l00030" name="l00030"></a><span class="lineno"><a class="line" href="structneorv32__uart__t.html#a38eec82aae9ed522a0d2afb9a9560036"> 30</a></span> uint32_t <a class="code hl_variable" href="structneorv32__uart__t.html#a38eec82aae9ed522a0d2afb9a9560036">DATA</a>; </div> +<div class="line"><a id="l00031" name="l00031"></a><span class="lineno"> 31</span>} <a class="code hl_struct" href="structneorv32__uart__t.html">neorv32_uart_t</a>;</div> +</div> +<div class="line"><a id="l00032" name="l00032"></a><span class="lineno"> 32</span> </div> +<div class="line"><a id="l00034" name="l00034"></a><span class="lineno"><a class="line" href="neorv32__uart_8h.html#a4c880a6b27e46f459e750425258b1bdb"> 34</a></span><span class="preprocessor">#define NEORV32_UART0 ((neorv32_uart_t*) (NEORV32_UART0_BASE))</span></div> +<div class="line"><a id="l00035" name="l00035"></a><span class="lineno"> 35</span> </div> +<div class="line"><a id="l00037" name="l00037"></a><span class="lineno"><a class="line" href="neorv32__uart_8h.html#aa2a9ded4523f001bf69935c80247fa2d"> 37</a></span><span class="preprocessor">#define NEORV32_UART1 ((neorv32_uart_t*) (NEORV32_UART1_BASE))</span></div> +<div class="line"><a id="l00038" name="l00038"></a><span class="lineno"> 38</span> </div> +<div class="foldopen" id="foldopen00040" data-start="{" data-end="};"> +<div class="line"><a id="l00040" name="l00040"></a><span class="lineno"><a class="line" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afc"> 40</a></span><span class="keyword">enum</span> <a class="code hl_enumeration" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afc">NEORV32_UART_CTRL_enum</a> {</div> +<div class="line"><a id="l00041" name="l00041"></a><span class="lineno"><a class="line" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca38f6c0e5991f8f80159a388c1080f7c2"> 41</a></span> <a class="code hl_enumvalue" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca38f6c0e5991f8f80159a388c1080f7c2">UART_CTRL_EN</a> = 0, </div> +<div class="line"><a id="l00042" name="l00042"></a><span class="lineno"><a class="line" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca42ed376220259ab22c6f837d08273ef1"> 42</a></span> <a class="code hl_enumvalue" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca42ed376220259ab22c6f837d08273ef1">UART_CTRL_SIM_MODE</a> = 1, </div> +<div class="line"><a id="l00043" name="l00043"></a><span class="lineno"><a class="line" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afcacab78fcd440167c5a2c0f5d300c8f07c"> 43</a></span> <a class="code hl_enumvalue" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afcacab78fcd440167c5a2c0f5d300c8f07c">UART_CTRL_HWFC_EN</a> = 2, </div> +<div class="line"><a id="l00044" name="l00044"></a><span class="lineno"><a class="line" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca1ddbca448bb30c77c42499fff1312183"> 44</a></span> <a class="code hl_enumvalue" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca1ddbca448bb30c77c42499fff1312183">UART_CTRL_PRSC0</a> = 3, </div> +<div class="line"><a id="l00045" name="l00045"></a><span class="lineno"><a class="line" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca9c1d8e8763a653339210ff4e6e3067d2"> 45</a></span> <a class="code hl_enumvalue" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca9c1d8e8763a653339210ff4e6e3067d2">UART_CTRL_PRSC1</a> = 4, </div> +<div class="line"><a id="l00046" name="l00046"></a><span class="lineno"><a class="line" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca8afd60e4bd3854fab623b91fa4f33f70"> 46</a></span> <a class="code hl_enumvalue" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca8afd60e4bd3854fab623b91fa4f33f70">UART_CTRL_PRSC2</a> = 5, </div> +<div class="line"><a id="l00047" name="l00047"></a><span class="lineno"><a class="line" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afcad38432e7e050276d4667daf92c1e3fd5"> 47</a></span> <a class="code hl_enumvalue" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afcad38432e7e050276d4667daf92c1e3fd5">UART_CTRL_BAUD0</a> = 6, </div> +<div class="line"><a id="l00048" name="l00048"></a><span class="lineno"><a class="line" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca1e702002402897eca82bf398504bc439"> 48</a></span> <a class="code hl_enumvalue" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca1e702002402897eca82bf398504bc439">UART_CTRL_BAUD1</a> = 7, </div> +<div class="line"><a id="l00049" name="l00049"></a><span class="lineno"><a class="line" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca36266026e11f22aca1584bd81cd38cd6"> 49</a></span> <a class="code hl_enumvalue" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca36266026e11f22aca1584bd81cd38cd6">UART_CTRL_BAUD2</a> = 8, </div> +<div class="line"><a id="l00050" name="l00050"></a><span class="lineno"><a class="line" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca58190cd41c2ce69512bea10740d35276"> 50</a></span> <a class="code hl_enumvalue" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca58190cd41c2ce69512bea10740d35276">UART_CTRL_BAUD3</a> = 9, </div> +<div class="line"><a id="l00051" name="l00051"></a><span class="lineno"><a class="line" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca81ea805f01b93a59664823b940c7a424"> 51</a></span> <a class="code hl_enumvalue" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca81ea805f01b93a59664823b940c7a424">UART_CTRL_BAUD4</a> = 10, </div> +<div class="line"><a id="l00052" name="l00052"></a><span class="lineno"><a class="line" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca5da1d6007af0265fe48ace8469e07833"> 52</a></span> <a class="code hl_enumvalue" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca5da1d6007af0265fe48ace8469e07833">UART_CTRL_BAUD5</a> = 11, </div> +<div class="line"><a id="l00053" name="l00053"></a><span class="lineno"><a class="line" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca9ac3c1e23d684cb2f67060d6ebe1fa63"> 53</a></span> <a class="code hl_enumvalue" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca9ac3c1e23d684cb2f67060d6ebe1fa63">UART_CTRL_BAUD6</a> = 12, </div> +<div class="line"><a id="l00054" name="l00054"></a><span class="lineno"><a class="line" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca9c12648f7f058f444db434cd8a8d854e"> 54</a></span> <a class="code hl_enumvalue" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca9c12648f7f058f444db434cd8a8d854e">UART_CTRL_BAUD7</a> = 13, </div> +<div class="line"><a id="l00055" name="l00055"></a><span class="lineno"><a class="line" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca09c311eb1f6b38500e6fcbb6ad9dd9ff"> 55</a></span> <a class="code hl_enumvalue" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca09c311eb1f6b38500e6fcbb6ad9dd9ff">UART_CTRL_BAUD8</a> = 14, </div> +<div class="line"><a id="l00056" name="l00056"></a><span class="lineno"><a class="line" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca697321bddeaa2cac1ea034c418be540e"> 56</a></span> <a class="code hl_enumvalue" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca697321bddeaa2cac1ea034c418be540e">UART_CTRL_BAUD9</a> = 15, </div> +<div class="line"><a id="l00058" name="l00058"></a><span class="lineno"><a class="line" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca2015dd85e361aa0476e847953b62baff"> 58</a></span> <a class="code hl_enumvalue" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca2015dd85e361aa0476e847953b62baff">UART_CTRL_RX_NEMPTY</a> = 16, </div> +<div class="line"><a id="l00059" name="l00059"></a><span class="lineno"><a class="line" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca3fc934d0ce6b36e3e131c6682db22247"> 59</a></span> <a class="code hl_enumvalue" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca3fc934d0ce6b36e3e131c6682db22247">UART_CTRL_RX_HALF</a> = 17, </div> +<div class="line"><a id="l00060" name="l00060"></a><span class="lineno"><a class="line" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca47c44fa21e51401621c28019025c1166"> 60</a></span> <a class="code hl_enumvalue" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca47c44fa21e51401621c28019025c1166">UART_CTRL_RX_FULL</a> = 18, </div> +<div class="line"><a id="l00061" name="l00061"></a><span class="lineno"><a class="line" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afcac5c044233b6c4162cf862f3d9831ef46"> 61</a></span> <a class="code hl_enumvalue" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afcac5c044233b6c4162cf862f3d9831ef46">UART_CTRL_TX_EMPTY</a> = 19, </div> +<div class="line"><a id="l00062" name="l00062"></a><span class="lineno"><a class="line" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca5b0e40ab30bdb198f496d09e89d2d0d9"> 62</a></span> <a class="code hl_enumvalue" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca5b0e40ab30bdb198f496d09e89d2d0d9">UART_CTRL_TX_NHALF</a> = 20, </div> +<div class="line"><a id="l00063" name="l00063"></a><span class="lineno"><a class="line" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca36b4195e5d1f12e1fd1a0d30cad0e411"> 63</a></span> <a class="code hl_enumvalue" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca36b4195e5d1f12e1fd1a0d30cad0e411">UART_CTRL_TX_FULL</a> = 21, </div> +<div class="line"><a id="l00065" name="l00065"></a><span class="lineno"><a class="line" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca569ea830518914c5330fa14680b02851"> 65</a></span> <a class="code hl_enumvalue" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca569ea830518914c5330fa14680b02851">UART_CTRL_IRQ_RX_NEMPTY</a> = 22, </div> +<div class="line"><a id="l00066" name="l00066"></a><span class="lineno"><a class="line" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afcaa219ea3ed5b21f5023bbc5ffa5c5f175"> 66</a></span> <a class="code hl_enumvalue" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afcaa219ea3ed5b21f5023bbc5ffa5c5f175">UART_CTRL_IRQ_RX_HALF</a> = 23, </div> +<div class="line"><a id="l00067" name="l00067"></a><span class="lineno"><a class="line" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afcae5f01868b170d71a5f3064023c96a82a"> 67</a></span> <a class="code hl_enumvalue" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afcae5f01868b170d71a5f3064023c96a82a">UART_CTRL_IRQ_RX_FULL</a> = 24, </div> +<div class="line"><a id="l00068" name="l00068"></a><span class="lineno"><a class="line" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca15b9fca73877aad446a8cd338e228e2c"> 68</a></span> <a class="code hl_enumvalue" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca15b9fca73877aad446a8cd338e228e2c">UART_CTRL_IRQ_TX_EMPTY</a> = 25, </div> +<div class="line"><a id="l00069" name="l00069"></a><span class="lineno"><a class="line" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca726b73ef9c44ccc1a45a4230a8bda9d1"> 69</a></span> <a class="code hl_enumvalue" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca726b73ef9c44ccc1a45a4230a8bda9d1">UART_CTRL_IRQ_TX_NHALF</a> = 26, </div> +<div class="line"><a id="l00071" name="l00071"></a><span class="lineno"><a class="line" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afcaefbef37247d88a7e38e1c53b8a33ed33"> 71</a></span> <a class="code hl_enumvalue" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afcaefbef37247d88a7e38e1c53b8a33ed33">UART_CTRL_RX_CLR</a> = 28, </div> +<div class="line"><a id="l00072" name="l00072"></a><span class="lineno"><a class="line" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca408412a32673cc7f6ea70682e3e61431"> 72</a></span> <a class="code hl_enumvalue" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca408412a32673cc7f6ea70682e3e61431">UART_CTRL_TX_CLR</a> = 29, </div> +<div class="line"><a id="l00073" name="l00073"></a><span class="lineno"><a class="line" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca81a52e0b81018f2cf43e64d74caba632"> 73</a></span> <a class="code hl_enumvalue" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca81a52e0b81018f2cf43e64d74caba632">UART_CTRL_RX_OVER</a> = 30, </div> +<div class="line"><a id="l00074" name="l00074"></a><span class="lineno"> 74</span> <a class="code hl_enumvalue" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca0eb636d8b7961d7073c5c7341b5bbe25">UART_CTRL_TX_BUSY</a> = 31 </div> +<div class="line"><a id="l00075" name="l00075"></a><span class="lineno"><a class="line" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca0eb636d8b7961d7073c5c7341b5bbe25"> 75</a></span>};</div> +</div> +<div class="line"><a id="l00076" name="l00076"></a><span class="lineno"> 76</span> </div> +<div class="foldopen" id="foldopen00078" data-start="{" data-end="};"> +<div class="line"><a id="l00078" name="l00078"></a><span class="lineno"><a class="line" href="neorv32__uart_8h.html#adcf35350a9ea18a59c32c35f528643f2"> 78</a></span><span class="keyword">enum</span> <a class="code hl_enumeration" href="neorv32__uart_8h.html#adcf35350a9ea18a59c32c35f528643f2">NEORV32_UART_DATA_enum</a> {</div> +<div class="line"><a id="l00079" name="l00079"></a><span class="lineno"><a class="line" href="neorv32__uart_8h.html#adcf35350a9ea18a59c32c35f528643f2ae70e9f6cd69af724932e79ea7e7f7195"> 79</a></span> <a class="code hl_enumvalue" href="neorv32__uart_8h.html#adcf35350a9ea18a59c32c35f528643f2ae70e9f6cd69af724932e79ea7e7f7195">UART_DATA_RTX_LSB</a> = 0, </div> +<div class="line"><a id="l00080" name="l00080"></a><span class="lineno"><a class="line" href="neorv32__uart_8h.html#adcf35350a9ea18a59c32c35f528643f2a19926d013ca202645d38f2c704782ebb"> 80</a></span> <a class="code hl_enumvalue" href="neorv32__uart_8h.html#adcf35350a9ea18a59c32c35f528643f2a19926d013ca202645d38f2c704782ebb">UART_DATA_RTX_MSB</a> = 7, </div> +<div class="line"><a id="l00082" name="l00082"></a><span class="lineno"><a class="line" href="neorv32__uart_8h.html#adcf35350a9ea18a59c32c35f528643f2a43b296e86d1f2ec7400d57655c3180ef"> 82</a></span> <a class="code hl_enumvalue" href="neorv32__uart_8h.html#adcf35350a9ea18a59c32c35f528643f2a43b296e86d1f2ec7400d57655c3180ef">UART_DATA_RX_FIFO_SIZE_LSB</a> = 8, </div> +<div class="line"><a id="l00083" name="l00083"></a><span class="lineno"><a class="line" href="neorv32__uart_8h.html#adcf35350a9ea18a59c32c35f528643f2a81a82ac0dc5c8c8d7af21553288e3225"> 83</a></span> <a class="code hl_enumvalue" href="neorv32__uart_8h.html#adcf35350a9ea18a59c32c35f528643f2a81a82ac0dc5c8c8d7af21553288e3225">UART_DATA_RX_FIFO_SIZE_MSB</a> = 11, </div> +<div class="line"><a id="l00085" name="l00085"></a><span class="lineno"><a class="line" href="neorv32__uart_8h.html#adcf35350a9ea18a59c32c35f528643f2a6d718ad0bb82a5cb053c117cd2d6ca8e"> 85</a></span> <a class="code hl_enumvalue" href="neorv32__uart_8h.html#adcf35350a9ea18a59c32c35f528643f2a6d718ad0bb82a5cb053c117cd2d6ca8e">UART_DATA_TX_FIFO_SIZE_LSB</a> = 12, </div> +<div class="line"><a id="l00086" name="l00086"></a><span class="lineno"><a class="line" href="neorv32__uart_8h.html#adcf35350a9ea18a59c32c35f528643f2ada92cbbe278e3e0592eba58c97699529"> 86</a></span> <a class="code hl_enumvalue" href="neorv32__uart_8h.html#adcf35350a9ea18a59c32c35f528643f2ada92cbbe278e3e0592eba58c97699529">UART_DATA_TX_FIFO_SIZE_MSB</a> = 15, </div> +<div class="line"><a id="l00087" name="l00087"></a><span class="lineno"> 87</span>};</div> +</div> +<div class="line"><a id="l00091" name="l00091"></a><span class="lineno"> 91</span><span class="comment">/**********************************************************************/</span></div> +<div class="line"><a id="l00095" name="l00095"></a><span class="lineno"> 95</span><span class="keywordtype">int</span> <a class="code hl_function" href="neorv32__uart_8h.html#abef6415b0391dc055713404312196682">neorv32_uart_available</a>(<a class="code hl_struct" href="structneorv32__uart__t.html">neorv32_uart_t</a> *UARTx);</div> +<div class="line"><a id="l00096" name="l00096"></a><span class="lineno"> 96</span><span class="keywordtype">int</span> <a class="code hl_function" href="neorv32__uart_8h.html#af85fb929c912d3edef3d86ffa833982a">neorv32_uart_get_rx_fifo_depth</a>(<a class="code hl_struct" href="structneorv32__uart__t.html">neorv32_uart_t</a> *UARTx);</div> +<div class="line"><a id="l00097" name="l00097"></a><span class="lineno"> 97</span><span class="keywordtype">int</span> <a class="code hl_function" href="neorv32__uart_8h.html#a031e3e27c8783c299623468020a22b0e">neorv32_uart_get_tx_fifo_depth</a>(<a class="code hl_struct" href="structneorv32__uart__t.html">neorv32_uart_t</a> *UARTx);</div> +<div class="line"><a id="l00098" name="l00098"></a><span class="lineno"> 98</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__uart_8h.html#a9cdec36f2723c5373664022d1b68b841">neorv32_uart_setup</a>(<a class="code hl_struct" href="structneorv32__uart__t.html">neorv32_uart_t</a> *UARTx, uint32_t baudrate, uint32_t irq_mask);</div> +<div class="line"><a id="l00099" name="l00099"></a><span class="lineno"> 99</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__uart_8h.html#afa0533e81d53057c36f4997a2dbbe2bc">neorv32_uart_enable</a>(<a class="code hl_struct" href="structneorv32__uart__t.html">neorv32_uart_t</a> *UARTx);</div> +<div class="line"><a id="l00100" name="l00100"></a><span class="lineno"> 100</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__uart_8h.html#ae18804ccd29ec2fd1cc06e9ce985b704">neorv32_uart_disable</a>(<a class="code hl_struct" href="structneorv32__uart__t.html">neorv32_uart_t</a> *UARTx);</div> +<div class="line"><a id="l00101" name="l00101"></a><span class="lineno"> 101</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__uart_8h.html#a734b610f4cd1b474d7763f9700a715ec">neorv32_uart_rtscts_enable</a>(<a class="code hl_struct" href="structneorv32__uart__t.html">neorv32_uart_t</a> *UARTx);</div> +<div class="line"><a id="l00102" name="l00102"></a><span class="lineno"> 102</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__uart_8h.html#a7b2f924ef4554b1fa90433c38d97558d">neorv32_uart_rtscts_disable</a>(<a class="code hl_struct" href="structneorv32__uart__t.html">neorv32_uart_t</a> *UARTx);</div> +<div class="line"><a id="l00103" name="l00103"></a><span class="lineno"> 103</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__uart_8h.html#a9bc7bb94a50b74e1145b78eec6094129">neorv32_uart_putc</a>(<a class="code hl_struct" href="structneorv32__uart__t.html">neorv32_uart_t</a> *UARTx, <span class="keywordtype">char</span> c);</div> +<div class="line"><a id="l00104" name="l00104"></a><span class="lineno"> 104</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__uart_8h.html#afe0de59c14faff1e0c890d5465be25f0">neorv32_uart_rx_clear</a>(<a class="code hl_struct" href="structneorv32__uart__t.html">neorv32_uart_t</a> *UARTx);</div> +<div class="line"><a id="l00105" name="l00105"></a><span class="lineno"> 105</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__uart_8h.html#a27971954262a2fd1f21d3bf1ba27e87c">neorv32_uart_tx_clear</a>(<a class="code hl_struct" href="structneorv32__uart__t.html">neorv32_uart_t</a> *UARTx);</div> +<div class="line"><a id="l00106" name="l00106"></a><span class="lineno"> 106</span><span class="keywordtype">int</span> <a class="code hl_function" href="neorv32__uart_8h.html#aa7bef48a58e044c246b8c4ad32864502">neorv32_uart_tx_busy</a>(<a class="code hl_struct" href="structneorv32__uart__t.html">neorv32_uart_t</a> *UARTx);</div> +<div class="line"><a id="l00107" name="l00107"></a><span class="lineno"> 107</span><span class="keywordtype">char</span> <a class="code hl_function" href="neorv32__uart_8h.html#a2efd432f63b8d36d44263d0b1f39a6dc">neorv32_uart_getc</a>(<a class="code hl_struct" href="structneorv32__uart__t.html">neorv32_uart_t</a> *UARTx);</div> +<div class="line"><a id="l00108" name="l00108"></a><span class="lineno"> 108</span><span class="keywordtype">int</span> <a class="code hl_function" href="neorv32__uart_8h.html#adedb0e07efb232717534017167a5be98">neorv32_uart_char_received</a>(<a class="code hl_struct" href="structneorv32__uart__t.html">neorv32_uart_t</a> *UARTx);</div> +<div class="line"><a id="l00109" name="l00109"></a><span class="lineno"> 109</span><span class="keywordtype">char</span> <a class="code hl_function" href="neorv32__uart_8h.html#aa490df3a9bb2aa3215fa6fad34ffe7d1">neorv32_uart_char_received_get</a>(<a class="code hl_struct" href="structneorv32__uart__t.html">neorv32_uart_t</a> *UARTx);</div> +<div class="line"><a id="l00110" name="l00110"></a><span class="lineno"> 110</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__uart_8h.html#a45a07d5e71677162baaa1025759c67a2">neorv32_uart_puts</a>(<a class="code hl_struct" href="structneorv32__uart__t.html">neorv32_uart_t</a> *UARTx, <span class="keyword">const</span> <span class="keywordtype">char</span> *s);</div> +<div class="line"><a id="l00111" name="l00111"></a><span class="lineno"> 111</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__uart_8h.html#a8714cdb1c04d94bec322c6215ea10238">neorv32_uart_vprintf</a>(<a class="code hl_struct" href="structneorv32__uart__t.html">neorv32_uart_t</a> *UARTx, <span class="keyword">const</span> <span class="keywordtype">char</span> *format, va_list args);</div> +<div class="line"><a id="l00112" name="l00112"></a><span class="lineno"> 112</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__uart_8h.html#ab8c1f9f451def9126ab2749d7bbe50d9">neorv32_uart_printf</a>(<a class="code hl_struct" href="structneorv32__uart__t.html">neorv32_uart_t</a> *UARTx, <span class="keyword">const</span> <span class="keywordtype">char</span> *format, ...);</div> +<div class="line"><a id="l00113" name="l00113"></a><span class="lineno"> 113</span><span class="keywordtype">int</span> <a class="code hl_function" href="neorv32__uart_8h.html#ac429964878bd6deab61d9ed8659bca75">neorv32_uart_scan</a>(<a class="code hl_struct" href="structneorv32__uart__t.html">neorv32_uart_t</a> *UARTx, <span class="keywordtype">char</span> *buffer, <span class="keywordtype">int</span> max_size, <span class="keywordtype">int</span> echo);</div> +<div class="line"><a id="l00117" name="l00117"></a><span class="lineno"> 117</span><span class="comment">/**********************************************************************/</span></div> +<div class="line"><a id="l00121" name="l00121"></a><span class="lineno"> 121</span><span class="preprocessor">#define neorv32_uart0_available() neorv32_uart_available(NEORV32_UART0)</span></div> +<div class="line"><a id="l00122" name="l00122"></a><span class="lineno"> 122</span><span class="preprocessor">#define neorv32_uart0_get_rx_fifo_depth() neorv32_uart_get_rx_fifo_depth(NEORV32_UART0)</span></div> +<div class="line"><a id="l00123" name="l00123"></a><span class="lineno"> 123</span><span class="preprocessor">#define neorv32_uart0_get_tx_fifo_depth() neorv32_uart_get_tx_fifo_depth(NEORV32_UART0)</span></div> +<div class="line"><a id="l00124" name="l00124"></a><span class="lineno"> 124</span><span class="preprocessor">#define neorv32_uart0_setup(baudrate, irq_mask) neorv32_uart_setup(NEORV32_UART0, baudrate, irq_mask)</span></div> +<div class="line"><a id="l00125" name="l00125"></a><span class="lineno"> 125</span><span class="preprocessor">#define neorv32_uart0_disable() neorv32_uart_disable(NEORV32_UART0)</span></div> +<div class="line"><a id="l00126" name="l00126"></a><span class="lineno"> 126</span><span class="preprocessor">#define neorv32_uart0_enable() neorv32_uart_enable(NEORV32_UART0)</span></div> +<div class="line"><a id="l00127" name="l00127"></a><span class="lineno"> 127</span><span class="preprocessor">#define neorv32_uart0_rtscts_disable() neorv32_uart_rtscts_disable(NEORV32_UART0)</span></div> +<div class="line"><a id="l00128" name="l00128"></a><span class="lineno"> 128</span><span class="preprocessor">#define neorv32_uart0_rtscts_enable() neorv32_uart_rtscts_enable(NEORV32_UART0)</span></div> +<div class="line"><a id="l00129" name="l00129"></a><span class="lineno"> 129</span><span class="preprocessor">#define neorv32_uart0_putc(c) neorv32_uart_putc(NEORV32_UART0, c)</span></div> +<div class="line"><a id="l00130" name="l00130"></a><span class="lineno"> 130</span><span class="preprocessor">#define neorv32_uart0_rx_clear() neorv32_uart_rx_clear(NEORV32_UART0)</span></div> +<div class="line"><a id="l00131" name="l00131"></a><span class="lineno"> 131</span><span class="preprocessor">#define neorv32_uart0_tx_clear() neorv32_uart_tx_clear(NEORV32_UART0)</span></div> +<div class="line"><a id="l00132" name="l00132"></a><span class="lineno"> 132</span><span class="preprocessor">#define neorv32_uart0_tx_busy() neorv32_uart_tx_busy(NEORV32_UART0)</span></div> +<div class="line"><a id="l00133" name="l00133"></a><span class="lineno"> 133</span><span class="preprocessor">#define neorv32_uart0_getc() neorv32_uart_getc(NEORV32_UART0)</span></div> +<div class="line"><a id="l00134" name="l00134"></a><span class="lineno"> 134</span><span class="preprocessor">#define neorv32_uart0_char_received() neorv32_uart_char_received(NEORV32_UART0)</span></div> +<div class="line"><a id="l00135" name="l00135"></a><span class="lineno"> 135</span><span class="preprocessor">#define neorv32_uart0_char_received_get() neorv32_uart_char_received_get(NEORV32_UART0)</span></div> +<div class="line"><a id="l00136" name="l00136"></a><span class="lineno"> 136</span><span class="preprocessor">#define neorv32_uart0_puts(s) neorv32_uart_puts(NEORV32_UART0, s)</span></div> +<div class="line"><a id="l00137" name="l00137"></a><span class="lineno"> 137</span><span class="preprocessor">#define neorv32_uart0_printf(...) neorv32_uart_printf(NEORV32_UART0, __VA_ARGS__)</span></div> +<div class="line"><a id="l00138" name="l00138"></a><span class="lineno"> 138</span><span class="preprocessor">#define neorv32_uart0_scan(buffer, max_size, echo) neorv32_uart_scan(NEORV32_UART0, buffer, max_size, echo)</span></div> +<div class="line"><a id="l00139" name="l00139"></a><span class="lineno"> 139</span> </div> +<div class="line"><a id="l00140" name="l00140"></a><span class="lineno"> 140</span><span class="preprocessor">#define neorv32_uart1_available() neorv32_uart_available(NEORV32_UART1)</span></div> +<div class="line"><a id="l00141" name="l00141"></a><span class="lineno"> 141</span><span class="preprocessor">#define neorv32_uart1_get_rx_fifo_depth() neorv32_uart_get_rx_fifo_depth(NEORV32_UART1)</span></div> +<div class="line"><a id="l00142" name="l00142"></a><span class="lineno"> 142</span><span class="preprocessor">#define neorv32_uart1_get_tx_fifo_depth() neorv32_uart_get_tx_fifo_depth(NEORV32_UART1)</span></div> +<div class="line"><a id="l00143" name="l00143"></a><span class="lineno"> 143</span><span class="preprocessor">#define neorv32_uart1_setup(baudrate, irq_mask) neorv32_uart_setup(NEORV32_UART1, baudrate, irq_mask)</span></div> +<div class="line"><a id="l00144" name="l00144"></a><span class="lineno"> 144</span><span class="preprocessor">#define neorv32_uart1_disable() neorv32_uart_disable(NEORV32_UART1)</span></div> +<div class="line"><a id="l00145" name="l00145"></a><span class="lineno"> 145</span><span class="preprocessor">#define neorv32_uart1_enable() neorv32_uart_enable(NEORV32_UART1)</span></div> +<div class="line"><a id="l00146" name="l00146"></a><span class="lineno"> 146</span><span class="preprocessor">#define neorv32_uart1_rtscts_disable() neorv32_uart_rtscts_disable(NEORV32_UART1)</span></div> +<div class="line"><a id="l00147" name="l00147"></a><span class="lineno"> 147</span><span class="preprocessor">#define neorv32_uart1_rtscts_enable() neorv32_uart_rtscts_enable(NEORV32_UART1)</span></div> +<div class="line"><a id="l00148" name="l00148"></a><span class="lineno"> 148</span><span class="preprocessor">#define neorv32_uart1_putc(c) neorv32_uart_putc(NEORV32_UART1, c)</span></div> +<div class="line"><a id="l00149" name="l00149"></a><span class="lineno"> 149</span><span class="preprocessor">#define neorv32_uart1_rx_clear() neorv32_uart_rx_clear(NEORV32_UART1)</span></div> +<div class="line"><a id="l00150" name="l00150"></a><span class="lineno"> 150</span><span class="preprocessor">#define neorv32_uart1_tx_clear() neorv32_uart_tx_clear(NEORV32_UART1)</span></div> +<div class="line"><a id="l00151" name="l00151"></a><span class="lineno"> 151</span><span class="preprocessor">#define neorv32_uart1_tx_busy() neorv32_uart_tx_busy(NEORV32_UART1)</span></div> +<div class="line"><a id="l00152" name="l00152"></a><span class="lineno"> 152</span><span class="preprocessor">#define neorv32_uart1_getc() neorv32_uart_getc(NEORV32_UART1)</span></div> +<div class="line"><a id="l00153" name="l00153"></a><span class="lineno"> 153</span><span class="preprocessor">#define neorv32_uart1_char_received() neorv32_uart_char_received(NEORV32_UART1)</span></div> +<div class="line"><a id="l00154" name="l00154"></a><span class="lineno"> 154</span><span class="preprocessor">#define neorv32_uart1_char_received_get() neorv32_uart_char_received_get(NEORV32_UART1)</span></div> +<div class="line"><a id="l00155" name="l00155"></a><span class="lineno"> 155</span><span class="preprocessor">#define neorv32_uart1_puts(s) neorv32_uart_puts(NEORV32_UART1, s)</span></div> +<div class="line"><a id="l00156" name="l00156"></a><span class="lineno"> 156</span><span class="preprocessor">#define neorv32_uart1_printf(...) neorv32_uart_printf(NEORV32_UART1, __VA_ARGS__)</span></div> +<div class="line"><a id="l00157" name="l00157"></a><span class="lineno"> 157</span><span class="preprocessor">#define neorv32_uart1_scan(buffer, max_size, echo) neorv32_uart_scan(NEORV32_UART1, buffer, max_size, echo)</span></div> +<div class="line"><a id="l00161" name="l00161"></a><span class="lineno"> 161</span><span class="preprocessor">#endif </span><span class="comment">// neorv32_uart_h</span></div> +<div class="ttc" id="aneorv32__uart_8h_html_a031e3e27c8783c299623468020a22b0e"><div class="ttname"><a href="neorv32__uart_8h.html#a031e3e27c8783c299623468020a22b0e">neorv32_uart_get_tx_fifo_depth</a></div><div class="ttdeci">int neorv32_uart_get_tx_fifo_depth(neorv32_uart_t *UARTx)</div><div class="ttdef"><b>Definition</b> neorv32_uart.c:128</div></div> +<div class="ttc" id="aneorv32__uart_8h_html_a27971954262a2fd1f21d3bf1ba27e87c"><div class="ttname"><a href="neorv32__uart_8h.html#a27971954262a2fd1f21d3bf1ba27e87c">neorv32_uart_tx_clear</a></div><div class="ttdeci">void neorv32_uart_tx_clear(neorv32_uart_t *UARTx)</div><div class="ttdef"><b>Definition</b> neorv32_uart.c:209</div></div> +<div class="ttc" id="aneorv32__uart_8h_html_a2efd432f63b8d36d44263d0b1f39a6dc"><div class="ttname"><a href="neorv32__uart_8h.html#a2efd432f63b8d36d44263d0b1f39a6dc">neorv32_uart_getc</a></div><div class="ttdeci">char neorv32_uart_getc(neorv32_uart_t *UARTx)</div><div class="ttdef"><b>Definition</b> neorv32_uart.c:240</div></div> +<div class="ttc" id="aneorv32__uart_8h_html_a45a07d5e71677162baaa1025759c67a2"><div class="ttname"><a href="neorv32__uart_8h.html#a45a07d5e71677162baaa1025759c67a2">neorv32_uart_puts</a></div><div class="ttdeci">void neorv32_uart_puts(neorv32_uart_t *UARTx, const char *s)</div><div class="ttdef"><b>Definition</b> neorv32_uart.c:293</div></div> +<div class="ttc" id="aneorv32__uart_8h_html_a734b610f4cd1b474d7763f9700a715ec"><div class="ttname"><a href="neorv32__uart_8h.html#a734b610f4cd1b474d7763f9700a715ec">neorv32_uart_rtscts_enable</a></div><div class="ttdeci">void neorv32_uart_rtscts_enable(neorv32_uart_t *UARTx)</div><div class="ttdef"><b>Definition</b> neorv32_uart.c:162</div></div> +<div class="ttc" id="aneorv32__uart_8h_html_a7b2f924ef4554b1fa90433c38d97558d"><div class="ttname"><a href="neorv32__uart_8h.html#a7b2f924ef4554b1fa90433c38d97558d">neorv32_uart_rtscts_disable</a></div><div class="ttdeci">void neorv32_uart_rtscts_disable(neorv32_uart_t *UARTx)</div><div class="ttdef"><b>Definition</b> neorv32_uart.c:173</div></div> +<div class="ttc" id="aneorv32__uart_8h_html_a8714cdb1c04d94bec322c6215ea10238"><div class="ttname"><a href="neorv32__uart_8h.html#a8714cdb1c04d94bec322c6215ea10238">neorv32_uart_vprintf</a></div><div class="ttdeci">void neorv32_uart_vprintf(neorv32_uart_t *UARTx, const char *format, va_list args)</div><div class="ttdef"><b>Definition</b> neorv32_uart.c:315</div></div> +<div class="ttc" id="aneorv32__uart_8h_html_a9bc7bb94a50b74e1145b78eec6094129"><div class="ttname"><a href="neorv32__uart_8h.html#a9bc7bb94a50b74e1145b78eec6094129">neorv32_uart_putc</a></div><div class="ttdeci">void neorv32_uart_putc(neorv32_uart_t *UARTx, char c)</div><div class="ttdef"><b>Definition</b> neorv32_uart.c:185</div></div> +<div class="ttc" id="aneorv32__uart_8h_html_a9cdec36f2723c5373664022d1b68b841"><div class="ttname"><a href="neorv32__uart_8h.html#a9cdec36f2723c5373664022d1b68b841">neorv32_uart_setup</a></div><div class="ttdeci">void neorv32_uart_setup(neorv32_uart_t *UARTx, uint32_t baudrate, uint32_t irq_mask)</div><div class="ttdef"><b>Definition</b> neorv32_uart.c:55</div></div> +<div class="ttc" id="aneorv32__uart_8h_html_aa490df3a9bb2aa3215fa6fad34ffe7d1"><div class="ttname"><a href="neorv32__uart_8h.html#aa490df3a9bb2aa3215fa6fad34ffe7d1">neorv32_uart_char_received_get</a></div><div class="ttdeci">char neorv32_uart_char_received_get(neorv32_uart_t *UARTx)</div><div class="ttdef"><b>Definition</b> neorv32_uart.c:279</div></div> +<div class="ttc" id="aneorv32__uart_8h_html_aa7bef48a58e044c246b8c4ad32864502"><div class="ttname"><a href="neorv32__uart_8h.html#aa7bef48a58e044c246b8c4ad32864502">neorv32_uart_tx_busy</a></div><div class="ttdeci">int neorv32_uart_tx_busy(neorv32_uart_t *UARTx)</div><div class="ttdef"><b>Definition</b> neorv32_uart.c:221</div></div> +<div class="ttc" id="aneorv32__uart_8h_html_ab8c1f9f451def9126ab2749d7bbe50d9"><div class="ttname"><a href="neorv32__uart_8h.html#ab8c1f9f451def9126ab2749d7bbe50d9">neorv32_uart_printf</a></div><div class="ttdeci">void neorv32_uart_printf(neorv32_uart_t *UARTx, const char *format,...)</div><div class="ttdef"><b>Definition</b> neorv32_uart.c:398</div></div> +<div class="ttc" id="aneorv32__uart_8h_html_abef6415b0391dc055713404312196682"><div class="ttname"><a href="neorv32__uart_8h.html#abef6415b0391dc055713404312196682">neorv32_uart_available</a></div><div class="ttdeci">int neorv32_uart_available(neorv32_uart_t *UARTx)</div><div class="ttdef"><b>Definition</b> neorv32_uart.c:34</div></div> +<div class="ttc" id="aneorv32__uart_8h_html_ac429964878bd6deab61d9ed8659bca75"><div class="ttname"><a href="neorv32__uart_8h.html#ac429964878bd6deab61d9ed8659bca75">neorv32_uart_scan</a></div><div class="ttdeci">int neorv32_uart_scan(neorv32_uart_t *UARTx, char *buffer, int max_size, int echo)</div><div class="ttdef"><b>Definition</b> neorv32_uart.c:418</div></div> +<div class="ttc" id="aneorv32__uart_8h_html_ad9f75f453beca1619344bb4213352afc"><div class="ttname"><a href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afc">NEORV32_UART_CTRL_enum</a></div><div class="ttdeci">NEORV32_UART_CTRL_enum</div><div class="ttdef"><b>Definition</b> neorv32_uart.h:40</div></div> +<div class="ttc" id="aneorv32__uart_8h_html_ad9f75f453beca1619344bb4213352afca09c311eb1f6b38500e6fcbb6ad9dd9ff"><div class="ttname"><a href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca09c311eb1f6b38500e6fcbb6ad9dd9ff">UART_CTRL_BAUD8</a></div><div class="ttdeci">@ UART_CTRL_BAUD8</div><div class="ttdef"><b>Definition</b> neorv32_uart.h:55</div></div> +<div class="ttc" id="aneorv32__uart_8h_html_ad9f75f453beca1619344bb4213352afca0eb636d8b7961d7073c5c7341b5bbe25"><div class="ttname"><a href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca0eb636d8b7961d7073c5c7341b5bbe25">UART_CTRL_TX_BUSY</a></div><div class="ttdeci">@ UART_CTRL_TX_BUSY</div><div class="ttdef"><b>Definition</b> neorv32_uart.h:74</div></div> +<div class="ttc" id="aneorv32__uart_8h_html_ad9f75f453beca1619344bb4213352afca15b9fca73877aad446a8cd338e228e2c"><div class="ttname"><a href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca15b9fca73877aad446a8cd338e228e2c">UART_CTRL_IRQ_TX_EMPTY</a></div><div class="ttdeci">@ UART_CTRL_IRQ_TX_EMPTY</div><div class="ttdef"><b>Definition</b> neorv32_uart.h:68</div></div> +<div class="ttc" id="aneorv32__uart_8h_html_ad9f75f453beca1619344bb4213352afca1ddbca448bb30c77c42499fff1312183"><div class="ttname"><a href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca1ddbca448bb30c77c42499fff1312183">UART_CTRL_PRSC0</a></div><div class="ttdeci">@ UART_CTRL_PRSC0</div><div class="ttdef"><b>Definition</b> neorv32_uart.h:44</div></div> +<div class="ttc" id="aneorv32__uart_8h_html_ad9f75f453beca1619344bb4213352afca1e702002402897eca82bf398504bc439"><div class="ttname"><a href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca1e702002402897eca82bf398504bc439">UART_CTRL_BAUD1</a></div><div class="ttdeci">@ UART_CTRL_BAUD1</div><div class="ttdef"><b>Definition</b> neorv32_uart.h:48</div></div> +<div class="ttc" id="aneorv32__uart_8h_html_ad9f75f453beca1619344bb4213352afca2015dd85e361aa0476e847953b62baff"><div class="ttname"><a href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca2015dd85e361aa0476e847953b62baff">UART_CTRL_RX_NEMPTY</a></div><div class="ttdeci">@ UART_CTRL_RX_NEMPTY</div><div class="ttdef"><b>Definition</b> neorv32_uart.h:58</div></div> +<div class="ttc" id="aneorv32__uart_8h_html_ad9f75f453beca1619344bb4213352afca36266026e11f22aca1584bd81cd38cd6"><div class="ttname"><a href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca36266026e11f22aca1584bd81cd38cd6">UART_CTRL_BAUD2</a></div><div class="ttdeci">@ UART_CTRL_BAUD2</div><div class="ttdef"><b>Definition</b> neorv32_uart.h:49</div></div> +<div class="ttc" id="aneorv32__uart_8h_html_ad9f75f453beca1619344bb4213352afca36b4195e5d1f12e1fd1a0d30cad0e411"><div class="ttname"><a href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca36b4195e5d1f12e1fd1a0d30cad0e411">UART_CTRL_TX_FULL</a></div><div class="ttdeci">@ UART_CTRL_TX_FULL</div><div class="ttdef"><b>Definition</b> neorv32_uart.h:63</div></div> +<div class="ttc" id="aneorv32__uart_8h_html_ad9f75f453beca1619344bb4213352afca38f6c0e5991f8f80159a388c1080f7c2"><div class="ttname"><a href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca38f6c0e5991f8f80159a388c1080f7c2">UART_CTRL_EN</a></div><div class="ttdeci">@ UART_CTRL_EN</div><div class="ttdef"><b>Definition</b> neorv32_uart.h:41</div></div> +<div class="ttc" id="aneorv32__uart_8h_html_ad9f75f453beca1619344bb4213352afca3fc934d0ce6b36e3e131c6682db22247"><div class="ttname"><a href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca3fc934d0ce6b36e3e131c6682db22247">UART_CTRL_RX_HALF</a></div><div class="ttdeci">@ UART_CTRL_RX_HALF</div><div class="ttdef"><b>Definition</b> neorv32_uart.h:59</div></div> +<div class="ttc" id="aneorv32__uart_8h_html_ad9f75f453beca1619344bb4213352afca408412a32673cc7f6ea70682e3e61431"><div class="ttname"><a href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca408412a32673cc7f6ea70682e3e61431">UART_CTRL_TX_CLR</a></div><div class="ttdeci">@ UART_CTRL_TX_CLR</div><div class="ttdef"><b>Definition</b> neorv32_uart.h:72</div></div> +<div class="ttc" id="aneorv32__uart_8h_html_ad9f75f453beca1619344bb4213352afca42ed376220259ab22c6f837d08273ef1"><div class="ttname"><a href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca42ed376220259ab22c6f837d08273ef1">UART_CTRL_SIM_MODE</a></div><div class="ttdeci">@ UART_CTRL_SIM_MODE</div><div class="ttdef"><b>Definition</b> neorv32_uart.h:42</div></div> +<div class="ttc" id="aneorv32__uart_8h_html_ad9f75f453beca1619344bb4213352afca47c44fa21e51401621c28019025c1166"><div class="ttname"><a href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca47c44fa21e51401621c28019025c1166">UART_CTRL_RX_FULL</a></div><div class="ttdeci">@ UART_CTRL_RX_FULL</div><div class="ttdef"><b>Definition</b> neorv32_uart.h:60</div></div> +<div class="ttc" id="aneorv32__uart_8h_html_ad9f75f453beca1619344bb4213352afca569ea830518914c5330fa14680b02851"><div class="ttname"><a href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca569ea830518914c5330fa14680b02851">UART_CTRL_IRQ_RX_NEMPTY</a></div><div class="ttdeci">@ UART_CTRL_IRQ_RX_NEMPTY</div><div class="ttdef"><b>Definition</b> neorv32_uart.h:65</div></div> +<div class="ttc" id="aneorv32__uart_8h_html_ad9f75f453beca1619344bb4213352afca58190cd41c2ce69512bea10740d35276"><div class="ttname"><a href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca58190cd41c2ce69512bea10740d35276">UART_CTRL_BAUD3</a></div><div class="ttdeci">@ UART_CTRL_BAUD3</div><div class="ttdef"><b>Definition</b> neorv32_uart.h:50</div></div> +<div class="ttc" id="aneorv32__uart_8h_html_ad9f75f453beca1619344bb4213352afca5b0e40ab30bdb198f496d09e89d2d0d9"><div class="ttname"><a href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca5b0e40ab30bdb198f496d09e89d2d0d9">UART_CTRL_TX_NHALF</a></div><div class="ttdeci">@ UART_CTRL_TX_NHALF</div><div class="ttdef"><b>Definition</b> neorv32_uart.h:62</div></div> +<div class="ttc" id="aneorv32__uart_8h_html_ad9f75f453beca1619344bb4213352afca5da1d6007af0265fe48ace8469e07833"><div class="ttname"><a href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca5da1d6007af0265fe48ace8469e07833">UART_CTRL_BAUD5</a></div><div class="ttdeci">@ UART_CTRL_BAUD5</div><div class="ttdef"><b>Definition</b> neorv32_uart.h:52</div></div> +<div class="ttc" id="aneorv32__uart_8h_html_ad9f75f453beca1619344bb4213352afca697321bddeaa2cac1ea034c418be540e"><div class="ttname"><a href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca697321bddeaa2cac1ea034c418be540e">UART_CTRL_BAUD9</a></div><div class="ttdeci">@ UART_CTRL_BAUD9</div><div class="ttdef"><b>Definition</b> neorv32_uart.h:56</div></div> +<div class="ttc" id="aneorv32__uart_8h_html_ad9f75f453beca1619344bb4213352afca726b73ef9c44ccc1a45a4230a8bda9d1"><div class="ttname"><a href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca726b73ef9c44ccc1a45a4230a8bda9d1">UART_CTRL_IRQ_TX_NHALF</a></div><div class="ttdeci">@ UART_CTRL_IRQ_TX_NHALF</div><div class="ttdef"><b>Definition</b> neorv32_uart.h:69</div></div> +<div class="ttc" id="aneorv32__uart_8h_html_ad9f75f453beca1619344bb4213352afca81a52e0b81018f2cf43e64d74caba632"><div class="ttname"><a href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca81a52e0b81018f2cf43e64d74caba632">UART_CTRL_RX_OVER</a></div><div class="ttdeci">@ UART_CTRL_RX_OVER</div><div class="ttdef"><b>Definition</b> neorv32_uart.h:73</div></div> +<div class="ttc" id="aneorv32__uart_8h_html_ad9f75f453beca1619344bb4213352afca81ea805f01b93a59664823b940c7a424"><div class="ttname"><a href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca81ea805f01b93a59664823b940c7a424">UART_CTRL_BAUD4</a></div><div class="ttdeci">@ UART_CTRL_BAUD4</div><div class="ttdef"><b>Definition</b> neorv32_uart.h:51</div></div> +<div class="ttc" id="aneorv32__uart_8h_html_ad9f75f453beca1619344bb4213352afca8afd60e4bd3854fab623b91fa4f33f70"><div class="ttname"><a href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca8afd60e4bd3854fab623b91fa4f33f70">UART_CTRL_PRSC2</a></div><div class="ttdeci">@ UART_CTRL_PRSC2</div><div class="ttdef"><b>Definition</b> neorv32_uart.h:46</div></div> +<div class="ttc" id="aneorv32__uart_8h_html_ad9f75f453beca1619344bb4213352afca9ac3c1e23d684cb2f67060d6ebe1fa63"><div class="ttname"><a href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca9ac3c1e23d684cb2f67060d6ebe1fa63">UART_CTRL_BAUD6</a></div><div class="ttdeci">@ UART_CTRL_BAUD6</div><div class="ttdef"><b>Definition</b> neorv32_uart.h:53</div></div> +<div class="ttc" id="aneorv32__uart_8h_html_ad9f75f453beca1619344bb4213352afca9c12648f7f058f444db434cd8a8d854e"><div class="ttname"><a href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca9c12648f7f058f444db434cd8a8d854e">UART_CTRL_BAUD7</a></div><div class="ttdeci">@ UART_CTRL_BAUD7</div><div class="ttdef"><b>Definition</b> neorv32_uart.h:54</div></div> +<div class="ttc" id="aneorv32__uart_8h_html_ad9f75f453beca1619344bb4213352afca9c1d8e8763a653339210ff4e6e3067d2"><div class="ttname"><a href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca9c1d8e8763a653339210ff4e6e3067d2">UART_CTRL_PRSC1</a></div><div class="ttdeci">@ UART_CTRL_PRSC1</div><div class="ttdef"><b>Definition</b> neorv32_uart.h:45</div></div> +<div class="ttc" id="aneorv32__uart_8h_html_ad9f75f453beca1619344bb4213352afcaa219ea3ed5b21f5023bbc5ffa5c5f175"><div class="ttname"><a href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afcaa219ea3ed5b21f5023bbc5ffa5c5f175">UART_CTRL_IRQ_RX_HALF</a></div><div class="ttdeci">@ UART_CTRL_IRQ_RX_HALF</div><div class="ttdef"><b>Definition</b> neorv32_uart.h:66</div></div> +<div class="ttc" id="aneorv32__uart_8h_html_ad9f75f453beca1619344bb4213352afcac5c044233b6c4162cf862f3d9831ef46"><div class="ttname"><a href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afcac5c044233b6c4162cf862f3d9831ef46">UART_CTRL_TX_EMPTY</a></div><div class="ttdeci">@ UART_CTRL_TX_EMPTY</div><div class="ttdef"><b>Definition</b> neorv32_uart.h:61</div></div> +<div class="ttc" id="aneorv32__uart_8h_html_ad9f75f453beca1619344bb4213352afcacab78fcd440167c5a2c0f5d300c8f07c"><div class="ttname"><a href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afcacab78fcd440167c5a2c0f5d300c8f07c">UART_CTRL_HWFC_EN</a></div><div class="ttdeci">@ UART_CTRL_HWFC_EN</div><div class="ttdef"><b>Definition</b> neorv32_uart.h:43</div></div> +<div class="ttc" id="aneorv32__uart_8h_html_ad9f75f453beca1619344bb4213352afcad38432e7e050276d4667daf92c1e3fd5"><div class="ttname"><a href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afcad38432e7e050276d4667daf92c1e3fd5">UART_CTRL_BAUD0</a></div><div class="ttdeci">@ UART_CTRL_BAUD0</div><div class="ttdef"><b>Definition</b> neorv32_uart.h:47</div></div> +<div class="ttc" id="aneorv32__uart_8h_html_ad9f75f453beca1619344bb4213352afcae5f01868b170d71a5f3064023c96a82a"><div class="ttname"><a href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afcae5f01868b170d71a5f3064023c96a82a">UART_CTRL_IRQ_RX_FULL</a></div><div class="ttdeci">@ UART_CTRL_IRQ_RX_FULL</div><div class="ttdef"><b>Definition</b> neorv32_uart.h:67</div></div> +<div class="ttc" id="aneorv32__uart_8h_html_ad9f75f453beca1619344bb4213352afcaefbef37247d88a7e38e1c53b8a33ed33"><div class="ttname"><a href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afcaefbef37247d88a7e38e1c53b8a33ed33">UART_CTRL_RX_CLR</a></div><div class="ttdeci">@ UART_CTRL_RX_CLR</div><div class="ttdef"><b>Definition</b> neorv32_uart.h:71</div></div> +<div class="ttc" id="aneorv32__uart_8h_html_adcf35350a9ea18a59c32c35f528643f2"><div class="ttname"><a href="neorv32__uart_8h.html#adcf35350a9ea18a59c32c35f528643f2">NEORV32_UART_DATA_enum</a></div><div class="ttdeci">NEORV32_UART_DATA_enum</div><div class="ttdef"><b>Definition</b> neorv32_uart.h:78</div></div> +<div class="ttc" id="aneorv32__uart_8h_html_adcf35350a9ea18a59c32c35f528643f2a19926d013ca202645d38f2c704782ebb"><div class="ttname"><a href="neorv32__uart_8h.html#adcf35350a9ea18a59c32c35f528643f2a19926d013ca202645d38f2c704782ebb">UART_DATA_RTX_MSB</a></div><div class="ttdeci">@ UART_DATA_RTX_MSB</div><div class="ttdef"><b>Definition</b> neorv32_uart.h:80</div></div> +<div class="ttc" id="aneorv32__uart_8h_html_adcf35350a9ea18a59c32c35f528643f2a43b296e86d1f2ec7400d57655c3180ef"><div class="ttname"><a href="neorv32__uart_8h.html#adcf35350a9ea18a59c32c35f528643f2a43b296e86d1f2ec7400d57655c3180ef">UART_DATA_RX_FIFO_SIZE_LSB</a></div><div class="ttdeci">@ UART_DATA_RX_FIFO_SIZE_LSB</div><div class="ttdef"><b>Definition</b> neorv32_uart.h:82</div></div> +<div class="ttc" id="aneorv32__uart_8h_html_adcf35350a9ea18a59c32c35f528643f2a6d718ad0bb82a5cb053c117cd2d6ca8e"><div class="ttname"><a href="neorv32__uart_8h.html#adcf35350a9ea18a59c32c35f528643f2a6d718ad0bb82a5cb053c117cd2d6ca8e">UART_DATA_TX_FIFO_SIZE_LSB</a></div><div class="ttdeci">@ UART_DATA_TX_FIFO_SIZE_LSB</div><div class="ttdef"><b>Definition</b> neorv32_uart.h:85</div></div> +<div class="ttc" id="aneorv32__uart_8h_html_adcf35350a9ea18a59c32c35f528643f2a81a82ac0dc5c8c8d7af21553288e3225"><div class="ttname"><a href="neorv32__uart_8h.html#adcf35350a9ea18a59c32c35f528643f2a81a82ac0dc5c8c8d7af21553288e3225">UART_DATA_RX_FIFO_SIZE_MSB</a></div><div class="ttdeci">@ UART_DATA_RX_FIFO_SIZE_MSB</div><div class="ttdef"><b>Definition</b> neorv32_uart.h:83</div></div> +<div class="ttc" id="aneorv32__uart_8h_html_adcf35350a9ea18a59c32c35f528643f2ada92cbbe278e3e0592eba58c97699529"><div class="ttname"><a href="neorv32__uart_8h.html#adcf35350a9ea18a59c32c35f528643f2ada92cbbe278e3e0592eba58c97699529">UART_DATA_TX_FIFO_SIZE_MSB</a></div><div class="ttdeci">@ UART_DATA_TX_FIFO_SIZE_MSB</div><div class="ttdef"><b>Definition</b> neorv32_uart.h:86</div></div> +<div class="ttc" id="aneorv32__uart_8h_html_adcf35350a9ea18a59c32c35f528643f2ae70e9f6cd69af724932e79ea7e7f7195"><div class="ttname"><a href="neorv32__uart_8h.html#adcf35350a9ea18a59c32c35f528643f2ae70e9f6cd69af724932e79ea7e7f7195">UART_DATA_RTX_LSB</a></div><div class="ttdeci">@ UART_DATA_RTX_LSB</div><div class="ttdef"><b>Definition</b> neorv32_uart.h:79</div></div> +<div class="ttc" id="aneorv32__uart_8h_html_adedb0e07efb232717534017167a5be98"><div class="ttname"><a href="neorv32__uart_8h.html#adedb0e07efb232717534017167a5be98">neorv32_uart_char_received</a></div><div class="ttdeci">int neorv32_uart_char_received(neorv32_uart_t *UARTx)</div><div class="ttdef"><b>Definition</b> neorv32_uart.c:259</div></div> +<div class="ttc" id="aneorv32__uart_8h_html_ae18804ccd29ec2fd1cc06e9ce985b704"><div class="ttname"><a href="neorv32__uart_8h.html#ae18804ccd29ec2fd1cc06e9ce985b704">neorv32_uart_disable</a></div><div class="ttdeci">void neorv32_uart_disable(neorv32_uart_t *UARTx)</div><div class="ttdef"><b>Definition</b> neorv32_uart.c:151</div></div> +<div class="ttc" id="aneorv32__uart_8h_html_af85fb929c912d3edef3d86ffa833982a"><div class="ttname"><a href="neorv32__uart_8h.html#af85fb929c912d3edef3d86ffa833982a">neorv32_uart_get_rx_fifo_depth</a></div><div class="ttdeci">int neorv32_uart_get_rx_fifo_depth(neorv32_uart_t *UARTx)</div><div class="ttdef"><b>Definition</b> neorv32_uart.c:114</div></div> +<div class="ttc" id="aneorv32__uart_8h_html_afa0533e81d53057c36f4997a2dbbe2bc"><div class="ttname"><a href="neorv32__uart_8h.html#afa0533e81d53057c36f4997a2dbbe2bc">neorv32_uart_enable</a></div><div class="ttdeci">void neorv32_uart_enable(neorv32_uart_t *UARTx)</div><div class="ttdef"><b>Definition</b> neorv32_uart.c:140</div></div> +<div class="ttc" id="aneorv32__uart_8h_html_afe0de59c14faff1e0c890d5465be25f0"><div class="ttname"><a href="neorv32__uart_8h.html#afe0de59c14faff1e0c890d5465be25f0">neorv32_uart_rx_clear</a></div><div class="ttdeci">void neorv32_uart_rx_clear(neorv32_uart_t *UARTx)</div><div class="ttdef"><b>Definition</b> neorv32_uart.c:198</div></div> +<div class="ttc" id="astructneorv32__uart__t_html"><div class="ttname"><a href="structneorv32__uart__t.html">neorv32_uart_t</a></div><div class="ttdef"><b>Definition</b> neorv32_uart.h:28</div></div> +<div class="ttc" id="astructneorv32__uart__t_html_a0a6227aeea38335d2b9a9da46b35451b"><div class="ttname"><a href="structneorv32__uart__t.html#a0a6227aeea38335d2b9a9da46b35451b">neorv32_uart_t::CTRL</a></div><div class="ttdeci">uint32_t CTRL</div><div class="ttdef"><b>Definition</b> neorv32_uart.h:29</div></div> +<div class="ttc" id="astructneorv32__uart__t_html_a38eec82aae9ed522a0d2afb9a9560036"><div class="ttname"><a href="structneorv32__uart__t.html#a38eec82aae9ed522a0d2afb9a9560036">neorv32_uart_t::DATA</a></div><div class="ttdeci">uint32_t DATA</div><div class="ttdef"><b>Definition</b> neorv32_uart.h:30</div></div> +</div><!-- fragment --></div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/neorv32__wdt_8c.html b/sw/neorv32__wdt_8c.html new file mode 100644 index 0000000000..d1ed7617a7 --- /dev/null +++ b/sw/neorv32__wdt_8c.html @@ -0,0 +1,254 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/lib/source/neorv32_wdt.c File Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_7d04193005ada6f9450f847f4adb6b5b.html">lib</a></li><li class="navelem"><a class="el" href="dir_0c6ac14e2254a316d41123f98feeb67b.html">source</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#func-members">Functions</a> </div> + <div class="headertitle"><div class="title">neorv32_wdt.c File Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p>Direct Memory Access Controller (DMA) HW driver source file. +<a href="#details">More...</a></p> +<div class="textblock"><code>#include &quot;<a class="el" href="neorv32_8h_source.html">neorv32.h</a>&quot;</code><br /> +</div><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="func-members" name="func-members"></a> +Functions</h2></td></tr> +<tr class="memitem:a459a918c5a86c0167e8c748352d39827" id="r_a459a918c5a86c0167e8c748352d39827"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a459a918c5a86c0167e8c748352d39827">neorv32_wdt_available</a> (void)</td></tr> +<tr class="separator:a459a918c5a86c0167e8c748352d39827"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a2aa72608191d34ef41c5f545988ff400" id="r_a2aa72608191d34ef41c5f545988ff400"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a2aa72608191d34ef41c5f545988ff400">neorv32_wdt_setup</a> (uint32_t timeout, int lock, int debug_en, int sleep_en, int strict)</td></tr> +<tr class="separator:a2aa72608191d34ef41c5f545988ff400"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aba52520582392a671e2b717715a330b2" id="r_aba52520582392a671e2b717715a330b2"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aba52520582392a671e2b717715a330b2">neorv32_wdt_disable</a> (void)</td></tr> +<tr class="separator:aba52520582392a671e2b717715a330b2"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a2e4df2b352d11c31063ef2fc16c510ad" id="r_a2e4df2b352d11c31063ef2fc16c510ad"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a2e4df2b352d11c31063ef2fc16c510ad">neorv32_wdt_feed</a> (void)</td></tr> +<tr class="separator:a2e4df2b352d11c31063ef2fc16c510ad"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a80fa8d178d18c9b02d32d93e815b532e" id="r_a80fa8d178d18c9b02d32d93e815b532e"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a80fa8d178d18c9b02d32d93e815b532e">neorv32_wdt_get_cause</a> (void)</td></tr> +<tr class="separator:a80fa8d178d18c9b02d32d93e815b532e"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>Direct Memory Access Controller (DMA) HW driver source file. </p> +<p>Watchdog Timer (WDT) HW driver source file.</p> +<dl class="section note"><dt>Note</dt><dd>These functions should only be used if the DMA controller was synthesized (IO_DMA_EN = true).</dd></dl> +<dl class="section see"><dt>See also</dt><dd><a href="https://stnolting.github.io/neorv32/sw/files.html">https://stnolting.github.io/neorv32/sw/files.html</a></dd></dl> +<dl class="section note"><dt>Note</dt><dd>These functions should only be used if the WDT unit was synthesized (IO_WDT_EN = true).</dd></dl> +<dl class="section see"><dt>See also</dt><dd><a href="https://stnolting.github.io/neorv32/sw/files.html">https://stnolting.github.io/neorv32/sw/files.html</a> </dd></dl> +</div><h2 class="groupheader">Function Documentation</h2> +<a id="a459a918c5a86c0167e8c748352d39827" name="a459a918c5a86c0167e8c748352d39827"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a459a918c5a86c0167e8c748352d39827">&#9670;&#160;</a></span>neorv32_wdt_available()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_wdt_available </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Check if WDT unit was synthesized.</p> +<dl class="section return"><dt>Returns</dt><dd>0 if WDT was not synthesized, 1 if WDT is available. </dd></dl> + +</div> +</div> +<a id="aba52520582392a671e2b717715a330b2" name="aba52520582392a671e2b717715a330b2"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aba52520582392a671e2b717715a330b2">&#9670;&#160;</a></span>neorv32_wdt_disable()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_wdt_disable </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Disable watchdog timer.</p> +<dl class="section return"><dt>Returns</dt><dd>Returns 0 if WDT is really deactivated, -1 otherwise. </dd></dl> + +</div> +</div> +<a id="a2e4df2b352d11c31063ef2fc16c510ad" name="a2e4df2b352d11c31063ef2fc16c510ad"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a2e4df2b352d11c31063ef2fc16c510ad">&#9670;&#160;</a></span>neorv32_wdt_feed()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_wdt_feed </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Feed watchdog (reset timeout counter). </p> + +</div> +</div> +<a id="a80fa8d178d18c9b02d32d93e815b532e" name="a80fa8d178d18c9b02d32d93e815b532e"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a80fa8d178d18c9b02d32d93e815b532e">&#9670;&#160;</a></span>neorv32_wdt_get_cause()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_wdt_get_cause </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Get cause of last system reset.</p> +<dl class="section return"><dt>Returns</dt><dd>Cause of last reset (0: external reset, 1: OCD reset, 2: WDT reset). </dd></dl> + +</div> +</div> +<a id="a2aa72608191d34ef41c5f545988ff400" name="a2aa72608191d34ef41c5f545988ff400"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a2aa72608191d34ef41c5f545988ff400">&#9670;&#160;</a></span>neorv32_wdt_setup()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_wdt_setup </td> + <td>(</td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>timeout</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>lock</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>debug_en</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>sleep_en</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>strict</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Configure and enable watchdog timer. The WDT control register bits are listed in <a class="el" href="neorv32__wdt_8h.html#a0a4cb24fd818277c5bb9b10ff519f23e">NEORV32_WDT_CTRL_enum</a>.</p> +<dl class="section warning"><dt>Warning</dt><dd>Once the lock bit is set it can only be removed by a hardware reset!</dd></dl> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">timeout</td><td>24-bit timeout value. A WDT IRQ is triggered when the internal counter reaches 'timeout/2'. A system hardware reset is triggered when the internal counter reaches 'timeout'. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">lock</td><td>Control register will be locked when 1 (until next reset). </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">debug_en</td><td>Allow watchdog to continue operation even when CPU is in debug mode. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">sleep_en</td><td>Allow watchdog to continue operation even when CPU is in sleep mode. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">strict</td><td>Force hardware reset if reset password is incorrect. </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/neorv32__wdt_8h.html b/sw/neorv32__wdt_8h.html new file mode 100644 index 0000000000..a658384eaa --- /dev/null +++ b/sw/neorv32__wdt_8h.html @@ -0,0 +1,383 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/lib/include/neorv32_wdt.h File Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_7d04193005ada6f9450f847f4adb6b5b.html">lib</a></li><li class="navelem"><a class="el" href="dir_752b1e5d3973bf735fa78bf6b4727df9.html">include</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#nested-classes">Data Structures</a> &#124; +<a href="#define-members">Macros</a> &#124; +<a href="#enum-members">Enumerations</a> </div> + <div class="headertitle"><div class="title">neorv32_wdt.h File Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p>Watchdog Timer (WDT) HW driver header file. +<a href="#details">More...</a></p> +<div class="textblock"><code>#include &lt;stdint.h&gt;</code><br /> +</div> +<p><a href="neorv32__wdt_8h_source.html">Go to the source code of this file.</a></p> +<table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="nested-classes" name="nested-classes"></a> +Data Structures</h2></td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">struct &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structneorv32__wdt__t.html">neorv32_wdt_t</a></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="define-members" name="define-members"></a> +Macros</h2></td></tr> +<tr class="memitem:af2a2bd9c74bdba1b46bd92025bd00ab6" id="r_af2a2bd9c74bdba1b46bd92025bd00ab6"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#af2a2bd9c74bdba1b46bd92025bd00ab6">WDT_PASSWORD</a>&#160;&#160;&#160;(0x709D1AB3)</td></tr> +<tr class="separator:af2a2bd9c74bdba1b46bd92025bd00ab6"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="enum-members" name="enum-members"></a> +Enumerations</h2></td></tr> +<tr class="memitem:a70098b4ee893774864536fb4100ff049" id="r_a70098b4ee893774864536fb4100ff049"><td class="memItemLeft" align="right" valign="top">enum &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a70098b4ee893774864536fb4100ff049">NEORV32_WDT_RCAUSE_enum</a> { <a class="el" href="#a70098b4ee893774864536fb4100ff049ac5fc25cdc29c248b1a570b6095ddded0">WDT_RCAUSE_EXT</a> = 0b00 +, <a class="el" href="#a70098b4ee893774864536fb4100ff049a764a7797f17d82f619a6d30c0878bf1e">WDT_RCAUSE_OCD</a> = 0b01 +, <a class="el" href="#a70098b4ee893774864536fb4100ff049a974e73fb98b6a3591c214eba6071fd3c">WDT_RCAUSE_WDT</a> = 0b10 + }</td></tr> +<tr class="separator:a70098b4ee893774864536fb4100ff049"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="func-members" name="func-members"></a> +Functions</h2></td></tr> +<tr><td colspan="2"><div class="groupHeader">Prototypes</div></td></tr> +<tr class="memitem:a459a918c5a86c0167e8c748352d39827" id="r_a459a918c5a86c0167e8c748352d39827"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a459a918c5a86c0167e8c748352d39827">neorv32_wdt_available</a> (void)</td></tr> +<tr class="separator:a459a918c5a86c0167e8c748352d39827"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a2aa72608191d34ef41c5f545988ff400" id="r_a2aa72608191d34ef41c5f545988ff400"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a2aa72608191d34ef41c5f545988ff400">neorv32_wdt_setup</a> (uint32_t timeout, int lock, int debug_en, int sleep_en, int strict)</td></tr> +<tr class="separator:a2aa72608191d34ef41c5f545988ff400"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aba52520582392a671e2b717715a330b2" id="r_aba52520582392a671e2b717715a330b2"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aba52520582392a671e2b717715a330b2">neorv32_wdt_disable</a> (void)</td></tr> +<tr class="separator:aba52520582392a671e2b717715a330b2"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a2e4df2b352d11c31063ef2fc16c510ad" id="r_a2e4df2b352d11c31063ef2fc16c510ad"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a2e4df2b352d11c31063ef2fc16c510ad">neorv32_wdt_feed</a> (void)</td></tr> +<tr class="separator:a2e4df2b352d11c31063ef2fc16c510ad"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a80fa8d178d18c9b02d32d93e815b532e" id="r_a80fa8d178d18c9b02d32d93e815b532e"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a80fa8d178d18c9b02d32d93e815b532e">neorv32_wdt_get_cause</a> (void)</td></tr> +<tr class="separator:a80fa8d178d18c9b02d32d93e815b532e"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader">IO Device: Watchdog Timer (WDT)</h2></td></tr> +<tr class="memitem:a78615b08cd799063011606d084fef46c" id="r_a78615b08cd799063011606d084fef46c"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a78615b08cd799063011606d084fef46c">NEORV32_WDT</a>&#160;&#160;&#160;((<a class="el" href="structneorv32__wdt__t.html">neorv32_wdt_t</a>*) (<a class="el" href="neorv32_8h.html#a3012986cdd5748ee96bcc74cd7108dea">NEORV32_WDT_BASE</a>))</td></tr> +<tr class="separator:a78615b08cd799063011606d084fef46c"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a0a4cb24fd818277c5bb9b10ff519f23e" id="r_a0a4cb24fd818277c5bb9b10ff519f23e"><td class="memItemLeft" align="right" valign="top">enum &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a0a4cb24fd818277c5bb9b10ff519f23e">NEORV32_WDT_CTRL_enum</a> { <br /> +&#160;&#160;<a class="el" href="#a0a4cb24fd818277c5bb9b10ff519f23ea0e078b41b69bd6089acceb592e14553f">WDT_CTRL_EN</a> = 0 +, <a class="el" href="#a0a4cb24fd818277c5bb9b10ff519f23eadc44267502fceb8e7311dfa502fe54d3">WDT_CTRL_LOCK</a> = 1 +, <a class="el" href="#a0a4cb24fd818277c5bb9b10ff519f23ea4b0d994fe5ff8d8004c7f25b621fb3a9">WDT_CTRL_DBEN</a> = 2 +, <a class="el" href="#a0a4cb24fd818277c5bb9b10ff519f23ea7b7ea5bd390ecbb5ee0d9542ef124148">WDT_CTRL_SEN</a> = 3 +, <br /> +&#160;&#160;<a class="el" href="#a0a4cb24fd818277c5bb9b10ff519f23ea28dd25b66c4a50d0ea47a16c460031ac">WDT_CTRL_STRICT</a> = 4 +, <a class="el" href="#a0a4cb24fd818277c5bb9b10ff519f23ea0e7d3e97517f97042ce5606dd5247779">WDT_CTRL_RCAUSE_LO</a> = 5 +, <a class="el" href="#a0a4cb24fd818277c5bb9b10ff519f23ea6012d63ea4734fc8a063c9edc6785abd">WDT_CTRL_RCAUSE_HI</a> = 6 +, <a class="el" href="#a0a4cb24fd818277c5bb9b10ff519f23ea45df3c9100beb420add34bf71a0e8609">WDT_CTRL_TIMEOUT_LSB</a> = 8 +, <br /> +&#160;&#160;<a class="el" href="#a0a4cb24fd818277c5bb9b10ff519f23ea25dea2104b29a3c20dcc3782c2d43dc7">WDT_CTRL_TIMEOUT_MSB</a> = 31 +<br /> + }</td></tr> +<tr class="separator:a0a4cb24fd818277c5bb9b10ff519f23e"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>Watchdog Timer (WDT) HW driver header file. </p> +<dl class="section note"><dt>Note</dt><dd>These functions should only be used if the WDT unit was synthesized (IO_WDT_EN = true).</dd></dl> +<dl class="section see"><dt>See also</dt><dd><a href="https://stnolting.github.io/neorv32/sw/files.html">https://stnolting.github.io/neorv32/sw/files.html</a> </dd></dl> +</div><h2 class="groupheader">Macro Definition Documentation</h2> +<a id="a78615b08cd799063011606d084fef46c" name="a78615b08cd799063011606d084fef46c"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a78615b08cd799063011606d084fef46c">&#9670;&#160;</a></span>NEORV32_WDT</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define NEORV32_WDT&#160;&#160;&#160;((<a class="el" href="structneorv32__wdt__t.html">neorv32_wdt_t</a>*) (<a class="el" href="neorv32_8h.html#a3012986cdd5748ee96bcc74cd7108dea">NEORV32_WDT_BASE</a>))</td> + </tr> + </table> +</div><div class="memdoc"> +<p>WDT module hardware access (<a class="el" href="structneorv32__wdt__t.html">neorv32_wdt_t</a>) </p> + +</div> +</div> +<a id="af2a2bd9c74bdba1b46bd92025bd00ab6" name="af2a2bd9c74bdba1b46bd92025bd00ab6"></a> +<h2 class="memtitle"><span class="permalink"><a href="#af2a2bd9c74bdba1b46bd92025bd00ab6">&#9670;&#160;</a></span>WDT_PASSWORD</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define WDT_PASSWORD&#160;&#160;&#160;(0x709D1AB3)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Reset Password </p> + +</div> +</div> +<h2 class="groupheader">Enumeration Type Documentation</h2> +<a id="a0a4cb24fd818277c5bb9b10ff519f23e" name="a0a4cb24fd818277c5bb9b10ff519f23e"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a0a4cb24fd818277c5bb9b10ff519f23e">&#9670;&#160;</a></span>NEORV32_WDT_CTRL_enum</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">enum <a class="el" href="#a0a4cb24fd818277c5bb9b10ff519f23e">NEORV32_WDT_CTRL_enum</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>WDT control register bits </p> +<table class="fieldtable"> +<tr><th colspan="2">Enumerator</th></tr><tr><td class="fieldname"><a id="a0a4cb24fd818277c5bb9b10ff519f23ea0e078b41b69bd6089acceb592e14553f" name="a0a4cb24fd818277c5bb9b10ff519f23ea0e078b41b69bd6089acceb592e14553f"></a>WDT_CTRL_EN&#160;</td><td class="fielddoc"><p>WDT control register(0) (r/w): Watchdog enable </p> +</td></tr> +<tr><td class="fieldname"><a id="a0a4cb24fd818277c5bb9b10ff519f23eadc44267502fceb8e7311dfa502fe54d3" name="a0a4cb24fd818277c5bb9b10ff519f23eadc44267502fceb8e7311dfa502fe54d3"></a>WDT_CTRL_LOCK&#160;</td><td class="fielddoc"><p>WDT control register(1) (r/w): Lock write access to control register, clears on reset only </p> +</td></tr> +<tr><td class="fieldname"><a id="a0a4cb24fd818277c5bb9b10ff519f23ea4b0d994fe5ff8d8004c7f25b621fb3a9" name="a0a4cb24fd818277c5bb9b10ff519f23ea4b0d994fe5ff8d8004c7f25b621fb3a9"></a>WDT_CTRL_DBEN&#160;</td><td class="fielddoc"><p>WDT control register(2) (r/w): Allow WDT to continue operation even when CPU is in debug mode </p> +</td></tr> +<tr><td class="fieldname"><a id="a0a4cb24fd818277c5bb9b10ff519f23ea7b7ea5bd390ecbb5ee0d9542ef124148" name="a0a4cb24fd818277c5bb9b10ff519f23ea7b7ea5bd390ecbb5ee0d9542ef124148"></a>WDT_CTRL_SEN&#160;</td><td class="fielddoc"><p>WDT control register(3) (r/w): Allow WDT to continue operation even when CPU is in sleep mode </p> +</td></tr> +<tr><td class="fieldname"><a id="a0a4cb24fd818277c5bb9b10ff519f23ea28dd25b66c4a50d0ea47a16c460031ac" name="a0a4cb24fd818277c5bb9b10ff519f23ea28dd25b66c4a50d0ea47a16c460031ac"></a>WDT_CTRL_STRICT&#160;</td><td class="fielddoc"><p>WDT control register(4) (r/w): Force hardware reset if reset password is incorrect or if write attempt to locked CTRL register </p> +</td></tr> +<tr><td class="fieldname"><a id="a0a4cb24fd818277c5bb9b10ff519f23ea0e7d3e97517f97042ce5606dd5247779" name="a0a4cb24fd818277c5bb9b10ff519f23ea0e7d3e97517f97042ce5606dd5247779"></a>WDT_CTRL_RCAUSE_LO&#160;</td><td class="fielddoc"><p>WDT control register(5) (r/-): Cause of last system reset - low </p> +</td></tr> +<tr><td class="fieldname"><a id="a0a4cb24fd818277c5bb9b10ff519f23ea6012d63ea4734fc8a063c9edc6785abd" name="a0a4cb24fd818277c5bb9b10ff519f23ea6012d63ea4734fc8a063c9edc6785abd"></a>WDT_CTRL_RCAUSE_HI&#160;</td><td class="fielddoc"><p>WDT control register(5) (r/-): Cause of last system reset - high </p> +</td></tr> +<tr><td class="fieldname"><a id="a0a4cb24fd818277c5bb9b10ff519f23ea45df3c9100beb420add34bf71a0e8609" name="a0a4cb24fd818277c5bb9b10ff519f23ea45df3c9100beb420add34bf71a0e8609"></a>WDT_CTRL_TIMEOUT_LSB&#160;</td><td class="fielddoc"><p>WDT control register(8) (r/w): Timeout value, LSB </p> +</td></tr> +<tr><td class="fieldname"><a id="a0a4cb24fd818277c5bb9b10ff519f23ea25dea2104b29a3c20dcc3782c2d43dc7" name="a0a4cb24fd818277c5bb9b10ff519f23ea25dea2104b29a3c20dcc3782c2d43dc7"></a>WDT_CTRL_TIMEOUT_MSB&#160;</td><td class="fielddoc"><p>WDT control register(31) (r/w): Timeout value, MSB </p> +</td></tr> +</table> + +</div> +</div> +<a id="a70098b4ee893774864536fb4100ff049" name="a70098b4ee893774864536fb4100ff049"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a70098b4ee893774864536fb4100ff049">&#9670;&#160;</a></span>NEORV32_WDT_RCAUSE_enum</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">enum <a class="el" href="#a70098b4ee893774864536fb4100ff049">NEORV32_WDT_RCAUSE_enum</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Reset Cause </p> +<table class="fieldtable"> +<tr><th colspan="2">Enumerator</th></tr><tr><td class="fieldname"><a id="a70098b4ee893774864536fb4100ff049ac5fc25cdc29c248b1a570b6095ddded0" name="a70098b4ee893774864536fb4100ff049ac5fc25cdc29c248b1a570b6095ddded0"></a>WDT_RCAUSE_EXT&#160;</td><td class="fielddoc"><p>Reset caused by external signal/pin </p> +</td></tr> +<tr><td class="fieldname"><a id="a70098b4ee893774864536fb4100ff049a764a7797f17d82f619a6d30c0878bf1e" name="a70098b4ee893774864536fb4100ff049a764a7797f17d82f619a6d30c0878bf1e"></a>WDT_RCAUSE_OCD&#160;</td><td class="fielddoc"><p>Reset caused by on-chip debugger </p> +</td></tr> +<tr><td class="fieldname"><a id="a70098b4ee893774864536fb4100ff049a974e73fb98b6a3591c214eba6071fd3c" name="a70098b4ee893774864536fb4100ff049a974e73fb98b6a3591c214eba6071fd3c"></a>WDT_RCAUSE_WDT&#160;</td><td class="fielddoc"><p>Reset caused by watchdog timer </p> +</td></tr> +</table> + +</div> +</div> +<h2 class="groupheader">Function Documentation</h2> +<a id="a459a918c5a86c0167e8c748352d39827" name="a459a918c5a86c0167e8c748352d39827"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a459a918c5a86c0167e8c748352d39827">&#9670;&#160;</a></span>neorv32_wdt_available()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_wdt_available </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Check if WDT unit was synthesized.</p> +<dl class="section return"><dt>Returns</dt><dd>0 if WDT was not synthesized, 1 if WDT is available. </dd></dl> + +</div> +</div> +<a id="aba52520582392a671e2b717715a330b2" name="aba52520582392a671e2b717715a330b2"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aba52520582392a671e2b717715a330b2">&#9670;&#160;</a></span>neorv32_wdt_disable()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_wdt_disable </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Disable watchdog timer.</p> +<dl class="section return"><dt>Returns</dt><dd>Returns 0 if WDT is really deactivated, -1 otherwise. </dd></dl> + +</div> +</div> +<a id="a2e4df2b352d11c31063ef2fc16c510ad" name="a2e4df2b352d11c31063ef2fc16c510ad"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a2e4df2b352d11c31063ef2fc16c510ad">&#9670;&#160;</a></span>neorv32_wdt_feed()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_wdt_feed </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Feed watchdog (reset timeout counter). </p> + +</div> +</div> +<a id="a80fa8d178d18c9b02d32d93e815b532e" name="a80fa8d178d18c9b02d32d93e815b532e"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a80fa8d178d18c9b02d32d93e815b532e">&#9670;&#160;</a></span>neorv32_wdt_get_cause()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_wdt_get_cause </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Get cause of last system reset.</p> +<dl class="section return"><dt>Returns</dt><dd>Cause of last reset (0: external reset, 1: OCD reset, 2: WDT reset). </dd></dl> + +</div> +</div> +<a id="a2aa72608191d34ef41c5f545988ff400" name="a2aa72608191d34ef41c5f545988ff400"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a2aa72608191d34ef41c5f545988ff400">&#9670;&#160;</a></span>neorv32_wdt_setup()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_wdt_setup </td> + <td>(</td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>timeout</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>lock</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>debug_en</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>sleep_en</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>strict</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Configure and enable watchdog timer. The WDT control register bits are listed in <a class="el" href="#a0a4cb24fd818277c5bb9b10ff519f23e">NEORV32_WDT_CTRL_enum</a>.</p> +<dl class="section warning"><dt>Warning</dt><dd>Once the lock bit is set it can only be removed by a hardware reset!</dd></dl> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">timeout</td><td>24-bit timeout value. A WDT IRQ is triggered when the internal counter reaches 'timeout/2'. A system hardware reset is triggered when the internal counter reaches 'timeout'. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">lock</td><td>Control register will be locked when 1 (until next reset). </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">debug_en</td><td>Allow watchdog to continue operation even when CPU is in debug mode. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">sleep_en</td><td>Allow watchdog to continue operation even when CPU is in sleep mode. </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">strict</td><td>Force hardware reset if reset password is incorrect. </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/neorv32__wdt_8h_source.html b/sw/neorv32__wdt_8h_source.html new file mode 100644 index 0000000000..fec1a6895c --- /dev/null +++ b/sw/neorv32__wdt_8h_source.html @@ -0,0 +1,183 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/lib/include/neorv32_wdt.h Source File</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_7d04193005ada6f9450f847f4adb6b5b.html">lib</a></li><li class="navelem"><a class="el" href="dir_752b1e5d3973bf735fa78bf6b4727df9.html">include</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="headertitle"><div class="title">neorv32_wdt.h</div></div> +</div><!--header--> +<div class="contents"> +<a href="neorv32__wdt_8h.html">Go to the documentation of this file.</a><div class="fragment"><div class="line"><a id="l00001" name="l00001"></a><span class="lineno"> 1</span><span class="comment">// ================================================================================ //</span></div> +<div class="line"><a id="l00002" name="l00002"></a><span class="lineno"> 2</span><span class="comment">// The NEORV32 RISC-V Processor - https://github.com/stnolting/neorv32 //</span></div> +<div class="line"><a id="l00003" name="l00003"></a><span class="lineno"> 3</span><span class="comment">// Copyright (c) NEORV32 contributors. //</span></div> +<div class="line"><a id="l00004" name="l00004"></a><span class="lineno"> 4</span><span class="comment">// Copyright (c) 2020 - 2024 Stephan Nolting. All rights reserved. //</span></div> +<div class="line"><a id="l00005" name="l00005"></a><span class="lineno"> 5</span><span class="comment">// Licensed under the BSD-3-Clause license, see LICENSE for details. //</span></div> +<div class="line"><a id="l00006" name="l00006"></a><span class="lineno"> 6</span><span class="comment">// SPDX-License-Identifier: BSD-3-Clause //</span></div> +<div class="line"><a id="l00007" name="l00007"></a><span class="lineno"> 7</span><span class="comment">// ================================================================================ //</span></div> +<div class="line"><a id="l00008" name="l00008"></a><span class="lineno"> 8</span> </div> +<div class="line"><a id="l00018" name="l00018"></a><span class="lineno"> 18</span><span class="preprocessor">#ifndef neorv32_wdt_h</span></div> +<div class="line"><a id="l00019" name="l00019"></a><span class="lineno"> 19</span><span class="preprocessor">#define neorv32_wdt_h</span></div> +<div class="line"><a id="l00020" name="l00020"></a><span class="lineno"> 20</span> </div> +<div class="line"><a id="l00021" name="l00021"></a><span class="lineno"> 21</span><span class="preprocessor">#include &lt;stdint.h&gt;</span></div> +<div class="line"><a id="l00022" name="l00022"></a><span class="lineno"> 22</span> </div> +<div class="line"><a id="l00023" name="l00023"></a><span class="lineno"> 23</span> </div> +<div class="line"><a id="l00024" name="l00024"></a><span class="lineno"> 24</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen00029" data-start="{" data-end="};"> +<div class="line"><a id="l00029" name="l00029"></a><span class="lineno"><a class="line" href="structneorv32__wdt__t.html"> 29</a></span><span class="keyword">typedef</span> <span class="keyword">volatile</span> <span class="keyword">struct </span>__attribute__((packed,aligned(4))) {</div> +<div class="line"><a id="l00030" name="l00030"></a><span class="lineno"><a class="line" href="structneorv32__wdt__t.html#a6ae41e28d08b0f06118c499f52b56f41"> 30</a></span> uint32_t <a class="code hl_variable" href="structneorv32__wdt__t.html#a6ae41e28d08b0f06118c499f52b56f41">CTRL</a>; </div> +<div class="line"><a id="l00031" name="l00031"></a><span class="lineno"><a class="line" href="structneorv32__wdt__t.html#a0a273e8ca2bd92547bf7727ec65a9449"> 31</a></span> uint32_t <a class="code hl_variable" href="structneorv32__wdt__t.html#a0a273e8ca2bd92547bf7727ec65a9449">RESET</a>; </div> +<div class="line"><a id="l00032" name="l00032"></a><span class="lineno"> 32</span>} <a class="code hl_struct" href="structneorv32__wdt__t.html">neorv32_wdt_t</a>;</div> +</div> +<div class="line"><a id="l00033" name="l00033"></a><span class="lineno"> 33</span> </div> +<div class="line"><a id="l00035" name="l00035"></a><span class="lineno"><a class="line" href="neorv32__wdt_8h.html#a78615b08cd799063011606d084fef46c"> 35</a></span><span class="preprocessor">#define NEORV32_WDT ((neorv32_wdt_t*) (NEORV32_WDT_BASE))</span></div> +<div class="line"><a id="l00036" name="l00036"></a><span class="lineno"> 36</span> </div> +<div class="foldopen" id="foldopen00038" data-start="{" data-end="};"> +<div class="line"><a id="l00038" name="l00038"></a><span class="lineno"><a class="line" href="neorv32__wdt_8h.html#a0a4cb24fd818277c5bb9b10ff519f23e"> 38</a></span><span class="keyword">enum</span> <a class="code hl_enumeration" href="neorv32__wdt_8h.html#a0a4cb24fd818277c5bb9b10ff519f23e">NEORV32_WDT_CTRL_enum</a> {</div> +<div class="line"><a id="l00039" name="l00039"></a><span class="lineno"><a class="line" href="neorv32__wdt_8h.html#a0a4cb24fd818277c5bb9b10ff519f23ea0e078b41b69bd6089acceb592e14553f"> 39</a></span> <a class="code hl_enumvalue" href="neorv32__wdt_8h.html#a0a4cb24fd818277c5bb9b10ff519f23ea0e078b41b69bd6089acceb592e14553f">WDT_CTRL_EN</a> = 0, </div> +<div class="line"><a id="l00040" name="l00040"></a><span class="lineno"><a class="line" href="neorv32__wdt_8h.html#a0a4cb24fd818277c5bb9b10ff519f23eadc44267502fceb8e7311dfa502fe54d3"> 40</a></span> <a class="code hl_enumvalue" href="neorv32__wdt_8h.html#a0a4cb24fd818277c5bb9b10ff519f23eadc44267502fceb8e7311dfa502fe54d3">WDT_CTRL_LOCK</a> = 1, </div> +<div class="line"><a id="l00041" name="l00041"></a><span class="lineno"><a class="line" href="neorv32__wdt_8h.html#a0a4cb24fd818277c5bb9b10ff519f23ea4b0d994fe5ff8d8004c7f25b621fb3a9"> 41</a></span> <a class="code hl_enumvalue" href="neorv32__wdt_8h.html#a0a4cb24fd818277c5bb9b10ff519f23ea4b0d994fe5ff8d8004c7f25b621fb3a9">WDT_CTRL_DBEN</a> = 2, </div> +<div class="line"><a id="l00042" name="l00042"></a><span class="lineno"><a class="line" href="neorv32__wdt_8h.html#a0a4cb24fd818277c5bb9b10ff519f23ea7b7ea5bd390ecbb5ee0d9542ef124148"> 42</a></span> <a class="code hl_enumvalue" href="neorv32__wdt_8h.html#a0a4cb24fd818277c5bb9b10ff519f23ea7b7ea5bd390ecbb5ee0d9542ef124148">WDT_CTRL_SEN</a> = 3, </div> +<div class="line"><a id="l00043" name="l00043"></a><span class="lineno"><a class="line" href="neorv32__wdt_8h.html#a0a4cb24fd818277c5bb9b10ff519f23ea28dd25b66c4a50d0ea47a16c460031ac"> 43</a></span> <a class="code hl_enumvalue" href="neorv32__wdt_8h.html#a0a4cb24fd818277c5bb9b10ff519f23ea28dd25b66c4a50d0ea47a16c460031ac">WDT_CTRL_STRICT</a> = 4, </div> +<div class="line"><a id="l00044" name="l00044"></a><span class="lineno"><a class="line" href="neorv32__wdt_8h.html#a0a4cb24fd818277c5bb9b10ff519f23ea0e7d3e97517f97042ce5606dd5247779"> 44</a></span> <a class="code hl_enumvalue" href="neorv32__wdt_8h.html#a0a4cb24fd818277c5bb9b10ff519f23ea0e7d3e97517f97042ce5606dd5247779">WDT_CTRL_RCAUSE_LO</a> = 5, </div> +<div class="line"><a id="l00045" name="l00045"></a><span class="lineno"><a class="line" href="neorv32__wdt_8h.html#a0a4cb24fd818277c5bb9b10ff519f23ea6012d63ea4734fc8a063c9edc6785abd"> 45</a></span> <a class="code hl_enumvalue" href="neorv32__wdt_8h.html#a0a4cb24fd818277c5bb9b10ff519f23ea6012d63ea4734fc8a063c9edc6785abd">WDT_CTRL_RCAUSE_HI</a> = 6, </div> +<div class="line"><a id="l00047" name="l00047"></a><span class="lineno"><a class="line" href="neorv32__wdt_8h.html#a0a4cb24fd818277c5bb9b10ff519f23ea45df3c9100beb420add34bf71a0e8609"> 47</a></span> <a class="code hl_enumvalue" href="neorv32__wdt_8h.html#a0a4cb24fd818277c5bb9b10ff519f23ea45df3c9100beb420add34bf71a0e8609">WDT_CTRL_TIMEOUT_LSB</a> = 8, </div> +<div class="line"><a id="l00048" name="l00048"></a><span class="lineno"> 48</span> <a class="code hl_enumvalue" href="neorv32__wdt_8h.html#a0a4cb24fd818277c5bb9b10ff519f23ea25dea2104b29a3c20dcc3782c2d43dc7">WDT_CTRL_TIMEOUT_MSB</a> = 31 </div> +<div class="line"><a id="l00049" name="l00049"></a><span class="lineno"><a class="line" href="neorv32__wdt_8h.html#a0a4cb24fd818277c5bb9b10ff519f23ea25dea2104b29a3c20dcc3782c2d43dc7"> 49</a></span>};</div> +</div> +<div class="line"><a id="l00053" name="l00053"></a><span class="lineno"> 53</span><span class="comment">/**********************************************************************/</span></div> +<div class="line"><a id="l00056" name="l00056"></a><span class="lineno"><a class="line" href="neorv32__wdt_8h.html#af2a2bd9c74bdba1b46bd92025bd00ab6"> 56</a></span><span class="preprocessor">#define WDT_PASSWORD (0x709D1AB3)</span></div> +<div class="line"><a id="l00057" name="l00057"></a><span class="lineno"> 57</span> </div> +<div class="line"><a id="l00058" name="l00058"></a><span class="lineno"> 58</span> </div> +<div class="line"><a id="l00059" name="l00059"></a><span class="lineno"> 59</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen00062" data-start="{" data-end="};"> +<div class="line"><a id="l00062" name="l00062"></a><span class="lineno"><a class="line" href="neorv32__wdt_8h.html#a70098b4ee893774864536fb4100ff049"> 62</a></span><span class="keyword">enum</span> <a class="code hl_enumeration" href="neorv32__wdt_8h.html#a70098b4ee893774864536fb4100ff049">NEORV32_WDT_RCAUSE_enum</a> {</div> +<div class="line"><a id="l00063" name="l00063"></a><span class="lineno"><a class="line" href="neorv32__wdt_8h.html#a70098b4ee893774864536fb4100ff049ac5fc25cdc29c248b1a570b6095ddded0"> 63</a></span> <a class="code hl_enumvalue" href="neorv32__wdt_8h.html#a70098b4ee893774864536fb4100ff049ac5fc25cdc29c248b1a570b6095ddded0">WDT_RCAUSE_EXT</a> = 0b00, </div> +<div class="line"><a id="l00064" name="l00064"></a><span class="lineno"><a class="line" href="neorv32__wdt_8h.html#a70098b4ee893774864536fb4100ff049a764a7797f17d82f619a6d30c0878bf1e"> 64</a></span> <a class="code hl_enumvalue" href="neorv32__wdt_8h.html#a70098b4ee893774864536fb4100ff049a764a7797f17d82f619a6d30c0878bf1e">WDT_RCAUSE_OCD</a> = 0b01, </div> +<div class="line"><a id="l00065" name="l00065"></a><span class="lineno"> 65</span> <a class="code hl_enumvalue" href="neorv32__wdt_8h.html#a70098b4ee893774864536fb4100ff049a974e73fb98b6a3591c214eba6071fd3c">WDT_RCAUSE_WDT</a> = 0b10 </div> +<div class="line"><a id="l00066" name="l00066"></a><span class="lineno"><a class="line" href="neorv32__wdt_8h.html#a70098b4ee893774864536fb4100ff049a974e73fb98b6a3591c214eba6071fd3c"> 66</a></span>};</div> +</div> +<div class="line"><a id="l00067" name="l00067"></a><span class="lineno"> 67</span> </div> +<div class="line"><a id="l00068" name="l00068"></a><span class="lineno"> 68</span> </div> +<div class="line"><a id="l00069" name="l00069"></a><span class="lineno"> 69</span><span class="comment">/**********************************************************************/</span></div> +<div class="line"><a id="l00073" name="l00073"></a><span class="lineno"> 73</span><span class="keywordtype">int</span> <a class="code hl_function" href="neorv32__wdt_8h.html#a459a918c5a86c0167e8c748352d39827">neorv32_wdt_available</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00074" name="l00074"></a><span class="lineno"> 74</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__wdt_8h.html#a2aa72608191d34ef41c5f545988ff400">neorv32_wdt_setup</a>(uint32_t timeout, <span class="keywordtype">int</span> lock, <span class="keywordtype">int</span> debug_en, <span class="keywordtype">int</span> sleep_en, <span class="keywordtype">int</span> strict);</div> +<div class="line"><a id="l00075" name="l00075"></a><span class="lineno"> 75</span><span class="keywordtype">int</span> <a class="code hl_function" href="neorv32__wdt_8h.html#aba52520582392a671e2b717715a330b2">neorv32_wdt_disable</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00076" name="l00076"></a><span class="lineno"> 76</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__wdt_8h.html#a2e4df2b352d11c31063ef2fc16c510ad">neorv32_wdt_feed</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00077" name="l00077"></a><span class="lineno"> 77</span><span class="keywordtype">int</span> <a class="code hl_function" href="neorv32__wdt_8h.html#a80fa8d178d18c9b02d32d93e815b532e">neorv32_wdt_get_cause</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00081" name="l00081"></a><span class="lineno"> 81</span><span class="preprocessor">#endif </span><span class="comment">// neorv32_wdt_h</span></div> +<div class="ttc" id="aneorv32__wdt_8h_html_a0a4cb24fd818277c5bb9b10ff519f23e"><div class="ttname"><a href="neorv32__wdt_8h.html#a0a4cb24fd818277c5bb9b10ff519f23e">NEORV32_WDT_CTRL_enum</a></div><div class="ttdeci">NEORV32_WDT_CTRL_enum</div><div class="ttdef"><b>Definition</b> neorv32_wdt.h:38</div></div> +<div class="ttc" id="aneorv32__wdt_8h_html_a0a4cb24fd818277c5bb9b10ff519f23ea0e078b41b69bd6089acceb592e14553f"><div class="ttname"><a href="neorv32__wdt_8h.html#a0a4cb24fd818277c5bb9b10ff519f23ea0e078b41b69bd6089acceb592e14553f">WDT_CTRL_EN</a></div><div class="ttdeci">@ WDT_CTRL_EN</div><div class="ttdef"><b>Definition</b> neorv32_wdt.h:39</div></div> +<div class="ttc" id="aneorv32__wdt_8h_html_a0a4cb24fd818277c5bb9b10ff519f23ea0e7d3e97517f97042ce5606dd5247779"><div class="ttname"><a href="neorv32__wdt_8h.html#a0a4cb24fd818277c5bb9b10ff519f23ea0e7d3e97517f97042ce5606dd5247779">WDT_CTRL_RCAUSE_LO</a></div><div class="ttdeci">@ WDT_CTRL_RCAUSE_LO</div><div class="ttdef"><b>Definition</b> neorv32_wdt.h:44</div></div> +<div class="ttc" id="aneorv32__wdt_8h_html_a0a4cb24fd818277c5bb9b10ff519f23ea25dea2104b29a3c20dcc3782c2d43dc7"><div class="ttname"><a href="neorv32__wdt_8h.html#a0a4cb24fd818277c5bb9b10ff519f23ea25dea2104b29a3c20dcc3782c2d43dc7">WDT_CTRL_TIMEOUT_MSB</a></div><div class="ttdeci">@ WDT_CTRL_TIMEOUT_MSB</div><div class="ttdef"><b>Definition</b> neorv32_wdt.h:48</div></div> +<div class="ttc" id="aneorv32__wdt_8h_html_a0a4cb24fd818277c5bb9b10ff519f23ea28dd25b66c4a50d0ea47a16c460031ac"><div class="ttname"><a href="neorv32__wdt_8h.html#a0a4cb24fd818277c5bb9b10ff519f23ea28dd25b66c4a50d0ea47a16c460031ac">WDT_CTRL_STRICT</a></div><div class="ttdeci">@ WDT_CTRL_STRICT</div><div class="ttdef"><b>Definition</b> neorv32_wdt.h:43</div></div> +<div class="ttc" id="aneorv32__wdt_8h_html_a0a4cb24fd818277c5bb9b10ff519f23ea45df3c9100beb420add34bf71a0e8609"><div class="ttname"><a href="neorv32__wdt_8h.html#a0a4cb24fd818277c5bb9b10ff519f23ea45df3c9100beb420add34bf71a0e8609">WDT_CTRL_TIMEOUT_LSB</a></div><div class="ttdeci">@ WDT_CTRL_TIMEOUT_LSB</div><div class="ttdef"><b>Definition</b> neorv32_wdt.h:47</div></div> +<div class="ttc" id="aneorv32__wdt_8h_html_a0a4cb24fd818277c5bb9b10ff519f23ea4b0d994fe5ff8d8004c7f25b621fb3a9"><div class="ttname"><a href="neorv32__wdt_8h.html#a0a4cb24fd818277c5bb9b10ff519f23ea4b0d994fe5ff8d8004c7f25b621fb3a9">WDT_CTRL_DBEN</a></div><div class="ttdeci">@ WDT_CTRL_DBEN</div><div class="ttdef"><b>Definition</b> neorv32_wdt.h:41</div></div> +<div class="ttc" id="aneorv32__wdt_8h_html_a0a4cb24fd818277c5bb9b10ff519f23ea6012d63ea4734fc8a063c9edc6785abd"><div class="ttname"><a href="neorv32__wdt_8h.html#a0a4cb24fd818277c5bb9b10ff519f23ea6012d63ea4734fc8a063c9edc6785abd">WDT_CTRL_RCAUSE_HI</a></div><div class="ttdeci">@ WDT_CTRL_RCAUSE_HI</div><div class="ttdef"><b>Definition</b> neorv32_wdt.h:45</div></div> +<div class="ttc" id="aneorv32__wdt_8h_html_a0a4cb24fd818277c5bb9b10ff519f23ea7b7ea5bd390ecbb5ee0d9542ef124148"><div class="ttname"><a href="neorv32__wdt_8h.html#a0a4cb24fd818277c5bb9b10ff519f23ea7b7ea5bd390ecbb5ee0d9542ef124148">WDT_CTRL_SEN</a></div><div class="ttdeci">@ WDT_CTRL_SEN</div><div class="ttdef"><b>Definition</b> neorv32_wdt.h:42</div></div> +<div class="ttc" id="aneorv32__wdt_8h_html_a0a4cb24fd818277c5bb9b10ff519f23eadc44267502fceb8e7311dfa502fe54d3"><div class="ttname"><a href="neorv32__wdt_8h.html#a0a4cb24fd818277c5bb9b10ff519f23eadc44267502fceb8e7311dfa502fe54d3">WDT_CTRL_LOCK</a></div><div class="ttdeci">@ WDT_CTRL_LOCK</div><div class="ttdef"><b>Definition</b> neorv32_wdt.h:40</div></div> +<div class="ttc" id="aneorv32__wdt_8h_html_a2aa72608191d34ef41c5f545988ff400"><div class="ttname"><a href="neorv32__wdt_8h.html#a2aa72608191d34ef41c5f545988ff400">neorv32_wdt_setup</a></div><div class="ttdeci">void neorv32_wdt_setup(uint32_t timeout, int lock, int debug_en, int sleep_en, int strict)</div><div class="ttdef"><b>Definition</b> neorv32_wdt.c:49</div></div> +<div class="ttc" id="aneorv32__wdt_8h_html_a2e4df2b352d11c31063ef2fc16c510ad"><div class="ttname"><a href="neorv32__wdt_8h.html#a2e4df2b352d11c31063ef2fc16c510ad">neorv32_wdt_feed</a></div><div class="ttdeci">void neorv32_wdt_feed(void)</div><div class="ttdef"><b>Definition</b> neorv32_wdt.c:93</div></div> +<div class="ttc" id="aneorv32__wdt_8h_html_a459a918c5a86c0167e8c748352d39827"><div class="ttname"><a href="neorv32__wdt_8h.html#a459a918c5a86c0167e8c748352d39827">neorv32_wdt_available</a></div><div class="ttdeci">int neorv32_wdt_available(void)</div><div class="ttdef"><b>Definition</b> neorv32_wdt.c:26</div></div> +<div class="ttc" id="aneorv32__wdt_8h_html_a70098b4ee893774864536fb4100ff049"><div class="ttname"><a href="neorv32__wdt_8h.html#a70098b4ee893774864536fb4100ff049">NEORV32_WDT_RCAUSE_enum</a></div><div class="ttdeci">NEORV32_WDT_RCAUSE_enum</div><div class="ttdef"><b>Definition</b> neorv32_wdt.h:62</div></div> +<div class="ttc" id="aneorv32__wdt_8h_html_a70098b4ee893774864536fb4100ff049a764a7797f17d82f619a6d30c0878bf1e"><div class="ttname"><a href="neorv32__wdt_8h.html#a70098b4ee893774864536fb4100ff049a764a7797f17d82f619a6d30c0878bf1e">WDT_RCAUSE_OCD</a></div><div class="ttdeci">@ WDT_RCAUSE_OCD</div><div class="ttdef"><b>Definition</b> neorv32_wdt.h:64</div></div> +<div class="ttc" id="aneorv32__wdt_8h_html_a70098b4ee893774864536fb4100ff049a974e73fb98b6a3591c214eba6071fd3c"><div class="ttname"><a href="neorv32__wdt_8h.html#a70098b4ee893774864536fb4100ff049a974e73fb98b6a3591c214eba6071fd3c">WDT_RCAUSE_WDT</a></div><div class="ttdeci">@ WDT_RCAUSE_WDT</div><div class="ttdef"><b>Definition</b> neorv32_wdt.h:65</div></div> +<div class="ttc" id="aneorv32__wdt_8h_html_a70098b4ee893774864536fb4100ff049ac5fc25cdc29c248b1a570b6095ddded0"><div class="ttname"><a href="neorv32__wdt_8h.html#a70098b4ee893774864536fb4100ff049ac5fc25cdc29c248b1a570b6095ddded0">WDT_RCAUSE_EXT</a></div><div class="ttdeci">@ WDT_RCAUSE_EXT</div><div class="ttdef"><b>Definition</b> neorv32_wdt.h:63</div></div> +<div class="ttc" id="aneorv32__wdt_8h_html_a80fa8d178d18c9b02d32d93e815b532e"><div class="ttname"><a href="neorv32__wdt_8h.html#a80fa8d178d18c9b02d32d93e815b532e">neorv32_wdt_get_cause</a></div><div class="ttdeci">int neorv32_wdt_get_cause(void)</div><div class="ttdef"><b>Definition</b> neorv32_wdt.c:104</div></div> +<div class="ttc" id="aneorv32__wdt_8h_html_aba52520582392a671e2b717715a330b2"><div class="ttname"><a href="neorv32__wdt_8h.html#aba52520582392a671e2b717715a330b2">neorv32_wdt_disable</a></div><div class="ttdeci">int neorv32_wdt_disable(void)</div><div class="ttdef"><b>Definition</b> neorv32_wdt.c:74</div></div> +<div class="ttc" id="astructneorv32__wdt__t_html"><div class="ttname"><a href="structneorv32__wdt__t.html">neorv32_wdt_t</a></div><div class="ttdef"><b>Definition</b> neorv32_wdt.h:29</div></div> +<div class="ttc" id="astructneorv32__wdt__t_html_a0a273e8ca2bd92547bf7727ec65a9449"><div class="ttname"><a href="structneorv32__wdt__t.html#a0a273e8ca2bd92547bf7727ec65a9449">neorv32_wdt_t::RESET</a></div><div class="ttdeci">uint32_t RESET</div><div class="ttdef"><b>Definition</b> neorv32_wdt.h:31</div></div> +<div class="ttc" id="astructneorv32__wdt__t_html_a6ae41e28d08b0f06118c499f52b56f41"><div class="ttname"><a href="structneorv32__wdt__t.html#a6ae41e28d08b0f06118c499f52b56f41">neorv32_wdt_t::CTRL</a></div><div class="ttdeci">uint32_t CTRL</div><div class="ttdef"><b>Definition</b> neorv32_wdt.h:30</div></div> +</div><!-- fragment --></div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/neorv32__xip_8c.html b/sw/neorv32__xip_8c.html new file mode 100644 index 0000000000..1abc5b8756 --- /dev/null +++ b/sw/neorv32__xip_8c.html @@ -0,0 +1,312 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/lib/source/neorv32_xip.c File Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_7d04193005ada6f9450f847f4adb6b5b.html">lib</a></li><li class="navelem"><a class="el" href="dir_0c6ac14e2254a316d41123f98feeb67b.html">source</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#func-members">Functions</a> </div> + <div class="headertitle"><div class="title">neorv32_xip.c File Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p>Execute in place module (XIP) HW driver source file. +<a href="#details">More...</a></p> +<div class="textblock"><code>#include &quot;<a class="el" href="neorv32_8h_source.html">neorv32.h</a>&quot;</code><br /> +</div><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="func-members" name="func-members"></a> +Functions</h2></td></tr> +<tr class="memitem:afe2e5682a26cafdb0585d2233bccc7c6" id="r_afe2e5682a26cafdb0585d2233bccc7c6"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#afe2e5682a26cafdb0585d2233bccc7c6">neorv32_xip_available</a> (void)</td></tr> +<tr class="separator:afe2e5682a26cafdb0585d2233bccc7c6"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a549d68abdf5a3d7484abe6d5370bb999" id="r_a549d68abdf5a3d7484abe6d5370bb999"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a549d68abdf5a3d7484abe6d5370bb999">neorv32_xip_setup</a> (int prsc, int cdiv, int cpol, int cpha, uint8_t rd_cmd)</td></tr> +<tr class="separator:a549d68abdf5a3d7484abe6d5370bb999"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a0ab2c36c973030a811e6d7abe0afc393" id="r_a0ab2c36c973030a811e6d7abe0afc393"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a0ab2c36c973030a811e6d7abe0afc393">neorv32_xip_start</a> (int abytes)</td></tr> +<tr class="separator:a0ab2c36c973030a811e6d7abe0afc393"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a6aef2ea29451ba2aa55160da777a5115" id="r_a6aef2ea29451ba2aa55160da777a5115"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a6aef2ea29451ba2aa55160da777a5115">neorv32_xip_highspeed_enable</a> (void)</td></tr> +<tr class="separator:a6aef2ea29451ba2aa55160da777a5115"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ad74f2842ed2251e3ae5c19e06dced0c3" id="r_ad74f2842ed2251e3ae5c19e06dced0c3"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ad74f2842ed2251e3ae5c19e06dced0c3">neorv32_xip_highspeed_disable</a> (void)</td></tr> +<tr class="separator:ad74f2842ed2251e3ae5c19e06dced0c3"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a88f728101e82939bf7f8b9ab5a904706" id="r_a88f728101e82939bf7f8b9ab5a904706"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a88f728101e82939bf7f8b9ab5a904706">neorv32_xip_get_clock_speed</a> (void)</td></tr> +<tr class="separator:a88f728101e82939bf7f8b9ab5a904706"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a92f1446a3bb7fe6dee5dbed33882b223" id="r_a92f1446a3bb7fe6dee5dbed33882b223"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a92f1446a3bb7fe6dee5dbed33882b223">neorv32_xip_spi_trans</a> (int nbytes, uint64_t *rtx_data)</td></tr> +<tr class="separator:a92f1446a3bb7fe6dee5dbed33882b223"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>Execute in place module (XIP) HW driver source file. </p> +<dl class="section note"><dt>Note</dt><dd>These functions should only be used if the XIP module was synthesized (IO_XIP_EN = true).</dd></dl> +<dl class="section see"><dt>See also</dt><dd><a href="https://stnolting.github.io/neorv32/sw/files.html">https://stnolting.github.io/neorv32/sw/files.html</a> </dd></dl> +</div><h2 class="groupheader">Function Documentation</h2> +<a id="afe2e5682a26cafdb0585d2233bccc7c6" name="afe2e5682a26cafdb0585d2233bccc7c6"></a> +<h2 class="memtitle"><span class="permalink"><a href="#afe2e5682a26cafdb0585d2233bccc7c6">&#9670;&#160;</a></span>neorv32_xip_available()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_xip_available </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Check if XIP module was synthesized.</p> +<dl class="section return"><dt>Returns</dt><dd>0 if XIP was not synthesized, 1 if XIP is available. </dd></dl> + +</div> +</div> +<a id="a88f728101e82939bf7f8b9ab5a904706" name="a88f728101e82939bf7f8b9ab5a904706"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a88f728101e82939bf7f8b9ab5a904706">&#9670;&#160;</a></span>neorv32_xip_get_clock_speed()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_xip_get_clock_speed </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Get configured clock speed in Hz.</p> +<dl class="section return"><dt>Returns</dt><dd>Actual configured XIP clock speed in Hz. </dd></dl> + +</div> +</div> +<a id="ad74f2842ed2251e3ae5c19e06dced0c3" name="ad74f2842ed2251e3ae5c19e06dced0c3"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ad74f2842ed2251e3ae5c19e06dced0c3">&#9670;&#160;</a></span>neorv32_xip_highspeed_disable()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_xip_highspeed_disable </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Disable high-speed SPI mode. </p> + +</div> +</div> +<a id="a6aef2ea29451ba2aa55160da777a5115" name="a6aef2ea29451ba2aa55160da777a5115"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a6aef2ea29451ba2aa55160da777a5115">&#9670;&#160;</a></span>neorv32_xip_highspeed_enable()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_xip_highspeed_enable </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Enable high-speed SPI mode (running at half of the processor clock).</p> +<dl class="section note"><dt>Note</dt><dd>High-speed SPI mode ignores the programmed clock prescaler configuration. </dd></dl> + +</div> +</div> +<a id="a549d68abdf5a3d7484abe6d5370bb999" name="a549d68abdf5a3d7484abe6d5370bb999"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a549d68abdf5a3d7484abe6d5370bb999">&#9670;&#160;</a></span>neorv32_xip_setup()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_xip_setup </td> + <td>(</td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>prsc</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>cdiv</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>cpol</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>cpha</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">uint8_t</td> <td class="paramname"><span class="paramname"><em>rd_cmd</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Configure XIP module: configure SPI/flash properties.</p> +<dl class="section warning"><dt>Warning</dt><dd>This will reset the XIP module overriding the CTRL register. </dd></dl> +<dl class="section note"><dt>Note</dt><dd>This function will also send 64 dummy clocks via the SPI port (with chip-select disabled).</dd></dl> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">prsc</td><td>SPI clock prescaler select (0..7). @prama[in] cdiv Clock divider (0..15). </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">cpol</td><td>SPI clock polarity (0/1). </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">cpha</td><td>SPI clock phase(0/1). </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">rd_cmd</td><td>SPI flash read byte command. </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="a92f1446a3bb7fe6dee5dbed33882b223" name="a92f1446a3bb7fe6dee5dbed33882b223"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a92f1446a3bb7fe6dee5dbed33882b223">&#9670;&#160;</a></span>neorv32_xip_spi_trans()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_xip_spi_trans </td> + <td>(</td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>nbytes</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">uint64_t *</td> <td class="paramname"><span class="paramname"><em>rtx_data</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Direct SPI access to the XIP flash.</p> +<dl class="section warning"><dt>Warning</dt><dd>This function can only be used BEFORE the XIP-mode is activated! </dd></dl> +<dl class="section note"><dt>Note</dt><dd>This function is blocking.</dd></dl> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">nbytes</td><td>Number of bytes to transfer (1..8). </td></tr> + <tr><td class="paramdir">[in,out]</td><td class="paramname">rtx_data</td><td>Pointer to 64-bit TX/RX data (MSB-aligned for sending, LSB-aligned for receiving (only 32-bit)). </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>0 if valid transfer, 1 if transfer configuration error. </dd></dl> + +</div> +</div> +<a id="a0ab2c36c973030a811e6d7abe0afc393" name="a0ab2c36c973030a811e6d7abe0afc393"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a0ab2c36c973030a811e6d7abe0afc393">&#9670;&#160;</a></span>neorv32_xip_start()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_xip_start </td> + <td>(</td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>abytes</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Enable XIP mode (to allow CPU to <em>transparently</em> fetch data &amp; instructions).</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">abytes</td><td>Number of address bytes used to access the SPI flash (1,2,3,4). </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>0 if XIP configuration is OK, -1 if configuration error. </dd></dl> + +</div> +</div> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/neorv32__xip_8h.html b/sw/neorv32__xip_8h.html new file mode 100644 index 0000000000..308ddb65ef --- /dev/null +++ b/sw/neorv32__xip_8h.html @@ -0,0 +1,433 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/lib/include/neorv32_xip.h File Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_7d04193005ada6f9450f847f4adb6b5b.html">lib</a></li><li class="navelem"><a class="el" href="dir_752b1e5d3973bf735fa78bf6b4727df9.html">include</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#nested-classes">Data Structures</a> </div> + <div class="headertitle"><div class="title">neorv32_xip.h File Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p>Execute in place module (XIP) HW driver header file. +<a href="#details">More...</a></p> +<div class="textblock"><code>#include &lt;stdint.h&gt;</code><br /> +</div> +<p><a href="neorv32__xip_8h_source.html">Go to the source code of this file.</a></p> +<table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="nested-classes" name="nested-classes"></a> +Data Structures</h2></td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">struct &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structneorv32__xip__t.html">neorv32_xip_t</a></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="func-members" name="func-members"></a> +Functions</h2></td></tr> +<tr><td colspan="2"><div class="groupHeader">Prototypes</div></td></tr> +<tr class="memitem:afe2e5682a26cafdb0585d2233bccc7c6" id="r_afe2e5682a26cafdb0585d2233bccc7c6"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#afe2e5682a26cafdb0585d2233bccc7c6">neorv32_xip_available</a> (void)</td></tr> +<tr class="separator:afe2e5682a26cafdb0585d2233bccc7c6"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a549d68abdf5a3d7484abe6d5370bb999" id="r_a549d68abdf5a3d7484abe6d5370bb999"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a549d68abdf5a3d7484abe6d5370bb999">neorv32_xip_setup</a> (int prsc, int cdiv, int cpol, int cpha, uint8_t rd_cmd)</td></tr> +<tr class="separator:a549d68abdf5a3d7484abe6d5370bb999"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a0ab2c36c973030a811e6d7abe0afc393" id="r_a0ab2c36c973030a811e6d7abe0afc393"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a0ab2c36c973030a811e6d7abe0afc393">neorv32_xip_start</a> (int abytes)</td></tr> +<tr class="separator:a0ab2c36c973030a811e6d7abe0afc393"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a6aef2ea29451ba2aa55160da777a5115" id="r_a6aef2ea29451ba2aa55160da777a5115"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a6aef2ea29451ba2aa55160da777a5115">neorv32_xip_highspeed_enable</a> (void)</td></tr> +<tr class="separator:a6aef2ea29451ba2aa55160da777a5115"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ad74f2842ed2251e3ae5c19e06dced0c3" id="r_ad74f2842ed2251e3ae5c19e06dced0c3"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ad74f2842ed2251e3ae5c19e06dced0c3">neorv32_xip_highspeed_disable</a> (void)</td></tr> +<tr class="separator:ad74f2842ed2251e3ae5c19e06dced0c3"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a88f728101e82939bf7f8b9ab5a904706" id="r_a88f728101e82939bf7f8b9ab5a904706"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a88f728101e82939bf7f8b9ab5a904706">neorv32_xip_get_clock_speed</a> (void)</td></tr> +<tr class="separator:a88f728101e82939bf7f8b9ab5a904706"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a92f1446a3bb7fe6dee5dbed33882b223" id="r_a92f1446a3bb7fe6dee5dbed33882b223"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a92f1446a3bb7fe6dee5dbed33882b223">neorv32_xip_spi_trans</a> (int nbytes, uint64_t *rtx_data)</td></tr> +<tr class="separator:a92f1446a3bb7fe6dee5dbed33882b223"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader">IO Device: Execute In Place Module (XIP)</h2></td></tr> +<tr class="memitem:a3d6f138a347c16883b51069428eb7c1e" id="r_a3d6f138a347c16883b51069428eb7c1e"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a3d6f138a347c16883b51069428eb7c1e">NEORV32_XIP</a>&#160;&#160;&#160;((<a class="el" href="structneorv32__xip__t.html">neorv32_xip_t</a>*) (<a class="el" href="neorv32_8h.html#ae0978315beac8399f96f520bda81c7fe">NEORV32_XIP_BASE</a>))</td></tr> +<tr class="separator:a3d6f138a347c16883b51069428eb7c1e"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a72ed1ff87de1222cc3a13177c7483ceb" id="r_a72ed1ff87de1222cc3a13177c7483ceb"><td class="memItemLeft" align="right" valign="top">enum &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a72ed1ff87de1222cc3a13177c7483ceb">NEORV32_XIP_CTRL_enum</a> { <br /> +&#160;&#160;<a class="el" href="#a72ed1ff87de1222cc3a13177c7483ceba27658ce3cc81c9e258b73fb02d7f1045">XIP_CTRL_EN</a> = 0 +, <a class="el" href="#a72ed1ff87de1222cc3a13177c7483ceba67a0c0483eaf92e9cd03e9076be5b50d">XIP_CTRL_PRSC0</a> = 1 +, <a class="el" href="#a72ed1ff87de1222cc3a13177c7483cebae47f2e1e8c023fd52e25a3dad5e332af">XIP_CTRL_PRSC1</a> = 2 +, <a class="el" href="#a72ed1ff87de1222cc3a13177c7483ceba896815c075a91a8291585eb61b6e0086">XIP_CTRL_PRSC2</a> = 3 +, <br /> +&#160;&#160;<a class="el" href="#a72ed1ff87de1222cc3a13177c7483ceba95ae19cf5d5140df397ead62f151247f">XIP_CTRL_CPOL</a> = 4 +, <a class="el" href="#a72ed1ff87de1222cc3a13177c7483cebad31736f4a159745be94b487079c4c14d">XIP_CTRL_CPHA</a> = 5 +, <a class="el" href="#a72ed1ff87de1222cc3a13177c7483ceba23be66e49d28dd12c5321e576d2f0c7a">XIP_CTRL_SPI_NBYTES_LSB</a> = 6 +, <a class="el" href="#a72ed1ff87de1222cc3a13177c7483ceba5d13c4fe190fcd68dfcbbbe33d2e844c">XIP_CTRL_SPI_NBYTES_MSB</a> = 9 +, <br /> +&#160;&#160;<a class="el" href="#a72ed1ff87de1222cc3a13177c7483ceba3cbd45a66e05a4fcfc5ec810b8cee937">XIP_CTRL_XIP_EN</a> = 10 +, <a class="el" href="#a72ed1ff87de1222cc3a13177c7483ceba603f9d8d22ae2a6abc61b666bc88a4df">XIP_CTRL_XIP_ABYTES_LSB</a> = 11 +, <a class="el" href="#a72ed1ff87de1222cc3a13177c7483ceba5885ed5fcd2eed969bd921afe8dff4fc">XIP_CTRL_XIP_ABYTES_MSB</a> = 12 +, <a class="el" href="#a72ed1ff87de1222cc3a13177c7483ceba8287016f167727f147806aa11129e05b">XIP_CTRL_RD_CMD_LSB</a> = 13 +, <br /> +&#160;&#160;<a class="el" href="#a72ed1ff87de1222cc3a13177c7483ceba2c78cd2d32cfba4d89f7aab92f7939e7">XIP_CTRL_RD_CMD_MSB</a> = 20 +, <a class="el" href="#a72ed1ff87de1222cc3a13177c7483ceba5aadb2c374d34b878b56a660baec2080">XIP_CTRL_SPI_CSEN</a> = 21 +, <a class="el" href="#a72ed1ff87de1222cc3a13177c7483cebaaeb104a59215667aabb5a751632ae781">XIP_CTRL_HIGHSPEED</a> = 22 +, <a class="el" href="#a72ed1ff87de1222cc3a13177c7483cebaf9b56aa629973ce4a9c8ff61a2c90ba3">XIP_CTRL_CDIV0</a> = 23 +, <br /> +&#160;&#160;<a class="el" href="#a72ed1ff87de1222cc3a13177c7483ceba68775854b8f2cfa2f32d2eb82a714073">XIP_CTRL_CDIV1</a> = 24 +, <a class="el" href="#a72ed1ff87de1222cc3a13177c7483ceba43d7305e0e0398cb44c99e70dcd96445">XIP_CTRL_CDIV2</a> = 25 +, <a class="el" href="#a72ed1ff87de1222cc3a13177c7483ceba61ffffe9acda5c622b48b6360e357eef">XIP_CTRL_CDIV3</a> = 26 +, <a class="el" href="#a72ed1ff87de1222cc3a13177c7483ceba7ad9f81356d6923d524d1c9e39acdd2c">XIP_CTRL_BURST_EN</a> = 29 +, <br /> +&#160;&#160;<a class="el" href="#a72ed1ff87de1222cc3a13177c7483ceba76d2379d0e7ab09e7e686bc886888fa5">XIP_CTRL_PHY_BUSY</a> = 30 +, <a class="el" href="#a72ed1ff87de1222cc3a13177c7483ceba2c4a47f88d299782b8618b68fb87d59a">XIP_CTRL_XIP_BUSY</a> = 31 +<br /> + }</td></tr> +<tr class="separator:a72ed1ff87de1222cc3a13177c7483ceb"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>Execute in place module (XIP) HW driver header file. </p> +<dl class="section note"><dt>Note</dt><dd>These functions should only be used if the XIP module was synthesized (IO_XIP_EN = true).</dd></dl> +<dl class="section see"><dt>See also</dt><dd><a href="https://stnolting.github.io/neorv32/sw/files.html">https://stnolting.github.io/neorv32/sw/files.html</a> </dd></dl> +</div><h2 class="groupheader">Macro Definition Documentation</h2> +<a id="a3d6f138a347c16883b51069428eb7c1e" name="a3d6f138a347c16883b51069428eb7c1e"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a3d6f138a347c16883b51069428eb7c1e">&#9670;&#160;</a></span>NEORV32_XIP</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define NEORV32_XIP&#160;&#160;&#160;((<a class="el" href="structneorv32__xip__t.html">neorv32_xip_t</a>*) (<a class="el" href="neorv32_8h.html#ae0978315beac8399f96f520bda81c7fe">NEORV32_XIP_BASE</a>))</td> + </tr> + </table> +</div><div class="memdoc"> +<p>XIP module hardware access (<a class="el" href="structneorv32__xip__t.html">neorv32_xip_t</a>) </p> + +</div> +</div> +<h2 class="groupheader">Enumeration Type Documentation</h2> +<a id="a72ed1ff87de1222cc3a13177c7483ceb" name="a72ed1ff87de1222cc3a13177c7483ceb"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a72ed1ff87de1222cc3a13177c7483ceb">&#9670;&#160;</a></span>NEORV32_XIP_CTRL_enum</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">enum <a class="el" href="#a72ed1ff87de1222cc3a13177c7483ceb">NEORV32_XIP_CTRL_enum</a></td> + </tr> + </table> +</div><div class="memdoc"> +<p>XIP control/data register bits </p> +<table class="fieldtable"> +<tr><th colspan="2">Enumerator</th></tr><tr><td class="fieldname"><a id="a72ed1ff87de1222cc3a13177c7483ceba27658ce3cc81c9e258b73fb02d7f1045" name="a72ed1ff87de1222cc3a13177c7483ceba27658ce3cc81c9e258b73fb02d7f1045"></a>XIP_CTRL_EN&#160;</td><td class="fielddoc"><p>XIP control register( 0) (r/w): XIP module enable </p> +</td></tr> +<tr><td class="fieldname"><a id="a72ed1ff87de1222cc3a13177c7483ceba67a0c0483eaf92e9cd03e9076be5b50d" name="a72ed1ff87de1222cc3a13177c7483ceba67a0c0483eaf92e9cd03e9076be5b50d"></a>XIP_CTRL_PRSC0&#160;</td><td class="fielddoc"><p>XIP control register( 1) (r/w): Clock prescaler select bit 0 </p> +</td></tr> +<tr><td class="fieldname"><a id="a72ed1ff87de1222cc3a13177c7483cebae47f2e1e8c023fd52e25a3dad5e332af" name="a72ed1ff87de1222cc3a13177c7483cebae47f2e1e8c023fd52e25a3dad5e332af"></a>XIP_CTRL_PRSC1&#160;</td><td class="fielddoc"><p>XIP control register( 2) (r/w): Clock prescaler select bit 1 </p> +</td></tr> +<tr><td class="fieldname"><a id="a72ed1ff87de1222cc3a13177c7483ceba896815c075a91a8291585eb61b6e0086" name="a72ed1ff87de1222cc3a13177c7483ceba896815c075a91a8291585eb61b6e0086"></a>XIP_CTRL_PRSC2&#160;</td><td class="fielddoc"><p>XIP control register( 3) (r/w): Clock prescaler select bit 2 </p> +</td></tr> +<tr><td class="fieldname"><a id="a72ed1ff87de1222cc3a13177c7483ceba95ae19cf5d5140df397ead62f151247f" name="a72ed1ff87de1222cc3a13177c7483ceba95ae19cf5d5140df397ead62f151247f"></a>XIP_CTRL_CPOL&#160;</td><td class="fielddoc"><p>XIP control register( 4) (r/w): SPI (idle) clock polarity </p> +</td></tr> +<tr><td class="fieldname"><a id="a72ed1ff87de1222cc3a13177c7483cebad31736f4a159745be94b487079c4c14d" name="a72ed1ff87de1222cc3a13177c7483cebad31736f4a159745be94b487079c4c14d"></a>XIP_CTRL_CPHA&#160;</td><td class="fielddoc"><p>XIP control register( 5) (r/w): SPI clock phase </p> +</td></tr> +<tr><td class="fieldname"><a id="a72ed1ff87de1222cc3a13177c7483ceba23be66e49d28dd12c5321e576d2f0c7a" name="a72ed1ff87de1222cc3a13177c7483ceba23be66e49d28dd12c5321e576d2f0c7a"></a>XIP_CTRL_SPI_NBYTES_LSB&#160;</td><td class="fielddoc"><p>XIP control register( 6) (r/w): Number of bytes in SPI transmission, LSB </p> +</td></tr> +<tr><td class="fieldname"><a id="a72ed1ff87de1222cc3a13177c7483ceba5d13c4fe190fcd68dfcbbbe33d2e844c" name="a72ed1ff87de1222cc3a13177c7483ceba5d13c4fe190fcd68dfcbbbe33d2e844c"></a>XIP_CTRL_SPI_NBYTES_MSB&#160;</td><td class="fielddoc"><p>XIP control register( 9) (r/w): Number of bytes in SPI transmission, MSB </p> +</td></tr> +<tr><td class="fieldname"><a id="a72ed1ff87de1222cc3a13177c7483ceba3cbd45a66e05a4fcfc5ec810b8cee937" name="a72ed1ff87de1222cc3a13177c7483ceba3cbd45a66e05a4fcfc5ec810b8cee937"></a>XIP_CTRL_XIP_EN&#160;</td><td class="fielddoc"><p>XIP control register(10) (r/w): XIP access enable </p> +</td></tr> +<tr><td class="fieldname"><a id="a72ed1ff87de1222cc3a13177c7483ceba603f9d8d22ae2a6abc61b666bc88a4df" name="a72ed1ff87de1222cc3a13177c7483ceba603f9d8d22ae2a6abc61b666bc88a4df"></a>XIP_CTRL_XIP_ABYTES_LSB&#160;</td><td class="fielddoc"><p>XIP control register(11) (r/w): Number XIP address bytes (minus 1), LSB </p> +</td></tr> +<tr><td class="fieldname"><a id="a72ed1ff87de1222cc3a13177c7483ceba5885ed5fcd2eed969bd921afe8dff4fc" name="a72ed1ff87de1222cc3a13177c7483ceba5885ed5fcd2eed969bd921afe8dff4fc"></a>XIP_CTRL_XIP_ABYTES_MSB&#160;</td><td class="fielddoc"><p>XIP control register(12) (r/w): Number XIP address bytes (minus 1), MSB </p> +</td></tr> +<tr><td class="fieldname"><a id="a72ed1ff87de1222cc3a13177c7483ceba8287016f167727f147806aa11129e05b" name="a72ed1ff87de1222cc3a13177c7483ceba8287016f167727f147806aa11129e05b"></a>XIP_CTRL_RD_CMD_LSB&#160;</td><td class="fielddoc"><p>XIP control register(13) (r/w): SPI flash read command, LSB </p> +</td></tr> +<tr><td class="fieldname"><a id="a72ed1ff87de1222cc3a13177c7483ceba2c78cd2d32cfba4d89f7aab92f7939e7" name="a72ed1ff87de1222cc3a13177c7483ceba2c78cd2d32cfba4d89f7aab92f7939e7"></a>XIP_CTRL_RD_CMD_MSB&#160;</td><td class="fielddoc"><p>XIP control register(20) (r/w): SPI flash read command, MSB </p> +</td></tr> +<tr><td class="fieldname"><a id="a72ed1ff87de1222cc3a13177c7483ceba5aadb2c374d34b878b56a660baec2080" name="a72ed1ff87de1222cc3a13177c7483ceba5aadb2c374d34b878b56a660baec2080"></a>XIP_CTRL_SPI_CSEN&#160;</td><td class="fielddoc"><p>XIP control register(21) (r/w): SPI chip-select enable </p> +</td></tr> +<tr><td class="fieldname"><a id="a72ed1ff87de1222cc3a13177c7483cebaaeb104a59215667aabb5a751632ae781" name="a72ed1ff87de1222cc3a13177c7483cebaaeb104a59215667aabb5a751632ae781"></a>XIP_CTRL_HIGHSPEED&#160;</td><td class="fielddoc"><p>XIP control register(22) (r/w): SPI high-speed mode enable (ignoring XIP_CTRL_PRSC) </p> +</td></tr> +<tr><td class="fieldname"><a id="a72ed1ff87de1222cc3a13177c7483cebaf9b56aa629973ce4a9c8ff61a2c90ba3" name="a72ed1ff87de1222cc3a13177c7483cebaf9b56aa629973ce4a9c8ff61a2c90ba3"></a>XIP_CTRL_CDIV0&#160;</td><td class="fielddoc"><p>XIP control register(23) (r/w): Clock divider bit 0 </p> +</td></tr> +<tr><td class="fieldname"><a id="a72ed1ff87de1222cc3a13177c7483ceba68775854b8f2cfa2f32d2eb82a714073" name="a72ed1ff87de1222cc3a13177c7483ceba68775854b8f2cfa2f32d2eb82a714073"></a>XIP_CTRL_CDIV1&#160;</td><td class="fielddoc"><p>XIP control register(24) (r/w): Clock divider bit 1 </p> +</td></tr> +<tr><td class="fieldname"><a id="a72ed1ff87de1222cc3a13177c7483ceba43d7305e0e0398cb44c99e70dcd96445" name="a72ed1ff87de1222cc3a13177c7483ceba43d7305e0e0398cb44c99e70dcd96445"></a>XIP_CTRL_CDIV2&#160;</td><td class="fielddoc"><p>XIP control register(25) (r/w): Clock divider bit 2 </p> +</td></tr> +<tr><td class="fieldname"><a id="a72ed1ff87de1222cc3a13177c7483ceba61ffffe9acda5c622b48b6360e357eef" name="a72ed1ff87de1222cc3a13177c7483ceba61ffffe9acda5c622b48b6360e357eef"></a>XIP_CTRL_CDIV3&#160;</td><td class="fielddoc"><p>XIP control register(26) (r/w): Clock divider bit 3 </p> +</td></tr> +<tr><td class="fieldname"><a id="a72ed1ff87de1222cc3a13177c7483ceba7ad9f81356d6923d524d1c9e39acdd2c" name="a72ed1ff87de1222cc3a13177c7483ceba7ad9f81356d6923d524d1c9e39acdd2c"></a>XIP_CTRL_BURST_EN&#160;</td><td class="fielddoc"><p>XIP control register(29) (r/-): Burst mode enabled (set if XIP cache is implemented) </p> +</td></tr> +<tr><td class="fieldname"><a id="a72ed1ff87de1222cc3a13177c7483ceba76d2379d0e7ab09e7e686bc886888fa5" name="a72ed1ff87de1222cc3a13177c7483ceba76d2379d0e7ab09e7e686bc886888fa5"></a>XIP_CTRL_PHY_BUSY&#160;</td><td class="fielddoc"><p>XIP control register(30) (r/-): SPI PHY is busy </p> +</td></tr> +<tr><td class="fieldname"><a id="a72ed1ff87de1222cc3a13177c7483ceba2c4a47f88d299782b8618b68fb87d59a" name="a72ed1ff87de1222cc3a13177c7483ceba2c4a47f88d299782b8618b68fb87d59a"></a>XIP_CTRL_XIP_BUSY&#160;</td><td class="fielddoc"><p>XIP control register(31) (r/-): XIP access in progress </p> +</td></tr> +</table> + +</div> +</div> +<h2 class="groupheader">Function Documentation</h2> +<a id="afe2e5682a26cafdb0585d2233bccc7c6" name="afe2e5682a26cafdb0585d2233bccc7c6"></a> +<h2 class="memtitle"><span class="permalink"><a href="#afe2e5682a26cafdb0585d2233bccc7c6">&#9670;&#160;</a></span>neorv32_xip_available()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_xip_available </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Check if XIP module was synthesized.</p> +<dl class="section return"><dt>Returns</dt><dd>0 if XIP was not synthesized, 1 if XIP is available. </dd></dl> + +</div> +</div> +<a id="a88f728101e82939bf7f8b9ab5a904706" name="a88f728101e82939bf7f8b9ab5a904706"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a88f728101e82939bf7f8b9ab5a904706">&#9670;&#160;</a></span>neorv32_xip_get_clock_speed()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_xip_get_clock_speed </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Get configured clock speed in Hz.</p> +<dl class="section return"><dt>Returns</dt><dd>Actual configured XIP clock speed in Hz. </dd></dl> + +</div> +</div> +<a id="ad74f2842ed2251e3ae5c19e06dced0c3" name="ad74f2842ed2251e3ae5c19e06dced0c3"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ad74f2842ed2251e3ae5c19e06dced0c3">&#9670;&#160;</a></span>neorv32_xip_highspeed_disable()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_xip_highspeed_disable </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Disable high-speed SPI mode. </p> + +</div> +</div> +<a id="a6aef2ea29451ba2aa55160da777a5115" name="a6aef2ea29451ba2aa55160da777a5115"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a6aef2ea29451ba2aa55160da777a5115">&#9670;&#160;</a></span>neorv32_xip_highspeed_enable()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_xip_highspeed_enable </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Enable high-speed SPI mode (running at half of the processor clock).</p> +<dl class="section note"><dt>Note</dt><dd>High-speed SPI mode ignores the programmed clock prescaler configuration. </dd></dl> + +</div> +</div> +<a id="a549d68abdf5a3d7484abe6d5370bb999" name="a549d68abdf5a3d7484abe6d5370bb999"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a549d68abdf5a3d7484abe6d5370bb999">&#9670;&#160;</a></span>neorv32_xip_setup()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_xip_setup </td> + <td>(</td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>prsc</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>cdiv</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>cpol</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>cpha</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">uint8_t</td> <td class="paramname"><span class="paramname"><em>rd_cmd</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Configure XIP module: configure SPI/flash properties.</p> +<dl class="section warning"><dt>Warning</dt><dd>This will reset the XIP module overriding the CTRL register. </dd></dl> +<dl class="section note"><dt>Note</dt><dd>This function will also send 64 dummy clocks via the SPI port (with chip-select disabled).</dd></dl> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">prsc</td><td>SPI clock prescaler select (0..7). @prama[in] cdiv Clock divider (0..15). </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">cpol</td><td>SPI clock polarity (0/1). </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">cpha</td><td>SPI clock phase(0/1). </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">rd_cmd</td><td>SPI flash read byte command. </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="a92f1446a3bb7fe6dee5dbed33882b223" name="a92f1446a3bb7fe6dee5dbed33882b223"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a92f1446a3bb7fe6dee5dbed33882b223">&#9670;&#160;</a></span>neorv32_xip_spi_trans()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_xip_spi_trans </td> + <td>(</td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>nbytes</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">uint64_t *</td> <td class="paramname"><span class="paramname"><em>rtx_data</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Direct SPI access to the XIP flash.</p> +<dl class="section warning"><dt>Warning</dt><dd>This function can only be used BEFORE the XIP-mode is activated! </dd></dl> +<dl class="section note"><dt>Note</dt><dd>This function is blocking.</dd></dl> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">nbytes</td><td>Number of bytes to transfer (1..8). </td></tr> + <tr><td class="paramdir">[in,out]</td><td class="paramname">rtx_data</td><td>Pointer to 64-bit TX/RX data (MSB-aligned for sending, LSB-aligned for receiving (only 32-bit)). </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>0 if valid transfer, 1 if transfer configuration error. </dd></dl> + +</div> +</div> +<a id="a0ab2c36c973030a811e6d7abe0afc393" name="a0ab2c36c973030a811e6d7abe0afc393"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a0ab2c36c973030a811e6d7abe0afc393">&#9670;&#160;</a></span>neorv32_xip_start()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_xip_start </td> + <td>(</td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>abytes</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Enable XIP mode (to allow CPU to <em>transparently</em> fetch data &amp; instructions).</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">abytes</td><td>Number of address bytes used to access the SPI flash (1,2,3,4). </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>0 if XIP configuration is OK, -1 if configuration error. </dd></dl> + +</div> +</div> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/neorv32__xip_8h_source.html b/sw/neorv32__xip_8h_source.html new file mode 100644 index 0000000000..fc0878b395 --- /dev/null +++ b/sw/neorv32__xip_8h_source.html @@ -0,0 +1,199 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/lib/include/neorv32_xip.h Source File</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_7d04193005ada6f9450f847f4adb6b5b.html">lib</a></li><li class="navelem"><a class="el" href="dir_752b1e5d3973bf735fa78bf6b4727df9.html">include</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="headertitle"><div class="title">neorv32_xip.h</div></div> +</div><!--header--> +<div class="contents"> +<a href="neorv32__xip_8h.html">Go to the documentation of this file.</a><div class="fragment"><div class="line"><a id="l00001" name="l00001"></a><span class="lineno"> 1</span><span class="comment">// ================================================================================ //</span></div> +<div class="line"><a id="l00002" name="l00002"></a><span class="lineno"> 2</span><span class="comment">// The NEORV32 RISC-V Processor - https://github.com/stnolting/neorv32 //</span></div> +<div class="line"><a id="l00003" name="l00003"></a><span class="lineno"> 3</span><span class="comment">// Copyright (c) NEORV32 contributors. //</span></div> +<div class="line"><a id="l00004" name="l00004"></a><span class="lineno"> 4</span><span class="comment">// Copyright (c) 2020 - 2024 Stephan Nolting. All rights reserved. //</span></div> +<div class="line"><a id="l00005" name="l00005"></a><span class="lineno"> 5</span><span class="comment">// Licensed under the BSD-3-Clause license, see LICENSE for details. //</span></div> +<div class="line"><a id="l00006" name="l00006"></a><span class="lineno"> 6</span><span class="comment">// SPDX-License-Identifier: BSD-3-Clause //</span></div> +<div class="line"><a id="l00007" name="l00007"></a><span class="lineno"> 7</span><span class="comment">// ================================================================================ //</span></div> +<div class="line"><a id="l00008" name="l00008"></a><span class="lineno"> 8</span> </div> +<div class="line"><a id="l00018" name="l00018"></a><span class="lineno"> 18</span><span class="preprocessor">#ifndef neorv32_xip_h</span></div> +<div class="line"><a id="l00019" name="l00019"></a><span class="lineno"> 19</span><span class="preprocessor">#define neorv32_xip_h</span></div> +<div class="line"><a id="l00020" name="l00020"></a><span class="lineno"> 20</span> </div> +<div class="line"><a id="l00021" name="l00021"></a><span class="lineno"> 21</span><span class="preprocessor">#include &lt;stdint.h&gt;</span></div> +<div class="line"><a id="l00022" name="l00022"></a><span class="lineno"> 22</span> </div> +<div class="line"><a id="l00023" name="l00023"></a><span class="lineno"> 23</span> </div> +<div class="line"><a id="l00024" name="l00024"></a><span class="lineno"> 24</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen00029" data-start="{" data-end="};"> +<div class="line"><a id="l00029" name="l00029"></a><span class="lineno"><a class="line" href="structneorv32__xip__t.html"> 29</a></span><span class="keyword">typedef</span> <span class="keyword">volatile</span> <span class="keyword">struct </span>__attribute__((packed,aligned(4))) {</div> +<div class="line"><a id="l00030" name="l00030"></a><span class="lineno"><a class="line" href="structneorv32__xip__t.html#a7ead9d6a4f784d766a6b2755c6d35235"> 30</a></span> uint32_t <a class="code hl_variable" href="structneorv32__xip__t.html#a7ead9d6a4f784d766a6b2755c6d35235">CTRL</a>; </div> +<div class="line"><a id="l00031" name="l00031"></a><span class="lineno"><a class="line" href="structneorv32__xip__t.html#aacb77d586c3caec518e8e0024cfe745c"> 31</a></span> <span class="keyword">const</span> uint32_t <a class="code hl_variable" href="structneorv32__xip__t.html#aacb77d586c3caec518e8e0024cfe745c">reserved</a>; </div> +<div class="line"><a id="l00032" name="l00032"></a><span class="lineno"><a class="line" href="structneorv32__xip__t.html#ad64048bb3544e712b1c668c2ef343ccb"> 32</a></span> uint32_t <a class="code hl_variable" href="structneorv32__xip__t.html#ad64048bb3544e712b1c668c2ef343ccb">DATA_LO</a>; </div> +<div class="line"><a id="l00033" name="l00033"></a><span class="lineno"><a class="line" href="structneorv32__xip__t.html#a516ab9c075ef6d1fb741e243db7703b2"> 33</a></span> uint32_t <a class="code hl_variable" href="structneorv32__xip__t.html#a516ab9c075ef6d1fb741e243db7703b2">DATA_HI</a>; </div> +<div class="line"><a id="l00034" name="l00034"></a><span class="lineno"> 34</span>} <a class="code hl_struct" href="structneorv32__xip__t.html">neorv32_xip_t</a>;</div> +</div> +<div class="line"><a id="l00035" name="l00035"></a><span class="lineno"> 35</span> </div> +<div class="line"><a id="l00037" name="l00037"></a><span class="lineno"><a class="line" href="neorv32__xip_8h.html#a3d6f138a347c16883b51069428eb7c1e"> 37</a></span><span class="preprocessor">#define NEORV32_XIP ((neorv32_xip_t*) (NEORV32_XIP_BASE))</span></div> +<div class="line"><a id="l00038" name="l00038"></a><span class="lineno"> 38</span> </div> +<div class="foldopen" id="foldopen00040" data-start="{" data-end="};"> +<div class="line"><a id="l00040" name="l00040"></a><span class="lineno"><a class="line" href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceb"> 40</a></span><span class="keyword">enum</span> <a class="code hl_enumeration" href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceb">NEORV32_XIP_CTRL_enum</a> {</div> +<div class="line"><a id="l00041" name="l00041"></a><span class="lineno"><a class="line" href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba27658ce3cc81c9e258b73fb02d7f1045"> 41</a></span> <a class="code hl_enumvalue" href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba27658ce3cc81c9e258b73fb02d7f1045">XIP_CTRL_EN</a> = 0, </div> +<div class="line"><a id="l00042" name="l00042"></a><span class="lineno"><a class="line" href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba67a0c0483eaf92e9cd03e9076be5b50d"> 42</a></span> <a class="code hl_enumvalue" href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba67a0c0483eaf92e9cd03e9076be5b50d">XIP_CTRL_PRSC0</a> = 1, </div> +<div class="line"><a id="l00043" name="l00043"></a><span class="lineno"><a class="line" href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483cebae47f2e1e8c023fd52e25a3dad5e332af"> 43</a></span> <a class="code hl_enumvalue" href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483cebae47f2e1e8c023fd52e25a3dad5e332af">XIP_CTRL_PRSC1</a> = 2, </div> +<div class="line"><a id="l00044" name="l00044"></a><span class="lineno"><a class="line" href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba896815c075a91a8291585eb61b6e0086"> 44</a></span> <a class="code hl_enumvalue" href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba896815c075a91a8291585eb61b6e0086">XIP_CTRL_PRSC2</a> = 3, </div> +<div class="line"><a id="l00045" name="l00045"></a><span class="lineno"><a class="line" href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba95ae19cf5d5140df397ead62f151247f"> 45</a></span> <a class="code hl_enumvalue" href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba95ae19cf5d5140df397ead62f151247f">XIP_CTRL_CPOL</a> = 4, </div> +<div class="line"><a id="l00046" name="l00046"></a><span class="lineno"><a class="line" href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483cebad31736f4a159745be94b487079c4c14d"> 46</a></span> <a class="code hl_enumvalue" href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483cebad31736f4a159745be94b487079c4c14d">XIP_CTRL_CPHA</a> = 5, </div> +<div class="line"><a id="l00047" name="l00047"></a><span class="lineno"><a class="line" href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba23be66e49d28dd12c5321e576d2f0c7a"> 47</a></span> <a class="code hl_enumvalue" href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba23be66e49d28dd12c5321e576d2f0c7a">XIP_CTRL_SPI_NBYTES_LSB</a> = 6, </div> +<div class="line"><a id="l00048" name="l00048"></a><span class="lineno"><a class="line" href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba5d13c4fe190fcd68dfcbbbe33d2e844c"> 48</a></span> <a class="code hl_enumvalue" href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba5d13c4fe190fcd68dfcbbbe33d2e844c">XIP_CTRL_SPI_NBYTES_MSB</a> = 9, </div> +<div class="line"><a id="l00049" name="l00049"></a><span class="lineno"><a class="line" href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba3cbd45a66e05a4fcfc5ec810b8cee937"> 49</a></span> <a class="code hl_enumvalue" href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba3cbd45a66e05a4fcfc5ec810b8cee937">XIP_CTRL_XIP_EN</a> = 10, </div> +<div class="line"><a id="l00050" name="l00050"></a><span class="lineno"><a class="line" href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba603f9d8d22ae2a6abc61b666bc88a4df"> 50</a></span> <a class="code hl_enumvalue" href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba603f9d8d22ae2a6abc61b666bc88a4df">XIP_CTRL_XIP_ABYTES_LSB</a> = 11, </div> +<div class="line"><a id="l00051" name="l00051"></a><span class="lineno"><a class="line" href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba5885ed5fcd2eed969bd921afe8dff4fc"> 51</a></span> <a class="code hl_enumvalue" href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba5885ed5fcd2eed969bd921afe8dff4fc">XIP_CTRL_XIP_ABYTES_MSB</a> = 12, </div> +<div class="line"><a id="l00052" name="l00052"></a><span class="lineno"><a class="line" href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba8287016f167727f147806aa11129e05b"> 52</a></span> <a class="code hl_enumvalue" href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba8287016f167727f147806aa11129e05b">XIP_CTRL_RD_CMD_LSB</a> = 13, </div> +<div class="line"><a id="l00053" name="l00053"></a><span class="lineno"><a class="line" href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba2c78cd2d32cfba4d89f7aab92f7939e7"> 53</a></span> <a class="code hl_enumvalue" href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba2c78cd2d32cfba4d89f7aab92f7939e7">XIP_CTRL_RD_CMD_MSB</a> = 20, </div> +<div class="line"><a id="l00054" name="l00054"></a><span class="lineno"><a class="line" href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba5aadb2c374d34b878b56a660baec2080"> 54</a></span> <a class="code hl_enumvalue" href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba5aadb2c374d34b878b56a660baec2080">XIP_CTRL_SPI_CSEN</a> = 21, </div> +<div class="line"><a id="l00055" name="l00055"></a><span class="lineno"><a class="line" href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483cebaaeb104a59215667aabb5a751632ae781"> 55</a></span> <a class="code hl_enumvalue" href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483cebaaeb104a59215667aabb5a751632ae781">XIP_CTRL_HIGHSPEED</a> = 22, </div> +<div class="line"><a id="l00056" name="l00056"></a><span class="lineno"><a class="line" href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483cebaf9b56aa629973ce4a9c8ff61a2c90ba3"> 56</a></span> <a class="code hl_enumvalue" href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483cebaf9b56aa629973ce4a9c8ff61a2c90ba3">XIP_CTRL_CDIV0</a> = 23, </div> +<div class="line"><a id="l00057" name="l00057"></a><span class="lineno"><a class="line" href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba68775854b8f2cfa2f32d2eb82a714073"> 57</a></span> <a class="code hl_enumvalue" href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba68775854b8f2cfa2f32d2eb82a714073">XIP_CTRL_CDIV1</a> = 24, </div> +<div class="line"><a id="l00058" name="l00058"></a><span class="lineno"><a class="line" href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba43d7305e0e0398cb44c99e70dcd96445"> 58</a></span> <a class="code hl_enumvalue" href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba43d7305e0e0398cb44c99e70dcd96445">XIP_CTRL_CDIV2</a> = 25, </div> +<div class="line"><a id="l00059" name="l00059"></a><span class="lineno"><a class="line" href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba61ffffe9acda5c622b48b6360e357eef"> 59</a></span> <a class="code hl_enumvalue" href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba61ffffe9acda5c622b48b6360e357eef">XIP_CTRL_CDIV3</a> = 26, </div> +<div class="line"><a id="l00061" name="l00061"></a><span class="lineno"><a class="line" href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba7ad9f81356d6923d524d1c9e39acdd2c"> 61</a></span> <a class="code hl_enumvalue" href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba7ad9f81356d6923d524d1c9e39acdd2c">XIP_CTRL_BURST_EN</a> = 29, </div> +<div class="line"><a id="l00062" name="l00062"></a><span class="lineno"><a class="line" href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba76d2379d0e7ab09e7e686bc886888fa5"> 62</a></span> <a class="code hl_enumvalue" href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba76d2379d0e7ab09e7e686bc886888fa5">XIP_CTRL_PHY_BUSY</a> = 30, </div> +<div class="line"><a id="l00063" name="l00063"></a><span class="lineno"> 63</span> <a class="code hl_enumvalue" href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba2c4a47f88d299782b8618b68fb87d59a">XIP_CTRL_XIP_BUSY</a> = 31 </div> +<div class="line"><a id="l00064" name="l00064"></a><span class="lineno"><a class="line" href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba2c4a47f88d299782b8618b68fb87d59a"> 64</a></span>};</div> +</div> +<div class="line"><a id="l00068" name="l00068"></a><span class="lineno"> 68</span><span class="comment">/**********************************************************************/</span></div> +<div class="line"><a id="l00072" name="l00072"></a><span class="lineno"> 72</span><span class="keywordtype">int</span> <a class="code hl_function" href="neorv32__xip_8h.html#afe2e5682a26cafdb0585d2233bccc7c6">neorv32_xip_available</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00073" name="l00073"></a><span class="lineno"> 73</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__xip_8h.html#a549d68abdf5a3d7484abe6d5370bb999">neorv32_xip_setup</a>(<span class="keywordtype">int</span> prsc, <span class="keywordtype">int</span> cdiv, <span class="keywordtype">int</span> cpol, <span class="keywordtype">int</span> cpha, uint8_t rd_cmd);</div> +<div class="line"><a id="l00074" name="l00074"></a><span class="lineno"> 74</span><span class="keywordtype">int</span> <a class="code hl_function" href="neorv32__xip_8h.html#a0ab2c36c973030a811e6d7abe0afc393">neorv32_xip_start</a>(<span class="keywordtype">int</span> abytes);</div> +<div class="line"><a id="l00075" name="l00075"></a><span class="lineno"> 75</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__xip_8h.html#a6aef2ea29451ba2aa55160da777a5115">neorv32_xip_highspeed_enable</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00076" name="l00076"></a><span class="lineno"> 76</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__xip_8h.html#ad74f2842ed2251e3ae5c19e06dced0c3">neorv32_xip_highspeed_disable</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00077" name="l00077"></a><span class="lineno"> 77</span>uint32_t <a class="code hl_function" href="neorv32__xip_8h.html#a88f728101e82939bf7f8b9ab5a904706">neorv32_xip_get_clock_speed</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00078" name="l00078"></a><span class="lineno"> 78</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__xip_8h.html#a92f1446a3bb7fe6dee5dbed33882b223">neorv32_xip_spi_trans</a>(<span class="keywordtype">int</span> nbytes, uint64_t *rtx_data);</div> +<div class="line"><a id="l00082" name="l00082"></a><span class="lineno"> 82</span><span class="preprocessor">#endif </span><span class="comment">// neorv32_xip_h</span></div> +<div class="ttc" id="aneorv32__xip_8h_html_a0ab2c36c973030a811e6d7abe0afc393"><div class="ttname"><a href="neorv32__xip_8h.html#a0ab2c36c973030a811e6d7abe0afc393">neorv32_xip_start</a></div><div class="ttdeci">int neorv32_xip_start(int abytes)</div><div class="ttdef"><b>Definition</b> neorv32_xip.c:86</div></div> +<div class="ttc" id="aneorv32__xip_8h_html_a549d68abdf5a3d7484abe6d5370bb999"><div class="ttname"><a href="neorv32__xip_8h.html#a549d68abdf5a3d7484abe6d5370bb999">neorv32_xip_setup</a></div><div class="ttdeci">void neorv32_xip_setup(int prsc, int cdiv, int cpol, int cpha, uint8_t rd_cmd)</div><div class="ttdef"><b>Definition</b> neorv32_xip.c:49</div></div> +<div class="ttc" id="aneorv32__xip_8h_html_a6aef2ea29451ba2aa55160da777a5115"><div class="ttname"><a href="neorv32__xip_8h.html#a6aef2ea29451ba2aa55160da777a5115">neorv32_xip_highspeed_enable</a></div><div class="ttdeci">void neorv32_xip_highspeed_enable(void)</div><div class="ttdef"><b>Definition</b> neorv32_xip.c:116</div></div> +<div class="ttc" id="aneorv32__xip_8h_html_a72ed1ff87de1222cc3a13177c7483ceb"><div class="ttname"><a href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceb">NEORV32_XIP_CTRL_enum</a></div><div class="ttdeci">NEORV32_XIP_CTRL_enum</div><div class="ttdef"><b>Definition</b> neorv32_xip.h:40</div></div> +<div class="ttc" id="aneorv32__xip_8h_html_a72ed1ff87de1222cc3a13177c7483ceba23be66e49d28dd12c5321e576d2f0c7a"><div class="ttname"><a href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba23be66e49d28dd12c5321e576d2f0c7a">XIP_CTRL_SPI_NBYTES_LSB</a></div><div class="ttdeci">@ XIP_CTRL_SPI_NBYTES_LSB</div><div class="ttdef"><b>Definition</b> neorv32_xip.h:47</div></div> +<div class="ttc" id="aneorv32__xip_8h_html_a72ed1ff87de1222cc3a13177c7483ceba27658ce3cc81c9e258b73fb02d7f1045"><div class="ttname"><a href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba27658ce3cc81c9e258b73fb02d7f1045">XIP_CTRL_EN</a></div><div class="ttdeci">@ XIP_CTRL_EN</div><div class="ttdef"><b>Definition</b> neorv32_xip.h:41</div></div> +<div class="ttc" id="aneorv32__xip_8h_html_a72ed1ff87de1222cc3a13177c7483ceba2c4a47f88d299782b8618b68fb87d59a"><div class="ttname"><a href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba2c4a47f88d299782b8618b68fb87d59a">XIP_CTRL_XIP_BUSY</a></div><div class="ttdeci">@ XIP_CTRL_XIP_BUSY</div><div class="ttdef"><b>Definition</b> neorv32_xip.h:63</div></div> +<div class="ttc" id="aneorv32__xip_8h_html_a72ed1ff87de1222cc3a13177c7483ceba2c78cd2d32cfba4d89f7aab92f7939e7"><div class="ttname"><a href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba2c78cd2d32cfba4d89f7aab92f7939e7">XIP_CTRL_RD_CMD_MSB</a></div><div class="ttdeci">@ XIP_CTRL_RD_CMD_MSB</div><div class="ttdef"><b>Definition</b> neorv32_xip.h:53</div></div> +<div class="ttc" id="aneorv32__xip_8h_html_a72ed1ff87de1222cc3a13177c7483ceba3cbd45a66e05a4fcfc5ec810b8cee937"><div class="ttname"><a href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba3cbd45a66e05a4fcfc5ec810b8cee937">XIP_CTRL_XIP_EN</a></div><div class="ttdeci">@ XIP_CTRL_XIP_EN</div><div class="ttdef"><b>Definition</b> neorv32_xip.h:49</div></div> +<div class="ttc" id="aneorv32__xip_8h_html_a72ed1ff87de1222cc3a13177c7483ceba43d7305e0e0398cb44c99e70dcd96445"><div class="ttname"><a href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba43d7305e0e0398cb44c99e70dcd96445">XIP_CTRL_CDIV2</a></div><div class="ttdeci">@ XIP_CTRL_CDIV2</div><div class="ttdef"><b>Definition</b> neorv32_xip.h:58</div></div> +<div class="ttc" id="aneorv32__xip_8h_html_a72ed1ff87de1222cc3a13177c7483ceba5885ed5fcd2eed969bd921afe8dff4fc"><div class="ttname"><a href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba5885ed5fcd2eed969bd921afe8dff4fc">XIP_CTRL_XIP_ABYTES_MSB</a></div><div class="ttdeci">@ XIP_CTRL_XIP_ABYTES_MSB</div><div class="ttdef"><b>Definition</b> neorv32_xip.h:51</div></div> +<div class="ttc" id="aneorv32__xip_8h_html_a72ed1ff87de1222cc3a13177c7483ceba5aadb2c374d34b878b56a660baec2080"><div class="ttname"><a href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba5aadb2c374d34b878b56a660baec2080">XIP_CTRL_SPI_CSEN</a></div><div class="ttdeci">@ XIP_CTRL_SPI_CSEN</div><div class="ttdef"><b>Definition</b> neorv32_xip.h:54</div></div> +<div class="ttc" id="aneorv32__xip_8h_html_a72ed1ff87de1222cc3a13177c7483ceba5d13c4fe190fcd68dfcbbbe33d2e844c"><div class="ttname"><a href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba5d13c4fe190fcd68dfcbbbe33d2e844c">XIP_CTRL_SPI_NBYTES_MSB</a></div><div class="ttdeci">@ XIP_CTRL_SPI_NBYTES_MSB</div><div class="ttdef"><b>Definition</b> neorv32_xip.h:48</div></div> +<div class="ttc" id="aneorv32__xip_8h_html_a72ed1ff87de1222cc3a13177c7483ceba603f9d8d22ae2a6abc61b666bc88a4df"><div class="ttname"><a href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba603f9d8d22ae2a6abc61b666bc88a4df">XIP_CTRL_XIP_ABYTES_LSB</a></div><div class="ttdeci">@ XIP_CTRL_XIP_ABYTES_LSB</div><div class="ttdef"><b>Definition</b> neorv32_xip.h:50</div></div> +<div class="ttc" id="aneorv32__xip_8h_html_a72ed1ff87de1222cc3a13177c7483ceba61ffffe9acda5c622b48b6360e357eef"><div class="ttname"><a href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba61ffffe9acda5c622b48b6360e357eef">XIP_CTRL_CDIV3</a></div><div class="ttdeci">@ XIP_CTRL_CDIV3</div><div class="ttdef"><b>Definition</b> neorv32_xip.h:59</div></div> +<div class="ttc" id="aneorv32__xip_8h_html_a72ed1ff87de1222cc3a13177c7483ceba67a0c0483eaf92e9cd03e9076be5b50d"><div class="ttname"><a href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba67a0c0483eaf92e9cd03e9076be5b50d">XIP_CTRL_PRSC0</a></div><div class="ttdeci">@ XIP_CTRL_PRSC0</div><div class="ttdef"><b>Definition</b> neorv32_xip.h:42</div></div> +<div class="ttc" id="aneorv32__xip_8h_html_a72ed1ff87de1222cc3a13177c7483ceba68775854b8f2cfa2f32d2eb82a714073"><div class="ttname"><a href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba68775854b8f2cfa2f32d2eb82a714073">XIP_CTRL_CDIV1</a></div><div class="ttdeci">@ XIP_CTRL_CDIV1</div><div class="ttdef"><b>Definition</b> neorv32_xip.h:57</div></div> +<div class="ttc" id="aneorv32__xip_8h_html_a72ed1ff87de1222cc3a13177c7483ceba76d2379d0e7ab09e7e686bc886888fa5"><div class="ttname"><a href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba76d2379d0e7ab09e7e686bc886888fa5">XIP_CTRL_PHY_BUSY</a></div><div class="ttdeci">@ XIP_CTRL_PHY_BUSY</div><div class="ttdef"><b>Definition</b> neorv32_xip.h:62</div></div> +<div class="ttc" id="aneorv32__xip_8h_html_a72ed1ff87de1222cc3a13177c7483ceba7ad9f81356d6923d524d1c9e39acdd2c"><div class="ttname"><a href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba7ad9f81356d6923d524d1c9e39acdd2c">XIP_CTRL_BURST_EN</a></div><div class="ttdeci">@ XIP_CTRL_BURST_EN</div><div class="ttdef"><b>Definition</b> neorv32_xip.h:61</div></div> +<div class="ttc" id="aneorv32__xip_8h_html_a72ed1ff87de1222cc3a13177c7483ceba8287016f167727f147806aa11129e05b"><div class="ttname"><a href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba8287016f167727f147806aa11129e05b">XIP_CTRL_RD_CMD_LSB</a></div><div class="ttdeci">@ XIP_CTRL_RD_CMD_LSB</div><div class="ttdef"><b>Definition</b> neorv32_xip.h:52</div></div> +<div class="ttc" id="aneorv32__xip_8h_html_a72ed1ff87de1222cc3a13177c7483ceba896815c075a91a8291585eb61b6e0086"><div class="ttname"><a href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba896815c075a91a8291585eb61b6e0086">XIP_CTRL_PRSC2</a></div><div class="ttdeci">@ XIP_CTRL_PRSC2</div><div class="ttdef"><b>Definition</b> neorv32_xip.h:44</div></div> +<div class="ttc" id="aneorv32__xip_8h_html_a72ed1ff87de1222cc3a13177c7483ceba95ae19cf5d5140df397ead62f151247f"><div class="ttname"><a href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba95ae19cf5d5140df397ead62f151247f">XIP_CTRL_CPOL</a></div><div class="ttdeci">@ XIP_CTRL_CPOL</div><div class="ttdef"><b>Definition</b> neorv32_xip.h:45</div></div> +<div class="ttc" id="aneorv32__xip_8h_html_a72ed1ff87de1222cc3a13177c7483cebaaeb104a59215667aabb5a751632ae781"><div class="ttname"><a href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483cebaaeb104a59215667aabb5a751632ae781">XIP_CTRL_HIGHSPEED</a></div><div class="ttdeci">@ XIP_CTRL_HIGHSPEED</div><div class="ttdef"><b>Definition</b> neorv32_xip.h:55</div></div> +<div class="ttc" id="aneorv32__xip_8h_html_a72ed1ff87de1222cc3a13177c7483cebad31736f4a159745be94b487079c4c14d"><div class="ttname"><a href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483cebad31736f4a159745be94b487079c4c14d">XIP_CTRL_CPHA</a></div><div class="ttdeci">@ XIP_CTRL_CPHA</div><div class="ttdef"><b>Definition</b> neorv32_xip.h:46</div></div> +<div class="ttc" id="aneorv32__xip_8h_html_a72ed1ff87de1222cc3a13177c7483cebae47f2e1e8c023fd52e25a3dad5e332af"><div class="ttname"><a href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483cebae47f2e1e8c023fd52e25a3dad5e332af">XIP_CTRL_PRSC1</a></div><div class="ttdeci">@ XIP_CTRL_PRSC1</div><div class="ttdef"><b>Definition</b> neorv32_xip.h:43</div></div> +<div class="ttc" id="aneorv32__xip_8h_html_a72ed1ff87de1222cc3a13177c7483cebaf9b56aa629973ce4a9c8ff61a2c90ba3"><div class="ttname"><a href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483cebaf9b56aa629973ce4a9c8ff61a2c90ba3">XIP_CTRL_CDIV0</a></div><div class="ttdeci">@ XIP_CTRL_CDIV0</div><div class="ttdef"><b>Definition</b> neorv32_xip.h:56</div></div> +<div class="ttc" id="aneorv32__xip_8h_html_a88f728101e82939bf7f8b9ab5a904706"><div class="ttname"><a href="neorv32__xip_8h.html#a88f728101e82939bf7f8b9ab5a904706">neorv32_xip_get_clock_speed</a></div><div class="ttdeci">uint32_t neorv32_xip_get_clock_speed(void)</div><div class="ttdef"><b>Definition</b> neorv32_xip.c:136</div></div> +<div class="ttc" id="aneorv32__xip_8h_html_a92f1446a3bb7fe6dee5dbed33882b223"><div class="ttname"><a href="neorv32__xip_8h.html#a92f1446a3bb7fe6dee5dbed33882b223">neorv32_xip_spi_trans</a></div><div class="ttdeci">void neorv32_xip_spi_trans(int nbytes, uint64_t *rtx_data)</div><div class="ttdef"><b>Definition</b> neorv32_xip.c:167</div></div> +<div class="ttc" id="aneorv32__xip_8h_html_ad74f2842ed2251e3ae5c19e06dced0c3"><div class="ttname"><a href="neorv32__xip_8h.html#ad74f2842ed2251e3ae5c19e06dced0c3">neorv32_xip_highspeed_disable</a></div><div class="ttdeci">void neorv32_xip_highspeed_disable(void)</div><div class="ttdef"><b>Definition</b> neorv32_xip.c:125</div></div> +<div class="ttc" id="aneorv32__xip_8h_html_afe2e5682a26cafdb0585d2233bccc7c6"><div class="ttname"><a href="neorv32__xip_8h.html#afe2e5682a26cafdb0585d2233bccc7c6">neorv32_xip_available</a></div><div class="ttdeci">int neorv32_xip_available(void)</div><div class="ttdef"><b>Definition</b> neorv32_xip.c:26</div></div> +<div class="ttc" id="astructneorv32__xip__t_html"><div class="ttname"><a href="structneorv32__xip__t.html">neorv32_xip_t</a></div><div class="ttdef"><b>Definition</b> neorv32_xip.h:29</div></div> +<div class="ttc" id="astructneorv32__xip__t_html_a516ab9c075ef6d1fb741e243db7703b2"><div class="ttname"><a href="structneorv32__xip__t.html#a516ab9c075ef6d1fb741e243db7703b2">neorv32_xip_t::DATA_HI</a></div><div class="ttdeci">uint32_t DATA_HI</div><div class="ttdef"><b>Definition</b> neorv32_xip.h:33</div></div> +<div class="ttc" id="astructneorv32__xip__t_html_a7ead9d6a4f784d766a6b2755c6d35235"><div class="ttname"><a href="structneorv32__xip__t.html#a7ead9d6a4f784d766a6b2755c6d35235">neorv32_xip_t::CTRL</a></div><div class="ttdeci">uint32_t CTRL</div><div class="ttdef"><b>Definition</b> neorv32_xip.h:30</div></div> +<div class="ttc" id="astructneorv32__xip__t_html_aacb77d586c3caec518e8e0024cfe745c"><div class="ttname"><a href="structneorv32__xip__t.html#aacb77d586c3caec518e8e0024cfe745c">neorv32_xip_t::reserved</a></div><div class="ttdeci">const uint32_t reserved</div><div class="ttdef"><b>Definition</b> neorv32_xip.h:31</div></div> +<div class="ttc" id="astructneorv32__xip__t_html_ad64048bb3544e712b1c668c2ef343ccb"><div class="ttname"><a href="structneorv32__xip__t.html#ad64048bb3544e712b1c668c2ef343ccb">neorv32_xip_t::DATA_LO</a></div><div class="ttdeci">uint32_t DATA_LO</div><div class="ttdef"><b>Definition</b> neorv32_xip.h:32</div></div> +</div><!-- fragment --></div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/neorv32__xirq_8c.html b/sw/neorv32__xirq_8c.html new file mode 100644 index 0000000000..465355fcfc --- /dev/null +++ b/sw/neorv32__xirq_8c.html @@ -0,0 +1,479 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/lib/source/neorv32_xirq.c File Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_7d04193005ada6f9450f847f4adb6b5b.html">lib</a></li><li class="navelem"><a class="el" href="dir_0c6ac14e2254a316d41123f98feeb67b.html">source</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#func-members">Functions</a> &#124; +<a href="#var-members">Variables</a> </div> + <div class="headertitle"><div class="title">neorv32_xirq.c File Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p>External Interrupt controller HW driver source file. +<a href="#details">More...</a></p> +<div class="textblock"><code>#include &quot;<a class="el" href="neorv32_8h_source.html">neorv32.h</a>&quot;</code><br /> +</div><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="func-members" name="func-members"></a> +Functions</h2></td></tr> +<tr class="memitem:a14661d628dd31e6bfce89376c6614627" id="r_a14661d628dd31e6bfce89376c6614627"><td class="memItemLeft" align="right" valign="top">static void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a14661d628dd31e6bfce89376c6614627">__neorv32_xirq_core</a> (void)</td></tr> +<tr class="separator:a14661d628dd31e6bfce89376c6614627"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ae4d9362b23a1341c595a4cd239a87091" id="r_ae4d9362b23a1341c595a4cd239a87091"><td class="memItemLeft" align="right" valign="top">static void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ae4d9362b23a1341c595a4cd239a87091">__neorv32_xirq_dummy_handler</a> (void)</td></tr> +<tr class="separator:ae4d9362b23a1341c595a4cd239a87091"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aaf30757d526030a8d81081915ab29a76" id="r_aaf30757d526030a8d81081915ab29a76"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aaf30757d526030a8d81081915ab29a76">neorv32_xirq_available</a> (void)</td></tr> +<tr class="separator:aaf30757d526030a8d81081915ab29a76"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a9295997fce7114a8205325c4d75dd200" id="r_a9295997fce7114a8205325c4d75dd200"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a9295997fce7114a8205325c4d75dd200">neorv32_xirq_setup</a> (void)</td></tr> +<tr class="separator:a9295997fce7114a8205325c4d75dd200"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a76468156ef52b371e06bc2ca8eddcd27" id="r_a76468156ef52b371e06bc2ca8eddcd27"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a76468156ef52b371e06bc2ca8eddcd27">neorv32_xirq_global_enable</a> (void)</td></tr> +<tr class="separator:a76468156ef52b371e06bc2ca8eddcd27"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ac64d3ff5619968499bccebebe6a6cab3" id="r_ac64d3ff5619968499bccebebe6a6cab3"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ac64d3ff5619968499bccebebe6a6cab3">neorv32_xirq_global_disable</a> (void)</td></tr> +<tr class="separator:ac64d3ff5619968499bccebebe6a6cab3"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a717a8e34908cc01345e68920e76f229c" id="r_a717a8e34908cc01345e68920e76f229c"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a717a8e34908cc01345e68920e76f229c">neorv32_xirq_get_num</a> (void)</td></tr> +<tr class="separator:a717a8e34908cc01345e68920e76f229c"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a0d137f09d1e7dcd31c157b856033ac42" id="r_a0d137f09d1e7dcd31c157b856033ac42"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a0d137f09d1e7dcd31c157b856033ac42">neorv32_xirq_setup_trigger</a> (int channel, int config)</td></tr> +<tr class="separator:a0d137f09d1e7dcd31c157b856033ac42"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a83ecaf568a6f6bcb1e1efdb1eef6df9c" id="r_a83ecaf568a6f6bcb1e1efdb1eef6df9c"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a83ecaf568a6f6bcb1e1efdb1eef6df9c">neorv32_xirq_clear_pending</a> (int channel)</td></tr> +<tr class="separator:a83ecaf568a6f6bcb1e1efdb1eef6df9c"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:abe63c0968c94b472082c8156a1a7db5c" id="r_abe63c0968c94b472082c8156a1a7db5c"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#abe63c0968c94b472082c8156a1a7db5c">neorv32_xirq_channel_enable</a> (int channel)</td></tr> +<tr class="separator:abe63c0968c94b472082c8156a1a7db5c"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ae17509ad0c828aa9b36747b253cdbf0a" id="r_ae17509ad0c828aa9b36747b253cdbf0a"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ae17509ad0c828aa9b36747b253cdbf0a">neorv32_xirq_channel_disable</a> (int channel)</td></tr> +<tr class="separator:ae17509ad0c828aa9b36747b253cdbf0a"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a9129984f91c02afafaa072a5d86f9876" id="r_a9129984f91c02afafaa072a5d86f9876"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a9129984f91c02afafaa072a5d86f9876">neorv32_xirq_install</a> (int channel, void(*handler)(void))</td></tr> +<tr class="separator:a9129984f91c02afafaa072a5d86f9876"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a49ae67d1d5066cd795149e96b81127f7" id="r_a49ae67d1d5066cd795149e96b81127f7"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a49ae67d1d5066cd795149e96b81127f7">neorv32_xirq_uninstall</a> (int channel)</td></tr> +<tr class="separator:a49ae67d1d5066cd795149e96b81127f7"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="var-members" name="var-members"></a> +Variables</h2></td></tr> +<tr class="memitem:a76d73c3bf372989703c685a9e8d229ac" id="r_a76d73c3bf372989703c685a9e8d229ac"><td class="memItemLeft" align="right" valign="top">static uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a76d73c3bf372989703c685a9e8d229ac">__neorv32_xirq_vector_lut</a> [32]</td></tr> +<tr class="separator:a76d73c3bf372989703c685a9e8d229ac"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>External Interrupt controller HW driver source file. </p> +<dl class="section note"><dt>Note</dt><dd>These functions should only be used if the XIRQ controller was synthesized.</dd></dl> +<dl class="section see"><dt>See also</dt><dd><a href="https://stnolting.github.io/neorv32/sw/files.html">https://stnolting.github.io/neorv32/sw/files.html</a> </dd></dl> +</div><h2 class="groupheader">Function Documentation</h2> +<a id="a14661d628dd31e6bfce89376c6614627" name="a14661d628dd31e6bfce89376c6614627"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a14661d628dd31e6bfce89376c6614627">&#9670;&#160;</a></span>__neorv32_xirq_core()</h2> + +<div class="memitem"> +<div class="memproto"> +<table class="mlabels"> + <tr> + <td class="mlabels-left"> + <table class="memname"> + <tr> + <td class="memname">static void __neorv32_xirq_core </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> + </td> + <td class="mlabels-right"> +<span class="mlabels"><span class="mlabel">static</span></span> </td> + </tr> +</table> +</div><div class="memdoc"> +<p>This is the actual second-level (F)IRQ handler for the XIRQ. It will call the previously installed handler if an XIRQ fires. </p> + +</div> +</div> +<a id="ae4d9362b23a1341c595a4cd239a87091" name="ae4d9362b23a1341c595a4cd239a87091"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ae4d9362b23a1341c595a4cd239a87091">&#9670;&#160;</a></span>__neorv32_xirq_dummy_handler()</h2> + +<div class="memitem"> +<div class="memproto"> +<table class="mlabels"> + <tr> + <td class="mlabels-left"> + <table class="memname"> + <tr> + <td class="memname">static void __neorv32_xirq_dummy_handler </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> + </td> + <td class="mlabels-right"> +<span class="mlabels"><span class="mlabel">static</span></span> </td> + </tr> +</table> +</div><div class="memdoc"> +<p>XIRQ dummy handler. </p> + +</div> +</div> +<a id="aaf30757d526030a8d81081915ab29a76" name="aaf30757d526030a8d81081915ab29a76"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aaf30757d526030a8d81081915ab29a76">&#9670;&#160;</a></span>neorv32_xirq_available()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_xirq_available </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Check if external interrupt controller was synthesized.</p> +<dl class="section return"><dt>Returns</dt><dd>0 if XIRQ was not synthesized, 1 if EXTIRQ is available. </dd></dl> + +</div> +</div> +<a id="ae17509ad0c828aa9b36747b253cdbf0a" name="ae17509ad0c828aa9b36747b253cdbf0a"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ae17509ad0c828aa9b36747b253cdbf0a">&#9670;&#160;</a></span>neorv32_xirq_channel_disable()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_xirq_channel_disable </td> + <td>(</td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>channel</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Disable IRQ channel.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">channel</td><td>XIRQ interrupt channel (0..31). </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="abe63c0968c94b472082c8156a1a7db5c" name="abe63c0968c94b472082c8156a1a7db5c"></a> +<h2 class="memtitle"><span class="permalink"><a href="#abe63c0968c94b472082c8156a1a7db5c">&#9670;&#160;</a></span>neorv32_xirq_channel_enable()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_xirq_channel_enable </td> + <td>(</td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>channel</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Enable IRQ channel.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">channel</td><td>XIRQ interrupt channel (0..31). </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="a83ecaf568a6f6bcb1e1efdb1eef6df9c" name="a83ecaf568a6f6bcb1e1efdb1eef6df9c"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a83ecaf568a6f6bcb1e1efdb1eef6df9c">&#9670;&#160;</a></span>neorv32_xirq_clear_pending()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_xirq_clear_pending </td> + <td>(</td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>channel</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Clear pending interrupt.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">channel</td><td>XIRQ interrupt channel (0..31). </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="a717a8e34908cc01345e68920e76f229c" name="a717a8e34908cc01345e68920e76f229c"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a717a8e34908cc01345e68920e76f229c">&#9670;&#160;</a></span>neorv32_xirq_get_num()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_xirq_get_num </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Get number of implemented XIRQ channels</p> +<dl class="section return"><dt>Returns</dt><dd>Number of implemented channels (0..32). </dd></dl> + +</div> +</div> +<a id="ac64d3ff5619968499bccebebe6a6cab3" name="ac64d3ff5619968499bccebebe6a6cab3"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ac64d3ff5619968499bccebebe6a6cab3">&#9670;&#160;</a></span>neorv32_xirq_global_disable()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_xirq_global_disable </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Globally disable XIRQ interrupts (via according FIRQ channel).</p> +<dl class="section note"><dt>Note</dt><dd>Triggered / triggering XIRQ will remain pending. </dd></dl> + +</div> +</div> +<a id="a76468156ef52b371e06bc2ca8eddcd27" name="a76468156ef52b371e06bc2ca8eddcd27"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a76468156ef52b371e06bc2ca8eddcd27">&#9670;&#160;</a></span>neorv32_xirq_global_enable()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_xirq_global_enable </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Globally enable XIRQ interrupts (via according FIRQ channel).</p> +<dl class="section note"><dt>Note</dt><dd>Triggered / triggering XIRQ will remain pending. </dd></dl> + +</div> +</div> +<a id="a9129984f91c02afafaa072a5d86f9876" name="a9129984f91c02afafaa072a5d86f9876"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a9129984f91c02afafaa072a5d86f9876">&#9670;&#160;</a></span>neorv32_xirq_install()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_xirq_install </td> + <td>(</td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>channel</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">void(*</td> <td class="paramname"><span class="paramname"><em>handler&#160;</em></span>)(void)&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Install interrupt handler function for XIRQ channel.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">channel</td><td>XIRQ interrupt channel (0..31). </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">handler</td><td>The actual handler function for the specified interrupt (function MUST be of type "void function(void);"). </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>0 if success, 1 if error. </dd></dl> + +</div> +</div> +<a id="a9295997fce7114a8205325c4d75dd200" name="a9295997fce7114a8205325c4d75dd200"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a9295997fce7114a8205325c4d75dd200">&#9670;&#160;</a></span>neorv32_xirq_setup()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_xirq_setup </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Initialize XIRQ controller.</p> +<dl class="section note"><dt>Note</dt><dd>All interrupt channels will be deactivated, all pending IRQs will be deleted and all handler addresses will be deleted.</dd></dl> +<dl class="section return"><dt>Returns</dt><dd>0 if success, != 0 if error. </dd></dl> + +</div> +</div> +<a id="a0d137f09d1e7dcd31c157b856033ac42" name="a0d137f09d1e7dcd31c157b856033ac42"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a0d137f09d1e7dcd31c157b856033ac42">&#9670;&#160;</a></span>neorv32_xirq_setup_trigger()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_xirq_setup_trigger </td> + <td>(</td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>channel</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>config</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Configure a channel's trigger type.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">channel</td><td>XIRQ interrupt channel (0..31). </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">config</td><td>Trigger type: 00 = low-level, 01 = high-level, 10 = falling-edge, 11 = rising-edge. </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="a49ae67d1d5066cd795149e96b81127f7" name="a49ae67d1d5066cd795149e96b81127f7"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a49ae67d1d5066cd795149e96b81127f7">&#9670;&#160;</a></span>neorv32_xirq_uninstall()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_xirq_uninstall </td> + <td>(</td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>channel</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Uninstall interrupt handler function for XIRQ channel.</p> +<dl class="section note"><dt>Note</dt><dd>This will also deactivate the according XIRQ channel.</dd></dl> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">channel</td><td>XIRQ interrupt channel (0..31). </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>0 if success, 1 if error. </dd></dl> + +</div> +</div> +<h2 class="groupheader">Variable Documentation</h2> +<a id="a76d73c3bf372989703c685a9e8d229ac" name="a76d73c3bf372989703c685a9e8d229ac"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a76d73c3bf372989703c685a9e8d229ac">&#9670;&#160;</a></span>__neorv32_xirq_vector_lut</h2> + +<div class="memitem"> +<div class="memproto"> +<table class="mlabels"> + <tr> + <td class="mlabels-left"> + <table class="memname"> + <tr> + <td class="memname">uint32_t __neorv32_xirq_vector_lut[32]</td> + </tr> + </table> + </td> + <td class="mlabels-right"> +<span class="mlabels"><span class="mlabel">static</span></span> </td> + </tr> +</table> +</div><div class="memdoc"> +<p>The &gt;private&lt; trap vector look-up table of the XIRQ. </p> + +</div> +</div> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/neorv32__xirq_8h.html b/sw/neorv32__xirq_8h.html new file mode 100644 index 0000000000..92737d19ab --- /dev/null +++ b/sw/neorv32__xirq_8h.html @@ -0,0 +1,491 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/lib/include/neorv32_xirq.h File Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_7d04193005ada6f9450f847f4adb6b5b.html">lib</a></li><li class="navelem"><a class="el" href="dir_752b1e5d3973bf735fa78bf6b4727df9.html">include</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#nested-classes">Data Structures</a> </div> + <div class="headertitle"><div class="title">neorv32_xirq.h File Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p>External Interrupt controller HW driver header file. +<a href="#details">More...</a></p> +<div class="textblock"><code>#include &lt;stdint.h&gt;</code><br /> +</div> +<p><a href="neorv32__xirq_8h_source.html">Go to the source code of this file.</a></p> +<table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="nested-classes" name="nested-classes"></a> +Data Structures</h2></td></tr> +<tr class="memitem:"><td class="memItemLeft" align="right" valign="top">struct &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structneorv32__xirq__t.html">neorv32_xirq_t</a></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="define-members" name="define-members"></a> +Macros</h2></td></tr> +<tr><td colspan="2"><div class="groupHeader">IO Device: External Interrupt Controller (XIRQ)</div></td></tr> +<tr class="memitem:a0c0886139e9837867202e5f6a83307c4" id="r_a0c0886139e9837867202e5f6a83307c4"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a0c0886139e9837867202e5f6a83307c4">NEORV32_XIRQ</a>&#160;&#160;&#160;((<a class="el" href="structneorv32__xirq__t.html">neorv32_xirq_t</a>*) (<a class="el" href="neorv32_8h.html#a942a897be2d4ae6820bee0f7bb3a0ff1">NEORV32_XIRQ_BASE</a>))</td></tr> +<tr class="separator:a0c0886139e9837867202e5f6a83307c4"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr><td colspan="2"><div class="groupHeader"></div></td></tr> +<tr class="memitem:a8bc89e6a47b4d0d95fb2afac4cdc9292" id="r_a8bc89e6a47b4d0d95fb2afac4cdc9292"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a8bc89e6a47b4d0d95fb2afac4cdc9292">XIRQ_TRIGGER_LEVEL_LOW</a>&#160;&#160;&#160;(0b00)</td></tr> +<tr class="separator:a8bc89e6a47b4d0d95fb2afac4cdc9292"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a9b10e89b2e257e1af410bff89f29911c" id="r_a9b10e89b2e257e1af410bff89f29911c"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a9b10e89b2e257e1af410bff89f29911c">XIRQ_TRIGGER_LEVEL_HIGH</a>&#160;&#160;&#160;(0b01)</td></tr> +<tr class="separator:a9b10e89b2e257e1af410bff89f29911c"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a59316ffc7ee1aacf1d55d460bdca4d04" id="r_a59316ffc7ee1aacf1d55d460bdca4d04"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a59316ffc7ee1aacf1d55d460bdca4d04">XIRQ_TRIGGER_EDGE_FALLING</a>&#160;&#160;&#160;(0b10)</td></tr> +<tr class="separator:a59316ffc7ee1aacf1d55d460bdca4d04"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ab7a05371e4dc3de3a9be11c59f5376ee" id="r_ab7a05371e4dc3de3a9be11c59f5376ee"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ab7a05371e4dc3de3a9be11c59f5376ee">XIRQ_TRIGGER_EDGE_RISING</a>&#160;&#160;&#160;(0b11)</td></tr> +<tr class="separator:ab7a05371e4dc3de3a9be11c59f5376ee"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="func-members" name="func-members"></a> +Functions</h2></td></tr> +<tr><td colspan="2"><div class="groupHeader">Prototypes</div></td></tr> +<tr class="memitem:aaf30757d526030a8d81081915ab29a76" id="r_aaf30757d526030a8d81081915ab29a76"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aaf30757d526030a8d81081915ab29a76">neorv32_xirq_available</a> (void)</td></tr> +<tr class="separator:aaf30757d526030a8d81081915ab29a76"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a9295997fce7114a8205325c4d75dd200" id="r_a9295997fce7114a8205325c4d75dd200"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a9295997fce7114a8205325c4d75dd200">neorv32_xirq_setup</a> (void)</td></tr> +<tr class="separator:a9295997fce7114a8205325c4d75dd200"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a76468156ef52b371e06bc2ca8eddcd27" id="r_a76468156ef52b371e06bc2ca8eddcd27"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a76468156ef52b371e06bc2ca8eddcd27">neorv32_xirq_global_enable</a> (void)</td></tr> +<tr class="separator:a76468156ef52b371e06bc2ca8eddcd27"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ac64d3ff5619968499bccebebe6a6cab3" id="r_ac64d3ff5619968499bccebebe6a6cab3"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ac64d3ff5619968499bccebebe6a6cab3">neorv32_xirq_global_disable</a> (void)</td></tr> +<tr class="separator:ac64d3ff5619968499bccebebe6a6cab3"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a717a8e34908cc01345e68920e76f229c" id="r_a717a8e34908cc01345e68920e76f229c"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a717a8e34908cc01345e68920e76f229c">neorv32_xirq_get_num</a> (void)</td></tr> +<tr class="separator:a717a8e34908cc01345e68920e76f229c"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a0d137f09d1e7dcd31c157b856033ac42" id="r_a0d137f09d1e7dcd31c157b856033ac42"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a0d137f09d1e7dcd31c157b856033ac42">neorv32_xirq_setup_trigger</a> (int channel, int config)</td></tr> +<tr class="separator:a0d137f09d1e7dcd31c157b856033ac42"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a83ecaf568a6f6bcb1e1efdb1eef6df9c" id="r_a83ecaf568a6f6bcb1e1efdb1eef6df9c"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a83ecaf568a6f6bcb1e1efdb1eef6df9c">neorv32_xirq_clear_pending</a> (int channel)</td></tr> +<tr class="separator:a83ecaf568a6f6bcb1e1efdb1eef6df9c"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:abe63c0968c94b472082c8156a1a7db5c" id="r_abe63c0968c94b472082c8156a1a7db5c"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#abe63c0968c94b472082c8156a1a7db5c">neorv32_xirq_channel_enable</a> (int channel)</td></tr> +<tr class="separator:abe63c0968c94b472082c8156a1a7db5c"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ae17509ad0c828aa9b36747b253cdbf0a" id="r_ae17509ad0c828aa9b36747b253cdbf0a"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ae17509ad0c828aa9b36747b253cdbf0a">neorv32_xirq_channel_disable</a> (int channel)</td></tr> +<tr class="separator:ae17509ad0c828aa9b36747b253cdbf0a"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a9129984f91c02afafaa072a5d86f9876" id="r_a9129984f91c02afafaa072a5d86f9876"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a9129984f91c02afafaa072a5d86f9876">neorv32_xirq_install</a> (int channel, void(*handler)(void))</td></tr> +<tr class="separator:a9129984f91c02afafaa072a5d86f9876"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a49ae67d1d5066cd795149e96b81127f7" id="r_a49ae67d1d5066cd795149e96b81127f7"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a49ae67d1d5066cd795149e96b81127f7">neorv32_xirq_uninstall</a> (int channel)</td></tr> +<tr class="separator:a49ae67d1d5066cd795149e96b81127f7"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>External Interrupt controller HW driver header file. </p> +<dl class="section see"><dt>See also</dt><dd><a href="https://stnolting.github.io/neorv32/sw/files.html">https://stnolting.github.io/neorv32/sw/files.html</a> </dd></dl> +</div><h2 class="groupheader">Macro Definition Documentation</h2> +<a id="a0c0886139e9837867202e5f6a83307c4" name="a0c0886139e9837867202e5f6a83307c4"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a0c0886139e9837867202e5f6a83307c4">&#9670;&#160;</a></span>NEORV32_XIRQ</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define NEORV32_XIRQ&#160;&#160;&#160;((<a class="el" href="structneorv32__xirq__t.html">neorv32_xirq_t</a>*) (<a class="el" href="neorv32_8h.html#a942a897be2d4ae6820bee0f7bb3a0ff1">NEORV32_XIRQ_BASE</a>))</td> + </tr> + </table> +</div><div class="memdoc"> +<p>XIRQ module hardware access (<a class="el" href="structneorv32__xirq__t.html">neorv32_xirq_t</a>) </p> + +</div> +</div> +<a id="a59316ffc7ee1aacf1d55d460bdca4d04" name="a59316ffc7ee1aacf1d55d460bdca4d04"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a59316ffc7ee1aacf1d55d460bdca4d04">&#9670;&#160;</a></span>XIRQ_TRIGGER_EDGE_FALLING</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define XIRQ_TRIGGER_EDGE_FALLING&#160;&#160;&#160;(0b10)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>XIRQ trigger configuration </p> + +</div> +</div> +<a id="ab7a05371e4dc3de3a9be11c59f5376ee" name="ab7a05371e4dc3de3a9be11c59f5376ee"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ab7a05371e4dc3de3a9be11c59f5376ee">&#9670;&#160;</a></span>XIRQ_TRIGGER_EDGE_RISING</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define XIRQ_TRIGGER_EDGE_RISING&#160;&#160;&#160;(0b11)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>XIRQ trigger configuration </p> + +</div> +</div> +<a id="a9b10e89b2e257e1af410bff89f29911c" name="a9b10e89b2e257e1af410bff89f29911c"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a9b10e89b2e257e1af410bff89f29911c">&#9670;&#160;</a></span>XIRQ_TRIGGER_LEVEL_HIGH</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define XIRQ_TRIGGER_LEVEL_HIGH&#160;&#160;&#160;(0b01)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>XIRQ trigger configuration </p> + +</div> +</div> +<a id="a8bc89e6a47b4d0d95fb2afac4cdc9292" name="a8bc89e6a47b4d0d95fb2afac4cdc9292"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a8bc89e6a47b4d0d95fb2afac4cdc9292">&#9670;&#160;</a></span>XIRQ_TRIGGER_LEVEL_LOW</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">#define XIRQ_TRIGGER_LEVEL_LOW&#160;&#160;&#160;(0b00)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>XIRQ trigger configuration </p> + +</div> +</div> +<h2 class="groupheader">Function Documentation</h2> +<a id="aaf30757d526030a8d81081915ab29a76" name="aaf30757d526030a8d81081915ab29a76"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aaf30757d526030a8d81081915ab29a76">&#9670;&#160;</a></span>neorv32_xirq_available()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_xirq_available </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Check if external interrupt controller was synthesized.</p> +<dl class="section return"><dt>Returns</dt><dd>0 if XIRQ was not synthesized, 1 if EXTIRQ is available. </dd></dl> + +</div> +</div> +<a id="ae17509ad0c828aa9b36747b253cdbf0a" name="ae17509ad0c828aa9b36747b253cdbf0a"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ae17509ad0c828aa9b36747b253cdbf0a">&#9670;&#160;</a></span>neorv32_xirq_channel_disable()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_xirq_channel_disable </td> + <td>(</td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>channel</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Disable IRQ channel.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">channel</td><td>XIRQ interrupt channel (0..31). </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="abe63c0968c94b472082c8156a1a7db5c" name="abe63c0968c94b472082c8156a1a7db5c"></a> +<h2 class="memtitle"><span class="permalink"><a href="#abe63c0968c94b472082c8156a1a7db5c">&#9670;&#160;</a></span>neorv32_xirq_channel_enable()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_xirq_channel_enable </td> + <td>(</td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>channel</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Enable IRQ channel.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">channel</td><td>XIRQ interrupt channel (0..31). </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="a83ecaf568a6f6bcb1e1efdb1eef6df9c" name="a83ecaf568a6f6bcb1e1efdb1eef6df9c"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a83ecaf568a6f6bcb1e1efdb1eef6df9c">&#9670;&#160;</a></span>neorv32_xirq_clear_pending()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_xirq_clear_pending </td> + <td>(</td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>channel</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Clear pending interrupt.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">channel</td><td>XIRQ interrupt channel (0..31). </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="a717a8e34908cc01345e68920e76f229c" name="a717a8e34908cc01345e68920e76f229c"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a717a8e34908cc01345e68920e76f229c">&#9670;&#160;</a></span>neorv32_xirq_get_num()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_xirq_get_num </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Get number of implemented XIRQ channels</p> +<dl class="section return"><dt>Returns</dt><dd>Number of implemented channels (0..32). </dd></dl> + +</div> +</div> +<a id="ac64d3ff5619968499bccebebe6a6cab3" name="ac64d3ff5619968499bccebebe6a6cab3"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ac64d3ff5619968499bccebebe6a6cab3">&#9670;&#160;</a></span>neorv32_xirq_global_disable()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_xirq_global_disable </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Globally disable XIRQ interrupts (via according FIRQ channel).</p> +<dl class="section note"><dt>Note</dt><dd>Triggered / triggering XIRQ will remain pending. </dd></dl> + +</div> +</div> +<a id="a76468156ef52b371e06bc2ca8eddcd27" name="a76468156ef52b371e06bc2ca8eddcd27"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a76468156ef52b371e06bc2ca8eddcd27">&#9670;&#160;</a></span>neorv32_xirq_global_enable()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_xirq_global_enable </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Globally enable XIRQ interrupts (via according FIRQ channel).</p> +<dl class="section note"><dt>Note</dt><dd>Triggered / triggering XIRQ will remain pending. </dd></dl> + +</div> +</div> +<a id="a9129984f91c02afafaa072a5d86f9876" name="a9129984f91c02afafaa072a5d86f9876"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a9129984f91c02afafaa072a5d86f9876">&#9670;&#160;</a></span>neorv32_xirq_install()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_xirq_install </td> + <td>(</td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>channel</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">void(*</td> <td class="paramname"><span class="paramname"><em>handler&#160;</em></span>)(void)&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Install interrupt handler function for XIRQ channel.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">channel</td><td>XIRQ interrupt channel (0..31). </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">handler</td><td>The actual handler function for the specified interrupt (function MUST be of type "void function(void);"). </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>0 if success, 1 if error. </dd></dl> + +</div> +</div> +<a id="a9295997fce7114a8205325c4d75dd200" name="a9295997fce7114a8205325c4d75dd200"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a9295997fce7114a8205325c4d75dd200">&#9670;&#160;</a></span>neorv32_xirq_setup()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_xirq_setup </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Initialize XIRQ controller.</p> +<dl class="section note"><dt>Note</dt><dd>All interrupt channels will be deactivated, all pending IRQs will be deleted and all handler addresses will be deleted.</dd></dl> +<dl class="section return"><dt>Returns</dt><dd>0 if success, != 0 if error. </dd></dl> + +</div> +</div> +<a id="a0d137f09d1e7dcd31c157b856033ac42" name="a0d137f09d1e7dcd31c157b856033ac42"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a0d137f09d1e7dcd31c157b856033ac42">&#9670;&#160;</a></span>neorv32_xirq_setup_trigger()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void neorv32_xirq_setup_trigger </td> + <td>(</td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>channel</em></span>, </td> + </tr> + <tr> + <td class="paramkey"></td> + <td></td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>config</em></span>&#160;)</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Configure a channel's trigger type.</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">channel</td><td>XIRQ interrupt channel (0..31). </td></tr> + <tr><td class="paramdir">[in]</td><td class="paramname">config</td><td>Trigger type: 00 = low-level, 01 = high-level, 10 = falling-edge, 11 = rising-edge. </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="a49ae67d1d5066cd795149e96b81127f7" name="a49ae67d1d5066cd795149e96b81127f7"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a49ae67d1d5066cd795149e96b81127f7">&#9670;&#160;</a></span>neorv32_xirq_uninstall()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int neorv32_xirq_uninstall </td> + <td>(</td> + <td class="paramtype">int</td> <td class="paramname"><span class="paramname"><em>channel</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Uninstall interrupt handler function for XIRQ channel.</p> +<dl class="section note"><dt>Note</dt><dd>This will also deactivate the according XIRQ channel.</dd></dl> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">channel</td><td>XIRQ interrupt channel (0..31). </td></tr> + </table> + </dd> +</dl> +<dl class="section return"><dt>Returns</dt><dd>0 if success, 1 if error. </dd></dl> + +</div> +</div> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/neorv32__xirq_8h_source.html b/sw/neorv32__xirq_8h_source.html new file mode 100644 index 0000000000..09e0acd2fa --- /dev/null +++ b/sw/neorv32__xirq_8h_source.html @@ -0,0 +1,170 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/lib/include/neorv32_xirq.h Source File</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_7d04193005ada6f9450f847f4adb6b5b.html">lib</a></li><li class="navelem"><a class="el" href="dir_752b1e5d3973bf735fa78bf6b4727df9.html">include</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="headertitle"><div class="title">neorv32_xirq.h</div></div> +</div><!--header--> +<div class="contents"> +<a href="neorv32__xirq_8h.html">Go to the documentation of this file.</a><div class="fragment"><div class="line"><a id="l00001" name="l00001"></a><span class="lineno"> 1</span><span class="comment">// ================================================================================ //</span></div> +<div class="line"><a id="l00002" name="l00002"></a><span class="lineno"> 2</span><span class="comment">// The NEORV32 RISC-V Processor - https://github.com/stnolting/neorv32 //</span></div> +<div class="line"><a id="l00003" name="l00003"></a><span class="lineno"> 3</span><span class="comment">// Copyright (c) NEORV32 contributors. //</span></div> +<div class="line"><a id="l00004" name="l00004"></a><span class="lineno"> 4</span><span class="comment">// Copyright (c) 2020 - 2024 Stephan Nolting. All rights reserved. //</span></div> +<div class="line"><a id="l00005" name="l00005"></a><span class="lineno"> 5</span><span class="comment">// Licensed under the BSD-3-Clause license, see LICENSE for details. //</span></div> +<div class="line"><a id="l00006" name="l00006"></a><span class="lineno"> 6</span><span class="comment">// SPDX-License-Identifier: BSD-3-Clause //</span></div> +<div class="line"><a id="l00007" name="l00007"></a><span class="lineno"> 7</span><span class="comment">// ================================================================================ //</span></div> +<div class="line"><a id="l00008" name="l00008"></a><span class="lineno"> 8</span> </div> +<div class="line"><a id="l00016" name="l00016"></a><span class="lineno"> 16</span><span class="preprocessor">#ifndef neorv32_xirq_h</span></div> +<div class="line"><a id="l00017" name="l00017"></a><span class="lineno"> 17</span><span class="preprocessor">#define neorv32_xirq_h</span></div> +<div class="line"><a id="l00018" name="l00018"></a><span class="lineno"> 18</span> </div> +<div class="line"><a id="l00019" name="l00019"></a><span class="lineno"> 19</span><span class="preprocessor">#include &lt;stdint.h&gt;</span></div> +<div class="line"><a id="l00020" name="l00020"></a><span class="lineno"> 20</span> </div> +<div class="line"><a id="l00021" name="l00021"></a><span class="lineno"> 21</span> </div> +<div class="line"><a id="l00022" name="l00022"></a><span class="lineno"> 22</span><span class="comment">/**********************************************************************/</span></div> +<div class="foldopen" id="foldopen00027" data-start="{" data-end="};"> +<div class="line"><a id="l00027" name="l00027"></a><span class="lineno"><a class="line" href="structneorv32__xirq__t.html"> 27</a></span><span class="keyword">typedef</span> <span class="keyword">volatile</span> <span class="keyword">struct </span>__attribute__((packed,aligned(4))) {</div> +<div class="line"><a id="l00028" name="l00028"></a><span class="lineno"><a class="line" href="structneorv32__xirq__t.html#aef3c2b491207abd68bf6392f97096a74"> 28</a></span> uint32_t <a class="code hl_variable" href="structneorv32__xirq__t.html#aef3c2b491207abd68bf6392f97096a74">EIE</a>; </div> +<div class="line"><a id="l00029" name="l00029"></a><span class="lineno"><a class="line" href="structneorv32__xirq__t.html#a788d8004f3b85fb66e947415d8fcc058"> 29</a></span> uint32_t <a class="code hl_variable" href="structneorv32__xirq__t.html#a788d8004f3b85fb66e947415d8fcc058">EIP</a>; </div> +<div class="line"><a id="l00030" name="l00030"></a><span class="lineno"><a class="line" href="structneorv32__xirq__t.html#ae4f7f3f41210ff329b6f82d5dfada88a"> 30</a></span> uint32_t <a class="code hl_variable" href="structneorv32__xirq__t.html#ae4f7f3f41210ff329b6f82d5dfada88a">ESC</a>; </div> +<div class="line"><a id="l00031" name="l00031"></a><span class="lineno"><a class="line" href="structneorv32__xirq__t.html#ab7117c210b5f0a8ebc369eeba6a4a5bc"> 31</a></span> uint32_t <a class="code hl_variable" href="structneorv32__xirq__t.html#ab7117c210b5f0a8ebc369eeba6a4a5bc">TTYP</a>; </div> +<div class="line"><a id="l00032" name="l00032"></a><span class="lineno"><a class="line" href="structneorv32__xirq__t.html#a5fe0036a2cada585228b60aaa780e92a"> 32</a></span> uint32_t <a class="code hl_variable" href="structneorv32__xirq__t.html#a5fe0036a2cada585228b60aaa780e92a">TPOL</a>; </div> +<div class="line"><a id="l00033" name="l00033"></a><span class="lineno"><a class="line" href="structneorv32__xirq__t.html#a9be02c0398fab5763a3afbd7a018f092"> 33</a></span> <span class="keyword">const</span> uint32_t <a class="code hl_variable" href="structneorv32__xirq__t.html#a9be02c0398fab5763a3afbd7a018f092">reserved0</a>; </div> +<div class="line"><a id="l00034" name="l00034"></a><span class="lineno"><a class="line" href="structneorv32__xirq__t.html#ac4c999cf3da75e39753619f917d9d654"> 34</a></span> <span class="keyword">const</span> uint32_t <a class="code hl_variable" href="structneorv32__xirq__t.html#ac4c999cf3da75e39753619f917d9d654">reserved1</a>; </div> +<div class="line"><a id="l00035" name="l00035"></a><span class="lineno"><a class="line" href="structneorv32__xirq__t.html#afba6ed500e1448719783923975b2dc64"> 35</a></span> <span class="keyword">const</span> uint32_t <a class="code hl_variable" href="structneorv32__xirq__t.html#afba6ed500e1448719783923975b2dc64">reserved2</a>; </div> +<div class="line"><a id="l00036" name="l00036"></a><span class="lineno"> 36</span>} <a class="code hl_struct" href="structneorv32__xirq__t.html">neorv32_xirq_t</a>;</div> +</div> +<div class="line"><a id="l00037" name="l00037"></a><span class="lineno"> 37</span> </div> +<div class="line"><a id="l00039" name="l00039"></a><span class="lineno"><a class="line" href="neorv32__xirq_8h.html#a0c0886139e9837867202e5f6a83307c4"> 39</a></span><span class="preprocessor">#define NEORV32_XIRQ ((neorv32_xirq_t*) (NEORV32_XIRQ_BASE))</span></div> +<div class="line"><a id="l00043" name="l00043"></a><span class="lineno"> 43</span><span class="comment">/**********************************************************************/</span></div> +<div class="line"><a id="l00047" name="l00047"></a><span class="lineno"><a class="line" href="neorv32__xirq_8h.html#a8bc89e6a47b4d0d95fb2afac4cdc9292"> 47</a></span><span class="preprocessor">#define XIRQ_TRIGGER_LEVEL_LOW (0b00) </span><span class="comment">// low-level</span></div> +<div class="line"><a id="l00048" name="l00048"></a><span class="lineno"><a class="line" href="neorv32__xirq_8h.html#a9b10e89b2e257e1af410bff89f29911c"> 48</a></span><span class="preprocessor">#define XIRQ_TRIGGER_LEVEL_HIGH (0b01) </span><span class="comment">// high-level</span></div> +<div class="line"><a id="l00049" name="l00049"></a><span class="lineno"><a class="line" href="neorv32__xirq_8h.html#a59316ffc7ee1aacf1d55d460bdca4d04"> 49</a></span><span class="preprocessor">#define XIRQ_TRIGGER_EDGE_FALLING (0b10) </span><span class="comment">// falling-edge</span></div> +<div class="line"><a id="l00050" name="l00050"></a><span class="lineno"><a class="line" href="neorv32__xirq_8h.html#ab7a05371e4dc3de3a9be11c59f5376ee"> 50</a></span><span class="preprocessor">#define XIRQ_TRIGGER_EDGE_RISING (0b11) </span><span class="comment">// rising-edge</span></div> +<div class="line"><a id="l00054" name="l00054"></a><span class="lineno"> 54</span><span class="comment">/**********************************************************************/</span><span class="preprocessor"></span></div> +<div class="line"><a id="l00058" name="l00058"></a><span class="lineno"> 58</span><span class="keywordtype">int</span> <a class="code hl_function" href="neorv32__xirq_8h.html#aaf30757d526030a8d81081915ab29a76">neorv32_xirq_available</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00059" name="l00059"></a><span class="lineno"> 59</span><span class="keywordtype">int</span> <a class="code hl_function" href="neorv32__xirq_8h.html#a9295997fce7114a8205325c4d75dd200">neorv32_xirq_setup</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00060" name="l00060"></a><span class="lineno"> 60</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__xirq_8h.html#a76468156ef52b371e06bc2ca8eddcd27">neorv32_xirq_global_enable</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00061" name="l00061"></a><span class="lineno"> 61</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__xirq_8h.html#ac64d3ff5619968499bccebebe6a6cab3">neorv32_xirq_global_disable</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00062" name="l00062"></a><span class="lineno"> 62</span><span class="keywordtype">int</span> <a class="code hl_function" href="neorv32__xirq_8h.html#a717a8e34908cc01345e68920e76f229c">neorv32_xirq_get_num</a>(<span class="keywordtype">void</span>);</div> +<div class="line"><a id="l00063" name="l00063"></a><span class="lineno"> 63</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__xirq_8h.html#a0d137f09d1e7dcd31c157b856033ac42">neorv32_xirq_setup_trigger</a>(<span class="keywordtype">int</span> channel, <span class="keywordtype">int</span> config);</div> +<div class="line"><a id="l00064" name="l00064"></a><span class="lineno"> 64</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__xirq_8h.html#a83ecaf568a6f6bcb1e1efdb1eef6df9c">neorv32_xirq_clear_pending</a>(<span class="keywordtype">int</span> channel);</div> +<div class="line"><a id="l00065" name="l00065"></a><span class="lineno"> 65</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__xirq_8h.html#abe63c0968c94b472082c8156a1a7db5c">neorv32_xirq_channel_enable</a>(<span class="keywordtype">int</span> channel);</div> +<div class="line"><a id="l00066" name="l00066"></a><span class="lineno"> 66</span><span class="keywordtype">void</span> <a class="code hl_function" href="neorv32__xirq_8h.html#ae17509ad0c828aa9b36747b253cdbf0a">neorv32_xirq_channel_disable</a>(<span class="keywordtype">int</span> channel);</div> +<div class="line"><a id="l00067" name="l00067"></a><span class="lineno"> 67</span><span class="keywordtype">int</span> <a class="code hl_function" href="neorv32__xirq_8h.html#a9129984f91c02afafaa072a5d86f9876">neorv32_xirq_install</a>(<span class="keywordtype">int</span> channel, <span class="keywordtype">void</span> (*handler)(<span class="keywordtype">void</span>));</div> +<div class="line"><a id="l00068" name="l00068"></a><span class="lineno"> 68</span><span class="keywordtype">int</span> <a class="code hl_function" href="neorv32__xirq_8h.html#a49ae67d1d5066cd795149e96b81127f7">neorv32_xirq_uninstall</a>(<span class="keywordtype">int</span> channel);</div> +<div class="line"><a id="l00072" name="l00072"></a><span class="lineno"> 72</span><span class="preprocessor">#endif </span><span class="comment">// neorv32_xirq_h</span></div> +<div class="ttc" id="aneorv32__xirq_8h_html_a0d137f09d1e7dcd31c157b856033ac42"><div class="ttname"><a href="neorv32__xirq_8h.html#a0d137f09d1e7dcd31c157b856033ac42">neorv32_xirq_setup_trigger</a></div><div class="ttdeci">void neorv32_xirq_setup_trigger(int channel, int config)</div><div class="ttdef"><b>Definition</b> neorv32_xirq.c:157</div></div> +<div class="ttc" id="aneorv32__xirq_8h_html_a49ae67d1d5066cd795149e96b81127f7"><div class="ttname"><a href="neorv32__xirq_8h.html#a49ae67d1d5066cd795149e96b81127f7">neorv32_xirq_uninstall</a></div><div class="ttdeci">int neorv32_xirq_uninstall(int channel)</div><div class="ttdef"><b>Definition</b> neorv32_xirq.c:242</div></div> +<div class="ttc" id="aneorv32__xirq_8h_html_a717a8e34908cc01345e68920e76f229c"><div class="ttname"><a href="neorv32__xirq_8h.html#a717a8e34908cc01345e68920e76f229c">neorv32_xirq_get_num</a></div><div class="ttdeci">int neorv32_xirq_get_num(void)</div><div class="ttdef"><b>Definition</b> neorv32_xirq.c:126</div></div> +<div class="ttc" id="aneorv32__xirq_8h_html_a76468156ef52b371e06bc2ca8eddcd27"><div class="ttname"><a href="neorv32__xirq_8h.html#a76468156ef52b371e06bc2ca8eddcd27">neorv32_xirq_global_enable</a></div><div class="ttdeci">void neorv32_xirq_global_enable(void)</div><div class="ttdef"><b>Definition</b> neorv32_xirq.c:102</div></div> +<div class="ttc" id="aneorv32__xirq_8h_html_a83ecaf568a6f6bcb1e1efdb1eef6df9c"><div class="ttname"><a href="neorv32__xirq_8h.html#a83ecaf568a6f6bcb1e1efdb1eef6df9c">neorv32_xirq_clear_pending</a></div><div class="ttdeci">void neorv32_xirq_clear_pending(int channel)</div><div class="ttdef"><b>Definition</b> neorv32_xirq.c:185</div></div> +<div class="ttc" id="aneorv32__xirq_8h_html_a9129984f91c02afafaa072a5d86f9876"><div class="ttname"><a href="neorv32__xirq_8h.html#a9129984f91c02afafaa072a5d86f9876">neorv32_xirq_install</a></div><div class="ttdeci">int neorv32_xirq_install(int channel, void(*handler)(void))</div><div class="ttdef"><b>Definition</b> neorv32_xirq.c:223</div></div> +<div class="ttc" id="aneorv32__xirq_8h_html_a9295997fce7114a8205325c4d75dd200"><div class="ttname"><a href="neorv32__xirq_8h.html#a9295997fce7114a8205325c4d75dd200">neorv32_xirq_setup</a></div><div class="ttdeci">int neorv32_xirq_setup(void)</div><div class="ttdef"><b>Definition</b> neorv32_xirq.c:81</div></div> +<div class="ttc" id="aneorv32__xirq_8h_html_aaf30757d526030a8d81081915ab29a76"><div class="ttname"><a href="neorv32__xirq_8h.html#aaf30757d526030a8d81081915ab29a76">neorv32_xirq_available</a></div><div class="ttdeci">int neorv32_xirq_available(void)</div><div class="ttdef"><b>Definition</b> neorv32_xirq.c:62</div></div> +<div class="ttc" id="aneorv32__xirq_8h_html_abe63c0968c94b472082c8156a1a7db5c"><div class="ttname"><a href="neorv32__xirq_8h.html#abe63c0968c94b472082c8156a1a7db5c">neorv32_xirq_channel_enable</a></div><div class="ttdeci">void neorv32_xirq_channel_enable(int channel)</div><div class="ttdef"><b>Definition</b> neorv32_xirq.c:197</div></div> +<div class="ttc" id="aneorv32__xirq_8h_html_ac64d3ff5619968499bccebebe6a6cab3"><div class="ttname"><a href="neorv32__xirq_8h.html#ac64d3ff5619968499bccebebe6a6cab3">neorv32_xirq_global_disable</a></div><div class="ttdeci">void neorv32_xirq_global_disable(void)</div><div class="ttdef"><b>Definition</b> neorv32_xirq.c:114</div></div> +<div class="ttc" id="aneorv32__xirq_8h_html_ae17509ad0c828aa9b36747b253cdbf0a"><div class="ttname"><a href="neorv32__xirq_8h.html#ae17509ad0c828aa9b36747b253cdbf0a">neorv32_xirq_channel_disable</a></div><div class="ttdeci">void neorv32_xirq_channel_disable(int channel)</div><div class="ttdef"><b>Definition</b> neorv32_xirq.c:209</div></div> +<div class="ttc" id="astructneorv32__xirq__t_html"><div class="ttname"><a href="structneorv32__xirq__t.html">neorv32_xirq_t</a></div><div class="ttdef"><b>Definition</b> neorv32_xirq.h:27</div></div> +<div class="ttc" id="astructneorv32__xirq__t_html_a5fe0036a2cada585228b60aaa780e92a"><div class="ttname"><a href="structneorv32__xirq__t.html#a5fe0036a2cada585228b60aaa780e92a">neorv32_xirq_t::TPOL</a></div><div class="ttdeci">uint32_t TPOL</div><div class="ttdef"><b>Definition</b> neorv32_xirq.h:32</div></div> +<div class="ttc" id="astructneorv32__xirq__t_html_a788d8004f3b85fb66e947415d8fcc058"><div class="ttname"><a href="structneorv32__xirq__t.html#a788d8004f3b85fb66e947415d8fcc058">neorv32_xirq_t::EIP</a></div><div class="ttdeci">uint32_t EIP</div><div class="ttdef"><b>Definition</b> neorv32_xirq.h:29</div></div> +<div class="ttc" id="astructneorv32__xirq__t_html_a9be02c0398fab5763a3afbd7a018f092"><div class="ttname"><a href="structneorv32__xirq__t.html#a9be02c0398fab5763a3afbd7a018f092">neorv32_xirq_t::reserved0</a></div><div class="ttdeci">const uint32_t reserved0</div><div class="ttdef"><b>Definition</b> neorv32_xirq.h:33</div></div> +<div class="ttc" id="astructneorv32__xirq__t_html_ab7117c210b5f0a8ebc369eeba6a4a5bc"><div class="ttname"><a href="structneorv32__xirq__t.html#ab7117c210b5f0a8ebc369eeba6a4a5bc">neorv32_xirq_t::TTYP</a></div><div class="ttdeci">uint32_t TTYP</div><div class="ttdef"><b>Definition</b> neorv32_xirq.h:31</div></div> +<div class="ttc" id="astructneorv32__xirq__t_html_ac4c999cf3da75e39753619f917d9d654"><div class="ttname"><a href="structneorv32__xirq__t.html#ac4c999cf3da75e39753619f917d9d654">neorv32_xirq_t::reserved1</a></div><div class="ttdeci">const uint32_t reserved1</div><div class="ttdef"><b>Definition</b> neorv32_xirq.h:34</div></div> +<div class="ttc" id="astructneorv32__xirq__t_html_ae4f7f3f41210ff329b6f82d5dfada88a"><div class="ttname"><a href="structneorv32__xirq__t.html#ae4f7f3f41210ff329b6f82d5dfada88a">neorv32_xirq_t::ESC</a></div><div class="ttdeci">uint32_t ESC</div><div class="ttdef"><b>Definition</b> neorv32_xirq.h:30</div></div> +<div class="ttc" id="astructneorv32__xirq__t_html_aef3c2b491207abd68bf6392f97096a74"><div class="ttname"><a href="structneorv32__xirq__t.html#aef3c2b491207abd68bf6392f97096a74">neorv32_xirq_t::EIE</a></div><div class="ttdeci">uint32_t EIE</div><div class="ttdef"><b>Definition</b> neorv32_xirq.h:28</div></div> +<div class="ttc" id="astructneorv32__xirq__t_html_afba6ed500e1448719783923975b2dc64"><div class="ttname"><a href="structneorv32__xirq__t.html#afba6ed500e1448719783923975b2dc64">neorv32_xirq_t::reserved2</a></div><div class="ttdeci">const uint32_t reserved2</div><div class="ttdef"><b>Definition</b> neorv32_xirq.h:35</div></div> +</div><!-- fragment --></div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/neorv32_logo_small.png b/sw/neorv32_logo_small.png new file mode 100644 index 0000000000000000000000000000000000000000..457f55e5a767e4c258bc32345c58944c90506a98 GIT binary patch literal 4604 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 literal 0 HcmV?d00001 diff --git a/sw/onewire__aux_8h_source.html b/sw/onewire__aux_8h_source.html new file mode 100644 index 0000000000..041facce22 --- /dev/null +++ b/sw/onewire__aux_8h_source.html @@ -0,0 +1,401 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/example/demo_onewire/onewire_aux.h Source File</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_f0f9b27afba2e8cc2da6e5fddcc1a8c9.html">example</a></li><li class="navelem"><a class="el" href="dir_3b3bafc48b460f797485cc75b94aa81c.html">demo_onewire</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="headertitle"><div class="title">onewire_aux.h</div></div> +</div><!--header--> +<div class="contents"> +<div class="fragment"><div class="line"><a id="l00001" name="l00001"></a><span class="lineno"> 1</span><span class="comment">// APPLICATION NOTE 187 &quot;1-Wire Search Algorithm&quot; by Maxim Integrated</span></div> +<div class="line"><a id="l00002" name="l00002"></a><span class="lineno"> 2</span><span class="comment">// https://www.maximintegrated.com/en/design/technical-documents/app-notes/1/187.html</span></div> +<div class="line"><a id="l00003" name="l00003"></a><span class="lineno"> 3</span><span class="comment">// modified for the NEORV32 Processor</span></div> +<div class="line"><a id="l00004" name="l00004"></a><span class="lineno"> 4</span> </div> +<div class="line"><a id="l00005" name="l00005"></a><span class="lineno"> 5</span><span class="preprocessor">#ifndef onewire_aux_h</span></div> +<div class="line"><a id="l00006" name="l00006"></a><span class="lineno"> 6</span><span class="preprocessor">#define onewire_aux_h</span></div> +<div class="line"><a id="l00007" name="l00007"></a><span class="lineno"> 7</span> </div> +<div class="line"><a id="l00008" name="l00008"></a><span class="lineno"> 8</span><span class="preprocessor">#include &lt;<a class="code" href="neorv32_8h.html">neorv32.h</a>&gt;</span></div> +<div class="line"><a id="l00009" name="l00009"></a><span class="lineno"> 9</span> </div> +<div class="line"><a id="l00010" name="l00010"></a><span class="lineno"> 10</span><span class="comment">// definitions</span></div> +<div class="line"><a id="l00011" name="l00011"></a><span class="lineno"> 11</span><span class="preprocessor">#define FALSE 0</span></div> +<div class="line"><a id="l00012" name="l00012"></a><span class="lineno"> 12</span><span class="preprocessor">#define TRUE 1</span></div> +<div class="line"><a id="l00013" name="l00013"></a><span class="lineno"> 13</span> </div> +<div class="line"><a id="l00014" name="l00014"></a><span class="lineno"> 14</span><span class="keyword">static</span> <span class="keywordtype">unsigned</span> <span class="keywordtype">char</span> dscrc_table[] = {</div> +<div class="line"><a id="l00015" name="l00015"></a><span class="lineno"> 15</span> 0, 94,188,226, 97, 63,221,131,194,156,126, 32,163,253, 31, 65,</div> +<div class="line"><a id="l00016" name="l00016"></a><span class="lineno"> 16</span> 157,195, 33,127,252,162, 64, 30, 95, 1,227,189, 62, 96,130,220,</div> +<div class="line"><a id="l00017" name="l00017"></a><span class="lineno"> 17</span> 35,125,159,193, 66, 28,254,160,225,191, 93, 3,128,222, 60, 98,</div> +<div class="line"><a id="l00018" name="l00018"></a><span class="lineno"> 18</span> 190,224, 2, 92,223,129, 99, 61,124, 34,192,158, 29, 67,161,255,</div> +<div class="line"><a id="l00019" name="l00019"></a><span class="lineno"> 19</span> 70, 24,250,164, 39,121,155,197,132,218, 56,102,229,187, 89, 7,</div> +<div class="line"><a id="l00020" name="l00020"></a><span class="lineno"> 20</span> 219,133,103, 57,186,228, 6, 88, 25, 71,165,251,120, 38,196,154,</div> +<div class="line"><a id="l00021" name="l00021"></a><span class="lineno"> 21</span> 101, 59,217,135, 4, 90,184,230,167,249, 27, 69,198,152,122, 36,</div> +<div class="line"><a id="l00022" name="l00022"></a><span class="lineno"> 22</span> 248,166, 68, 26,153,199, 37,123, 58,100,134,216, 91, 5,231,185,</div> +<div class="line"><a id="l00023" name="l00023"></a><span class="lineno"> 23</span> 140,210, 48,110,237,179, 81, 15, 78, 16,242,172, 47,113,147,205,</div> +<div class="line"><a id="l00024" name="l00024"></a><span class="lineno"> 24</span> 17, 79,173,243,112, 46,204,146,211,141,111, 49,178,236, 14, 80,</div> +<div class="line"><a id="l00025" name="l00025"></a><span class="lineno"> 25</span> 175,241, 19, 77,206,144,114, 44,109, 51,209,143, 12, 82,176,238,</div> +<div class="line"><a id="l00026" name="l00026"></a><span class="lineno"> 26</span> 50,108,142,208, 83, 13,239,177,240,174, 76, 18,145,207, 45,115,</div> +<div class="line"><a id="l00027" name="l00027"></a><span class="lineno"> 27</span> 202,148,118, 40,171,245, 23, 73, 8, 86,180,234,105, 55,213,139,</div> +<div class="line"><a id="l00028" name="l00028"></a><span class="lineno"> 28</span> 87, 9,235,181, 54,104,138,212,149,203, 41,119,244,170, 72, 22,</div> +<div class="line"><a id="l00029" name="l00029"></a><span class="lineno"> 29</span> 233,183, 85, 11,136,214, 52,106, 43,117,151,201, 74, 20,246,168,</div> +<div class="line"><a id="l00030" name="l00030"></a><span class="lineno"> 30</span> 116, 42,200,150, 21, 75,169,247,182,232, 10, 84,215,137,107, 53};</div> +<div class="line"><a id="l00031" name="l00031"></a><span class="lineno"> 31</span> </div> +<div class="line"><a id="l00032" name="l00032"></a><span class="lineno"> 32</span><span class="comment">// method declarations</span></div> +<div class="line"><a id="l00033" name="l00033"></a><span class="lineno"> 33</span><span class="keywordtype">int</span> OWFirst();</div> +<div class="line"><a id="l00034" name="l00034"></a><span class="lineno"> 34</span><span class="keywordtype">int</span> OWNext();</div> +<div class="line"><a id="l00035" name="l00035"></a><span class="lineno"> 35</span><span class="keywordtype">int</span> OWVerify();</div> +<div class="line"><a id="l00036" name="l00036"></a><span class="lineno"> 36</span><span class="keywordtype">void</span> OWTargetSetup(<span class="keywordtype">unsigned</span> <span class="keywordtype">char</span> family_code);</div> +<div class="line"><a id="l00037" name="l00037"></a><span class="lineno"> 37</span><span class="keywordtype">void</span> OWFamilySkipSetup();</div> +<div class="line"><a id="l00038" name="l00038"></a><span class="lineno"> 38</span><span class="keywordtype">int</span> OWSearch();</div> +<div class="line"><a id="l00039" name="l00039"></a><span class="lineno"> 39</span><span class="keywordtype">unsigned</span> <span class="keywordtype">char</span> docrc8(<span class="keywordtype">unsigned</span> <span class="keywordtype">char</span> value);</div> +<div class="line"><a id="l00040" name="l00040"></a><span class="lineno"> 40</span> </div> +<div class="line"><a id="l00041" name="l00041"></a><span class="lineno"> 41</span><span class="comment">// global search state</span></div> +<div class="line"><a id="l00042" name="l00042"></a><span class="lineno"> 42</span><span class="keywordtype">unsigned</span> <span class="keywordtype">char</span> ROM_NO[8];</div> +<div class="line"><a id="l00043" name="l00043"></a><span class="lineno"> 43</span><span class="keywordtype">int</span> LastDiscrepancy;</div> +<div class="line"><a id="l00044" name="l00044"></a><span class="lineno"> 44</span><span class="keywordtype">int</span> LastFamilyDiscrepancy;</div> +<div class="line"><a id="l00045" name="l00045"></a><span class="lineno"> 45</span><span class="keywordtype">int</span> LastDeviceFlag;</div> +<div class="line"><a id="l00046" name="l00046"></a><span class="lineno"> 46</span><span class="keywordtype">unsigned</span> <span class="keywordtype">char</span> crc8;</div> +<div class="line"><a id="l00047" name="l00047"></a><span class="lineno"> 47</span> </div> +<div class="line"><a id="l00048" name="l00048"></a><span class="lineno"> 48</span><span class="comment">//--------------------------------------------------------------------------</span></div> +<div class="line"><a id="l00049" name="l00049"></a><span class="lineno"> 49</span><span class="comment">// Find the &#39;first&#39; devices on the 1-Wire bus</span></div> +<div class="line"><a id="l00050" name="l00050"></a><span class="lineno"> 50</span><span class="comment">// Return TRUE : device found, ROM number in ROM_NO buffer</span></div> +<div class="line"><a id="l00051" name="l00051"></a><span class="lineno"> 51</span><span class="comment">// FALSE : no device present</span></div> +<div class="line"><a id="l00052" name="l00052"></a><span class="lineno"> 52</span><span class="comment">//</span></div> +<div class="line"><a id="l00053" name="l00053"></a><span class="lineno"> 53</span><span class="keywordtype">int</span> OWFirst()</div> +<div class="line"><a id="l00054" name="l00054"></a><span class="lineno"> 54</span>{</div> +<div class="line"><a id="l00055" name="l00055"></a><span class="lineno"> 55</span> <span class="comment">// reset the search state</span></div> +<div class="line"><a id="l00056" name="l00056"></a><span class="lineno"> 56</span> LastDiscrepancy = 0;</div> +<div class="line"><a id="l00057" name="l00057"></a><span class="lineno"> 57</span> LastDeviceFlag = FALSE;</div> +<div class="line"><a id="l00058" name="l00058"></a><span class="lineno"> 58</span> LastFamilyDiscrepancy = 0;</div> +<div class="line"><a id="l00059" name="l00059"></a><span class="lineno"> 59</span> </div> +<div class="line"><a id="l00060" name="l00060"></a><span class="lineno"> 60</span> <span class="keywordflow">return</span> OWSearch();</div> +<div class="line"><a id="l00061" name="l00061"></a><span class="lineno"> 61</span>}</div> +<div class="line"><a id="l00062" name="l00062"></a><span class="lineno"> 62</span> </div> +<div class="line"><a id="l00063" name="l00063"></a><span class="lineno"> 63</span><span class="comment">//--------------------------------------------------------------------------</span></div> +<div class="line"><a id="l00064" name="l00064"></a><span class="lineno"> 64</span><span class="comment">// Find the &#39;next&#39; devices on the 1-Wire bus</span></div> +<div class="line"><a id="l00065" name="l00065"></a><span class="lineno"> 65</span><span class="comment">// Return TRUE : device found, ROM number in ROM_NO buffer</span></div> +<div class="line"><a id="l00066" name="l00066"></a><span class="lineno"> 66</span><span class="comment">// FALSE : device not found, end of search</span></div> +<div class="line"><a id="l00067" name="l00067"></a><span class="lineno"> 67</span><span class="comment">//</span></div> +<div class="line"><a id="l00068" name="l00068"></a><span class="lineno"> 68</span><span class="keywordtype">int</span> OWNext()</div> +<div class="line"><a id="l00069" name="l00069"></a><span class="lineno"> 69</span>{</div> +<div class="line"><a id="l00070" name="l00070"></a><span class="lineno"> 70</span> <span class="comment">// leave the search state alone</span></div> +<div class="line"><a id="l00071" name="l00071"></a><span class="lineno"> 71</span> <span class="keywordflow">return</span> OWSearch();</div> +<div class="line"><a id="l00072" name="l00072"></a><span class="lineno"> 72</span>}</div> +<div class="line"><a id="l00073" name="l00073"></a><span class="lineno"> 73</span> </div> +<div class="line"><a id="l00074" name="l00074"></a><span class="lineno"> 74</span><span class="comment">//--------------------------------------------------------------------------</span></div> +<div class="line"><a id="l00075" name="l00075"></a><span class="lineno"> 75</span><span class="comment">// Perform the 1-Wire Search Algorithm on the 1-Wire bus using the existing</span></div> +<div class="line"><a id="l00076" name="l00076"></a><span class="lineno"> 76</span><span class="comment">// search state.</span></div> +<div class="line"><a id="l00077" name="l00077"></a><span class="lineno"> 77</span><span class="comment">// Return TRUE : device found, ROM number in ROM_NO buffer</span></div> +<div class="line"><a id="l00078" name="l00078"></a><span class="lineno"> 78</span><span class="comment">// FALSE : device not found, end of search</span></div> +<div class="line"><a id="l00079" name="l00079"></a><span class="lineno"> 79</span><span class="comment">//</span></div> +<div class="line"><a id="l00080" name="l00080"></a><span class="lineno"> 80</span><span class="keywordtype">int</span> OWSearch()</div> +<div class="line"><a id="l00081" name="l00081"></a><span class="lineno"> 81</span>{</div> +<div class="line"><a id="l00082" name="l00082"></a><span class="lineno"> 82</span> <span class="keywordtype">int</span> id_bit_number;</div> +<div class="line"><a id="l00083" name="l00083"></a><span class="lineno"> 83</span> <span class="keywordtype">int</span> last_zero, rom_byte_number, search_result;</div> +<div class="line"><a id="l00084" name="l00084"></a><span class="lineno"> 84</span> <span class="keywordtype">int</span> id_bit, cmp_id_bit;</div> +<div class="line"><a id="l00085" name="l00085"></a><span class="lineno"> 85</span> <span class="keywordtype">unsigned</span> <span class="keywordtype">char</span> rom_byte_mask, search_direction;</div> +<div class="line"><a id="l00086" name="l00086"></a><span class="lineno"> 86</span> </div> +<div class="line"><a id="l00087" name="l00087"></a><span class="lineno"> 87</span> <span class="comment">// initialize for search</span></div> +<div class="line"><a id="l00088" name="l00088"></a><span class="lineno"> 88</span> id_bit_number = 1;</div> +<div class="line"><a id="l00089" name="l00089"></a><span class="lineno"> 89</span> last_zero = 0;</div> +<div class="line"><a id="l00090" name="l00090"></a><span class="lineno"> 90</span> rom_byte_number = 0;</div> +<div class="line"><a id="l00091" name="l00091"></a><span class="lineno"> 91</span> rom_byte_mask = 1;</div> +<div class="line"><a id="l00092" name="l00092"></a><span class="lineno"> 92</span> search_result = 0;</div> +<div class="line"><a id="l00093" name="l00093"></a><span class="lineno"> 93</span> crc8 = 0;</div> +<div class="line"><a id="l00094" name="l00094"></a><span class="lineno"> 94</span> </div> +<div class="line"><a id="l00095" name="l00095"></a><span class="lineno"> 95</span> <span class="comment">// if the last call was not the last one</span></div> +<div class="line"><a id="l00096" name="l00096"></a><span class="lineno"> 96</span> <span class="keywordflow">if</span> (!LastDeviceFlag)</div> +<div class="line"><a id="l00097" name="l00097"></a><span class="lineno"> 97</span> {</div> +<div class="line"><a id="l00098" name="l00098"></a><span class="lineno"> 98</span> <span class="comment">// 1-Wire reset</span></div> +<div class="line"><a id="l00099" name="l00099"></a><span class="lineno"> 99</span> <span class="keywordflow">if</span> (<a class="code hl_function" href="neorv32__onewire_8c.html#af8ca6be495176797b7da3857e2f794f9">neorv32_onewire_reset_blocking</a>())</div> +<div class="line"><a id="l00100" name="l00100"></a><span class="lineno"> 100</span> {</div> +<div class="line"><a id="l00101" name="l00101"></a><span class="lineno"> 101</span> <span class="comment">// reset the search</span></div> +<div class="line"><a id="l00102" name="l00102"></a><span class="lineno"> 102</span> LastDiscrepancy = 0;</div> +<div class="line"><a id="l00103" name="l00103"></a><span class="lineno"> 103</span> LastDeviceFlag = FALSE;</div> +<div class="line"><a id="l00104" name="l00104"></a><span class="lineno"> 104</span> LastFamilyDiscrepancy = 0;</div> +<div class="line"><a id="l00105" name="l00105"></a><span class="lineno"> 105</span> <span class="keywordflow">return</span> FALSE;</div> +<div class="line"><a id="l00106" name="l00106"></a><span class="lineno"> 106</span> }</div> +<div class="line"><a id="l00107" name="l00107"></a><span class="lineno"> 107</span> </div> +<div class="line"><a id="l00108" name="l00108"></a><span class="lineno"> 108</span> <span class="comment">// issue the search command </span></div> +<div class="line"><a id="l00109" name="l00109"></a><span class="lineno"> 109</span> <a class="code hl_function" href="neorv32__onewire_8c.html#ac78557c77482b59394677f42fda4fdf1">neorv32_onewire_write_byte_blocking</a>(0xF0); </div> +<div class="line"><a id="l00110" name="l00110"></a><span class="lineno"> 110</span> </div> +<div class="line"><a id="l00111" name="l00111"></a><span class="lineno"> 111</span> <span class="comment">// loop to do the search</span></div> +<div class="line"><a id="l00112" name="l00112"></a><span class="lineno"> 112</span> <span class="keywordflow">do</span></div> +<div class="line"><a id="l00113" name="l00113"></a><span class="lineno"> 113</span> {</div> +<div class="line"><a id="l00114" name="l00114"></a><span class="lineno"> 114</span> <span class="comment">// read a bit and its complement</span></div> +<div class="line"><a id="l00115" name="l00115"></a><span class="lineno"> 115</span> id_bit = <a class="code hl_function" href="neorv32__onewire_8c.html#ace8b7cf697b068b6b51676d84dec5960">neorv32_onewire_read_bit_blocking</a>();</div> +<div class="line"><a id="l00116" name="l00116"></a><span class="lineno"> 116</span> cmp_id_bit = <a class="code hl_function" href="neorv32__onewire_8c.html#ace8b7cf697b068b6b51676d84dec5960">neorv32_onewire_read_bit_blocking</a>();</div> +<div class="line"><a id="l00117" name="l00117"></a><span class="lineno"> 117</span> </div> +<div class="line"><a id="l00118" name="l00118"></a><span class="lineno"> 118</span> <span class="comment">// check for no devices on 1-wire</span></div> +<div class="line"><a id="l00119" name="l00119"></a><span class="lineno"> 119</span> <span class="keywordflow">if</span> ((id_bit == 1) &amp;&amp; (cmp_id_bit == 1))</div> +<div class="line"><a id="l00120" name="l00120"></a><span class="lineno"> 120</span> <span class="keywordflow">break</span>;</div> +<div class="line"><a id="l00121" name="l00121"></a><span class="lineno"> 121</span> <span class="keywordflow">else</span></div> +<div class="line"><a id="l00122" name="l00122"></a><span class="lineno"> 122</span> {</div> +<div class="line"><a id="l00123" name="l00123"></a><span class="lineno"> 123</span> <span class="comment">// all devices coupled have 0 or 1</span></div> +<div class="line"><a id="l00124" name="l00124"></a><span class="lineno"> 124</span> <span class="keywordflow">if</span> (id_bit != cmp_id_bit)</div> +<div class="line"><a id="l00125" name="l00125"></a><span class="lineno"> 125</span> search_direction = id_bit; <span class="comment">// bit write value for search</span></div> +<div class="line"><a id="l00126" name="l00126"></a><span class="lineno"> 126</span> <span class="keywordflow">else</span></div> +<div class="line"><a id="l00127" name="l00127"></a><span class="lineno"> 127</span> {</div> +<div class="line"><a id="l00128" name="l00128"></a><span class="lineno"> 128</span> <span class="comment">// if this discrepancy if before the Last Discrepancy</span></div> +<div class="line"><a id="l00129" name="l00129"></a><span class="lineno"> 129</span> <span class="comment">// on a previous next then pick the same as last time</span></div> +<div class="line"><a id="l00130" name="l00130"></a><span class="lineno"> 130</span> <span class="keywordflow">if</span> (id_bit_number &lt; LastDiscrepancy)</div> +<div class="line"><a id="l00131" name="l00131"></a><span class="lineno"> 131</span> search_direction = ((ROM_NO[rom_byte_number] &amp; rom_byte_mask) &gt; 0);</div> +<div class="line"><a id="l00132" name="l00132"></a><span class="lineno"> 132</span> <span class="keywordflow">else</span></div> +<div class="line"><a id="l00133" name="l00133"></a><span class="lineno"> 133</span> <span class="comment">// if equal to last pick 1, if not then pick 0</span></div> +<div class="line"><a id="l00134" name="l00134"></a><span class="lineno"> 134</span> search_direction = (id_bit_number == LastDiscrepancy);</div> +<div class="line"><a id="l00135" name="l00135"></a><span class="lineno"> 135</span> </div> +<div class="line"><a id="l00136" name="l00136"></a><span class="lineno"> 136</span> <span class="comment">// if 0 was picked then record its position in LastZero</span></div> +<div class="line"><a id="l00137" name="l00137"></a><span class="lineno"> 137</span> <span class="keywordflow">if</span> (search_direction == 0)</div> +<div class="line"><a id="l00138" name="l00138"></a><span class="lineno"> 138</span> {</div> +<div class="line"><a id="l00139" name="l00139"></a><span class="lineno"> 139</span> last_zero = id_bit_number;</div> +<div class="line"><a id="l00140" name="l00140"></a><span class="lineno"> 140</span> </div> +<div class="line"><a id="l00141" name="l00141"></a><span class="lineno"> 141</span> <span class="comment">// check for Last discrepancy in family</span></div> +<div class="line"><a id="l00142" name="l00142"></a><span class="lineno"> 142</span> <span class="keywordflow">if</span> (last_zero &lt; 9)</div> +<div class="line"><a id="l00143" name="l00143"></a><span class="lineno"> 143</span> LastFamilyDiscrepancy = last_zero;</div> +<div class="line"><a id="l00144" name="l00144"></a><span class="lineno"> 144</span> }</div> +<div class="line"><a id="l00145" name="l00145"></a><span class="lineno"> 145</span> }</div> +<div class="line"><a id="l00146" name="l00146"></a><span class="lineno"> 146</span> </div> +<div class="line"><a id="l00147" name="l00147"></a><span class="lineno"> 147</span> <span class="comment">// set or clear the bit in the ROM byte rom_byte_number</span></div> +<div class="line"><a id="l00148" name="l00148"></a><span class="lineno"> 148</span> <span class="comment">// with mask rom_byte_mask</span></div> +<div class="line"><a id="l00149" name="l00149"></a><span class="lineno"> 149</span> <span class="keywordflow">if</span> (search_direction == 1)</div> +<div class="line"><a id="l00150" name="l00150"></a><span class="lineno"> 150</span> ROM_NO[rom_byte_number] |= rom_byte_mask;</div> +<div class="line"><a id="l00151" name="l00151"></a><span class="lineno"> 151</span> <span class="keywordflow">else</span></div> +<div class="line"><a id="l00152" name="l00152"></a><span class="lineno"> 152</span> ROM_NO[rom_byte_number] &amp;= ~rom_byte_mask;</div> +<div class="line"><a id="l00153" name="l00153"></a><span class="lineno"> 153</span> </div> +<div class="line"><a id="l00154" name="l00154"></a><span class="lineno"> 154</span> <span class="comment">// serial number search direction write bit</span></div> +<div class="line"><a id="l00155" name="l00155"></a><span class="lineno"> 155</span> <a class="code hl_function" href="neorv32__onewire_8c.html#a6f7b6690a2437e0b574a8a9a23dc0eaa">neorv32_onewire_write_bit_blocking</a>(search_direction);</div> +<div class="line"><a id="l00156" name="l00156"></a><span class="lineno"> 156</span> </div> +<div class="line"><a id="l00157" name="l00157"></a><span class="lineno"> 157</span> <span class="comment">// increment the byte counter id_bit_number</span></div> +<div class="line"><a id="l00158" name="l00158"></a><span class="lineno"> 158</span> <span class="comment">// and shift the mask rom_byte_mask</span></div> +<div class="line"><a id="l00159" name="l00159"></a><span class="lineno"> 159</span> id_bit_number++;</div> +<div class="line"><a id="l00160" name="l00160"></a><span class="lineno"> 160</span> rom_byte_mask &lt;&lt;= 1;</div> +<div class="line"><a id="l00161" name="l00161"></a><span class="lineno"> 161</span> </div> +<div class="line"><a id="l00162" name="l00162"></a><span class="lineno"> 162</span> <span class="comment">// if the mask is 0 then go to new SerialNum byte rom_byte_number and reset mask</span></div> +<div class="line"><a id="l00163" name="l00163"></a><span class="lineno"> 163</span> <span class="keywordflow">if</span> (rom_byte_mask == 0)</div> +<div class="line"><a id="l00164" name="l00164"></a><span class="lineno"> 164</span> {</div> +<div class="line"><a id="l00165" name="l00165"></a><span class="lineno"> 165</span> docrc8(ROM_NO[rom_byte_number]); <span class="comment">// accumulate the CRC</span></div> +<div class="line"><a id="l00166" name="l00166"></a><span class="lineno"> 166</span> rom_byte_number++;</div> +<div class="line"><a id="l00167" name="l00167"></a><span class="lineno"> 167</span> rom_byte_mask = 1;</div> +<div class="line"><a id="l00168" name="l00168"></a><span class="lineno"> 168</span> }</div> +<div class="line"><a id="l00169" name="l00169"></a><span class="lineno"> 169</span> }</div> +<div class="line"><a id="l00170" name="l00170"></a><span class="lineno"> 170</span> }</div> +<div class="line"><a id="l00171" name="l00171"></a><span class="lineno"> 171</span> <span class="keywordflow">while</span>(rom_byte_number &lt; 8); <span class="comment">// loop until through all ROM bytes 0-7</span></div> +<div class="line"><a id="l00172" name="l00172"></a><span class="lineno"> 172</span> </div> +<div class="line"><a id="l00173" name="l00173"></a><span class="lineno"> 173</span> <span class="comment">// if the search was successful then</span></div> +<div class="line"><a id="l00174" name="l00174"></a><span class="lineno"> 174</span> <span class="keywordflow">if</span> (!((id_bit_number &lt; 65) || (crc8 != 0)))</div> +<div class="line"><a id="l00175" name="l00175"></a><span class="lineno"> 175</span> {</div> +<div class="line"><a id="l00176" name="l00176"></a><span class="lineno"> 176</span> <span class="comment">// search successful so set LastDiscrepancy,LastDeviceFlag,search_result</span></div> +<div class="line"><a id="l00177" name="l00177"></a><span class="lineno"> 177</span> LastDiscrepancy = last_zero;</div> +<div class="line"><a id="l00178" name="l00178"></a><span class="lineno"> 178</span> </div> +<div class="line"><a id="l00179" name="l00179"></a><span class="lineno"> 179</span> <span class="comment">// check for last device</span></div> +<div class="line"><a id="l00180" name="l00180"></a><span class="lineno"> 180</span> <span class="keywordflow">if</span> (LastDiscrepancy == 0)</div> +<div class="line"><a id="l00181" name="l00181"></a><span class="lineno"> 181</span> LastDeviceFlag = TRUE;</div> +<div class="line"><a id="l00182" name="l00182"></a><span class="lineno"> 182</span> </div> +<div class="line"><a id="l00183" name="l00183"></a><span class="lineno"> 183</span> search_result = TRUE;</div> +<div class="line"><a id="l00184" name="l00184"></a><span class="lineno"> 184</span> }</div> +<div class="line"><a id="l00185" name="l00185"></a><span class="lineno"> 185</span> }</div> +<div class="line"><a id="l00186" name="l00186"></a><span class="lineno"> 186</span> </div> +<div class="line"><a id="l00187" name="l00187"></a><span class="lineno"> 187</span> <span class="comment">// if no device found then reset counters so next &#39;search&#39; will be like a first</span></div> +<div class="line"><a id="l00188" name="l00188"></a><span class="lineno"> 188</span> <span class="keywordflow">if</span> (!search_result || !ROM_NO[0])</div> +<div class="line"><a id="l00189" name="l00189"></a><span class="lineno"> 189</span> {</div> +<div class="line"><a id="l00190" name="l00190"></a><span class="lineno"> 190</span> LastDiscrepancy = 0;</div> +<div class="line"><a id="l00191" name="l00191"></a><span class="lineno"> 191</span> LastDeviceFlag = FALSE;</div> +<div class="line"><a id="l00192" name="l00192"></a><span class="lineno"> 192</span> LastFamilyDiscrepancy = 0;</div> +<div class="line"><a id="l00193" name="l00193"></a><span class="lineno"> 193</span> search_result = FALSE;</div> +<div class="line"><a id="l00194" name="l00194"></a><span class="lineno"> 194</span> }</div> +<div class="line"><a id="l00195" name="l00195"></a><span class="lineno"> 195</span> </div> +<div class="line"><a id="l00196" name="l00196"></a><span class="lineno"> 196</span> <span class="keywordflow">return</span> search_result;</div> +<div class="line"><a id="l00197" name="l00197"></a><span class="lineno"> 197</span>}</div> +<div class="line"><a id="l00198" name="l00198"></a><span class="lineno"> 198</span> </div> +<div class="line"><a id="l00199" name="l00199"></a><span class="lineno"> 199</span><span class="comment">//--------------------------------------------------------------------------</span></div> +<div class="line"><a id="l00200" name="l00200"></a><span class="lineno"> 200</span><span class="comment">// Verify the device with the ROM number in ROM_NO buffer is present.</span></div> +<div class="line"><a id="l00201" name="l00201"></a><span class="lineno"> 201</span><span class="comment">// Return TRUE : device verified present</span></div> +<div class="line"><a id="l00202" name="l00202"></a><span class="lineno"> 202</span><span class="comment">// FALSE : device not present</span></div> +<div class="line"><a id="l00203" name="l00203"></a><span class="lineno"> 203</span><span class="comment">//</span></div> +<div class="line"><a id="l00204" name="l00204"></a><span class="lineno"> 204</span><span class="keywordtype">int</span> OWVerify()</div> +<div class="line"><a id="l00205" name="l00205"></a><span class="lineno"> 205</span>{</div> +<div class="line"><a id="l00206" name="l00206"></a><span class="lineno"> 206</span> <span class="keywordtype">unsigned</span> <span class="keywordtype">char</span> rom_backup[8];</div> +<div class="line"><a id="l00207" name="l00207"></a><span class="lineno"> 207</span> <span class="keywordtype">int</span> i,rslt,ld_backup,ldf_backup,lfd_backup;</div> +<div class="line"><a id="l00208" name="l00208"></a><span class="lineno"> 208</span> </div> +<div class="line"><a id="l00209" name="l00209"></a><span class="lineno"> 209</span> <span class="comment">// keep a backup copy of the current state</span></div> +<div class="line"><a id="l00210" name="l00210"></a><span class="lineno"> 210</span> <span class="keywordflow">for</span> (i = 0; i &lt; 8; i++)</div> +<div class="line"><a id="l00211" name="l00211"></a><span class="lineno"> 211</span> rom_backup[i] = ROM_NO[i];</div> +<div class="line"><a id="l00212" name="l00212"></a><span class="lineno"> 212</span> ld_backup = LastDiscrepancy;</div> +<div class="line"><a id="l00213" name="l00213"></a><span class="lineno"> 213</span> ldf_backup = LastDeviceFlag;</div> +<div class="line"><a id="l00214" name="l00214"></a><span class="lineno"> 214</span> lfd_backup = LastFamilyDiscrepancy;</div> +<div class="line"><a id="l00215" name="l00215"></a><span class="lineno"> 215</span> </div> +<div class="line"><a id="l00216" name="l00216"></a><span class="lineno"> 216</span> <span class="comment">// set search to find the same device</span></div> +<div class="line"><a id="l00217" name="l00217"></a><span class="lineno"> 217</span> LastDiscrepancy = 64;</div> +<div class="line"><a id="l00218" name="l00218"></a><span class="lineno"> 218</span> LastDeviceFlag = FALSE;</div> +<div class="line"><a id="l00219" name="l00219"></a><span class="lineno"> 219</span> </div> +<div class="line"><a id="l00220" name="l00220"></a><span class="lineno"> 220</span> <span class="keywordflow">if</span> (OWSearch())</div> +<div class="line"><a id="l00221" name="l00221"></a><span class="lineno"> 221</span> {</div> +<div class="line"><a id="l00222" name="l00222"></a><span class="lineno"> 222</span> <span class="comment">// check if same device found</span></div> +<div class="line"><a id="l00223" name="l00223"></a><span class="lineno"> 223</span> rslt = TRUE;</div> +<div class="line"><a id="l00224" name="l00224"></a><span class="lineno"> 224</span> <span class="keywordflow">for</span> (i = 0; i &lt; 8; i++)</div> +<div class="line"><a id="l00225" name="l00225"></a><span class="lineno"> 225</span> {</div> +<div class="line"><a id="l00226" name="l00226"></a><span class="lineno"> 226</span> <span class="keywordflow">if</span> (rom_backup[i] != ROM_NO[i])</div> +<div class="line"><a id="l00227" name="l00227"></a><span class="lineno"> 227</span> {</div> +<div class="line"><a id="l00228" name="l00228"></a><span class="lineno"> 228</span> rslt = FALSE;</div> +<div class="line"><a id="l00229" name="l00229"></a><span class="lineno"> 229</span> <span class="keywordflow">break</span>;</div> +<div class="line"><a id="l00230" name="l00230"></a><span class="lineno"> 230</span> }</div> +<div class="line"><a id="l00231" name="l00231"></a><span class="lineno"> 231</span> }</div> +<div class="line"><a id="l00232" name="l00232"></a><span class="lineno"> 232</span> }</div> +<div class="line"><a id="l00233" name="l00233"></a><span class="lineno"> 233</span> <span class="keywordflow">else</span></div> +<div class="line"><a id="l00234" name="l00234"></a><span class="lineno"> 234</span> rslt = FALSE;</div> +<div class="line"><a id="l00235" name="l00235"></a><span class="lineno"> 235</span> </div> +<div class="line"><a id="l00236" name="l00236"></a><span class="lineno"> 236</span> <span class="comment">// restore the search state </span></div> +<div class="line"><a id="l00237" name="l00237"></a><span class="lineno"> 237</span> <span class="keywordflow">for</span> (i = 0; i &lt; 8; i++)</div> +<div class="line"><a id="l00238" name="l00238"></a><span class="lineno"> 238</span> ROM_NO[i] = rom_backup[i];</div> +<div class="line"><a id="l00239" name="l00239"></a><span class="lineno"> 239</span> LastDiscrepancy = ld_backup;</div> +<div class="line"><a id="l00240" name="l00240"></a><span class="lineno"> 240</span> LastDeviceFlag = ldf_backup;</div> +<div class="line"><a id="l00241" name="l00241"></a><span class="lineno"> 241</span> LastFamilyDiscrepancy = lfd_backup;</div> +<div class="line"><a id="l00242" name="l00242"></a><span class="lineno"> 242</span> </div> +<div class="line"><a id="l00243" name="l00243"></a><span class="lineno"> 243</span> <span class="comment">// return the result of the verify</span></div> +<div class="line"><a id="l00244" name="l00244"></a><span class="lineno"> 244</span> <span class="keywordflow">return</span> rslt;</div> +<div class="line"><a id="l00245" name="l00245"></a><span class="lineno"> 245</span>}</div> +<div class="line"><a id="l00246" name="l00246"></a><span class="lineno"> 246</span> </div> +<div class="line"><a id="l00247" name="l00247"></a><span class="lineno"> 247</span><span class="comment">//--------------------------------------------------------------------------</span></div> +<div class="line"><a id="l00248" name="l00248"></a><span class="lineno"> 248</span><span class="comment">// Setup the search to find the device type &#39;family_code&#39; on the next call</span></div> +<div class="line"><a id="l00249" name="l00249"></a><span class="lineno"> 249</span><span class="comment">// to OWNext() if it is present.</span></div> +<div class="line"><a id="l00250" name="l00250"></a><span class="lineno"> 250</span><span class="comment">//</span></div> +<div class="line"><a id="l00251" name="l00251"></a><span class="lineno"> 251</span><span class="keywordtype">void</span> OWTargetSetup(<span class="keywordtype">unsigned</span> <span class="keywordtype">char</span> family_code)</div> +<div class="line"><a id="l00252" name="l00252"></a><span class="lineno"> 252</span>{</div> +<div class="line"><a id="l00253" name="l00253"></a><span class="lineno"> 253</span> <span class="keywordtype">int</span> i;</div> +<div class="line"><a id="l00254" name="l00254"></a><span class="lineno"> 254</span> </div> +<div class="line"><a id="l00255" name="l00255"></a><span class="lineno"> 255</span> <span class="comment">// set the search state to find SearchFamily type devices</span></div> +<div class="line"><a id="l00256" name="l00256"></a><span class="lineno"> 256</span> ROM_NO[0] = family_code;</div> +<div class="line"><a id="l00257" name="l00257"></a><span class="lineno"> 257</span> <span class="keywordflow">for</span> (i = 1; i &lt; 8; i++)</div> +<div class="line"><a id="l00258" name="l00258"></a><span class="lineno"> 258</span> ROM_NO[i] = 0;</div> +<div class="line"><a id="l00259" name="l00259"></a><span class="lineno"> 259</span> LastDiscrepancy = 64;</div> +<div class="line"><a id="l00260" name="l00260"></a><span class="lineno"> 260</span> LastFamilyDiscrepancy = 0;</div> +<div class="line"><a id="l00261" name="l00261"></a><span class="lineno"> 261</span> LastDeviceFlag = FALSE;</div> +<div class="line"><a id="l00262" name="l00262"></a><span class="lineno"> 262</span>}</div> +<div class="line"><a id="l00263" name="l00263"></a><span class="lineno"> 263</span> </div> +<div class="line"><a id="l00264" name="l00264"></a><span class="lineno"> 264</span><span class="comment">//--------------------------------------------------------------------------</span></div> +<div class="line"><a id="l00265" name="l00265"></a><span class="lineno"> 265</span><span class="comment">// Setup the search to skip the current device type on the next call</span></div> +<div class="line"><a id="l00266" name="l00266"></a><span class="lineno"> 266</span><span class="comment">// to OWNext().</span></div> +<div class="line"><a id="l00267" name="l00267"></a><span class="lineno"> 267</span><span class="comment">//</span></div> +<div class="line"><a id="l00268" name="l00268"></a><span class="lineno"> 268</span><span class="keywordtype">void</span> OWFamilySkipSetup()</div> +<div class="line"><a id="l00269" name="l00269"></a><span class="lineno"> 269</span>{</div> +<div class="line"><a id="l00270" name="l00270"></a><span class="lineno"> 270</span> <span class="comment">// set the Last discrepancy to last family discrepancy</span></div> +<div class="line"><a id="l00271" name="l00271"></a><span class="lineno"> 271</span> LastDiscrepancy = LastFamilyDiscrepancy;</div> +<div class="line"><a id="l00272" name="l00272"></a><span class="lineno"> 272</span> LastFamilyDiscrepancy = 0;</div> +<div class="line"><a id="l00273" name="l00273"></a><span class="lineno"> 273</span> </div> +<div class="line"><a id="l00274" name="l00274"></a><span class="lineno"> 274</span> <span class="comment">// check for end of list</span></div> +<div class="line"><a id="l00275" name="l00275"></a><span class="lineno"> 275</span> <span class="keywordflow">if</span> (LastDiscrepancy == 0)</div> +<div class="line"><a id="l00276" name="l00276"></a><span class="lineno"> 276</span> LastDeviceFlag = TRUE;</div> +<div class="line"><a id="l00277" name="l00277"></a><span class="lineno"> 277</span>}</div> +<div class="line"><a id="l00278" name="l00278"></a><span class="lineno"> 278</span> </div> +<div class="line"><a id="l00279" name="l00279"></a><span class="lineno"> 279</span><span class="comment">//--------------------------------------------------------------------------</span></div> +<div class="line"><a id="l00280" name="l00280"></a><span class="lineno"> 280</span><span class="comment">// Calculate the CRC8 of the byte value provided with the current </span></div> +<div class="line"><a id="l00281" name="l00281"></a><span class="lineno"> 281</span><span class="comment">// global &#39;crc8&#39; value. </span></div> +<div class="line"><a id="l00282" name="l00282"></a><span class="lineno"> 282</span><span class="comment">// Returns current global crc8 value</span></div> +<div class="line"><a id="l00283" name="l00283"></a><span class="lineno"> 283</span><span class="comment">//</span></div> +<div class="line"><a id="l00284" name="l00284"></a><span class="lineno"> 284</span><span class="keywordtype">unsigned</span> <span class="keywordtype">char</span> docrc8(<span class="keywordtype">unsigned</span> <span class="keywordtype">char</span> value)</div> +<div class="line"><a id="l00285" name="l00285"></a><span class="lineno"> 285</span>{</div> +<div class="line"><a id="l00286" name="l00286"></a><span class="lineno"> 286</span> <span class="comment">// See Application Note 27</span></div> +<div class="line"><a id="l00287" name="l00287"></a><span class="lineno"> 287</span> </div> +<div class="line"><a id="l00288" name="l00288"></a><span class="lineno"> 288</span> <span class="comment">// TEST BUILD</span></div> +<div class="line"><a id="l00289" name="l00289"></a><span class="lineno"> 289</span> crc8 = dscrc_table[crc8 ^ value];</div> +<div class="line"><a id="l00290" name="l00290"></a><span class="lineno"> 290</span> <span class="keywordflow">return</span> crc8;</div> +<div class="line"><a id="l00291" name="l00291"></a><span class="lineno"> 291</span>}</div> +<div class="line"><a id="l00292" name="l00292"></a><span class="lineno"> 292</span> </div> +<div class="line"><a id="l00293" name="l00293"></a><span class="lineno"> 293</span><span class="preprocessor">#endif </span><span class="comment">// onewire_aux_h</span></div> +<div class="ttc" id="aneorv32_8h_html"><div class="ttname"><a href="neorv32_8h.html">neorv32.h</a></div><div class="ttdoc">Main NEORV32 core library / driver / HAL include file.</div></div> +<div class="ttc" id="aneorv32__onewire_8c_html_a6f7b6690a2437e0b574a8a9a23dc0eaa"><div class="ttname"><a href="neorv32__onewire_8c.html#a6f7b6690a2437e0b574a8a9a23dc0eaa">neorv32_onewire_write_bit_blocking</a></div><div class="ttdeci">void neorv32_onewire_write_bit_blocking(uint8_t bit)</div><div class="ttdef"><b>Definition</b> neorv32_onewire.c:327</div></div> +<div class="ttc" id="aneorv32__onewire_8c_html_ac78557c77482b59394677f42fda4fdf1"><div class="ttname"><a href="neorv32__onewire_8c.html#ac78557c77482b59394677f42fda4fdf1">neorv32_onewire_write_byte_blocking</a></div><div class="ttdeci">void neorv32_onewire_write_byte_blocking(uint8_t byte)</div><div class="ttdef"><b>Definition</b> neorv32_onewire.c:364</div></div> +<div class="ttc" id="aneorv32__onewire_8c_html_ace8b7cf697b068b6b51676d84dec5960"><div class="ttname"><a href="neorv32__onewire_8c.html#ace8b7cf697b068b6b51676d84dec5960">neorv32_onewire_read_bit_blocking</a></div><div class="ttdeci">uint8_t neorv32_onewire_read_bit_blocking(void)</div><div class="ttdef"><b>Definition</b> neorv32_onewire.c:307</div></div> +<div class="ttc" id="aneorv32__onewire_8c_html_af8ca6be495176797b7da3857e2f794f9"><div class="ttname"><a href="neorv32__onewire_8c.html#af8ca6be495176797b7da3857e2f794f9">neorv32_onewire_reset_blocking</a></div><div class="ttdeci">int neorv32_onewire_reset_blocking(void)</div><div class="ttdef"><b>Definition</b> neorv32_onewire.c:287</div></div> +</div><!-- fragment --></div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/open.png b/sw/open.png new file mode 100644 index 0000000000000000000000000000000000000000..30f75c7efe2dd0c9e956e35b69777a02751f048b GIT binary patch literal 123 zcmeAS@N?(olHy`uVBq!ia0vp^oFL4>1|%O$WD@{VPM$7~Ar*{o?;hlAFyLXmaDC0y znK1_#cQqJWPES%4Uujug^TE?jMft$}Eq^WaR~)%f)vSNs&gek&x%A9X9sM<Rdl=8h W@EqZ{ytxBt8iS{+pUXO@geCxcDJg#d literal 0 HcmV?d00001 diff --git a/sw/pages.html b/sw/pages.html new file mode 100644 index 0000000000..a8a9c6f295 --- /dev/null +++ b/sw/pages.html @@ -0,0 +1,104 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: Related Pages</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +</div><!-- top --> +<div id="doc-content"> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div class="header"> + <div class="headertitle"><div class="title">Related Pages</div></div> +</div><!--header--> +<div class="contents"> +<div class="textblock">Here is a list of all related documentation pages:</div><div class="directory"> +<table class="directory"> +<tr id="row_0_" class="even"><td class="entry"><span style="width:16px;display:inline-block;">&#160;</span><a class="el" href="md_README.html" target="_self">README</a></td><td class="desc"></td></tr> +</table> +</div><!-- directory --> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/plus.svg b/sw/plus.svg new file mode 100644 index 0000000000..0752016553 --- /dev/null +++ b/sw/plus.svg @@ -0,0 +1,9 @@ +<?xml version="1.0" encoding="UTF-8" standalone="no"?> +<svg width="12px" height="12px" viewBox="0 0 105.83333 105.83333" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:svg="http://www.w3.org/2000/svg"> + <g> + <rect style="fill:#808080;stroke-width:0" width="105.83333" height="105.83334" x="4.2409692e-08" y="-1.2701158e-06" ry="0" /> + <rect style="fill:#fcfcfc;stroke-width:0" width="79.375" height="79.375" x="13.229166" y="13.229166" /> + <rect style="fill:#808080;stroke-width:0" width="52.916668" height="15.874998" x="26.458332" y="44.979168" /> + <rect style="fill:#808080;stroke-width:0" width="15.874998" height="52.916668" x="44.979168" y="26.458332" /> + </g> +</svg> diff --git a/sw/plusd.svg b/sw/plusd.svg new file mode 100644 index 0000000000..0c65bfe946 --- /dev/null +++ b/sw/plusd.svg @@ -0,0 +1,9 @@ +<?xml version="1.0" encoding="UTF-8" standalone="no"?> +<svg width="12px" height="12px" viewBox="0 0 105.83333 105.83333" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:svg="http://www.w3.org/2000/svg"> + <g> + <rect style="fill:#808080;stroke-width:0" width="105.83333" height="105.83334" x="4.2409692e-08" y="-1.2701158e-06" ry="0" /> + <rect style="fill:#000000;stroke-width:0" width="79.375" height="79.375" x="13.229166" y="13.229166" /> + <rect style="fill:#808080;stroke-width:0" width="52.916668" height="15.874998" x="26.458332" y="44.979168" /> + <rect style="fill:#808080;stroke-width:0" width="15.874998" height="52.916668" x="44.979168" y="26.458332" /> + </g> +</svg> diff --git a/sw/processor__check_2main_8c.html b/sw/processor__check_2main_8c.html new file mode 100644 index 0000000000..839579e508 --- /dev/null +++ b/sw/processor__check_2main_8c.html @@ -0,0 +1,460 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/example/processor_check/main.c File Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_f0f9b27afba2e8cc2da6e5fddcc1a8c9.html">example</a></li><li class="navelem"><a class="el" href="dir_7a2c74f70a4cdf2e836a07048e2f71dd.html">processor_check</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#func-members">Functions</a> &#124; +<a href="#var-members">Variables</a> </div> + <div class="headertitle"><div class="title">main.c File Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p>CPU/Processor test/verification program. +<a href="#details">More...</a></p> +<div class="textblock"><code>#include &lt;<a class="el" href="neorv32_8h_source.html">neorv32.h</a>&gt;</code><br /> +<code>#include &lt;string.h&gt;</code><br /> +</div><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="define-members" name="define-members"></a> +Macros</h2></td></tr> +<tr><td colspan="2"><div class="groupHeader">User configuration</div></td></tr> +<tr class="memitem:ad4455691936f92fdd6c37566fc58ba1f" id="r_ad4455691936f92fdd6c37566fc58ba1f"><td class="memItemLeft" align="right" valign="top"><a id="ad4455691936f92fdd6c37566fc58ba1f" name="ad4455691936f92fdd6c37566fc58ba1f"></a> +#define&#160;</td><td class="memItemRight" valign="bottom"><b>BAUD_RATE</b>&#160;&#160;&#160;(19200)</td></tr> +<tr class="separator:ad4455691936f92fdd6c37566fc58ba1f"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a58c2e480e4c407c3a0d8639d3c8fbe93" id="r_a58c2e480e4c407c3a0d8639d3c8fbe93"><td class="memItemLeft" align="right" valign="top"><a id="a58c2e480e4c407c3a0d8639d3c8fbe93" name="a58c2e480e4c407c3a0d8639d3c8fbe93"></a> +#define&#160;</td><td class="memItemRight" valign="bottom"><b>ADDR_UNALIGNED_1</b>&#160;&#160;&#160;(0x00000001UL)</td></tr> +<tr class="separator:a58c2e480e4c407c3a0d8639d3c8fbe93"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a1197de60262f6f7ef6b7be05637f41f9" id="r_a1197de60262f6f7ef6b7be05637f41f9"><td class="memItemLeft" align="right" valign="top"><a id="a1197de60262f6f7ef6b7be05637f41f9" name="a1197de60262f6f7ef6b7be05637f41f9"></a> +#define&#160;</td><td class="memItemRight" valign="bottom"><b>ADDR_UNALIGNED_3</b>&#160;&#160;&#160;(0x00000003UL)</td></tr> +<tr class="separator:a1197de60262f6f7ef6b7be05637f41f9"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a577145c482d9444e298153c98f37c210" id="r_a577145c482d9444e298153c98f37c210"><td class="memItemLeft" align="right" valign="top"><a id="a577145c482d9444e298153c98f37c210" name="a577145c482d9444e298153c98f37c210"></a> +#define&#160;</td><td class="memItemRight" valign="bottom"><b>ADDR_UNREACHABLE</b>&#160;&#160;&#160;(<a class="el" href="neorv32_8h.html#a9bf0149681677f7d87abf8f62e2d9a3d">NEORV32_DM_BASE</a>)</td></tr> +<tr class="separator:a577145c482d9444e298153c98f37c210"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a32aece76361713a064649137ee25b1a4" id="r_a32aece76361713a064649137ee25b1a4"><td class="memItemLeft" align="right" valign="top"><a id="a32aece76361713a064649137ee25b1a4" name="a32aece76361713a064649137ee25b1a4"></a> +#define&#160;</td><td class="memItemRight" valign="bottom"><b>EXT_MEM_BASE</b>&#160;&#160;&#160;(0xF0000000UL)</td></tr> +<tr class="separator:a32aece76361713a064649137ee25b1a4"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr><td colspan="2"><div class="groupHeader">UART print macros</div></td></tr> +<tr class="memitem:acbfde3de517fdc818a720383ec516d5b" id="r_acbfde3de517fdc818a720383ec516d5b"><td class="memItemLeft" align="right" valign="top"><a id="acbfde3de517fdc818a720383ec516d5b" name="acbfde3de517fdc818a720383ec516d5b"></a> +#define&#160;</td><td class="memItemRight" valign="bottom"><b>PRINT_STANDARD</b>(...)&#160;&#160;&#160;neorv32_uart0_printf(__VA_ARGS__)</td></tr> +<tr class="separator:acbfde3de517fdc818a720383ec516d5b"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:acaa90e675a32d0f349ece12c9437e98f" id="r_acaa90e675a32d0f349ece12c9437e98f"><td class="memItemLeft" align="right" valign="top"><a id="acaa90e675a32d0f349ece12c9437e98f" name="acaa90e675a32d0f349ece12c9437e98f"></a> +#define&#160;</td><td class="memItemRight" valign="bottom"><b>PRINT_CRITICAL</b>(...)&#160;&#160;&#160;neorv32_uart0_printf(__VA_ARGS__)</td></tr> +<tr class="separator:acaa90e675a32d0f349ece12c9437e98f"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="func-members" name="func-members"></a> +Functions</h2></td></tr> +<tr class="memitem:ada24f2cd9d2d384265517f539711de62" id="r_ada24f2cd9d2d384265517f539711de62"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ada24f2cd9d2d384265517f539711de62">sim_irq_trigger</a> (uint32_t sel)</td></tr> +<tr class="separator:ada24f2cd9d2d384265517f539711de62"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a9a64ce0ee69c4c32cecc8b2b2746604c" id="r_a9a64ce0ee69c4c32cecc8b2b2746604c"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a9a64ce0ee69c4c32cecc8b2b2746604c">global_trap_handler</a> (void)</td></tr> +<tr class="separator:a9a64ce0ee69c4c32cecc8b2b2746604c"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a349743a03307abb5130a3e89d903971b" id="r_a349743a03307abb5130a3e89d903971b"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a349743a03307abb5130a3e89d903971b">rte_service_handler</a> (void)</td></tr> +<tr class="separator:a349743a03307abb5130a3e89d903971b"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a0d695ebfaae3b4614ddb62640cbf8b7b" id="r_a0d695ebfaae3b4614ddb62640cbf8b7b"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a0d695ebfaae3b4614ddb62640cbf8b7b">vectored_irq_table</a> (void)</td></tr> +<tr class="separator:a0d695ebfaae3b4614ddb62640cbf8b7b"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a9504ca74fdb80711a88d2a16d4cb4cf4" id="r_a9504ca74fdb80711a88d2a16d4cb4cf4"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a9504ca74fdb80711a88d2a16d4cb4cf4">vectored_global_handler</a> (void)</td></tr> +<tr class="separator:a9504ca74fdb80711a88d2a16d4cb4cf4"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a1a455bede4ab48f32d3ed0868e398044" id="r_a1a455bede4ab48f32d3ed0868e398044"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a1a455bede4ab48f32d3ed0868e398044">vectored_mei_handler</a> (void)</td></tr> +<tr class="separator:a1a455bede4ab48f32d3ed0868e398044"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a31d9e432f6a368e6222f5e0907eeb6f4" id="r_a31d9e432f6a368e6222f5e0907eeb6f4"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a31d9e432f6a368e6222f5e0907eeb6f4">hw_breakpoint_handler</a> (void)</td></tr> +<tr class="separator:a31d9e432f6a368e6222f5e0907eeb6f4"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ac91bfdd45696444673dc7d6b1b644082" id="r_ac91bfdd45696444673dc7d6b1b644082"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ac91bfdd45696444673dc7d6b1b644082">trigger_module_dummy</a> (void)</td></tr> +<tr class="separator:ac91bfdd45696444673dc7d6b1b644082"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aa4fe70578c4dccabe1e31fae941378cb" id="r_aa4fe70578c4dccabe1e31fae941378cb"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aa4fe70578c4dccabe1e31fae941378cb">xirq_trap_handler0</a> (void)</td></tr> +<tr class="separator:aa4fe70578c4dccabe1e31fae941378cb"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a277cb06ef74e4cfe1ef783069f9b6527" id="r_a277cb06ef74e4cfe1ef783069f9b6527"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a277cb06ef74e4cfe1ef783069f9b6527">xirq_trap_handler1</a> (void)</td></tr> +<tr class="separator:a277cb06ef74e4cfe1ef783069f9b6527"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ae61d39109b2747429ec3a3c1b5533598" id="r_ae61d39109b2747429ec3a3c1b5533598"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ae61d39109b2747429ec3a3c1b5533598">test_ok</a> (void)</td></tr> +<tr class="separator:ae61d39109b2747429ec3a3c1b5533598"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a1e0a5d63896fa26a6c25c0012fc6b938" id="r_a1e0a5d63896fa26a6c25c0012fc6b938"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a1e0a5d63896fa26a6c25c0012fc6b938">test_fail</a> (void)</td></tr> +<tr class="separator:a1e0a5d63896fa26a6c25c0012fc6b938"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ae66f6b31b5ad750f1fe042a706a4e3d4" id="r_ae66f6b31b5ad750f1fe042a706a4e3d4"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ae66f6b31b5ad750f1fe042a706a4e3d4">main</a> ()</td></tr> +<tr class="separator:ae66f6b31b5ad750f1fe042a706a4e3d4"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="var-members" name="var-members"></a> +Variables</h2></td></tr> +<tr class="memitem:ae0783283256fd1826040b1090342a4d2" id="r_ae0783283256fd1826040b1090342a4d2"><td class="memItemLeft" align="right" valign="top"><a id="ae0783283256fd1826040b1090342a4d2" name="ae0783283256fd1826040b1090342a4d2"></a> +const uint32_t&#160;</td><td class="memItemRight" valign="bottom"><b>mcause_never_c</b> = 0x80000000UL</td></tr> +<tr class="separator:ae0783283256fd1826040b1090342a4d2"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a109a78ab4c60a2b9c00c8fd6174d2af7" id="r_a109a78ab4c60a2b9c00c8fd6174d2af7"><td class="memItemLeft" align="right" valign="top"><a id="a109a78ab4c60a2b9c00c8fd6174d2af7" name="a109a78ab4c60a2b9c00c8fd6174d2af7"></a> +volatile int&#160;</td><td class="memItemRight" valign="bottom"><b>cnt_fail</b> = 0</td></tr> +<tr class="separator:a109a78ab4c60a2b9c00c8fd6174d2af7"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a144bdb576c534127820da75219d1ae13" id="r_a144bdb576c534127820da75219d1ae13"><td class="memItemLeft" align="right" valign="top"><a id="a144bdb576c534127820da75219d1ae13" name="a144bdb576c534127820da75219d1ae13"></a> +volatile int&#160;</td><td class="memItemRight" valign="bottom"><b>cnt_ok</b> = 0</td></tr> +<tr class="separator:a144bdb576c534127820da75219d1ae13"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ac778536f0a8aa9e25139fd2eab0febb8" id="r_ac778536f0a8aa9e25139fd2eab0febb8"><td class="memItemLeft" align="right" valign="top"><a id="ac778536f0a8aa9e25139fd2eab0febb8" name="ac778536f0a8aa9e25139fd2eab0febb8"></a> +volatile int&#160;</td><td class="memItemRight" valign="bottom"><b>cnt_test</b> = 0</td></tr> +<tr class="separator:ac778536f0a8aa9e25139fd2eab0febb8"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ae2b99614860e64dd115f1061d6e81439" id="r_ae2b99614860e64dd115f1061d6e81439"><td class="memItemLeft" align="right" valign="top"><a id="ae2b99614860e64dd115f1061d6e81439" name="ae2b99614860e64dd115f1061d6e81439"></a> +volatile uint32_t&#160;</td><td class="memItemRight" valign="bottom"><b>num_hpm_cnts_global</b> = 0</td></tr> +<tr class="separator:ae2b99614860e64dd115f1061d6e81439"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aa3a6d1f668e064493017c66046f24843" id="r_aa3a6d1f668e064493017c66046f24843"><td class="memItemLeft" align="right" valign="top"><a id="aa3a6d1f668e064493017c66046f24843" name="aa3a6d1f668e064493017c66046f24843"></a> +volatile int&#160;</td><td class="memItemRight" valign="bottom"><b>vectored_mei_handler_ack</b> = 0</td></tr> +<tr class="separator:aa3a6d1f668e064493017c66046f24843"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aa7a94a1ae71c7ab1650351c2af18b745" id="r_aa7a94a1ae71c7ab1650351c2af18b745"><td class="memItemLeft" align="right" valign="top"><a id="aa7a94a1ae71c7ab1650351c2af18b745" name="aa7a94a1ae71c7ab1650351c2af18b745"></a> +volatile uint32_t&#160;</td><td class="memItemRight" valign="bottom"><b>xirq_trap_handler_ack</b> = 0</td></tr> +<tr class="separator:aa7a94a1ae71c7ab1650351c2af18b745"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a49b20a83a39c69f841db1ca6653a5d16" id="r_a49b20a83a39c69f841db1ca6653a5d16"><td class="memItemLeft" align="right" valign="top"><a id="a49b20a83a39c69f841db1ca6653a5d16" name="a49b20a83a39c69f841db1ca6653a5d16"></a> +volatile uint32_t&#160;</td><td class="memItemRight" valign="bottom"><b>hw_brk_mscratch_ok</b> = 0</td></tr> +<tr class="separator:a49b20a83a39c69f841db1ca6653a5d16"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a264dc6692665c4813b594da243f3a7e2" id="r_a264dc6692665c4813b594da243f3a7e2"><td class="memItemLeft" align="right" valign="top"><a id="a264dc6692665c4813b594da243f3a7e2" name="a264dc6692665c4813b594da243f3a7e2"></a> +volatile uint32_t&#160;</td><td class="memItemRight" valign="bottom"><b>dma_src</b></td></tr> +<tr class="separator:a264dc6692665c4813b594da243f3a7e2"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:acd15f2c828419bbdaf6acf27404df5a9" id="r_acd15f2c828419bbdaf6acf27404df5a9"><td class="memItemLeft" align="right" valign="top"><a id="acd15f2c828419bbdaf6acf27404df5a9" name="acd15f2c828419bbdaf6acf27404df5a9"></a> +volatile uint32_t&#160;</td><td class="memItemRight" valign="bottom"><b>store_access_addr</b> [2]</td></tr> +<tr class="separator:acd15f2c828419bbdaf6acf27404df5a9"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a9141e95a5f98420ddf8a43e6d20ff6dc" id="r_a9141e95a5f98420ddf8a43e6d20ff6dc"><td class="memItemLeft" align="right" valign="top"><a id="a9141e95a5f98420ddf8a43e6d20ff6dc" name="a9141e95a5f98420ddf8a43e6d20ff6dc"></a> +volatile uint32_t&#160;</td><td class="memItemRight" valign="bottom"><b>amo_var</b></td></tr> +<tr class="separator:a9141e95a5f98420ddf8a43e6d20ff6dc"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a1a3f256100e7e01c261bac5c7130ec1a" id="r_a1a3f256100e7e01c261bac5c7130ec1a"><td class="memItemLeft" align="right" valign="top"><a id="a1a3f256100e7e01c261bac5c7130ec1a" name="a1a3f256100e7e01c261bac5c7130ec1a"></a> +volatile uint32_t&#160;</td><td class="memItemRight" valign="bottom"><b>pmp_access</b> [2]</td></tr> +<tr class="separator:a1a3f256100e7e01c261bac5c7130ec1a"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a7ad64774414ab59e4e1ed52d24f62f71" id="r_a7ad64774414ab59e4e1ed52d24f62f71"><td class="memItemLeft" align="right" valign="top"><a id="a7ad64774414ab59e4e1ed52d24f62f71" name="a7ad64774414ab59e4e1ed52d24f62f71"></a> +volatile uint32_t&#160;</td><td class="memItemRight" valign="bottom"><b>trap_cnt</b></td></tr> +<tr class="separator:a7ad64774414ab59e4e1ed52d24f62f71"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a58d31bd38ed6dca5083f002b70ad73c6" id="r_a58d31bd38ed6dca5083f002b70ad73c6"><td class="memItemLeft" align="right" valign="top"><a id="a58d31bd38ed6dca5083f002b70ad73c6" name="a58d31bd38ed6dca5083f002b70ad73c6"></a> +volatile uint32_t&#160;</td><td class="memItemRight" valign="bottom"><b>pmp_num_regions</b></td></tr> +<tr class="separator:a58d31bd38ed6dca5083f002b70ad73c6"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>CPU/Processor test/verification program. </p> +<dl class="section author"><dt>Author</dt><dd>Stephan Nolting </dd></dl> +</div><h2 class="groupheader">Function Documentation</h2> +<a id="a9a64ce0ee69c4c32cecc8b2b2746604c" name="a9a64ce0ee69c4c32cecc8b2b2746604c"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a9a64ce0ee69c4c32cecc8b2b2746604c">&#9670;&#160;</a></span>global_trap_handler()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void global_trap_handler </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Trap handler for ALL exceptions/interrupts. </p> + +</div> +</div> +<a id="a31d9e432f6a368e6222f5e0907eeb6f4" name="a31d9e432f6a368e6222f5e0907eeb6f4"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a31d9e432f6a368e6222f5e0907eeb6f4">&#9670;&#160;</a></span>hw_breakpoint_handler()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void hw_breakpoint_handler </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Hardware-breakpoint trap handler </p> + +</div> +</div> +<a id="ae66f6b31b5ad750f1fe042a706a4e3d4" name="ae66f6b31b5ad750f1fe042a706a4e3d4"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ae66f6b31b5ad750f1fe042a706a4e3d4">&#9670;&#160;</a></span>main()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">int main </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>High-level CPU/processor test program.</p> +<dl class="section warning"><dt>Warning</dt><dd>This test is intended for simulation only. </dd> +<dd> +This test requires all optional extensions/modules to be enabled.</dd></dl> +<dl class="section return"><dt>Returns</dt><dd>0 if execution was successful </dd></dl> + +</div> +</div> +<a id="a349743a03307abb5130a3e89d903971b" name="a349743a03307abb5130a3e89d903971b"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a349743a03307abb5130a3e89d903971b">&#9670;&#160;</a></span>rte_service_handler()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void rte_service_handler </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>RTE's ecall "system service handler"; modifies application context to provide "system services" </p> + +</div> +</div> +<a id="ada24f2cd9d2d384265517f539711de62" name="ada24f2cd9d2d384265517f539711de62"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ada24f2cd9d2d384265517f539711de62">&#9670;&#160;</a></span>sim_irq_trigger()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void sim_irq_trigger </td> + <td>(</td> + <td class="paramtype">uint32_t</td> <td class="paramname"><span class="paramname"><em>sel</em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Simulation-based function to set/clear CPU interrupts (MSI, MEI).</p> +<dl class="params"><dt>Parameters</dt><dd> + <table class="params"> + <tr><td class="paramdir">[in]</td><td class="paramname">sel</td><td>IRQ select mask (bit positions according to <a class="el" href="neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33">NEORV32_CSR_MIE_enum</a>). </td></tr> + </table> + </dd> +</dl> + +</div> +</div> +<a id="a1e0a5d63896fa26a6c25c0012fc6b938" name="a1e0a5d63896fa26a6c25c0012fc6b938"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a1e0a5d63896fa26a6c25c0012fc6b938">&#9670;&#160;</a></span>test_fail()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void test_fail </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Test results helper function: Shows "[FAIL]" and increments global cnt_fail </p> + +</div> +</div> +<a id="ae61d39109b2747429ec3a3c1b5533598" name="ae61d39109b2747429ec3a3c1b5533598"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ae61d39109b2747429ec3a3c1b5533598">&#9670;&#160;</a></span>test_ok()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void test_ok </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Test results helper function: Shows "[ok]" and increments global cnt_ok </p> + +</div> +</div> +<a id="ac91bfdd45696444673dc7d6b1b644082" name="ac91bfdd45696444673dc7d6b1b644082"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ac91bfdd45696444673dc7d6b1b644082">&#9670;&#160;</a></span>trigger_module_dummy()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void trigger_module_dummy </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Test function for the trigger module </p> + +</div> +</div> +<a id="a9504ca74fdb80711a88d2a16d4cb4cf4" name="a9504ca74fdb80711a88d2a16d4cb4cf4"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a9504ca74fdb80711a88d2a16d4cb4cf4">&#9670;&#160;</a></span>vectored_global_handler()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void vectored_global_handler </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Vectored trap handler for ALL exceptions/interrupts. </p> + +</div> +</div> +<a id="a0d695ebfaae3b4614ddb62640cbf8b7b" name="a0d695ebfaae3b4614ddb62640cbf8b7b"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a0d695ebfaae3b4614ddb62640cbf8b7b">&#9670;&#160;</a></span>vectored_irq_table()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void vectored_irq_table </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Vectored mtvec mode jump table. </p> + +</div> +</div> +<a id="a1a455bede4ab48f32d3ed0868e398044" name="a1a455bede4ab48f32d3ed0868e398044"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a1a455bede4ab48f32d3ed0868e398044">&#9670;&#160;</a></span>vectored_mei_handler()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void vectored_mei_handler </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>Machine external interrupt handler. </p> + +</div> +</div> +<a id="aa4fe70578c4dccabe1e31fae941378cb" name="aa4fe70578c4dccabe1e31fae941378cb"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aa4fe70578c4dccabe1e31fae941378cb">&#9670;&#160;</a></span>xirq_trap_handler0()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void xirq_trap_handler0 </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>XIRQ handler channel 0. </p> + +</div> +</div> +<a id="a277cb06ef74e4cfe1ef783069f9b6527" name="a277cb06ef74e4cfe1ef783069f9b6527"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a277cb06ef74e4cfe1ef783069f9b6527">&#9670;&#160;</a></span>xirq_trap_handler1()</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">void xirq_trap_handler1 </td> + <td>(</td> + <td class="paramtype">void</td> <td class="paramname"><span class="paramname"><em></em></span></td><td>)</td> + <td></td> + </tr> + </table> +</div><div class="memdoc"> +<p>XIRQ handler channel 1. </p> + +</div> +</div> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/resize.js b/sw/resize.js new file mode 100644 index 0000000000..7d8cdc7d4f --- /dev/null +++ b/sw/resize.js @@ -0,0 +1,145 @@ +/* + @licstart The following is the entire license notice for the JavaScript code in this file. + + The MIT License (MIT) + + Copyright (C) 1997-2020 by Dimitri van Heesch + + Permission is hereby granted, free of charge, to any person obtaining a copy of this software + and associated documentation files (the "Software"), to deal in the Software without restriction, + including without limitation the rights to use, copy, modify, merge, publish, distribute, + sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is + furnished to do so, subject to the following conditions: + + The above copyright notice and this permission notice shall be included in all copies or + substantial portions of the Software. + + THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING + BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND + NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, + DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. + + @licend The above is the entire license notice for the JavaScript code in this file + */ + +function initResizable(treeview) { + let sidenav,navtree,content,header,footer,barWidth=6; + const RESIZE_COOKIE_NAME = ''+'width'; + + function resizeWidth() { + const sidenavWidth = $(sidenav).outerWidth(); + content.css({marginLeft:parseInt(sidenavWidth)+"px"}); + if (typeof page_layout!=='undefined' && page_layout==1) { + footer.css({marginLeft:parseInt(sidenavWidth)+"px"}); + } + Cookie.writeSetting(RESIZE_COOKIE_NAME,sidenavWidth-barWidth); + } + + function restoreWidth(navWidth) { + content.css({marginLeft:parseInt(navWidth)+barWidth+"px"}); + if (typeof page_layout!=='undefined' && page_layout==1) { + footer.css({marginLeft:parseInt(navWidth)+barWidth+"px"}); + } + sidenav.css({width:navWidth + "px"}); + } + + function resizeHeight(treeview) { + const headerHeight = header.outerHeight(); + const windowHeight = $(window).height(); + let contentHeight; + if (treeview) + { + const footerHeight = footer.outerHeight(); + let navtreeHeight,sideNavHeight; + if (typeof page_layout==='undefined' || page_layout==0) { /* DISABLE_INDEX=NO */ + contentHeight = windowHeight - headerHeight - footerHeight; + navtreeHeight = contentHeight; + sideNavHeight = contentHeight; + } else if (page_layout==1) { /* DISABLE_INDEX=YES */ + contentHeight = windowHeight - footerHeight; + navtreeHeight = windowHeight - headerHeight; + sideNavHeight = windowHeight; + } + navtree.css({height:navtreeHeight + "px"}); + sidenav.css({height:sideNavHeight + "px"}); + } + else + { + contentHeight = windowHeight - headerHeight; + } + content.css({height:contentHeight + "px"}); + if (location.hash.slice(1)) { + (document.getElementById(location.hash.slice(1))||document.body).scrollIntoView(); + } + } + + function collapseExpand() { + let newWidth; + if (sidenav.width()>0) { + newWidth=0; + } else { + const width = Cookie.readSetting(RESIZE_COOKIE_NAME,250); + newWidth = (width>250 && width<$(window).width()) ? width : 250; + } + restoreWidth(newWidth); + const sidenavWidth = $(sidenav).outerWidth(); + Cookie.writeSetting(RESIZE_COOKIE_NAME,sidenavWidth-barWidth); + } + + header = $("#top"); + content = $("#doc-content"); + footer = $("#nav-path"); + sidenav = $("#side-nav"); + if (!treeview) { +// title = $("#titlearea"); +// titleH = $(title).height(); +// let animating = false; +// content.on("scroll", function() { +// slideOpts = { duration: 200, +// step: function() { +// contentHeight = $(window).height() - header.outerHeight(); +// content.css({ height : contentHeight + "px" }); +// }, +// done: function() { animating=false; } +// }; +// if (content.scrollTop()>titleH && title.css('display')!='none' && !animating) { +// title.slideUp(slideOpts); +// animating=true; +// } else if (content.scrollTop()<=titleH && title.css('display')=='none' && !animating) { +// title.slideDown(slideOpts); +// animating=true; +// } +// }); + } else { + navtree = $("#nav-tree"); + $(".side-nav-resizable").resizable({resize: function(e, ui) { resizeWidth(); } }); + $(sidenav).resizable({ minWidth: 0 }); + } + $(window).resize(function() { resizeHeight(treeview); }); + if (treeview) + { + const device = navigator.userAgent.toLowerCase(); + const touch_device = device.match(/(iphone|ipod|ipad|android)/); + if (touch_device) { /* wider split bar for touch only devices */ + $(sidenav).css({ paddingRight:'20px' }); + $('.ui-resizable-e').css({ width:'20px' }); + $('#nav-sync').css({ right:'34px' }); + barWidth=20; + } + const width = Cookie.readSetting(RESIZE_COOKIE_NAME,250); + if (width) { restoreWidth(width); } else { resizeWidth(); } + } + resizeHeight(treeview); + const url = location.href; + const i=url.indexOf("#"); + if (i>=0) window.location.hash=url.substr(i); + const _preventDefault = function(evt) { evt.preventDefault(); }; + if (treeview) + { + $("#splitbar").bind("dragstart", _preventDefault).bind("selectstart", _preventDefault); + $(".ui-resizable-handle").dblclick(collapseExpand); + } + $(window).on('load',resizeHeight); +} +/* @license-end */ diff --git a/sw/search/all_0.js b/sw/search/all_0.js new file mode 100644 index 0000000000..7b0e67ce96 --- /dev/null +++ b/sw/search/all_0.js @@ -0,0 +1,4 @@ +var searchData= +[ + ['1_20overview_0',['1. Overview',['../md_README.html#autotoc_md1',1,'']]] +]; diff --git a/sw/search/all_1.js b/sw/search/all_1.js new file mode 100644 index 0000000000..bf3dd22bfa --- /dev/null +++ b/sw/search/all_1.js @@ -0,0 +1,4 @@ +var searchData= +[ + ['2_20features_0',['2. Features',['../md_README.html#autotoc_md4',1,'']]] +]; diff --git a/sw/search/all_10.js b/sw/search/all_10.js new file mode 100644 index 0000000000..f6d15f15af --- /dev/null +++ b/sw/search/all_10.js @@ -0,0 +1,5 @@ +var searchData= +[ + ['key_0',['key',['../demo__cfu_2main_8c.html#ab5c498f9da12ab2d6ddc89bf4a46dec6',1,'main.c']]], + ['key_20features_1',['Key Features',['../md_README.html#autotoc_md2',1,'']]] +]; diff --git a/sw/search/all_11.js b/sw/search/all_11.js new file mode 100644 index 0000000000..eefde675d0 --- /dev/null +++ b/sw/search/all_11.js @@ -0,0 +1,4 @@ +var searchData= +[ + ['legal_0',[':copyright: Legal',['../md_README.html#autotoc_md13',1,'']]] +]; diff --git a/sw/search/all_12.js b/sw/search/all_12.js new file mode 100644 index 0000000000..06f14f0b7e --- /dev/null +++ b/sw/search/all_12.js @@ -0,0 +1,11 @@ +var searchData= +[ + ['main_0',['main',['../bootloader_8c.html#a840291bc02cba5474a4cb46a9b9566fe',1,'main(void):&#160;bootloader.c'],['../atomic__test_2main_8c.html#ae66f6b31b5ad750f1fe042a706a4e3d4',1,'main():&#160;main.c'],['../bus__explorer_2main_8c.html#ae66f6b31b5ad750f1fe042a706a4e3d4',1,'main():&#160;main.c'],['../demo__blink__led_2main_8c.html#ae66f6b31b5ad750f1fe042a706a4e3d4',1,'main():&#160;main.c'],['../demo__cfs_2main_8c.html#ae66f6b31b5ad750f1fe042a706a4e3d4',1,'main():&#160;main.c'],['../demo__cfu_2main_8c.html#ae66f6b31b5ad750f1fe042a706a4e3d4',1,'main():&#160;main.c'],['../demo__crc_2main_8c.html#ae66f6b31b5ad750f1fe042a706a4e3d4',1,'main():&#160;main.c'],['../demo__dma_2main_8c.html#ae66f6b31b5ad750f1fe042a706a4e3d4',1,'main():&#160;main.c'],['../demo__emulate__unaligned_2main_8c.html#ae66f6b31b5ad750f1fe042a706a4e3d4',1,'main():&#160;main.c'],['../demo__gptmr_2main_8c.html#ae66f6b31b5ad750f1fe042a706a4e3d4',1,'main():&#160;main.c'],['../demo__hpm_2main_8c.html#ae66f6b31b5ad750f1fe042a706a4e3d4',1,'main():&#160;main.c'],['../demo__mtime_2main_8c.html#ae66f6b31b5ad750f1fe042a706a4e3d4',1,'main():&#160;main.c'],['../demo__neopixel_2main_8c.html#ae66f6b31b5ad750f1fe042a706a4e3d4',1,'main():&#160;main.c'],['../demo__newlib_2main_8c.html#ae66f6b31b5ad750f1fe042a706a4e3d4',1,'main():&#160;main.c'],['../demo__onewire_2main_8c.html#ae66f6b31b5ad750f1fe042a706a4e3d4',1,'main():&#160;main.c'],['../demo__pwm_2main_8c.html#ae66f6b31b5ad750f1fe042a706a4e3d4',1,'main():&#160;main.c'],['../demo__sdi_2main_8c.html#ae66f6b31b5ad750f1fe042a706a4e3d4',1,'main():&#160;main.c'],['../demo__slink_2main_8c.html#ae66f6b31b5ad750f1fe042a706a4e3d4',1,'main():&#160;main.c'],['../demo__spi_2main_8c.html#ae66f6b31b5ad750f1fe042a706a4e3d4',1,'main():&#160;main.c'],['../demo__spi__irq_2main_8c.html#ae66f6b31b5ad750f1fe042a706a4e3d4',1,'main():&#160;main.c'],['../demo__trng_2main_8c.html#a840291bc02cba5474a4cb46a9b9566fe',1,'main(void):&#160;main.c'],['../demo__twi_2main_8c.html#ae66f6b31b5ad750f1fe042a706a4e3d4',1,'main():&#160;main.c'],['../demo__wdt_2main_8c.html#ae66f6b31b5ad750f1fe042a706a4e3d4',1,'main():&#160;main.c'],['../demo__xip_2main_8c.html#ae66f6b31b5ad750f1fe042a706a4e3d4',1,'main():&#160;main.c'],['../demo__xirq_2main_8c.html#ae66f6b31b5ad750f1fe042a706a4e3d4',1,'main():&#160;main.c'],['../float__corner__test_2main_8c.html#ae66f6b31b5ad750f1fe042a706a4e3d4',1,'main():&#160;main.c'],['../floating__point__test_2main_8c.html#ae66f6b31b5ad750f1fe042a706a4e3d4',1,'main():&#160;main.c'],['../game__of__life_2main_8c.html#a840291bc02cba5474a4cb46a9b9566fe',1,'main(void):&#160;main.c'],['../hello__world_2main_8c.html#ae66f6b31b5ad750f1fe042a706a4e3d4',1,'main():&#160;main.c'],['../processor__check_2main_8c.html#ae66f6b31b5ad750f1fe042a706a4e3d4',1,'main():&#160;main.c']]], + ['main_2ec_1',['main.c',['../atomic__test_2main_8c.html',1,'(Global Namespace)'],['../bus__explorer_2main_8c.html',1,'(Global Namespace)'],['../demo__blink__led_2main_8c.html',1,'(Global Namespace)'],['../demo__cfs_2main_8c.html',1,'(Global Namespace)'],['../demo__cfu_2main_8c.html',1,'(Global Namespace)'],['../demo__crc_2main_8c.html',1,'(Global Namespace)'],['../demo__dma_2main_8c.html',1,'(Global Namespace)'],['../demo__emulate__unaligned_2main_8c.html',1,'(Global Namespace)'],['../demo__gptmr_2main_8c.html',1,'(Global Namespace)'],['../demo__hpm_2main_8c.html',1,'(Global Namespace)'],['../demo__mtime_2main_8c.html',1,'(Global Namespace)'],['../demo__neopixel_2main_8c.html',1,'(Global Namespace)'],['../demo__newlib_2main_8c.html',1,'(Global Namespace)'],['../demo__onewire_2main_8c.html',1,'(Global Namespace)'],['../demo__pwm_2main_8c.html',1,'(Global Namespace)'],['../demo__sdi_2main_8c.html',1,'(Global Namespace)'],['../demo__slink_2main_8c.html',1,'(Global Namespace)'],['../demo__spi_2main_8c.html',1,'(Global Namespace)'],['../demo__spi__irq_2main_8c.html',1,'(Global Namespace)'],['../demo__trng_2main_8c.html',1,'(Global Namespace)'],['../demo__twi_2main_8c.html',1,'(Global Namespace)'],['../demo__wdt_2main_8c.html',1,'(Global Namespace)'],['../demo__xip_2main_8c.html',1,'(Global Namespace)'],['../demo__xirq_2main_8c.html',1,'(Global Namespace)'],['../float__corner__test_2main_8c.html',1,'(Global Namespace)'],['../floating__point__test_2main_8c.html',1,'(Global Namespace)'],['../game__of__life_2main_8c.html',1,'(Global Namespace)'],['../hello__world_2main_8c.html',1,'(Global Namespace)'],['../processor__check_2main_8c.html',1,'(Global Namespace)']]], + ['max_5fintensity_2',['MAX_INTENSITY',['../demo__neopixel_2main_8c.html#a1d1d5e7ff16f25b68fdf779befd298f7',1,'main.c']]], + ['mem_3',['MEM',['../structneorv32__sysinfo__t.html#a51eee92b1824c1b19eb0a83a0a9c7d4c',1,'neorv32_sysinfo_t']]], + ['minutes_4',['minutes',['../structdate__t.html#a2ab79834ebae42979e359bf30ad5f67a',1,'date_t']]], + ['mode_5',['MODE',['../structneorv32__crc__t.html#ad720502701f16e6e952bbcaee980017c',1,'neorv32_crc_t']]], + ['month_6',['month',['../structdate__t.html#a1a97f6a755cd4209a0880cf811d52c7b',1,'date_t']]], + ['mtime_5firq_5fhandler_7',['mtime_irq_handler',['../demo__mtime_2main_8c.html#a329137855a7c2e098715a0771c5585d7',1,'main.c']]] +]; diff --git a/sw/search/all_13.js b/sw/search/all_13.js new file mode 100644 index 0000000000..5d22b0d92d --- /dev/null +++ b/sw/search/all_13.js @@ -0,0 +1,432 @@ +var searchData= +[ + ['neoled_5fctrl_5fbufs_5f0_0',['NEOLED_CTRL_BUFS_0',['../neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a3bb5d0d1f78cebccbc8620a0194f43b8',1,'neorv32_neoled.h']]], + ['neoled_5fctrl_5fbufs_5f1_1',['NEOLED_CTRL_BUFS_1',['../neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412aed0a878e73ad501bed3bbe6905974368',1,'neorv32_neoled.h']]], + ['neoled_5fctrl_5fbufs_5f2_2',['NEOLED_CTRL_BUFS_2',['../neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412ae7b9d45c4ef69ca15fa13aa107e68156',1,'neorv32_neoled.h']]], + ['neoled_5fctrl_5fbufs_5f3_3',['NEOLED_CTRL_BUFS_3',['../neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412ac1922a5311e91a74710eddbf86ccc1c1',1,'neorv32_neoled.h']]], + ['neoled_5fctrl_5fen_4',['NEOLED_CTRL_EN',['../neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412af97ab77b33a250d87025c3dd3a21fea7',1,'neorv32_neoled.h']]], + ['neoled_5fctrl_5firq_5fconf_5',['NEOLED_CTRL_IRQ_CONF',['../neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a37421074b86a260b276534b7c4949339',1,'neorv32_neoled.h']]], + ['neoled_5fctrl_5fmode_6',['NEOLED_CTRL_MODE',['../neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412abf6779cbeae87ab55efc9573932fc865',1,'neorv32_neoled.h']]], + ['neoled_5fctrl_5fprsc0_7',['NEOLED_CTRL_PRSC0',['../neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a142ed3fd65e01f853666a1169f920ad0',1,'neorv32_neoled.h']]], + ['neoled_5fctrl_5fprsc1_8',['NEOLED_CTRL_PRSC1',['../neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a0f4178d81ec6fe9a8b0e30230d318a91',1,'neorv32_neoled.h']]], + ['neoled_5fctrl_5fprsc2_9',['NEOLED_CTRL_PRSC2',['../neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a3d8d54c05080fddb16df4176527bafa8',1,'neorv32_neoled.h']]], + ['neoled_5fctrl_5fstrobe_10',['NEOLED_CTRL_STROBE',['../neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a436ad310b025bd3000af37986c193de5',1,'neorv32_neoled.h']]], + ['neoled_5fctrl_5ft_5fone_5fh_5f0_11',['NEOLED_CTRL_T_ONE_H_0',['../neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a770df505d47353f6c9289059c416d9c8',1,'neorv32_neoled.h']]], + ['neoled_5fctrl_5ft_5fone_5fh_5f1_12',['NEOLED_CTRL_T_ONE_H_1',['../neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412aea15666ad4bb9eb1eba5dc9ed96114a6',1,'neorv32_neoled.h']]], + ['neoled_5fctrl_5ft_5fone_5fh_5f2_13',['NEOLED_CTRL_T_ONE_H_2',['../neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a4d362af8c630823b5104401a9c7d734e',1,'neorv32_neoled.h']]], + ['neoled_5fctrl_5ft_5fone_5fh_5f3_14',['NEOLED_CTRL_T_ONE_H_3',['../neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a369f36e73783c2923d07ca333081a4a6',1,'neorv32_neoled.h']]], + ['neoled_5fctrl_5ft_5fone_5fh_5f4_15',['NEOLED_CTRL_T_ONE_H_4',['../neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a0c15850d0ab005b075f1a317646e18b1',1,'neorv32_neoled.h']]], + ['neoled_5fctrl_5ft_5ftot_5f0_16',['NEOLED_CTRL_T_TOT_0',['../neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a44d8f064decabc690ed1f092be2b049b',1,'neorv32_neoled.h']]], + ['neoled_5fctrl_5ft_5ftot_5f1_17',['NEOLED_CTRL_T_TOT_1',['../neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412addf4d6d1fd09f145d8aa497c4a7479c2',1,'neorv32_neoled.h']]], + ['neoled_5fctrl_5ft_5ftot_5f2_18',['NEOLED_CTRL_T_TOT_2',['../neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a42d09d42d39fc0eb2697853c99f4d5b0',1,'neorv32_neoled.h']]], + ['neoled_5fctrl_5ft_5ftot_5f3_19',['NEOLED_CTRL_T_TOT_3',['../neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412acbcd3c046b528e1900e86428da231df2',1,'neorv32_neoled.h']]], + ['neoled_5fctrl_5ft_5ftot_5f4_20',['NEOLED_CTRL_T_TOT_4',['../neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a3f1a0ad71d9fd892829ec0246be343b3',1,'neorv32_neoled.h']]], + ['neoled_5fctrl_5ft_5fzero_5fh_5f0_21',['NEOLED_CTRL_T_ZERO_H_0',['../neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a7285e332ec7c2b3aeb34290e3e60ded7',1,'neorv32_neoled.h']]], + ['neoled_5fctrl_5ft_5fzero_5fh_5f1_22',['NEOLED_CTRL_T_ZERO_H_1',['../neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a1ef56b35c966786c42f2a2f800e30eae',1,'neorv32_neoled.h']]], + ['neoled_5fctrl_5ft_5fzero_5fh_5f2_23',['NEOLED_CTRL_T_ZERO_H_2',['../neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a9d9411382d943c1659b6b761c462319b',1,'neorv32_neoled.h']]], + ['neoled_5fctrl_5ft_5fzero_5fh_5f3_24',['NEOLED_CTRL_T_ZERO_H_3',['../neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412abf2ea111a4ff34b6cb4dd987c5692f5c',1,'neorv32_neoled.h']]], + ['neoled_5fctrl_5ft_5fzero_5fh_5f4_25',['NEOLED_CTRL_T_ZERO_H_4',['../neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a0d5d01b8d30119bb86c1d079f7d5a9ad',1,'neorv32_neoled.h']]], + ['neoled_5fctrl_5ftx_5fbusy_26',['NEOLED_CTRL_TX_BUSY',['../neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a55da98b018c7cc32cd1e80087ed9018e',1,'neorv32_neoled.h']]], + ['neoled_5fctrl_5ftx_5fempty_27',['NEOLED_CTRL_TX_EMPTY',['../neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a23937f0a728da197590e1d383507cb23',1,'neorv32_neoled.h']]], + ['neoled_5fctrl_5ftx_5ffull_28',['NEOLED_CTRL_TX_FULL',['../neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412acfac5269688b2a03794dc17b11f1b983',1,'neorv32_neoled.h']]], + ['neoled_5fctrl_5ftx_5fhalf_29',['NEOLED_CTRL_TX_HALF',['../neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a16c09df2784cfb6fafffaeaf245f1b73',1,'neorv32_neoled.h']]], + ['neoled_5ffirq_5fenable_30',['NEOLED_FIRQ_ENABLE',['../neorv32_8h.html#a8d0409818600c0b2acfe8253e8f027b8',1,'neorv32.h']]], + ['neoled_5ffirq_5fpending_31',['NEOLED_FIRQ_PENDING',['../neorv32_8h.html#aded7d7f5f4ba3a6d90f9a29e62a8cfab',1,'neorv32.h']]], + ['neoled_5frte_5fid_32',['NEOLED_RTE_ID',['../neorv32_8h.html#aca6cfc3f580c4dfe1e213009ee450c58',1,'neorv32.h']]], + ['neoled_5ftrap_5fcode_33',['NEOLED_TRAP_CODE',['../neorv32_8h.html#ab4a2ac455d7426992de6877ea7325f21',1,'neorv32.h']]], + ['neorv32_20_5fneorv32_5fcentral_5fprocessing_5funit_5fcpu_20neorv32_20cpu_20a_20the_20core_34',[':abacus: &lt;a href=&quot;https://stnolting.github.io/neorv32/#_neorv32_central_processing_unit_cpu&quot; &gt;NEORV32 CPU&lt;/a&gt; - The Core',['../md_README.html#autotoc_md10',1,'']]], + ['neorv32_20_5fneorv32_5fprocessor_5fsoc_20neorv32_20processor_20a_20the_20soc_35',[':desktop_computer: &lt;a href=&quot;https://stnolting.github.io/neorv32/#_neorv32_processor_soc&quot; &gt;NEORV32 Processor&lt;/a&gt; - The SoC',['../md_README.html#autotoc_md9',1,'']]], + ['neorv32_20_5foverview_20neorv32_20project_20a_20an_20introduction_36',[':mag: &lt;a href=&quot;https://stnolting.github.io/neorv32/#_overview&quot; &gt;NEORV32 Project&lt;/a&gt; - An Introduction',['../md_README.html#autotoc_md8',1,'']]], + ['neorv32_20_5fsoftware_5fframework_20software_20framework_20a_20the_20software_20ecosystem_37',[':floppy_disk: &lt;a href=&quot;https://stnolting.github.io/neorv32/#_software_framework&quot; &gt;Software Framework&lt;/a&gt; - The Software Ecosystem',['../md_README.html#autotoc_md11',1,'']]], + ['neorv32_20cpu_20a_20the_20core_38',[':abacus: &lt;a href=&quot;https://stnolting.github.io/neorv32/#_neorv32_central_processing_unit_cpu&quot; &gt;NEORV32 CPU&lt;/a&gt; - The Core',['../md_README.html#autotoc_md10',1,'']]], + ['neorv32_20processor_20a_20the_20soc_39',[':desktop_computer: &lt;a href=&quot;https://stnolting.github.io/neorv32/#_neorv32_processor_soc&quot; &gt;NEORV32 Processor&lt;/a&gt; - The SoC',['../md_README.html#autotoc_md9',1,'']]], + ['neorv32_20project_20a_20an_20introduction_40',[':mag: &lt;a href=&quot;https://stnolting.github.io/neorv32/#_overview&quot; &gt;NEORV32 Project&lt;/a&gt; - An Introduction',['../md_README.html#autotoc_md8',1,'']]], + ['neorv32_20risc_20v_20processor_41',['The NEORV32 RISC-V Processor',['../md_README.html#autotoc_md0',1,'']]], + ['neorv32_20ug_20user_20guide_20a_20getting_20started_42',[':rocket: &lt;a href=&quot;https://stnolting.github.io/neorv32/ug/&quot; &gt;User Guide&lt;/a&gt; - Getting Started!',['../md_README.html#autotoc_md12',1,'']]], + ['neorv32_2eh_43',['neorv32.h',['../neorv32_8h.html',1,'']]], + ['neorv32_5faux_2ec_44',['neorv32_aux.c',['../neorv32__aux_8c.html',1,'']]], + ['neorv32_5faux_2eh_45',['neorv32_aux.h',['../neorv32__aux_8h.html',1,'']]], + ['neorv32_5faux_5fdate2unixtime_46',['neorv32_aux_date2unixtime',['../neorv32__aux_8c.html#a94aa8369ba5f4ebdf5628fcb1ab2ba1c',1,'neorv32_aux_date2unixtime(date_t *date):&#160;neorv32_aux.c'],['../neorv32__aux_8h.html#a94aa8369ba5f4ebdf5628fcb1ab2ba1c',1,'neorv32_aux_date2unixtime(date_t *date):&#160;neorv32_aux.c']]], + ['neorv32_5faux_5fhexstr2uint64_47',['neorv32_aux_hexstr2uint64',['../neorv32__aux_8c.html#aec4703f369e1567c22f140d2ec9daafc',1,'neorv32_aux_hexstr2uint64(char *buffer, uint8_t length):&#160;neorv32_aux.c'],['../neorv32__aux_8h.html#aec4703f369e1567c22f140d2ec9daafc',1,'neorv32_aux_hexstr2uint64(char *buffer, uint8_t length):&#160;neorv32_aux.c']]], + ['neorv32_5faux_5funixtime2date_48',['neorv32_aux_unixtime2date',['../neorv32__aux_8c.html#a885a81838a91b57797e849cb835c6887',1,'neorv32_aux_unixtime2date(uint64_t unixtime, date_t *date):&#160;neorv32_aux.c'],['../neorv32__aux_8h.html#a885a81838a91b57797e849cb835c6887',1,'neorv32_aux_unixtime2date(uint64_t unixtime, date_t *date):&#160;neorv32_aux.c']]], + ['neorv32_5faux_5fxorshift32_49',['neorv32_aux_xorshift32',['../neorv32__aux_8c.html#aff31dd983f75f70eeae331c65acaa50e',1,'neorv32_aux_xorshift32(void):&#160;neorv32_aux.c'],['../neorv32__aux_8h.html#aff31dd983f75f70eeae331c65acaa50e',1,'neorv32_aux_xorshift32(void):&#160;neorv32_aux.c']]], + ['neorv32_5fcfs_50',['NEORV32_CFS',['../neorv32__cfs_8h.html#a6c101b306bd096f78d351e39b308d3e2',1,'neorv32_cfs.h']]], + ['neorv32_5fcfs_2ec_51',['neorv32_cfs.c',['../neorv32__cfs_8c.html',1,'']]], + ['neorv32_5fcfs_2eh_52',['neorv32_cfs.h',['../neorv32__cfs_8h.html',1,'']]], + ['neorv32_5fcfs_5favailable_53',['neorv32_cfs_available',['../neorv32__cfs_8c.html#abac96dfaefe433eca1c0b93fa6183d2e',1,'neorv32_cfs_available(void):&#160;neorv32_cfs.c'],['../neorv32__cfs_8h.html#abac96dfaefe433eca1c0b93fa6183d2e',1,'neorv32_cfs_available(void):&#160;neorv32_cfs.c']]], + ['neorv32_5fcfs_5fbase_54',['NEORV32_CFS_BASE',['../neorv32_8h.html#a41d6f97daef61641da96b9f72f6b272f',1,'neorv32.h']]], + ['neorv32_5fcfs_5ft_55',['neorv32_cfs_t',['../structneorv32__cfs__t.html',1,'']]], + ['neorv32_5fcfu_5fr3_5finstr_56',['neorv32_cfu_r3_instr',['../neorv32__cpu__cfu_8h.html#a69d60ccd0cee950b08ce585c3f13b85c',1,'neorv32_cpu_cfu.h']]], + ['neorv32_5fcfu_5fr4_5finstr_57',['neorv32_cfu_r4_instr',['../neorv32__cpu__cfu_8h.html#a046a640f7f4a7b1b99a824fb325e2079',1,'neorv32_cpu_cfu.h']]], + ['neorv32_5fcfu_5fr5_5finstr_5fa_58',['neorv32_cfu_r5_instr_a',['../neorv32__cpu__cfu_8h.html#a65198d9caf04a5cd3a72accc2cecf870',1,'neorv32_cpu_cfu.h']]], + ['neorv32_5fcfu_5fr5_5finstr_5fb_59',['neorv32_cfu_r5_instr_b',['../neorv32__cpu__cfu_8h.html#ab3affefbff898567c6c02c4d10765b04',1,'neorv32_cpu_cfu.h']]], + ['neorv32_5fclock_5fprsc_5fenum_60',['NEORV32_CLOCK_PRSC_enum',['../neorv32_8h.html#a10022df4c223533b04d5aebe222e8b73',1,'neorv32.h']]], + ['neorv32_5fcpu_2ec_61',['neorv32_cpu.c',['../neorv32__cpu_8c.html',1,'']]], + ['neorv32_5fcpu_2eh_62',['neorv32_cpu.h',['../neorv32__cpu_8h.html',1,'']]], + ['neorv32_5fcpu_5famo_2ec_63',['neorv32_cpu_amo.c',['../neorv32__cpu__amo_8c.html',1,'']]], + ['neorv32_5fcpu_5famo_2eh_64',['neorv32_cpu_amo.h',['../neorv32__cpu__amo_8h.html',1,'']]], + ['neorv32_5fcpu_5famoaddw_65',['neorv32_cpu_amoaddw',['../neorv32__cpu__amo_8c.html#ada27ec89b2530f7b7f14de947cc82bf9',1,'neorv32_cpu_amoaddw(uint32_t addr, uint32_t wdata):&#160;neorv32_cpu_amo.c'],['../neorv32__cpu__amo_8h.html#ada27ec89b2530f7b7f14de947cc82bf9',1,'neorv32_cpu_amoaddw(uint32_t addr, uint32_t wdata):&#160;neorv32_cpu_amo.c']]], + ['neorv32_5fcpu_5famoandw_66',['neorv32_cpu_amoandw',['../neorv32__cpu__amo_8c.html#a9b4540dadbfd5da907117570d8006e36',1,'neorv32_cpu_amoandw(uint32_t addr, uint32_t wdata):&#160;neorv32_cpu_amo.c'],['../neorv32__cpu__amo_8h.html#a9b4540dadbfd5da907117570d8006e36',1,'neorv32_cpu_amoandw(uint32_t addr, uint32_t wdata):&#160;neorv32_cpu_amo.c']]], + ['neorv32_5fcpu_5famolr_67',['neorv32_cpu_amolr',['../neorv32__cpu__amo_8h.html#ad4437bbc61a4e40d7d01dfe9459f6639',1,'neorv32_cpu_amo.h']]], + ['neorv32_5fcpu_5famomaxuw_68',['neorv32_cpu_amomaxuw',['../neorv32__cpu__amo_8c.html#a31a6a3b5a33655f4a7b27d4c85b75f07',1,'neorv32_cpu_amomaxuw(uint32_t addr, uint32_t wdata):&#160;neorv32_cpu_amo.c'],['../neorv32__cpu__amo_8h.html#a31a6a3b5a33655f4a7b27d4c85b75f07',1,'neorv32_cpu_amomaxuw(uint32_t addr, uint32_t wdata):&#160;neorv32_cpu_amo.c']]], + ['neorv32_5fcpu_5famomaxw_69',['neorv32_cpu_amomaxw',['../neorv32__cpu__amo_8c.html#a62cf36637d7a04079228acecfe8a5cf3',1,'neorv32_cpu_amomaxw(uint32_t addr, int32_t wdata):&#160;neorv32_cpu_amo.c'],['../neorv32__cpu__amo_8h.html#a62cf36637d7a04079228acecfe8a5cf3',1,'neorv32_cpu_amomaxw(uint32_t addr, int32_t wdata):&#160;neorv32_cpu_amo.c']]], + ['neorv32_5fcpu_5famominuw_70',['neorv32_cpu_amominuw',['../neorv32__cpu__amo_8c.html#a1281e18b95cd525073e1123c5d04e9e2',1,'neorv32_cpu_amominuw(uint32_t addr, uint32_t wdata):&#160;neorv32_cpu_amo.c'],['../neorv32__cpu__amo_8h.html#a1281e18b95cd525073e1123c5d04e9e2',1,'neorv32_cpu_amominuw(uint32_t addr, uint32_t wdata):&#160;neorv32_cpu_amo.c']]], + ['neorv32_5fcpu_5famominw_71',['neorv32_cpu_amominw',['../neorv32__cpu__amo_8c.html#a8e383fb8825538b5579d5ce075830697',1,'neorv32_cpu_amominw(uint32_t addr, int32_t wdata):&#160;neorv32_cpu_amo.c'],['../neorv32__cpu__amo_8h.html#a8e383fb8825538b5579d5ce075830697',1,'neorv32_cpu_amominw(uint32_t addr, int32_t wdata):&#160;neorv32_cpu_amo.c']]], + ['neorv32_5fcpu_5famoorw_72',['neorv32_cpu_amoorw',['../neorv32__cpu__amo_8c.html#adc80b1f2b3a4e70fee44c0edb08fc402',1,'neorv32_cpu_amoorw(uint32_t addr, uint32_t wdata):&#160;neorv32_cpu_amo.c'],['../neorv32__cpu__amo_8h.html#adc80b1f2b3a4e70fee44c0edb08fc402',1,'neorv32_cpu_amoorw(uint32_t addr, uint32_t wdata):&#160;neorv32_cpu_amo.c']]], + ['neorv32_5fcpu_5famosc_73',['neorv32_cpu_amosc',['../neorv32__cpu__amo_8h.html#a5e73eaa273c41a06972e862976fda53c',1,'neorv32_cpu_amo.h']]], + ['neorv32_5fcpu_5famoswapw_74',['neorv32_cpu_amoswapw',['../neorv32__cpu__amo_8c.html#aad0d96e61bacc3af13ff471dd44ca8e9',1,'neorv32_cpu_amoswapw(uint32_t addr, uint32_t wdata):&#160;neorv32_cpu_amo.c'],['../neorv32__cpu__amo_8h.html#aad0d96e61bacc3af13ff471dd44ca8e9',1,'neorv32_cpu_amoswapw(uint32_t addr, uint32_t wdata):&#160;neorv32_cpu_amo.c']]], + ['neorv32_5fcpu_5famoxorw_75',['neorv32_cpu_amoxorw',['../neorv32__cpu__amo_8c.html#a65b67f48356fa9b30596485473311377',1,'neorv32_cpu_amoxorw(uint32_t addr, uint32_t wdata):&#160;neorv32_cpu_amo.c'],['../neorv32__cpu__amo_8h.html#a65b67f48356fa9b30596485473311377',1,'neorv32_cpu_amoxorw(uint32_t addr, uint32_t wdata):&#160;neorv32_cpu_amo.c']]], + ['neorv32_5fcpu_5fcfu_2ec_76',['neorv32_cpu_cfu.c',['../neorv32__cpu__cfu_8c.html',1,'']]], + ['neorv32_5fcpu_5fcfu_2eh_77',['neorv32_cpu_cfu.h',['../neorv32__cpu__cfu_8h.html',1,'']]], + ['neorv32_5fcpu_5fcfu_5favailable_78',['neorv32_cpu_cfu_available',['../neorv32__cpu__cfu_8c.html#a13019b8afa1a80c0e5c24eb4d72e75c1',1,'neorv32_cpu_cfu_available(void):&#160;neorv32_cpu_cfu.c'],['../neorv32__cpu__cfu_8h.html#a13019b8afa1a80c0e5c24eb4d72e75c1',1,'neorv32_cpu_cfu_available(void):&#160;neorv32_cpu_cfu.c']]], + ['neorv32_5fcpu_5fcsr_2eh_79',['neorv32_cpu_csr.h',['../neorv32__cpu__csr_8h.html',1,'']]], + ['neorv32_5fcpu_5fcsr_5fclr_80',['neorv32_cpu_csr_clr',['../neorv32__cpu_8h.html#ab8f533ddbc3a3af5e3bca2287ac10122',1,'neorv32_cpu.h']]], + ['neorv32_5fcpu_5fcsr_5fread_81',['neorv32_cpu_csr_read',['../neorv32__cpu_8h.html#aab7a9f9cf608599f2b124dd499cb8418',1,'neorv32_cpu.h']]], + ['neorv32_5fcpu_5fcsr_5fset_82',['neorv32_cpu_csr_set',['../neorv32__cpu_8h.html#a25a09de97229aac839ef6f74da604acf',1,'neorv32_cpu.h']]], + ['neorv32_5fcpu_5fcsr_5fwrite_83',['neorv32_cpu_csr_write',['../neorv32__cpu_8h.html#afb5ef6e0b1a3e26570edfd8379490455',1,'neorv32_cpu.h']]], + ['neorv32_5fcpu_5fdelay_5fms_84',['neorv32_cpu_delay_ms',['../neorv32__cpu_8c.html#aa9027535b13d9f9325e734997fc4a137',1,'neorv32_cpu_delay_ms(uint32_t time_ms):&#160;neorv32_cpu.c'],['../neorv32__cpu_8h.html#aa9027535b13d9f9325e734997fc4a137',1,'neorv32_cpu_delay_ms(uint32_t time_ms):&#160;neorv32_cpu.c']]], + ['neorv32_5fcpu_5fget_5fclk_5ffrom_5fprsc_85',['neorv32_cpu_get_clk_from_prsc',['../neorv32__cpu_8c.html#a8346fb926f84f3d7bccbb4741105505f',1,'neorv32_cpu_get_clk_from_prsc(int prsc):&#160;neorv32_cpu.c'],['../neorv32__cpu_8h.html#a8346fb926f84f3d7bccbb4741105505f',1,'neorv32_cpu_get_clk_from_prsc(int prsc):&#160;neorv32_cpu.c']]], + ['neorv32_5fcpu_5fget_5fcycle_86',['neorv32_cpu_get_cycle',['../neorv32__cpu_8c.html#ac3fd7dc7cd1e0a08225c41820af27f92',1,'neorv32_cpu_get_cycle(void):&#160;neorv32_cpu.c'],['../neorv32__cpu_8h.html#ac3fd7dc7cd1e0a08225c41820af27f92',1,'neorv32_cpu_get_cycle(void):&#160;neorv32_cpu.c']]], + ['neorv32_5fcpu_5fget_5finstret_87',['neorv32_cpu_get_instret',['../neorv32__cpu_8c.html#a387aa304770b05594c4acca128a60a75',1,'neorv32_cpu_get_instret(void):&#160;neorv32_cpu.c'],['../neorv32__cpu_8h.html#a387aa304770b05594c4acca128a60a75',1,'neorv32_cpu_get_instret(void):&#160;neorv32_cpu.c']]], + ['neorv32_5fcpu_5fgoto_5fuser_5fmode_88',['neorv32_cpu_goto_user_mode',['../neorv32__cpu_8c.html#aca49efb45d3808ad76cf65ba291f546d',1,'neorv32_cpu_goto_user_mode(void):&#160;neorv32_cpu.c'],['../neorv32__cpu_8h.html#aca49efb45d3808ad76cf65ba291f546d',1,'neorv32_cpu_goto_user_mode(void):&#160;neorv32_cpu.c']]], + ['neorv32_5fcpu_5fhpm_5fget_5fnum_5fcounters_89',['neorv32_cpu_hpm_get_num_counters',['../neorv32__cpu_8c.html#a70f49b80322aa457f29f7671f94a183d',1,'neorv32_cpu_hpm_get_num_counters(void):&#160;neorv32_cpu.c'],['../neorv32__cpu_8h.html#a70f49b80322aa457f29f7671f94a183d',1,'neorv32_cpu_hpm_get_num_counters(void):&#160;neorv32_cpu.c']]], + ['neorv32_5fcpu_5fhpm_5fget_5fsize_90',['neorv32_cpu_hpm_get_size',['../neorv32__cpu_8c.html#adb3ae542bbb0ddf9f562a4e42bc24d10',1,'neorv32_cpu_hpm_get_size(void):&#160;neorv32_cpu.c'],['../neorv32__cpu_8h.html#adb3ae542bbb0ddf9f562a4e42bc24d10',1,'neorv32_cpu_hpm_get_size(void):&#160;neorv32_cpu.c']]], + ['neorv32_5fcpu_5fload_5fsigned_5fbyte_91',['neorv32_cpu_load_signed_byte',['../neorv32__cpu_8h.html#a31f903596ab1bcddea79fdf608eaa666',1,'neorv32_cpu.h']]], + ['neorv32_5fcpu_5fload_5fsigned_5fhalf_92',['neorv32_cpu_load_signed_half',['../neorv32__cpu_8h.html#ae9c8b6c681536ddea3aff0e63f30ef70',1,'neorv32_cpu.h']]], + ['neorv32_5fcpu_5fload_5funsigned_5fbyte_93',['neorv32_cpu_load_unsigned_byte',['../neorv32__cpu_8h.html#ac54ec9b59e17c7cd9b9907abee82ce95',1,'neorv32_cpu.h']]], + ['neorv32_5fcpu_5fload_5funsigned_5fhalf_94',['neorv32_cpu_load_unsigned_half',['../neorv32__cpu_8h.html#a32544cd652debb4affb308806a115d5b',1,'neorv32_cpu.h']]], + ['neorv32_5fcpu_5fload_5funsigned_5fword_95',['neorv32_cpu_load_unsigned_word',['../neorv32__cpu_8h.html#a3b6cf445e2136486564ef3d3473c91dd',1,'neorv32_cpu.h']]], + ['neorv32_5fcpu_5fpmp_5fconfigure_5fregion_96',['neorv32_cpu_pmp_configure_region',['../neorv32__cpu_8c.html#aa458a700619b2f7666cfcffe02ec2e2c',1,'neorv32_cpu_pmp_configure_region(int index, uint32_t addr, uint8_t config):&#160;neorv32_cpu.c'],['../neorv32__cpu_8h.html#aa458a700619b2f7666cfcffe02ec2e2c',1,'neorv32_cpu_pmp_configure_region(int index, uint32_t addr, uint8_t config):&#160;neorv32_cpu.c']]], + ['neorv32_5fcpu_5fpmp_5fget_5fgranularity_97',['neorv32_cpu_pmp_get_granularity',['../neorv32__cpu_8c.html#ad4f8160f4821b6691e9682ef60c7cd7b',1,'neorv32_cpu_pmp_get_granularity(void):&#160;neorv32_cpu.c'],['../neorv32__cpu_8h.html#ad4f8160f4821b6691e9682ef60c7cd7b',1,'neorv32_cpu_pmp_get_granularity(void):&#160;neorv32_cpu.c']]], + ['neorv32_5fcpu_5fpmp_5fget_5fnum_5fregions_98',['neorv32_cpu_pmp_get_num_regions',['../neorv32__cpu_8c.html#a27dd614bc270dfa30ed73323ebda2d2d',1,'neorv32_cpu_pmp_get_num_regions(void):&#160;neorv32_cpu.c'],['../neorv32__cpu_8h.html#a27dd614bc270dfa30ed73323ebda2d2d',1,'neorv32_cpu_pmp_get_num_regions(void):&#160;neorv32_cpu.c']]], + ['neorv32_5fcpu_5fset_5fmcycle_99',['neorv32_cpu_set_mcycle',['../neorv32__cpu_8c.html#a232d0290c459dc790d989fcdc4d121bf',1,'neorv32_cpu_set_mcycle(uint64_t value):&#160;neorv32_cpu.c'],['../neorv32__cpu_8h.html#a232d0290c459dc790d989fcdc4d121bf',1,'neorv32_cpu_set_mcycle(uint64_t value):&#160;neorv32_cpu.c']]], + ['neorv32_5fcpu_5fset_5fminstret_100',['neorv32_cpu_set_minstret',['../neorv32__cpu_8c.html#a5c3cf52498abb3cf3c14a724b287ecf0',1,'neorv32_cpu_set_minstret(uint64_t value):&#160;neorv32_cpu.c'],['../neorv32__cpu_8h.html#a5c3cf52498abb3cf3c14a724b287ecf0',1,'neorv32_cpu_set_minstret(uint64_t value):&#160;neorv32_cpu.c']]], + ['neorv32_5fcpu_5fsleep_101',['neorv32_cpu_sleep',['../neorv32__cpu_8h.html#a769ca4556213619f6fea4ff6bfb979dd',1,'neorv32_cpu.h']]], + ['neorv32_5fcpu_5fstore_5funsigned_5fbyte_102',['neorv32_cpu_store_unsigned_byte',['../neorv32__cpu_8h.html#aeec8ad2a82885c40a307346f9003483e',1,'neorv32_cpu.h']]], + ['neorv32_5fcpu_5fstore_5funsigned_5fhalf_103',['neorv32_cpu_store_unsigned_half',['../neorv32__cpu_8h.html#a31f30f6d6542758cd3073a9939b07653',1,'neorv32_cpu.h']]], + ['neorv32_5fcpu_5fstore_5funsigned_5fword_104',['neorv32_cpu_store_unsigned_word',['../neorv32__cpu_8h.html#a173bb06b4ae9c8964469068dafcb7b0e',1,'neorv32_cpu.h']]], + ['neorv32_5fcrc_105',['NEORV32_CRC',['../neorv32__crc_8h.html#a110962d2b370f9d7997e459d9fd34271',1,'neorv32_crc.h']]], + ['neorv32_5fcrc_2ec_106',['neorv32_crc.c',['../neorv32__crc_8c.html',1,'']]], + ['neorv32_5fcrc_2eh_107',['neorv32_crc.h',['../neorv32__crc_8h.html',1,'']]], + ['neorv32_5fcrc_5favailable_108',['neorv32_crc_available',['../neorv32__crc_8c.html#aa46c647317752f8bb6d5836d4876a704',1,'neorv32_crc_available(void):&#160;neorv32_crc.c'],['../neorv32__crc_8h.html#aa46c647317752f8bb6d5836d4876a704',1,'neorv32_crc_available(void):&#160;neorv32_crc.c']]], + ['neorv32_5fcrc_5fbase_109',['NEORV32_CRC_BASE',['../neorv32_8h.html#a0e2377055bdc0f416b5ae4385610600d',1,'neorv32.h']]], + ['neorv32_5fcrc_5fblock_110',['neorv32_crc_block',['../neorv32__crc_8c.html#a9243006e6cc94c03450646d26a7289b2',1,'neorv32_crc_block(uint8_t *byte, int length):&#160;neorv32_crc.c'],['../neorv32__crc_8h.html#a9243006e6cc94c03450646d26a7289b2',1,'neorv32_crc_block(uint8_t *byte, int length):&#160;neorv32_crc.c']]], + ['neorv32_5fcrc_5fget_111',['neorv32_crc_get',['../neorv32__crc_8c.html#a444b88f1536f65acc301fb19eddcf227',1,'neorv32_crc_get(void):&#160;neorv32_crc.c'],['../neorv32__crc_8h.html#a444b88f1536f65acc301fb19eddcf227',1,'neorv32_crc_get(void):&#160;neorv32_crc.c']]], + ['neorv32_5fcrc_5fmode_5fenum_112',['NEORV32_CRC_MODE_enum',['../neorv32__crc_8h.html#a1ae84a58f475bafc2fc3f2c690fd6447',1,'neorv32_crc.h']]], + ['neorv32_5fcrc_5fsetup_113',['neorv32_crc_setup',['../neorv32__crc_8c.html#a4ff5f7b91e9f668535ed33b6382ae623',1,'neorv32_crc_setup(uint32_t mode, uint32_t poly, uint32_t start):&#160;neorv32_crc.c'],['../neorv32__crc_8h.html#a4ff5f7b91e9f668535ed33b6382ae623',1,'neorv32_crc_setup(uint32_t mode, uint32_t poly, uint32_t start):&#160;neorv32_crc.c']]], + ['neorv32_5fcrc_5fsingle_114',['neorv32_crc_single',['../neorv32__crc_8c.html#ad9d50c76a485160667d486bce32cbeb8',1,'neorv32_crc_single(uint8_t byte):&#160;neorv32_crc.c'],['../neorv32__crc_8h.html#ad9d50c76a485160667d486bce32cbeb8',1,'neorv32_crc_single(uint8_t byte):&#160;neorv32_crc.c']]], + ['neorv32_5fcrc_5ft_115',['neorv32_crc_t',['../structneorv32__crc__t.html',1,'']]], + ['neorv32_5fcsr_5fenum_116',['NEORV32_CSR_enum',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49',1,'neorv32_cpu_csr.h']]], + ['neorv32_5fcsr_5ffflags_5fenum_117',['NEORV32_CSR_FFLAGS_enum',['../neorv32__cpu__csr_8h.html#afde0761e3150d82511136f56179c204b',1,'neorv32_cpu_csr.h']]], + ['neorv32_5fcsr_5fmcountinhibit_5fenum_118',['NEORV32_CSR_MCOUNTINHIBIT_enum',['../neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfe',1,'neorv32_cpu_csr.h']]], + ['neorv32_5fcsr_5fmie_5fenum_119',['NEORV32_CSR_MIE_enum',['../neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33',1,'neorv32_cpu_csr.h']]], + ['neorv32_5fcsr_5fmip_5fenum_120',['NEORV32_CSR_MIP_enum',['../neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21b',1,'neorv32_cpu_csr.h']]], + ['neorv32_5fcsr_5fmisa_5fenum_121',['NEORV32_CSR_MISA_enum',['../neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830c',1,'neorv32_cpu_csr.h']]], + ['neorv32_5fcsr_5fmstatus_5fenum_122',['NEORV32_CSR_MSTATUS_enum',['../neorv32__cpu__csr_8h.html#a76b70a2334131e7589d84c1ee96de485',1,'neorv32_cpu_csr.h']]], + ['neorv32_5fcsr_5fxisa_5fenum_123',['NEORV32_CSR_XISA_enum',['../neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387',1,'neorv32_cpu_csr.h']]], + ['neorv32_5fdm_5fbase_124',['NEORV32_DM_BASE',['../neorv32_8h.html#a9bf0149681677f7d87abf8f62e2d9a3d',1,'neorv32.h']]], + ['neorv32_5fdma_125',['NEORV32_DMA',['../neorv32__dma_8h.html#a0dcb61a0e0d2b45beb7818015adc8639',1,'neorv32_dma.h']]], + ['neorv32_5fdma_2eh_126',['neorv32_dma.h',['../neorv32__dma_8h.html',1,'']]], + ['neorv32_5fdma_5favailable_127',['neorv32_dma_available',['../neorv32__dma_8h.html#a13260c3252f0375d8982590d270d7dfd',1,'neorv32_dma.c']]], + ['neorv32_5fdma_5fbase_128',['NEORV32_DMA_BASE',['../neorv32_8h.html#aa8d3a83ffad1e71f0832a5da78d62008',1,'neorv32.h']]], + ['neorv32_5fdma_5fctrl_5fenum_129',['NEORV32_DMA_CTRL_enum',['../neorv32__dma_8h.html#a6716eddb145b80ad38799da3b87cb2a4',1,'neorv32_dma.h']]], + ['neorv32_5fdma_5fdisable_130',['neorv32_dma_disable',['../neorv32__dma_8h.html#a6df244028455cf7f8d4cf1520c4670a7',1,'neorv32_dma.c']]], + ['neorv32_5fdma_5fdone_131',['neorv32_dma_done',['../neorv32__dma_8h.html#afc8cc32f7d80d0f5ab33b2f1ecf77956',1,'neorv32_dma.c']]], + ['neorv32_5fdma_5fenable_132',['neorv32_dma_enable',['../neorv32__dma_8h.html#ac3b72447e8a132faf26577ac714b8284',1,'neorv32_dma.c']]], + ['neorv32_5fdma_5ffence_5fdisable_133',['neorv32_dma_fence_disable',['../neorv32__dma_8h.html#a8f37adfa07050b0a1cb8430c9ce1fcc2',1,'neorv32_dma.c']]], + ['neorv32_5fdma_5ffence_5fenable_134',['neorv32_dma_fence_enable',['../neorv32__dma_8h.html#a2c7257567ccdb7a986f5ef7c74d3917c',1,'neorv32_dma.c']]], + ['neorv32_5fdma_5fstatus_135',['neorv32_dma_status',['../neorv32__dma_8h.html#aa116f9714174abbe8a3583e441fee24b',1,'neorv32_dma.c']]], + ['neorv32_5fdma_5fstatus_5fenum_136',['NEORV32_DMA_STATUS_enum',['../neorv32__dma_8h.html#a002cb188ea5156df0ba282e239a6e74b',1,'neorv32_dma.h']]], + ['neorv32_5fdma_5ft_137',['neorv32_dma_t',['../structneorv32__dma__t.html',1,'']]], + ['neorv32_5fdma_5ftransfer_138',['neorv32_dma_transfer',['../neorv32__dma_8h.html#a2ce0d31e04604b2523135d52a877febf',1,'neorv32_dma.c']]], + ['neorv32_5fdma_5ftransfer_5fauto_139',['neorv32_dma_transfer_auto',['../neorv32__dma_8h.html#a6ebd1595ee6fa0e6cbfbd1ce7476f18e',1,'neorv32_dma.c']]], + ['neorv32_5fdma_5fttype_5fenum_140',['NEORV32_DMA_TTYPE_enum',['../neorv32__dma_8h.html#a33187c5a074d62b46d2262e352edb8d9',1,'neorv32_dma.h']]], + ['neorv32_5fexception_5fcodes_5fenum_141',['NEORV32_EXCEPTION_CODES_enum',['../neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1',1,'neorv32_cpu_csr.h']]], + ['neorv32_5fexecutable_5fenum_142',['NEORV32_EXECUTABLE_enum',['../bootloader_8c.html#a165a347c51d8aae06a564a2f297f2feb',1,'bootloader.c']]], + ['neorv32_5fgpio_143',['NEORV32_GPIO',['../neorv32__gpio_8h.html#a1e35bbf26b9d1aa5373af0b9468eb445',1,'neorv32_gpio.h']]], + ['neorv32_5fgpio_2ec_144',['neorv32_gpio.c',['../neorv32__gpio_8c.html',1,'']]], + ['neorv32_5fgpio_2eh_145',['neorv32_gpio.h',['../neorv32__gpio_8h.html',1,'']]], + ['neorv32_5fgpio_5favailable_146',['neorv32_gpio_available',['../neorv32__gpio_8c.html#a41d39a41ba5879eb85d3ed4481fcff81',1,'neorv32_gpio_available(void):&#160;neorv32_gpio.c'],['../neorv32__gpio_8h.html#a41d39a41ba5879eb85d3ed4481fcff81',1,'neorv32_gpio_available(void):&#160;neorv32_gpio.c']]], + ['neorv32_5fgpio_5fbase_147',['NEORV32_GPIO_BASE',['../neorv32_8h.html#a7fd1e24d4de2eed7bf9cd5391562c7f4',1,'neorv32.h']]], + ['neorv32_5fgpio_5fpin_5fget_148',['neorv32_gpio_pin_get',['../neorv32__gpio_8c.html#afa3ee54aca47ff35f706b627ac66e95a',1,'neorv32_gpio_pin_get(int pin):&#160;neorv32_gpio.c'],['../neorv32__gpio_8h.html#afa3ee54aca47ff35f706b627ac66e95a',1,'neorv32_gpio_pin_get(int pin):&#160;neorv32_gpio.c']]], + ['neorv32_5fgpio_5fpin_5fset_149',['neorv32_gpio_pin_set',['../neorv32__gpio_8c.html#a60fd0830d634f0c1f784d815384665cb',1,'neorv32_gpio_pin_set(int pin, int value):&#160;neorv32_gpio.c'],['../neorv32__gpio_8h.html#a60fd0830d634f0c1f784d815384665cb',1,'neorv32_gpio_pin_set(int pin, int value):&#160;neorv32_gpio.c']]], + ['neorv32_5fgpio_5fpin_5ftoggle_150',['neorv32_gpio_pin_toggle',['../neorv32__gpio_8c.html#a1958850fc1689eae9ddfcaa4a7513400',1,'neorv32_gpio_pin_toggle(int pin):&#160;neorv32_gpio.c'],['../neorv32__gpio_8h.html#a1958850fc1689eae9ddfcaa4a7513400',1,'neorv32_gpio_pin_toggle(int pin):&#160;neorv32_gpio.c']]], + ['neorv32_5fgpio_5fport_5fget_151',['neorv32_gpio_port_get',['../neorv32__gpio_8c.html#ac42379f2fb5ca0bb63850d7957852b84',1,'neorv32_gpio_port_get(void):&#160;neorv32_gpio.c'],['../neorv32__gpio_8h.html#ac42379f2fb5ca0bb63850d7957852b84',1,'neorv32_gpio_port_get(void):&#160;neorv32_gpio.c']]], + ['neorv32_5fgpio_5fport_5fset_152',['neorv32_gpio_port_set',['../neorv32__gpio_8c.html#a8dc7846945e4609fc96d81caee99ac00',1,'neorv32_gpio_port_set(uint64_t port_data):&#160;neorv32_gpio.c'],['../neorv32__gpio_8h.html#a789222709485cd8467aad5eddf69d2df',1,'neorv32_gpio_port_set(uint64_t d):&#160;neorv32_gpio.c']]], + ['neorv32_5fgpio_5fport_5ftoggle_153',['neorv32_gpio_port_toggle',['../neorv32__gpio_8c.html#a210529f789779387d3f014e6253e803f',1,'neorv32_gpio_port_toggle(uint64_t toggle):&#160;neorv32_gpio.c'],['../neorv32__gpio_8h.html#a210529f789779387d3f014e6253e803f',1,'neorv32_gpio_port_toggle(uint64_t toggle):&#160;neorv32_gpio.c']]], + ['neorv32_5fgpio_5ft_154',['neorv32_gpio_t',['../structneorv32__gpio__t.html',1,'']]], + ['neorv32_5fgptmr_155',['NEORV32_GPTMR',['../neorv32__gptmr_8h.html#a9e047791588ff21fc4dc1b06456bdfd2',1,'neorv32_gptmr.h']]], + ['neorv32_5fgptmr_2ec_156',['neorv32_gptmr.c',['../neorv32__gptmr_8c.html',1,'']]], + ['neorv32_5fgptmr_2eh_157',['neorv32_gptmr.h',['../neorv32__gptmr_8h.html',1,'']]], + ['neorv32_5fgptmr_5favailable_158',['neorv32_gptmr_available',['../neorv32__gptmr_8c.html#ae79a08c52ad3e83f9c4393acfabf035f',1,'neorv32_gptmr_available(void):&#160;neorv32_gptmr.c'],['../neorv32__gptmr_8h.html#ae79a08c52ad3e83f9c4393acfabf035f',1,'neorv32_gptmr_available(void):&#160;neorv32_gptmr.c']]], + ['neorv32_5fgptmr_5fbase_159',['NEORV32_GPTMR_BASE',['../neorv32_8h.html#a0991b1a5ba1e8c3550eb9770d43589d0',1,'neorv32.h']]], + ['neorv32_5fgptmr_5fctrl_5fenum_160',['NEORV32_GPTMR_CTRL_enum',['../neorv32__gptmr_8h.html#a135b0750d4afed16e5867134e3843988',1,'neorv32_gptmr.h']]], + ['neorv32_5fgptmr_5fdisable_161',['neorv32_gptmr_disable',['../neorv32__gptmr_8c.html#a7c9bc6d28ad12611b08fa2867c2db874',1,'neorv32_gptmr_disable(void):&#160;neorv32_gptmr.c'],['../neorv32__gptmr_8h.html#a7c9bc6d28ad12611b08fa2867c2db874',1,'neorv32_gptmr_disable(void):&#160;neorv32_gptmr.c']]], + ['neorv32_5fgptmr_5fenable_162',['neorv32_gptmr_enable',['../neorv32__gptmr_8c.html#a59e684348835772a7e83446e478d4a13',1,'neorv32_gptmr_enable(void):&#160;neorv32_gptmr.c'],['../neorv32__gptmr_8h.html#a59e684348835772a7e83446e478d4a13',1,'neorv32_gptmr_enable(void):&#160;neorv32_gptmr.c']]], + ['neorv32_5fgptmr_5firq_5fack_163',['neorv32_gptmr_irq_ack',['../neorv32__gptmr_8c.html#ac73aa4e41a064abb4ca554a389888e67',1,'neorv32_gptmr_irq_ack(void):&#160;neorv32_gptmr.c'],['../neorv32__gptmr_8h.html#ac73aa4e41a064abb4ca554a389888e67',1,'neorv32_gptmr_irq_ack(void):&#160;neorv32_gptmr.c']]], + ['neorv32_5fgptmr_5fsetup_164',['neorv32_gptmr_setup',['../neorv32__gptmr_8c.html#a6aa27efd2163eebf8fc49fe1c591708f',1,'neorv32_gptmr_setup(int prsc, uint32_t threshold, int cont_mode):&#160;neorv32_gptmr.c'],['../neorv32__gptmr_8h.html#a6aa27efd2163eebf8fc49fe1c591708f',1,'neorv32_gptmr_setup(int prsc, uint32_t threshold, int cont_mode):&#160;neorv32_gptmr.c']]], + ['neorv32_5fgptmr_5ft_165',['neorv32_gptmr_t',['../structneorv32__gptmr__t.html',1,'']]], + ['neorv32_5fhpmcnt_5fevent_5fenum_166',['NEORV32_HPMCNT_EVENT_enum',['../neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfe',1,'neorv32_cpu_csr.h']]], + ['neorv32_5fintrinsics_2eh_167',['neorv32_intrinsics.h',['../neorv32__intrinsics_8h.html',1,'']]], + ['neorv32_5flegacy_2eh_168',['neorv32_legacy.h',['../neorv32__legacy_8h.html',1,'']]], + ['neorv32_5fmtime_169',['NEORV32_MTIME',['../neorv32__mtime_8h.html#a68935be182e0081039326a9f344a36b3',1,'neorv32_mtime.h']]], + ['neorv32_5fmtime_2ec_170',['neorv32_mtime.c',['../neorv32__mtime_8c.html',1,'']]], + ['neorv32_5fmtime_2eh_171',['neorv32_mtime.h',['../neorv32__mtime_8h.html',1,'']]], + ['neorv32_5fmtime_5favailable_172',['neorv32_mtime_available',['../neorv32__mtime_8c.html#ab2b49a0594c66692aedf76ff9935581c',1,'neorv32_mtime_available(void):&#160;neorv32_mtime.c'],['../neorv32__mtime_8h.html#ab2b49a0594c66692aedf76ff9935581c',1,'neorv32_mtime_available(void):&#160;neorv32_mtime.c']]], + ['neorv32_5fmtime_5fbase_173',['NEORV32_MTIME_BASE',['../neorv32_8h.html#ab98f762df259a2bbc28d19d2acfe9e23',1,'neorv32.h']]], + ['neorv32_5fmtime_5fget_5ftime_174',['neorv32_mtime_get_time',['../neorv32__mtime_8c.html#adedbbdeb71c06d2d60d3af73451de01e',1,'neorv32_mtime_get_time(void):&#160;neorv32_mtime.c'],['../neorv32__mtime_8h.html#adedbbdeb71c06d2d60d3af73451de01e',1,'neorv32_mtime_get_time(void):&#160;neorv32_mtime.c']]], + ['neorv32_5fmtime_5fget_5ftimecmp_175',['neorv32_mtime_get_timecmp',['../neorv32__mtime_8c.html#acb3cc18ff8421ebd6ef471e089c23491',1,'neorv32_mtime_get_timecmp(void):&#160;neorv32_mtime.c'],['../neorv32__mtime_8h.html#acb3cc18ff8421ebd6ef471e089c23491',1,'neorv32_mtime_get_timecmp(void):&#160;neorv32_mtime.c']]], + ['neorv32_5fmtime_5fget_5funixtime_176',['neorv32_mtime_get_unixtime',['../neorv32__mtime_8c.html#a50d08fcc3d91fc2d88b9a6a80c656f1a',1,'neorv32_mtime_get_unixtime(void):&#160;neorv32_mtime.c'],['../neorv32__mtime_8h.html#a50d08fcc3d91fc2d88b9a6a80c656f1a',1,'neorv32_mtime_get_unixtime(void):&#160;neorv32_mtime.c']]], + ['neorv32_5fmtime_5fset_5ftime_177',['neorv32_mtime_set_time',['../neorv32__mtime_8c.html#a1c30809d6e887f022a7794f720243015',1,'neorv32_mtime_set_time(uint64_t time):&#160;neorv32_mtime.c'],['../neorv32__mtime_8h.html#a1c30809d6e887f022a7794f720243015',1,'neorv32_mtime_set_time(uint64_t time):&#160;neorv32_mtime.c']]], + ['neorv32_5fmtime_5fset_5ftimecmp_178',['neorv32_mtime_set_timecmp',['../neorv32__mtime_8c.html#a81ff371c1aa10901264873316ee84a49',1,'neorv32_mtime_set_timecmp(uint64_t timecmp):&#160;neorv32_mtime.c'],['../neorv32__mtime_8h.html#a81ff371c1aa10901264873316ee84a49',1,'neorv32_mtime_set_timecmp(uint64_t timecmp):&#160;neorv32_mtime.c']]], + ['neorv32_5fmtime_5fset_5funixtime_179',['neorv32_mtime_set_unixtime',['../neorv32__mtime_8c.html#a022c3292c6e75095bb3ffd4c42fd4bfa',1,'neorv32_mtime_set_unixtime(uint64_t unixtime):&#160;neorv32_mtime.c'],['../neorv32__mtime_8h.html#a022c3292c6e75095bb3ffd4c42fd4bfa',1,'neorv32_mtime_set_unixtime(uint64_t unixtime):&#160;neorv32_mtime.c']]], + ['neorv32_5fmtime_5ft_180',['neorv32_mtime_t',['../structneorv32__mtime__t.html',1,'']]], + ['neorv32_5fneoled_181',['NEORV32_NEOLED',['../neorv32__neoled_8h.html#a3ccc1097bc70f92235d693b612fa994a',1,'neorv32_neoled.h']]], + ['neorv32_5fneoled_2ec_182',['neorv32_neoled.c',['../neorv32__neoled_8c.html',1,'']]], + ['neorv32_5fneoled_2eh_183',['neorv32_neoled.h',['../neorv32__neoled_8h.html',1,'']]], + ['neorv32_5fneoled_5favailable_184',['neorv32_neoled_available',['../neorv32__neoled_8c.html#a57398d92fb4fc735b33e89271726e1d6',1,'neorv32_neoled_available(void):&#160;neorv32_neoled.c'],['../neorv32__neoled_8h.html#a57398d92fb4fc735b33e89271726e1d6',1,'neorv32_neoled_available(void):&#160;neorv32_neoled.c']]], + ['neorv32_5fneoled_5fbase_185',['NEORV32_NEOLED_BASE',['../neorv32_8h.html#a559fdce92e8af5efc426c8fc48d14f99',1,'neorv32.h']]], + ['neorv32_5fneoled_5fctrl_5fenum_186',['NEORV32_NEOLED_CTRL_enum',['../neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412',1,'neorv32_neoled.h']]], + ['neorv32_5fneoled_5fdisable_187',['neorv32_neoled_disable',['../neorv32__neoled_8c.html#a8daaa97a85e0eb94d4a38eb2119ea183',1,'neorv32_neoled_disable(void):&#160;neorv32_neoled.c'],['../neorv32__neoled_8h.html#a8daaa97a85e0eb94d4a38eb2119ea183',1,'neorv32_neoled_disable(void):&#160;neorv32_neoled.c']]], + ['neorv32_5fneoled_5fenable_188',['neorv32_neoled_enable',['../neorv32__neoled_8c.html#a8181d5c1d15b7b5eecdc018341ac14fa',1,'neorv32_neoled_enable(void):&#160;neorv32_neoled.c'],['../neorv32__neoled_8h.html#a8181d5c1d15b7b5eecdc018341ac14fa',1,'neorv32_neoled_enable(void):&#160;neorv32_neoled.c']]], + ['neorv32_5fneoled_5fget_5fbuffer_5fsize_189',['neorv32_neoled_get_buffer_size',['../neorv32__neoled_8c.html#a81c2c49198531fb6551eb288e29c084e',1,'neorv32_neoled_get_buffer_size(void):&#160;neorv32_neoled.c'],['../neorv32__neoled_8h.html#a81c2c49198531fb6551eb288e29c084e',1,'neorv32_neoled_get_buffer_size(void):&#160;neorv32_neoled.c']]], + ['neorv32_5fneoled_5fset_5fmode_190',['neorv32_neoled_set_mode',['../neorv32__neoled_8c.html#a484fcc6797b6d9cef86192e9593ec33d',1,'neorv32_neoled_set_mode(uint32_t mode):&#160;neorv32_neoled.c'],['../neorv32__neoled_8h.html#a484fcc6797b6d9cef86192e9593ec33d',1,'neorv32_neoled_set_mode(uint32_t mode):&#160;neorv32_neoled.c']]], + ['neorv32_5fneoled_5fsetup_191',['neorv32_neoled_setup',['../neorv32__neoled_8c.html#ac6e94602453779a2791bd0734465f5a3',1,'neorv32_neoled_setup(uint32_t prsc, uint32_t t_total, uint32_t t_high_zero, uint32_t t_high_one, int irq_mode):&#160;neorv32_neoled.c'],['../neorv32__neoled_8h.html#ac6e94602453779a2791bd0734465f5a3',1,'neorv32_neoled_setup(uint32_t prsc, uint32_t t_total, uint32_t t_high_zero, uint32_t t_high_one, int irq_mode):&#160;neorv32_neoled.c']]], + ['neorv32_5fneoled_5fsetup_5fws2812_192',['neorv32_neoled_setup_ws2812',['../neorv32__neoled_8c.html#adade69c7368c28180b9992d5f0ab6031',1,'neorv32_neoled_setup_ws2812(int irq_mode):&#160;neorv32_neoled.c'],['../neorv32__neoled_8h.html#adade69c7368c28180b9992d5f0ab6031',1,'neorv32_neoled_setup_ws2812(int irq_mode):&#160;neorv32_neoled.c']]], + ['neorv32_5fneoled_5fstrobe_5fblocking_193',['neorv32_neoled_strobe_blocking',['../neorv32__neoled_8c.html#a5aa9eb4dd3655fa08e1b61eb0f36589c',1,'neorv32_neoled_strobe_blocking(void):&#160;neorv32_neoled.c'],['../neorv32__neoled_8h.html#a5aa9eb4dd3655fa08e1b61eb0f36589c',1,'neorv32_neoled_strobe_blocking(void):&#160;neorv32_neoled.c']]], + ['neorv32_5fneoled_5fstrobe_5fnonblocking_194',['neorv32_neoled_strobe_nonblocking',['../neorv32__neoled_8c.html#abf7882b949373df0774fc9cc20c2bd2e',1,'neorv32_neoled_strobe_nonblocking(void):&#160;neorv32_neoled.c'],['../neorv32__neoled_8h.html#abf7882b949373df0774fc9cc20c2bd2e',1,'neorv32_neoled_strobe_nonblocking(void):&#160;neorv32_neoled.c']]], + ['neorv32_5fneoled_5ft_195',['neorv32_neoled_t',['../structneorv32__neoled__t.html',1,'']]], + ['neorv32_5fneoled_5fwrite_5fblocking_196',['neorv32_neoled_write_blocking',['../neorv32__neoled_8c.html#a3ee5b3602da3ae982628e2802587e451',1,'neorv32_neoled_write_blocking(uint32_t data):&#160;neorv32_neoled.c'],['../neorv32__neoled_8h.html#a3ee5b3602da3ae982628e2802587e451',1,'neorv32_neoled_write_blocking(uint32_t data):&#160;neorv32_neoled.c']]], + ['neorv32_5fneoled_5fwrite_5fnonblocking_197',['neorv32_neoled_write_nonblocking',['../neorv32__neoled_8h.html#ad2a318bd59be12de34797ced0f7743c6',1,'neorv32_neoled.h']]], + ['neorv32_5fonewire_198',['NEORV32_ONEWIRE',['../neorv32__onewire_8h.html#a6f119e35d7ac01f110987508ff3becc9',1,'neorv32_onewire.h']]], + ['neorv32_5fonewire_2ec_199',['neorv32_onewire.c',['../neorv32__onewire_8c.html',1,'']]], + ['neorv32_5fonewire_2eh_200',['neorv32_onewire.h',['../neorv32__onewire_8h.html',1,'']]], + ['neorv32_5fonewire_5favailable_201',['neorv32_onewire_available',['../neorv32__onewire_8c.html#a865e5c381fd3c27c6981a589a5124d1e',1,'neorv32_onewire_available(void):&#160;neorv32_onewire.c'],['../neorv32__onewire_8h.html#a865e5c381fd3c27c6981a589a5124d1e',1,'neorv32_onewire_available(void):&#160;neorv32_onewire.c']]], + ['neorv32_5fonewire_5fbase_202',['NEORV32_ONEWIRE_BASE',['../neorv32_8h.html#a8d0b612e52b77395a05d4f18af6fcf00',1,'neorv32.h']]], + ['neorv32_5fonewire_5fbusy_203',['neorv32_onewire_busy',['../neorv32__onewire_8c.html#a01b6236b89c045ddbd58398361c6ee0a',1,'neorv32_onewire_busy(void):&#160;neorv32_onewire.c'],['../neorv32__onewire_8h.html#a01b6236b89c045ddbd58398361c6ee0a',1,'neorv32_onewire_busy(void):&#160;neorv32_onewire.c']]], + ['neorv32_5fonewire_5fctrl_5fenum_204',['NEORV32_ONEWIRE_CTRL_enum',['../neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831',1,'neorv32_onewire.h']]], + ['neorv32_5fonewire_5fdata_5fenum_205',['NEORV32_ONEWIRE_DATA_enum',['../neorv32__onewire_8h.html#ae770490afa8662fb8577065531d51368',1,'neorv32_onewire.h']]], + ['neorv32_5fonewire_5fdisable_206',['neorv32_onewire_disable',['../neorv32__onewire_8c.html#a7e329eeb1cd98301a53b271a6a102385',1,'neorv32_onewire_disable(void):&#160;neorv32_onewire.c'],['../neorv32__onewire_8h.html#a7e329eeb1cd98301a53b271a6a102385',1,'neorv32_onewire_disable(void):&#160;neorv32_onewire.c']]], + ['neorv32_5fonewire_5fenable_207',['neorv32_onewire_enable',['../neorv32__onewire_8c.html#ae6fe766e7decf18869cfb86bba741ca4',1,'neorv32_onewire_enable(void):&#160;neorv32_onewire.c'],['../neorv32__onewire_8h.html#ae6fe766e7decf18869cfb86bba741ca4',1,'neorv32_onewire_enable(void):&#160;neorv32_onewire.c']]], + ['neorv32_5fonewire_5fread_5fbit_208',['neorv32_onewire_read_bit',['../neorv32__onewire_8c.html#aace8398062b759256a516e6245aced83',1,'neorv32_onewire_read_bit(void):&#160;neorv32_onewire.c'],['../neorv32__onewire_8h.html#aace8398062b759256a516e6245aced83',1,'neorv32_onewire_read_bit(void):&#160;neorv32_onewire.c']]], + ['neorv32_5fonewire_5fread_5fbit_5fblocking_209',['neorv32_onewire_read_bit_blocking',['../neorv32__onewire_8c.html#ace8b7cf697b068b6b51676d84dec5960',1,'neorv32_onewire_read_bit_blocking(void):&#160;neorv32_onewire.c'],['../neorv32__onewire_8h.html#ace8b7cf697b068b6b51676d84dec5960',1,'neorv32_onewire_read_bit_blocking(void):&#160;neorv32_onewire.c']]], + ['neorv32_5fonewire_5fread_5fbit_5fget_210',['neorv32_onewire_read_bit_get',['../neorv32__onewire_8c.html#aa4a19d2d8dc3b3401307615aec201190',1,'neorv32_onewire_read_bit_get(void):&#160;neorv32_onewire.c'],['../neorv32__onewire_8h.html#aa4a19d2d8dc3b3401307615aec201190',1,'neorv32_onewire_read_bit_get(void):&#160;neorv32_onewire.c']]], + ['neorv32_5fonewire_5fread_5fbyte_211',['neorv32_onewire_read_byte',['../neorv32__onewire_8c.html#a01ddba7a9148be542b5c52e39e6f46d6',1,'neorv32_onewire_read_byte(void):&#160;neorv32_onewire.c'],['../neorv32__onewire_8h.html#a01ddba7a9148be542b5c52e39e6f46d6',1,'neorv32_onewire_read_byte(void):&#160;neorv32_onewire.c']]], + ['neorv32_5fonewire_5fread_5fbyte_5fblocking_212',['neorv32_onewire_read_byte_blocking',['../neorv32__onewire_8c.html#a7510e65a26aeefb40e994fd00667537e',1,'neorv32_onewire_read_byte_blocking(void):&#160;neorv32_onewire.c'],['../neorv32__onewire_8h.html#a7510e65a26aeefb40e994fd00667537e',1,'neorv32_onewire_read_byte_blocking(void):&#160;neorv32_onewire.c']]], + ['neorv32_5fonewire_5fread_5fbyte_5fget_213',['neorv32_onewire_read_byte_get',['../neorv32__onewire_8c.html#a4c7eec15c095c97c939163f631f51dab',1,'neorv32_onewire_read_byte_get(void):&#160;neorv32_onewire.c'],['../neorv32__onewire_8h.html#a4c7eec15c095c97c939163f631f51dab',1,'neorv32_onewire_read_byte_get(void):&#160;neorv32_onewire.c']]], + ['neorv32_5fonewire_5freset_214',['neorv32_onewire_reset',['../neorv32__onewire_8c.html#a3072f7167831edc95dee44ecfef6a0d4',1,'neorv32_onewire_reset(void):&#160;neorv32_onewire.c'],['../neorv32__onewire_8h.html#a3072f7167831edc95dee44ecfef6a0d4',1,'neorv32_onewire_reset(void):&#160;neorv32_onewire.c']]], + ['neorv32_5fonewire_5freset_5fblocking_215',['neorv32_onewire_reset_blocking',['../neorv32__onewire_8c.html#af8ca6be495176797b7da3857e2f794f9',1,'neorv32_onewire_reset_blocking(void):&#160;neorv32_onewire.c'],['../neorv32__onewire_8h.html#af8ca6be495176797b7da3857e2f794f9',1,'neorv32_onewire_reset_blocking(void):&#160;neorv32_onewire.c']]], + ['neorv32_5fonewire_5freset_5fget_5fpresence_216',['neorv32_onewire_reset_get_presence',['../neorv32__onewire_8c.html#a43eb8a08eeaa83e3d7e9aa5058a4269f',1,'neorv32_onewire_reset_get_presence(void):&#160;neorv32_onewire.c'],['../neorv32__onewire_8h.html#a43eb8a08eeaa83e3d7e9aa5058a4269f',1,'neorv32_onewire_reset_get_presence(void):&#160;neorv32_onewire.c']]], + ['neorv32_5fonewire_5fsense_217',['neorv32_onewire_sense',['../neorv32__onewire_8c.html#a122531c7154126858c46d89e003d838d',1,'neorv32_onewire_sense(void):&#160;neorv32_onewire.c'],['../neorv32__onewire_8h.html#a122531c7154126858c46d89e003d838d',1,'neorv32_onewire_sense(void):&#160;neorv32_onewire.c']]], + ['neorv32_5fonewire_5fsetup_218',['neorv32_onewire_setup',['../neorv32__onewire_8c.html#a224005037387484dfa510a1355a62828',1,'neorv32_onewire_setup(uint32_t t_base):&#160;neorv32_onewire.c'],['../neorv32__onewire_8h.html#a224005037387484dfa510a1355a62828',1,'neorv32_onewire_setup(uint32_t t_base):&#160;neorv32_onewire.c']]], + ['neorv32_5fonewire_5ft_219',['neorv32_onewire_t',['../structneorv32__onewire__t.html',1,'']]], + ['neorv32_5fonewire_5fwrite_5fbit_220',['neorv32_onewire_write_bit',['../neorv32__onewire_8c.html#a49d0a2a386f129fd2f4fed880bba31d4',1,'neorv32_onewire_write_bit(uint8_t bit):&#160;neorv32_onewire.c'],['../neorv32__onewire_8h.html#a49d0a2a386f129fd2f4fed880bba31d4',1,'neorv32_onewire_write_bit(uint8_t bit):&#160;neorv32_onewire.c']]], + ['neorv32_5fonewire_5fwrite_5fbit_5fblocking_221',['neorv32_onewire_write_bit_blocking',['../neorv32__onewire_8c.html#a6f7b6690a2437e0b574a8a9a23dc0eaa',1,'neorv32_onewire_write_bit_blocking(uint8_t bit):&#160;neorv32_onewire.c'],['../neorv32__onewire_8h.html#a6f7b6690a2437e0b574a8a9a23dc0eaa',1,'neorv32_onewire_write_bit_blocking(uint8_t bit):&#160;neorv32_onewire.c']]], + ['neorv32_5fonewire_5fwrite_5fbyte_222',['neorv32_onewire_write_byte',['../neorv32__onewire_8c.html#a23b96b68c3214b188525eb102cafb620',1,'neorv32_onewire_write_byte(uint8_t byte):&#160;neorv32_onewire.c'],['../neorv32__onewire_8h.html#a23b96b68c3214b188525eb102cafb620',1,'neorv32_onewire_write_byte(uint8_t byte):&#160;neorv32_onewire.c']]], + ['neorv32_5fonewire_5fwrite_5fbyte_5fblocking_223',['neorv32_onewire_write_byte_blocking',['../neorv32__onewire_8c.html#ac78557c77482b59394677f42fda4fdf1',1,'neorv32_onewire_write_byte_blocking(uint8_t byte):&#160;neorv32_onewire.c'],['../neorv32__onewire_8h.html#ac78557c77482b59394677f42fda4fdf1',1,'neorv32_onewire_write_byte_blocking(uint8_t byte):&#160;neorv32_onewire.c']]], + ['neorv32_5fpmp_5fmodes_5fenum_224',['NEORV32_PMP_MODES_enum',['../neorv32__cpu__csr_8h.html#a8f2418fb5e2175f35ee2362469ce01f5',1,'neorv32_cpu_csr.h']]], + ['neorv32_5fpmpcfg_5fattributes_5fenum_225',['NEORV32_PMPCFG_ATTRIBUTES_enum',['../neorv32__cpu__csr_8h.html#abc0e8daad1e9beda4d9950452cc930ea',1,'neorv32_cpu_csr.h']]], + ['neorv32_5fpmw_5fget_5fnum_5fchannels_226',['neorv32_pmw_get_num_channels',['../neorv32__pwm_8c.html#a43d8a47dc79ebac24c8a7d2d8247d2a5',1,'neorv32_pmw_get_num_channels(void):&#160;neorv32_pwm.c'],['../neorv32__pwm_8h.html#a43d8a47dc79ebac24c8a7d2d8247d2a5',1,'neorv32_pmw_get_num_channels(void):&#160;neorv32_pwm.c']]], + ['neorv32_5fpwm_227',['NEORV32_PWM',['../neorv32__pwm_8h.html#ad4cb534c29e26fa56c10bef7afab8f51',1,'neorv32_pwm.h']]], + ['neorv32_5fpwm_2ec_228',['neorv32_pwm.c',['../neorv32__pwm_8c.html',1,'']]], + ['neorv32_5fpwm_2eh_229',['neorv32_pwm.h',['../neorv32__pwm_8h.html',1,'']]], + ['neorv32_5fpwm_5favailable_230',['neorv32_pwm_available',['../neorv32__pwm_8c.html#afb12c860b2f7fa6cd1e069ea540da41c',1,'neorv32_pwm_available(void):&#160;neorv32_pwm.c'],['../neorv32__pwm_8h.html#afb12c860b2f7fa6cd1e069ea540da41c',1,'neorv32_pwm_available(void):&#160;neorv32_pwm.c']]], + ['neorv32_5fpwm_5fbase_231',['NEORV32_PWM_BASE',['../neorv32_8h.html#afef7a6b121a788560b29e2ee2a58c725',1,'neorv32.h']]], + ['neorv32_5fpwm_5fctrl_5fenum_232',['NEORV32_PWM_CTRL_enum',['../neorv32__pwm_8h.html#af350f93b601a92ef56516198d1570b7d',1,'neorv32_pwm.h']]], + ['neorv32_5fpwm_5fdisable_233',['neorv32_pwm_disable',['../neorv32__pwm_8c.html#a8f16fdc6e048899305a3234f42fe272f',1,'neorv32_pwm_disable(void):&#160;neorv32_pwm.c'],['../neorv32__pwm_8h.html#a8f16fdc6e048899305a3234f42fe272f',1,'neorv32_pwm_disable(void):&#160;neorv32_pwm.c']]], + ['neorv32_5fpwm_5fenable_234',['neorv32_pwm_enable',['../neorv32__pwm_8c.html#abc62a63dc139b185cdf53d0267501288',1,'neorv32_pwm_enable(void):&#160;neorv32_pwm.c'],['../neorv32__pwm_8h.html#abc62a63dc139b185cdf53d0267501288',1,'neorv32_pwm_enable(void):&#160;neorv32_pwm.c']]], + ['neorv32_5fpwm_5fget_235',['neorv32_pwm_get',['../neorv32__pwm_8c.html#a64f66ae4f9689a650a70f3c5b45802b6',1,'neorv32_pwm_get(int channel):&#160;neorv32_pwm.c'],['../neorv32__pwm_8h.html#a64f66ae4f9689a650a70f3c5b45802b6',1,'neorv32_pwm_get(int channel):&#160;neorv32_pwm.c']]], + ['neorv32_5fpwm_5fset_236',['neorv32_pwm_set',['../neorv32__pwm_8c.html#aa24bc867effa7756bfbe7818d85aface',1,'neorv32_pwm_set(int channel, uint8_t dc):&#160;neorv32_pwm.c'],['../neorv32__pwm_8h.html#aa24bc867effa7756bfbe7818d85aface',1,'neorv32_pwm_set(int channel, uint8_t dc):&#160;neorv32_pwm.c']]], + ['neorv32_5fpwm_5fsetup_237',['neorv32_pwm_setup',['../neorv32__pwm_8c.html#a5502d483de07d2d8c42e2388ed987069',1,'neorv32_pwm_setup(int prsc):&#160;neorv32_pwm.c'],['../neorv32__pwm_8h.html#a5502d483de07d2d8c42e2388ed987069',1,'neorv32_pwm_setup(int prsc):&#160;neorv32_pwm.c']]], + ['neorv32_5fpwm_5ft_238',['neorv32_pwm_t',['../structneorv32__pwm__t.html',1,'']]], + ['neorv32_5frte_2ec_239',['neorv32_rte.c',['../neorv32__rte_8c.html',1,'']]], + ['neorv32_5frte_2eh_240',['neorv32_rte.h',['../neorv32__rte_8h.html',1,'']]], + ['neorv32_5frte_5fcontext_5fget_241',['neorv32_rte_context_get',['../neorv32__rte_8c.html#a65e71acc8916b42b59dc2cf6bba30ba3',1,'neorv32_rte_context_get(int x):&#160;neorv32_rte.c'],['../neorv32__rte_8h.html#a65e71acc8916b42b59dc2cf6bba30ba3',1,'neorv32_rte_context_get(int x):&#160;neorv32_rte.c']]], + ['neorv32_5frte_5fcontext_5fput_242',['neorv32_rte_context_put',['../neorv32__rte_8c.html#ae13a9c1fd59ad71afb0d47cf9a0b303e',1,'neorv32_rte_context_put(int x, uint32_t data):&#160;neorv32_rte.c'],['../neorv32__rte_8h.html#ae13a9c1fd59ad71afb0d47cf9a0b303e',1,'neorv32_rte_context_put(int x, uint32_t data):&#160;neorv32_rte.c']]], + ['neorv32_5frte_5fdebug_5fhandler_243',['neorv32_rte_debug_handler',['../neorv32__rte_8c.html#a65422bb44f1e7bc011e9bfc5d8451ebe',1,'neorv32_rte_debug_handler(void):&#160;neorv32_rte.c'],['../neorv32__rte_8h.html#a65422bb44f1e7bc011e9bfc5d8451ebe',1,'neorv32_rte_debug_handler(void):&#160;neorv32_rte.c']]], + ['neorv32_5frte_5fhandler_5finstall_244',['neorv32_rte_handler_install',['../neorv32__rte_8c.html#a2cf31cfa569a03a20d554b6400c4c5e2',1,'neorv32_rte_handler_install(int id, void(*handler)(void)):&#160;neorv32_rte.c'],['../neorv32__rte_8h.html#a2cf31cfa569a03a20d554b6400c4c5e2',1,'neorv32_rte_handler_install(int id, void(*handler)(void)):&#160;neorv32_rte.c']]], + ['neorv32_5frte_5fhandler_5funinstall_245',['neorv32_rte_handler_uninstall',['../neorv32__rte_8c.html#a10fde6229bf391e46148405616404a65',1,'neorv32_rte_handler_uninstall(int id):&#160;neorv32_rte.c'],['../neorv32__rte_8h.html#a10fde6229bf391e46148405616404a65',1,'neorv32_rte_handler_uninstall(int id):&#160;neorv32_rte.c']]], + ['neorv32_5frte_5fnum_5ftraps_246',['NEORV32_RTE_NUM_TRAPS',['../neorv32__rte_8h.html#ad14a1ca41df1e9300bfd01aef07dce59',1,'neorv32_rte.h']]], + ['neorv32_5frte_5fprint_5fabout_247',['neorv32_rte_print_about',['../neorv32__rte_8c.html#aa442c0e39f9156a131c3432fda587692',1,'neorv32_rte_print_about(void):&#160;neorv32_rte.c'],['../neorv32__rte_8h.html#aa442c0e39f9156a131c3432fda587692',1,'neorv32_rte_print_about(void):&#160;neorv32_rte.c']]], + ['neorv32_5frte_5fprint_5fhw_5fconfig_248',['neorv32_rte_print_hw_config',['../neorv32__rte_8c.html#a05e8304963e402d228a76aff1868771c',1,'neorv32_rte_print_hw_config(void):&#160;neorv32_rte.c'],['../neorv32__rte_8h.html#a05e8304963e402d228a76aff1868771c',1,'neorv32_rte_print_hw_config(void):&#160;neorv32_rte.c']]], + ['neorv32_5frte_5fprint_5fhw_5fversion_249',['neorv32_rte_print_hw_version',['../neorv32__rte_8c.html#aad6f5256a265807c4cde163bcba8dae9',1,'neorv32_rte_print_hw_version(void):&#160;neorv32_rte.c'],['../neorv32__rte_8h.html#aad6f5256a265807c4cde163bcba8dae9',1,'neorv32_rte_print_hw_version(void):&#160;neorv32_rte.c']]], + ['neorv32_5frte_5fprint_5flicense_250',['neorv32_rte_print_license',['../neorv32__rte_8c.html#acd96aa73eebe6d4bbc9aabe1230cbabc',1,'neorv32_rte_print_license(void):&#160;neorv32_rte.c'],['../neorv32__rte_8h.html#acd96aa73eebe6d4bbc9aabe1230cbabc',1,'neorv32_rte_print_license(void):&#160;neorv32_rte.c']]], + ['neorv32_5frte_5fprint_5flogo_251',['neorv32_rte_print_logo',['../neorv32__rte_8c.html#a16df1b48f2e1258a51d3bb7f49531cf3',1,'neorv32_rte_print_logo(void):&#160;neorv32_rte.c'],['../neorv32__rte_8h.html#a16df1b48f2e1258a51d3bb7f49531cf3',1,'neorv32_rte_print_logo(void):&#160;neorv32_rte.c']]], + ['neorv32_5frte_5fsetup_252',['neorv32_rte_setup',['../neorv32__rte_8c.html#a343e1913bdc37db9b168fb4def0e6170',1,'neorv32_rte_setup(void):&#160;neorv32_rte.c'],['../neorv32__rte_8h.html#a343e1913bdc37db9b168fb4def0e6170',1,'neorv32_rte_setup(void):&#160;neorv32_rte.c']]], + ['neorv32_5frte_5ftrap_5fenum_253',['NEORV32_RTE_TRAP_enum',['../neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70a',1,'neorv32_rte.h']]], + ['neorv32_5fsdi_254',['NEORV32_SDI',['../neorv32__sdi_8h.html#afd0921633d6523d9b7235055e9bbf928',1,'neorv32_sdi.h']]], + ['neorv32_5fsdi_2ec_255',['neorv32_sdi.c',['../neorv32__sdi_8c.html',1,'']]], + ['neorv32_5fsdi_2eh_256',['neorv32_sdi.h',['../neorv32__sdi_8h.html',1,'']]], + ['neorv32_5fsdi_5favailable_257',['neorv32_sdi_available',['../neorv32__sdi_8c.html#a51412722efdb18cd09667622b215e825',1,'neorv32_sdi_available(void):&#160;neorv32_sdi.c'],['../neorv32__sdi_8h.html#a51412722efdb18cd09667622b215e825',1,'neorv32_sdi_available(void):&#160;neorv32_sdi.c']]], + ['neorv32_5fsdi_5fbase_258',['NEORV32_SDI_BASE',['../neorv32_8h.html#a9b316ec038bd94ada42c9dab57a0a3cb',1,'neorv32.h']]], + ['neorv32_5fsdi_5fcheck_5fcs_259',['neorv32_sdi_check_cs',['../neorv32__sdi_8c.html#a2636cf1959ce1f3eb4b77c00ca2e2707',1,'neorv32_sdi_check_cs(void):&#160;neorv32_sdi.c'],['../neorv32__sdi_8h.html#a2636cf1959ce1f3eb4b77c00ca2e2707',1,'neorv32_sdi_check_cs(void):&#160;neorv32_sdi.c']]], + ['neorv32_5fsdi_5fctrl_5fenum_260',['NEORV32_SDI_CTRL_enum',['../neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6',1,'neorv32_sdi.h']]], + ['neorv32_5fsdi_5fdisable_261',['neorv32_sdi_disable',['../neorv32__sdi_8c.html#a8bd54bca8aea6147651c8115ee616f54',1,'neorv32_sdi_disable(void):&#160;neorv32_sdi.c'],['../neorv32__sdi_8h.html#a8bd54bca8aea6147651c8115ee616f54',1,'neorv32_sdi_disable(void):&#160;neorv32_sdi.c']]], + ['neorv32_5fsdi_5fenable_262',['neorv32_sdi_enable',['../neorv32__sdi_8c.html#a5d68b9b1642baf3519076e55a22a8f61',1,'neorv32_sdi_enable(void):&#160;neorv32_sdi.c'],['../neorv32__sdi_8h.html#a5d68b9b1642baf3519076e55a22a8f61',1,'neorv32_sdi_enable(void):&#160;neorv32_sdi.c']]], + ['neorv32_5fsdi_5fget_263',['neorv32_sdi_get',['../neorv32__sdi_8c.html#a4d54ce22ec97eb83da118439576e3277',1,'neorv32_sdi_get(uint8_t *data):&#160;neorv32_sdi.c'],['../neorv32__sdi_8h.html#a4d54ce22ec97eb83da118439576e3277',1,'neorv32_sdi_get(uint8_t *data):&#160;neorv32_sdi.c']]], + ['neorv32_5fsdi_5fget_5ffifo_5fdepth_264',['neorv32_sdi_get_fifo_depth',['../neorv32__sdi_8c.html#a7390faeb01b4de3dd5ac18335736b90c',1,'neorv32_sdi_get_fifo_depth(void):&#160;neorv32_sdi.c'],['../neorv32__sdi_8h.html#a7390faeb01b4de3dd5ac18335736b90c',1,'neorv32_sdi_get_fifo_depth(void):&#160;neorv32_sdi.c']]], + ['neorv32_5fsdi_5fput_265',['neorv32_sdi_put',['../neorv32__sdi_8c.html#ac7a262d16c42bbac27723ff779545569',1,'neorv32_sdi_put(uint8_t data):&#160;neorv32_sdi.c'],['../neorv32__sdi_8h.html#ac7a262d16c42bbac27723ff779545569',1,'neorv32_sdi_put(uint8_t data):&#160;neorv32_sdi.c']]], + ['neorv32_5fsdi_5fsetup_266',['neorv32_sdi_setup',['../neorv32__sdi_8c.html#a3246118dc0d7e1f61bc2485bbab44149',1,'neorv32_sdi_setup(uint32_t irq_mask):&#160;neorv32_sdi.c'],['../neorv32__sdi_8h.html#a3246118dc0d7e1f61bc2485bbab44149',1,'neorv32_sdi_setup(uint32_t irq_mask):&#160;neorv32_sdi.c']]], + ['neorv32_5fsdi_5ft_267',['neorv32_sdi_t',['../structneorv32__sdi__t.html',1,'']]], + ['neorv32_5fslink_268',['NEORV32_SLINK',['../neorv32__slink_8h.html#a6380d894432de119a20993096db534df',1,'neorv32_slink.h']]], + ['neorv32_5fslink_2ec_269',['neorv32_slink.c',['../neorv32__slink_8c.html',1,'']]], + ['neorv32_5fslink_2eh_270',['neorv32_slink.h',['../neorv32__slink_8h.html',1,'']]], + ['neorv32_5fslink_5favailable_271',['neorv32_slink_available',['../neorv32__slink_8c.html#aaf0f7bc96b797e819ccaae94292d9ddb',1,'neorv32_slink_available(void):&#160;neorv32_slink.c'],['../neorv32__slink_8h.html#aaf0f7bc96b797e819ccaae94292d9ddb',1,'neorv32_slink_available(void):&#160;neorv32_slink.c']]], + ['neorv32_5fslink_5fbase_272',['NEORV32_SLINK_BASE',['../neorv32_8h.html#ab5e6dc57886cd5ed98b86f22fc37d7cc',1,'neorv32.h']]], + ['neorv32_5fslink_5fcheck_5flast_273',['neorv32_slink_check_last',['../neorv32__slink_8c.html#a3e02c558548c1c6178c49adee9a007f7',1,'neorv32_slink_check_last(void):&#160;neorv32_slink.c'],['../neorv32__slink_8h.html#a3e02c558548c1c6178c49adee9a007f7',1,'neorv32_slink_check_last(void):&#160;neorv32_slink.c']]], + ['neorv32_5fslink_5fctrl_5fenum_274',['NEORV32_SLINK_CTRL_enum',['../neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1',1,'neorv32_slink.h']]], + ['neorv32_5fslink_5fget_275',['neorv32_slink_get',['../neorv32__slink_8c.html#ace319592c12dc6a0fe1b7dd66bdf9284',1,'neorv32_slink_get(void):&#160;neorv32_slink.c'],['../neorv32__slink_8h.html#ace319592c12dc6a0fe1b7dd66bdf9284',1,'neorv32_slink_get(void):&#160;neorv32_slink.c']]], + ['neorv32_5fslink_5fget_5frx_5ffifo_5fdepth_276',['neorv32_slink_get_rx_fifo_depth',['../neorv32__slink_8c.html#a575c7663ca0bd07c95b1d45152a3ddf8',1,'neorv32_slink_get_rx_fifo_depth(void):&#160;neorv32_slink.c'],['../neorv32__slink_8h.html#a575c7663ca0bd07c95b1d45152a3ddf8',1,'neorv32_slink_get_rx_fifo_depth(void):&#160;neorv32_slink.c']]], + ['neorv32_5fslink_5fget_5fsrc_277',['neorv32_slink_get_src',['../neorv32__slink_8c.html#a1a9269f42552a849450aecd99f7ec7a0',1,'neorv32_slink_get_src(void):&#160;neorv32_slink.c'],['../neorv32__slink_8h.html#a1a9269f42552a849450aecd99f7ec7a0',1,'neorv32_slink_get_src(void):&#160;neorv32_slink.c']]], + ['neorv32_5fslink_5fget_5ftx_5ffifo_5fdepth_278',['neorv32_slink_get_tx_fifo_depth',['../neorv32__slink_8c.html#aaf0d0d1b890353d4f3bf49450ec2fad2',1,'neorv32_slink_get_tx_fifo_depth(void):&#160;neorv32_slink.c'],['../neorv32__slink_8h.html#aaf0d0d1b890353d4f3bf49450ec2fad2',1,'neorv32_slink_get_tx_fifo_depth(void):&#160;neorv32_slink.c']]], + ['neorv32_5fslink_5fput_279',['neorv32_slink_put',['../neorv32__slink_8c.html#aaa9fdb9cbfa7888e92790ab65431d21d',1,'neorv32_slink_put(uint32_t tx_data):&#160;neorv32_slink.c'],['../neorv32__slink_8h.html#aaa9fdb9cbfa7888e92790ab65431d21d',1,'neorv32_slink_put(uint32_t tx_data):&#160;neorv32_slink.c']]], + ['neorv32_5fslink_5fput_5flast_280',['neorv32_slink_put_last',['../neorv32__slink_8c.html#a2136bc0b12ee2e6703e84a6417a1e8eb',1,'neorv32_slink_put_last(uint32_t tx_data):&#160;neorv32_slink.c'],['../neorv32__slink_8h.html#a2136bc0b12ee2e6703e84a6417a1e8eb',1,'neorv32_slink_put_last(uint32_t tx_data):&#160;neorv32_slink.c']]], + ['neorv32_5fslink_5froute_5fenum_281',['NEORV32_SLINK_ROUTE_enum',['../neorv32__slink_8h.html#ac3e5e02fd89a357135adca6d28cd0e45',1,'neorv32_slink.h']]], + ['neorv32_5fslink_5frx_5fclear_282',['neorv32_slink_rx_clear',['../neorv32__slink_8c.html#ad149fea81e6d28f77450b8ba50cf706e',1,'neorv32_slink_rx_clear(void):&#160;neorv32_slink.c'],['../neorv32__slink_8h.html#ad149fea81e6d28f77450b8ba50cf706e',1,'neorv32_slink_rx_clear(void):&#160;neorv32_slink.c']]], + ['neorv32_5fslink_5frx_5fstatus_283',['neorv32_slink_rx_status',['../neorv32__slink_8c.html#ad57fc0941fe32e8bf423ce3e57e2c10a',1,'neorv32_slink_rx_status(void):&#160;neorv32_slink.c'],['../neorv32__slink_8h.html#ad57fc0941fe32e8bf423ce3e57e2c10a',1,'neorv32_slink_rx_status(void):&#160;neorv32_slink.c']]], + ['neorv32_5fslink_5fset_5fdst_284',['neorv32_slink_set_dst',['../neorv32__slink_8c.html#ad857d7e78ca2b5eb0d0a4f2c515fe7bc',1,'neorv32_slink_set_dst(uint32_t dst):&#160;neorv32_slink.c'],['../neorv32__slink_8h.html#ad857d7e78ca2b5eb0d0a4f2c515fe7bc',1,'neorv32_slink_set_dst(uint32_t dst):&#160;neorv32_slink.c']]], + ['neorv32_5fslink_5fsetup_285',['neorv32_slink_setup',['../neorv32__slink_8c.html#a8f0b4a768f53a72a5c16034e160ce321',1,'neorv32_slink_setup(uint32_t rx_irq, uint32_t tx_irq):&#160;neorv32_slink.c'],['../neorv32__slink_8h.html#a8f0b4a768f53a72a5c16034e160ce321',1,'neorv32_slink_setup(uint32_t rx_irq, uint32_t tx_irq):&#160;neorv32_slink.c']]], + ['neorv32_5fslink_5fstatus_5fenum_286',['NEORV32_SLINK_STATUS_enum',['../neorv32__slink_8h.html#a84f7fe82f188bd4e68f41549587822bf',1,'neorv32_slink.h']]], + ['neorv32_5fslink_5ft_287',['neorv32_slink_t',['../structneorv32__slink__t.html',1,'']]], + ['neorv32_5fslink_5ftx_5fclear_288',['neorv32_slink_tx_clear',['../neorv32__slink_8c.html#ac7484e9e3848f94efe016dd064f6a57f',1,'neorv32_slink_tx_clear(void):&#160;neorv32_slink.c'],['../neorv32__slink_8h.html#ac7484e9e3848f94efe016dd064f6a57f',1,'neorv32_slink_tx_clear(void):&#160;neorv32_slink.c']]], + ['neorv32_5fslink_5ftx_5fstatus_289',['neorv32_slink_tx_status',['../neorv32__slink_8c.html#ad0252e7ae915e5840cd17e8c52e94a1c',1,'neorv32_slink_tx_status(void):&#160;neorv32_slink.c'],['../neorv32__slink_8h.html#ad0252e7ae915e5840cd17e8c52e94a1c',1,'neorv32_slink_tx_status(void):&#160;neorv32_slink.c']]], + ['neorv32_5fspi_290',['NEORV32_SPI',['../neorv32__spi_8h.html#a5f3afc4e268670c54d90df67fa38ca22',1,'neorv32_spi.h']]], + ['neorv32_5fspi_2ec_291',['neorv32_spi.c',['../neorv32__spi_8c.html',1,'']]], + ['neorv32_5fspi_2eh_292',['neorv32_spi.h',['../neorv32__spi_8h.html',1,'']]], + ['neorv32_5fspi_5favailable_293',['neorv32_spi_available',['../neorv32__spi_8c.html#a7266ee439d0ec11c5cedd4bf1a258272',1,'neorv32_spi_available(void):&#160;neorv32_spi.c'],['../neorv32__spi_8h.html#a7266ee439d0ec11c5cedd4bf1a258272',1,'neorv32_spi_available(void):&#160;neorv32_spi.c']]], + ['neorv32_5fspi_5fbase_294',['NEORV32_SPI_BASE',['../neorv32_8h.html#aa466dc5eace7351bd438606f0f7475a7',1,'neorv32.h']]], + ['neorv32_5fspi_5fbusy_295',['neorv32_spi_busy',['../neorv32__spi_8c.html#a332c7a1be511812ac0a2b102c165398a',1,'neorv32_spi_busy(void):&#160;neorv32_spi.c'],['../neorv32__spi_8h.html#a332c7a1be511812ac0a2b102c165398a',1,'neorv32_spi_busy(void):&#160;neorv32_spi.c']]], + ['neorv32_5fspi_5fcheck_5fcs_296',['neorv32_spi_check_cs',['../neorv32__spi_8c.html#a82bb4d4c222b2bdc57e917c348481501',1,'neorv32_spi_check_cs(void):&#160;neorv32_spi.c'],['../neorv32__spi_8h.html#a82bb4d4c222b2bdc57e917c348481501',1,'neorv32_spi_check_cs(void):&#160;neorv32_spi.c']]], + ['neorv32_5fspi_5fcs_5fdis_297',['neorv32_spi_cs_dis',['../neorv32__spi_8c.html#aa10ec90ccba6325eeeebb8f6f298d30c',1,'neorv32_spi_cs_dis(void):&#160;neorv32_spi.c'],['../neorv32__spi_8h.html#aa10ec90ccba6325eeeebb8f6f298d30c',1,'neorv32_spi_cs_dis(void):&#160;neorv32_spi.c']]], + ['neorv32_5fspi_5fcs_5fdis_5fnonblocking_298',['neorv32_spi_cs_dis_nonblocking',['../neorv32__spi_8c.html#ad8dd1b5a85a9daef4c8c21c9990884c1',1,'neorv32_spi_cs_dis_nonblocking(void):&#160;neorv32_spi.c'],['../neorv32__spi_8h.html#ad8dd1b5a85a9daef4c8c21c9990884c1',1,'neorv32_spi_cs_dis_nonblocking(void):&#160;neorv32_spi.c']]], + ['neorv32_5fspi_5fcs_5fen_299',['neorv32_spi_cs_en',['../neorv32__spi_8c.html#a737961d040ac09567350f89034f9e122',1,'neorv32_spi_cs_en(int cs):&#160;neorv32_spi.c'],['../neorv32__spi_8h.html#a737961d040ac09567350f89034f9e122',1,'neorv32_spi_cs_en(int cs):&#160;neorv32_spi.c']]], + ['neorv32_5fspi_5fcs_5fen_5fnonblocking_300',['neorv32_spi_cs_en_nonblocking',['../neorv32__spi_8c.html#a97b5536347a27b053f071ba49071ba6f',1,'neorv32_spi_cs_en_nonblocking(int cs):&#160;neorv32_spi.c'],['../neorv32__spi_8h.html#a97b5536347a27b053f071ba49071ba6f',1,'neorv32_spi_cs_en_nonblocking(int cs):&#160;neorv32_spi.c']]], + ['neorv32_5fspi_5fctrl_5fenum_301',['NEORV32_SPI_CTRL_enum',['../neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3b',1,'neorv32_spi.h']]], + ['neorv32_5fspi_5fdata_5fenum_302',['NEORV32_SPI_DATA_enum',['../neorv32__spi_8h.html#aab478c23898c0b06cee53a1cbda38bf8',1,'neorv32_spi.h']]], + ['neorv32_5fspi_5fdisable_303',['neorv32_spi_disable',['../neorv32__spi_8c.html#a817dd9a38bfceb2048e40874a83ba169',1,'neorv32_spi_disable(void):&#160;neorv32_spi.c'],['../neorv32__spi_8h.html#a817dd9a38bfceb2048e40874a83ba169',1,'neorv32_spi_disable(void):&#160;neorv32_spi.c']]], + ['neorv32_5fspi_5fenable_304',['neorv32_spi_enable',['../neorv32__spi_8c.html#a8fa25d144ccb20a2faf0450c8dddd16e',1,'neorv32_spi_enable(void):&#160;neorv32_spi.c'],['../neorv32__spi_8h.html#a8fa25d144ccb20a2faf0450c8dddd16e',1,'neorv32_spi_enable(void):&#160;neorv32_spi.c']]], + ['neorv32_5fspi_5fget_5fclock_5fspeed_305',['neorv32_spi_get_clock_speed',['../neorv32__spi_8c.html#a01c6b63d7349447e2277f2649c3c89f2',1,'neorv32_spi_get_clock_speed(void):&#160;neorv32_spi.c'],['../neorv32__spi_8h.html#a01c6b63d7349447e2277f2649c3c89f2',1,'neorv32_spi_get_clock_speed(void):&#160;neorv32_spi.c']]], + ['neorv32_5fspi_5fget_5ffifo_5fdepth_306',['neorv32_spi_get_fifo_depth',['../neorv32__spi_8c.html#ae1c4da7e4dc2e42b04d7187f684f142c',1,'neorv32_spi_get_fifo_depth(void):&#160;neorv32_spi.c'],['../neorv32__spi_8h.html#ae1c4da7e4dc2e42b04d7187f684f142c',1,'neorv32_spi_get_fifo_depth(void):&#160;neorv32_spi.c']]], + ['neorv32_5fspi_5fget_5fnonblocking_307',['neorv32_spi_get_nonblocking',['../neorv32__spi_8c.html#aad66fa8f8d1a92d4f355de7579bfbfd2',1,'neorv32_spi_get_nonblocking(void):&#160;neorv32_spi.c'],['../neorv32__spi_8h.html#aad66fa8f8d1a92d4f355de7579bfbfd2',1,'neorv32_spi_get_nonblocking(void):&#160;neorv32_spi.c']]], + ['neorv32_5fspi_5fhighspeed_5fdisable_308',['neorv32_spi_highspeed_disable',['../neorv32__spi_8c.html#a67e9717635e272bc0e04408135a2f04d',1,'neorv32_spi_highspeed_disable(void):&#160;neorv32_spi.c'],['../neorv32__spi_8h.html#a67e9717635e272bc0e04408135a2f04d',1,'neorv32_spi_highspeed_disable(void):&#160;neorv32_spi.c']]], + ['neorv32_5fspi_5fhighspeed_5fenable_309',['neorv32_spi_highspeed_enable',['../neorv32__spi_8c.html#acf131faa3ad970c19a3cd8a47cb54f65',1,'neorv32_spi_highspeed_enable(void):&#160;neorv32_spi.c'],['../neorv32__spi_8h.html#acf131faa3ad970c19a3cd8a47cb54f65',1,'neorv32_spi_highspeed_enable(void):&#160;neorv32_spi.c']]], + ['neorv32_5fspi_5finit_310',['neorv32_spi_init',['../neorv32__spi__irq_8c.html#a4aa4746fd210ecc0c3614089a6951ddf',1,'neorv32_spi_init(t_neorv32_spi *self):&#160;neorv32_spi_irq.c'],['../neorv32__spi__irq_8h.html#a4aa4746fd210ecc0c3614089a6951ddf',1,'neorv32_spi_init(t_neorv32_spi *self):&#160;neorv32_spi_irq.c']]], + ['neorv32_5fspi_5firq_2ec_311',['neorv32_spi_irq.c',['../neorv32__spi__irq_8c.html',1,'']]], + ['neorv32_5fspi_5firq_2eh_312',['neorv32_spi_irq.h',['../neorv32__spi__irq_8h.html',1,'']]], + ['neorv32_5fspi_5fisr_313',['neorv32_spi_isr',['../neorv32__spi__irq_8c.html#aa641816bb302df497664aa21ea69ed16',1,'neorv32_spi_isr(t_neorv32_spi *self):&#160;neorv32_spi_irq.c'],['../neorv32__spi__irq_8h.html#aa641816bb302df497664aa21ea69ed16',1,'neorv32_spi_isr(t_neorv32_spi *self):&#160;neorv32_spi_irq.c']]], + ['neorv32_5fspi_5fput_5fnonblocking_314',['neorv32_spi_put_nonblocking',['../neorv32__spi_8c.html#aec8583e988789e846d21c2a35e6b06e7',1,'neorv32_spi_put_nonblocking(uint8_t tx_data):&#160;neorv32_spi.c'],['../neorv32__spi_8h.html#aec8583e988789e846d21c2a35e6b06e7',1,'neorv32_spi_put_nonblocking(uint8_t tx_data):&#160;neorv32_spi.c']]], + ['neorv32_5fspi_5frw_315',['neorv32_spi_rw',['../neorv32__spi__irq_8c.html#a1f44ed849415d8e1d659c0485762c485',1,'neorv32_spi_rw(t_neorv32_spi *self, uint8_t csn, void *spi, uint32_t len):&#160;neorv32_spi_irq.c'],['../neorv32__spi__irq_8h.html#a1f44ed849415d8e1d659c0485762c485',1,'neorv32_spi_rw(t_neorv32_spi *self, uint8_t csn, void *spi, uint32_t len):&#160;neorv32_spi_irq.c']]], + ['neorv32_5fspi_5frw_5fbusy_316',['neorv32_spi_rw_busy',['../neorv32__spi__irq_8c.html#a1863e19932bc6a79f2ca27d23eb74ef5',1,'neorv32_spi_rw_busy(t_neorv32_spi *self):&#160;neorv32_spi_irq.c'],['../neorv32__spi__irq_8h.html#a1863e19932bc6a79f2ca27d23eb74ef5',1,'neorv32_spi_rw_busy(t_neorv32_spi *self):&#160;neorv32_spi_irq.c']]], + ['neorv32_5fspi_5fsetup_317',['neorv32_spi_setup',['../neorv32__spi_8c.html#a7d8124d986b69210081df6f1aa653552',1,'neorv32_spi_setup(int prsc, int cdiv, int clk_phase, int clk_polarity, uint32_t irq_mask):&#160;neorv32_spi.c'],['../neorv32__spi_8h.html#a7d8124d986b69210081df6f1aa653552',1,'neorv32_spi_setup(int prsc, int cdiv, int clk_phase, int clk_polarity, uint32_t irq_mask):&#160;neorv32_spi.c']]], + ['neorv32_5fspi_5ft_318',['neorv32_spi_t',['../structneorv32__spi__t.html',1,'']]], + ['neorv32_5fspi_5ftrans_319',['neorv32_spi_trans',['../neorv32__spi_8c.html#a7af79950eefc26e67a89bde02f255532',1,'neorv32_spi_trans(uint8_t tx_data):&#160;neorv32_spi.c'],['../neorv32__spi_8h.html#a7af79950eefc26e67a89bde02f255532',1,'neorv32_spi_trans(uint8_t tx_data):&#160;neorv32_spi.c']]], + ['neorv32_5fsysinfo_5fbase_320',['NEORV32_SYSINFO_BASE',['../neorv32_8h.html#a5aa936f38782232c7ed3eab1283ee536',1,'neorv32.h']]], + ['neorv32_5fsysinfo_5ft_321',['neorv32_sysinfo_t',['../structneorv32__sysinfo__t.html',1,'']]], + ['neorv32_5ftrng_322',['NEORV32_TRNG',['../neorv32__trng_8h.html#a9794ff3746eb5321ad9c2bf522ea26dd',1,'neorv32_trng.h']]], + ['neorv32_5ftrng_2ec_323',['neorv32_trng.c',['../neorv32__trng_8c.html',1,'']]], + ['neorv32_5ftrng_2eh_324',['neorv32_trng.h',['../neorv32__trng_8h.html',1,'']]], + ['neorv32_5ftrng_5favailable_325',['neorv32_trng_available',['../neorv32__trng_8c.html#af0c4139ff68763623b3d658a8dd8b5ce',1,'neorv32_trng_available(void):&#160;neorv32_trng.c'],['../neorv32__trng_8h.html#af0c4139ff68763623b3d658a8dd8b5ce',1,'neorv32_trng_available(void):&#160;neorv32_trng.c']]], + ['neorv32_5ftrng_5fbase_326',['NEORV32_TRNG_BASE',['../neorv32_8h.html#ab4846cd153e8a23deec45d81cc8372a2',1,'neorv32.h']]], + ['neorv32_5ftrng_5fcheck_5fsim_5fmode_327',['neorv32_trng_check_sim_mode',['../neorv32__trng_8c.html#aba36f08dd88f2f3e58353ae72eaa14f7',1,'neorv32_trng_check_sim_mode(void):&#160;neorv32_trng.c'],['../neorv32__trng_8h.html#aba36f08dd88f2f3e58353ae72eaa14f7',1,'neorv32_trng_check_sim_mode(void):&#160;neorv32_trng.c']]], + ['neorv32_5ftrng_5fctrl_5fenum_328',['NEORV32_TRNG_CTRL_enum',['../neorv32__trng_8h.html#a1440e1355bf5bff17760992adc156b1a',1,'neorv32_trng.h']]], + ['neorv32_5ftrng_5fdisable_329',['neorv32_trng_disable',['../neorv32__trng_8c.html#ae838bc980e28c300dc2c9c3f34a46bb8',1,'neorv32_trng_disable(void):&#160;neorv32_trng.c'],['../neorv32__trng_8h.html#ae838bc980e28c300dc2c9c3f34a46bb8',1,'neorv32_trng_disable(void):&#160;neorv32_trng.c']]], + ['neorv32_5ftrng_5fenable_330',['neorv32_trng_enable',['../neorv32__trng_8c.html#a8b8a1771e37a152792264561b93228fa',1,'neorv32_trng_enable(int irq_sel):&#160;neorv32_trng.c'],['../neorv32__trng_8h.html#a8b8a1771e37a152792264561b93228fa',1,'neorv32_trng_enable(int irq_sel):&#160;neorv32_trng.c']]], + ['neorv32_5ftrng_5ffifo_5fclear_331',['neorv32_trng_fifo_clear',['../neorv32__trng_8c.html#a87cfe338e2ff559f96c73f729465f967',1,'neorv32_trng_fifo_clear(void):&#160;neorv32_trng.c'],['../neorv32__trng_8h.html#a87cfe338e2ff559f96c73f729465f967',1,'neorv32_trng_fifo_clear(void):&#160;neorv32_trng.c']]], + ['neorv32_5ftrng_5fget_332',['neorv32_trng_get',['../neorv32__trng_8c.html#a9148bcb6a7c448c364e78fa98aac6985',1,'neorv32_trng_get(uint8_t *data):&#160;neorv32_trng.c'],['../neorv32__trng_8h.html#a9148bcb6a7c448c364e78fa98aac6985',1,'neorv32_trng_get(uint8_t *data):&#160;neorv32_trng.c']]], + ['neorv32_5ftrng_5fget_5ffifo_5fdepth_333',['neorv32_trng_get_fifo_depth',['../neorv32__trng_8c.html#ad24e44372f4fd1ed29a6967dccab4fb0',1,'neorv32_trng_get_fifo_depth(void):&#160;neorv32_trng.c'],['../neorv32__trng_8h.html#ad24e44372f4fd1ed29a6967dccab4fb0',1,'neorv32_trng_get_fifo_depth(void):&#160;neorv32_trng.c']]], + ['neorv32_5ftrng_5ft_334',['neorv32_trng_t',['../structneorv32__trng__t.html',1,'']]], + ['neorv32_5ftwi_335',['NEORV32_TWI',['../neorv32__twi_8h.html#a2769c2fe5e0de01b12fe4a5fad029768',1,'neorv32_twi.h']]], + ['neorv32_5ftwi_2ec_336',['neorv32_twi.c',['../neorv32__twi_8c.html',1,'']]], + ['neorv32_5ftwi_2eh_337',['neorv32_twi.h',['../neorv32__twi_8h.html',1,'']]], + ['neorv32_5ftwi_5favailable_338',['neorv32_twi_available',['../neorv32__twi_8c.html#aa2e01ebbc0c82d65ed4ded351f4d8711',1,'neorv32_twi_available(void):&#160;neorv32_twi.c'],['../neorv32__twi_8h.html#aa2e01ebbc0c82d65ed4ded351f4d8711',1,'neorv32_twi_available(void):&#160;neorv32_twi.c']]], + ['neorv32_5ftwi_5fbase_339',['NEORV32_TWI_BASE',['../neorv32_8h.html#a4a741408a4bb0938e03b99555306db9c',1,'neorv32.h']]], + ['neorv32_5ftwi_5fbusy_340',['neorv32_twi_busy',['../neorv32__twi_8c.html#a4fff1ddade320f6cc568c6266f2c2acd',1,'neorv32_twi_busy(void):&#160;neorv32_twi.c'],['../neorv32__twi_8h.html#a4fff1ddade320f6cc568c6266f2c2acd',1,'neorv32_twi_busy(void):&#160;neorv32_twi.c']]], + ['neorv32_5ftwi_5fctrl_5fenum_341',['NEORV32_TWI_CTRL_enum',['../neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafa',1,'neorv32_twi.h']]], + ['neorv32_5ftwi_5fdcmd_5fenum_342',['NEORV32_TWI_DCMD_enum',['../neorv32__twi_8h.html#a3421852c63baca60fe58c990b1c653d8',1,'neorv32_twi.h']]], + ['neorv32_5ftwi_5fdisable_343',['neorv32_twi_disable',['../neorv32__twi_8c.html#ae5f31e737c7a6c3c86070ff34cb0d861',1,'neorv32_twi_disable(void):&#160;neorv32_twi.c'],['../neorv32__twi_8h.html#ae5f31e737c7a6c3c86070ff34cb0d861',1,'neorv32_twi_disable(void):&#160;neorv32_twi.c']]], + ['neorv32_5ftwi_5fenable_344',['neorv32_twi_enable',['../neorv32__twi_8c.html#a22717887cffff1e6830756bc73140e7b',1,'neorv32_twi_enable(void):&#160;neorv32_twi.c'],['../neorv32__twi_8h.html#a22717887cffff1e6830756bc73140e7b',1,'neorv32_twi_enable(void):&#160;neorv32_twi.c']]], + ['neorv32_5ftwi_5fgenerate_5fstart_345',['neorv32_twi_generate_start',['../neorv32__twi_8c.html#a633d460e4735eb369d74a834b03c8b78',1,'neorv32_twi_generate_start(void):&#160;neorv32_twi.c'],['../neorv32__twi_8h.html#a633d460e4735eb369d74a834b03c8b78',1,'neorv32_twi_generate_start(void):&#160;neorv32_twi.c']]], + ['neorv32_5ftwi_5fgenerate_5fstart_5fnonblocking_346',['neorv32_twi_generate_start_nonblocking',['../neorv32__twi_8c.html#adbf2eaed0c76221da5c3091665fc885e',1,'neorv32_twi_generate_start_nonblocking(void):&#160;neorv32_twi.c'],['../neorv32__twi_8h.html#adbf2eaed0c76221da5c3091665fc885e',1,'neorv32_twi_generate_start_nonblocking(void):&#160;neorv32_twi.c']]], + ['neorv32_5ftwi_5fgenerate_5fstop_347',['neorv32_twi_generate_stop',['../neorv32__twi_8c.html#ad352447adcccccabd4e20577b34fbece',1,'neorv32_twi_generate_stop(void):&#160;neorv32_twi.c'],['../neorv32__twi_8h.html#ad352447adcccccabd4e20577b34fbece',1,'neorv32_twi_generate_stop(void):&#160;neorv32_twi.c']]], + ['neorv32_5ftwi_5fgenerate_5fstop_5fnonblocking_348',['neorv32_twi_generate_stop_nonblocking',['../neorv32__twi_8c.html#aa22430aab0a38d88cbd2c4220c573da0',1,'neorv32_twi_generate_stop_nonblocking(void):&#160;neorv32_twi.c'],['../neorv32__twi_8h.html#aa22430aab0a38d88cbd2c4220c573da0',1,'neorv32_twi_generate_stop_nonblocking(void):&#160;neorv32_twi.c']]], + ['neorv32_5ftwi_5fget_349',['neorv32_twi_get',['../neorv32__twi_8c.html#a7735376d26560866b153ed205dfcb2ba',1,'neorv32_twi_get(uint8_t *data):&#160;neorv32_twi.c'],['../neorv32__twi_8h.html#a7735376d26560866b153ed205dfcb2ba',1,'neorv32_twi_get(uint8_t *data):&#160;neorv32_twi.c']]], + ['neorv32_5ftwi_5fget_5ffifo_5fdepth_350',['neorv32_twi_get_fifo_depth',['../neorv32__twi_8c.html#a2c8f3bc55f4a9a8bdcb111759cf56ae2',1,'neorv32_twi_get_fifo_depth(void):&#160;neorv32_twi.c'],['../neorv32__twi_8h.html#a2c8f3bc55f4a9a8bdcb111759cf56ae2',1,'neorv32_twi_get_fifo_depth(void):&#160;neorv32_twi.c']]], + ['neorv32_5ftwi_5fsend_5fnonblocking_351',['neorv32_twi_send_nonblocking',['../neorv32__twi_8c.html#a28fc44cce5d28f6e8c32268b239b07d5',1,'neorv32_twi_send_nonblocking(uint8_t data, int mack):&#160;neorv32_twi.c'],['../neorv32__twi_8h.html#a28fc44cce5d28f6e8c32268b239b07d5',1,'neorv32_twi_send_nonblocking(uint8_t data, int mack):&#160;neorv32_twi.c']]], + ['neorv32_5ftwi_5fsetup_352',['neorv32_twi_setup',['../neorv32__twi_8c.html#a7ea6f3509a7cf622234d4b83e33afbe3',1,'neorv32_twi_setup(int prsc, int cdiv, int clkstr):&#160;neorv32_twi.c'],['../neorv32__twi_8h.html#a7ea6f3509a7cf622234d4b83e33afbe3',1,'neorv32_twi_setup(int prsc, int cdiv, int clkstr):&#160;neorv32_twi.c']]], + ['neorv32_5ftwi_5ft_353',['neorv32_twi_t',['../structneorv32__twi__t.html',1,'']]], + ['neorv32_5ftwi_5ftrans_354',['neorv32_twi_trans',['../neorv32__twi_8c.html#ac7020f3379602f11c47ca16f1bd82f2e',1,'neorv32_twi_trans(uint8_t *data, int mack):&#160;neorv32_twi.c'],['../neorv32__twi_8h.html#ac7020f3379602f11c47ca16f1bd82f2e',1,'neorv32_twi_trans(uint8_t *data, int mack):&#160;neorv32_twi.c']]], + ['neorv32_5fuart_2ec_355',['neorv32_uart.c',['../neorv32__uart_8c.html',1,'']]], + ['neorv32_5fuart_2eh_356',['neorv32_uart.h',['../neorv32__uart_8h.html',1,'']]], + ['neorv32_5fuart0_357',['NEORV32_UART0',['../neorv32__uart_8h.html#a4c880a6b27e46f459e750425258b1bdb',1,'neorv32_uart.h']]], + ['neorv32_5fuart0_5fbase_358',['NEORV32_UART0_BASE',['../neorv32_8h.html#a000b37f710043fe21e49b2fdbc039d94',1,'neorv32.h']]], + ['neorv32_5fuart1_359',['NEORV32_UART1',['../neorv32__uart_8h.html#aa2a9ded4523f001bf69935c80247fa2d',1,'neorv32_uart.h']]], + ['neorv32_5fuart1_5fbase_360',['NEORV32_UART1_BASE',['../neorv32_8h.html#a26a1defe18ce222b8b4ed1c760344700',1,'neorv32.h']]], + ['neorv32_5fuart_5favailable_361',['neorv32_uart_available',['../neorv32__uart_8c.html#abef6415b0391dc055713404312196682',1,'neorv32_uart_available(neorv32_uart_t *UARTx):&#160;neorv32_uart.c'],['../neorv32__uart_8h.html#abef6415b0391dc055713404312196682',1,'neorv32_uart_available(neorv32_uart_t *UARTx):&#160;neorv32_uart.c']]], + ['neorv32_5fuart_5fchar_5freceived_362',['neorv32_uart_char_received',['../neorv32__uart_8c.html#adedb0e07efb232717534017167a5be98',1,'neorv32_uart_char_received(neorv32_uart_t *UARTx):&#160;neorv32_uart.c'],['../neorv32__uart_8h.html#adedb0e07efb232717534017167a5be98',1,'neorv32_uart_char_received(neorv32_uart_t *UARTx):&#160;neorv32_uart.c']]], + ['neorv32_5fuart_5fchar_5freceived_5fget_363',['neorv32_uart_char_received_get',['../neorv32__uart_8c.html#aa490df3a9bb2aa3215fa6fad34ffe7d1',1,'neorv32_uart_char_received_get(neorv32_uart_t *UARTx):&#160;neorv32_uart.c'],['../neorv32__uart_8h.html#aa490df3a9bb2aa3215fa6fad34ffe7d1',1,'neorv32_uart_char_received_get(neorv32_uart_t *UARTx):&#160;neorv32_uart.c']]], + ['neorv32_5fuart_5fctrl_5fenum_364',['NEORV32_UART_CTRL_enum',['../neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afc',1,'neorv32_uart.h']]], + ['neorv32_5fuart_5fdata_5fenum_365',['NEORV32_UART_DATA_enum',['../neorv32__uart_8h.html#adcf35350a9ea18a59c32c35f528643f2',1,'neorv32_uart.h']]], + ['neorv32_5fuart_5fdisable_366',['neorv32_uart_disable',['../neorv32__uart_8c.html#ae18804ccd29ec2fd1cc06e9ce985b704',1,'neorv32_uart_disable(neorv32_uart_t *UARTx):&#160;neorv32_uart.c'],['../neorv32__uart_8h.html#ae18804ccd29ec2fd1cc06e9ce985b704',1,'neorv32_uart_disable(neorv32_uart_t *UARTx):&#160;neorv32_uart.c']]], + ['neorv32_5fuart_5fenable_367',['neorv32_uart_enable',['../neorv32__uart_8c.html#afa0533e81d53057c36f4997a2dbbe2bc',1,'neorv32_uart_enable(neorv32_uart_t *UARTx):&#160;neorv32_uart.c'],['../neorv32__uart_8h.html#afa0533e81d53057c36f4997a2dbbe2bc',1,'neorv32_uart_enable(neorv32_uart_t *UARTx):&#160;neorv32_uart.c']]], + ['neorv32_5fuart_5fget_5frx_5ffifo_5fdepth_368',['neorv32_uart_get_rx_fifo_depth',['../neorv32__uart_8c.html#af85fb929c912d3edef3d86ffa833982a',1,'neorv32_uart_get_rx_fifo_depth(neorv32_uart_t *UARTx):&#160;neorv32_uart.c'],['../neorv32__uart_8h.html#af85fb929c912d3edef3d86ffa833982a',1,'neorv32_uart_get_rx_fifo_depth(neorv32_uart_t *UARTx):&#160;neorv32_uart.c']]], + ['neorv32_5fuart_5fget_5ftx_5ffifo_5fdepth_369',['neorv32_uart_get_tx_fifo_depth',['../neorv32__uart_8c.html#a031e3e27c8783c299623468020a22b0e',1,'neorv32_uart_get_tx_fifo_depth(neorv32_uart_t *UARTx):&#160;neorv32_uart.c'],['../neorv32__uart_8h.html#a031e3e27c8783c299623468020a22b0e',1,'neorv32_uart_get_tx_fifo_depth(neorv32_uart_t *UARTx):&#160;neorv32_uart.c']]], + ['neorv32_5fuart_5fgetc_370',['neorv32_uart_getc',['../neorv32__uart_8c.html#a2efd432f63b8d36d44263d0b1f39a6dc',1,'neorv32_uart_getc(neorv32_uart_t *UARTx):&#160;neorv32_uart.c'],['../neorv32__uart_8h.html#a2efd432f63b8d36d44263d0b1f39a6dc',1,'neorv32_uart_getc(neorv32_uart_t *UARTx):&#160;neorv32_uart.c']]], + ['neorv32_5fuart_5fprintf_371',['neorv32_uart_printf',['../neorv32__uart_8c.html#ab8c1f9f451def9126ab2749d7bbe50d9',1,'neorv32_uart_printf(neorv32_uart_t *UARTx, const char *format,...):&#160;neorv32_uart.c'],['../neorv32__uart_8h.html#ab8c1f9f451def9126ab2749d7bbe50d9',1,'neorv32_uart_printf(neorv32_uart_t *UARTx, const char *format,...):&#160;neorv32_uart.c']]], + ['neorv32_5fuart_5fputc_372',['neorv32_uart_putc',['../neorv32__uart_8c.html#a9bc7bb94a50b74e1145b78eec6094129',1,'neorv32_uart_putc(neorv32_uart_t *UARTx, char c):&#160;neorv32_uart.c'],['../neorv32__uart_8h.html#a9bc7bb94a50b74e1145b78eec6094129',1,'neorv32_uart_putc(neorv32_uart_t *UARTx, char c):&#160;neorv32_uart.c']]], + ['neorv32_5fuart_5fputs_373',['neorv32_uart_puts',['../neorv32__uart_8c.html#a45a07d5e71677162baaa1025759c67a2',1,'neorv32_uart_puts(neorv32_uart_t *UARTx, const char *s):&#160;neorv32_uart.c'],['../neorv32__uart_8h.html#a45a07d5e71677162baaa1025759c67a2',1,'neorv32_uart_puts(neorv32_uart_t *UARTx, const char *s):&#160;neorv32_uart.c']]], + ['neorv32_5fuart_5frtscts_5fdisable_374',['neorv32_uart_rtscts_disable',['../neorv32__uart_8c.html#a7b2f924ef4554b1fa90433c38d97558d',1,'neorv32_uart_rtscts_disable(neorv32_uart_t *UARTx):&#160;neorv32_uart.c'],['../neorv32__uart_8h.html#a7b2f924ef4554b1fa90433c38d97558d',1,'neorv32_uart_rtscts_disable(neorv32_uart_t *UARTx):&#160;neorv32_uart.c']]], + ['neorv32_5fuart_5frtscts_5fenable_375',['neorv32_uart_rtscts_enable',['../neorv32__uart_8c.html#a734b610f4cd1b474d7763f9700a715ec',1,'neorv32_uart_rtscts_enable(neorv32_uart_t *UARTx):&#160;neorv32_uart.c'],['../neorv32__uart_8h.html#a734b610f4cd1b474d7763f9700a715ec',1,'neorv32_uart_rtscts_enable(neorv32_uart_t *UARTx):&#160;neorv32_uart.c']]], + ['neorv32_5fuart_5frx_5fclear_376',['neorv32_uart_rx_clear',['../neorv32__uart_8c.html#afe0de59c14faff1e0c890d5465be25f0',1,'neorv32_uart_rx_clear(neorv32_uart_t *UARTx):&#160;neorv32_uart.c'],['../neorv32__uart_8h.html#afe0de59c14faff1e0c890d5465be25f0',1,'neorv32_uart_rx_clear(neorv32_uart_t *UARTx):&#160;neorv32_uart.c']]], + ['neorv32_5fuart_5fscan_377',['neorv32_uart_scan',['../neorv32__uart_8c.html#ac429964878bd6deab61d9ed8659bca75',1,'neorv32_uart_scan(neorv32_uart_t *UARTx, char *buffer, int max_size, int echo):&#160;neorv32_uart.c'],['../neorv32__uart_8h.html#ac429964878bd6deab61d9ed8659bca75',1,'neorv32_uart_scan(neorv32_uart_t *UARTx, char *buffer, int max_size, int echo):&#160;neorv32_uart.c']]], + ['neorv32_5fuart_5fsetup_378',['neorv32_uart_setup',['../neorv32__uart_8c.html#a9cdec36f2723c5373664022d1b68b841',1,'neorv32_uart_setup(neorv32_uart_t *UARTx, uint32_t baudrate, uint32_t irq_mask):&#160;neorv32_uart.c'],['../neorv32__uart_8h.html#a9cdec36f2723c5373664022d1b68b841',1,'neorv32_uart_setup(neorv32_uart_t *UARTx, uint32_t baudrate, uint32_t irq_mask):&#160;neorv32_uart.c']]], + ['neorv32_5fuart_5ft_379',['neorv32_uart_t',['../structneorv32__uart__t.html',1,'']]], + ['neorv32_5fuart_5ftx_5fbusy_380',['neorv32_uart_tx_busy',['../neorv32__uart_8c.html#aa7bef48a58e044c246b8c4ad32864502',1,'neorv32_uart_tx_busy(neorv32_uart_t *UARTx):&#160;neorv32_uart.c'],['../neorv32__uart_8h.html#aa7bef48a58e044c246b8c4ad32864502',1,'neorv32_uart_tx_busy(neorv32_uart_t *UARTx):&#160;neorv32_uart.c']]], + ['neorv32_5fuart_5ftx_5fclear_381',['neorv32_uart_tx_clear',['../neorv32__uart_8c.html#a27971954262a2fd1f21d3bf1ba27e87c',1,'neorv32_uart_tx_clear(neorv32_uart_t *UARTx):&#160;neorv32_uart.c'],['../neorv32__uart_8h.html#a27971954262a2fd1f21d3bf1ba27e87c',1,'neorv32_uart_tx_clear(neorv32_uart_t *UARTx):&#160;neorv32_uart.c']]], + ['neorv32_5fuart_5fvprintf_382',['neorv32_uart_vprintf',['../neorv32__uart_8c.html#a8714cdb1c04d94bec322c6215ea10238',1,'neorv32_uart_vprintf(neorv32_uart_t *UARTx, const char *format, va_list args):&#160;neorv32_uart.c'],['../neorv32__uart_8h.html#a8714cdb1c04d94bec322c6215ea10238',1,'neorv32_uart_vprintf(neorv32_uart_t *UARTx, const char *format, va_list args):&#160;neorv32_uart.c']]], + ['neorv32_5fwdt_383',['NEORV32_WDT',['../neorv32__wdt_8h.html#a78615b08cd799063011606d084fef46c',1,'neorv32_wdt.h']]], + ['neorv32_5fwdt_2ec_384',['neorv32_wdt.c',['../neorv32__wdt_8c.html',1,'']]], + ['neorv32_5fwdt_2eh_385',['neorv32_wdt.h',['../neorv32__wdt_8h.html',1,'']]], + ['neorv32_5fwdt_5favailable_386',['neorv32_wdt_available',['../neorv32__wdt_8c.html#a459a918c5a86c0167e8c748352d39827',1,'neorv32_wdt_available(void):&#160;neorv32_wdt.c'],['../neorv32__wdt_8h.html#a459a918c5a86c0167e8c748352d39827',1,'neorv32_wdt_available(void):&#160;neorv32_wdt.c']]], + ['neorv32_5fwdt_5fbase_387',['NEORV32_WDT_BASE',['../neorv32_8h.html#a3012986cdd5748ee96bcc74cd7108dea',1,'neorv32.h']]], + ['neorv32_5fwdt_5fctrl_5fenum_388',['NEORV32_WDT_CTRL_enum',['../neorv32__wdt_8h.html#a0a4cb24fd818277c5bb9b10ff519f23e',1,'neorv32_wdt.h']]], + ['neorv32_5fwdt_5fdisable_389',['neorv32_wdt_disable',['../neorv32__wdt_8c.html#aba52520582392a671e2b717715a330b2',1,'neorv32_wdt_disable(void):&#160;neorv32_wdt.c'],['../neorv32__wdt_8h.html#aba52520582392a671e2b717715a330b2',1,'neorv32_wdt_disable(void):&#160;neorv32_wdt.c']]], + ['neorv32_5fwdt_5ffeed_390',['neorv32_wdt_feed',['../neorv32__wdt_8c.html#a2e4df2b352d11c31063ef2fc16c510ad',1,'neorv32_wdt_feed(void):&#160;neorv32_wdt.c'],['../neorv32__wdt_8h.html#a2e4df2b352d11c31063ef2fc16c510ad',1,'neorv32_wdt_feed(void):&#160;neorv32_wdt.c']]], + ['neorv32_5fwdt_5fget_5fcause_391',['neorv32_wdt_get_cause',['../neorv32__wdt_8c.html#a80fa8d178d18c9b02d32d93e815b532e',1,'neorv32_wdt_get_cause(void):&#160;neorv32_wdt.c'],['../neorv32__wdt_8h.html#a80fa8d178d18c9b02d32d93e815b532e',1,'neorv32_wdt_get_cause(void):&#160;neorv32_wdt.c']]], + ['neorv32_5fwdt_5frcause_5fenum_392',['NEORV32_WDT_RCAUSE_enum',['../neorv32__wdt_8h.html#a70098b4ee893774864536fb4100ff049',1,'neorv32_wdt.h']]], + ['neorv32_5fwdt_5fsetup_393',['neorv32_wdt_setup',['../neorv32__wdt_8c.html#a2aa72608191d34ef41c5f545988ff400',1,'neorv32_wdt_setup(uint32_t timeout, int lock, int debug_en, int sleep_en, int strict):&#160;neorv32_wdt.c'],['../neorv32__wdt_8h.html#a2aa72608191d34ef41c5f545988ff400',1,'neorv32_wdt_setup(uint32_t timeout, int lock, int debug_en, int sleep_en, int strict):&#160;neorv32_wdt.c']]], + ['neorv32_5fwdt_5ft_394',['neorv32_wdt_t',['../structneorv32__wdt__t.html',1,'']]], + ['neorv32_5fxip_395',['NEORV32_XIP',['../neorv32__xip_8h.html#a3d6f138a347c16883b51069428eb7c1e',1,'neorv32_xip.h']]], + ['neorv32_5fxip_2ec_396',['neorv32_xip.c',['../neorv32__xip_8c.html',1,'']]], + ['neorv32_5fxip_2eh_397',['neorv32_xip.h',['../neorv32__xip_8h.html',1,'']]], + ['neorv32_5fxip_5favailable_398',['neorv32_xip_available',['../neorv32__xip_8c.html#afe2e5682a26cafdb0585d2233bccc7c6',1,'neorv32_xip_available(void):&#160;neorv32_xip.c'],['../neorv32__xip_8h.html#afe2e5682a26cafdb0585d2233bccc7c6',1,'neorv32_xip_available(void):&#160;neorv32_xip.c']]], + ['neorv32_5fxip_5fbase_399',['NEORV32_XIP_BASE',['../neorv32_8h.html#ae0978315beac8399f96f520bda81c7fe',1,'neorv32.h']]], + ['neorv32_5fxip_5fctrl_5fenum_400',['NEORV32_XIP_CTRL_enum',['../neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceb',1,'neorv32_xip.h']]], + ['neorv32_5fxip_5fget_5fclock_5fspeed_401',['neorv32_xip_get_clock_speed',['../neorv32__xip_8c.html#a88f728101e82939bf7f8b9ab5a904706',1,'neorv32_xip_get_clock_speed(void):&#160;neorv32_xip.c'],['../neorv32__xip_8h.html#a88f728101e82939bf7f8b9ab5a904706',1,'neorv32_xip_get_clock_speed(void):&#160;neorv32_xip.c']]], + ['neorv32_5fxip_5fhighspeed_5fdisable_402',['neorv32_xip_highspeed_disable',['../neorv32__xip_8c.html#ad74f2842ed2251e3ae5c19e06dced0c3',1,'neorv32_xip_highspeed_disable(void):&#160;neorv32_xip.c'],['../neorv32__xip_8h.html#ad74f2842ed2251e3ae5c19e06dced0c3',1,'neorv32_xip_highspeed_disable(void):&#160;neorv32_xip.c']]], + ['neorv32_5fxip_5fhighspeed_5fenable_403',['neorv32_xip_highspeed_enable',['../neorv32__xip_8c.html#a6aef2ea29451ba2aa55160da777a5115',1,'neorv32_xip_highspeed_enable(void):&#160;neorv32_xip.c'],['../neorv32__xip_8h.html#a6aef2ea29451ba2aa55160da777a5115',1,'neorv32_xip_highspeed_enable(void):&#160;neorv32_xip.c']]], + ['neorv32_5fxip_5fsetup_404',['neorv32_xip_setup',['../neorv32__xip_8c.html#a549d68abdf5a3d7484abe6d5370bb999',1,'neorv32_xip_setup(int prsc, int cdiv, int cpol, int cpha, uint8_t rd_cmd):&#160;neorv32_xip.c'],['../neorv32__xip_8h.html#a549d68abdf5a3d7484abe6d5370bb999',1,'neorv32_xip_setup(int prsc, int cdiv, int cpol, int cpha, uint8_t rd_cmd):&#160;neorv32_xip.c']]], + ['neorv32_5fxip_5fspi_5ftrans_405',['neorv32_xip_spi_trans',['../neorv32__xip_8c.html#a92f1446a3bb7fe6dee5dbed33882b223',1,'neorv32_xip_spi_trans(int nbytes, uint64_t *rtx_data):&#160;neorv32_xip.c'],['../neorv32__xip_8h.html#a92f1446a3bb7fe6dee5dbed33882b223',1,'neorv32_xip_spi_trans(int nbytes, uint64_t *rtx_data):&#160;neorv32_xip.c']]], + ['neorv32_5fxip_5fstart_406',['neorv32_xip_start',['../neorv32__xip_8c.html#a0ab2c36c973030a811e6d7abe0afc393',1,'neorv32_xip_start(int abytes):&#160;neorv32_xip.c'],['../neorv32__xip_8h.html#a0ab2c36c973030a811e6d7abe0afc393',1,'neorv32_xip_start(int abytes):&#160;neorv32_xip.c']]], + ['neorv32_5fxip_5ft_407',['neorv32_xip_t',['../structneorv32__xip__t.html',1,'']]], + ['neorv32_5fxirq_408',['NEORV32_XIRQ',['../neorv32__xirq_8h.html#a0c0886139e9837867202e5f6a83307c4',1,'neorv32_xirq.h']]], + ['neorv32_5fxirq_2ec_409',['neorv32_xirq.c',['../neorv32__xirq_8c.html',1,'']]], + ['neorv32_5fxirq_2eh_410',['neorv32_xirq.h',['../neorv32__xirq_8h.html',1,'']]], + ['neorv32_5fxirq_5favailable_411',['neorv32_xirq_available',['../neorv32__xirq_8c.html#aaf30757d526030a8d81081915ab29a76',1,'neorv32_xirq_available(void):&#160;neorv32_xirq.c'],['../neorv32__xirq_8h.html#aaf30757d526030a8d81081915ab29a76',1,'neorv32_xirq_available(void):&#160;neorv32_xirq.c']]], + ['neorv32_5fxirq_5fbase_412',['NEORV32_XIRQ_BASE',['../neorv32_8h.html#a942a897be2d4ae6820bee0f7bb3a0ff1',1,'neorv32.h']]], + ['neorv32_5fxirq_5fchannel_5fdisable_413',['neorv32_xirq_channel_disable',['../neorv32__xirq_8c.html#ae17509ad0c828aa9b36747b253cdbf0a',1,'neorv32_xirq_channel_disable(int channel):&#160;neorv32_xirq.c'],['../neorv32__xirq_8h.html#ae17509ad0c828aa9b36747b253cdbf0a',1,'neorv32_xirq_channel_disable(int channel):&#160;neorv32_xirq.c']]], + ['neorv32_5fxirq_5fchannel_5fenable_414',['neorv32_xirq_channel_enable',['../neorv32__xirq_8c.html#abe63c0968c94b472082c8156a1a7db5c',1,'neorv32_xirq_channel_enable(int channel):&#160;neorv32_xirq.c'],['../neorv32__xirq_8h.html#abe63c0968c94b472082c8156a1a7db5c',1,'neorv32_xirq_channel_enable(int channel):&#160;neorv32_xirq.c']]], + ['neorv32_5fxirq_5fclear_5fpending_415',['neorv32_xirq_clear_pending',['../neorv32__xirq_8c.html#a83ecaf568a6f6bcb1e1efdb1eef6df9c',1,'neorv32_xirq_clear_pending(int channel):&#160;neorv32_xirq.c'],['../neorv32__xirq_8h.html#a83ecaf568a6f6bcb1e1efdb1eef6df9c',1,'neorv32_xirq_clear_pending(int channel):&#160;neorv32_xirq.c']]], + ['neorv32_5fxirq_5fget_5fnum_416',['neorv32_xirq_get_num',['../neorv32__xirq_8c.html#a717a8e34908cc01345e68920e76f229c',1,'neorv32_xirq_get_num(void):&#160;neorv32_xirq.c'],['../neorv32__xirq_8h.html#a717a8e34908cc01345e68920e76f229c',1,'neorv32_xirq_get_num(void):&#160;neorv32_xirq.c']]], + ['neorv32_5fxirq_5fglobal_5fdisable_417',['neorv32_xirq_global_disable',['../neorv32__xirq_8c.html#ac64d3ff5619968499bccebebe6a6cab3',1,'neorv32_xirq_global_disable(void):&#160;neorv32_xirq.c'],['../neorv32__xirq_8h.html#ac64d3ff5619968499bccebebe6a6cab3',1,'neorv32_xirq_global_disable(void):&#160;neorv32_xirq.c']]], + ['neorv32_5fxirq_5fglobal_5fenable_418',['neorv32_xirq_global_enable',['../neorv32__xirq_8c.html#a76468156ef52b371e06bc2ca8eddcd27',1,'neorv32_xirq_global_enable(void):&#160;neorv32_xirq.c'],['../neorv32__xirq_8h.html#a76468156ef52b371e06bc2ca8eddcd27',1,'neorv32_xirq_global_enable(void):&#160;neorv32_xirq.c']]], + ['neorv32_5fxirq_5finstall_419',['neorv32_xirq_install',['../neorv32__xirq_8c.html#a9129984f91c02afafaa072a5d86f9876',1,'neorv32_xirq_install(int channel, void(*handler)(void)):&#160;neorv32_xirq.c'],['../neorv32__xirq_8h.html#a9129984f91c02afafaa072a5d86f9876',1,'neorv32_xirq_install(int channel, void(*handler)(void)):&#160;neorv32_xirq.c']]], + ['neorv32_5fxirq_5fsetup_420',['neorv32_xirq_setup',['../neorv32__xirq_8c.html#a9295997fce7114a8205325c4d75dd200',1,'neorv32_xirq_setup(void):&#160;neorv32_xirq.c'],['../neorv32__xirq_8h.html#a9295997fce7114a8205325c4d75dd200',1,'neorv32_xirq_setup(void):&#160;neorv32_xirq.c']]], + ['neorv32_5fxirq_5fsetup_5ftrigger_421',['neorv32_xirq_setup_trigger',['../neorv32__xirq_8c.html#a0d137f09d1e7dcd31c157b856033ac42',1,'neorv32_xirq_setup_trigger(int channel, int config):&#160;neorv32_xirq.c'],['../neorv32__xirq_8h.html#a0d137f09d1e7dcd31c157b856033ac42',1,'neorv32_xirq_setup_trigger(int channel, int config):&#160;neorv32_xirq.c']]], + ['neorv32_5fxirq_5ft_422',['neorv32_xirq_t',['../structneorv32__xirq__t.html',1,'']]], + ['neorv32_5fxirq_5funinstall_423',['neorv32_xirq_uninstall',['../neorv32__xirq_8c.html#a49ae67d1d5066cd795149e96b81127f7',1,'neorv32_xirq_uninstall(int channel):&#160;neorv32_xirq.c'],['../neorv32__xirq_8h.html#a49ae67d1d5066cd795149e96b81127f7',1,'neorv32_xirq_uninstall(int channel):&#160;neorv32_xirq.c']]], + ['neorv32_5fzfinx_5fextension_5fintrinsics_2eh_424',['neorv32_zfinx_extension_intrinsics.h',['../floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html',1,'']]], + ['num_5fcells_5fx_425',['NUM_CELLS_X',['../game__of__life_2main_8c.html#a78c5b500f0f057bcaedf6fedeca7c537',1,'main.c']]], + ['num_5fcells_5fy_426',['NUM_CELLS_Y',['../game__of__life_2main_8c.html#aed77778557404b38bebb05b5830368b4',1,'main.c']]], + ['num_5fleds_5f24bit_427',['NUM_LEDS_24BIT',['../demo__neopixel_2main_8c.html#aa1dddb8d6b3b4d2f19afc3c09e2ff572',1,'main.c']]], + ['num_5ftest_5fcases_428',['NUM_TEST_CASES',['../atomic__test_2main_8c.html#a83792c34853f1d2801b59ad46adc7e1e',1,'NUM_TEST_CASES:&#160;main.c'],['../float__corner__test_2main_8c.html#a83792c34853f1d2801b59ad46adc7e1e',1,'NUM_TEST_CASES:&#160;main.c'],['../floating__point__test_2main_8c.html#a83792c34853f1d2801b59ad46adc7e1e',1,'NUM_TEST_CASES:&#160;main.c']]] +]; diff --git a/sw/search/all_14.js b/sw/search/all_14.js new file mode 100644 index 0000000000..d74d0dbc09 --- /dev/null +++ b/sw/search/all_14.js @@ -0,0 +1,28 @@ +var searchData= +[ + ['onewire_5fctrl_5fbusy_0',['ONEWIRE_CTRL_BUSY',['../neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831aac8933755e80d72e1e9c293198d831b9',1,'neorv32_onewire.h']]], + ['onewire_5fctrl_5fclkdiv0_1',['ONEWIRE_CTRL_CLKDIV0',['../neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831acdfca08f34d7379aaf8505ba3425c6f5',1,'neorv32_onewire.h']]], + ['onewire_5fctrl_5fclkdiv1_2',['ONEWIRE_CTRL_CLKDIV1',['../neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831afa1476a5e04eb4eabf4d7a595eca2df9',1,'neorv32_onewire.h']]], + ['onewire_5fctrl_5fclkdiv2_3',['ONEWIRE_CTRL_CLKDIV2',['../neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831aec9f056072e1db747e74a5c695d2a1df',1,'neorv32_onewire.h']]], + ['onewire_5fctrl_5fclkdiv3_4',['ONEWIRE_CTRL_CLKDIV3',['../neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831ab8600bd09d74e39869259881b84ebfbf',1,'neorv32_onewire.h']]], + ['onewire_5fctrl_5fclkdiv4_5',['ONEWIRE_CTRL_CLKDIV4',['../neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831a32af8c86e7166e02e801727bd261c179',1,'neorv32_onewire.h']]], + ['onewire_5fctrl_5fclkdiv5_6',['ONEWIRE_CTRL_CLKDIV5',['../neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831a789d65fd9b0ab17bffd0d6de9d2e132a',1,'neorv32_onewire.h']]], + ['onewire_5fctrl_5fclkdiv6_7',['ONEWIRE_CTRL_CLKDIV6',['../neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831a27f040454bebc6218b490f7160ea2312',1,'neorv32_onewire.h']]], + ['onewire_5fctrl_5fclkdiv7_8',['ONEWIRE_CTRL_CLKDIV7',['../neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831a8b19096f72ef96a7597fda9be625ed40',1,'neorv32_onewire.h']]], + ['onewire_5fctrl_5fen_9',['ONEWIRE_CTRL_EN',['../neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831ab87882c202f80185278c69e482f147da',1,'neorv32_onewire.h']]], + ['onewire_5fctrl_5fpresence_10',['ONEWIRE_CTRL_PRESENCE',['../neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831a92e1ff9fa10319d64c8d2c6a6d61b37e',1,'neorv32_onewire.h']]], + ['onewire_5fctrl_5fprsc0_11',['ONEWIRE_CTRL_PRSC0',['../neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831abfed6417c3abd7ef94cd18a3b32c4393',1,'neorv32_onewire.h']]], + ['onewire_5fctrl_5fprsc1_12',['ONEWIRE_CTRL_PRSC1',['../neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831aee1e24261e263c70bf2e36dcafc9dc74',1,'neorv32_onewire.h']]], + ['onewire_5fctrl_5fsense_13',['ONEWIRE_CTRL_SENSE',['../neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831af992c94d0b9a7b7b92a5a23366b9a8c6',1,'neorv32_onewire.h']]], + ['onewire_5fctrl_5ftrig_5fbit_14',['ONEWIRE_CTRL_TRIG_BIT',['../neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831a7ecbccef9e77e68caf22ed2c416e1f77',1,'neorv32_onewire.h']]], + ['onewire_5fctrl_5ftrig_5fbyte_15',['ONEWIRE_CTRL_TRIG_BYTE',['../neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831acfd8a56f668ca55dbbaa1714b1235dfe',1,'neorv32_onewire.h']]], + ['onewire_5fctrl_5ftrig_5frst_16',['ONEWIRE_CTRL_TRIG_RST',['../neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831a98624ec944e0413a208cdf54bbbf4c75',1,'neorv32_onewire.h']]], + ['onewire_5fdata_5flsb_17',['ONEWIRE_DATA_LSB',['../neorv32__onewire_8h.html#ae770490afa8662fb8577065531d51368a6ad35475e3f80a8c68ce0caa9c3754a5',1,'neorv32_onewire.h']]], + ['onewire_5fdata_5fmsb_18',['ONEWIRE_DATA_MSB',['../neorv32__onewire_8h.html#ae770490afa8662fb8577065531d51368af967429634efb019ada46bf75f373aa3',1,'neorv32_onewire.h']]], + ['onewire_5ffirq_5fenable_19',['ONEWIRE_FIRQ_ENABLE',['../neorv32_8h.html#a8bb1918679e32e898af2d485cfa44afb',1,'neorv32.h']]], + ['onewire_5ffirq_5fpending_20',['ONEWIRE_FIRQ_PENDING',['../neorv32_8h.html#a3853ef999f99ca062e6025038811d0f0',1,'neorv32.h']]], + ['onewire_5frte_5fid_21',['ONEWIRE_RTE_ID',['../neorv32_8h.html#a142f4a1c754edfab292706618d427b94',1,'neorv32.h']]], + ['onewire_5ftrap_5fcode_22',['ONEWIRE_TRAP_CODE',['../neorv32_8h.html#a3e7aaa405a7d1fcd71a36c4b6b5a4081',1,'neorv32.h']]], + ['output_23',['OUTPUT',['../structneorv32__gpio__t.html#abaf7de4f79adfc3debcde93fa4a921bb',1,'neorv32_gpio_t']]], + ['overview_24',['1. Overview',['../md_README.html#autotoc_md1',1,'']]] +]; diff --git a/sw/search/all_15.js b/sw/search/all_15.js new file mode 100644 index 0000000000..1c38806efe --- /dev/null +++ b/sw/search/all_15.js @@ -0,0 +1,39 @@ +var searchData= +[ + ['performance_0',['4. Performance',['../md_README.html#autotoc_md6',1,'']]], + ['plain_5fdata_5fhw_1',['plain_data_hw',['../demo__cfu_2main_8c.html#aee8dde13fe2f5ac52dd6075e2fe1eab5',1,'main.c']]], + ['plain_5fdata_5fsw_2',['plain_data_sw',['../demo__cfu_2main_8c.html#a72ba1460776ad684028448ca51810bbe',1,'main.c']]], + ['pmp_5fna4_3',['PMP_NA4',['../neorv32__cpu__csr_8h.html#a8f2418fb5e2175f35ee2362469ce01f5aae0e0c33b0d034cb50286239f955d892',1,'neorv32_cpu_csr.h']]], + ['pmp_5fnapot_4',['PMP_NAPOT',['../neorv32__cpu__csr_8h.html#a8f2418fb5e2175f35ee2362469ce01f5ad555e9dfc0c00612bdea623617ff2820',1,'neorv32_cpu_csr.h']]], + ['pmp_5foff_5',['PMP_OFF',['../neorv32__cpu__csr_8h.html#a8f2418fb5e2175f35ee2362469ce01f5a003ccfae4aae1dad4fd65d5d4c7737c4',1,'neorv32_cpu_csr.h']]], + ['pmp_5ftor_6',['PMP_TOR',['../neorv32__cpu__csr_8h.html#a8f2418fb5e2175f35ee2362469ce01f5a629a81a205abee94bad9d5bb5dfa26b1',1,'neorv32_cpu_csr.h']]], + ['pmpcfg_5fa_5flsb_7',['PMPCFG_A_LSB',['../neorv32__cpu__csr_8h.html#abc0e8daad1e9beda4d9950452cc930eaaae1e6440956ad6b7cbf6062aa50f43b1',1,'neorv32_cpu_csr.h']]], + ['pmpcfg_5fa_5fmsb_8',['PMPCFG_A_MSB',['../neorv32__cpu__csr_8h.html#abc0e8daad1e9beda4d9950452cc930eaa67ad3243eeb74f86a01efbade76f21e4',1,'neorv32_cpu_csr.h']]], + ['pmpcfg_5fl_9',['PMPCFG_L',['../neorv32__cpu__csr_8h.html#abc0e8daad1e9beda4d9950452cc930eaa59c294bc43d2117bb55e301eec683f14',1,'neorv32_cpu_csr.h']]], + ['pmpcfg_5fr_10',['PMPCFG_R',['../neorv32__cpu__csr_8h.html#abc0e8daad1e9beda4d9950452cc930eaad3aca82a2ab57364e83f677d3d4f71a6',1,'neorv32_cpu_csr.h']]], + ['pmpcfg_5fw_11',['PMPCFG_W',['../neorv32__cpu__csr_8h.html#abc0e8daad1e9beda4d9950452cc930eaa7689905760f917499b1151cced384d2f',1,'neorv32_cpu_csr.h']]], + ['pmpcfg_5fx_12',['PMPCFG_X',['../neorv32__cpu__csr_8h.html#abc0e8daad1e9beda4d9950452cc930eaaec94712deafba09c0cf956c6fd68fa8d',1,'neorv32_cpu_csr.h']]], + ['poly_13',['POLY',['../structneorv32__crc__t.html#a9bbcab843ddba4f9772d07478947a661',1,'neorv32_crc_t']]], + ['pop_5fcount_14',['pop_count',['../game__of__life_2main_8c.html#aac4bec7738b12f5a4b4d7a3a6cb1ab8d',1,'main.c']]], + ['print_5fgetc_15',['PRINT_GETC',['../bootloader_8c.html#a999b04603115ce08b0cb33e333312480',1,'bootloader.c']]], + ['print_5fhelp_16',['print_help',['../bootloader_8c.html#a402ea961bfc2ffeee61e3a7c330b1559',1,'bootloader.c']]], + ['print_5fhex_5fbyte_17',['print_hex_byte',['../demo__twi_2main_8c.html#a2ebc688bc1dad328693fc0974b378fa0',1,'main.c']]], + ['print_5fhex_5fword_18',['print_hex_word',['../bootloader_8c.html#a70b7d5c3b3ae97e4e72e84c4bc28fb8a',1,'bootloader.c']]], + ['print_5fputc_19',['PRINT_PUTC',['../bootloader_8c.html#aa7afbe8348ebd1a876a4d247553292e9',1,'bootloader.c']]], + ['print_5frandom_5fdata_20',['print_random_data',['../demo__trng_2main_8c.html#a64205d97b57c99dc5e95b8621827f4a4',1,'main.c']]], + ['print_5freport_21',['print_report',['../atomic__test_2main_8c.html#a99377a057d14aaa9b45f8cab890e8cf7',1,'print_report(int num_err, int num_tests):&#160;main.c'],['../float__corner__test_2main_8c.html#a1740720aa8ce1a30fcf642be9140d203',1,'print_report(uint32_t num_err):&#160;main.c'],['../floating__point__test_2main_8c.html#a1740720aa8ce1a30fcf642be9140d203',1,'print_report(uint32_t num_err):&#160;main.c']]], + ['print_5ftext_22',['PRINT_TEXT',['../bootloader_8c.html#a0e5a66f68ecc7a6f42088f349707e852',1,'bootloader.c']]], + ['print_5funiverse_23',['print_universe',['../game__of__life_2main_8c.html#a9a455dea83a25f656fcc5217ad513dac',1,'main.c']]], + ['print_5fxnum_24',['PRINT_XNUM',['../bootloader_8c.html#a2f5cc04cf9c85f5d2958b384e053053b',1,'bootloader.c']]], + ['processor_25',['The NEORV32 RISC-V Processor',['../md_README.html#autotoc_md0',1,'']]], + ['processor_20a_20the_20soc_26',[':desktop_computer: &lt;a href=&quot;https://stnolting.github.io/neorv32/#_neorv32_processor_soc&quot; &gt;NEORV32 Processor&lt;/a&gt; - The SoC',['../md_README.html#autotoc_md9',1,'']]], + ['project_20a_20an_20introduction_27',[':mag: &lt;a href=&quot;https://stnolting.github.io/neorv32/#_overview&quot; &gt;NEORV32 Project&lt;/a&gt; - An Introduction',['../md_README.html#autotoc_md8',1,'']]], + ['project_20status_28',['Project Status',['../md_README.html#autotoc_md3',1,'']]], + ['ptrspibuf_29',['ptrSpiBuf',['../structt__neorv32__spi.html#a487a6510820871ff8d0da7699463f6d9',1,'t_neorv32_spi']]], + ['putchar_30',['putchar',['../neorv32__uart_8c.html#a07036e93939040c563e862a6a31b65bc',1,'neorv32_uart.c']]], + ['pwm_5fctrl_5fen_31',['PWM_CTRL_EN',['../neorv32__pwm_8h.html#af350f93b601a92ef56516198d1570b7dafb99fba508460086efdd495d4649c65a',1,'neorv32_pwm.h']]], + ['pwm_5fctrl_5fprsc0_32',['PWM_CTRL_PRSC0',['../neorv32__pwm_8h.html#af350f93b601a92ef56516198d1570b7da01ab6de6ac34be1ed68f22e17acbe274',1,'neorv32_pwm.h']]], + ['pwm_5fctrl_5fprsc1_33',['PWM_CTRL_PRSC1',['../neorv32__pwm_8h.html#af350f93b601a92ef56516198d1570b7daa6fca8a4eecfb99b8f0fa99e187e30bb',1,'neorv32_pwm.h']]], + ['pwm_5fctrl_5fprsc2_34',['PWM_CTRL_PRSC2',['../neorv32__pwm_8h.html#af350f93b601a92ef56516198d1570b7da0fd36a63fd4c37ef3bc4732518ebf13d',1,'neorv32_pwm.h']]], + ['pwm_5fmax_35',['PWM_MAX',['../demo__pwm_2main_8c.html#a391fa1e490bd712720989b58fa0d9904',1,'main.c']]] +]; diff --git a/sw/search/all_16.js b/sw/search/all_16.js new file mode 100644 index 0000000000..c7d58cd92b --- /dev/null +++ b/sw/search/all_16.js @@ -0,0 +1,103 @@ +var searchData= +[ + ['ram_5fbuffer_0',['ram_buffer',['../demo__xip_2main_8c.html#acc95e55a622d79c2a398397d1f9b8033',1,'main.c']]], + ['read_5fbyte_1',['read_byte',['../demo__onewire_2main_8c.html#a951a31029af34715f20856eb82432637',1,'main.c']]], + ['read_5fmemory_2',['read_memory',['../bus__explorer_2main_8c.html#afc9b1ab3db46eccf51d55c715fa2fbd4',1,'main.c']]], + ['readme_3',['README',['../md_README.html',1,'']]], + ['record_4',['record',['../structrecord.html',1,'']]], + ['reg_5',['REG',['../structneorv32__cfs__t.html#a48d3e81b207f4dcce0b0cc901583dc4d',1,'neorv32_cfs_t']]], + ['repetition_5fcount_5ftest_6',['repetition_count_test',['../demo__trng_2main_8c.html#af37eae672fee5e81f00a1dbf51b7e417',1,'main.c']]], + ['reserved_7',['reserved',['../structneorv32__xip__t.html#aacb77d586c3caec518e8e0024cfe745c',1,'neorv32_xip_t']]], + ['reserved0_8',['reserved0',['../structneorv32__xirq__t.html#a9be02c0398fab5763a3afbd7a018f092',1,'neorv32_xirq_t']]], + ['reserved1_9',['reserved1',['../structneorv32__xirq__t.html#ac4c999cf3da75e39753619f917d9d654',1,'neorv32_xirq_t']]], + ['reserved2_10',['reserved2',['../structneorv32__xirq__t.html#afba6ed500e1448719783923975b2dc64',1,'neorv32_xirq_t']]], + ['reset_11',['RESET',['../structneorv32__wdt__t.html#a0a273e8ca2bd92547bf7727ec65a9449',1,'neorv32_wdt_t']]], + ['results_12',['3. FPGA Implementation Results',['../md_README.html#autotoc_md5',1,'']]], + ['risc_20v_20processor_13',['The NEORV32 RISC-V Processor',['../md_README.html#autotoc_md0',1,'']]], + ['riscv_5femulate_5ffadds_14',['riscv_emulate_fadds',['../floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a9d676567276439875c9b1a15b892b555',1,'neorv32_zfinx_extension_intrinsics.h']]], + ['riscv_5femulate_5ffclasss_15',['riscv_emulate_fclasss',['../floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#ae41a0bf9d28c35f4d6db7177ccf8ee06',1,'neorv32_zfinx_extension_intrinsics.h']]], + ['riscv_5femulate_5ffcvt_5fsw_16',['riscv_emulate_fcvt_sw',['../floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a0f2260b7b5793a95c49670379fc89617',1,'neorv32_zfinx_extension_intrinsics.h']]], + ['riscv_5femulate_5ffcvt_5fswu_17',['riscv_emulate_fcvt_swu',['../floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a10a05bface37bff32c78ed0746845794',1,'neorv32_zfinx_extension_intrinsics.h']]], + ['riscv_5femulate_5ffcvt_5fws_18',['riscv_emulate_fcvt_ws',['../floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a292365fe41a7a661e61ae746306ba5e9',1,'neorv32_zfinx_extension_intrinsics.h']]], + ['riscv_5femulate_5ffcvt_5fwus_19',['riscv_emulate_fcvt_wus',['../floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#aad9fc7337e09081cf8c5bff8c28776c8',1,'neorv32_zfinx_extension_intrinsics.h']]], + ['riscv_5femulate_5ffdivs_20',['riscv_emulate_fdivs',['../floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#aeaf46a17b671278be2bf804159827a40',1,'neorv32_zfinx_extension_intrinsics.h']]], + ['riscv_5femulate_5ffeqs_21',['riscv_emulate_feqs',['../floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a7cb3c6570b911cd1dfb7b6e798cc1d21',1,'neorv32_zfinx_extension_intrinsics.h']]], + ['riscv_5femulate_5ffles_22',['riscv_emulate_fles',['../floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#ac5fdef0607602fa0bdb93b3535fd709e',1,'neorv32_zfinx_extension_intrinsics.h']]], + ['riscv_5femulate_5fflts_23',['riscv_emulate_flts',['../floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a2b802122d53a2ce517b3d39fec34d7e0',1,'neorv32_zfinx_extension_intrinsics.h']]], + ['riscv_5femulate_5ffmadds_24',['riscv_emulate_fmadds',['../floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a39212f2e2bb0f1752092a1732f93edf3',1,'neorv32_zfinx_extension_intrinsics.h']]], + ['riscv_5femulate_5ffmaxs_25',['riscv_emulate_fmaxs',['../floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#af9b16a32d2bb13c8af5a678271d74889',1,'neorv32_zfinx_extension_intrinsics.h']]], + ['riscv_5femulate_5ffmins_26',['riscv_emulate_fmins',['../floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a872cd30fb61190bd1ac719d25b01f5a3',1,'neorv32_zfinx_extension_intrinsics.h']]], + ['riscv_5femulate_5ffmsubs_27',['riscv_emulate_fmsubs',['../floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a05d0d5a8eb9422e93448efdeb679cabf',1,'neorv32_zfinx_extension_intrinsics.h']]], + ['riscv_5femulate_5ffmuls_28',['riscv_emulate_fmuls',['../floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#ad43e8bdf4a6fbe229d22d24680f2be80',1,'neorv32_zfinx_extension_intrinsics.h']]], + ['riscv_5femulate_5ffnmadds_29',['riscv_emulate_fnmadds',['../floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#ac8bb4450b39854ab07839e8f3505361c',1,'neorv32_zfinx_extension_intrinsics.h']]], + ['riscv_5femulate_5ffnmsubs_30',['riscv_emulate_fnmsubs',['../floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a833638b346722dfa9d7d5c8d60998ec8',1,'neorv32_zfinx_extension_intrinsics.h']]], + ['riscv_5femulate_5ffsgnjns_31',['riscv_emulate_fsgnjns',['../floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a0c985e626ed1d69314f4e3a0f1f58624',1,'neorv32_zfinx_extension_intrinsics.h']]], + ['riscv_5femulate_5ffsgnjs_32',['riscv_emulate_fsgnjs',['../floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a12498d635f422f607b9b83facf3050dd',1,'neorv32_zfinx_extension_intrinsics.h']]], + ['riscv_5femulate_5ffsgnjxs_33',['riscv_emulate_fsgnjxs',['../floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a98caf7f310820052ae96ce0f45e6cd26',1,'neorv32_zfinx_extension_intrinsics.h']]], + ['riscv_5femulate_5ffsqrts_34',['riscv_emulate_fsqrts',['../floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a1ceb3450f1e5c62d3079cd0e93c03501',1,'neorv32_zfinx_extension_intrinsics.h']]], + ['riscv_5femulate_5ffsubs_35',['riscv_emulate_fsubs',['../floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#ace5d95b855ec1aa8eacdb5bbeea58197',1,'neorv32_zfinx_extension_intrinsics.h']]], + ['riscv_5fintrinsic_5ffadds_36',['riscv_intrinsic_fadds',['../floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a4b151fcb252fc7b894f247f5af6a1809',1,'neorv32_zfinx_extension_intrinsics.h']]], + ['riscv_5fintrinsic_5ffclasss_37',['riscv_intrinsic_fclasss',['../floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a3064a5c57b5f45d57c4d19eb798724f6',1,'neorv32_zfinx_extension_intrinsics.h']]], + ['riscv_5fintrinsic_5ffcvt_5fsw_38',['riscv_intrinsic_fcvt_sw',['../floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a2103eb86052f6f8e24a8a848ffc6528a',1,'neorv32_zfinx_extension_intrinsics.h']]], + ['riscv_5fintrinsic_5ffcvt_5fswu_39',['riscv_intrinsic_fcvt_swu',['../floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a837b7330f9d568791687ae1384b8ef28',1,'neorv32_zfinx_extension_intrinsics.h']]], + ['riscv_5fintrinsic_5ffcvt_5fws_40',['riscv_intrinsic_fcvt_ws',['../floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a523fa0fb6f521311c7f44692c586b3ee',1,'neorv32_zfinx_extension_intrinsics.h']]], + ['riscv_5fintrinsic_5ffcvt_5fwus_41',['riscv_intrinsic_fcvt_wus',['../floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a3bc6ee3059a7e99b187c4ea5e217715b',1,'neorv32_zfinx_extension_intrinsics.h']]], + ['riscv_5fintrinsic_5ffdivs_42',['riscv_intrinsic_fdivs',['../floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#ab6a9d15643e3085ff80c7883f183a42b',1,'neorv32_zfinx_extension_intrinsics.h']]], + ['riscv_5fintrinsic_5ffeqs_43',['riscv_intrinsic_feqs',['../floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#af4ddfae45807d4e41f758672ee14cf7b',1,'neorv32_zfinx_extension_intrinsics.h']]], + ['riscv_5fintrinsic_5ffles_44',['riscv_intrinsic_fles',['../floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#adb83fab39d91e9291da2b7b07830cf82',1,'neorv32_zfinx_extension_intrinsics.h']]], + ['riscv_5fintrinsic_5fflts_45',['riscv_intrinsic_flts',['../floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a85aa18294a58997db2c324184196669c',1,'neorv32_zfinx_extension_intrinsics.h']]], + ['riscv_5fintrinsic_5ffmadds_46',['riscv_intrinsic_fmadds',['../floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#abbdb403cdeef414fa2f867b702d5f6eb',1,'neorv32_zfinx_extension_intrinsics.h']]], + ['riscv_5fintrinsic_5ffmaxs_47',['riscv_intrinsic_fmaxs',['../floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a87c1ce499e5e43554cb0f407cf0d3f7f',1,'neorv32_zfinx_extension_intrinsics.h']]], + ['riscv_5fintrinsic_5ffmins_48',['riscv_intrinsic_fmins',['../floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#abf7f9e466906306d9755fd5bc7946e3c',1,'neorv32_zfinx_extension_intrinsics.h']]], + ['riscv_5fintrinsic_5ffmsubs_49',['riscv_intrinsic_fmsubs',['../floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a03aba9c70c5286dacebaeb0ef5219cc9',1,'neorv32_zfinx_extension_intrinsics.h']]], + ['riscv_5fintrinsic_5ffmuls_50',['riscv_intrinsic_fmuls',['../floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a87a106e0d24a3183712e438d2bcbfa2d',1,'neorv32_zfinx_extension_intrinsics.h']]], + ['riscv_5fintrinsic_5ffnmadds_51',['riscv_intrinsic_fnmadds',['../floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#aa6473bc2d2721b57277b83a3ae0cfdb6',1,'neorv32_zfinx_extension_intrinsics.h']]], + ['riscv_5fintrinsic_5ffnmsubs_52',['riscv_intrinsic_fnmsubs',['../floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a639fc7bd75933888540e9cceb67221a0',1,'neorv32_zfinx_extension_intrinsics.h']]], + ['riscv_5fintrinsic_5ffsgnjns_53',['riscv_intrinsic_fsgnjns',['../floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#aa4010772a986d03929ba7a43dfdcddd9',1,'neorv32_zfinx_extension_intrinsics.h']]], + ['riscv_5fintrinsic_5ffsgnjs_54',['riscv_intrinsic_fsgnjs',['../floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#aff3acd90bcfbda96945f95a0e0bae12b',1,'neorv32_zfinx_extension_intrinsics.h']]], + ['riscv_5fintrinsic_5ffsgnjxs_55',['riscv_intrinsic_fsgnjxs',['../floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a2235d91cdac03bf8071003a5c59b9dd0',1,'neorv32_zfinx_extension_intrinsics.h']]], + ['riscv_5fintrinsic_5ffsqrts_56',['riscv_intrinsic_fsqrts',['../floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a17e2b7a399c956d548a609185084ea3c',1,'neorv32_zfinx_extension_intrinsics.h']]], + ['riscv_5fintrinsic_5ffsubs_57',['riscv_intrinsic_fsubs',['../floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#af8473ba61abab8ae2e3ecbaf22d70e89',1,'neorv32_zfinx_extension_intrinsics.h']]], + ['route_58',['ROUTE',['../structneorv32__slink__t.html#a0b2417a1a587da45909ce2a948f90e22',1,'neorv32_slink_t']]], + ['rte_5fservice_5fhandler_59',['rte_service_handler',['../processor__check_2main_8c.html#a349743a03307abb5130a3e89d903971b',1,'main.c']]], + ['rte_5ftrap_5fbreakpoint_60',['RTE_TRAP_BREAKPOINT',['../neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa463611404367b5910c42dd31c0a218a2',1,'neorv32_rte.h']]], + ['rte_5ftrap_5ffirq_5f0_61',['RTE_TRAP_FIRQ_0',['../neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aab36a403cd7b833439ce7f9a708c33922',1,'neorv32_rte.h']]], + ['rte_5ftrap_5ffirq_5f1_62',['RTE_TRAP_FIRQ_1',['../neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aab199b53a1458017fa5278e0aeecf41fd',1,'neorv32_rte.h']]], + ['rte_5ftrap_5ffirq_5f10_63',['RTE_TRAP_FIRQ_10',['../neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aadebcc4d91aea1364b1481111f1060c52',1,'neorv32_rte.h']]], + ['rte_5ftrap_5ffirq_5f11_64',['RTE_TRAP_FIRQ_11',['../neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aab49ff0110481f22da22a085d2633a0e0',1,'neorv32_rte.h']]], + ['rte_5ftrap_5ffirq_5f12_65',['RTE_TRAP_FIRQ_12',['../neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aaecea4f1d524a33d02324382357b2bcb9',1,'neorv32_rte.h']]], + ['rte_5ftrap_5ffirq_5f13_66',['RTE_TRAP_FIRQ_13',['../neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa609613cf25bb8f2d0e323089d6798220',1,'neorv32_rte.h']]], + ['rte_5ftrap_5ffirq_5f14_67',['RTE_TRAP_FIRQ_14',['../neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aaadd66d9b9c33a6869fa3c30e1e434313',1,'neorv32_rte.h']]], + ['rte_5ftrap_5ffirq_5f15_68',['RTE_TRAP_FIRQ_15',['../neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa1d18312227bfd5332ebcc1f74c979dbe',1,'neorv32_rte.h']]], + ['rte_5ftrap_5ffirq_5f2_69',['RTE_TRAP_FIRQ_2',['../neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa29ffa3108fadc78bf375773c3232c489',1,'neorv32_rte.h']]], + ['rte_5ftrap_5ffirq_5f3_70',['RTE_TRAP_FIRQ_3',['../neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa4a74188fd87ea17a594ac6fe8ddf71be',1,'neorv32_rte.h']]], + ['rte_5ftrap_5ffirq_5f4_71',['RTE_TRAP_FIRQ_4',['../neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa8b39868bf91da54f9ec492918e0c01ff',1,'neorv32_rte.h']]], + ['rte_5ftrap_5ffirq_5f5_72',['RTE_TRAP_FIRQ_5',['../neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa01f562418ddbbb6b84be168673deeea9',1,'neorv32_rte.h']]], + ['rte_5ftrap_5ffirq_5f6_73',['RTE_TRAP_FIRQ_6',['../neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aac9fb28ea8bafff182f12c29d2fad6998',1,'neorv32_rte.h']]], + ['rte_5ftrap_5ffirq_5f7_74',['RTE_TRAP_FIRQ_7',['../neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa73bb84f7b6c7528bec552ac1d3e9ccdb',1,'neorv32_rte.h']]], + ['rte_5ftrap_5ffirq_5f8_75',['RTE_TRAP_FIRQ_8',['../neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa3edbf47bd9a278e100bb808c8bb68308',1,'neorv32_rte.h']]], + ['rte_5ftrap_5ffirq_5f9_76',['RTE_TRAP_FIRQ_9',['../neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa2cd04189d91465dad2bc2a8852406b76',1,'neorv32_rte.h']]], + ['rte_5ftrap_5fi_5faccess_77',['RTE_TRAP_I_ACCESS',['../neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa931a4f314b04233924b01e8245153be4',1,'neorv32_rte.h']]], + ['rte_5ftrap_5fi_5fillegal_78',['RTE_TRAP_I_ILLEGAL',['../neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa48f4d253b260784a1ffaaded508166e2',1,'neorv32_rte.h']]], + ['rte_5ftrap_5fi_5fmisaligned_79',['RTE_TRAP_I_MISALIGNED',['../neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aaf647ff8d55d021379202879627c91d81',1,'neorv32_rte.h']]], + ['rte_5ftrap_5fl_5faccess_80',['RTE_TRAP_L_ACCESS',['../neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa97047b024b72807a0b312979c9359dab',1,'neorv32_rte.h']]], + ['rte_5ftrap_5fl_5fmisaligned_81',['RTE_TRAP_L_MISALIGNED',['../neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa8e2cc9a533ebbc0e1d29c3ec8afbe61f',1,'neorv32_rte.h']]], + ['rte_5ftrap_5fmei_82',['RTE_TRAP_MEI',['../neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aad2a55d5586d33497fd21b1da8aa98fff',1,'neorv32_rte.h']]], + ['rte_5ftrap_5fmenv_5fcall_83',['RTE_TRAP_MENV_CALL',['../neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aaea6027bf0354c3120fa61c8094dd7a1d',1,'neorv32_rte.h']]], + ['rte_5ftrap_5fmsi_84',['RTE_TRAP_MSI',['../neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aadddffa9acdfcce80dd68ad4b26725174',1,'neorv32_rte.h']]], + ['rte_5ftrap_5fmti_85',['RTE_TRAP_MTI',['../neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aacf17d4b2454c43a1cb544e532d247fff',1,'neorv32_rte.h']]], + ['rte_5ftrap_5fs_5faccess_86',['RTE_TRAP_S_ACCESS',['../neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aaa9b8334712ecad0500c7610a25741ec7',1,'neorv32_rte.h']]], + ['rte_5ftrap_5fs_5fmisaligned_87',['RTE_TRAP_S_MISALIGNED',['../neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa85934b3fd8b5268340f84810b3f67232',1,'neorv32_rte.h']]], + ['rte_5ftrap_5fuenv_5fcall_88',['RTE_TRAP_UENV_CALL',['../neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa155f84a52bace69f81a99de59701decc',1,'neorv32_rte.h']]], + ['run_5faddsub_5ftests_89',['RUN_ADDSUB_TESTS',['../float__corner__test_2main_8c.html#a2d16b9e484b7af7897c7ae83f945ceca',1,'RUN_ADDSUB_TESTS:&#160;main.c'],['../floating__point__test_2main_8c.html#a2d16b9e484b7af7897c7ae83f945ceca',1,'RUN_ADDSUB_TESTS:&#160;main.c']]], + ['run_5fclassify_5ftests_90',['RUN_CLASSIFY_TESTS',['../float__corner__test_2main_8c.html#a7e134923925fa24fd1090281c3a416c3',1,'RUN_CLASSIFY_TESTS:&#160;main.c'],['../floating__point__test_2main_8c.html#a7e134923925fa24fd1090281c3a416c3',1,'RUN_CLASSIFY_TESTS:&#160;main.c']]], + ['run_5fcompare_5ftests_91',['RUN_COMPARE_TESTS',['../float__corner__test_2main_8c.html#a4ee0f6d28896a97d2c0cad866e77b874',1,'RUN_COMPARE_TESTS:&#160;main.c'],['../floating__point__test_2main_8c.html#a4ee0f6d28896a97d2c0cad866e77b874',1,'RUN_COMPARE_TESTS:&#160;main.c']]], + ['run_5fconv_5ftests_92',['RUN_CONV_TESTS',['../float__corner__test_2main_8c.html#aa3b6c4d49be7372de9e771a0475306ac',1,'RUN_CONV_TESTS:&#160;main.c'],['../floating__point__test_2main_8c.html#aa3b6c4d49be7372de9e771a0475306ac',1,'RUN_CONV_TESTS:&#160;main.c']]], + ['run_5fcsr_5ftests_93',['RUN_CSR_TESTS',['../floating__point__test_2main_8c.html#a7ec330b668b5b24d666d7769ccecfee3',1,'main.c']]], + ['run_5fexc_5ftests_94',['RUN_EXC_TESTS',['../floating__point__test_2main_8c.html#a1a1af220e72c69b03d13b2df53650e10',1,'main.c']]], + ['run_5fminmax_5ftests_95',['RUN_MINMAX_TESTS',['../float__corner__test_2main_8c.html#aed386f612417aeeeac8b08db27d515e4',1,'RUN_MINMAX_TESTS:&#160;main.c'],['../floating__point__test_2main_8c.html#aed386f612417aeeeac8b08db27d515e4',1,'RUN_MINMAX_TESTS:&#160;main.c']]], + ['run_5fmul_5ftests_96',['RUN_MUL_TESTS',['../float__corner__test_2main_8c.html#a97323ecaf1ae85e68a736b06bc3b58f8',1,'RUN_MUL_TESTS:&#160;main.c'],['../floating__point__test_2main_8c.html#a97323ecaf1ae85e68a736b06bc3b58f8',1,'RUN_MUL_TESTS:&#160;main.c']]], + ['run_5fsgninj_5ftests_97',['RUN_SGNINJ_TESTS',['../float__corner__test_2main_8c.html#a94f0b0908f48f383145ed61ef8eb0713',1,'RUN_SGNINJ_TESTS:&#160;main.c'],['../floating__point__test_2main_8c.html#a94f0b0908f48f383145ed61ef8eb0713',1,'RUN_SGNINJ_TESTS:&#160;main.c']]], + ['run_5ftiming_5ftests_98',['RUN_TIMING_TESTS',['../float__corner__test_2main_8c.html#a6969308bd3633928893a2666f1df66fc',1,'RUN_TIMING_TESTS:&#160;main.c'],['../floating__point__test_2main_8c.html#a6969308bd3633928893a2666f1df66fc',1,'RUN_TIMING_TESTS:&#160;main.c']]], + ['run_5funavail_5ftests_99',['RUN_UNAVAIL_TESTS',['../float__corner__test_2main_8c.html#a923de9c3e55322d85522740c0d0ff867',1,'RUN_UNAVAIL_TESTS:&#160;main.c'],['../floating__point__test_2main_8c.html#a923de9c3e55322d85522740c0d0ff867',1,'RUN_UNAVAIL_TESTS:&#160;main.c']]] +]; diff --git a/sw/search/all_17.js b/sw/search/all_17.js new file mode 100644 index 0000000000..49e1b05f3e --- /dev/null +++ b/sw/search/all_17.js @@ -0,0 +1,161 @@ +var searchData= +[ + ['save_5fexe_0',['save_exe',['../bootloader_8c.html#ababfffe8e7036179e150ad3b9bda3a74',1,'bootloader.c']]], + ['scan_5fbus_1',['scan_bus',['../demo__onewire_2main_8c.html#ac07c9cfd80ac2e24be9dac6cf943b7de',1,'main.c']]], + ['scan_5ftwi_2',['scan_twi',['../demo__twi_2main_8c.html#aace46ee34e954f9ebee5873beb0785f1',1,'main.c']]], + ['sdi_5fctrl_5fcs_5factive_3',['SDI_CTRL_CS_ACTIVE',['../neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6ad288a52f2bdaa1ea6ddbadf7f32a3a63',1,'neorv32_sdi.h']]], + ['sdi_5fctrl_5fen_4',['SDI_CTRL_EN',['../neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6af6016d120844c2d8d8da4fccc09f9809',1,'neorv32_sdi.h']]], + ['sdi_5fctrl_5ffifo_5flsb_5',['SDI_CTRL_FIFO_LSB',['../neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6a840c74518f55028608e2353ec6ce58c4',1,'neorv32_sdi.h']]], + ['sdi_5fctrl_5ffifo_5fmsb_6',['SDI_CTRL_FIFO_MSB',['../neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6ab3b57f906bd3fc16242fa06601ce1716',1,'neorv32_sdi.h']]], + ['sdi_5fctrl_5firq_5frx_5favail_7',['SDI_CTRL_IRQ_RX_AVAIL',['../neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6a2a611e339fd9ae7854931743802ff5c0',1,'neorv32_sdi.h']]], + ['sdi_5fctrl_5firq_5frx_5ffull_8',['SDI_CTRL_IRQ_RX_FULL',['../neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6a051d69f43c2b0f15c5e9e9252c906c9d',1,'neorv32_sdi.h']]], + ['sdi_5fctrl_5firq_5frx_5fhalf_9',['SDI_CTRL_IRQ_RX_HALF',['../neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6af1e2abec3b3bc2ff9ecb2698d933a281',1,'neorv32_sdi.h']]], + ['sdi_5fctrl_5firq_5ftx_5fempty_10',['SDI_CTRL_IRQ_TX_EMPTY',['../neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6a5df074faedb03cf3cc0cfa90eaccd210',1,'neorv32_sdi.h']]], + ['sdi_5fctrl_5firq_5ftx_5fnhalf_11',['SDI_CTRL_IRQ_TX_NHALF',['../neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6a762237a6107ee690276c36108fa1c1ed',1,'neorv32_sdi.h']]], + ['sdi_5fctrl_5frx_5favail_12',['SDI_CTRL_RX_AVAIL',['../neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6ae15186a46909f1a957269b21af6a14a0',1,'neorv32_sdi.h']]], + ['sdi_5fctrl_5frx_5ffull_13',['SDI_CTRL_RX_FULL',['../neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6a45ade3854c01dc1b14a80e3fea29417a',1,'neorv32_sdi.h']]], + ['sdi_5fctrl_5frx_5fhalf_14',['SDI_CTRL_RX_HALF',['../neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6ac9381cffb4da427baf31cdbbeae5e1f4',1,'neorv32_sdi.h']]], + ['sdi_5fctrl_5ftx_5fempty_15',['SDI_CTRL_TX_EMPTY',['../neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6aa9b89463a37e3a9c554195c2f87fb8d8',1,'neorv32_sdi.h']]], + ['sdi_5fctrl_5ftx_5ffull_16',['SDI_CTRL_TX_FULL',['../neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6adb5c4613ce0a6178a01599cf8fd6984a',1,'neorv32_sdi.h']]], + ['sdi_5fctrl_5ftx_5fnhalf_17',['SDI_CTRL_TX_NHALF',['../neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6aeac16a67f250cce5ea420790e80b8bb9',1,'neorv32_sdi.h']]], + ['sdi_5ffirq_5fenable_18',['SDI_FIRQ_ENABLE',['../neorv32_8h.html#a30cf20b6d704c50cc5c46238bb43646f',1,'neorv32.h']]], + ['sdi_5ffirq_5fpending_19',['SDI_FIRQ_PENDING',['../neorv32_8h.html#a68611c0dfbe331739eff10230ac3fede',1,'neorv32.h']]], + ['sdi_5fget_20',['sdi_get',['../demo__sdi_2main_8c.html#aa25f620a5631e862252be1d5429e8585',1,'main.c']]], + ['sdi_5fput_21',['sdi_put',['../demo__sdi_2main_8c.html#ae3dc843520a800d7ba2b5d6be03d9c3d',1,'main.c']]], + ['sdi_5frte_5fid_22',['SDI_RTE_ID',['../neorv32_8h.html#aa0ff72ea560d7e1462787dc31bd467cf',1,'neorv32.h']]], + ['sdi_5ftrap_5fcode_23',['SDI_TRAP_CODE',['../neorv32_8h.html#a68925ca3f482f148caedd36118fd8d79',1,'neorv32.h']]], + ['seconds_24',['seconds',['../structdate__t.html#a1071948e7754cb415da9714d59a315bf',1,'date_t']]], + ['send_5ftwi_25',['send_twi',['../demo__twi_2main_8c.html#aa94edd4f55a3ac18913f661f4bc16fb1',1,'main.c']]], + ['set_5fcell_26',['set_cell',['../game__of__life_2main_8c.html#a5315eb56128f1ca40d9f4d477c345dd7',1,'main.c']]], + ['set_5fclock_27',['set_clock',['../demo__twi_2main_8c.html#acee0c1770467f85a150d072ac7e1252f',1,'main.c']]], + ['setup_5faccess_28',['setup_access',['../bus__explorer_2main_8c.html#a2b6196c2e97a7f7702c0068780304ec1',1,'main.c']]], + ['show_5f1wire_5fcommands_29',['show_1wire_commands',['../demo__onewire_2main_8c.html#a29d5831498c2eaf0415d6f01efb9e7ce',1,'main.c']]], + ['show_5farrays_30',['show_arrays',['../demo__dma_2main_8c.html#a8ad0c7bfd07edb6d42d86b166347206b',1,'main.c']]], + ['show_5fhelp_31',['show_help',['../demo__onewire_2main_8c.html#af25820ed386a66a0d6bb4dcdd2204704',1,'main.c']]], + ['silent_5fmode_32',['SILENT_MODE',['../atomic__test_2main_8c.html#a87f296d7594bb8178cf76f0c045b7013',1,'SILENT_MODE:&#160;main.c'],['../float__corner__test_2main_8c.html#a87f296d7594bb8178cf76f0c045b7013',1,'SILENT_MODE:&#160;main.c'],['../floating__point__test_2main_8c.html#a87f296d7594bb8178cf76f0c045b7013',1,'SILENT_MODE:&#160;main.c']]], + ['sim_5firq_5ftrigger_33',['sim_irq_trigger',['../processor__check_2main_8c.html#ada24f2cd9d2d384265517f539711de62',1,'main.c']]], + ['slink_5fctrl_5fen_34',['SLINK_CTRL_EN',['../neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1a739187f413b7436dc4037187e4a9e86a',1,'neorv32_slink.h']]], + ['slink_5fctrl_5firq_5frx_5ffull_35',['SLINK_CTRL_IRQ_RX_FULL',['../neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1ac8a688706aee72d2027e022b64664309',1,'neorv32_slink.h']]], + ['slink_5fctrl_5firq_5frx_5fhalf_36',['SLINK_CTRL_IRQ_RX_HALF',['../neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1afa9353cd824d1b2833930ce9e922e392',1,'neorv32_slink.h']]], + ['slink_5fctrl_5firq_5frx_5fnempty_37',['SLINK_CTRL_IRQ_RX_NEMPTY',['../neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1a5452eab0fe12d174ec804c4c72060854',1,'neorv32_slink.h']]], + ['slink_5fctrl_5firq_5ftx_5fempty_38',['SLINK_CTRL_IRQ_TX_EMPTY',['../neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1ae06ad5f627f8902e2368e0daff6cfa88',1,'neorv32_slink.h']]], + ['slink_5fctrl_5firq_5ftx_5fnfull_39',['SLINK_CTRL_IRQ_TX_NFULL',['../neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1a8f994f256f57c006c88b9e38df3f54fa',1,'neorv32_slink.h']]], + ['slink_5fctrl_5firq_5ftx_5fnhalf_40',['SLINK_CTRL_IRQ_TX_NHALF',['../neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1a7bf757dbfb1fdaddceaed3a3887003cf',1,'neorv32_slink.h']]], + ['slink_5fctrl_5frx_5fclr_41',['SLINK_CTRL_RX_CLR',['../neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1a156fa3209b2652af6b58b0fdfc6cab1b',1,'neorv32_slink.h']]], + ['slink_5fctrl_5frx_5fempty_42',['SLINK_CTRL_RX_EMPTY',['../neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1ae78f82e54bd9d737bbcbc5c7af0e9d4b',1,'neorv32_slink.h']]], + ['slink_5fctrl_5frx_5ffifo_5flsb_43',['SLINK_CTRL_RX_FIFO_LSB',['../neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1a9c68af961c1147846929ca55e9e4e88c',1,'neorv32_slink.h']]], + ['slink_5fctrl_5frx_5ffifo_5fmsb_44',['SLINK_CTRL_RX_FIFO_MSB',['../neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1a945e2b7eda65dc13ca38eb21c9c4f657',1,'neorv32_slink.h']]], + ['slink_5fctrl_5frx_5ffull_45',['SLINK_CTRL_RX_FULL',['../neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1aa7521fbe691fef233c0dff4053e4493e',1,'neorv32_slink.h']]], + ['slink_5fctrl_5frx_5fhalf_46',['SLINK_CTRL_RX_HALF',['../neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1af695158b9cf5466d87c207f9bd0a688e',1,'neorv32_slink.h']]], + ['slink_5fctrl_5frx_5flast_47',['SLINK_CTRL_RX_LAST',['../neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1a624723683d247668ef44137393e576aa',1,'neorv32_slink.h']]], + ['slink_5fctrl_5ftx_5fclr_48',['SLINK_CTRL_TX_CLR',['../neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1ad366597a44d3dff7dbab4cde72bed82f',1,'neorv32_slink.h']]], + ['slink_5fctrl_5ftx_5fempty_49',['SLINK_CTRL_TX_EMPTY',['../neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1a308cf7829ecca32f7a3da1bd74339854',1,'neorv32_slink.h']]], + ['slink_5fctrl_5ftx_5ffifo_5flsb_50',['SLINK_CTRL_TX_FIFO_LSB',['../neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1aba613343fc17715fc1bb07729588a12d',1,'neorv32_slink.h']]], + ['slink_5fctrl_5ftx_5ffifo_5fmsb_51',['SLINK_CTRL_TX_FIFO_MSB',['../neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1af27a9e6e50b169d3f5efd0a08ba4a943',1,'neorv32_slink.h']]], + ['slink_5fctrl_5ftx_5ffull_52',['SLINK_CTRL_TX_FULL',['../neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1af94314ed65c6a8d9c364d99d7ae960ee',1,'neorv32_slink.h']]], + ['slink_5fctrl_5ftx_5fhalf_53',['SLINK_CTRL_TX_HALF',['../neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1a530b8b76301f36fbda134b330447de78',1,'neorv32_slink.h']]], + ['slink_5ffifo_5fempty_54',['SLINK_FIFO_EMPTY',['../neorv32__slink_8h.html#a84f7fe82f188bd4e68f41549587822bfa9f24886f55b7f78ae8909ea8a573058c',1,'neorv32_slink.h']]], + ['slink_5ffifo_5ffull_55',['SLINK_FIFO_FULL',['../neorv32__slink_8h.html#a84f7fe82f188bd4e68f41549587822bfa2f96e61f0e07ef4ecd40f14e69b69211',1,'neorv32_slink.h']]], + ['slink_5ffifo_5fhalf_56',['SLINK_FIFO_HALF',['../neorv32__slink_8h.html#a84f7fe82f188bd4e68f41549587822bfadc37988b8aee38e85626064b2c3704f9',1,'neorv32_slink.h']]], + ['slink_5ffirq_5fhandler_57',['slink_firq_handler',['../demo__slink_2main_8c.html#a48c79e20ed1d4138d61b5593bdbe537a',1,'main.c']]], + ['slink_5froute_5fdst_5flsb_58',['SLINK_ROUTE_DST_LSB',['../neorv32__slink_8h.html#ac3e5e02fd89a357135adca6d28cd0e45a9a2311357bd87c85a5cc45f08b0d8f80',1,'neorv32_slink.h']]], + ['slink_5froute_5fdst_5fmsb_59',['SLINK_ROUTE_DST_MSB',['../neorv32__slink_8h.html#ac3e5e02fd89a357135adca6d28cd0e45a7e8da208ecaf142107587033e2d63ec1',1,'neorv32_slink.h']]], + ['slink_5froute_5fsrc_5flsb_60',['SLINK_ROUTE_SRC_LSB',['../neorv32__slink_8h.html#ac3e5e02fd89a357135adca6d28cd0e45a69942c3a7b7b0550634f4016e639b0c2',1,'neorv32_slink.h']]], + ['slink_5froute_5fsrc_5fmsb_61',['SLINK_ROUTE_SRC_MSB',['../neorv32__slink_8h.html#ac3e5e02fd89a357135adca6d28cd0e45a7b7b0b9bd4fe448cae97a3a21460f983',1,'neorv32_slink.h']]], + ['slink_5frx_5ffirq_5fenable_62',['SLINK_RX_FIRQ_ENABLE',['../neorv32_8h.html#a8680ab1f14e512f21913572b35cbbf77',1,'neorv32.h']]], + ['slink_5frx_5ffirq_5fpending_63',['SLINK_RX_FIRQ_PENDING',['../neorv32_8h.html#a5c48d5c4effb47cdb019aa2da7c84526',1,'neorv32.h']]], + ['slink_5frx_5frte_5fid_64',['SLINK_RX_RTE_ID',['../neorv32_8h.html#a4fff18e72d10377cdcb8d2ac0a617a5d',1,'neorv32.h']]], + ['slink_5frx_5ftrap_5fcode_65',['SLINK_RX_TRAP_CODE',['../neorv32_8h.html#ab1fdaedb2c4c8753ef3be87c82568dda',1,'neorv32.h']]], + ['slink_5ftx_5ffirq_5fenable_66',['SLINK_TX_FIRQ_ENABLE',['../neorv32_8h.html#a232fe0eb5665373b6e2b464bdc228df2',1,'neorv32.h']]], + ['slink_5ftx_5ffirq_5fpending_67',['SLINK_TX_FIRQ_PENDING',['../neorv32_8h.html#ac8e98b2af75c8e31f9815dee3dcbaf8e',1,'neorv32.h']]], + ['slink_5ftx_5frte_5fid_68',['SLINK_TX_RTE_ID',['../neorv32_8h.html#a4e039d13b8d3f20453e1bb6b40512e43',1,'neorv32.h']]], + ['slink_5ftx_5ftrap_5fcode_69',['SLINK_TX_TRAP_CODE',['../neorv32_8h.html#a7fbe28901775e284d5700086f0b0bfcd',1,'neorv32.h']]], + ['soc_70',['SOC',['../structneorv32__sysinfo__t.html#ac43abe3b416da3a2895d1d06537a14c3',1,'neorv32_sysinfo_t']]], + ['soc_71',[':desktop_computer: &lt;a href=&quot;https://stnolting.github.io/neorv32/#_neorv32_processor_soc&quot; &gt;NEORV32 Processor&lt;/a&gt; - The SoC',['../md_README.html#autotoc_md9',1,'']]], + ['software_20ecosystem_72',[':floppy_disk: &lt;a href=&quot;https://stnolting.github.io/neorv32/#_software_framework&quot; &gt;Software Framework&lt;/a&gt; - The Software Ecosystem',['../md_README.html#autotoc_md11',1,'']]], + ['software_20framework_20a_20the_20software_20ecosystem_73',[':floppy_disk: &lt;a href=&quot;https://stnolting.github.io/neorv32/#_software_framework&quot; &gt;Software Framework&lt;/a&gt; - The Software Ecosystem',['../md_README.html#autotoc_md11',1,'']]], + ['spi_5fboot_5fbase_5faddr_74',['SPI_BOOT_BASE_ADDR',['../bootloader_8c.html#a418adcf57119600c3580fd2297d28de0',1,'bootloader.c']]], + ['spi_5fcs_75',['spi_cs',['../demo__spi_2main_8c.html#a6f94991b8943a141ed4124585222470d',1,'main.c']]], + ['spi_5fcs_5factive_76',['SPI_CS_ACTIVE',['../neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba5e12c05349444d3d1defff49dec00580',1,'neorv32_spi.h']]], + ['spi_5fctrl_5fbusy_77',['SPI_CTRL_BUSY',['../neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba7957cf1cf3997cd059ed81cba73a688c',1,'neorv32_spi.h']]], + ['spi_5fctrl_5fcdiv0_78',['SPI_CTRL_CDIV0',['../neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3bae6db5cfa843a58d7c09783e7f29fa49f',1,'neorv32_spi.h']]], + ['spi_5fctrl_5fcdiv1_79',['SPI_CTRL_CDIV1',['../neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba0b9ca202963b68b999f94baab50fbc48',1,'neorv32_spi.h']]], + ['spi_5fctrl_5fcdiv2_80',['SPI_CTRL_CDIV2',['../neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba97aaa7a4ffcc6d17a00c4f992e517c46',1,'neorv32_spi.h']]], + ['spi_5fctrl_5fcdiv3_81',['SPI_CTRL_CDIV3',['../neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba85164e4e00b5ccd34158f98f691bca29',1,'neorv32_spi.h']]], + ['spi_5fctrl_5fcpha_82',['SPI_CTRL_CPHA',['../neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba4d787c993152a9417fcd50f76820c7b0',1,'neorv32_spi.h']]], + ['spi_5fctrl_5fcpol_83',['SPI_CTRL_CPOL',['../neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba7661acb97cc8c6dd7f333be4f4a2d315',1,'neorv32_spi.h']]], + ['spi_5fctrl_5fen_84',['SPI_CTRL_EN',['../neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba647a6357971f94b79b7672785c06a4ea',1,'neorv32_spi.h']]], + ['spi_5fctrl_5ffifo_5flsb_85',['SPI_CTRL_FIFO_LSB',['../neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba12f67abd206066651c1d62fc29fafcdb',1,'neorv32_spi.h']]], + ['spi_5fctrl_5ffifo_5fmsb_86',['SPI_CTRL_FIFO_MSB',['../neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba8c0426f70974f0ab129481f2db7cf0ed',1,'neorv32_spi.h']]], + ['spi_5fctrl_5fhighspeed_87',['SPI_CTRL_HIGHSPEED',['../neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3bac38b12af6b8fb6bf2fc6f6ff6baee91e',1,'neorv32_spi.h']]], + ['spi_5fctrl_5firq_5fidle_88',['SPI_CTRL_IRQ_IDLE',['../neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba3f80e9c6ef6445ad769038c955c171a2',1,'neorv32_spi.h']]], + ['spi_5fctrl_5firq_5frx_5favail_89',['SPI_CTRL_IRQ_RX_AVAIL',['../neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba2cd2350ffc819b7198d1833b525c5ca0',1,'neorv32_spi.h']]], + ['spi_5fctrl_5firq_5ftx_5fempty_90',['SPI_CTRL_IRQ_TX_EMPTY',['../neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3bafcdc17528f9f4521c02ec5c473b44622',1,'neorv32_spi.h']]], + ['spi_5fctrl_5firq_5ftx_5fhalf_91',['SPI_CTRL_IRQ_TX_HALF',['../neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba8c18d975418ad444255f80317448d26b',1,'neorv32_spi.h']]], + ['spi_5fctrl_5fprsc0_92',['SPI_CTRL_PRSC0',['../neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3babc927c4ea78433de697a9fe96f47248e',1,'neorv32_spi.h']]], + ['spi_5fctrl_5fprsc1_93',['SPI_CTRL_PRSC1',['../neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba49c38a34b95c034249a094fbc93e0a61',1,'neorv32_spi.h']]], + ['spi_5fctrl_5fprsc2_94',['SPI_CTRL_PRSC2',['../neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba7a5244e443e1fe4ff6b7a2176f90ae7a',1,'neorv32_spi.h']]], + ['spi_5fctrl_5frx_5favail_95',['SPI_CTRL_RX_AVAIL',['../neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba115b097b76b3b99716f54a63c6ce5633',1,'neorv32_spi.h']]], + ['spi_5fctrl_5ftx_5fempty_96',['SPI_CTRL_TX_EMPTY',['../neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba487b87333d33db0a05cd2a229225ffc6',1,'neorv32_spi.h']]], + ['spi_5fctrl_5ftx_5ffull_97',['SPI_CTRL_TX_FULL',['../neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba96860d260b31ee4c232b6b0eb45f7905',1,'neorv32_spi.h']]], + ['spi_5fctrl_5ftx_5fnhalf_98',['SPI_CTRL_TX_NHALF',['../neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba5efcaded20b93d2bffeaa4ea813f73b4',1,'neorv32_spi.h']]], + ['spi_5fdata_5fcmd_99',['SPI_DATA_CMD',['../neorv32__spi_8h.html#aab478c23898c0b06cee53a1cbda38bf8a8b565083f989905b8335d9d22a14c4b6',1,'neorv32_spi.h']]], + ['spi_5fdata_5fcsen_100',['SPI_DATA_CSEN',['../neorv32__spi_8h.html#aab478c23898c0b06cee53a1cbda38bf8a5673b6a3382dc5452e3cfcd4e8f3c8a2',1,'neorv32_spi.h']]], + ['spi_5fdata_5flsb_101',['SPI_DATA_LSB',['../neorv32__spi_8h.html#aab478c23898c0b06cee53a1cbda38bf8ae3c36a644c05cea0fccaefb9da90a1b4',1,'neorv32_spi.h']]], + ['spi_5fdata_5fmsb_102',['SPI_DATA_MSB',['../neorv32__spi_8h.html#aab478c23898c0b06cee53a1cbda38bf8a0167ec9c252ee0228ab9d21f4acba600',1,'neorv32_spi.h']]], + ['spi_5fen_103',['SPI_EN',['../bootloader_8c.html#aea75cf0485ce0a4ea320eba994859686',1,'bootloader.c']]], + ['spi_5ffirq_5fenable_104',['SPI_FIRQ_ENABLE',['../neorv32_8h.html#ab8fcd3f80c373eb0f9d0fc6bf64ca626',1,'neorv32.h']]], + ['spi_5ffirq_5fpending_105',['SPI_FIRQ_PENDING',['../neorv32_8h.html#ab2f58f746febb29a9828447c733f8043',1,'neorv32.h']]], + ['spi_5fflash_5faddr_5fbytes_106',['SPI_FLASH_ADDR_BYTES',['../bootloader_8c.html#afe60a31c8561952f2f734fd67e6f7406',1,'bootloader.c']]], + ['spi_5fflash_5fcheck_107',['spi_flash_check',['../bootloader_8c.html#a1919595ed2232aebb3e774b916ab1662',1,'bootloader.c']]], + ['spi_5fflash_5fclk_5fprsc_108',['SPI_FLASH_CLK_PRSC',['../bootloader_8c.html#a709071a651213770b4efe6e6e055ec3d',1,'bootloader.c']]], + ['spi_5fflash_5fcmd_109',['SPI_FLASH_CMD',['../demo__xip_2main_8c.html#af30de1c8d8502ad374612d308cfbd12e',1,'main.c']]], + ['spi_5fflash_5fcmd_5fenum_110',['SPI_FLASH_CMD_enum',['../bootloader_8c.html#aa5e5723e4cbf83805c3b1197cd401fed',1,'bootloader.c']]], + ['spi_5fflash_5fcmd_5fpage_5fprogram_111',['SPI_FLASH_CMD_PAGE_PROGRAM',['../bootloader_8c.html#aa5e5723e4cbf83805c3b1197cd401feda31c8d698c551d081a0adeafb988ed49e',1,'bootloader.c']]], + ['spi_5fflash_5fcmd_5fread_112',['SPI_FLASH_CMD_READ',['../bootloader_8c.html#aa5e5723e4cbf83805c3b1197cd401feda6c1994ba2cfd97e0c77dcdf8bbdfdfa6',1,'SPI_FLASH_CMD_READ:&#160;bootloader.c'],['../demo__xip_2main_8c.html#af30de1c8d8502ad374612d308cfbd12ea6c1994ba2cfd97e0c77dcdf8bbdfdfa6',1,'SPI_FLASH_CMD_READ:&#160;main.c']]], + ['spi_5fflash_5fcmd_5fread_5fstatus_113',['SPI_FLASH_CMD_READ_STATUS',['../bootloader_8c.html#aa5e5723e4cbf83805c3b1197cd401feda5fbc6551a10549b38e5ab4a76c38f214',1,'SPI_FLASH_CMD_READ_STATUS:&#160;bootloader.c'],['../demo__xip_2main_8c.html#af30de1c8d8502ad374612d308cfbd12ea5fbc6551a10549b38e5ab4a76c38f214',1,'SPI_FLASH_CMD_READ_STATUS:&#160;main.c']]], + ['spi_5fflash_5fcmd_5fsector_5ferase_114',['SPI_FLASH_CMD_SECTOR_ERASE',['../bootloader_8c.html#aa5e5723e4cbf83805c3b1197cd401fedacd62141d6331f66e31bd252e2a92b836',1,'SPI_FLASH_CMD_SECTOR_ERASE:&#160;bootloader.c'],['../demo__xip_2main_8c.html#af30de1c8d8502ad374612d308cfbd12eacd62141d6331f66e31bd252e2a92b836',1,'SPI_FLASH_CMD_SECTOR_ERASE:&#160;main.c']]], + ['spi_5fflash_5fcmd_5fwake_115',['SPI_FLASH_CMD_WAKE',['../bootloader_8c.html#aa5e5723e4cbf83805c3b1197cd401feda25bf16cd42b1fd1d95e0957b5be137d2',1,'bootloader.c']]], + ['spi_5fflash_5fcmd_5fwrite_116',['SPI_FLASH_CMD_WRITE',['../demo__xip_2main_8c.html#af30de1c8d8502ad374612d308cfbd12ea528cebc54176f6f4c0a8f7f16fb28ca1',1,'main.c']]], + ['spi_5fflash_5fcmd_5fwrite_5fdisable_117',['SPI_FLASH_CMD_WRITE_DISABLE',['../bootloader_8c.html#aa5e5723e4cbf83805c3b1197cd401fedaa91d3c1d788b21fc798a5976c9f0da77',1,'SPI_FLASH_CMD_WRITE_DISABLE:&#160;bootloader.c'],['../demo__xip_2main_8c.html#af30de1c8d8502ad374612d308cfbd12eaa91d3c1d788b21fc798a5976c9f0da77',1,'SPI_FLASH_CMD_WRITE_DISABLE:&#160;main.c']]], + ['spi_5fflash_5fcmd_5fwrite_5fenable_118',['SPI_FLASH_CMD_WRITE_ENABLE',['../bootloader_8c.html#aa5e5723e4cbf83805c3b1197cd401feda152e091e93778f217f8b766298351513',1,'SPI_FLASH_CMD_WRITE_ENABLE:&#160;bootloader.c'],['../demo__xip_2main_8c.html#af30de1c8d8502ad374612d308cfbd12ea152e091e93778f217f8b766298351513',1,'SPI_FLASH_CMD_WRITE_ENABLE:&#160;main.c']]], + ['spi_5fflash_5fcs_119',['SPI_FLASH_CS',['../bootloader_8c.html#aa2132454aada86216009f3af206899b1',1,'bootloader.c']]], + ['spi_5fflash_5ferase_5fsector_120',['spi_flash_erase_sector',['../bootloader_8c.html#a0d877f0611dfcee32a483c8a3660eb1b',1,'bootloader.c']]], + ['spi_5fflash_5fread_5fbyte_121',['spi_flash_read_byte',['../bootloader_8c.html#a09e72e2debdd94929b2be4c7713d5e17',1,'bootloader.c']]], + ['spi_5fflash_5fread_5fstatus_122',['spi_flash_read_status',['../bootloader_8c.html#a005966cd0b32f3d5c041028c4b1c99f5',1,'bootloader.c']]], + ['spi_5fflash_5fsector_5fsize_123',['SPI_FLASH_SECTOR_SIZE',['../bootloader_8c.html#a00924a8ba223b2ca0e7031259b292c84',1,'bootloader.c']]], + ['spi_5fflash_5fsreg_124',['SPI_FLASH_SREG',['../demo__xip_2main_8c.html#adccf1bb8f1f203cb1350f7f2eb15a08e',1,'main.c']]], + ['spi_5fflash_5fsreg_5fenum_125',['SPI_FLASH_SREG_enum',['../bootloader_8c.html#a97299f563ebc1fca4c663b025a15136f',1,'bootloader.c']]], + ['spi_5fflash_5fsreg_5fwel_126',['SPI_FLASH_SREG_WEL',['../demo__xip_2main_8c.html#adccf1bb8f1f203cb1350f7f2eb15a08ea90f3b76faed13819ee13e574d1bff0c1',1,'main.c']]], + ['spi_5fflash_5fsreg_5fwip_127',['SPI_FLASH_SREG_WIP',['../demo__xip_2main_8c.html#adccf1bb8f1f203cb1350f7f2eb15a08eac84de63bbea3989c71bcc92d1d01cfa4',1,'main.c']]], + ['spi_5fflash_5fwakeup_128',['spi_flash_wakeup',['../bootloader_8c.html#a1fbdccc60f05756213c9f3d64bac6d47',1,'bootloader.c']]], + ['spi_5fflash_5fwrite_5faddr_129',['spi_flash_write_addr',['../bootloader_8c.html#a6a8caddda6e729d747726471b0b0f742',1,'bootloader.c']]], + ['spi_5fflash_5fwrite_5fbyte_130',['spi_flash_write_byte',['../bootloader_8c.html#a006c27b7d80897b78ab8cd83a391331f',1,'bootloader.c']]], + ['spi_5fflash_5fwrite_5fdisable_131',['spi_flash_write_disable',['../bootloader_8c.html#a82d26a2d6293ed7fd44a5c622adfbd45',1,'bootloader.c']]], + ['spi_5fflash_5fwrite_5fenable_132',['spi_flash_write_enable',['../bootloader_8c.html#a9642e28ef2baec5b356ad9a70970d0e6',1,'bootloader.c']]], + ['spi_5fflash_5fwrite_5fword_133',['spi_flash_write_word',['../bootloader_8c.html#a717c72166af7c2ff7e73bd0b47128338',1,'bootloader.c']]], + ['spi_5firq_5fhandler_134',['spi_irq_handler',['../demo__spi__irq_2main_8c.html#a7e266cc5247c999948dacc2102bd184a',1,'main.c']]], + ['spi_5frte_5fid_135',['SPI_RTE_ID',['../neorv32_8h.html#a4c1cd9ec9f80da2080e5d0d35cc524dd',1,'neorv32.h']]], + ['spi_5fsetup_136',['spi_setup',['../demo__spi_2main_8c.html#a755192be6c3cf9904564b0eee99de445',1,'main.c']]], + ['spi_5ftrans_137',['spi_trans',['../demo__spi_2main_8c.html#a13e10b34fbbffca6c31f0ce25b3f8432',1,'main.c']]], + ['spi_5ftrap_5fcode_138',['SPI_TRAP_CODE',['../neorv32_8h.html#a83c212f1f5d8ee2a5921b3b2b19e9cc4',1,'neorv32.h']]], + ['src_5fbase_139',['SRC_BASE',['../structneorv32__dma__t.html#a3b214d1a373c7f15b374e113d7110b42',1,'neorv32_dma_t']]], + ['sreg_140',['SREG',['../structneorv32__crc__t.html#abf2b419f2aefdb6f2a6b81a02cb8612d',1,'neorv32_crc_t']]], + ['start_5fapp_141',['start_app',['../bootloader_8c.html#ae8de91537ac2782f0f0ebc3b2d4fb1df',1,'bootloader.c']]], + ['started_142',['Started',['../md_README.html#autotoc_md7',1,'5. Getting Started'],['../md_README.html#autotoc_md12',1,':rocket: &lt;a href=&quot;https://stnolting.github.io/neorv32/ug/&quot; &gt;User Guide&lt;/a&gt; - Getting Started!']]], + ['status_143',['Project Status',['../md_README.html#autotoc_md3',1,'']]], + ['status_5fled_5fen_144',['STATUS_LED_EN',['../bootloader_8c.html#aa9696325b450773c7a87c991abca3a54',1,'bootloader.c']]], + ['status_5fled_5fpin_145',['STATUS_LED_PIN',['../bootloader_8c.html#a089a71f836911c71b3f73fdd3b4b890b',1,'bootloader.c']]], + ['stnolting_20github_20io_20neorv32_20_5fneorv32_5fcentral_5fprocessing_5funit_5fcpu_20neorv32_20cpu_20a_20the_20core_146',[':abacus: &lt;a href=&quot;https://stnolting.github.io/neorv32/#_neorv32_central_processing_unit_cpu&quot; &gt;NEORV32 CPU&lt;/a&gt; - The Core',['../md_README.html#autotoc_md10',1,'']]], + ['stnolting_20github_20io_20neorv32_20_5fneorv32_5fprocessor_5fsoc_20neorv32_20processor_20a_20the_20soc_147',[':desktop_computer: &lt;a href=&quot;https://stnolting.github.io/neorv32/#_neorv32_processor_soc&quot; &gt;NEORV32 Processor&lt;/a&gt; - The SoC',['../md_README.html#autotoc_md9',1,'']]], + ['stnolting_20github_20io_20neorv32_20_5foverview_20neorv32_20project_20a_20an_20introduction_148',[':mag: &lt;a href=&quot;https://stnolting.github.io/neorv32/#_overview&quot; &gt;NEORV32 Project&lt;/a&gt; - An Introduction',['../md_README.html#autotoc_md8',1,'']]], + ['stnolting_20github_20io_20neorv32_20_5fsoftware_5fframework_20software_20framework_20a_20the_20software_20ecosystem_149',[':floppy_disk: &lt;a href=&quot;https://stnolting.github.io/neorv32/#_software_framework&quot; &gt;Software Framework&lt;/a&gt; - The Software Ecosystem',['../md_README.html#autotoc_md11',1,'']]], + ['stnolting_20github_20io_20neorv32_20ug_20user_20guide_20a_20getting_20started_150',[':rocket: &lt;a href=&quot;https://stnolting.github.io/neorv32/ug/&quot; &gt;User Guide&lt;/a&gt; - Getting Started!',['../md_README.html#autotoc_md12',1,'']]], + ['str_151',['str',['../bootloader_8c.html#af6cf19e40e97afb5a7c29f7b439d091d',1,'bootloader.c']]], + ['subnormal_5fflush_152',['subnormal_flush',['../floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a791f880781a1bcea1861471be7d1a851',1,'neorv32_zfinx_extension_intrinsics.h']]], + ['subwords16_5ft_153',['subwords16_t',['../unionsubwords16__t.html',1,'']]], + ['subwords32_5ft_154',['subwords32_t',['../unionsubwords32__t.html',1,'']]], + ['subwords64_5ft_155',['subwords64_t',['../unionsubwords64__t.html',1,'']]], + ['syscalls_2ec_156',['syscalls.c',['../syscalls_8c.html',1,'']]], + ['system_5ferror_157',['system_error',['../bootloader_8c.html#a3bdfe2f25b1bfb42f80624ffff22ab01',1,'bootloader.c']]] +]; diff --git a/sw/search/all_18.js b/sw/search/all_18.js new file mode 100644 index 0000000000..2e096554d0 --- /dev/null +++ b/sw/search/all_18.js @@ -0,0 +1,91 @@ +var searchData= +[ + ['t_5fneorv32_5fspi_0',['t_neorv32_spi',['../structt__neorv32__spi.html',1,'']]], + ['test_5ffail_1',['test_fail',['../processor__check_2main_8c.html#a1e0a5d63896fa26a6c25c0012fc6b938',1,'main.c']]], + ['test_5fok_2',['test_ok',['../processor__check_2main_8c.html#ae61d39109b2747429ec3a3c1b5533598',1,'main.c']]], + ['testcases_3',['TESTCASES',['../demo__cfs_2main_8c.html#a906949f076e3e0d0082af3c3b1acb518',1,'main.c']]], + ['the_20core_4',[':abacus: &lt;a href=&quot;https://stnolting.github.io/neorv32/#_neorv32_central_processing_unit_cpu&quot; &gt;NEORV32 CPU&lt;/a&gt; - The Core',['../md_README.html#autotoc_md10',1,'']]], + ['the_20neorv32_20risc_20v_20processor_5',['The NEORV32 RISC-V Processor',['../md_README.html#autotoc_md0',1,'']]], + ['the_20soc_6',[':desktop_computer: &lt;a href=&quot;https://stnolting.github.io/neorv32/#_neorv32_processor_soc&quot; &gt;NEORV32 Processor&lt;/a&gt; - The SoC',['../md_README.html#autotoc_md9',1,'']]], + ['the_20software_20ecosystem_7',[':floppy_disk: &lt;a href=&quot;https://stnolting.github.io/neorv32/#_software_framework&quot; &gt;Software Framework&lt;/a&gt; - The Software Ecosystem',['../md_README.html#autotoc_md11',1,'']]], + ['thres_8',['THRES',['../structneorv32__gptmr__t.html#a666ebcbea13dafcf1987629f3e0092ee',1,'neorv32_gptmr_t']]], + ['time_5fdec_5fhw_9',['time_dec_hw',['../demo__cfu_2main_8c.html#acb6dd9d6ab74ac94f174a11ff3ad76af',1,'main.c']]], + ['time_5fdec_5fsw_10',['time_dec_sw',['../demo__cfu_2main_8c.html#a2d3853c367c3bce99e787c0df445030a',1,'main.c']]], + ['time_5fenc_5fhw_11',['time_enc_hw',['../demo__cfu_2main_8c.html#a094212e3731a9aecbd278fac243de6ec',1,'main.c']]], + ['time_5fenc_5fsw_12',['time_enc_sw',['../demo__cfu_2main_8c.html#ad424a26173bd8d84b8d1cae94a55f248',1,'main.c']]], + ['time_5fhi_13',['TIME_HI',['../structneorv32__mtime__t.html#a1ffe0be2c45f5d7aa2686abf40cd1693',1,'neorv32_mtime_t']]], + ['time_5flo_14',['TIME_LO',['../structneorv32__mtime__t.html#acccaa3dd87a57ebd5f7ae504771e904e',1,'neorv32_mtime_t']]], + ['timecmp_5fhi_15',['TIMECMP_HI',['../structneorv32__mtime__t.html#af05df268c8f699401cf752e4249ba422',1,'neorv32_mtime_t']]], + ['timecmp_5flo_16',['TIMECMP_LO',['../structneorv32__mtime__t.html#ab5fa56ca5c2f9d547f58d169d6da96e5',1,'neorv32_mtime_t']]], + ['tpol_17',['TPOL',['../structneorv32__xirq__t.html#a5fe0036a2cada585228b60aaa780e92a',1,'neorv32_xirq_t']]], + ['trap_5fcode_5fbreakpoint_18',['TRAP_CODE_BREAKPOINT',['../neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a2c9510cb7583a0144f96678fc217335e',1,'neorv32_cpu_csr.h']]], + ['trap_5fcode_5ffirq_5f0_19',['TRAP_CODE_FIRQ_0',['../neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a0cef77904935798d247d8396838297c1',1,'neorv32_cpu_csr.h']]], + ['trap_5fcode_5ffirq_5f1_20',['TRAP_CODE_FIRQ_1',['../neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1ae0b1049ae7f8cbfb6ff216e69ed5dae7',1,'neorv32_cpu_csr.h']]], + ['trap_5fcode_5ffirq_5f10_21',['TRAP_CODE_FIRQ_10',['../neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a4f6b9c6bba91fe04becb776ad22dcf42',1,'neorv32_cpu_csr.h']]], + ['trap_5fcode_5ffirq_5f11_22',['TRAP_CODE_FIRQ_11',['../neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a874dcc43cf8fbbf2e0614e7db9e38334',1,'neorv32_cpu_csr.h']]], + ['trap_5fcode_5ffirq_5f12_23',['TRAP_CODE_FIRQ_12',['../neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a151f01e5f284f876cafafc7427720e4c',1,'neorv32_cpu_csr.h']]], + ['trap_5fcode_5ffirq_5f13_24',['TRAP_CODE_FIRQ_13',['../neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a7c8e97297cc4dcd6d5a1de65a124f3e9',1,'neorv32_cpu_csr.h']]], + ['trap_5fcode_5ffirq_5f14_25',['TRAP_CODE_FIRQ_14',['../neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a821f813de47eb781ab7715f780da3b1e',1,'neorv32_cpu_csr.h']]], + ['trap_5fcode_5ffirq_5f15_26',['TRAP_CODE_FIRQ_15',['../neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1aa4eeafe2f6f59aff01e29461c664a110',1,'neorv32_cpu_csr.h']]], + ['trap_5fcode_5ffirq_5f2_27',['TRAP_CODE_FIRQ_2',['../neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1ad753d3e2563b4fd663430af9f3888dc7',1,'neorv32_cpu_csr.h']]], + ['trap_5fcode_5ffirq_5f3_28',['TRAP_CODE_FIRQ_3',['../neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a356f8485166529503d0fb246bd0aeeb0',1,'neorv32_cpu_csr.h']]], + ['trap_5fcode_5ffirq_5f4_29',['TRAP_CODE_FIRQ_4',['../neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1aaa8e7bb251852ef75a78be71eef0b547',1,'neorv32_cpu_csr.h']]], + ['trap_5fcode_5ffirq_5f5_30',['TRAP_CODE_FIRQ_5',['../neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a5789dfabd8ec265fa0734ddd94e98757',1,'neorv32_cpu_csr.h']]], + ['trap_5fcode_5ffirq_5f6_31',['TRAP_CODE_FIRQ_6',['../neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a809e997f55e83c6812c965655511d473',1,'neorv32_cpu_csr.h']]], + ['trap_5fcode_5ffirq_5f7_32',['TRAP_CODE_FIRQ_7',['../neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1aeab719bcce9e9551bd6da65a7ae08a26',1,'neorv32_cpu_csr.h']]], + ['trap_5fcode_5ffirq_5f8_33',['TRAP_CODE_FIRQ_8',['../neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1abfd21d1380dcacb9282e525da104d916',1,'neorv32_cpu_csr.h']]], + ['trap_5fcode_5ffirq_5f9_34',['TRAP_CODE_FIRQ_9',['../neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a350e762a599479fb2c6d23ccc5ee22b4',1,'neorv32_cpu_csr.h']]], + ['trap_5fcode_5fi_5faccess_35',['TRAP_CODE_I_ACCESS',['../neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a6a0ebfce4e18f36aeb43d5a65445cfe1',1,'neorv32_cpu_csr.h']]], + ['trap_5fcode_5fi_5fillegal_36',['TRAP_CODE_I_ILLEGAL',['../neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1af1ad8f557f3b685b59a913611e1da173',1,'neorv32_cpu_csr.h']]], + ['trap_5fcode_5fi_5fmisaligned_37',['TRAP_CODE_I_MISALIGNED',['../neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a0a8010d7cc91b9557973a7a118828bee',1,'neorv32_cpu_csr.h']]], + ['trap_5fcode_5fl_5faccess_38',['TRAP_CODE_L_ACCESS',['../neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a28448f0c670169140dc28b6794310cea',1,'neorv32_cpu_csr.h']]], + ['trap_5fcode_5fl_5fmisaligned_39',['TRAP_CODE_L_MISALIGNED',['../neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a69e68a954da0bb33d1624484a6777ff9',1,'neorv32_cpu_csr.h']]], + ['trap_5fcode_5fmei_40',['TRAP_CODE_MEI',['../neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a1a412b9d8eefba7880555d34625d2cc0',1,'neorv32_cpu_csr.h']]], + ['trap_5fcode_5fmenv_5fcall_41',['TRAP_CODE_MENV_CALL',['../neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a20e5a2680f2f5956bfa92852d5544eac',1,'neorv32_cpu_csr.h']]], + ['trap_5fcode_5fmsi_42',['TRAP_CODE_MSI',['../neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1ae0cebf99f36ef6be60e4a9d2c9f894b0',1,'neorv32_cpu_csr.h']]], + ['trap_5fcode_5fmti_43',['TRAP_CODE_MTI',['../neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a187ae38819b81672c15808e63c3b46b7',1,'neorv32_cpu_csr.h']]], + ['trap_5fcode_5fs_5faccess_44',['TRAP_CODE_S_ACCESS',['../neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a70bcfc75fe1056d93a3606f78c0cb887',1,'neorv32_cpu_csr.h']]], + ['trap_5fcode_5fs_5fmisaligned_45',['TRAP_CODE_S_MISALIGNED',['../neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a19708405f9f6300edf6b992c6d408a2d',1,'neorv32_cpu_csr.h']]], + ['trap_5fcode_5fuenv_5fcall_46',['TRAP_CODE_UENV_CALL',['../neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1aa102472d6a264bb92e0581ccaa413e02',1,'neorv32_cpu_csr.h']]], + ['trap_5fhandler_5femulate_5famo_47',['trap_handler_emulate_amo',['../atomic__test_2main_8c.html#aafcbf639ae4f66e5dfe9dea511a59f9d',1,'main.c']]], + ['trap_5fhandler_5femulate_5funaligned_5flw_48',['trap_handler_emulate_unaligned_lw',['../demo__emulate__unaligned_2main_8c.html#a07da42351229525998965b219e827460',1,'main.c']]], + ['trigger_5fmodule_5fdummy_49',['trigger_module_dummy',['../processor__check_2main_8c.html#ac91bfdd45696444673dc7d6b1b644082',1,'main.c']]], + ['trng_5fctrl_5fdata_5flsb_50',['TRNG_CTRL_DATA_LSB',['../neorv32__trng_8h.html#a1440e1355bf5bff17760992adc156b1aa50bb6e10e245a977dcf29a7a138776c6',1,'neorv32_trng.h']]], + ['trng_5fctrl_5fdata_5fmsb_51',['TRNG_CTRL_DATA_MSB',['../neorv32__trng_8h.html#a1440e1355bf5bff17760992adc156b1aa95620874acc9393a05d670824c0bbed2',1,'neorv32_trng.h']]], + ['trng_5fctrl_5fen_52',['TRNG_CTRL_EN',['../neorv32__trng_8h.html#a1440e1355bf5bff17760992adc156b1aa0bdf0194eefe95884c5c5853a2f7670d',1,'neorv32_trng.h']]], + ['trng_5fctrl_5ffifo_5fclr_53',['TRNG_CTRL_FIFO_CLR',['../neorv32__trng_8h.html#a1440e1355bf5bff17760992adc156b1aabf1bb7bc3b44394c85709edd1c9f03ac',1,'neorv32_trng.h']]], + ['trng_5fctrl_5ffifo_5flsb_54',['TRNG_CTRL_FIFO_LSB',['../neorv32__trng_8h.html#a1440e1355bf5bff17760992adc156b1aa8c0325eede4ffec4530cfd5dc700dc52',1,'neorv32_trng.h']]], + ['trng_5fctrl_5ffifo_5fmsb_55',['TRNG_CTRL_FIFO_MSB',['../neorv32__trng_8h.html#a1440e1355bf5bff17760992adc156b1aa919c3105723e4fe46e341c63cbf276f5',1,'neorv32_trng.h']]], + ['trng_5fctrl_5firq_5fsel_56',['TRNG_CTRL_IRQ_SEL',['../neorv32__trng_8h.html#a1440e1355bf5bff17760992adc156b1aa968a770fe6b172183dd97818e09c63da',1,'neorv32_trng.h']]], + ['trng_5fctrl_5fsim_5fmode_57',['TRNG_CTRL_SIM_MODE',['../neorv32__trng_8h.html#a1440e1355bf5bff17760992adc156b1aaa6990058793ac7d96250693f935837c5',1,'neorv32_trng.h']]], + ['trng_5fctrl_5fvalid_58',['TRNG_CTRL_VALID',['../neorv32__trng_8h.html#a1440e1355bf5bff17760992adc156b1aa2e0079358668db409fb763eaccb93da9',1,'neorv32_trng.h']]], + ['trng_5ffirq_5fenable_59',['TRNG_FIRQ_ENABLE',['../neorv32_8h.html#a2896d832852c016eb85210b523642f11',1,'neorv32.h']]], + ['trng_5ffirq_5fpending_60',['TRNG_FIRQ_PENDING',['../neorv32_8h.html#a9c387ca4e2736a27056c11819947c84a',1,'neorv32.h']]], + ['trng_5frte_5fid_61',['TRNG_RTE_ID',['../neorv32_8h.html#afaa705a674acf3fd6c8cb294eaf11c5e',1,'neorv32.h']]], + ['trng_5ftrap_5fcode_62',['TRNG_TRAP_CODE',['../neorv32_8h.html#a11e34802c61a01fd6cba46e3f92d5ac1',1,'neorv32.h']]], + ['ttyp_63',['TTYP',['../structneorv32__xirq__t.html#ab7117c210b5f0a8ebc369eeba6a4a5bc',1,'neorv32_xirq_t']]], + ['ttype_64',['TTYPE',['../structneorv32__dma__t.html#a70c28642195765409d97b941e98f47ca',1,'neorv32_dma_t']]], + ['twi_5fctrl_5fbusy_65',['TWI_CTRL_BUSY',['../neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaa443a2a65ee810f428d40a4f8474d8e6d',1,'neorv32_twi.h']]], + ['twi_5fctrl_5fcdiv0_66',['TWI_CTRL_CDIV0',['../neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaa75d3a61b5e642e5d5c1f699c35c26b31',1,'neorv32_twi.h']]], + ['twi_5fctrl_5fcdiv1_67',['TWI_CTRL_CDIV1',['../neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaa4473769463a0c7e4b58ed0b983610674',1,'neorv32_twi.h']]], + ['twi_5fctrl_5fcdiv2_68',['TWI_CTRL_CDIV2',['../neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaaa6db454861ad5be70846ed4f9eb2ea12',1,'neorv32_twi.h']]], + ['twi_5fctrl_5fcdiv3_69',['TWI_CTRL_CDIV3',['../neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaa99e2153a53cc1f9d7cc83d52c698cbcc',1,'neorv32_twi.h']]], + ['twi_5fctrl_5fclkstr_70',['TWI_CTRL_CLKSTR',['../neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaac62d6e3c47a8195a6a9ccc79129bfe48',1,'neorv32_twi.h']]], + ['twi_5fctrl_5fen_71',['TWI_CTRL_EN',['../neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaa43381fe5ab9fe64ebdf76638eba5a694',1,'neorv32_twi.h']]], + ['twi_5fctrl_5ffifo_5flsb_72',['TWI_CTRL_FIFO_LSB',['../neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaa74126d424719b1db61f5e1ab567489fb',1,'neorv32_twi.h']]], + ['twi_5fctrl_5ffifo_5fmsb_73',['TWI_CTRL_FIFO_MSB',['../neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaa183f5b9c3993d04cc9aea2a79e9a4f75',1,'neorv32_twi.h']]], + ['twi_5fctrl_5fprsc0_74',['TWI_CTRL_PRSC0',['../neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaa9033ac6cc891bff0da52449aa4b6a8d9',1,'neorv32_twi.h']]], + ['twi_5fctrl_5fprsc1_75',['TWI_CTRL_PRSC1',['../neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaa8b666cd2e40ca9ba3f9a635f0ed107df',1,'neorv32_twi.h']]], + ['twi_5fctrl_5fprsc2_76',['TWI_CTRL_PRSC2',['../neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaa4d55ed983ca2f94fa9deac196d949b31',1,'neorv32_twi.h']]], + ['twi_5fctrl_5frx_5favail_77',['TWI_CTRL_RX_AVAIL',['../neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaad2798dfabf3a72e6138135e983734671',1,'neorv32_twi.h']]], + ['twi_5fctrl_5ftx_5ffull_78',['TWI_CTRL_TX_FULL',['../neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaaa0597dc9dea3f6f7a2f19dbcc7a2dabb',1,'neorv32_twi.h']]], + ['twi_5fdcmd_5fack_79',['TWI_DCMD_ACK',['../neorv32__twi_8h.html#a3421852c63baca60fe58c990b1c653d8af64359afd3627db0a79733d00128f3a5',1,'neorv32_twi.h']]], + ['twi_5fdcmd_5fcmd_5fhi_80',['TWI_DCMD_CMD_HI',['../neorv32__twi_8h.html#a3421852c63baca60fe58c990b1c653d8accd7e8be435db3055c27f0a6d5e0201e',1,'neorv32_twi.h']]], + ['twi_5fdcmd_5fcmd_5flo_81',['TWI_DCMD_CMD_LO',['../neorv32__twi_8h.html#a3421852c63baca60fe58c990b1c653d8ab2e20f7f5a5b131c31772341caa97e5e',1,'neorv32_twi.h']]], + ['twi_5fdcmd_5flsb_82',['TWI_DCMD_LSB',['../neorv32__twi_8h.html#a3421852c63baca60fe58c990b1c653d8adf6176c87655bbbb5c7cea9dea29ce56',1,'neorv32_twi.h']]], + ['twi_5fdcmd_5fmsb_83',['TWI_DCMD_MSB',['../neorv32__twi_8h.html#a3421852c63baca60fe58c990b1c653d8ab7f53f7cef06031c1a34db04c602a50d',1,'neorv32_twi.h']]], + ['twi_5ffirq_5fenable_84',['TWI_FIRQ_ENABLE',['../neorv32_8h.html#a0913144fce247e24ccd0f178b9ac32b7',1,'neorv32.h']]], + ['twi_5ffirq_5fpending_85',['TWI_FIRQ_PENDING',['../neorv32_8h.html#a48b80113ca718fbdc50d75e1ec96a1ff',1,'neorv32.h']]], + ['twi_5frte_5fid_86',['TWI_RTE_ID',['../neorv32_8h.html#a1ac29f2f7bace5ba92b2b68a4541a60c',1,'neorv32.h']]], + ['twi_5ftrap_5fcode_87',['TWI_TRAP_CODE',['../neorv32_8h.html#a0afc1a759116d4d73a199ef769bced47',1,'neorv32.h']]] +]; diff --git a/sw/search/all_19.js b/sw/search/all_19.js new file mode 100644 index 0000000000..e0e5baac41 --- /dev/null +++ b/sw/search/all_19.js @@ -0,0 +1,70 @@ +var searchData= +[ + ['uart0_5frx_5ffirq_5fenable_0',['UART0_RX_FIRQ_ENABLE',['../neorv32_8h.html#a6b55ce6abe6b141000a6bb00949169e9',1,'neorv32.h']]], + ['uart0_5frx_5ffirq_5fpending_1',['UART0_RX_FIRQ_PENDING',['../neorv32_8h.html#a0b738b26abb2b951f1f5c5d9525d7701',1,'neorv32.h']]], + ['uart0_5frx_5frte_5fid_2',['UART0_RX_RTE_ID',['../neorv32_8h.html#ae8588cca20d5e36f74c5207c376389a1',1,'neorv32.h']]], + ['uart0_5frx_5ftrap_5fcode_3',['UART0_RX_TRAP_CODE',['../neorv32_8h.html#a7a849638eff31f2e1955bdc53d4fc84d',1,'neorv32.h']]], + ['uart0_5ftx_5ffirq_5fenable_4',['UART0_TX_FIRQ_ENABLE',['../neorv32_8h.html#aff756a395771f22c5f412f23f177ea7d',1,'neorv32.h']]], + ['uart0_5ftx_5ffirq_5fpending_5',['UART0_TX_FIRQ_PENDING',['../neorv32_8h.html#addbe29166bb77bc045ad0e3db68e57e9',1,'neorv32.h']]], + ['uart0_5ftx_5frte_5fid_6',['UART0_TX_RTE_ID',['../neorv32_8h.html#a9dc37695ca169bc0eb93898e7aeeee58',1,'neorv32.h']]], + ['uart0_5ftx_5ftrap_5fcode_7',['UART0_TX_TRAP_CODE',['../neorv32_8h.html#ab50df423fdba86bb83bc5d90a4c3bb20',1,'neorv32.h']]], + ['uart1_5frx_5ffirq_5fenable_8',['UART1_RX_FIRQ_ENABLE',['../neorv32_8h.html#a6c118c1784d8446360b00cde97437ca7',1,'neorv32.h']]], + ['uart1_5frx_5ffirq_5fpending_9',['UART1_RX_FIRQ_PENDING',['../neorv32_8h.html#a2e70d3a4e2973d224643813fcf315a20',1,'neorv32.h']]], + ['uart1_5frx_5frte_5fid_10',['UART1_RX_RTE_ID',['../neorv32_8h.html#ab1c351f5ea19ac9ea864155be9cc0b4b',1,'neorv32.h']]], + ['uart1_5frx_5ftrap_5fcode_11',['UART1_RX_TRAP_CODE',['../neorv32_8h.html#ad0b9eb2ee1f411d7fccdf4fe263214e1',1,'neorv32.h']]], + ['uart1_5ftx_5ffirq_5fenable_12',['UART1_TX_FIRQ_ENABLE',['../neorv32_8h.html#a0039bae3454a22e71d64e70d674f5d6a',1,'neorv32.h']]], + ['uart1_5ftx_5ffirq_5fpending_13',['UART1_TX_FIRQ_PENDING',['../neorv32_8h.html#ac4060532b7aa390623f54720460a2680',1,'neorv32.h']]], + ['uart1_5ftx_5frte_5fid_14',['UART1_TX_RTE_ID',['../neorv32_8h.html#a6af270d7ae8b1cde30e44eb9142491d3',1,'neorv32.h']]], + ['uart1_5ftx_5ftrap_5fcode_15',['UART1_TX_TRAP_CODE',['../neorv32_8h.html#a4cc50287c7a53982761a8116396ff7dd',1,'neorv32.h']]], + ['uart_5fbaud_16',['UART_BAUD',['../bootloader_8c.html#a1fac9153314479ad0ad495d752f0224a',1,'bootloader.c']]], + ['uart_5fctrl_5fbaud0_17',['UART_CTRL_BAUD0',['../neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afcad38432e7e050276d4667daf92c1e3fd5',1,'neorv32_uart.h']]], + ['uart_5fctrl_5fbaud1_18',['UART_CTRL_BAUD1',['../neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca1e702002402897eca82bf398504bc439',1,'neorv32_uart.h']]], + ['uart_5fctrl_5fbaud2_19',['UART_CTRL_BAUD2',['../neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca36266026e11f22aca1584bd81cd38cd6',1,'neorv32_uart.h']]], + ['uart_5fctrl_5fbaud3_20',['UART_CTRL_BAUD3',['../neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca58190cd41c2ce69512bea10740d35276',1,'neorv32_uart.h']]], + ['uart_5fctrl_5fbaud4_21',['UART_CTRL_BAUD4',['../neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca81ea805f01b93a59664823b940c7a424',1,'neorv32_uart.h']]], + ['uart_5fctrl_5fbaud5_22',['UART_CTRL_BAUD5',['../neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca5da1d6007af0265fe48ace8469e07833',1,'neorv32_uart.h']]], + ['uart_5fctrl_5fbaud6_23',['UART_CTRL_BAUD6',['../neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca9ac3c1e23d684cb2f67060d6ebe1fa63',1,'neorv32_uart.h']]], + ['uart_5fctrl_5fbaud7_24',['UART_CTRL_BAUD7',['../neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca9c12648f7f058f444db434cd8a8d854e',1,'neorv32_uart.h']]], + ['uart_5fctrl_5fbaud8_25',['UART_CTRL_BAUD8',['../neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca09c311eb1f6b38500e6fcbb6ad9dd9ff',1,'neorv32_uart.h']]], + ['uart_5fctrl_5fbaud9_26',['UART_CTRL_BAUD9',['../neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca697321bddeaa2cac1ea034c418be540e',1,'neorv32_uart.h']]], + ['uart_5fctrl_5fen_27',['UART_CTRL_EN',['../neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca38f6c0e5991f8f80159a388c1080f7c2',1,'neorv32_uart.h']]], + ['uart_5fctrl_5fhwfc_5fen_28',['UART_CTRL_HWFC_EN',['../neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afcacab78fcd440167c5a2c0f5d300c8f07c',1,'neorv32_uart.h']]], + ['uart_5fctrl_5firq_5frx_5ffull_29',['UART_CTRL_IRQ_RX_FULL',['../neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afcae5f01868b170d71a5f3064023c96a82a',1,'neorv32_uart.h']]], + ['uart_5fctrl_5firq_5frx_5fhalf_30',['UART_CTRL_IRQ_RX_HALF',['../neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afcaa219ea3ed5b21f5023bbc5ffa5c5f175',1,'neorv32_uart.h']]], + ['uart_5fctrl_5firq_5frx_5fnempty_31',['UART_CTRL_IRQ_RX_NEMPTY',['../neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca569ea830518914c5330fa14680b02851',1,'neorv32_uart.h']]], + ['uart_5fctrl_5firq_5ftx_5fempty_32',['UART_CTRL_IRQ_TX_EMPTY',['../neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca15b9fca73877aad446a8cd338e228e2c',1,'neorv32_uart.h']]], + ['uart_5fctrl_5firq_5ftx_5fnhalf_33',['UART_CTRL_IRQ_TX_NHALF',['../neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca726b73ef9c44ccc1a45a4230a8bda9d1',1,'neorv32_uart.h']]], + ['uart_5fctrl_5fprsc0_34',['UART_CTRL_PRSC0',['../neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca1ddbca448bb30c77c42499fff1312183',1,'neorv32_uart.h']]], + ['uart_5fctrl_5fprsc1_35',['UART_CTRL_PRSC1',['../neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca9c1d8e8763a653339210ff4e6e3067d2',1,'neorv32_uart.h']]], + ['uart_5fctrl_5fprsc2_36',['UART_CTRL_PRSC2',['../neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca8afd60e4bd3854fab623b91fa4f33f70',1,'neorv32_uart.h']]], + ['uart_5fctrl_5frx_5fclr_37',['UART_CTRL_RX_CLR',['../neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afcaefbef37247d88a7e38e1c53b8a33ed33',1,'neorv32_uart.h']]], + ['uart_5fctrl_5frx_5ffull_38',['UART_CTRL_RX_FULL',['../neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca47c44fa21e51401621c28019025c1166',1,'neorv32_uart.h']]], + ['uart_5fctrl_5frx_5fhalf_39',['UART_CTRL_RX_HALF',['../neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca3fc934d0ce6b36e3e131c6682db22247',1,'neorv32_uart.h']]], + ['uart_5fctrl_5frx_5fnempty_40',['UART_CTRL_RX_NEMPTY',['../neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca2015dd85e361aa0476e847953b62baff',1,'neorv32_uart.h']]], + ['uart_5fctrl_5frx_5fover_41',['UART_CTRL_RX_OVER',['../neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca81a52e0b81018f2cf43e64d74caba632',1,'neorv32_uart.h']]], + ['uart_5fctrl_5fsim_5fmode_42',['UART_CTRL_SIM_MODE',['../neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca42ed376220259ab22c6f837d08273ef1',1,'neorv32_uart.h']]], + ['uart_5fctrl_5ftx_5fbusy_43',['UART_CTRL_TX_BUSY',['../neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca0eb636d8b7961d7073c5c7341b5bbe25',1,'neorv32_uart.h']]], + ['uart_5fctrl_5ftx_5fclr_44',['UART_CTRL_TX_CLR',['../neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca408412a32673cc7f6ea70682e3e61431',1,'neorv32_uart.h']]], + ['uart_5fctrl_5ftx_5fempty_45',['UART_CTRL_TX_EMPTY',['../neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afcac5c044233b6c4162cf862f3d9831ef46',1,'neorv32_uart.h']]], + ['uart_5fctrl_5ftx_5ffull_46',['UART_CTRL_TX_FULL',['../neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca36b4195e5d1f12e1fd1a0d30cad0e411',1,'neorv32_uart.h']]], + ['uart_5fctrl_5ftx_5fnhalf_47',['UART_CTRL_TX_NHALF',['../neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca5b0e40ab30bdb198f496d09e89d2d0d9',1,'neorv32_uart.h']]], + ['uart_5fdata_5frtx_5flsb_48',['UART_DATA_RTX_LSB',['../neorv32__uart_8h.html#adcf35350a9ea18a59c32c35f528643f2ae70e9f6cd69af724932e79ea7e7f7195',1,'neorv32_uart.h']]], + ['uart_5fdata_5frtx_5fmsb_49',['UART_DATA_RTX_MSB',['../neorv32__uart_8h.html#adcf35350a9ea18a59c32c35f528643f2a19926d013ca202645d38f2c704782ebb',1,'neorv32_uart.h']]], + ['uart_5fdata_5frx_5ffifo_5fsize_5flsb_50',['UART_DATA_RX_FIFO_SIZE_LSB',['../neorv32__uart_8h.html#adcf35350a9ea18a59c32c35f528643f2a43b296e86d1f2ec7400d57655c3180ef',1,'neorv32_uart.h']]], + ['uart_5fdata_5frx_5ffifo_5fsize_5fmsb_51',['UART_DATA_RX_FIFO_SIZE_MSB',['../neorv32__uart_8h.html#adcf35350a9ea18a59c32c35f528643f2a81a82ac0dc5c8c8d7af21553288e3225',1,'neorv32_uart.h']]], + ['uart_5fdata_5ftx_5ffifo_5fsize_5flsb_52',['UART_DATA_TX_FIFO_SIZE_LSB',['../neorv32__uart_8h.html#adcf35350a9ea18a59c32c35f528643f2a6d718ad0bb82a5cb053c117cd2d6ca8e',1,'neorv32_uart.h']]], + ['uart_5fdata_5ftx_5ffifo_5fsize_5fmsb_53',['UART_DATA_TX_FIFO_SIZE_MSB',['../neorv32__uart_8h.html#adcf35350a9ea18a59c32c35f528643f2ada92cbbe278e3e0592eba58c97699529',1,'neorv32_uart.h']]], + ['uart_5fen_54',['UART_EN',['../bootloader_8c.html#af1c2f103ac6e3183f08b39099fab2be9',1,'bootloader.c']]], + ['uart_5fget_5fexecutable_55',['uart_get_executable',['../demo__xip_2main_8c.html#a0458656f8a108ff31f4bbbd005f029a0',1,'main.c']]], + ['uart_5fget_5fword_56',['uart_get_word',['../demo__xip_2main_8c.html#a3043d09bdc155f57f45cd91e0cd4d15b',1,'main.c']]], + ['uart_5fhw_5fhandshake_5fen_57',['UART_HW_HANDSHAKE_EN',['../bootloader_8c.html#a20e93d623ce07939c3fdd53898f9d583',1,'bootloader.c']]], + ['ug_20user_20guide_20a_20getting_20started_58',[':rocket: &lt;a href=&quot;https://stnolting.github.io/neorv32/ug/&quot; &gt;User Guide&lt;/a&gt; - Getting Started!',['../md_README.html#autotoc_md12',1,'']]], + ['uint16fifo_59',['uint16Fifo',['../structt__neorv32__spi.html#a71fb3f91af197e1abdbe97d62130ad0f',1,'t_neorv32_spi']]], + ['uint32read_60',['uint32Read',['../structt__neorv32__spi.html#a5750a54f8312ec2fed349eb9fbeff323',1,'t_neorv32_spi']]], + ['uint32total_61',['uint32Total',['../structt__neorv32__spi.html#aa4d96f72e57fb6930ab43de6fb0a85ae',1,'t_neorv32_spi']]], + ['uint32write_62',['uint32Write',['../structt__neorv32__spi.html#aa89b7a769e54e331798e4d68d02a7b43',1,'t_neorv32_spi']]], + ['uint8csn_63',['uint8Csn',['../structt__neorv32__spi.html#a435c266758a440d32de4344472e3514a',1,'t_neorv32_spi']]], + ['uint8isbusy_64',['uint8IsBusy',['../structt__neorv32__spi.html#a8ed31f9393bee5b963e08582b6c517ed',1,'t_neorv32_spi']]], + ['universe_65',['universe',['../game__of__life_2main_8c.html#ae0b5214cf0cd93049e9df8a95a09d826',1,'main.c']]], + ['user_20guide_20a_20getting_20started_66',[':rocket: &lt;a href=&quot;https://stnolting.github.io/neorv32/ug/&quot; &gt;User Guide&lt;/a&gt; - Getting Started!',['../md_README.html#autotoc_md12',1,'']]] +]; diff --git a/sw/search/all_1a.js b/sw/search/all_1a.js new file mode 100644 index 0000000000..922a76a9be --- /dev/null +++ b/sw/search/all_1a.js @@ -0,0 +1,8 @@ +var searchData= +[ + ['v_20processor_0',['The NEORV32 RISC-V Processor',['../md_README.html#autotoc_md0',1,'']]], + ['vectored_5fglobal_5fhandler_1',['vectored_global_handler',['../processor__check_2main_8c.html#a9504ca74fdb80711a88d2a16d4cb4cf4',1,'main.c']]], + ['vectored_5firq_5ftable_2',['vectored_irq_table',['../processor__check_2main_8c.html#a0d695ebfaae3b4614ddb62640cbf8b7b',1,'main.c']]], + ['vectored_5fmei_5fhandler_3',['vectored_mei_handler',['../processor__check_2main_8c.html#a1a455bede4ab48f32d3ed0868e398044',1,'main.c']]], + ['verify_5fresult_4',['verify_result',['../float__corner__test_2main_8c.html#a941ef8d24fd8e8fe4536626b2ce72410',1,'verify_result(uint32_t num, uint32_t opa, uint32_t opb, uint32_t ref, uint32_t res):&#160;main.c'],['../floating__point__test_2main_8c.html#a941ef8d24fd8e8fe4536626b2ce72410',1,'verify_result(uint32_t num, uint32_t opa, uint32_t opb, uint32_t ref, uint32_t res):&#160;main.c']]] +]; diff --git a/sw/search/all_1b.js b/sw/search/all_1b.js new file mode 100644 index 0000000000..fcd963d5e9 --- /dev/null +++ b/sw/search/all_1b.js @@ -0,0 +1,20 @@ +var searchData= +[ + ['wdt_5fctrl_5fdben_0',['WDT_CTRL_DBEN',['../neorv32__wdt_8h.html#a0a4cb24fd818277c5bb9b10ff519f23ea4b0d994fe5ff8d8004c7f25b621fb3a9',1,'neorv32_wdt.h']]], + ['wdt_5fctrl_5fen_1',['WDT_CTRL_EN',['../neorv32__wdt_8h.html#a0a4cb24fd818277c5bb9b10ff519f23ea0e078b41b69bd6089acceb592e14553f',1,'neorv32_wdt.h']]], + ['wdt_5fctrl_5flock_2',['WDT_CTRL_LOCK',['../neorv32__wdt_8h.html#a0a4cb24fd818277c5bb9b10ff519f23eadc44267502fceb8e7311dfa502fe54d3',1,'neorv32_wdt.h']]], + ['wdt_5fctrl_5frcause_5fhi_3',['WDT_CTRL_RCAUSE_HI',['../neorv32__wdt_8h.html#a0a4cb24fd818277c5bb9b10ff519f23ea6012d63ea4734fc8a063c9edc6785abd',1,'neorv32_wdt.h']]], + ['wdt_5fctrl_5frcause_5flo_4',['WDT_CTRL_RCAUSE_LO',['../neorv32__wdt_8h.html#a0a4cb24fd818277c5bb9b10ff519f23ea0e7d3e97517f97042ce5606dd5247779',1,'neorv32_wdt.h']]], + ['wdt_5fctrl_5fsen_5',['WDT_CTRL_SEN',['../neorv32__wdt_8h.html#a0a4cb24fd818277c5bb9b10ff519f23ea7b7ea5bd390ecbb5ee0d9542ef124148',1,'neorv32_wdt.h']]], + ['wdt_5fctrl_5fstrict_6',['WDT_CTRL_STRICT',['../neorv32__wdt_8h.html#a0a4cb24fd818277c5bb9b10ff519f23ea28dd25b66c4a50d0ea47a16c460031ac',1,'neorv32_wdt.h']]], + ['wdt_5fctrl_5ftimeout_5flsb_7',['WDT_CTRL_TIMEOUT_LSB',['../neorv32__wdt_8h.html#a0a4cb24fd818277c5bb9b10ff519f23ea45df3c9100beb420add34bf71a0e8609',1,'neorv32_wdt.h']]], + ['wdt_5fctrl_5ftimeout_5fmsb_8',['WDT_CTRL_TIMEOUT_MSB',['../neorv32__wdt_8h.html#a0a4cb24fd818277c5bb9b10ff519f23ea25dea2104b29a3c20dcc3782c2d43dc7',1,'neorv32_wdt.h']]], + ['wdt_5fpassword_9',['WDT_PASSWORD',['../neorv32__wdt_8h.html#af2a2bd9c74bdba1b46bd92025bd00ab6',1,'neorv32_wdt.h']]], + ['wdt_5frcause_5fext_10',['WDT_RCAUSE_EXT',['../neorv32__wdt_8h.html#a70098b4ee893774864536fb4100ff049ac5fc25cdc29c248b1a570b6095ddded0',1,'neorv32_wdt.h']]], + ['wdt_5frcause_5focd_11',['WDT_RCAUSE_OCD',['../neorv32__wdt_8h.html#a70098b4ee893774864536fb4100ff049a764a7797f17d82f619a6d30c0878bf1e',1,'neorv32_wdt.h']]], + ['wdt_5frcause_5fwdt_12',['WDT_RCAUSE_WDT',['../neorv32__wdt_8h.html#a70098b4ee893774864536fb4100ff049a974e73fb98b6a3591c214eba6071fd3c',1,'neorv32_wdt.h']]], + ['wdt_5ftimeout_5fs_13',['WDT_TIMEOUT_S',['../demo__wdt_2main_8c.html#a01af3905e60b1869f669315f4a1297f5',1,'main.c']]], + ['weekday_14',['weekday',['../structdate__t.html#a44167cd71416886e55048310af6d4e1b',1,'date_t']]], + ['write_5fbyte_15',['write_byte',['../demo__onewire_2main_8c.html#a28283848f09bf8feebc860a51545f487',1,'main.c']]], + ['write_5fmemory_16',['write_memory',['../bus__explorer_2main_8c.html#a96729fb5279642ac56c8e6a513789b45',1,'main.c']]] +]; diff --git a/sw/search/all_1c.js b/sw/search/all_1c.js new file mode 100644 index 0000000000..5faa061518 --- /dev/null +++ b/sw/search/all_1c.js @@ -0,0 +1,50 @@ +var searchData= +[ + ['xip_5fclk_5fprsc_0',['XIP_CLK_PRSC',['../demo__xip_2main_8c.html#aec72efe062dbdb149ae6d4f8b1be6793',1,'main.c']]], + ['xip_5fctrl_5fburst_5fen_1',['XIP_CTRL_BURST_EN',['../neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba7ad9f81356d6923d524d1c9e39acdd2c',1,'neorv32_xip.h']]], + ['xip_5fctrl_5fcdiv0_2',['XIP_CTRL_CDIV0',['../neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483cebaf9b56aa629973ce4a9c8ff61a2c90ba3',1,'neorv32_xip.h']]], + ['xip_5fctrl_5fcdiv1_3',['XIP_CTRL_CDIV1',['../neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba68775854b8f2cfa2f32d2eb82a714073',1,'neorv32_xip.h']]], + ['xip_5fctrl_5fcdiv2_4',['XIP_CTRL_CDIV2',['../neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba43d7305e0e0398cb44c99e70dcd96445',1,'neorv32_xip.h']]], + ['xip_5fctrl_5fcdiv3_5',['XIP_CTRL_CDIV3',['../neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba61ffffe9acda5c622b48b6360e357eef',1,'neorv32_xip.h']]], + ['xip_5fctrl_5fcpha_6',['XIP_CTRL_CPHA',['../neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483cebad31736f4a159745be94b487079c4c14d',1,'neorv32_xip.h']]], + ['xip_5fctrl_5fcpol_7',['XIP_CTRL_CPOL',['../neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba95ae19cf5d5140df397ead62f151247f',1,'neorv32_xip.h']]], + ['xip_5fctrl_5fen_8',['XIP_CTRL_EN',['../neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba27658ce3cc81c9e258b73fb02d7f1045',1,'neorv32_xip.h']]], + ['xip_5fctrl_5fhighspeed_9',['XIP_CTRL_HIGHSPEED',['../neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483cebaaeb104a59215667aabb5a751632ae781',1,'neorv32_xip.h']]], + ['xip_5fctrl_5fphy_5fbusy_10',['XIP_CTRL_PHY_BUSY',['../neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba76d2379d0e7ab09e7e686bc886888fa5',1,'neorv32_xip.h']]], + ['xip_5fctrl_5fprsc0_11',['XIP_CTRL_PRSC0',['../neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba67a0c0483eaf92e9cd03e9076be5b50d',1,'neorv32_xip.h']]], + ['xip_5fctrl_5fprsc1_12',['XIP_CTRL_PRSC1',['../neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483cebae47f2e1e8c023fd52e25a3dad5e332af',1,'neorv32_xip.h']]], + ['xip_5fctrl_5fprsc2_13',['XIP_CTRL_PRSC2',['../neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba896815c075a91a8291585eb61b6e0086',1,'neorv32_xip.h']]], + ['xip_5fctrl_5frd_5fcmd_5flsb_14',['XIP_CTRL_RD_CMD_LSB',['../neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba8287016f167727f147806aa11129e05b',1,'neorv32_xip.h']]], + ['xip_5fctrl_5frd_5fcmd_5fmsb_15',['XIP_CTRL_RD_CMD_MSB',['../neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba2c78cd2d32cfba4d89f7aab92f7939e7',1,'neorv32_xip.h']]], + ['xip_5fctrl_5fspi_5fcsen_16',['XIP_CTRL_SPI_CSEN',['../neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba5aadb2c374d34b878b56a660baec2080',1,'neorv32_xip.h']]], + ['xip_5fctrl_5fspi_5fnbytes_5flsb_17',['XIP_CTRL_SPI_NBYTES_LSB',['../neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba23be66e49d28dd12c5321e576d2f0c7a',1,'neorv32_xip.h']]], + ['xip_5fctrl_5fspi_5fnbytes_5fmsb_18',['XIP_CTRL_SPI_NBYTES_MSB',['../neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba5d13c4fe190fcd68dfcbbbe33d2e844c',1,'neorv32_xip.h']]], + ['xip_5fctrl_5fxip_5fabytes_5flsb_19',['XIP_CTRL_XIP_ABYTES_LSB',['../neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba603f9d8d22ae2a6abc61b666bc88a4df',1,'neorv32_xip.h']]], + ['xip_5fctrl_5fxip_5fabytes_5fmsb_20',['XIP_CTRL_XIP_ABYTES_MSB',['../neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba5885ed5fcd2eed969bd921afe8dff4fc',1,'neorv32_xip.h']]], + ['xip_5fctrl_5fxip_5fbusy_21',['XIP_CTRL_XIP_BUSY',['../neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba2c4a47f88d299782b8618b68fb87d59a',1,'neorv32_xip.h']]], + ['xip_5fctrl_5fxip_5fen_22',['XIP_CTRL_XIP_EN',['../neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba3cbd45a66e05a4fcfc5ec810b8cee937',1,'neorv32_xip.h']]], + ['xip_5fen_23',['XIP_EN',['../bootloader_8c.html#a2cf31934b909299fb93bb5eebdbc7c9e',1,'bootloader.c']]], + ['xip_5fflash_5faccess_5fcheck_24',['xip_flash_access_check',['../demo__xip_2main_8c.html#a23bd7bd7b0808d919fd09ac0a8258498',1,'main.c']]], + ['xip_5fflash_5ferase_5fsector_25',['xip_flash_erase_sector',['../demo__xip_2main_8c.html#a9e0b2714126b6699ddb65485c93293e4',1,'main.c']]], + ['xip_5fflash_5fprogram_26',['xip_flash_program',['../demo__xip_2main_8c.html#a4ddfa8fdc072cadeef18a4a10bc8b174',1,'main.c']]], + ['xip_5fmem_5fbase_5faddress_27',['XIP_MEM_BASE_ADDRESS',['../neorv32_8h.html#aa01bea676e878a9e87ca10ce2d91e51f',1,'neorv32.h']]], + ['xirq_5ffirq_5fenable_28',['XIRQ_FIRQ_ENABLE',['../neorv32_8h.html#afe0cb262d517c7da73d6b5dc78886334',1,'neorv32.h']]], + ['xirq_5ffirq_5fpending_29',['XIRQ_FIRQ_PENDING',['../neorv32_8h.html#a866768963f8648363dce40de9f34d61b',1,'neorv32.h']]], + ['xirq_5fhandler_5fch0_30',['xirq_handler_ch0',['../demo__xirq_2main_8c.html#a8874ccfc0b56171c359b5c2ceaf2bd80',1,'main.c']]], + ['xirq_5fhandler_5fch1_31',['xirq_handler_ch1',['../demo__xirq_2main_8c.html#abfe0c0bc47a683ba55df2aed63a12d4b',1,'main.c']]], + ['xirq_5fhandler_5fch2_32',['xirq_handler_ch2',['../demo__xirq_2main_8c.html#ae8e3b3236aa2303c2b5e6e421b72cf73',1,'main.c']]], + ['xirq_5fhandler_5fch3_33',['xirq_handler_ch3',['../demo__xirq_2main_8c.html#a99e9ae3088f39995c852b2c53ec21266',1,'main.c']]], + ['xirq_5frte_5fid_34',['XIRQ_RTE_ID',['../neorv32_8h.html#a95387d3482ec8e5c1d734805fdf64fa5',1,'neorv32.h']]], + ['xirq_5ftrap_5fcode_35',['XIRQ_TRAP_CODE',['../neorv32_8h.html#a16b9a7444833b5581df073661deb8f3a',1,'neorv32.h']]], + ['xirq_5ftrap_5fhandler0_36',['xirq_trap_handler0',['../processor__check_2main_8c.html#aa4fe70578c4dccabe1e31fae941378cb',1,'main.c']]], + ['xirq_5ftrap_5fhandler1_37',['xirq_trap_handler1',['../processor__check_2main_8c.html#a277cb06ef74e4cfe1ef783069f9b6527',1,'main.c']]], + ['xirq_5ftrigger_5fedge_5ffalling_38',['XIRQ_TRIGGER_EDGE_FALLING',['../neorv32__xirq_8h.html#a59316ffc7ee1aacf1d55d460bdca4d04',1,'neorv32_xirq.h']]], + ['xirq_5ftrigger_5fedge_5frising_39',['XIRQ_TRIGGER_EDGE_RISING',['../neorv32__xirq_8h.html#ab7a05371e4dc3de3a9be11c59f5376ee',1,'neorv32_xirq.h']]], + ['xirq_5ftrigger_5flevel_5fhigh_40',['XIRQ_TRIGGER_LEVEL_HIGH',['../neorv32__xirq_8h.html#a9b10e89b2e257e1af410bff89f29911c',1,'neorv32_xirq.h']]], + ['xirq_5ftrigger_5flevel_5flow_41',['XIRQ_TRIGGER_LEVEL_LOW',['../neorv32__xirq_8h.html#a8bc89e6a47b4d0d95fb2afac4cdc9292',1,'neorv32_xirq.h']]], + ['xstr_42',['xstr',['../bootloader_8c.html#aff6b53dd58cea43d24393a9a2f79e772',1,'bootloader.c']]], + ['xtea_5fcycles_43',['XTEA_CYCLES',['../demo__cfu_2main_8c.html#a34755f457331741d24090b3819b5d416',1,'main.c']]], + ['xtea_5fdelta_44',['xtea_delta',['../demo__cfu_2main_8c.html#a26da64691624f3c899f2394a427d6593',1,'main.c']]], + ['xtea_5fsw_5fdecipher_45',['xtea_sw_decipher',['../demo__cfu_2main_8c.html#a0e980c5d81b1eca90b8073e54099bdb0',1,'main.c']]], + ['xtea_5fsw_5fencipher_46',['xtea_sw_encipher',['../demo__cfu_2main_8c.html#a8dc502bf508491eed1f39c4acf040efb',1,'main.c']]] +]; diff --git a/sw/search/all_1d.js b/sw/search/all_1d.js new file mode 100644 index 0000000000..e613d54073 --- /dev/null +++ b/sw/search/all_1d.js @@ -0,0 +1,4 @@ +var searchData= +[ + ['year_0',['year',['../structdate__t.html#aabab1b1efd94b69bfb28b639c612dd4f',1,'date_t']]] +]; diff --git a/sw/search/all_2.js b/sw/search/all_2.js new file mode 100644 index 0000000000..5446ba6c31 --- /dev/null +++ b/sw/search/all_2.js @@ -0,0 +1,4 @@ +var searchData= +[ + ['3_20fpga_20implementation_20results_0',['3. FPGA Implementation Results',['../md_README.html#autotoc_md5',1,'']]] +]; diff --git a/sw/search/all_3.js b/sw/search/all_3.js new file mode 100644 index 0000000000..c0b02ef08a --- /dev/null +++ b/sw/search/all_3.js @@ -0,0 +1,4 @@ +var searchData= +[ + ['4_20performance_0',['4. Performance',['../md_README.html#autotoc_md6',1,'']]] +]; diff --git a/sw/search/all_4.js b/sw/search/all_4.js new file mode 100644 index 0000000000..45ecc7f21c --- /dev/null +++ b/sw/search/all_4.js @@ -0,0 +1,4 @@ +var searchData= +[ + ['5_20getting_20started_0',['5. Getting Started',['../md_README.html#autotoc_md7',1,'']]] +]; diff --git a/sw/search/all_5.js b/sw/search/all_5.js new file mode 100644 index 0000000000..aecbaf92b7 --- /dev/null +++ b/sw/search/all_5.js @@ -0,0 +1,10 @@ +var searchData= +[ + ['_3aabacus_3a_20a_20href_20https_3a_20stnolting_20github_20io_20neorv32_20_5fneorv32_5fcentral_5fprocessing_5funit_5fcpu_20neorv32_20cpu_20a_20the_20core_0',[':abacus: &lt;a href=&quot;https://stnolting.github.io/neorv32/#_neorv32_central_processing_unit_cpu&quot; &gt;NEORV32 CPU&lt;/a&gt; - The Core',['../md_README.html#autotoc_md10',1,'']]], + ['_3acopyright_3a_20legal_1',[':copyright: Legal',['../md_README.html#autotoc_md13',1,'']]], + ['_3adesktop_5fcomputer_3a_20a_20href_20https_3a_20stnolting_20github_20io_20neorv32_20_5fneorv32_5fprocessor_5fsoc_20neorv32_20processor_20a_20the_20soc_2',[':desktop_computer: &lt;a href=&quot;https://stnolting.github.io/neorv32/#_neorv32_processor_soc&quot; &gt;NEORV32 Processor&lt;/a&gt; - The SoC',['../md_README.html#autotoc_md9',1,'']]], + ['_3aemail_3a_20contact_3',[':email: Contact',['../md_README.html#autotoc_md14',1,'']]], + ['_3afloppy_5fdisk_3a_20a_20href_20https_3a_20stnolting_20github_20io_20neorv32_20_5fsoftware_5fframework_20software_20framework_20a_20the_20software_20ecosystem_4',[':floppy_disk: &lt;a href=&quot;https://stnolting.github.io/neorv32/#_software_framework&quot; &gt;Software Framework&lt;/a&gt; - The Software Ecosystem',['../md_README.html#autotoc_md11',1,'']]], + ['_3amag_3a_20a_20href_20https_3a_20stnolting_20github_20io_20neorv32_20_5foverview_20neorv32_20project_20a_20an_20introduction_5',[':mag: &lt;a href=&quot;https://stnolting.github.io/neorv32/#_overview&quot; &gt;NEORV32 Project&lt;/a&gt; - An Introduction',['../md_README.html#autotoc_md8',1,'']]], + ['_3arocket_3a_20a_20href_20https_3a_20stnolting_20github_20io_20neorv32_20ug_20user_20guide_20a_20getting_20started_6',[':rocket: &lt;a href=&quot;https://stnolting.github.io/neorv32/ug/&quot; &gt;User Guide&lt;/a&gt; - Getting Started!',['../md_README.html#autotoc_md12',1,'']]] +]; diff --git a/sw/search/all_6.js b/sw/search/all_6.js new file mode 100644 index 0000000000..adacc03458 --- /dev/null +++ b/sw/search/all_6.js @@ -0,0 +1,17 @@ +var searchData= +[ + ['_5f_5fcrt0_5fmax_5fheap_0',['__crt0_max_heap',['../demo__newlib_2main_8c.html#aaa2cb9e7075a852870fd67eff2861b18',1,'main.c']]], + ['_5f_5fneorv32_5frte_5fcore_1',['__neorv32_rte_core',['../neorv32__rte_8c.html#a53f1e006f0bf61deb7ad018f35228873',1,'neorv32_rte.c']]], + ['_5f_5fneorv32_5frte_5fprint_5fhex_5fword_2',['__neorv32_rte_print_hex_word',['../neorv32__rte_8c.html#a01bf6c01f5a8cda2132b9ac98824edc1',1,'neorv32_rte.c']]], + ['_5f_5fneorv32_5frte_5fvector_5flut_3',['__neorv32_rte_vector_lut',['../neorv32__rte_8c.html#a2c8272b4628edddb943bcfad829b561a',1,'neorv32_rte.c']]], + ['_5f_5fneorv32_5fuart_5fitoa_4',['__neorv32_uart_itoa',['../neorv32__uart_8c.html#a3543435827204d82755b0a23bdea1296',1,'neorv32_uart.c']]], + ['_5f_5fneorv32_5fuart_5ftohex_5',['__neorv32_uart_tohex',['../neorv32__uart_8c.html#aefa844cd170e50e088c42829029060f3',1,'neorv32_uart.c']]], + ['_5f_5fneorv32_5fuart_5ftouppercase_6',['__neorv32_uart_touppercase',['../neorv32__uart_8c.html#adf807d0476b475276b8b29924297cda9',1,'neorv32_uart.c']]], + ['_5f_5fneorv32_5fxirq_5fcore_7',['__neorv32_xirq_core',['../neorv32__xirq_8c.html#a14661d628dd31e6bfce89376c6614627',1,'neorv32_xirq.c']]], + ['_5f_5fneorv32_5fxirq_5fdummy_5fhandler_8',['__neorv32_xirq_dummy_handler',['../neorv32__xirq_8c.html#ae4d9362b23a1341c595a4cd239a87091',1,'neorv32_xirq.c']]], + ['_5f_5fneorv32_5fxirq_5fvector_5flut_9',['__neorv32_xirq_vector_lut',['../neorv32__xirq_8c.html#a76d73c3bf372989703c685a9e8d229ac',1,'neorv32_xirq.c']]], + ['_5fneorv32_5fcentral_5fprocessing_5funit_5fcpu_20neorv32_20cpu_20a_20the_20core_10',[':abacus: &lt;a href=&quot;https://stnolting.github.io/neorv32/#_neorv32_central_processing_unit_cpu&quot; &gt;NEORV32 CPU&lt;/a&gt; - The Core',['../md_README.html#autotoc_md10',1,'']]], + ['_5fneorv32_5fprocessor_5fsoc_20neorv32_20processor_20a_20the_20soc_11',[':desktop_computer: &lt;a href=&quot;https://stnolting.github.io/neorv32/#_neorv32_processor_soc&quot; &gt;NEORV32 Processor&lt;/a&gt; - The SoC',['../md_README.html#autotoc_md9',1,'']]], + ['_5foverview_20neorv32_20project_20a_20an_20introduction_12',[':mag: &lt;a href=&quot;https://stnolting.github.io/neorv32/#_overview&quot; &gt;NEORV32 Project&lt;/a&gt; - An Introduction',['../md_README.html#autotoc_md8',1,'']]], + ['_5fsoftware_5fframework_20software_20framework_20a_20the_20software_20ecosystem_13',[':floppy_disk: &lt;a href=&quot;https://stnolting.github.io/neorv32/#_software_framework&quot; &gt;Software Framework&lt;/a&gt; - The Software Ecosystem',['../md_README.html#autotoc_md11',1,'']]] +]; diff --git a/sw/search/all_7.js b/sw/search/all_7.js new file mode 100644 index 0000000000..f459a92129 --- /dev/null +++ b/sw/search/all_7.js @@ -0,0 +1,18 @@ +var searchData= +[ + ['a_20an_20introduction_0',[':mag: &lt;a href=&quot;https://stnolting.github.io/neorv32/#_overview&quot; &gt;NEORV32 Project&lt;/a&gt; - An Introduction',['../md_README.html#autotoc_md8',1,'']]], + ['a_20getting_20started_1',[':rocket: &lt;a href=&quot;https://stnolting.github.io/neorv32/ug/&quot; &gt;User Guide&lt;/a&gt; - Getting Started!',['../md_README.html#autotoc_md12',1,'']]], + ['a_20href_20https_3a_20stnolting_20github_20io_20neorv32_20_5fneorv32_5fcentral_5fprocessing_5funit_5fcpu_20neorv32_20cpu_20a_20the_20core_2',[':abacus: &lt;a href=&quot;https://stnolting.github.io/neorv32/#_neorv32_central_processing_unit_cpu&quot; &gt;NEORV32 CPU&lt;/a&gt; - The Core',['../md_README.html#autotoc_md10',1,'']]], + ['a_20href_20https_3a_20stnolting_20github_20io_20neorv32_20_5fneorv32_5fprocessor_5fsoc_20neorv32_20processor_20a_20the_20soc_3',[':desktop_computer: &lt;a href=&quot;https://stnolting.github.io/neorv32/#_neorv32_processor_soc&quot; &gt;NEORV32 Processor&lt;/a&gt; - The SoC',['../md_README.html#autotoc_md9',1,'']]], + ['a_20href_20https_3a_20stnolting_20github_20io_20neorv32_20_5foverview_20neorv32_20project_20a_20an_20introduction_4',[':mag: &lt;a href=&quot;https://stnolting.github.io/neorv32/#_overview&quot; &gt;NEORV32 Project&lt;/a&gt; - An Introduction',['../md_README.html#autotoc_md8',1,'']]], + ['a_20href_20https_3a_20stnolting_20github_20io_20neorv32_20_5fsoftware_5fframework_20software_20framework_20a_20the_20software_20ecosystem_5',[':floppy_disk: &lt;a href=&quot;https://stnolting.github.io/neorv32/#_software_framework&quot; &gt;Software Framework&lt;/a&gt; - The Software Ecosystem',['../md_README.html#autotoc_md11',1,'']]], + ['a_20href_20https_3a_20stnolting_20github_20io_20neorv32_20ug_20user_20guide_20a_20getting_20started_6',[':rocket: &lt;a href=&quot;https://stnolting.github.io/neorv32/ug/&quot; &gt;User Guide&lt;/a&gt; - Getting Started!',['../md_README.html#autotoc_md12',1,'']]], + ['a_20the_20core_7',[':abacus: &lt;a href=&quot;https://stnolting.github.io/neorv32/#_neorv32_central_processing_unit_cpu&quot; &gt;NEORV32 CPU&lt;/a&gt; - The Core',['../md_README.html#autotoc_md10',1,'']]], + ['a_20the_20soc_8',[':desktop_computer: &lt;a href=&quot;https://stnolting.github.io/neorv32/#_neorv32_processor_soc&quot; &gt;NEORV32 Processor&lt;/a&gt; - The SoC',['../md_README.html#autotoc_md9',1,'']]], + ['a_20the_20software_20ecosystem_9',[':floppy_disk: &lt;a href=&quot;https://stnolting.github.io/neorv32/#_software_framework&quot; &gt;Software Framework&lt;/a&gt; - The Software Ecosystem',['../md_README.html#autotoc_md11',1,'']]], + ['adaptive_5fproportion_5ftest_10',['adaptive_proportion_test',['../demo__trng_2main_8c.html#a23a91e6fe2cc44f3c29baf0d331e05db',1,'main.c']]], + ['amo_5fvar_11',['amo_var',['../atomic__test_2main_8c.html#a9141e95a5f98420ddf8a43e6d20ff6dc',1,'main.c']]], + ['an_20introduction_12',[':mag: &lt;a href=&quot;https://stnolting.github.io/neorv32/#_overview&quot; &gt;NEORV32 Project&lt;/a&gt; - An Introduction',['../md_README.html#autotoc_md8',1,'']]], + ['auto_5fboot_5ftimeout_13',['AUTO_BOOT_TIMEOUT',['../bootloader_8c.html#af6fcb607a9c320da869b72aa30893a69',1,'bootloader.c']]], + ['aux_5fprint_5fhex_5fbyte_14',['aux_print_hex_byte',['../bus__explorer_2main_8c.html#ac582208281cd6fce4eb61c234f312ef6',1,'aux_print_hex_byte(uint8_t byte):&#160;main.c'],['../demo__spi_2main_8c.html#ac582208281cd6fce4eb61c234f312ef6',1,'aux_print_hex_byte(uint8_t byte):&#160;main.c']]] +]; diff --git a/sw/search/all_8.js b/sw/search/all_8.js new file mode 100644 index 0000000000..f2f7c3f55e --- /dev/null +++ b/sw/search/all_8.js @@ -0,0 +1,9 @@ +var searchData= +[ + ['baud_5frate_0',['BAUD_RATE',['../atomic__test_2main_8c.html#ad4455691936f92fdd6c37566fc58ba1f',1,'BAUD_RATE:&#160;main.c'],['../bus__explorer_2main_8c.html#ad4455691936f92fdd6c37566fc58ba1f',1,'BAUD_RATE:&#160;main.c'],['../demo__cfs_2main_8c.html#ad4455691936f92fdd6c37566fc58ba1f',1,'BAUD_RATE:&#160;main.c'],['../demo__cfu_2main_8c.html#ad4455691936f92fdd6c37566fc58ba1f',1,'BAUD_RATE:&#160;main.c'],['../demo__crc_2main_8c.html#ad4455691936f92fdd6c37566fc58ba1f',1,'BAUD_RATE:&#160;main.c'],['../demo__dma_2main_8c.html#ad4455691936f92fdd6c37566fc58ba1f',1,'BAUD_RATE:&#160;main.c'],['../demo__emulate__unaligned_2main_8c.html#ad4455691936f92fdd6c37566fc58ba1f',1,'BAUD_RATE:&#160;main.c'],['../demo__gptmr_2main_8c.html#ad4455691936f92fdd6c37566fc58ba1f',1,'BAUD_RATE:&#160;main.c'],['../demo__hpm_2main_8c.html#ad4455691936f92fdd6c37566fc58ba1f',1,'BAUD_RATE:&#160;main.c'],['../demo__neopixel_2main_8c.html#ad4455691936f92fdd6c37566fc58ba1f',1,'BAUD_RATE:&#160;main.c'],['../demo__newlib_2main_8c.html#ad4455691936f92fdd6c37566fc58ba1f',1,'BAUD_RATE:&#160;main.c'],['../demo__onewire_2main_8c.html#ad4455691936f92fdd6c37566fc58ba1f',1,'BAUD_RATE:&#160;main.c'],['../demo__pwm_2main_8c.html#ad4455691936f92fdd6c37566fc58ba1f',1,'BAUD_RATE:&#160;main.c'],['../demo__sdi_2main_8c.html#ad4455691936f92fdd6c37566fc58ba1f',1,'BAUD_RATE:&#160;main.c'],['../demo__slink_2main_8c.html#ad4455691936f92fdd6c37566fc58ba1f',1,'BAUD_RATE:&#160;main.c'],['../demo__spi_2main_8c.html#ad4455691936f92fdd6c37566fc58ba1f',1,'BAUD_RATE:&#160;main.c'],['../demo__spi__irq_2main_8c.html#ad4455691936f92fdd6c37566fc58ba1f',1,'BAUD_RATE:&#160;main.c'],['../demo__trng_2main_8c.html#ad4455691936f92fdd6c37566fc58ba1f',1,'BAUD_RATE:&#160;main.c'],['../demo__twi_2main_8c.html#ad4455691936f92fdd6c37566fc58ba1f',1,'BAUD_RATE:&#160;main.c'],['../demo__wdt_2main_8c.html#ad4455691936f92fdd6c37566fc58ba1f',1,'BAUD_RATE:&#160;main.c'],['../demo__xip_2main_8c.html#ad4455691936f92fdd6c37566fc58ba1f',1,'BAUD_RATE:&#160;main.c'],['../demo__xirq_2main_8c.html#ad4455691936f92fdd6c37566fc58ba1f',1,'BAUD_RATE:&#160;main.c'],['../float__corner__test_2main_8c.html#ad4455691936f92fdd6c37566fc58ba1f',1,'BAUD_RATE:&#160;main.c'],['../floating__point__test_2main_8c.html#ad4455691936f92fdd6c37566fc58ba1f',1,'BAUD_RATE:&#160;main.c'],['../game__of__life_2main_8c.html#ad4455691936f92fdd6c37566fc58ba1f',1,'BAUD_RATE:&#160;main.c'],['../hello__world_2main_8c.html#ad4455691936f92fdd6c37566fc58ba1f',1,'BAUD_RATE:&#160;main.c']]], + ['binary_5fvalue_1',['binary_value',['../unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606',1,'float_conv_t']]], + ['bootloader_2ec_2',['bootloader.c',['../bootloader_8c.html',1,'']]], + ['bootloader_5fbase_5faddress_3',['BOOTLOADER_BASE_ADDRESS',['../neorv32_8h.html#abd8c9b7d79f49de1722611b2835cde58',1,'neorv32.h']]], + ['bootloader_5ftrap_5fhandler_4',['bootloader_trap_handler',['../bootloader_8c.html#af13b4b3d5e6597feacf331e6d16b08e9',1,'bootloader.c']]], + ['buffer_5fsize_5',['BUFFER_SIZE',['../demo__xip_2main_8c.html#a6b20d41d6252e9871430c242cb1a56e7',1,'main.c']]] +]; diff --git a/sw/search/all_9.js b/sw/search/all_9.js new file mode 100644 index 0000000000..fc0168e256 --- /dev/null +++ b/sw/search/all_9.js @@ -0,0 +1,267 @@ +var searchData= +[ + ['cache_0',['CACHE',['../structneorv32__sysinfo__t.html#ada99a36ccda38b254d5b6a84883101f6',1,'neorv32_sysinfo_t']]], + ['cell_5falive_1',['CELL_ALIVE',['../game__of__life_2main_8c.html#afa6488273e16792d9c3da5e40e3f572d',1,'main.c']]], + ['cell_5fdead_2',['CELL_DEAD',['../game__of__life_2main_8c.html#abe6bebcf1cb4f5b4d522c1706eb48663',1,'main.c']]], + ['cfs_5ffirq_5fenable_3',['CFS_FIRQ_ENABLE',['../neorv32_8h.html#ace79ee46daf3a1b689d9fe79dfcd6627',1,'neorv32.h']]], + ['cfs_5ffirq_5fpending_4',['CFS_FIRQ_PENDING',['../neorv32_8h.html#aae182648a2c23d070b9db0295388e001',1,'neorv32.h']]], + ['cfs_5frte_5fid_5',['CFS_RTE_ID',['../neorv32_8h.html#a095f41fbefaa7acc1bfdd65cd3ce06ea',1,'neorv32.h']]], + ['cfs_5ftrap_5fcode_6',['CFS_TRAP_CODE',['../neorv32_8h.html#aae6b2ae3fba20ff80bfb59735f179c26',1,'neorv32.h']]], + ['check_5fresult_7',['check_result',['../atomic__test_2main_8c.html#a4f4c6d8481b4100f90955ba5a70428a4',1,'main.c']]], + ['clear_5funiverse_8',['clear_universe',['../game__of__life_2main_8c.html#a819f10c5b644a07eeb069b6e7f12050e',1,'main.c']]], + ['clk_9',['CLK',['../structneorv32__sysinfo__t.html#afc225843ee31efff6350415b5aaae761',1,'neorv32_sysinfo_t']]], + ['clk_5fprsc_5f1024_10',['CLK_PRSC_1024',['../neorv32_8h.html#a10022df4c223533b04d5aebe222e8b73a18aac15afd5ebd8d3a00dd6e513daf17',1,'neorv32.h']]], + ['clk_5fprsc_5f128_11',['CLK_PRSC_128',['../neorv32_8h.html#a10022df4c223533b04d5aebe222e8b73a933045a5405de55781d687315f42054e',1,'neorv32.h']]], + ['clk_5fprsc_5f2_12',['CLK_PRSC_2',['../neorv32_8h.html#a10022df4c223533b04d5aebe222e8b73ad63d40139c50d76618cf1258cbdc0d05',1,'neorv32.h']]], + ['clk_5fprsc_5f2048_13',['CLK_PRSC_2048',['../neorv32_8h.html#a10022df4c223533b04d5aebe222e8b73aa138f0cad547028d5124f89d6dcc8c79',1,'neorv32.h']]], + ['clk_5fprsc_5f4_14',['CLK_PRSC_4',['../neorv32_8h.html#a10022df4c223533b04d5aebe222e8b73a648249b3ab8c2500880c1e68b98f81d1',1,'neorv32.h']]], + ['clk_5fprsc_5f4096_15',['CLK_PRSC_4096',['../neorv32_8h.html#a10022df4c223533b04d5aebe222e8b73a0f20c29722bf9afc478b1a286a6b7eee',1,'neorv32.h']]], + ['clk_5fprsc_5f64_16',['CLK_PRSC_64',['../neorv32_8h.html#a10022df4c223533b04d5aebe222e8b73a5990532893f2d9606e3c02aff60ca5da',1,'neorv32.h']]], + ['clk_5fprsc_5f8_17',['CLK_PRSC_8',['../neorv32_8h.html#a10022df4c223533b04d5aebe222e8b73aa4e3a6a5b3cd895f63b4544f63ce22c9',1,'neorv32.h']]], + ['compute_5frate_18',['compute_rate',['../demo__trng_2main_8c.html#abbde1237eed617466fb971a78c3acd1e',1,'main.c']]], + ['contact_19',[':email: Contact',['../md_README.html#autotoc_md14',1,'']]], + ['core_20',[':abacus: &lt;a href=&quot;https://stnolting.github.io/neorv32/#_neorv32_central_processing_unit_cpu&quot; &gt;NEORV32 CPU&lt;/a&gt; - The Core',['../md_README.html#autotoc_md10',1,'']]], + ['count_21',['COUNT',['../structneorv32__gptmr__t.html#a1abc5bae1dffc64006e965d4570da479',1,'neorv32_gptmr_t']]], + ['cpu_20a_20the_20core_22',[':abacus: &lt;a href=&quot;https://stnolting.github.io/neorv32/#_neorv32_central_processing_unit_cpu&quot; &gt;NEORV32 CPU&lt;/a&gt; - The Core',['../md_README.html#autotoc_md10',1,'']]], + ['crc_5fmode16_23',['CRC_MODE16',['../neorv32__crc_8h.html#a1ae84a58f475bafc2fc3f2c690fd6447aa5cfd5d285b4cb8997c7e754491d050f',1,'neorv32_crc.h']]], + ['crc_5fmode32_24',['CRC_MODE32',['../neorv32__crc_8h.html#a1ae84a58f475bafc2fc3f2c690fd6447a7cf26bd4a7e8d6e45016633f650f00aa',1,'neorv32_crc.h']]], + ['crc_5fmode8_25',['CRC_MODE8',['../neorv32__crc_8h.html#a1ae84a58f475bafc2fc3f2c690fd6447a9409185edbae1bd0afdeda4e58aa6d1a',1,'neorv32_crc.h']]], + ['csr_5fcfureg0_26',['CSR_CFUREG0',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ae0e9cf0b99b8614ea0b870d38970281f',1,'neorv32_cpu_csr.h']]], + ['csr_5fcfureg1_27',['CSR_CFUREG1',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a382304065a6db773f925b80b9447b8a8',1,'neorv32_cpu_csr.h']]], + ['csr_5fcfureg2_28',['CSR_CFUREG2',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a427d7cf036b49efd46166c01f0504b68',1,'neorv32_cpu_csr.h']]], + ['csr_5fcfureg3_29',['CSR_CFUREG3',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aefefa1cff0cf5d01109486e5a8bebedf',1,'neorv32_cpu_csr.h']]], + ['csr_5fcycle_30',['CSR_CYCLE',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aaaf0f6b17a06d5922bcfdb47b382137e',1,'neorv32_cpu_csr.h']]], + ['csr_5fcycleh_31',['CSR_CYCLEH',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aa276bedb7dab28935163397b4879f6db',1,'neorv32_cpu_csr.h']]], + ['csr_5fdcsr_32',['CSR_DCSR',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a6bb3ba59a25803d6f98faad67609a9a9',1,'neorv32_cpu_csr.h']]], + ['csr_5fdpc_33',['CSR_DPC',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49af4c98d949d2eb44f2518fdf314344d3b',1,'neorv32_cpu_csr.h']]], + ['csr_5fdscratch0_34',['CSR_DSCRATCH0',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a0f4a1ae740efd80d14d21e90f355e9d7',1,'neorv32_cpu_csr.h']]], + ['csr_5ffcsr_35',['CSR_FCSR',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a5e1abf46b4f55bd18e1d132b32696ab6',1,'neorv32_cpu_csr.h']]], + ['csr_5ffflags_36',['CSR_FFLAGS',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a625f606c14fd4d7224d7109e10508e7a',1,'neorv32_cpu_csr.h']]], + ['csr_5ffflags_5fdz_37',['CSR_FFLAGS_DZ',['../neorv32__cpu__csr_8h.html#afde0761e3150d82511136f56179c204ba365f3f519bca34a349907c82c873d52b',1,'neorv32_cpu_csr.h']]], + ['csr_5ffflags_5fnv_38',['CSR_FFLAGS_NV',['../neorv32__cpu__csr_8h.html#afde0761e3150d82511136f56179c204ba3ac330a4b03178e756c980eaa48ad165',1,'neorv32_cpu_csr.h']]], + ['csr_5ffflags_5fnx_39',['CSR_FFLAGS_NX',['../neorv32__cpu__csr_8h.html#afde0761e3150d82511136f56179c204ba91a314defd310786a9ed67f7ef2ef5a6',1,'neorv32_cpu_csr.h']]], + ['csr_5ffflags_5fof_40',['CSR_FFLAGS_OF',['../neorv32__cpu__csr_8h.html#afde0761e3150d82511136f56179c204ba612390e07a065fa13eeaeac84af48c6e',1,'neorv32_cpu_csr.h']]], + ['csr_5ffflags_5fuf_41',['CSR_FFLAGS_UF',['../neorv32__cpu__csr_8h.html#afde0761e3150d82511136f56179c204babc6d405724563844569028f463885819',1,'neorv32_cpu_csr.h']]], + ['csr_5ffrm_42',['CSR_FRM',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a7f198c465959dde37b7056dd06d45812',1,'neorv32_cpu_csr.h']]], + ['csr_5fhpmcounter10_43',['CSR_HPMCOUNTER10',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aa407e701bdbb9d26f84684b811c008a9',1,'neorv32_cpu_csr.h']]], + ['csr_5fhpmcounter10h_44',['CSR_HPMCOUNTER10H',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ae56e95d6d6dd63ff6f5b4192cf48c88b',1,'neorv32_cpu_csr.h']]], + ['csr_5fhpmcounter11_45',['CSR_HPMCOUNTER11',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a9fd1ff4e8a42992c0a3ec02c397dd7f8',1,'neorv32_cpu_csr.h']]], + ['csr_5fhpmcounter11h_46',['CSR_HPMCOUNTER11H',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a2af8c5dcc87d92bcce392fb5b3aa065e',1,'neorv32_cpu_csr.h']]], + ['csr_5fhpmcounter12_47',['CSR_HPMCOUNTER12',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ae58f15a95aa41126819effe046ced804',1,'neorv32_cpu_csr.h']]], + ['csr_5fhpmcounter12h_48',['CSR_HPMCOUNTER12H',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a74359db2583feb7119d4bcaa926242a0',1,'neorv32_cpu_csr.h']]], + ['csr_5fhpmcounter13_49',['CSR_HPMCOUNTER13',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a24d8617a6ff2c1e49c9a73853ad9e450',1,'neorv32_cpu_csr.h']]], + ['csr_5fhpmcounter13h_50',['CSR_HPMCOUNTER13H',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a4fa22699e96d6da8665077e3c95891ef',1,'neorv32_cpu_csr.h']]], + ['csr_5fhpmcounter14_51',['CSR_HPMCOUNTER14',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aa47ed1a4a4f9fcabceed0d6d626d0aaf',1,'neorv32_cpu_csr.h']]], + ['csr_5fhpmcounter14h_52',['CSR_HPMCOUNTER14H',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a03f29e792be2854efc9e66d710b78a1d',1,'neorv32_cpu_csr.h']]], + ['csr_5fhpmcounter15_53',['CSR_HPMCOUNTER15',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a7277a8f929a5a250f7227fbbdf545dbc',1,'neorv32_cpu_csr.h']]], + ['csr_5fhpmcounter15h_54',['CSR_HPMCOUNTER15H',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a11169bd08920d40c8f94fd29e1d33eff',1,'neorv32_cpu_csr.h']]], + ['csr_5fhpmcounter3_55',['CSR_HPMCOUNTER3',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a3ee699d5b2886c54c92992f66b109b67',1,'neorv32_cpu_csr.h']]], + ['csr_5fhpmcounter3h_56',['CSR_HPMCOUNTER3H',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aaa3e6a1ac8999be42d7c13891546bb50',1,'neorv32_cpu_csr.h']]], + ['csr_5fhpmcounter4_57',['CSR_HPMCOUNTER4',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a98ed49716d0d89712863e7a542d38d2a',1,'neorv32_cpu_csr.h']]], + ['csr_5fhpmcounter4h_58',['CSR_HPMCOUNTER4H',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a8837ff8d2741639aa69da59659f9a080',1,'neorv32_cpu_csr.h']]], + ['csr_5fhpmcounter5_59',['CSR_HPMCOUNTER5',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ab2376c3b7c3ec0b44105ec1ed951bfb0',1,'neorv32_cpu_csr.h']]], + ['csr_5fhpmcounter5h_60',['CSR_HPMCOUNTER5H',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ad489feaa5ad1feb00d3df71d3e5b0cac',1,'neorv32_cpu_csr.h']]], + ['csr_5fhpmcounter6_61',['CSR_HPMCOUNTER6',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aa2f644a4f54ba3834bafa738208c0803',1,'neorv32_cpu_csr.h']]], + ['csr_5fhpmcounter6h_62',['CSR_HPMCOUNTER6H',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a438a65757b85f182dfb1f2a06c9ad520',1,'neorv32_cpu_csr.h']]], + ['csr_5fhpmcounter7_63',['CSR_HPMCOUNTER7',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a125c4d0051548dea9104808b7bee1316',1,'neorv32_cpu_csr.h']]], + ['csr_5fhpmcounter7h_64',['CSR_HPMCOUNTER7H',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a6332d4ff090aa7c302d191219e846fff',1,'neorv32_cpu_csr.h']]], + ['csr_5fhpmcounter8_65',['CSR_HPMCOUNTER8',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49acac87125f8c723cc5df4d4169a82852b',1,'neorv32_cpu_csr.h']]], + ['csr_5fhpmcounter8h_66',['CSR_HPMCOUNTER8H',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aa8ce8fc8a57dd82872d02b4113249a77',1,'neorv32_cpu_csr.h']]], + ['csr_5fhpmcounter9_67',['CSR_HPMCOUNTER9',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ab45ebb3bd861074a15cc2ad874756e8f',1,'neorv32_cpu_csr.h']]], + ['csr_5fhpmcounter9h_68',['CSR_HPMCOUNTER9H',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49acdf793b30919e7fa1b85995abe531a20',1,'neorv32_cpu_csr.h']]], + ['csr_5finstret_69',['CSR_INSTRET',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a8144da8cd8691ac54aa0712685865b66',1,'neorv32_cpu_csr.h']]], + ['csr_5finstreth_70',['CSR_INSTRETH',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a9b66978d76260283007d399fc735d153',1,'neorv32_cpu_csr.h']]], + ['csr_5fmarchid_71',['CSR_MARCHID',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ad95cb95266533123447ff0e917f890e4',1,'neorv32_cpu_csr.h']]], + ['csr_5fmcause_72',['CSR_MCAUSE',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a2e14b57fee5376741634db7980a5005b',1,'neorv32_cpu_csr.h']]], + ['csr_5fmconfigptr_73',['CSR_MCONFIGPTR',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a0545d0921b3f90d037dbb25bc5fcc2f9',1,'neorv32_cpu_csr.h']]], + ['csr_5fmcounteren_74',['CSR_MCOUNTEREN',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a1860dd9579906c67a3565063043dcf78',1,'neorv32_cpu_csr.h']]], + ['csr_5fmcountinhibit_75',['CSR_MCOUNTINHIBIT',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a3ce1dc0e2810f0df78feaa1c607a5ca6',1,'neorv32_cpu_csr.h']]], + ['csr_5fmcountinhibit_5fcy_76',['CSR_MCOUNTINHIBIT_CY',['../neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea201ac39b0eba389b0d02c3951a3311a3',1,'neorv32_cpu_csr.h']]], + ['csr_5fmcountinhibit_5fhpm10_77',['CSR_MCOUNTINHIBIT_HPM10',['../neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea9517cd32744c5064fa30780f911cd22e',1,'neorv32_cpu_csr.h']]], + ['csr_5fmcountinhibit_5fhpm11_78',['CSR_MCOUNTINHIBIT_HPM11',['../neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfeacaf997fe8b912596224e2bb632e6a806',1,'neorv32_cpu_csr.h']]], + ['csr_5fmcountinhibit_5fhpm12_79',['CSR_MCOUNTINHIBIT_HPM12',['../neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea8d866a4c815d8ba890a1e00ce9600486',1,'neorv32_cpu_csr.h']]], + ['csr_5fmcountinhibit_5fhpm13_80',['CSR_MCOUNTINHIBIT_HPM13',['../neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfead9f6c4eb4284ee82b9e8d0c79f62b3ed',1,'neorv32_cpu_csr.h']]], + ['csr_5fmcountinhibit_5fhpm14_81',['CSR_MCOUNTINHIBIT_HPM14',['../neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfeaa83c0688869b1c43de0c4474e940f987',1,'neorv32_cpu_csr.h']]], + ['csr_5fmcountinhibit_5fhpm15_82',['CSR_MCOUNTINHIBIT_HPM15',['../neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea0b547cb5876c0e7956e3d062e0784085',1,'neorv32_cpu_csr.h']]], + ['csr_5fmcountinhibit_5fhpm16_83',['CSR_MCOUNTINHIBIT_HPM16',['../neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea68aba71ea77aba4005fb24a945ef38e4',1,'neorv32_cpu_csr.h']]], + ['csr_5fmcountinhibit_5fhpm17_84',['CSR_MCOUNTINHIBIT_HPM17',['../neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea8d57acf13a086635a63bc13ccdf479b3',1,'neorv32_cpu_csr.h']]], + ['csr_5fmcountinhibit_5fhpm18_85',['CSR_MCOUNTINHIBIT_HPM18',['../neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfeaa680d196d2ba0e403801a860bb9d8ce0',1,'neorv32_cpu_csr.h']]], + ['csr_5fmcountinhibit_5fhpm19_86',['CSR_MCOUNTINHIBIT_HPM19',['../neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea3683e296caafe771b6dd57f4cf86f3dc',1,'neorv32_cpu_csr.h']]], + ['csr_5fmcountinhibit_5fhpm20_87',['CSR_MCOUNTINHIBIT_HPM20',['../neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfeaeb4b1b6abafd22eec0764d5503878cca',1,'neorv32_cpu_csr.h']]], + ['csr_5fmcountinhibit_5fhpm21_88',['CSR_MCOUNTINHIBIT_HPM21',['../neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea1dc0276a5354c805ac56fd46c5037d38',1,'neorv32_cpu_csr.h']]], + ['csr_5fmcountinhibit_5fhpm22_89',['CSR_MCOUNTINHIBIT_HPM22',['../neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfeaf1b6153a0c664367bfefb78b2ca8b34e',1,'neorv32_cpu_csr.h']]], + ['csr_5fmcountinhibit_5fhpm23_90',['CSR_MCOUNTINHIBIT_HPM23',['../neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea85c0c2b2a5101380dec72516dda1a904',1,'neorv32_cpu_csr.h']]], + ['csr_5fmcountinhibit_5fhpm24_91',['CSR_MCOUNTINHIBIT_HPM24',['../neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea74ec85a2e94aa0b9e8af29401ef7ecb1',1,'neorv32_cpu_csr.h']]], + ['csr_5fmcountinhibit_5fhpm25_92',['CSR_MCOUNTINHIBIT_HPM25',['../neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfeaee2b5a2b7bd7ac07dae45900bc2faf46',1,'neorv32_cpu_csr.h']]], + ['csr_5fmcountinhibit_5fhpm26_93',['CSR_MCOUNTINHIBIT_HPM26',['../neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea141a4a211c496d2af1c79d8e8e0c2a74',1,'neorv32_cpu_csr.h']]], + ['csr_5fmcountinhibit_5fhpm27_94',['CSR_MCOUNTINHIBIT_HPM27',['../neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea46def851d4582b4bcec1f9d8bafd58db',1,'neorv32_cpu_csr.h']]], + ['csr_5fmcountinhibit_5fhpm28_95',['CSR_MCOUNTINHIBIT_HPM28',['../neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea33d0fd3378ec3a2fcc3c8738c6cd2f32',1,'neorv32_cpu_csr.h']]], + ['csr_5fmcountinhibit_5fhpm29_96',['CSR_MCOUNTINHIBIT_HPM29',['../neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfeaa39882f7dad9b7e16b317c75bad31382',1,'neorv32_cpu_csr.h']]], + ['csr_5fmcountinhibit_5fhpm3_97',['CSR_MCOUNTINHIBIT_HPM3',['../neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfeaf7020159e0ba346561bfba101d22c752',1,'neorv32_cpu_csr.h']]], + ['csr_5fmcountinhibit_5fhpm30_98',['CSR_MCOUNTINHIBIT_HPM30',['../neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea0f45818fa4cb9033a3093987fa8515c7',1,'neorv32_cpu_csr.h']]], + ['csr_5fmcountinhibit_5fhpm31_99',['CSR_MCOUNTINHIBIT_HPM31',['../neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea1da1186ef2f4e7297a4fecaaccdc1d05',1,'neorv32_cpu_csr.h']]], + ['csr_5fmcountinhibit_5fhpm4_100',['CSR_MCOUNTINHIBIT_HPM4',['../neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea40427b799da049413c5536afa623c61d',1,'neorv32_cpu_csr.h']]], + ['csr_5fmcountinhibit_5fhpm5_101',['CSR_MCOUNTINHIBIT_HPM5',['../neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea2769a6e6a75f2f903523e4e95a899bb6',1,'neorv32_cpu_csr.h']]], + ['csr_5fmcountinhibit_5fhpm6_102',['CSR_MCOUNTINHIBIT_HPM6',['../neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfead55b6af15841617d7dca3ab4fab893db',1,'neorv32_cpu_csr.h']]], + ['csr_5fmcountinhibit_5fhpm7_103',['CSR_MCOUNTINHIBIT_HPM7',['../neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea3b3571fceb687da2d3807b0e59bdf7ab',1,'neorv32_cpu_csr.h']]], + ['csr_5fmcountinhibit_5fhpm8_104',['CSR_MCOUNTINHIBIT_HPM8',['../neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfeabd21344124eda4402523203185a58b8a',1,'neorv32_cpu_csr.h']]], + ['csr_5fmcountinhibit_5fhpm9_105',['CSR_MCOUNTINHIBIT_HPM9',['../neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea0f207455df0fed75fa68ba49c435889a',1,'neorv32_cpu_csr.h']]], + ['csr_5fmcountinhibit_5fir_106',['CSR_MCOUNTINHIBIT_IR',['../neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea5f182f39f9a4b871a097a51e57865bfa',1,'neorv32_cpu_csr.h']]], + ['csr_5fmcycle_107',['CSR_MCYCLE',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a32c22641ed66c6d20902306a2b1fad77',1,'neorv32_cpu_csr.h']]], + ['csr_5fmcycleh_108',['CSR_MCYCLEH',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a28fcfd06ca1012c19cf053e57689687b',1,'neorv32_cpu_csr.h']]], + ['csr_5fmenvcfg_109',['CSR_MENVCFG',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a9c55619ffb05e84b7210e2d47326fa98',1,'neorv32_cpu_csr.h']]], + ['csr_5fmenvcfgh_110',['CSR_MENVCFGH',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a46b8d3c288cbbfbf5a0af6e5cd8c5bc8',1,'neorv32_cpu_csr.h']]], + ['csr_5fmepc_111',['CSR_MEPC',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a5d60a25a66754066589e8facb7d41153',1,'neorv32_cpu_csr.h']]], + ['csr_5fmhartid_112',['CSR_MHARTID',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a6ba48e2306ae92f498552e1ea04d6790',1,'neorv32_cpu_csr.h']]], + ['csr_5fmhpmcounter10_113',['CSR_MHPMCOUNTER10',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a575e5342d8ec304c32dbbe99d6fd6c0f',1,'neorv32_cpu_csr.h']]], + ['csr_5fmhpmcounter10h_114',['CSR_MHPMCOUNTER10H',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a1e41d2b27d7e8da14871852d81123cfd',1,'neorv32_cpu_csr.h']]], + ['csr_5fmhpmcounter11_115',['CSR_MHPMCOUNTER11',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a8840b3d4f45453fc96813ccb369a68e5',1,'neorv32_cpu_csr.h']]], + ['csr_5fmhpmcounter11h_116',['CSR_MHPMCOUNTER11H',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a7fd76fcfc0d0dd47e112786bea5e4071',1,'neorv32_cpu_csr.h']]], + ['csr_5fmhpmcounter12_117',['CSR_MHPMCOUNTER12',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a1328a226d36d23cc81740397bde47a4e',1,'neorv32_cpu_csr.h']]], + ['csr_5fmhpmcounter12h_118',['CSR_MHPMCOUNTER12H',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a332ec2b0740f8e899a1b2ec86f7ee9f2',1,'neorv32_cpu_csr.h']]], + ['csr_5fmhpmcounter13_119',['CSR_MHPMCOUNTER13',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a9bdd102877ff50d38c86c3d741aeb4b0',1,'neorv32_cpu_csr.h']]], + ['csr_5fmhpmcounter13h_120',['CSR_MHPMCOUNTER13H',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a5de5c5a036dc594a554d37df9ccf657d',1,'neorv32_cpu_csr.h']]], + ['csr_5fmhpmcounter14_121',['CSR_MHPMCOUNTER14',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49adae22d860d8162e15120051951e45229',1,'neorv32_cpu_csr.h']]], + ['csr_5fmhpmcounter14h_122',['CSR_MHPMCOUNTER14H',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ac65bab6fd71439600c8fc549171251fa',1,'neorv32_cpu_csr.h']]], + ['csr_5fmhpmcounter15_123',['CSR_MHPMCOUNTER15',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a20400929087fabba410a098667d2d4ff',1,'neorv32_cpu_csr.h']]], + ['csr_5fmhpmcounter15h_124',['CSR_MHPMCOUNTER15H',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49af609807e2917f73e27e5f27b38a0fa46',1,'neorv32_cpu_csr.h']]], + ['csr_5fmhpmcounter3_125',['CSR_MHPMCOUNTER3',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ae0a96f499dcde474af6ee620fbb1ebdc',1,'neorv32_cpu_csr.h']]], + ['csr_5fmhpmcounter3h_126',['CSR_MHPMCOUNTER3H',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a252980a4da90c1f5c1ef85d164f72f25',1,'neorv32_cpu_csr.h']]], + ['csr_5fmhpmcounter4_127',['CSR_MHPMCOUNTER4',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a9b84bd948dd52a7779b5fd16beddaab9',1,'neorv32_cpu_csr.h']]], + ['csr_5fmhpmcounter4h_128',['CSR_MHPMCOUNTER4H',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a2e9cfbf3c2828dd4bd92d2b8a1c99f85',1,'neorv32_cpu_csr.h']]], + ['csr_5fmhpmcounter5_129',['CSR_MHPMCOUNTER5',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49af15d389bb8f91c989df488d231666394',1,'neorv32_cpu_csr.h']]], + ['csr_5fmhpmcounter5h_130',['CSR_MHPMCOUNTER5H',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a7648dd0a47007d44a14e95ba47726599',1,'neorv32_cpu_csr.h']]], + ['csr_5fmhpmcounter6_131',['CSR_MHPMCOUNTER6',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49af65b9e99b9cadb3cb8d37f97cdbfeb9d',1,'neorv32_cpu_csr.h']]], + ['csr_5fmhpmcounter6h_132',['CSR_MHPMCOUNTER6H',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a49b7bc2df67a6c73a68757de9b218f77',1,'neorv32_cpu_csr.h']]], + ['csr_5fmhpmcounter7_133',['CSR_MHPMCOUNTER7',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a919f39b0d299feb80403b42a466de444',1,'neorv32_cpu_csr.h']]], + ['csr_5fmhpmcounter7h_134',['CSR_MHPMCOUNTER7H',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ac0183bb6f357ed33136493ae7ded987a',1,'neorv32_cpu_csr.h']]], + ['csr_5fmhpmcounter8_135',['CSR_MHPMCOUNTER8',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a5a4cde90c547e913bddc719b3ab75e79',1,'neorv32_cpu_csr.h']]], + ['csr_5fmhpmcounter8h_136',['CSR_MHPMCOUNTER8H',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a9e75518df7d14a009e3a0d5588641ddc',1,'neorv32_cpu_csr.h']]], + ['csr_5fmhpmcounter9_137',['CSR_MHPMCOUNTER9',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a18c2a249f1f7852f42f9e10dc59d46bb',1,'neorv32_cpu_csr.h']]], + ['csr_5fmhpmcounter9h_138',['CSR_MHPMCOUNTER9H',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a7341886c7a4aed6fc7d8677c016a2cb8',1,'neorv32_cpu_csr.h']]], + ['csr_5fmhpmevent10_139',['CSR_MHPMEVENT10',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a23850b1804966cde2c1e84cde752d512',1,'neorv32_cpu_csr.h']]], + ['csr_5fmhpmevent11_140',['CSR_MHPMEVENT11',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a7fb1de2019dd2b548084d5ca1630efbf',1,'neorv32_cpu_csr.h']]], + ['csr_5fmhpmevent12_141',['CSR_MHPMEVENT12',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ad648b5ece209d47e9484fd7aa83e8e5f',1,'neorv32_cpu_csr.h']]], + ['csr_5fmhpmevent13_142',['CSR_MHPMEVENT13',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a8c31899b81bb5dba9b92a0f0ca71aea6',1,'neorv32_cpu_csr.h']]], + ['csr_5fmhpmevent14_143',['CSR_MHPMEVENT14',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a964a6a50d0138447fad47e9c982a7ba4',1,'neorv32_cpu_csr.h']]], + ['csr_5fmhpmevent15_144',['CSR_MHPMEVENT15',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a06dfdeed757606529e4a99c033691b54',1,'neorv32_cpu_csr.h']]], + ['csr_5fmhpmevent3_145',['CSR_MHPMEVENT3',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a4a93ac5ab276cfd2f9cd296c8ce1bff6',1,'neorv32_cpu_csr.h']]], + ['csr_5fmhpmevent4_146',['CSR_MHPMEVENT4',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ab5f998725e002ffc2ff516ee973fe459',1,'neorv32_cpu_csr.h']]], + ['csr_5fmhpmevent5_147',['CSR_MHPMEVENT5',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a2524659ca2785af51af7acf9cd560a9d',1,'neorv32_cpu_csr.h']]], + ['csr_5fmhpmevent6_148',['CSR_MHPMEVENT6',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a1cfa1e3bc3c8a1c9a86c251a510d11cd',1,'neorv32_cpu_csr.h']]], + ['csr_5fmhpmevent7_149',['CSR_MHPMEVENT7',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a2e53e6e01ca8d1b801f6dfba602f3f59',1,'neorv32_cpu_csr.h']]], + ['csr_5fmhpmevent8_150',['CSR_MHPMEVENT8',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ad6296ca83bbe1280624f3c21adbd8a79',1,'neorv32_cpu_csr.h']]], + ['csr_5fmhpmevent9_151',['CSR_MHPMEVENT9',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49af6727a9bdd60ccf020812095b7396632',1,'neorv32_cpu_csr.h']]], + ['csr_5fmie_152',['CSR_MIE',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49acc0f9f5f3b5702f1b57f2ba3b6b62610',1,'neorv32_cpu_csr.h']]], + ['csr_5fmie_5ffirq0e_153',['CSR_MIE_FIRQ0E',['../neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a99f43f8bbfb29fba6224f081c363ac7d',1,'neorv32_cpu_csr.h']]], + ['csr_5fmie_5ffirq10e_154',['CSR_MIE_FIRQ10E',['../neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33affcb52dc57bb8c0cb1e7d3c1392d544a',1,'neorv32_cpu_csr.h']]], + ['csr_5fmie_5ffirq11e_155',['CSR_MIE_FIRQ11E',['../neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33af058342854a0becd3bcc33877d9244cd',1,'neorv32_cpu_csr.h']]], + ['csr_5fmie_5ffirq12e_156',['CSR_MIE_FIRQ12E',['../neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a41f91a37f7e0c75c783312af6a72e943',1,'neorv32_cpu_csr.h']]], + ['csr_5fmie_5ffirq13e_157',['CSR_MIE_FIRQ13E',['../neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a134ed02c7293008b21b1df472be8f11f',1,'neorv32_cpu_csr.h']]], + ['csr_5fmie_5ffirq14e_158',['CSR_MIE_FIRQ14E',['../neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a864d135708530016cfc52a65a1e4d79b',1,'neorv32_cpu_csr.h']]], + ['csr_5fmie_5ffirq15e_159',['CSR_MIE_FIRQ15E',['../neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33aa2dfa1183af312de2959dadd217fddc1',1,'neorv32_cpu_csr.h']]], + ['csr_5fmie_5ffirq1e_160',['CSR_MIE_FIRQ1E',['../neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33ac1e1d44becec1b393f79a118ed3d8beb',1,'neorv32_cpu_csr.h']]], + ['csr_5fmie_5ffirq2e_161',['CSR_MIE_FIRQ2E',['../neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33afc805280e20ffface116ca61e11645f7',1,'neorv32_cpu_csr.h']]], + ['csr_5fmie_5ffirq3e_162',['CSR_MIE_FIRQ3E',['../neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a666066099d6cebadbef21d81c179e8db',1,'neorv32_cpu_csr.h']]], + ['csr_5fmie_5ffirq4e_163',['CSR_MIE_FIRQ4E',['../neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a592939f1b7d79097f7f13d6ab0c268dc',1,'neorv32_cpu_csr.h']]], + ['csr_5fmie_5ffirq5e_164',['CSR_MIE_FIRQ5E',['../neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a3079a8fbf3b8e376865bff76f2173698',1,'neorv32_cpu_csr.h']]], + ['csr_5fmie_5ffirq6e_165',['CSR_MIE_FIRQ6E',['../neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a96315d6b5b9531bcbc1e78a3c9ab166a',1,'neorv32_cpu_csr.h']]], + ['csr_5fmie_5ffirq7e_166',['CSR_MIE_FIRQ7E',['../neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a3d9d729940170609affbc6813054ebe8',1,'neorv32_cpu_csr.h']]], + ['csr_5fmie_5ffirq8e_167',['CSR_MIE_FIRQ8E',['../neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a396c6c4b425b3fff598e2f846052f98e',1,'neorv32_cpu_csr.h']]], + ['csr_5fmie_5ffirq9e_168',['CSR_MIE_FIRQ9E',['../neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a06fdb61dab31c3490da6c37d47914f19',1,'neorv32_cpu_csr.h']]], + ['csr_5fmie_5fmeie_169',['CSR_MIE_MEIE',['../neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33ae8e4f0ee46abbbb3361de035a57b8324',1,'neorv32_cpu_csr.h']]], + ['csr_5fmie_5fmsie_170',['CSR_MIE_MSIE',['../neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33afd2f1c78c442c8c29ab075cacee0a27a',1,'neorv32_cpu_csr.h']]], + ['csr_5fmie_5fmtie_171',['CSR_MIE_MTIE',['../neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a3658e8663e94cd8eaa7201b7a850d083',1,'neorv32_cpu_csr.h']]], + ['csr_5fmimpid_172',['CSR_MIMPID',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a06d39cf0f13d6401dcf426d56149c8cd',1,'neorv32_cpu_csr.h']]], + ['csr_5fminstret_173',['CSR_MINSTRET',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a98f5e2cf2d5dbb0125a222b0065c86eb',1,'neorv32_cpu_csr.h']]], + ['csr_5fminstreth_174',['CSR_MINSTRETH',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49afffb28b62b9baa127ae3bad919208988',1,'neorv32_cpu_csr.h']]], + ['csr_5fmip_175',['CSR_MIP',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49addb485275c954d1181d5bd4e4609082c',1,'neorv32_cpu_csr.h']]], + ['csr_5fmip_5ffirq0p_176',['CSR_MIP_FIRQ0P',['../neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba28a85ad8bd4c30fd3a91298dfa4fdb00',1,'neorv32_cpu_csr.h']]], + ['csr_5fmip_5ffirq10p_177',['CSR_MIP_FIRQ10P',['../neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba2b50cfa8be461b088ea8506ce4c741ba',1,'neorv32_cpu_csr.h']]], + ['csr_5fmip_5ffirq11p_178',['CSR_MIP_FIRQ11P',['../neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba69ea0d3d76d4cec398f3b96959cc3544',1,'neorv32_cpu_csr.h']]], + ['csr_5fmip_5ffirq12p_179',['CSR_MIP_FIRQ12P',['../neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba03edd398920b817150d29107c0b40792',1,'neorv32_cpu_csr.h']]], + ['csr_5fmip_5ffirq13p_180',['CSR_MIP_FIRQ13P',['../neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba14da6a2a962bf82970638a948ffbc570',1,'neorv32_cpu_csr.h']]], + ['csr_5fmip_5ffirq14p_181',['CSR_MIP_FIRQ14P',['../neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21baad1e5e452a9c37561308765431f0260d',1,'neorv32_cpu_csr.h']]], + ['csr_5fmip_5ffirq15p_182',['CSR_MIP_FIRQ15P',['../neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba12da8c32d38d5a3539a0b766718bfd2d',1,'neorv32_cpu_csr.h']]], + ['csr_5fmip_5ffirq1p_183',['CSR_MIP_FIRQ1P',['../neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba2b577b1da1074c29ad58005af1f91d52',1,'neorv32_cpu_csr.h']]], + ['csr_5fmip_5ffirq2p_184',['CSR_MIP_FIRQ2P',['../neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21badf45c5a135431f958fa63574c1dfac6e',1,'neorv32_cpu_csr.h']]], + ['csr_5fmip_5ffirq3p_185',['CSR_MIP_FIRQ3P',['../neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba7512bb6c4841ddd477422b49ebb2a155',1,'neorv32_cpu_csr.h']]], + ['csr_5fmip_5ffirq4p_186',['CSR_MIP_FIRQ4P',['../neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21bab6421f242bb8a487a986346e11196eb8',1,'neorv32_cpu_csr.h']]], + ['csr_5fmip_5ffirq5p_187',['CSR_MIP_FIRQ5P',['../neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21baaa55d19f9a47889bc364c94bda04b677',1,'neorv32_cpu_csr.h']]], + ['csr_5fmip_5ffirq6p_188',['CSR_MIP_FIRQ6P',['../neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21baffa7342631aa0526aaa44c0c549b1f3e',1,'neorv32_cpu_csr.h']]], + ['csr_5fmip_5ffirq7p_189',['CSR_MIP_FIRQ7P',['../neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21baad691486001a68f2375dcf5793ee795a',1,'neorv32_cpu_csr.h']]], + ['csr_5fmip_5ffirq8p_190',['CSR_MIP_FIRQ8P',['../neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21baf5bbd23d4f311f640db42e9015f87580',1,'neorv32_cpu_csr.h']]], + ['csr_5fmip_5ffirq9p_191',['CSR_MIP_FIRQ9P',['../neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21bad94c9691ce59b97fcfec14d345046c3e',1,'neorv32_cpu_csr.h']]], + ['csr_5fmip_5fmeip_192',['CSR_MIP_MEIP',['../neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba1d761ef98f88c40509168ac66b7a4872',1,'neorv32_cpu_csr.h']]], + ['csr_5fmip_5fmsip_193',['CSR_MIP_MSIP',['../neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba1470cfe04f9d3ce45b7156b2a7fae159',1,'neorv32_cpu_csr.h']]], + ['csr_5fmip_5fmtip_194',['CSR_MIP_MTIP',['../neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba344943c62922561378d33ec51ac236e4',1,'neorv32_cpu_csr.h']]], + ['csr_5fmisa_195',['CSR_MISA',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ade079242596ce14ce1ba9842ed29b84c',1,'neorv32_cpu_csr.h']]], + ['csr_5fmisa_5fa_196',['CSR_MISA_A',['../neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830ca89412df9f99d2a0ddc4665446397f1a2',1,'neorv32_cpu_csr.h']]], + ['csr_5fmisa_5fb_197',['CSR_MISA_B',['../neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830cadd469404a928e012a298773ec46926ad',1,'neorv32_cpu_csr.h']]], + ['csr_5fmisa_5fc_198',['CSR_MISA_C',['../neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830ca886699013158c74810598fa2fd6b07fa',1,'neorv32_cpu_csr.h']]], + ['csr_5fmisa_5fd_199',['CSR_MISA_D',['../neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830ca1dd1be1071450f9b00a817bce19fa665',1,'neorv32_cpu_csr.h']]], + ['csr_5fmisa_5fe_200',['CSR_MISA_E',['../neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830ca0ac798fd19cb7dbe1146afecda448fec',1,'neorv32_cpu_csr.h']]], + ['csr_5fmisa_5ff_201',['CSR_MISA_F',['../neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830ca9ec2cae2b948de1043540a4ca1665c40',1,'neorv32_cpu_csr.h']]], + ['csr_5fmisa_5fi_202',['CSR_MISA_I',['../neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830ca6091fd2c7ae38ad33be68a0fdfa50cca',1,'neorv32_cpu_csr.h']]], + ['csr_5fmisa_5fm_203',['CSR_MISA_M',['../neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830ca317a631e4598532f5bffe8fb93aff94b',1,'neorv32_cpu_csr.h']]], + ['csr_5fmisa_5fmxl_5fhi_204',['CSR_MISA_MXL_HI',['../neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830cafb3e4b08b87f5c161468a9e58ade12cc',1,'neorv32_cpu_csr.h']]], + ['csr_5fmisa_5fmxl_5flo_205',['CSR_MISA_MXL_LO',['../neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830cab5a55e97b8511f42fe68559a38f7f138',1,'neorv32_cpu_csr.h']]], + ['csr_5fmisa_5fu_206',['CSR_MISA_U',['../neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830cacd9d71e674d3a6d04984b6df706d9deb',1,'neorv32_cpu_csr.h']]], + ['csr_5fmisa_5fx_207',['CSR_MISA_X',['../neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830ca0b119a20be29fcae8fecf2a81c60d193',1,'neorv32_cpu_csr.h']]], + ['csr_5fmscratch_208',['CSR_MSCRATCH',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ae29976bb072639975ad0cdb985c7f004',1,'neorv32_cpu_csr.h']]], + ['csr_5fmstatus_209',['CSR_MSTATUS',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ad0e5de789d6390f750b8af03cdd15450',1,'neorv32_cpu_csr.h']]], + ['csr_5fmstatus_5fmie_210',['CSR_MSTATUS_MIE',['../neorv32__cpu__csr_8h.html#a76b70a2334131e7589d84c1ee96de485ae2603e365b3f1abfb46d53ed6b13dc56',1,'neorv32_cpu_csr.h']]], + ['csr_5fmstatus_5fmpie_211',['CSR_MSTATUS_MPIE',['../neorv32__cpu__csr_8h.html#a76b70a2334131e7589d84c1ee96de485aaa1d482f828ac9cafc40fcfc298bec34',1,'neorv32_cpu_csr.h']]], + ['csr_5fmstatus_5fmpp_5fh_212',['CSR_MSTATUS_MPP_H',['../neorv32__cpu__csr_8h.html#a76b70a2334131e7589d84c1ee96de485a8067c609c2360cab3bafa3c43e03dbf0',1,'neorv32_cpu_csr.h']]], + ['csr_5fmstatus_5fmpp_5fl_213',['CSR_MSTATUS_MPP_L',['../neorv32__cpu__csr_8h.html#a76b70a2334131e7589d84c1ee96de485af0ae9aca74144aa7dbdf656f71cc5c97',1,'neorv32_cpu_csr.h']]], + ['csr_5fmstatus_5fmprv_214',['CSR_MSTATUS_MPRV',['../neorv32__cpu__csr_8h.html#a76b70a2334131e7589d84c1ee96de485a75cefdbdef36b7fc248765b27c606a44',1,'neorv32_cpu_csr.h']]], + ['csr_5fmstatus_5ftw_215',['CSR_MSTATUS_TW',['../neorv32__cpu__csr_8h.html#a76b70a2334131e7589d84c1ee96de485ac94a070f3fe7962e8c49a81545cacf2d',1,'neorv32_cpu_csr.h']]], + ['csr_5fmstatush_216',['CSR_MSTATUSH',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ac2541060307369b2031e9ec07bbd0067',1,'neorv32_cpu_csr.h']]], + ['csr_5fmtinst_217',['CSR_MTINST',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a4f229c169ada239033a1383412ce58c8',1,'neorv32_cpu_csr.h']]], + ['csr_5fmtval_218',['CSR_MTVAL',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a76d30359e3b54197fb53f9939734cf1e',1,'neorv32_cpu_csr.h']]], + ['csr_5fmtvec_219',['CSR_MTVEC',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aa632d218400268df6dc6b289ff088d21',1,'neorv32_cpu_csr.h']]], + ['csr_5fmvendorid_220',['CSR_MVENDORID',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49af5c5a21909aaca2b57f9a15f4bac246b',1,'neorv32_cpu_csr.h']]], + ['csr_5fmxisa_221',['CSR_MXISA',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a396847bcf1634a1602ab117bfb57bdd2',1,'neorv32_cpu_csr.h']]], + ['csr_5fmxisa_5ffastmul_222',['CSR_MXISA_FASTMUL',['../neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387a48e57689f8a5b51d9ee9d648da7efc64',1,'neorv32_cpu_csr.h']]], + ['csr_5fmxisa_5ffastshift_223',['CSR_MXISA_FASTSHIFT',['../neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387ad5ac9e2188757e6c42c159f0c5887868',1,'neorv32_cpu_csr.h']]], + ['csr_5fmxisa_5fis_5fsim_224',['CSR_MXISA_IS_SIM',['../neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387a9b121ec0ad6271b6e07658f861015f6a',1,'neorv32_cpu_csr.h']]], + ['csr_5fmxisa_5frfhwrst_225',['CSR_MXISA_RFHWRST',['../neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387a6843c660d75f33e4252c7fccd4565a2d',1,'neorv32_cpu_csr.h']]], + ['csr_5fmxisa_5fsdext_226',['CSR_MXISA_SDEXT',['../neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387ab6aec595e6aa5ce7c98c7806d23d7af5',1,'neorv32_cpu_csr.h']]], + ['csr_5fmxisa_5fsdtrig_227',['CSR_MXISA_SDTRIG',['../neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387a59eae4272528f589f299ef9cce45af5b',1,'neorv32_cpu_csr.h']]], + ['csr_5fmxisa_5fsmpmp_228',['CSR_MXISA_SMPMP',['../neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387a6938948290d86b0ad25923f35d6c86d3',1,'neorv32_cpu_csr.h']]], + ['csr_5fmxisa_5fzfinx_229',['CSR_MXISA_ZFINX',['../neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387a56ec3195d0d27f362f58fadb2e037ed1',1,'neorv32_cpu_csr.h']]], + ['csr_5fmxisa_5fzicntr_230',['CSR_MXISA_ZICNTR',['../neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387a42a3b78195741af4b6aeeb98cbea46fe',1,'neorv32_cpu_csr.h']]], + ['csr_5fmxisa_5fzicond_231',['CSR_MXISA_ZICOND',['../neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387ab1f289cfaa9f54f7831a2abcdf9fca2e',1,'neorv32_cpu_csr.h']]], + ['csr_5fmxisa_5fzicsr_232',['CSR_MXISA_ZICSR',['../neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387accf1dd12be89e45df1423a5600789f2c',1,'neorv32_cpu_csr.h']]], + ['csr_5fmxisa_5fzifencei_233',['CSR_MXISA_ZIFENCEI',['../neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387a6979d4389ed9f8605d338fc616d29f0e',1,'neorv32_cpu_csr.h']]], + ['csr_5fmxisa_5fzihpm_234',['CSR_MXISA_ZIHPM',['../neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387ac13e6883af3a9da18057462239b9fb34',1,'neorv32_cpu_csr.h']]], + ['csr_5fmxisa_5fzmmul_235',['CSR_MXISA_ZMMUL',['../neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387a79b2b4b20e08ad31b50724a7a27fb20f',1,'neorv32_cpu_csr.h']]], + ['csr_5fmxisa_5fzxcfu_236',['CSR_MXISA_ZXCFU',['../neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387af422ae3b5caba59e33a29b5d069597e0',1,'neorv32_cpu_csr.h']]], + ['csr_5fpmpaddr0_237',['CSR_PMPADDR0',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a8941071db6145d34fff842249c0dcb9f',1,'neorv32_cpu_csr.h']]], + ['csr_5fpmpaddr1_238',['CSR_PMPADDR1',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a6a2933f3a1fa243de02db8a795e3ca41',1,'neorv32_cpu_csr.h']]], + ['csr_5fpmpaddr10_239',['CSR_PMPADDR10',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ad97b6fe934a3bed6b02d0c8d81165d60',1,'neorv32_cpu_csr.h']]], + ['csr_5fpmpaddr11_240',['CSR_PMPADDR11',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a3e5708c0f79cf58ae761b6bb8c2a4383',1,'neorv32_cpu_csr.h']]], + ['csr_5fpmpaddr12_241',['CSR_PMPADDR12',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a23026793ee53c8d55d23f63195368a6b',1,'neorv32_cpu_csr.h']]], + ['csr_5fpmpaddr13_242',['CSR_PMPADDR13',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a30879e88b250d3e94d9d9e728ffcc2cc',1,'neorv32_cpu_csr.h']]], + ['csr_5fpmpaddr14_243',['CSR_PMPADDR14',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a91a8b5008b4e08ab34c1516e21bf0ba8',1,'neorv32_cpu_csr.h']]], + ['csr_5fpmpaddr15_244',['CSR_PMPADDR15',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a6879b4bf5d2db92d236b9091df4841f2',1,'neorv32_cpu_csr.h']]], + ['csr_5fpmpaddr2_245',['CSR_PMPADDR2',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aa0b8c0561e8a778dce9c3b86499ffc50',1,'neorv32_cpu_csr.h']]], + ['csr_5fpmpaddr3_246',['CSR_PMPADDR3',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a89bad989197e9358563557311b3c97e9',1,'neorv32_cpu_csr.h']]], + ['csr_5fpmpaddr4_247',['CSR_PMPADDR4',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ace4529c53ad2d46767f86d920eada507',1,'neorv32_cpu_csr.h']]], + ['csr_5fpmpaddr5_248',['CSR_PMPADDR5',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ad9e78f71409fd7783cc2ae7c28b5e42c',1,'neorv32_cpu_csr.h']]], + ['csr_5fpmpaddr6_249',['CSR_PMPADDR6',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49af57b5b7b57cd6e8b3489a27dfd702444',1,'neorv32_cpu_csr.h']]], + ['csr_5fpmpaddr7_250',['CSR_PMPADDR7',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ae8ea19cf3e527dbc0d36a43dfd1b7346',1,'neorv32_cpu_csr.h']]], + ['csr_5fpmpaddr8_251',['CSR_PMPADDR8',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aec68bf7e26e44170c24599f7c6a8365b',1,'neorv32_cpu_csr.h']]], + ['csr_5fpmpaddr9_252',['CSR_PMPADDR9',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a54d38c8cf364d886eb7ac64463eedf77',1,'neorv32_cpu_csr.h']]], + ['csr_5fpmpcfg0_253',['CSR_PMPCFG0',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49af1a79349e46a4829af78d2cdfd0dc44f',1,'neorv32_cpu_csr.h']]], + ['csr_5fpmpcfg1_254',['CSR_PMPCFG1',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a22eea318ec1ac72cc14e133b71ef4b16',1,'neorv32_cpu_csr.h']]], + ['csr_5fpmpcfg2_255',['CSR_PMPCFG2',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a0c9492f6b956f088847f72b28e7b1446',1,'neorv32_cpu_csr.h']]], + ['csr_5fpmpcfg3_256',['CSR_PMPCFG3',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a067ed3778590ae97dc9b16069f0ed850',1,'neorv32_cpu_csr.h']]], + ['csr_5ftdata1_257',['CSR_TDATA1',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a80eab0e17f5fe41edde485044674dc57',1,'neorv32_cpu_csr.h']]], + ['csr_5ftdata2_258',['CSR_TDATA2',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49acf336638697242b691b691dc56b9aadc',1,'neorv32_cpu_csr.h']]], + ['csr_5ftinfo_259',['CSR_TINFO',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49af67c819c104f7e3ec34f2cbb847cf83b',1,'neorv32_cpu_csr.h']]], + ['csr_5ftselect_260',['CSR_TSELECT',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aaae2f0b2e3f5a31dff933868873f6d5d',1,'neorv32_cpu_csr.h']]], + ['ctrl_261',['CTRL',['../structneorv32__dma__t.html#a8480d6ad3ba5063cdf21dca286711569',1,'neorv32_dma_t::CTRL'],['../structneorv32__gptmr__t.html#a3c477ccb24ed12122d9d90244431c7e9',1,'neorv32_gptmr_t::CTRL'],['../structneorv32__neoled__t.html#adfe7618c002ff88dd22e65fcedfd6139',1,'neorv32_neoled_t::CTRL'],['../structneorv32__onewire__t.html#a310df3bab43e4438417b2ff948f4712a',1,'neorv32_onewire_t::CTRL'],['../structneorv32__pwm__t.html#ab86705332ebd9c45635c3195c6b3dcc5',1,'neorv32_pwm_t::CTRL'],['../structneorv32__sdi__t.html#af494f25cbcd8478cf384eb868e447303',1,'neorv32_sdi_t::CTRL'],['../structneorv32__slink__t.html#a39ece6aeeea6982002e164902a1e784f',1,'neorv32_slink_t::CTRL'],['../structneorv32__spi__t.html#a34fa748f0e3ceb75822c0a5553bd0420',1,'neorv32_spi_t::CTRL'],['../structneorv32__trng__t.html#ae2ff37ce30fb85ef59d9012534bc7e67',1,'neorv32_trng_t::CTRL'],['../structneorv32__twi__t.html#a148a1c681a2632881b25ee41652b5304',1,'neorv32_twi_t::CTRL'],['../structneorv32__uart__t.html#a0a6227aeea38335d2b9a9da46b35451b',1,'neorv32_uart_t::CTRL'],['../structneorv32__wdt__t.html#a6ae41e28d08b0f06118c499f52b56f41',1,'neorv32_wdt_t::CTRL'],['../structneorv32__xip__t.html#a7ead9d6a4f784d766a6b2755c6d35235',1,'neorv32_xip_t::CTRL']]], + ['cypher_5fdata_5fhw_262',['cypher_data_hw',['../demo__cfu_2main_8c.html#a9ad2780a4cfe0d9cb4f1a846a92063ae',1,'main.c']]], + ['cypher_5fdata_5fsw_263',['cypher_data_sw',['../demo__cfu_2main_8c.html#a33b2d9298edf94c5961e67a59c371d00',1,'main.c']]] +]; diff --git a/sw/search/all_a.js b/sw/search/all_a.js new file mode 100644 index 0000000000..e31f40f90a --- /dev/null +++ b/sw/search/all_a.js @@ -0,0 +1,51 @@ +var searchData= +[ + ['data_0',['DATA',['../structneorv32__crc__t.html#a47f286612848f597859aaef0d2d5da4d',1,'neorv32_crc_t::DATA'],['../structneorv32__neoled__t.html#a995fb1d63a9dfb3f20d715932781c1de',1,'neorv32_neoled_t::DATA'],['../structneorv32__onewire__t.html#a2c04aa736b901940ed65b96202c8af7a',1,'neorv32_onewire_t::DATA'],['../structneorv32__sdi__t.html#a3ea6903c0924d0a1b633b6a2b0ae44f1',1,'neorv32_sdi_t::DATA'],['../structneorv32__slink__t.html#a8af7d4ea9787cf94c599c82133c6aa74',1,'neorv32_slink_t::DATA'],['../structneorv32__spi__t.html#a3901bad351213e34820197a33d589f1e',1,'neorv32_spi_t::DATA'],['../structneorv32__uart__t.html#a38eec82aae9ed522a0d2afb9a9560036',1,'neorv32_uart_t::DATA']]], + ['data_5fblock_1',['data_block',['../demo__emulate__unaligned_2main_8c.html#a556f675911f865ead06c36072b1b9c3b',1,'main.c']]], + ['data_5fhi_2',['DATA_HI',['../structneorv32__xip__t.html#a516ab9c075ef6d1fb741e243db7703b2',1,'neorv32_xip_t']]], + ['data_5flast_3',['DATA_LAST',['../structneorv32__slink__t.html#ada8f10141d2161b83a5a367722ed6a77',1,'neorv32_slink_t']]], + ['data_5flo_4',['DATA_LO',['../structneorv32__xip__t.html#ad64048bb3544e712b1c668c2ef343ccb',1,'neorv32_xip_t']]], + ['data_5fnum_5',['DATA_NUM',['../demo__cfu_2main_8c.html#ac637695e266f3af7799e352b374412ad',1,'main.c']]], + ['date_5ft_6',['date_t',['../structdate__t.html',1,'']]], + ['day_7',['day',['../structdate__t.html#a482ad87226bae7841dfec63e035aeace',1,'date_t']]], + ['dc_8',['DC',['../structneorv32__pwm__t.html#a6d29528ca60921a6ef8e5bcde81925e7',1,'neorv32_pwm_t']]], + ['dcmd_9',['DCMD',['../structneorv32__twi__t.html#ae311e0827bdb178c6dd8c4535b80d5cb',1,'neorv32_twi_t']]], + ['debug_5finfo_10',['DEBUG_INFO',['../demo__emulate__unaligned_2main_8c.html#a4407b4d6eae3ba7fe9538b1242a7e165',1,'main.c']]], + ['dma_5fcmd_5fb2b_11',['DMA_CMD_B2B',['../neorv32__dma_8h.html#a5e01d4454c97eb8e4ecd1455090bbfa9',1,'neorv32_dma.h']]], + ['dma_5fcmd_5fb2sw_12',['DMA_CMD_B2SW',['../neorv32__dma_8h.html#adfecb3debff251070e4f6eb809412129',1,'neorv32_dma.h']]], + ['dma_5fcmd_5fb2uw_13',['DMA_CMD_B2UW',['../neorv32__dma_8h.html#aeb63f99217f14d1ddde35c1f6c104e72',1,'neorv32_dma.h']]], + ['dma_5fcmd_5fdst_5fconst_14',['DMA_CMD_DST_CONST',['../neorv32__dma_8h.html#a6a0ce532aad39e6489e9d52bcb6f4cd2',1,'neorv32_dma.h']]], + ['dma_5fcmd_5fdst_5finc_15',['DMA_CMD_DST_INC',['../neorv32__dma_8h.html#a61caa2602c6b148af55d990e3c0ae6be',1,'neorv32_dma.h']]], + ['dma_5fcmd_5fendian_16',['DMA_CMD_ENDIAN',['../neorv32__dma_8h.html#a18fb7faa0a35f562821ca854d7c648b4',1,'neorv32_dma.h']]], + ['dma_5fcmd_5fsrc_5fconst_17',['DMA_CMD_SRC_CONST',['../neorv32__dma_8h.html#ae380022d8b8fb70da91f0892f2bc32c8',1,'neorv32_dma.h']]], + ['dma_5fcmd_5fsrc_5finc_18',['DMA_CMD_SRC_INC',['../neorv32__dma_8h.html#acc081d58b53d1eddd2bff35b128d7da2',1,'neorv32_dma.h']]], + ['dma_5fcmd_5fw2w_19',['DMA_CMD_W2W',['../neorv32__dma_8h.html#a13a16ba8d6daf9c82312bf4d392d15a8',1,'neorv32_dma.h']]], + ['dma_5fctrl_5fauto_20',['DMA_CTRL_AUTO',['../neorv32__dma_8h.html#a6716eddb145b80ad38799da3b87cb2a4a5aeeb05d6365d94d92808df2490daa3b',1,'neorv32_dma.h']]], + ['dma_5fctrl_5fbusy_21',['DMA_CTRL_BUSY',['../neorv32__dma_8h.html#a6716eddb145b80ad38799da3b87cb2a4a8e5ff34ac48eea4b352378bb2af47bcb',1,'neorv32_dma.h']]], + ['dma_5fctrl_5fdone_22',['DMA_CTRL_DONE',['../neorv32__dma_8h.html#a6716eddb145b80ad38799da3b87cb2a4a0d51df1bb87dc54d331891c5db787bcc',1,'neorv32_dma.h']]], + ['dma_5fctrl_5fen_23',['DMA_CTRL_EN',['../neorv32__dma_8h.html#a6716eddb145b80ad38799da3b87cb2a4a5f39deea0212f45423243c8100c40838',1,'neorv32_dma.h']]], + ['dma_5fctrl_5ferror_5frd_24',['DMA_CTRL_ERROR_RD',['../neorv32__dma_8h.html#a6716eddb145b80ad38799da3b87cb2a4a539609fc4d80867b3eb98c78206f5f96',1,'neorv32_dma.h']]], + ['dma_5fctrl_5ferror_5fwr_25',['DMA_CTRL_ERROR_WR',['../neorv32__dma_8h.html#a6716eddb145b80ad38799da3b87cb2a4af7e038b0b0e3ac64f5a2c598eb9c5101',1,'neorv32_dma.h']]], + ['dma_5fctrl_5ffence_26',['DMA_CTRL_FENCE',['../neorv32__dma_8h.html#a6716eddb145b80ad38799da3b87cb2a4ace9fdcdfa8784abad30e033c273e7d00',1,'neorv32_dma.h']]], + ['dma_5fctrl_5ffirq_5fsel_5flsb_27',['DMA_CTRL_FIRQ_SEL_LSB',['../neorv32__dma_8h.html#a6716eddb145b80ad38799da3b87cb2a4aaf040e663494b39b890d7171d0a584b9',1,'neorv32_dma.h']]], + ['dma_5fctrl_5ffirq_5fsel_5fmsb_28',['DMA_CTRL_FIRQ_SEL_MSB',['../neorv32__dma_8h.html#a6716eddb145b80ad38799da3b87cb2a4a3eba1f7868f0c985effb69785ced011a',1,'neorv32_dma.h']]], + ['dma_5fctrl_5ffirq_5ftype_29',['DMA_CTRL_FIRQ_TYPE',['../neorv32__dma_8h.html#a6716eddb145b80ad38799da3b87cb2a4aeaf5ee8f6a84668aa15cd3e21f076afe',1,'neorv32_dma.h']]], + ['dma_5ffirq_5fenable_30',['DMA_FIRQ_ENABLE',['../neorv32_8h.html#ace46f95dec73b33bf2535eb653bf8f65',1,'neorv32.h']]], + ['dma_5ffirq_5fhandler_31',['dma_firq_handler',['../demo__dma_2main_8c.html#aefcc5abb86a652587ff69be120a66487',1,'main.c']]], + ['dma_5ffirq_5fpending_32',['DMA_FIRQ_PENDING',['../neorv32_8h.html#a1fa2b25383e6d05cf26f3517091ddbbf',1,'neorv32.h']]], + ['dma_5frte_5fid_33',['DMA_RTE_ID',['../neorv32_8h.html#a568b54ba7dfdae736d8d685dc4d32113',1,'neorv32.h']]], + ['dma_5fstatus_5fbusy_34',['DMA_STATUS_BUSY',['../neorv32__dma_8h.html#a002cb188ea5156df0ba282e239a6e74bad0f66e962296f5451d73dc1cae1fdc0d',1,'neorv32_dma.h']]], + ['dma_5fstatus_5ferr_5frd_35',['DMA_STATUS_ERR_RD',['../neorv32__dma_8h.html#a002cb188ea5156df0ba282e239a6e74baed7242b847e3cc8cf20d7da99f9b1492',1,'neorv32_dma.h']]], + ['dma_5fstatus_5ferr_5fwr_36',['DMA_STATUS_ERR_WR',['../neorv32__dma_8h.html#a002cb188ea5156df0ba282e239a6e74ba038b6ef194c3db158cb59168f763a7b8',1,'neorv32_dma.h']]], + ['dma_5fstatus_5fidle_37',['DMA_STATUS_IDLE',['../neorv32__dma_8h.html#a002cb188ea5156df0ba282e239a6e74bac9c380cd5729386e5f5673e20b86326f',1,'neorv32_dma.h']]], + ['dma_5ftrap_5fcode_38',['DMA_TRAP_CODE',['../neorv32_8h.html#ad2e81443af8a4ce2db3a4e3c1a8fb784',1,'neorv32.h']]], + ['dma_5fttype_5fdst_5finc_39',['DMA_TTYPE_DST_INC',['../neorv32__dma_8h.html#a33187c5a074d62b46d2262e352edb8d9abb1293915b076e5d37be6724b44ab0da',1,'neorv32_dma.h']]], + ['dma_5fttype_5fendian_40',['DMA_TTYPE_ENDIAN',['../neorv32__dma_8h.html#a33187c5a074d62b46d2262e352edb8d9a37ea8ef1e6b342db330d3885545fc802',1,'neorv32_dma.h']]], + ['dma_5fttype_5fnum_5flsb_41',['DMA_TTYPE_NUM_LSB',['../neorv32__dma_8h.html#a33187c5a074d62b46d2262e352edb8d9a8dba4160c033c763f5102928c471e450',1,'neorv32_dma.h']]], + ['dma_5fttype_5fnum_5fmsb_42',['DMA_TTYPE_NUM_MSB',['../neorv32__dma_8h.html#a33187c5a074d62b46d2262e352edb8d9a61553eee00ed2382565bf826074c44bd',1,'neorv32_dma.h']]], + ['dma_5fttype_5fqsel_5flsb_43',['DMA_TTYPE_QSEL_LSB',['../neorv32__dma_8h.html#a33187c5a074d62b46d2262e352edb8d9afcfdedeca4c4a1def4905660811e31e2',1,'neorv32_dma.h']]], + ['dma_5fttype_5fqsel_5fmsb_44',['DMA_TTYPE_QSEL_MSB',['../neorv32__dma_8h.html#a33187c5a074d62b46d2262e352edb8d9a4217c9a8ac4ccc52bb45944f30a598c5',1,'neorv32_dma.h']]], + ['dma_5fttype_5fsrc_5finc_45',['DMA_TTYPE_SRC_INC',['../neorv32__dma_8h.html#a33187c5a074d62b46d2262e352edb8d9a4b99a30b851851f3388dd4e77effacec',1,'neorv32_dma.h']]], + ['dst_5fbase_46',['DST_BASE',['../structneorv32__dma__t.html#aee8a6cf3cbd9fe3c5995f046ffb9a1c0',1,'neorv32_dma_t']]], + ['dump_5fmemory_47',['dump_memory',['../bus__explorer_2main_8c.html#a6405739c6012158151eb082c31c312da',1,'main.c']]] +]; diff --git a/sw/search/all_b.js b/sw/search/all_b.js new file mode 100644 index 0000000000..b7205745f6 --- /dev/null +++ b/sw/search/all_b.js @@ -0,0 +1,23 @@ +var searchData= +[ + ['ecosystem_0',[':floppy_disk: &lt;a href=&quot;https://stnolting.github.io/neorv32/#_software_framework&quot; &gt;Software Framework&lt;/a&gt; - The Software Ecosystem',['../md_README.html#autotoc_md11',1,'']]], + ['eie_1',['EIE',['../structneorv32__xirq__t.html#aef3c2b491207abd68bf6392f97096a74',1,'neorv32_xirq_t']]], + ['eip_2',['EIP',['../structneorv32__xirq__t.html#a788d8004f3b85fb66e947415d8fcc058',1,'neorv32_xirq_t']]], + ['error_5fchecksum_3',['ERROR_CHECKSUM',['../bootloader_8c.html#aa0c639898508ff8e4fab6290101f3088a471ebe6c0766abc6fa4e82a09bfdb985',1,'bootloader.c']]], + ['error_5fcodes_5fenum_4',['ERROR_CODES_enum',['../bootloader_8c.html#aa0c639898508ff8e4fab6290101f3088',1,'bootloader.c']]], + ['error_5fflash_5',['ERROR_FLASH',['../bootloader_8c.html#aa0c639898508ff8e4fab6290101f3088a684d6723fa25e7651e13d99fb249363c',1,'bootloader.c']]], + ['error_5fmessage_6',['error_message',['../bootloader_8c.html#a6fea855ffe2fa0cd5ea9f98c0d5adc4d',1,'bootloader.c']]], + ['error_5fsignature_7',['ERROR_SIGNATURE',['../bootloader_8c.html#aa0c639898508ff8e4fab6290101f3088ad41014563cb3ca69ab69b94d43e97caa',1,'bootloader.c']]], + ['error_5fsize_8',['ERROR_SIZE',['../bootloader_8c.html#aa0c639898508ff8e4fab6290101f3088a2d77ed1c715fb969a1faa01c71625f2d',1,'bootloader.c']]], + ['esc_9',['ESC',['../structneorv32__xirq__t.html#ae4f7f3f41210ff329b6f82d5dfada88a',1,'neorv32_xirq_t']]], + ['exe_5favailable_10',['exe_available',['../bootloader_8c.html#a0f9fcfdf758260b9b79b6eda063dd87a',1,'bootloader.c']]], + ['exe_5fbase_5faddr_11',['EXE_BASE_ADDR',['../bootloader_8c.html#a18936dc79b9e5aa84df016b046a6b977',1,'bootloader.c']]], + ['exe_5foffset_5fchecksum_12',['EXE_OFFSET_CHECKSUM',['../bootloader_8c.html#a165a347c51d8aae06a564a2f297f2febabc27a855096a70dca0f8bc148a123be4',1,'bootloader.c']]], + ['exe_5foffset_5fdata_13',['EXE_OFFSET_DATA',['../bootloader_8c.html#a165a347c51d8aae06a564a2f297f2febaea032c54a21057710ef2021638972ce6',1,'bootloader.c']]], + ['exe_5foffset_5fsignature_14',['EXE_OFFSET_SIGNATURE',['../bootloader_8c.html#a165a347c51d8aae06a564a2f297f2feba61100996f309c45b8b628ade2e3acc7f',1,'bootloader.c']]], + ['exe_5foffset_5fsize_15',['EXE_OFFSET_SIZE',['../bootloader_8c.html#a165a347c51d8aae06a564a2f297f2febacc430caa4bff2fef4568c757893fe2fe',1,'bootloader.c']]], + ['exe_5fsignature_16',['EXE_SIGNATURE',['../bootloader_8c.html#a0035ad41f622dbfc2412318a8ed39257',1,'EXE_SIGNATURE:&#160;bootloader.c'],['../demo__xip_2main_8c.html#a0035ad41f622dbfc2412318a8ed39257',1,'EXE_SIGNATURE:&#160;main.c']]], + ['exe_5fstream_5fflash_17',['EXE_STREAM_FLASH',['../bootloader_8c.html#abcbf77626fdd0b475d245f836eab7a83a98526cd8f81d570c57d98193b32cf114',1,'bootloader.c']]], + ['exe_5fstream_5fsource_5fenum_18',['EXE_STREAM_SOURCE_enum',['../bootloader_8c.html#abcbf77626fdd0b475d245f836eab7a83',1,'bootloader.c']]], + ['exe_5fstream_5fuart_19',['EXE_STREAM_UART',['../bootloader_8c.html#abcbf77626fdd0b475d245f836eab7a83ab149261ddf3f08e44e9d2538e384f58f',1,'bootloader.c']]] +]; diff --git a/sw/search/all_c.js b/sw/search/all_c.js new file mode 100644 index 0000000000..e0b5a3e998 --- /dev/null +++ b/sw/search/all_c.js @@ -0,0 +1,12 @@ +var searchData= +[ + ['features_0',['Features',['../md_README.html#autotoc_md4',1,'2. Features'],['../md_README.html#autotoc_md2',1,'Key Features']]], + ['flash_5fabytes_1',['FLASH_ABYTES',['../demo__xip_2main_8c.html#af9b3c37c806499fc435302f5bce6a122',1,'main.c']]], + ['flash_5fbase_2',['FLASH_BASE',['../demo__xip_2main_8c.html#a23a9099a5f8fc9c6e253c0eecb2be8db',1,'main.c']]], + ['flash_5fsreg_5fbusy_3',['FLASH_SREG_BUSY',['../bootloader_8c.html#a97299f563ebc1fca4c663b025a15136fa133cd87673ce9a612da494583e03dae9',1,'bootloader.c']]], + ['flash_5fsreg_5fwel_4',['FLASH_SREG_WEL',['../bootloader_8c.html#a97299f563ebc1fca4c663b025a15136fa22e8c983d74430ea0930e37781e88bf9',1,'bootloader.c']]], + ['float_5fconv_5ft_5',['float_conv_t',['../unionfloat__conv__t.html',1,'']]], + ['float_5fvalue_6',['float_value',['../unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788',1,'float_conv_t']]], + ['fpga_20implementation_20results_7',['3. FPGA Implementation Results',['../md_README.html#autotoc_md5',1,'']]], + ['framework_20a_20the_20software_20ecosystem_8',[':floppy_disk: &lt;a href=&quot;https://stnolting.github.io/neorv32/#_software_framework&quot; &gt;Software Framework&lt;/a&gt; - The Software Ecosystem',['../md_README.html#autotoc_md11',1,'']]] +]; diff --git a/sw/search/all_d.js b/sw/search/all_d.js new file mode 100644 index 0000000000..5c3f53821a --- /dev/null +++ b/sw/search/all_d.js @@ -0,0 +1,32 @@ +var searchData= +[ + ['gen_5fdelay_0',['GEN_DELAY',['../game__of__life_2main_8c.html#a3f33bf77abbf35c245956489f8f7e3a7',1,'main.c']]], + ['generate_5fhistogram_1',['generate_histogram',['../demo__trng_2main_8c.html#a4e49f5e3feb4bd5755f919cd3310b506',1,'main.c']]], + ['get_5fcell_2',['get_cell',['../game__of__life_2main_8c.html#a6bd541a19c62ea9ec620eaad3f218d16',1,'main.c']]], + ['get_5fexe_3',['get_exe',['../bootloader_8c.html#ac18819795adb6dbdd52b0587e7fbb569',1,'bootloader.c']]], + ['get_5fexe_5fword_4',['get_exe_word',['../bootloader_8c.html#ac58d9f7dc79a549bde1cb50f619c19af',1,'bootloader.c']]], + ['get_5fneighborhood_5',['get_neighborhood',['../game__of__life_2main_8c.html#a977190adaa24a3f49fca1540b51d25a0',1,'main.c']]], + ['get_5ftest_5fvector_6',['get_test_vector',['../float__corner__test_2main_8c.html#a73c70bd0fb6d695cb113eaeb50923e3e',1,'get_test_vector(void):&#160;main.c'],['../floating__point__test_2main_8c.html#a73c70bd0fb6d695cb113eaeb50923e3e',1,'get_test_vector(void):&#160;main.c']]], + ['getchar_7',['getchar',['../neorv32__uart_8c.html#a3e29caa20f7cffe18f410f01278905a8',1,'neorv32_uart.c']]], + ['getting_20started_8',['Getting Started',['../md_README.html#autotoc_md7',1,'5. Getting Started'],['../md_README.html#autotoc_md12',1,':rocket: &lt;a href=&quot;https://stnolting.github.io/neorv32/ug/&quot; &gt;User Guide&lt;/a&gt; - Getting Started!']]], + ['getting_5fexe_9',['getting_exe',['../bootloader_8c.html#a5fa6b109bf211d1768f84c9d38eef240',1,'bootloader.c']]], + ['github_20io_20neorv32_20_5fneorv32_5fcentral_5fprocessing_5funit_5fcpu_20neorv32_20cpu_20a_20the_20core_10',[':abacus: &lt;a href=&quot;https://stnolting.github.io/neorv32/#_neorv32_central_processing_unit_cpu&quot; &gt;NEORV32 CPU&lt;/a&gt; - The Core',['../md_README.html#autotoc_md10',1,'']]], + ['github_20io_20neorv32_20_5fneorv32_5fprocessor_5fsoc_20neorv32_20processor_20a_20the_20soc_11',[':desktop_computer: &lt;a href=&quot;https://stnolting.github.io/neorv32/#_neorv32_processor_soc&quot; &gt;NEORV32 Processor&lt;/a&gt; - The SoC',['../md_README.html#autotoc_md9',1,'']]], + ['github_20io_20neorv32_20_5foverview_20neorv32_20project_20a_20an_20introduction_12',[':mag: &lt;a href=&quot;https://stnolting.github.io/neorv32/#_overview&quot; &gt;NEORV32 Project&lt;/a&gt; - An Introduction',['../md_README.html#autotoc_md8',1,'']]], + ['github_20io_20neorv32_20_5fsoftware_5fframework_20software_20framework_20a_20the_20software_20ecosystem_13',[':floppy_disk: &lt;a href=&quot;https://stnolting.github.io/neorv32/#_software_framework&quot; &gt;Software Framework&lt;/a&gt; - The Software Ecosystem',['../md_README.html#autotoc_md11',1,'']]], + ['github_20io_20neorv32_20ug_20user_20guide_20a_20getting_20started_14',[':rocket: &lt;a href=&quot;https://stnolting.github.io/neorv32/ug/&quot; &gt;User Guide&lt;/a&gt; - Getting Started!',['../md_README.html#autotoc_md12',1,'']]], + ['global_5ftrap_5fhandler_15',['global_trap_handler',['../processor__check_2main_8c.html#a9a64ce0ee69c4c32cecc8b2b2746604c',1,'main.c']]], + ['gptmr_5fctrl_5fen_16',['GPTMR_CTRL_EN',['../neorv32__gptmr_8h.html#a135b0750d4afed16e5867134e3843988abbfa7abcbd80b9c47e83e23e5cefaf90',1,'neorv32_gptmr.h']]], + ['gptmr_5fctrl_5firq_5fclr_17',['GPTMR_CTRL_IRQ_CLR',['../neorv32__gptmr_8h.html#a135b0750d4afed16e5867134e3843988aadb663ad9a0dfd37fc65dffc1a289b38',1,'neorv32_gptmr.h']]], + ['gptmr_5fctrl_5firq_5fpnd_18',['GPTMR_CTRL_IRQ_PND',['../neorv32__gptmr_8h.html#a135b0750d4afed16e5867134e3843988a3a868dc710ab9add083137e4e3fe888a',1,'neorv32_gptmr.h']]], + ['gptmr_5fctrl_5fmode_19',['GPTMR_CTRL_MODE',['../neorv32__gptmr_8h.html#a135b0750d4afed16e5867134e3843988a473870880c0eca71578d6969e816af43',1,'neorv32_gptmr.h']]], + ['gptmr_5fctrl_5fprsc0_20',['GPTMR_CTRL_PRSC0',['../neorv32__gptmr_8h.html#a135b0750d4afed16e5867134e3843988ae4716a7a9e356484a8e478f07920cde3',1,'neorv32_gptmr.h']]], + ['gptmr_5fctrl_5fprsc1_21',['GPTMR_CTRL_PRSC1',['../neorv32__gptmr_8h.html#a135b0750d4afed16e5867134e3843988a1e1e8e516fa4918441e3c77153940298',1,'neorv32_gptmr.h']]], + ['gptmr_5fctrl_5fprsc2_22',['GPTMR_CTRL_PRSC2',['../neorv32__gptmr_8h.html#a135b0750d4afed16e5867134e3843988a185861fbdc5f276735481237ad844833',1,'neorv32_gptmr.h']]], + ['gptmr_5ffirq_5fenable_23',['GPTMR_FIRQ_ENABLE',['../neorv32_8h.html#a0a59186908b498cb92273b7767966e26',1,'neorv32.h']]], + ['gptmr_5ffirq_5fhandler_24',['gptmr_firq_handler',['../demo__gptmr_2main_8c.html#a2bd89412466a65329711bfd5c29199c9',1,'main.c']]], + ['gptmr_5ffirq_5fpending_25',['GPTMR_FIRQ_PENDING',['../neorv32_8h.html#a4a3164d123ddddd07750f868e67d82d8',1,'neorv32.h']]], + ['gptmr_5frte_5fid_26',['GPTMR_RTE_ID',['../neorv32_8h.html#aac38deeef36de0a474ab238a3054f860',1,'neorv32.h']]], + ['gptmr_5ftrap_5fcode_27',['GPTMR_TRAP_CODE',['../neorv32_8h.html#a445543c36d1f78477aa8ea4841c720a1',1,'neorv32.h']]], + ['guide_20a_20getting_20started_28',[':rocket: &lt;a href=&quot;https://stnolting.github.io/neorv32/ug/&quot; &gt;User Guide&lt;/a&gt; - Getting Started!',['../md_README.html#autotoc_md12',1,'']]] +]; diff --git a/sw/search/all_e.js b/sw/search/all_e.js new file mode 100644 index 0000000000..658d38f72c --- /dev/null +++ b/sw/search/all_e.js @@ -0,0 +1,29 @@ +var searchData= +[ + ['hexdump_0',['hexdump',['../bus__explorer_2main_8c.html#a02640a99db37b8d92b9edffc9720a210',1,'main.c']]], + ['hours_1',['hours',['../structdate__t.html#a39a23695634a2814d827984f4eea54eb',1,'date_t']]], + ['hpmcnt_5fevent_5fbranch_2',['HPMCNT_EVENT_BRANCH',['../neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfea9e1e2b50352b2555e9c64e76776919a6',1,'neorv32_cpu_csr.h']]], + ['hpmcnt_5fevent_5fbranched_3',['HPMCNT_EVENT_BRANCHED',['../neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfea0f15c5a824cb1678423ac4ef72a5f4f5',1,'neorv32_cpu_csr.h']]], + ['hpmcnt_5fevent_5fcompr_4',['HPMCNT_EVENT_COMPR',['../neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfea685ed663611d988702ec59c254eb61dd',1,'neorv32_cpu_csr.h']]], + ['hpmcnt_5fevent_5fcy_5',['HPMCNT_EVENT_CY',['../neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfea2b683572525adc02ce0910031cfea914',1,'neorv32_cpu_csr.h']]], + ['hpmcnt_5fevent_5fir_6',['HPMCNT_EVENT_IR',['../neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfeaab438295e5f00ffe4c2457a54ee9bfc4',1,'neorv32_cpu_csr.h']]], + ['hpmcnt_5fevent_5fload_7',['HPMCNT_EVENT_LOAD',['../neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfea1a06f216e1a12afa0b90d6e1218b3c91',1,'neorv32_cpu_csr.h']]], + ['hpmcnt_5fevent_5fstore_8',['HPMCNT_EVENT_STORE',['../neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfea6a942852e3cd85616a63addb8e9d76f2',1,'neorv32_cpu_csr.h']]], + ['hpmcnt_5fevent_5ftm_9',['HPMCNT_EVENT_TM',['../neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfea578ef6fc107c22b5cb7be5950f695640',1,'neorv32_cpu_csr.h']]], + ['hpmcnt_5fevent_5ftrap_10',['HPMCNT_EVENT_TRAP',['../neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfea3a4f5bf9251def87a71162dbcf9043c5',1,'neorv32_cpu_csr.h']]], + ['hpmcnt_5fevent_5fwait_5falu_11',['HPMCNT_EVENT_WAIT_ALU',['../neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfeaffbb04d0053ebd079c6cacb4e5e7ed6b',1,'neorv32_cpu_csr.h']]], + ['hpmcnt_5fevent_5fwait_5fdis_12',['HPMCNT_EVENT_WAIT_DIS',['../neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfeabcb123b5b150b4413e5fd48475faab27',1,'neorv32_cpu_csr.h']]], + ['hpmcnt_5fevent_5fwait_5flsu_13',['HPMCNT_EVENT_WAIT_LSU',['../neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfea67a59934bc66bc7ccf82d24fe8a18a3b',1,'neorv32_cpu_csr.h']]], + ['href_20https_3a_20stnolting_20github_20io_20neorv32_20_5fneorv32_5fcentral_5fprocessing_5funit_5fcpu_20neorv32_20cpu_20a_20the_20core_14',[':abacus: &lt;a href=&quot;https://stnolting.github.io/neorv32/#_neorv32_central_processing_unit_cpu&quot; &gt;NEORV32 CPU&lt;/a&gt; - The Core',['../md_README.html#autotoc_md10',1,'']]], + ['href_20https_3a_20stnolting_20github_20io_20neorv32_20_5fneorv32_5fprocessor_5fsoc_20neorv32_20processor_20a_20the_20soc_15',[':desktop_computer: &lt;a href=&quot;https://stnolting.github.io/neorv32/#_neorv32_processor_soc&quot; &gt;NEORV32 Processor&lt;/a&gt; - The SoC',['../md_README.html#autotoc_md9',1,'']]], + ['href_20https_3a_20stnolting_20github_20io_20neorv32_20_5foverview_20neorv32_20project_20a_20an_20introduction_16',[':mag: &lt;a href=&quot;https://stnolting.github.io/neorv32/#_overview&quot; &gt;NEORV32 Project&lt;/a&gt; - An Introduction',['../md_README.html#autotoc_md8',1,'']]], + ['href_20https_3a_20stnolting_20github_20io_20neorv32_20_5fsoftware_5fframework_20software_20framework_20a_20the_20software_20ecosystem_17',[':floppy_disk: &lt;a href=&quot;https://stnolting.github.io/neorv32/#_software_framework&quot; &gt;Software Framework&lt;/a&gt; - The Software Ecosystem',['../md_README.html#autotoc_md11',1,'']]], + ['href_20https_3a_20stnolting_20github_20io_20neorv32_20ug_20user_20guide_20a_20getting_20started_18',[':rocket: &lt;a href=&quot;https://stnolting.github.io/neorv32/ug/&quot; &gt;User Guide&lt;/a&gt; - Getting Started!',['../md_README.html#autotoc_md12',1,'']]], + ['hsv2rgb_19',['hsv2rgb',['../demo__neopixel_2main_8c.html#a2736ec755f9e10c80bf66f727f870ffc',1,'main.c']]], + ['https_3a_20stnolting_20github_20io_20neorv32_20_5fneorv32_5fcentral_5fprocessing_5funit_5fcpu_20neorv32_20cpu_20a_20the_20core_20',[':abacus: &lt;a href=&quot;https://stnolting.github.io/neorv32/#_neorv32_central_processing_unit_cpu&quot; &gt;NEORV32 CPU&lt;/a&gt; - The Core',['../md_README.html#autotoc_md10',1,'']]], + ['https_3a_20stnolting_20github_20io_20neorv32_20_5fneorv32_5fprocessor_5fsoc_20neorv32_20processor_20a_20the_20soc_21',[':desktop_computer: &lt;a href=&quot;https://stnolting.github.io/neorv32/#_neorv32_processor_soc&quot; &gt;NEORV32 Processor&lt;/a&gt; - The SoC',['../md_README.html#autotoc_md9',1,'']]], + ['https_3a_20stnolting_20github_20io_20neorv32_20_5foverview_20neorv32_20project_20a_20an_20introduction_22',[':mag: &lt;a href=&quot;https://stnolting.github.io/neorv32/#_overview&quot; &gt;NEORV32 Project&lt;/a&gt; - An Introduction',['../md_README.html#autotoc_md8',1,'']]], + ['https_3a_20stnolting_20github_20io_20neorv32_20_5fsoftware_5fframework_20software_20framework_20a_20the_20software_20ecosystem_23',[':floppy_disk: &lt;a href=&quot;https://stnolting.github.io/neorv32/#_software_framework&quot; &gt;Software Framework&lt;/a&gt; - The Software Ecosystem',['../md_README.html#autotoc_md11',1,'']]], + ['https_3a_20stnolting_20github_20io_20neorv32_20ug_20user_20guide_20a_20getting_20started_24',[':rocket: &lt;a href=&quot;https://stnolting.github.io/neorv32/ug/&quot; &gt;User Guide&lt;/a&gt; - Getting Started!',['../md_README.html#autotoc_md12',1,'']]], + ['hw_5fbreakpoint_5fhandler_25',['hw_breakpoint_handler',['../processor__check_2main_8c.html#a31d9e432f6a368e6222f5e0907eeb6f4',1,'main.c']]] +]; diff --git a/sw/search/all_f.js b/sw/search/all_f.js new file mode 100644 index 0000000000..9133a18dbd --- /dev/null +++ b/sw/search/all_f.js @@ -0,0 +1,13 @@ +var searchData= +[ + ['implementation_20results_0',['3. FPGA Implementation Results',['../md_README.html#autotoc_md5',1,'']]], + ['input_1',['INPUT',['../structneorv32__gpio__t.html#a208ee622d43fee3574072f19a98c8808',1,'neorv32_gpio_t']]], + ['input_5fdata_2',['input_data',['../demo__cfu_2main_8c.html#a2e2ccb9136736a673dbef71f207e97a0',1,'main.c']]], + ['introduction_3',[':mag: &lt;a href=&quot;https://stnolting.github.io/neorv32/#_overview&quot; &gt;NEORV32 Project&lt;/a&gt; - An Introduction',['../md_README.html#autotoc_md8',1,'']]], + ['io_20neorv32_20_5fneorv32_5fcentral_5fprocessing_5funit_5fcpu_20neorv32_20cpu_20a_20the_20core_4',[':abacus: &lt;a href=&quot;https://stnolting.github.io/neorv32/#_neorv32_central_processing_unit_cpu&quot; &gt;NEORV32 CPU&lt;/a&gt; - The Core',['../md_README.html#autotoc_md10',1,'']]], + ['io_20neorv32_20_5fneorv32_5fprocessor_5fsoc_20neorv32_20processor_20a_20the_20soc_5',[':desktop_computer: &lt;a href=&quot;https://stnolting.github.io/neorv32/#_neorv32_processor_soc&quot; &gt;NEORV32 Processor&lt;/a&gt; - The SoC',['../md_README.html#autotoc_md9',1,'']]], + ['io_20neorv32_20_5foverview_20neorv32_20project_20a_20an_20introduction_6',[':mag: &lt;a href=&quot;https://stnolting.github.io/neorv32/#_overview&quot; &gt;NEORV32 Project&lt;/a&gt; - An Introduction',['../md_README.html#autotoc_md8',1,'']]], + ['io_20neorv32_20_5fsoftware_5fframework_20software_20framework_20a_20the_20software_20ecosystem_7',[':floppy_disk: &lt;a href=&quot;https://stnolting.github.io/neorv32/#_software_framework&quot; &gt;Software Framework&lt;/a&gt; - The Software Ecosystem',['../md_README.html#autotoc_md11',1,'']]], + ['io_20neorv32_20ug_20user_20guide_20a_20getting_20started_8',[':rocket: &lt;a href=&quot;https://stnolting.github.io/neorv32/ug/&quot; &gt;User Guide&lt;/a&gt; - Getting Started!',['../md_README.html#autotoc_md12',1,'']]], + ['io_5fbase_5faddress_9',['IO_BASE_ADDRESS',['../neorv32_8h.html#a1eb0cb7fed7e154e15cb4009880a879c',1,'neorv32.h']]] +]; diff --git a/sw/search/classes_0.js b/sw/search/classes_0.js new file mode 100644 index 0000000000..17705b744a --- /dev/null +++ b/sw/search/classes_0.js @@ -0,0 +1,4 @@ +var searchData= +[ + ['date_5ft_0',['date_t',['../structdate__t.html',1,'']]] +]; diff --git a/sw/search/classes_1.js b/sw/search/classes_1.js new file mode 100644 index 0000000000..089b78ab05 --- /dev/null +++ b/sw/search/classes_1.js @@ -0,0 +1,4 @@ +var searchData= +[ + ['float_5fconv_5ft_0',['float_conv_t',['../unionfloat__conv__t.html',1,'']]] +]; diff --git a/sw/search/classes_2.js b/sw/search/classes_2.js new file mode 100644 index 0000000000..bb9cfe19a3 --- /dev/null +++ b/sw/search/classes_2.js @@ -0,0 +1,22 @@ +var searchData= +[ + ['neorv32_5fcfs_5ft_0',['neorv32_cfs_t',['../structneorv32__cfs__t.html',1,'']]], + ['neorv32_5fcrc_5ft_1',['neorv32_crc_t',['../structneorv32__crc__t.html',1,'']]], + ['neorv32_5fdma_5ft_2',['neorv32_dma_t',['../structneorv32__dma__t.html',1,'']]], + ['neorv32_5fgpio_5ft_3',['neorv32_gpio_t',['../structneorv32__gpio__t.html',1,'']]], + ['neorv32_5fgptmr_5ft_4',['neorv32_gptmr_t',['../structneorv32__gptmr__t.html',1,'']]], + ['neorv32_5fmtime_5ft_5',['neorv32_mtime_t',['../structneorv32__mtime__t.html',1,'']]], + ['neorv32_5fneoled_5ft_6',['neorv32_neoled_t',['../structneorv32__neoled__t.html',1,'']]], + ['neorv32_5fonewire_5ft_7',['neorv32_onewire_t',['../structneorv32__onewire__t.html',1,'']]], + ['neorv32_5fpwm_5ft_8',['neorv32_pwm_t',['../structneorv32__pwm__t.html',1,'']]], + ['neorv32_5fsdi_5ft_9',['neorv32_sdi_t',['../structneorv32__sdi__t.html',1,'']]], + ['neorv32_5fslink_5ft_10',['neorv32_slink_t',['../structneorv32__slink__t.html',1,'']]], + ['neorv32_5fspi_5ft_11',['neorv32_spi_t',['../structneorv32__spi__t.html',1,'']]], + ['neorv32_5fsysinfo_5ft_12',['neorv32_sysinfo_t',['../structneorv32__sysinfo__t.html',1,'']]], + ['neorv32_5ftrng_5ft_13',['neorv32_trng_t',['../structneorv32__trng__t.html',1,'']]], + ['neorv32_5ftwi_5ft_14',['neorv32_twi_t',['../structneorv32__twi__t.html',1,'']]], + ['neorv32_5fuart_5ft_15',['neorv32_uart_t',['../structneorv32__uart__t.html',1,'']]], + ['neorv32_5fwdt_5ft_16',['neorv32_wdt_t',['../structneorv32__wdt__t.html',1,'']]], + ['neorv32_5fxip_5ft_17',['neorv32_xip_t',['../structneorv32__xip__t.html',1,'']]], + ['neorv32_5fxirq_5ft_18',['neorv32_xirq_t',['../structneorv32__xirq__t.html',1,'']]] +]; diff --git a/sw/search/classes_3.js b/sw/search/classes_3.js new file mode 100644 index 0000000000..6ef84e426d --- /dev/null +++ b/sw/search/classes_3.js @@ -0,0 +1,4 @@ +var searchData= +[ + ['record_0',['record',['../structrecord.html',1,'']]] +]; diff --git a/sw/search/classes_4.js b/sw/search/classes_4.js new file mode 100644 index 0000000000..8321706b36 --- /dev/null +++ b/sw/search/classes_4.js @@ -0,0 +1,6 @@ +var searchData= +[ + ['subwords16_5ft_0',['subwords16_t',['../unionsubwords16__t.html',1,'']]], + ['subwords32_5ft_1',['subwords32_t',['../unionsubwords32__t.html',1,'']]], + ['subwords64_5ft_2',['subwords64_t',['../unionsubwords64__t.html',1,'']]] +]; diff --git a/sw/search/classes_5.js b/sw/search/classes_5.js new file mode 100644 index 0000000000..1dc259cfb2 --- /dev/null +++ b/sw/search/classes_5.js @@ -0,0 +1,4 @@ +var searchData= +[ + ['t_5fneorv32_5fspi_0',['t_neorv32_spi',['../structt__neorv32__spi.html',1,'']]] +]; diff --git a/sw/search/close.svg b/sw/search/close.svg new file mode 100644 index 0000000000..337d6cc132 --- /dev/null +++ b/sw/search/close.svg @@ -0,0 +1,18 @@ +<?xml version="1.0" encoding="UTF-8" standalone="no"?> +<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" + "https://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd"> +<svg + xmlns="http://www.w3.org/2000/svg" + xmlns:xlink="http://www.w3.org/1999/xlink" + viewBox="0 0 11 11" + height="11" + width="11" + id="svg2" + version="1.1"> + <defs + id="defs6" /> + <path + id="path12" + d="M 5.5 0.5 A 5 5 0 0 0 0.5 5.5 A 5 5 0 0 0 5.5 10.5 A 5 5 0 0 0 10.5 5.5 A 5 5 0 0 0 5.5 0.5 z M 3.5820312 3 A 0.58291923 0.58291923 0 0 1 4 3.1757812 L 5.5 4.6757812 L 7 3.1757812 A 0.58291923 0.58291923 0 0 1 7.4003906 3 A 0.58291923 0.58291923 0 0 1 7.8242188 4 L 6.3242188 5.5 L 7.8242188 7 A 0.58291923 0.58291923 0 1 1 7 7.8242188 L 5.5 6.3242188 L 4 7.8242188 A 0.58291923 0.58291923 0 1 1 3.1757812 7 L 4.6757812 5.5 L 3.1757812 4 A 0.58291923 0.58291923 0 0 1 3.5820312 3 z " + style="stroke-width:1.09870648;fill:#bababa;fill-opacity:1" /> +</svg> diff --git a/sw/search/defines_0.js b/sw/search/defines_0.js new file mode 100644 index 0000000000..33ed6086d0 --- /dev/null +++ b/sw/search/defines_0.js @@ -0,0 +1,4 @@ +var searchData= +[ + ['auto_5fboot_5ftimeout_0',['AUTO_BOOT_TIMEOUT',['../bootloader_8c.html#af6fcb607a9c320da869b72aa30893a69',1,'bootloader.c']]] +]; diff --git a/sw/search/defines_1.js b/sw/search/defines_1.js new file mode 100644 index 0000000000..fd5d2ad6c3 --- /dev/null +++ b/sw/search/defines_1.js @@ -0,0 +1,6 @@ +var searchData= +[ + ['baud_5frate_0',['BAUD_RATE',['../atomic__test_2main_8c.html#ad4455691936f92fdd6c37566fc58ba1f',1,'BAUD_RATE:&#160;main.c'],['../bus__explorer_2main_8c.html#ad4455691936f92fdd6c37566fc58ba1f',1,'BAUD_RATE:&#160;main.c'],['../demo__cfs_2main_8c.html#ad4455691936f92fdd6c37566fc58ba1f',1,'BAUD_RATE:&#160;main.c'],['../demo__cfu_2main_8c.html#ad4455691936f92fdd6c37566fc58ba1f',1,'BAUD_RATE:&#160;main.c'],['../demo__crc_2main_8c.html#ad4455691936f92fdd6c37566fc58ba1f',1,'BAUD_RATE:&#160;main.c'],['../demo__dma_2main_8c.html#ad4455691936f92fdd6c37566fc58ba1f',1,'BAUD_RATE:&#160;main.c'],['../demo__emulate__unaligned_2main_8c.html#ad4455691936f92fdd6c37566fc58ba1f',1,'BAUD_RATE:&#160;main.c'],['../demo__gptmr_2main_8c.html#ad4455691936f92fdd6c37566fc58ba1f',1,'BAUD_RATE:&#160;main.c'],['../demo__hpm_2main_8c.html#ad4455691936f92fdd6c37566fc58ba1f',1,'BAUD_RATE:&#160;main.c'],['../demo__neopixel_2main_8c.html#ad4455691936f92fdd6c37566fc58ba1f',1,'BAUD_RATE:&#160;main.c'],['../demo__newlib_2main_8c.html#ad4455691936f92fdd6c37566fc58ba1f',1,'BAUD_RATE:&#160;main.c'],['../demo__onewire_2main_8c.html#ad4455691936f92fdd6c37566fc58ba1f',1,'BAUD_RATE:&#160;main.c'],['../demo__pwm_2main_8c.html#ad4455691936f92fdd6c37566fc58ba1f',1,'BAUD_RATE:&#160;main.c'],['../demo__sdi_2main_8c.html#ad4455691936f92fdd6c37566fc58ba1f',1,'BAUD_RATE:&#160;main.c'],['../demo__slink_2main_8c.html#ad4455691936f92fdd6c37566fc58ba1f',1,'BAUD_RATE:&#160;main.c'],['../demo__spi_2main_8c.html#ad4455691936f92fdd6c37566fc58ba1f',1,'BAUD_RATE:&#160;main.c'],['../demo__spi__irq_2main_8c.html#ad4455691936f92fdd6c37566fc58ba1f',1,'BAUD_RATE:&#160;main.c'],['../demo__trng_2main_8c.html#ad4455691936f92fdd6c37566fc58ba1f',1,'BAUD_RATE:&#160;main.c'],['../demo__twi_2main_8c.html#ad4455691936f92fdd6c37566fc58ba1f',1,'BAUD_RATE:&#160;main.c'],['../demo__wdt_2main_8c.html#ad4455691936f92fdd6c37566fc58ba1f',1,'BAUD_RATE:&#160;main.c'],['../demo__xip_2main_8c.html#ad4455691936f92fdd6c37566fc58ba1f',1,'BAUD_RATE:&#160;main.c'],['../demo__xirq_2main_8c.html#ad4455691936f92fdd6c37566fc58ba1f',1,'BAUD_RATE:&#160;main.c'],['../float__corner__test_2main_8c.html#ad4455691936f92fdd6c37566fc58ba1f',1,'BAUD_RATE:&#160;main.c'],['../floating__point__test_2main_8c.html#ad4455691936f92fdd6c37566fc58ba1f',1,'BAUD_RATE:&#160;main.c'],['../game__of__life_2main_8c.html#ad4455691936f92fdd6c37566fc58ba1f',1,'BAUD_RATE:&#160;main.c'],['../hello__world_2main_8c.html#ad4455691936f92fdd6c37566fc58ba1f',1,'BAUD_RATE:&#160;main.c']]], + ['bootloader_5fbase_5faddress_1',['BOOTLOADER_BASE_ADDRESS',['../neorv32_8h.html#abd8c9b7d79f49de1722611b2835cde58',1,'neorv32.h']]], + ['buffer_5fsize_2',['BUFFER_SIZE',['../demo__xip_2main_8c.html#a6b20d41d6252e9871430c242cb1a56e7',1,'main.c']]] +]; diff --git a/sw/search/defines_10.js b/sw/search/defines_10.js new file mode 100644 index 0000000000..b96b4efdea --- /dev/null +++ b/sw/search/defines_10.js @@ -0,0 +1,5 @@ +var searchData= +[ + ['wdt_5fpassword_0',['WDT_PASSWORD',['../neorv32__wdt_8h.html#af2a2bd9c74bdba1b46bd92025bd00ab6',1,'neorv32_wdt.h']]], + ['wdt_5ftimeout_5fs_1',['WDT_TIMEOUT_S',['../demo__wdt_2main_8c.html#a01af3905e60b1869f669315f4a1297f5',1,'main.c']]] +]; diff --git a/sw/search/defines_11.js b/sw/search/defines_11.js new file mode 100644 index 0000000000..c6258db8b7 --- /dev/null +++ b/sw/search/defines_11.js @@ -0,0 +1,16 @@ +var searchData= +[ + ['xip_5fclk_5fprsc_0',['XIP_CLK_PRSC',['../demo__xip_2main_8c.html#aec72efe062dbdb149ae6d4f8b1be6793',1,'main.c']]], + ['xip_5fen_1',['XIP_EN',['../bootloader_8c.html#a2cf31934b909299fb93bb5eebdbc7c9e',1,'bootloader.c']]], + ['xip_5fmem_5fbase_5faddress_2',['XIP_MEM_BASE_ADDRESS',['../neorv32_8h.html#aa01bea676e878a9e87ca10ce2d91e51f',1,'neorv32.h']]], + ['xirq_5ffirq_5fenable_3',['XIRQ_FIRQ_ENABLE',['../neorv32_8h.html#afe0cb262d517c7da73d6b5dc78886334',1,'neorv32.h']]], + ['xirq_5ffirq_5fpending_4',['XIRQ_FIRQ_PENDING',['../neorv32_8h.html#a866768963f8648363dce40de9f34d61b',1,'neorv32.h']]], + ['xirq_5frte_5fid_5',['XIRQ_RTE_ID',['../neorv32_8h.html#a95387d3482ec8e5c1d734805fdf64fa5',1,'neorv32.h']]], + ['xirq_5ftrap_5fcode_6',['XIRQ_TRAP_CODE',['../neorv32_8h.html#a16b9a7444833b5581df073661deb8f3a',1,'neorv32.h']]], + ['xirq_5ftrigger_5fedge_5ffalling_7',['XIRQ_TRIGGER_EDGE_FALLING',['../neorv32__xirq_8h.html#a59316ffc7ee1aacf1d55d460bdca4d04',1,'neorv32_xirq.h']]], + ['xirq_5ftrigger_5fedge_5frising_8',['XIRQ_TRIGGER_EDGE_RISING',['../neorv32__xirq_8h.html#ab7a05371e4dc3de3a9be11c59f5376ee',1,'neorv32_xirq.h']]], + ['xirq_5ftrigger_5flevel_5fhigh_9',['XIRQ_TRIGGER_LEVEL_HIGH',['../neorv32__xirq_8h.html#a9b10e89b2e257e1af410bff89f29911c',1,'neorv32_xirq.h']]], + ['xirq_5ftrigger_5flevel_5flow_10',['XIRQ_TRIGGER_LEVEL_LOW',['../neorv32__xirq_8h.html#a8bc89e6a47b4d0d95fb2afac4cdc9292',1,'neorv32_xirq.h']]], + ['xstr_11',['xstr',['../bootloader_8c.html#aff6b53dd58cea43d24393a9a2f79e772',1,'bootloader.c']]], + ['xtea_5fcycles_12',['XTEA_CYCLES',['../demo__cfu_2main_8c.html#a34755f457331741d24090b3819b5d416',1,'main.c']]] +]; diff --git a/sw/search/defines_2.js b/sw/search/defines_2.js new file mode 100644 index 0000000000..a05b8ec2f4 --- /dev/null +++ b/sw/search/defines_2.js @@ -0,0 +1,9 @@ +var searchData= +[ + ['cell_5falive_0',['CELL_ALIVE',['../game__of__life_2main_8c.html#afa6488273e16792d9c3da5e40e3f572d',1,'main.c']]], + ['cell_5fdead_1',['CELL_DEAD',['../game__of__life_2main_8c.html#abe6bebcf1cb4f5b4d522c1706eb48663',1,'main.c']]], + ['cfs_5ffirq_5fenable_2',['CFS_FIRQ_ENABLE',['../neorv32_8h.html#ace79ee46daf3a1b689d9fe79dfcd6627',1,'neorv32.h']]], + ['cfs_5ffirq_5fpending_3',['CFS_FIRQ_PENDING',['../neorv32_8h.html#aae182648a2c23d070b9db0295388e001',1,'neorv32.h']]], + ['cfs_5frte_5fid_4',['CFS_RTE_ID',['../neorv32_8h.html#a095f41fbefaa7acc1bfdd65cd3ce06ea',1,'neorv32.h']]], + ['cfs_5ftrap_5fcode_5',['CFS_TRAP_CODE',['../neorv32_8h.html#aae6b2ae3fba20ff80bfb59735f179c26',1,'neorv32.h']]] +]; diff --git a/sw/search/defines_3.js b/sw/search/defines_3.js new file mode 100644 index 0000000000..df151d2df5 --- /dev/null +++ b/sw/search/defines_3.js @@ -0,0 +1,18 @@ +var searchData= +[ + ['data_5fnum_0',['DATA_NUM',['../demo__cfu_2main_8c.html#ac637695e266f3af7799e352b374412ad',1,'main.c']]], + ['debug_5finfo_1',['DEBUG_INFO',['../demo__emulate__unaligned_2main_8c.html#a4407b4d6eae3ba7fe9538b1242a7e165',1,'main.c']]], + ['dma_5fcmd_5fb2b_2',['DMA_CMD_B2B',['../neorv32__dma_8h.html#a5e01d4454c97eb8e4ecd1455090bbfa9',1,'neorv32_dma.h']]], + ['dma_5fcmd_5fb2sw_3',['DMA_CMD_B2SW',['../neorv32__dma_8h.html#adfecb3debff251070e4f6eb809412129',1,'neorv32_dma.h']]], + ['dma_5fcmd_5fb2uw_4',['DMA_CMD_B2UW',['../neorv32__dma_8h.html#aeb63f99217f14d1ddde35c1f6c104e72',1,'neorv32_dma.h']]], + ['dma_5fcmd_5fdst_5fconst_5',['DMA_CMD_DST_CONST',['../neorv32__dma_8h.html#a6a0ce532aad39e6489e9d52bcb6f4cd2',1,'neorv32_dma.h']]], + ['dma_5fcmd_5fdst_5finc_6',['DMA_CMD_DST_INC',['../neorv32__dma_8h.html#a61caa2602c6b148af55d990e3c0ae6be',1,'neorv32_dma.h']]], + ['dma_5fcmd_5fendian_7',['DMA_CMD_ENDIAN',['../neorv32__dma_8h.html#a18fb7faa0a35f562821ca854d7c648b4',1,'neorv32_dma.h']]], + ['dma_5fcmd_5fsrc_5fconst_8',['DMA_CMD_SRC_CONST',['../neorv32__dma_8h.html#ae380022d8b8fb70da91f0892f2bc32c8',1,'neorv32_dma.h']]], + ['dma_5fcmd_5fsrc_5finc_9',['DMA_CMD_SRC_INC',['../neorv32__dma_8h.html#acc081d58b53d1eddd2bff35b128d7da2',1,'neorv32_dma.h']]], + ['dma_5fcmd_5fw2w_10',['DMA_CMD_W2W',['../neorv32__dma_8h.html#a13a16ba8d6daf9c82312bf4d392d15a8',1,'neorv32_dma.h']]], + ['dma_5ffirq_5fenable_11',['DMA_FIRQ_ENABLE',['../neorv32_8h.html#ace46f95dec73b33bf2535eb653bf8f65',1,'neorv32.h']]], + ['dma_5ffirq_5fpending_12',['DMA_FIRQ_PENDING',['../neorv32_8h.html#a1fa2b25383e6d05cf26f3517091ddbbf',1,'neorv32.h']]], + ['dma_5frte_5fid_13',['DMA_RTE_ID',['../neorv32_8h.html#a568b54ba7dfdae736d8d685dc4d32113',1,'neorv32.h']]], + ['dma_5ftrap_5fcode_14',['DMA_TRAP_CODE',['../neorv32_8h.html#ad2e81443af8a4ce2db3a4e3c1a8fb784',1,'neorv32.h']]] +]; diff --git a/sw/search/defines_4.js b/sw/search/defines_4.js new file mode 100644 index 0000000000..d208589ed0 --- /dev/null +++ b/sw/search/defines_4.js @@ -0,0 +1,5 @@ +var searchData= +[ + ['exe_5fbase_5faddr_0',['EXE_BASE_ADDR',['../bootloader_8c.html#a18936dc79b9e5aa84df016b046a6b977',1,'bootloader.c']]], + ['exe_5fsignature_1',['EXE_SIGNATURE',['../bootloader_8c.html#a0035ad41f622dbfc2412318a8ed39257',1,'EXE_SIGNATURE:&#160;bootloader.c'],['../demo__xip_2main_8c.html#a0035ad41f622dbfc2412318a8ed39257',1,'EXE_SIGNATURE:&#160;main.c']]] +]; diff --git a/sw/search/defines_5.js b/sw/search/defines_5.js new file mode 100644 index 0000000000..c614565b25 --- /dev/null +++ b/sw/search/defines_5.js @@ -0,0 +1,5 @@ +var searchData= +[ + ['flash_5fabytes_0',['FLASH_ABYTES',['../demo__xip_2main_8c.html#af9b3c37c806499fc435302f5bce6a122',1,'main.c']]], + ['flash_5fbase_1',['FLASH_BASE',['../demo__xip_2main_8c.html#a23a9099a5f8fc9c6e253c0eecb2be8db',1,'main.c']]] +]; diff --git a/sw/search/defines_6.js b/sw/search/defines_6.js new file mode 100644 index 0000000000..59cec1265e --- /dev/null +++ b/sw/search/defines_6.js @@ -0,0 +1,8 @@ +var searchData= +[ + ['gen_5fdelay_0',['GEN_DELAY',['../game__of__life_2main_8c.html#a3f33bf77abbf35c245956489f8f7e3a7',1,'main.c']]], + ['gptmr_5ffirq_5fenable_1',['GPTMR_FIRQ_ENABLE',['../neorv32_8h.html#a0a59186908b498cb92273b7767966e26',1,'neorv32.h']]], + ['gptmr_5ffirq_5fpending_2',['GPTMR_FIRQ_PENDING',['../neorv32_8h.html#a4a3164d123ddddd07750f868e67d82d8',1,'neorv32.h']]], + ['gptmr_5frte_5fid_3',['GPTMR_RTE_ID',['../neorv32_8h.html#aac38deeef36de0a474ab238a3054f860',1,'neorv32.h']]], + ['gptmr_5ftrap_5fcode_4',['GPTMR_TRAP_CODE',['../neorv32_8h.html#a445543c36d1f78477aa8ea4841c720a1',1,'neorv32.h']]] +]; diff --git a/sw/search/defines_7.js b/sw/search/defines_7.js new file mode 100644 index 0000000000..d6cd67517a --- /dev/null +++ b/sw/search/defines_7.js @@ -0,0 +1,4 @@ +var searchData= +[ + ['io_5fbase_5faddress_0',['IO_BASE_ADDRESS',['../neorv32_8h.html#a1eb0cb7fed7e154e15cb4009880a879c',1,'neorv32.h']]] +]; diff --git a/sw/search/defines_8.js b/sw/search/defines_8.js new file mode 100644 index 0000000000..d735f4ec41 --- /dev/null +++ b/sw/search/defines_8.js @@ -0,0 +1,4 @@ +var searchData= +[ + ['max_5fintensity_0',['MAX_INTENSITY',['../demo__neopixel_2main_8c.html#a1d1d5e7ff16f25b68fdf779befd298f7',1,'main.c']]] +]; diff --git a/sw/search/defines_9.js b/sw/search/defines_9.js new file mode 100644 index 0000000000..1cbdbd02d0 --- /dev/null +++ b/sw/search/defines_9.js @@ -0,0 +1,56 @@ +var searchData= +[ + ['neoled_5ffirq_5fenable_0',['NEOLED_FIRQ_ENABLE',['../neorv32_8h.html#a8d0409818600c0b2acfe8253e8f027b8',1,'neorv32.h']]], + ['neoled_5ffirq_5fpending_1',['NEOLED_FIRQ_PENDING',['../neorv32_8h.html#aded7d7f5f4ba3a6d90f9a29e62a8cfab',1,'neorv32.h']]], + ['neoled_5frte_5fid_2',['NEOLED_RTE_ID',['../neorv32_8h.html#aca6cfc3f580c4dfe1e213009ee450c58',1,'neorv32.h']]], + ['neoled_5ftrap_5fcode_3',['NEOLED_TRAP_CODE',['../neorv32_8h.html#ab4a2ac455d7426992de6877ea7325f21',1,'neorv32.h']]], + ['neorv32_5fcfs_4',['NEORV32_CFS',['../neorv32__cfs_8h.html#a6c101b306bd096f78d351e39b308d3e2',1,'neorv32_cfs.h']]], + ['neorv32_5fcfs_5fbase_5',['NEORV32_CFS_BASE',['../neorv32_8h.html#a41d6f97daef61641da96b9f72f6b272f',1,'neorv32.h']]], + ['neorv32_5fcfu_5fr3_5finstr_6',['neorv32_cfu_r3_instr',['../neorv32__cpu__cfu_8h.html#a69d60ccd0cee950b08ce585c3f13b85c',1,'neorv32_cpu_cfu.h']]], + ['neorv32_5fcfu_5fr4_5finstr_7',['neorv32_cfu_r4_instr',['../neorv32__cpu__cfu_8h.html#a046a640f7f4a7b1b99a824fb325e2079',1,'neorv32_cpu_cfu.h']]], + ['neorv32_5fcfu_5fr5_5finstr_5fa_8',['neorv32_cfu_r5_instr_a',['../neorv32__cpu__cfu_8h.html#a65198d9caf04a5cd3a72accc2cecf870',1,'neorv32_cpu_cfu.h']]], + ['neorv32_5fcfu_5fr5_5finstr_5fb_9',['neorv32_cfu_r5_instr_b',['../neorv32__cpu__cfu_8h.html#ab3affefbff898567c6c02c4d10765b04',1,'neorv32_cpu_cfu.h']]], + ['neorv32_5fcrc_10',['NEORV32_CRC',['../neorv32__crc_8h.html#a110962d2b370f9d7997e459d9fd34271',1,'neorv32_crc.h']]], + ['neorv32_5fcrc_5fbase_11',['NEORV32_CRC_BASE',['../neorv32_8h.html#a0e2377055bdc0f416b5ae4385610600d',1,'neorv32.h']]], + ['neorv32_5fdm_5fbase_12',['NEORV32_DM_BASE',['../neorv32_8h.html#a9bf0149681677f7d87abf8f62e2d9a3d',1,'neorv32.h']]], + ['neorv32_5fdma_13',['NEORV32_DMA',['../neorv32__dma_8h.html#a0dcb61a0e0d2b45beb7818015adc8639',1,'neorv32_dma.h']]], + ['neorv32_5fdma_5fbase_14',['NEORV32_DMA_BASE',['../neorv32_8h.html#aa8d3a83ffad1e71f0832a5da78d62008',1,'neorv32.h']]], + ['neorv32_5fgpio_15',['NEORV32_GPIO',['../neorv32__gpio_8h.html#a1e35bbf26b9d1aa5373af0b9468eb445',1,'neorv32_gpio.h']]], + ['neorv32_5fgpio_5fbase_16',['NEORV32_GPIO_BASE',['../neorv32_8h.html#a7fd1e24d4de2eed7bf9cd5391562c7f4',1,'neorv32.h']]], + ['neorv32_5fgptmr_17',['NEORV32_GPTMR',['../neorv32__gptmr_8h.html#a9e047791588ff21fc4dc1b06456bdfd2',1,'neorv32_gptmr.h']]], + ['neorv32_5fgptmr_5fbase_18',['NEORV32_GPTMR_BASE',['../neorv32_8h.html#a0991b1a5ba1e8c3550eb9770d43589d0',1,'neorv32.h']]], + ['neorv32_5fmtime_19',['NEORV32_MTIME',['../neorv32__mtime_8h.html#a68935be182e0081039326a9f344a36b3',1,'neorv32_mtime.h']]], + ['neorv32_5fmtime_5fbase_20',['NEORV32_MTIME_BASE',['../neorv32_8h.html#ab98f762df259a2bbc28d19d2acfe9e23',1,'neorv32.h']]], + ['neorv32_5fneoled_21',['NEORV32_NEOLED',['../neorv32__neoled_8h.html#a3ccc1097bc70f92235d693b612fa994a',1,'neorv32_neoled.h']]], + ['neorv32_5fneoled_5fbase_22',['NEORV32_NEOLED_BASE',['../neorv32_8h.html#a559fdce92e8af5efc426c8fc48d14f99',1,'neorv32.h']]], + ['neorv32_5fonewire_23',['NEORV32_ONEWIRE',['../neorv32__onewire_8h.html#a6f119e35d7ac01f110987508ff3becc9',1,'neorv32_onewire.h']]], + ['neorv32_5fonewire_5fbase_24',['NEORV32_ONEWIRE_BASE',['../neorv32_8h.html#a8d0b612e52b77395a05d4f18af6fcf00',1,'neorv32.h']]], + ['neorv32_5fpwm_25',['NEORV32_PWM',['../neorv32__pwm_8h.html#ad4cb534c29e26fa56c10bef7afab8f51',1,'neorv32_pwm.h']]], + ['neorv32_5fpwm_5fbase_26',['NEORV32_PWM_BASE',['../neorv32_8h.html#afef7a6b121a788560b29e2ee2a58c725',1,'neorv32.h']]], + ['neorv32_5frte_5fnum_5ftraps_27',['NEORV32_RTE_NUM_TRAPS',['../neorv32__rte_8h.html#ad14a1ca41df1e9300bfd01aef07dce59',1,'neorv32_rte.h']]], + ['neorv32_5fsdi_28',['NEORV32_SDI',['../neorv32__sdi_8h.html#afd0921633d6523d9b7235055e9bbf928',1,'neorv32_sdi.h']]], + ['neorv32_5fsdi_5fbase_29',['NEORV32_SDI_BASE',['../neorv32_8h.html#a9b316ec038bd94ada42c9dab57a0a3cb',1,'neorv32.h']]], + ['neorv32_5fslink_30',['NEORV32_SLINK',['../neorv32__slink_8h.html#a6380d894432de119a20993096db534df',1,'neorv32_slink.h']]], + ['neorv32_5fslink_5fbase_31',['NEORV32_SLINK_BASE',['../neorv32_8h.html#ab5e6dc57886cd5ed98b86f22fc37d7cc',1,'neorv32.h']]], + ['neorv32_5fspi_32',['NEORV32_SPI',['../neorv32__spi_8h.html#a5f3afc4e268670c54d90df67fa38ca22',1,'neorv32_spi.h']]], + ['neorv32_5fspi_5fbase_33',['NEORV32_SPI_BASE',['../neorv32_8h.html#aa466dc5eace7351bd438606f0f7475a7',1,'neorv32.h']]], + ['neorv32_5fsysinfo_5fbase_34',['NEORV32_SYSINFO_BASE',['../neorv32_8h.html#a5aa936f38782232c7ed3eab1283ee536',1,'neorv32.h']]], + ['neorv32_5ftrng_35',['NEORV32_TRNG',['../neorv32__trng_8h.html#a9794ff3746eb5321ad9c2bf522ea26dd',1,'neorv32_trng.h']]], + ['neorv32_5ftrng_5fbase_36',['NEORV32_TRNG_BASE',['../neorv32_8h.html#ab4846cd153e8a23deec45d81cc8372a2',1,'neorv32.h']]], + ['neorv32_5ftwi_37',['NEORV32_TWI',['../neorv32__twi_8h.html#a2769c2fe5e0de01b12fe4a5fad029768',1,'neorv32_twi.h']]], + ['neorv32_5ftwi_5fbase_38',['NEORV32_TWI_BASE',['../neorv32_8h.html#a4a741408a4bb0938e03b99555306db9c',1,'neorv32.h']]], + ['neorv32_5fuart0_39',['NEORV32_UART0',['../neorv32__uart_8h.html#a4c880a6b27e46f459e750425258b1bdb',1,'neorv32_uart.h']]], + ['neorv32_5fuart0_5fbase_40',['NEORV32_UART0_BASE',['../neorv32_8h.html#a000b37f710043fe21e49b2fdbc039d94',1,'neorv32.h']]], + ['neorv32_5fuart1_41',['NEORV32_UART1',['../neorv32__uart_8h.html#aa2a9ded4523f001bf69935c80247fa2d',1,'neorv32_uart.h']]], + ['neorv32_5fuart1_5fbase_42',['NEORV32_UART1_BASE',['../neorv32_8h.html#a26a1defe18ce222b8b4ed1c760344700',1,'neorv32.h']]], + ['neorv32_5fwdt_43',['NEORV32_WDT',['../neorv32__wdt_8h.html#a78615b08cd799063011606d084fef46c',1,'neorv32_wdt.h']]], + ['neorv32_5fwdt_5fbase_44',['NEORV32_WDT_BASE',['../neorv32_8h.html#a3012986cdd5748ee96bcc74cd7108dea',1,'neorv32.h']]], + ['neorv32_5fxip_45',['NEORV32_XIP',['../neorv32__xip_8h.html#a3d6f138a347c16883b51069428eb7c1e',1,'neorv32_xip.h']]], + ['neorv32_5fxip_5fbase_46',['NEORV32_XIP_BASE',['../neorv32_8h.html#ae0978315beac8399f96f520bda81c7fe',1,'neorv32.h']]], + ['neorv32_5fxirq_47',['NEORV32_XIRQ',['../neorv32__xirq_8h.html#a0c0886139e9837867202e5f6a83307c4',1,'neorv32_xirq.h']]], + ['neorv32_5fxirq_5fbase_48',['NEORV32_XIRQ_BASE',['../neorv32_8h.html#a942a897be2d4ae6820bee0f7bb3a0ff1',1,'neorv32.h']]], + ['num_5fcells_5fx_49',['NUM_CELLS_X',['../game__of__life_2main_8c.html#a78c5b500f0f057bcaedf6fedeca7c537',1,'main.c']]], + ['num_5fcells_5fy_50',['NUM_CELLS_Y',['../game__of__life_2main_8c.html#aed77778557404b38bebb05b5830368b4',1,'main.c']]], + ['num_5fleds_5f24bit_51',['NUM_LEDS_24BIT',['../demo__neopixel_2main_8c.html#aa1dddb8d6b3b4d2f19afc3c09e2ff572',1,'main.c']]], + ['num_5ftest_5fcases_52',['NUM_TEST_CASES',['../atomic__test_2main_8c.html#a83792c34853f1d2801b59ad46adc7e1e',1,'NUM_TEST_CASES:&#160;main.c'],['../float__corner__test_2main_8c.html#a83792c34853f1d2801b59ad46adc7e1e',1,'NUM_TEST_CASES:&#160;main.c'],['../floating__point__test_2main_8c.html#a83792c34853f1d2801b59ad46adc7e1e',1,'NUM_TEST_CASES:&#160;main.c']]] +]; diff --git a/sw/search/defines_a.js b/sw/search/defines_a.js new file mode 100644 index 0000000000..26b4983d3e --- /dev/null +++ b/sw/search/defines_a.js @@ -0,0 +1,7 @@ +var searchData= +[ + ['onewire_5ffirq_5fenable_0',['ONEWIRE_FIRQ_ENABLE',['../neorv32_8h.html#a8bb1918679e32e898af2d485cfa44afb',1,'neorv32.h']]], + ['onewire_5ffirq_5fpending_1',['ONEWIRE_FIRQ_PENDING',['../neorv32_8h.html#a3853ef999f99ca062e6025038811d0f0',1,'neorv32.h']]], + ['onewire_5frte_5fid_2',['ONEWIRE_RTE_ID',['../neorv32_8h.html#a142f4a1c754edfab292706618d427b94',1,'neorv32.h']]], + ['onewire_5ftrap_5fcode_3',['ONEWIRE_TRAP_CODE',['../neorv32_8h.html#a3e7aaa405a7d1fcd71a36c4b6b5a4081',1,'neorv32.h']]] +]; diff --git a/sw/search/defines_b.js b/sw/search/defines_b.js new file mode 100644 index 0000000000..1dc0612091 --- /dev/null +++ b/sw/search/defines_b.js @@ -0,0 +1,8 @@ +var searchData= +[ + ['print_5fgetc_0',['PRINT_GETC',['../bootloader_8c.html#a999b04603115ce08b0cb33e333312480',1,'bootloader.c']]], + ['print_5fputc_1',['PRINT_PUTC',['../bootloader_8c.html#aa7afbe8348ebd1a876a4d247553292e9',1,'bootloader.c']]], + ['print_5ftext_2',['PRINT_TEXT',['../bootloader_8c.html#a0e5a66f68ecc7a6f42088f349707e852',1,'bootloader.c']]], + ['print_5fxnum_3',['PRINT_XNUM',['../bootloader_8c.html#a2f5cc04cf9c85f5d2958b384e053053b',1,'bootloader.c']]], + ['pwm_5fmax_4',['PWM_MAX',['../demo__pwm_2main_8c.html#a391fa1e490bd712720989b58fa0d9904',1,'main.c']]] +]; diff --git a/sw/search/defines_c.js b/sw/search/defines_c.js new file mode 100644 index 0000000000..b9ad18f545 --- /dev/null +++ b/sw/search/defines_c.js @@ -0,0 +1,14 @@ +var searchData= +[ + ['run_5faddsub_5ftests_0',['RUN_ADDSUB_TESTS',['../float__corner__test_2main_8c.html#a2d16b9e484b7af7897c7ae83f945ceca',1,'RUN_ADDSUB_TESTS:&#160;main.c'],['../floating__point__test_2main_8c.html#a2d16b9e484b7af7897c7ae83f945ceca',1,'RUN_ADDSUB_TESTS:&#160;main.c']]], + ['run_5fclassify_5ftests_1',['RUN_CLASSIFY_TESTS',['../float__corner__test_2main_8c.html#a7e134923925fa24fd1090281c3a416c3',1,'RUN_CLASSIFY_TESTS:&#160;main.c'],['../floating__point__test_2main_8c.html#a7e134923925fa24fd1090281c3a416c3',1,'RUN_CLASSIFY_TESTS:&#160;main.c']]], + ['run_5fcompare_5ftests_2',['RUN_COMPARE_TESTS',['../float__corner__test_2main_8c.html#a4ee0f6d28896a97d2c0cad866e77b874',1,'RUN_COMPARE_TESTS:&#160;main.c'],['../floating__point__test_2main_8c.html#a4ee0f6d28896a97d2c0cad866e77b874',1,'RUN_COMPARE_TESTS:&#160;main.c']]], + ['run_5fconv_5ftests_3',['RUN_CONV_TESTS',['../float__corner__test_2main_8c.html#aa3b6c4d49be7372de9e771a0475306ac',1,'RUN_CONV_TESTS:&#160;main.c'],['../floating__point__test_2main_8c.html#aa3b6c4d49be7372de9e771a0475306ac',1,'RUN_CONV_TESTS:&#160;main.c']]], + ['run_5fcsr_5ftests_4',['RUN_CSR_TESTS',['../floating__point__test_2main_8c.html#a7ec330b668b5b24d666d7769ccecfee3',1,'main.c']]], + ['run_5fexc_5ftests_5',['RUN_EXC_TESTS',['../floating__point__test_2main_8c.html#a1a1af220e72c69b03d13b2df53650e10',1,'main.c']]], + ['run_5fminmax_5ftests_6',['RUN_MINMAX_TESTS',['../float__corner__test_2main_8c.html#aed386f612417aeeeac8b08db27d515e4',1,'RUN_MINMAX_TESTS:&#160;main.c'],['../floating__point__test_2main_8c.html#aed386f612417aeeeac8b08db27d515e4',1,'RUN_MINMAX_TESTS:&#160;main.c']]], + ['run_5fmul_5ftests_7',['RUN_MUL_TESTS',['../float__corner__test_2main_8c.html#a97323ecaf1ae85e68a736b06bc3b58f8',1,'RUN_MUL_TESTS:&#160;main.c'],['../floating__point__test_2main_8c.html#a97323ecaf1ae85e68a736b06bc3b58f8',1,'RUN_MUL_TESTS:&#160;main.c']]], + ['run_5fsgninj_5ftests_8',['RUN_SGNINJ_TESTS',['../float__corner__test_2main_8c.html#a94f0b0908f48f383145ed61ef8eb0713',1,'RUN_SGNINJ_TESTS:&#160;main.c'],['../floating__point__test_2main_8c.html#a94f0b0908f48f383145ed61ef8eb0713',1,'RUN_SGNINJ_TESTS:&#160;main.c']]], + ['run_5ftiming_5ftests_9',['RUN_TIMING_TESTS',['../float__corner__test_2main_8c.html#a6969308bd3633928893a2666f1df66fc',1,'RUN_TIMING_TESTS:&#160;main.c'],['../floating__point__test_2main_8c.html#a6969308bd3633928893a2666f1df66fc',1,'RUN_TIMING_TESTS:&#160;main.c']]], + ['run_5funavail_5ftests_10',['RUN_UNAVAIL_TESTS',['../float__corner__test_2main_8c.html#a923de9c3e55322d85522740c0d0ff867',1,'RUN_UNAVAIL_TESTS:&#160;main.c'],['../floating__point__test_2main_8c.html#a923de9c3e55322d85522740c0d0ff867',1,'RUN_UNAVAIL_TESTS:&#160;main.c']]] +]; diff --git a/sw/search/defines_d.js b/sw/search/defines_d.js new file mode 100644 index 0000000000..d459ef152a --- /dev/null +++ b/sw/search/defines_d.js @@ -0,0 +1,29 @@ +var searchData= +[ + ['sdi_5ffirq_5fenable_0',['SDI_FIRQ_ENABLE',['../neorv32_8h.html#a30cf20b6d704c50cc5c46238bb43646f',1,'neorv32.h']]], + ['sdi_5ffirq_5fpending_1',['SDI_FIRQ_PENDING',['../neorv32_8h.html#a68611c0dfbe331739eff10230ac3fede',1,'neorv32.h']]], + ['sdi_5frte_5fid_2',['SDI_RTE_ID',['../neorv32_8h.html#aa0ff72ea560d7e1462787dc31bd467cf',1,'neorv32.h']]], + ['sdi_5ftrap_5fcode_3',['SDI_TRAP_CODE',['../neorv32_8h.html#a68925ca3f482f148caedd36118fd8d79',1,'neorv32.h']]], + ['silent_5fmode_4',['SILENT_MODE',['../atomic__test_2main_8c.html#a87f296d7594bb8178cf76f0c045b7013',1,'SILENT_MODE:&#160;main.c'],['../float__corner__test_2main_8c.html#a87f296d7594bb8178cf76f0c045b7013',1,'SILENT_MODE:&#160;main.c'],['../floating__point__test_2main_8c.html#a87f296d7594bb8178cf76f0c045b7013',1,'SILENT_MODE:&#160;main.c']]], + ['slink_5frx_5ffirq_5fenable_5',['SLINK_RX_FIRQ_ENABLE',['../neorv32_8h.html#a8680ab1f14e512f21913572b35cbbf77',1,'neorv32.h']]], + ['slink_5frx_5ffirq_5fpending_6',['SLINK_RX_FIRQ_PENDING',['../neorv32_8h.html#a5c48d5c4effb47cdb019aa2da7c84526',1,'neorv32.h']]], + ['slink_5frx_5frte_5fid_7',['SLINK_RX_RTE_ID',['../neorv32_8h.html#a4fff18e72d10377cdcb8d2ac0a617a5d',1,'neorv32.h']]], + ['slink_5frx_5ftrap_5fcode_8',['SLINK_RX_TRAP_CODE',['../neorv32_8h.html#ab1fdaedb2c4c8753ef3be87c82568dda',1,'neorv32.h']]], + ['slink_5ftx_5ffirq_5fenable_9',['SLINK_TX_FIRQ_ENABLE',['../neorv32_8h.html#a232fe0eb5665373b6e2b464bdc228df2',1,'neorv32.h']]], + ['slink_5ftx_5ffirq_5fpending_10',['SLINK_TX_FIRQ_PENDING',['../neorv32_8h.html#ac8e98b2af75c8e31f9815dee3dcbaf8e',1,'neorv32.h']]], + ['slink_5ftx_5frte_5fid_11',['SLINK_TX_RTE_ID',['../neorv32_8h.html#a4e039d13b8d3f20453e1bb6b40512e43',1,'neorv32.h']]], + ['slink_5ftx_5ftrap_5fcode_12',['SLINK_TX_TRAP_CODE',['../neorv32_8h.html#a7fbe28901775e284d5700086f0b0bfcd',1,'neorv32.h']]], + ['spi_5fboot_5fbase_5faddr_13',['SPI_BOOT_BASE_ADDR',['../bootloader_8c.html#a418adcf57119600c3580fd2297d28de0',1,'bootloader.c']]], + ['spi_5fen_14',['SPI_EN',['../bootloader_8c.html#aea75cf0485ce0a4ea320eba994859686',1,'bootloader.c']]], + ['spi_5ffirq_5fenable_15',['SPI_FIRQ_ENABLE',['../neorv32_8h.html#ab8fcd3f80c373eb0f9d0fc6bf64ca626',1,'neorv32.h']]], + ['spi_5ffirq_5fpending_16',['SPI_FIRQ_PENDING',['../neorv32_8h.html#ab2f58f746febb29a9828447c733f8043',1,'neorv32.h']]], + ['spi_5fflash_5faddr_5fbytes_17',['SPI_FLASH_ADDR_BYTES',['../bootloader_8c.html#afe60a31c8561952f2f734fd67e6f7406',1,'bootloader.c']]], + ['spi_5fflash_5fclk_5fprsc_18',['SPI_FLASH_CLK_PRSC',['../bootloader_8c.html#a709071a651213770b4efe6e6e055ec3d',1,'bootloader.c']]], + ['spi_5fflash_5fcs_19',['SPI_FLASH_CS',['../bootloader_8c.html#aa2132454aada86216009f3af206899b1',1,'bootloader.c']]], + ['spi_5fflash_5fsector_5fsize_20',['SPI_FLASH_SECTOR_SIZE',['../bootloader_8c.html#a00924a8ba223b2ca0e7031259b292c84',1,'bootloader.c']]], + ['spi_5frte_5fid_21',['SPI_RTE_ID',['../neorv32_8h.html#a4c1cd9ec9f80da2080e5d0d35cc524dd',1,'neorv32.h']]], + ['spi_5ftrap_5fcode_22',['SPI_TRAP_CODE',['../neorv32_8h.html#a83c212f1f5d8ee2a5921b3b2b19e9cc4',1,'neorv32.h']]], + ['status_5fled_5fen_23',['STATUS_LED_EN',['../bootloader_8c.html#aa9696325b450773c7a87c991abca3a54',1,'bootloader.c']]], + ['status_5fled_5fpin_24',['STATUS_LED_PIN',['../bootloader_8c.html#a089a71f836911c71b3f73fdd3b4b890b',1,'bootloader.c']]], + ['str_25',['str',['../bootloader_8c.html#af6cf19e40e97afb5a7c29f7b439d091d',1,'bootloader.c']]] +]; diff --git a/sw/search/defines_e.js b/sw/search/defines_e.js new file mode 100644 index 0000000000..a054ee04ad --- /dev/null +++ b/sw/search/defines_e.js @@ -0,0 +1,12 @@ +var searchData= +[ + ['testcases_0',['TESTCASES',['../demo__cfs_2main_8c.html#a906949f076e3e0d0082af3c3b1acb518',1,'main.c']]], + ['trng_5ffirq_5fenable_1',['TRNG_FIRQ_ENABLE',['../neorv32_8h.html#a2896d832852c016eb85210b523642f11',1,'neorv32.h']]], + ['trng_5ffirq_5fpending_2',['TRNG_FIRQ_PENDING',['../neorv32_8h.html#a9c387ca4e2736a27056c11819947c84a',1,'neorv32.h']]], + ['trng_5frte_5fid_3',['TRNG_RTE_ID',['../neorv32_8h.html#afaa705a674acf3fd6c8cb294eaf11c5e',1,'neorv32.h']]], + ['trng_5ftrap_5fcode_4',['TRNG_TRAP_CODE',['../neorv32_8h.html#a11e34802c61a01fd6cba46e3f92d5ac1',1,'neorv32.h']]], + ['twi_5ffirq_5fenable_5',['TWI_FIRQ_ENABLE',['../neorv32_8h.html#a0913144fce247e24ccd0f178b9ac32b7',1,'neorv32.h']]], + ['twi_5ffirq_5fpending_6',['TWI_FIRQ_PENDING',['../neorv32_8h.html#a48b80113ca718fbdc50d75e1ec96a1ff',1,'neorv32.h']]], + ['twi_5frte_5fid_7',['TWI_RTE_ID',['../neorv32_8h.html#a1ac29f2f7bace5ba92b2b68a4541a60c',1,'neorv32.h']]], + ['twi_5ftrap_5fcode_8',['TWI_TRAP_CODE',['../neorv32_8h.html#a0afc1a759116d4d73a199ef769bced47',1,'neorv32.h']]] +]; diff --git a/sw/search/defines_f.js b/sw/search/defines_f.js new file mode 100644 index 0000000000..05bac95a4d --- /dev/null +++ b/sw/search/defines_f.js @@ -0,0 +1,22 @@ +var searchData= +[ + ['uart0_5frx_5ffirq_5fenable_0',['UART0_RX_FIRQ_ENABLE',['../neorv32_8h.html#a6b55ce6abe6b141000a6bb00949169e9',1,'neorv32.h']]], + ['uart0_5frx_5ffirq_5fpending_1',['UART0_RX_FIRQ_PENDING',['../neorv32_8h.html#a0b738b26abb2b951f1f5c5d9525d7701',1,'neorv32.h']]], + ['uart0_5frx_5frte_5fid_2',['UART0_RX_RTE_ID',['../neorv32_8h.html#ae8588cca20d5e36f74c5207c376389a1',1,'neorv32.h']]], + ['uart0_5frx_5ftrap_5fcode_3',['UART0_RX_TRAP_CODE',['../neorv32_8h.html#a7a849638eff31f2e1955bdc53d4fc84d',1,'neorv32.h']]], + ['uart0_5ftx_5ffirq_5fenable_4',['UART0_TX_FIRQ_ENABLE',['../neorv32_8h.html#aff756a395771f22c5f412f23f177ea7d',1,'neorv32.h']]], + ['uart0_5ftx_5ffirq_5fpending_5',['UART0_TX_FIRQ_PENDING',['../neorv32_8h.html#addbe29166bb77bc045ad0e3db68e57e9',1,'neorv32.h']]], + ['uart0_5ftx_5frte_5fid_6',['UART0_TX_RTE_ID',['../neorv32_8h.html#a9dc37695ca169bc0eb93898e7aeeee58',1,'neorv32.h']]], + ['uart0_5ftx_5ftrap_5fcode_7',['UART0_TX_TRAP_CODE',['../neorv32_8h.html#ab50df423fdba86bb83bc5d90a4c3bb20',1,'neorv32.h']]], + ['uart1_5frx_5ffirq_5fenable_8',['UART1_RX_FIRQ_ENABLE',['../neorv32_8h.html#a6c118c1784d8446360b00cde97437ca7',1,'neorv32.h']]], + ['uart1_5frx_5ffirq_5fpending_9',['UART1_RX_FIRQ_PENDING',['../neorv32_8h.html#a2e70d3a4e2973d224643813fcf315a20',1,'neorv32.h']]], + ['uart1_5frx_5frte_5fid_10',['UART1_RX_RTE_ID',['../neorv32_8h.html#ab1c351f5ea19ac9ea864155be9cc0b4b',1,'neorv32.h']]], + ['uart1_5frx_5ftrap_5fcode_11',['UART1_RX_TRAP_CODE',['../neorv32_8h.html#ad0b9eb2ee1f411d7fccdf4fe263214e1',1,'neorv32.h']]], + ['uart1_5ftx_5ffirq_5fenable_12',['UART1_TX_FIRQ_ENABLE',['../neorv32_8h.html#a0039bae3454a22e71d64e70d674f5d6a',1,'neorv32.h']]], + ['uart1_5ftx_5ffirq_5fpending_13',['UART1_TX_FIRQ_PENDING',['../neorv32_8h.html#ac4060532b7aa390623f54720460a2680',1,'neorv32.h']]], + ['uart1_5ftx_5frte_5fid_14',['UART1_TX_RTE_ID',['../neorv32_8h.html#a6af270d7ae8b1cde30e44eb9142491d3',1,'neorv32.h']]], + ['uart1_5ftx_5ftrap_5fcode_15',['UART1_TX_TRAP_CODE',['../neorv32_8h.html#a4cc50287c7a53982761a8116396ff7dd',1,'neorv32.h']]], + ['uart_5fbaud_16',['UART_BAUD',['../bootloader_8c.html#a1fac9153314479ad0ad495d752f0224a',1,'bootloader.c']]], + ['uart_5fen_17',['UART_EN',['../bootloader_8c.html#af1c2f103ac6e3183f08b39099fab2be9',1,'bootloader.c']]], + ['uart_5fhw_5fhandshake_5fen_18',['UART_HW_HANDSHAKE_EN',['../bootloader_8c.html#a20e93d623ce07939c3fdd53898f9d583',1,'bootloader.c']]] +]; diff --git a/sw/search/enums_0.js b/sw/search/enums_0.js new file mode 100644 index 0000000000..2e35050ee5 --- /dev/null +++ b/sw/search/enums_0.js @@ -0,0 +1,5 @@ +var searchData= +[ + ['error_5fcodes_5fenum_0',['ERROR_CODES_enum',['../bootloader_8c.html#aa0c639898508ff8e4fab6290101f3088',1,'bootloader.c']]], + ['exe_5fstream_5fsource_5fenum_1',['EXE_STREAM_SOURCE_enum',['../bootloader_8c.html#abcbf77626fdd0b475d245f836eab7a83',1,'bootloader.c']]] +]; diff --git a/sw/search/enums_1.js b/sw/search/enums_1.js new file mode 100644 index 0000000000..a97d9537a4 --- /dev/null +++ b/sw/search/enums_1.js @@ -0,0 +1,41 @@ +var searchData= +[ + ['neorv32_5fclock_5fprsc_5fenum_0',['NEORV32_CLOCK_PRSC_enum',['../neorv32_8h.html#a10022df4c223533b04d5aebe222e8b73',1,'neorv32.h']]], + ['neorv32_5fcrc_5fmode_5fenum_1',['NEORV32_CRC_MODE_enum',['../neorv32__crc_8h.html#a1ae84a58f475bafc2fc3f2c690fd6447',1,'neorv32_crc.h']]], + ['neorv32_5fcsr_5fenum_2',['NEORV32_CSR_enum',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49',1,'neorv32_cpu_csr.h']]], + ['neorv32_5fcsr_5ffflags_5fenum_3',['NEORV32_CSR_FFLAGS_enum',['../neorv32__cpu__csr_8h.html#afde0761e3150d82511136f56179c204b',1,'neorv32_cpu_csr.h']]], + ['neorv32_5fcsr_5fmcountinhibit_5fenum_4',['NEORV32_CSR_MCOUNTINHIBIT_enum',['../neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfe',1,'neorv32_cpu_csr.h']]], + ['neorv32_5fcsr_5fmie_5fenum_5',['NEORV32_CSR_MIE_enum',['../neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33',1,'neorv32_cpu_csr.h']]], + ['neorv32_5fcsr_5fmip_5fenum_6',['NEORV32_CSR_MIP_enum',['../neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21b',1,'neorv32_cpu_csr.h']]], + ['neorv32_5fcsr_5fmisa_5fenum_7',['NEORV32_CSR_MISA_enum',['../neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830c',1,'neorv32_cpu_csr.h']]], + ['neorv32_5fcsr_5fmstatus_5fenum_8',['NEORV32_CSR_MSTATUS_enum',['../neorv32__cpu__csr_8h.html#a76b70a2334131e7589d84c1ee96de485',1,'neorv32_cpu_csr.h']]], + ['neorv32_5fcsr_5fxisa_5fenum_9',['NEORV32_CSR_XISA_enum',['../neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387',1,'neorv32_cpu_csr.h']]], + ['neorv32_5fdma_5fctrl_5fenum_10',['NEORV32_DMA_CTRL_enum',['../neorv32__dma_8h.html#a6716eddb145b80ad38799da3b87cb2a4',1,'neorv32_dma.h']]], + ['neorv32_5fdma_5fstatus_5fenum_11',['NEORV32_DMA_STATUS_enum',['../neorv32__dma_8h.html#a002cb188ea5156df0ba282e239a6e74b',1,'neorv32_dma.h']]], + ['neorv32_5fdma_5fttype_5fenum_12',['NEORV32_DMA_TTYPE_enum',['../neorv32__dma_8h.html#a33187c5a074d62b46d2262e352edb8d9',1,'neorv32_dma.h']]], + ['neorv32_5fexception_5fcodes_5fenum_13',['NEORV32_EXCEPTION_CODES_enum',['../neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1',1,'neorv32_cpu_csr.h']]], + ['neorv32_5fexecutable_5fenum_14',['NEORV32_EXECUTABLE_enum',['../bootloader_8c.html#a165a347c51d8aae06a564a2f297f2feb',1,'bootloader.c']]], + ['neorv32_5fgptmr_5fctrl_5fenum_15',['NEORV32_GPTMR_CTRL_enum',['../neorv32__gptmr_8h.html#a135b0750d4afed16e5867134e3843988',1,'neorv32_gptmr.h']]], + ['neorv32_5fhpmcnt_5fevent_5fenum_16',['NEORV32_HPMCNT_EVENT_enum',['../neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfe',1,'neorv32_cpu_csr.h']]], + ['neorv32_5fneoled_5fctrl_5fenum_17',['NEORV32_NEOLED_CTRL_enum',['../neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412',1,'neorv32_neoled.h']]], + ['neorv32_5fonewire_5fctrl_5fenum_18',['NEORV32_ONEWIRE_CTRL_enum',['../neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831',1,'neorv32_onewire.h']]], + ['neorv32_5fonewire_5fdata_5fenum_19',['NEORV32_ONEWIRE_DATA_enum',['../neorv32__onewire_8h.html#ae770490afa8662fb8577065531d51368',1,'neorv32_onewire.h']]], + ['neorv32_5fpmp_5fmodes_5fenum_20',['NEORV32_PMP_MODES_enum',['../neorv32__cpu__csr_8h.html#a8f2418fb5e2175f35ee2362469ce01f5',1,'neorv32_cpu_csr.h']]], + ['neorv32_5fpmpcfg_5fattributes_5fenum_21',['NEORV32_PMPCFG_ATTRIBUTES_enum',['../neorv32__cpu__csr_8h.html#abc0e8daad1e9beda4d9950452cc930ea',1,'neorv32_cpu_csr.h']]], + ['neorv32_5fpwm_5fctrl_5fenum_22',['NEORV32_PWM_CTRL_enum',['../neorv32__pwm_8h.html#af350f93b601a92ef56516198d1570b7d',1,'neorv32_pwm.h']]], + ['neorv32_5frte_5ftrap_5fenum_23',['NEORV32_RTE_TRAP_enum',['../neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70a',1,'neorv32_rte.h']]], + ['neorv32_5fsdi_5fctrl_5fenum_24',['NEORV32_SDI_CTRL_enum',['../neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6',1,'neorv32_sdi.h']]], + ['neorv32_5fslink_5fctrl_5fenum_25',['NEORV32_SLINK_CTRL_enum',['../neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1',1,'neorv32_slink.h']]], + ['neorv32_5fslink_5froute_5fenum_26',['NEORV32_SLINK_ROUTE_enum',['../neorv32__slink_8h.html#ac3e5e02fd89a357135adca6d28cd0e45',1,'neorv32_slink.h']]], + ['neorv32_5fslink_5fstatus_5fenum_27',['NEORV32_SLINK_STATUS_enum',['../neorv32__slink_8h.html#a84f7fe82f188bd4e68f41549587822bf',1,'neorv32_slink.h']]], + ['neorv32_5fspi_5fctrl_5fenum_28',['NEORV32_SPI_CTRL_enum',['../neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3b',1,'neorv32_spi.h']]], + ['neorv32_5fspi_5fdata_5fenum_29',['NEORV32_SPI_DATA_enum',['../neorv32__spi_8h.html#aab478c23898c0b06cee53a1cbda38bf8',1,'neorv32_spi.h']]], + ['neorv32_5ftrng_5fctrl_5fenum_30',['NEORV32_TRNG_CTRL_enum',['../neorv32__trng_8h.html#a1440e1355bf5bff17760992adc156b1a',1,'neorv32_trng.h']]], + ['neorv32_5ftwi_5fctrl_5fenum_31',['NEORV32_TWI_CTRL_enum',['../neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafa',1,'neorv32_twi.h']]], + ['neorv32_5ftwi_5fdcmd_5fenum_32',['NEORV32_TWI_DCMD_enum',['../neorv32__twi_8h.html#a3421852c63baca60fe58c990b1c653d8',1,'neorv32_twi.h']]], + ['neorv32_5fuart_5fctrl_5fenum_33',['NEORV32_UART_CTRL_enum',['../neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afc',1,'neorv32_uart.h']]], + ['neorv32_5fuart_5fdata_5fenum_34',['NEORV32_UART_DATA_enum',['../neorv32__uart_8h.html#adcf35350a9ea18a59c32c35f528643f2',1,'neorv32_uart.h']]], + ['neorv32_5fwdt_5fctrl_5fenum_35',['NEORV32_WDT_CTRL_enum',['../neorv32__wdt_8h.html#a0a4cb24fd818277c5bb9b10ff519f23e',1,'neorv32_wdt.h']]], + ['neorv32_5fwdt_5frcause_5fenum_36',['NEORV32_WDT_RCAUSE_enum',['../neorv32__wdt_8h.html#a70098b4ee893774864536fb4100ff049',1,'neorv32_wdt.h']]], + ['neorv32_5fxip_5fctrl_5fenum_37',['NEORV32_XIP_CTRL_enum',['../neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceb',1,'neorv32_xip.h']]] +]; diff --git a/sw/search/enums_2.js b/sw/search/enums_2.js new file mode 100644 index 0000000000..8e1c48fc01 --- /dev/null +++ b/sw/search/enums_2.js @@ -0,0 +1,7 @@ +var searchData= +[ + ['spi_5fflash_5fcmd_0',['SPI_FLASH_CMD',['../demo__xip_2main_8c.html#af30de1c8d8502ad374612d308cfbd12e',1,'main.c']]], + ['spi_5fflash_5fcmd_5fenum_1',['SPI_FLASH_CMD_enum',['../bootloader_8c.html#aa5e5723e4cbf83805c3b1197cd401fed',1,'bootloader.c']]], + ['spi_5fflash_5fsreg_2',['SPI_FLASH_SREG',['../demo__xip_2main_8c.html#adccf1bb8f1f203cb1350f7f2eb15a08e',1,'main.c']]], + ['spi_5fflash_5fsreg_5fenum_3',['SPI_FLASH_SREG_enum',['../bootloader_8c.html#a97299f563ebc1fca4c663b025a15136f',1,'bootloader.c']]] +]; diff --git a/sw/search/enumvalues_0.js b/sw/search/enumvalues_0.js new file mode 100644 index 0000000000..7d22d3b1fb --- /dev/null +++ b/sw/search/enumvalues_0.js @@ -0,0 +1,249 @@ +var searchData= +[ + ['clk_5fprsc_5f1024_0',['CLK_PRSC_1024',['../neorv32_8h.html#a10022df4c223533b04d5aebe222e8b73a18aac15afd5ebd8d3a00dd6e513daf17',1,'neorv32.h']]], + ['clk_5fprsc_5f128_1',['CLK_PRSC_128',['../neorv32_8h.html#a10022df4c223533b04d5aebe222e8b73a933045a5405de55781d687315f42054e',1,'neorv32.h']]], + ['clk_5fprsc_5f2_2',['CLK_PRSC_2',['../neorv32_8h.html#a10022df4c223533b04d5aebe222e8b73ad63d40139c50d76618cf1258cbdc0d05',1,'neorv32.h']]], + ['clk_5fprsc_5f2048_3',['CLK_PRSC_2048',['../neorv32_8h.html#a10022df4c223533b04d5aebe222e8b73aa138f0cad547028d5124f89d6dcc8c79',1,'neorv32.h']]], + ['clk_5fprsc_5f4_4',['CLK_PRSC_4',['../neorv32_8h.html#a10022df4c223533b04d5aebe222e8b73a648249b3ab8c2500880c1e68b98f81d1',1,'neorv32.h']]], + ['clk_5fprsc_5f4096_5',['CLK_PRSC_4096',['../neorv32_8h.html#a10022df4c223533b04d5aebe222e8b73a0f20c29722bf9afc478b1a286a6b7eee',1,'neorv32.h']]], + ['clk_5fprsc_5f64_6',['CLK_PRSC_64',['../neorv32_8h.html#a10022df4c223533b04d5aebe222e8b73a5990532893f2d9606e3c02aff60ca5da',1,'neorv32.h']]], + ['clk_5fprsc_5f8_7',['CLK_PRSC_8',['../neorv32_8h.html#a10022df4c223533b04d5aebe222e8b73aa4e3a6a5b3cd895f63b4544f63ce22c9',1,'neorv32.h']]], + ['crc_5fmode16_8',['CRC_MODE16',['../neorv32__crc_8h.html#a1ae84a58f475bafc2fc3f2c690fd6447aa5cfd5d285b4cb8997c7e754491d050f',1,'neorv32_crc.h']]], + ['crc_5fmode32_9',['CRC_MODE32',['../neorv32__crc_8h.html#a1ae84a58f475bafc2fc3f2c690fd6447a7cf26bd4a7e8d6e45016633f650f00aa',1,'neorv32_crc.h']]], + ['crc_5fmode8_10',['CRC_MODE8',['../neorv32__crc_8h.html#a1ae84a58f475bafc2fc3f2c690fd6447a9409185edbae1bd0afdeda4e58aa6d1a',1,'neorv32_crc.h']]], + ['csr_5fcfureg0_11',['CSR_CFUREG0',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ae0e9cf0b99b8614ea0b870d38970281f',1,'neorv32_cpu_csr.h']]], + ['csr_5fcfureg1_12',['CSR_CFUREG1',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a382304065a6db773f925b80b9447b8a8',1,'neorv32_cpu_csr.h']]], + ['csr_5fcfureg2_13',['CSR_CFUREG2',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a427d7cf036b49efd46166c01f0504b68',1,'neorv32_cpu_csr.h']]], + ['csr_5fcfureg3_14',['CSR_CFUREG3',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aefefa1cff0cf5d01109486e5a8bebedf',1,'neorv32_cpu_csr.h']]], + ['csr_5fcycle_15',['CSR_CYCLE',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aaaf0f6b17a06d5922bcfdb47b382137e',1,'neorv32_cpu_csr.h']]], + ['csr_5fcycleh_16',['CSR_CYCLEH',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aa276bedb7dab28935163397b4879f6db',1,'neorv32_cpu_csr.h']]], + ['csr_5fdcsr_17',['CSR_DCSR',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a6bb3ba59a25803d6f98faad67609a9a9',1,'neorv32_cpu_csr.h']]], + ['csr_5fdpc_18',['CSR_DPC',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49af4c98d949d2eb44f2518fdf314344d3b',1,'neorv32_cpu_csr.h']]], + ['csr_5fdscratch0_19',['CSR_DSCRATCH0',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a0f4a1ae740efd80d14d21e90f355e9d7',1,'neorv32_cpu_csr.h']]], + ['csr_5ffcsr_20',['CSR_FCSR',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a5e1abf46b4f55bd18e1d132b32696ab6',1,'neorv32_cpu_csr.h']]], + ['csr_5ffflags_21',['CSR_FFLAGS',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a625f606c14fd4d7224d7109e10508e7a',1,'neorv32_cpu_csr.h']]], + ['csr_5ffflags_5fdz_22',['CSR_FFLAGS_DZ',['../neorv32__cpu__csr_8h.html#afde0761e3150d82511136f56179c204ba365f3f519bca34a349907c82c873d52b',1,'neorv32_cpu_csr.h']]], + ['csr_5ffflags_5fnv_23',['CSR_FFLAGS_NV',['../neorv32__cpu__csr_8h.html#afde0761e3150d82511136f56179c204ba3ac330a4b03178e756c980eaa48ad165',1,'neorv32_cpu_csr.h']]], + ['csr_5ffflags_5fnx_24',['CSR_FFLAGS_NX',['../neorv32__cpu__csr_8h.html#afde0761e3150d82511136f56179c204ba91a314defd310786a9ed67f7ef2ef5a6',1,'neorv32_cpu_csr.h']]], + ['csr_5ffflags_5fof_25',['CSR_FFLAGS_OF',['../neorv32__cpu__csr_8h.html#afde0761e3150d82511136f56179c204ba612390e07a065fa13eeaeac84af48c6e',1,'neorv32_cpu_csr.h']]], + ['csr_5ffflags_5fuf_26',['CSR_FFLAGS_UF',['../neorv32__cpu__csr_8h.html#afde0761e3150d82511136f56179c204babc6d405724563844569028f463885819',1,'neorv32_cpu_csr.h']]], + ['csr_5ffrm_27',['CSR_FRM',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a7f198c465959dde37b7056dd06d45812',1,'neorv32_cpu_csr.h']]], + ['csr_5fhpmcounter10_28',['CSR_HPMCOUNTER10',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aa407e701bdbb9d26f84684b811c008a9',1,'neorv32_cpu_csr.h']]], + ['csr_5fhpmcounter10h_29',['CSR_HPMCOUNTER10H',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ae56e95d6d6dd63ff6f5b4192cf48c88b',1,'neorv32_cpu_csr.h']]], + ['csr_5fhpmcounter11_30',['CSR_HPMCOUNTER11',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a9fd1ff4e8a42992c0a3ec02c397dd7f8',1,'neorv32_cpu_csr.h']]], + ['csr_5fhpmcounter11h_31',['CSR_HPMCOUNTER11H',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a2af8c5dcc87d92bcce392fb5b3aa065e',1,'neorv32_cpu_csr.h']]], + ['csr_5fhpmcounter12_32',['CSR_HPMCOUNTER12',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ae58f15a95aa41126819effe046ced804',1,'neorv32_cpu_csr.h']]], + ['csr_5fhpmcounter12h_33',['CSR_HPMCOUNTER12H',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a74359db2583feb7119d4bcaa926242a0',1,'neorv32_cpu_csr.h']]], + ['csr_5fhpmcounter13_34',['CSR_HPMCOUNTER13',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a24d8617a6ff2c1e49c9a73853ad9e450',1,'neorv32_cpu_csr.h']]], + ['csr_5fhpmcounter13h_35',['CSR_HPMCOUNTER13H',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a4fa22699e96d6da8665077e3c95891ef',1,'neorv32_cpu_csr.h']]], + ['csr_5fhpmcounter14_36',['CSR_HPMCOUNTER14',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aa47ed1a4a4f9fcabceed0d6d626d0aaf',1,'neorv32_cpu_csr.h']]], + ['csr_5fhpmcounter14h_37',['CSR_HPMCOUNTER14H',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a03f29e792be2854efc9e66d710b78a1d',1,'neorv32_cpu_csr.h']]], + ['csr_5fhpmcounter15_38',['CSR_HPMCOUNTER15',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a7277a8f929a5a250f7227fbbdf545dbc',1,'neorv32_cpu_csr.h']]], + ['csr_5fhpmcounter15h_39',['CSR_HPMCOUNTER15H',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a11169bd08920d40c8f94fd29e1d33eff',1,'neorv32_cpu_csr.h']]], + ['csr_5fhpmcounter3_40',['CSR_HPMCOUNTER3',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a3ee699d5b2886c54c92992f66b109b67',1,'neorv32_cpu_csr.h']]], + ['csr_5fhpmcounter3h_41',['CSR_HPMCOUNTER3H',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aaa3e6a1ac8999be42d7c13891546bb50',1,'neorv32_cpu_csr.h']]], + ['csr_5fhpmcounter4_42',['CSR_HPMCOUNTER4',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a98ed49716d0d89712863e7a542d38d2a',1,'neorv32_cpu_csr.h']]], + ['csr_5fhpmcounter4h_43',['CSR_HPMCOUNTER4H',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a8837ff8d2741639aa69da59659f9a080',1,'neorv32_cpu_csr.h']]], + ['csr_5fhpmcounter5_44',['CSR_HPMCOUNTER5',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ab2376c3b7c3ec0b44105ec1ed951bfb0',1,'neorv32_cpu_csr.h']]], + ['csr_5fhpmcounter5h_45',['CSR_HPMCOUNTER5H',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ad489feaa5ad1feb00d3df71d3e5b0cac',1,'neorv32_cpu_csr.h']]], + ['csr_5fhpmcounter6_46',['CSR_HPMCOUNTER6',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aa2f644a4f54ba3834bafa738208c0803',1,'neorv32_cpu_csr.h']]], + ['csr_5fhpmcounter6h_47',['CSR_HPMCOUNTER6H',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a438a65757b85f182dfb1f2a06c9ad520',1,'neorv32_cpu_csr.h']]], + ['csr_5fhpmcounter7_48',['CSR_HPMCOUNTER7',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a125c4d0051548dea9104808b7bee1316',1,'neorv32_cpu_csr.h']]], + ['csr_5fhpmcounter7h_49',['CSR_HPMCOUNTER7H',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a6332d4ff090aa7c302d191219e846fff',1,'neorv32_cpu_csr.h']]], + ['csr_5fhpmcounter8_50',['CSR_HPMCOUNTER8',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49acac87125f8c723cc5df4d4169a82852b',1,'neorv32_cpu_csr.h']]], + ['csr_5fhpmcounter8h_51',['CSR_HPMCOUNTER8H',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aa8ce8fc8a57dd82872d02b4113249a77',1,'neorv32_cpu_csr.h']]], + ['csr_5fhpmcounter9_52',['CSR_HPMCOUNTER9',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ab45ebb3bd861074a15cc2ad874756e8f',1,'neorv32_cpu_csr.h']]], + ['csr_5fhpmcounter9h_53',['CSR_HPMCOUNTER9H',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49acdf793b30919e7fa1b85995abe531a20',1,'neorv32_cpu_csr.h']]], + ['csr_5finstret_54',['CSR_INSTRET',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a8144da8cd8691ac54aa0712685865b66',1,'neorv32_cpu_csr.h']]], + ['csr_5finstreth_55',['CSR_INSTRETH',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a9b66978d76260283007d399fc735d153',1,'neorv32_cpu_csr.h']]], + ['csr_5fmarchid_56',['CSR_MARCHID',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ad95cb95266533123447ff0e917f890e4',1,'neorv32_cpu_csr.h']]], + ['csr_5fmcause_57',['CSR_MCAUSE',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a2e14b57fee5376741634db7980a5005b',1,'neorv32_cpu_csr.h']]], + ['csr_5fmconfigptr_58',['CSR_MCONFIGPTR',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a0545d0921b3f90d037dbb25bc5fcc2f9',1,'neorv32_cpu_csr.h']]], + ['csr_5fmcounteren_59',['CSR_MCOUNTEREN',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a1860dd9579906c67a3565063043dcf78',1,'neorv32_cpu_csr.h']]], + ['csr_5fmcountinhibit_60',['CSR_MCOUNTINHIBIT',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a3ce1dc0e2810f0df78feaa1c607a5ca6',1,'neorv32_cpu_csr.h']]], + ['csr_5fmcountinhibit_5fcy_61',['CSR_MCOUNTINHIBIT_CY',['../neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea201ac39b0eba389b0d02c3951a3311a3',1,'neorv32_cpu_csr.h']]], + ['csr_5fmcountinhibit_5fhpm10_62',['CSR_MCOUNTINHIBIT_HPM10',['../neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea9517cd32744c5064fa30780f911cd22e',1,'neorv32_cpu_csr.h']]], + ['csr_5fmcountinhibit_5fhpm11_63',['CSR_MCOUNTINHIBIT_HPM11',['../neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfeacaf997fe8b912596224e2bb632e6a806',1,'neorv32_cpu_csr.h']]], + ['csr_5fmcountinhibit_5fhpm12_64',['CSR_MCOUNTINHIBIT_HPM12',['../neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea8d866a4c815d8ba890a1e00ce9600486',1,'neorv32_cpu_csr.h']]], + ['csr_5fmcountinhibit_5fhpm13_65',['CSR_MCOUNTINHIBIT_HPM13',['../neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfead9f6c4eb4284ee82b9e8d0c79f62b3ed',1,'neorv32_cpu_csr.h']]], + ['csr_5fmcountinhibit_5fhpm14_66',['CSR_MCOUNTINHIBIT_HPM14',['../neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfeaa83c0688869b1c43de0c4474e940f987',1,'neorv32_cpu_csr.h']]], + ['csr_5fmcountinhibit_5fhpm15_67',['CSR_MCOUNTINHIBIT_HPM15',['../neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea0b547cb5876c0e7956e3d062e0784085',1,'neorv32_cpu_csr.h']]], + ['csr_5fmcountinhibit_5fhpm16_68',['CSR_MCOUNTINHIBIT_HPM16',['../neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea68aba71ea77aba4005fb24a945ef38e4',1,'neorv32_cpu_csr.h']]], + ['csr_5fmcountinhibit_5fhpm17_69',['CSR_MCOUNTINHIBIT_HPM17',['../neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea8d57acf13a086635a63bc13ccdf479b3',1,'neorv32_cpu_csr.h']]], + ['csr_5fmcountinhibit_5fhpm18_70',['CSR_MCOUNTINHIBIT_HPM18',['../neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfeaa680d196d2ba0e403801a860bb9d8ce0',1,'neorv32_cpu_csr.h']]], + ['csr_5fmcountinhibit_5fhpm19_71',['CSR_MCOUNTINHIBIT_HPM19',['../neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea3683e296caafe771b6dd57f4cf86f3dc',1,'neorv32_cpu_csr.h']]], + ['csr_5fmcountinhibit_5fhpm20_72',['CSR_MCOUNTINHIBIT_HPM20',['../neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfeaeb4b1b6abafd22eec0764d5503878cca',1,'neorv32_cpu_csr.h']]], + ['csr_5fmcountinhibit_5fhpm21_73',['CSR_MCOUNTINHIBIT_HPM21',['../neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea1dc0276a5354c805ac56fd46c5037d38',1,'neorv32_cpu_csr.h']]], + ['csr_5fmcountinhibit_5fhpm22_74',['CSR_MCOUNTINHIBIT_HPM22',['../neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfeaf1b6153a0c664367bfefb78b2ca8b34e',1,'neorv32_cpu_csr.h']]], + ['csr_5fmcountinhibit_5fhpm23_75',['CSR_MCOUNTINHIBIT_HPM23',['../neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea85c0c2b2a5101380dec72516dda1a904',1,'neorv32_cpu_csr.h']]], + ['csr_5fmcountinhibit_5fhpm24_76',['CSR_MCOUNTINHIBIT_HPM24',['../neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea74ec85a2e94aa0b9e8af29401ef7ecb1',1,'neorv32_cpu_csr.h']]], + ['csr_5fmcountinhibit_5fhpm25_77',['CSR_MCOUNTINHIBIT_HPM25',['../neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfeaee2b5a2b7bd7ac07dae45900bc2faf46',1,'neorv32_cpu_csr.h']]], + ['csr_5fmcountinhibit_5fhpm26_78',['CSR_MCOUNTINHIBIT_HPM26',['../neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea141a4a211c496d2af1c79d8e8e0c2a74',1,'neorv32_cpu_csr.h']]], + ['csr_5fmcountinhibit_5fhpm27_79',['CSR_MCOUNTINHIBIT_HPM27',['../neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea46def851d4582b4bcec1f9d8bafd58db',1,'neorv32_cpu_csr.h']]], + ['csr_5fmcountinhibit_5fhpm28_80',['CSR_MCOUNTINHIBIT_HPM28',['../neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea33d0fd3378ec3a2fcc3c8738c6cd2f32',1,'neorv32_cpu_csr.h']]], + ['csr_5fmcountinhibit_5fhpm29_81',['CSR_MCOUNTINHIBIT_HPM29',['../neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfeaa39882f7dad9b7e16b317c75bad31382',1,'neorv32_cpu_csr.h']]], + ['csr_5fmcountinhibit_5fhpm3_82',['CSR_MCOUNTINHIBIT_HPM3',['../neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfeaf7020159e0ba346561bfba101d22c752',1,'neorv32_cpu_csr.h']]], + ['csr_5fmcountinhibit_5fhpm30_83',['CSR_MCOUNTINHIBIT_HPM30',['../neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea0f45818fa4cb9033a3093987fa8515c7',1,'neorv32_cpu_csr.h']]], + ['csr_5fmcountinhibit_5fhpm31_84',['CSR_MCOUNTINHIBIT_HPM31',['../neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea1da1186ef2f4e7297a4fecaaccdc1d05',1,'neorv32_cpu_csr.h']]], + ['csr_5fmcountinhibit_5fhpm4_85',['CSR_MCOUNTINHIBIT_HPM4',['../neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea40427b799da049413c5536afa623c61d',1,'neorv32_cpu_csr.h']]], + ['csr_5fmcountinhibit_5fhpm5_86',['CSR_MCOUNTINHIBIT_HPM5',['../neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea2769a6e6a75f2f903523e4e95a899bb6',1,'neorv32_cpu_csr.h']]], + ['csr_5fmcountinhibit_5fhpm6_87',['CSR_MCOUNTINHIBIT_HPM6',['../neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfead55b6af15841617d7dca3ab4fab893db',1,'neorv32_cpu_csr.h']]], + ['csr_5fmcountinhibit_5fhpm7_88',['CSR_MCOUNTINHIBIT_HPM7',['../neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea3b3571fceb687da2d3807b0e59bdf7ab',1,'neorv32_cpu_csr.h']]], + ['csr_5fmcountinhibit_5fhpm8_89',['CSR_MCOUNTINHIBIT_HPM8',['../neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfeabd21344124eda4402523203185a58b8a',1,'neorv32_cpu_csr.h']]], + ['csr_5fmcountinhibit_5fhpm9_90',['CSR_MCOUNTINHIBIT_HPM9',['../neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea0f207455df0fed75fa68ba49c435889a',1,'neorv32_cpu_csr.h']]], + ['csr_5fmcountinhibit_5fir_91',['CSR_MCOUNTINHIBIT_IR',['../neorv32__cpu__csr_8h.html#ab6886ca6858d57854495986ef9b5cbfea5f182f39f9a4b871a097a51e57865bfa',1,'neorv32_cpu_csr.h']]], + ['csr_5fmcycle_92',['CSR_MCYCLE',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a32c22641ed66c6d20902306a2b1fad77',1,'neorv32_cpu_csr.h']]], + ['csr_5fmcycleh_93',['CSR_MCYCLEH',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a28fcfd06ca1012c19cf053e57689687b',1,'neorv32_cpu_csr.h']]], + ['csr_5fmenvcfg_94',['CSR_MENVCFG',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a9c55619ffb05e84b7210e2d47326fa98',1,'neorv32_cpu_csr.h']]], + ['csr_5fmenvcfgh_95',['CSR_MENVCFGH',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a46b8d3c288cbbfbf5a0af6e5cd8c5bc8',1,'neorv32_cpu_csr.h']]], + ['csr_5fmepc_96',['CSR_MEPC',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a5d60a25a66754066589e8facb7d41153',1,'neorv32_cpu_csr.h']]], + ['csr_5fmhartid_97',['CSR_MHARTID',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a6ba48e2306ae92f498552e1ea04d6790',1,'neorv32_cpu_csr.h']]], + ['csr_5fmhpmcounter10_98',['CSR_MHPMCOUNTER10',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a575e5342d8ec304c32dbbe99d6fd6c0f',1,'neorv32_cpu_csr.h']]], + ['csr_5fmhpmcounter10h_99',['CSR_MHPMCOUNTER10H',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a1e41d2b27d7e8da14871852d81123cfd',1,'neorv32_cpu_csr.h']]], + ['csr_5fmhpmcounter11_100',['CSR_MHPMCOUNTER11',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a8840b3d4f45453fc96813ccb369a68e5',1,'neorv32_cpu_csr.h']]], + ['csr_5fmhpmcounter11h_101',['CSR_MHPMCOUNTER11H',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a7fd76fcfc0d0dd47e112786bea5e4071',1,'neorv32_cpu_csr.h']]], + ['csr_5fmhpmcounter12_102',['CSR_MHPMCOUNTER12',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a1328a226d36d23cc81740397bde47a4e',1,'neorv32_cpu_csr.h']]], + ['csr_5fmhpmcounter12h_103',['CSR_MHPMCOUNTER12H',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a332ec2b0740f8e899a1b2ec86f7ee9f2',1,'neorv32_cpu_csr.h']]], + ['csr_5fmhpmcounter13_104',['CSR_MHPMCOUNTER13',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a9bdd102877ff50d38c86c3d741aeb4b0',1,'neorv32_cpu_csr.h']]], + ['csr_5fmhpmcounter13h_105',['CSR_MHPMCOUNTER13H',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a5de5c5a036dc594a554d37df9ccf657d',1,'neorv32_cpu_csr.h']]], + ['csr_5fmhpmcounter14_106',['CSR_MHPMCOUNTER14',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49adae22d860d8162e15120051951e45229',1,'neorv32_cpu_csr.h']]], + ['csr_5fmhpmcounter14h_107',['CSR_MHPMCOUNTER14H',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ac65bab6fd71439600c8fc549171251fa',1,'neorv32_cpu_csr.h']]], + ['csr_5fmhpmcounter15_108',['CSR_MHPMCOUNTER15',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a20400929087fabba410a098667d2d4ff',1,'neorv32_cpu_csr.h']]], + ['csr_5fmhpmcounter15h_109',['CSR_MHPMCOUNTER15H',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49af609807e2917f73e27e5f27b38a0fa46',1,'neorv32_cpu_csr.h']]], + ['csr_5fmhpmcounter3_110',['CSR_MHPMCOUNTER3',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ae0a96f499dcde474af6ee620fbb1ebdc',1,'neorv32_cpu_csr.h']]], + ['csr_5fmhpmcounter3h_111',['CSR_MHPMCOUNTER3H',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a252980a4da90c1f5c1ef85d164f72f25',1,'neorv32_cpu_csr.h']]], + ['csr_5fmhpmcounter4_112',['CSR_MHPMCOUNTER4',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a9b84bd948dd52a7779b5fd16beddaab9',1,'neorv32_cpu_csr.h']]], + ['csr_5fmhpmcounter4h_113',['CSR_MHPMCOUNTER4H',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a2e9cfbf3c2828dd4bd92d2b8a1c99f85',1,'neorv32_cpu_csr.h']]], + ['csr_5fmhpmcounter5_114',['CSR_MHPMCOUNTER5',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49af15d389bb8f91c989df488d231666394',1,'neorv32_cpu_csr.h']]], + ['csr_5fmhpmcounter5h_115',['CSR_MHPMCOUNTER5H',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a7648dd0a47007d44a14e95ba47726599',1,'neorv32_cpu_csr.h']]], + ['csr_5fmhpmcounter6_116',['CSR_MHPMCOUNTER6',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49af65b9e99b9cadb3cb8d37f97cdbfeb9d',1,'neorv32_cpu_csr.h']]], + ['csr_5fmhpmcounter6h_117',['CSR_MHPMCOUNTER6H',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a49b7bc2df67a6c73a68757de9b218f77',1,'neorv32_cpu_csr.h']]], + ['csr_5fmhpmcounter7_118',['CSR_MHPMCOUNTER7',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a919f39b0d299feb80403b42a466de444',1,'neorv32_cpu_csr.h']]], + ['csr_5fmhpmcounter7h_119',['CSR_MHPMCOUNTER7H',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ac0183bb6f357ed33136493ae7ded987a',1,'neorv32_cpu_csr.h']]], + ['csr_5fmhpmcounter8_120',['CSR_MHPMCOUNTER8',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a5a4cde90c547e913bddc719b3ab75e79',1,'neorv32_cpu_csr.h']]], + ['csr_5fmhpmcounter8h_121',['CSR_MHPMCOUNTER8H',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a9e75518df7d14a009e3a0d5588641ddc',1,'neorv32_cpu_csr.h']]], + ['csr_5fmhpmcounter9_122',['CSR_MHPMCOUNTER9',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a18c2a249f1f7852f42f9e10dc59d46bb',1,'neorv32_cpu_csr.h']]], + ['csr_5fmhpmcounter9h_123',['CSR_MHPMCOUNTER9H',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a7341886c7a4aed6fc7d8677c016a2cb8',1,'neorv32_cpu_csr.h']]], + ['csr_5fmhpmevent10_124',['CSR_MHPMEVENT10',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a23850b1804966cde2c1e84cde752d512',1,'neorv32_cpu_csr.h']]], + ['csr_5fmhpmevent11_125',['CSR_MHPMEVENT11',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a7fb1de2019dd2b548084d5ca1630efbf',1,'neorv32_cpu_csr.h']]], + ['csr_5fmhpmevent12_126',['CSR_MHPMEVENT12',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ad648b5ece209d47e9484fd7aa83e8e5f',1,'neorv32_cpu_csr.h']]], + ['csr_5fmhpmevent13_127',['CSR_MHPMEVENT13',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a8c31899b81bb5dba9b92a0f0ca71aea6',1,'neorv32_cpu_csr.h']]], + ['csr_5fmhpmevent14_128',['CSR_MHPMEVENT14',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a964a6a50d0138447fad47e9c982a7ba4',1,'neorv32_cpu_csr.h']]], + ['csr_5fmhpmevent15_129',['CSR_MHPMEVENT15',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a06dfdeed757606529e4a99c033691b54',1,'neorv32_cpu_csr.h']]], + ['csr_5fmhpmevent3_130',['CSR_MHPMEVENT3',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a4a93ac5ab276cfd2f9cd296c8ce1bff6',1,'neorv32_cpu_csr.h']]], + ['csr_5fmhpmevent4_131',['CSR_MHPMEVENT4',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ab5f998725e002ffc2ff516ee973fe459',1,'neorv32_cpu_csr.h']]], + ['csr_5fmhpmevent5_132',['CSR_MHPMEVENT5',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a2524659ca2785af51af7acf9cd560a9d',1,'neorv32_cpu_csr.h']]], + ['csr_5fmhpmevent6_133',['CSR_MHPMEVENT6',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a1cfa1e3bc3c8a1c9a86c251a510d11cd',1,'neorv32_cpu_csr.h']]], + ['csr_5fmhpmevent7_134',['CSR_MHPMEVENT7',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a2e53e6e01ca8d1b801f6dfba602f3f59',1,'neorv32_cpu_csr.h']]], + ['csr_5fmhpmevent8_135',['CSR_MHPMEVENT8',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ad6296ca83bbe1280624f3c21adbd8a79',1,'neorv32_cpu_csr.h']]], + ['csr_5fmhpmevent9_136',['CSR_MHPMEVENT9',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49af6727a9bdd60ccf020812095b7396632',1,'neorv32_cpu_csr.h']]], + ['csr_5fmie_137',['CSR_MIE',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49acc0f9f5f3b5702f1b57f2ba3b6b62610',1,'neorv32_cpu_csr.h']]], + ['csr_5fmie_5ffirq0e_138',['CSR_MIE_FIRQ0E',['../neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a99f43f8bbfb29fba6224f081c363ac7d',1,'neorv32_cpu_csr.h']]], + ['csr_5fmie_5ffirq10e_139',['CSR_MIE_FIRQ10E',['../neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33affcb52dc57bb8c0cb1e7d3c1392d544a',1,'neorv32_cpu_csr.h']]], + ['csr_5fmie_5ffirq11e_140',['CSR_MIE_FIRQ11E',['../neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33af058342854a0becd3bcc33877d9244cd',1,'neorv32_cpu_csr.h']]], + ['csr_5fmie_5ffirq12e_141',['CSR_MIE_FIRQ12E',['../neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a41f91a37f7e0c75c783312af6a72e943',1,'neorv32_cpu_csr.h']]], + ['csr_5fmie_5ffirq13e_142',['CSR_MIE_FIRQ13E',['../neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a134ed02c7293008b21b1df472be8f11f',1,'neorv32_cpu_csr.h']]], + ['csr_5fmie_5ffirq14e_143',['CSR_MIE_FIRQ14E',['../neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a864d135708530016cfc52a65a1e4d79b',1,'neorv32_cpu_csr.h']]], + ['csr_5fmie_5ffirq15e_144',['CSR_MIE_FIRQ15E',['../neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33aa2dfa1183af312de2959dadd217fddc1',1,'neorv32_cpu_csr.h']]], + ['csr_5fmie_5ffirq1e_145',['CSR_MIE_FIRQ1E',['../neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33ac1e1d44becec1b393f79a118ed3d8beb',1,'neorv32_cpu_csr.h']]], + ['csr_5fmie_5ffirq2e_146',['CSR_MIE_FIRQ2E',['../neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33afc805280e20ffface116ca61e11645f7',1,'neorv32_cpu_csr.h']]], + ['csr_5fmie_5ffirq3e_147',['CSR_MIE_FIRQ3E',['../neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a666066099d6cebadbef21d81c179e8db',1,'neorv32_cpu_csr.h']]], + ['csr_5fmie_5ffirq4e_148',['CSR_MIE_FIRQ4E',['../neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a592939f1b7d79097f7f13d6ab0c268dc',1,'neorv32_cpu_csr.h']]], + ['csr_5fmie_5ffirq5e_149',['CSR_MIE_FIRQ5E',['../neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a3079a8fbf3b8e376865bff76f2173698',1,'neorv32_cpu_csr.h']]], + ['csr_5fmie_5ffirq6e_150',['CSR_MIE_FIRQ6E',['../neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a96315d6b5b9531bcbc1e78a3c9ab166a',1,'neorv32_cpu_csr.h']]], + ['csr_5fmie_5ffirq7e_151',['CSR_MIE_FIRQ7E',['../neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a3d9d729940170609affbc6813054ebe8',1,'neorv32_cpu_csr.h']]], + ['csr_5fmie_5ffirq8e_152',['CSR_MIE_FIRQ8E',['../neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a396c6c4b425b3fff598e2f846052f98e',1,'neorv32_cpu_csr.h']]], + ['csr_5fmie_5ffirq9e_153',['CSR_MIE_FIRQ9E',['../neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a06fdb61dab31c3490da6c37d47914f19',1,'neorv32_cpu_csr.h']]], + ['csr_5fmie_5fmeie_154',['CSR_MIE_MEIE',['../neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33ae8e4f0ee46abbbb3361de035a57b8324',1,'neorv32_cpu_csr.h']]], + ['csr_5fmie_5fmsie_155',['CSR_MIE_MSIE',['../neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33afd2f1c78c442c8c29ab075cacee0a27a',1,'neorv32_cpu_csr.h']]], + ['csr_5fmie_5fmtie_156',['CSR_MIE_MTIE',['../neorv32__cpu__csr_8h.html#a0e9714690687badee43180c3cb62be33a3658e8663e94cd8eaa7201b7a850d083',1,'neorv32_cpu_csr.h']]], + ['csr_5fmimpid_157',['CSR_MIMPID',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a06d39cf0f13d6401dcf426d56149c8cd',1,'neorv32_cpu_csr.h']]], + ['csr_5fminstret_158',['CSR_MINSTRET',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a98f5e2cf2d5dbb0125a222b0065c86eb',1,'neorv32_cpu_csr.h']]], + ['csr_5fminstreth_159',['CSR_MINSTRETH',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49afffb28b62b9baa127ae3bad919208988',1,'neorv32_cpu_csr.h']]], + ['csr_5fmip_160',['CSR_MIP',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49addb485275c954d1181d5bd4e4609082c',1,'neorv32_cpu_csr.h']]], + ['csr_5fmip_5ffirq0p_161',['CSR_MIP_FIRQ0P',['../neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba28a85ad8bd4c30fd3a91298dfa4fdb00',1,'neorv32_cpu_csr.h']]], + ['csr_5fmip_5ffirq10p_162',['CSR_MIP_FIRQ10P',['../neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba2b50cfa8be461b088ea8506ce4c741ba',1,'neorv32_cpu_csr.h']]], + ['csr_5fmip_5ffirq11p_163',['CSR_MIP_FIRQ11P',['../neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba69ea0d3d76d4cec398f3b96959cc3544',1,'neorv32_cpu_csr.h']]], + ['csr_5fmip_5ffirq12p_164',['CSR_MIP_FIRQ12P',['../neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba03edd398920b817150d29107c0b40792',1,'neorv32_cpu_csr.h']]], + ['csr_5fmip_5ffirq13p_165',['CSR_MIP_FIRQ13P',['../neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba14da6a2a962bf82970638a948ffbc570',1,'neorv32_cpu_csr.h']]], + ['csr_5fmip_5ffirq14p_166',['CSR_MIP_FIRQ14P',['../neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21baad1e5e452a9c37561308765431f0260d',1,'neorv32_cpu_csr.h']]], + ['csr_5fmip_5ffirq15p_167',['CSR_MIP_FIRQ15P',['../neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba12da8c32d38d5a3539a0b766718bfd2d',1,'neorv32_cpu_csr.h']]], + ['csr_5fmip_5ffirq1p_168',['CSR_MIP_FIRQ1P',['../neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba2b577b1da1074c29ad58005af1f91d52',1,'neorv32_cpu_csr.h']]], + ['csr_5fmip_5ffirq2p_169',['CSR_MIP_FIRQ2P',['../neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21badf45c5a135431f958fa63574c1dfac6e',1,'neorv32_cpu_csr.h']]], + ['csr_5fmip_5ffirq3p_170',['CSR_MIP_FIRQ3P',['../neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba7512bb6c4841ddd477422b49ebb2a155',1,'neorv32_cpu_csr.h']]], + ['csr_5fmip_5ffirq4p_171',['CSR_MIP_FIRQ4P',['../neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21bab6421f242bb8a487a986346e11196eb8',1,'neorv32_cpu_csr.h']]], + ['csr_5fmip_5ffirq5p_172',['CSR_MIP_FIRQ5P',['../neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21baaa55d19f9a47889bc364c94bda04b677',1,'neorv32_cpu_csr.h']]], + ['csr_5fmip_5ffirq6p_173',['CSR_MIP_FIRQ6P',['../neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21baffa7342631aa0526aaa44c0c549b1f3e',1,'neorv32_cpu_csr.h']]], + ['csr_5fmip_5ffirq7p_174',['CSR_MIP_FIRQ7P',['../neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21baad691486001a68f2375dcf5793ee795a',1,'neorv32_cpu_csr.h']]], + ['csr_5fmip_5ffirq8p_175',['CSR_MIP_FIRQ8P',['../neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21baf5bbd23d4f311f640db42e9015f87580',1,'neorv32_cpu_csr.h']]], + ['csr_5fmip_5ffirq9p_176',['CSR_MIP_FIRQ9P',['../neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21bad94c9691ce59b97fcfec14d345046c3e',1,'neorv32_cpu_csr.h']]], + ['csr_5fmip_5fmeip_177',['CSR_MIP_MEIP',['../neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba1d761ef98f88c40509168ac66b7a4872',1,'neorv32_cpu_csr.h']]], + ['csr_5fmip_5fmsip_178',['CSR_MIP_MSIP',['../neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba1470cfe04f9d3ce45b7156b2a7fae159',1,'neorv32_cpu_csr.h']]], + ['csr_5fmip_5fmtip_179',['CSR_MIP_MTIP',['../neorv32__cpu__csr_8h.html#a6301c554bf831b97fc28f9984a1ec21ba344943c62922561378d33ec51ac236e4',1,'neorv32_cpu_csr.h']]], + ['csr_5fmisa_180',['CSR_MISA',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ade079242596ce14ce1ba9842ed29b84c',1,'neorv32_cpu_csr.h']]], + ['csr_5fmisa_5fa_181',['CSR_MISA_A',['../neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830ca89412df9f99d2a0ddc4665446397f1a2',1,'neorv32_cpu_csr.h']]], + ['csr_5fmisa_5fb_182',['CSR_MISA_B',['../neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830cadd469404a928e012a298773ec46926ad',1,'neorv32_cpu_csr.h']]], + ['csr_5fmisa_5fc_183',['CSR_MISA_C',['../neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830ca886699013158c74810598fa2fd6b07fa',1,'neorv32_cpu_csr.h']]], + ['csr_5fmisa_5fd_184',['CSR_MISA_D',['../neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830ca1dd1be1071450f9b00a817bce19fa665',1,'neorv32_cpu_csr.h']]], + ['csr_5fmisa_5fe_185',['CSR_MISA_E',['../neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830ca0ac798fd19cb7dbe1146afecda448fec',1,'neorv32_cpu_csr.h']]], + ['csr_5fmisa_5ff_186',['CSR_MISA_F',['../neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830ca9ec2cae2b948de1043540a4ca1665c40',1,'neorv32_cpu_csr.h']]], + ['csr_5fmisa_5fi_187',['CSR_MISA_I',['../neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830ca6091fd2c7ae38ad33be68a0fdfa50cca',1,'neorv32_cpu_csr.h']]], + ['csr_5fmisa_5fm_188',['CSR_MISA_M',['../neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830ca317a631e4598532f5bffe8fb93aff94b',1,'neorv32_cpu_csr.h']]], + ['csr_5fmisa_5fmxl_5fhi_189',['CSR_MISA_MXL_HI',['../neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830cafb3e4b08b87f5c161468a9e58ade12cc',1,'neorv32_cpu_csr.h']]], + ['csr_5fmisa_5fmxl_5flo_190',['CSR_MISA_MXL_LO',['../neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830cab5a55e97b8511f42fe68559a38f7f138',1,'neorv32_cpu_csr.h']]], + ['csr_5fmisa_5fu_191',['CSR_MISA_U',['../neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830cacd9d71e674d3a6d04984b6df706d9deb',1,'neorv32_cpu_csr.h']]], + ['csr_5fmisa_5fx_192',['CSR_MISA_X',['../neorv32__cpu__csr_8h.html#afed7f00bbb39468f038d9ca6fbac830ca0b119a20be29fcae8fecf2a81c60d193',1,'neorv32_cpu_csr.h']]], + ['csr_5fmscratch_193',['CSR_MSCRATCH',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ae29976bb072639975ad0cdb985c7f004',1,'neorv32_cpu_csr.h']]], + ['csr_5fmstatus_194',['CSR_MSTATUS',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ad0e5de789d6390f750b8af03cdd15450',1,'neorv32_cpu_csr.h']]], + ['csr_5fmstatus_5fmie_195',['CSR_MSTATUS_MIE',['../neorv32__cpu__csr_8h.html#a76b70a2334131e7589d84c1ee96de485ae2603e365b3f1abfb46d53ed6b13dc56',1,'neorv32_cpu_csr.h']]], + ['csr_5fmstatus_5fmpie_196',['CSR_MSTATUS_MPIE',['../neorv32__cpu__csr_8h.html#a76b70a2334131e7589d84c1ee96de485aaa1d482f828ac9cafc40fcfc298bec34',1,'neorv32_cpu_csr.h']]], + ['csr_5fmstatus_5fmpp_5fh_197',['CSR_MSTATUS_MPP_H',['../neorv32__cpu__csr_8h.html#a76b70a2334131e7589d84c1ee96de485a8067c609c2360cab3bafa3c43e03dbf0',1,'neorv32_cpu_csr.h']]], + ['csr_5fmstatus_5fmpp_5fl_198',['CSR_MSTATUS_MPP_L',['../neorv32__cpu__csr_8h.html#a76b70a2334131e7589d84c1ee96de485af0ae9aca74144aa7dbdf656f71cc5c97',1,'neorv32_cpu_csr.h']]], + ['csr_5fmstatus_5fmprv_199',['CSR_MSTATUS_MPRV',['../neorv32__cpu__csr_8h.html#a76b70a2334131e7589d84c1ee96de485a75cefdbdef36b7fc248765b27c606a44',1,'neorv32_cpu_csr.h']]], + ['csr_5fmstatus_5ftw_200',['CSR_MSTATUS_TW',['../neorv32__cpu__csr_8h.html#a76b70a2334131e7589d84c1ee96de485ac94a070f3fe7962e8c49a81545cacf2d',1,'neorv32_cpu_csr.h']]], + ['csr_5fmstatush_201',['CSR_MSTATUSH',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ac2541060307369b2031e9ec07bbd0067',1,'neorv32_cpu_csr.h']]], + ['csr_5fmtinst_202',['CSR_MTINST',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a4f229c169ada239033a1383412ce58c8',1,'neorv32_cpu_csr.h']]], + ['csr_5fmtval_203',['CSR_MTVAL',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a76d30359e3b54197fb53f9939734cf1e',1,'neorv32_cpu_csr.h']]], + ['csr_5fmtvec_204',['CSR_MTVEC',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aa632d218400268df6dc6b289ff088d21',1,'neorv32_cpu_csr.h']]], + ['csr_5fmvendorid_205',['CSR_MVENDORID',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49af5c5a21909aaca2b57f9a15f4bac246b',1,'neorv32_cpu_csr.h']]], + ['csr_5fmxisa_206',['CSR_MXISA',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a396847bcf1634a1602ab117bfb57bdd2',1,'neorv32_cpu_csr.h']]], + ['csr_5fmxisa_5ffastmul_207',['CSR_MXISA_FASTMUL',['../neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387a48e57689f8a5b51d9ee9d648da7efc64',1,'neorv32_cpu_csr.h']]], + ['csr_5fmxisa_5ffastshift_208',['CSR_MXISA_FASTSHIFT',['../neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387ad5ac9e2188757e6c42c159f0c5887868',1,'neorv32_cpu_csr.h']]], + ['csr_5fmxisa_5fis_5fsim_209',['CSR_MXISA_IS_SIM',['../neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387a9b121ec0ad6271b6e07658f861015f6a',1,'neorv32_cpu_csr.h']]], + ['csr_5fmxisa_5frfhwrst_210',['CSR_MXISA_RFHWRST',['../neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387a6843c660d75f33e4252c7fccd4565a2d',1,'neorv32_cpu_csr.h']]], + ['csr_5fmxisa_5fsdext_211',['CSR_MXISA_SDEXT',['../neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387ab6aec595e6aa5ce7c98c7806d23d7af5',1,'neorv32_cpu_csr.h']]], + ['csr_5fmxisa_5fsdtrig_212',['CSR_MXISA_SDTRIG',['../neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387a59eae4272528f589f299ef9cce45af5b',1,'neorv32_cpu_csr.h']]], + ['csr_5fmxisa_5fsmpmp_213',['CSR_MXISA_SMPMP',['../neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387a6938948290d86b0ad25923f35d6c86d3',1,'neorv32_cpu_csr.h']]], + ['csr_5fmxisa_5fzfinx_214',['CSR_MXISA_ZFINX',['../neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387a56ec3195d0d27f362f58fadb2e037ed1',1,'neorv32_cpu_csr.h']]], + ['csr_5fmxisa_5fzicntr_215',['CSR_MXISA_ZICNTR',['../neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387a42a3b78195741af4b6aeeb98cbea46fe',1,'neorv32_cpu_csr.h']]], + ['csr_5fmxisa_5fzicond_216',['CSR_MXISA_ZICOND',['../neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387ab1f289cfaa9f54f7831a2abcdf9fca2e',1,'neorv32_cpu_csr.h']]], + ['csr_5fmxisa_5fzicsr_217',['CSR_MXISA_ZICSR',['../neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387accf1dd12be89e45df1423a5600789f2c',1,'neorv32_cpu_csr.h']]], + ['csr_5fmxisa_5fzifencei_218',['CSR_MXISA_ZIFENCEI',['../neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387a6979d4389ed9f8605d338fc616d29f0e',1,'neorv32_cpu_csr.h']]], + ['csr_5fmxisa_5fzihpm_219',['CSR_MXISA_ZIHPM',['../neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387ac13e6883af3a9da18057462239b9fb34',1,'neorv32_cpu_csr.h']]], + ['csr_5fmxisa_5fzmmul_220',['CSR_MXISA_ZMMUL',['../neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387a79b2b4b20e08ad31b50724a7a27fb20f',1,'neorv32_cpu_csr.h']]], + ['csr_5fmxisa_5fzxcfu_221',['CSR_MXISA_ZXCFU',['../neorv32__cpu__csr_8h.html#af05490a8af176ab4ba945d327d448387af422ae3b5caba59e33a29b5d069597e0',1,'neorv32_cpu_csr.h']]], + ['csr_5fpmpaddr0_222',['CSR_PMPADDR0',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a8941071db6145d34fff842249c0dcb9f',1,'neorv32_cpu_csr.h']]], + ['csr_5fpmpaddr1_223',['CSR_PMPADDR1',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a6a2933f3a1fa243de02db8a795e3ca41',1,'neorv32_cpu_csr.h']]], + ['csr_5fpmpaddr10_224',['CSR_PMPADDR10',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ad97b6fe934a3bed6b02d0c8d81165d60',1,'neorv32_cpu_csr.h']]], + ['csr_5fpmpaddr11_225',['CSR_PMPADDR11',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a3e5708c0f79cf58ae761b6bb8c2a4383',1,'neorv32_cpu_csr.h']]], + ['csr_5fpmpaddr12_226',['CSR_PMPADDR12',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a23026793ee53c8d55d23f63195368a6b',1,'neorv32_cpu_csr.h']]], + ['csr_5fpmpaddr13_227',['CSR_PMPADDR13',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a30879e88b250d3e94d9d9e728ffcc2cc',1,'neorv32_cpu_csr.h']]], + ['csr_5fpmpaddr14_228',['CSR_PMPADDR14',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a91a8b5008b4e08ab34c1516e21bf0ba8',1,'neorv32_cpu_csr.h']]], + ['csr_5fpmpaddr15_229',['CSR_PMPADDR15',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a6879b4bf5d2db92d236b9091df4841f2',1,'neorv32_cpu_csr.h']]], + ['csr_5fpmpaddr2_230',['CSR_PMPADDR2',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aa0b8c0561e8a778dce9c3b86499ffc50',1,'neorv32_cpu_csr.h']]], + ['csr_5fpmpaddr3_231',['CSR_PMPADDR3',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a89bad989197e9358563557311b3c97e9',1,'neorv32_cpu_csr.h']]], + ['csr_5fpmpaddr4_232',['CSR_PMPADDR4',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ace4529c53ad2d46767f86d920eada507',1,'neorv32_cpu_csr.h']]], + ['csr_5fpmpaddr5_233',['CSR_PMPADDR5',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ad9e78f71409fd7783cc2ae7c28b5e42c',1,'neorv32_cpu_csr.h']]], + ['csr_5fpmpaddr6_234',['CSR_PMPADDR6',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49af57b5b7b57cd6e8b3489a27dfd702444',1,'neorv32_cpu_csr.h']]], + ['csr_5fpmpaddr7_235',['CSR_PMPADDR7',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49ae8ea19cf3e527dbc0d36a43dfd1b7346',1,'neorv32_cpu_csr.h']]], + ['csr_5fpmpaddr8_236',['CSR_PMPADDR8',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aec68bf7e26e44170c24599f7c6a8365b',1,'neorv32_cpu_csr.h']]], + ['csr_5fpmpaddr9_237',['CSR_PMPADDR9',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a54d38c8cf364d886eb7ac64463eedf77',1,'neorv32_cpu_csr.h']]], + ['csr_5fpmpcfg0_238',['CSR_PMPCFG0',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49af1a79349e46a4829af78d2cdfd0dc44f',1,'neorv32_cpu_csr.h']]], + ['csr_5fpmpcfg1_239',['CSR_PMPCFG1',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a22eea318ec1ac72cc14e133b71ef4b16',1,'neorv32_cpu_csr.h']]], + ['csr_5fpmpcfg2_240',['CSR_PMPCFG2',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a0c9492f6b956f088847f72b28e7b1446',1,'neorv32_cpu_csr.h']]], + ['csr_5fpmpcfg3_241',['CSR_PMPCFG3',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a067ed3778590ae97dc9b16069f0ed850',1,'neorv32_cpu_csr.h']]], + ['csr_5ftdata1_242',['CSR_TDATA1',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49a80eab0e17f5fe41edde485044674dc57',1,'neorv32_cpu_csr.h']]], + ['csr_5ftdata2_243',['CSR_TDATA2',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49acf336638697242b691b691dc56b9aadc',1,'neorv32_cpu_csr.h']]], + ['csr_5ftinfo_244',['CSR_TINFO',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49af67c819c104f7e3ec34f2cbb847cf83b',1,'neorv32_cpu_csr.h']]], + ['csr_5ftselect_245',['CSR_TSELECT',['../neorv32__cpu__csr_8h.html#ac065a8cc32eed9a69ea1798492a69f49aaae2f0b2e3f5a31dff933868873f6d5d',1,'neorv32_cpu_csr.h']]] +]; diff --git a/sw/search/enumvalues_1.js b/sw/search/enumvalues_1.js new file mode 100644 index 0000000000..e7a8b04b0c --- /dev/null +++ b/sw/search/enumvalues_1.js @@ -0,0 +1,24 @@ +var searchData= +[ + ['dma_5fctrl_5fauto_0',['DMA_CTRL_AUTO',['../neorv32__dma_8h.html#a6716eddb145b80ad38799da3b87cb2a4a5aeeb05d6365d94d92808df2490daa3b',1,'neorv32_dma.h']]], + ['dma_5fctrl_5fbusy_1',['DMA_CTRL_BUSY',['../neorv32__dma_8h.html#a6716eddb145b80ad38799da3b87cb2a4a8e5ff34ac48eea4b352378bb2af47bcb',1,'neorv32_dma.h']]], + ['dma_5fctrl_5fdone_2',['DMA_CTRL_DONE',['../neorv32__dma_8h.html#a6716eddb145b80ad38799da3b87cb2a4a0d51df1bb87dc54d331891c5db787bcc',1,'neorv32_dma.h']]], + ['dma_5fctrl_5fen_3',['DMA_CTRL_EN',['../neorv32__dma_8h.html#a6716eddb145b80ad38799da3b87cb2a4a5f39deea0212f45423243c8100c40838',1,'neorv32_dma.h']]], + ['dma_5fctrl_5ferror_5frd_4',['DMA_CTRL_ERROR_RD',['../neorv32__dma_8h.html#a6716eddb145b80ad38799da3b87cb2a4a539609fc4d80867b3eb98c78206f5f96',1,'neorv32_dma.h']]], + ['dma_5fctrl_5ferror_5fwr_5',['DMA_CTRL_ERROR_WR',['../neorv32__dma_8h.html#a6716eddb145b80ad38799da3b87cb2a4af7e038b0b0e3ac64f5a2c598eb9c5101',1,'neorv32_dma.h']]], + ['dma_5fctrl_5ffence_6',['DMA_CTRL_FENCE',['../neorv32__dma_8h.html#a6716eddb145b80ad38799da3b87cb2a4ace9fdcdfa8784abad30e033c273e7d00',1,'neorv32_dma.h']]], + ['dma_5fctrl_5ffirq_5fsel_5flsb_7',['DMA_CTRL_FIRQ_SEL_LSB',['../neorv32__dma_8h.html#a6716eddb145b80ad38799da3b87cb2a4aaf040e663494b39b890d7171d0a584b9',1,'neorv32_dma.h']]], + ['dma_5fctrl_5ffirq_5fsel_5fmsb_8',['DMA_CTRL_FIRQ_SEL_MSB',['../neorv32__dma_8h.html#a6716eddb145b80ad38799da3b87cb2a4a3eba1f7868f0c985effb69785ced011a',1,'neorv32_dma.h']]], + ['dma_5fctrl_5ffirq_5ftype_9',['DMA_CTRL_FIRQ_TYPE',['../neorv32__dma_8h.html#a6716eddb145b80ad38799da3b87cb2a4aeaf5ee8f6a84668aa15cd3e21f076afe',1,'neorv32_dma.h']]], + ['dma_5fstatus_5fbusy_10',['DMA_STATUS_BUSY',['../neorv32__dma_8h.html#a002cb188ea5156df0ba282e239a6e74bad0f66e962296f5451d73dc1cae1fdc0d',1,'neorv32_dma.h']]], + ['dma_5fstatus_5ferr_5frd_11',['DMA_STATUS_ERR_RD',['../neorv32__dma_8h.html#a002cb188ea5156df0ba282e239a6e74baed7242b847e3cc8cf20d7da99f9b1492',1,'neorv32_dma.h']]], + ['dma_5fstatus_5ferr_5fwr_12',['DMA_STATUS_ERR_WR',['../neorv32__dma_8h.html#a002cb188ea5156df0ba282e239a6e74ba038b6ef194c3db158cb59168f763a7b8',1,'neorv32_dma.h']]], + ['dma_5fstatus_5fidle_13',['DMA_STATUS_IDLE',['../neorv32__dma_8h.html#a002cb188ea5156df0ba282e239a6e74bac9c380cd5729386e5f5673e20b86326f',1,'neorv32_dma.h']]], + ['dma_5fttype_5fdst_5finc_14',['DMA_TTYPE_DST_INC',['../neorv32__dma_8h.html#a33187c5a074d62b46d2262e352edb8d9abb1293915b076e5d37be6724b44ab0da',1,'neorv32_dma.h']]], + ['dma_5fttype_5fendian_15',['DMA_TTYPE_ENDIAN',['../neorv32__dma_8h.html#a33187c5a074d62b46d2262e352edb8d9a37ea8ef1e6b342db330d3885545fc802',1,'neorv32_dma.h']]], + ['dma_5fttype_5fnum_5flsb_16',['DMA_TTYPE_NUM_LSB',['../neorv32__dma_8h.html#a33187c5a074d62b46d2262e352edb8d9a8dba4160c033c763f5102928c471e450',1,'neorv32_dma.h']]], + ['dma_5fttype_5fnum_5fmsb_17',['DMA_TTYPE_NUM_MSB',['../neorv32__dma_8h.html#a33187c5a074d62b46d2262e352edb8d9a61553eee00ed2382565bf826074c44bd',1,'neorv32_dma.h']]], + ['dma_5fttype_5fqsel_5flsb_18',['DMA_TTYPE_QSEL_LSB',['../neorv32__dma_8h.html#a33187c5a074d62b46d2262e352edb8d9afcfdedeca4c4a1def4905660811e31e2',1,'neorv32_dma.h']]], + ['dma_5fttype_5fqsel_5fmsb_19',['DMA_TTYPE_QSEL_MSB',['../neorv32__dma_8h.html#a33187c5a074d62b46d2262e352edb8d9a4217c9a8ac4ccc52bb45944f30a598c5',1,'neorv32_dma.h']]], + ['dma_5fttype_5fsrc_5finc_20',['DMA_TTYPE_SRC_INC',['../neorv32__dma_8h.html#a33187c5a074d62b46d2262e352edb8d9a4b99a30b851851f3388dd4e77effacec',1,'neorv32_dma.h']]] +]; diff --git a/sw/search/enumvalues_2.js b/sw/search/enumvalues_2.js new file mode 100644 index 0000000000..e6f7c9021e --- /dev/null +++ b/sw/search/enumvalues_2.js @@ -0,0 +1,13 @@ +var searchData= +[ + ['error_5fchecksum_0',['ERROR_CHECKSUM',['../bootloader_8c.html#aa0c639898508ff8e4fab6290101f3088a471ebe6c0766abc6fa4e82a09bfdb985',1,'bootloader.c']]], + ['error_5fflash_1',['ERROR_FLASH',['../bootloader_8c.html#aa0c639898508ff8e4fab6290101f3088a684d6723fa25e7651e13d99fb249363c',1,'bootloader.c']]], + ['error_5fsignature_2',['ERROR_SIGNATURE',['../bootloader_8c.html#aa0c639898508ff8e4fab6290101f3088ad41014563cb3ca69ab69b94d43e97caa',1,'bootloader.c']]], + ['error_5fsize_3',['ERROR_SIZE',['../bootloader_8c.html#aa0c639898508ff8e4fab6290101f3088a2d77ed1c715fb969a1faa01c71625f2d',1,'bootloader.c']]], + ['exe_5foffset_5fchecksum_4',['EXE_OFFSET_CHECKSUM',['../bootloader_8c.html#a165a347c51d8aae06a564a2f297f2febabc27a855096a70dca0f8bc148a123be4',1,'bootloader.c']]], + ['exe_5foffset_5fdata_5',['EXE_OFFSET_DATA',['../bootloader_8c.html#a165a347c51d8aae06a564a2f297f2febaea032c54a21057710ef2021638972ce6',1,'bootloader.c']]], + ['exe_5foffset_5fsignature_6',['EXE_OFFSET_SIGNATURE',['../bootloader_8c.html#a165a347c51d8aae06a564a2f297f2feba61100996f309c45b8b628ade2e3acc7f',1,'bootloader.c']]], + ['exe_5foffset_5fsize_7',['EXE_OFFSET_SIZE',['../bootloader_8c.html#a165a347c51d8aae06a564a2f297f2febacc430caa4bff2fef4568c757893fe2fe',1,'bootloader.c']]], + ['exe_5fstream_5fflash_8',['EXE_STREAM_FLASH',['../bootloader_8c.html#abcbf77626fdd0b475d245f836eab7a83a98526cd8f81d570c57d98193b32cf114',1,'bootloader.c']]], + ['exe_5fstream_5fuart_9',['EXE_STREAM_UART',['../bootloader_8c.html#abcbf77626fdd0b475d245f836eab7a83ab149261ddf3f08e44e9d2538e384f58f',1,'bootloader.c']]] +]; diff --git a/sw/search/enumvalues_3.js b/sw/search/enumvalues_3.js new file mode 100644 index 0000000000..0df0a5b234 --- /dev/null +++ b/sw/search/enumvalues_3.js @@ -0,0 +1,5 @@ +var searchData= +[ + ['flash_5fsreg_5fbusy_0',['FLASH_SREG_BUSY',['../bootloader_8c.html#a97299f563ebc1fca4c663b025a15136fa133cd87673ce9a612da494583e03dae9',1,'bootloader.c']]], + ['flash_5fsreg_5fwel_1',['FLASH_SREG_WEL',['../bootloader_8c.html#a97299f563ebc1fca4c663b025a15136fa22e8c983d74430ea0930e37781e88bf9',1,'bootloader.c']]] +]; diff --git a/sw/search/enumvalues_4.js b/sw/search/enumvalues_4.js new file mode 100644 index 0000000000..8d51681688 --- /dev/null +++ b/sw/search/enumvalues_4.js @@ -0,0 +1,10 @@ +var searchData= +[ + ['gptmr_5fctrl_5fen_0',['GPTMR_CTRL_EN',['../neorv32__gptmr_8h.html#a135b0750d4afed16e5867134e3843988abbfa7abcbd80b9c47e83e23e5cefaf90',1,'neorv32_gptmr.h']]], + ['gptmr_5fctrl_5firq_5fclr_1',['GPTMR_CTRL_IRQ_CLR',['../neorv32__gptmr_8h.html#a135b0750d4afed16e5867134e3843988aadb663ad9a0dfd37fc65dffc1a289b38',1,'neorv32_gptmr.h']]], + ['gptmr_5fctrl_5firq_5fpnd_2',['GPTMR_CTRL_IRQ_PND',['../neorv32__gptmr_8h.html#a135b0750d4afed16e5867134e3843988a3a868dc710ab9add083137e4e3fe888a',1,'neorv32_gptmr.h']]], + ['gptmr_5fctrl_5fmode_3',['GPTMR_CTRL_MODE',['../neorv32__gptmr_8h.html#a135b0750d4afed16e5867134e3843988a473870880c0eca71578d6969e816af43',1,'neorv32_gptmr.h']]], + ['gptmr_5fctrl_5fprsc0_4',['GPTMR_CTRL_PRSC0',['../neorv32__gptmr_8h.html#a135b0750d4afed16e5867134e3843988ae4716a7a9e356484a8e478f07920cde3',1,'neorv32_gptmr.h']]], + ['gptmr_5fctrl_5fprsc1_5',['GPTMR_CTRL_PRSC1',['../neorv32__gptmr_8h.html#a135b0750d4afed16e5867134e3843988a1e1e8e516fa4918441e3c77153940298',1,'neorv32_gptmr.h']]], + ['gptmr_5fctrl_5fprsc2_6',['GPTMR_CTRL_PRSC2',['../neorv32__gptmr_8h.html#a135b0750d4afed16e5867134e3843988a185861fbdc5f276735481237ad844833',1,'neorv32_gptmr.h']]] +]; diff --git a/sw/search/enumvalues_5.js b/sw/search/enumvalues_5.js new file mode 100644 index 0000000000..8580a871a3 --- /dev/null +++ b/sw/search/enumvalues_5.js @@ -0,0 +1,15 @@ +var searchData= +[ + ['hpmcnt_5fevent_5fbranch_0',['HPMCNT_EVENT_BRANCH',['../neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfea9e1e2b50352b2555e9c64e76776919a6',1,'neorv32_cpu_csr.h']]], + ['hpmcnt_5fevent_5fbranched_1',['HPMCNT_EVENT_BRANCHED',['../neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfea0f15c5a824cb1678423ac4ef72a5f4f5',1,'neorv32_cpu_csr.h']]], + ['hpmcnt_5fevent_5fcompr_2',['HPMCNT_EVENT_COMPR',['../neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfea685ed663611d988702ec59c254eb61dd',1,'neorv32_cpu_csr.h']]], + ['hpmcnt_5fevent_5fcy_3',['HPMCNT_EVENT_CY',['../neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfea2b683572525adc02ce0910031cfea914',1,'neorv32_cpu_csr.h']]], + ['hpmcnt_5fevent_5fir_4',['HPMCNT_EVENT_IR',['../neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfeaab438295e5f00ffe4c2457a54ee9bfc4',1,'neorv32_cpu_csr.h']]], + ['hpmcnt_5fevent_5fload_5',['HPMCNT_EVENT_LOAD',['../neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfea1a06f216e1a12afa0b90d6e1218b3c91',1,'neorv32_cpu_csr.h']]], + ['hpmcnt_5fevent_5fstore_6',['HPMCNT_EVENT_STORE',['../neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfea6a942852e3cd85616a63addb8e9d76f2',1,'neorv32_cpu_csr.h']]], + ['hpmcnt_5fevent_5ftm_7',['HPMCNT_EVENT_TM',['../neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfea578ef6fc107c22b5cb7be5950f695640',1,'neorv32_cpu_csr.h']]], + ['hpmcnt_5fevent_5ftrap_8',['HPMCNT_EVENT_TRAP',['../neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfea3a4f5bf9251def87a71162dbcf9043c5',1,'neorv32_cpu_csr.h']]], + ['hpmcnt_5fevent_5fwait_5falu_9',['HPMCNT_EVENT_WAIT_ALU',['../neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfeaffbb04d0053ebd079c6cacb4e5e7ed6b',1,'neorv32_cpu_csr.h']]], + ['hpmcnt_5fevent_5fwait_5fdis_10',['HPMCNT_EVENT_WAIT_DIS',['../neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfeabcb123b5b150b4413e5fd48475faab27',1,'neorv32_cpu_csr.h']]], + ['hpmcnt_5fevent_5fwait_5flsu_11',['HPMCNT_EVENT_WAIT_LSU',['../neorv32__cpu__csr_8h.html#a5cb925a3e41efd5e767bb39b3ee60cfea67a59934bc66bc7ccf82d24fe8a18a3b',1,'neorv32_cpu_csr.h']]] +]; diff --git a/sw/search/enumvalues_6.js b/sw/search/enumvalues_6.js new file mode 100644 index 0000000000..9f98fd6357 --- /dev/null +++ b/sw/search/enumvalues_6.js @@ -0,0 +1,33 @@ +var searchData= +[ + ['neoled_5fctrl_5fbufs_5f0_0',['NEOLED_CTRL_BUFS_0',['../neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a3bb5d0d1f78cebccbc8620a0194f43b8',1,'neorv32_neoled.h']]], + ['neoled_5fctrl_5fbufs_5f1_1',['NEOLED_CTRL_BUFS_1',['../neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412aed0a878e73ad501bed3bbe6905974368',1,'neorv32_neoled.h']]], + ['neoled_5fctrl_5fbufs_5f2_2',['NEOLED_CTRL_BUFS_2',['../neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412ae7b9d45c4ef69ca15fa13aa107e68156',1,'neorv32_neoled.h']]], + ['neoled_5fctrl_5fbufs_5f3_3',['NEOLED_CTRL_BUFS_3',['../neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412ac1922a5311e91a74710eddbf86ccc1c1',1,'neorv32_neoled.h']]], + ['neoled_5fctrl_5fen_4',['NEOLED_CTRL_EN',['../neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412af97ab77b33a250d87025c3dd3a21fea7',1,'neorv32_neoled.h']]], + ['neoled_5fctrl_5firq_5fconf_5',['NEOLED_CTRL_IRQ_CONF',['../neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a37421074b86a260b276534b7c4949339',1,'neorv32_neoled.h']]], + ['neoled_5fctrl_5fmode_6',['NEOLED_CTRL_MODE',['../neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412abf6779cbeae87ab55efc9573932fc865',1,'neorv32_neoled.h']]], + ['neoled_5fctrl_5fprsc0_7',['NEOLED_CTRL_PRSC0',['../neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a142ed3fd65e01f853666a1169f920ad0',1,'neorv32_neoled.h']]], + ['neoled_5fctrl_5fprsc1_8',['NEOLED_CTRL_PRSC1',['../neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a0f4178d81ec6fe9a8b0e30230d318a91',1,'neorv32_neoled.h']]], + ['neoled_5fctrl_5fprsc2_9',['NEOLED_CTRL_PRSC2',['../neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a3d8d54c05080fddb16df4176527bafa8',1,'neorv32_neoled.h']]], + ['neoled_5fctrl_5fstrobe_10',['NEOLED_CTRL_STROBE',['../neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a436ad310b025bd3000af37986c193de5',1,'neorv32_neoled.h']]], + ['neoled_5fctrl_5ft_5fone_5fh_5f0_11',['NEOLED_CTRL_T_ONE_H_0',['../neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a770df505d47353f6c9289059c416d9c8',1,'neorv32_neoled.h']]], + ['neoled_5fctrl_5ft_5fone_5fh_5f1_12',['NEOLED_CTRL_T_ONE_H_1',['../neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412aea15666ad4bb9eb1eba5dc9ed96114a6',1,'neorv32_neoled.h']]], + ['neoled_5fctrl_5ft_5fone_5fh_5f2_13',['NEOLED_CTRL_T_ONE_H_2',['../neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a4d362af8c630823b5104401a9c7d734e',1,'neorv32_neoled.h']]], + ['neoled_5fctrl_5ft_5fone_5fh_5f3_14',['NEOLED_CTRL_T_ONE_H_3',['../neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a369f36e73783c2923d07ca333081a4a6',1,'neorv32_neoled.h']]], + ['neoled_5fctrl_5ft_5fone_5fh_5f4_15',['NEOLED_CTRL_T_ONE_H_4',['../neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a0c15850d0ab005b075f1a317646e18b1',1,'neorv32_neoled.h']]], + ['neoled_5fctrl_5ft_5ftot_5f0_16',['NEOLED_CTRL_T_TOT_0',['../neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a44d8f064decabc690ed1f092be2b049b',1,'neorv32_neoled.h']]], + ['neoled_5fctrl_5ft_5ftot_5f1_17',['NEOLED_CTRL_T_TOT_1',['../neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412addf4d6d1fd09f145d8aa497c4a7479c2',1,'neorv32_neoled.h']]], + ['neoled_5fctrl_5ft_5ftot_5f2_18',['NEOLED_CTRL_T_TOT_2',['../neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a42d09d42d39fc0eb2697853c99f4d5b0',1,'neorv32_neoled.h']]], + ['neoled_5fctrl_5ft_5ftot_5f3_19',['NEOLED_CTRL_T_TOT_3',['../neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412acbcd3c046b528e1900e86428da231df2',1,'neorv32_neoled.h']]], + ['neoled_5fctrl_5ft_5ftot_5f4_20',['NEOLED_CTRL_T_TOT_4',['../neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a3f1a0ad71d9fd892829ec0246be343b3',1,'neorv32_neoled.h']]], + ['neoled_5fctrl_5ft_5fzero_5fh_5f0_21',['NEOLED_CTRL_T_ZERO_H_0',['../neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a7285e332ec7c2b3aeb34290e3e60ded7',1,'neorv32_neoled.h']]], + ['neoled_5fctrl_5ft_5fzero_5fh_5f1_22',['NEOLED_CTRL_T_ZERO_H_1',['../neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a1ef56b35c966786c42f2a2f800e30eae',1,'neorv32_neoled.h']]], + ['neoled_5fctrl_5ft_5fzero_5fh_5f2_23',['NEOLED_CTRL_T_ZERO_H_2',['../neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a9d9411382d943c1659b6b761c462319b',1,'neorv32_neoled.h']]], + ['neoled_5fctrl_5ft_5fzero_5fh_5f3_24',['NEOLED_CTRL_T_ZERO_H_3',['../neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412abf2ea111a4ff34b6cb4dd987c5692f5c',1,'neorv32_neoled.h']]], + ['neoled_5fctrl_5ft_5fzero_5fh_5f4_25',['NEOLED_CTRL_T_ZERO_H_4',['../neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a0d5d01b8d30119bb86c1d079f7d5a9ad',1,'neorv32_neoled.h']]], + ['neoled_5fctrl_5ftx_5fbusy_26',['NEOLED_CTRL_TX_BUSY',['../neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a55da98b018c7cc32cd1e80087ed9018e',1,'neorv32_neoled.h']]], + ['neoled_5fctrl_5ftx_5fempty_27',['NEOLED_CTRL_TX_EMPTY',['../neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a23937f0a728da197590e1d383507cb23',1,'neorv32_neoled.h']]], + ['neoled_5fctrl_5ftx_5ffull_28',['NEOLED_CTRL_TX_FULL',['../neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412acfac5269688b2a03794dc17b11f1b983',1,'neorv32_neoled.h']]], + ['neoled_5fctrl_5ftx_5fhalf_29',['NEOLED_CTRL_TX_HALF',['../neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412a16c09df2784cfb6fafffaeaf245f1b73',1,'neorv32_neoled.h']]] +]; diff --git a/sw/search/enumvalues_7.js b/sw/search/enumvalues_7.js new file mode 100644 index 0000000000..c6c6b72de6 --- /dev/null +++ b/sw/search/enumvalues_7.js @@ -0,0 +1,22 @@ +var searchData= +[ + ['onewire_5fctrl_5fbusy_0',['ONEWIRE_CTRL_BUSY',['../neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831aac8933755e80d72e1e9c293198d831b9',1,'neorv32_onewire.h']]], + ['onewire_5fctrl_5fclkdiv0_1',['ONEWIRE_CTRL_CLKDIV0',['../neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831acdfca08f34d7379aaf8505ba3425c6f5',1,'neorv32_onewire.h']]], + ['onewire_5fctrl_5fclkdiv1_2',['ONEWIRE_CTRL_CLKDIV1',['../neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831afa1476a5e04eb4eabf4d7a595eca2df9',1,'neorv32_onewire.h']]], + ['onewire_5fctrl_5fclkdiv2_3',['ONEWIRE_CTRL_CLKDIV2',['../neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831aec9f056072e1db747e74a5c695d2a1df',1,'neorv32_onewire.h']]], + ['onewire_5fctrl_5fclkdiv3_4',['ONEWIRE_CTRL_CLKDIV3',['../neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831ab8600bd09d74e39869259881b84ebfbf',1,'neorv32_onewire.h']]], + ['onewire_5fctrl_5fclkdiv4_5',['ONEWIRE_CTRL_CLKDIV4',['../neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831a32af8c86e7166e02e801727bd261c179',1,'neorv32_onewire.h']]], + ['onewire_5fctrl_5fclkdiv5_6',['ONEWIRE_CTRL_CLKDIV5',['../neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831a789d65fd9b0ab17bffd0d6de9d2e132a',1,'neorv32_onewire.h']]], + ['onewire_5fctrl_5fclkdiv6_7',['ONEWIRE_CTRL_CLKDIV6',['../neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831a27f040454bebc6218b490f7160ea2312',1,'neorv32_onewire.h']]], + ['onewire_5fctrl_5fclkdiv7_8',['ONEWIRE_CTRL_CLKDIV7',['../neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831a8b19096f72ef96a7597fda9be625ed40',1,'neorv32_onewire.h']]], + ['onewire_5fctrl_5fen_9',['ONEWIRE_CTRL_EN',['../neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831ab87882c202f80185278c69e482f147da',1,'neorv32_onewire.h']]], + ['onewire_5fctrl_5fpresence_10',['ONEWIRE_CTRL_PRESENCE',['../neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831a92e1ff9fa10319d64c8d2c6a6d61b37e',1,'neorv32_onewire.h']]], + ['onewire_5fctrl_5fprsc0_11',['ONEWIRE_CTRL_PRSC0',['../neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831abfed6417c3abd7ef94cd18a3b32c4393',1,'neorv32_onewire.h']]], + ['onewire_5fctrl_5fprsc1_12',['ONEWIRE_CTRL_PRSC1',['../neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831aee1e24261e263c70bf2e36dcafc9dc74',1,'neorv32_onewire.h']]], + ['onewire_5fctrl_5fsense_13',['ONEWIRE_CTRL_SENSE',['../neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831af992c94d0b9a7b7b92a5a23366b9a8c6',1,'neorv32_onewire.h']]], + ['onewire_5fctrl_5ftrig_5fbit_14',['ONEWIRE_CTRL_TRIG_BIT',['../neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831a7ecbccef9e77e68caf22ed2c416e1f77',1,'neorv32_onewire.h']]], + ['onewire_5fctrl_5ftrig_5fbyte_15',['ONEWIRE_CTRL_TRIG_BYTE',['../neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831acfd8a56f668ca55dbbaa1714b1235dfe',1,'neorv32_onewire.h']]], + ['onewire_5fctrl_5ftrig_5frst_16',['ONEWIRE_CTRL_TRIG_RST',['../neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831a98624ec944e0413a208cdf54bbbf4c75',1,'neorv32_onewire.h']]], + ['onewire_5fdata_5flsb_17',['ONEWIRE_DATA_LSB',['../neorv32__onewire_8h.html#ae770490afa8662fb8577065531d51368a6ad35475e3f80a8c68ce0caa9c3754a5',1,'neorv32_onewire.h']]], + ['onewire_5fdata_5fmsb_18',['ONEWIRE_DATA_MSB',['../neorv32__onewire_8h.html#ae770490afa8662fb8577065531d51368af967429634efb019ada46bf75f373aa3',1,'neorv32_onewire.h']]] +]; diff --git a/sw/search/enumvalues_8.js b/sw/search/enumvalues_8.js new file mode 100644 index 0000000000..6cd1083c5d --- /dev/null +++ b/sw/search/enumvalues_8.js @@ -0,0 +1,17 @@ +var searchData= +[ + ['pmp_5fna4_0',['PMP_NA4',['../neorv32__cpu__csr_8h.html#a8f2418fb5e2175f35ee2362469ce01f5aae0e0c33b0d034cb50286239f955d892',1,'neorv32_cpu_csr.h']]], + ['pmp_5fnapot_1',['PMP_NAPOT',['../neorv32__cpu__csr_8h.html#a8f2418fb5e2175f35ee2362469ce01f5ad555e9dfc0c00612bdea623617ff2820',1,'neorv32_cpu_csr.h']]], + ['pmp_5foff_2',['PMP_OFF',['../neorv32__cpu__csr_8h.html#a8f2418fb5e2175f35ee2362469ce01f5a003ccfae4aae1dad4fd65d5d4c7737c4',1,'neorv32_cpu_csr.h']]], + ['pmp_5ftor_3',['PMP_TOR',['../neorv32__cpu__csr_8h.html#a8f2418fb5e2175f35ee2362469ce01f5a629a81a205abee94bad9d5bb5dfa26b1',1,'neorv32_cpu_csr.h']]], + ['pmpcfg_5fa_5flsb_4',['PMPCFG_A_LSB',['../neorv32__cpu__csr_8h.html#abc0e8daad1e9beda4d9950452cc930eaaae1e6440956ad6b7cbf6062aa50f43b1',1,'neorv32_cpu_csr.h']]], + ['pmpcfg_5fa_5fmsb_5',['PMPCFG_A_MSB',['../neorv32__cpu__csr_8h.html#abc0e8daad1e9beda4d9950452cc930eaa67ad3243eeb74f86a01efbade76f21e4',1,'neorv32_cpu_csr.h']]], + ['pmpcfg_5fl_6',['PMPCFG_L',['../neorv32__cpu__csr_8h.html#abc0e8daad1e9beda4d9950452cc930eaa59c294bc43d2117bb55e301eec683f14',1,'neorv32_cpu_csr.h']]], + ['pmpcfg_5fr_7',['PMPCFG_R',['../neorv32__cpu__csr_8h.html#abc0e8daad1e9beda4d9950452cc930eaad3aca82a2ab57364e83f677d3d4f71a6',1,'neorv32_cpu_csr.h']]], + ['pmpcfg_5fw_8',['PMPCFG_W',['../neorv32__cpu__csr_8h.html#abc0e8daad1e9beda4d9950452cc930eaa7689905760f917499b1151cced384d2f',1,'neorv32_cpu_csr.h']]], + ['pmpcfg_5fx_9',['PMPCFG_X',['../neorv32__cpu__csr_8h.html#abc0e8daad1e9beda4d9950452cc930eaaec94712deafba09c0cf956c6fd68fa8d',1,'neorv32_cpu_csr.h']]], + ['pwm_5fctrl_5fen_10',['PWM_CTRL_EN',['../neorv32__pwm_8h.html#af350f93b601a92ef56516198d1570b7dafb99fba508460086efdd495d4649c65a',1,'neorv32_pwm.h']]], + ['pwm_5fctrl_5fprsc0_11',['PWM_CTRL_PRSC0',['../neorv32__pwm_8h.html#af350f93b601a92ef56516198d1570b7da01ab6de6ac34be1ed68f22e17acbe274',1,'neorv32_pwm.h']]], + ['pwm_5fctrl_5fprsc1_12',['PWM_CTRL_PRSC1',['../neorv32__pwm_8h.html#af350f93b601a92ef56516198d1570b7daa6fca8a4eecfb99b8f0fa99e187e30bb',1,'neorv32_pwm.h']]], + ['pwm_5fctrl_5fprsc2_13',['PWM_CTRL_PRSC2',['../neorv32__pwm_8h.html#af350f93b601a92ef56516198d1570b7da0fd36a63fd4c37ef3bc4732518ebf13d',1,'neorv32_pwm.h']]] +]; diff --git a/sw/search/enumvalues_9.js b/sw/search/enumvalues_9.js new file mode 100644 index 0000000000..34d19a066c --- /dev/null +++ b/sw/search/enumvalues_9.js @@ -0,0 +1,32 @@ +var searchData= +[ + ['rte_5ftrap_5fbreakpoint_0',['RTE_TRAP_BREAKPOINT',['../neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa463611404367b5910c42dd31c0a218a2',1,'neorv32_rte.h']]], + ['rte_5ftrap_5ffirq_5f0_1',['RTE_TRAP_FIRQ_0',['../neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aab36a403cd7b833439ce7f9a708c33922',1,'neorv32_rte.h']]], + ['rte_5ftrap_5ffirq_5f1_2',['RTE_TRAP_FIRQ_1',['../neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aab199b53a1458017fa5278e0aeecf41fd',1,'neorv32_rte.h']]], + ['rte_5ftrap_5ffirq_5f10_3',['RTE_TRAP_FIRQ_10',['../neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aadebcc4d91aea1364b1481111f1060c52',1,'neorv32_rte.h']]], + ['rte_5ftrap_5ffirq_5f11_4',['RTE_TRAP_FIRQ_11',['../neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aab49ff0110481f22da22a085d2633a0e0',1,'neorv32_rte.h']]], + ['rte_5ftrap_5ffirq_5f12_5',['RTE_TRAP_FIRQ_12',['../neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aaecea4f1d524a33d02324382357b2bcb9',1,'neorv32_rte.h']]], + ['rte_5ftrap_5ffirq_5f13_6',['RTE_TRAP_FIRQ_13',['../neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa609613cf25bb8f2d0e323089d6798220',1,'neorv32_rte.h']]], + ['rte_5ftrap_5ffirq_5f14_7',['RTE_TRAP_FIRQ_14',['../neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aaadd66d9b9c33a6869fa3c30e1e434313',1,'neorv32_rte.h']]], + ['rte_5ftrap_5ffirq_5f15_8',['RTE_TRAP_FIRQ_15',['../neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa1d18312227bfd5332ebcc1f74c979dbe',1,'neorv32_rte.h']]], + ['rte_5ftrap_5ffirq_5f2_9',['RTE_TRAP_FIRQ_2',['../neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa29ffa3108fadc78bf375773c3232c489',1,'neorv32_rte.h']]], + ['rte_5ftrap_5ffirq_5f3_10',['RTE_TRAP_FIRQ_3',['../neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa4a74188fd87ea17a594ac6fe8ddf71be',1,'neorv32_rte.h']]], + ['rte_5ftrap_5ffirq_5f4_11',['RTE_TRAP_FIRQ_4',['../neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa8b39868bf91da54f9ec492918e0c01ff',1,'neorv32_rte.h']]], + ['rte_5ftrap_5ffirq_5f5_12',['RTE_TRAP_FIRQ_5',['../neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa01f562418ddbbb6b84be168673deeea9',1,'neorv32_rte.h']]], + ['rte_5ftrap_5ffirq_5f6_13',['RTE_TRAP_FIRQ_6',['../neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aac9fb28ea8bafff182f12c29d2fad6998',1,'neorv32_rte.h']]], + ['rte_5ftrap_5ffirq_5f7_14',['RTE_TRAP_FIRQ_7',['../neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa73bb84f7b6c7528bec552ac1d3e9ccdb',1,'neorv32_rte.h']]], + ['rte_5ftrap_5ffirq_5f8_15',['RTE_TRAP_FIRQ_8',['../neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa3edbf47bd9a278e100bb808c8bb68308',1,'neorv32_rte.h']]], + ['rte_5ftrap_5ffirq_5f9_16',['RTE_TRAP_FIRQ_9',['../neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa2cd04189d91465dad2bc2a8852406b76',1,'neorv32_rte.h']]], + ['rte_5ftrap_5fi_5faccess_17',['RTE_TRAP_I_ACCESS',['../neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa931a4f314b04233924b01e8245153be4',1,'neorv32_rte.h']]], + ['rte_5ftrap_5fi_5fillegal_18',['RTE_TRAP_I_ILLEGAL',['../neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa48f4d253b260784a1ffaaded508166e2',1,'neorv32_rte.h']]], + ['rte_5ftrap_5fi_5fmisaligned_19',['RTE_TRAP_I_MISALIGNED',['../neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aaf647ff8d55d021379202879627c91d81',1,'neorv32_rte.h']]], + ['rte_5ftrap_5fl_5faccess_20',['RTE_TRAP_L_ACCESS',['../neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa97047b024b72807a0b312979c9359dab',1,'neorv32_rte.h']]], + ['rte_5ftrap_5fl_5fmisaligned_21',['RTE_TRAP_L_MISALIGNED',['../neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa8e2cc9a533ebbc0e1d29c3ec8afbe61f',1,'neorv32_rte.h']]], + ['rte_5ftrap_5fmei_22',['RTE_TRAP_MEI',['../neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aad2a55d5586d33497fd21b1da8aa98fff',1,'neorv32_rte.h']]], + ['rte_5ftrap_5fmenv_5fcall_23',['RTE_TRAP_MENV_CALL',['../neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aaea6027bf0354c3120fa61c8094dd7a1d',1,'neorv32_rte.h']]], + ['rte_5ftrap_5fmsi_24',['RTE_TRAP_MSI',['../neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aadddffa9acdfcce80dd68ad4b26725174',1,'neorv32_rte.h']]], + ['rte_5ftrap_5fmti_25',['RTE_TRAP_MTI',['../neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aacf17d4b2454c43a1cb544e532d247fff',1,'neorv32_rte.h']]], + ['rte_5ftrap_5fs_5faccess_26',['RTE_TRAP_S_ACCESS',['../neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aaa9b8334712ecad0500c7610a25741ec7',1,'neorv32_rte.h']]], + ['rte_5ftrap_5fs_5fmisaligned_27',['RTE_TRAP_S_MISALIGNED',['../neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa85934b3fd8b5268340f84810b3f67232',1,'neorv32_rte.h']]], + ['rte_5ftrap_5fuenv_5fcall_28',['RTE_TRAP_UENV_CALL',['../neorv32__rte_8h.html#ad28f86ab02d89ade2f0bc12e0a8ca70aa155f84a52bace69f81a99de59701decc',1,'neorv32_rte.h']]] +]; diff --git a/sw/search/enumvalues_a.js b/sw/search/enumvalues_a.js new file mode 100644 index 0000000000..16a897b327 --- /dev/null +++ b/sw/search/enumvalues_a.js @@ -0,0 +1,82 @@ +var searchData= +[ + ['sdi_5fctrl_5fcs_5factive_0',['SDI_CTRL_CS_ACTIVE',['../neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6ad288a52f2bdaa1ea6ddbadf7f32a3a63',1,'neorv32_sdi.h']]], + ['sdi_5fctrl_5fen_1',['SDI_CTRL_EN',['../neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6af6016d120844c2d8d8da4fccc09f9809',1,'neorv32_sdi.h']]], + ['sdi_5fctrl_5ffifo_5flsb_2',['SDI_CTRL_FIFO_LSB',['../neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6a840c74518f55028608e2353ec6ce58c4',1,'neorv32_sdi.h']]], + ['sdi_5fctrl_5ffifo_5fmsb_3',['SDI_CTRL_FIFO_MSB',['../neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6ab3b57f906bd3fc16242fa06601ce1716',1,'neorv32_sdi.h']]], + ['sdi_5fctrl_5firq_5frx_5favail_4',['SDI_CTRL_IRQ_RX_AVAIL',['../neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6a2a611e339fd9ae7854931743802ff5c0',1,'neorv32_sdi.h']]], + ['sdi_5fctrl_5firq_5frx_5ffull_5',['SDI_CTRL_IRQ_RX_FULL',['../neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6a051d69f43c2b0f15c5e9e9252c906c9d',1,'neorv32_sdi.h']]], + ['sdi_5fctrl_5firq_5frx_5fhalf_6',['SDI_CTRL_IRQ_RX_HALF',['../neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6af1e2abec3b3bc2ff9ecb2698d933a281',1,'neorv32_sdi.h']]], + ['sdi_5fctrl_5firq_5ftx_5fempty_7',['SDI_CTRL_IRQ_TX_EMPTY',['../neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6a5df074faedb03cf3cc0cfa90eaccd210',1,'neorv32_sdi.h']]], + ['sdi_5fctrl_5firq_5ftx_5fnhalf_8',['SDI_CTRL_IRQ_TX_NHALF',['../neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6a762237a6107ee690276c36108fa1c1ed',1,'neorv32_sdi.h']]], + ['sdi_5fctrl_5frx_5favail_9',['SDI_CTRL_RX_AVAIL',['../neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6ae15186a46909f1a957269b21af6a14a0',1,'neorv32_sdi.h']]], + ['sdi_5fctrl_5frx_5ffull_10',['SDI_CTRL_RX_FULL',['../neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6a45ade3854c01dc1b14a80e3fea29417a',1,'neorv32_sdi.h']]], + ['sdi_5fctrl_5frx_5fhalf_11',['SDI_CTRL_RX_HALF',['../neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6ac9381cffb4da427baf31cdbbeae5e1f4',1,'neorv32_sdi.h']]], + ['sdi_5fctrl_5ftx_5fempty_12',['SDI_CTRL_TX_EMPTY',['../neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6aa9b89463a37e3a9c554195c2f87fb8d8',1,'neorv32_sdi.h']]], + ['sdi_5fctrl_5ftx_5ffull_13',['SDI_CTRL_TX_FULL',['../neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6adb5c4613ce0a6178a01599cf8fd6984a',1,'neorv32_sdi.h']]], + ['sdi_5fctrl_5ftx_5fnhalf_14',['SDI_CTRL_TX_NHALF',['../neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6aeac16a67f250cce5ea420790e80b8bb9',1,'neorv32_sdi.h']]], + ['slink_5fctrl_5fen_15',['SLINK_CTRL_EN',['../neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1a739187f413b7436dc4037187e4a9e86a',1,'neorv32_slink.h']]], + ['slink_5fctrl_5firq_5frx_5ffull_16',['SLINK_CTRL_IRQ_RX_FULL',['../neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1ac8a688706aee72d2027e022b64664309',1,'neorv32_slink.h']]], + ['slink_5fctrl_5firq_5frx_5fhalf_17',['SLINK_CTRL_IRQ_RX_HALF',['../neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1afa9353cd824d1b2833930ce9e922e392',1,'neorv32_slink.h']]], + ['slink_5fctrl_5firq_5frx_5fnempty_18',['SLINK_CTRL_IRQ_RX_NEMPTY',['../neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1a5452eab0fe12d174ec804c4c72060854',1,'neorv32_slink.h']]], + ['slink_5fctrl_5firq_5ftx_5fempty_19',['SLINK_CTRL_IRQ_TX_EMPTY',['../neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1ae06ad5f627f8902e2368e0daff6cfa88',1,'neorv32_slink.h']]], + ['slink_5fctrl_5firq_5ftx_5fnfull_20',['SLINK_CTRL_IRQ_TX_NFULL',['../neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1a8f994f256f57c006c88b9e38df3f54fa',1,'neorv32_slink.h']]], + ['slink_5fctrl_5firq_5ftx_5fnhalf_21',['SLINK_CTRL_IRQ_TX_NHALF',['../neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1a7bf757dbfb1fdaddceaed3a3887003cf',1,'neorv32_slink.h']]], + ['slink_5fctrl_5frx_5fclr_22',['SLINK_CTRL_RX_CLR',['../neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1a156fa3209b2652af6b58b0fdfc6cab1b',1,'neorv32_slink.h']]], + ['slink_5fctrl_5frx_5fempty_23',['SLINK_CTRL_RX_EMPTY',['../neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1ae78f82e54bd9d737bbcbc5c7af0e9d4b',1,'neorv32_slink.h']]], + ['slink_5fctrl_5frx_5ffifo_5flsb_24',['SLINK_CTRL_RX_FIFO_LSB',['../neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1a9c68af961c1147846929ca55e9e4e88c',1,'neorv32_slink.h']]], + ['slink_5fctrl_5frx_5ffifo_5fmsb_25',['SLINK_CTRL_RX_FIFO_MSB',['../neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1a945e2b7eda65dc13ca38eb21c9c4f657',1,'neorv32_slink.h']]], + ['slink_5fctrl_5frx_5ffull_26',['SLINK_CTRL_RX_FULL',['../neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1aa7521fbe691fef233c0dff4053e4493e',1,'neorv32_slink.h']]], + ['slink_5fctrl_5frx_5fhalf_27',['SLINK_CTRL_RX_HALF',['../neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1af695158b9cf5466d87c207f9bd0a688e',1,'neorv32_slink.h']]], + ['slink_5fctrl_5frx_5flast_28',['SLINK_CTRL_RX_LAST',['../neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1a624723683d247668ef44137393e576aa',1,'neorv32_slink.h']]], + ['slink_5fctrl_5ftx_5fclr_29',['SLINK_CTRL_TX_CLR',['../neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1ad366597a44d3dff7dbab4cde72bed82f',1,'neorv32_slink.h']]], + ['slink_5fctrl_5ftx_5fempty_30',['SLINK_CTRL_TX_EMPTY',['../neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1a308cf7829ecca32f7a3da1bd74339854',1,'neorv32_slink.h']]], + ['slink_5fctrl_5ftx_5ffifo_5flsb_31',['SLINK_CTRL_TX_FIFO_LSB',['../neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1aba613343fc17715fc1bb07729588a12d',1,'neorv32_slink.h']]], + ['slink_5fctrl_5ftx_5ffifo_5fmsb_32',['SLINK_CTRL_TX_FIFO_MSB',['../neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1af27a9e6e50b169d3f5efd0a08ba4a943',1,'neorv32_slink.h']]], + ['slink_5fctrl_5ftx_5ffull_33',['SLINK_CTRL_TX_FULL',['../neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1af94314ed65c6a8d9c364d99d7ae960ee',1,'neorv32_slink.h']]], + ['slink_5fctrl_5ftx_5fhalf_34',['SLINK_CTRL_TX_HALF',['../neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1a530b8b76301f36fbda134b330447de78',1,'neorv32_slink.h']]], + ['slink_5ffifo_5fempty_35',['SLINK_FIFO_EMPTY',['../neorv32__slink_8h.html#a84f7fe82f188bd4e68f41549587822bfa9f24886f55b7f78ae8909ea8a573058c',1,'neorv32_slink.h']]], + ['slink_5ffifo_5ffull_36',['SLINK_FIFO_FULL',['../neorv32__slink_8h.html#a84f7fe82f188bd4e68f41549587822bfa2f96e61f0e07ef4ecd40f14e69b69211',1,'neorv32_slink.h']]], + ['slink_5ffifo_5fhalf_37',['SLINK_FIFO_HALF',['../neorv32__slink_8h.html#a84f7fe82f188bd4e68f41549587822bfadc37988b8aee38e85626064b2c3704f9',1,'neorv32_slink.h']]], + ['slink_5froute_5fdst_5flsb_38',['SLINK_ROUTE_DST_LSB',['../neorv32__slink_8h.html#ac3e5e02fd89a357135adca6d28cd0e45a9a2311357bd87c85a5cc45f08b0d8f80',1,'neorv32_slink.h']]], + ['slink_5froute_5fdst_5fmsb_39',['SLINK_ROUTE_DST_MSB',['../neorv32__slink_8h.html#ac3e5e02fd89a357135adca6d28cd0e45a7e8da208ecaf142107587033e2d63ec1',1,'neorv32_slink.h']]], + ['slink_5froute_5fsrc_5flsb_40',['SLINK_ROUTE_SRC_LSB',['../neorv32__slink_8h.html#ac3e5e02fd89a357135adca6d28cd0e45a69942c3a7b7b0550634f4016e639b0c2',1,'neorv32_slink.h']]], + ['slink_5froute_5fsrc_5fmsb_41',['SLINK_ROUTE_SRC_MSB',['../neorv32__slink_8h.html#ac3e5e02fd89a357135adca6d28cd0e45a7b7b0b9bd4fe448cae97a3a21460f983',1,'neorv32_slink.h']]], + ['spi_5fcs_5factive_42',['SPI_CS_ACTIVE',['../neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba5e12c05349444d3d1defff49dec00580',1,'neorv32_spi.h']]], + ['spi_5fctrl_5fbusy_43',['SPI_CTRL_BUSY',['../neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba7957cf1cf3997cd059ed81cba73a688c',1,'neorv32_spi.h']]], + ['spi_5fctrl_5fcdiv0_44',['SPI_CTRL_CDIV0',['../neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3bae6db5cfa843a58d7c09783e7f29fa49f',1,'neorv32_spi.h']]], + ['spi_5fctrl_5fcdiv1_45',['SPI_CTRL_CDIV1',['../neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba0b9ca202963b68b999f94baab50fbc48',1,'neorv32_spi.h']]], + ['spi_5fctrl_5fcdiv2_46',['SPI_CTRL_CDIV2',['../neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba97aaa7a4ffcc6d17a00c4f992e517c46',1,'neorv32_spi.h']]], + ['spi_5fctrl_5fcdiv3_47',['SPI_CTRL_CDIV3',['../neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba85164e4e00b5ccd34158f98f691bca29',1,'neorv32_spi.h']]], + ['spi_5fctrl_5fcpha_48',['SPI_CTRL_CPHA',['../neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba4d787c993152a9417fcd50f76820c7b0',1,'neorv32_spi.h']]], + ['spi_5fctrl_5fcpol_49',['SPI_CTRL_CPOL',['../neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba7661acb97cc8c6dd7f333be4f4a2d315',1,'neorv32_spi.h']]], + ['spi_5fctrl_5fen_50',['SPI_CTRL_EN',['../neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba647a6357971f94b79b7672785c06a4ea',1,'neorv32_spi.h']]], + ['spi_5fctrl_5ffifo_5flsb_51',['SPI_CTRL_FIFO_LSB',['../neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba12f67abd206066651c1d62fc29fafcdb',1,'neorv32_spi.h']]], + ['spi_5fctrl_5ffifo_5fmsb_52',['SPI_CTRL_FIFO_MSB',['../neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba8c0426f70974f0ab129481f2db7cf0ed',1,'neorv32_spi.h']]], + ['spi_5fctrl_5fhighspeed_53',['SPI_CTRL_HIGHSPEED',['../neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3bac38b12af6b8fb6bf2fc6f6ff6baee91e',1,'neorv32_spi.h']]], + ['spi_5fctrl_5firq_5fidle_54',['SPI_CTRL_IRQ_IDLE',['../neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba3f80e9c6ef6445ad769038c955c171a2',1,'neorv32_spi.h']]], + ['spi_5fctrl_5firq_5frx_5favail_55',['SPI_CTRL_IRQ_RX_AVAIL',['../neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba2cd2350ffc819b7198d1833b525c5ca0',1,'neorv32_spi.h']]], + ['spi_5fctrl_5firq_5ftx_5fempty_56',['SPI_CTRL_IRQ_TX_EMPTY',['../neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3bafcdc17528f9f4521c02ec5c473b44622',1,'neorv32_spi.h']]], + ['spi_5fctrl_5firq_5ftx_5fhalf_57',['SPI_CTRL_IRQ_TX_HALF',['../neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba8c18d975418ad444255f80317448d26b',1,'neorv32_spi.h']]], + ['spi_5fctrl_5fprsc0_58',['SPI_CTRL_PRSC0',['../neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3babc927c4ea78433de697a9fe96f47248e',1,'neorv32_spi.h']]], + ['spi_5fctrl_5fprsc1_59',['SPI_CTRL_PRSC1',['../neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba49c38a34b95c034249a094fbc93e0a61',1,'neorv32_spi.h']]], + ['spi_5fctrl_5fprsc2_60',['SPI_CTRL_PRSC2',['../neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba7a5244e443e1fe4ff6b7a2176f90ae7a',1,'neorv32_spi.h']]], + ['spi_5fctrl_5frx_5favail_61',['SPI_CTRL_RX_AVAIL',['../neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba115b097b76b3b99716f54a63c6ce5633',1,'neorv32_spi.h']]], + ['spi_5fctrl_5ftx_5fempty_62',['SPI_CTRL_TX_EMPTY',['../neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba487b87333d33db0a05cd2a229225ffc6',1,'neorv32_spi.h']]], + ['spi_5fctrl_5ftx_5ffull_63',['SPI_CTRL_TX_FULL',['../neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba96860d260b31ee4c232b6b0eb45f7905',1,'neorv32_spi.h']]], + ['spi_5fctrl_5ftx_5fnhalf_64',['SPI_CTRL_TX_NHALF',['../neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3ba5efcaded20b93d2bffeaa4ea813f73b4',1,'neorv32_spi.h']]], + ['spi_5fdata_5fcmd_65',['SPI_DATA_CMD',['../neorv32__spi_8h.html#aab478c23898c0b06cee53a1cbda38bf8a8b565083f989905b8335d9d22a14c4b6',1,'neorv32_spi.h']]], + ['spi_5fdata_5fcsen_66',['SPI_DATA_CSEN',['../neorv32__spi_8h.html#aab478c23898c0b06cee53a1cbda38bf8a5673b6a3382dc5452e3cfcd4e8f3c8a2',1,'neorv32_spi.h']]], + ['spi_5fdata_5flsb_67',['SPI_DATA_LSB',['../neorv32__spi_8h.html#aab478c23898c0b06cee53a1cbda38bf8ae3c36a644c05cea0fccaefb9da90a1b4',1,'neorv32_spi.h']]], + ['spi_5fdata_5fmsb_68',['SPI_DATA_MSB',['../neorv32__spi_8h.html#aab478c23898c0b06cee53a1cbda38bf8a0167ec9c252ee0228ab9d21f4acba600',1,'neorv32_spi.h']]], + ['spi_5fflash_5fcmd_5fpage_5fprogram_69',['SPI_FLASH_CMD_PAGE_PROGRAM',['../bootloader_8c.html#aa5e5723e4cbf83805c3b1197cd401feda31c8d698c551d081a0adeafb988ed49e',1,'bootloader.c']]], + ['spi_5fflash_5fcmd_5fread_70',['SPI_FLASH_CMD_READ',['../bootloader_8c.html#aa5e5723e4cbf83805c3b1197cd401feda6c1994ba2cfd97e0c77dcdf8bbdfdfa6',1,'SPI_FLASH_CMD_READ:&#160;bootloader.c'],['../demo__xip_2main_8c.html#af30de1c8d8502ad374612d308cfbd12ea6c1994ba2cfd97e0c77dcdf8bbdfdfa6',1,'SPI_FLASH_CMD_READ:&#160;main.c']]], + ['spi_5fflash_5fcmd_5fread_5fstatus_71',['SPI_FLASH_CMD_READ_STATUS',['../bootloader_8c.html#aa5e5723e4cbf83805c3b1197cd401feda5fbc6551a10549b38e5ab4a76c38f214',1,'SPI_FLASH_CMD_READ_STATUS:&#160;bootloader.c'],['../demo__xip_2main_8c.html#af30de1c8d8502ad374612d308cfbd12ea5fbc6551a10549b38e5ab4a76c38f214',1,'SPI_FLASH_CMD_READ_STATUS:&#160;main.c']]], + ['spi_5fflash_5fcmd_5fsector_5ferase_72',['SPI_FLASH_CMD_SECTOR_ERASE',['../bootloader_8c.html#aa5e5723e4cbf83805c3b1197cd401fedacd62141d6331f66e31bd252e2a92b836',1,'SPI_FLASH_CMD_SECTOR_ERASE:&#160;bootloader.c'],['../demo__xip_2main_8c.html#af30de1c8d8502ad374612d308cfbd12eacd62141d6331f66e31bd252e2a92b836',1,'SPI_FLASH_CMD_SECTOR_ERASE:&#160;main.c']]], + ['spi_5fflash_5fcmd_5fwake_73',['SPI_FLASH_CMD_WAKE',['../bootloader_8c.html#aa5e5723e4cbf83805c3b1197cd401feda25bf16cd42b1fd1d95e0957b5be137d2',1,'bootloader.c']]], + ['spi_5fflash_5fcmd_5fwrite_74',['SPI_FLASH_CMD_WRITE',['../demo__xip_2main_8c.html#af30de1c8d8502ad374612d308cfbd12ea528cebc54176f6f4c0a8f7f16fb28ca1',1,'main.c']]], + ['spi_5fflash_5fcmd_5fwrite_5fdisable_75',['SPI_FLASH_CMD_WRITE_DISABLE',['../bootloader_8c.html#aa5e5723e4cbf83805c3b1197cd401fedaa91d3c1d788b21fc798a5976c9f0da77',1,'SPI_FLASH_CMD_WRITE_DISABLE:&#160;bootloader.c'],['../demo__xip_2main_8c.html#af30de1c8d8502ad374612d308cfbd12eaa91d3c1d788b21fc798a5976c9f0da77',1,'SPI_FLASH_CMD_WRITE_DISABLE:&#160;main.c']]], + ['spi_5fflash_5fcmd_5fwrite_5fenable_76',['SPI_FLASH_CMD_WRITE_ENABLE',['../bootloader_8c.html#aa5e5723e4cbf83805c3b1197cd401feda152e091e93778f217f8b766298351513',1,'SPI_FLASH_CMD_WRITE_ENABLE:&#160;bootloader.c'],['../demo__xip_2main_8c.html#af30de1c8d8502ad374612d308cfbd12ea152e091e93778f217f8b766298351513',1,'SPI_FLASH_CMD_WRITE_ENABLE:&#160;main.c']]], + ['spi_5fflash_5fsreg_5fwel_77',['SPI_FLASH_SREG_WEL',['../demo__xip_2main_8c.html#adccf1bb8f1f203cb1350f7f2eb15a08ea90f3b76faed13819ee13e574d1bff0c1',1,'main.c']]], + ['spi_5fflash_5fsreg_5fwip_78',['SPI_FLASH_SREG_WIP',['../demo__xip_2main_8c.html#adccf1bb8f1f203cb1350f7f2eb15a08eac84de63bbea3989c71bcc92d1d01cfa4',1,'main.c']]] +]; diff --git a/sw/search/enumvalues_b.js b/sw/search/enumvalues_b.js new file mode 100644 index 0000000000..172efda5a9 --- /dev/null +++ b/sw/search/enumvalues_b.js @@ -0,0 +1,60 @@ +var searchData= +[ + ['trap_5fcode_5fbreakpoint_0',['TRAP_CODE_BREAKPOINT',['../neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a2c9510cb7583a0144f96678fc217335e',1,'neorv32_cpu_csr.h']]], + ['trap_5fcode_5ffirq_5f0_1',['TRAP_CODE_FIRQ_0',['../neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a0cef77904935798d247d8396838297c1',1,'neorv32_cpu_csr.h']]], + ['trap_5fcode_5ffirq_5f1_2',['TRAP_CODE_FIRQ_1',['../neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1ae0b1049ae7f8cbfb6ff216e69ed5dae7',1,'neorv32_cpu_csr.h']]], + ['trap_5fcode_5ffirq_5f10_3',['TRAP_CODE_FIRQ_10',['../neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a4f6b9c6bba91fe04becb776ad22dcf42',1,'neorv32_cpu_csr.h']]], + ['trap_5fcode_5ffirq_5f11_4',['TRAP_CODE_FIRQ_11',['../neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a874dcc43cf8fbbf2e0614e7db9e38334',1,'neorv32_cpu_csr.h']]], + ['trap_5fcode_5ffirq_5f12_5',['TRAP_CODE_FIRQ_12',['../neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a151f01e5f284f876cafafc7427720e4c',1,'neorv32_cpu_csr.h']]], + ['trap_5fcode_5ffirq_5f13_6',['TRAP_CODE_FIRQ_13',['../neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a7c8e97297cc4dcd6d5a1de65a124f3e9',1,'neorv32_cpu_csr.h']]], + ['trap_5fcode_5ffirq_5f14_7',['TRAP_CODE_FIRQ_14',['../neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a821f813de47eb781ab7715f780da3b1e',1,'neorv32_cpu_csr.h']]], + ['trap_5fcode_5ffirq_5f15_8',['TRAP_CODE_FIRQ_15',['../neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1aa4eeafe2f6f59aff01e29461c664a110',1,'neorv32_cpu_csr.h']]], + ['trap_5fcode_5ffirq_5f2_9',['TRAP_CODE_FIRQ_2',['../neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1ad753d3e2563b4fd663430af9f3888dc7',1,'neorv32_cpu_csr.h']]], + ['trap_5fcode_5ffirq_5f3_10',['TRAP_CODE_FIRQ_3',['../neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a356f8485166529503d0fb246bd0aeeb0',1,'neorv32_cpu_csr.h']]], + ['trap_5fcode_5ffirq_5f4_11',['TRAP_CODE_FIRQ_4',['../neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1aaa8e7bb251852ef75a78be71eef0b547',1,'neorv32_cpu_csr.h']]], + ['trap_5fcode_5ffirq_5f5_12',['TRAP_CODE_FIRQ_5',['../neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a5789dfabd8ec265fa0734ddd94e98757',1,'neorv32_cpu_csr.h']]], + ['trap_5fcode_5ffirq_5f6_13',['TRAP_CODE_FIRQ_6',['../neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a809e997f55e83c6812c965655511d473',1,'neorv32_cpu_csr.h']]], + ['trap_5fcode_5ffirq_5f7_14',['TRAP_CODE_FIRQ_7',['../neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1aeab719bcce9e9551bd6da65a7ae08a26',1,'neorv32_cpu_csr.h']]], + ['trap_5fcode_5ffirq_5f8_15',['TRAP_CODE_FIRQ_8',['../neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1abfd21d1380dcacb9282e525da104d916',1,'neorv32_cpu_csr.h']]], + ['trap_5fcode_5ffirq_5f9_16',['TRAP_CODE_FIRQ_9',['../neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a350e762a599479fb2c6d23ccc5ee22b4',1,'neorv32_cpu_csr.h']]], + ['trap_5fcode_5fi_5faccess_17',['TRAP_CODE_I_ACCESS',['../neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a6a0ebfce4e18f36aeb43d5a65445cfe1',1,'neorv32_cpu_csr.h']]], + ['trap_5fcode_5fi_5fillegal_18',['TRAP_CODE_I_ILLEGAL',['../neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1af1ad8f557f3b685b59a913611e1da173',1,'neorv32_cpu_csr.h']]], + ['trap_5fcode_5fi_5fmisaligned_19',['TRAP_CODE_I_MISALIGNED',['../neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a0a8010d7cc91b9557973a7a118828bee',1,'neorv32_cpu_csr.h']]], + ['trap_5fcode_5fl_5faccess_20',['TRAP_CODE_L_ACCESS',['../neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a28448f0c670169140dc28b6794310cea',1,'neorv32_cpu_csr.h']]], + ['trap_5fcode_5fl_5fmisaligned_21',['TRAP_CODE_L_MISALIGNED',['../neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a69e68a954da0bb33d1624484a6777ff9',1,'neorv32_cpu_csr.h']]], + ['trap_5fcode_5fmei_22',['TRAP_CODE_MEI',['../neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a1a412b9d8eefba7880555d34625d2cc0',1,'neorv32_cpu_csr.h']]], + ['trap_5fcode_5fmenv_5fcall_23',['TRAP_CODE_MENV_CALL',['../neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a20e5a2680f2f5956bfa92852d5544eac',1,'neorv32_cpu_csr.h']]], + ['trap_5fcode_5fmsi_24',['TRAP_CODE_MSI',['../neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1ae0cebf99f36ef6be60e4a9d2c9f894b0',1,'neorv32_cpu_csr.h']]], + ['trap_5fcode_5fmti_25',['TRAP_CODE_MTI',['../neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a187ae38819b81672c15808e63c3b46b7',1,'neorv32_cpu_csr.h']]], + ['trap_5fcode_5fs_5faccess_26',['TRAP_CODE_S_ACCESS',['../neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a70bcfc75fe1056d93a3606f78c0cb887',1,'neorv32_cpu_csr.h']]], + ['trap_5fcode_5fs_5fmisaligned_27',['TRAP_CODE_S_MISALIGNED',['../neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1a19708405f9f6300edf6b992c6d408a2d',1,'neorv32_cpu_csr.h']]], + ['trap_5fcode_5fuenv_5fcall_28',['TRAP_CODE_UENV_CALL',['../neorv32__cpu__csr_8h.html#acb0fcbc551fec4c45676ff1317be24e1aa102472d6a264bb92e0581ccaa413e02',1,'neorv32_cpu_csr.h']]], + ['trng_5fctrl_5fdata_5flsb_29',['TRNG_CTRL_DATA_LSB',['../neorv32__trng_8h.html#a1440e1355bf5bff17760992adc156b1aa50bb6e10e245a977dcf29a7a138776c6',1,'neorv32_trng.h']]], + ['trng_5fctrl_5fdata_5fmsb_30',['TRNG_CTRL_DATA_MSB',['../neorv32__trng_8h.html#a1440e1355bf5bff17760992adc156b1aa95620874acc9393a05d670824c0bbed2',1,'neorv32_trng.h']]], + ['trng_5fctrl_5fen_31',['TRNG_CTRL_EN',['../neorv32__trng_8h.html#a1440e1355bf5bff17760992adc156b1aa0bdf0194eefe95884c5c5853a2f7670d',1,'neorv32_trng.h']]], + ['trng_5fctrl_5ffifo_5fclr_32',['TRNG_CTRL_FIFO_CLR',['../neorv32__trng_8h.html#a1440e1355bf5bff17760992adc156b1aabf1bb7bc3b44394c85709edd1c9f03ac',1,'neorv32_trng.h']]], + ['trng_5fctrl_5ffifo_5flsb_33',['TRNG_CTRL_FIFO_LSB',['../neorv32__trng_8h.html#a1440e1355bf5bff17760992adc156b1aa8c0325eede4ffec4530cfd5dc700dc52',1,'neorv32_trng.h']]], + ['trng_5fctrl_5ffifo_5fmsb_34',['TRNG_CTRL_FIFO_MSB',['../neorv32__trng_8h.html#a1440e1355bf5bff17760992adc156b1aa919c3105723e4fe46e341c63cbf276f5',1,'neorv32_trng.h']]], + ['trng_5fctrl_5firq_5fsel_35',['TRNG_CTRL_IRQ_SEL',['../neorv32__trng_8h.html#a1440e1355bf5bff17760992adc156b1aa968a770fe6b172183dd97818e09c63da',1,'neorv32_trng.h']]], + ['trng_5fctrl_5fsim_5fmode_36',['TRNG_CTRL_SIM_MODE',['../neorv32__trng_8h.html#a1440e1355bf5bff17760992adc156b1aaa6990058793ac7d96250693f935837c5',1,'neorv32_trng.h']]], + ['trng_5fctrl_5fvalid_37',['TRNG_CTRL_VALID',['../neorv32__trng_8h.html#a1440e1355bf5bff17760992adc156b1aa2e0079358668db409fb763eaccb93da9',1,'neorv32_trng.h']]], + ['twi_5fctrl_5fbusy_38',['TWI_CTRL_BUSY',['../neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaa443a2a65ee810f428d40a4f8474d8e6d',1,'neorv32_twi.h']]], + ['twi_5fctrl_5fcdiv0_39',['TWI_CTRL_CDIV0',['../neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaa75d3a61b5e642e5d5c1f699c35c26b31',1,'neorv32_twi.h']]], + ['twi_5fctrl_5fcdiv1_40',['TWI_CTRL_CDIV1',['../neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaa4473769463a0c7e4b58ed0b983610674',1,'neorv32_twi.h']]], + ['twi_5fctrl_5fcdiv2_41',['TWI_CTRL_CDIV2',['../neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaaa6db454861ad5be70846ed4f9eb2ea12',1,'neorv32_twi.h']]], + ['twi_5fctrl_5fcdiv3_42',['TWI_CTRL_CDIV3',['../neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaa99e2153a53cc1f9d7cc83d52c698cbcc',1,'neorv32_twi.h']]], + ['twi_5fctrl_5fclkstr_43',['TWI_CTRL_CLKSTR',['../neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaac62d6e3c47a8195a6a9ccc79129bfe48',1,'neorv32_twi.h']]], + ['twi_5fctrl_5fen_44',['TWI_CTRL_EN',['../neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaa43381fe5ab9fe64ebdf76638eba5a694',1,'neorv32_twi.h']]], + ['twi_5fctrl_5ffifo_5flsb_45',['TWI_CTRL_FIFO_LSB',['../neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaa74126d424719b1db61f5e1ab567489fb',1,'neorv32_twi.h']]], + ['twi_5fctrl_5ffifo_5fmsb_46',['TWI_CTRL_FIFO_MSB',['../neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaa183f5b9c3993d04cc9aea2a79e9a4f75',1,'neorv32_twi.h']]], + ['twi_5fctrl_5fprsc0_47',['TWI_CTRL_PRSC0',['../neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaa9033ac6cc891bff0da52449aa4b6a8d9',1,'neorv32_twi.h']]], + ['twi_5fctrl_5fprsc1_48',['TWI_CTRL_PRSC1',['../neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaa8b666cd2e40ca9ba3f9a635f0ed107df',1,'neorv32_twi.h']]], + ['twi_5fctrl_5fprsc2_49',['TWI_CTRL_PRSC2',['../neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaa4d55ed983ca2f94fa9deac196d949b31',1,'neorv32_twi.h']]], + ['twi_5fctrl_5frx_5favail_50',['TWI_CTRL_RX_AVAIL',['../neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaad2798dfabf3a72e6138135e983734671',1,'neorv32_twi.h']]], + ['twi_5fctrl_5ftx_5ffull_51',['TWI_CTRL_TX_FULL',['../neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafaaa0597dc9dea3f6f7a2f19dbcc7a2dabb',1,'neorv32_twi.h']]], + ['twi_5fdcmd_5fack_52',['TWI_DCMD_ACK',['../neorv32__twi_8h.html#a3421852c63baca60fe58c990b1c653d8af64359afd3627db0a79733d00128f3a5',1,'neorv32_twi.h']]], + ['twi_5fdcmd_5fcmd_5fhi_53',['TWI_DCMD_CMD_HI',['../neorv32__twi_8h.html#a3421852c63baca60fe58c990b1c653d8accd7e8be435db3055c27f0a6d5e0201e',1,'neorv32_twi.h']]], + ['twi_5fdcmd_5fcmd_5flo_54',['TWI_DCMD_CMD_LO',['../neorv32__twi_8h.html#a3421852c63baca60fe58c990b1c653d8ab2e20f7f5a5b131c31772341caa97e5e',1,'neorv32_twi.h']]], + ['twi_5fdcmd_5flsb_55',['TWI_DCMD_LSB',['../neorv32__twi_8h.html#a3421852c63baca60fe58c990b1c653d8adf6176c87655bbbb5c7cea9dea29ce56',1,'neorv32_twi.h']]], + ['twi_5fdcmd_5fmsb_56',['TWI_DCMD_MSB',['../neorv32__twi_8h.html#a3421852c63baca60fe58c990b1c653d8ab7f53f7cef06031c1a34db04c602a50d',1,'neorv32_twi.h']]] +]; diff --git a/sw/search/enumvalues_c.js b/sw/search/enumvalues_c.js new file mode 100644 index 0000000000..7d68973c21 --- /dev/null +++ b/sw/search/enumvalues_c.js @@ -0,0 +1,40 @@ +var searchData= +[ + ['uart_5fctrl_5fbaud0_0',['UART_CTRL_BAUD0',['../neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afcad38432e7e050276d4667daf92c1e3fd5',1,'neorv32_uart.h']]], + ['uart_5fctrl_5fbaud1_1',['UART_CTRL_BAUD1',['../neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca1e702002402897eca82bf398504bc439',1,'neorv32_uart.h']]], + ['uart_5fctrl_5fbaud2_2',['UART_CTRL_BAUD2',['../neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca36266026e11f22aca1584bd81cd38cd6',1,'neorv32_uart.h']]], + ['uart_5fctrl_5fbaud3_3',['UART_CTRL_BAUD3',['../neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca58190cd41c2ce69512bea10740d35276',1,'neorv32_uart.h']]], + ['uart_5fctrl_5fbaud4_4',['UART_CTRL_BAUD4',['../neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca81ea805f01b93a59664823b940c7a424',1,'neorv32_uart.h']]], + ['uart_5fctrl_5fbaud5_5',['UART_CTRL_BAUD5',['../neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca5da1d6007af0265fe48ace8469e07833',1,'neorv32_uart.h']]], + ['uart_5fctrl_5fbaud6_6',['UART_CTRL_BAUD6',['../neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca9ac3c1e23d684cb2f67060d6ebe1fa63',1,'neorv32_uart.h']]], + ['uart_5fctrl_5fbaud7_7',['UART_CTRL_BAUD7',['../neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca9c12648f7f058f444db434cd8a8d854e',1,'neorv32_uart.h']]], + ['uart_5fctrl_5fbaud8_8',['UART_CTRL_BAUD8',['../neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca09c311eb1f6b38500e6fcbb6ad9dd9ff',1,'neorv32_uart.h']]], + ['uart_5fctrl_5fbaud9_9',['UART_CTRL_BAUD9',['../neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca697321bddeaa2cac1ea034c418be540e',1,'neorv32_uart.h']]], + ['uart_5fctrl_5fen_10',['UART_CTRL_EN',['../neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca38f6c0e5991f8f80159a388c1080f7c2',1,'neorv32_uart.h']]], + ['uart_5fctrl_5fhwfc_5fen_11',['UART_CTRL_HWFC_EN',['../neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afcacab78fcd440167c5a2c0f5d300c8f07c',1,'neorv32_uart.h']]], + ['uart_5fctrl_5firq_5frx_5ffull_12',['UART_CTRL_IRQ_RX_FULL',['../neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afcae5f01868b170d71a5f3064023c96a82a',1,'neorv32_uart.h']]], + ['uart_5fctrl_5firq_5frx_5fhalf_13',['UART_CTRL_IRQ_RX_HALF',['../neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afcaa219ea3ed5b21f5023bbc5ffa5c5f175',1,'neorv32_uart.h']]], + ['uart_5fctrl_5firq_5frx_5fnempty_14',['UART_CTRL_IRQ_RX_NEMPTY',['../neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca569ea830518914c5330fa14680b02851',1,'neorv32_uart.h']]], + ['uart_5fctrl_5firq_5ftx_5fempty_15',['UART_CTRL_IRQ_TX_EMPTY',['../neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca15b9fca73877aad446a8cd338e228e2c',1,'neorv32_uart.h']]], + ['uart_5fctrl_5firq_5ftx_5fnhalf_16',['UART_CTRL_IRQ_TX_NHALF',['../neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca726b73ef9c44ccc1a45a4230a8bda9d1',1,'neorv32_uart.h']]], + ['uart_5fctrl_5fprsc0_17',['UART_CTRL_PRSC0',['../neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca1ddbca448bb30c77c42499fff1312183',1,'neorv32_uart.h']]], + ['uart_5fctrl_5fprsc1_18',['UART_CTRL_PRSC1',['../neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca9c1d8e8763a653339210ff4e6e3067d2',1,'neorv32_uart.h']]], + ['uart_5fctrl_5fprsc2_19',['UART_CTRL_PRSC2',['../neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca8afd60e4bd3854fab623b91fa4f33f70',1,'neorv32_uart.h']]], + ['uart_5fctrl_5frx_5fclr_20',['UART_CTRL_RX_CLR',['../neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afcaefbef37247d88a7e38e1c53b8a33ed33',1,'neorv32_uart.h']]], + ['uart_5fctrl_5frx_5ffull_21',['UART_CTRL_RX_FULL',['../neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca47c44fa21e51401621c28019025c1166',1,'neorv32_uart.h']]], + ['uart_5fctrl_5frx_5fhalf_22',['UART_CTRL_RX_HALF',['../neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca3fc934d0ce6b36e3e131c6682db22247',1,'neorv32_uart.h']]], + ['uart_5fctrl_5frx_5fnempty_23',['UART_CTRL_RX_NEMPTY',['../neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca2015dd85e361aa0476e847953b62baff',1,'neorv32_uart.h']]], + ['uart_5fctrl_5frx_5fover_24',['UART_CTRL_RX_OVER',['../neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca81a52e0b81018f2cf43e64d74caba632',1,'neorv32_uart.h']]], + ['uart_5fctrl_5fsim_5fmode_25',['UART_CTRL_SIM_MODE',['../neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca42ed376220259ab22c6f837d08273ef1',1,'neorv32_uart.h']]], + ['uart_5fctrl_5ftx_5fbusy_26',['UART_CTRL_TX_BUSY',['../neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca0eb636d8b7961d7073c5c7341b5bbe25',1,'neorv32_uart.h']]], + ['uart_5fctrl_5ftx_5fclr_27',['UART_CTRL_TX_CLR',['../neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca408412a32673cc7f6ea70682e3e61431',1,'neorv32_uart.h']]], + ['uart_5fctrl_5ftx_5fempty_28',['UART_CTRL_TX_EMPTY',['../neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afcac5c044233b6c4162cf862f3d9831ef46',1,'neorv32_uart.h']]], + ['uart_5fctrl_5ftx_5ffull_29',['UART_CTRL_TX_FULL',['../neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca36b4195e5d1f12e1fd1a0d30cad0e411',1,'neorv32_uart.h']]], + ['uart_5fctrl_5ftx_5fnhalf_30',['UART_CTRL_TX_NHALF',['../neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afca5b0e40ab30bdb198f496d09e89d2d0d9',1,'neorv32_uart.h']]], + ['uart_5fdata_5frtx_5flsb_31',['UART_DATA_RTX_LSB',['../neorv32__uart_8h.html#adcf35350a9ea18a59c32c35f528643f2ae70e9f6cd69af724932e79ea7e7f7195',1,'neorv32_uart.h']]], + ['uart_5fdata_5frtx_5fmsb_32',['UART_DATA_RTX_MSB',['../neorv32__uart_8h.html#adcf35350a9ea18a59c32c35f528643f2a19926d013ca202645d38f2c704782ebb',1,'neorv32_uart.h']]], + ['uart_5fdata_5frx_5ffifo_5fsize_5flsb_33',['UART_DATA_RX_FIFO_SIZE_LSB',['../neorv32__uart_8h.html#adcf35350a9ea18a59c32c35f528643f2a43b296e86d1f2ec7400d57655c3180ef',1,'neorv32_uart.h']]], + ['uart_5fdata_5frx_5ffifo_5fsize_5fmsb_34',['UART_DATA_RX_FIFO_SIZE_MSB',['../neorv32__uart_8h.html#adcf35350a9ea18a59c32c35f528643f2a81a82ac0dc5c8c8d7af21553288e3225',1,'neorv32_uart.h']]], + ['uart_5fdata_5ftx_5ffifo_5fsize_5flsb_35',['UART_DATA_TX_FIFO_SIZE_LSB',['../neorv32__uart_8h.html#adcf35350a9ea18a59c32c35f528643f2a6d718ad0bb82a5cb053c117cd2d6ca8e',1,'neorv32_uart.h']]], + ['uart_5fdata_5ftx_5ffifo_5fsize_5fmsb_36',['UART_DATA_TX_FIFO_SIZE_MSB',['../neorv32__uart_8h.html#adcf35350a9ea18a59c32c35f528643f2ada92cbbe278e3e0592eba58c97699529',1,'neorv32_uart.h']]] +]; diff --git a/sw/search/enumvalues_d.js b/sw/search/enumvalues_d.js new file mode 100644 index 0000000000..8d89c7e741 --- /dev/null +++ b/sw/search/enumvalues_d.js @@ -0,0 +1,15 @@ +var searchData= +[ + ['wdt_5fctrl_5fdben_0',['WDT_CTRL_DBEN',['../neorv32__wdt_8h.html#a0a4cb24fd818277c5bb9b10ff519f23ea4b0d994fe5ff8d8004c7f25b621fb3a9',1,'neorv32_wdt.h']]], + ['wdt_5fctrl_5fen_1',['WDT_CTRL_EN',['../neorv32__wdt_8h.html#a0a4cb24fd818277c5bb9b10ff519f23ea0e078b41b69bd6089acceb592e14553f',1,'neorv32_wdt.h']]], + ['wdt_5fctrl_5flock_2',['WDT_CTRL_LOCK',['../neorv32__wdt_8h.html#a0a4cb24fd818277c5bb9b10ff519f23eadc44267502fceb8e7311dfa502fe54d3',1,'neorv32_wdt.h']]], + ['wdt_5fctrl_5frcause_5fhi_3',['WDT_CTRL_RCAUSE_HI',['../neorv32__wdt_8h.html#a0a4cb24fd818277c5bb9b10ff519f23ea6012d63ea4734fc8a063c9edc6785abd',1,'neorv32_wdt.h']]], + ['wdt_5fctrl_5frcause_5flo_4',['WDT_CTRL_RCAUSE_LO',['../neorv32__wdt_8h.html#a0a4cb24fd818277c5bb9b10ff519f23ea0e7d3e97517f97042ce5606dd5247779',1,'neorv32_wdt.h']]], + ['wdt_5fctrl_5fsen_5',['WDT_CTRL_SEN',['../neorv32__wdt_8h.html#a0a4cb24fd818277c5bb9b10ff519f23ea7b7ea5bd390ecbb5ee0d9542ef124148',1,'neorv32_wdt.h']]], + ['wdt_5fctrl_5fstrict_6',['WDT_CTRL_STRICT',['../neorv32__wdt_8h.html#a0a4cb24fd818277c5bb9b10ff519f23ea28dd25b66c4a50d0ea47a16c460031ac',1,'neorv32_wdt.h']]], + ['wdt_5fctrl_5ftimeout_5flsb_7',['WDT_CTRL_TIMEOUT_LSB',['../neorv32__wdt_8h.html#a0a4cb24fd818277c5bb9b10ff519f23ea45df3c9100beb420add34bf71a0e8609',1,'neorv32_wdt.h']]], + ['wdt_5fctrl_5ftimeout_5fmsb_8',['WDT_CTRL_TIMEOUT_MSB',['../neorv32__wdt_8h.html#a0a4cb24fd818277c5bb9b10ff519f23ea25dea2104b29a3c20dcc3782c2d43dc7',1,'neorv32_wdt.h']]], + ['wdt_5frcause_5fext_9',['WDT_RCAUSE_EXT',['../neorv32__wdt_8h.html#a70098b4ee893774864536fb4100ff049ac5fc25cdc29c248b1a570b6095ddded0',1,'neorv32_wdt.h']]], + ['wdt_5frcause_5focd_10',['WDT_RCAUSE_OCD',['../neorv32__wdt_8h.html#a70098b4ee893774864536fb4100ff049a764a7797f17d82f619a6d30c0878bf1e',1,'neorv32_wdt.h']]], + ['wdt_5frcause_5fwdt_11',['WDT_RCAUSE_WDT',['../neorv32__wdt_8h.html#a70098b4ee893774864536fb4100ff049a974e73fb98b6a3591c214eba6071fd3c',1,'neorv32_wdt.h']]] +]; diff --git a/sw/search/enumvalues_e.js b/sw/search/enumvalues_e.js new file mode 100644 index 0000000000..cd1b7db0a7 --- /dev/null +++ b/sw/search/enumvalues_e.js @@ -0,0 +1,25 @@ +var searchData= +[ + ['xip_5fctrl_5fburst_5fen_0',['XIP_CTRL_BURST_EN',['../neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba7ad9f81356d6923d524d1c9e39acdd2c',1,'neorv32_xip.h']]], + ['xip_5fctrl_5fcdiv0_1',['XIP_CTRL_CDIV0',['../neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483cebaf9b56aa629973ce4a9c8ff61a2c90ba3',1,'neorv32_xip.h']]], + ['xip_5fctrl_5fcdiv1_2',['XIP_CTRL_CDIV1',['../neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba68775854b8f2cfa2f32d2eb82a714073',1,'neorv32_xip.h']]], + ['xip_5fctrl_5fcdiv2_3',['XIP_CTRL_CDIV2',['../neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba43d7305e0e0398cb44c99e70dcd96445',1,'neorv32_xip.h']]], + ['xip_5fctrl_5fcdiv3_4',['XIP_CTRL_CDIV3',['../neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba61ffffe9acda5c622b48b6360e357eef',1,'neorv32_xip.h']]], + ['xip_5fctrl_5fcpha_5',['XIP_CTRL_CPHA',['../neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483cebad31736f4a159745be94b487079c4c14d',1,'neorv32_xip.h']]], + ['xip_5fctrl_5fcpol_6',['XIP_CTRL_CPOL',['../neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba95ae19cf5d5140df397ead62f151247f',1,'neorv32_xip.h']]], + ['xip_5fctrl_5fen_7',['XIP_CTRL_EN',['../neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba27658ce3cc81c9e258b73fb02d7f1045',1,'neorv32_xip.h']]], + ['xip_5fctrl_5fhighspeed_8',['XIP_CTRL_HIGHSPEED',['../neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483cebaaeb104a59215667aabb5a751632ae781',1,'neorv32_xip.h']]], + ['xip_5fctrl_5fphy_5fbusy_9',['XIP_CTRL_PHY_BUSY',['../neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba76d2379d0e7ab09e7e686bc886888fa5',1,'neorv32_xip.h']]], + ['xip_5fctrl_5fprsc0_10',['XIP_CTRL_PRSC0',['../neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba67a0c0483eaf92e9cd03e9076be5b50d',1,'neorv32_xip.h']]], + ['xip_5fctrl_5fprsc1_11',['XIP_CTRL_PRSC1',['../neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483cebae47f2e1e8c023fd52e25a3dad5e332af',1,'neorv32_xip.h']]], + ['xip_5fctrl_5fprsc2_12',['XIP_CTRL_PRSC2',['../neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba896815c075a91a8291585eb61b6e0086',1,'neorv32_xip.h']]], + ['xip_5fctrl_5frd_5fcmd_5flsb_13',['XIP_CTRL_RD_CMD_LSB',['../neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba8287016f167727f147806aa11129e05b',1,'neorv32_xip.h']]], + ['xip_5fctrl_5frd_5fcmd_5fmsb_14',['XIP_CTRL_RD_CMD_MSB',['../neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba2c78cd2d32cfba4d89f7aab92f7939e7',1,'neorv32_xip.h']]], + ['xip_5fctrl_5fspi_5fcsen_15',['XIP_CTRL_SPI_CSEN',['../neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba5aadb2c374d34b878b56a660baec2080',1,'neorv32_xip.h']]], + ['xip_5fctrl_5fspi_5fnbytes_5flsb_16',['XIP_CTRL_SPI_NBYTES_LSB',['../neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba23be66e49d28dd12c5321e576d2f0c7a',1,'neorv32_xip.h']]], + ['xip_5fctrl_5fspi_5fnbytes_5fmsb_17',['XIP_CTRL_SPI_NBYTES_MSB',['../neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba5d13c4fe190fcd68dfcbbbe33d2e844c',1,'neorv32_xip.h']]], + ['xip_5fctrl_5fxip_5fabytes_5flsb_18',['XIP_CTRL_XIP_ABYTES_LSB',['../neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba603f9d8d22ae2a6abc61b666bc88a4df',1,'neorv32_xip.h']]], + ['xip_5fctrl_5fxip_5fabytes_5fmsb_19',['XIP_CTRL_XIP_ABYTES_MSB',['../neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba5885ed5fcd2eed969bd921afe8dff4fc',1,'neorv32_xip.h']]], + ['xip_5fctrl_5fxip_5fbusy_20',['XIP_CTRL_XIP_BUSY',['../neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba2c4a47f88d299782b8618b68fb87d59a',1,'neorv32_xip.h']]], + ['xip_5fctrl_5fxip_5fen_21',['XIP_CTRL_XIP_EN',['../neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceba3cbd45a66e05a4fcfc5ec810b8cee937',1,'neorv32_xip.h']]] +]; diff --git a/sw/search/files_0.js b/sw/search/files_0.js new file mode 100644 index 0000000000..b7e62c16c3 --- /dev/null +++ b/sw/search/files_0.js @@ -0,0 +1,4 @@ +var searchData= +[ + ['bootloader_2ec_0',['bootloader.c',['../bootloader_8c.html',1,'']]] +]; diff --git a/sw/search/files_1.js b/sw/search/files_1.js new file mode 100644 index 0000000000..b309f44f74 --- /dev/null +++ b/sw/search/files_1.js @@ -0,0 +1,4 @@ +var searchData= +[ + ['main_2ec_0',['main.c',['../atomic__test_2main_8c.html',1,'(Global Namespace)'],['../bus__explorer_2main_8c.html',1,'(Global Namespace)'],['../demo__blink__led_2main_8c.html',1,'(Global Namespace)'],['../demo__cfs_2main_8c.html',1,'(Global Namespace)'],['../demo__cfu_2main_8c.html',1,'(Global Namespace)'],['../demo__crc_2main_8c.html',1,'(Global Namespace)'],['../demo__dma_2main_8c.html',1,'(Global Namespace)'],['../demo__emulate__unaligned_2main_8c.html',1,'(Global Namespace)'],['../demo__gptmr_2main_8c.html',1,'(Global Namespace)'],['../demo__hpm_2main_8c.html',1,'(Global Namespace)'],['../demo__mtime_2main_8c.html',1,'(Global Namespace)'],['../demo__neopixel_2main_8c.html',1,'(Global Namespace)'],['../demo__newlib_2main_8c.html',1,'(Global Namespace)'],['../demo__onewire_2main_8c.html',1,'(Global Namespace)'],['../demo__pwm_2main_8c.html',1,'(Global Namespace)'],['../demo__sdi_2main_8c.html',1,'(Global Namespace)'],['../demo__slink_2main_8c.html',1,'(Global Namespace)'],['../demo__spi_2main_8c.html',1,'(Global Namespace)'],['../demo__spi__irq_2main_8c.html',1,'(Global Namespace)'],['../demo__trng_2main_8c.html',1,'(Global Namespace)'],['../demo__twi_2main_8c.html',1,'(Global Namespace)'],['../demo__wdt_2main_8c.html',1,'(Global Namespace)'],['../demo__xip_2main_8c.html',1,'(Global Namespace)'],['../demo__xirq_2main_8c.html',1,'(Global Namespace)'],['../float__corner__test_2main_8c.html',1,'(Global Namespace)'],['../floating__point__test_2main_8c.html',1,'(Global Namespace)'],['../game__of__life_2main_8c.html',1,'(Global Namespace)'],['../hello__world_2main_8c.html',1,'(Global Namespace)'],['../processor__check_2main_8c.html',1,'(Global Namespace)']]] +]; diff --git a/sw/search/files_2.js b/sw/search/files_2.js new file mode 100644 index 0000000000..64ce464e68 --- /dev/null +++ b/sw/search/files_2.js @@ -0,0 +1,55 @@ +var searchData= +[ + ['neorv32_2eh_0',['neorv32.h',['../neorv32_8h.html',1,'']]], + ['neorv32_5faux_2ec_1',['neorv32_aux.c',['../neorv32__aux_8c.html',1,'']]], + ['neorv32_5faux_2eh_2',['neorv32_aux.h',['../neorv32__aux_8h.html',1,'']]], + ['neorv32_5fcfs_2ec_3',['neorv32_cfs.c',['../neorv32__cfs_8c.html',1,'']]], + ['neorv32_5fcfs_2eh_4',['neorv32_cfs.h',['../neorv32__cfs_8h.html',1,'']]], + ['neorv32_5fcpu_2ec_5',['neorv32_cpu.c',['../neorv32__cpu_8c.html',1,'']]], + ['neorv32_5fcpu_2eh_6',['neorv32_cpu.h',['../neorv32__cpu_8h.html',1,'']]], + ['neorv32_5fcpu_5famo_2ec_7',['neorv32_cpu_amo.c',['../neorv32__cpu__amo_8c.html',1,'']]], + ['neorv32_5fcpu_5famo_2eh_8',['neorv32_cpu_amo.h',['../neorv32__cpu__amo_8h.html',1,'']]], + ['neorv32_5fcpu_5fcfu_2ec_9',['neorv32_cpu_cfu.c',['../neorv32__cpu__cfu_8c.html',1,'']]], + ['neorv32_5fcpu_5fcfu_2eh_10',['neorv32_cpu_cfu.h',['../neorv32__cpu__cfu_8h.html',1,'']]], + ['neorv32_5fcpu_5fcsr_2eh_11',['neorv32_cpu_csr.h',['../neorv32__cpu__csr_8h.html',1,'']]], + ['neorv32_5fcrc_2ec_12',['neorv32_crc.c',['../neorv32__crc_8c.html',1,'']]], + ['neorv32_5fcrc_2eh_13',['neorv32_crc.h',['../neorv32__crc_8h.html',1,'']]], + ['neorv32_5fdma_2eh_14',['neorv32_dma.h',['../neorv32__dma_8h.html',1,'']]], + ['neorv32_5fgpio_2ec_15',['neorv32_gpio.c',['../neorv32__gpio_8c.html',1,'']]], + ['neorv32_5fgpio_2eh_16',['neorv32_gpio.h',['../neorv32__gpio_8h.html',1,'']]], + ['neorv32_5fgptmr_2ec_17',['neorv32_gptmr.c',['../neorv32__gptmr_8c.html',1,'']]], + ['neorv32_5fgptmr_2eh_18',['neorv32_gptmr.h',['../neorv32__gptmr_8h.html',1,'']]], + ['neorv32_5fintrinsics_2eh_19',['neorv32_intrinsics.h',['../neorv32__intrinsics_8h.html',1,'']]], + ['neorv32_5flegacy_2eh_20',['neorv32_legacy.h',['../neorv32__legacy_8h.html',1,'']]], + ['neorv32_5fmtime_2ec_21',['neorv32_mtime.c',['../neorv32__mtime_8c.html',1,'']]], + ['neorv32_5fmtime_2eh_22',['neorv32_mtime.h',['../neorv32__mtime_8h.html',1,'']]], + ['neorv32_5fneoled_2ec_23',['neorv32_neoled.c',['../neorv32__neoled_8c.html',1,'']]], + ['neorv32_5fneoled_2eh_24',['neorv32_neoled.h',['../neorv32__neoled_8h.html',1,'']]], + ['neorv32_5fonewire_2ec_25',['neorv32_onewire.c',['../neorv32__onewire_8c.html',1,'']]], + ['neorv32_5fonewire_2eh_26',['neorv32_onewire.h',['../neorv32__onewire_8h.html',1,'']]], + ['neorv32_5fpwm_2ec_27',['neorv32_pwm.c',['../neorv32__pwm_8c.html',1,'']]], + ['neorv32_5fpwm_2eh_28',['neorv32_pwm.h',['../neorv32__pwm_8h.html',1,'']]], + ['neorv32_5frte_2ec_29',['neorv32_rte.c',['../neorv32__rte_8c.html',1,'']]], + ['neorv32_5frte_2eh_30',['neorv32_rte.h',['../neorv32__rte_8h.html',1,'']]], + ['neorv32_5fsdi_2ec_31',['neorv32_sdi.c',['../neorv32__sdi_8c.html',1,'']]], + ['neorv32_5fsdi_2eh_32',['neorv32_sdi.h',['../neorv32__sdi_8h.html',1,'']]], + ['neorv32_5fslink_2ec_33',['neorv32_slink.c',['../neorv32__slink_8c.html',1,'']]], + ['neorv32_5fslink_2eh_34',['neorv32_slink.h',['../neorv32__slink_8h.html',1,'']]], + ['neorv32_5fspi_2ec_35',['neorv32_spi.c',['../neorv32__spi_8c.html',1,'']]], + ['neorv32_5fspi_2eh_36',['neorv32_spi.h',['../neorv32__spi_8h.html',1,'']]], + ['neorv32_5fspi_5firq_2ec_37',['neorv32_spi_irq.c',['../neorv32__spi__irq_8c.html',1,'']]], + ['neorv32_5fspi_5firq_2eh_38',['neorv32_spi_irq.h',['../neorv32__spi__irq_8h.html',1,'']]], + ['neorv32_5ftrng_2ec_39',['neorv32_trng.c',['../neorv32__trng_8c.html',1,'']]], + ['neorv32_5ftrng_2eh_40',['neorv32_trng.h',['../neorv32__trng_8h.html',1,'']]], + ['neorv32_5ftwi_2ec_41',['neorv32_twi.c',['../neorv32__twi_8c.html',1,'']]], + ['neorv32_5ftwi_2eh_42',['neorv32_twi.h',['../neorv32__twi_8h.html',1,'']]], + ['neorv32_5fuart_2ec_43',['neorv32_uart.c',['../neorv32__uart_8c.html',1,'']]], + ['neorv32_5fuart_2eh_44',['neorv32_uart.h',['../neorv32__uart_8h.html',1,'']]], + ['neorv32_5fwdt_2ec_45',['neorv32_wdt.c',['../neorv32__wdt_8c.html',1,'']]], + ['neorv32_5fwdt_2eh_46',['neorv32_wdt.h',['../neorv32__wdt_8h.html',1,'']]], + ['neorv32_5fxip_2ec_47',['neorv32_xip.c',['../neorv32__xip_8c.html',1,'']]], + ['neorv32_5fxip_2eh_48',['neorv32_xip.h',['../neorv32__xip_8h.html',1,'']]], + ['neorv32_5fxirq_2ec_49',['neorv32_xirq.c',['../neorv32__xirq_8c.html',1,'']]], + ['neorv32_5fxirq_2eh_50',['neorv32_xirq.h',['../neorv32__xirq_8h.html',1,'']]], + ['neorv32_5fzfinx_5fextension_5fintrinsics_2eh_51',['neorv32_zfinx_extension_intrinsics.h',['../floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html',1,'']]] +]; diff --git a/sw/search/files_3.js b/sw/search/files_3.js new file mode 100644 index 0000000000..8f61d309d5 --- /dev/null +++ b/sw/search/files_3.js @@ -0,0 +1,4 @@ +var searchData= +[ + ['syscalls_2ec_0',['syscalls.c',['../syscalls_8c.html',1,'']]] +]; diff --git a/sw/search/functions_0.js b/sw/search/functions_0.js new file mode 100644 index 0000000000..ea864102f4 --- /dev/null +++ b/sw/search/functions_0.js @@ -0,0 +1,10 @@ +var searchData= +[ + ['_5f_5fneorv32_5frte_5fcore_0',['__neorv32_rte_core',['../neorv32__rte_8c.html#a53f1e006f0bf61deb7ad018f35228873',1,'neorv32_rte.c']]], + ['_5f_5fneorv32_5frte_5fprint_5fhex_5fword_1',['__neorv32_rte_print_hex_word',['../neorv32__rte_8c.html#a01bf6c01f5a8cda2132b9ac98824edc1',1,'neorv32_rte.c']]], + ['_5f_5fneorv32_5fuart_5fitoa_2',['__neorv32_uart_itoa',['../neorv32__uart_8c.html#a3543435827204d82755b0a23bdea1296',1,'neorv32_uart.c']]], + ['_5f_5fneorv32_5fuart_5ftohex_3',['__neorv32_uart_tohex',['../neorv32__uart_8c.html#aefa844cd170e50e088c42829029060f3',1,'neorv32_uart.c']]], + ['_5f_5fneorv32_5fuart_5ftouppercase_4',['__neorv32_uart_touppercase',['../neorv32__uart_8c.html#adf807d0476b475276b8b29924297cda9',1,'neorv32_uart.c']]], + ['_5f_5fneorv32_5fxirq_5fcore_5',['__neorv32_xirq_core',['../neorv32__xirq_8c.html#a14661d628dd31e6bfce89376c6614627',1,'neorv32_xirq.c']]], + ['_5f_5fneorv32_5fxirq_5fdummy_5fhandler_6',['__neorv32_xirq_dummy_handler',['../neorv32__xirq_8c.html#ae4d9362b23a1341c595a4cd239a87091',1,'neorv32_xirq.c']]] +]; diff --git a/sw/search/functions_1.js b/sw/search/functions_1.js new file mode 100644 index 0000000000..caab3fbf1e --- /dev/null +++ b/sw/search/functions_1.js @@ -0,0 +1,5 @@ +var searchData= +[ + ['adaptive_5fproportion_5ftest_0',['adaptive_proportion_test',['../demo__trng_2main_8c.html#a23a91e6fe2cc44f3c29baf0d331e05db',1,'main.c']]], + ['aux_5fprint_5fhex_5fbyte_1',['aux_print_hex_byte',['../bus__explorer_2main_8c.html#ac582208281cd6fce4eb61c234f312ef6',1,'aux_print_hex_byte(uint8_t byte):&#160;main.c'],['../demo__spi_2main_8c.html#ac582208281cd6fce4eb61c234f312ef6',1,'aux_print_hex_byte(uint8_t byte):&#160;main.c']]] +]; diff --git a/sw/search/functions_10.js b/sw/search/functions_10.js new file mode 100644 index 0000000000..43e788b2a1 --- /dev/null +++ b/sw/search/functions_10.js @@ -0,0 +1,14 @@ +var searchData= +[ + ['xip_5fflash_5faccess_5fcheck_0',['xip_flash_access_check',['../demo__xip_2main_8c.html#a23bd7bd7b0808d919fd09ac0a8258498',1,'main.c']]], + ['xip_5fflash_5ferase_5fsector_1',['xip_flash_erase_sector',['../demo__xip_2main_8c.html#a9e0b2714126b6699ddb65485c93293e4',1,'main.c']]], + ['xip_5fflash_5fprogram_2',['xip_flash_program',['../demo__xip_2main_8c.html#a4ddfa8fdc072cadeef18a4a10bc8b174',1,'main.c']]], + ['xirq_5fhandler_5fch0_3',['xirq_handler_ch0',['../demo__xirq_2main_8c.html#a8874ccfc0b56171c359b5c2ceaf2bd80',1,'main.c']]], + ['xirq_5fhandler_5fch1_4',['xirq_handler_ch1',['../demo__xirq_2main_8c.html#abfe0c0bc47a683ba55df2aed63a12d4b',1,'main.c']]], + ['xirq_5fhandler_5fch2_5',['xirq_handler_ch2',['../demo__xirq_2main_8c.html#ae8e3b3236aa2303c2b5e6e421b72cf73',1,'main.c']]], + ['xirq_5fhandler_5fch3_6',['xirq_handler_ch3',['../demo__xirq_2main_8c.html#a99e9ae3088f39995c852b2c53ec21266',1,'main.c']]], + ['xirq_5ftrap_5fhandler0_7',['xirq_trap_handler0',['../processor__check_2main_8c.html#aa4fe70578c4dccabe1e31fae941378cb',1,'main.c']]], + ['xirq_5ftrap_5fhandler1_8',['xirq_trap_handler1',['../processor__check_2main_8c.html#a277cb06ef74e4cfe1ef783069f9b6527',1,'main.c']]], + ['xtea_5fsw_5fdecipher_9',['xtea_sw_decipher',['../demo__cfu_2main_8c.html#a0e980c5d81b1eca90b8073e54099bdb0',1,'main.c']]], + ['xtea_5fsw_5fencipher_10',['xtea_sw_encipher',['../demo__cfu_2main_8c.html#a8dc502bf508491eed1f39c4acf040efb',1,'main.c']]] +]; diff --git a/sw/search/functions_2.js b/sw/search/functions_2.js new file mode 100644 index 0000000000..bdc159bac7 --- /dev/null +++ b/sw/search/functions_2.js @@ -0,0 +1,4 @@ +var searchData= +[ + ['bootloader_5ftrap_5fhandler_0',['bootloader_trap_handler',['../bootloader_8c.html#af13b4b3d5e6597feacf331e6d16b08e9',1,'bootloader.c']]] +]; diff --git a/sw/search/functions_3.js b/sw/search/functions_3.js new file mode 100644 index 0000000000..2bd5c8d7d2 --- /dev/null +++ b/sw/search/functions_3.js @@ -0,0 +1,6 @@ +var searchData= +[ + ['check_5fresult_0',['check_result',['../atomic__test_2main_8c.html#a4f4c6d8481b4100f90955ba5a70428a4',1,'main.c']]], + ['clear_5funiverse_1',['clear_universe',['../game__of__life_2main_8c.html#a819f10c5b644a07eeb069b6e7f12050e',1,'main.c']]], + ['compute_5frate_2',['compute_rate',['../demo__trng_2main_8c.html#abbde1237eed617466fb971a78c3acd1e',1,'main.c']]] +]; diff --git a/sw/search/functions_4.js b/sw/search/functions_4.js new file mode 100644 index 0000000000..91222bca01 --- /dev/null +++ b/sw/search/functions_4.js @@ -0,0 +1,5 @@ +var searchData= +[ + ['dma_5ffirq_5fhandler_0',['dma_firq_handler',['../demo__dma_2main_8c.html#aefcc5abb86a652587ff69be120a66487',1,'main.c']]], + ['dump_5fmemory_1',['dump_memory',['../bus__explorer_2main_8c.html#a6405739c6012158151eb082c31c312da',1,'main.c']]] +]; diff --git a/sw/search/functions_5.js b/sw/search/functions_5.js new file mode 100644 index 0000000000..de76ff3d24 --- /dev/null +++ b/sw/search/functions_5.js @@ -0,0 +1,12 @@ +var searchData= +[ + ['generate_5fhistogram_0',['generate_histogram',['../demo__trng_2main_8c.html#a4e49f5e3feb4bd5755f919cd3310b506',1,'main.c']]], + ['get_5fcell_1',['get_cell',['../game__of__life_2main_8c.html#a6bd541a19c62ea9ec620eaad3f218d16',1,'main.c']]], + ['get_5fexe_2',['get_exe',['../bootloader_8c.html#ac18819795adb6dbdd52b0587e7fbb569',1,'bootloader.c']]], + ['get_5fexe_5fword_3',['get_exe_word',['../bootloader_8c.html#ac58d9f7dc79a549bde1cb50f619c19af',1,'bootloader.c']]], + ['get_5fneighborhood_4',['get_neighborhood',['../game__of__life_2main_8c.html#a977190adaa24a3f49fca1540b51d25a0',1,'main.c']]], + ['get_5ftest_5fvector_5',['get_test_vector',['../float__corner__test_2main_8c.html#a73c70bd0fb6d695cb113eaeb50923e3e',1,'get_test_vector(void):&#160;main.c'],['../floating__point__test_2main_8c.html#a73c70bd0fb6d695cb113eaeb50923e3e',1,'get_test_vector(void):&#160;main.c']]], + ['getchar_6',['getchar',['../neorv32__uart_8c.html#a3e29caa20f7cffe18f410f01278905a8',1,'neorv32_uart.c']]], + ['global_5ftrap_5fhandler_7',['global_trap_handler',['../processor__check_2main_8c.html#a9a64ce0ee69c4c32cecc8b2b2746604c',1,'main.c']]], + ['gptmr_5ffirq_5fhandler_8',['gptmr_firq_handler',['../demo__gptmr_2main_8c.html#a2bd89412466a65329711bfd5c29199c9',1,'main.c']]] +]; diff --git a/sw/search/functions_6.js b/sw/search/functions_6.js new file mode 100644 index 0000000000..2a5ee30c60 --- /dev/null +++ b/sw/search/functions_6.js @@ -0,0 +1,6 @@ +var searchData= +[ + ['hexdump_0',['hexdump',['../bus__explorer_2main_8c.html#a02640a99db37b8d92b9edffc9720a210',1,'main.c']]], + ['hsv2rgb_1',['hsv2rgb',['../demo__neopixel_2main_8c.html#a2736ec755f9e10c80bf66f727f870ffc',1,'main.c']]], + ['hw_5fbreakpoint_5fhandler_2',['hw_breakpoint_handler',['../processor__check_2main_8c.html#a31d9e432f6a368e6222f5e0907eeb6f4',1,'main.c']]] +]; diff --git a/sw/search/functions_7.js b/sw/search/functions_7.js new file mode 100644 index 0000000000..c8f1f6cc6a --- /dev/null +++ b/sw/search/functions_7.js @@ -0,0 +1,5 @@ +var searchData= +[ + ['main_0',['main',['../bootloader_8c.html#a840291bc02cba5474a4cb46a9b9566fe',1,'main(void):&#160;bootloader.c'],['../atomic__test_2main_8c.html#ae66f6b31b5ad750f1fe042a706a4e3d4',1,'main():&#160;main.c'],['../bus__explorer_2main_8c.html#ae66f6b31b5ad750f1fe042a706a4e3d4',1,'main():&#160;main.c'],['../demo__blink__led_2main_8c.html#ae66f6b31b5ad750f1fe042a706a4e3d4',1,'main():&#160;main.c'],['../demo__cfs_2main_8c.html#ae66f6b31b5ad750f1fe042a706a4e3d4',1,'main():&#160;main.c'],['../demo__cfu_2main_8c.html#ae66f6b31b5ad750f1fe042a706a4e3d4',1,'main():&#160;main.c'],['../demo__crc_2main_8c.html#ae66f6b31b5ad750f1fe042a706a4e3d4',1,'main():&#160;main.c'],['../demo__dma_2main_8c.html#ae66f6b31b5ad750f1fe042a706a4e3d4',1,'main():&#160;main.c'],['../demo__emulate__unaligned_2main_8c.html#ae66f6b31b5ad750f1fe042a706a4e3d4',1,'main():&#160;main.c'],['../demo__gptmr_2main_8c.html#ae66f6b31b5ad750f1fe042a706a4e3d4',1,'main():&#160;main.c'],['../demo__hpm_2main_8c.html#ae66f6b31b5ad750f1fe042a706a4e3d4',1,'main():&#160;main.c'],['../demo__mtime_2main_8c.html#ae66f6b31b5ad750f1fe042a706a4e3d4',1,'main():&#160;main.c'],['../demo__neopixel_2main_8c.html#ae66f6b31b5ad750f1fe042a706a4e3d4',1,'main():&#160;main.c'],['../demo__newlib_2main_8c.html#ae66f6b31b5ad750f1fe042a706a4e3d4',1,'main():&#160;main.c'],['../demo__onewire_2main_8c.html#ae66f6b31b5ad750f1fe042a706a4e3d4',1,'main():&#160;main.c'],['../demo__pwm_2main_8c.html#ae66f6b31b5ad750f1fe042a706a4e3d4',1,'main():&#160;main.c'],['../demo__sdi_2main_8c.html#ae66f6b31b5ad750f1fe042a706a4e3d4',1,'main():&#160;main.c'],['../demo__slink_2main_8c.html#ae66f6b31b5ad750f1fe042a706a4e3d4',1,'main():&#160;main.c'],['../demo__spi_2main_8c.html#ae66f6b31b5ad750f1fe042a706a4e3d4',1,'main():&#160;main.c'],['../demo__spi__irq_2main_8c.html#ae66f6b31b5ad750f1fe042a706a4e3d4',1,'main():&#160;main.c'],['../demo__trng_2main_8c.html#a840291bc02cba5474a4cb46a9b9566fe',1,'main(void):&#160;main.c'],['../demo__twi_2main_8c.html#ae66f6b31b5ad750f1fe042a706a4e3d4',1,'main():&#160;main.c'],['../demo__wdt_2main_8c.html#ae66f6b31b5ad750f1fe042a706a4e3d4',1,'main():&#160;main.c'],['../demo__xip_2main_8c.html#ae66f6b31b5ad750f1fe042a706a4e3d4',1,'main():&#160;main.c'],['../demo__xirq_2main_8c.html#ae66f6b31b5ad750f1fe042a706a4e3d4',1,'main():&#160;main.c'],['../float__corner__test_2main_8c.html#ae66f6b31b5ad750f1fe042a706a4e3d4',1,'main():&#160;main.c'],['../floating__point__test_2main_8c.html#ae66f6b31b5ad750f1fe042a706a4e3d4',1,'main():&#160;main.c'],['../game__of__life_2main_8c.html#a840291bc02cba5474a4cb46a9b9566fe',1,'main(void):&#160;main.c'],['../hello__world_2main_8c.html#ae66f6b31b5ad750f1fe042a706a4e3d4',1,'main():&#160;main.c'],['../processor__check_2main_8c.html#ae66f6b31b5ad750f1fe042a706a4e3d4',1,'main():&#160;main.c']]], + ['mtime_5firq_5fhandler_1',['mtime_irq_handler',['../demo__mtime_2main_8c.html#a329137855a7c2e098715a0771c5585d7',1,'main.c']]] +]; diff --git a/sw/search/functions_8.js b/sw/search/functions_8.js new file mode 100644 index 0000000000..c07dd614b1 --- /dev/null +++ b/sw/search/functions_8.js @@ -0,0 +1,231 @@ +var searchData= +[ + ['neorv32_5faux_5fdate2unixtime_0',['neorv32_aux_date2unixtime',['../neorv32__aux_8c.html#a94aa8369ba5f4ebdf5628fcb1ab2ba1c',1,'neorv32_aux_date2unixtime(date_t *date):&#160;neorv32_aux.c'],['../neorv32__aux_8h.html#a94aa8369ba5f4ebdf5628fcb1ab2ba1c',1,'neorv32_aux_date2unixtime(date_t *date):&#160;neorv32_aux.c']]], + ['neorv32_5faux_5fhexstr2uint64_1',['neorv32_aux_hexstr2uint64',['../neorv32__aux_8c.html#aec4703f369e1567c22f140d2ec9daafc',1,'neorv32_aux_hexstr2uint64(char *buffer, uint8_t length):&#160;neorv32_aux.c'],['../neorv32__aux_8h.html#aec4703f369e1567c22f140d2ec9daafc',1,'neorv32_aux_hexstr2uint64(char *buffer, uint8_t length):&#160;neorv32_aux.c']]], + ['neorv32_5faux_5funixtime2date_2',['neorv32_aux_unixtime2date',['../neorv32__aux_8c.html#a885a81838a91b57797e849cb835c6887',1,'neorv32_aux_unixtime2date(uint64_t unixtime, date_t *date):&#160;neorv32_aux.c'],['../neorv32__aux_8h.html#a885a81838a91b57797e849cb835c6887',1,'neorv32_aux_unixtime2date(uint64_t unixtime, date_t *date):&#160;neorv32_aux.c']]], + ['neorv32_5faux_5fxorshift32_3',['neorv32_aux_xorshift32',['../neorv32__aux_8c.html#aff31dd983f75f70eeae331c65acaa50e',1,'neorv32_aux_xorshift32(void):&#160;neorv32_aux.c'],['../neorv32__aux_8h.html#aff31dd983f75f70eeae331c65acaa50e',1,'neorv32_aux_xorshift32(void):&#160;neorv32_aux.c']]], + ['neorv32_5fcfs_5favailable_4',['neorv32_cfs_available',['../neorv32__cfs_8c.html#abac96dfaefe433eca1c0b93fa6183d2e',1,'neorv32_cfs_available(void):&#160;neorv32_cfs.c'],['../neorv32__cfs_8h.html#abac96dfaefe433eca1c0b93fa6183d2e',1,'neorv32_cfs_available(void):&#160;neorv32_cfs.c']]], + ['neorv32_5fcpu_5famoaddw_5',['neorv32_cpu_amoaddw',['../neorv32__cpu__amo_8c.html#ada27ec89b2530f7b7f14de947cc82bf9',1,'neorv32_cpu_amoaddw(uint32_t addr, uint32_t wdata):&#160;neorv32_cpu_amo.c'],['../neorv32__cpu__amo_8h.html#ada27ec89b2530f7b7f14de947cc82bf9',1,'neorv32_cpu_amoaddw(uint32_t addr, uint32_t wdata):&#160;neorv32_cpu_amo.c']]], + ['neorv32_5fcpu_5famoandw_6',['neorv32_cpu_amoandw',['../neorv32__cpu__amo_8c.html#a9b4540dadbfd5da907117570d8006e36',1,'neorv32_cpu_amoandw(uint32_t addr, uint32_t wdata):&#160;neorv32_cpu_amo.c'],['../neorv32__cpu__amo_8h.html#a9b4540dadbfd5da907117570d8006e36',1,'neorv32_cpu_amoandw(uint32_t addr, uint32_t wdata):&#160;neorv32_cpu_amo.c']]], + ['neorv32_5fcpu_5famolr_7',['neorv32_cpu_amolr',['../neorv32__cpu__amo_8h.html#ad4437bbc61a4e40d7d01dfe9459f6639',1,'neorv32_cpu_amo.h']]], + ['neorv32_5fcpu_5famomaxuw_8',['neorv32_cpu_amomaxuw',['../neorv32__cpu__amo_8c.html#a31a6a3b5a33655f4a7b27d4c85b75f07',1,'neorv32_cpu_amomaxuw(uint32_t addr, uint32_t wdata):&#160;neorv32_cpu_amo.c'],['../neorv32__cpu__amo_8h.html#a31a6a3b5a33655f4a7b27d4c85b75f07',1,'neorv32_cpu_amomaxuw(uint32_t addr, uint32_t wdata):&#160;neorv32_cpu_amo.c']]], + ['neorv32_5fcpu_5famomaxw_9',['neorv32_cpu_amomaxw',['../neorv32__cpu__amo_8c.html#a62cf36637d7a04079228acecfe8a5cf3',1,'neorv32_cpu_amomaxw(uint32_t addr, int32_t wdata):&#160;neorv32_cpu_amo.c'],['../neorv32__cpu__amo_8h.html#a62cf36637d7a04079228acecfe8a5cf3',1,'neorv32_cpu_amomaxw(uint32_t addr, int32_t wdata):&#160;neorv32_cpu_amo.c']]], + ['neorv32_5fcpu_5famominuw_10',['neorv32_cpu_amominuw',['../neorv32__cpu__amo_8c.html#a1281e18b95cd525073e1123c5d04e9e2',1,'neorv32_cpu_amominuw(uint32_t addr, uint32_t wdata):&#160;neorv32_cpu_amo.c'],['../neorv32__cpu__amo_8h.html#a1281e18b95cd525073e1123c5d04e9e2',1,'neorv32_cpu_amominuw(uint32_t addr, uint32_t wdata):&#160;neorv32_cpu_amo.c']]], + ['neorv32_5fcpu_5famominw_11',['neorv32_cpu_amominw',['../neorv32__cpu__amo_8c.html#a8e383fb8825538b5579d5ce075830697',1,'neorv32_cpu_amominw(uint32_t addr, int32_t wdata):&#160;neorv32_cpu_amo.c'],['../neorv32__cpu__amo_8h.html#a8e383fb8825538b5579d5ce075830697',1,'neorv32_cpu_amominw(uint32_t addr, int32_t wdata):&#160;neorv32_cpu_amo.c']]], + ['neorv32_5fcpu_5famoorw_12',['neorv32_cpu_amoorw',['../neorv32__cpu__amo_8c.html#adc80b1f2b3a4e70fee44c0edb08fc402',1,'neorv32_cpu_amoorw(uint32_t addr, uint32_t wdata):&#160;neorv32_cpu_amo.c'],['../neorv32__cpu__amo_8h.html#adc80b1f2b3a4e70fee44c0edb08fc402',1,'neorv32_cpu_amoorw(uint32_t addr, uint32_t wdata):&#160;neorv32_cpu_amo.c']]], + ['neorv32_5fcpu_5famosc_13',['neorv32_cpu_amosc',['../neorv32__cpu__amo_8h.html#a5e73eaa273c41a06972e862976fda53c',1,'neorv32_cpu_amo.h']]], + ['neorv32_5fcpu_5famoswapw_14',['neorv32_cpu_amoswapw',['../neorv32__cpu__amo_8c.html#aad0d96e61bacc3af13ff471dd44ca8e9',1,'neorv32_cpu_amoswapw(uint32_t addr, uint32_t wdata):&#160;neorv32_cpu_amo.c'],['../neorv32__cpu__amo_8h.html#aad0d96e61bacc3af13ff471dd44ca8e9',1,'neorv32_cpu_amoswapw(uint32_t addr, uint32_t wdata):&#160;neorv32_cpu_amo.c']]], + ['neorv32_5fcpu_5famoxorw_15',['neorv32_cpu_amoxorw',['../neorv32__cpu__amo_8c.html#a65b67f48356fa9b30596485473311377',1,'neorv32_cpu_amoxorw(uint32_t addr, uint32_t wdata):&#160;neorv32_cpu_amo.c'],['../neorv32__cpu__amo_8h.html#a65b67f48356fa9b30596485473311377',1,'neorv32_cpu_amoxorw(uint32_t addr, uint32_t wdata):&#160;neorv32_cpu_amo.c']]], + ['neorv32_5fcpu_5fcfu_5favailable_16',['neorv32_cpu_cfu_available',['../neorv32__cpu__cfu_8c.html#a13019b8afa1a80c0e5c24eb4d72e75c1',1,'neorv32_cpu_cfu_available(void):&#160;neorv32_cpu_cfu.c'],['../neorv32__cpu__cfu_8h.html#a13019b8afa1a80c0e5c24eb4d72e75c1',1,'neorv32_cpu_cfu_available(void):&#160;neorv32_cpu_cfu.c']]], + ['neorv32_5fcpu_5fcsr_5fclr_17',['neorv32_cpu_csr_clr',['../neorv32__cpu_8h.html#ab8f533ddbc3a3af5e3bca2287ac10122',1,'neorv32_cpu.h']]], + ['neorv32_5fcpu_5fcsr_5fread_18',['neorv32_cpu_csr_read',['../neorv32__cpu_8h.html#aab7a9f9cf608599f2b124dd499cb8418',1,'neorv32_cpu.h']]], + ['neorv32_5fcpu_5fcsr_5fset_19',['neorv32_cpu_csr_set',['../neorv32__cpu_8h.html#a25a09de97229aac839ef6f74da604acf',1,'neorv32_cpu.h']]], + ['neorv32_5fcpu_5fcsr_5fwrite_20',['neorv32_cpu_csr_write',['../neorv32__cpu_8h.html#afb5ef6e0b1a3e26570edfd8379490455',1,'neorv32_cpu.h']]], + ['neorv32_5fcpu_5fdelay_5fms_21',['neorv32_cpu_delay_ms',['../neorv32__cpu_8c.html#aa9027535b13d9f9325e734997fc4a137',1,'neorv32_cpu_delay_ms(uint32_t time_ms):&#160;neorv32_cpu.c'],['../neorv32__cpu_8h.html#aa9027535b13d9f9325e734997fc4a137',1,'neorv32_cpu_delay_ms(uint32_t time_ms):&#160;neorv32_cpu.c']]], + ['neorv32_5fcpu_5fget_5fclk_5ffrom_5fprsc_22',['neorv32_cpu_get_clk_from_prsc',['../neorv32__cpu_8c.html#a8346fb926f84f3d7bccbb4741105505f',1,'neorv32_cpu_get_clk_from_prsc(int prsc):&#160;neorv32_cpu.c'],['../neorv32__cpu_8h.html#a8346fb926f84f3d7bccbb4741105505f',1,'neorv32_cpu_get_clk_from_prsc(int prsc):&#160;neorv32_cpu.c']]], + ['neorv32_5fcpu_5fget_5fcycle_23',['neorv32_cpu_get_cycle',['../neorv32__cpu_8c.html#ac3fd7dc7cd1e0a08225c41820af27f92',1,'neorv32_cpu_get_cycle(void):&#160;neorv32_cpu.c'],['../neorv32__cpu_8h.html#ac3fd7dc7cd1e0a08225c41820af27f92',1,'neorv32_cpu_get_cycle(void):&#160;neorv32_cpu.c']]], + ['neorv32_5fcpu_5fget_5finstret_24',['neorv32_cpu_get_instret',['../neorv32__cpu_8c.html#a387aa304770b05594c4acca128a60a75',1,'neorv32_cpu_get_instret(void):&#160;neorv32_cpu.c'],['../neorv32__cpu_8h.html#a387aa304770b05594c4acca128a60a75',1,'neorv32_cpu_get_instret(void):&#160;neorv32_cpu.c']]], + ['neorv32_5fcpu_5fgoto_5fuser_5fmode_25',['neorv32_cpu_goto_user_mode',['../neorv32__cpu_8c.html#aca49efb45d3808ad76cf65ba291f546d',1,'neorv32_cpu_goto_user_mode(void):&#160;neorv32_cpu.c'],['../neorv32__cpu_8h.html#aca49efb45d3808ad76cf65ba291f546d',1,'neorv32_cpu_goto_user_mode(void):&#160;neorv32_cpu.c']]], + ['neorv32_5fcpu_5fhpm_5fget_5fnum_5fcounters_26',['neorv32_cpu_hpm_get_num_counters',['../neorv32__cpu_8c.html#a70f49b80322aa457f29f7671f94a183d',1,'neorv32_cpu_hpm_get_num_counters(void):&#160;neorv32_cpu.c'],['../neorv32__cpu_8h.html#a70f49b80322aa457f29f7671f94a183d',1,'neorv32_cpu_hpm_get_num_counters(void):&#160;neorv32_cpu.c']]], + ['neorv32_5fcpu_5fhpm_5fget_5fsize_27',['neorv32_cpu_hpm_get_size',['../neorv32__cpu_8c.html#adb3ae542bbb0ddf9f562a4e42bc24d10',1,'neorv32_cpu_hpm_get_size(void):&#160;neorv32_cpu.c'],['../neorv32__cpu_8h.html#adb3ae542bbb0ddf9f562a4e42bc24d10',1,'neorv32_cpu_hpm_get_size(void):&#160;neorv32_cpu.c']]], + ['neorv32_5fcpu_5fload_5fsigned_5fbyte_28',['neorv32_cpu_load_signed_byte',['../neorv32__cpu_8h.html#a31f903596ab1bcddea79fdf608eaa666',1,'neorv32_cpu.h']]], + ['neorv32_5fcpu_5fload_5fsigned_5fhalf_29',['neorv32_cpu_load_signed_half',['../neorv32__cpu_8h.html#ae9c8b6c681536ddea3aff0e63f30ef70',1,'neorv32_cpu.h']]], + ['neorv32_5fcpu_5fload_5funsigned_5fbyte_30',['neorv32_cpu_load_unsigned_byte',['../neorv32__cpu_8h.html#ac54ec9b59e17c7cd9b9907abee82ce95',1,'neorv32_cpu.h']]], + ['neorv32_5fcpu_5fload_5funsigned_5fhalf_31',['neorv32_cpu_load_unsigned_half',['../neorv32__cpu_8h.html#a32544cd652debb4affb308806a115d5b',1,'neorv32_cpu.h']]], + ['neorv32_5fcpu_5fload_5funsigned_5fword_32',['neorv32_cpu_load_unsigned_word',['../neorv32__cpu_8h.html#a3b6cf445e2136486564ef3d3473c91dd',1,'neorv32_cpu.h']]], + ['neorv32_5fcpu_5fpmp_5fconfigure_5fregion_33',['neorv32_cpu_pmp_configure_region',['../neorv32__cpu_8c.html#aa458a700619b2f7666cfcffe02ec2e2c',1,'neorv32_cpu_pmp_configure_region(int index, uint32_t addr, uint8_t config):&#160;neorv32_cpu.c'],['../neorv32__cpu_8h.html#aa458a700619b2f7666cfcffe02ec2e2c',1,'neorv32_cpu_pmp_configure_region(int index, uint32_t addr, uint8_t config):&#160;neorv32_cpu.c']]], + ['neorv32_5fcpu_5fpmp_5fget_5fgranularity_34',['neorv32_cpu_pmp_get_granularity',['../neorv32__cpu_8c.html#ad4f8160f4821b6691e9682ef60c7cd7b',1,'neorv32_cpu_pmp_get_granularity(void):&#160;neorv32_cpu.c'],['../neorv32__cpu_8h.html#ad4f8160f4821b6691e9682ef60c7cd7b',1,'neorv32_cpu_pmp_get_granularity(void):&#160;neorv32_cpu.c']]], + ['neorv32_5fcpu_5fpmp_5fget_5fnum_5fregions_35',['neorv32_cpu_pmp_get_num_regions',['../neorv32__cpu_8c.html#a27dd614bc270dfa30ed73323ebda2d2d',1,'neorv32_cpu_pmp_get_num_regions(void):&#160;neorv32_cpu.c'],['../neorv32__cpu_8h.html#a27dd614bc270dfa30ed73323ebda2d2d',1,'neorv32_cpu_pmp_get_num_regions(void):&#160;neorv32_cpu.c']]], + ['neorv32_5fcpu_5fset_5fmcycle_36',['neorv32_cpu_set_mcycle',['../neorv32__cpu_8c.html#a232d0290c459dc790d989fcdc4d121bf',1,'neorv32_cpu_set_mcycle(uint64_t value):&#160;neorv32_cpu.c'],['../neorv32__cpu_8h.html#a232d0290c459dc790d989fcdc4d121bf',1,'neorv32_cpu_set_mcycle(uint64_t value):&#160;neorv32_cpu.c']]], + ['neorv32_5fcpu_5fset_5fminstret_37',['neorv32_cpu_set_minstret',['../neorv32__cpu_8c.html#a5c3cf52498abb3cf3c14a724b287ecf0',1,'neorv32_cpu_set_minstret(uint64_t value):&#160;neorv32_cpu.c'],['../neorv32__cpu_8h.html#a5c3cf52498abb3cf3c14a724b287ecf0',1,'neorv32_cpu_set_minstret(uint64_t value):&#160;neorv32_cpu.c']]], + ['neorv32_5fcpu_5fsleep_38',['neorv32_cpu_sleep',['../neorv32__cpu_8h.html#a769ca4556213619f6fea4ff6bfb979dd',1,'neorv32_cpu.h']]], + ['neorv32_5fcpu_5fstore_5funsigned_5fbyte_39',['neorv32_cpu_store_unsigned_byte',['../neorv32__cpu_8h.html#aeec8ad2a82885c40a307346f9003483e',1,'neorv32_cpu.h']]], + ['neorv32_5fcpu_5fstore_5funsigned_5fhalf_40',['neorv32_cpu_store_unsigned_half',['../neorv32__cpu_8h.html#a31f30f6d6542758cd3073a9939b07653',1,'neorv32_cpu.h']]], + ['neorv32_5fcpu_5fstore_5funsigned_5fword_41',['neorv32_cpu_store_unsigned_word',['../neorv32__cpu_8h.html#a173bb06b4ae9c8964469068dafcb7b0e',1,'neorv32_cpu.h']]], + ['neorv32_5fcrc_5favailable_42',['neorv32_crc_available',['../neorv32__crc_8c.html#aa46c647317752f8bb6d5836d4876a704',1,'neorv32_crc_available(void):&#160;neorv32_crc.c'],['../neorv32__crc_8h.html#aa46c647317752f8bb6d5836d4876a704',1,'neorv32_crc_available(void):&#160;neorv32_crc.c']]], + ['neorv32_5fcrc_5fblock_43',['neorv32_crc_block',['../neorv32__crc_8c.html#a9243006e6cc94c03450646d26a7289b2',1,'neorv32_crc_block(uint8_t *byte, int length):&#160;neorv32_crc.c'],['../neorv32__crc_8h.html#a9243006e6cc94c03450646d26a7289b2',1,'neorv32_crc_block(uint8_t *byte, int length):&#160;neorv32_crc.c']]], + ['neorv32_5fcrc_5fget_44',['neorv32_crc_get',['../neorv32__crc_8c.html#a444b88f1536f65acc301fb19eddcf227',1,'neorv32_crc_get(void):&#160;neorv32_crc.c'],['../neorv32__crc_8h.html#a444b88f1536f65acc301fb19eddcf227',1,'neorv32_crc_get(void):&#160;neorv32_crc.c']]], + ['neorv32_5fcrc_5fsetup_45',['neorv32_crc_setup',['../neorv32__crc_8c.html#a4ff5f7b91e9f668535ed33b6382ae623',1,'neorv32_crc_setup(uint32_t mode, uint32_t poly, uint32_t start):&#160;neorv32_crc.c'],['../neorv32__crc_8h.html#a4ff5f7b91e9f668535ed33b6382ae623',1,'neorv32_crc_setup(uint32_t mode, uint32_t poly, uint32_t start):&#160;neorv32_crc.c']]], + ['neorv32_5fcrc_5fsingle_46',['neorv32_crc_single',['../neorv32__crc_8c.html#ad9d50c76a485160667d486bce32cbeb8',1,'neorv32_crc_single(uint8_t byte):&#160;neorv32_crc.c'],['../neorv32__crc_8h.html#ad9d50c76a485160667d486bce32cbeb8',1,'neorv32_crc_single(uint8_t byte):&#160;neorv32_crc.c']]], + ['neorv32_5fdma_5favailable_47',['neorv32_dma_available',['../neorv32__dma_8h.html#a13260c3252f0375d8982590d270d7dfd',1,'neorv32_dma.c']]], + ['neorv32_5fdma_5fdisable_48',['neorv32_dma_disable',['../neorv32__dma_8h.html#a6df244028455cf7f8d4cf1520c4670a7',1,'neorv32_dma.c']]], + ['neorv32_5fdma_5fdone_49',['neorv32_dma_done',['../neorv32__dma_8h.html#afc8cc32f7d80d0f5ab33b2f1ecf77956',1,'neorv32_dma.c']]], + ['neorv32_5fdma_5fenable_50',['neorv32_dma_enable',['../neorv32__dma_8h.html#ac3b72447e8a132faf26577ac714b8284',1,'neorv32_dma.c']]], + ['neorv32_5fdma_5ffence_5fdisable_51',['neorv32_dma_fence_disable',['../neorv32__dma_8h.html#a8f37adfa07050b0a1cb8430c9ce1fcc2',1,'neorv32_dma.c']]], + ['neorv32_5fdma_5ffence_5fenable_52',['neorv32_dma_fence_enable',['../neorv32__dma_8h.html#a2c7257567ccdb7a986f5ef7c74d3917c',1,'neorv32_dma.c']]], + ['neorv32_5fdma_5fstatus_53',['neorv32_dma_status',['../neorv32__dma_8h.html#aa116f9714174abbe8a3583e441fee24b',1,'neorv32_dma.c']]], + ['neorv32_5fdma_5ftransfer_54',['neorv32_dma_transfer',['../neorv32__dma_8h.html#a2ce0d31e04604b2523135d52a877febf',1,'neorv32_dma.c']]], + ['neorv32_5fdma_5ftransfer_5fauto_55',['neorv32_dma_transfer_auto',['../neorv32__dma_8h.html#a6ebd1595ee6fa0e6cbfbd1ce7476f18e',1,'neorv32_dma.c']]], + ['neorv32_5fgpio_5favailable_56',['neorv32_gpio_available',['../neorv32__gpio_8c.html#a41d39a41ba5879eb85d3ed4481fcff81',1,'neorv32_gpio_available(void):&#160;neorv32_gpio.c'],['../neorv32__gpio_8h.html#a41d39a41ba5879eb85d3ed4481fcff81',1,'neorv32_gpio_available(void):&#160;neorv32_gpio.c']]], + ['neorv32_5fgpio_5fpin_5fget_57',['neorv32_gpio_pin_get',['../neorv32__gpio_8c.html#afa3ee54aca47ff35f706b627ac66e95a',1,'neorv32_gpio_pin_get(int pin):&#160;neorv32_gpio.c'],['../neorv32__gpio_8h.html#afa3ee54aca47ff35f706b627ac66e95a',1,'neorv32_gpio_pin_get(int pin):&#160;neorv32_gpio.c']]], + ['neorv32_5fgpio_5fpin_5fset_58',['neorv32_gpio_pin_set',['../neorv32__gpio_8c.html#a60fd0830d634f0c1f784d815384665cb',1,'neorv32_gpio_pin_set(int pin, int value):&#160;neorv32_gpio.c'],['../neorv32__gpio_8h.html#a60fd0830d634f0c1f784d815384665cb',1,'neorv32_gpio_pin_set(int pin, int value):&#160;neorv32_gpio.c']]], + ['neorv32_5fgpio_5fpin_5ftoggle_59',['neorv32_gpio_pin_toggle',['../neorv32__gpio_8c.html#a1958850fc1689eae9ddfcaa4a7513400',1,'neorv32_gpio_pin_toggle(int pin):&#160;neorv32_gpio.c'],['../neorv32__gpio_8h.html#a1958850fc1689eae9ddfcaa4a7513400',1,'neorv32_gpio_pin_toggle(int pin):&#160;neorv32_gpio.c']]], + ['neorv32_5fgpio_5fport_5fget_60',['neorv32_gpio_port_get',['../neorv32__gpio_8c.html#ac42379f2fb5ca0bb63850d7957852b84',1,'neorv32_gpio_port_get(void):&#160;neorv32_gpio.c'],['../neorv32__gpio_8h.html#ac42379f2fb5ca0bb63850d7957852b84',1,'neorv32_gpio_port_get(void):&#160;neorv32_gpio.c']]], + ['neorv32_5fgpio_5fport_5fset_61',['neorv32_gpio_port_set',['../neorv32__gpio_8c.html#a8dc7846945e4609fc96d81caee99ac00',1,'neorv32_gpio_port_set(uint64_t port_data):&#160;neorv32_gpio.c'],['../neorv32__gpio_8h.html#a789222709485cd8467aad5eddf69d2df',1,'neorv32_gpio_port_set(uint64_t d):&#160;neorv32_gpio.c']]], + ['neorv32_5fgpio_5fport_5ftoggle_62',['neorv32_gpio_port_toggle',['../neorv32__gpio_8c.html#a210529f789779387d3f014e6253e803f',1,'neorv32_gpio_port_toggle(uint64_t toggle):&#160;neorv32_gpio.c'],['../neorv32__gpio_8h.html#a210529f789779387d3f014e6253e803f',1,'neorv32_gpio_port_toggle(uint64_t toggle):&#160;neorv32_gpio.c']]], + ['neorv32_5fgptmr_5favailable_63',['neorv32_gptmr_available',['../neorv32__gptmr_8c.html#ae79a08c52ad3e83f9c4393acfabf035f',1,'neorv32_gptmr_available(void):&#160;neorv32_gptmr.c'],['../neorv32__gptmr_8h.html#ae79a08c52ad3e83f9c4393acfabf035f',1,'neorv32_gptmr_available(void):&#160;neorv32_gptmr.c']]], + ['neorv32_5fgptmr_5fdisable_64',['neorv32_gptmr_disable',['../neorv32__gptmr_8c.html#a7c9bc6d28ad12611b08fa2867c2db874',1,'neorv32_gptmr_disable(void):&#160;neorv32_gptmr.c'],['../neorv32__gptmr_8h.html#a7c9bc6d28ad12611b08fa2867c2db874',1,'neorv32_gptmr_disable(void):&#160;neorv32_gptmr.c']]], + ['neorv32_5fgptmr_5fenable_65',['neorv32_gptmr_enable',['../neorv32__gptmr_8c.html#a59e684348835772a7e83446e478d4a13',1,'neorv32_gptmr_enable(void):&#160;neorv32_gptmr.c'],['../neorv32__gptmr_8h.html#a59e684348835772a7e83446e478d4a13',1,'neorv32_gptmr_enable(void):&#160;neorv32_gptmr.c']]], + ['neorv32_5fgptmr_5firq_5fack_66',['neorv32_gptmr_irq_ack',['../neorv32__gptmr_8c.html#ac73aa4e41a064abb4ca554a389888e67',1,'neorv32_gptmr_irq_ack(void):&#160;neorv32_gptmr.c'],['../neorv32__gptmr_8h.html#ac73aa4e41a064abb4ca554a389888e67',1,'neorv32_gptmr_irq_ack(void):&#160;neorv32_gptmr.c']]], + ['neorv32_5fgptmr_5fsetup_67',['neorv32_gptmr_setup',['../neorv32__gptmr_8c.html#a6aa27efd2163eebf8fc49fe1c591708f',1,'neorv32_gptmr_setup(int prsc, uint32_t threshold, int cont_mode):&#160;neorv32_gptmr.c'],['../neorv32__gptmr_8h.html#a6aa27efd2163eebf8fc49fe1c591708f',1,'neorv32_gptmr_setup(int prsc, uint32_t threshold, int cont_mode):&#160;neorv32_gptmr.c']]], + ['neorv32_5fmtime_5favailable_68',['neorv32_mtime_available',['../neorv32__mtime_8c.html#ab2b49a0594c66692aedf76ff9935581c',1,'neorv32_mtime_available(void):&#160;neorv32_mtime.c'],['../neorv32__mtime_8h.html#ab2b49a0594c66692aedf76ff9935581c',1,'neorv32_mtime_available(void):&#160;neorv32_mtime.c']]], + ['neorv32_5fmtime_5fget_5ftime_69',['neorv32_mtime_get_time',['../neorv32__mtime_8c.html#adedbbdeb71c06d2d60d3af73451de01e',1,'neorv32_mtime_get_time(void):&#160;neorv32_mtime.c'],['../neorv32__mtime_8h.html#adedbbdeb71c06d2d60d3af73451de01e',1,'neorv32_mtime_get_time(void):&#160;neorv32_mtime.c']]], + ['neorv32_5fmtime_5fget_5ftimecmp_70',['neorv32_mtime_get_timecmp',['../neorv32__mtime_8c.html#acb3cc18ff8421ebd6ef471e089c23491',1,'neorv32_mtime_get_timecmp(void):&#160;neorv32_mtime.c'],['../neorv32__mtime_8h.html#acb3cc18ff8421ebd6ef471e089c23491',1,'neorv32_mtime_get_timecmp(void):&#160;neorv32_mtime.c']]], + ['neorv32_5fmtime_5fget_5funixtime_71',['neorv32_mtime_get_unixtime',['../neorv32__mtime_8c.html#a50d08fcc3d91fc2d88b9a6a80c656f1a',1,'neorv32_mtime_get_unixtime(void):&#160;neorv32_mtime.c'],['../neorv32__mtime_8h.html#a50d08fcc3d91fc2d88b9a6a80c656f1a',1,'neorv32_mtime_get_unixtime(void):&#160;neorv32_mtime.c']]], + ['neorv32_5fmtime_5fset_5ftime_72',['neorv32_mtime_set_time',['../neorv32__mtime_8c.html#a1c30809d6e887f022a7794f720243015',1,'neorv32_mtime_set_time(uint64_t time):&#160;neorv32_mtime.c'],['../neorv32__mtime_8h.html#a1c30809d6e887f022a7794f720243015',1,'neorv32_mtime_set_time(uint64_t time):&#160;neorv32_mtime.c']]], + ['neorv32_5fmtime_5fset_5ftimecmp_73',['neorv32_mtime_set_timecmp',['../neorv32__mtime_8c.html#a81ff371c1aa10901264873316ee84a49',1,'neorv32_mtime_set_timecmp(uint64_t timecmp):&#160;neorv32_mtime.c'],['../neorv32__mtime_8h.html#a81ff371c1aa10901264873316ee84a49',1,'neorv32_mtime_set_timecmp(uint64_t timecmp):&#160;neorv32_mtime.c']]], + ['neorv32_5fmtime_5fset_5funixtime_74',['neorv32_mtime_set_unixtime',['../neorv32__mtime_8c.html#a022c3292c6e75095bb3ffd4c42fd4bfa',1,'neorv32_mtime_set_unixtime(uint64_t unixtime):&#160;neorv32_mtime.c'],['../neorv32__mtime_8h.html#a022c3292c6e75095bb3ffd4c42fd4bfa',1,'neorv32_mtime_set_unixtime(uint64_t unixtime):&#160;neorv32_mtime.c']]], + ['neorv32_5fneoled_5favailable_75',['neorv32_neoled_available',['../neorv32__neoled_8c.html#a57398d92fb4fc735b33e89271726e1d6',1,'neorv32_neoled_available(void):&#160;neorv32_neoled.c'],['../neorv32__neoled_8h.html#a57398d92fb4fc735b33e89271726e1d6',1,'neorv32_neoled_available(void):&#160;neorv32_neoled.c']]], + ['neorv32_5fneoled_5fdisable_76',['neorv32_neoled_disable',['../neorv32__neoled_8c.html#a8daaa97a85e0eb94d4a38eb2119ea183',1,'neorv32_neoled_disable(void):&#160;neorv32_neoled.c'],['../neorv32__neoled_8h.html#a8daaa97a85e0eb94d4a38eb2119ea183',1,'neorv32_neoled_disable(void):&#160;neorv32_neoled.c']]], + ['neorv32_5fneoled_5fenable_77',['neorv32_neoled_enable',['../neorv32__neoled_8c.html#a8181d5c1d15b7b5eecdc018341ac14fa',1,'neorv32_neoled_enable(void):&#160;neorv32_neoled.c'],['../neorv32__neoled_8h.html#a8181d5c1d15b7b5eecdc018341ac14fa',1,'neorv32_neoled_enable(void):&#160;neorv32_neoled.c']]], + ['neorv32_5fneoled_5fget_5fbuffer_5fsize_78',['neorv32_neoled_get_buffer_size',['../neorv32__neoled_8c.html#a81c2c49198531fb6551eb288e29c084e',1,'neorv32_neoled_get_buffer_size(void):&#160;neorv32_neoled.c'],['../neorv32__neoled_8h.html#a81c2c49198531fb6551eb288e29c084e',1,'neorv32_neoled_get_buffer_size(void):&#160;neorv32_neoled.c']]], + ['neorv32_5fneoled_5fset_5fmode_79',['neorv32_neoled_set_mode',['../neorv32__neoled_8c.html#a484fcc6797b6d9cef86192e9593ec33d',1,'neorv32_neoled_set_mode(uint32_t mode):&#160;neorv32_neoled.c'],['../neorv32__neoled_8h.html#a484fcc6797b6d9cef86192e9593ec33d',1,'neorv32_neoled_set_mode(uint32_t mode):&#160;neorv32_neoled.c']]], + ['neorv32_5fneoled_5fsetup_80',['neorv32_neoled_setup',['../neorv32__neoled_8c.html#ac6e94602453779a2791bd0734465f5a3',1,'neorv32_neoled_setup(uint32_t prsc, uint32_t t_total, uint32_t t_high_zero, uint32_t t_high_one, int irq_mode):&#160;neorv32_neoled.c'],['../neorv32__neoled_8h.html#ac6e94602453779a2791bd0734465f5a3',1,'neorv32_neoled_setup(uint32_t prsc, uint32_t t_total, uint32_t t_high_zero, uint32_t t_high_one, int irq_mode):&#160;neorv32_neoled.c']]], + ['neorv32_5fneoled_5fsetup_5fws2812_81',['neorv32_neoled_setup_ws2812',['../neorv32__neoled_8c.html#adade69c7368c28180b9992d5f0ab6031',1,'neorv32_neoled_setup_ws2812(int irq_mode):&#160;neorv32_neoled.c'],['../neorv32__neoled_8h.html#adade69c7368c28180b9992d5f0ab6031',1,'neorv32_neoled_setup_ws2812(int irq_mode):&#160;neorv32_neoled.c']]], + ['neorv32_5fneoled_5fstrobe_5fblocking_82',['neorv32_neoled_strobe_blocking',['../neorv32__neoled_8c.html#a5aa9eb4dd3655fa08e1b61eb0f36589c',1,'neorv32_neoled_strobe_blocking(void):&#160;neorv32_neoled.c'],['../neorv32__neoled_8h.html#a5aa9eb4dd3655fa08e1b61eb0f36589c',1,'neorv32_neoled_strobe_blocking(void):&#160;neorv32_neoled.c']]], + ['neorv32_5fneoled_5fstrobe_5fnonblocking_83',['neorv32_neoled_strobe_nonblocking',['../neorv32__neoled_8c.html#abf7882b949373df0774fc9cc20c2bd2e',1,'neorv32_neoled_strobe_nonblocking(void):&#160;neorv32_neoled.c'],['../neorv32__neoled_8h.html#abf7882b949373df0774fc9cc20c2bd2e',1,'neorv32_neoled_strobe_nonblocking(void):&#160;neorv32_neoled.c']]], + ['neorv32_5fneoled_5fwrite_5fblocking_84',['neorv32_neoled_write_blocking',['../neorv32__neoled_8c.html#a3ee5b3602da3ae982628e2802587e451',1,'neorv32_neoled_write_blocking(uint32_t data):&#160;neorv32_neoled.c'],['../neorv32__neoled_8h.html#a3ee5b3602da3ae982628e2802587e451',1,'neorv32_neoled_write_blocking(uint32_t data):&#160;neorv32_neoled.c']]], + ['neorv32_5fneoled_5fwrite_5fnonblocking_85',['neorv32_neoled_write_nonblocking',['../neorv32__neoled_8h.html#ad2a318bd59be12de34797ced0f7743c6',1,'neorv32_neoled.h']]], + ['neorv32_5fonewire_5favailable_86',['neorv32_onewire_available',['../neorv32__onewire_8c.html#a865e5c381fd3c27c6981a589a5124d1e',1,'neorv32_onewire_available(void):&#160;neorv32_onewire.c'],['../neorv32__onewire_8h.html#a865e5c381fd3c27c6981a589a5124d1e',1,'neorv32_onewire_available(void):&#160;neorv32_onewire.c']]], + ['neorv32_5fonewire_5fbusy_87',['neorv32_onewire_busy',['../neorv32__onewire_8c.html#a01b6236b89c045ddbd58398361c6ee0a',1,'neorv32_onewire_busy(void):&#160;neorv32_onewire.c'],['../neorv32__onewire_8h.html#a01b6236b89c045ddbd58398361c6ee0a',1,'neorv32_onewire_busy(void):&#160;neorv32_onewire.c']]], + ['neorv32_5fonewire_5fdisable_88',['neorv32_onewire_disable',['../neorv32__onewire_8c.html#a7e329eeb1cd98301a53b271a6a102385',1,'neorv32_onewire_disable(void):&#160;neorv32_onewire.c'],['../neorv32__onewire_8h.html#a7e329eeb1cd98301a53b271a6a102385',1,'neorv32_onewire_disable(void):&#160;neorv32_onewire.c']]], + ['neorv32_5fonewire_5fenable_89',['neorv32_onewire_enable',['../neorv32__onewire_8c.html#ae6fe766e7decf18869cfb86bba741ca4',1,'neorv32_onewire_enable(void):&#160;neorv32_onewire.c'],['../neorv32__onewire_8h.html#ae6fe766e7decf18869cfb86bba741ca4',1,'neorv32_onewire_enable(void):&#160;neorv32_onewire.c']]], + ['neorv32_5fonewire_5fread_5fbit_90',['neorv32_onewire_read_bit',['../neorv32__onewire_8c.html#aace8398062b759256a516e6245aced83',1,'neorv32_onewire_read_bit(void):&#160;neorv32_onewire.c'],['../neorv32__onewire_8h.html#aace8398062b759256a516e6245aced83',1,'neorv32_onewire_read_bit(void):&#160;neorv32_onewire.c']]], + ['neorv32_5fonewire_5fread_5fbit_5fblocking_91',['neorv32_onewire_read_bit_blocking',['../neorv32__onewire_8c.html#ace8b7cf697b068b6b51676d84dec5960',1,'neorv32_onewire_read_bit_blocking(void):&#160;neorv32_onewire.c'],['../neorv32__onewire_8h.html#ace8b7cf697b068b6b51676d84dec5960',1,'neorv32_onewire_read_bit_blocking(void):&#160;neorv32_onewire.c']]], + ['neorv32_5fonewire_5fread_5fbit_5fget_92',['neorv32_onewire_read_bit_get',['../neorv32__onewire_8c.html#aa4a19d2d8dc3b3401307615aec201190',1,'neorv32_onewire_read_bit_get(void):&#160;neorv32_onewire.c'],['../neorv32__onewire_8h.html#aa4a19d2d8dc3b3401307615aec201190',1,'neorv32_onewire_read_bit_get(void):&#160;neorv32_onewire.c']]], + ['neorv32_5fonewire_5fread_5fbyte_93',['neorv32_onewire_read_byte',['../neorv32__onewire_8c.html#a01ddba7a9148be542b5c52e39e6f46d6',1,'neorv32_onewire_read_byte(void):&#160;neorv32_onewire.c'],['../neorv32__onewire_8h.html#a01ddba7a9148be542b5c52e39e6f46d6',1,'neorv32_onewire_read_byte(void):&#160;neorv32_onewire.c']]], + ['neorv32_5fonewire_5fread_5fbyte_5fblocking_94',['neorv32_onewire_read_byte_blocking',['../neorv32__onewire_8c.html#a7510e65a26aeefb40e994fd00667537e',1,'neorv32_onewire_read_byte_blocking(void):&#160;neorv32_onewire.c'],['../neorv32__onewire_8h.html#a7510e65a26aeefb40e994fd00667537e',1,'neorv32_onewire_read_byte_blocking(void):&#160;neorv32_onewire.c']]], + ['neorv32_5fonewire_5fread_5fbyte_5fget_95',['neorv32_onewire_read_byte_get',['../neorv32__onewire_8c.html#a4c7eec15c095c97c939163f631f51dab',1,'neorv32_onewire_read_byte_get(void):&#160;neorv32_onewire.c'],['../neorv32__onewire_8h.html#a4c7eec15c095c97c939163f631f51dab',1,'neorv32_onewire_read_byte_get(void):&#160;neorv32_onewire.c']]], + ['neorv32_5fonewire_5freset_96',['neorv32_onewire_reset',['../neorv32__onewire_8c.html#a3072f7167831edc95dee44ecfef6a0d4',1,'neorv32_onewire_reset(void):&#160;neorv32_onewire.c'],['../neorv32__onewire_8h.html#a3072f7167831edc95dee44ecfef6a0d4',1,'neorv32_onewire_reset(void):&#160;neorv32_onewire.c']]], + ['neorv32_5fonewire_5freset_5fblocking_97',['neorv32_onewire_reset_blocking',['../neorv32__onewire_8c.html#af8ca6be495176797b7da3857e2f794f9',1,'neorv32_onewire_reset_blocking(void):&#160;neorv32_onewire.c'],['../neorv32__onewire_8h.html#af8ca6be495176797b7da3857e2f794f9',1,'neorv32_onewire_reset_blocking(void):&#160;neorv32_onewire.c']]], + ['neorv32_5fonewire_5freset_5fget_5fpresence_98',['neorv32_onewire_reset_get_presence',['../neorv32__onewire_8c.html#a43eb8a08eeaa83e3d7e9aa5058a4269f',1,'neorv32_onewire_reset_get_presence(void):&#160;neorv32_onewire.c'],['../neorv32__onewire_8h.html#a43eb8a08eeaa83e3d7e9aa5058a4269f',1,'neorv32_onewire_reset_get_presence(void):&#160;neorv32_onewire.c']]], + ['neorv32_5fonewire_5fsense_99',['neorv32_onewire_sense',['../neorv32__onewire_8c.html#a122531c7154126858c46d89e003d838d',1,'neorv32_onewire_sense(void):&#160;neorv32_onewire.c'],['../neorv32__onewire_8h.html#a122531c7154126858c46d89e003d838d',1,'neorv32_onewire_sense(void):&#160;neorv32_onewire.c']]], + ['neorv32_5fonewire_5fsetup_100',['neorv32_onewire_setup',['../neorv32__onewire_8c.html#a224005037387484dfa510a1355a62828',1,'neorv32_onewire_setup(uint32_t t_base):&#160;neorv32_onewire.c'],['../neorv32__onewire_8h.html#a224005037387484dfa510a1355a62828',1,'neorv32_onewire_setup(uint32_t t_base):&#160;neorv32_onewire.c']]], + ['neorv32_5fonewire_5fwrite_5fbit_101',['neorv32_onewire_write_bit',['../neorv32__onewire_8c.html#a49d0a2a386f129fd2f4fed880bba31d4',1,'neorv32_onewire_write_bit(uint8_t bit):&#160;neorv32_onewire.c'],['../neorv32__onewire_8h.html#a49d0a2a386f129fd2f4fed880bba31d4',1,'neorv32_onewire_write_bit(uint8_t bit):&#160;neorv32_onewire.c']]], + ['neorv32_5fonewire_5fwrite_5fbit_5fblocking_102',['neorv32_onewire_write_bit_blocking',['../neorv32__onewire_8c.html#a6f7b6690a2437e0b574a8a9a23dc0eaa',1,'neorv32_onewire_write_bit_blocking(uint8_t bit):&#160;neorv32_onewire.c'],['../neorv32__onewire_8h.html#a6f7b6690a2437e0b574a8a9a23dc0eaa',1,'neorv32_onewire_write_bit_blocking(uint8_t bit):&#160;neorv32_onewire.c']]], + ['neorv32_5fonewire_5fwrite_5fbyte_103',['neorv32_onewire_write_byte',['../neorv32__onewire_8c.html#a23b96b68c3214b188525eb102cafb620',1,'neorv32_onewire_write_byte(uint8_t byte):&#160;neorv32_onewire.c'],['../neorv32__onewire_8h.html#a23b96b68c3214b188525eb102cafb620',1,'neorv32_onewire_write_byte(uint8_t byte):&#160;neorv32_onewire.c']]], + ['neorv32_5fonewire_5fwrite_5fbyte_5fblocking_104',['neorv32_onewire_write_byte_blocking',['../neorv32__onewire_8c.html#ac78557c77482b59394677f42fda4fdf1',1,'neorv32_onewire_write_byte_blocking(uint8_t byte):&#160;neorv32_onewire.c'],['../neorv32__onewire_8h.html#ac78557c77482b59394677f42fda4fdf1',1,'neorv32_onewire_write_byte_blocking(uint8_t byte):&#160;neorv32_onewire.c']]], + ['neorv32_5fpmw_5fget_5fnum_5fchannels_105',['neorv32_pmw_get_num_channels',['../neorv32__pwm_8c.html#a43d8a47dc79ebac24c8a7d2d8247d2a5',1,'neorv32_pmw_get_num_channels(void):&#160;neorv32_pwm.c'],['../neorv32__pwm_8h.html#a43d8a47dc79ebac24c8a7d2d8247d2a5',1,'neorv32_pmw_get_num_channels(void):&#160;neorv32_pwm.c']]], + ['neorv32_5fpwm_5favailable_106',['neorv32_pwm_available',['../neorv32__pwm_8c.html#afb12c860b2f7fa6cd1e069ea540da41c',1,'neorv32_pwm_available(void):&#160;neorv32_pwm.c'],['../neorv32__pwm_8h.html#afb12c860b2f7fa6cd1e069ea540da41c',1,'neorv32_pwm_available(void):&#160;neorv32_pwm.c']]], + ['neorv32_5fpwm_5fdisable_107',['neorv32_pwm_disable',['../neorv32__pwm_8c.html#a8f16fdc6e048899305a3234f42fe272f',1,'neorv32_pwm_disable(void):&#160;neorv32_pwm.c'],['../neorv32__pwm_8h.html#a8f16fdc6e048899305a3234f42fe272f',1,'neorv32_pwm_disable(void):&#160;neorv32_pwm.c']]], + ['neorv32_5fpwm_5fenable_108',['neorv32_pwm_enable',['../neorv32__pwm_8c.html#abc62a63dc139b185cdf53d0267501288',1,'neorv32_pwm_enable(void):&#160;neorv32_pwm.c'],['../neorv32__pwm_8h.html#abc62a63dc139b185cdf53d0267501288',1,'neorv32_pwm_enable(void):&#160;neorv32_pwm.c']]], + ['neorv32_5fpwm_5fget_109',['neorv32_pwm_get',['../neorv32__pwm_8c.html#a64f66ae4f9689a650a70f3c5b45802b6',1,'neorv32_pwm_get(int channel):&#160;neorv32_pwm.c'],['../neorv32__pwm_8h.html#a64f66ae4f9689a650a70f3c5b45802b6',1,'neorv32_pwm_get(int channel):&#160;neorv32_pwm.c']]], + ['neorv32_5fpwm_5fset_110',['neorv32_pwm_set',['../neorv32__pwm_8c.html#aa24bc867effa7756bfbe7818d85aface',1,'neorv32_pwm_set(int channel, uint8_t dc):&#160;neorv32_pwm.c'],['../neorv32__pwm_8h.html#aa24bc867effa7756bfbe7818d85aface',1,'neorv32_pwm_set(int channel, uint8_t dc):&#160;neorv32_pwm.c']]], + ['neorv32_5fpwm_5fsetup_111',['neorv32_pwm_setup',['../neorv32__pwm_8c.html#a5502d483de07d2d8c42e2388ed987069',1,'neorv32_pwm_setup(int prsc):&#160;neorv32_pwm.c'],['../neorv32__pwm_8h.html#a5502d483de07d2d8c42e2388ed987069',1,'neorv32_pwm_setup(int prsc):&#160;neorv32_pwm.c']]], + ['neorv32_5frte_5fcontext_5fget_112',['neorv32_rte_context_get',['../neorv32__rte_8c.html#a65e71acc8916b42b59dc2cf6bba30ba3',1,'neorv32_rte_context_get(int x):&#160;neorv32_rte.c'],['../neorv32__rte_8h.html#a65e71acc8916b42b59dc2cf6bba30ba3',1,'neorv32_rte_context_get(int x):&#160;neorv32_rte.c']]], + ['neorv32_5frte_5fcontext_5fput_113',['neorv32_rte_context_put',['../neorv32__rte_8c.html#ae13a9c1fd59ad71afb0d47cf9a0b303e',1,'neorv32_rte_context_put(int x, uint32_t data):&#160;neorv32_rte.c'],['../neorv32__rte_8h.html#ae13a9c1fd59ad71afb0d47cf9a0b303e',1,'neorv32_rte_context_put(int x, uint32_t data):&#160;neorv32_rte.c']]], + ['neorv32_5frte_5fdebug_5fhandler_114',['neorv32_rte_debug_handler',['../neorv32__rte_8c.html#a65422bb44f1e7bc011e9bfc5d8451ebe',1,'neorv32_rte_debug_handler(void):&#160;neorv32_rte.c'],['../neorv32__rte_8h.html#a65422bb44f1e7bc011e9bfc5d8451ebe',1,'neorv32_rte_debug_handler(void):&#160;neorv32_rte.c']]], + ['neorv32_5frte_5fhandler_5finstall_115',['neorv32_rte_handler_install',['../neorv32__rte_8c.html#a2cf31cfa569a03a20d554b6400c4c5e2',1,'neorv32_rte_handler_install(int id, void(*handler)(void)):&#160;neorv32_rte.c'],['../neorv32__rte_8h.html#a2cf31cfa569a03a20d554b6400c4c5e2',1,'neorv32_rte_handler_install(int id, void(*handler)(void)):&#160;neorv32_rte.c']]], + ['neorv32_5frte_5fhandler_5funinstall_116',['neorv32_rte_handler_uninstall',['../neorv32__rte_8c.html#a10fde6229bf391e46148405616404a65',1,'neorv32_rte_handler_uninstall(int id):&#160;neorv32_rte.c'],['../neorv32__rte_8h.html#a10fde6229bf391e46148405616404a65',1,'neorv32_rte_handler_uninstall(int id):&#160;neorv32_rte.c']]], + ['neorv32_5frte_5fprint_5fabout_117',['neorv32_rte_print_about',['../neorv32__rte_8c.html#aa442c0e39f9156a131c3432fda587692',1,'neorv32_rte_print_about(void):&#160;neorv32_rte.c'],['../neorv32__rte_8h.html#aa442c0e39f9156a131c3432fda587692',1,'neorv32_rte_print_about(void):&#160;neorv32_rte.c']]], + ['neorv32_5frte_5fprint_5fhw_5fconfig_118',['neorv32_rte_print_hw_config',['../neorv32__rte_8c.html#a05e8304963e402d228a76aff1868771c',1,'neorv32_rte_print_hw_config(void):&#160;neorv32_rte.c'],['../neorv32__rte_8h.html#a05e8304963e402d228a76aff1868771c',1,'neorv32_rte_print_hw_config(void):&#160;neorv32_rte.c']]], + ['neorv32_5frte_5fprint_5fhw_5fversion_119',['neorv32_rte_print_hw_version',['../neorv32__rte_8c.html#aad6f5256a265807c4cde163bcba8dae9',1,'neorv32_rte_print_hw_version(void):&#160;neorv32_rte.c'],['../neorv32__rte_8h.html#aad6f5256a265807c4cde163bcba8dae9',1,'neorv32_rte_print_hw_version(void):&#160;neorv32_rte.c']]], + ['neorv32_5frte_5fprint_5flicense_120',['neorv32_rte_print_license',['../neorv32__rte_8c.html#acd96aa73eebe6d4bbc9aabe1230cbabc',1,'neorv32_rte_print_license(void):&#160;neorv32_rte.c'],['../neorv32__rte_8h.html#acd96aa73eebe6d4bbc9aabe1230cbabc',1,'neorv32_rte_print_license(void):&#160;neorv32_rte.c']]], + ['neorv32_5frte_5fprint_5flogo_121',['neorv32_rte_print_logo',['../neorv32__rte_8c.html#a16df1b48f2e1258a51d3bb7f49531cf3',1,'neorv32_rte_print_logo(void):&#160;neorv32_rte.c'],['../neorv32__rte_8h.html#a16df1b48f2e1258a51d3bb7f49531cf3',1,'neorv32_rte_print_logo(void):&#160;neorv32_rte.c']]], + ['neorv32_5frte_5fsetup_122',['neorv32_rte_setup',['../neorv32__rte_8c.html#a343e1913bdc37db9b168fb4def0e6170',1,'neorv32_rte_setup(void):&#160;neorv32_rte.c'],['../neorv32__rte_8h.html#a343e1913bdc37db9b168fb4def0e6170',1,'neorv32_rte_setup(void):&#160;neorv32_rte.c']]], + ['neorv32_5fsdi_5favailable_123',['neorv32_sdi_available',['../neorv32__sdi_8c.html#a51412722efdb18cd09667622b215e825',1,'neorv32_sdi_available(void):&#160;neorv32_sdi.c'],['../neorv32__sdi_8h.html#a51412722efdb18cd09667622b215e825',1,'neorv32_sdi_available(void):&#160;neorv32_sdi.c']]], + ['neorv32_5fsdi_5fcheck_5fcs_124',['neorv32_sdi_check_cs',['../neorv32__sdi_8c.html#a2636cf1959ce1f3eb4b77c00ca2e2707',1,'neorv32_sdi_check_cs(void):&#160;neorv32_sdi.c'],['../neorv32__sdi_8h.html#a2636cf1959ce1f3eb4b77c00ca2e2707',1,'neorv32_sdi_check_cs(void):&#160;neorv32_sdi.c']]], + ['neorv32_5fsdi_5fdisable_125',['neorv32_sdi_disable',['../neorv32__sdi_8c.html#a8bd54bca8aea6147651c8115ee616f54',1,'neorv32_sdi_disable(void):&#160;neorv32_sdi.c'],['../neorv32__sdi_8h.html#a8bd54bca8aea6147651c8115ee616f54',1,'neorv32_sdi_disable(void):&#160;neorv32_sdi.c']]], + ['neorv32_5fsdi_5fenable_126',['neorv32_sdi_enable',['../neorv32__sdi_8c.html#a5d68b9b1642baf3519076e55a22a8f61',1,'neorv32_sdi_enable(void):&#160;neorv32_sdi.c'],['../neorv32__sdi_8h.html#a5d68b9b1642baf3519076e55a22a8f61',1,'neorv32_sdi_enable(void):&#160;neorv32_sdi.c']]], + ['neorv32_5fsdi_5fget_127',['neorv32_sdi_get',['../neorv32__sdi_8c.html#a4d54ce22ec97eb83da118439576e3277',1,'neorv32_sdi_get(uint8_t *data):&#160;neorv32_sdi.c'],['../neorv32__sdi_8h.html#a4d54ce22ec97eb83da118439576e3277',1,'neorv32_sdi_get(uint8_t *data):&#160;neorv32_sdi.c']]], + ['neorv32_5fsdi_5fget_5ffifo_5fdepth_128',['neorv32_sdi_get_fifo_depth',['../neorv32__sdi_8c.html#a7390faeb01b4de3dd5ac18335736b90c',1,'neorv32_sdi_get_fifo_depth(void):&#160;neorv32_sdi.c'],['../neorv32__sdi_8h.html#a7390faeb01b4de3dd5ac18335736b90c',1,'neorv32_sdi_get_fifo_depth(void):&#160;neorv32_sdi.c']]], + ['neorv32_5fsdi_5fput_129',['neorv32_sdi_put',['../neorv32__sdi_8c.html#ac7a262d16c42bbac27723ff779545569',1,'neorv32_sdi_put(uint8_t data):&#160;neorv32_sdi.c'],['../neorv32__sdi_8h.html#ac7a262d16c42bbac27723ff779545569',1,'neorv32_sdi_put(uint8_t data):&#160;neorv32_sdi.c']]], + ['neorv32_5fsdi_5fsetup_130',['neorv32_sdi_setup',['../neorv32__sdi_8c.html#a3246118dc0d7e1f61bc2485bbab44149',1,'neorv32_sdi_setup(uint32_t irq_mask):&#160;neorv32_sdi.c'],['../neorv32__sdi_8h.html#a3246118dc0d7e1f61bc2485bbab44149',1,'neorv32_sdi_setup(uint32_t irq_mask):&#160;neorv32_sdi.c']]], + ['neorv32_5fslink_5favailable_131',['neorv32_slink_available',['../neorv32__slink_8c.html#aaf0f7bc96b797e819ccaae94292d9ddb',1,'neorv32_slink_available(void):&#160;neorv32_slink.c'],['../neorv32__slink_8h.html#aaf0f7bc96b797e819ccaae94292d9ddb',1,'neorv32_slink_available(void):&#160;neorv32_slink.c']]], + ['neorv32_5fslink_5fcheck_5flast_132',['neorv32_slink_check_last',['../neorv32__slink_8c.html#a3e02c558548c1c6178c49adee9a007f7',1,'neorv32_slink_check_last(void):&#160;neorv32_slink.c'],['../neorv32__slink_8h.html#a3e02c558548c1c6178c49adee9a007f7',1,'neorv32_slink_check_last(void):&#160;neorv32_slink.c']]], + ['neorv32_5fslink_5fget_133',['neorv32_slink_get',['../neorv32__slink_8c.html#ace319592c12dc6a0fe1b7dd66bdf9284',1,'neorv32_slink_get(void):&#160;neorv32_slink.c'],['../neorv32__slink_8h.html#ace319592c12dc6a0fe1b7dd66bdf9284',1,'neorv32_slink_get(void):&#160;neorv32_slink.c']]], + ['neorv32_5fslink_5fget_5frx_5ffifo_5fdepth_134',['neorv32_slink_get_rx_fifo_depth',['../neorv32__slink_8c.html#a575c7663ca0bd07c95b1d45152a3ddf8',1,'neorv32_slink_get_rx_fifo_depth(void):&#160;neorv32_slink.c'],['../neorv32__slink_8h.html#a575c7663ca0bd07c95b1d45152a3ddf8',1,'neorv32_slink_get_rx_fifo_depth(void):&#160;neorv32_slink.c']]], + ['neorv32_5fslink_5fget_5fsrc_135',['neorv32_slink_get_src',['../neorv32__slink_8c.html#a1a9269f42552a849450aecd99f7ec7a0',1,'neorv32_slink_get_src(void):&#160;neorv32_slink.c'],['../neorv32__slink_8h.html#a1a9269f42552a849450aecd99f7ec7a0',1,'neorv32_slink_get_src(void):&#160;neorv32_slink.c']]], + ['neorv32_5fslink_5fget_5ftx_5ffifo_5fdepth_136',['neorv32_slink_get_tx_fifo_depth',['../neorv32__slink_8c.html#aaf0d0d1b890353d4f3bf49450ec2fad2',1,'neorv32_slink_get_tx_fifo_depth(void):&#160;neorv32_slink.c'],['../neorv32__slink_8h.html#aaf0d0d1b890353d4f3bf49450ec2fad2',1,'neorv32_slink_get_tx_fifo_depth(void):&#160;neorv32_slink.c']]], + ['neorv32_5fslink_5fput_137',['neorv32_slink_put',['../neorv32__slink_8c.html#aaa9fdb9cbfa7888e92790ab65431d21d',1,'neorv32_slink_put(uint32_t tx_data):&#160;neorv32_slink.c'],['../neorv32__slink_8h.html#aaa9fdb9cbfa7888e92790ab65431d21d',1,'neorv32_slink_put(uint32_t tx_data):&#160;neorv32_slink.c']]], + ['neorv32_5fslink_5fput_5flast_138',['neorv32_slink_put_last',['../neorv32__slink_8c.html#a2136bc0b12ee2e6703e84a6417a1e8eb',1,'neorv32_slink_put_last(uint32_t tx_data):&#160;neorv32_slink.c'],['../neorv32__slink_8h.html#a2136bc0b12ee2e6703e84a6417a1e8eb',1,'neorv32_slink_put_last(uint32_t tx_data):&#160;neorv32_slink.c']]], + ['neorv32_5fslink_5frx_5fclear_139',['neorv32_slink_rx_clear',['../neorv32__slink_8c.html#ad149fea81e6d28f77450b8ba50cf706e',1,'neorv32_slink_rx_clear(void):&#160;neorv32_slink.c'],['../neorv32__slink_8h.html#ad149fea81e6d28f77450b8ba50cf706e',1,'neorv32_slink_rx_clear(void):&#160;neorv32_slink.c']]], + ['neorv32_5fslink_5frx_5fstatus_140',['neorv32_slink_rx_status',['../neorv32__slink_8c.html#ad57fc0941fe32e8bf423ce3e57e2c10a',1,'neorv32_slink_rx_status(void):&#160;neorv32_slink.c'],['../neorv32__slink_8h.html#ad57fc0941fe32e8bf423ce3e57e2c10a',1,'neorv32_slink_rx_status(void):&#160;neorv32_slink.c']]], + ['neorv32_5fslink_5fset_5fdst_141',['neorv32_slink_set_dst',['../neorv32__slink_8c.html#ad857d7e78ca2b5eb0d0a4f2c515fe7bc',1,'neorv32_slink_set_dst(uint32_t dst):&#160;neorv32_slink.c'],['../neorv32__slink_8h.html#ad857d7e78ca2b5eb0d0a4f2c515fe7bc',1,'neorv32_slink_set_dst(uint32_t dst):&#160;neorv32_slink.c']]], + ['neorv32_5fslink_5fsetup_142',['neorv32_slink_setup',['../neorv32__slink_8c.html#a8f0b4a768f53a72a5c16034e160ce321',1,'neorv32_slink_setup(uint32_t rx_irq, uint32_t tx_irq):&#160;neorv32_slink.c'],['../neorv32__slink_8h.html#a8f0b4a768f53a72a5c16034e160ce321',1,'neorv32_slink_setup(uint32_t rx_irq, uint32_t tx_irq):&#160;neorv32_slink.c']]], + ['neorv32_5fslink_5ftx_5fclear_143',['neorv32_slink_tx_clear',['../neorv32__slink_8c.html#ac7484e9e3848f94efe016dd064f6a57f',1,'neorv32_slink_tx_clear(void):&#160;neorv32_slink.c'],['../neorv32__slink_8h.html#ac7484e9e3848f94efe016dd064f6a57f',1,'neorv32_slink_tx_clear(void):&#160;neorv32_slink.c']]], + ['neorv32_5fslink_5ftx_5fstatus_144',['neorv32_slink_tx_status',['../neorv32__slink_8c.html#ad0252e7ae915e5840cd17e8c52e94a1c',1,'neorv32_slink_tx_status(void):&#160;neorv32_slink.c'],['../neorv32__slink_8h.html#ad0252e7ae915e5840cd17e8c52e94a1c',1,'neorv32_slink_tx_status(void):&#160;neorv32_slink.c']]], + ['neorv32_5fspi_5favailable_145',['neorv32_spi_available',['../neorv32__spi_8c.html#a7266ee439d0ec11c5cedd4bf1a258272',1,'neorv32_spi_available(void):&#160;neorv32_spi.c'],['../neorv32__spi_8h.html#a7266ee439d0ec11c5cedd4bf1a258272',1,'neorv32_spi_available(void):&#160;neorv32_spi.c']]], + ['neorv32_5fspi_5fbusy_146',['neorv32_spi_busy',['../neorv32__spi_8c.html#a332c7a1be511812ac0a2b102c165398a',1,'neorv32_spi_busy(void):&#160;neorv32_spi.c'],['../neorv32__spi_8h.html#a332c7a1be511812ac0a2b102c165398a',1,'neorv32_spi_busy(void):&#160;neorv32_spi.c']]], + ['neorv32_5fspi_5fcheck_5fcs_147',['neorv32_spi_check_cs',['../neorv32__spi_8c.html#a82bb4d4c222b2bdc57e917c348481501',1,'neorv32_spi_check_cs(void):&#160;neorv32_spi.c'],['../neorv32__spi_8h.html#a82bb4d4c222b2bdc57e917c348481501',1,'neorv32_spi_check_cs(void):&#160;neorv32_spi.c']]], + ['neorv32_5fspi_5fcs_5fdis_148',['neorv32_spi_cs_dis',['../neorv32__spi_8c.html#aa10ec90ccba6325eeeebb8f6f298d30c',1,'neorv32_spi_cs_dis(void):&#160;neorv32_spi.c'],['../neorv32__spi_8h.html#aa10ec90ccba6325eeeebb8f6f298d30c',1,'neorv32_spi_cs_dis(void):&#160;neorv32_spi.c']]], + ['neorv32_5fspi_5fcs_5fdis_5fnonblocking_149',['neorv32_spi_cs_dis_nonblocking',['../neorv32__spi_8c.html#ad8dd1b5a85a9daef4c8c21c9990884c1',1,'neorv32_spi_cs_dis_nonblocking(void):&#160;neorv32_spi.c'],['../neorv32__spi_8h.html#ad8dd1b5a85a9daef4c8c21c9990884c1',1,'neorv32_spi_cs_dis_nonblocking(void):&#160;neorv32_spi.c']]], + ['neorv32_5fspi_5fcs_5fen_150',['neorv32_spi_cs_en',['../neorv32__spi_8c.html#a737961d040ac09567350f89034f9e122',1,'neorv32_spi_cs_en(int cs):&#160;neorv32_spi.c'],['../neorv32__spi_8h.html#a737961d040ac09567350f89034f9e122',1,'neorv32_spi_cs_en(int cs):&#160;neorv32_spi.c']]], + ['neorv32_5fspi_5fcs_5fen_5fnonblocking_151',['neorv32_spi_cs_en_nonblocking',['../neorv32__spi_8c.html#a97b5536347a27b053f071ba49071ba6f',1,'neorv32_spi_cs_en_nonblocking(int cs):&#160;neorv32_spi.c'],['../neorv32__spi_8h.html#a97b5536347a27b053f071ba49071ba6f',1,'neorv32_spi_cs_en_nonblocking(int cs):&#160;neorv32_spi.c']]], + ['neorv32_5fspi_5fdisable_152',['neorv32_spi_disable',['../neorv32__spi_8c.html#a817dd9a38bfceb2048e40874a83ba169',1,'neorv32_spi_disable(void):&#160;neorv32_spi.c'],['../neorv32__spi_8h.html#a817dd9a38bfceb2048e40874a83ba169',1,'neorv32_spi_disable(void):&#160;neorv32_spi.c']]], + ['neorv32_5fspi_5fenable_153',['neorv32_spi_enable',['../neorv32__spi_8c.html#a8fa25d144ccb20a2faf0450c8dddd16e',1,'neorv32_spi_enable(void):&#160;neorv32_spi.c'],['../neorv32__spi_8h.html#a8fa25d144ccb20a2faf0450c8dddd16e',1,'neorv32_spi_enable(void):&#160;neorv32_spi.c']]], + ['neorv32_5fspi_5fget_5fclock_5fspeed_154',['neorv32_spi_get_clock_speed',['../neorv32__spi_8c.html#a01c6b63d7349447e2277f2649c3c89f2',1,'neorv32_spi_get_clock_speed(void):&#160;neorv32_spi.c'],['../neorv32__spi_8h.html#a01c6b63d7349447e2277f2649c3c89f2',1,'neorv32_spi_get_clock_speed(void):&#160;neorv32_spi.c']]], + ['neorv32_5fspi_5fget_5ffifo_5fdepth_155',['neorv32_spi_get_fifo_depth',['../neorv32__spi_8c.html#ae1c4da7e4dc2e42b04d7187f684f142c',1,'neorv32_spi_get_fifo_depth(void):&#160;neorv32_spi.c'],['../neorv32__spi_8h.html#ae1c4da7e4dc2e42b04d7187f684f142c',1,'neorv32_spi_get_fifo_depth(void):&#160;neorv32_spi.c']]], + ['neorv32_5fspi_5fget_5fnonblocking_156',['neorv32_spi_get_nonblocking',['../neorv32__spi_8c.html#aad66fa8f8d1a92d4f355de7579bfbfd2',1,'neorv32_spi_get_nonblocking(void):&#160;neorv32_spi.c'],['../neorv32__spi_8h.html#aad66fa8f8d1a92d4f355de7579bfbfd2',1,'neorv32_spi_get_nonblocking(void):&#160;neorv32_spi.c']]], + ['neorv32_5fspi_5fhighspeed_5fdisable_157',['neorv32_spi_highspeed_disable',['../neorv32__spi_8c.html#a67e9717635e272bc0e04408135a2f04d',1,'neorv32_spi_highspeed_disable(void):&#160;neorv32_spi.c'],['../neorv32__spi_8h.html#a67e9717635e272bc0e04408135a2f04d',1,'neorv32_spi_highspeed_disable(void):&#160;neorv32_spi.c']]], + ['neorv32_5fspi_5fhighspeed_5fenable_158',['neorv32_spi_highspeed_enable',['../neorv32__spi_8c.html#acf131faa3ad970c19a3cd8a47cb54f65',1,'neorv32_spi_highspeed_enable(void):&#160;neorv32_spi.c'],['../neorv32__spi_8h.html#acf131faa3ad970c19a3cd8a47cb54f65',1,'neorv32_spi_highspeed_enable(void):&#160;neorv32_spi.c']]], + ['neorv32_5fspi_5finit_159',['neorv32_spi_init',['../neorv32__spi__irq_8c.html#a4aa4746fd210ecc0c3614089a6951ddf',1,'neorv32_spi_init(t_neorv32_spi *self):&#160;neorv32_spi_irq.c'],['../neorv32__spi__irq_8h.html#a4aa4746fd210ecc0c3614089a6951ddf',1,'neorv32_spi_init(t_neorv32_spi *self):&#160;neorv32_spi_irq.c']]], + ['neorv32_5fspi_5fisr_160',['neorv32_spi_isr',['../neorv32__spi__irq_8c.html#aa641816bb302df497664aa21ea69ed16',1,'neorv32_spi_isr(t_neorv32_spi *self):&#160;neorv32_spi_irq.c'],['../neorv32__spi__irq_8h.html#aa641816bb302df497664aa21ea69ed16',1,'neorv32_spi_isr(t_neorv32_spi *self):&#160;neorv32_spi_irq.c']]], + ['neorv32_5fspi_5fput_5fnonblocking_161',['neorv32_spi_put_nonblocking',['../neorv32__spi_8c.html#aec8583e988789e846d21c2a35e6b06e7',1,'neorv32_spi_put_nonblocking(uint8_t tx_data):&#160;neorv32_spi.c'],['../neorv32__spi_8h.html#aec8583e988789e846d21c2a35e6b06e7',1,'neorv32_spi_put_nonblocking(uint8_t tx_data):&#160;neorv32_spi.c']]], + ['neorv32_5fspi_5frw_162',['neorv32_spi_rw',['../neorv32__spi__irq_8c.html#a1f44ed849415d8e1d659c0485762c485',1,'neorv32_spi_rw(t_neorv32_spi *self, uint8_t csn, void *spi, uint32_t len):&#160;neorv32_spi_irq.c'],['../neorv32__spi__irq_8h.html#a1f44ed849415d8e1d659c0485762c485',1,'neorv32_spi_rw(t_neorv32_spi *self, uint8_t csn, void *spi, uint32_t len):&#160;neorv32_spi_irq.c']]], + ['neorv32_5fspi_5frw_5fbusy_163',['neorv32_spi_rw_busy',['../neorv32__spi__irq_8c.html#a1863e19932bc6a79f2ca27d23eb74ef5',1,'neorv32_spi_rw_busy(t_neorv32_spi *self):&#160;neorv32_spi_irq.c'],['../neorv32__spi__irq_8h.html#a1863e19932bc6a79f2ca27d23eb74ef5',1,'neorv32_spi_rw_busy(t_neorv32_spi *self):&#160;neorv32_spi_irq.c']]], + ['neorv32_5fspi_5fsetup_164',['neorv32_spi_setup',['../neorv32__spi_8c.html#a7d8124d986b69210081df6f1aa653552',1,'neorv32_spi_setup(int prsc, int cdiv, int clk_phase, int clk_polarity, uint32_t irq_mask):&#160;neorv32_spi.c'],['../neorv32__spi_8h.html#a7d8124d986b69210081df6f1aa653552',1,'neorv32_spi_setup(int prsc, int cdiv, int clk_phase, int clk_polarity, uint32_t irq_mask):&#160;neorv32_spi.c']]], + ['neorv32_5fspi_5ftrans_165',['neorv32_spi_trans',['../neorv32__spi_8c.html#a7af79950eefc26e67a89bde02f255532',1,'neorv32_spi_trans(uint8_t tx_data):&#160;neorv32_spi.c'],['../neorv32__spi_8h.html#a7af79950eefc26e67a89bde02f255532',1,'neorv32_spi_trans(uint8_t tx_data):&#160;neorv32_spi.c']]], + ['neorv32_5ftrng_5favailable_166',['neorv32_trng_available',['../neorv32__trng_8c.html#af0c4139ff68763623b3d658a8dd8b5ce',1,'neorv32_trng_available(void):&#160;neorv32_trng.c'],['../neorv32__trng_8h.html#af0c4139ff68763623b3d658a8dd8b5ce',1,'neorv32_trng_available(void):&#160;neorv32_trng.c']]], + ['neorv32_5ftrng_5fcheck_5fsim_5fmode_167',['neorv32_trng_check_sim_mode',['../neorv32__trng_8c.html#aba36f08dd88f2f3e58353ae72eaa14f7',1,'neorv32_trng_check_sim_mode(void):&#160;neorv32_trng.c'],['../neorv32__trng_8h.html#aba36f08dd88f2f3e58353ae72eaa14f7',1,'neorv32_trng_check_sim_mode(void):&#160;neorv32_trng.c']]], + ['neorv32_5ftrng_5fdisable_168',['neorv32_trng_disable',['../neorv32__trng_8c.html#ae838bc980e28c300dc2c9c3f34a46bb8',1,'neorv32_trng_disable(void):&#160;neorv32_trng.c'],['../neorv32__trng_8h.html#ae838bc980e28c300dc2c9c3f34a46bb8',1,'neorv32_trng_disable(void):&#160;neorv32_trng.c']]], + ['neorv32_5ftrng_5fenable_169',['neorv32_trng_enable',['../neorv32__trng_8c.html#a8b8a1771e37a152792264561b93228fa',1,'neorv32_trng_enable(int irq_sel):&#160;neorv32_trng.c'],['../neorv32__trng_8h.html#a8b8a1771e37a152792264561b93228fa',1,'neorv32_trng_enable(int irq_sel):&#160;neorv32_trng.c']]], + ['neorv32_5ftrng_5ffifo_5fclear_170',['neorv32_trng_fifo_clear',['../neorv32__trng_8c.html#a87cfe338e2ff559f96c73f729465f967',1,'neorv32_trng_fifo_clear(void):&#160;neorv32_trng.c'],['../neorv32__trng_8h.html#a87cfe338e2ff559f96c73f729465f967',1,'neorv32_trng_fifo_clear(void):&#160;neorv32_trng.c']]], + ['neorv32_5ftrng_5fget_171',['neorv32_trng_get',['../neorv32__trng_8c.html#a9148bcb6a7c448c364e78fa98aac6985',1,'neorv32_trng_get(uint8_t *data):&#160;neorv32_trng.c'],['../neorv32__trng_8h.html#a9148bcb6a7c448c364e78fa98aac6985',1,'neorv32_trng_get(uint8_t *data):&#160;neorv32_trng.c']]], + ['neorv32_5ftrng_5fget_5ffifo_5fdepth_172',['neorv32_trng_get_fifo_depth',['../neorv32__trng_8c.html#ad24e44372f4fd1ed29a6967dccab4fb0',1,'neorv32_trng_get_fifo_depth(void):&#160;neorv32_trng.c'],['../neorv32__trng_8h.html#ad24e44372f4fd1ed29a6967dccab4fb0',1,'neorv32_trng_get_fifo_depth(void):&#160;neorv32_trng.c']]], + ['neorv32_5ftwi_5favailable_173',['neorv32_twi_available',['../neorv32__twi_8c.html#aa2e01ebbc0c82d65ed4ded351f4d8711',1,'neorv32_twi_available(void):&#160;neorv32_twi.c'],['../neorv32__twi_8h.html#aa2e01ebbc0c82d65ed4ded351f4d8711',1,'neorv32_twi_available(void):&#160;neorv32_twi.c']]], + ['neorv32_5ftwi_5fbusy_174',['neorv32_twi_busy',['../neorv32__twi_8c.html#a4fff1ddade320f6cc568c6266f2c2acd',1,'neorv32_twi_busy(void):&#160;neorv32_twi.c'],['../neorv32__twi_8h.html#a4fff1ddade320f6cc568c6266f2c2acd',1,'neorv32_twi_busy(void):&#160;neorv32_twi.c']]], + ['neorv32_5ftwi_5fdisable_175',['neorv32_twi_disable',['../neorv32__twi_8c.html#ae5f31e737c7a6c3c86070ff34cb0d861',1,'neorv32_twi_disable(void):&#160;neorv32_twi.c'],['../neorv32__twi_8h.html#ae5f31e737c7a6c3c86070ff34cb0d861',1,'neorv32_twi_disable(void):&#160;neorv32_twi.c']]], + ['neorv32_5ftwi_5fenable_176',['neorv32_twi_enable',['../neorv32__twi_8c.html#a22717887cffff1e6830756bc73140e7b',1,'neorv32_twi_enable(void):&#160;neorv32_twi.c'],['../neorv32__twi_8h.html#a22717887cffff1e6830756bc73140e7b',1,'neorv32_twi_enable(void):&#160;neorv32_twi.c']]], + ['neorv32_5ftwi_5fgenerate_5fstart_177',['neorv32_twi_generate_start',['../neorv32__twi_8c.html#a633d460e4735eb369d74a834b03c8b78',1,'neorv32_twi_generate_start(void):&#160;neorv32_twi.c'],['../neorv32__twi_8h.html#a633d460e4735eb369d74a834b03c8b78',1,'neorv32_twi_generate_start(void):&#160;neorv32_twi.c']]], + ['neorv32_5ftwi_5fgenerate_5fstart_5fnonblocking_178',['neorv32_twi_generate_start_nonblocking',['../neorv32__twi_8c.html#adbf2eaed0c76221da5c3091665fc885e',1,'neorv32_twi_generate_start_nonblocking(void):&#160;neorv32_twi.c'],['../neorv32__twi_8h.html#adbf2eaed0c76221da5c3091665fc885e',1,'neorv32_twi_generate_start_nonblocking(void):&#160;neorv32_twi.c']]], + ['neorv32_5ftwi_5fgenerate_5fstop_179',['neorv32_twi_generate_stop',['../neorv32__twi_8c.html#ad352447adcccccabd4e20577b34fbece',1,'neorv32_twi_generate_stop(void):&#160;neorv32_twi.c'],['../neorv32__twi_8h.html#ad352447adcccccabd4e20577b34fbece',1,'neorv32_twi_generate_stop(void):&#160;neorv32_twi.c']]], + ['neorv32_5ftwi_5fgenerate_5fstop_5fnonblocking_180',['neorv32_twi_generate_stop_nonblocking',['../neorv32__twi_8c.html#aa22430aab0a38d88cbd2c4220c573da0',1,'neorv32_twi_generate_stop_nonblocking(void):&#160;neorv32_twi.c'],['../neorv32__twi_8h.html#aa22430aab0a38d88cbd2c4220c573da0',1,'neorv32_twi_generate_stop_nonblocking(void):&#160;neorv32_twi.c']]], + ['neorv32_5ftwi_5fget_181',['neorv32_twi_get',['../neorv32__twi_8c.html#a7735376d26560866b153ed205dfcb2ba',1,'neorv32_twi_get(uint8_t *data):&#160;neorv32_twi.c'],['../neorv32__twi_8h.html#a7735376d26560866b153ed205dfcb2ba',1,'neorv32_twi_get(uint8_t *data):&#160;neorv32_twi.c']]], + ['neorv32_5ftwi_5fget_5ffifo_5fdepth_182',['neorv32_twi_get_fifo_depth',['../neorv32__twi_8c.html#a2c8f3bc55f4a9a8bdcb111759cf56ae2',1,'neorv32_twi_get_fifo_depth(void):&#160;neorv32_twi.c'],['../neorv32__twi_8h.html#a2c8f3bc55f4a9a8bdcb111759cf56ae2',1,'neorv32_twi_get_fifo_depth(void):&#160;neorv32_twi.c']]], + ['neorv32_5ftwi_5fsend_5fnonblocking_183',['neorv32_twi_send_nonblocking',['../neorv32__twi_8c.html#a28fc44cce5d28f6e8c32268b239b07d5',1,'neorv32_twi_send_nonblocking(uint8_t data, int mack):&#160;neorv32_twi.c'],['../neorv32__twi_8h.html#a28fc44cce5d28f6e8c32268b239b07d5',1,'neorv32_twi_send_nonblocking(uint8_t data, int mack):&#160;neorv32_twi.c']]], + ['neorv32_5ftwi_5fsetup_184',['neorv32_twi_setup',['../neorv32__twi_8c.html#a7ea6f3509a7cf622234d4b83e33afbe3',1,'neorv32_twi_setup(int prsc, int cdiv, int clkstr):&#160;neorv32_twi.c'],['../neorv32__twi_8h.html#a7ea6f3509a7cf622234d4b83e33afbe3',1,'neorv32_twi_setup(int prsc, int cdiv, int clkstr):&#160;neorv32_twi.c']]], + ['neorv32_5ftwi_5ftrans_185',['neorv32_twi_trans',['../neorv32__twi_8c.html#ac7020f3379602f11c47ca16f1bd82f2e',1,'neorv32_twi_trans(uint8_t *data, int mack):&#160;neorv32_twi.c'],['../neorv32__twi_8h.html#ac7020f3379602f11c47ca16f1bd82f2e',1,'neorv32_twi_trans(uint8_t *data, int mack):&#160;neorv32_twi.c']]], + ['neorv32_5fuart_5favailable_186',['neorv32_uart_available',['../neorv32__uart_8c.html#abef6415b0391dc055713404312196682',1,'neorv32_uart_available(neorv32_uart_t *UARTx):&#160;neorv32_uart.c'],['../neorv32__uart_8h.html#abef6415b0391dc055713404312196682',1,'neorv32_uart_available(neorv32_uart_t *UARTx):&#160;neorv32_uart.c']]], + ['neorv32_5fuart_5fchar_5freceived_187',['neorv32_uart_char_received',['../neorv32__uart_8c.html#adedb0e07efb232717534017167a5be98',1,'neorv32_uart_char_received(neorv32_uart_t *UARTx):&#160;neorv32_uart.c'],['../neorv32__uart_8h.html#adedb0e07efb232717534017167a5be98',1,'neorv32_uart_char_received(neorv32_uart_t *UARTx):&#160;neorv32_uart.c']]], + ['neorv32_5fuart_5fchar_5freceived_5fget_188',['neorv32_uart_char_received_get',['../neorv32__uart_8c.html#aa490df3a9bb2aa3215fa6fad34ffe7d1',1,'neorv32_uart_char_received_get(neorv32_uart_t *UARTx):&#160;neorv32_uart.c'],['../neorv32__uart_8h.html#aa490df3a9bb2aa3215fa6fad34ffe7d1',1,'neorv32_uart_char_received_get(neorv32_uart_t *UARTx):&#160;neorv32_uart.c']]], + ['neorv32_5fuart_5fdisable_189',['neorv32_uart_disable',['../neorv32__uart_8c.html#ae18804ccd29ec2fd1cc06e9ce985b704',1,'neorv32_uart_disable(neorv32_uart_t *UARTx):&#160;neorv32_uart.c'],['../neorv32__uart_8h.html#ae18804ccd29ec2fd1cc06e9ce985b704',1,'neorv32_uart_disable(neorv32_uart_t *UARTx):&#160;neorv32_uart.c']]], + ['neorv32_5fuart_5fenable_190',['neorv32_uart_enable',['../neorv32__uart_8c.html#afa0533e81d53057c36f4997a2dbbe2bc',1,'neorv32_uart_enable(neorv32_uart_t *UARTx):&#160;neorv32_uart.c'],['../neorv32__uart_8h.html#afa0533e81d53057c36f4997a2dbbe2bc',1,'neorv32_uart_enable(neorv32_uart_t *UARTx):&#160;neorv32_uart.c']]], + ['neorv32_5fuart_5fget_5frx_5ffifo_5fdepth_191',['neorv32_uart_get_rx_fifo_depth',['../neorv32__uart_8c.html#af85fb929c912d3edef3d86ffa833982a',1,'neorv32_uart_get_rx_fifo_depth(neorv32_uart_t *UARTx):&#160;neorv32_uart.c'],['../neorv32__uart_8h.html#af85fb929c912d3edef3d86ffa833982a',1,'neorv32_uart_get_rx_fifo_depth(neorv32_uart_t *UARTx):&#160;neorv32_uart.c']]], + ['neorv32_5fuart_5fget_5ftx_5ffifo_5fdepth_192',['neorv32_uart_get_tx_fifo_depth',['../neorv32__uart_8c.html#a031e3e27c8783c299623468020a22b0e',1,'neorv32_uart_get_tx_fifo_depth(neorv32_uart_t *UARTx):&#160;neorv32_uart.c'],['../neorv32__uart_8h.html#a031e3e27c8783c299623468020a22b0e',1,'neorv32_uart_get_tx_fifo_depth(neorv32_uart_t *UARTx):&#160;neorv32_uart.c']]], + ['neorv32_5fuart_5fgetc_193',['neorv32_uart_getc',['../neorv32__uart_8c.html#a2efd432f63b8d36d44263d0b1f39a6dc',1,'neorv32_uart_getc(neorv32_uart_t *UARTx):&#160;neorv32_uart.c'],['../neorv32__uart_8h.html#a2efd432f63b8d36d44263d0b1f39a6dc',1,'neorv32_uart_getc(neorv32_uart_t *UARTx):&#160;neorv32_uart.c']]], + ['neorv32_5fuart_5fprintf_194',['neorv32_uart_printf',['../neorv32__uart_8c.html#ab8c1f9f451def9126ab2749d7bbe50d9',1,'neorv32_uart_printf(neorv32_uart_t *UARTx, const char *format,...):&#160;neorv32_uart.c'],['../neorv32__uart_8h.html#ab8c1f9f451def9126ab2749d7bbe50d9',1,'neorv32_uart_printf(neorv32_uart_t *UARTx, const char *format,...):&#160;neorv32_uart.c']]], + ['neorv32_5fuart_5fputc_195',['neorv32_uart_putc',['../neorv32__uart_8c.html#a9bc7bb94a50b74e1145b78eec6094129',1,'neorv32_uart_putc(neorv32_uart_t *UARTx, char c):&#160;neorv32_uart.c'],['../neorv32__uart_8h.html#a9bc7bb94a50b74e1145b78eec6094129',1,'neorv32_uart_putc(neorv32_uart_t *UARTx, char c):&#160;neorv32_uart.c']]], + ['neorv32_5fuart_5fputs_196',['neorv32_uart_puts',['../neorv32__uart_8c.html#a45a07d5e71677162baaa1025759c67a2',1,'neorv32_uart_puts(neorv32_uart_t *UARTx, const char *s):&#160;neorv32_uart.c'],['../neorv32__uart_8h.html#a45a07d5e71677162baaa1025759c67a2',1,'neorv32_uart_puts(neorv32_uart_t *UARTx, const char *s):&#160;neorv32_uart.c']]], + ['neorv32_5fuart_5frtscts_5fdisable_197',['neorv32_uart_rtscts_disable',['../neorv32__uart_8c.html#a7b2f924ef4554b1fa90433c38d97558d',1,'neorv32_uart_rtscts_disable(neorv32_uart_t *UARTx):&#160;neorv32_uart.c'],['../neorv32__uart_8h.html#a7b2f924ef4554b1fa90433c38d97558d',1,'neorv32_uart_rtscts_disable(neorv32_uart_t *UARTx):&#160;neorv32_uart.c']]], + ['neorv32_5fuart_5frtscts_5fenable_198',['neorv32_uart_rtscts_enable',['../neorv32__uart_8c.html#a734b610f4cd1b474d7763f9700a715ec',1,'neorv32_uart_rtscts_enable(neorv32_uart_t *UARTx):&#160;neorv32_uart.c'],['../neorv32__uart_8h.html#a734b610f4cd1b474d7763f9700a715ec',1,'neorv32_uart_rtscts_enable(neorv32_uart_t *UARTx):&#160;neorv32_uart.c']]], + ['neorv32_5fuart_5frx_5fclear_199',['neorv32_uart_rx_clear',['../neorv32__uart_8c.html#afe0de59c14faff1e0c890d5465be25f0',1,'neorv32_uart_rx_clear(neorv32_uart_t *UARTx):&#160;neorv32_uart.c'],['../neorv32__uart_8h.html#afe0de59c14faff1e0c890d5465be25f0',1,'neorv32_uart_rx_clear(neorv32_uart_t *UARTx):&#160;neorv32_uart.c']]], + ['neorv32_5fuart_5fscan_200',['neorv32_uart_scan',['../neorv32__uart_8c.html#ac429964878bd6deab61d9ed8659bca75',1,'neorv32_uart_scan(neorv32_uart_t *UARTx, char *buffer, int max_size, int echo):&#160;neorv32_uart.c'],['../neorv32__uart_8h.html#ac429964878bd6deab61d9ed8659bca75',1,'neorv32_uart_scan(neorv32_uart_t *UARTx, char *buffer, int max_size, int echo):&#160;neorv32_uart.c']]], + ['neorv32_5fuart_5fsetup_201',['neorv32_uart_setup',['../neorv32__uart_8c.html#a9cdec36f2723c5373664022d1b68b841',1,'neorv32_uart_setup(neorv32_uart_t *UARTx, uint32_t baudrate, uint32_t irq_mask):&#160;neorv32_uart.c'],['../neorv32__uart_8h.html#a9cdec36f2723c5373664022d1b68b841',1,'neorv32_uart_setup(neorv32_uart_t *UARTx, uint32_t baudrate, uint32_t irq_mask):&#160;neorv32_uart.c']]], + ['neorv32_5fuart_5ftx_5fbusy_202',['neorv32_uart_tx_busy',['../neorv32__uart_8c.html#aa7bef48a58e044c246b8c4ad32864502',1,'neorv32_uart_tx_busy(neorv32_uart_t *UARTx):&#160;neorv32_uart.c'],['../neorv32__uart_8h.html#aa7bef48a58e044c246b8c4ad32864502',1,'neorv32_uart_tx_busy(neorv32_uart_t *UARTx):&#160;neorv32_uart.c']]], + ['neorv32_5fuart_5ftx_5fclear_203',['neorv32_uart_tx_clear',['../neorv32__uart_8c.html#a27971954262a2fd1f21d3bf1ba27e87c',1,'neorv32_uart_tx_clear(neorv32_uart_t *UARTx):&#160;neorv32_uart.c'],['../neorv32__uart_8h.html#a27971954262a2fd1f21d3bf1ba27e87c',1,'neorv32_uart_tx_clear(neorv32_uart_t *UARTx):&#160;neorv32_uart.c']]], + ['neorv32_5fuart_5fvprintf_204',['neorv32_uart_vprintf',['../neorv32__uart_8c.html#a8714cdb1c04d94bec322c6215ea10238',1,'neorv32_uart_vprintf(neorv32_uart_t *UARTx, const char *format, va_list args):&#160;neorv32_uart.c'],['../neorv32__uart_8h.html#a8714cdb1c04d94bec322c6215ea10238',1,'neorv32_uart_vprintf(neorv32_uart_t *UARTx, const char *format, va_list args):&#160;neorv32_uart.c']]], + ['neorv32_5fwdt_5favailable_205',['neorv32_wdt_available',['../neorv32__wdt_8c.html#a459a918c5a86c0167e8c748352d39827',1,'neorv32_wdt_available(void):&#160;neorv32_wdt.c'],['../neorv32__wdt_8h.html#a459a918c5a86c0167e8c748352d39827',1,'neorv32_wdt_available(void):&#160;neorv32_wdt.c']]], + ['neorv32_5fwdt_5fdisable_206',['neorv32_wdt_disable',['../neorv32__wdt_8c.html#aba52520582392a671e2b717715a330b2',1,'neorv32_wdt_disable(void):&#160;neorv32_wdt.c'],['../neorv32__wdt_8h.html#aba52520582392a671e2b717715a330b2',1,'neorv32_wdt_disable(void):&#160;neorv32_wdt.c']]], + ['neorv32_5fwdt_5ffeed_207',['neorv32_wdt_feed',['../neorv32__wdt_8c.html#a2e4df2b352d11c31063ef2fc16c510ad',1,'neorv32_wdt_feed(void):&#160;neorv32_wdt.c'],['../neorv32__wdt_8h.html#a2e4df2b352d11c31063ef2fc16c510ad',1,'neorv32_wdt_feed(void):&#160;neorv32_wdt.c']]], + ['neorv32_5fwdt_5fget_5fcause_208',['neorv32_wdt_get_cause',['../neorv32__wdt_8c.html#a80fa8d178d18c9b02d32d93e815b532e',1,'neorv32_wdt_get_cause(void):&#160;neorv32_wdt.c'],['../neorv32__wdt_8h.html#a80fa8d178d18c9b02d32d93e815b532e',1,'neorv32_wdt_get_cause(void):&#160;neorv32_wdt.c']]], + ['neorv32_5fwdt_5fsetup_209',['neorv32_wdt_setup',['../neorv32__wdt_8c.html#a2aa72608191d34ef41c5f545988ff400',1,'neorv32_wdt_setup(uint32_t timeout, int lock, int debug_en, int sleep_en, int strict):&#160;neorv32_wdt.c'],['../neorv32__wdt_8h.html#a2aa72608191d34ef41c5f545988ff400',1,'neorv32_wdt_setup(uint32_t timeout, int lock, int debug_en, int sleep_en, int strict):&#160;neorv32_wdt.c']]], + ['neorv32_5fxip_5favailable_210',['neorv32_xip_available',['../neorv32__xip_8c.html#afe2e5682a26cafdb0585d2233bccc7c6',1,'neorv32_xip_available(void):&#160;neorv32_xip.c'],['../neorv32__xip_8h.html#afe2e5682a26cafdb0585d2233bccc7c6',1,'neorv32_xip_available(void):&#160;neorv32_xip.c']]], + ['neorv32_5fxip_5fget_5fclock_5fspeed_211',['neorv32_xip_get_clock_speed',['../neorv32__xip_8c.html#a88f728101e82939bf7f8b9ab5a904706',1,'neorv32_xip_get_clock_speed(void):&#160;neorv32_xip.c'],['../neorv32__xip_8h.html#a88f728101e82939bf7f8b9ab5a904706',1,'neorv32_xip_get_clock_speed(void):&#160;neorv32_xip.c']]], + ['neorv32_5fxip_5fhighspeed_5fdisable_212',['neorv32_xip_highspeed_disable',['../neorv32__xip_8c.html#ad74f2842ed2251e3ae5c19e06dced0c3',1,'neorv32_xip_highspeed_disable(void):&#160;neorv32_xip.c'],['../neorv32__xip_8h.html#ad74f2842ed2251e3ae5c19e06dced0c3',1,'neorv32_xip_highspeed_disable(void):&#160;neorv32_xip.c']]], + ['neorv32_5fxip_5fhighspeed_5fenable_213',['neorv32_xip_highspeed_enable',['../neorv32__xip_8c.html#a6aef2ea29451ba2aa55160da777a5115',1,'neorv32_xip_highspeed_enable(void):&#160;neorv32_xip.c'],['../neorv32__xip_8h.html#a6aef2ea29451ba2aa55160da777a5115',1,'neorv32_xip_highspeed_enable(void):&#160;neorv32_xip.c']]], + ['neorv32_5fxip_5fsetup_214',['neorv32_xip_setup',['../neorv32__xip_8c.html#a549d68abdf5a3d7484abe6d5370bb999',1,'neorv32_xip_setup(int prsc, int cdiv, int cpol, int cpha, uint8_t rd_cmd):&#160;neorv32_xip.c'],['../neorv32__xip_8h.html#a549d68abdf5a3d7484abe6d5370bb999',1,'neorv32_xip_setup(int prsc, int cdiv, int cpol, int cpha, uint8_t rd_cmd):&#160;neorv32_xip.c']]], + ['neorv32_5fxip_5fspi_5ftrans_215',['neorv32_xip_spi_trans',['../neorv32__xip_8c.html#a92f1446a3bb7fe6dee5dbed33882b223',1,'neorv32_xip_spi_trans(int nbytes, uint64_t *rtx_data):&#160;neorv32_xip.c'],['../neorv32__xip_8h.html#a92f1446a3bb7fe6dee5dbed33882b223',1,'neorv32_xip_spi_trans(int nbytes, uint64_t *rtx_data):&#160;neorv32_xip.c']]], + ['neorv32_5fxip_5fstart_216',['neorv32_xip_start',['../neorv32__xip_8c.html#a0ab2c36c973030a811e6d7abe0afc393',1,'neorv32_xip_start(int abytes):&#160;neorv32_xip.c'],['../neorv32__xip_8h.html#a0ab2c36c973030a811e6d7abe0afc393',1,'neorv32_xip_start(int abytes):&#160;neorv32_xip.c']]], + ['neorv32_5fxirq_5favailable_217',['neorv32_xirq_available',['../neorv32__xirq_8c.html#aaf30757d526030a8d81081915ab29a76',1,'neorv32_xirq_available(void):&#160;neorv32_xirq.c'],['../neorv32__xirq_8h.html#aaf30757d526030a8d81081915ab29a76',1,'neorv32_xirq_available(void):&#160;neorv32_xirq.c']]], + ['neorv32_5fxirq_5fchannel_5fdisable_218',['neorv32_xirq_channel_disable',['../neorv32__xirq_8c.html#ae17509ad0c828aa9b36747b253cdbf0a',1,'neorv32_xirq_channel_disable(int channel):&#160;neorv32_xirq.c'],['../neorv32__xirq_8h.html#ae17509ad0c828aa9b36747b253cdbf0a',1,'neorv32_xirq_channel_disable(int channel):&#160;neorv32_xirq.c']]], + ['neorv32_5fxirq_5fchannel_5fenable_219',['neorv32_xirq_channel_enable',['../neorv32__xirq_8c.html#abe63c0968c94b472082c8156a1a7db5c',1,'neorv32_xirq_channel_enable(int channel):&#160;neorv32_xirq.c'],['../neorv32__xirq_8h.html#abe63c0968c94b472082c8156a1a7db5c',1,'neorv32_xirq_channel_enable(int channel):&#160;neorv32_xirq.c']]], + ['neorv32_5fxirq_5fclear_5fpending_220',['neorv32_xirq_clear_pending',['../neorv32__xirq_8c.html#a83ecaf568a6f6bcb1e1efdb1eef6df9c',1,'neorv32_xirq_clear_pending(int channel):&#160;neorv32_xirq.c'],['../neorv32__xirq_8h.html#a83ecaf568a6f6bcb1e1efdb1eef6df9c',1,'neorv32_xirq_clear_pending(int channel):&#160;neorv32_xirq.c']]], + ['neorv32_5fxirq_5fget_5fnum_221',['neorv32_xirq_get_num',['../neorv32__xirq_8c.html#a717a8e34908cc01345e68920e76f229c',1,'neorv32_xirq_get_num(void):&#160;neorv32_xirq.c'],['../neorv32__xirq_8h.html#a717a8e34908cc01345e68920e76f229c',1,'neorv32_xirq_get_num(void):&#160;neorv32_xirq.c']]], + ['neorv32_5fxirq_5fglobal_5fdisable_222',['neorv32_xirq_global_disable',['../neorv32__xirq_8c.html#ac64d3ff5619968499bccebebe6a6cab3',1,'neorv32_xirq_global_disable(void):&#160;neorv32_xirq.c'],['../neorv32__xirq_8h.html#ac64d3ff5619968499bccebebe6a6cab3',1,'neorv32_xirq_global_disable(void):&#160;neorv32_xirq.c']]], + ['neorv32_5fxirq_5fglobal_5fenable_223',['neorv32_xirq_global_enable',['../neorv32__xirq_8c.html#a76468156ef52b371e06bc2ca8eddcd27',1,'neorv32_xirq_global_enable(void):&#160;neorv32_xirq.c'],['../neorv32__xirq_8h.html#a76468156ef52b371e06bc2ca8eddcd27',1,'neorv32_xirq_global_enable(void):&#160;neorv32_xirq.c']]], + ['neorv32_5fxirq_5finstall_224',['neorv32_xirq_install',['../neorv32__xirq_8c.html#a9129984f91c02afafaa072a5d86f9876',1,'neorv32_xirq_install(int channel, void(*handler)(void)):&#160;neorv32_xirq.c'],['../neorv32__xirq_8h.html#a9129984f91c02afafaa072a5d86f9876',1,'neorv32_xirq_install(int channel, void(*handler)(void)):&#160;neorv32_xirq.c']]], + ['neorv32_5fxirq_5fsetup_225',['neorv32_xirq_setup',['../neorv32__xirq_8c.html#a9295997fce7114a8205325c4d75dd200',1,'neorv32_xirq_setup(void):&#160;neorv32_xirq.c'],['../neorv32__xirq_8h.html#a9295997fce7114a8205325c4d75dd200',1,'neorv32_xirq_setup(void):&#160;neorv32_xirq.c']]], + ['neorv32_5fxirq_5fsetup_5ftrigger_226',['neorv32_xirq_setup_trigger',['../neorv32__xirq_8c.html#a0d137f09d1e7dcd31c157b856033ac42',1,'neorv32_xirq_setup_trigger(int channel, int config):&#160;neorv32_xirq.c'],['../neorv32__xirq_8h.html#a0d137f09d1e7dcd31c157b856033ac42',1,'neorv32_xirq_setup_trigger(int channel, int config):&#160;neorv32_xirq.c']]], + ['neorv32_5fxirq_5funinstall_227',['neorv32_xirq_uninstall',['../neorv32__xirq_8c.html#a49ae67d1d5066cd795149e96b81127f7',1,'neorv32_xirq_uninstall(int channel):&#160;neorv32_xirq.c'],['../neorv32__xirq_8h.html#a49ae67d1d5066cd795149e96b81127f7',1,'neorv32_xirq_uninstall(int channel):&#160;neorv32_xirq.c']]] +]; diff --git a/sw/search/functions_9.js b/sw/search/functions_9.js new file mode 100644 index 0000000000..057388cf68 --- /dev/null +++ b/sw/search/functions_9.js @@ -0,0 +1,11 @@ +var searchData= +[ + ['pop_5fcount_0',['pop_count',['../game__of__life_2main_8c.html#aac4bec7738b12f5a4b4d7a3a6cb1ab8d',1,'main.c']]], + ['print_5fhelp_1',['print_help',['../bootloader_8c.html#a402ea961bfc2ffeee61e3a7c330b1559',1,'bootloader.c']]], + ['print_5fhex_5fbyte_2',['print_hex_byte',['../demo__twi_2main_8c.html#a2ebc688bc1dad328693fc0974b378fa0',1,'main.c']]], + ['print_5fhex_5fword_3',['print_hex_word',['../bootloader_8c.html#a70b7d5c3b3ae97e4e72e84c4bc28fb8a',1,'bootloader.c']]], + ['print_5frandom_5fdata_4',['print_random_data',['../demo__trng_2main_8c.html#a64205d97b57c99dc5e95b8621827f4a4',1,'main.c']]], + ['print_5freport_5',['print_report',['../atomic__test_2main_8c.html#a99377a057d14aaa9b45f8cab890e8cf7',1,'print_report(int num_err, int num_tests):&#160;main.c'],['../float__corner__test_2main_8c.html#a1740720aa8ce1a30fcf642be9140d203',1,'print_report(uint32_t num_err):&#160;main.c'],['../floating__point__test_2main_8c.html#a1740720aa8ce1a30fcf642be9140d203',1,'print_report(uint32_t num_err):&#160;main.c']]], + ['print_5funiverse_6',['print_universe',['../game__of__life_2main_8c.html#a9a455dea83a25f656fcc5217ad513dac',1,'main.c']]], + ['putchar_7',['putchar',['../neorv32__uart_8c.html#a07036e93939040c563e862a6a31b65bc',1,'neorv32_uart.c']]] +]; diff --git a/sw/search/functions_a.js b/sw/search/functions_a.js new file mode 100644 index 0000000000..f1960ec5c7 --- /dev/null +++ b/sw/search/functions_a.js @@ -0,0 +1,51 @@ +var searchData= +[ + ['read_5fbyte_0',['read_byte',['../demo__onewire_2main_8c.html#a951a31029af34715f20856eb82432637',1,'main.c']]], + ['read_5fmemory_1',['read_memory',['../bus__explorer_2main_8c.html#afc9b1ab3db46eccf51d55c715fa2fbd4',1,'main.c']]], + ['repetition_5fcount_5ftest_2',['repetition_count_test',['../demo__trng_2main_8c.html#af37eae672fee5e81f00a1dbf51b7e417',1,'main.c']]], + ['riscv_5femulate_5ffadds_3',['riscv_emulate_fadds',['../floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a9d676567276439875c9b1a15b892b555',1,'neorv32_zfinx_extension_intrinsics.h']]], + ['riscv_5femulate_5ffclasss_4',['riscv_emulate_fclasss',['../floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#ae41a0bf9d28c35f4d6db7177ccf8ee06',1,'neorv32_zfinx_extension_intrinsics.h']]], + ['riscv_5femulate_5ffcvt_5fsw_5',['riscv_emulate_fcvt_sw',['../floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a0f2260b7b5793a95c49670379fc89617',1,'neorv32_zfinx_extension_intrinsics.h']]], + ['riscv_5femulate_5ffcvt_5fswu_6',['riscv_emulate_fcvt_swu',['../floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a10a05bface37bff32c78ed0746845794',1,'neorv32_zfinx_extension_intrinsics.h']]], + ['riscv_5femulate_5ffcvt_5fws_7',['riscv_emulate_fcvt_ws',['../floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a292365fe41a7a661e61ae746306ba5e9',1,'neorv32_zfinx_extension_intrinsics.h']]], + ['riscv_5femulate_5ffcvt_5fwus_8',['riscv_emulate_fcvt_wus',['../floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#aad9fc7337e09081cf8c5bff8c28776c8',1,'neorv32_zfinx_extension_intrinsics.h']]], + ['riscv_5femulate_5ffdivs_9',['riscv_emulate_fdivs',['../floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#aeaf46a17b671278be2bf804159827a40',1,'neorv32_zfinx_extension_intrinsics.h']]], + ['riscv_5femulate_5ffeqs_10',['riscv_emulate_feqs',['../floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a7cb3c6570b911cd1dfb7b6e798cc1d21',1,'neorv32_zfinx_extension_intrinsics.h']]], + ['riscv_5femulate_5ffles_11',['riscv_emulate_fles',['../floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#ac5fdef0607602fa0bdb93b3535fd709e',1,'neorv32_zfinx_extension_intrinsics.h']]], + ['riscv_5femulate_5fflts_12',['riscv_emulate_flts',['../floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a2b802122d53a2ce517b3d39fec34d7e0',1,'neorv32_zfinx_extension_intrinsics.h']]], + ['riscv_5femulate_5ffmadds_13',['riscv_emulate_fmadds',['../floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a39212f2e2bb0f1752092a1732f93edf3',1,'neorv32_zfinx_extension_intrinsics.h']]], + ['riscv_5femulate_5ffmaxs_14',['riscv_emulate_fmaxs',['../floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#af9b16a32d2bb13c8af5a678271d74889',1,'neorv32_zfinx_extension_intrinsics.h']]], + ['riscv_5femulate_5ffmins_15',['riscv_emulate_fmins',['../floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a872cd30fb61190bd1ac719d25b01f5a3',1,'neorv32_zfinx_extension_intrinsics.h']]], + ['riscv_5femulate_5ffmsubs_16',['riscv_emulate_fmsubs',['../floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a05d0d5a8eb9422e93448efdeb679cabf',1,'neorv32_zfinx_extension_intrinsics.h']]], + ['riscv_5femulate_5ffmuls_17',['riscv_emulate_fmuls',['../floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#ad43e8bdf4a6fbe229d22d24680f2be80',1,'neorv32_zfinx_extension_intrinsics.h']]], + ['riscv_5femulate_5ffnmadds_18',['riscv_emulate_fnmadds',['../floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#ac8bb4450b39854ab07839e8f3505361c',1,'neorv32_zfinx_extension_intrinsics.h']]], + ['riscv_5femulate_5ffnmsubs_19',['riscv_emulate_fnmsubs',['../floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a833638b346722dfa9d7d5c8d60998ec8',1,'neorv32_zfinx_extension_intrinsics.h']]], + ['riscv_5femulate_5ffsgnjns_20',['riscv_emulate_fsgnjns',['../floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a0c985e626ed1d69314f4e3a0f1f58624',1,'neorv32_zfinx_extension_intrinsics.h']]], + ['riscv_5femulate_5ffsgnjs_21',['riscv_emulate_fsgnjs',['../floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a12498d635f422f607b9b83facf3050dd',1,'neorv32_zfinx_extension_intrinsics.h']]], + ['riscv_5femulate_5ffsgnjxs_22',['riscv_emulate_fsgnjxs',['../floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a98caf7f310820052ae96ce0f45e6cd26',1,'neorv32_zfinx_extension_intrinsics.h']]], + ['riscv_5femulate_5ffsqrts_23',['riscv_emulate_fsqrts',['../floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a1ceb3450f1e5c62d3079cd0e93c03501',1,'neorv32_zfinx_extension_intrinsics.h']]], + ['riscv_5femulate_5ffsubs_24',['riscv_emulate_fsubs',['../floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#ace5d95b855ec1aa8eacdb5bbeea58197',1,'neorv32_zfinx_extension_intrinsics.h']]], + ['riscv_5fintrinsic_5ffadds_25',['riscv_intrinsic_fadds',['../floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a4b151fcb252fc7b894f247f5af6a1809',1,'neorv32_zfinx_extension_intrinsics.h']]], + ['riscv_5fintrinsic_5ffclasss_26',['riscv_intrinsic_fclasss',['../floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a3064a5c57b5f45d57c4d19eb798724f6',1,'neorv32_zfinx_extension_intrinsics.h']]], + ['riscv_5fintrinsic_5ffcvt_5fsw_27',['riscv_intrinsic_fcvt_sw',['../floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a2103eb86052f6f8e24a8a848ffc6528a',1,'neorv32_zfinx_extension_intrinsics.h']]], + ['riscv_5fintrinsic_5ffcvt_5fswu_28',['riscv_intrinsic_fcvt_swu',['../floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a837b7330f9d568791687ae1384b8ef28',1,'neorv32_zfinx_extension_intrinsics.h']]], + ['riscv_5fintrinsic_5ffcvt_5fws_29',['riscv_intrinsic_fcvt_ws',['../floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a523fa0fb6f521311c7f44692c586b3ee',1,'neorv32_zfinx_extension_intrinsics.h']]], + ['riscv_5fintrinsic_5ffcvt_5fwus_30',['riscv_intrinsic_fcvt_wus',['../floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a3bc6ee3059a7e99b187c4ea5e217715b',1,'neorv32_zfinx_extension_intrinsics.h']]], + ['riscv_5fintrinsic_5ffdivs_31',['riscv_intrinsic_fdivs',['../floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#ab6a9d15643e3085ff80c7883f183a42b',1,'neorv32_zfinx_extension_intrinsics.h']]], + ['riscv_5fintrinsic_5ffeqs_32',['riscv_intrinsic_feqs',['../floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#af4ddfae45807d4e41f758672ee14cf7b',1,'neorv32_zfinx_extension_intrinsics.h']]], + ['riscv_5fintrinsic_5ffles_33',['riscv_intrinsic_fles',['../floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#adb83fab39d91e9291da2b7b07830cf82',1,'neorv32_zfinx_extension_intrinsics.h']]], + ['riscv_5fintrinsic_5fflts_34',['riscv_intrinsic_flts',['../floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a85aa18294a58997db2c324184196669c',1,'neorv32_zfinx_extension_intrinsics.h']]], + ['riscv_5fintrinsic_5ffmadds_35',['riscv_intrinsic_fmadds',['../floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#abbdb403cdeef414fa2f867b702d5f6eb',1,'neorv32_zfinx_extension_intrinsics.h']]], + ['riscv_5fintrinsic_5ffmaxs_36',['riscv_intrinsic_fmaxs',['../floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a87c1ce499e5e43554cb0f407cf0d3f7f',1,'neorv32_zfinx_extension_intrinsics.h']]], + ['riscv_5fintrinsic_5ffmins_37',['riscv_intrinsic_fmins',['../floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#abf7f9e466906306d9755fd5bc7946e3c',1,'neorv32_zfinx_extension_intrinsics.h']]], + ['riscv_5fintrinsic_5ffmsubs_38',['riscv_intrinsic_fmsubs',['../floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a03aba9c70c5286dacebaeb0ef5219cc9',1,'neorv32_zfinx_extension_intrinsics.h']]], + ['riscv_5fintrinsic_5ffmuls_39',['riscv_intrinsic_fmuls',['../floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a87a106e0d24a3183712e438d2bcbfa2d',1,'neorv32_zfinx_extension_intrinsics.h']]], + ['riscv_5fintrinsic_5ffnmadds_40',['riscv_intrinsic_fnmadds',['../floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#aa6473bc2d2721b57277b83a3ae0cfdb6',1,'neorv32_zfinx_extension_intrinsics.h']]], + ['riscv_5fintrinsic_5ffnmsubs_41',['riscv_intrinsic_fnmsubs',['../floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a639fc7bd75933888540e9cceb67221a0',1,'neorv32_zfinx_extension_intrinsics.h']]], + ['riscv_5fintrinsic_5ffsgnjns_42',['riscv_intrinsic_fsgnjns',['../floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#aa4010772a986d03929ba7a43dfdcddd9',1,'neorv32_zfinx_extension_intrinsics.h']]], + ['riscv_5fintrinsic_5ffsgnjs_43',['riscv_intrinsic_fsgnjs',['../floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#aff3acd90bcfbda96945f95a0e0bae12b',1,'neorv32_zfinx_extension_intrinsics.h']]], + ['riscv_5fintrinsic_5ffsgnjxs_44',['riscv_intrinsic_fsgnjxs',['../floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a2235d91cdac03bf8071003a5c59b9dd0',1,'neorv32_zfinx_extension_intrinsics.h']]], + ['riscv_5fintrinsic_5ffsqrts_45',['riscv_intrinsic_fsqrts',['../floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a17e2b7a399c956d548a609185084ea3c',1,'neorv32_zfinx_extension_intrinsics.h']]], + ['riscv_5fintrinsic_5ffsubs_46',['riscv_intrinsic_fsubs',['../floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#af8473ba61abab8ae2e3ecbaf22d70e89',1,'neorv32_zfinx_extension_intrinsics.h']]], + ['rte_5fservice_5fhandler_47',['rte_service_handler',['../processor__check_2main_8c.html#a349743a03307abb5130a3e89d903971b',1,'main.c']]] +]; diff --git a/sw/search/functions_b.js b/sw/search/functions_b.js new file mode 100644 index 0000000000..c7ad12bcff --- /dev/null +++ b/sw/search/functions_b.js @@ -0,0 +1,34 @@ +var searchData= +[ + ['save_5fexe_0',['save_exe',['../bootloader_8c.html#ababfffe8e7036179e150ad3b9bda3a74',1,'bootloader.c']]], + ['scan_5fbus_1',['scan_bus',['../demo__onewire_2main_8c.html#ac07c9cfd80ac2e24be9dac6cf943b7de',1,'main.c']]], + ['scan_5ftwi_2',['scan_twi',['../demo__twi_2main_8c.html#aace46ee34e954f9ebee5873beb0785f1',1,'main.c']]], + ['sdi_5fget_3',['sdi_get',['../demo__sdi_2main_8c.html#aa25f620a5631e862252be1d5429e8585',1,'main.c']]], + ['sdi_5fput_4',['sdi_put',['../demo__sdi_2main_8c.html#ae3dc843520a800d7ba2b5d6be03d9c3d',1,'main.c']]], + ['send_5ftwi_5',['send_twi',['../demo__twi_2main_8c.html#aa94edd4f55a3ac18913f661f4bc16fb1',1,'main.c']]], + ['set_5fcell_6',['set_cell',['../game__of__life_2main_8c.html#a5315eb56128f1ca40d9f4d477c345dd7',1,'main.c']]], + ['set_5fclock_7',['set_clock',['../demo__twi_2main_8c.html#acee0c1770467f85a150d072ac7e1252f',1,'main.c']]], + ['setup_5faccess_8',['setup_access',['../bus__explorer_2main_8c.html#a2b6196c2e97a7f7702c0068780304ec1',1,'main.c']]], + ['show_5f1wire_5fcommands_9',['show_1wire_commands',['../demo__onewire_2main_8c.html#a29d5831498c2eaf0415d6f01efb9e7ce',1,'main.c']]], + ['show_5farrays_10',['show_arrays',['../demo__dma_2main_8c.html#a8ad0c7bfd07edb6d42d86b166347206b',1,'main.c']]], + ['show_5fhelp_11',['show_help',['../demo__onewire_2main_8c.html#af25820ed386a66a0d6bb4dcdd2204704',1,'main.c']]], + ['sim_5firq_5ftrigger_12',['sim_irq_trigger',['../processor__check_2main_8c.html#ada24f2cd9d2d384265517f539711de62',1,'main.c']]], + ['slink_5ffirq_5fhandler_13',['slink_firq_handler',['../demo__slink_2main_8c.html#a48c79e20ed1d4138d61b5593bdbe537a',1,'main.c']]], + ['spi_5fcs_14',['spi_cs',['../demo__spi_2main_8c.html#a6f94991b8943a141ed4124585222470d',1,'main.c']]], + ['spi_5fflash_5fcheck_15',['spi_flash_check',['../bootloader_8c.html#a1919595ed2232aebb3e774b916ab1662',1,'bootloader.c']]], + ['spi_5fflash_5ferase_5fsector_16',['spi_flash_erase_sector',['../bootloader_8c.html#a0d877f0611dfcee32a483c8a3660eb1b',1,'bootloader.c']]], + ['spi_5fflash_5fread_5fbyte_17',['spi_flash_read_byte',['../bootloader_8c.html#a09e72e2debdd94929b2be4c7713d5e17',1,'bootloader.c']]], + ['spi_5fflash_5fread_5fstatus_18',['spi_flash_read_status',['../bootloader_8c.html#a005966cd0b32f3d5c041028c4b1c99f5',1,'bootloader.c']]], + ['spi_5fflash_5fwakeup_19',['spi_flash_wakeup',['../bootloader_8c.html#a1fbdccc60f05756213c9f3d64bac6d47',1,'bootloader.c']]], + ['spi_5fflash_5fwrite_5faddr_20',['spi_flash_write_addr',['../bootloader_8c.html#a6a8caddda6e729d747726471b0b0f742',1,'bootloader.c']]], + ['spi_5fflash_5fwrite_5fbyte_21',['spi_flash_write_byte',['../bootloader_8c.html#a006c27b7d80897b78ab8cd83a391331f',1,'bootloader.c']]], + ['spi_5fflash_5fwrite_5fdisable_22',['spi_flash_write_disable',['../bootloader_8c.html#a82d26a2d6293ed7fd44a5c622adfbd45',1,'bootloader.c']]], + ['spi_5fflash_5fwrite_5fenable_23',['spi_flash_write_enable',['../bootloader_8c.html#a9642e28ef2baec5b356ad9a70970d0e6',1,'bootloader.c']]], + ['spi_5fflash_5fwrite_5fword_24',['spi_flash_write_word',['../bootloader_8c.html#a717c72166af7c2ff7e73bd0b47128338',1,'bootloader.c']]], + ['spi_5firq_5fhandler_25',['spi_irq_handler',['../demo__spi__irq_2main_8c.html#a7e266cc5247c999948dacc2102bd184a',1,'main.c']]], + ['spi_5fsetup_26',['spi_setup',['../demo__spi_2main_8c.html#a755192be6c3cf9904564b0eee99de445',1,'main.c']]], + ['spi_5ftrans_27',['spi_trans',['../demo__spi_2main_8c.html#a13e10b34fbbffca6c31f0ce25b3f8432',1,'main.c']]], + ['start_5fapp_28',['start_app',['../bootloader_8c.html#ae8de91537ac2782f0f0ebc3b2d4fb1df',1,'bootloader.c']]], + ['subnormal_5fflush_29',['subnormal_flush',['../floating__point__test_2neorv32__zfinx__extension__intrinsics_8h.html#a791f880781a1bcea1861471be7d1a851',1,'neorv32_zfinx_extension_intrinsics.h']]], + ['system_5ferror_30',['system_error',['../bootloader_8c.html#a3bdfe2f25b1bfb42f80624ffff22ab01',1,'bootloader.c']]] +]; diff --git a/sw/search/functions_c.js b/sw/search/functions_c.js new file mode 100644 index 0000000000..0ebfaceba5 --- /dev/null +++ b/sw/search/functions_c.js @@ -0,0 +1,8 @@ +var searchData= +[ + ['test_5ffail_0',['test_fail',['../processor__check_2main_8c.html#a1e0a5d63896fa26a6c25c0012fc6b938',1,'main.c']]], + ['test_5fok_1',['test_ok',['../processor__check_2main_8c.html#ae61d39109b2747429ec3a3c1b5533598',1,'main.c']]], + ['trap_5fhandler_5femulate_5famo_2',['trap_handler_emulate_amo',['../atomic__test_2main_8c.html#aafcbf639ae4f66e5dfe9dea511a59f9d',1,'main.c']]], + ['trap_5fhandler_5femulate_5funaligned_5flw_3',['trap_handler_emulate_unaligned_lw',['../demo__emulate__unaligned_2main_8c.html#a07da42351229525998965b219e827460',1,'main.c']]], + ['trigger_5fmodule_5fdummy_4',['trigger_module_dummy',['../processor__check_2main_8c.html#ac91bfdd45696444673dc7d6b1b644082',1,'main.c']]] +]; diff --git a/sw/search/functions_d.js b/sw/search/functions_d.js new file mode 100644 index 0000000000..2488556a56 --- /dev/null +++ b/sw/search/functions_d.js @@ -0,0 +1,5 @@ +var searchData= +[ + ['uart_5fget_5fexecutable_0',['uart_get_executable',['../demo__xip_2main_8c.html#a0458656f8a108ff31f4bbbd005f029a0',1,'main.c']]], + ['uart_5fget_5fword_1',['uart_get_word',['../demo__xip_2main_8c.html#a3043d09bdc155f57f45cd91e0cd4d15b',1,'main.c']]] +]; diff --git a/sw/search/functions_e.js b/sw/search/functions_e.js new file mode 100644 index 0000000000..7348ca9c65 --- /dev/null +++ b/sw/search/functions_e.js @@ -0,0 +1,7 @@ +var searchData= +[ + ['vectored_5fglobal_5fhandler_0',['vectored_global_handler',['../processor__check_2main_8c.html#a9504ca74fdb80711a88d2a16d4cb4cf4',1,'main.c']]], + ['vectored_5firq_5ftable_1',['vectored_irq_table',['../processor__check_2main_8c.html#a0d695ebfaae3b4614ddb62640cbf8b7b',1,'main.c']]], + ['vectored_5fmei_5fhandler_2',['vectored_mei_handler',['../processor__check_2main_8c.html#a1a455bede4ab48f32d3ed0868e398044',1,'main.c']]], + ['verify_5fresult_3',['verify_result',['../float__corner__test_2main_8c.html#a941ef8d24fd8e8fe4536626b2ce72410',1,'verify_result(uint32_t num, uint32_t opa, uint32_t opb, uint32_t ref, uint32_t res):&#160;main.c'],['../floating__point__test_2main_8c.html#a941ef8d24fd8e8fe4536626b2ce72410',1,'verify_result(uint32_t num, uint32_t opa, uint32_t opb, uint32_t ref, uint32_t res):&#160;main.c']]] +]; diff --git a/sw/search/functions_f.js b/sw/search/functions_f.js new file mode 100644 index 0000000000..5a8501980a --- /dev/null +++ b/sw/search/functions_f.js @@ -0,0 +1,5 @@ +var searchData= +[ + ['write_5fbyte_0',['write_byte',['../demo__onewire_2main_8c.html#a28283848f09bf8feebc860a51545f487',1,'main.c']]], + ['write_5fmemory_1',['write_memory',['../bus__explorer_2main_8c.html#a96729fb5279642ac56c8e6a513789b45',1,'main.c']]] +]; diff --git a/sw/search/mag.svg b/sw/search/mag.svg new file mode 100644 index 0000000000..ffb6cf0d02 --- /dev/null +++ b/sw/search/mag.svg @@ -0,0 +1,24 @@ +<?xml version="1.0" encoding="UTF-8" standalone="no"?> +<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" + "https://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd"> +<svg + xmlns="http://www.w3.org/2000/svg" + xmlns:xlink="http://www.w3.org/1999/xlink" + viewBox="0 0 20 19" + height="19" + width="20" + id="svg2" + version="1.1"> + <defs + id="defs6" /> + <circle + r="3.5" + cy="8.5" + cx="5.5" + id="path4611" + style="fill:#000000;fill-opacity:0;stroke:#656565;stroke-width:1.4;stroke-opacity:1;stroke-miterlimit:4;stroke-dasharray:none" /> + <path + id="path4630" + d="m 8.1085854,11.109059 2.7823556,2.782356" + style="fill:none;stroke:#656565;stroke-width:1.4;stroke-linecap:round;stroke-linejoin:miter;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:1" /> +</svg> diff --git a/sw/search/mag_d.svg b/sw/search/mag_d.svg new file mode 100644 index 0000000000..4122773f92 --- /dev/null +++ b/sw/search/mag_d.svg @@ -0,0 +1,24 @@ +<?xml version="1.0" encoding="UTF-8" standalone="no"?> +<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" + "https://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd"> +<svg + xmlns="http://www.w3.org/2000/svg" + xmlns:xlink="http://www.w3.org/1999/xlink" + viewBox="0 0 20 19" + height="19" + width="20" + id="svg2" + version="1.1"> + <defs + id="defs6" /> + <circle + r="3.5" + cy="8.5" + cx="5.5" + id="path4611" + style="fill:#000000;fill-opacity:0;stroke:#C5C5C5;stroke-width:1.4;stroke-opacity:1;stroke-miterlimit:4;stroke-dasharray:none" /> + <path + id="path4630" + d="m 8.1085854,11.109059 2.7823556,2.782356" + style="fill:none;stroke:#C5C5C5;stroke-width:1.4;stroke-linecap:round;stroke-linejoin:miter;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:1" /> +</svg> diff --git a/sw/search/mag_sel.svg b/sw/search/mag_sel.svg new file mode 100644 index 0000000000..553dba8773 --- /dev/null +++ b/sw/search/mag_sel.svg @@ -0,0 +1,31 @@ +<?xml version="1.0" encoding="UTF-8" standalone="no"?> +<!-- Created with Inkscape (http://www.inkscape.org/) --> +<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" + "https://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd"> +<svg + xmlns="http://www.w3.org/2000/svg" + version="1.1" + id="svg2" + width="20" + height="19" + viewBox="0 0 20 19" + > + <defs + id="defs6" /> + <circle + style="fill:#000000;fill-opacity:0;stroke:#656565;stroke-width:1.4;stroke-opacity:1;stroke-miterlimit:4;stroke-dasharray:none" + id="path4611" + cx="5.5" + cy="8.5" + r="3.5" /> + <path + style="fill:#656565;fill-opacity:1;stroke:none;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1" + d="M 11,7 13.5,10 16,7 Z" + id="path4609" + /> + <path + style="fill:none;stroke:#656565;stroke-width:1.4;stroke-linecap:round;stroke-linejoin:miter;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:1" + d="m 8.1085854,11.109059 2.7823556,2.782356" + id="path4630" + /> +</svg> diff --git a/sw/search/mag_seld.svg b/sw/search/mag_seld.svg new file mode 100644 index 0000000000..c906f84c83 --- /dev/null +++ b/sw/search/mag_seld.svg @@ -0,0 +1,31 @@ +<?xml version="1.0" encoding="UTF-8" standalone="no"?> +<!-- Created with Inkscape (http://www.inkscape.org/) --> +<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" + "https://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd"> +<svg + xmlns="http://www.w3.org/2000/svg" + version="1.1" + id="svg2" + width="20" + height="19" + viewBox="0 0 20 19" + > + <defs + id="defs6" /> + <circle + style="fill:#000000;fill-opacity:0;stroke:#c5C5C5;stroke-width:1.4;stroke-opacity:1;stroke-miterlimit:4;stroke-dasharray:none" + id="path4611" + cx="5.5" + cy="8.5" + r="3.5" /> + <path + style="fill:#c5C5C5;fill-opacity:1;stroke:none;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1" + d="M 11,7 13.5,10 16,7 Z" + id="path4609" + /> + <path + style="fill:none;stroke:#c5C5C5;stroke-width:1.4;stroke-linecap:round;stroke-linejoin:miter;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:1" + d="m 8.1085854,11.109059 2.7823556,2.782356" + id="path4630" + /> +</svg> diff --git a/sw/search/pages_0.js b/sw/search/pages_0.js new file mode 100644 index 0000000000..de89bd8806 --- /dev/null +++ b/sw/search/pages_0.js @@ -0,0 +1,4 @@ +var searchData= +[ + ['readme_0',['README',['../md_README.html',1,'']]] +]; diff --git a/sw/search/search.css b/sw/search/search.css new file mode 100644 index 0000000000..19f76f9d5b --- /dev/null +++ b/sw/search/search.css @@ -0,0 +1,291 @@ +/*---------------- Search Box positioning */ + +#main-menu > li:last-child { + /* This <li> object is the parent of the search bar */ + display: flex; + justify-content: center; + align-items: center; + height: 36px; + margin-right: 1em; +} + +/*---------------- Search box styling */ + +.SRPage * { + font-weight: normal; + line-height: normal; +} + +dark-mode-toggle { + margin-left: 5px; + display: flex; + float: right; +} + +#MSearchBox { + display: inline-block; + white-space : nowrap; + background: var(--search-background-color); + border-radius: 0.65em; + box-shadow: var(--search-box-shadow); + z-index: 102; +} + +#MSearchBox .left { + display: inline-block; + vertical-align: middle; + height: 1.4em; +} + +#MSearchSelect { + display: inline-block; + vertical-align: middle; + width: 20px; + height: 19px; + background-image: var(--search-magnification-select-image); + margin: 0 0 0 0.3em; + padding: 0; +} + +#MSearchSelectExt { + display: inline-block; + vertical-align: middle; + width: 10px; + height: 19px; + background-image: var(--search-magnification-image); + margin: 0 0 0 0.5em; + padding: 0; +} + + +#MSearchField { + display: inline-block; + vertical-align: middle; + width: 7.5em; + height: 19px; + margin: 0 0.15em; + padding: 0; + line-height: 1em; + border:none; + color: var(--search-foreground-color); + outline: none; + font-family: var(--font-family-search); + -webkit-border-radius: 0px; + border-radius: 0px; + background: none; +} + +@media(hover: none) { + /* to avoid zooming on iOS */ + #MSearchField { + font-size: 16px; + } +} + +#MSearchBox .right { + display: inline-block; + vertical-align: middle; + width: 1.4em; + height: 1.4em; +} + +#MSearchClose { + display: none; + font-size: inherit; + background : none; + border: none; + margin: 0; + padding: 0; + outline: none; + +} + +#MSearchCloseImg { + padding: 0.3em; + margin: 0; +} + +.MSearchBoxActive #MSearchField { + color: var(--search-active-color); +} + + + +/*---------------- Search filter selection */ + +#MSearchSelectWindow { + display: none; + position: absolute; + left: 0; top: 0; + border: 1px solid var(--search-filter-border-color); + background-color: var(--search-filter-background-color); + z-index: 10001; + padding-top: 4px; + padding-bottom: 4px; + -moz-border-radius: 4px; + -webkit-border-top-left-radius: 4px; + -webkit-border-top-right-radius: 4px; + -webkit-border-bottom-left-radius: 4px; + -webkit-border-bottom-right-radius: 4px; + -webkit-box-shadow: 5px 5px 5px rgba(0, 0, 0, 0.15); +} + +.SelectItem { + font: 8pt var(--font-family-search); + padding-left: 2px; + padding-right: 12px; + border: 0px; +} + +span.SelectionMark { + margin-right: 4px; + font-family: var(--font-family-monospace); + outline-style: none; + text-decoration: none; +} + +a.SelectItem { + display: block; + outline-style: none; + color: var(--search-filter-foreground-color); + text-decoration: none; + padding-left: 6px; + padding-right: 12px; +} + +a.SelectItem:focus, +a.SelectItem:active { + color: var(--search-filter-foreground-color); + outline-style: none; + text-decoration: none; +} + +a.SelectItem:hover { + color: var(--search-filter-highlight-text-color); + background-color: var(--search-filter-highlight-bg-color); + outline-style: none; + text-decoration: none; + cursor: pointer; + display: block; +} + +/*---------------- Search results window */ + +iframe#MSearchResults { + /*width: 60ex;*/ + height: 15em; +} + +#MSearchResultsWindow { + display: none; + position: absolute; + left: 0; top: 0; + border: 1px solid var(--search-results-border-color); + background-color: var(--search-results-background-color); + z-index:10000; + width: 300px; + height: 400px; + overflow: auto; +} + +/* ----------------------------------- */ + + +#SRIndex { + clear:both; +} + +.SREntry { + font-size: 10pt; + padding-left: 1ex; +} + +.SRPage .SREntry { + font-size: 8pt; + padding: 1px 5px; +} + +div.SRPage { + margin: 5px 2px; + background-color: var(--search-results-background-color); +} + +.SRChildren { + padding-left: 3ex; padding-bottom: .5em +} + +.SRPage .SRChildren { + display: none; +} + +.SRSymbol { + font-weight: bold; + color: var(--search-results-foreground-color); + font-family: var(--font-family-search); + text-decoration: none; + outline: none; +} + +a.SRScope { + display: block; + color: var(--search-results-foreground-color); + font-family: var(--font-family-search); + font-size: 8pt; + text-decoration: none; + outline: none; +} + +a.SRSymbol:focus, a.SRSymbol:active, +a.SRScope:focus, a.SRScope:active { + text-decoration: underline; +} + +span.SRScope { + padding-left: 4px; + font-family: var(--font-family-search); +} + +.SRPage .SRStatus { + padding: 2px 5px; + font-size: 8pt; + font-style: italic; + font-family: var(--font-family-search); +} + +.SRResult { + display: none; +} + +div.searchresults { + margin-left: 10px; + margin-right: 10px; +} + +/*---------------- External search page results */ + +.pages b { + color: white; + padding: 5px 5px 3px 5px; + background-image: var(--nav-gradient-active-image-parent); + background-repeat: repeat-x; + text-shadow: 0 1px 1px #000000; +} + +.pages { + line-height: 17px; + margin-left: 4px; + text-decoration: none; +} + +.hl { + font-weight: bold; +} + +#searchresults { + margin-bottom: 20px; +} + +.searchpages { + margin-top: 10px; +} + diff --git a/sw/search/search.js b/sw/search/search.js new file mode 100644 index 0000000000..666af01e5e --- /dev/null +++ b/sw/search/search.js @@ -0,0 +1,694 @@ +/* + @licstart The following is the entire license notice for the JavaScript code in this file. + + The MIT License (MIT) + + Copyright (C) 1997-2020 by Dimitri van Heesch + + Permission is hereby granted, free of charge, to any person obtaining a copy of this software + and associated documentation files (the "Software"), to deal in the Software without restriction, + including without limitation the rights to use, copy, modify, merge, publish, distribute, + sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is + furnished to do so, subject to the following conditions: + + The above copyright notice and this permission notice shall be included in all copies or + substantial portions of the Software. + + THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING + BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND + NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, + DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. + + @licend The above is the entire license notice for the JavaScript code in this file + */ +const SEARCH_COOKIE_NAME = ''+'search_grp'; + +const searchResults = new SearchResults(); + +/* A class handling everything associated with the search panel. + + Parameters: + name - The name of the global variable that will be + storing this instance. Is needed to be able to set timeouts. + resultPath - path to use for external files +*/ +function SearchBox(name, resultsPath, extension) { + if (!name || !resultsPath) { alert("Missing parameters to SearchBox."); } + if (!extension || extension == "") { extension = ".html"; } + + function getXPos(item) { + let x = 0; + if (item.offsetWidth) { + while (item && item!=document.body) { + x += item.offsetLeft; + item = item.offsetParent; + } + } + return x; + } + + function getYPos(item) { + let y = 0; + if (item.offsetWidth) { + while (item && item!=document.body) { + y += item.offsetTop; + item = item.offsetParent; + } + } + return y; + } + + // ---------- Instance variables + this.name = name; + this.resultsPath = resultsPath; + this.keyTimeout = 0; + this.keyTimeoutLength = 500; + this.closeSelectionTimeout = 300; + this.lastSearchValue = ""; + this.lastResultsPage = ""; + this.hideTimeout = 0; + this.searchIndex = 0; + this.searchActive = false; + this.extension = extension; + + // ----------- DOM Elements + + this.DOMSearchField = () => document.getElementById("MSearchField"); + this.DOMSearchSelect = () => document.getElementById("MSearchSelect"); + this.DOMSearchSelectWindow = () => document.getElementById("MSearchSelectWindow"); + this.DOMPopupSearchResults = () => document.getElementById("MSearchResults"); + this.DOMPopupSearchResultsWindow = () => document.getElementById("MSearchResultsWindow"); + this.DOMSearchClose = () => document.getElementById("MSearchClose"); + this.DOMSearchBox = () => document.getElementById("MSearchBox"); + + // ------------ Event Handlers + + // Called when focus is added or removed from the search field. + this.OnSearchFieldFocus = function(isActive) { + this.Activate(isActive); + } + + this.OnSearchSelectShow = function() { + const searchSelectWindow = this.DOMSearchSelectWindow(); + const searchField = this.DOMSearchSelect(); + + const left = getXPos(searchField); + const top = getYPos(searchField) + searchField.offsetHeight; + + // show search selection popup + searchSelectWindow.style.display='block'; + searchSelectWindow.style.left = left + 'px'; + searchSelectWindow.style.top = top + 'px'; + + // stop selection hide timer + if (this.hideTimeout) { + clearTimeout(this.hideTimeout); + this.hideTimeout=0; + } + return false; // to avoid "image drag" default event + } + + this.OnSearchSelectHide = function() { + this.hideTimeout = setTimeout(this.CloseSelectionWindow.bind(this), + this.closeSelectionTimeout); + } + + // Called when the content of the search field is changed. + this.OnSearchFieldChange = function(evt) { + if (this.keyTimeout) { // kill running timer + clearTimeout(this.keyTimeout); + this.keyTimeout = 0; + } + + const e = evt ? evt : window.event; // for IE + if (e.keyCode==40 || e.keyCode==13) { + if (e.shiftKey==1) { + this.OnSearchSelectShow(); + const win=this.DOMSearchSelectWindow(); + for (let i=0;i<win.childNodes.length;i++) { + const child = win.childNodes[i]; // get span within a + if (child.className=='SelectItem') { + child.focus(); + return; + } + } + return; + } else { + const elem = searchResults.NavNext(0); + if (elem) elem.focus(); + } + } else if (e.keyCode==27) { // Escape out of the search field + e.stopPropagation(); + this.DOMSearchField().blur(); + this.DOMPopupSearchResultsWindow().style.display = 'none'; + this.DOMSearchClose().style.display = 'none'; + this.lastSearchValue = ''; + this.Activate(false); + return; + } + + // strip whitespaces + const searchValue = this.DOMSearchField().value.replace(/ +/g, ""); + + if (searchValue != this.lastSearchValue) { // search value has changed + if (searchValue != "") { // non-empty search + // set timer for search update + this.keyTimeout = setTimeout(this.Search.bind(this), this.keyTimeoutLength); + } else { // empty search field + this.DOMPopupSearchResultsWindow().style.display = 'none'; + this.DOMSearchClose().style.display = 'none'; + this.lastSearchValue = ''; + } + } + } + + this.SelectItemCount = function() { + let count=0; + const win=this.DOMSearchSelectWindow(); + for (let i=0;i<win.childNodes.length;i++) { + const child = win.childNodes[i]; // get span within a + if (child.className=='SelectItem') { + count++; + } + } + return count; + } + + this.GetSelectionIdByName = function(name) { + let j=0; + const win=this.DOMSearchSelectWindow(); + for (let i=0;i<win.childNodes.length;i++) { + const child = win.childNodes[i]; + if (child.className=='SelectItem') { + if (child.childNodes[1].nodeValue==name) { + return j; + } + j++; + } + } + return 0; + } + + this.SelectItemSet = function(id) { + let j=0; + const win=this.DOMSearchSelectWindow(); + for (let i=0;i<win.childNodes.length;i++) { + const child = win.childNodes[i]; // get span within a + if (child.className=='SelectItem') { + const node = child.firstChild; + if (j==id) { + node.innerHTML='&#8226;'; + Cookie.writeSetting(SEARCH_COOKIE_NAME, child.childNodes[1].nodeValue, 0) + } else { + node.innerHTML='&#160;'; + } + j++; + } + } + } + + // Called when an search filter selection is made. + // set item with index id as the active item + this.OnSelectItem = function(id) { + this.searchIndex = id; + this.SelectItemSet(id); + const searchValue = this.DOMSearchField().value.replace(/ +/g, ""); + if (searchValue!="" && this.searchActive) { // something was found -> do a search + this.Search(); + } + } + + this.OnSearchSelectKey = function(evt) { + const e = (evt) ? evt : window.event; // for IE + if (e.keyCode==40 && this.searchIndex<this.SelectItemCount()) { // Down + this.searchIndex++; + this.OnSelectItem(this.searchIndex); + } else if (e.keyCode==38 && this.searchIndex>0) { // Up + this.searchIndex--; + this.OnSelectItem(this.searchIndex); + } else if (e.keyCode==13 || e.keyCode==27) { + e.stopPropagation(); + this.OnSelectItem(this.searchIndex); + this.CloseSelectionWindow(); + this.DOMSearchField().focus(); + } + return false; + } + + // --------- Actions + + // Closes the results window. + this.CloseResultsWindow = function() { + this.DOMPopupSearchResultsWindow().style.display = 'none'; + this.DOMSearchClose().style.display = 'none'; + this.Activate(false); + } + + this.CloseSelectionWindow = function() { + this.DOMSearchSelectWindow().style.display = 'none'; + } + + // Performs a search. + this.Search = function() { + this.keyTimeout = 0; + + // strip leading whitespace + const searchValue = this.DOMSearchField().value.replace(/^ +/, ""); + + const code = searchValue.toLowerCase().charCodeAt(0); + let idxChar = searchValue.substr(0, 1).toLowerCase(); + if ( 0xD800 <= code && code <= 0xDBFF && searchValue > 1) { // surrogate pair + idxChar = searchValue.substr(0, 2); + } + + let jsFile; + let idx = indexSectionsWithContent[this.searchIndex].indexOf(idxChar); + if (idx!=-1) { + const hexCode=idx.toString(16); + jsFile = this.resultsPath + indexSectionNames[this.searchIndex] + '_' + hexCode + '.js'; + } + + const loadJS = function(url, impl, loc) { + const scriptTag = document.createElement('script'); + scriptTag.src = url; + scriptTag.onload = impl; + scriptTag.onreadystatechange = impl; + loc.appendChild(scriptTag); + } + + const domPopupSearchResultsWindow = this.DOMPopupSearchResultsWindow(); + const domSearchBox = this.DOMSearchBox(); + const domPopupSearchResults = this.DOMPopupSearchResults(); + const domSearchClose = this.DOMSearchClose(); + const resultsPath = this.resultsPath; + + const handleResults = function() { + document.getElementById("Loading").style.display="none"; + if (typeof searchData !== 'undefined') { + createResults(resultsPath); + document.getElementById("NoMatches").style.display="none"; + } + + if (idx!=-1) { + searchResults.Search(searchValue); + } else { // no file with search results => force empty search results + searchResults.Search('===='); + } + + if (domPopupSearchResultsWindow.style.display!='block') { + domSearchClose.style.display = 'inline-block'; + let left = getXPos(domSearchBox) + 150; + let top = getYPos(domSearchBox) + 20; + domPopupSearchResultsWindow.style.display = 'block'; + left -= domPopupSearchResults.offsetWidth; + const maxWidth = document.body.clientWidth; + const maxHeight = document.body.clientHeight; + let width = 300; + if (left<10) left=10; + if (width+left+8>maxWidth) width=maxWidth-left-8; + let height = 400; + if (height+top+8>maxHeight) height=maxHeight-top-8; + domPopupSearchResultsWindow.style.top = top + 'px'; + domPopupSearchResultsWindow.style.left = left + 'px'; + domPopupSearchResultsWindow.style.width = width + 'px'; + domPopupSearchResultsWindow.style.height = height + 'px'; + } + } + + if (jsFile) { + loadJS(jsFile, handleResults, this.DOMPopupSearchResultsWindow()); + } else { + handleResults(); + } + + this.lastSearchValue = searchValue; + } + + // -------- Activation Functions + + // Activates or deactivates the search panel, resetting things to + // their default values if necessary. + this.Activate = function(isActive) { + if (isActive || // open it + this.DOMPopupSearchResultsWindow().style.display == 'block' + ) { + this.DOMSearchBox().className = 'MSearchBoxActive'; + this.searchActive = true; + } else if (!isActive) { // directly remove the panel + this.DOMSearchBox().className = 'MSearchBoxInactive'; + this.searchActive = false; + this.lastSearchValue = '' + this.lastResultsPage = ''; + this.DOMSearchField().value = ''; + } + } +} + +// ----------------------------------------------------------------------- + +// The class that handles everything on the search results page. +function SearchResults() { + + function convertToId(search) { + let result = ''; + for (let i=0;i<search.length;i++) { + const c = search.charAt(i); + const cn = c.charCodeAt(0); + if (c.match(/[a-z0-9\u0080-\uFFFF]/)) { + result+=c; + } else if (cn<16) { + result+="_0"+cn.toString(16); + } else { + result+="_"+cn.toString(16); + } + } + return result; + } + + // The number of matches from the last run of <Search()>. + this.lastMatchCount = 0; + this.lastKey = 0; + this.repeatOn = false; + + // Toggles the visibility of the passed element ID. + this.FindChildElement = function(id) { + const parentElement = document.getElementById(id); + let element = parentElement.firstChild; + + while (element && element!=parentElement) { + if (element.nodeName.toLowerCase() == 'div' && element.className == 'SRChildren') { + return element; + } + + if (element.nodeName.toLowerCase() == 'div' && element.hasChildNodes()) { + element = element.firstChild; + } else if (element.nextSibling) { + element = element.nextSibling; + } else { + do { + element = element.parentNode; + } + while (element && element!=parentElement && !element.nextSibling); + + if (element && element!=parentElement) { + element = element.nextSibling; + } + } + } + } + + this.Toggle = function(id) { + const element = this.FindChildElement(id); + if (element) { + if (element.style.display == 'block') { + element.style.display = 'none'; + } else { + element.style.display = 'block'; + } + } + } + + // Searches for the passed string. If there is no parameter, + // it takes it from the URL query. + // + // Always returns true, since other documents may try to call it + // and that may or may not be possible. + this.Search = function(search) { + if (!search) { // get search word from URL + search = window.location.search; + search = search.substring(1); // Remove the leading '?' + search = unescape(search); + } + + search = search.replace(/^ +/, ""); // strip leading spaces + search = search.replace(/ +$/, ""); // strip trailing spaces + search = search.toLowerCase(); + search = convertToId(search); + + const resultRows = document.getElementsByTagName("div"); + let matches = 0; + + let i = 0; + while (i < resultRows.length) { + const row = resultRows.item(i); + if (row.className == "SRResult") { + let rowMatchName = row.id.toLowerCase(); + rowMatchName = rowMatchName.replace(/^sr\d*_/, ''); // strip 'sr123_' + + if (search.length<=rowMatchName.length && + rowMatchName.substr(0, search.length)==search) { + row.style.display = 'block'; + matches++; + } else { + row.style.display = 'none'; + } + } + i++; + } + document.getElementById("Searching").style.display='none'; + if (matches == 0) { // no results + document.getElementById("NoMatches").style.display='block'; + } else { // at least one result + document.getElementById("NoMatches").style.display='none'; + } + this.lastMatchCount = matches; + return true; + } + + // return the first item with index index or higher that is visible + this.NavNext = function(index) { + let focusItem; + for (;;) { + const focusName = 'Item'+index; + focusItem = document.getElementById(focusName); + if (focusItem && focusItem.parentNode.parentNode.style.display=='block') { + break; + } else if (!focusItem) { // last element + break; + } + focusItem=null; + index++; + } + return focusItem; + } + + this.NavPrev = function(index) { + let focusItem; + for (;;) { + const focusName = 'Item'+index; + focusItem = document.getElementById(focusName); + if (focusItem && focusItem.parentNode.parentNode.style.display=='block') { + break; + } else if (!focusItem) { // last element + break; + } + focusItem=null; + index--; + } + return focusItem; + } + + this.ProcessKeys = function(e) { + if (e.type == "keydown") { + this.repeatOn = false; + this.lastKey = e.keyCode; + } else if (e.type == "keypress") { + if (!this.repeatOn) { + if (this.lastKey) this.repeatOn = true; + return false; // ignore first keypress after keydown + } + } else if (e.type == "keyup") { + this.lastKey = 0; + this.repeatOn = false; + } + return this.lastKey!=0; + } + + this.Nav = function(evt,itemIndex) { + const e = (evt) ? evt : window.event; // for IE + if (e.keyCode==13) return true; + if (!this.ProcessKeys(e)) return false; + + if (this.lastKey==38) { // Up + const newIndex = itemIndex-1; + let focusItem = this.NavPrev(newIndex); + if (focusItem) { + let child = this.FindChildElement(focusItem.parentNode.parentNode.id); + if (child && child.style.display == 'block') { // children visible + let n=0; + let tmpElem; + for (;;) { // search for last child + tmpElem = document.getElementById('Item'+newIndex+'_c'+n); + if (tmpElem) { + focusItem = tmpElem; + } else { // found it! + break; + } + n++; + } + } + } + if (focusItem) { + focusItem.focus(); + } else { // return focus to search field + document.getElementById("MSearchField").focus(); + } + } else if (this.lastKey==40) { // Down + const newIndex = itemIndex+1; + let focusItem; + const item = document.getElementById('Item'+itemIndex); + const elem = this.FindChildElement(item.parentNode.parentNode.id); + if (elem && elem.style.display == 'block') { // children visible + focusItem = document.getElementById('Item'+itemIndex+'_c0'); + } + if (!focusItem) focusItem = this.NavNext(newIndex); + if (focusItem) focusItem.focus(); + } else if (this.lastKey==39) { // Right + const item = document.getElementById('Item'+itemIndex); + const elem = this.FindChildElement(item.parentNode.parentNode.id); + if (elem) elem.style.display = 'block'; + } else if (this.lastKey==37) { // Left + const item = document.getElementById('Item'+itemIndex); + const elem = this.FindChildElement(item.parentNode.parentNode.id); + if (elem) elem.style.display = 'none'; + } else if (this.lastKey==27) { // Escape + e.stopPropagation(); + searchBox.CloseResultsWindow(); + document.getElementById("MSearchField").focus(); + } else if (this.lastKey==13) { // Enter + return true; + } + return false; + } + + this.NavChild = function(evt,itemIndex,childIndex) { + const e = (evt) ? evt : window.event; // for IE + if (e.keyCode==13) return true; + if (!this.ProcessKeys(e)) return false; + + if (this.lastKey==38) { // Up + if (childIndex>0) { + const newIndex = childIndex-1; + document.getElementById('Item'+itemIndex+'_c'+newIndex).focus(); + } else { // already at first child, jump to parent + document.getElementById('Item'+itemIndex).focus(); + } + } else if (this.lastKey==40) { // Down + const newIndex = childIndex+1; + let elem = document.getElementById('Item'+itemIndex+'_c'+newIndex); + if (!elem) { // last child, jump to parent next parent + elem = this.NavNext(itemIndex+1); + } + if (elem) { + elem.focus(); + } + } else if (this.lastKey==27) { // Escape + e.stopPropagation(); + searchBox.CloseResultsWindow(); + document.getElementById("MSearchField").focus(); + } else if (this.lastKey==13) { // Enter + return true; + } + return false; + } +} + +function createResults(resultsPath) { + + function setKeyActions(elem,action) { + elem.setAttribute('onkeydown',action); + elem.setAttribute('onkeypress',action); + elem.setAttribute('onkeyup',action); + } + + function setClassAttr(elem,attr) { + elem.setAttribute('class',attr); + elem.setAttribute('className',attr); + } + + const results = document.getElementById("SRResults"); + results.innerHTML = ''; + searchData.forEach((elem,index) => { + const id = elem[0]; + const srResult = document.createElement('div'); + srResult.setAttribute('id','SR_'+id); + setClassAttr(srResult,'SRResult'); + const srEntry = document.createElement('div'); + setClassAttr(srEntry,'SREntry'); + const srLink = document.createElement('a'); + srLink.setAttribute('id','Item'+index); + setKeyActions(srLink,'return searchResults.Nav(event,'+index+')'); + setClassAttr(srLink,'SRSymbol'); + srLink.innerHTML = elem[1][0]; + srEntry.appendChild(srLink); + if (elem[1].length==2) { // single result + srLink.setAttribute('href',resultsPath+elem[1][1][0]); + srLink.setAttribute('onclick','searchBox.CloseResultsWindow()'); + if (elem[1][1][1]) { + srLink.setAttribute('target','_parent'); + } else { + srLink.setAttribute('target','_blank'); + } + const srScope = document.createElement('span'); + setClassAttr(srScope,'SRScope'); + srScope.innerHTML = elem[1][1][2]; + srEntry.appendChild(srScope); + } else { // multiple results + srLink.setAttribute('href','javascript:searchResults.Toggle("SR_'+id+'")'); + const srChildren = document.createElement('div'); + setClassAttr(srChildren,'SRChildren'); + for (let c=0; c<elem[1].length-1; c++) { + const srChild = document.createElement('a'); + srChild.setAttribute('id','Item'+index+'_c'+c); + setKeyActions(srChild,'return searchResults.NavChild(event,'+index+','+c+')'); + setClassAttr(srChild,'SRScope'); + srChild.setAttribute('href',resultsPath+elem[1][c+1][0]); + srChild.setAttribute('onclick','searchBox.CloseResultsWindow()'); + if (elem[1][c+1][1]) { + srChild.setAttribute('target','_parent'); + } else { + srChild.setAttribute('target','_blank'); + } + srChild.innerHTML = elem[1][c+1][2]; + srChildren.appendChild(srChild); + } + srEntry.appendChild(srChildren); + } + srResult.appendChild(srEntry); + results.appendChild(srResult); + }); +} + +function init_search() { + const results = document.getElementById("MSearchSelectWindow"); + + results.tabIndex=0; + for (let key in indexSectionLabels) { + const link = document.createElement('a'); + link.setAttribute('class','SelectItem'); + link.setAttribute('onclick','searchBox.OnSelectItem('+key+')'); + link.href='javascript:void(0)'; + link.innerHTML='<span class="SelectionMark">&#160;</span>'+indexSectionLabels[key]; + results.appendChild(link); + } + + const input = document.getElementById("MSearchSelect"); + const searchSelectWindow = document.getElementById("MSearchSelectWindow"); + input.tabIndex=0; + input.addEventListener("keydown", function(event) { + if (event.keyCode==13 || event.keyCode==40) { + event.preventDefault(); + if (searchSelectWindow.style.display == 'block') { + searchBox.CloseSelectionWindow(); + } else { + searchBox.OnSearchSelectShow(); + searchBox.DOMSearchSelectWindow().focus(); + } + } + }); + const name = Cookie.readSetting(SEARCH_COOKIE_NAME,0); + const id = searchBox.GetSelectionIdByName(name); + searchBox.OnSelectItem(id); +} +/* @license-end */ diff --git a/sw/search/searchdata.js b/sw/search/searchdata.js new file mode 100644 index 0000000000..a4ce3f0a34 --- /dev/null +++ b/sw/search/searchdata.js @@ -0,0 +1,39 @@ +var indexSectionsWithContent = +{ + 0: "12345:_abcdefghiklmnoprstuvwxy", + 1: "dfnrst", + 2: "bmns", + 3: "_abcdghmnprstuvwx", + 4: "_abcdefghikmoprstuwxy", + 5: "ens", + 6: "cdefghnoprstuwx", + 7: "abcdefgimnoprstuwx", + 8: "r" +}; + +var indexSectionNames = +{ + 0: "all", + 1: "classes", + 2: "files", + 3: "functions", + 4: "variables", + 5: "enums", + 6: "enumvalues", + 7: "defines", + 8: "pages" +}; + +var indexSectionLabels = +{ + 0: "All", + 1: "Data Structures", + 2: "Files", + 3: "Functions", + 4: "Variables", + 5: "Enumerations", + 6: "Enumerator", + 7: "Macros", + 8: "Pages" +}; + diff --git a/sw/search/variables_0.js b/sw/search/variables_0.js new file mode 100644 index 0000000000..5ff8f5d161 --- /dev/null +++ b/sw/search/variables_0.js @@ -0,0 +1,6 @@ +var searchData= +[ + ['_5f_5fcrt0_5fmax_5fheap_0',['__crt0_max_heap',['../demo__newlib_2main_8c.html#aaa2cb9e7075a852870fd67eff2861b18',1,'main.c']]], + ['_5f_5fneorv32_5frte_5fvector_5flut_1',['__neorv32_rte_vector_lut',['../neorv32__rte_8c.html#a2c8272b4628edddb943bcfad829b561a',1,'neorv32_rte.c']]], + ['_5f_5fneorv32_5fxirq_5fvector_5flut_2',['__neorv32_xirq_vector_lut',['../neorv32__xirq_8c.html#a76d73c3bf372989703c685a9e8d229ac',1,'neorv32_xirq.c']]] +]; diff --git a/sw/search/variables_1.js b/sw/search/variables_1.js new file mode 100644 index 0000000000..35e5501d58 --- /dev/null +++ b/sw/search/variables_1.js @@ -0,0 +1,4 @@ +var searchData= +[ + ['amo_5fvar_0',['amo_var',['../atomic__test_2main_8c.html#a9141e95a5f98420ddf8a43e6d20ff6dc',1,'main.c']]] +]; diff --git a/sw/search/variables_10.js b/sw/search/variables_10.js new file mode 100644 index 0000000000..0f86d31936 --- /dev/null +++ b/sw/search/variables_10.js @@ -0,0 +1,15 @@ +var searchData= +[ + ['thres_0',['THRES',['../structneorv32__gptmr__t.html#a666ebcbea13dafcf1987629f3e0092ee',1,'neorv32_gptmr_t']]], + ['time_5fdec_5fhw_1',['time_dec_hw',['../demo__cfu_2main_8c.html#acb6dd9d6ab74ac94f174a11ff3ad76af',1,'main.c']]], + ['time_5fdec_5fsw_2',['time_dec_sw',['../demo__cfu_2main_8c.html#a2d3853c367c3bce99e787c0df445030a',1,'main.c']]], + ['time_5fenc_5fhw_3',['time_enc_hw',['../demo__cfu_2main_8c.html#a094212e3731a9aecbd278fac243de6ec',1,'main.c']]], + ['time_5fenc_5fsw_4',['time_enc_sw',['../demo__cfu_2main_8c.html#ad424a26173bd8d84b8d1cae94a55f248',1,'main.c']]], + ['time_5fhi_5',['TIME_HI',['../structneorv32__mtime__t.html#a1ffe0be2c45f5d7aa2686abf40cd1693',1,'neorv32_mtime_t']]], + ['time_5flo_6',['TIME_LO',['../structneorv32__mtime__t.html#acccaa3dd87a57ebd5f7ae504771e904e',1,'neorv32_mtime_t']]], + ['timecmp_5fhi_7',['TIMECMP_HI',['../structneorv32__mtime__t.html#af05df268c8f699401cf752e4249ba422',1,'neorv32_mtime_t']]], + ['timecmp_5flo_8',['TIMECMP_LO',['../structneorv32__mtime__t.html#ab5fa56ca5c2f9d547f58d169d6da96e5',1,'neorv32_mtime_t']]], + ['tpol_9',['TPOL',['../structneorv32__xirq__t.html#a5fe0036a2cada585228b60aaa780e92a',1,'neorv32_xirq_t']]], + ['ttyp_10',['TTYP',['../structneorv32__xirq__t.html#ab7117c210b5f0a8ebc369eeba6a4a5bc',1,'neorv32_xirq_t']]], + ['ttype_11',['TTYPE',['../structneorv32__dma__t.html#a70c28642195765409d97b941e98f47ca',1,'neorv32_dma_t']]] +]; diff --git a/sw/search/variables_11.js b/sw/search/variables_11.js new file mode 100644 index 0000000000..14be767282 --- /dev/null +++ b/sw/search/variables_11.js @@ -0,0 +1,10 @@ +var searchData= +[ + ['uint16fifo_0',['uint16Fifo',['../structt__neorv32__spi.html#a71fb3f91af197e1abdbe97d62130ad0f',1,'t_neorv32_spi']]], + ['uint32read_1',['uint32Read',['../structt__neorv32__spi.html#a5750a54f8312ec2fed349eb9fbeff323',1,'t_neorv32_spi']]], + ['uint32total_2',['uint32Total',['../structt__neorv32__spi.html#aa4d96f72e57fb6930ab43de6fb0a85ae',1,'t_neorv32_spi']]], + ['uint32write_3',['uint32Write',['../structt__neorv32__spi.html#aa89b7a769e54e331798e4d68d02a7b43',1,'t_neorv32_spi']]], + ['uint8csn_4',['uint8Csn',['../structt__neorv32__spi.html#a435c266758a440d32de4344472e3514a',1,'t_neorv32_spi']]], + ['uint8isbusy_5',['uint8IsBusy',['../structt__neorv32__spi.html#a8ed31f9393bee5b963e08582b6c517ed',1,'t_neorv32_spi']]], + ['universe_6',['universe',['../game__of__life_2main_8c.html#ae0b5214cf0cd93049e9df8a95a09d826',1,'main.c']]] +]; diff --git a/sw/search/variables_12.js b/sw/search/variables_12.js new file mode 100644 index 0000000000..d211425b5a --- /dev/null +++ b/sw/search/variables_12.js @@ -0,0 +1,4 @@ +var searchData= +[ + ['weekday_0',['weekday',['../structdate__t.html#a44167cd71416886e55048310af6d4e1b',1,'date_t']]] +]; diff --git a/sw/search/variables_13.js b/sw/search/variables_13.js new file mode 100644 index 0000000000..fa66a55138 --- /dev/null +++ b/sw/search/variables_13.js @@ -0,0 +1,4 @@ +var searchData= +[ + ['xtea_5fdelta_0',['xtea_delta',['../demo__cfu_2main_8c.html#a26da64691624f3c899f2394a427d6593',1,'main.c']]] +]; diff --git a/sw/search/variables_14.js b/sw/search/variables_14.js new file mode 100644 index 0000000000..e613d54073 --- /dev/null +++ b/sw/search/variables_14.js @@ -0,0 +1,4 @@ +var searchData= +[ + ['year_0',['year',['../structdate__t.html#aabab1b1efd94b69bfb28b639c612dd4f',1,'date_t']]] +]; diff --git a/sw/search/variables_2.js b/sw/search/variables_2.js new file mode 100644 index 0000000000..cf22cf2ffa --- /dev/null +++ b/sw/search/variables_2.js @@ -0,0 +1,4 @@ +var searchData= +[ + ['binary_5fvalue_0',['binary_value',['../unionfloat__conv__t.html#a59ad19d41b1d973a6bda9032e1937606',1,'float_conv_t']]] +]; diff --git a/sw/search/variables_3.js b/sw/search/variables_3.js new file mode 100644 index 0000000000..37ac8ae1e0 --- /dev/null +++ b/sw/search/variables_3.js @@ -0,0 +1,9 @@ +var searchData= +[ + ['cache_0',['CACHE',['../structneorv32__sysinfo__t.html#ada99a36ccda38b254d5b6a84883101f6',1,'neorv32_sysinfo_t']]], + ['clk_1',['CLK',['../structneorv32__sysinfo__t.html#afc225843ee31efff6350415b5aaae761',1,'neorv32_sysinfo_t']]], + ['count_2',['COUNT',['../structneorv32__gptmr__t.html#a1abc5bae1dffc64006e965d4570da479',1,'neorv32_gptmr_t']]], + ['ctrl_3',['CTRL',['../structneorv32__dma__t.html#a8480d6ad3ba5063cdf21dca286711569',1,'neorv32_dma_t::CTRL'],['../structneorv32__gptmr__t.html#a3c477ccb24ed12122d9d90244431c7e9',1,'neorv32_gptmr_t::CTRL'],['../structneorv32__neoled__t.html#adfe7618c002ff88dd22e65fcedfd6139',1,'neorv32_neoled_t::CTRL'],['../structneorv32__onewire__t.html#a310df3bab43e4438417b2ff948f4712a',1,'neorv32_onewire_t::CTRL'],['../structneorv32__pwm__t.html#ab86705332ebd9c45635c3195c6b3dcc5',1,'neorv32_pwm_t::CTRL'],['../structneorv32__sdi__t.html#af494f25cbcd8478cf384eb868e447303',1,'neorv32_sdi_t::CTRL'],['../structneorv32__slink__t.html#a39ece6aeeea6982002e164902a1e784f',1,'neorv32_slink_t::CTRL'],['../structneorv32__spi__t.html#a34fa748f0e3ceb75822c0a5553bd0420',1,'neorv32_spi_t::CTRL'],['../structneorv32__trng__t.html#ae2ff37ce30fb85ef59d9012534bc7e67',1,'neorv32_trng_t::CTRL'],['../structneorv32__twi__t.html#a148a1c681a2632881b25ee41652b5304',1,'neorv32_twi_t::CTRL'],['../structneorv32__uart__t.html#a0a6227aeea38335d2b9a9da46b35451b',1,'neorv32_uart_t::CTRL'],['../structneorv32__wdt__t.html#a6ae41e28d08b0f06118c499f52b56f41',1,'neorv32_wdt_t::CTRL'],['../structneorv32__xip__t.html#a7ead9d6a4f784d766a6b2755c6d35235',1,'neorv32_xip_t::CTRL']]], + ['cypher_5fdata_5fhw_4',['cypher_data_hw',['../demo__cfu_2main_8c.html#a9ad2780a4cfe0d9cb4f1a846a92063ae',1,'main.c']]], + ['cypher_5fdata_5fsw_5',['cypher_data_sw',['../demo__cfu_2main_8c.html#a33b2d9298edf94c5961e67a59c371d00',1,'main.c']]] +]; diff --git a/sw/search/variables_4.js b/sw/search/variables_4.js new file mode 100644 index 0000000000..79fa9c1b38 --- /dev/null +++ b/sw/search/variables_4.js @@ -0,0 +1,12 @@ +var searchData= +[ + ['data_0',['DATA',['../structneorv32__crc__t.html#a47f286612848f597859aaef0d2d5da4d',1,'neorv32_crc_t::DATA'],['../structneorv32__neoled__t.html#a995fb1d63a9dfb3f20d715932781c1de',1,'neorv32_neoled_t::DATA'],['../structneorv32__onewire__t.html#a2c04aa736b901940ed65b96202c8af7a',1,'neorv32_onewire_t::DATA'],['../structneorv32__sdi__t.html#a3ea6903c0924d0a1b633b6a2b0ae44f1',1,'neorv32_sdi_t::DATA'],['../structneorv32__slink__t.html#a8af7d4ea9787cf94c599c82133c6aa74',1,'neorv32_slink_t::DATA'],['../structneorv32__spi__t.html#a3901bad351213e34820197a33d589f1e',1,'neorv32_spi_t::DATA'],['../structneorv32__uart__t.html#a38eec82aae9ed522a0d2afb9a9560036',1,'neorv32_uart_t::DATA']]], + ['data_5fblock_1',['data_block',['../demo__emulate__unaligned_2main_8c.html#a556f675911f865ead06c36072b1b9c3b',1,'main.c']]], + ['data_5fhi_2',['DATA_HI',['../structneorv32__xip__t.html#a516ab9c075ef6d1fb741e243db7703b2',1,'neorv32_xip_t']]], + ['data_5flast_3',['DATA_LAST',['../structneorv32__slink__t.html#ada8f10141d2161b83a5a367722ed6a77',1,'neorv32_slink_t']]], + ['data_5flo_4',['DATA_LO',['../structneorv32__xip__t.html#ad64048bb3544e712b1c668c2ef343ccb',1,'neorv32_xip_t']]], + ['day_5',['day',['../structdate__t.html#a482ad87226bae7841dfec63e035aeace',1,'date_t']]], + ['dc_6',['DC',['../structneorv32__pwm__t.html#a6d29528ca60921a6ef8e5bcde81925e7',1,'neorv32_pwm_t']]], + ['dcmd_7',['DCMD',['../structneorv32__twi__t.html#ae311e0827bdb178c6dd8c4535b80d5cb',1,'neorv32_twi_t']]], + ['dst_5fbase_8',['DST_BASE',['../structneorv32__dma__t.html#aee8a6cf3cbd9fe3c5995f046ffb9a1c0',1,'neorv32_dma_t']]] +]; diff --git a/sw/search/variables_5.js b/sw/search/variables_5.js new file mode 100644 index 0000000000..37729fc474 --- /dev/null +++ b/sw/search/variables_5.js @@ -0,0 +1,8 @@ +var searchData= +[ + ['eie_0',['EIE',['../structneorv32__xirq__t.html#aef3c2b491207abd68bf6392f97096a74',1,'neorv32_xirq_t']]], + ['eip_1',['EIP',['../structneorv32__xirq__t.html#a788d8004f3b85fb66e947415d8fcc058',1,'neorv32_xirq_t']]], + ['error_5fmessage_2',['error_message',['../bootloader_8c.html#a6fea855ffe2fa0cd5ea9f98c0d5adc4d',1,'bootloader.c']]], + ['esc_3',['ESC',['../structneorv32__xirq__t.html#ae4f7f3f41210ff329b6f82d5dfada88a',1,'neorv32_xirq_t']]], + ['exe_5favailable_4',['exe_available',['../bootloader_8c.html#a0f9fcfdf758260b9b79b6eda063dd87a',1,'bootloader.c']]] +]; diff --git a/sw/search/variables_6.js b/sw/search/variables_6.js new file mode 100644 index 0000000000..2d679bafaf --- /dev/null +++ b/sw/search/variables_6.js @@ -0,0 +1,4 @@ +var searchData= +[ + ['float_5fvalue_0',['float_value',['../unionfloat__conv__t.html#a95f2e38b437bd8d4e8de7f61d7474788',1,'float_conv_t']]] +]; diff --git a/sw/search/variables_7.js b/sw/search/variables_7.js new file mode 100644 index 0000000000..e155197cf7 --- /dev/null +++ b/sw/search/variables_7.js @@ -0,0 +1,4 @@ +var searchData= +[ + ['getting_5fexe_0',['getting_exe',['../bootloader_8c.html#a5fa6b109bf211d1768f84c9d38eef240',1,'bootloader.c']]] +]; diff --git a/sw/search/variables_8.js b/sw/search/variables_8.js new file mode 100644 index 0000000000..b429ea957f --- /dev/null +++ b/sw/search/variables_8.js @@ -0,0 +1,4 @@ +var searchData= +[ + ['hours_0',['hours',['../structdate__t.html#a39a23695634a2814d827984f4eea54eb',1,'date_t']]] +]; diff --git a/sw/search/variables_9.js b/sw/search/variables_9.js new file mode 100644 index 0000000000..accfbc0675 --- /dev/null +++ b/sw/search/variables_9.js @@ -0,0 +1,5 @@ +var searchData= +[ + ['input_0',['INPUT',['../structneorv32__gpio__t.html#a208ee622d43fee3574072f19a98c8808',1,'neorv32_gpio_t']]], + ['input_5fdata_1',['input_data',['../demo__cfu_2main_8c.html#a2e2ccb9136736a673dbef71f207e97a0',1,'main.c']]] +]; diff --git a/sw/search/variables_a.js b/sw/search/variables_a.js new file mode 100644 index 0000000000..d846b41912 --- /dev/null +++ b/sw/search/variables_a.js @@ -0,0 +1,4 @@ +var searchData= +[ + ['key_0',['key',['../demo__cfu_2main_8c.html#ab5c498f9da12ab2d6ddc89bf4a46dec6',1,'main.c']]] +]; diff --git a/sw/search/variables_b.js b/sw/search/variables_b.js new file mode 100644 index 0000000000..ae0df75c40 --- /dev/null +++ b/sw/search/variables_b.js @@ -0,0 +1,7 @@ +var searchData= +[ + ['mem_0',['MEM',['../structneorv32__sysinfo__t.html#a51eee92b1824c1b19eb0a83a0a9c7d4c',1,'neorv32_sysinfo_t']]], + ['minutes_1',['minutes',['../structdate__t.html#a2ab79834ebae42979e359bf30ad5f67a',1,'date_t']]], + ['mode_2',['MODE',['../structneorv32__crc__t.html#ad720502701f16e6e952bbcaee980017c',1,'neorv32_crc_t']]], + ['month_3',['month',['../structdate__t.html#a1a97f6a755cd4209a0880cf811d52c7b',1,'date_t']]] +]; diff --git a/sw/search/variables_c.js b/sw/search/variables_c.js new file mode 100644 index 0000000000..e2ad7e8df0 --- /dev/null +++ b/sw/search/variables_c.js @@ -0,0 +1,4 @@ +var searchData= +[ + ['output_0',['OUTPUT',['../structneorv32__gpio__t.html#abaf7de4f79adfc3debcde93fa4a921bb',1,'neorv32_gpio_t']]] +]; diff --git a/sw/search/variables_d.js b/sw/search/variables_d.js new file mode 100644 index 0000000000..da8c8bf963 --- /dev/null +++ b/sw/search/variables_d.js @@ -0,0 +1,7 @@ +var searchData= +[ + ['plain_5fdata_5fhw_0',['plain_data_hw',['../demo__cfu_2main_8c.html#aee8dde13fe2f5ac52dd6075e2fe1eab5',1,'main.c']]], + ['plain_5fdata_5fsw_1',['plain_data_sw',['../demo__cfu_2main_8c.html#a72ba1460776ad684028448ca51810bbe',1,'main.c']]], + ['poly_2',['POLY',['../structneorv32__crc__t.html#a9bbcab843ddba4f9772d07478947a661',1,'neorv32_crc_t']]], + ['ptrspibuf_3',['ptrSpiBuf',['../structt__neorv32__spi.html#a487a6510820871ff8d0da7699463f6d9',1,'t_neorv32_spi']]] +]; diff --git a/sw/search/variables_e.js b/sw/search/variables_e.js new file mode 100644 index 0000000000..dc8c302f84 --- /dev/null +++ b/sw/search/variables_e.js @@ -0,0 +1,11 @@ +var searchData= +[ + ['ram_5fbuffer_0',['ram_buffer',['../demo__xip_2main_8c.html#acc95e55a622d79c2a398397d1f9b8033',1,'main.c']]], + ['reg_1',['REG',['../structneorv32__cfs__t.html#a48d3e81b207f4dcce0b0cc901583dc4d',1,'neorv32_cfs_t']]], + ['reserved_2',['reserved',['../structneorv32__xip__t.html#aacb77d586c3caec518e8e0024cfe745c',1,'neorv32_xip_t']]], + ['reserved0_3',['reserved0',['../structneorv32__xirq__t.html#a9be02c0398fab5763a3afbd7a018f092',1,'neorv32_xirq_t']]], + ['reserved1_4',['reserved1',['../structneorv32__xirq__t.html#ac4c999cf3da75e39753619f917d9d654',1,'neorv32_xirq_t']]], + ['reserved2_5',['reserved2',['../structneorv32__xirq__t.html#afba6ed500e1448719783923975b2dc64',1,'neorv32_xirq_t']]], + ['reset_6',['RESET',['../structneorv32__wdt__t.html#a0a273e8ca2bd92547bf7727ec65a9449',1,'neorv32_wdt_t']]], + ['route_7',['ROUTE',['../structneorv32__slink__t.html#a0b2417a1a587da45909ce2a948f90e22',1,'neorv32_slink_t']]] +]; diff --git a/sw/search/variables_f.js b/sw/search/variables_f.js new file mode 100644 index 0000000000..51d476430b --- /dev/null +++ b/sw/search/variables_f.js @@ -0,0 +1,7 @@ +var searchData= +[ + ['seconds_0',['seconds',['../structdate__t.html#a1071948e7754cb415da9714d59a315bf',1,'date_t']]], + ['soc_1',['SOC',['../structneorv32__sysinfo__t.html#ac43abe3b416da3a2895d1d06537a14c3',1,'neorv32_sysinfo_t']]], + ['src_5fbase_2',['SRC_BASE',['../structneorv32__dma__t.html#a3b214d1a373c7f15b374e113d7110b42',1,'neorv32_dma_t']]], + ['sreg_3',['SREG',['../structneorv32__crc__t.html#abf2b419f2aefdb6f2a6b81a02cb8612d',1,'neorv32_crc_t']]] +]; diff --git a/sw/splitbar.png b/sw/splitbar.png new file mode 100644 index 0000000000000000000000000000000000000000..fe895f2c58179b471a22d8320b39a4bd7312ec8e GIT binary patch literal 314 zcmeAS@N?(olHy`uVBq!ia0vp^Yzz!63>-{AmhX=Jf(#6djGiuzAr*{o?=JLmPLyc> z_*`QK&+BH@jW<lVxsx`Ym~nPnqw$O~`M84{XS6<Mm0<Zit<Tk``D^RashfFq{wG<# zZG2vRxL<$IhkFMSBd@N1`uRtp)t>rYJ7>r6%keRM@)Qyv8R=enp0jiI>aWlGyB58O zFVR20d+y`K7vDw(hJF3;>dD*3-?v=<8M)@x|E<fHWtM%;-WUJ&>EGLnJsniYK!2U1 Y!`|5biEc?d1`HDhPgg&ebxsLQ02F6;9RL6T literal 0 HcmV?d00001 diff --git a/sw/splitbard.png b/sw/splitbard.png new file mode 100644 index 0000000000000000000000000000000000000000..8367416d757fd7b6dc4272b6432dc75a75abd068 GIT binary patch literal 282 zcmeAS@N?(olHy`uVBq!ia0vp^Yzz!63>-{AmhX=Jf<Wq_r;B4q1>@VhhFKy35^fiT zT~&lUj3=cDh^%3HDY9k5CEku}PHXNoNC(_$U3XPb<d2ww+4sWx@iO~d@7T)Z$L;%F z_Vvfjr-#*_i?>&Q*ME25pT;2(*BOgAf<+R$lzakPG`kF31()Fx{L5Wrac|GQzjeE= zueY1`Ze{#x<8=S|`~MgGetGce)#vN&|J{Cd^tS%;tBYTo?+^d68<#n_Y_xx`J||4O V@QB{^CqU0Kc)I$ztaD0e0svEzbJzd? literal 0 HcmV?d00001 diff --git a/sw/structdate__t.html b/sw/structdate__t.html new file mode 100644 index 0000000000..03c12b84d3 --- /dev/null +++ b/sw/structdate__t.html @@ -0,0 +1,228 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: date_t Struct Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#pub-attribs">Data Fields</a> </div> + <div class="headertitle"><div class="title">date_t Struct Reference</div></div> +</div><!--header--> +<div class="contents"> +<table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="pub-attribs" name="pub-attribs"></a> +Data Fields</h2></td></tr> +<tr class="memitem:aabab1b1efd94b69bfb28b639c612dd4f" id="r_aabab1b1efd94b69bfb28b639c612dd4f"><td class="memItemLeft" align="right" valign="top">uint16_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aabab1b1efd94b69bfb28b639c612dd4f">year</a></td></tr> +<tr class="separator:aabab1b1efd94b69bfb28b639c612dd4f"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a1a97f6a755cd4209a0880cf811d52c7b" id="r_a1a97f6a755cd4209a0880cf811d52c7b"><td class="memItemLeft" align="right" valign="top">uint8_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a1a97f6a755cd4209a0880cf811d52c7b">month</a></td></tr> +<tr class="separator:a1a97f6a755cd4209a0880cf811d52c7b"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a482ad87226bae7841dfec63e035aeace" id="r_a482ad87226bae7841dfec63e035aeace"><td class="memItemLeft" align="right" valign="top">uint8_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a482ad87226bae7841dfec63e035aeace">day</a></td></tr> +<tr class="separator:a482ad87226bae7841dfec63e035aeace"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a44167cd71416886e55048310af6d4e1b" id="r_a44167cd71416886e55048310af6d4e1b"><td class="memItemLeft" align="right" valign="top">uint8_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a44167cd71416886e55048310af6d4e1b">weekday</a></td></tr> +<tr class="separator:a44167cd71416886e55048310af6d4e1b"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a39a23695634a2814d827984f4eea54eb" id="r_a39a23695634a2814d827984f4eea54eb"><td class="memItemLeft" align="right" valign="top">uint8_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a39a23695634a2814d827984f4eea54eb">hours</a></td></tr> +<tr class="separator:a39a23695634a2814d827984f4eea54eb"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a2ab79834ebae42979e359bf30ad5f67a" id="r_a2ab79834ebae42979e359bf30ad5f67a"><td class="memItemLeft" align="right" valign="top">uint8_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a2ab79834ebae42979e359bf30ad5f67a">minutes</a></td></tr> +<tr class="separator:a2ab79834ebae42979e359bf30ad5f67a"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a1071948e7754cb415da9714d59a315bf" id="r_a1071948e7754cb415da9714d59a315bf"><td class="memItemLeft" align="right" valign="top">uint8_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a1071948e7754cb415da9714d59a315bf">seconds</a></td></tr> +<tr class="separator:a1071948e7754cb415da9714d59a315bf"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<h2 class="groupheader">Field Documentation</h2> +<a id="a482ad87226bae7841dfec63e035aeace" name="a482ad87226bae7841dfec63e035aeace"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a482ad87226bae7841dfec63e035aeace">&#9670;&#160;</a></span>day</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint8_t date_t::day</td> + </tr> + </table> +</div><div class="memdoc"> +<p>1..31 </p> + +</div> +</div> +<a id="a39a23695634a2814d827984f4eea54eb" name="a39a23695634a2814d827984f4eea54eb"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a39a23695634a2814d827984f4eea54eb">&#9670;&#160;</a></span>hours</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint8_t date_t::hours</td> + </tr> + </table> +</div><div class="memdoc"> +<p>0..23 </p> + +</div> +</div> +<a id="a2ab79834ebae42979e359bf30ad5f67a" name="a2ab79834ebae42979e359bf30ad5f67a"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a2ab79834ebae42979e359bf30ad5f67a">&#9670;&#160;</a></span>minutes</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint8_t date_t::minutes</td> + </tr> + </table> +</div><div class="memdoc"> +<p>0..59 </p> + +</div> +</div> +<a id="a1a97f6a755cd4209a0880cf811d52c7b" name="a1a97f6a755cd4209a0880cf811d52c7b"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a1a97f6a755cd4209a0880cf811d52c7b">&#9670;&#160;</a></span>month</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint8_t date_t::month</td> + </tr> + </table> +</div><div class="memdoc"> +<p>1..12 </p> + +</div> +</div> +<a id="a1071948e7754cb415da9714d59a315bf" name="a1071948e7754cb415da9714d59a315bf"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a1071948e7754cb415da9714d59a315bf">&#9670;&#160;</a></span>seconds</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint8_t date_t::seconds</td> + </tr> + </table> +</div><div class="memdoc"> +<p>0..59 </p> + +</div> +</div> +<a id="a44167cd71416886e55048310af6d4e1b" name="a44167cd71416886e55048310af6d4e1b"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a44167cd71416886e55048310af6d4e1b">&#9670;&#160;</a></span>weekday</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint8_t date_t::weekday</td> + </tr> + </table> +</div><div class="memdoc"> +<p>1..7 starting with Monday </p> + +</div> +</div> +<a id="aabab1b1efd94b69bfb28b639c612dd4f" name="aabab1b1efd94b69bfb28b639c612dd4f"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aabab1b1efd94b69bfb28b639c612dd4f">&#9670;&#160;</a></span>year</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint16_t date_t::year</td> + </tr> + </table> +</div><div class="memdoc"> +<p>current year (absolute) </p> + +</div> +</div> +<hr/>The documentation for this struct was generated from the following file:<ul> +<li>sw/lib/include/<a class="el" href="neorv32__aux_8h_source.html">neorv32_aux.h</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/structneorv32__cfs__t.html b/sw/structneorv32__cfs__t.html new file mode 100644 index 0000000000..51c6af3425 --- /dev/null +++ b/sw/structneorv32__cfs__t.html @@ -0,0 +1,130 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: neorv32_cfs_t Struct Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#pub-attribs">Data Fields</a> </div> + <div class="headertitle"><div class="title">neorv32_cfs_t Struct Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p><code>#include &lt;<a class="el" href="neorv32__cfs_8h_source.html">neorv32_cfs.h</a>&gt;</code></p> +<table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="pub-attribs" name="pub-attribs"></a> +Data Fields</h2></td></tr> +<tr class="memitem:a48d3e81b207f4dcce0b0cc901583dc4d" id="r_a48d3e81b207f4dcce0b0cc901583dc4d"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a48d3e81b207f4dcce0b0cc901583dc4d">REG</a> [64]</td></tr> +<tr class="separator:a48d3e81b207f4dcce0b0cc901583dc4d"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>CFS module prototype </p> +</div><h2 class="groupheader">Field Documentation</h2> +<a id="a48d3e81b207f4dcce0b0cc901583dc4d" name="a48d3e81b207f4dcce0b0cc901583dc4d"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a48d3e81b207f4dcce0b0cc901583dc4d">&#9670;&#160;</a></span>REG</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_cfs_t::REG[64]</td> + </tr> + </table> +</div><div class="memdoc"> +<p>offset 4*0..4*63: CFS register 0..63, user-defined </p> + +</div> +</div> +<hr/>The documentation for this struct was generated from the following file:<ul> +<li>sw/lib/include/<a class="el" href="neorv32__cfs_8h_source.html">neorv32_cfs.h</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/structneorv32__crc__t.html b/sw/structneorv32__crc__t.html new file mode 100644 index 0000000000..e595018ddd --- /dev/null +++ b/sw/structneorv32__crc__t.html @@ -0,0 +1,181 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: neorv32_crc_t Struct Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#pub-attribs">Data Fields</a> </div> + <div class="headertitle"><div class="title">neorv32_crc_t Struct Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p><code>#include &lt;<a class="el" href="neorv32__crc_8h_source.html">neorv32_crc.h</a>&gt;</code></p> +<table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="pub-attribs" name="pub-attribs"></a> +Data Fields</h2></td></tr> +<tr class="memitem:ad720502701f16e6e952bbcaee980017c" id="r_ad720502701f16e6e952bbcaee980017c"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ad720502701f16e6e952bbcaee980017c">MODE</a></td></tr> +<tr class="separator:ad720502701f16e6e952bbcaee980017c"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a9bbcab843ddba4f9772d07478947a661" id="r_a9bbcab843ddba4f9772d07478947a661"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a9bbcab843ddba4f9772d07478947a661">POLY</a></td></tr> +<tr class="separator:a9bbcab843ddba4f9772d07478947a661"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a47f286612848f597859aaef0d2d5da4d" id="r_a47f286612848f597859aaef0d2d5da4d"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a47f286612848f597859aaef0d2d5da4d">DATA</a></td></tr> +<tr class="separator:a47f286612848f597859aaef0d2d5da4d"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:abf2b419f2aefdb6f2a6b81a02cb8612d" id="r_abf2b419f2aefdb6f2a6b81a02cb8612d"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#abf2b419f2aefdb6f2a6b81a02cb8612d">SREG</a></td></tr> +<tr class="separator:abf2b419f2aefdb6f2a6b81a02cb8612d"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>CRC module prototype </p> +</div><h2 class="groupheader">Field Documentation</h2> +<a id="a47f286612848f597859aaef0d2d5da4d" name="a47f286612848f597859aaef0d2d5da4d"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a47f286612848f597859aaef0d2d5da4d">&#9670;&#160;</a></span>DATA</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_crc_t::DATA</td> + </tr> + </table> +</div><div class="memdoc"> +<p>offset 8: data input register </p> + +</div> +</div> +<a id="ad720502701f16e6e952bbcaee980017c" name="ad720502701f16e6e952bbcaee980017c"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ad720502701f16e6e952bbcaee980017c">&#9670;&#160;</a></span>MODE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_crc_t::MODE</td> + </tr> + </table> +</div><div class="memdoc"> +<p>offset 0: mode register (<a class="el" href="neorv32__crc_8h.html#a1ae84a58f475bafc2fc3f2c690fd6447">NEORV32_CRC_MODE_enum</a>) </p> + +</div> +</div> +<a id="a9bbcab843ddba4f9772d07478947a661" name="a9bbcab843ddba4f9772d07478947a661"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a9bbcab843ddba4f9772d07478947a661">&#9670;&#160;</a></span>POLY</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_crc_t::POLY</td> + </tr> + </table> +</div><div class="memdoc"> +<p>offset 4: polynomial register </p> + +</div> +</div> +<a id="abf2b419f2aefdb6f2a6b81a02cb8612d" name="abf2b419f2aefdb6f2a6b81a02cb8612d"></a> +<h2 class="memtitle"><span class="permalink"><a href="#abf2b419f2aefdb6f2a6b81a02cb8612d">&#9670;&#160;</a></span>SREG</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_crc_t::SREG</td> + </tr> + </table> +</div><div class="memdoc"> +<p>offset 12: CRC shift register </p> + +</div> +</div> +<hr/>The documentation for this struct was generated from the following file:<ul> +<li>sw/lib/include/<a class="el" href="neorv32__crc_8h_source.html">neorv32_crc.h</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/structneorv32__dma__t.html b/sw/structneorv32__dma__t.html new file mode 100644 index 0000000000..524811ceac --- /dev/null +++ b/sw/structneorv32__dma__t.html @@ -0,0 +1,181 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: neorv32_dma_t Struct Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#pub-attribs">Data Fields</a> </div> + <div class="headertitle"><div class="title">neorv32_dma_t Struct Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p><code>#include &lt;<a class="el" href="neorv32__dma_8h_source.html">neorv32_dma.h</a>&gt;</code></p> +<table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="pub-attribs" name="pub-attribs"></a> +Data Fields</h2></td></tr> +<tr class="memitem:a8480d6ad3ba5063cdf21dca286711569" id="r_a8480d6ad3ba5063cdf21dca286711569"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a8480d6ad3ba5063cdf21dca286711569">CTRL</a></td></tr> +<tr class="separator:a8480d6ad3ba5063cdf21dca286711569"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a3b214d1a373c7f15b374e113d7110b42" id="r_a3b214d1a373c7f15b374e113d7110b42"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a3b214d1a373c7f15b374e113d7110b42">SRC_BASE</a></td></tr> +<tr class="separator:a3b214d1a373c7f15b374e113d7110b42"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aee8a6cf3cbd9fe3c5995f046ffb9a1c0" id="r_aee8a6cf3cbd9fe3c5995f046ffb9a1c0"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aee8a6cf3cbd9fe3c5995f046ffb9a1c0">DST_BASE</a></td></tr> +<tr class="separator:aee8a6cf3cbd9fe3c5995f046ffb9a1c0"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a70c28642195765409d97b941e98f47ca" id="r_a70c28642195765409d97b941e98f47ca"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a70c28642195765409d97b941e98f47ca">TTYPE</a></td></tr> +<tr class="separator:a70c28642195765409d97b941e98f47ca"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>DMA module prototype </p> +</div><h2 class="groupheader">Field Documentation</h2> +<a id="a8480d6ad3ba5063cdf21dca286711569" name="a8480d6ad3ba5063cdf21dca286711569"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a8480d6ad3ba5063cdf21dca286711569">&#9670;&#160;</a></span>CTRL</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_dma_t::CTRL</td> + </tr> + </table> +</div><div class="memdoc"> +<p>offset 0: control and status register (<a class="el" href="neorv32__dma_8h.html#a6716eddb145b80ad38799da3b87cb2a4">NEORV32_DMA_CTRL_enum</a>) </p> + +</div> +</div> +<a id="aee8a6cf3cbd9fe3c5995f046ffb9a1c0" name="aee8a6cf3cbd9fe3c5995f046ffb9a1c0"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aee8a6cf3cbd9fe3c5995f046ffb9a1c0">&#9670;&#160;</a></span>DST_BASE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_dma_t::DST_BASE</td> + </tr> + </table> +</div><div class="memdoc"> +<p>offset 8: destination base address register </p> + +</div> +</div> +<a id="a3b214d1a373c7f15b374e113d7110b42" name="a3b214d1a373c7f15b374e113d7110b42"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a3b214d1a373c7f15b374e113d7110b42">&#9670;&#160;</a></span>SRC_BASE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_dma_t::SRC_BASE</td> + </tr> + </table> +</div><div class="memdoc"> +<p>offset 4: source base address register </p> + +</div> +</div> +<a id="a70c28642195765409d97b941e98f47ca" name="a70c28642195765409d97b941e98f47ca"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a70c28642195765409d97b941e98f47ca">&#9670;&#160;</a></span>TTYPE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_dma_t::TTYPE</td> + </tr> + </table> +</div><div class="memdoc"> +<p>offset 12: transfer type configuration register &amp; manual trigger (<a class="el" href="neorv32__dma_8h.html#a33187c5a074d62b46d2262e352edb8d9">NEORV32_DMA_TTYPE_enum</a>) </p> + +</div> +</div> +<hr/>The documentation for this struct was generated from the following file:<ul> +<li>sw/lib/include/<a class="el" href="neorv32__dma_8h_source.html">neorv32_dma.h</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/structneorv32__gpio__t.html b/sw/structneorv32__gpio__t.html new file mode 100644 index 0000000000..009e716279 --- /dev/null +++ b/sw/structneorv32__gpio__t.html @@ -0,0 +1,147 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: neorv32_gpio_t Struct Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#pub-attribs">Data Fields</a> </div> + <div class="headertitle"><div class="title">neorv32_gpio_t Struct Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p><code>#include &lt;<a class="el" href="neorv32__gpio_8h_source.html">neorv32_gpio.h</a>&gt;</code></p> +<table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="pub-attribs" name="pub-attribs"></a> +Data Fields</h2></td></tr> +<tr class="memitem:a208ee622d43fee3574072f19a98c8808" id="r_a208ee622d43fee3574072f19a98c8808"><td class="memItemLeft" align="right" valign="top">const uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a208ee622d43fee3574072f19a98c8808">INPUT</a> [2]</td></tr> +<tr class="separator:a208ee622d43fee3574072f19a98c8808"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:abaf7de4f79adfc3debcde93fa4a921bb" id="r_abaf7de4f79adfc3debcde93fa4a921bb"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#abaf7de4f79adfc3debcde93fa4a921bb">OUTPUT</a> [2]</td></tr> +<tr class="separator:abaf7de4f79adfc3debcde93fa4a921bb"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>GPIO module prototype </p> +</div><h2 class="groupheader">Field Documentation</h2> +<a id="a208ee622d43fee3574072f19a98c8808" name="a208ee622d43fee3574072f19a98c8808"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a208ee622d43fee3574072f19a98c8808">&#9670;&#160;</a></span>INPUT</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">const uint32_t neorv32_gpio_t::INPUT[2]</td> + </tr> + </table> +</div><div class="memdoc"> +<p>offset 0: parallel input port, read-only </p> + +</div> +</div> +<a id="abaf7de4f79adfc3debcde93fa4a921bb" name="abaf7de4f79adfc3debcde93fa4a921bb"></a> +<h2 class="memtitle"><span class="permalink"><a href="#abaf7de4f79adfc3debcde93fa4a921bb">&#9670;&#160;</a></span>OUTPUT</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_gpio_t::OUTPUT[2]</td> + </tr> + </table> +</div><div class="memdoc"> +<p>offset 8: parallel output port </p> + +</div> +</div> +<hr/>The documentation for this struct was generated from the following file:<ul> +<li>sw/lib/include/<a class="el" href="neorv32__gpio_8h_source.html">neorv32_gpio.h</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/structneorv32__gptmr__t.html b/sw/structneorv32__gptmr__t.html new file mode 100644 index 0000000000..ee98f7af0d --- /dev/null +++ b/sw/structneorv32__gptmr__t.html @@ -0,0 +1,164 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: neorv32_gptmr_t Struct Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#pub-attribs">Data Fields</a> </div> + <div class="headertitle"><div class="title">neorv32_gptmr_t Struct Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p><code>#include &lt;<a class="el" href="neorv32__gptmr_8h_source.html">neorv32_gptmr.h</a>&gt;</code></p> +<table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="pub-attribs" name="pub-attribs"></a> +Data Fields</h2></td></tr> +<tr class="memitem:a3c477ccb24ed12122d9d90244431c7e9" id="r_a3c477ccb24ed12122d9d90244431c7e9"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a3c477ccb24ed12122d9d90244431c7e9">CTRL</a></td></tr> +<tr class="separator:a3c477ccb24ed12122d9d90244431c7e9"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a666ebcbea13dafcf1987629f3e0092ee" id="r_a666ebcbea13dafcf1987629f3e0092ee"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a666ebcbea13dafcf1987629f3e0092ee">THRES</a></td></tr> +<tr class="separator:a666ebcbea13dafcf1987629f3e0092ee"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a1abc5bae1dffc64006e965d4570da479" id="r_a1abc5bae1dffc64006e965d4570da479"><td class="memItemLeft" align="right" valign="top">const uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a1abc5bae1dffc64006e965d4570da479">COUNT</a></td></tr> +<tr class="separator:a1abc5bae1dffc64006e965d4570da479"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>GPTMR module prototype </p> +</div><h2 class="groupheader">Field Documentation</h2> +<a id="a1abc5bae1dffc64006e965d4570da479" name="a1abc5bae1dffc64006e965d4570da479"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a1abc5bae1dffc64006e965d4570da479">&#9670;&#160;</a></span>COUNT</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">const uint32_t neorv32_gptmr_t::COUNT</td> + </tr> + </table> +</div><div class="memdoc"> +<p>offset 8: counter register, read-only </p> + +</div> +</div> +<a id="a3c477ccb24ed12122d9d90244431c7e9" name="a3c477ccb24ed12122d9d90244431c7e9"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a3c477ccb24ed12122d9d90244431c7e9">&#9670;&#160;</a></span>CTRL</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_gptmr_t::CTRL</td> + </tr> + </table> +</div><div class="memdoc"> +<p>offset 0: control register (<a class="el" href="neorv32__gptmr_8h.html#a135b0750d4afed16e5867134e3843988">NEORV32_GPTMR_CTRL_enum</a>) </p> + +</div> +</div> +<a id="a666ebcbea13dafcf1987629f3e0092ee" name="a666ebcbea13dafcf1987629f3e0092ee"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a666ebcbea13dafcf1987629f3e0092ee">&#9670;&#160;</a></span>THRES</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_gptmr_t::THRES</td> + </tr> + </table> +</div><div class="memdoc"> +<p>offset 4: threshold register </p> + +</div> +</div> +<hr/>The documentation for this struct was generated from the following file:<ul> +<li>sw/lib/include/<a class="el" href="neorv32__gptmr_8h_source.html">neorv32_gptmr.h</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/structneorv32__mtime__t.html b/sw/structneorv32__mtime__t.html new file mode 100644 index 0000000000..cf52e0fccf --- /dev/null +++ b/sw/structneorv32__mtime__t.html @@ -0,0 +1,181 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: neorv32_mtime_t Struct Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#pub-attribs">Data Fields</a> </div> + <div class="headertitle"><div class="title">neorv32_mtime_t Struct Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p><code>#include &lt;<a class="el" href="neorv32__mtime_8h_source.html">neorv32_mtime.h</a>&gt;</code></p> +<table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="pub-attribs" name="pub-attribs"></a> +Data Fields</h2></td></tr> +<tr class="memitem:acccaa3dd87a57ebd5f7ae504771e904e" id="r_acccaa3dd87a57ebd5f7ae504771e904e"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#acccaa3dd87a57ebd5f7ae504771e904e">TIME_LO</a></td></tr> +<tr class="separator:acccaa3dd87a57ebd5f7ae504771e904e"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a1ffe0be2c45f5d7aa2686abf40cd1693" id="r_a1ffe0be2c45f5d7aa2686abf40cd1693"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a1ffe0be2c45f5d7aa2686abf40cd1693">TIME_HI</a></td></tr> +<tr class="separator:a1ffe0be2c45f5d7aa2686abf40cd1693"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ab5fa56ca5c2f9d547f58d169d6da96e5" id="r_ab5fa56ca5c2f9d547f58d169d6da96e5"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ab5fa56ca5c2f9d547f58d169d6da96e5">TIMECMP_LO</a></td></tr> +<tr class="separator:ab5fa56ca5c2f9d547f58d169d6da96e5"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:af05df268c8f699401cf752e4249ba422" id="r_af05df268c8f699401cf752e4249ba422"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#af05df268c8f699401cf752e4249ba422">TIMECMP_HI</a></td></tr> +<tr class="separator:af05df268c8f699401cf752e4249ba422"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>MTIME module prototype </p> +</div><h2 class="groupheader">Field Documentation</h2> +<a id="a1ffe0be2c45f5d7aa2686abf40cd1693" name="a1ffe0be2c45f5d7aa2686abf40cd1693"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a1ffe0be2c45f5d7aa2686abf40cd1693">&#9670;&#160;</a></span>TIME_HI</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_mtime_t::TIME_HI</td> + </tr> + </table> +</div><div class="memdoc"> +<p>offset 4: time register high word </p> + +</div> +</div> +<a id="acccaa3dd87a57ebd5f7ae504771e904e" name="acccaa3dd87a57ebd5f7ae504771e904e"></a> +<h2 class="memtitle"><span class="permalink"><a href="#acccaa3dd87a57ebd5f7ae504771e904e">&#9670;&#160;</a></span>TIME_LO</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_mtime_t::TIME_LO</td> + </tr> + </table> +</div><div class="memdoc"> +<p>offset 0: time register low word </p> + +</div> +</div> +<a id="af05df268c8f699401cf752e4249ba422" name="af05df268c8f699401cf752e4249ba422"></a> +<h2 class="memtitle"><span class="permalink"><a href="#af05df268c8f699401cf752e4249ba422">&#9670;&#160;</a></span>TIMECMP_HI</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_mtime_t::TIMECMP_HI</td> + </tr> + </table> +</div><div class="memdoc"> +<p>offset 12: compare register high word </p> + +</div> +</div> +<a id="ab5fa56ca5c2f9d547f58d169d6da96e5" name="ab5fa56ca5c2f9d547f58d169d6da96e5"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ab5fa56ca5c2f9d547f58d169d6da96e5">&#9670;&#160;</a></span>TIMECMP_LO</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_mtime_t::TIMECMP_LO</td> + </tr> + </table> +</div><div class="memdoc"> +<p>offset 8: compare register low word </p> + +</div> +</div> +<hr/>The documentation for this struct was generated from the following file:<ul> +<li>sw/lib/include/<a class="el" href="neorv32__mtime_8h_source.html">neorv32_mtime.h</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/structneorv32__neoled__t.html b/sw/structneorv32__neoled__t.html new file mode 100644 index 0000000000..c334440bf5 --- /dev/null +++ b/sw/structneorv32__neoled__t.html @@ -0,0 +1,147 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: neorv32_neoled_t Struct Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#pub-attribs">Data Fields</a> </div> + <div class="headertitle"><div class="title">neorv32_neoled_t Struct Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p><code>#include &lt;<a class="el" href="neorv32__neoled_8h_source.html">neorv32_neoled.h</a>&gt;</code></p> +<table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="pub-attribs" name="pub-attribs"></a> +Data Fields</h2></td></tr> +<tr class="memitem:adfe7618c002ff88dd22e65fcedfd6139" id="r_adfe7618c002ff88dd22e65fcedfd6139"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#adfe7618c002ff88dd22e65fcedfd6139">CTRL</a></td></tr> +<tr class="separator:adfe7618c002ff88dd22e65fcedfd6139"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a995fb1d63a9dfb3f20d715932781c1de" id="r_a995fb1d63a9dfb3f20d715932781c1de"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a995fb1d63a9dfb3f20d715932781c1de">DATA</a></td></tr> +<tr class="separator:a995fb1d63a9dfb3f20d715932781c1de"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>NEOLED module prototype </p> +</div><h2 class="groupheader">Field Documentation</h2> +<a id="adfe7618c002ff88dd22e65fcedfd6139" name="adfe7618c002ff88dd22e65fcedfd6139"></a> +<h2 class="memtitle"><span class="permalink"><a href="#adfe7618c002ff88dd22e65fcedfd6139">&#9670;&#160;</a></span>CTRL</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_neoled_t::CTRL</td> + </tr> + </table> +</div><div class="memdoc"> +<p>offset 0: control register </p> + +</div> +</div> +<a id="a995fb1d63a9dfb3f20d715932781c1de" name="a995fb1d63a9dfb3f20d715932781c1de"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a995fb1d63a9dfb3f20d715932781c1de">&#9670;&#160;</a></span>DATA</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_neoled_t::DATA</td> + </tr> + </table> +</div><div class="memdoc"> +<p>offset 4: data register (<a class="el" href="neorv32__neoled_8h.html#ab99c7fed050816eae0fa0315562e0412">NEORV32_NEOLED_CTRL_enum</a>) </p> + +</div> +</div> +<hr/>The documentation for this struct was generated from the following file:<ul> +<li>sw/lib/include/<a class="el" href="neorv32__neoled_8h_source.html">neorv32_neoled.h</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/structneorv32__onewire__t.html b/sw/structneorv32__onewire__t.html new file mode 100644 index 0000000000..6490ee6090 --- /dev/null +++ b/sw/structneorv32__onewire__t.html @@ -0,0 +1,147 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: neorv32_onewire_t Struct Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#pub-attribs">Data Fields</a> </div> + <div class="headertitle"><div class="title">neorv32_onewire_t Struct Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p><code>#include &lt;<a class="el" href="neorv32__onewire_8h_source.html">neorv32_onewire.h</a>&gt;</code></p> +<table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="pub-attribs" name="pub-attribs"></a> +Data Fields</h2></td></tr> +<tr class="memitem:a310df3bab43e4438417b2ff948f4712a" id="r_a310df3bab43e4438417b2ff948f4712a"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a310df3bab43e4438417b2ff948f4712a">CTRL</a></td></tr> +<tr class="separator:a310df3bab43e4438417b2ff948f4712a"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a2c04aa736b901940ed65b96202c8af7a" id="r_a2c04aa736b901940ed65b96202c8af7a"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a2c04aa736b901940ed65b96202c8af7a">DATA</a></td></tr> +<tr class="separator:a2c04aa736b901940ed65b96202c8af7a"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>ONEWIRE module prototype </p> +</div><h2 class="groupheader">Field Documentation</h2> +<a id="a310df3bab43e4438417b2ff948f4712a" name="a310df3bab43e4438417b2ff948f4712a"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a310df3bab43e4438417b2ff948f4712a">&#9670;&#160;</a></span>CTRL</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_onewire_t::CTRL</td> + </tr> + </table> +</div><div class="memdoc"> +<p>offset 0: control register (<a class="el" href="neorv32__onewire_8h.html#ade1a01f533843880868ec7496d116831">NEORV32_ONEWIRE_CTRL_enum</a>) </p> + +</div> +</div> +<a id="a2c04aa736b901940ed65b96202c8af7a" name="a2c04aa736b901940ed65b96202c8af7a"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a2c04aa736b901940ed65b96202c8af7a">&#9670;&#160;</a></span>DATA</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_onewire_t::DATA</td> + </tr> + </table> +</div><div class="memdoc"> +<p>offset 4: transmission data register (<a class="el" href="neorv32__onewire_8h.html#ae770490afa8662fb8577065531d51368">NEORV32_ONEWIRE_DATA_enum</a>) </p> + +</div> +</div> +<hr/>The documentation for this struct was generated from the following file:<ul> +<li>sw/lib/include/<a class="el" href="neorv32__onewire_8h_source.html">neorv32_onewire.h</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/structneorv32__pwm__t.html b/sw/structneorv32__pwm__t.html new file mode 100644 index 0000000000..38f7ef5fc4 --- /dev/null +++ b/sw/structneorv32__pwm__t.html @@ -0,0 +1,147 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: neorv32_pwm_t Struct Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#pub-attribs">Data Fields</a> </div> + <div class="headertitle"><div class="title">neorv32_pwm_t Struct Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p><code>#include &lt;<a class="el" href="neorv32__pwm_8h_source.html">neorv32_pwm.h</a>&gt;</code></p> +<table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="pub-attribs" name="pub-attribs"></a> +Data Fields</h2></td></tr> +<tr class="memitem:ab86705332ebd9c45635c3195c6b3dcc5" id="r_ab86705332ebd9c45635c3195c6b3dcc5"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ab86705332ebd9c45635c3195c6b3dcc5">CTRL</a></td></tr> +<tr class="separator:ab86705332ebd9c45635c3195c6b3dcc5"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a6d29528ca60921a6ef8e5bcde81925e7" id="r_a6d29528ca60921a6ef8e5bcde81925e7"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a6d29528ca60921a6ef8e5bcde81925e7">DC</a> [3]</td></tr> +<tr class="separator:a6d29528ca60921a6ef8e5bcde81925e7"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>PWM module prototype </p> +</div><h2 class="groupheader">Field Documentation</h2> +<a id="ab86705332ebd9c45635c3195c6b3dcc5" name="ab86705332ebd9c45635c3195c6b3dcc5"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ab86705332ebd9c45635c3195c6b3dcc5">&#9670;&#160;</a></span>CTRL</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_pwm_t::CTRL</td> + </tr> + </table> +</div><div class="memdoc"> +<p>offset 0: control register (<a class="el" href="neorv32__pwm_8h.html#af350f93b601a92ef56516198d1570b7d">NEORV32_PWM_CTRL_enum</a>) </p> + +</div> +</div> +<a id="a6d29528ca60921a6ef8e5bcde81925e7" name="a6d29528ca60921a6ef8e5bcde81925e7"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a6d29528ca60921a6ef8e5bcde81925e7">&#9670;&#160;</a></span>DC</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_pwm_t::DC[3]</td> + </tr> + </table> +</div><div class="memdoc"> +<p>offset 4..12: duty cycle register 0..2 </p> + +</div> +</div> +<hr/>The documentation for this struct was generated from the following file:<ul> +<li>sw/lib/include/<a class="el" href="neorv32__pwm_8h_source.html">neorv32_pwm.h</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/structneorv32__sdi__t.html b/sw/structneorv32__sdi__t.html new file mode 100644 index 0000000000..ead7d8be1d --- /dev/null +++ b/sw/structneorv32__sdi__t.html @@ -0,0 +1,147 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: neorv32_sdi_t Struct Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#pub-attribs">Data Fields</a> </div> + <div class="headertitle"><div class="title">neorv32_sdi_t Struct Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p><code>#include &lt;<a class="el" href="neorv32__sdi_8h_source.html">neorv32_sdi.h</a>&gt;</code></p> +<table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="pub-attribs" name="pub-attribs"></a> +Data Fields</h2></td></tr> +<tr class="memitem:af494f25cbcd8478cf384eb868e447303" id="r_af494f25cbcd8478cf384eb868e447303"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#af494f25cbcd8478cf384eb868e447303">CTRL</a></td></tr> +<tr class="separator:af494f25cbcd8478cf384eb868e447303"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a3ea6903c0924d0a1b633b6a2b0ae44f1" id="r_a3ea6903c0924d0a1b633b6a2b0ae44f1"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a3ea6903c0924d0a1b633b6a2b0ae44f1">DATA</a></td></tr> +<tr class="separator:a3ea6903c0924d0a1b633b6a2b0ae44f1"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>SDI module prototype </p> +</div><h2 class="groupheader">Field Documentation</h2> +<a id="af494f25cbcd8478cf384eb868e447303" name="af494f25cbcd8478cf384eb868e447303"></a> +<h2 class="memtitle"><span class="permalink"><a href="#af494f25cbcd8478cf384eb868e447303">&#9670;&#160;</a></span>CTRL</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_sdi_t::CTRL</td> + </tr> + </table> +</div><div class="memdoc"> +<p>offset 0: control register (<a class="el" href="neorv32__sdi_8h.html#abad9f422cbdff1b73100e98f7ab20ec6">NEORV32_SDI_CTRL_enum</a>) </p> + +</div> +</div> +<a id="a3ea6903c0924d0a1b633b6a2b0ae44f1" name="a3ea6903c0924d0a1b633b6a2b0ae44f1"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a3ea6903c0924d0a1b633b6a2b0ae44f1">&#9670;&#160;</a></span>DATA</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_sdi_t::DATA</td> + </tr> + </table> +</div><div class="memdoc"> +<p>offset 4: data register </p> + +</div> +</div> +<hr/>The documentation for this struct was generated from the following file:<ul> +<li>sw/lib/include/<a class="el" href="neorv32__sdi_8h_source.html">neorv32_sdi.h</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/structneorv32__slink__t.html b/sw/structneorv32__slink__t.html new file mode 100644 index 0000000000..53d73d20e3 --- /dev/null +++ b/sw/structneorv32__slink__t.html @@ -0,0 +1,181 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: neorv32_slink_t Struct Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#pub-attribs">Data Fields</a> </div> + <div class="headertitle"><div class="title">neorv32_slink_t Struct Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p><code>#include &lt;<a class="el" href="neorv32__slink_8h_source.html">neorv32_slink.h</a>&gt;</code></p> +<table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="pub-attribs" name="pub-attribs"></a> +Data Fields</h2></td></tr> +<tr class="memitem:a39ece6aeeea6982002e164902a1e784f" id="r_a39ece6aeeea6982002e164902a1e784f"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a39ece6aeeea6982002e164902a1e784f">CTRL</a></td></tr> +<tr class="separator:a39ece6aeeea6982002e164902a1e784f"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a0b2417a1a587da45909ce2a948f90e22" id="r_a0b2417a1a587da45909ce2a948f90e22"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a0b2417a1a587da45909ce2a948f90e22">ROUTE</a></td></tr> +<tr class="separator:a0b2417a1a587da45909ce2a948f90e22"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a8af7d4ea9787cf94c599c82133c6aa74" id="r_a8af7d4ea9787cf94c599c82133c6aa74"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a8af7d4ea9787cf94c599c82133c6aa74">DATA</a></td></tr> +<tr class="separator:a8af7d4ea9787cf94c599c82133c6aa74"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ada8f10141d2161b83a5a367722ed6a77" id="r_ada8f10141d2161b83a5a367722ed6a77"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ada8f10141d2161b83a5a367722ed6a77">DATA_LAST</a></td></tr> +<tr class="separator:ada8f10141d2161b83a5a367722ed6a77"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>SLINK module prototype </p> +</div><h2 class="groupheader">Field Documentation</h2> +<a id="a39ece6aeeea6982002e164902a1e784f" name="a39ece6aeeea6982002e164902a1e784f"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a39ece6aeeea6982002e164902a1e784f">&#9670;&#160;</a></span>CTRL</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_slink_t::CTRL</td> + </tr> + </table> +</div><div class="memdoc"> +<p>offset 0: control register (<a class="el" href="neorv32__slink_8h.html#ac0385a56c38315d492b3414d98235ef1">NEORV32_SLINK_CTRL_enum</a>) </p> + +</div> +</div> +<a id="a8af7d4ea9787cf94c599c82133c6aa74" name="a8af7d4ea9787cf94c599c82133c6aa74"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a8af7d4ea9787cf94c599c82133c6aa74">&#9670;&#160;</a></span>DATA</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_slink_t::DATA</td> + </tr> + </table> +</div><div class="memdoc"> +<p>offset 8: RX/TX data register </p> + +</div> +</div> +<a id="ada8f10141d2161b83a5a367722ed6a77" name="ada8f10141d2161b83a5a367722ed6a77"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ada8f10141d2161b83a5a367722ed6a77">&#9670;&#160;</a></span>DATA_LAST</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_slink_t::DATA_LAST</td> + </tr> + </table> +</div><div class="memdoc"> +<p>offset 12: RX/TX data register (+ TX end-of-stream) </p> + +</div> +</div> +<a id="a0b2417a1a587da45909ce2a948f90e22" name="a0b2417a1a587da45909ce2a948f90e22"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a0b2417a1a587da45909ce2a948f90e22">&#9670;&#160;</a></span>ROUTE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_slink_t::ROUTE</td> + </tr> + </table> +</div><div class="memdoc"> +<p>offset 4: routing information (<a class="el" href="neorv32__slink_8h.html#ac3e5e02fd89a357135adca6d28cd0e45">NEORV32_SLINK_ROUTE_enum</a>) </p> + +</div> +</div> +<hr/>The documentation for this struct was generated from the following file:<ul> +<li>sw/lib/include/<a class="el" href="neorv32__slink_8h_source.html">neorv32_slink.h</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/structneorv32__spi__t.html b/sw/structneorv32__spi__t.html new file mode 100644 index 0000000000..5cd5d881d1 --- /dev/null +++ b/sw/structneorv32__spi__t.html @@ -0,0 +1,147 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: neorv32_spi_t Struct Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#pub-attribs">Data Fields</a> </div> + <div class="headertitle"><div class="title">neorv32_spi_t Struct Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p><code>#include &lt;<a class="el" href="neorv32__spi_8h_source.html">neorv32_spi.h</a>&gt;</code></p> +<table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="pub-attribs" name="pub-attribs"></a> +Data Fields</h2></td></tr> +<tr class="memitem:a34fa748f0e3ceb75822c0a5553bd0420" id="r_a34fa748f0e3ceb75822c0a5553bd0420"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a34fa748f0e3ceb75822c0a5553bd0420">CTRL</a></td></tr> +<tr class="separator:a34fa748f0e3ceb75822c0a5553bd0420"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a3901bad351213e34820197a33d589f1e" id="r_a3901bad351213e34820197a33d589f1e"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a3901bad351213e34820197a33d589f1e">DATA</a></td></tr> +<tr class="separator:a3901bad351213e34820197a33d589f1e"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>SPI module prototype </p> +</div><h2 class="groupheader">Field Documentation</h2> +<a id="a34fa748f0e3ceb75822c0a5553bd0420" name="a34fa748f0e3ceb75822c0a5553bd0420"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a34fa748f0e3ceb75822c0a5553bd0420">&#9670;&#160;</a></span>CTRL</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_spi_t::CTRL</td> + </tr> + </table> +</div><div class="memdoc"> +<p>offset 0: control register (<a class="el" href="neorv32__spi_8h.html#ae269b2f5b2afd46ae16801762ade2c3b">NEORV32_SPI_CTRL_enum</a>) </p> + +</div> +</div> +<a id="a3901bad351213e34820197a33d589f1e" name="a3901bad351213e34820197a33d589f1e"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a3901bad351213e34820197a33d589f1e">&#9670;&#160;</a></span>DATA</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_spi_t::DATA</td> + </tr> + </table> +</div><div class="memdoc"> +<p>offset 4: data register (<a class="el" href="neorv32__spi_8h.html#aab478c23898c0b06cee53a1cbda38bf8">NEORV32_SPI_DATA_enum</a>) </p> + +</div> +</div> +<hr/>The documentation for this struct was generated from the following file:<ul> +<li>sw/lib/include/<a class="el" href="neorv32__spi_8h_source.html">neorv32_spi.h</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/structneorv32__sysinfo__t.html b/sw/structneorv32__sysinfo__t.html new file mode 100644 index 0000000000..2739bb106b --- /dev/null +++ b/sw/structneorv32__sysinfo__t.html @@ -0,0 +1,181 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: neorv32_sysinfo_t Struct Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#pub-attribs">Data Fields</a> </div> + <div class="headertitle"><div class="title">neorv32_sysinfo_t Struct Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p><code>#include &lt;<a class="el" href="neorv32__sysinfo_8h_source.html">neorv32_sysinfo.h</a>&gt;</code></p> +<table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="pub-attribs" name="pub-attribs"></a> +Data Fields</h2></td></tr> +<tr class="memitem:afc225843ee31efff6350415b5aaae761" id="r_afc225843ee31efff6350415b5aaae761"><td class="memItemLeft" align="right" valign="top">const uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#afc225843ee31efff6350415b5aaae761">CLK</a></td></tr> +<tr class="separator:afc225843ee31efff6350415b5aaae761"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a51eee92b1824c1b19eb0a83a0a9c7d4c" id="r_a51eee92b1824c1b19eb0a83a0a9c7d4c"><td class="memItemLeft" align="right" valign="top">const uint8_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a51eee92b1824c1b19eb0a83a0a9c7d4c">MEM</a> [4]</td></tr> +<tr class="separator:a51eee92b1824c1b19eb0a83a0a9c7d4c"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ac43abe3b416da3a2895d1d06537a14c3" id="r_ac43abe3b416da3a2895d1d06537a14c3"><td class="memItemLeft" align="right" valign="top">const uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ac43abe3b416da3a2895d1d06537a14c3">SOC</a></td></tr> +<tr class="separator:ac43abe3b416da3a2895d1d06537a14c3"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ada99a36ccda38b254d5b6a84883101f6" id="r_ada99a36ccda38b254d5b6a84883101f6"><td class="memItemLeft" align="right" valign="top">const uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ada99a36ccda38b254d5b6a84883101f6">CACHE</a></td></tr> +<tr class="separator:ada99a36ccda38b254d5b6a84883101f6"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>SYSINFO module prototype - whole module is read-only </p> +</div><h2 class="groupheader">Field Documentation</h2> +<a id="ada99a36ccda38b254d5b6a84883101f6" name="ada99a36ccda38b254d5b6a84883101f6"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ada99a36ccda38b254d5b6a84883101f6">&#9670;&#160;</a></span>CACHE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">const uint32_t neorv32_sysinfo_t::CACHE</td> + </tr> + </table> +</div><div class="memdoc"> +<p>offset 12: cache configuration (NEORV32_SYSINFO_CACHE_enum) </p> + +</div> +</div> +<a id="afc225843ee31efff6350415b5aaae761" name="afc225843ee31efff6350415b5aaae761"></a> +<h2 class="memtitle"><span class="permalink"><a href="#afc225843ee31efff6350415b5aaae761">&#9670;&#160;</a></span>CLK</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">const uint32_t neorv32_sysinfo_t::CLK</td> + </tr> + </table> +</div><div class="memdoc"> +<p>offset 0: clock speed in Hz </p> + +</div> +</div> +<a id="a51eee92b1824c1b19eb0a83a0a9c7d4c" name="a51eee92b1824c1b19eb0a83a0a9c7d4c"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a51eee92b1824c1b19eb0a83a0a9c7d4c">&#9670;&#160;</a></span>MEM</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">const uint8_t neorv32_sysinfo_t::MEM[4]</td> + </tr> + </table> +</div><div class="memdoc"> +<p>offset 4: Memory configuration (sizes) (NEORV32_SYSINFO_MEM_enum) </p> + +</div> +</div> +<a id="ac43abe3b416da3a2895d1d06537a14c3" name="ac43abe3b416da3a2895d1d06537a14c3"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ac43abe3b416da3a2895d1d06537a14c3">&#9670;&#160;</a></span>SOC</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">const uint32_t neorv32_sysinfo_t::SOC</td> + </tr> + </table> +</div><div class="memdoc"> +<p>offset 8: SoC features (NEORV32_SYSINFO_SOC_enum) </p> + +</div> +</div> +<hr/>The documentation for this struct was generated from the following file:<ul> +<li>sw/lib/include/<a class="el" href="neorv32__sysinfo_8h_source.html">neorv32_sysinfo.h</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/structneorv32__trng__t.html b/sw/structneorv32__trng__t.html new file mode 100644 index 0000000000..4b75664930 --- /dev/null +++ b/sw/structneorv32__trng__t.html @@ -0,0 +1,130 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: neorv32_trng_t Struct Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#pub-attribs">Data Fields</a> </div> + <div class="headertitle"><div class="title">neorv32_trng_t Struct Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p><code>#include &lt;<a class="el" href="neorv32__trng_8h_source.html">neorv32_trng.h</a>&gt;</code></p> +<table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="pub-attribs" name="pub-attribs"></a> +Data Fields</h2></td></tr> +<tr class="memitem:ae2ff37ce30fb85ef59d9012534bc7e67" id="r_ae2ff37ce30fb85ef59d9012534bc7e67"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ae2ff37ce30fb85ef59d9012534bc7e67">CTRL</a></td></tr> +<tr class="separator:ae2ff37ce30fb85ef59d9012534bc7e67"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>TRNG module prototype </p> +</div><h2 class="groupheader">Field Documentation</h2> +<a id="ae2ff37ce30fb85ef59d9012534bc7e67" name="ae2ff37ce30fb85ef59d9012534bc7e67"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ae2ff37ce30fb85ef59d9012534bc7e67">&#9670;&#160;</a></span>CTRL</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_trng_t::CTRL</td> + </tr> + </table> +</div><div class="memdoc"> +<p>offset 0: control register (<a class="el" href="neorv32__trng_8h.html#a1440e1355bf5bff17760992adc156b1a">NEORV32_TRNG_CTRL_enum</a>) </p> + +</div> +</div> +<hr/>The documentation for this struct was generated from the following file:<ul> +<li>sw/lib/include/<a class="el" href="neorv32__trng_8h_source.html">neorv32_trng.h</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/structneorv32__twi__t.html b/sw/structneorv32__twi__t.html new file mode 100644 index 0000000000..15d7764b6e --- /dev/null +++ b/sw/structneorv32__twi__t.html @@ -0,0 +1,147 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: neorv32_twi_t Struct Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#pub-attribs">Data Fields</a> </div> + <div class="headertitle"><div class="title">neorv32_twi_t Struct Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p><code>#include &lt;<a class="el" href="neorv32__twi_8h_source.html">neorv32_twi.h</a>&gt;</code></p> +<table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="pub-attribs" name="pub-attribs"></a> +Data Fields</h2></td></tr> +<tr class="memitem:a148a1c681a2632881b25ee41652b5304" id="r_a148a1c681a2632881b25ee41652b5304"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a148a1c681a2632881b25ee41652b5304">CTRL</a></td></tr> +<tr class="separator:a148a1c681a2632881b25ee41652b5304"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ae311e0827bdb178c6dd8c4535b80d5cb" id="r_ae311e0827bdb178c6dd8c4535b80d5cb"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ae311e0827bdb178c6dd8c4535b80d5cb">DCMD</a></td></tr> +<tr class="separator:ae311e0827bdb178c6dd8c4535b80d5cb"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>TWI module prototype </p> +</div><h2 class="groupheader">Field Documentation</h2> +<a id="a148a1c681a2632881b25ee41652b5304" name="a148a1c681a2632881b25ee41652b5304"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a148a1c681a2632881b25ee41652b5304">&#9670;&#160;</a></span>CTRL</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_twi_t::CTRL</td> + </tr> + </table> +</div><div class="memdoc"> +<p>offset 0: control register (<a class="el" href="neorv32__twi_8h.html#a71ef393d3b34d2dd0698590994b7dafa">NEORV32_TWI_CTRL_enum</a>) </p> + +</div> +</div> +<a id="ae311e0827bdb178c6dd8c4535b80d5cb" name="ae311e0827bdb178c6dd8c4535b80d5cb"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ae311e0827bdb178c6dd8c4535b80d5cb">&#9670;&#160;</a></span>DCMD</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_twi_t::DCMD</td> + </tr> + </table> +</div><div class="memdoc"> +<p>offset 4: data/cmd register (<a class="el" href="neorv32__twi_8h.html#a3421852c63baca60fe58c990b1c653d8">NEORV32_TWI_DCMD_enum</a>) </p> + +</div> +</div> +<hr/>The documentation for this struct was generated from the following file:<ul> +<li>sw/lib/include/<a class="el" href="neorv32__twi_8h_source.html">neorv32_twi.h</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/structneorv32__uart__t.html b/sw/structneorv32__uart__t.html new file mode 100644 index 0000000000..3b88112c43 --- /dev/null +++ b/sw/structneorv32__uart__t.html @@ -0,0 +1,147 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: neorv32_uart_t Struct Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#pub-attribs">Data Fields</a> </div> + <div class="headertitle"><div class="title">neorv32_uart_t Struct Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p><code>#include &lt;<a class="el" href="neorv32__uart_8h_source.html">neorv32_uart.h</a>&gt;</code></p> +<table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="pub-attribs" name="pub-attribs"></a> +Data Fields</h2></td></tr> +<tr class="memitem:a0a6227aeea38335d2b9a9da46b35451b" id="r_a0a6227aeea38335d2b9a9da46b35451b"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a0a6227aeea38335d2b9a9da46b35451b">CTRL</a></td></tr> +<tr class="separator:a0a6227aeea38335d2b9a9da46b35451b"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a38eec82aae9ed522a0d2afb9a9560036" id="r_a38eec82aae9ed522a0d2afb9a9560036"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a38eec82aae9ed522a0d2afb9a9560036">DATA</a></td></tr> +<tr class="separator:a38eec82aae9ed522a0d2afb9a9560036"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>UART module prototype </p> +</div><h2 class="groupheader">Field Documentation</h2> +<a id="a0a6227aeea38335d2b9a9da46b35451b" name="a0a6227aeea38335d2b9a9da46b35451b"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a0a6227aeea38335d2b9a9da46b35451b">&#9670;&#160;</a></span>CTRL</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_uart_t::CTRL</td> + </tr> + </table> +</div><div class="memdoc"> +<p>offset 0: control register (<a class="el" href="neorv32__uart_8h.html#ad9f75f453beca1619344bb4213352afc">NEORV32_UART_CTRL_enum</a>) </p> + +</div> +</div> +<a id="a38eec82aae9ed522a0d2afb9a9560036" name="a38eec82aae9ed522a0d2afb9a9560036"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a38eec82aae9ed522a0d2afb9a9560036">&#9670;&#160;</a></span>DATA</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_uart_t::DATA</td> + </tr> + </table> +</div><div class="memdoc"> +<p>offset 4: data register (<a class="el" href="neorv32__uart_8h.html#adcf35350a9ea18a59c32c35f528643f2">NEORV32_UART_DATA_enum</a>) </p> + +</div> +</div> +<hr/>The documentation for this struct was generated from the following file:<ul> +<li>sw/lib/include/<a class="el" href="neorv32__uart_8h_source.html">neorv32_uart.h</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/structneorv32__wdt__t.html b/sw/structneorv32__wdt__t.html new file mode 100644 index 0000000000..39bba9911d --- /dev/null +++ b/sw/structneorv32__wdt__t.html @@ -0,0 +1,147 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: neorv32_wdt_t Struct Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#pub-attribs">Data Fields</a> </div> + <div class="headertitle"><div class="title">neorv32_wdt_t Struct Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p><code>#include &lt;<a class="el" href="neorv32__wdt_8h_source.html">neorv32_wdt.h</a>&gt;</code></p> +<table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="pub-attribs" name="pub-attribs"></a> +Data Fields</h2></td></tr> +<tr class="memitem:a6ae41e28d08b0f06118c499f52b56f41" id="r_a6ae41e28d08b0f06118c499f52b56f41"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a6ae41e28d08b0f06118c499f52b56f41">CTRL</a></td></tr> +<tr class="separator:a6ae41e28d08b0f06118c499f52b56f41"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a0a273e8ca2bd92547bf7727ec65a9449" id="r_a0a273e8ca2bd92547bf7727ec65a9449"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a0a273e8ca2bd92547bf7727ec65a9449">RESET</a></td></tr> +<tr class="separator:a0a273e8ca2bd92547bf7727ec65a9449"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>WDT module prototype </p> +</div><h2 class="groupheader">Field Documentation</h2> +<a id="a6ae41e28d08b0f06118c499f52b56f41" name="a6ae41e28d08b0f06118c499f52b56f41"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a6ae41e28d08b0f06118c499f52b56f41">&#9670;&#160;</a></span>CTRL</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_wdt_t::CTRL</td> + </tr> + </table> +</div><div class="memdoc"> +<p>offset 0: control register (<a class="el" href="neorv32__wdt_8h.html#a0a4cb24fd818277c5bb9b10ff519f23e">NEORV32_WDT_CTRL_enum</a>) </p> + +</div> +</div> +<a id="a0a273e8ca2bd92547bf7727ec65a9449" name="a0a273e8ca2bd92547bf7727ec65a9449"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a0a273e8ca2bd92547bf7727ec65a9449">&#9670;&#160;</a></span>RESET</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_wdt_t::RESET</td> + </tr> + </table> +</div><div class="memdoc"> +<p>offset 4: WDT reset trigger (write password to "feed" watchdog) </p> + +</div> +</div> +<hr/>The documentation for this struct was generated from the following file:<ul> +<li>sw/lib/include/<a class="el" href="neorv32__wdt_8h_source.html">neorv32_wdt.h</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/structneorv32__xip__t.html b/sw/structneorv32__xip__t.html new file mode 100644 index 0000000000..5f0dc06203 --- /dev/null +++ b/sw/structneorv32__xip__t.html @@ -0,0 +1,181 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: neorv32_xip_t Struct Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#pub-attribs">Data Fields</a> </div> + <div class="headertitle"><div class="title">neorv32_xip_t Struct Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p><code>#include &lt;<a class="el" href="neorv32__xip_8h_source.html">neorv32_xip.h</a>&gt;</code></p> +<table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="pub-attribs" name="pub-attribs"></a> +Data Fields</h2></td></tr> +<tr class="memitem:a7ead9d6a4f784d766a6b2755c6d35235" id="r_a7ead9d6a4f784d766a6b2755c6d35235"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a7ead9d6a4f784d766a6b2755c6d35235">CTRL</a></td></tr> +<tr class="separator:a7ead9d6a4f784d766a6b2755c6d35235"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aacb77d586c3caec518e8e0024cfe745c" id="r_aacb77d586c3caec518e8e0024cfe745c"><td class="memItemLeft" align="right" valign="top">const uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aacb77d586c3caec518e8e0024cfe745c">reserved</a></td></tr> +<tr class="separator:aacb77d586c3caec518e8e0024cfe745c"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ad64048bb3544e712b1c668c2ef343ccb" id="r_ad64048bb3544e712b1c668c2ef343ccb"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ad64048bb3544e712b1c668c2ef343ccb">DATA_LO</a></td></tr> +<tr class="separator:ad64048bb3544e712b1c668c2ef343ccb"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a516ab9c075ef6d1fb741e243db7703b2" id="r_a516ab9c075ef6d1fb741e243db7703b2"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a516ab9c075ef6d1fb741e243db7703b2">DATA_HI</a></td></tr> +<tr class="separator:a516ab9c075ef6d1fb741e243db7703b2"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>XIP module prototype </p> +</div><h2 class="groupheader">Field Documentation</h2> +<a id="a7ead9d6a4f784d766a6b2755c6d35235" name="a7ead9d6a4f784d766a6b2755c6d35235"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a7ead9d6a4f784d766a6b2755c6d35235">&#9670;&#160;</a></span>CTRL</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_xip_t::CTRL</td> + </tr> + </table> +</div><div class="memdoc"> +<p>offset 0: control register (<a class="el" href="neorv32__xip_8h.html#a72ed1ff87de1222cc3a13177c7483ceb">NEORV32_XIP_CTRL_enum</a>) </p> + +</div> +</div> +<a id="a516ab9c075ef6d1fb741e243db7703b2" name="a516ab9c075ef6d1fb741e243db7703b2"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a516ab9c075ef6d1fb741e243db7703b2">&#9670;&#160;</a></span>DATA_HI</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_xip_t::DATA_HI</td> + </tr> + </table> +</div><div class="memdoc"> +<p>offset 12: SPI data register high </p> + +</div> +</div> +<a id="ad64048bb3544e712b1c668c2ef343ccb" name="ad64048bb3544e712b1c668c2ef343ccb"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ad64048bb3544e712b1c668c2ef343ccb">&#9670;&#160;</a></span>DATA_LO</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_xip_t::DATA_LO</td> + </tr> + </table> +</div><div class="memdoc"> +<p>offset 8: SPI data register low </p> + +</div> +</div> +<a id="aacb77d586c3caec518e8e0024cfe745c" name="aacb77d586c3caec518e8e0024cfe745c"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aacb77d586c3caec518e8e0024cfe745c">&#9670;&#160;</a></span>reserved</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">const uint32_t neorv32_xip_t::reserved</td> + </tr> + </table> +</div><div class="memdoc"> +<p>offset 4: reserved </p> + +</div> +</div> +<hr/>The documentation for this struct was generated from the following file:<ul> +<li>sw/lib/include/<a class="el" href="neorv32__xip_8h_source.html">neorv32_xip.h</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/structneorv32__xirq__t.html b/sw/structneorv32__xirq__t.html new file mode 100644 index 0000000000..cd34bad144 --- /dev/null +++ b/sw/structneorv32__xirq__t.html @@ -0,0 +1,249 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: neorv32_xirq_t Struct Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#pub-attribs">Data Fields</a> </div> + <div class="headertitle"><div class="title">neorv32_xirq_t Struct Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p><code>#include &lt;<a class="el" href="neorv32__xirq_8h_source.html">neorv32_xirq.h</a>&gt;</code></p> +<table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="pub-attribs" name="pub-attribs"></a> +Data Fields</h2></td></tr> +<tr class="memitem:aef3c2b491207abd68bf6392f97096a74" id="r_aef3c2b491207abd68bf6392f97096a74"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aef3c2b491207abd68bf6392f97096a74">EIE</a></td></tr> +<tr class="separator:aef3c2b491207abd68bf6392f97096a74"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a788d8004f3b85fb66e947415d8fcc058" id="r_a788d8004f3b85fb66e947415d8fcc058"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a788d8004f3b85fb66e947415d8fcc058">EIP</a></td></tr> +<tr class="separator:a788d8004f3b85fb66e947415d8fcc058"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ae4f7f3f41210ff329b6f82d5dfada88a" id="r_ae4f7f3f41210ff329b6f82d5dfada88a"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ae4f7f3f41210ff329b6f82d5dfada88a">ESC</a></td></tr> +<tr class="separator:ae4f7f3f41210ff329b6f82d5dfada88a"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ab7117c210b5f0a8ebc369eeba6a4a5bc" id="r_ab7117c210b5f0a8ebc369eeba6a4a5bc"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ab7117c210b5f0a8ebc369eeba6a4a5bc">TTYP</a></td></tr> +<tr class="separator:ab7117c210b5f0a8ebc369eeba6a4a5bc"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a5fe0036a2cada585228b60aaa780e92a" id="r_a5fe0036a2cada585228b60aaa780e92a"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a5fe0036a2cada585228b60aaa780e92a">TPOL</a></td></tr> +<tr class="separator:a5fe0036a2cada585228b60aaa780e92a"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a9be02c0398fab5763a3afbd7a018f092" id="r_a9be02c0398fab5763a3afbd7a018f092"><td class="memItemLeft" align="right" valign="top">const uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a9be02c0398fab5763a3afbd7a018f092">reserved0</a></td></tr> +<tr class="separator:a9be02c0398fab5763a3afbd7a018f092"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ac4c999cf3da75e39753619f917d9d654" id="r_ac4c999cf3da75e39753619f917d9d654"><td class="memItemLeft" align="right" valign="top">const uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#ac4c999cf3da75e39753619f917d9d654">reserved1</a></td></tr> +<tr class="separator:ac4c999cf3da75e39753619f917d9d654"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:afba6ed500e1448719783923975b2dc64" id="r_afba6ed500e1448719783923975b2dc64"><td class="memItemLeft" align="right" valign="top">const uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#afba6ed500e1448719783923975b2dc64">reserved2</a></td></tr> +<tr class="separator:afba6ed500e1448719783923975b2dc64"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>XIRQ module prototype </p> +</div><h2 class="groupheader">Field Documentation</h2> +<a id="aef3c2b491207abd68bf6392f97096a74" name="aef3c2b491207abd68bf6392f97096a74"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aef3c2b491207abd68bf6392f97096a74">&#9670;&#160;</a></span>EIE</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_xirq_t::EIE</td> + </tr> + </table> +</div><div class="memdoc"> +<p>offset 0: external interrupt enable register </p> + +</div> +</div> +<a id="a788d8004f3b85fb66e947415d8fcc058" name="a788d8004f3b85fb66e947415d8fcc058"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a788d8004f3b85fb66e947415d8fcc058">&#9670;&#160;</a></span>EIP</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_xirq_t::EIP</td> + </tr> + </table> +</div><div class="memdoc"> +<p>offset 4: external interrupt pending register </p> + +</div> +</div> +<a id="ae4f7f3f41210ff329b6f82d5dfada88a" name="ae4f7f3f41210ff329b6f82d5dfada88a"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ae4f7f3f41210ff329b6f82d5dfada88a">&#9670;&#160;</a></span>ESC</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_xirq_t::ESC</td> + </tr> + </table> +</div><div class="memdoc"> +<p>offset 8: external interrupt source register </p> + +</div> +</div> +<a id="a9be02c0398fab5763a3afbd7a018f092" name="a9be02c0398fab5763a3afbd7a018f092"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a9be02c0398fab5763a3afbd7a018f092">&#9670;&#160;</a></span>reserved0</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">const uint32_t neorv32_xirq_t::reserved0</td> + </tr> + </table> +</div><div class="memdoc"> +<p>offset 20: reserved </p> + +</div> +</div> +<a id="ac4c999cf3da75e39753619f917d9d654" name="ac4c999cf3da75e39753619f917d9d654"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ac4c999cf3da75e39753619f917d9d654">&#9670;&#160;</a></span>reserved1</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">const uint32_t neorv32_xirq_t::reserved1</td> + </tr> + </table> +</div><div class="memdoc"> +<p>offset 24: reserved </p> + +</div> +</div> +<a id="afba6ed500e1448719783923975b2dc64" name="afba6ed500e1448719783923975b2dc64"></a> +<h2 class="memtitle"><span class="permalink"><a href="#afba6ed500e1448719783923975b2dc64">&#9670;&#160;</a></span>reserved2</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">const uint32_t neorv32_xirq_t::reserved2</td> + </tr> + </table> +</div><div class="memdoc"> +<p>offset 28: reserved </p> + +</div> +</div> +<a id="a5fe0036a2cada585228b60aaa780e92a" name="a5fe0036a2cada585228b60aaa780e92a"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a5fe0036a2cada585228b60aaa780e92a">&#9670;&#160;</a></span>TPOL</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_xirq_t::TPOL</td> + </tr> + </table> +</div><div class="memdoc"> +<p>offset 16: external interrupt source register </p> + +</div> +</div> +<a id="ab7117c210b5f0a8ebc369eeba6a4a5bc" name="ab7117c210b5f0a8ebc369eeba6a4a5bc"></a> +<h2 class="memtitle"><span class="permalink"><a href="#ab7117c210b5f0a8ebc369eeba6a4a5bc">&#9670;&#160;</a></span>TTYP</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t neorv32_xirq_t::TTYP</td> + </tr> + </table> +</div><div class="memdoc"> +<p>offset 12: external interrupt source register </p> + +</div> +</div> +<hr/>The documentation for this struct was generated from the following file:<ul> +<li>sw/lib/include/<a class="el" href="neorv32__xirq_8h_source.html">neorv32_xirq.h</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/structrecord.html b/sw/structrecord.html new file mode 100644 index 0000000000..7cba111064 --- /dev/null +++ b/sw/structrecord.html @@ -0,0 +1,155 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: record Struct Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#pub-attribs">Data Fields</a> </div> + <div class="headertitle"><div class="title">record Struct Reference</div></div> +</div><!--header--> +<div class="contents"> +<table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="pub-attribs" name="pub-attribs"></a> +Data Fields</h2></td></tr> +<tr class="memitem:ad8b33bb16e8d3101a17b5dbbf37b051f" id="r_ad8b33bb16e8d3101a17b5dbbf37b051f"><td class="memItemLeft" align="right" valign="top"><a id="ad8b33bb16e8d3101a17b5dbbf37b051f" name="ad8b33bb16e8d3101a17b5dbbf37b051f"></a> +struct <a class="el" href="structrecord.html">record</a> *&#160;</td><td class="memItemRight" valign="bottom"><b>Ptr_Comp</b></td></tr> +<tr class="separator:ad8b33bb16e8d3101a17b5dbbf37b051f"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a9464937f85e9a8b11f38229764c0dff7" id="r_a9464937f85e9a8b11f38229764c0dff7"><td class="memItemLeft" align="right" valign="top"><a id="a9464937f85e9a8b11f38229764c0dff7" name="a9464937f85e9a8b11f38229764c0dff7"></a> +Enumeration&#160;</td><td class="memItemRight" valign="bottom"><b>Discr</b></td></tr> +<tr class="separator:a9464937f85e9a8b11f38229764c0dff7"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a411f007775868401459a118a7b210e35" id="r_a411f007775868401459a118a7b210e35"><td class="memItemLeft" ><a id="a411f007775868401459a118a7b210e35" name="a411f007775868401459a118a7b210e35"></a> +union {&#160;</td><td class="memItemRight" valign="bottom"></td></tr> +<tr class="separator:"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aac622781dd01254adab01f3412b85e35" id="r_aac622781dd01254adab01f3412b85e35"><td class="memItemLeft" > +&#160;&#160;&#160;struct {&#160;</td><td class="memItemRight" valign="bottom"></td></tr> +<tr class="separator:aa7708fbf51a87d91ed0636e13260e753"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a9eb1f354ec5a2004f2444757e71595c8" id="r_a9eb1f354ec5a2004f2444757e71595c8"><td class="memItemLeft" > +&#160;&#160;&#160;&#160;&#160;&#160;Enumeration&#160;&#160;&#160;<b>Enum_Comp</b>&#160;</td><td class="memItemRight" valign="bottom"></td></tr> +<tr class="separator:a9eb1f354ec5a2004f2444757e71595c8"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a347e674f08251f18ba82d57b050d4125" id="r_a347e674f08251f18ba82d57b050d4125"><td class="memItemLeft" > +&#160;&#160;&#160;&#160;&#160;&#160;int&#160;&#160;&#160;<b>Int_Comp</b>&#160;</td><td class="memItemRight" valign="bottom"></td></tr> +<tr class="separator:a347e674f08251f18ba82d57b050d4125"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aa8ef470d7dbb66c7c0932edd33ede2b4" id="r_aa8ef470d7dbb66c7c0932edd33ede2b4"><td class="memItemLeft" > +&#160;&#160;&#160;&#160;&#160;&#160;char&#160;&#160;&#160;<b>Str_Comp</b> [31]&#160;</td><td class="memItemRight" valign="bottom"></td></tr> +<tr class="separator:aa8ef470d7dbb66c7c0932edd33ede2b4"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aac622781dd01254adab01f3412b85e35" id="r_aac622781dd01254adab01f3412b85e35"><td class="memItemLeft" valign="top">&#160;&#160;&#160;}&#160;&#160;&#160;<b>var_1</b>&#160;</td><td class="memItemRight" valign="bottom"></td></tr> +<tr class="separator:aac622781dd01254adab01f3412b85e35"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:acff560158cb5a697a2db95c291622399" id="r_acff560158cb5a697a2db95c291622399"><td class="memItemLeft" > +&#160;&#160;&#160;struct {&#160;</td><td class="memItemRight" valign="bottom"></td></tr> +<tr class="separator:aa0eb18bd040c631e8d88434c5abff601"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ac320afb9d4a056d72c6878e6bd56020b" id="r_ac320afb9d4a056d72c6878e6bd56020b"><td class="memItemLeft" > +&#160;&#160;&#160;&#160;&#160;&#160;Enumeration&#160;&#160;&#160;<b>E_Comp_2</b>&#160;</td><td class="memItemRight" valign="bottom"></td></tr> +<tr class="separator:ac320afb9d4a056d72c6878e6bd56020b"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a3128048869b46615ddf99a930ba7cad0" id="r_a3128048869b46615ddf99a930ba7cad0"><td class="memItemLeft" > +&#160;&#160;&#160;&#160;&#160;&#160;char&#160;&#160;&#160;<b>Str_2_Comp</b> [31]&#160;</td><td class="memItemRight" valign="bottom"></td></tr> +<tr class="separator:a3128048869b46615ddf99a930ba7cad0"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:acff560158cb5a697a2db95c291622399" id="r_acff560158cb5a697a2db95c291622399"><td class="memItemLeft" valign="top">&#160;&#160;&#160;}&#160;&#160;&#160;<b>var_2</b>&#160;</td><td class="memItemRight" valign="bottom"></td></tr> +<tr class="separator:acff560158cb5a697a2db95c291622399"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a346ca9bbcc2f93826b656ded50b2c853" id="r_a346ca9bbcc2f93826b656ded50b2c853"><td class="memItemLeft" > +&#160;&#160;&#160;struct {&#160;</td><td class="memItemRight" valign="bottom"></td></tr> +<tr class="separator:ab188e1dd656f71796bf8751673f912e0"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a2dda9ded52716954a77cd6782cac2be0" id="r_a2dda9ded52716954a77cd6782cac2be0"><td class="memItemLeft" > +&#160;&#160;&#160;&#160;&#160;&#160;char&#160;&#160;&#160;<b>Ch_1_Comp</b>&#160;</td><td class="memItemRight" valign="bottom"></td></tr> +<tr class="separator:a2dda9ded52716954a77cd6782cac2be0"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a8e971f4eeb0d9071cc79ad13fa7d0166" id="r_a8e971f4eeb0d9071cc79ad13fa7d0166"><td class="memItemLeft" > +&#160;&#160;&#160;&#160;&#160;&#160;char&#160;&#160;&#160;<b>Ch_2_Comp</b>&#160;</td><td class="memItemRight" valign="bottom"></td></tr> +<tr class="separator:a8e971f4eeb0d9071cc79ad13fa7d0166"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a346ca9bbcc2f93826b656ded50b2c853" id="r_a346ca9bbcc2f93826b656ded50b2c853"><td class="memItemLeft" valign="top">&#160;&#160;&#160;}&#160;&#160;&#160;<b>var_3</b>&#160;</td><td class="memItemRight" valign="bottom"></td></tr> +<tr class="separator:a346ca9bbcc2f93826b656ded50b2c853"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a411f007775868401459a118a7b210e35" id="r_a411f007775868401459a118a7b210e35"><td class="memItemLeft" valign="top">}&#160;</td><td class="memItemRight" valign="bottom"><b>variant</b>&#160;</td><td class="memItemRight" valign="bottom"></td></tr> +<tr class="separator:a411f007775868401459a118a7b210e35"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<hr/>The documentation for this struct was generated from the following file:<ul> +<li>sw/example/dhrystone/<a class="el" href="dhry_8h_source.html">dhry.h</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/structt__neorv32__spi.html b/sw/structt__neorv32__spi.html new file mode 100644 index 0000000000..627a8e526c --- /dev/null +++ b/sw/structt__neorv32__spi.html @@ -0,0 +1,228 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: t_neorv32_spi Struct Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#pub-attribs">Data Fields</a> </div> + <div class="headertitle"><div class="title">t_neorv32_spi Struct Reference</div></div> +</div><!--header--> +<div class="contents"> +<table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="pub-attribs" name="pub-attribs"></a> +Data Fields</h2></td></tr> +<tr class="memitem:a487a6510820871ff8d0da7699463f6d9" id="r_a487a6510820871ff8d0da7699463f6d9"><td class="memItemLeft" align="right" valign="top">uint8_t *&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a487a6510820871ff8d0da7699463f6d9">ptrSpiBuf</a></td></tr> +<tr class="separator:a487a6510820871ff8d0da7699463f6d9"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a435c266758a440d32de4344472e3514a" id="r_a435c266758a440d32de4344472e3514a"><td class="memItemLeft" align="right" valign="top">uint8_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a435c266758a440d32de4344472e3514a">uint8Csn</a></td></tr> +<tr class="separator:a435c266758a440d32de4344472e3514a"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a71fb3f91af197e1abdbe97d62130ad0f" id="r_a71fb3f91af197e1abdbe97d62130ad0f"><td class="memItemLeft" align="right" valign="top">uint16_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a71fb3f91af197e1abdbe97d62130ad0f">uint16Fifo</a></td></tr> +<tr class="separator:a71fb3f91af197e1abdbe97d62130ad0f"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aa4d96f72e57fb6930ab43de6fb0a85ae" id="r_aa4d96f72e57fb6930ab43de6fb0a85ae"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aa4d96f72e57fb6930ab43de6fb0a85ae">uint32Total</a></td></tr> +<tr class="separator:aa4d96f72e57fb6930ab43de6fb0a85ae"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aa89b7a769e54e331798e4d68d02a7b43" id="r_aa89b7a769e54e331798e4d68d02a7b43"><td class="memItemLeft" align="right" valign="top">volatile uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#aa89b7a769e54e331798e4d68d02a7b43">uint32Write</a></td></tr> +<tr class="separator:aa89b7a769e54e331798e4d68d02a7b43"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a5750a54f8312ec2fed349eb9fbeff323" id="r_a5750a54f8312ec2fed349eb9fbeff323"><td class="memItemLeft" align="right" valign="top">volatile uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a5750a54f8312ec2fed349eb9fbeff323">uint32Read</a></td></tr> +<tr class="separator:a5750a54f8312ec2fed349eb9fbeff323"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a8ed31f9393bee5b963e08582b6c517ed" id="r_a8ed31f9393bee5b963e08582b6c517ed"><td class="memItemLeft" align="right" valign="top">volatile uint8_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a8ed31f9393bee5b963e08582b6c517ed">uint8IsBusy</a></td></tr> +<tr class="separator:a8ed31f9393bee5b963e08582b6c517ed"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<h2 class="groupheader">Field Documentation</h2> +<a id="a487a6510820871ff8d0da7699463f6d9" name="a487a6510820871ff8d0da7699463f6d9"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a487a6510820871ff8d0da7699463f6d9">&#9670;&#160;</a></span>ptrSpiBuf</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint8_t* t_neorv32_spi::ptrSpiBuf</td> + </tr> + </table> +</div><div class="memdoc"> +<p>SPI buffer data pointer </p> + +</div> +</div> +<a id="a71fb3f91af197e1abdbe97d62130ad0f" name="a71fb3f91af197e1abdbe97d62130ad0f"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a71fb3f91af197e1abdbe97d62130ad0f">&#9670;&#160;</a></span>uint16Fifo</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint16_t t_neorv32_spi::uint16Fifo</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Number of elements in Fifo </p> + +</div> +</div> +<a id="a5750a54f8312ec2fed349eb9fbeff323" name="a5750a54f8312ec2fed349eb9fbeff323"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a5750a54f8312ec2fed349eb9fbeff323">&#9670;&#160;</a></span>uint32Read</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">volatile uint32_t t_neorv32_spi::uint32Read</td> + </tr> + </table> +</div><div class="memdoc"> +<p>From SPI core read elements </p> + +</div> +</div> +<a id="aa4d96f72e57fb6930ab43de6fb0a85ae" name="aa4d96f72e57fb6930ab43de6fb0a85ae"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aa4d96f72e57fb6930ab43de6fb0a85ae">&#9670;&#160;</a></span>uint32Total</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t t_neorv32_spi::uint32Total</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Number of elements in buffer </p> + +</div> +</div> +<a id="aa89b7a769e54e331798e4d68d02a7b43" name="aa89b7a769e54e331798e4d68d02a7b43"></a> +<h2 class="memtitle"><span class="permalink"><a href="#aa89b7a769e54e331798e4d68d02a7b43">&#9670;&#160;</a></span>uint32Write</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">volatile uint32_t t_neorv32_spi::uint32Write</td> + </tr> + </table> +</div><div class="memdoc"> +<p>To SPI core write elements </p> + +</div> +</div> +<a id="a435c266758a440d32de4344472e3514a" name="a435c266758a440d32de4344472e3514a"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a435c266758a440d32de4344472e3514a">&#9670;&#160;</a></span>uint8Csn</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint8_t t_neorv32_spi::uint8Csn</td> + </tr> + </table> +</div><div class="memdoc"> +<p>SPI chip select channel </p> + +</div> +</div> +<a id="a8ed31f9393bee5b963e08582b6c517ed" name="a8ed31f9393bee5b963e08582b6c517ed"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a8ed31f9393bee5b963e08582b6c517ed">&#9670;&#160;</a></span>uint8IsBusy</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">volatile uint8_t t_neorv32_spi::uint8IsBusy</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Spi Core is Busy </p> + +</div> +</div> +<hr/>The documentation for this struct was generated from the following file:<ul> +<li>sw/example/demo_spi_irq/drv/<a class="el" href="neorv32__spi__irq_8h_source.html">neorv32_spi_irq.h</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/sync_off.png b/sw/sync_off.png new file mode 100644 index 0000000000000000000000000000000000000000..3b443fc62892114406e3d399421b2a881b897acc GIT binary patch literal 853 zcmV-b1FHOqP)<h;3K|Lk000e1NJLTq000;O000;W1^@s6;CDUv0009VNkl<ZcmeI* zOK4PA7{KxW<S|JmGnqI|rb(KahDirA+8B+gVk8A)%pe9yF;+3L5iKZG7xuBS&@L(k z33MTXOIxMHjirbWgs8M;qhM?(_-v^nS(KzU#%Ih_`hB-^XYSm&39)2*I6vmhow@fr z=iKj{vvuv-e;!~uA+biR6pf-n<cdGVuox5<#BBg4c>oT|#XixUYy%lpuf3i8{fX!o zUyDD0jOrAiT^tq>fLSOOABs-#u{dV^F$b{L9&!2=9&RmV;;8s^x&UqB$PCj4FdKbh zoB1WTskPUPu05XzFbA}=KZ-GP1fPpAfSs>6AHb12UlR%-i&uOlTpFNS7{jm@mkU1V zh`nrXr~+^lsV-s1dkZOaI|kYyVj3WBpPCY{n~yd%u%e+d=f%`N0FItMPtdgBb@py; zq@v6NVArhyTC7)ULw-Jy8y42S1~4n(3LkrW8mW(F-4oXUP3E`e#g**YyqI7h-J2zK zK{m9##m4ri!7N>CqQqCcnI3hqo1I;Yh&QLNY4T`*ptiQGozK>FF$!$+84Z`xwmeMh zJ0WT+OH$WYFALEaGj2_l+#DC3t7_S`vHpSivNeFbP6+r50cO<q-Bsh$IuZaopT|9E z-75alp&U9s%(|8uI^NA(#AD;nc=%{ivdZX(QFJ7~-yf%_Adjk`W@NhjJTyZ8*;|!n z9=K#TJuZz+={YZ#>8iu)`7i%Z4BTPh@_m3Tk!nAm^)5Bqnr%Ov|Baunj#&RPtRuK& z4RGz|D5HNrW83-#ydk}tVKJrNmyYt-sT<tBHx6XfOFDx2(ijpMiR>xLGlJY5nc&Re zU4SgHNPx8~Yxwr$bsju?4q&%T1874xxzq+_%?h8_ofw~(bld=o3iC)LUNR*BY%c0y zWd_jX{Y8`l%z+ol1$@Qa?Cy!(0CVIEeYpKZ`(9{z>3$CIe;pJDQk$m3p}$>xBm4lb zKo{4S)`wdU9Ba9jJbVJ0C=SOefZe%d$8=2r={nu<_^a3~>c#t_U6dye5)JrR(_a^E f@}b6j1K9lwFJq@>o)+Ry00000NkvXXu0mjfWa5j* literal 0 HcmV?d00001 diff --git a/sw/sync_on.png b/sw/sync_on.png new file mode 100644 index 0000000000000000000000000000000000000000..e08320fb64e6fa33b573005ed6d8fe294e19db76 GIT binary patch literal 845 zcmV-T1G4;yP)<h;3K|Lk000e1NJLTq000;O000;W1^@s6;CDUv0009NNkl<ZcmeI* zUr1D09KiAKIOC-Ar)j4&EoU~y1|7@QCTmeCsMH~fFw#|0OWK8m>Y;xxyHF2B5Wzm| zOOGupOTn@c(JmBOl)e;XMNnZuiTJP>rM8<|Q`7I<ojWskx{8*sm){4kXJ+p2oO6HY zoL5W7@h*VL_(ZL!7GaSmtl}SWU-XD;q7T4~4ZuW>_))aP?*T)ow&n59{}X4$3Goat zgjs?*aasfbrokzG5cT4K=uG`E14xZl@z)F<o_Z}1zllSWC8!Z+rkFN>={P0Y^?$4t z>v!teRnNZym<6h{7sLyF1V0HsfEl+l6TrZpsfr1}luH~F7L}ktXu|*uVX^RG$L0`K zWs3j|0tIvVe(N%_?2{(iCPFGf#B6Hjy6o&}D$A%W%jfO8_W%ZO#-mh}EM$LMn7joJ z05dHr!5Y92g+31l<%i1(=L1a1pXX+OYnalY>31V4K}BjyRe3)9n#;-cCVRD_IG1fT zOKGeNY8q;TL@K{dj@D^scf&VCs*-Jb>8b>|`b*osv52-!A?BpbYtTQBns5EAU**$m zSnVSm(teh>tQi*S*A>#ySc=n;`BHz`DuG4&g4Kf8lLhca+zvZ7t7RflD6-i-mcK=M z!=^P$*u2)bkY5asG4gsss!Hn%u~>}kIW`vMs%lJLH+u*9<4PaV_c6U`KqWXQH%+Nu zTv41O(^ZVi@qhjQdG!fbZw&y+2o!iYymO^?ud3{P*HdoX83YV*Uu_HB=?U&W9%AU# z80}k1SS-CXTU7dcQlsm<^oYLxVSseqY6NO}dc`Nj?8vrhNuCdm@^{a3AQ_>6myOj+ z`1RsLUXF|dm|3k7s2jD(B{rzE>WI2scH8i1;=O5Cc9xB3^aJk%fQjqsu+kH#0=_5a z0nCE8@dbQa-|YIuUVvG0L_IwHMEhOj$M<u9&-IHqnYs=DL+lbi3lG2ysF!p!_2H=p zj-g89hmThki^;JHknVE4V`@zS$(ZbTd?1=dsrXLRiJbUBq7weAmVjEk@rP>j4Uq05 X8=0q~qBNan00000NkvXXu0mjfptF>5 literal 0 HcmV?d00001 diff --git a/sw/syscalls_8c.html b/sw/syscalls_8c.html new file mode 100644 index 0000000000..43346c2063 --- /dev/null +++ b/sw/syscalls_8c.html @@ -0,0 +1,180 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: sw/lib/source/syscalls.c File Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +<div id="nav-path" class="navpath"> + <ul> +<li class="navelem"><a class="el" href="dir_01fcd3835fb4e7d9331b722d86291b65.html">sw</a></li><li class="navelem"><a class="el" href="dir_7d04193005ada6f9450f847f4adb6b5b.html">lib</a></li><li class="navelem"><a class="el" href="dir_0c6ac14e2254a316d41123f98feeb67b.html">source</a></li> </ul> +</div> +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#func-members">Functions</a> &#124; +<a href="#var-members">Variables</a> </div> + <div class="headertitle"><div class="title">syscalls.c File Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p>Newlib system calls. +<a href="#details">More...</a></p> +<div class="textblock"><code>#include &quot;<a class="el" href="neorv32_8h_source.html">neorv32.h</a>&quot;</code><br /> +<code>#include &lt;newlib.h&gt;</code><br /> +<code>#include &lt;sys/stat.h&gt;</code><br /> +<code>#include &lt;sys/timeb.h&gt;</code><br /> +<code>#include &lt;sys/times.h&gt;</code><br /> +<code>#include &lt;sys/time.h&gt;</code><br /> +<code>#include &lt;time.h&gt;</code><br /> +<code>#include &lt;unistd.h&gt;</code><br /> +<code>#include &lt;errno.h&gt;</code><br /> +</div><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="func-members" name="func-members"></a> +Functions</h2></td></tr> +<tr class="memitem:a38f8394eee3a086b87ff6d431e1e5343" id="r_a38f8394eee3a086b87ff6d431e1e5343"><td class="memItemLeft" align="right" valign="top"><a id="a38f8394eee3a086b87ff6d431e1e5343" name="a38f8394eee3a086b87ff6d431e1e5343"></a> +void *&#160;</td><td class="memItemRight" valign="bottom"><b>_sbrk</b> (int incr)</td></tr> +<tr class="separator:a38f8394eee3a086b87ff6d431e1e5343"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a5aab5e2acfd600e3667dc915a2bbc7cb" id="r_a5aab5e2acfd600e3667dc915a2bbc7cb"><td class="memItemLeft" align="right" valign="top"><a id="a5aab5e2acfd600e3667dc915a2bbc7cb" name="a5aab5e2acfd600e3667dc915a2bbc7cb"></a> +int&#160;</td><td class="memItemRight" valign="bottom"><b>_close</b> (int file)</td></tr> +<tr class="separator:a5aab5e2acfd600e3667dc915a2bbc7cb"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a41eef54307912a82d20e71c3d47315aa" id="r_a41eef54307912a82d20e71c3d47315aa"><td class="memItemLeft" align="right" valign="top"><a id="a41eef54307912a82d20e71c3d47315aa" name="a41eef54307912a82d20e71c3d47315aa"></a> +int&#160;</td><td class="memItemRight" valign="bottom"><b>_fstat</b> (int file, struct stat *st)</td></tr> +<tr class="separator:a41eef54307912a82d20e71c3d47315aa"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ad3134a3dc296622b8d1c5456e481505b" id="r_ad3134a3dc296622b8d1c5456e481505b"><td class="memItemLeft" align="right" valign="top"><a id="ad3134a3dc296622b8d1c5456e481505b" name="ad3134a3dc296622b8d1c5456e481505b"></a> +int&#160;</td><td class="memItemRight" valign="bottom"><b>_isatty</b> (int file)</td></tr> +<tr class="separator:ad3134a3dc296622b8d1c5456e481505b"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a7a61311bdf1cb025fc07dc2bdae22ce4" id="r_a7a61311bdf1cb025fc07dc2bdae22ce4"><td class="memItemLeft" align="right" valign="top"><a id="a7a61311bdf1cb025fc07dc2bdae22ce4" name="a7a61311bdf1cb025fc07dc2bdae22ce4"></a> +int&#160;</td><td class="memItemRight" valign="bottom"><b>_lseek</b> (int file, int ptr, int dir)</td></tr> +<tr class="separator:a7a61311bdf1cb025fc07dc2bdae22ce4"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:abc96bd69b58b2deaddb484478d911c1b" id="r_abc96bd69b58b2deaddb484478d911c1b"><td class="memItemLeft" align="right" valign="top"><a id="abc96bd69b58b2deaddb484478d911c1b" name="abc96bd69b58b2deaddb484478d911c1b"></a> +void&#160;</td><td class="memItemRight" valign="bottom"><b>_exit</b> (int status)</td></tr> +<tr class="separator:abc96bd69b58b2deaddb484478d911c1b"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a3ada001944b574974184d2377be0bec3" id="r_a3ada001944b574974184d2377be0bec3"><td class="memItemLeft" align="right" valign="top"><a id="a3ada001944b574974184d2377be0bec3" name="a3ada001944b574974184d2377be0bec3"></a> +void&#160;</td><td class="memItemRight" valign="bottom"><b>_kill</b> (int pid, int sig)</td></tr> +<tr class="separator:a3ada001944b574974184d2377be0bec3"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a0ebe0c689c80a2bca135fd157da50fbf" id="r_a0ebe0c689c80a2bca135fd157da50fbf"><td class="memItemLeft" align="right" valign="top"><a id="a0ebe0c689c80a2bca135fd157da50fbf" name="a0ebe0c689c80a2bca135fd157da50fbf"></a> +int&#160;</td><td class="memItemRight" valign="bottom"><b>_getpid</b> ()</td></tr> +<tr class="separator:a0ebe0c689c80a2bca135fd157da50fbf"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aa025a12d45f60c7d0eae249e61f0c7f9" id="r_aa025a12d45f60c7d0eae249e61f0c7f9"><td class="memItemLeft" align="right" valign="top"><a id="aa025a12d45f60c7d0eae249e61f0c7f9" name="aa025a12d45f60c7d0eae249e61f0c7f9"></a> +int&#160;</td><td class="memItemRight" valign="bottom"><b>_write</b> (int file, char *ptr, int len)</td></tr> +<tr class="separator:aa025a12d45f60c7d0eae249e61f0c7f9"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a4f9bf1e1602f2828e0a54e70c3b2dccb" id="r_a4f9bf1e1602f2828e0a54e70c3b2dccb"><td class="memItemLeft" align="right" valign="top"><a id="a4f9bf1e1602f2828e0a54e70c3b2dccb" name="a4f9bf1e1602f2828e0a54e70c3b2dccb"></a> +int&#160;</td><td class="memItemRight" valign="bottom"><b>_read</b> (int file, char *ptr, int len)</td></tr> +<tr class="separator:a4f9bf1e1602f2828e0a54e70c3b2dccb"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:adb34f735d9a9fc1e9d1acc68a6c05d8c" id="r_adb34f735d9a9fc1e9d1acc68a6c05d8c"><td class="memItemLeft" align="right" valign="top"><a id="adb34f735d9a9fc1e9d1acc68a6c05d8c" name="adb34f735d9a9fc1e9d1acc68a6c05d8c"></a> +int&#160;</td><td class="memItemRight" valign="bottom"><b>_gettimeofday</b> (struct timeval *tp, void *tzp)</td></tr> +<tr class="separator:adb34f735d9a9fc1e9d1acc68a6c05d8c"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table><table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="var-members" name="var-members"></a> +Variables</h2></td></tr> +<tr class="memitem:ad65a8842cc674e3ddf69355898c0ecbf" id="r_ad65a8842cc674e3ddf69355898c0ecbf"><td class="memItemLeft" align="right" valign="top"><a id="ad65a8842cc674e3ddf69355898c0ecbf" name="ad65a8842cc674e3ddf69355898c0ecbf"></a> +int&#160;</td><td class="memItemRight" valign="bottom"><b>errno</b></td></tr> +<tr class="separator:ad65a8842cc674e3ddf69355898c0ecbf"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a6be269d32d0f390e81b9b9e405ca3650" id="r_a6be269d32d0f390e81b9b9e405ca3650"><td class="memItemLeft" align="right" valign="top"><a id="a6be269d32d0f390e81b9b9e405ca3650" name="a6be269d32d0f390e81b9b9e405ca3650"></a> +const volatile unsigned int&#160;</td><td class="memItemRight" valign="bottom"><b>__crt0_main_exit</b></td></tr> +<tr class="separator:a6be269d32d0f390e81b9b9e405ca3650"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a0eaa3dcfb1db0c72534046feb9fa9b60" id="r_a0eaa3dcfb1db0c72534046feb9fa9b60"><td class="memItemLeft" align="right" valign="top"><a id="a0eaa3dcfb1db0c72534046feb9fa9b60" name="a0eaa3dcfb1db0c72534046feb9fa9b60"></a> +char&#160;</td><td class="memItemRight" valign="bottom"><b>__heap_start</b> []</td></tr> +<tr class="separator:a0eaa3dcfb1db0c72534046feb9fa9b60"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:ae6ef7c715931df8bdc331577da14119b" id="r_ae6ef7c715931df8bdc331577da14119b"><td class="memItemLeft" align="right" valign="top"><a id="ae6ef7c715931df8bdc331577da14119b" name="ae6ef7c715931df8bdc331577da14119b"></a> +char&#160;</td><td class="memItemRight" valign="bottom"><b>__heap_end</b> []</td></tr> +<tr class="separator:ae6ef7c715931df8bdc331577da14119b"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aaa2cb9e7075a852870fd67eff2861b18" id="r_aaa2cb9e7075a852870fd67eff2861b18"><td class="memItemLeft" align="right" valign="top"><a id="aaa2cb9e7075a852870fd67eff2861b18" name="aaa2cb9e7075a852870fd67eff2861b18"></a> +char&#160;</td><td class="memItemRight" valign="bottom"><b>__crt0_max_heap</b> []</td></tr> +<tr class="separator:aaa2cb9e7075a852870fd67eff2861b18"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>Newlib system calls. </p> +<dl class="section warning"><dt>Warning</dt><dd>UART0 (if available) is used to read/write console data (STDIN, STDOUT, STDERR, ...).</dd></dl> +<dl class="section note"><dt>Note</dt><dd>Original source file: <a href="https://github.com/openhwgroup/cv32e40p/blob/master/example_tb/core/custom/syscalls.c">https://github.com/openhwgroup/cv32e40p/blob/master/example_tb/core/custom/syscalls.c</a> </dd> +<dd> +More information was derived from: <a href="https://interrupt.memfault.com/blog/boostrapping-libc-with-newlib#implementing-newlib">https://interrupt.memfault.com/blog/boostrapping-libc-with-newlib#implementing-newlib</a></dd></dl> +<dl class="section see"><dt>See also</dt><dd><a href="https://stnolting.github.io/neorv32/sw/files.html">https://stnolting.github.io/neorv32/sw/files.html</a> </dd></dl> +</div></div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/tab_a.png b/sw/tab_a.png new file mode 100644 index 0000000000000000000000000000000000000000..3b725c41c5a527a3a3e40097077d0e206a681247 GIT binary patch literal 142 zcmeAS@N?(olHy`uVBq!ia0vp^j6kfy!2~3aiye;!QlXwMjv*C{Z|8b*H5dputLHD# z=<0|*y7z(Vor?d;H&?EG&cXR}?!j-Lm&u1OOI7AIF5&c)RFE;&p0MYK>*Kl@eiymD r@|NpwKX@^z+;{u_Z~trSBfrMKa%3`zocFjEXaR$#tDnm{r-UW|TZ1%4 literal 0 HcmV?d00001 diff --git a/sw/tab_ad.png b/sw/tab_ad.png new file mode 100644 index 0000000000000000000000000000000000000000..e34850acfc24be58da6d2fd1ccc6b29cc84fe34d GIT binary patch literal 135 zcmeAS@N?(olHy`uVBq!ia0vp^j6kfy!2~3aiye;!QhuH;jv*C{Z|5d*H3V=pKi{In zd2jxLclDRPylmD}^l7{QOtL{vUjO{-WqItb5sQp2h-99b8^^Scr-=2mblCdZuUm?4 jzOJvgvt3{(cjKLW5(A@0qPS@<&}0TrS3j3^P6<r_{TVK| literal 0 HcmV?d00001 diff --git a/sw/tab_b.png b/sw/tab_b.png new file mode 100644 index 0000000000000000000000000000000000000000..e2b4a8638cb3496a016eaed9e16ffc12846dea18 GIT binary patch literal 169 zcmeAS@N?(olHy`uVBq!ia0vp^j6kfy!2~3aiye;!QU#tajv*C{Z}0l@H7kg?K0Lnr z!j&C6_(~HV9oQ0Pa6x{-v0AGV_E?vLn<f<Rf3mJ=+uzfrOMlc%s`x4TZtnrR|B~W{ zyZP0m7vvtXV80W5^J2vvp97)4WrPK1-P<H^B$Ll|TGvzm;+92|BpdT89$b1Qf7x5g UZ&RH}7SL`6Pgg&ebxsLQ0A}n&iU0rr literal 0 HcmV?d00001 diff --git a/sw/tab_bd.png b/sw/tab_bd.png new file mode 100644 index 0000000000000000000000000000000000000000..91c25249869ffe5269c24f8c441e3f1bf75df400 GIT binary patch literal 173 zcmeAS@N?(olHy`uVBq!ia0vp^j6kfy!2~3aiye;!QYD@)jv*C{Z|_EP9WoGMxiEXC z*+er<&!~9SeFB;qdWZkM*Qnb6=Y<v@&*3w2PyYNmP%60gwdFMP&wo;^^nBV|3(M2* z*jxC7^WBy{T+w*t)CB)8J1;C}`Wg1Eu&qNNCxPc5OM{{Il5M+!8{(pt&)hOwq4#ZF XiX*3<piHC_(0&F_S3j3^P6<r_`0_!v literal 0 HcmV?d00001 diff --git a/sw/tab_h.png b/sw/tab_h.png new file mode 100644 index 0000000000000000000000000000000000000000..fd5cb705488e60fcf30f56fcc951dee74f3b095b GIT binary patch literal 177 zcmeAS@N?(olHy`uVBq!ia0vp^j6kfy!2~3aiye;!QWc&qjv*C{Z}0jF9dr<AdpNI7 zaOs_6=O($9b?lc?Qk=SJVv5%FA{O^TY1^*qJ@<p}E}!uH_1eoPJ&tpVl={bg{Skd2 zp1FO|;|R90%G3WYZM5AU=A4%H?3qaQhHt%H9G|xYJ)ff*|MmI*zD3`*Z|LP?7d&26 cn!ZiLK0QM$CeyB_80ZEDPgg&ebxsLQ0C?O;!~g&Q literal 0 HcmV?d00001 diff --git a/sw/tab_hd.png b/sw/tab_hd.png new file mode 100644 index 0000000000000000000000000000000000000000..2489273d4ce1d11d3f7557335244c02b9959351b GIT binary patch literal 180 zcmeAS@N?(olHy`uVBq!ia0vp^j6kfy!2~3aiye;!Qq`U=jv*C{Z|8b*9dZzG*}eKq zLz7a+10_jMu|=F8x0f5va$Ursw|7c<-`q2fuRgxI>y&q2{!U5bk+Tso_B!YCpDh>v z{CM*1U8YvQRyBUHt^Ju0W_sq-?;9@_4equ-bavTs=gk796<RKfbH6P<&Zg{jpvTk5 g<odruKTrK<y!3{DoqTGTH_#ajp00i_>zopr0EBT&m;e9( literal 0 HcmV?d00001 diff --git a/sw/tab_s.png b/sw/tab_s.png new file mode 100644 index 0000000000000000000000000000000000000000..ab478c95b67371d700a20869f7de1ddd73522d50 GIT binary patch literal 184 zcmeAS@N?(olHy`uVBq!ia0vp^j6kfy!2~3aiye;!QuUrLjv*C{Z|^p8HaRdjTwH7) zC?wLlL}}I{)n%R&r+1}IGmDnq;&J#%V6)9VsYhS`O^BVBQlxOUep0c$RENLq#g8A$ z)z7%K_bI&n@J+X_=x}fJoEKed-$<>=ZI-;YrdjIl`U`uzuDWSP?o#Dmo{%SgM#oan kX~E1%D-|#H#QbHoIja2U-MgvsK&LQxy85}Sb4q9e0Efg%P5=M^ literal 0 HcmV?d00001 diff --git a/sw/tab_sd.png b/sw/tab_sd.png new file mode 100644 index 0000000000000000000000000000000000000000..757a565ced4730f85c833fb2547d8e199ae68f19 GIT binary patch literal 188 zcmeAS@N?(olHy`uVBq!ia0vp^j6kfy!2~3aiye;!Qq7(&jv*C{Z|_!fH5o7*c=%9% zcILh!EA=pAQKdx-Cdiev=v{eg{8Ht<{e8_NAN~b=)%W>-WDCE0PyDHGemi$BoXwcK z{>e9^za6*c1ilttWw&V+U;WCPlV9{LdC~Ey%_H(qj`xgfES(4Yz5jSTZfCt`<jkg7 oB>4E$0YRsR*S^mTCR^;V&sxC8{l_Cp7w8-YPgg&ebxsLQ00$vXK>z>% literal 0 HcmV?d00001 diff --git a/sw/tabs.css b/sw/tabs.css new file mode 100644 index 0000000000..fe4854aa50 --- /dev/null +++ b/sw/tabs.css @@ -0,0 +1 @@ +.sm{position:relative;z-index:9999}.sm,.sm ul,.sm li{display:block;list-style:none;margin:0;padding:0;line-height:normal;direction:ltr;text-align:left;-webkit-tap-highlight-color:rgba(0,0,0,0)}.sm-rtl,.sm-rtl ul,.sm-rtl li{direction:rtl;text-align:right}.sm>li>h1,.sm>li>h2,.sm>li>h3,.sm>li>h4,.sm>li>h5,.sm>li>h6{margin:0;padding:0}.sm ul{display:none}.sm li,.sm a{position:relative}.sm a{display:block}.sm a.disabled{cursor:not-allowed}.sm:after{content:"\00a0";display:block;height:0;font:0/0 serif;clear:both;visibility:hidden;overflow:hidden}.sm,.sm *,.sm *:before,.sm *:after{-moz-box-sizing:border-box;-webkit-box-sizing:border-box;box-sizing:border-box}.main-menu-btn{position:relative;display:inline-block;width:36px;height:36px;text-indent:36px;margin-left:8px;white-space:nowrap;overflow:hidden;cursor:pointer;-webkit-tap-highlight-color:rgba(0,0,0,0)}.main-menu-btn-icon,.main-menu-btn-icon:before,.main-menu-btn-icon:after{position:absolute;top:50%;left:2px;height:2px;width:24px;background:var(--nav-menu-button-color);-webkit-transition:all .25s;transition:all .25s}.main-menu-btn-icon:before{content:'';top:-7px;left:0}.main-menu-btn-icon:after{content:'';top:7px;left:0}#main-menu-state:checked ~ .main-menu-btn .main-menu-btn-icon{height:0}#main-menu-state:checked ~ .main-menu-btn .main-menu-btn-icon:before{top:0;-webkit-transform:rotate(-45deg);transform:rotate(-45deg)}#main-menu-state:checked ~ .main-menu-btn .main-menu-btn-icon:after{top:0;-webkit-transform:rotate(45deg);transform:rotate(45deg)}#main-menu-state{position:absolute;width:1px;height:1px;margin:-1px;border:0;padding:0;overflow:hidden;clip:rect(1px,1px,1px,1px)}#main-menu-state:not(:checked) ~ #main-menu{display:none}#main-menu-state:checked ~ #main-menu{display:block}@media(min-width:768px){.main-menu-btn{position:absolute;top:-99999px}#main-menu-state:not(:checked) ~ #main-menu{display:block}}.sm-dox{background-image:var(--nav-gradient-image)}.sm-dox a,.sm-dox a:focus,.sm-dox a:hover,.sm-dox a:active{padding:0 12px;padding-right:43px;font-family:var(--font-family-nav);font-size:13px;font-weight:bold;line-height:36px;text-decoration:none;text-shadow:var(--nav-text-normal-shadow);color:var(--nav-text-normal-color);outline:0}.sm-dox a:hover{background-image:var(--nav-gradient-active-image);background-repeat:repeat-x;color:var(--nav-text-hover-color);text-shadow:var(--nav-text-hover-shadow)}.sm-dox a.current{color:#d23600}.sm-dox a.disabled{color:#bbb}.sm-dox a span.sub-arrow{position:absolute;top:50%;margin-top:-14px;left:auto;right:3px;width:28px;height:28px;overflow:hidden;font:bold 12px/28px monospace !important;text-align:center;text-shadow:none;background:var(--nav-menu-toggle-color);-moz-border-radius:5px;-webkit-border-radius:5px;border-radius:5px}.sm-dox a span.sub-arrow:before{display:block;content:'+'}.sm-dox a.highlighted span.sub-arrow:before{display:block;content:'-'}.sm-dox>li:first-child>a,.sm-dox>li:first-child>:not(ul) a{-moz-border-radius:5px 5px 0 0;-webkit-border-radius:5px;border-radius:5px 5px 0 0}.sm-dox>li:last-child>a,.sm-dox>li:last-child>*:not(ul) a,.sm-dox>li:last-child>ul,.sm-dox>li:last-child>ul>li:last-child>a,.sm-dox>li:last-child>ul>li:last-child>*:not(ul) a,.sm-dox>li:last-child>ul>li:last-child>ul,.sm-dox>li:last-child>ul>li:last-child>ul>li:last-child>a,.sm-dox>li:last-child>ul>li:last-child>ul>li:last-child>*:not(ul) a,.sm-dox>li:last-child>ul>li:last-child>ul>li:last-child>ul,.sm-dox>li:last-child>ul>li:last-child>ul>li:last-child>ul>li:last-child>a,.sm-dox>li:last-child>ul>li:last-child>ul>li:last-child>ul>li:last-child>*:not(ul) a,.sm-dox>li:last-child>ul>li:last-child>ul>li:last-child>ul>li:last-child>ul,.sm-dox>li:last-child>ul>li:last-child>ul>li:last-child>ul>li:last-child>ul>li:last-child>a,.sm-dox>li:last-child>ul>li:last-child>ul>li:last-child>ul>li:last-child>ul>li:last-child>*:not(ul) a,.sm-dox>li:last-child>ul>li:last-child>ul>li:last-child>ul>li:last-child>ul>li:last-child>ul{-moz-border-radius:0 0 5px 5px;-webkit-border-radius:0;border-radius:0 0 5px 5px}.sm-dox>li:last-child>a.highlighted,.sm-dox>li:last-child>*:not(ul) a.highlighted,.sm-dox>li:last-child>ul>li:last-child>a.highlighted,.sm-dox>li:last-child>ul>li:last-child>*:not(ul) a.highlighted,.sm-dox>li:last-child>ul>li:last-child>ul>li:last-child>a.highlighted,.sm-dox>li:last-child>ul>li:last-child>ul>li:last-child>*:not(ul) a.highlighted,.sm-dox>li:last-child>ul>li:last-child>ul>li:last-child>ul>li:last-child>a.highlighted,.sm-dox>li:last-child>ul>li:last-child>ul>li:last-child>ul>li:last-child>*:not(ul) a.highlighted,.sm-dox>li:last-child>ul>li:last-child>ul>li:last-child>ul>li:last-child>ul>li:last-child>a.highlighted,.sm-dox>li:last-child>ul>li:last-child>ul>li:last-child>ul>li:last-child>ul>li:last-child>*:not(ul) a.highlighted{-moz-border-radius:0;-webkit-border-radius:0;border-radius:0}.sm-dox ul{background:var(--nav-menu-background-color)}.sm-dox ul a,.sm-dox ul a:focus,.sm-dox ul a:hover,.sm-dox ul a:active{font-size:12px;border-left:8px solid transparent;line-height:36px;text-shadow:none;background-color:var(--nav-menu-background-color);background-image:none}.sm-dox ul a:hover{background-image:var(--nav-gradient-active-image);background-repeat:repeat-x;color:var(--nav-text-hover-color);text-shadow:0 1px 1px black}.sm-dox ul ul a,.sm-dox ul ul a:hover,.sm-dox ul ul a:focus,.sm-dox ul ul a:active{border-left:16px solid transparent}.sm-dox ul ul ul a,.sm-dox ul ul ul a:hover,.sm-dox ul ul ul a:focus,.sm-dox ul ul ul a:active{border-left:24px solid transparent}.sm-dox ul ul ul ul a,.sm-dox ul ul ul ul a:hover,.sm-dox ul ul ul ul a:focus,.sm-dox ul ul ul ul a:active{border-left:32px solid transparent}.sm-dox ul ul ul ul ul a,.sm-dox ul ul ul ul ul a:hover,.sm-dox ul ul ul ul ul a:focus,.sm-dox ul ul ul ul ul a:active{border-left:40px solid transparent}@media(min-width:768px){.sm-dox ul{position:absolute;width:12em}.sm-dox li{float:left}.sm-dox.sm-rtl li{float:right}.sm-dox ul li,.sm-dox.sm-rtl ul li,.sm-dox.sm-vertical li{float:none}.sm-dox a{white-space:nowrap}.sm-dox ul a,.sm-dox.sm-vertical a{white-space:normal}.sm-dox .sm-nowrap>li>a,.sm-dox .sm-nowrap>li>:not(ul) a{white-space:nowrap}.sm-dox{padding:0 10px;background-image:var(--nav-gradient-image);line-height:36px}.sm-dox a span.sub-arrow{top:50%;margin-top:-2px;right:12px;width:0;height:0;border-width:4px;border-style:solid dashed dashed dashed;border-color:var(--nav-text-normal-color) transparent transparent transparent;background:transparent;-moz-border-radius:0;-webkit-border-radius:0;border-radius:0}.sm-dox a,.sm-dox a:focus,.sm-dox a:active,.sm-dox a:hover,.sm-dox a.highlighted{padding:0 12px;background-image:var(--nav-separator-image);background-repeat:no-repeat;background-position:right;-moz-border-radius:0 !important;-webkit-border-radius:0;border-radius:0 !important}.sm-dox a:hover{background-image:var(--nav-gradient-active-image);background-repeat:repeat-x;color:var(--nav-text-hover-color);text-shadow:var(--nav-text-hover-shadow)}.sm-dox a:hover span.sub-arrow{border-color:var(--nav-text-hover-color) transparent transparent transparent}.sm-dox a.has-submenu{padding-right:24px}.sm-dox li{border-top:0}.sm-dox>li>ul:before,.sm-dox>li>ul:after{content:'';position:absolute;top:-18px;left:30px;width:0;height:0;overflow:hidden;border-width:9px;border-style:dashed dashed solid dashed;border-color:transparent transparent #bbb transparent}.sm-dox>li>ul:after{top:-16px;left:31px;border-width:8px;border-color:transparent transparent var(--nav-menu-background-color) transparent}.sm-dox ul{border:1px solid #bbb;padding:5px 0;background:var(--nav-menu-background-color);-moz-border-radius:5px !important;-webkit-border-radius:5px;border-radius:5px !important;-moz-box-shadow:0 5px 9px rgba(0,0,0,0.2);-webkit-box-shadow:0 5px 9px rgba(0,0,0,0.2);box-shadow:0 5px 9px rgba(0,0,0,0.2)}.sm-dox ul a span.sub-arrow{right:8px;top:50%;margin-top:-5px;border-width:5px;border-color:transparent transparent transparent var(--nav-menu-foreground-color);border-style:dashed dashed dashed solid}.sm-dox ul a,.sm-dox ul a:hover,.sm-dox ul a:focus,.sm-dox ul a:active,.sm-dox ul a.highlighted{color:var(--nav-menu-foreground-color);background-image:none;border:0 !important}.sm-dox ul a:hover{background-image:var(--nav-gradient-active-image);background-repeat:repeat-x;color:var(--nav-text-hover-color);text-shadow:var(--nav-text-hover-shadow)}.sm-dox ul a:hover span.sub-arrow{border-color:transparent transparent transparent var(--nav-text-hover-color)}.sm-dox span.scroll-up,.sm-dox span.scroll-down{position:absolute;display:none;visibility:hidden;overflow:hidden;background:var(--nav-menu-background-color);height:36px}.sm-dox span.scroll-up:hover,.sm-dox span.scroll-down:hover{background:#eee}.sm-dox span.scroll-up:hover span.scroll-up-arrow,.sm-dox span.scroll-up:hover span.scroll-down-arrow{border-color:transparent transparent #d23600 transparent}.sm-dox span.scroll-down:hover span.scroll-down-arrow{border-color:#d23600 transparent transparent transparent}.sm-dox span.scroll-up-arrow,.sm-dox span.scroll-down-arrow{position:absolute;top:0;left:50%;margin-left:-6px;width:0;height:0;overflow:hidden;border-width:6px;border-style:dashed dashed solid dashed;border-color:transparent transparent var(--nav-menu-foreground-color) transparent}.sm-dox span.scroll-down-arrow{top:8px;border-style:solid dashed dashed dashed;border-color:var(--nav-menu-foreground-color) transparent transparent transparent}.sm-dox.sm-rtl a.has-submenu{padding-right:12px;padding-left:24px}.sm-dox.sm-rtl a span.sub-arrow{right:auto;left:12px}.sm-dox.sm-rtl.sm-vertical a.has-submenu{padding:10px 20px}.sm-dox.sm-rtl.sm-vertical a span.sub-arrow{right:auto;left:8px;border-style:dashed solid dashed dashed;border-color:transparent #555 transparent transparent}.sm-dox.sm-rtl>li>ul:before{left:auto;right:30px}.sm-dox.sm-rtl>li>ul:after{left:auto;right:31px}.sm-dox.sm-rtl ul a.has-submenu{padding:10px 20px !important}.sm-dox.sm-rtl ul a span.sub-arrow{right:auto;left:8px;border-style:dashed solid dashed dashed;border-color:transparent #555 transparent transparent}.sm-dox.sm-vertical{padding:10px 0;-moz-border-radius:5px;-webkit-border-radius:5px;border-radius:5px}.sm-dox.sm-vertical a{padding:10px 20px}.sm-dox.sm-vertical a:hover,.sm-dox.sm-vertical a:focus,.sm-dox.sm-vertical a:active,.sm-dox.sm-vertical a.highlighted{background:#fff}.sm-dox.sm-vertical a.disabled{background-image:var(--nav-gradient-image)}.sm-dox.sm-vertical a span.sub-arrow{right:8px;top:50%;margin-top:-5px;border-width:5px;border-style:dashed dashed dashed solid;border-color:transparent transparent transparent #555}.sm-dox.sm-vertical>li>ul:before,.sm-dox.sm-vertical>li>ul:after{display:none}.sm-dox.sm-vertical ul a{padding:10px 20px}.sm-dox.sm-vertical ul a:hover,.sm-dox.sm-vertical ul a:focus,.sm-dox.sm-vertical ul a:active,.sm-dox.sm-vertical ul a.highlighted{background:#eee}.sm-dox.sm-vertical ul a.disabled{background:var(--nav-menu-background-color)}} \ No newline at end of file diff --git a/sw/unionfloat__conv__t.html b/sw/unionfloat__conv__t.html new file mode 100644 index 0000000000..141f1bc799 --- /dev/null +++ b/sw/unionfloat__conv__t.html @@ -0,0 +1,148 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: float_conv_t Union Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#pub-attribs">Data Fields</a> </div> + <div class="headertitle"><div class="title">float_conv_t Union Reference</div></div> +</div><!--header--> +<div class="contents"> + +<p><code>#include &lt;<a class="el" href="float__corner__test_2neorv32__zfinx__extension__intrinsics_8h_source.html">neorv32_zfinx_extension_intrinsics.h</a>&gt;</code></p> +<table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="pub-attribs" name="pub-attribs"></a> +Data Fields</h2></td></tr> +<tr class="memitem:a59ad19d41b1d973a6bda9032e1937606" id="r_a59ad19d41b1d973a6bda9032e1937606"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a59ad19d41b1d973a6bda9032e1937606">binary_value</a></td></tr> +<tr class="separator:a59ad19d41b1d973a6bda9032e1937606"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a95f2e38b437bd8d4e8de7f61d7474788" id="r_a95f2e38b437bd8d4e8de7f61d7474788"><td class="memItemLeft" align="right" valign="top">float&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="#a95f2e38b437bd8d4e8de7f61d7474788">float_value</a></td></tr> +<tr class="separator:a95f2e38b437bd8d4e8de7f61d7474788"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2> +<div class="textblock"><p>Sanity check Custom data type to access floating-point values as native floats and in binary representation </p> +</div><h2 class="groupheader">Field Documentation</h2> +<a id="a59ad19d41b1d973a6bda9032e1937606" name="a59ad19d41b1d973a6bda9032e1937606"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a59ad19d41b1d973a6bda9032e1937606">&#9670;&#160;</a></span>binary_value</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">uint32_t float_conv_t::binary_value</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Access as native float </p> + +</div> +</div> +<a id="a95f2e38b437bd8d4e8de7f61d7474788" name="a95f2e38b437bd8d4e8de7f61d7474788"></a> +<h2 class="memtitle"><span class="permalink"><a href="#a95f2e38b437bd8d4e8de7f61d7474788">&#9670;&#160;</a></span>float_value</h2> + +<div class="memitem"> +<div class="memproto"> + <table class="memname"> + <tr> + <td class="memname">float float_conv_t::float_value</td> + </tr> + </table> +</div><div class="memdoc"> +<p>Access in binary representation </p> + +</div> +</div> +<hr/>The documentation for this union was generated from the following files:<ul> +<li>sw/example/float_corner_test/<a class="el" href="float__corner__test_2neorv32__zfinx__extension__intrinsics_8h_source.html">neorv32_zfinx_extension_intrinsics.h</a></li> +<li>sw/example/floating_point_test/<a class="el" href="floating__point__test_2neorv32__zfinx__extension__intrinsics_8h_source.html">neorv32_zfinx_extension_intrinsics.h</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/unionsubwords16__t.html b/sw/unionsubwords16__t.html new file mode 100644 index 0000000000..de4beb4d50 --- /dev/null +++ b/sw/unionsubwords16__t.html @@ -0,0 +1,114 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: subwords16_t Union Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#pub-attribs">Data Fields</a> </div> + <div class="headertitle"><div class="title">subwords16_t Union Reference</div></div> +</div><!--header--> +<div class="contents"> +<table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="pub-attribs" name="pub-attribs"></a> +Data Fields</h2></td></tr> +<tr class="memitem:af3542fb53e1cf8cf51043e17123a5955" id="r_af3542fb53e1cf8cf51043e17123a5955"><td class="memItemLeft" align="right" valign="top"><a id="af3542fb53e1cf8cf51043e17123a5955" name="af3542fb53e1cf8cf51043e17123a5955"></a> +uint16_t&#160;</td><td class="memItemRight" valign="bottom"><b>uint16</b> [sizeof(uint16_t)/sizeof(uint16_t)]</td></tr> +<tr class="separator:af3542fb53e1cf8cf51043e17123a5955"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a59531d2a833b3d540767c7fdd085a6d5" id="r_a59531d2a833b3d540767c7fdd085a6d5"><td class="memItemLeft" align="right" valign="top"><a id="a59531d2a833b3d540767c7fdd085a6d5" name="a59531d2a833b3d540767c7fdd085a6d5"></a> +uint8_t&#160;</td><td class="memItemRight" valign="bottom"><b>uint8</b> [sizeof(uint16_t)/sizeof(uint8_t)]</td></tr> +<tr class="separator:a59531d2a833b3d540767c7fdd085a6d5"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<hr/>The documentation for this union was generated from the following file:<ul> +<li>sw/lib/include/<a class="el" href="neorv32_8h_source.html">neorv32.h</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/unionsubwords32__t.html b/sw/unionsubwords32__t.html new file mode 100644 index 0000000000..7cbf879d56 --- /dev/null +++ b/sw/unionsubwords32__t.html @@ -0,0 +1,117 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: subwords32_t Union Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#pub-attribs">Data Fields</a> </div> + <div class="headertitle"><div class="title">subwords32_t Union Reference</div></div> +</div><!--header--> +<div class="contents"> +<table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="pub-attribs" name="pub-attribs"></a> +Data Fields</h2></td></tr> +<tr class="memitem:ae0842804ca9f19b2a295db3d978d1383" id="r_ae0842804ca9f19b2a295db3d978d1383"><td class="memItemLeft" align="right" valign="top"><a id="ae0842804ca9f19b2a295db3d978d1383" name="ae0842804ca9f19b2a295db3d978d1383"></a> +uint32_t&#160;</td><td class="memItemRight" valign="bottom"><b>uint32</b> [sizeof(uint32_t)/sizeof(uint32_t)]</td></tr> +<tr class="separator:ae0842804ca9f19b2a295db3d978d1383"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a4e7b238df02515aa6624102e209d7ff6" id="r_a4e7b238df02515aa6624102e209d7ff6"><td class="memItemLeft" align="right" valign="top"><a id="a4e7b238df02515aa6624102e209d7ff6" name="a4e7b238df02515aa6624102e209d7ff6"></a> +uint16_t&#160;</td><td class="memItemRight" valign="bottom"><b>uint16</b> [sizeof(uint32_t)/sizeof(uint16_t)]</td></tr> +<tr class="separator:a4e7b238df02515aa6624102e209d7ff6"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:aeb3242ba9fc1e3a49116465ce7a4239b" id="r_aeb3242ba9fc1e3a49116465ce7a4239b"><td class="memItemLeft" align="right" valign="top"><a id="aeb3242ba9fc1e3a49116465ce7a4239b" name="aeb3242ba9fc1e3a49116465ce7a4239b"></a> +uint8_t&#160;</td><td class="memItemRight" valign="bottom"><b>uint8</b> [sizeof(uint32_t)/sizeof(uint8_t)]</td></tr> +<tr class="separator:aeb3242ba9fc1e3a49116465ce7a4239b"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<hr/>The documentation for this union was generated from the following file:<ul> +<li>sw/lib/include/<a class="el" href="neorv32_8h_source.html">neorv32.h</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/sw/unionsubwords64__t.html b/sw/unionsubwords64__t.html new file mode 100644 index 0000000000..57fff312ce --- /dev/null +++ b/sw/unionsubwords64__t.html @@ -0,0 +1,120 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US"> +<head> +<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> +<meta http-equiv="X-UA-Compatible" content="IE=11"/> +<meta name="generator" content="Doxygen 1.11.0"/> +<meta name="viewport" content="width=device-width, initial-scale=1"/> +<title>NEORV32 Software Framework Documentation: subwords64_t Union Reference</title> +<link href="tabs.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="jquery.js"></script> +<script type="text/javascript" src="dynsections.js"></script> +<script type="text/javascript" src="clipboard.js"></script> +<link href="navtree.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="resize.js"></script> +<script type="text/javascript" src="cookie.js"></script> +<link href="search/search.css" rel="stylesheet" type="text/css"/> +<script type="text/javascript" src="search/searchdata.js"></script> +<script type="text/javascript" src="search/search.js"></script> +<link href="doxygen.css" rel="stylesheet" type="text/css" /> +</head> +<body> +<div id="top"><!-- do not remove this div, it is closed by doxygen! --> +<div id="titlearea"> +<table cellspacing="0" cellpadding="0"> + <tbody> + <tr id="projectrow"> + <td id="projectlogo"><img alt="Logo" src="neorv32_logo_small.png"/></td> + <td id="projectalign"> + <div id="projectname">NEORV32 Software Framework Documentation + </div> + <div id="projectbrief">The NEORV32 RISC-V Processor</div> + </td> + </tr> + </tbody> +</table> +</div> +<!-- end header part --> +<!-- Generated by Doxygen 1.11.0 --> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +var searchBox = new SearchBox("searchBox", "search/",'.html'); +/* @license-end */ +</script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { codefold.init(0); }); +/* @license-end */ +</script> +<script type="text/javascript" src="menudata.js"></script> +<script type="text/javascript" src="menu.js"></script> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function() { + initMenu('',true,false,'search.php','Search',false); + $(function() { init_search(); }); +}); +/* @license-end */ +</script> +<div id="main-nav"></div> +<script type="text/javascript"> +/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&amp;dn=expat.txt MIT */ +$(function(){ initResizable(false); }); +/* @license-end */ +</script> +<!-- window showing the filter options --> +<div id="MSearchSelectWindow" + onmouseover="return searchBox.OnSearchSelectShow()" + onmouseout="return searchBox.OnSearchSelectHide()" + onkeydown="return searchBox.OnSearchSelectKey(event)"> +</div> + +<!-- iframe showing the search results (closed by default) --> +<div id="MSearchResultsWindow"> +<div id="MSearchResults"> +<div class="SRPage"> +<div id="SRIndex"> +<div id="SRResults"></div> +<div class="SRStatus" id="Loading">Loading...</div> +<div class="SRStatus" id="Searching">Searching...</div> +<div class="SRStatus" id="NoMatches">No Matches</div> +</div> +</div> +</div> +</div> + +</div><!-- top --> +<div id="doc-content"> +<div class="header"> + <div class="summary"> +<a href="#pub-attribs">Data Fields</a> </div> + <div class="headertitle"><div class="title">subwords64_t Union Reference</div></div> +</div><!--header--> +<div class="contents"> +<table class="memberdecls"> +<tr class="heading"><td colspan="2"><h2 class="groupheader"><a id="pub-attribs" name="pub-attribs"></a> +Data Fields</h2></td></tr> +<tr class="memitem:a7c97aa749bdf861b0e540cc39256338c" id="r_a7c97aa749bdf861b0e540cc39256338c"><td class="memItemLeft" align="right" valign="top"><a id="a7c97aa749bdf861b0e540cc39256338c" name="a7c97aa749bdf861b0e540cc39256338c"></a> +uint64_t&#160;</td><td class="memItemRight" valign="bottom"><b>uint64</b></td></tr> +<tr class="separator:a7c97aa749bdf861b0e540cc39256338c"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a5d33f089b353a7770bd9cf77bc37dc29" id="r_a5d33f089b353a7770bd9cf77bc37dc29"><td class="memItemLeft" align="right" valign="top"><a id="a5d33f089b353a7770bd9cf77bc37dc29" name="a5d33f089b353a7770bd9cf77bc37dc29"></a> +uint32_t&#160;</td><td class="memItemRight" valign="bottom"><b>uint32</b> [sizeof(uint64_t)/sizeof(uint32_t)]</td></tr> +<tr class="separator:a5d33f089b353a7770bd9cf77bc37dc29"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a7879c29bae9e9fb59e9bc0bba632100d" id="r_a7879c29bae9e9fb59e9bc0bba632100d"><td class="memItemLeft" align="right" valign="top"><a id="a7879c29bae9e9fb59e9bc0bba632100d" name="a7879c29bae9e9fb59e9bc0bba632100d"></a> +uint16_t&#160;</td><td class="memItemRight" valign="bottom"><b>uint16</b> [sizeof(uint64_t)/sizeof(uint16_t)]</td></tr> +<tr class="separator:a7879c29bae9e9fb59e9bc0bba632100d"><td class="memSeparator" colspan="2">&#160;</td></tr> +<tr class="memitem:a2438964f074b260fa577d90de754c6f9" id="r_a2438964f074b260fa577d90de754c6f9"><td class="memItemLeft" align="right" valign="top"><a id="a2438964f074b260fa577d90de754c6f9" name="a2438964f074b260fa577d90de754c6f9"></a> +uint8_t&#160;</td><td class="memItemRight" valign="bottom"><b>uint8</b> [sizeof(uint64_t)/sizeof(uint8_t)]</td></tr> +<tr class="separator:a2438964f074b260fa577d90de754c6f9"><td class="memSeparator" colspan="2">&#160;</td></tr> +</table> +<hr/>The documentation for this union was generated from the following file:<ul> +<li>sw/lib/include/<a class="el" href="neorv32_8h_source.html">neorv32.h</a></li> +</ul> +</div><!-- contents --> +<!-- start footer part --> +<hr class="footer"/><address class="footer"><small> +Generated by&#160;<a href="https://www.doxygen.org/index.html"><img class="footer" src="doxygen.svg" width="104" height="31" alt="doxygen"/></a> 1.11.0 +</small></address> +</div><!-- doc-content --> +</body> +</html> diff --git a/ug/index.html b/ug/index.html new file mode 100644 index 0000000000..cf145fb26e --- /dev/null +++ b/ug/index.html @@ -0,0 +1,4828 @@ +<!DOCTYPE html> +<html lang="en"> +<head> +<meta charset="UTF-8"> +<meta http-equiv="X-UA-Compatible" content="IE=edge"> +<meta name="viewport" content="width=device-width, initial-scale=1.0"> +<meta name="generator" content="Asciidoctor 2.0.20"> +<meta name="description" content="A size-optimized, customizable and highly extensible MCU-class 32-bit RISC-V soft-core CPU and microcontroller-like SoC written in platform-independent VHDL."> +<meta name="keywords" content="neorv32, risc-v, riscv, rv32, fpga, soft-core, vhdl, microcontroller, cpu, soc, processor, gcc, openocd, gdb, verilog, rtl, asip, asic, safety"> +<link rel="icon" type="image/png" href="../img/icon.png"> +<title>[User Guide] The NEORV32 RISC-V Processor</title> +<link rel="stylesheet" href="https://fonts.googleapis.com/css?family=Open+Sans:300,300italic,400,400italic,600,600italic%7CNoto+Serif:400,400italic,700,700italic%7CDroid+Sans+Mono:400,700"> +<style> +/*! Asciidoctor default stylesheet | MIT License | https://asciidoctor.org */ +/* Uncomment the following line when using as a custom stylesheet */ +/* @import "https://fonts.googleapis.com/css?family=Open+Sans:300,300italic,400,400italic,600,600italic%7CNoto+Serif:400,400italic,700,700italic%7CDroid+Sans+Mono:400,700"; */ +html{font-family:sans-serif;-webkit-text-size-adjust:100%} +a{background:none} +a:focus{outline:thin dotted} +a:active,a:hover{outline:0} +h1{font-size:2em;margin:.67em 0} +b,strong{font-weight:bold} +abbr{font-size:.9em} +abbr[title]{cursor:help;border-bottom:1px dotted #dddddf;text-decoration:none} +dfn{font-style:italic} +hr{height:0} +mark{background:#ff0;color:#000} +code,kbd,pre,samp{font-family:monospace;font-size:1em} +pre{white-space:pre-wrap} +q{quotes:"\201C" "\201D" "\2018" "\2019"} +small{font-size:80%} +sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline} +sup{top:-.5em} +sub{bottom:-.25em} +img{border:0} +svg:not(:root){overflow:hidden} +figure{margin:0} +audio,video{display:inline-block} +audio:not([controls]){display:none;height:0} +fieldset{border:1px solid silver;margin:0 2px;padding:.35em .625em .75em} +legend{border:0;padding:0} +button,input,select,textarea{font-family:inherit;font-size:100%;margin:0} +button,input{line-height:normal} +button,select{text-transform:none} +button,html input[type=button],input[type=reset],input[type=submit]{-webkit-appearance:button;cursor:pointer} +button[disabled],html input[disabled]{cursor:default} +input[type=checkbox],input[type=radio]{padding:0} +button::-moz-focus-inner,input::-moz-focus-inner{border:0;padding:0} +textarea{overflow:auto;vertical-align:top} +table{border-collapse:collapse;border-spacing:0} +*,::before,::after{box-sizing:border-box} +html,body{font-size:100%} +body{background:#fff;color:rgba(0,0,0,.8);padding:0;margin:0;font-family:"Noto Serif","DejaVu Serif",serif;line-height:1;position:relative;cursor:auto;-moz-tab-size:4;-o-tab-size:4;tab-size:4;word-wrap:anywhere;-moz-osx-font-smoothing:grayscale;-webkit-font-smoothing:antialiased} +a:hover{cursor:pointer} +img,object,embed{max-width:100%;height:auto} +object,embed{height:100%} +img{-ms-interpolation-mode:bicubic} +.left{float:left!important} +.right{float:right!important} +.text-left{text-align:left!important} +.text-right{text-align:right!important} +.text-center{text-align:center!important} +.text-justify{text-align:justify!important} +.hide{display:none} +img,object,svg{display:inline-block;vertical-align:middle} +textarea{height:auto;min-height:50px} +select{width:100%} +.subheader,.admonitionblock td.content>.title,.audioblock>.title,.exampleblock>.title,.imageblock>.title,.listingblock>.title,.literalblock>.title,.stemblock>.title,.openblock>.title,.paragraph>.title,.quoteblock>.title,table.tableblock>.title,.verseblock>.title,.videoblock>.title,.dlist>.title,.olist>.title,.ulist>.title,.qlist>.title,.hdlist>.title{line-height:1.45;color:#7a2518;font-weight:400;margin-top:0;margin-bottom:.25em} +div,dl,dt,dd,ul,ol,li,h1,h2,h3,#toctitle,.sidebarblock>.content>.title,h4,h5,h6,pre,form,p,blockquote,th,td{margin:0;padding:0} +a{color:#2156a5;text-decoration:underline;line-height:inherit} +a:hover,a:focus{color:#1d4b8f} +a img{border:0} +p{line-height:1.6;margin-bottom:1.25em;text-rendering:optimizeLegibility} +p aside{font-size:.875em;line-height:1.35;font-style:italic} +h1,h2,h3,#toctitle,.sidebarblock>.content>.title,h4,h5,h6{font-family:"Open Sans","DejaVu Sans",sans-serif;font-weight:300;font-style:normal;color:#ba3925;text-rendering:optimizeLegibility;margin-top:1em;margin-bottom:.5em;line-height:1.0125em} +h1 small,h2 small,h3 small,#toctitle small,.sidebarblock>.content>.title small,h4 small,h5 small,h6 small{font-size:60%;color:#e99b8f;line-height:0} +h1{font-size:2.125em} +h2{font-size:1.6875em} +h3,#toctitle,.sidebarblock>.content>.title{font-size:1.375em} +h4,h5{font-size:1.125em} +h6{font-size:1em} +hr{border:solid #dddddf;border-width:1px 0 0;clear:both;margin:1.25em 0 1.1875em} +em,i{font-style:italic;line-height:inherit} +strong,b{font-weight:bold;line-height:inherit} +small{font-size:60%;line-height:inherit} +code{font-family:"Droid Sans Mono","DejaVu Sans Mono",monospace;font-weight:400;color:rgba(0,0,0,.9)} +ul,ol,dl{line-height:1.6;margin-bottom:1.25em;list-style-position:outside;font-family:inherit} +ul,ol{margin-left:1.5em} +ul li ul,ul li ol{margin-left:1.25em;margin-bottom:0} +ul.circle{list-style-type:circle} +ul.disc{list-style-type:disc} +ul.square{list-style-type:square} +ul.circle ul:not([class]),ul.disc ul:not([class]),ul.square ul:not([class]){list-style:inherit} +ol li ul,ol li ol{margin-left:1.25em;margin-bottom:0} +dl dt{margin-bottom:.3125em;font-weight:bold} +dl dd{margin-bottom:1.25em} +blockquote{margin:0 0 1.25em;padding:.5625em 1.25em 0 1.1875em;border-left:1px solid #ddd} +blockquote,blockquote p{line-height:1.6;color:rgba(0,0,0,.85)} +@media screen and (min-width:768px){h1,h2,h3,#toctitle,.sidebarblock>.content>.title,h4,h5,h6{line-height:1.2} +h1{font-size:2.75em} +h2{font-size:2.3125em} +h3,#toctitle,.sidebarblock>.content>.title{font-size:1.6875em} +h4{font-size:1.4375em}} +table{background:#fff;margin-bottom:1.25em;border:1px solid #dedede;word-wrap:normal} +table thead,table tfoot{background:#f7f8f7} +table thead tr th,table thead tr td,table tfoot tr th,table tfoot tr td{padding:.5em .625em .625em;font-size:inherit;color:rgba(0,0,0,.8);text-align:left} +table tr th,table tr td{padding:.5625em .625em;font-size:inherit;color:rgba(0,0,0,.8)} +table tr.even,table tr.alt{background:#f8f8f7} +table thead tr th,table tfoot tr th,table tbody tr td,table tr td,table tfoot tr td{line-height:1.6} +h1,h2,h3,#toctitle,.sidebarblock>.content>.title,h4,h5,h6{line-height:1.2;word-spacing:-.05em} +h1 strong,h2 strong,h3 strong,#toctitle strong,.sidebarblock>.content>.title strong,h4 strong,h5 strong,h6 strong{font-weight:400} +.center{margin-left:auto;margin-right:auto} +.stretch{width:100%} +.clearfix::before,.clearfix::after,.float-group::before,.float-group::after{content:" ";display:table} +.clearfix::after,.float-group::after{clear:both} +:not(pre).nobreak{word-wrap:normal} +:not(pre).nowrap{white-space:nowrap} +:not(pre).pre-wrap{white-space:pre-wrap} +:not(pre):not([class^=L])>code{font-size:.9375em;font-style:normal!important;letter-spacing:0;padding:.1em .5ex;word-spacing:-.15em;background:#f7f7f8;border-radius:4px;line-height:1.45;text-rendering:optimizeSpeed} +pre{color:rgba(0,0,0,.9);font-family:"Droid Sans Mono","DejaVu Sans Mono",monospace;line-height:1.45;text-rendering:optimizeSpeed} +pre code,pre pre{color:inherit;font-size:inherit;line-height:inherit} +pre>code{display:block} +pre.nowrap,pre.nowrap pre{white-space:pre;word-wrap:normal} +em em{font-style:normal} +strong strong{font-weight:400} +.keyseq{color:rgba(51,51,51,.8)} +kbd{font-family:"Droid Sans Mono","DejaVu Sans Mono",monospace;display:inline-block;color:rgba(0,0,0,.8);font-size:.65em;line-height:1.45;background:#f7f7f7;border:1px solid #ccc;border-radius:3px;box-shadow:0 1px 0 rgba(0,0,0,.2),inset 0 0 0 .1em #fff;margin:0 .15em;padding:.2em .5em;vertical-align:middle;position:relative;top:-.1em;white-space:nowrap} +.keyseq kbd:first-child{margin-left:0} +.keyseq kbd:last-child{margin-right:0} +.menuseq,.menuref{color:#000} +.menuseq b:not(.caret),.menuref{font-weight:inherit} +.menuseq{word-spacing:-.02em} +.menuseq b.caret{font-size:1.25em;line-height:.8} +.menuseq i.caret{font-weight:bold;text-align:center;width:.45em} +b.button::before,b.button::after{position:relative;top:-1px;font-weight:400} +b.button::before{content:"[";padding:0 3px 0 2px} +b.button::after{content:"]";padding:0 2px 0 3px} +p a>code:hover{color:rgba(0,0,0,.9)} +#header,#content,#footnotes,#footer{width:100%;margin:0 auto;max-width:62.5em;*zoom:1;position:relative;padding-left:.9375em;padding-right:.9375em} +#header::before,#header::after,#content::before,#content::after,#footnotes::before,#footnotes::after,#footer::before,#footer::after{content:" ";display:table} +#header::after,#content::after,#footnotes::after,#footer::after{clear:both} +#content{margin-top:1.25em} +#content::before{content:none} +#header>h1:first-child{color:rgba(0,0,0,.85);margin-top:2.25rem;margin-bottom:0} +#header>h1:first-child+#toc{margin-top:8px;border-top:1px solid #dddddf} +#header>h1:only-child,body.toc2 #header>h1:nth-last-child(2){border-bottom:1px solid #dddddf;padding-bottom:8px} +#header .details{border-bottom:1px solid #dddddf;line-height:1.45;padding-top:.25em;padding-bottom:.25em;padding-left:.25em;color:rgba(0,0,0,.6);display:flex;flex-flow:row wrap} +#header .details span:first-child{margin-left:-.125em} +#header .details span.email a{color:rgba(0,0,0,.85)} +#header .details br{display:none} +#header .details br+span::before{content:"\00a0\2013\00a0"} +#header .details br+span.author::before{content:"\00a0\22c5\00a0";color:rgba(0,0,0,.85)} +#header .details br+span#revremark::before{content:"\00a0|\00a0"} +#header #revnumber{text-transform:capitalize} +#header #revnumber::after{content:"\00a0"} +#content>h1:first-child:not([class]){color:rgba(0,0,0,.85);border-bottom:1px solid #dddddf;padding-bottom:8px;margin-top:0;padding-top:1rem;margin-bottom:1.25rem} +#toc{border-bottom:1px solid #e7e7e9;padding-bottom:.5em} +#toc>ul{margin-left:.125em} +#toc ul.sectlevel0>li>a{font-style:italic} +#toc ul.sectlevel0 ul.sectlevel1{margin:.5em 0} +#toc ul{font-family:"Open Sans","DejaVu Sans",sans-serif;list-style-type:none} +#toc li{line-height:1.3334;margin-top:.3334em} +#toc a{text-decoration:none} +#toc a:active{text-decoration:underline} +#toctitle{color:#7a2518;font-size:1.2em} +@media screen and (min-width:768px){#toctitle{font-size:1.375em} +body.toc2{padding-left:15em;padding-right:0} +#toc.toc2{margin-top:0!important;background:#f8f8f7;position:fixed;width:15em;left:0;top:0;border-right:1px solid #e7e7e9;border-top-width:0!important;border-bottom-width:0!important;z-index:1000;padding:1.25em 1em;height:100%;overflow:auto} +#toc.toc2 #toctitle{margin-top:0;margin-bottom:.8rem;font-size:1.2em} +#toc.toc2>ul{font-size:.9em;margin-bottom:0} +#toc.toc2 ul ul{margin-left:0;padding-left:1em} +#toc.toc2 ul.sectlevel0 ul.sectlevel1{padding-left:0;margin-top:.5em;margin-bottom:.5em} +body.toc2.toc-right{padding-left:0;padding-right:15em} +body.toc2.toc-right #toc.toc2{border-right-width:0;border-left:1px solid #e7e7e9;left:auto;right:0}} +@media screen and (min-width:1280px){body.toc2{padding-left:20em;padding-right:0} +#toc.toc2{width:20em} +#toc.toc2 #toctitle{font-size:1.375em} +#toc.toc2>ul{font-size:.95em} +#toc.toc2 ul ul{padding-left:1.25em} +body.toc2.toc-right{padding-left:0;padding-right:20em}} +#content #toc{border:1px solid #e0e0dc;margin-bottom:1.25em;padding:1.25em;background:#f8f8f7;border-radius:4px} +#content #toc>:first-child{margin-top:0} +#content #toc>:last-child{margin-bottom:0} +#footer{max-width:none;background:rgba(0,0,0,.8);padding:1.25em} +#footer-text{color:hsla(0,0%,100%,.8);line-height:1.44} +#content{margin-bottom:.625em} +.sect1{padding-bottom:.625em} +@media screen and (min-width:768px){#content{margin-bottom:1.25em} +.sect1{padding-bottom:1.25em}} +.sect1:last-child{padding-bottom:0} +.sect1+.sect1{border-top:1px solid #e7e7e9} +#content h1>a.anchor,h2>a.anchor,h3>a.anchor,#toctitle>a.anchor,.sidebarblock>.content>.title>a.anchor,h4>a.anchor,h5>a.anchor,h6>a.anchor{position:absolute;z-index:1001;width:1.5ex;margin-left:-1.5ex;display:block;text-decoration:none!important;visibility:hidden;text-align:center;font-weight:400} +#content h1>a.anchor::before,h2>a.anchor::before,h3>a.anchor::before,#toctitle>a.anchor::before,.sidebarblock>.content>.title>a.anchor::before,h4>a.anchor::before,h5>a.anchor::before,h6>a.anchor::before{content:"\00A7";font-size:.85em;display:block;padding-top:.1em} +#content h1:hover>a.anchor,#content h1>a.anchor:hover,h2:hover>a.anchor,h2>a.anchor:hover,h3:hover>a.anchor,#toctitle:hover>a.anchor,.sidebarblock>.content>.title:hover>a.anchor,h3>a.anchor:hover,#toctitle>a.anchor:hover,.sidebarblock>.content>.title>a.anchor:hover,h4:hover>a.anchor,h4>a.anchor:hover,h5:hover>a.anchor,h5>a.anchor:hover,h6:hover>a.anchor,h6>a.anchor:hover{visibility:visible} +#content h1>a.link,h2>a.link,h3>a.link,#toctitle>a.link,.sidebarblock>.content>.title>a.link,h4>a.link,h5>a.link,h6>a.link{color:#ba3925;text-decoration:none} +#content h1>a.link:hover,h2>a.link:hover,h3>a.link:hover,#toctitle>a.link:hover,.sidebarblock>.content>.title>a.link:hover,h4>a.link:hover,h5>a.link:hover,h6>a.link:hover{color:#a53221} +details,.audioblock,.imageblock,.literalblock,.listingblock,.stemblock,.videoblock{margin-bottom:1.25em} +details{margin-left:1.25rem} +details>summary{cursor:pointer;display:block;position:relative;line-height:1.6;margin-bottom:.625rem;outline:none;-webkit-tap-highlight-color:transparent} +details>summary::-webkit-details-marker{display:none} +details>summary::before{content:"";border:solid transparent;border-left:solid;border-width:.3em 0 .3em .5em;position:absolute;top:.5em;left:-1.25rem;transform:translateX(15%)} +details[open]>summary::before{border:solid transparent;border-top:solid;border-width:.5em .3em 0;transform:translateY(15%)} +details>summary::after{content:"";width:1.25rem;height:1em;position:absolute;top:.3em;left:-1.25rem} +.admonitionblock td.content>.title,.audioblock>.title,.exampleblock>.title,.imageblock>.title,.listingblock>.title,.literalblock>.title,.stemblock>.title,.openblock>.title,.paragraph>.title,.quoteblock>.title,table.tableblock>.title,.verseblock>.title,.videoblock>.title,.dlist>.title,.olist>.title,.ulist>.title,.qlist>.title,.hdlist>.title{text-rendering:optimizeLegibility;text-align:left;font-family:"Noto Serif","DejaVu Serif",serif;font-size:1rem;font-style:italic} +table.tableblock.fit-content>caption.title{white-space:nowrap;width:0} +.paragraph.lead>p,#preamble>.sectionbody>[class=paragraph]:first-of-type p{font-size:1.21875em;line-height:1.6;color:rgba(0,0,0,.85)} +.admonitionblock>table{border-collapse:separate;border:0;background:none;width:100%} +.admonitionblock>table td.icon{text-align:center;width:80px} +.admonitionblock>table td.icon img{max-width:none} +.admonitionblock>table td.icon .title{font-weight:bold;font-family:"Open Sans","DejaVu Sans",sans-serif;text-transform:uppercase} +.admonitionblock>table td.content{padding-left:1.125em;padding-right:1.25em;border-left:1px solid #dddddf;color:rgba(0,0,0,.6);word-wrap:anywhere} +.admonitionblock>table td.content>:last-child>:last-child{margin-bottom:0} +.exampleblock>.content{border:1px solid #e6e6e6;margin-bottom:1.25em;padding:1.25em;background:#fff;border-radius:4px} +.sidebarblock{border:1px solid #dbdbd6;margin-bottom:1.25em;padding:1.25em;background:#f3f3f2;border-radius:4px} +.sidebarblock>.content>.title{color:#7a2518;margin-top:0;text-align:center} +.exampleblock>.content>:first-child,.sidebarblock>.content>:first-child{margin-top:0} +.exampleblock>.content>:last-child,.exampleblock>.content>:last-child>:last-child,.exampleblock>.content .olist>ol>li:last-child>:last-child,.exampleblock>.content .ulist>ul>li:last-child>:last-child,.exampleblock>.content .qlist>ol>li:last-child>:last-child,.sidebarblock>.content>:last-child,.sidebarblock>.content>:last-child>:last-child,.sidebarblock>.content .olist>ol>li:last-child>:last-child,.sidebarblock>.content .ulist>ul>li:last-child>:last-child,.sidebarblock>.content .qlist>ol>li:last-child>:last-child{margin-bottom:0} +.literalblock pre,.listingblock>.content>pre{border-radius:4px;overflow-x:auto;padding:1em;font-size:.8125em} +@media screen and (min-width:768px){.literalblock pre,.listingblock>.content>pre{font-size:.90625em}} +@media screen and (min-width:1280px){.literalblock pre,.listingblock>.content>pre{font-size:1em}} +.literalblock pre,.listingblock>.content>pre:not(.highlight),.listingblock>.content>pre[class=highlight],.listingblock>.content>pre[class^="highlight "]{background:#f7f7f8} +.literalblock.output pre{color:#f7f7f8;background:rgba(0,0,0,.9)} +.listingblock>.content{position:relative} +.listingblock code[data-lang]::before{display:none;content:attr(data-lang);position:absolute;font-size:.75em;top:.425rem;right:.5rem;line-height:1;text-transform:uppercase;color:inherit;opacity:.5} +.listingblock:hover code[data-lang]::before{display:block} +.listingblock.terminal pre .command::before{content:attr(data-prompt);padding-right:.5em;color:inherit;opacity:.5} +.listingblock.terminal pre .command:not([data-prompt])::before{content:"$"} +.listingblock pre.highlightjs{padding:0} +.listingblock pre.highlightjs>code{padding:1em;border-radius:4px} +.listingblock pre.prettyprint{border-width:0} +.prettyprint{background:#f7f7f8} +pre.prettyprint .linenums{line-height:1.45;margin-left:2em} +pre.prettyprint li{background:none;list-style-type:inherit;padding-left:0} +pre.prettyprint li code[data-lang]::before{opacity:1} +pre.prettyprint li:not(:first-child) code[data-lang]::before{display:none} +table.linenotable{border-collapse:separate;border:0;margin-bottom:0;background:none} +table.linenotable td[class]{color:inherit;vertical-align:top;padding:0;line-height:inherit;white-space:normal} +table.linenotable td.code{padding-left:.75em} +table.linenotable td.linenos,pre.pygments .linenos{border-right:1px solid;opacity:.35;padding-right:.5em;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none} +pre.pygments span.linenos{display:inline-block;margin-right:.75em} +.quoteblock{margin:0 1em 1.25em 1.5em;display:table} +.quoteblock:not(.excerpt)>.title{margin-left:-1.5em;margin-bottom:.75em} +.quoteblock blockquote,.quoteblock p{color:rgba(0,0,0,.85);font-size:1.15rem;line-height:1.75;word-spacing:.1em;letter-spacing:0;font-style:italic;text-align:justify} +.quoteblock blockquote{margin:0;padding:0;border:0} +.quoteblock blockquote::before{content:"\201c";float:left;font-size:2.75em;font-weight:bold;line-height:.6em;margin-left:-.6em;color:#7a2518;text-shadow:0 1px 2px rgba(0,0,0,.1)} +.quoteblock blockquote>.paragraph:last-child p{margin-bottom:0} +.quoteblock .attribution{margin-top:.75em;margin-right:.5ex;text-align:right} +.verseblock{margin:0 1em 1.25em} +.verseblock pre{font-family:"Open Sans","DejaVu Sans",sans-serif;font-size:1.15rem;color:rgba(0,0,0,.85);font-weight:300;text-rendering:optimizeLegibility} +.verseblock pre strong{font-weight:400} +.verseblock .attribution{margin-top:1.25rem;margin-left:.5ex} +.quoteblock .attribution,.verseblock .attribution{font-size:.9375em;line-height:1.45;font-style:italic} +.quoteblock .attribution br,.verseblock .attribution br{display:none} +.quoteblock .attribution cite,.verseblock .attribution cite{display:block;letter-spacing:-.025em;color:rgba(0,0,0,.6)} +.quoteblock.abstract blockquote::before,.quoteblock.excerpt blockquote::before,.quoteblock .quoteblock blockquote::before{display:none} +.quoteblock.abstract blockquote,.quoteblock.abstract p,.quoteblock.excerpt blockquote,.quoteblock.excerpt p,.quoteblock .quoteblock blockquote,.quoteblock .quoteblock p{line-height:1.6;word-spacing:0} +.quoteblock.abstract{margin:0 1em 1.25em;display:block} +.quoteblock.abstract>.title{margin:0 0 .375em;font-size:1.15em;text-align:center} +.quoteblock.excerpt>blockquote,.quoteblock .quoteblock{padding:0 0 .25em 1em;border-left:.25em solid #dddddf} +.quoteblock.excerpt,.quoteblock .quoteblock{margin-left:0} +.quoteblock.excerpt blockquote,.quoteblock.excerpt p,.quoteblock .quoteblock blockquote,.quoteblock .quoteblock p{color:inherit;font-size:1.0625rem} +.quoteblock.excerpt .attribution,.quoteblock .quoteblock .attribution{color:inherit;font-size:.85rem;text-align:left;margin-right:0} +p.tableblock:last-child{margin-bottom:0} +td.tableblock>.content{margin-bottom:1.25em;word-wrap:anywhere} +td.tableblock>.content>:last-child{margin-bottom:-1.25em} +table.tableblock,th.tableblock,td.tableblock{border:0 solid #dedede} +table.grid-all>*>tr>*{border-width:1px} +table.grid-cols>*>tr>*{border-width:0 1px} +table.grid-rows>*>tr>*{border-width:1px 0} +table.frame-all{border-width:1px} +table.frame-ends{border-width:1px 0} +table.frame-sides{border-width:0 1px} +table.frame-none>colgroup+*>:first-child>*,table.frame-sides>colgroup+*>:first-child>*{border-top-width:0} +table.frame-none>:last-child>:last-child>*,table.frame-sides>:last-child>:last-child>*{border-bottom-width:0} +table.frame-none>*>tr>:first-child,table.frame-ends>*>tr>:first-child{border-left-width:0} +table.frame-none>*>tr>:last-child,table.frame-ends>*>tr>:last-child{border-right-width:0} +table.stripes-all>*>tr,table.stripes-odd>*>tr:nth-of-type(odd),table.stripes-even>*>tr:nth-of-type(even),table.stripes-hover>*>tr:hover{background:#f8f8f7} +th.halign-left,td.halign-left{text-align:left} +th.halign-right,td.halign-right{text-align:right} +th.halign-center,td.halign-center{text-align:center} +th.valign-top,td.valign-top{vertical-align:top} +th.valign-bottom,td.valign-bottom{vertical-align:bottom} +th.valign-middle,td.valign-middle{vertical-align:middle} +table thead th,table tfoot th{font-weight:bold} +tbody tr th{background:#f7f8f7} +tbody tr th,tbody tr th p,tfoot tr th,tfoot tr th p{color:rgba(0,0,0,.8);font-weight:bold} +p.tableblock>code:only-child{background:none;padding:0} +p.tableblock{font-size:1em} +ol{margin-left:1.75em} +ul li ol{margin-left:1.5em} +dl dd{margin-left:1.125em} +dl dd:last-child,dl dd:last-child>:last-child{margin-bottom:0} +li p,ul dd,ol dd,.olist .olist,.ulist .ulist,.ulist .olist,.olist .ulist{margin-bottom:.625em} +ul.checklist,ul.none,ol.none,ul.no-bullet,ol.no-bullet,ol.unnumbered,ul.unstyled,ol.unstyled{list-style-type:none} +ul.no-bullet,ol.no-bullet,ol.unnumbered{margin-left:.625em} +ul.unstyled,ol.unstyled{margin-left:0} +li>p:empty:only-child::before{content:"";display:inline-block} +ul.checklist>li>p:first-child{margin-left:-1em} +ul.checklist>li>p:first-child>.fa-square-o:first-child,ul.checklist>li>p:first-child>.fa-check-square-o:first-child{width:1.25em;font-size:.8em;position:relative;bottom:.125em} +ul.checklist>li>p:first-child>input[type=checkbox]:first-child{margin-right:.25em} +ul.inline{display:flex;flex-flow:row wrap;list-style:none;margin:0 0 .625em -1.25em} +ul.inline>li{margin-left:1.25em} +.unstyled dl dt{font-weight:400;font-style:normal} +ol.arabic{list-style-type:decimal} +ol.decimal{list-style-type:decimal-leading-zero} +ol.loweralpha{list-style-type:lower-alpha} +ol.upperalpha{list-style-type:upper-alpha} +ol.lowerroman{list-style-type:lower-roman} +ol.upperroman{list-style-type:upper-roman} +ol.lowergreek{list-style-type:lower-greek} +.hdlist>table,.colist>table{border:0;background:none} +.hdlist>table>tbody>tr,.colist>table>tbody>tr{background:none} +td.hdlist1,td.hdlist2{vertical-align:top;padding:0 .625em} +td.hdlist1{font-weight:bold;padding-bottom:1.25em} +td.hdlist2{word-wrap:anywhere} +.literalblock+.colist,.listingblock+.colist{margin-top:-.5em} +.colist td:not([class]):first-child{padding:.4em .75em 0;line-height:1;vertical-align:top} +.colist td:not([class]):first-child img{max-width:none} +.colist td:not([class]):last-child{padding:.25em 0} +.thumb,.th{line-height:0;display:inline-block;border:4px solid #fff;box-shadow:0 0 0 1px #ddd} +.imageblock.left{margin:.25em .625em 1.25em 0} +.imageblock.right{margin:.25em 0 1.25em .625em} +.imageblock>.title{margin-bottom:0} +.imageblock.thumb,.imageblock.th{border-width:6px} +.imageblock.thumb>.title,.imageblock.th>.title{padding:0 .125em} +.image.left,.image.right{margin-top:.25em;margin-bottom:.25em;display:inline-block;line-height:0} +.image.left{margin-right:.625em} +.image.right{margin-left:.625em} +a.image{text-decoration:none;display:inline-block} +a.image object{pointer-events:none} +sup.footnote,sup.footnoteref{font-size:.875em;position:static;vertical-align:super} +sup.footnote a,sup.footnoteref a{text-decoration:none} +sup.footnote a:active,sup.footnoteref a:active{text-decoration:underline} +#footnotes{padding-top:.75em;padding-bottom:.75em;margin-bottom:.625em} +#footnotes hr{width:20%;min-width:6.25em;margin:-.25em 0 .75em;border-width:1px 0 0} +#footnotes .footnote{padding:0 .375em 0 .225em;line-height:1.3334;font-size:.875em;margin-left:1.2em;margin-bottom:.2em} +#footnotes .footnote a:first-of-type{font-weight:bold;text-decoration:none;margin-left:-1.05em} +#footnotes .footnote:last-of-type{margin-bottom:0} +#content #footnotes{margin-top:-.625em;margin-bottom:0;padding:.75em 0} +div.unbreakable{page-break-inside:avoid} +.big{font-size:larger} +.small{font-size:smaller} +.underline{text-decoration:underline} +.overline{text-decoration:overline} +.line-through{text-decoration:line-through} +.aqua{color:#00bfbf} +.aqua-background{background:#00fafa} +.black{color:#000} +.black-background{background:#000} +.blue{color:#0000bf} +.blue-background{background:#0000fa} +.fuchsia{color:#bf00bf} +.fuchsia-background{background:#fa00fa} +.gray{color:#606060} +.gray-background{background:#7d7d7d} +.green{color:#006000} +.green-background{background:#007d00} +.lime{color:#00bf00} +.lime-background{background:#00fa00} +.maroon{color:#600000} +.maroon-background{background:#7d0000} +.navy{color:#000060} +.navy-background{background:#00007d} +.olive{color:#606000} +.olive-background{background:#7d7d00} +.purple{color:#600060} +.purple-background{background:#7d007d} +.red{color:#bf0000} +.red-background{background:#fa0000} +.silver{color:#909090} +.silver-background{background:#bcbcbc} +.teal{color:#006060} +.teal-background{background:#007d7d} +.white{color:#bfbfbf} +.white-background{background:#fafafa} +.yellow{color:#bfbf00} +.yellow-background{background:#fafa00} +span.icon>.fa{cursor:default} +a span.icon>.fa{cursor:inherit} +.admonitionblock td.icon [class^="fa icon-"]{font-size:2.5em;text-shadow:1px 1px 2px rgba(0,0,0,.5);cursor:default} +.admonitionblock td.icon .icon-note::before{content:"\f05a";color:#19407c} +.admonitionblock td.icon .icon-tip::before{content:"\f0eb";text-shadow:1px 1px 2px rgba(155,155,0,.8);color:#111} +.admonitionblock td.icon .icon-warning::before{content:"\f071";color:#bf6900} +.admonitionblock td.icon .icon-caution::before{content:"\f06d";color:#bf3400} +.admonitionblock td.icon .icon-important::before{content:"\f06a";color:#bf0000} +.conum[data-value]{display:inline-block;color:#fff!important;background:rgba(0,0,0,.8);border-radius:50%;text-align:center;font-size:.75em;width:1.67em;height:1.67em;line-height:1.67em;font-family:"Open Sans","DejaVu Sans",sans-serif;font-style:normal;font-weight:bold} +.conum[data-value] *{color:#fff!important} +.conum[data-value]+b{display:none} +.conum[data-value]::after{content:attr(data-value)} +pre .conum[data-value]{position:relative;top:-.125em} +b.conum *{color:inherit!important} +.conum:not([data-value]):empty{display:none} +dt,th.tableblock,td.content,div.footnote{text-rendering:optimizeLegibility} +h1,h2,p,td.content,span.alt,summary{letter-spacing:-.01em} +p strong,td.content strong,div.footnote strong{letter-spacing:-.005em} +p,blockquote,dt,td.content,td.hdlist1,span.alt,summary{font-size:1.0625rem} +p{margin-bottom:1.25rem} +.sidebarblock p,.sidebarblock dt,.sidebarblock td.content,p.tableblock{font-size:1em} +.exampleblock>.content{background:#fffef7;border-color:#e0e0dc;box-shadow:0 1px 4px #e0e0dc} +.print-only{display:none!important} +@page{margin:1.25cm .75cm} +@media print{*{box-shadow:none!important;text-shadow:none!important} +html{font-size:80%} +a{color:inherit!important;text-decoration:underline!important} +a.bare,a[href^="#"],a[href^="mailto:"]{text-decoration:none!important} +a[href^="http:"]:not(.bare)::after,a[href^="https:"]:not(.bare)::after{content:"(" attr(href) ")";display:inline-block;font-size:.875em;padding-left:.25em} +abbr[title]{border-bottom:1px dotted} +abbr[title]::after{content:" (" attr(title) ")"} +pre,blockquote,tr,img,object,svg{page-break-inside:avoid} +thead{display:table-header-group} +svg{max-width:100%} +p,blockquote,dt,td.content{font-size:1em;orphans:3;widows:3} +h2,h3,#toctitle,.sidebarblock>.content>.title{page-break-after:avoid} +#header,#content,#footnotes,#footer{max-width:none} +#toc,.sidebarblock,.exampleblock>.content{background:none!important} +#toc{border-bottom:1px solid #dddddf!important;padding-bottom:0!important} +body.book #header{text-align:center} +body.book #header>h1:first-child{border:0!important;margin:2.5em 0 1em} +body.book #header .details{border:0!important;display:block;padding:0!important} +body.book #header .details span:first-child{margin-left:0!important} +body.book #header .details br{display:block} +body.book #header .details br+span::before{content:none!important} +body.book #toc{border:0!important;text-align:left!important;padding:0!important;margin:0!important} +body.book #toc,body.book #preamble,body.book h1.sect0,body.book .sect1>h2{page-break-before:always} +.listingblock code[data-lang]::before{display:block} +#footer{padding:0 .9375em} +.hide-on-print{display:none!important} +.print-only{display:block!important} +.hide-for-print{display:none!important} +.show-for-print{display:inherit!important}} +@media amzn-kf8,print{#header>h1:first-child{margin-top:1.25rem} +.sect1{padding:0!important} +.sect1+.sect1{border:0} +#footer{background:none} +#footer-text{color:rgba(0,0,0,.6);font-size:.9em}} +@media amzn-kf8{#header,#content,#footnotes,#footer{padding:0}} +</style> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/4.7.0/css/font-awesome.min.css"> +</head> +<body class="book toc2 toc-left"> +<div id="header"> +<h1>The NEORV32 RISC-V Processor - User Guide</h1> +<div class="details"> +<span id="revnumber">version v1.10.1-r126-g74b0d5cf</span> +</div> +<div id="toc" class="toc2"> +<div id="toctitle">Table of Contents</div> +<ul class="sectlevel1"> +<li><a href="#_software_toolchain_setup">1. Software Toolchain Setup</a> +<ul class="sectlevel2"> +<li><a href="#_building_the_toolchain_from_scratch">1.1. Building the Toolchain from Scratch</a></li> +<li><a href="#_downloading_and_installing_a_prebuilt_toolchain">1.2. Downloading and Installing a Prebuilt Toolchain</a> +<ul class="sectlevel3"> +<li><a href="#_use_the_pre_built_toolchains">1.2.1. Use The Pre-Built Toolchains</a></li> +<li><a href="#_use_a_third_party_toolchain">1.2.2. Use a Third Party Toolchain</a></li> +</ul> +</li> +<li><a href="#_installation">1.3. Installation</a></li> +<li><a href="#_testing_the_installation">1.4. Testing the Installation</a></li> +</ul> +</li> +<li><a href="#_general_hardware_setup">2. General Hardware Setup</a></li> +<li><a href="#_general_software_framework_setup">3. General Software Framework Setup</a> +<ul class="sectlevel2"> +<li><a href="#_modifying_the_linker_script">3.1. Modifying the Linker Script</a></li> +<li><a href="#_overriding_the_default_configuration">3.2. Overriding the Default Configuration</a></li> +</ul> +</li> +<li><a href="#_application_program_compilation">4. Application Program Compilation</a></li> +<li><a href="#_uploading_and_starting_of_a_binary_executable_image_via_uart">5. Uploading and Starting of a Binary Executable Image via UART</a></li> +<li><a href="#_installing_an_executable_directly_into_memory">6. Installing an Executable Directly Into Memory</a></li> +<li><a href="#_setup_of_a_new_application_program_project">7. Setup of a New Application Program Project</a></li> +<li><a href="#_application_specific_processor_configuration">8. Application-Specific Processor Configuration</a> +<ul class="sectlevel2"> +<li><a href="#_optimize_for_performance">8.1. Optimize for Performance</a></li> +<li><a href="#_optimize_for_size">8.2. Optimize for Size</a></li> +<li><a href="#_optimize_for_clock_speed">8.3. Optimize for Clock Speed</a></li> +<li><a href="#_optimize_for_energy">8.4. Optimize for Energy</a></li> +</ul> +</li> +<li><a href="#_adding_custom_hardware_modules">9. Adding Custom Hardware Modules</a> +<ul class="sectlevel2"> +<li><a href="#_standard_external_interfaces">9.1. Standard (<em>External</em>) Interfaces</a></li> +<li><a href="#_external_bus_interface">9.2. External Bus Interface</a></li> +<li><a href="#_custom_functions_subsystem">9.3. Custom Functions Subsystem</a></li> +<li><a href="#_custom_functions_unit">9.4. Custom Functions Unit</a></li> +<li><a href="#_comparative_summary">9.5. Comparative Summary</a></li> +</ul> +</li> +<li><a href="#_customizing_the_internal_bootloader">10. Customizing the Internal Bootloader</a> +<ul class="sectlevel2"> +<li><a href="#_auto_boot_configuration">10.1. Auto-Boot Configuration</a></li> +</ul> +</li> +<li><a href="#_programming_an_external_spi_flash_via_the_bootloader">11. Programming an External SPI Flash via the Bootloader</a> +<ul class="sectlevel2"> +<li><a href="#_programming_an_executable">11.1. Programming an Executable</a></li> +</ul> +</li> +<li><a href="#_packaging_the_processor_as_vivado_ip_block">12. Packaging the Processor as Vivado IP Block</a></li> +<li><a href="#_simulating_the_processor">13. Simulating the Processor</a> +<ul class="sectlevel2"> +<li><a href="#_testbench">13.1. Testbench</a></li> +<li><a href="#_faster_simulation_console_output">13.2. Faster Simulation Console Output</a></li> +<li><a href="#_simulation_using_a_shell_script_with_ghdl">13.3. Simulation using a shell script (with GHDL)</a></li> +<li><a href="#_simulation_using_application_makefiles_in_console_with_ghdl">13.4. Simulation using Application Makefiles (In-Console with GHDL)</a> +<ul class="sectlevel3"> +<li><a href="#_hello_world">13.4.1. Hello World!</a></li> +</ul> +</li> +<li><a href="#_advanced_simulation_using_vunit">13.5. Advanced Simulation using VUnit</a></li> +</ul> +</li> +<li><a href="#_vhdl_development_environment">14. VHDL Development Environment</a></li> +<li><a href="#_building_the_documentation">15. Building the Documentation</a></li> +<li><a href="#_zephyr_rtos_support">16. Zephyr RTOS Support</a></li> +<li><a href="#_freertos_support">17. FreeRTOS Support</a></li> +<li><a href="#_litex_soc_builder_support">18. LiteX SoC Builder Support</a> +<ul class="sectlevel2"> +<li><a href="#_litex_setup">18.1. LiteX Setup</a></li> +<li><a href="#_litex_simulation">18.2. LiteX Simulation</a></li> +</ul> +</li> +<li><a href="#_debugging_using_the_on_chip_debugger">19. Debugging using the On-Chip Debugger</a> +<ul class="sectlevel2"> +<li><a href="#_hardware_requirements">19.1. Hardware Requirements</a></li> +<li><a href="#_openocd">19.2. OpenOCD</a></li> +<li><a href="#_debugging_with_gdb">19.3. Debugging with GDB</a> +<ul class="sectlevel3"> +<li><a href="#_software_breakpoints">19.3.1. Software Breakpoints</a></li> +<li><a href="#_hardware_breakpoints">19.3.2. Hardware Breakpoints</a></li> +</ul> +</li> +<li><a href="#_segger_embedded_studio">19.4. Segger Embedded Studio</a></li> +</ul> +</li> +<li><a href="#_neorv32_in_verilog">20. NEORV32 in Verilog</a></li> +<li><a href="#_eclipse_ide">21. Eclipse IDE</a> +<ul class="sectlevel2"> +<li><a href="#_eclipse_prerequisites">21.1. Eclipse Prerequisites</a></li> +<li><a href="#_import_the_provided_eclipse_example_project">21.2. Import The Provided Eclipse Example Project</a></li> +<li><a href="#_setup_a_new_eclipse_project_from_scratch">21.3. Setup a new Eclipse Project from Scratch</a> +<ul class="sectlevel3"> +<li><a href="#_create_a_new_project">21.3.1. Create a new Project</a></li> +<li><a href="#_add_initial_files">21.3.2. Add Initial Files</a></li> +<li><a href="#_add_build_targets_optional">21.3.3. Add Build Targets (optional)</a></li> +</ul> +</li> +<li><a href="#_configure_build_tools">21.4. Configure Build Tools</a></li> +<li><a href="#_adjust_default_build_configuration_optional">21.5. Adjust Default Build Configuration (optional)</a> +<ul class="sectlevel3"> +<li><a href="#_add_neorv32_software_framework">21.5.1. Add NEORV32 Software Framework</a></li> +<li><a href="#_setup_openocd">21.5.2. Setup OpenOCD</a></li> +<li><a href="#_setup_serial_terminal">21.5.3. Setup Serial Terminal</a></li> +</ul> +</li> +<li><a href="#_eclipse_setup_references">21.6. Eclipse Setup References</a></li> +</ul> +</li> +<li><a href="#_legal">22. Legal</a> +<ul class="sectlevel2"> +<li><a href="#_about">About</a></li> +<li><a href="#_license">License</a></li> +<li><a href="#_proprietary_notice">Proprietary Notice</a></li> +<li><a href="#_disclaimer">Disclaimer</a></li> +<li><a href="#_limitation_of_liability_for_external_links">Limitation of Liability for External Links</a></li> +<li><a href="#_citing">Citing</a></li> +<li><a href="#_acknowledgments">Acknowledgments</a></li> +</ul> +</li> +</ul> +</div> +</div> +<div id="content"> +<div id="preamble"> +<div class="sectionbody"> +<div class="imageblock text-center"> +<div class="content"> +<a class="image" href="https://github.com/stnolting/neorv32"><img src="../img/neorv32_logo.png" alt="neorv32 logo"></a> +</div> +</div> +<div class="imageblock text-center"> +<div class="content"> +<a class="image" href="https://riscv.org/"><img src="../img/riscv_logo.png" alt="riscv logo" width="350"></a> +</div> +</div> +<div class="paragraph text-center"> +<p><a href="https://github.com/stnolting/neorv32"><span class="image"><img src="https://img.shields.io/badge/GitHub-stnolting%2Fneorv32-ffbd00?style=flat-square&amp;logo=github&amp;" alt="GitHub stnolting%2Fneorv32 ffbd00?style=flat square&amp;logo=github&amp;" title="homepage"></span></a> +<a href="https://github.com/stnolting/neorv32/blob/main/LICENSE"><span class="image"><img src="https://img.shields.io/github/license/stnolting/neorv32?longCache=true&amp;style=flat-square" alt="neorv32?longCache=true&amp;style=flat square" title="license"></span></a> +<a href="https://github.com/stnolting/neorv32/releases/tag/nightly"><span class="image"><img src="https://img.shields.io/badge/data%20sheet-PDF-ffbd00?longCache=true&amp;style=flat-square&amp;logo=asciidoctor" alt="data%20sheet PDF ffbd00?longCache=true&amp;style=flat square&amp;logo=asciidoctor" title="datasheet (pdf)"></span></a> +<a href="https://stnolting.github.io/neorv32"><span class="image"><img src="https://img.shields.io/badge/-HTML-ffbd00?longCache=true&amp;style=flat-square" alt=" HTML ffbd00?longCache=true&amp;style=flat square" title="datasheet (html)"></span></a> +<a href="https://github.com/stnolting/neorv32/releases/tag/nightly"><span class="image"><img src="https://img.shields.io/badge/user%20guide-PDF-ffbd00?longCache=true&amp;style=flat-square&amp;logo=asciidoctor" alt="user%20guide PDF ffbd00?longCache=true&amp;style=flat square&amp;logo=asciidoctor" title="userguide (pdf)"></span></a> +<a href="https://stnolting.github.io/neorv32/sw/files.html"><span class="image"><img src="https://img.shields.io/badge/doxygen-HTML-ffbd00?longCache=true&amp;style=flat-square&amp;logo=Doxygen" alt="doxygen HTML ffbd00?longCache=true&amp;style=flat square&amp;logo=Doxygen" title="doxygen"></span></a><br> +<a href="https://github.com/stnolting/neorv32/releases"><span class="image"><img src="https://img.shields.io/github/v/release/stnolting/neorv32?longCache=true&amp;style=flat-square&amp;logo=GitHub" alt="neorv32?longCache=true&amp;style=flat square&amp;logo=GitHub" title="release"></span></a> +<a href="https://github.com/stnolting/neorv32/releases"><span class="image"><img src="https://img.shields.io/github/commits-since/stnolting/neorv32/latest?longCache=true&amp;style=flat-square&amp;logo=GitHub" alt="latest?longCache=true&amp;style=flat square&amp;logo=GitHub" title="release-commits"></span></a></p> +</div> +<div class="paragraph"> +<p><strong>Let&#8217;s Get It Started!</strong></p> +</div> +<div class="paragraph"> +<p>This user guide uses the NEORV32 project <em>as is</em> from the official <code>neorv32</code> repository. +To make your first NEORV32 project run, follow the guides from the upcoming sections. It is recommended to +follow these guides step by step and eventually in the presented order.</p> +</div> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +This guide uses the minimalistic and platform/toolchain agnostic SoC <strong>test setups</strong> from +<code>rtl/test_setups</code> for illustration. You can use one of the provided test setups for +your first FPGA tests.<br> +<br> +For more sophisticated example setups have a look at the +<a href="https://github.com/stnolting/neorv32-setups">neorv32-setups</a> repository, +which provides <strong>SoC setups</strong> for various FPGAs, boards and toolchains. +</td> +</tr> +</table> +</div> +<div class="paragraph"> +<p><strong>Quick Links</strong></p> +</div> +<div class="ulist"> +<ul> +<li> +<p><a href="#_software_toolchain_setup">Toolchain</a>, <a href="#_general_hardware_setup">hardware</a> and <a href="#_general_software_framework_setup">general software framework</a> setup</p> +</li> +<li> +<p><a href="#_application_program_compilation">compile</a> an application and <a href="#_uploading_and_starting_of_a_binary_executable_image_via_uart">upload</a> it or making it +<a href="#_installing_an_executable_directly_into_memory">persistent</a> in internal memory</p> +</li> +<li> +<p>setup a new <a href="#_setup_of_a_new_application_program_project">application project</a></p> +</li> +<li> +<p><a href="#_application_specific_processor_configuration">optimizing</a> the core for your application</p> +</li> +<li> +<p>add <a href="#_adding_custom_hardware_modules">custom hardware extensions</a> and <a href="#_customizing_the_internal_bootloader">customizing the bootloader</a></p> +</li> +<li> +<p><a href="#_programming_an_external_spi_flash_via_the_bootloader">program</a> an external SPI flash for persistent application storage</p> +</li> +<li> +<p>generate an AMD Vivado <a href="#_packaging_the_processor_as_vivado_ip_block">IP block</a></p> +</li> +<li> +<p><a href="#_simulating_the_processor">simulate</a> the processor and <a href="#_building_the_documentation">build the documentation</a></p> +</li> +<li> +<p>RTOS support for <a href="#_zephyr_rtos_support">Zephyr</a> and <a href="#_freertos_support">FreeRTOS</a></p> +</li> +<li> +<p>build SoCs using <a href="#_litex_soc_builder_support">LiteX</a></p> +</li> +<li> +<p>in-system <a href="#_debugging_using_the_on_chip_debugger">debugging</a> of the whole processor</p> +</li> +<li> +<p><a href="#_neorv32_in_verilog">NEORV32 in Verilog</a> - an all-Verilog "version" of the processor</p> +</li> +<li> +<p>use the <a href="#_eclipse_ide">Eclipse IDE</a> to develop and debug code for the NEORV32</p> +</li> +</ul> +</div> +<div style="page-break-after: always;"></div> +</div> +</div> +<div class="sect1"> +<h2 id="_software_toolchain_setup">1. Software Toolchain Setup</h2> +<div class="sectionbody"> +<div class="paragraph"> +<p>To compile (and debug) executables for the NEORV32 a RISC-V toolchain is required. +There are two possibilities to get this:</p> +</div> +<div class="olist arabic"> +<ol class="arabic"> +<li> +<p>Download and <em>build</em> the official RISC-V GNU toolchain yourself.</p> +</li> +<li> +<p>Download and install a prebuilt version of the toolchain; this might also done via the package manager / app store of your OS</p> +</li> +</ol> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +The default toolchain prefix (<code>RISCV_PREFIX</code> variable) for this project is <strong><code>riscv32-unknown-elf-</code></strong>. Of course you can use any other RISC-V +toolchain (like <code>riscv64-unknown-elf-</code>) that is capable to emit code for a <code>rv32</code> architecture. Just change <code>RISCV_PREFIX</code> +according to your needs. +</td> +</tr> +</table> +</div> +<div class="sect2"> +<h3 id="_building_the_toolchain_from_scratch">1.1. Building the Toolchain from Scratch</h3> +<div class="paragraph"> +<p>To build the toolchain by yourself you can follow the guide from the official <a href="https://github.com/riscv-collab/riscv-gnu-toolchain" class="bare">https://github.com/riscv-collab/riscv-gnu-toolchain</a> GitHub page. +You need to make sure the generated toolchain fits the architecture of the NEORV32 core. To get a toolchain that even supports minimal +ISA extension configurations, it is recommend to compile for <code>rv32i</code> only. Please note that this minimal ISA also provides further ISA +extensions like <code>m</code> or <code>c</code>. Of course you can use a <em>multilib</em> approach to generate toolchains for several target ISAs at once.</p> +</div> +<div class="listingblock"> +<div class="title">Listing 1. Preparing GCC build for <code>rv32i</code> (minimal ISA)</div> +<div class="content"> +<pre class="highlight"><code class="language-bash" data-lang="bash">$ git clone https://github.com/riscv/riscv-gnu-toolchain +$ cd riscv-gnu-toolchain + +$ riscv-gnu-toolchain$ ./configure --prefix=/opt/riscv --with-arch=rv32i --with-abi=ilp32 +$ riscv-gnu-toolchain$ make</code></pre> +</div> +</div> +<div class="admonitionblock important"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-important" title="Important"></i> +</td> +<td class="content"> +Keep in mind that - for instance - a toolchain build with <code>--with-arch=rv32imc</code> provides library code (like the C +standard library) compiled entirely utilizing compressed (<code>C</code>) and <code>mul</code>/<code>div</code> instructions (<code>M</code>). Hence, this +code CANNOT be executed (without emulation) on an architecture that does not support these ISA extensions. +</td> +</tr> +</table> +</div> +</div> +<div class="sect2"> +<h3 id="_downloading_and_installing_a_prebuilt_toolchain">1.2. Downloading and Installing a Prebuilt Toolchain</h3> +<div class="paragraph"> +<p>Alternatively, you can download a prebuilt toolchain.</p> +</div> +<div class="sect3"> +<h4 id="_use_the_pre_built_toolchains">1.2.1. Use The Pre-Built Toolchains</h4> +<div class="paragraph"> +<p>We have compiled several GCC toolchains on a 64-bit x86 Ubuntu (Ubuntu on Windows, actually) and uploaded it to +GitHub. You can directly download the according toolchain archive as single <em>zip-file</em> within a packed +release from <a href="https://github.com/stnolting/riscv-gcc-prebuilt" class="bare">https://github.com/stnolting/riscv-gcc-prebuilt</a>. More information about downloading and installing +these prebuilt toolchains can be found in the repository&#8217;s README.</p> +</div> +</div> +<div class="sect3"> +<h4 id="_use_a_third_party_toolchain">1.2.2. Use a Third Party Toolchain</h4> +<div class="paragraph"> +<p>Of course you can also use any other prebuilt version of the toolchain. There are a lot RISC-V GCC packages out there - +even for Windows. On Linux system you might even be able to fetch a toolchain via your distribution&#8217;s package manager.</p> +</div> +<div class="admonitionblock important"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-important" title="Important"></i> +</td> +<td class="content"> +Make sure the toolchain can (also) emit code for a <code>rv32i</code> architecture, uses the <code>ilp32</code> or <code>ilp32e</code> ABI and <strong>was not build</strong> using +CPU extensions that are not supported by the NEORV32 (like <code>D</code>). +</td> +</tr> +</table> +</div> +</div> +</div> +<div class="sect2"> +<h3 id="_installation">1.3. Installation</h3> +<div class="paragraph"> +<p>Now you have the toolchain binaries. The last step is to add them to your <code>PATH</code> environment variable (if you have not +already done so): make sure to add the <em>binaries</em> folder (<code>bin</code>) of your toolchain.</p> +</div> +<div class="listingblock"> +<div class="content"> +<pre class="highlight"><code class="language-bash" data-lang="bash">$ export PATH=$PATH:/opt/riscv/bin</code></pre> +</div> +</div> +<div class="paragraph"> +<p>You should add this command to your <code>.bashrc</code> (if you are using bash) to automatically add the RISC-V +toolchain at every console start.</p> +</div> +</div> +<div class="sect2"> +<h3 id="_testing_the_installation">1.4. Testing the Installation</h3> +<div class="paragraph"> +<p>To make sure everything works fine, navigate to an example project in the NEORV32 example folder and +execute the following command:</p> +</div> +<div class="listingblock"> +<div class="content"> +<pre class="highlight"><code class="language-bash" data-lang="bash">neorv32/sw/example/demo_blink_led$ make check</code></pre> +</div> +</div> +<div class="paragraph"> +<p>This will test all the tools required for generating NEORV32 executables. +Everything is working fine if <code>Toolchain check OK</code> appears at the end.</p> +</div> +<div style="page-break-after: always;"></div> +</div> +</div> +</div> +<div class="sect1"> +<h2 id="_general_hardware_setup">2. General Hardware Setup</h2> +<div class="sectionbody"> +<div class="paragraph"> +<p>This guide shows the basics of setting up a NEORV32 project for FPGA implementation (or simulation only) +<em>from scratch</em>. It uses a <em>simplified</em> test "SoC" setup of the processor to keeps things simple at the beginning. +This simple setup is intended for evaluation or as "hello world" project to check out the NEORV32 +on <em>your</em> FPGA board.</p> +</div> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +If you want to use a more sophisticated pre-defined setup to start with, check out the +<code>setups</code> folder, which provides example setups for various FPGA, boards and toolchains. +</td> +</tr> +</table> +</div> +<div class="paragraph"> +<p>The NEORV32 project features three minimalistic pre-configured test setups in +<a href="https://github.com/stnolting/neorv32/blob/main/rtl/test_setups"><code>rtl/test_setups</code></a>. +These test setups only implement very basic processor and CPU features. +The main difference between the setups is the processor boot concept - so how to get a software executable +<em>into</em> the processor:</p> +</div> +<div class="ulist"> +<ul> +<li> +<p><strong><code>rtl/test_setups/neorv32_testsetup_approm.vhd</code></strong>: this setup does not require a connection via UART. The +software executable is "installed" into the bitstream to initialize a read-only memory. Use this setup +if your FPGA board does <em>not</em> provide a UART interface.</p> +</li> +<li> +<p><strong><code>rtl/test_setups/neorv32_testsetup_bootloader.vhd</code></strong>: this setups uses the UART and the default NEORV32 +bootloader to upload new software executables. Use this setup if your board <em>does</em> provide a UART interface.</p> +</li> +<li> +<p><strong><code>rtl/test_setups/neorv32_testsetup_on_chip_debugger.vhd</code></strong>: besides the UARt bootloader, this setups uses +on-chip debugger to upload and inspect new software executables. Use this setup if your board <em>does</em> provide a JTAG +interface (the UART is optional).</p> +</li> +</ul> +</div> +<div class="imageblock text-center"> +<div class="content"> +<img src="../img/neorv32_test_setup.png" alt="neorv32 test setup"> +</div> +<div class="title">Figure 1. NEORV32 "hello world" test setup (<code>rtl/test_setups/neorv32_testsetup_bootloader.vhd</code>)</div> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">External Clock Source</div> +These test setups are intended to be directly used as <strong>design top entity</strong>. Of course you can also instantiate them +into another design unit. If your FPGA board only provides <em>very fast</em> external clock sources (like on the FOMU board) +you might need to add clock management components (PLLs, DCMs, MMCMs, &#8230;&#8203;) to the test setup or to the according top entity +if you instantiate one of the test setups. +</td> +</tr> +</table> +</div> +<div class="olist arabic"> +<ol class="arabic" start="1"> +<li> +<p>Create a new project with your FPGA EDA tool of choice.</p> +</li> +<li> +<p>Add all VHDL files from the project&#8217;s <code>rtl/core</code> folder to your project.</p> +</li> +</ol> +</div> +<div class="admonitionblock important"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-important" title="Important"></i> +</td> +<td class="content"> +<div class="title">Internal Memories</div> +For a <em>general</em> first setup (technology-independent) use the <code>*.default.vhd</code> memory architectures for the internal memories +(IMEM and DMEM). These are located in <code>rtl/core/mem</code> so make sure to add the files to your project, too.<br> +<br> +If synthesis cannot efficiently map those default memory descriptions to the available memory resources, you can later replace the +default memory architectures by optimized platform-specific memory architectures. <strong>Example:</strong> The <code>neorv32-setups/radiant/UPduino_v3</code> +example setup uses optimized memory primitives. Hence, it does not include the default memory architectures from +<code>rtl/core/mem</code> as these are replaced by device-specific implementations. However, it still has to include the entity +definitions from <code>rtl/core</code>. +</td> +</tr> +</table> +</div> +<div class="olist arabic"> +<ol class="arabic" start="3"> +<li> +<p>Make sure to add all the rtl files to a new library called <code>neorv32</code>. If your FPGA tools does not +provide a field to enter the library name, check out the "properties" menu of the added rtl files.</p> +</li> +</ol> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">Compile order</div> +Some tools (like Lattice Radiant) might require a <em>manual compile order</em> of the VHDL source files to identify the dependencies. +The package file <code>neorv32_package.vhd</code> should be analyzed first followed by the memory image files (<code>neorv32_application_imagevhd</code> +and <code>neorv32_bootloader_image.vhd</code>) and the entity-only files (<code>neorv32_*mem.entity.vhd</code>). +</td> +</tr> +</table> +</div> +<div class="olist arabic"> +<ol class="arabic" start="4"> +<li> +<p>The <code>rtl/core/neorv32_top.vhd</code> VHDL file is the top entity of the NEORV32 processor, which can be +instantiated into the "real" project. However, in this tutorial we will use one of the pre-defined +test setups from <code>rtl/test_setups</code> (see above).</p> +</li> +</ol> +</div> +<div class="admonitionblock important"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-important" title="Important"></i> +</td> +<td class="content"> +Make sure to include the <code>neorv32</code> package into your design when instantiating the processor: add +<code>library neorv32;</code> and <code>use neorv32.neorv32_package.all;</code> to your design unit. +</td> +</tr> +</table> +</div> +<div class="olist arabic"> +<ol class="arabic" start="5"> +<li> +<p>Add the pre-defined test setup of choice to the project, too, and select it as <em>top entity</em>.</p> +</li> +<li> +<p>The entity of both test setups +provide a minimal set of configuration generics, that might have to be adapted to match your FPGA and board:</p> +</li> +</ol> +</div> +<div class="listingblock"> +<div class="title">Listing 2. Test setup entity - configuration generics</div> +<div class="content"> +<pre class="highlight"><code class="language-vhdl" data-lang="vhdl"> generic ( + -- adapt these for your setup -- + CLOCK_FREQUENCY : natural := 100000000; <i class="conum" data-value="1"></i><b>(1)</b> + MEM_INT_IMEM_SIZE : natural := 16*1024; <i class="conum" data-value="2"></i><b>(2)</b> + MEM_INT_DMEM_SIZE : natural := 8*1024 <i class="conum" data-value="3"></i><b>(3)</b> + );</code></pre> +</div> +</div> +<div class="colist arabic"> +<table> +<tr> +<td><i class="conum" data-value="1"></i><b>1</b></td> +<td>Clock frequency of <code>clk_i</code> signal in Hertz</td> +</tr> +<tr> +<td><i class="conum" data-value="2"></i><b>2</b></td> +<td>Default size of internal instruction memory: 16kB</td> +</tr> +<tr> +<td><i class="conum" data-value="3"></i><b>3</b></td> +<td>Default size of internal data memory: 8kB</td> +</tr> +</table> +</div> +<div class="olist arabic"> +<ol class="arabic" start="7"> +<li> +<p>If you feel like it - or if your FPGA does not provide sufficient resources - you can modify the +<em>memory sizes</em> (<code>MEM_INT_IMEM_SIZE</code> and <code>MEM_INT_DMEM_SIZE</code> - marked with notes "2" and "3"). But as mentioned +above, let&#8217;s keep things simple at first and use the standard configuration for now.</p> +</li> +<li> +<p>There is one generic that <em>has to be set according to your FPGA board</em> setup: the actual clock frequency +of the top&#8217;s clock input signal (<code>clk_i</code>). Use the <code>CLOCK_FREQUENCY</code> generic to specify your clock source&#8217;s +frequency in Hertz (Hz).</p> +</li> +</ol> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +If you have changed the default memory configuration (<code>MEM_INT_IMEM_SIZE</code> and <code>MEM_INT_DMEM_SIZE</code> generics) +keep those new sizes in mind - these values are required for setting +up the software framework in the next section <a href="#_general_software_framework_setup">General Software Framework Setup</a>. +</td> +</tr> +</table> +</div> +<div class="olist arabic"> +<ol class="arabic" start="9"> +<li> +<p>Depending on your FPGA tool of choice, it is time to assign the signals of the test setup top entity to +the according pins of your FPGA board. All the signals can be found in the entity declaration of the +corresponding test setup:</p> +</li> +</ol> +</div> +<div class="listingblock"> +<div class="title">Listing 3. Entity signals of <code>neorv32_testsetup_approm.vhd</code></div> +<div class="content"> +<pre class="highlight"><code class="language-vhdl" data-lang="vhdl"> port ( + -- Global control -- + clk_i : in std_ulogic; -- global clock, rising edge + rstn_i : in std_ulogic; -- global reset, low-active, async + -- GPIO -- + gpio_o : out std_ulogic_vector(7 downto 0) -- parallel output + );</code></pre> +</div> +</div> +<div class="listingblock"> +<div class="title">Listing 4. Entity signals of <code>neorv32_testsetup_bootloader.vhd</code></div> +<div class="content"> +<pre class="highlight"><code class="language-vhdl" data-lang="vhdl"> port ( + -- Global control -- + clk_i : in std_ulogic; -- global clock, rising edge + rstn_i : in std_ulogic; -- global reset, low-active, async + -- GPIO -- + gpio_o : out std_ulogic_vector(7 downto 0); -- parallel output + -- UART0 -- + uart0_txd_o : out std_ulogic; -- UART0 send data + uart0_rxd_i : in std_ulogic -- UART0 receive data + );</code></pre> +</div> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">Signal Polarity</div> +If your FPGA board has inverse polarity for certain input/output you can add <code>not</code> gates. Example: The reset signal +<code>rstn_i</code> is low-active by default; the LEDs connected to <code>gpio_o</code> high-active by default. +You can do this in your board top if you instantiate the test setup, +or <em>inside</em> the test setup if this is your top entity (low-active LEDs example: <code>gpio_o &#8656; NOT con_gpio_o(7 downto 0);</code>). +</td> +</tr> +</table> +</div> +<div class="olist arabic"> +<ol class="arabic" start="10"> +<li> +<p>Attach the clock input <code>clk_i</code> to your clock source and connect the reset line <code>rstn_i</code> to a button of +your FPGA board. Check whether it is low-active or high-active - the reset signal of the processor is +<strong>low-active</strong>, so maybe you need to invert the input signal.</p> +</li> +<li> +<p>If possible, connected <em>at least</em> bit <code>0</code> of the GPIO output port <code>gpio_o</code> to a LED (see "Signal Polarity" note above).</p> +</li> +<li> +<p>If your are using a UART-based test setup connect the UART communication signals <code>uart0_txd_o</code> and <code>uart0_rxd_i</code> +to the host interface (e.g. USB-UART converter).</p> +</li> +<li> +<p>If your are using the on-chip debugger setup connect the processor&#8217;s JTAG signal <code>jtag_*</code> to a suitable JTAG adapter.</p> +</li> +<li> +<p>Perform the project HDL compilation (synthesis, mapping, bitstream generation).</p> +</li> +<li> +<p>Program the generated bitstream into your FPGA and press the button connected to the reset signal.</p> +</li> +<li> +<p>Done! The LED(s) connected to <code>gpio_o</code> should be flashing now.</p> +</li> +</ol> +</div> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +<div class="title">Going Further</div> +Now that the hardware is ready, you can advance to one of these chapters to learn how to get a software executable +into your processor setup (setup the GCC toolchain before; next section <a href="#_general_software_framework_setup">General Software Framework Setup</a>):<br> +<br> +<code>neorv32_testsetup_approm.vhd</code>: <a href="#_installing_an_executable_directly_into_memory">Installing an Executable Directly Into Memory</a> +<br> +<code>neorv32_testsetup_bootloader.vhd</code>: <a href="#_uploading_and_starting_of_a_binary_executable_image_via_uart">Uploading and Starting of a Binary Executable Image via UART</a> +<br> +<code>neorv32_testsetup_on_chip_debugger.vhd</code>: <a href="#_debugging_using_the_on_chip_debugger">Debugging using the On-Chip Debugger</a> +</td> +</tr> +</table> +</div> +<div style="page-break-after: always;"></div> +</div> +</div> +<div class="sect1"> +<h2 id="_general_software_framework_setup">3. General Software Framework Setup</h2> +<div class="sectionbody"> +<div class="paragraph"> +<p>To allow executables to be <em>actually executed</em> on the NEORV32 Processor the configuration of the software framework +has to be aware to the hardware configuration. This guide focuses on the <strong>memory configuration</strong>. To enable +certain CPU ISA features refer to the <a href="#_enabling_risc_v_cpu_extensions">[_enabling_risc_v_cpu_extensions]</a> section.</p> +</div> +<div class="paragraph"> +<p>This guide shows how to configure the linker script for a given hardware memory configuration. More information regarding the +linker script itself can be found in the according section of the data sheet: <a href="https://stnolting.github.io/neorv32/#_linker_script" class="bare">https://stnolting.github.io/neorv32/#_linker_script</a></p> +</div> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +If you have <strong>not</strong> changed the <em>default</em> memory configuration in section <a href="#_general_hardware_setup">General Hardware Setup</a> +you are already done and you can skip the rest of this section. +</td> +</tr> +</table> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +Always keep the processor&#8217;s <a href="https://stnolting.github.io/neorv32/#_address_space">Address Space</a> layout in mind +when modifying the linker script +</td> +</tr> +</table> +</div> +<div class="paragraph"> +<p>There are two options to modify the default memory configuration of the linker script:</p> +</div> +<div class="olist arabic"> +<ol class="arabic" start="1"> +<li> +<p><a href="#_modifying_the_linker_script">Modifying the Linker Script</a></p> +</li> +<li> +<p><a href="#_overriding_the_default_configuration">Overriding the Default Configuration</a> (recommended!)</p> +</li> +</ol> +</div> +<div class="sect2"> +<h3 id="_modifying_the_linker_script">3.1. Modifying the Linker Script</h3> +<div class="paragraph"> +<p>This will modify the linker script <em>itself</em>.</p> +</div> +<div class="olist arabic"> +<ol class="arabic" start="1"> +<li> +<p>Open the NEORV32 linker script <code>sw/common/neorv32.ld</code> with a text editor. Right at the +beginning of this script you will find the <code> NEORV32 memory configuration </code> configuration section:</p> +</li> +</ol> +</div> +<div class="listingblock"> +<div class="title">Listing 5. Cut-out of the linker script <code>neorv32.ld</code></div> +<div class="content"> +<pre class="highlight"><code>/* Default rom/ram (IMEM/DMEM) sizes */ +__neorv32_rom_size = DEFINED(__neorv32_rom_size) ? __neorv32_rom_size : 2048M; <i class="conum" data-value="1"></i><b>(1)</b> +__neorv32_ram_size = DEFINED(__neorv32_ram_size) ? __neorv32_ram_size : 8K; <i class="conum" data-value="2"></i><b>(2)</b> + +/* Default HEAP size (= 0; no heap at all) */ +__neorv32_heap_size = DEFINED(__neorv32_heap_size) ? __neorv32_heap_size : 0; <i class="conum" data-value="3"></i><b>(3)</b> + +/* Default section base addresses - do not change this unless the hardware-defined address space layout is changed! */ +__neorv32_rom_base = DEFINED(__neorv32_rom_base) ? __neorv32_rom_base : 0x00000000; /* = VHDL package's "ispace_base_c" */ <i class="conum" data-value="4"></i><b>(4)</b> +__neorv32_ram_base = DEFINED(__neorv32_ram_base) ? __neorv32_ram_base : 0x80000000; /* = VHDL package's "dspace_base_c" */ <i class="conum" data-value="5"></i><b>(5)</b></code></pre> +</div> +</div> +<div class="colist arabic"> +<table> +<tr> +<td><i class="conum" data-value="1"></i><b>1</b></td> +<td>Default (max) size of the instruction memory address space (right-most value) (internal/external IMEM): 2048MB</td> +</tr> +<tr> +<td><i class="conum" data-value="2"></i><b>2</b></td> +<td>Default size of the data memory address space (right-most value) (internal/external DMEM): 8kB</td> +</tr> +<tr> +<td><i class="conum" data-value="3"></i><b>3</b></td> +<td>Default size of the HEAP (right-most value): 0kB</td> +</tr> +<tr> +<td><i class="conum" data-value="4"></i><b>4</b></td> +<td>Default base address of the instruction memory address space (right-most value): <code>0x00000000</code></td> +</tr> +<tr> +<td><i class="conum" data-value="5"></i><b>5</b></td> +<td>Default base address of the data memory address space (right-most value): <code>0x80000000</code></td> +</tr> +</table> +</div> +<div class="olist arabic"> +<ol class="arabic" start="2"> +<li> +<p>Only the the <code>neorv32_ram_size</code> variable needs to modified! If you have changed the default DMEM (<em>MEM_INT_DMEM_SIZE</em> generic) +size then change the right-most parameter (here: <code>8kB</code>) so it is equal to your DMEM hardware configuration. The <code>neorv32_rom_size</code> +does not need to be modified even if you have changed the default IMEM size. +For more information see <a href="https://stnolting.github.io/neorv32/#_linker_script" class="bare">https://stnolting.github.io/neorv32/#_linker_script</a></p> +</li> +</ol> +</div> +<div class="olist arabic"> +<ol class="arabic" start="3"> +<li> +<p>Done! Save your changes and close the linker script.</p> +</li> +</ol> +</div> +</div> +<div class="sect2"> +<h3 id="_overriding_the_default_configuration">3.2. Overriding the Default Configuration</h3> +<div class="paragraph"> +<p>This will not change the default linker script at all. Hence, <strong>this approach is recommended</strong> as it allows to make +per-project memory configuration without changing the code base.</p> +</div> +<div class="paragraph"> +<p>The RAM and ROM sizes from <a href="#_modifying_the_linker_script">Modifying the Linker Script</a> (as well as the base addresses) can also be modified +by overriding the default values when invoking <code>make</code>. Therefore, the command needs to pass the according +values to the linker using the makefile&#8217;s <code>USER_FLAGS</code> variable.</p> +</div> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +See section "Application Makefile" of the data sheet for more information regarding the default makefile variables: +<a href="https://stnolting.github.io/neorv32/#_application_makefile" class="bare">https://stnolting.github.io/neorv32/#_application_makefile</a> +</td> +</tr> +</table> +</div> +<div class="listingblock"> +<div class="title">Listing 6. Example: override default RAM size while invoking make</div> +<div class="content"> +<pre class="highlight"><code class="language-bash" data-lang="bash">$ make USER_FLAGS+="-Wl,--defsym,__neorv32_rom_size=16k" clean_all exe</code></pre> +</div> +</div> +<div class="paragraph"> +<p>The <code>-Wl</code> will pass the following commands/flags to the linker. <code>--defsym</code> will define a symbol for the linker. +<code>neorv32_rom_size</code> is the variable that will be defined and <code>16k</code> is the value assigned to it (= 16*1024 bytes). As a result, this +command will set the RAM region to a size of 16kB.</p> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +When using this approach the customized attributes have to be specified every time the makefile is invoked! +You can put the RAM/ROM override commands into the project&#8217;s local makefile or define a simple shell script that defines +all the setup-related parameters (memory sizes, RISC-V ISA extensions, optimization goal, further tuning flags, etc.). +</td> +</tr> +</table> +</div> +<div style="page-break-after: always;"></div> +</div> +</div> +</div> +<div class="sect1"> +<h2 id="_application_program_compilation">4. Application Program Compilation</h2> +<div class="sectionbody"> +<div class="paragraph"> +<p>This guide shows how to compile an example C-code application into a NEORV32 executable that +can be uploaded via the bootloader or the on-chip debugger.</p> +</div> +<div class="admonitionblock important"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-important" title="Important"></i> +</td> +<td class="content"> +If your FPGA board does not provide such an interface - don&#8217;t worry! +Section <a href="#_installing_an_executable_directly_into_memory">Installing an Executable Directly Into Memory</a> shows how to +run custom programs on your FPGA setup without having a UART. +</td> +</tr> +</table> +</div> +<div class="olist arabic"> +<ol class="arabic" start="1"> +<li> +<p>Open a terminal console and navigate to one of the project&#8217;s example programs. For instance, navigate to the +simple <code>sw/example_demo_blink_led</code> example program. This program uses the NEORV32 GPIO module to display +an 8-bit counter on the lowest eight bit of the <code>gpio_o</code> output port.</p> +</li> +<li> +<p>To compile the project and generate an executable simply execute:</p> +</li> +</ol> +</div> +<div class="listingblock"> +<div class="content"> +<pre class="highlight"><code class="language-bash" data-lang="bash">neorv32/sw/example/demo_blink_led$ make clean_all exe</code></pre> +</div> +</div> +<div class="olist arabic"> +<ol class="arabic" start="3"> +<li> +<p>We are using the <code>clean_all</code> target to make sure everything is re-build.</p> +</li> +<li> +<p>This will compile and link the application sources together with all the included libraries. At the end, +your application is transformed into an ELF file (<code>main.elf</code>). The <em>NEORV32 image generator</em> (in <code>sw/image_gen</code>) +takes this file and creates a final executable. The makefile will show the resulting memory utilization and +the executable size:</p> +</li> +</ol> +</div> +<div class="listingblock"> +<div class="content"> +<pre class="highlight"><code class="language-bash" data-lang="bash">neorv32/sw/example/demo_blink_led$ make clean_all exe +Memory utilization: + text data bss dec hex filename + 1004 0 0 1004 3ec main.elf +Compiling ../../../sw/image_gen/image_gen +Executable (neorv32_exe.bin) size in bytes: +1016</code></pre> +</div> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +Make sure the size of the <code>text</code> segment (3176 bytes here) does not overflow the size of the processor&#8217;s +IMEM (if used at all) - otherwise there will be an error during synthesis or during bootloader upload. +</td> +</tr> +</table> +</div> +<div class="olist arabic"> +<ol class="arabic" start="5"> +<li> +<p>That&#8217;s it. The <code>exe</code> target has created the actual executable <code>neorv32_exe.bin</code> in the current folder +that is ready to be uploaded to the processor.</p> +</li> +</ol> +</div> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +The compilation process will also create a <code>main.asm</code> assembly listing file in the current folder, which +shows the actual assembly code of the application. +</td> +</tr> +</table> +</div> +<div style="page-break-after: always;"></div> +</div> +</div> +<div class="sect1"> +<h2 id="_uploading_and_starting_of_a_binary_executable_image_via_uart">5. Uploading and Starting of a Binary Executable Image via UART</h2> +<div class="sectionbody"> +<div class="paragraph"> +<p>Follow this guide to use the bootloader to upload an executable via UART.</p> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +This concept uses the default "Indirect Boot" scenario that uses the bootloader to upload new executables. +See datasheet section <a href="https://stnolting.github.io/neorv32/#_indirect_boot">Indirect Boot</a> for more information. +</td> +</tr> +</table> +</div> +<div class="admonitionblock important"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-important" title="Important"></i> +</td> +<td class="content"> +If your FPGA board does not provide such an interface - don&#8217;t worry! +Section <a href="#_installing_an_executable_directly_into_memory">Installing an Executable Directly Into Memory</a> shows how to +run custom programs on your FPGA setup without having a UART. +</td> +</tr> +</table> +</div> +<div class="olist arabic"> +<ol class="arabic" start="1"> +<li> +<p>Connect the primary UART (UART0) interface of your FPGA board to a serial port of your host computer.</p> +</li> +<li> +<p>Start a terminal program. In this tutorial, I am using TeraTerm for Windows. You can download it for free +from <a href="https://ttssh2.osdn.jp/index.html.en" class="bare">https://ttssh2.osdn.jp/index.html.en</a> . On Linux you could use <code>cutecom</code> (recommended) or <code>GTKTerm</code>, +which you can get here <a href="https://github.com/Jeija/gtkterm.git" class="bare">https://github.com/Jeija/gtkterm.git</a> (or install via your package manager).</p> +</li> +</ol> +</div> +<div class="admonitionblock important"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-important" title="Important"></i> +</td> +<td class="content"> +<em>Any</em> terminal program that can connect to a serial port should work. However, make sure the program +can transfer data in <em>raw</em> byte mode without any protocol overhead around it. Some terminal programs struggle with +transmitting files larger than 4kB (see <a href="https://github.com/stnolting/neorv32/pull/215" class="bare">https://github.com/stnolting/neorv32/pull/215</a>). Try a different program +if uploading a binary does not work (terminal stall). +</td> +</tr> +</table> +</div> +<div class="olist arabic"> +<ol class="arabic" start="3"> +<li> +<p>Open a connection to the the serial port your UART is connected to. Configure the terminal setting according to the +following parameters:</p> +<div class="ulist"> +<ul> +<li> +<p>19200 Baud</p> +</li> +<li> +<p>8 data bits</p> +</li> +<li> +<p>1 stop bit</p> +</li> +<li> +<p>no parity bits</p> +</li> +<li> +<p><em>no</em> transmission/flow control protocol</p> +</li> +<li> +<p>newline on <code>\r\n</code> (carriage return <strong>and</strong> line feed)</p> +</li> +</ul> +</div> +</li> +</ol> +</div> +<div class="olist arabic"> +<ol class="arabic" start="4"> +<li> +<p>Also make sure that single chars are send from your computer <em>without</em> any consecutive "new line" or "carriage +return" commands. This is highly dependent on your terminal application of choice, TeraTerm only +sends the raw chars by default. In <code>cutecom</code>, change <code>LF</code> to <code>None</code> in the drop-down menu +next to the input text box.</p> +</li> +<li> +<p>Press the NEORV32 reset button to restart the bootloader. The status LED starts blinking and the +bootloader intro screen appears in your console. Hurry up and press any key (hit space!) to abort the +automatic boot sequence and to start the actual bootloader user interface console.</p> +</li> +</ol> +</div> +<div class="listingblock"> +<div class="title">Listing 7. Bootloader console; aborted auto-boot sequence</div> +<div class="content"> +<pre class="highlight"><code class="language-bash" data-lang="bash">&lt;&lt; NEORV32 Bootloader &gt;&gt; + +BLDV: Mar 7 2023 +HWV: 0x01080107 +CID: 0x00000000 +CLK: 0x05f5e100 +MISA: 0x40901106 +XISA: 0xc0000fab +SOC: 0xffff402f +IMEM: 0x00008000 +DMEM: 0x00002000 + +Autoboot in 10s. Press any key to abort. +Aborted. + +Available CMDs: + h: Help + r: Restart + u: Upload + s: Store to flash + l: Load from flash + x: Boot from flash (XIP) + e: Execute +CMD:&gt;</code></pre> +</div> +</div> +<div class="olist arabic"> +<ol class="arabic" start="6"> +<li> +<p>Execute the "Upload" command by typing <code>u</code>. Now the bootloader is waiting for a binary executable to be send.</p> +</li> +</ol> +</div> +<div class="listingblock"> +<div class="content"> +<pre class="highlight"><code class="language-bash" data-lang="bash">CMD:&gt; u +Awaiting neorv32_exe.bin...</code></pre> +</div> +</div> +<div class="olist arabic"> +<ol class="arabic" start="7"> +<li> +<p>Use the "send file" option of your terminal program to send a NEORV32 executable (<code>neorv32_exe.bin</code>).</p> +</li> +<li> +<p>Again, make sure to transmit the executable in raw binary mode (no transfer protocol). +When using TeraTerm, select the "binary" option in the send file dialog.</p> +</li> +<li> +<p>If everything went fine, OK will appear in your terminal:</p> +</li> +</ol> +</div> +<div class="admonitionblock important"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-important" title="Important"></i> +</td> +<td class="content"> +Make sure to upload the NEORV32 executable <code>neorv32_exe.bin</code>. Uploading any other file (like <code>main.bin</code>) +will cause an <code>ERR_EXE</code> bootloader error (see <a href="https://stnolting.github.io/neorv32/#_bootloader_error_codes" class="bare">https://stnolting.github.io/neorv32/#_bootloader_error_codes</a>). +</td> +</tr> +</table> +</div> +<div class="listingblock"> +<div class="content"> +<pre class="highlight"><code class="language-bash" data-lang="bash">CMD:&gt; u +Awaiting neorv32_exe.bin... OK</code></pre> +</div> +</div> +<div class="olist arabic"> +<ol class="arabic" start="10"> +<li> +<p>The executable is now in the instruction memory of the processor. To execute the program right +now run the "Execute" command by typing <code>e</code>:</p> +</li> +</ol> +</div> +<div class="listingblock"> +<div class="content"> +<pre class="highlight"><code class="language-bash" data-lang="bash">CMD:&gt; u +Awaiting neorv32_exe.bin... OK +CMD:&gt; e +Booting... +Blinking LED demo program</code></pre> +</div> +</div> +<div class="olist arabic"> +<ol class="arabic" start="11"> +<li> +<p>If everything went fine, you should see the LEDs blinking.</p> +</li> +</ol> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +The bootloader will print error codes if something went wrong. +See section <a href="https://stnolting.github.io/neorv32/#_bootloader">Bootloader</a> of the NEORV32 datasheet for more information. +</td> +</tr> +</table> +</div> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +See section <a href="#_programming_an_external_spi_flash_via_the_bootloader">Programming an External SPI Flash via the Bootloader</a> to learn how to use an external SPI +flash for nonvolatile program storage. +</td> +</tr> +</table> +</div> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +Executables can also be uploaded via the <strong>on-chip debugger</strong>. +See section <a href="#_debugging_with_gdb">Debugging with GDB</a> for more information. +</td> +</tr> +</table> +</div> +<div style="page-break-after: always;"></div> +</div> +</div> +<div class="sect1"> +<h2 id="_installing_an_executable_directly_into_memory">6. Installing an Executable Directly Into Memory</h2> +<div class="sectionbody"> +<div class="paragraph"> +<p>If you do not want to use the bootloader (or the on-chip debugger) for executable upload or if your setup does not provide +a serial interface for that, you can also directly install an application into embedded memory.</p> +</div> +<div class="paragraph"> +<p>This concept uses the "Direct Boot" scenario that implements the processor-internal IMEM as ROM, which is +pre-initialized with the application&#8217;s executable during synthesis. Hence, it provides <em>non-volatile</em> storage of the +executable inside the processor. This storage cannot be altered during runtime and any source code modification of +the application requires to re-program the FPGA via the bitstream.</p> +</div> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +See datasheet section <a href="https://stnolting.github.io/neorv32/#_direct_boot">Direct Boot</a> for more information. +</td> +</tr> +</table> +</div> +<div class="paragraph"> +<p>Using the IMEM as ROM:</p> +</div> +<div class="ulist"> +<ul> +<li> +<p>for this boot concept the bootloader is no longer required</p> +</li> +<li> +<p>this concept only works for the internal IMEM (but can be extended to work with external memories coupled via the processor&#8217;s bus interface)</p> +</li> +<li> +<p>make sure that the memory components (like block RAM) the IMEM is mapped to support an initialization via the bitstream</p> +</li> +</ul> +</div> +<div class="olist arabic"> +<ol class="arabic" start="1"> +<li> +<p>At first, make sure your processor setup actually implements the internal IMEM: the <code>MEM_INT_IMEM_EN</code> generics has to be set to <code>true</code>:</p> +</li> +</ol> +</div> +<div class="listingblock"> +<div class="title">Listing 8. Processor top entity configuration - enable internal IMEM</div> +<div class="content"> +<pre class="highlight"><code class="language-vhdl" data-lang="vhdl"> -- Internal Instruction memory -- + MEM_INT_IMEM_EN =&gt; true, -- implement processor-internal instruction memory</code></pre> +</div> +</div> +<div class="olist arabic"> +<ol class="arabic" start="2"> +<li> +<p>For this setup we do not want the bootloader to be implemented at all. Disable implementation of the bootloader by setting the +<code>INT_BOOTLOADER_EN</code> generic to <code>false</code>. This will also modify the processor-internal IMEM so it is initialized with the executable during synthesis.</p> +</li> +</ol> +</div> +<div class="listingblock"> +<div class="title">Listing 9. Processor top entity configuration - disable internal bootloader</div> +<div class="content"> +<pre class="highlight"><code class="language-vhdl" data-lang="vhdl"> -- General -- + INT_BOOTLOADER_EN =&gt; false, -- boot configuration: false = boot from int/ext (I)MEM</code></pre> +</div> +</div> +<div class="olist arabic"> +<ol class="arabic" start="3"> +<li> +<p>To generate an "initialization image" for the IMEM that contains the actual application, run the <code>install</code> target when compiling your application:</p> +</li> +</ol> +</div> +<div class="listingblock"> +<div class="content"> +<pre class="highlight"><code class="language-bash" data-lang="bash">neorv32/sw/example/demo_blink_led$ make clean_all install +Memory utilization: + text data bss dec hex filename + 1004 0 0 1004 3ec main.elf +Compiling ../../../sw/image_gen/image_gen +Executable (neorv32_exe.bin) size in bytes: +1016 +Installing application image to ../../../rtl/core/neorv32_application_image.vhd</code></pre> +</div> +</div> +<div class="olist arabic"> +<ol class="arabic" start="4"> +<li> +<p>The <code>install</code> target has compiled all the application sources but instead of creating an executable (<code>neorv32_exe.bit</code>) that can be uploaded via the +bootloader, it has created a VHDL memory initialization image <code>core/neorv32_application_image.vhd</code>.</p> +</li> +<li> +<p>This VHDL file is automatically copied to the core&#8217;s rtl folder (<code>rtl/core</code>) so it will be included for the next synthesis.</p> +</li> +<li> +<p>Perform a new synthesis. The IMEM will be build as pre-initialized ROM (inferring embedded memories if possible).</p> +</li> +<li> +<p>Upload your bitstream. Your application code now resides unchangeable in the processor&#8217;s IMEM and is directly executed after reset.</p> +</li> +</ol> +</div> +<div class="paragraph"> +<p>The synthesis tool / simulator will print asserts to inform about the (IMEM) memory / boot configuration:</p> +</div> +<div class="listingblock"> +<div class="content"> +<pre class="highlight"><code>NEORV32 PROCESSOR CONFIG NOTE: Boot configuration: Direct boot from memory (processor-internal IMEM). +NEORV32 PROCESSOR CONFIG NOTE: Implementing processor-internal IMEM as ROM (1016 bytes), pre-initialized with application.</code></pre> +</div> +</div> +<div style="page-break-after: always;"></div> +</div> +</div> +<div class="sect1"> +<h2 id="_setup_of_a_new_application_program_project">7. Setup of a New Application Program Project</h2> +<div class="sectionbody"> +<div class="olist arabic"> +<ol class="arabic" start="1"> +<li> +<p>The easiest way of creating a <em>new</em> software application project is to copy an <em>existing</em> one. This will keep all +file dependencies. For example you can copy <code>sw/example/demo_blink_led</code> to <code>sw/example/flux_capacitor</code>.</p> +</li> +<li> +<p>If you want to place you application somewhere outside <code>sw/example</code> you need to adapt the application&#8217;s makefile. +In the makefile you will find a variable that keeps the relative or absolute path to the NEORV32 repository home +folder. Just modify this variable according to your new project&#8217;s home location:</p> +</li> +</ol> +</div> +<div class="listingblock"> +<div class="content"> +<pre class="highlight"><code class="language-makefile" data-lang="makefile"># Relative or absolute path to the NEORV32 home folder (use default if not set by user) +NEORV32_HOME ?= ../../..</code></pre> +</div> +</div> +<div class="olist arabic"> +<ol class="arabic" start="3"> +<li> +<p>If your project contains additional source files outside of the project folder, you can add them to +the <code>APP_SRC</code> variable:</p> +</li> +</ol> +</div> +<div class="listingblock"> +<div class="content"> +<pre class="highlight"><code class="language-makefile" data-lang="makefile"># User's application sources (add additional files here) +APP_SRC = $(wildcard *.c) ../somewhere/some_file.c</code></pre> +</div> +</div> +<div class="olist arabic"> +<ol class="arabic" start="4"> +<li> +<p>You also can add a folder containing your application&#8217;s include files to the +<code>APP_INC</code> variable (do not forget the <code>-I</code> prefix):</p> +</li> +</ol> +</div> +<div class="listingblock"> +<div class="content"> +<pre class="highlight"><code class="language-makefile" data-lang="makefile"># User's application include folders (don't forget the '-I' before each entry) +APP_INC = -I . -I ../somewhere/include_stuff_folder</code></pre> +</div> +</div> +<div style="page-break-after: always;"></div> +</div> +</div> +<div class="sect1"> +<h2 id="_application_specific_processor_configuration">8. Application-Specific Processor Configuration</h2> +<div class="sectionbody"> +<div class="paragraph"> +<p>The processor&#8217;s configuration options, which are mainly defined via the top entity VHDL generics, allow +to tailor the entire SoC according to the application-specific requirements. Note that this chapter does not focus on optional +<em>SoC features</em> like IO/peripheral modules - it rather gives ideas on how to optimize for <em>overall goals</em> +like performance and area.</p> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +Please keep in mind that optimizing the design in one direction (like performance) will also effect other potential +optimization goals (like area and energy). +</td> +</tr> +</table> +</div> +<div class="sect2"> +<h3 id="_optimize_for_performance">8.1. Optimize for Performance</h3> +<div class="paragraph"> +<p>The following points show some concepts to optimize the processor for performance regardless of the costs +(i.e. increasing area and energy requirements):</p> +</div> +<div class="ulist"> +<ul> +<li> +<p>Enable all performance-related RISC-V CPU extensions that implement dedicated hardware accelerators instead +of emulating operations entirely in software: <code>M</code>, <code>C</code>, <code>Zfinx</code></p> +</li> +<li> +<p>Enable mapping of compleX CPU operations to dedicated hardware: <code>FAST_MUL_EN &#8658; true</code> to use DSP slices for +multiplications, <code>FAST_SHIFT_EN &#8658; true</code> use a fast barrel shifter for shift operations.</p> +</li> +<li> +<p>Implement the instruction cache: <code>ICACHE_EN &#8658; true</code></p> +</li> +<li> +<p>Use as many <em>internal</em> memory as possible to reduce memory access latency: <code>MEM_INT_IMEM_EN &#8658; true</code> and +<code>MEM_INT_DMEM_EN &#8658; true</code>, maximize <code>MEM_INT_IMEM_SIZE</code> and <code>MEM_INT_DMEM_SIZE</code></p> +</li> +<li> +<p><em>To be continued&#8230;&#8203;</em></p> +</li> +</ul> +</div> +</div> +<div class="sect2"> +<h3 id="_optimize_for_size">8.2. Optimize for Size</h3> +<div class="paragraph"> +<p>The NEORV32 is a size-optimized processor system that is intended to fit into tiny niches within large SoC +designs or to be used a customized microcontroller in really tiny / low-power FPGAs (like Lattice iCE40). +Here are some ideas how to make the processor even smaller while maintaining it&#8217;s <em>general purpose system</em> +concept and maximum RISC-V compatibility.</p> +</div> +<div class="paragraph"> +<p><strong>SoC</strong></p> +</div> +<div class="ulist"> +<ul> +<li> +<p>This is obvious, but exclude all unused optional IO/peripheral modules from synthesis via the processor +configuration generics.</p> +</li> +<li> +<p>If an IO module provides an option to configure the number of "channels", constrain this number to the +actually required value (e.g. the PWM module <code>IO_PWM_NUM_CH</code> or the external interrupt controller <code>XIRQ_NUM_CH</code>).</p> +</li> +<li> +<p>Disable the instruction cache (<code>ICACHE_EN &#8658; false</code>) if the design only uses processor-internal IMEM +and DMEM memories.</p> +</li> +<li> +<p><em>To be continued&#8230;&#8203;</em></p> +</li> +</ul> +</div> +<div class="paragraph"> +<p><strong>CPU</strong></p> +</div> +<div class="ulist"> +<ul> +<li> +<p>Use the <em>embedded</em> RISC-V CPU architecture extension (<code>CPU_EXTENSION_RISCV_E</code>) to reduce block RAM utilization.</p> +</li> +<li> +<p>The compressed instructions extension (<code>CPU_EXTENSION_RISCV_C</code>) requires additional logic for the decoder but +also reduces program code size by approximately 30%.</p> +</li> +<li> +<p>If not explicitly used/required, exclude the CPU standard counters <code>[m]instret[h]</code> +(number of instruction) and <code>[m]cycle[h]</code> (number of cycles) from synthesis by disabling the <code>Zicntr</code> ISA extension +(note, this is not RISC-V compliant).</p> +</li> +<li> +<p>Map CPU shift operations to a small and iterative shifter unit (<code>FAST_SHIFT_EN &#8658; false</code>).</p> +</li> +<li> +<p>If you have unused DSP block available, you can map multiplication operations to those slices instead of +using LUTs to implement the multiplier (<code>FAST_MUL_EN &#8658; true</code>).</p> +</li> +<li> +<p>If there is no need to execute division in hardware, use the <code>Zmmul</code> extension instead of the full-scale +<code>M</code> extension.</p> +</li> +<li> +<p>Disable CPU extension that are not explicitly used.</p> +</li> +<li> +<p><em>To be continued&#8230;&#8203;</em></p> +</li> +</ul> +</div> +</div> +<div class="sect2"> +<h3 id="_optimize_for_clock_speed">8.3. Optimize for Clock Speed</h3> +<div class="paragraph"> +<p>The NEORV32 Processor and CPU are designed to provide minimal logic between register stages to keep the +critical path as short as possible. When enabling additional extension or modules the impact on the existing +logic is also kept at a minimum to prevent timing degrading. If there is a major impact on existing +logic (example: many physical memory protection address configuration registers) the VHDL code automatically +adds additional register stages to maintain critical path length. Obviously, this increases operation latency.</p> +</div> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +Enable the "ASIC style" register file option (<code>REGFILE_HW_RST</code>) to obtain maximum clock speed for the CPU (at the cost of +of an increased hardware footprint). +</td> +</tr> +</table> +</div> +<div class="paragraph"> +<p>In order to optimize for a minimal critical path (= maximum clock speed) the following points should be considered:</p> +</div> +<div class="ulist"> +<ul> +<li> +<p>Complex CPU extensions (in terms of hardware requirements) should be avoided (examples: floating-point unit, physical memory protection).</p> +</li> +<li> +<p>Large carry chains (&gt;32-bit) should be avoided (i.e. constrain the HPM counter sizes via <code>HPM_CNT_WIDTH</code>).</p> +</li> +<li> +<p>If the target FPGA provides sufficient DSP resources, CPU multiplication operations can be mapped to DSP slices (<code>FAST_MUL_EN &#8658; true</code>) +reducing LUT usage and critical path impact while also increasing overall performance.</p> +</li> +<li> +<p>Use the synchronous (registered) RX path configuration of the external bus interface (<code>XBUS_ASYNC_RX &#8658; false</code>).</p> +</li> +<li> +<p><em>To be continued&#8230;&#8203;</em></p> +</li> +</ul> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +The short and fixed-length critical path allows to integrate the core into existing clock domains. +So no clock domain-crossing and no sub-clock generation is required. However, for very high clock +frequencies (this is technology / platform dependent) clock domain crossing becomes crucial for chip-internal +connections. +</td> +</tr> +</table> +</div> +</div> +<div class="sect2"> +<h3 id="_optimize_for_energy">8.4. Optimize for Energy</h3> +<div class="paragraph"> +<p>There are no <em>dedicated</em> configuration options to optimize the processor for energy (minimal consumption; +energy/instruction ratio) yet. However, a reduced processor area (<a href="#_optimize_for_size">Optimize for Size</a>) will also reduce +static energy consumption.</p> +</div> +<div class="paragraph"> +<p>To optimize your setup for low-power applications, you can make use of the CPU sleep mode (<code>wfi</code> instruction). +Put the CPU to sleep mode whenever possible. If the clok gating feature is enabled (<code>CLOCK_GATING_EN</code>) the entire +CPU complex will be disconnected from the clock tree while in sleep mode.</p> +</div> +<div class="paragraph"> +<p>Disable all processor modules that are not actually used (exclude them +from synthesis if the will be <em>never</em> used; disable a module via it&#8217;s control register if the module is not +<em>currently</em> used).</p> +</div> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +<div class="title">Processor-internal clock generator shutdown</div> +If <em>no</em> IO/peripheral module is currently enabled, the processor&#8217;s internal clock generator circuit will be +shut down reducing switching activity and thus, dynamic energy consumption. +</td> +</tr> +</table> +</div> +<div style="page-break-after: always;"></div> +</div> +</div> +</div> +<div class="sect1"> +<h2 id="_adding_custom_hardware_modules">9. Adding Custom Hardware Modules</h2> +<div class="sectionbody"> +<div class="paragraph"> +<p>In resemblance to the RISC-V ISA, the NEORV32 processor was designed to ease customization and <em>extensibility</em>. +The processor provides several predefined options to add application-specific custom hardware modules and accelerators. +A <a href="#_comparative_summary">Comparative Summary</a> is given at the end of this section.</p> +</div> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +<div class="title">Debugging/Testing Custom Hardware Modules</div> +Custom hardware IP modules connected via the external bus interface or integrated as CFU can be debugged "in-system" using the +"bus explorer" example program (<code>sw/example_bus_explorer</code>). This program provides an interactive console (via UART0) +that allows to perform arbitrary read and write access from/to any memory-mapped register. +</td> +</tr> +</table> +</div> +<div class="sect2"> +<h3 id="_standard_external_interfaces">9.1. Standard (<em>External</em>) Interfaces</h3> +<div class="paragraph"> +<p>The processor already provides a set of standard interfaces that are intended to connect <em>chip-external</em> devices. +However, these interfaces can also be used chip-internally. The most suitable interfaces are +<a href="https://stnolting.github.io/neorv32/#_general_purpose_input_and_output_port_gpio">GPIO</a>, +<a href="https://stnolting.github.io/neorv32/#_primary_universal_asynchronous_receiver_and_transmitter_uart0">UART</a>, +<a href="https://stnolting.github.io/neorv32/#_serial_peripheral_interface_controller_spi">SPI</a> and +<a href="https://stnolting.github.io/neorv32/#_two_wire_serial_interface_controller_twi">TWI</a>.</p> +</div> +<div class="paragraph"> +<p>The SPI and especially the GPIO interfaces might be the most straightforward approaches since they +have a minimal protocol overhead. Device-specific interrupt capabilities could be added using the +<a href="https://stnolting.github.io/neorv32/#_external_interrupt_controller_xirq">External Interrupt Controller (XIRQ)</a>.</p> +</div> +<div class="paragraph"> +<p>Beyond simplicity, these interface only provide a very limited bandwidth and require more sophisticated +software handling ("bit-banging" for the GPIO). Hence, it is not recommend to use them for <em>chip-internal</em> communication.</p> +</div> +</div> +<div class="sect2"> +<h3 id="_external_bus_interface">9.2. External Bus Interface</h3> +<div class="paragraph"> +<p>The <a href="https://stnolting.github.io/neorv32/#_processor_external_bus_interface_xbus">External Bus Interface</a> +provides the classic approach for attaching custom IP. By default, the bus interface implements the widely adopted +Wishbone interface standard. This project also includes wrappers to convert to other protocol standards like ARM&#8217;s +AXI4-Lite or Intel&#8217;s Avalon protocols. By using a full-featured bus protocol, complex SoC designs can be implemented +including several modules and even multi-core architectures. Many FPGA EDA tools provide graphical editors to build +and customize whole SoC architectures and even include pre-defined IP libraries.</p> +</div> +<div class="imageblock"> +<div class="content"> +<img src="../img/neorv32_axi_soc.png" alt="neorv32 axi soc"> +</div> +<div class="title">Figure 2. Example AXI SoC using AMD Vivado</div> +</div> +<div class="paragraph"> +<p>Custom hardware modules attached to the processor&#8217;s bus interface have no limitations regarding their functionality. +User-defined interfaces (like DDR memory access) can be implemented and the hardware module can operate completely +independent of the CPU.</p> +</div> +<div class="paragraph"> +<p>The bus interface uses a memory-mapped approach. All data transfers are handled by simple load/store operations since the +external bus interface is mapped into the processor&#8217;s <a href="https://stnolting.github.io/neorv32/#_address_space">address space</a>. +This allows a very simple still high-bandwidth communications. However, high bus traffic may increase access latencies.</p> +</div> +</div> +<div class="sect2"> +<h3 id="_custom_functions_subsystem">9.3. Custom Functions Subsystem</h3> +<div class="paragraph"> +<p>The <a href="https://stnolting.github.io/neorv32/#_custom_functions_subsystem_cfs">Custom Functions Subsystem (CFS)</a> is +an "empty" template for a memory-mapped, processor-internal module.</p> +</div> +<div class="paragraph"> +<p>The basic idea of this subsystem is to provide a convenient, simple and flexible platform, where the user can +concentrate on implementing the actual design logic rather than taking care of the communication between the +CPU/software and the design logic. Note that the CFS does not have direct access to memory. All data (and control +instruction) have to be send by the CPU.</p> +</div> +<div class="paragraph"> +<p>The use-cases for the CFS include medium-scale hardware accelerators that need to be tightly-coupled to the CPU. +Potential use cases could be DSP modules like CORDIC, cryptographic accelerators or custom interfaces (like IIS).</p> +</div> +</div> +<div class="sect2"> +<h3 id="_custom_functions_unit">9.4. Custom Functions Unit</h3> +<div class="paragraph"> +<p>The <a href="https://stnolting.github.io/neorv32/#_custom_functions_unit_cfu">Custom Functions Unit (CFU)</a> is a functional +unit that is integrated right into the CPU&#8217;s pipeline. It allows to implement custom RISC-V instructions. +This extension option is intended for rather small logic that implements operations, which cannot be emulated +in pure software in an efficient way. Since the CFU has direct access to the core&#8217;s register file it can operate +with minimal data latency.</p> +</div> +</div> +<div class="sect2"> +<h3 id="_comparative_summary">9.5. Comparative Summary</h3> +<div class="paragraph"> +<p>The following table gives a comparative summary of the most important factors when choosing one of the +chip-internal extension options:</p> +</div> +<div class="ulist"> +<ul> +<li> +<p><a href="https://stnolting.github.io/neorv32/#_custom_functions_unit_cfu">Custom Functions Unit (CFU)</a> for CPU-internal custom RISC-V instructions</p> +</li> +<li> +<p><a href="https://stnolting.github.io/neorv32/#_custom_functions_subsystem_cfs">Custom Functions Subsystem (CFS)</a> for tightly-coupled processor-internal co-processors</p> +</li> +<li> +<p><a href="https://stnolting.github.io/neorv32/#_processor_external_memory_interface_wishbone">External Bus Interface (WISHBONE)</a> for processor-external memory-mapped modules</p> +</li> +</ul> +</div> +<table class="tableblock frame-all grid-rows stretch"> +<caption class="title">Table 1. Comparison of On-Chip Extension Options</caption> +<colgroup> +<col style="width: 25%;"> +<col style="width: 25%;"> +<col style="width: 25%;"> +<col style="width: 25%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-left valign-top"></th> +<th class="tableblock halign-center valign-top">Custom Functions Unit (CFU)</th> +<th class="tableblock halign-center valign-top">Custom Functions Subsystem (CFS)</th> +<th class="tableblock halign-center valign-top">External Bus Interface</th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><strong>RTL location</strong></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">CPU-internal</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">processor-internal</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">processor-external</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><strong>HW complexity/size</strong></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">small</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">medium</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">large</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><strong>CPU-independent operation</strong></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">no</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">yes</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">yes</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><strong>CPU interface</strong></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">register file access</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">memory-mapped</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">memory-mapped</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><strong>Low-level access mechanism</strong></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">custom instructions</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">load/store</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">load/store</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><strong>Access latency</strong></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">minimal</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">low</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">medium to high</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><strong>External IO interfaces</strong></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">not supported</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">yes, but limited</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">yes, user-defined</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><strong>Exception capability</strong></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">yes</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">no</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">no</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><strong>Interrupt capability</strong></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">no</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">yes</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">user-defined</p></td> +</tr> +</tbody> +</table> +<div style="page-break-after: always;"></div> +</div> +</div> +</div> +<div class="sect1"> +<h2 id="_customizing_the_internal_bootloader">10. Customizing the Internal Bootloader</h2> +<div class="sectionbody"> +<div class="paragraph"> +<p>The NEORV32 bootloader provides several options to configure and customize it for a certain application setup. +This configuration is done by passing <em>defines</em> when compiling the bootloader. Of course you can also +modify to bootloader source code to provide a setup that perfectly fits your needs.</p> +</div> +<div class="admonitionblock important"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-important" title="Important"></i> +</td> +<td class="content"> +Each time the bootloader sources are modified, the bootloader has to be re-compiled (and re-installed to the +bootloader ROM) and the processor has to be re-synthesized. +</td> +</tr> +</table> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +Keep in mind that the maximum size for the bootloader is limited to 8kB and it should be compiled using the +minimal base &amp; privileged ISA <code>rv32i_zicsr_zifencei</code> only to ensure it can work independently of the actual CPU configuration. +</td> +</tr> +</table> +</div> +<table class="tableblock frame-all grid-rows stretch"> +<caption class="title">Table 2. Bootloader configuration parameters</caption> +<colgroup> +<col style="width: 18.1818%;"> +<col style="width: 9.0909%;"> +<col style="width: 18.1818%;"> +<col style="width: 54.5455%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-left valign-top">Parameter</th> +<th class="tableblock halign-center valign-top">Default</th> +<th class="tableblock halign-center valign-top">Legal values</th> +<th class="tableblock halign-left valign-top">Description</th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-center valign-top" colspan="4"><p class="tableblock">Memory layout</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>EXE_BASE_ADDR</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>0x00000000</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><em>any</em></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Base address / boot address for the executable (see section "Address Space" in the NEORV32 data sheet)</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top" colspan="4"><p class="tableblock">Serial console interface</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>UART_EN</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>1</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>0</code>, <code>1</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Set to <code>0</code> to disable UART0 (no serial console at all)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>UART_BAUD</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>19200</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><em>any</em></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Baud rate of UART0</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>UART_HW_HANDSHAKE_EN</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>0</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>0</code>, <code>1</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Set to <code>1</code> to enable UART0 hardware flow control</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top" colspan="4"><p class="tableblock">Status LED</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>STATUS_LED_EN</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>1</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>0</code>, <code>1</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Enable bootloader status led ("heart beat") at <code>GPIO</code> output port pin #<code>STATUS_LED_PIN</code> when <code>1</code></p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>STATUS_LED_PIN</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>0</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>0</code> &#8230;&#8203; <code>31</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>GPIO</code> output pin used for the high-active status LED</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top" colspan="4"><p class="tableblock">Auto-boot configuration</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>AUTO_BOOT_TIMEOUT</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>10</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><em>any</em></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Time in seconds after the auto-boot sequence starts (if there is no UART input by the user); set to 0 to disabled auto-boot sequence</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top" colspan="4"><p class="tableblock">SPI configuration</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>SPI_EN</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>1</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>0</code>, <code>1</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Set <code>1</code> to enable the usage of the SPI module (including load/store executables from/to SPI flash options)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>SPI_FLASH_CS</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>0</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>0</code> &#8230;&#8203; <code>7</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">SPI chip select output (<code>spi_csn_o</code>) for selecting flash</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>SPI_FLASH_ADDR_BYTES</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>3</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>2</code>, <code>3</code>, <code>4</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">SPI flash address size in number of bytes (2=16-bit, 3=24-bit, 4=32-bit)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>SPI_FLASH_SECTOR_SIZE</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>65536</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><em>any</em></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">SPI flash sector size in bytes</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>SPI_FLASH_CLK_PRSC</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>CLK_PRSC_8</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>CLK_PRSC_2</code> <code>CLK_PRSC_4</code> <code>CLK_PRSC_8</code> <code>CLK_PRSC_64</code> <code>CLK_PRSC_128</code> <code>CLK_PRSC_1024</code> <code>CLK_PRSC_2024</code> <code>CLK_PRSC_4096</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">SPI clock pre-scaler (dividing main processor clock)</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>SPI_BOOT_BASE_ADDR</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>0x00400000</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><em>any</em> 32-bit value</p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Defines the <em>base</em> address of the executable in external flash</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top" colspan="4"><p class="tableblock">XIP configuration</p></td> +</tr> +<tr> +<td class="tableblock halign-left valign-top"><p class="tableblock"><code>XIP_EN</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>0</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>0</code>, <code>1</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">Set <code>1</code> to enable the XIP options</p></td> +</tr> +</tbody> +</table> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +The XIP options re-use the "SPI configuration" options for configuring the XIP&#8217;s SPI connection. +</td> +</tr> +</table> +</div> +<div class="paragraph"> +<p>Each configuration parameter is implemented as C-language <code>define</code> that can be manually overridden (<em>redefined</em>) when +invoking the bootloader&#8217;s makefile. The according parameter and its new value has to be <em>appended</em> +(using <code>+=</code>) to the makefile <code>USER_FLAGS</code> variable. Make sure to use the <code>-D</code> prefix here.</p> +</div> +<div class="paragraph"> +<p>For example, to configure a UART Baud rate of 57600 and redirecting the status LED to GPIO output pin 20 +use the following command:</p> +</div> +<div class="listingblock"> +<div class="title">Listing 10. Example: customizing, re-compiling and re-installing the bootloader</div> +<div class="content"> +<pre class="highlight"><code class="language-console" data-lang="console">sw/bootloader$ make USER_FLAGS+=-DUART_BAUD=57600 USER_FLAGS+=-DSTATUS_LED_PIN=20 clean_all bootloader</code></pre> +</div> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +The <code>clean_all</code> target ensure that all libraries are re-compiled. The <code>bootloader</code> target will automatically +compile and install the bootloader to the HDL boot ROM (updating <code>rtl/core/neorv32_bootloader_image.vhd</code>). +</td> +</tr> +</table> +</div> +<div class="sect2"> +<h3 id="_auto_boot_configuration">10.1. Auto-Boot Configuration</h3> +<div class="paragraph"> +<p>The default bootloader provides a UART-based user interface that allows to upload new executables +at any time. Optionally, the executable can also be programmed to an external SPI flash by the bootloader (see +section <a href="#_programming_an_external_spi_flash_via_the_bootloader">Programming an External SPI Flash via the Bootloader</a>).</p> +</div> +<div class="paragraph"> +<p>The bootloader also provides an <em>automatic boot sequence</em> (auto-boot) which will start copying an executable +from external SPI flash to IMEM using the default SPI configuration. By this, the default bootloader +provides a "non-volatile program storage" mechanism that automatically boots from external SPI flash +(after <code>AUTO_BOOT_TIMEOUT</code>) while still providing the option to re-program the SPI flash at any time +via the UART console.</p> +</div> +<div style="page-break-after: always;"></div> +</div> +</div> +</div> +<div class="sect1"> +<h2 id="_programming_an_external_spi_flash_via_the_bootloader">11. Programming an External SPI Flash via the Bootloader</h2> +<div class="sectionbody"> +<div class="paragraph"> +<p>The default processor-internal NEORV32 bootloader supports automatic booting from an external SPI flash. +This guide shows how to write an executable to the SPI flash via the bootloader so it can be automatically +fetched and executed after processor reset. For example, you can use a section of the FPGA bitstream configuration +memory to store an application executable.</p> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">Customization</div> +This section assumes the <em>default</em> configuration of the NEORV32 bootloader. +See section <a href="#_customizing_the_internal_bootloader">Customizing the Internal Bootloader</a> on how to customize the bootloader and its setting +(for example the SPI chip-select port, the SPI clock speed or the <strong>flash base address</strong> for storing the executable). +</td> +</tr> +</table> +</div> +<div class="sect2"> +<h3 id="_programming_an_executable">11.1. Programming an Executable</h3> +<div class="olist arabic"> +<ol class="arabic" start="1"> +<li> +<p>At first, reset the NEORV32 processor and wait until the bootloader start screen appears in your terminal program.</p> +</li> +<li> +<p>Abort the auto boot sequence and start the user console by pressing any key.</p> +</li> +<li> +<p>Press u to upload the executable that you want to store to the external flash:</p> +</li> +</ol> +</div> +<div class="listingblock"> +<div class="content"> +<pre class="highlight"><code>CMD:&gt; u +Awaiting neorv32_exe.bin...</code></pre> +</div> +</div> +<div class="olist arabic"> +<ol class="arabic" start="4"> +<li> +<p>Send the binary in raw binary via your terminal program. When the upload is completed and "OK" +appears, press <code>s</code> to trigger the programming of the flash (do not execute the image via the <code>e</code> +command as this might corrupt the image):</p> +</li> +</ol> +</div> +<div class="listingblock"> +<div class="content"> +<pre class="highlight"><code>CMD:&gt; u +Awaiting neorv32_exe.bin... OK +CMD:&gt; s +Write 0x000013FC bytes to SPI flash @ 0x02000000? (y/n)</code></pre> +</div> +</div> +<div class="olist arabic"> +<ol class="arabic" start="5"> +<li> +<p>The bootloader shows the size of the executable and the base address inside the SPI flash where the +executable is going to be stored. A prompt appears: Type <code>y</code> to start the programming or type <code>n</code> to +abort.</p> +</li> +</ol> +</div> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +Section <a href="#_customizing_the_internal_bootloader">Customizing the Internal Bootloader</a> show the according C-language <code>define</code> that can be modified +to specify the base address of the executable inside the SPI flash. +</td> +</tr> +</table> +</div> +<div class="listingblock"> +<div class="content"> +<pre class="highlight"><code>CMD:&gt; u +Awaiting neorv32_exe.bin... OK +CMD:&gt; s +Write 0x000013FC bytes to SPI flash @ 0x02000000? (y/n) y +Flashing... OK +CMD:&gt;</code></pre> +</div> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +The bootloader stores the executable in <strong>little-endian</strong> byte-order to the flash. +</td> +</tr> +</table> +</div> +<div class="olist arabic"> +<ol class="arabic" start="6"> +<li> +<p>If "OK" appears in the terminal line, the programming process was successful. Now you can use the +auto boot sequence to automatically boot your application from the flash at system start-up without +any user interaction.</p> +</li> +</ol> +</div> +<div style="page-break-after: always;"></div> +</div> +</div> +</div> +<div class="sect1"> +<h2 id="_packaging_the_processor_as_vivado_ip_block">12. Packaging the Processor as Vivado IP Block</h2> +<div class="sectionbody"> +<div class="paragraph"> +<p>Packaging the entire processor as IP module allows easy integration of the core (or even several cores) +into a block-design-based Vivado project. The NEORV32 repository provides a full-scale TCL script that +automatically packages the processor as Vivado IP block. For this, a specialized wrapper for the processor&#8217;s +top entity is provided (<code>rtl/system_integration/neorv32_vivado_ip.vhd</code>) that features AXI4-Lite (via XBUS) +and AXI4-Stream (via SLINK) compatible interfaces.</p> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">General AXI Wrapper</div> +The provided AXI wrapper can also be used for custom (AXI) setups outside of Vivado and/or IP block designs. +</td> +</tr> +</table> +</div> +<div class="imageblock"> +<div class="content"> +<img src="../img/vivado_ip_soc.png" alt="vivado ip soc"> +</div> +<div class="title">Figure 3. Example Vivado SoC using the NEORV32 IP Block</div> +</div> +<div class="paragraph"> +<p>Besides packaging the HDL modules, the TCL script also generates a simplified customization GUI that allows an easy +and intuitive configuration of the processor. The rather complex VHDL configuration generics are renamed and provided +with tool tips to make it easier to understand the different configuration options.</p> +</div> +<div class="imageblock"> +<div class="content"> +<img src="../img/vivado_ip_gui.png" alt="vivado ip gui"> +</div> +<div class="title">Figure 4. NEORV32 IP Customization GUI</div> +</div> +<div class="paragraph"> +<p>The following steps show how to package the processor using the provided TCL script and how to import +the generated IP block into the Vivado IP repository.</p> +</div> +<div class="olist arabic"> +<ol class="arabic" start="1"> +<li> +<p>Open the Vivado GUI.</p> +</li> +<li> +<p>In GUI mode select either "Tools &#8594; Run TCL Script" to directly execute the script or open the TCL +shell ("Window &#8594; Tcl Console") to manually invoke the script.</p> +</li> +<li> +<p>Use <code>cd</code> in the TCL console to navigate to the project&#8217;s <code>neorv32/rtl/system_integration</code> folder.</p> +</li> +<li> +<p>Execute <code>source neorv32_vivado_ip.tcl</code> in the TCL console.</p> +</li> +<li> +<p>A second Vivado instance will open automatically packaging the IP module. After this process is completed, +the second Vivado instance will automatically close again.</p> +</li> +<li> +<p>A new folder <code>neorv32_vivado_ip_work</code> is created in <code>neorv32/rtl/system_integration</code> which contains the IP-packaging +Vivado project.</p> +</li> +<li> +<p>Inside, the <code>packaged_ip</code> folder provides the actual IP module.</p> +</li> +<li> +<p>Open your design project in Vivado.</p> +</li> +<li> +<p>Click on "Settings" in the "Project Manager" on the left side.</p> +</li> +<li> +<p>Under "Project Settings" expand the "IP" section and click on "Repository".</p> +</li> +<li> +<p>Click the large plus button and select the previously generated IP folder (<code>path/to/neorv32/rtl/system_integration/neorv32_vivado_ip_work/packaged_ip</code>).</p> +</li> +<li> +<p>Click "Select" and close the Settings menu with "Apply" and "OK".</p> +</li> +<li> +<p>You will find the NEORV32 in the "User Repository" section of the Vivado IP catalog.</p> +</li> +</ol> +</div> +<div class="admonitionblock warning"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-warning" title="Warning"></i> +</td> +<td class="content"> +<div class="title">Combinatorial Loops DRC Errors</div> +If the TRNG is enabled it is recommended to add the following commands to the project&#8217;s constraints file in order +to prevent DRC errors during bitstream generation: +</td> +</tr> +</table> +</div> +<div class="listingblock"> +<div class="content"> +<pre class="highlight"><code class="language-xdc" data-lang="xdc">set_property SEVERITY {warning} [get_drc_checks LUTLP-1] +set_property IS_ENABLED FALSE [get_drc_checks LUTLP-1] +set_property ALLOW_COMBINATORIAL_LOOPS TRUE</code></pre> +</div> +</div> +<div style="page-break-after: always;"></div> +</div> +</div> +<div class="sect1"> +<h2 id="_simulating_the_processor">13. Simulating the Processor</h2> +<div class="sectionbody"> +<div class="paragraph"> +<p>The NEORV32 project includes a core CPU, built-in peripherals in the Processor Subsystem, and additional peripherals in +the templates and examples. +Therefore, there is a wide range of possible testing and verification strategies.</p> +</div> +<div class="paragraph"> +<p>On the one hand, a simple smoke testbench allows ensuring that functionality is correct from a software point of view. +That is used for running the RISC-V architecture tests, in order to guarantee compliance with the ISA specification(s).</p> +</div> +<div class="paragraph"> +<p>On the other hand, <a href="http://vunit.github.io/">VUnit</a> and <a href="http://vunit.github.io/verification_components/user_guide.html">Verification Components</a> +are used for verifying the functionality of the various peripherals from a hardware point of view.</p> +</div> +<div class="admonitionblock important"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-important" title="Important"></i> +</td> +<td class="content"> +<div class="title">AMD Vivado / ISIM</div> +When using AMD Vivado (ISIM for simulation) make sure to <strong>turn of</strong> "incremental compilation" (<em>Project Setting</em> +&#8594; <em>Simulation</em> &#8594; <em>Advanced</em> &#8594; _Enable incremental compilation). This will slow down simulation relaunch but will +ensure that all application images (<code>*_image.vhd</code>) are reanalyzed when recompiling the NEORV32 application or bootloader +</td> +</tr> +</table> +</div> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +The processor can check if it is being <em>simulated</em> by checking the SYSINFO <em>SYSINFO_SOC_IS_SIM</em> flag +(see <a href="https://stnolting.github.io/neorv32/#_system_configuration_information_memory_sysinfo" class="bare">https://stnolting.github.io/neorv32/#_system_configuration_information_memory_sysinfo</a>). +Note that this flag is not guaranteed to be set correctly (depending on the HDL toolchain&#8217;s pragma support). +</td> +</tr> +</table> +</div> +<div class="sect2"> +<h3 id="_testbench">13.1. Testbench</h3> +<div class="paragraph"> +<p>A plain-VHDL (no third-party libraries) testbench (<code>sim/simple/neorv32_tb.simple.vhd</code>) can be used for simulating and +testing the processor. +This testbench features a 100MHz clock and enables all optional peripheral and CPU extensions except for the <code>E</code>.</p> +</div> +<div class="admonitionblock important"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-important" title="Important"></i> +</td> +<td class="content"> +In the simple testbench several optional extensions are disabled, such as C or E. +If software is compiled using instructions corresponding to disabled extensions, the whole processor will hang in an eternal exception loop and, therefore, the simulation will timeout. +The <code>MARCH</code> must be a subset of the extensions enabled in the testbench. +</td> +</tr> +</table> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">True Random Number Generator</div> +The NEORV32 TRNG will be set to "simulation mode" when enabled for simulation (replacing the ring-oscillators +by pseudo-random LFSRs). See the neoTRNG documentation for more information. +</td> +</tr> +</table> +</div> +<div class="paragraph"> +<p>The simulation setup is configured via the "User Configuration" section located right at the beginning of +the testbench&#8217;s architecture. Each configuration constant provides comments to explain the functionality.</p> +</div> +<div class="paragraph"> +<p>Besides the actual NEORV32 Processor, the testbench also simulates "external" components that are connected +to the processor&#8217;s external bus/memory interface. These components are:</p> +</div> +<div class="ulist"> +<ul> +<li> +<p>an external instruction memory (that also allows booting from it)</p> +</li> +<li> +<p>an external data memory</p> +</li> +<li> +<p>an external memory to simulate "external IO devices"</p> +</li> +<li> +<p>a memory-mapped registers to trigger the processor&#8217;s interrupt signals</p> +</li> +</ul> +</div> +<div class="paragraph"> +<p>The following table shows the base addresses of these four components and their default configuration and +properties:</p> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="paragraph"> +<p>Attributes:</p> +</div> +<div class="ulist"> +<ul> +<li> +<p><code>r</code> = read</p> +</li> +<li> +<p><code>w</code> = write</p> +</li> +<li> +<p><code>e</code> = execute</p> +</li> +<li> +<p><code>8</code> = byte-accessible</p> +</li> +<li> +<p><code>16</code> = half-word-accessible</p> +</li> +<li> +<p><code>32</code> = word-accessible</p> +</li> +</ul> +</div> +</td> +</tr> +</table> +</div> +<table class="tableblock frame-all grid-rows stretch"> +<caption class="title">Table 3. Testbench: processor-external memories</caption> +<colgroup> +<col style="width: 17.3913%;"> +<col style="width: 13.0434%;"> +<col style="width: 21.7391%;"> +<col style="width: 47.8262%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-center valign-top">Base address</th> +<th class="tableblock halign-right valign-top">Size</th> +<th class="tableblock halign-center valign-top">Attributes</th> +<th class="tableblock halign-left valign-top">Description</th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>0x00000000</code></p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock"><code>imem_size_c</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>r/w/e 8/16/32</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">external IMEM (initialized with application image)</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>0x80000000</code></p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock"><code>dmem_size_c</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>r/w/e 8/16/32</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">external DMEM</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>0xf0000000</code></p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">64 bytes</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>r/w/e 8/16/32</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">external "IO" memory</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>0xff000000</code></p></td> +<td class="tableblock halign-right valign-top"><p class="tableblock">4 bytes</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>-/w/- -/-/32</code></p></td> +<td class="tableblock halign-left valign-top"><p class="tableblock">memory-mapped register to trigger "machine external", "machine software" and "SoC Fast Interrupt" interrupts</p></td> +</tr> +</tbody> +</table> +<div class="admonitionblock important"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-important" title="Important"></i> +</td> +<td class="content"> +The simulated NEORV32 does not use the bootloader and <em>directly boots</em> the current application image (from +the <code>rtl/core/neorv32_application_image.vhd</code> image file). +</td> +</tr> +</table> +</div> +<div class="admonitionblock important"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-important" title="Important"></i> +</td> +<td class="content"> +<div class="title">UART output during simulation</div> +Data written to the NEORV32 UART0 / UART1 transmitter is send to a virtual UART receiver implemented +as part of the testbench. Received chars are send to the simulator console and are also stored to a log file +(<code>neorv32.testbench_uart0.out</code> for UART0, <code>neorv32.testbench_uart1.out</code> for UART1) inside the simulation&#8217;s home folder. +<strong>Please note that printing via the native UART receiver takes a lot of time.</strong> For faster simulation console output +see section <a href="#_faster_simulation_console_output">Faster Simulation Console Output</a>. +</td> +</tr> +</table> +</div> +</div> +<div class="sect2"> +<h3 id="_faster_simulation_console_output">13.2. Faster Simulation Console Output</h3> +<div class="paragraph"> +<p>When printing data via the physical UART the communication speed will always be based on the configured BAUD +rate. For a simulation this might take some time. To have faster output you can enable the <strong>simulation mode</strong> +for UART0/UART1 (see section <a href="https://stnolting.github.io/neorv32/#_primary_universal_asynchronous_receiver_and_transmitter_uart0">Documentation: Primary Universal Asynchronous Receiver and Transmitter (UART0)</a>).</p> +</div> +<div class="paragraph"> +<p>ASCII data sent to UART0|UART1 will be immediately printed to the simulator console and logged to files in the simulator +execution directory:</p> +</div> +<div class="ulist"> +<ul> +<li> +<p><code>neorv32.uart?.sim_mode.text.out</code>: ASCII data.</p> +</li> +</ul> +</div> +<div class="paragraph"> +<p>You can "automatically" enable the simulation mode of UART0/UART1 when compiling an application. +In this case, the "real" UART0/UART1 transmitter unit is permanently disabled. +To enable the simulation mode just compile and install your application and add <em>UART?_SIM_MODE</em> to the compiler&#8217;s +<em>USER_FLAGS</em> variable (do not forget the <code>-D</code> suffix flag):</p> +</div> +<div class="listingblock"> +<div class="content"> +<pre class="highlight"><code class="language-bash" data-lang="bash">sw/example/demo_blink_led$ make USER_FLAGS+=-DUART0_SIM_MODE clean_all all</code></pre> +</div> +</div> +<div class="paragraph"> +<p>The provided define will change the default UART0/UART1 setup function in order to set the simulation +mode flag in the according UART&#8217;s control register.</p> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +The UART simulation output (to file and to screen) outputs "complete lines" at once. A line is +completed with a line feed (newline, ASCII <code>\n</code> = 10). +</td> +</tr> +</table> +</div> +</div> +<div class="sect2"> +<h3 id="_simulation_using_a_shell_script_with_ghdl">13.3. Simulation using a shell script (with GHDL)</h3> +<div class="paragraph"> +<p>To simulate the processor using <em>GHDL</em> navigate to the <code>sim/simple/</code> folder and run the provided shell script. +Any arguments that are provided while executing this script are passed to GHDL. +For example the simulation time can be set to 20ms using <code>--stop-time=20ms</code> as argument.</p> +</div> +<div class="listingblock"> +<div class="content"> +<pre class="highlight"><code class="language-bash" data-lang="bash">neorv32/sim/simple$ sh ghdl.sh --stop-time=20ms</code></pre> +</div> +</div> +</div> +<div class="sect2"> +<h3 id="_simulation_using_application_makefiles_in_console_with_ghdl">13.4. Simulation using Application Makefiles (In-Console with GHDL)</h3> +<div class="paragraph"> +<p>To directly compile and run a program in the console (using the default testbench and GHDL +as simulator) you can use the <code>sim</code> makefile target. Make sure to use the UART simulation mode +(<code>USER_FLAGS+=-DUART0_SIM_MODE</code> and/or <code>USER_FLAGS+=-DUART1_SIM_MODE</code>) to get +faster / direct-to-console UART output.</p> +</div> +<div class="listingblock"> +<div class="content"> +<pre class="highlight"><code class="language-bash" data-lang="bash">sw/example/demo_blink_led$ make USER_FLAGS+=-DUART0_SIM_MODE clean_all sim +[...] +Blinking LED demo program</code></pre> +</div> +</div> +<div class="sect3"> +<h4 id="_hello_world">13.4.1. Hello World!</h4> +<div class="paragraph"> +<p>To do a quick test of the NEORV32 make sure to have <a href="https://github.com/ghdl/ghdl">GHDL</a> and a +<a href="https://github.com/stnolting/riscv-gcc-prebuilt">RISC-V gcc toolchain</a> installed. +Navigate to the project&#8217;s <code>sw/example/hello_world</code> folder and run <code>make USER_FLAGS+=-DUART0_SIM_MODE clean_all sim</code>:</p> +</div> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +The simulator will output some <em>sanity check</em> notes (and warnings or even errors if something is ill-configured) +right at the beginning of the simulation to give a brief overview of the actual NEORV32 SoC and CPU configurations. +</td> +</tr> +</table> +</div> +<div class="listingblock"> +<div class="content"> +<pre class="highlight"><code class="language-bash" data-lang="bash">neorv32/sw/example/hello_world$ make USER_FLAGS+=-DUART0_SIM_MODE clean_all sim +../../../sw/lib/source/neorv32_uart.c: In function 'neorv32_uart_setup': +../../../sw/lib/source/neorv32_uart.c:116:2: warning: #warning UART0_SIM_MODE (primary UART) enabled! Sending all UART0.TX data to text.io simulation output instead of real UART0 transmitter. Use this for simulations only! [-Wcpp] + 116 | #warning UART0_SIM_MODE (primary UART) enabled! Sending all UART0.TX data to text.io simulation output instead of real UART0 transmitter. Use this for simulations only! <i class="conum" data-value="1"></i><b>(1)</b> + | ^~~~~~~ +Memory utilization: + text data bss dec hex filename + 4664 0 116 4780 12ac main.elf <i class="conum" data-value="2"></i><b>(2)</b> +Compiling ../../../sw/image_gen/image_gen +Installing application image to ../../../rtl/core/neorv32_application_image.vhd <i class="conum" data-value="3"></i><b>(3)</b> +Simulating neorv32_application_image.vhd... +Tip: Compile application with USER_FLAGS+=-DUART[0/1]_SIM_MODE to auto-enable UART[0/1]'s simulation mode (redirect UART output to simulator console). <i class="conum" data-value="4"></i><b>(4)</b> +Using simulation run arguments: --stop-time=10ms <i class="conum" data-value="5"></i><b>(5)</b> +../../rtl/core/neorv32_top.vhd:355:5:@0ms:(assertion note): [NEORV32] The NEORV32 RISC-V Processor (version 0x01090504), github.com/stnolting/neorv32 <i class="conum" data-value="6"></i><b>(6)</b> +../../rtl/core/neorv32_top.vhd:361:5:@0ms:(assertion note): [NEORV32] Processor Configuration: IMEM DMEM I-CACHE D-CACHE WISHBONE GPIO MTIME UART0 UART1 SPI SDI TWI PWM WDT TRNG CFS NEOLED XIRQ GPTMR XIP ONEWIRE DMA SLINK CRC SYSINFO OCD +../../rtl/core/neorv32_clockgate.vhd:60:3:@0ms:(assertion warning): [NEORV32] Clock gating enabled (using generic clock switch). +../../rtl/core/neorv32_cpu.vhd:142:3:@0ms:(assertion note): [NEORV32] CPU ISA: rv32imabu_zicsr_zicntr_zicond_zifencei_zfinx_zihpm_zxcfu_sdext_sdtrig_smpmp +../../rtl/core/neorv32_cpu.vhd:163:3:@0ms:(assertion note): [NEORV32] CPU tuning options: fast_mul fast_shift +../../rtl/core/neorv32_cpu.vhd:170:3:@0ms:(assertion warning): [NEORV32] Assuming this is a simulation. +../../rtl/core/neorv32_cpu_cp_fpu.vhd:292:3:@0ms:(assertion warning): [NEORV32] The floating-point unit (Zfinx) is still in experimental state. +../../rtl/core/mem/neorv32_imem.legacy.vhd:72:3:@0ms:(assertion note): [NEORV32] Implementing LEGACY processor-internal IMEM as pre-initialized ROM. +../../rtl/core/neorv32_wishbone.vhd:117:3:@0ms:(assertion note): [NEORV32] Ext. Bus Interface (WISHBONE) - PIPELINED Wishbone protocol, auto-timeout, LITTLE-endian byte order, registered RX, registered TX +../../rtl/core/neorv32_trng.vhd:343:3:@0ms:(assertion note): [neoTRNG NOTE] &lt;&lt; neoTRNG V3 - A Tiny and Platform-Independent True Random Number Generator &gt;&gt; +../../rtl/core/neorv32_trng.vhd:545:5:@0ms:(assertion warning): [neoTRNG WARNING] Implementing non-physical pseudo-RNG! +../../rtl/core/neorv32_trng.vhd:545:5:@0ms:(assertion warning): [neoTRNG WARNING] Implementing non-physical pseudo-RNG! +../../rtl/core/neorv32_trng.vhd:545:5:@0ms:(assertion warning): [neoTRNG WARNING] Implementing non-physical pseudo-RNG! +../../rtl/core/neorv32_debug_dm.vhd:227:3:@0ms:(assertion note): [NEORV32] OCD DM compatible to debug spec. version 1.0 +<i class="conum" data-value="7"></i><b>(7)</b> + ## ## ## ## + ## ## ######### ######## ######## ## ## ######## ######## ## ################ +#### ## ## ## ## ## ## ## ## ## ## ## ## ## #### #### +## ## ## ## ## ## ## ## ## ## ## ## ## ## ###### ## +## ## ## ######### ## ## ######### ## ## ##### ## ## #### ###### #### +## ## ## ## ## ## ## ## ## ## ## ## ## ## ###### ## +## #### ## ## ## ## ## ## ## ## ## ## ## #### #### +## ## ######### ######## ## ## ## ######## ########## ## ################ + ## ## ## ## +Hello world! :)</code></pre> +</div> +</div> +<div class="colist arabic"> +<table> +<tr> +<td><i class="conum" data-value="1"></i><b>1</b></td> +<td>Notifier that "simulation mode" of UART0 is enabled (by the <code>USER_FLAGS+=-DUART0_SIM_MODE</code> makefile flag). All UART0 output is send to the simulator console.</td> +</tr> +<tr> +<td><i class="conum" data-value="2"></i><b>2</b></td> +<td>Final executable size (<code>text</code>) and <em>static</em> data memory requirements (<code>data</code>, <code>bss</code>).</td> +</tr> +<tr> +<td><i class="conum" data-value="3"></i><b>3</b></td> +<td>The application code is <em>installed</em> as pre-initialized IMEM. This is the default approach for simulation.</td> +</tr> +<tr> +<td><i class="conum" data-value="4"></i><b>4</b></td> +<td>A note regarding UART "simulation mode", but we have already enabled that.</td> +</tr> +<tr> +<td><i class="conum" data-value="5"></i><b>5</b></td> +<td>List of (default) arguments that were send to the simulator. Here: maximum simulation time (10ms).</td> +</tr> +<tr> +<td><i class="conum" data-value="6"></i><b>6</b></td> +<td>"Sanity checks" from the core&#8217;s VHDL files. These reports give some brief information about the SoC/CPU configuration (&#8594; generics). If there are problems with the current configuration, an ERROR will appear.</td> +</tr> +<tr> +<td><i class="conum" data-value="7"></i><b>7</b></td> +<td>Execution of the actual program starts.</td> +</tr> +</table> +</div> +</div> +</div> +<div class="sect2"> +<h3 id="_advanced_simulation_using_vunit">13.5. Advanced Simulation using VUnit</h3> +<div class="paragraph"> +<p><a href="https://vunit.github.io/">VUnit</a> is an open source unit testing framework for VHDL/SystemVerilog. +It allows continuous and automated testing of HDL code by complementing traditional testing methodologies. +The motto of VUnit is <em>"testing early and often"</em> through automation.</p> +</div> +<div class="paragraph"> +<p>VUnit is composed by a <a href="http://vunit.github.io/py/ui.html">Python interface</a> and multiple optional +<a href="http://vunit.github.io/vhdl_libraries.html">VHDL libraries</a>. +The Python interface allows declaring sources and simulation options, and it handles the compilation, execution and +gathering of the results regardless of the simulator used. +That allows having a single <code>run.py</code> script to be used with GHDL, ModelSim/QuestaSim, Riviera PRO, etc. +On the other hand, the VUnit&#8217;s VHDL libraries provide utilities for assertions, logging, having virtual queues, handling CSV files, etc. +The <a href="http://vunit.github.io/verification_components/user_guide.html">Verification Component Library</a> uses those features +for abstracting away bit-toggling when verifying standard interfaces such as Wishbone, AXI, Avalon, UARTs, etc.</p> +</div> +<div class="paragraph"> +<p>Testbench sources in <code>sim</code> (such as <code>sim/neorv32_tb.vhd</code> and <code>sim/uart_rx*.vhd</code>) use VUnit&#8217;s VHDL libraries for testing +NEORV32 and peripherals. +The entry-point for executing the tests is <code>sim/run.py</code>.</p> +</div> +<div class="listingblock"> +<div class="content"> +<pre class="highlight"><code class="language-bash" data-lang="bash"># ./sim/run.py -l +neorv32.neorv32_tb.all +Listed 1 tests + +# ./sim/run.py -v +Compiling into neorv32: rtl/core/neorv32_uart.vhd passed +Compiling into neorv32: rtl/core/neorv32_twi.vhd passed +Compiling into neorv32: rtl/core/neorv32_trng.vhd passed +...</code></pre> +</div> +</div> +<div class="paragraph"> +<p>See <a href="http://vunit.github.io/user_guide.html">VUnit: User Guide</a> and <a href="http://vunit.github.io/cli.html">VUnit: Command Line Interface</a> for further info about VUnit&#8217;s features.</p> +</div> +<div style="page-break-after: always;"></div> +</div> +</div> +</div> +<div class="sect1"> +<h2 id="_vhdl_development_environment">14. VHDL Development Environment</h2> +<div class="sectionbody"> +<div class="paragraph"> +<p>To navigate and develop the NEORV32 processor VHDL code you can use the free and open source VHDL-LS language server. +The easiest way to get started is to install the <a href="https://marketplace.visualstudio.com/items?itemName=hbohlin.vhdl-ls">VHDL-LS VSCode extension</a>. +The VHDL-LS server requires a <code>vhdl_ls.toml</code> file which is automatically generated by the <code>sim/run.py</code> script. See <a href="#_simulating_the_processor">Simulate the processor</a> for further information.</p> +</div> +<div class="olist arabic"> +<ol class="arabic"> +<li> +<p>Run <code>sim/run.py</code> to create the library mapping file</p> +</li> +<li> +<p>Install the VHDL-LS VSCode extension</p> +</li> +<li> +<p>Open the root folder of the NEORV32 repository in VSCode</p> +</li> +<li> +<p>Open any VHDL file</p> +</li> +</ol> +</div> +<div style="page-break-after: always;"></div> +</div> +</div> +<div class="sect1"> +<h2 id="_building_the_documentation">15. Building the Documentation</h2> +<div class="sectionbody"> +<div class="paragraph"> +<p>The documentation (datasheet + user guide) is written using <code>asciidoc</code>. The according source files +can be found in <code>docs/&#8230;&#8203;</code>. The documentation of the software framework is written <em>in-code</em> using <code>doxygen</code>.</p> +</div> +<div class="paragraph"> +<p>A makefiles in the project&#8217;s <code>docs</code> directory is provided to build all of the documentation as HTML pages +or as PDF documents.</p> +</div> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +Pre-rendered PDFs are available online as <em>nightly pre-releases</em>: <a href="https://github.com/stnolting/neorv32/releases" class="bare">https://github.com/stnolting/neorv32/releases</a>. +The HTML-based documentation is also available online at the project&#8217;s <a href="https://stnolting.github.io/neorv32/">GitHub Pages</a>. +</td> +</tr> +</table> +</div> +<div class="paragraph"> +<p>The makefile provides a help target to show all available build options and their according outputs.</p> +</div> +<div class="listingblock"> +<div class="content"> +<pre class="highlight"><code class="language-bash" data-lang="bash">neorv32/docs$ make help</code></pre> +</div> +</div> +<div class="listingblock"> +<div class="title">Listing 11. Example: Generate HTML documentation (data sheet) using <code>asciidoctor</code></div> +<div class="content"> +<pre class="highlight"><code class="language-bash" data-lang="bash">neorv32/docs$ make html</code></pre> +</div> +</div> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +If you don&#8217;t have <code>asciidoctor</code> / <code>asciidoctor-pdf</code> installed, you can still generate all the documentation using +a <em>docker container</em> via <code>make container</code>. +</td> +</tr> +</table> +</div> +<div style="page-break-after: always;"></div> +</div> +</div> +<div class="sect1"> +<h2 id="_zephyr_rtos_support">16. Zephyr RTOS Support</h2> +<div class="sectionbody"> +<div class="paragraph"> +<p>The NEORV32 processor is supported by upstream Zephyr RTOS: <a href="https://docs.zephyrproject.org/latest/boards/riscv/neorv32/doc/index.html" class="bare">https://docs.zephyrproject.org/latest/boards/riscv/neorv32/doc/index.html</a></p> +</div> +<div class="admonitionblock important"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-important" title="Important"></i> +</td> +<td class="content"> +The absolute path to the NEORV32 executable image generator binary (<code>&#8230;&#8203;/neorv32/sw/image_gen</code>) has to be added to the <code>PATH</code> variable +so the Zephyr build system can generate executables and memory-initialization images. +</td> +</tr> +</table> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +Zephyr OS port provided by GitHub user <a href="https://github.com/henrikbrixandersen">henrikbrixandersen</a> +(see <a href="https://github.com/stnolting/neorv32/discussions/172" class="bare">https://github.com/stnolting/neorv32/discussions/172</a>). ❤️ +</td> +</tr> +</table> +</div> +<div style="page-break-after: always;"></div> +</div> +</div> +<div class="sect1"> +<h2 id="_freertos_support">17. FreeRTOS Support</h2> +<div class="sectionbody"> +<div class="paragraph"> +<p>A NEORV32-specific port and a simple demo for FreeRTOS (<a href="https://github.com/FreeRTOS/FreeRTOS" class="bare">https://github.com/FreeRTOS/FreeRTOS</a>) are +available in a separate repository on GitHub: <a href="https://github.com/stnolting/neorv32-freertos" class="bare">https://github.com/stnolting/neorv32-freertos</a></p> +</div> +<div style="page-break-after: always;"></div> +</div> +</div> +<div class="sect1"> +<h2 id="_litex_soc_builder_support">18. LiteX SoC Builder Support</h2> +<div class="sectionbody"> +<div class="paragraph"> +<p><a href="https://github.com/enjoy-digital/litex">LiteX</a> is a SoC builder framework by <a href="https://github.com/enjoy-digital">Enjoy-Digital</a> +that allows easy creation of complete system-on-chip designs - including sophisticated interfaces like Ethernet, serial ATA +and DDR memory controller. The NEORV32 has been ported to the LiteX framework to be used as central processing unit.</p> +</div> +<div class="paragraph"> +<p>The default microcontroller-like NEORV32 processor is not directly supported as all the peripherals would provide some <em>redundancy</em>. +Instead, the LiteX port uses a <em>core complex wrapper</em> that only includes the actual NEORV32 CPU, the instruction cache (optional), +the RISC-V machine system timer (optional), the on-chip debugger (optional) and the internal bus infrastructure. +The specific implementation of optional modules as well as RISC-V ISA configuration and performance optimization options are +controlled by a single <em>CONFIGURATION</em> option wrapped in the LiteX build flow. The external bus interface is used to connect to +other LiteX SoC parts.</p> +</div> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +<div class="title">Core Complex Wrapper</div> +The NEORV32 core complex wrapper used by LiteX for integration can be found in +<code>rtl/system_integration/neorv32_litex_core_complex.vhd</code>. +</td> +</tr> +</table> +</div> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +<div class="title">LiteX NEORV32 Documentation</div> +More information can be found in the "NEORV32" section of the LiteX project wiki: <a href="https://github.com/enjoy-digital/litex/wiki/CPUs" class="bare">https://github.com/enjoy-digital/litex/wiki/CPUs</a> +</td> +</tr> +</table> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">Work-In-Progress 🚧</div> +UG: synthesis - how to create a whole NEORV32 + LiteX SoC for a FPGA<br> +LiteX: debugger - the NEORV32 on-chip-debugger is not supported by the LiteX port yet<br> +LiteX: external interrupt - the "RISC-V machine external interrupt" is not supported by the LiteX port yet +</td> +</tr> +</table> +</div> +<div class="sect2"> +<h3 id="_litex_setup">18.1. LiteX Setup</h3> +<div class="olist arabic"> +<ol class="arabic" start="1"> +<li> +<p>Install LiteX and the RISC-V compiler following the excellent quick start guide: <a href="https://github.com/enjoy-digital/litex/wiki#quick-start-guide" class="bare">https://github.com/enjoy-digital/litex/wiki#quick-start-guide</a></p> +</li> +<li> +<p>The NEORV32 port for LiteX uses GHDL and yosys for converting the VHDL files via the <a href="https://github.com/ghdl/ghdl-yosys-plugin">GHDL-yosys-plugin</a>. +You can download prebuilt packages for example from <a href="https://github.com/YosysHQ/fpga-toolchain" class="bare">https://github.com/YosysHQ/fpga-toolchain</a>, which is _no longer maintained. It is superdesed +by <a href="https://github.com/YosysHQ/fpga-toolchain" class="bare">https://github.com/YosysHQ/fpga-toolchain</a>.</p> +</li> +<li> +<p><em>EXPERIMENTAL:</em> GHDL provides a <a href="https://ghdl.github.io/ghdl/using/Synthesis.html">synthesis options</a>, which converts a VHDL setup into a plain-Verilog +netlist module (not tested on LiteX yet). Check out <a href="https://github.com/stnolting/neorv32-verilog">neorv32-verilog</a> for more information.</p> +</li> +</ol> +</div> +<div class="admonitionblock warning"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-warning" title="Warning"></i> +</td> +<td class="content"> +<div class="title">GHDL-yosys Plugin</div> +If you would like to use the experimental GHDL Yosys plugin for VHDL on Linux or MacOS, you will need to set +the <code>GHDL_PREFIX</code> environment variable. e.g. <code>export GHDL_PREFIX=&lt;install_dir&gt;/fpga-toolchain/lib/ghdl</code>. +On Windows this is not necessary.<br> +<br> +If you are using an existing Makefile set up for ghdl-yosys-plugin and see ERROR: This version of yosys +is built without plugin support you probably need to remove <code>-m ghdl</code> from your yosys parameters. This is +because the plugin is typically loaded from a separate file but it is provided built into yosys in this +package.<br> +- from <a href="https://github.com/YosysHQ/fpga-toolchain" class="bare">https://github.com/YosysHQ/fpga-toolchain</a><br> +<br> +<strong>This means you might have to edit the call to yosys in <code>litex/soc/cores/cpu/neorv32/core.py</code>.</strong> +</td> +</tr> +</table> +</div> +<div class="olist arabic"> +<ol class="arabic" start="3"> +<li> +<p>Add the <code>bin</code> folder of the ghdl-yosys-plugin to your <code>PATH</code> environment variable. You can test your yosys installation +and check for the GHDL plugin:</p> +</li> +</ol> +</div> +<div class="listingblock"> +<div class="content"> +<pre class="highlight"><code class="language-bash" data-lang="bash">$ yosys -H + + /----------------------------------------------------------------------------\ + | | + | yosys -- Yosys Open SYnthesis Suite | + | | + | Copyright (C) 2012 - 2020 Claire Xenia Wolf &lt;claire@yosyshq.com&gt; | + | | + | Permission to use, copy, modify, and/or distribute this software for any | + | purpose with or without fee is hereby granted, provided that the above | + | copyright notice and this permission notice appear in all copies. | + | | + | THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES | + | WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF | + | MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR | + | ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES | + | WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN | + | ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF | + | OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. | + | | + \----------------------------------------------------------------------------/ + + Yosys 0.10+12 (open-tool-forge build) (git sha1 356ec7bb, gcc 9.3.0-17ubuntu1~20.04 -Os) + + +-- Running command `help' -- + + ... <i class="conum" data-value="1"></i><b>(1)</b> + ghdl load VHDL designs using GHDL <i class="conum" data-value="2"></i><b>(2)</b> + ...</code></pre> +</div> +</div> +<div class="colist arabic"> +<table> +<tr> +<td><i class="conum" data-value="1"></i><b>1</b></td> +<td>A long list of plugins&#8230;&#8203;</td> +</tr> +<tr> +<td><i class="conum" data-value="2"></i><b>2</b></td> +<td>This is the plugin we need.</td> +</tr> +</table> +</div> +</div> +<div class="sect2"> +<h3 id="_litex_simulation">18.2. LiteX Simulation</h3> +<div class="paragraph"> +<p>Start a simulation right in your console using the NEORV32 as target CPU:</p> +</div> +<div class="listingblock"> +<div class="content"> +<pre class="highlight"><code class="language-bash" data-lang="bash">$ litex_sim --cpu-type=neorv32</code></pre> +</div> +</div> +<div class="paragraph"> +<p>LiteX will start running its BIOS:</p> +</div> +<div class="listingblock"> +<div class="content"> +<pre class="highlight"><code> __ _ __ _ __ + / / (_) /____ | |/_/ + / /__/ / __/ -_)&gt; &lt; + /____/_/\__/\__/_/|_| + Build your hardware, easily! + + (c) Copyright 2012-2022 Enjoy-Digital + (c) Copyright 2007-2015 M-Labs + + BIOS built on Jul 19 2022 12:21:36 + BIOS CRC passed (6f76f1e8) + + LiteX git sha1: 0654279a + +--=============== SoC ==================-- +CPU: NEORV32-standard @ 1MHz +BUS: WISHBONE 32-bit @ 4GiB +CSR: 32-bit data +ROM: 128KiB +SRAM: 8KiB + + +--============== Boot ==================-- +Booting from serial... +Press Q or ESC to abort boot completely. +sL5DdSMmkekro +Timeout +No boot medium found + +--============= Console ================-- + +litex&gt; help + +LiteX BIOS, available commands: + +flush_cpu_dcache - Flush CPU data cache +crc - Compute CRC32 of a part of the address space +ident - Identifier of the system +help - Print this help + +serialboot - Boot from Serial (SFL) +reboot - Reboot +boot - Boot from Memory + +mem_cmp - Compare memory content +mem_speed - Test memory speed +mem_test - Test memory access +mem_copy - Copy address space +mem_write - Write address space +mem_read - Read address space +mem_list - List available memory regions + + +litex&gt;</code></pre> +</div> +</div> +<div class="paragraph"> +<p>You can use the provided console to execute LiteX commands.</p> +</div> +<div style="page-break-after: always;"></div> +</div> +</div> +</div> +<div class="sect1"> +<h2 id="_debugging_using_the_on_chip_debugger">19. Debugging using the On-Chip Debugger</h2> +<div class="sectionbody"> +<div class="paragraph"> +<p>The NEORV32 on-chip debugger ("OCD") allows <em>online</em> in-system debugging via an external JTAG access port from a +host machine. The general flow is independent of the host machine&#8217;s operating system. However, this tutorial uses +Windows and Linux (Ubuntu on Windows / WSL) in parallel running the upstream version of OpenOCD and the +RISC-V <em>GNU debugger</em> <code>gdb</code>.</p> +</div> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +<div class="title">TLDR</div> +You can start a pre-configured debug session (using default <code>main.elf</code> as executable and +<code>target extended-remote localhost:3333</code> as GDB connection configuration) by using the <strong>GDB</strong> makefile target +(i.e. <code>make gdb</code>). +</td> +</tr> +</table> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">OCD Hardware Implementation</div> +See datasheet section <a href="https://stnolting.github.io/neorv32/#_on_chip_debugger_ocd">On Chip Debugger (OCD)</a> +for more information regarding the actual hardware. +</td> +</tr> +</table> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">OCD CPU Requirements</div> +The on-chip debugger is only implemented if the <em>ON_CHIP_DEBUGGER_EN</em> generic is set <em>true</em>. Furthermore, it requires +the <code>Zicsr</code> and <code>Zifencei</code> CPU extension, which are always enabled by the CPU. +</td> +</tr> +</table> +</div> +<div class="sect2"> +<h3 id="_hardware_requirements">19.1. Hardware Requirements</h3> +<div class="paragraph"> +<p>Make sure the on-chip debugger of your NEORV32 setup is implemented (<code>ON_CHIP_DEBUGGER_EN</code> generic = true). This +tutorial uses <code>gdb</code> to <strong>directly upload an executable</strong> to the processor. If you are using the default +processor setup <em>with</em> internal instruction memory (IMEM) make sure it is implemented as RAM +(<code>INT_BOOTLOADER_EN</code> generic = true).</p> +</div> +<div class="paragraph"> +<p>Connect a JTAG adapter to the NEORV32 <code>jtag_*</code> interface signals. If you do not have a full-scale JTAG adapter, you can +also use a FTDI-based adapter like the "FT2232H-56Q Mini Module", which is a simple and inexpensive FTDI breakout board.</p> +</div> +<table class="tableblock frame-all grid-rows stretch"> +<caption class="title">Table 4. JTAG pin mapping</caption> +<colgroup> +<col style="width: 42.8571%;"> +<col style="width: 28.5714%;"> +<col style="width: 28.5715%;"> +</colgroup> +<thead> +<tr> +<th class="tableblock halign-center valign-top">NEORV32 top signal</th> +<th class="tableblock halign-center valign-top">JTAG signal</th> +<th class="tableblock halign-center valign-top">Default FTDI port</th> +</tr> +</thead> +<tbody> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>jtag_tck_i</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">TCK</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">D0</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>jtag_tdi_i</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">TDI</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">D1</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>jtag_tdo_o</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">TDO</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">D2</p></td> +</tr> +<tr> +<td class="tableblock halign-center valign-top"><p class="tableblock"><code>jtag_tms_i</code></p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">TMS</p></td> +<td class="tableblock halign-center valign-top"><p class="tableblock">D3</p></td> +</tr> +</tbody> +</table> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">JTAG TAP Reset</div> +The NEORV32 JTAG TAP does not provide a dedicated reset signal ("TRST"). However, the missing TRST is not a problem, +since JTAG-level resets can be triggered using with TMS signaling. +</td> +</tr> +</table> +</div> +</div> +<div class="sect2"> +<h3 id="_openocd">19.2. OpenOCD</h3> +<div class="paragraph"> +<p>The NEORV32 on-chip debugger can be accessed using the upstream version of OpenOCD. A pre-configured OpenOCD configuration +file is provided (<code>sw/openocd/openocd_neorv32.cfg</code>) that allows an easy access to the NEORV32 CPU.</p> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +You might need to adapt <code>ftdi vid_pid</code>, <code>ftdi channel</code> and <code>ftdi layout_init</code> in <code>sw/openocd/openocd_neorv32.cfg</code> +according to your interface chip and your operating system. +</td> +</tr> +</table> +</div> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +If you want to modify the JTAG clock speed (via <code>adapter speed</code> in <code>sw/openocd/openocd_neorv32.cfg</code>) make sure to meet +the clock requirements noted in <a href="https://stnolting.github.io/neorv32/#_debug_module_dm">Documentation: Debug Transport Module (DTM)</a>. +</td> +</tr> +</table> +</div> +<div class="paragraph"> +<p>To access the processor using OpenOCD, open a terminal and start OpenOCD with the pre-configured configuration file.</p> +</div> +<div class="listingblock"> +<div class="title">Listing 12. Connecting via OpenOCD (on Windows) using the default <code>openocd_neorv32.cfg</code> script</div> +<div class="content"> +<pre class="highlight"><code class="language-bash" data-lang="bash">N:\Projects\neorv32\sw\openocd&gt;openocd -f openocd_neorv32.cfg +Open On-Chip Debugger 0.11.0 (2021-11-18) [https://github.com/sysprogs/openocd] +Licensed under GNU GPL v2 +libusb1 09e75e98b4d9ea7909e8837b7a3f00dda4589dc3 +For bug reports, read + http://openocd.org/doc/doxygen/bugs.html +Info : clock speed 1000 kHz +Info : JTAG tap: neorv32.cpu tap/device found: 0x00000000 (mfg: 0x000 (&lt;invalid&gt;), part: 0x0000, ver: 0x0) +Info : datacount=1 progbufsize=2 +Info : Disabling abstract command reads from CSRs. +Info : Examined RISC-V core; found 1 harts +Info : hart 0: XLEN=32, misa=0x40901107 +Info : starting gdb server for neorv32.cpu.0 on 3333 +Info : Listening on port 3333 for gdb connections +Target HALTED. +Ready for remote connections. +Info : Listening on port 6666 for tcl connections +Info : Listening on port 4444 for telnet connections</code></pre> +</div> +</div> +<div class="paragraph"> +<p>OpenOCD has successfully connected to the NEORV32 on-chip debugger and has examined the CPU (showing the content of +the <code>misa</code> CSRs). The processor is halted and OpenOCD waits fot <code>gdb</code> to connect via port 3333.</p> +</div> +</div> +<div class="sect2"> +<h3 id="_debugging_with_gdb">19.3. Debugging with GDB</h3> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +<div class="title">GDB + SVD</div> +Together with a third-party plugin the processor&#8217;s SVD file can be imported right into GDB to allow comfortable +debugging of peripheral/IO devices (see <a href="https://github.com/stnolting/neorv32/discussions/656" class="bare">https://github.com/stnolting/neorv32/discussions/656</a>). +</td> +</tr> +</table> +</div> +<div class="paragraph"> +<p>This guide uses the simple "blink example" from <code>sw/example/demo_blink_led</code> as simplified test application to +show the basics of in-system debugging.</p> +</div> +<div class="paragraph"> +<p>At first, the application needs to be compiled. We will use the minimal machine architecture configuration +(<code>rv32i</code>) here to be independent of the actual processor/CPU configuration. +Navigate to <code>sw/example/demo_blink_led</code> and compile the application:</p> +</div> +<div class="listingblock"> +<div class="title">Listing 13. Compile the test application</div> +<div class="content"> +<pre class="highlight"><code class="language-bash" data-lang="bash">.../neorv32/sw/example/demo_blink_led$ make MARCH=rv32i USER_FLAGS+=-g clean_all all</code></pre> +</div> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">Adding debug symbols to the executable</div> +<code>USER_FLAGS+=-g</code> passes the <code>-g</code> flag to the compiler so it adds debug information/symbols +to the generated ELF file. This is optional but will provide more sophisticated debugging information +(like source file line numbers). +</td> +</tr> +</table> +</div> +<div class="paragraph"> +<p>This will generate an ELF file <code>main.elf</code> that contains all the symbols required for debugging. +Furthermore, an assembly listing file <code>main.asm</code> is generated that we will use to define breakpoints.</p> +</div> +<div class="paragraph"> +<p>Open another terminal in <code>sw/example/demo_blink_led</code> and start <code>gdb</code>.</p> +</div> +<div class="listingblock"> +<div class="title">Listing 14. Starting GDB (on Linux (Ubuntu on Windows))</div> +<div class="content"> +<pre class="highlight"><code class="language-bash" data-lang="bash">.../neorv32/sw/example/demo_blink_led$ riscv32-unknown-elf-gdb +GNU gdb (GDB) 10.1 +Copyright (C) 2020 Free Software Foundation, Inc. +License GPLv3+: GNU GPL version 3 or later &lt;http://gnu.org/licenses/gpl.html&gt; +This is free software: you are free to change and redistribute it. +There is NO WARRANTY, to the extent permitted by law. +Type "show copying" and "show warranty" for details. +This GDB was configured as "--host=x86_64-pc-linux-gnu --target=riscv32-unknown-elf". +Type "show configuration" for configuration details. +For bug reporting instructions, please see: +&lt;https://www.gnu.org/software/gdb/bugs/&gt;. +Find the GDB manual and other documentation resources online at: + &lt;http://www.gnu.org/software/gdb/documentation/&gt;. + +For help, type "help". +Type "apropos word" to search for commands related to "word". +(gdb)</code></pre> +</div> +</div> +<div class="paragraph"> +<p>Now connect to OpenOCD using the default port 3333 on your machine. +We will use the previously generated ELF file <code>main.elf</code> from the <code>demo_blink_led</code> example. +Finally, upload the program to the processor and start debugging.</p> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +The executable that is uploaded to the processor is <strong>not</strong> the default NEORV32 executable (<code>neorv32_exe.bin</code>) that +is used for uploading via the bootloader. Instead, all the required sections (like <code>.text</code>) are extracted from <code>mail.elf</code> +by GDB and uploaded via the debugger&#8217;s indirect memory access. +</td> +</tr> +</table> +</div> +<div class="listingblock"> +<div class="title">Listing 15. Running GDB</div> +<div class="content"> +<pre class="highlight"><code class="language-bash" data-lang="bash">(gdb) target extended-remote localhost:3333 <i class="conum" data-value="1"></i><b>(1)</b> +Remote debugging using localhost:3333 +warning: No executable has been specified and target does not support +determining executable automatically. Try using the "file" command. +0xffff0c94 in ?? () <i class="conum" data-value="2"></i><b>(2)</b> +(gdb) file main.elf <i class="conum" data-value="3"></i><b>(3)</b> +A program is being debugged already. +Are you sure you want to change the file? (y or n) y +Reading symbols from main.elf... +(gdb) load <i class="conum" data-value="4"></i><b>(4)</b> +Loading section .text, size 0xd0c lma 0x0 +Loading section .rodata, size 0x39c lma 0xd0c +Start address 0x00000000, load size 4264 +Transfer rate: 43 KB/sec, 2132 bytes/write. +(gdb)</code></pre> +</div> +</div> +<div class="colist arabic"> +<table> +<tr> +<td><i class="conum" data-value="1"></i><b>1</b></td> +<td>Connect to OpenOCD</td> +</tr> +<tr> +<td><i class="conum" data-value="2"></i><b>2</b></td> +<td>The CPU was still executing code from the bootloader ROM - but that does not matter here</td> +</tr> +<tr> +<td><i class="conum" data-value="3"></i><b>3</b></td> +<td>Select <code>mail.elf</code> from the <code>demo_blink_led</code> example</td> +</tr> +<tr> +<td><i class="conum" data-value="4"></i><b>4</b></td> +<td>Upload the executable</td> +</tr> +</table> +</div> +<div class="paragraph"> +<p>After the upload, GDB will make the processor jump to the beginning of the uploaded executable +(by default, this is the beginning of the instruction memory at <code>0x00000000</code>) skipping the bootloader +and halting the CPU right before executing the <code>demo_blink_led</code> application.</p> +</div> +<div class="admonitionblock important"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-important" title="Important"></i> +</td> +<td class="content"> +After gdb has connected to the CPU, it is recommended to disable the CPU&#8217;s global interrupt flag +(<code>mstatus.mie</code>, = bit #3) to prevent unintended calls of potentially outdated trap handlers. The global +interrupt flag can be cleared using the following gdb command: +<code>set $mstatus = ($mstatus &amp; ~(1&lt;&lt;3))</code>. Interrupts can be enabled globally again by the following command: +<code>set $mstatus = ($mstatus | (1&lt;&lt;3))</code>. +</td> +</tr> +</table> +</div> +<div class="sect3"> +<h4 id="_software_breakpoints">19.3.1. Software Breakpoints</h4> +<div class="paragraph"> +<p>The following steps are just a small showcase that illustrate a simple debugging scheme.</p> +</div> +<div class="paragraph"> +<p>While compiling <code>demo_blink_led</code>, an assembly listing file <code>main.asm</code> was generated. +Open this file with a text editor to check out what the CPU is going to do when resumed.</p> +</div> +<div class="paragraph"> +<p>The <code>demo_blink_led</code> example implements a simple counter on the 8 lowest GPIO output ports. The program uses +"busy wait" to have a visible delay between increments. This waiting is done by calling the <code>neorv32_cpu_delay_ms</code> +function. We will add a <em>breakpoint</em> right at the end of this wait function so we can step through the iterations +of the counter.</p> +</div> +<div class="listingblock"> +<div class="title">Listing 16. Cut-out from <code>main.asm</code> generated from the <code>demo_blink_led</code> example</div> +<div class="content"> +<pre class="highlight"><code class="language-assembly" data-lang="assembly">00000688 &lt;__neorv32_cpu_delay_ms_end&gt;: + 688: 01c12083 lw ra,28(sp) + 68c: 02010113 addi sp,sp,32 + 690: 00008067 ret</code></pre> +</div> +</div> +<div class="paragraph"> +<p>The very last instruction of the <code>neorv32_cpu_delay_ms</code> function is <code>ret</code> (= return) +at hexadecimal <code>690</code> in this example. Add this address as <em>breakpoint</em> to GDB.</p> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +The address might be different if you use a different version of the software framework or +if different ISA options are configured. +</td> +</tr> +</table> +</div> +<div class="listingblock"> +<div class="title">Listing 17. Adding a GDB software breakpoint</div> +<div class="content"> +<pre class="highlight"><code class="language-bash" data-lang="bash">(gdb) b * 0x690 <i class="conum" data-value="1"></i><b>(1)</b> +Breakpoint 1 at 0x690</code></pre> +</div> +</div> +<div class="colist arabic"> +<table> +<tr> +<td><i class="conum" data-value="1"></i><b>1</b></td> +<td><code>b</code> is an alias for <code>break</code>, which adds a <em>software</em> breakpoint.</td> +</tr> +</table> +</div> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +<div class="title">How do <em>software</em> breakpoints work?</div> +Software breakpoints are used for debugging programs that are accessed from read/write memory (RAM) like IMEM. The debugger +temporarily replaces the instruction word of the instruction, where the breakpoint shall be inserted, by a <code>ebreak</code> / <code>c.ebreak</code> +instruction. Whenever execution reaches this instruction, debug mode is entered and the debugger restores the original +instruction at this address to maintain original program behavior.<br> +<br> +When debugging programs executed from ROM <em>hardware-assisted</em> breakpoints using the core&#8217;s trigger module have to be used. +See section <a href="#_hardware_breakpoints">Hardware Breakpoints</a> for more information. +</td> +</tr> +</table> +</div> +<div class="paragraph"> +<p>Now execute <code>c</code> (= continue). The CPU will resume operation until it hits the break-point. +By this we can move from one counter increment to another.</p> +</div> +<div class="listingblock"> +<div class="title">Listing 18. Iterating from breakpoint to breakpoint</div> +<div class="content"> +<pre class="highlight"><code class="language-bash" data-lang="bash">Breakpoint 1 at 0x690 +(gdb) c +Continuing. + +Breakpoint 1, 0x00000690 in neorv32_cpu_delay_ms () +(gdb) c +Continuing. + +Breakpoint 1, 0x00000690 in neorv32_cpu_delay_ms () +(gdb) c +Continuing.</code></pre> +</div> +</div> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +<div class="title">Hardcoded EBREAK Instructions In The Program Code</div> +If your original application code uses the BREAK instruction (for example for some OS calls/signaling) this +instruction will cause an enter to debug mode when executed. These situation cannot be continued using gdb&#8217;s +<code>c</code> nor can they be "stepped-over" using the single-step command <code>s</code>. You need to declare the <code>ebreak</code> instruction +as breakpoint to be able to resume operation after executing it. See <a href="https://sourceware.org/pipermail/gdb/2021-January/049125.html" class="bare">https://sourceware.org/pipermail/gdb/2021-January/049125.html</a> +</td> +</tr> +</table> +</div> +</div> +<div class="sect3"> +<h4 id="_hardware_breakpoints">19.3.2. Hardware Breakpoints</h4> +<div class="paragraph"> +<p>Hardware-assisted breakpoints using the CPU&#8217;s trigger module are required when debugging code that is executed from +read-only memory (ROM) as GDB cannot temporarily replace instructions by BREAK instructions.</p> +</div> +<div class="paragraph"> +<p>From a user point of view hardware breakpoints behave like software breakpoints. GDB provides a command to setup +a hardware-assisted breakpoint:</p> +</div> +<div class="listingblock"> +<div class="title">Listing 19. Adding a GDB hardware breakpoint</div> +<div class="content"> +<pre class="highlight"><code class="language-bash" data-lang="bash">(gdb) hb * 0x690 <i class="conum" data-value="1"></i><b>(1)</b> +Breakpoint 1 at 0x690</code></pre> +</div> +</div> +<div class="colist arabic"> +<table> +<tr> +<td><i class="conum" data-value="1"></i><b>1</b></td> +<td><code>hb</code> is an alias for <code>hbreak</code>, which adds a <em>hardware</em> breakpoint.</td> +</tr> +</table> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +The CPU&#8217;s trigger module only provides a single <em>instruction address match</em> type trigger. Hence, only +a single <code>hb</code> hardware-assisted breakpoint can be used. +</td> +</tr> +</table> +</div> +</div> +</div> +<div class="sect2"> +<h3 id="_segger_embedded_studio">19.4. Segger Embedded Studio</h3> +<div class="paragraph"> +<p>Software for the NEORV32 processor can also be developed and debugged <em>in-system</em> using Segger Embedded Studio +and a Segger J-Link probe. The following links provide further information as well as an excellent tutorial.</p> +</div> +<div class="ulist"> +<ul> +<li> +<p>Segger Embedded Studio: <a href="https://www.segger.com/products/development-tools/embedded-studio" class="bare">https://www.segger.com/products/development-tools/embedded-studio</a></p> +</li> +<li> +<p>Segger notes regarding NEORV32: <a href="https://wiki.segger.com/J-Link_NEORV32" class="bare">https://wiki.segger.com/J-Link_NEORV32</a></p> +</li> +<li> +<p>Excellent tutorial: <a href="https://www.emb4fun.com/riscv/ses4rv/index.html" class="bare">https://www.emb4fun.com/riscv/ses4rv/index.html</a></p> +</li> +</ul> +</div> +<div style="page-break-after: always;"></div> +</div> +</div> +</div> +<div class="sect1"> +<h2 id="_neorv32_in_verilog">20. NEORV32 in Verilog</h2> +<div class="sectionbody"> +<div class="paragraph"> +<p>If you are more of a Verilog fan or if your EDA toolchain does not support VHDL or mixed-language designs +you can use an <strong>all-Verilog</strong> version of the processor provided by the <a href="https://github.com/stnolting/neorv32-verilog"><code>neorv32-verilog</code></a> repository.</p> +</div> +<div class="admonitionblock important"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-important" title="Important"></i> +</td> +<td class="content"> +Note that this is <strong>not a manual re-implementation of the core in Verilog</strong> but rather an automated conversion. +</td> +</tr> +</table> +</div> +<div class="paragraph"> +<p>GHDL&#8217;s synthesis feature is used to convert a pre-configured NEORV32 setup - including all peripherals, memories +and memory images - into an unoptimized plain-Verilog netlist module file without any (technology-specific) primitives.</p> +</div> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +<div class="title">GHDL Synthesis</div> +More information regarding GHDL&#8217;s synthesis option can be found at <a href="https://ghdl.github.io/ghdl/using/Synthesis.html" class="bare">https://ghdl.github.io/ghdl/using/Synthesis.html</a>. +</td> +</tr> +</table> +</div> +<div class="paragraph"> +<p>An intermediate VHDL wrapper is provided that can be used to configure the processor (using VHDL generics) and to customize +the interface ports. After conversion, a single Verilog file is generated that contains the whole NEORV32 processor. +The original processor module hierarchy is preserved as well as most (all?) signal names, which allows easy inspection and debugging +of simulation waveforms and synthesis results.</p> +</div> +<div class="listingblock"> +<div class="title">Listing 20. Example: interface of the resulting NEORV32 Verilog module (for a minimal SoC configuration)</div> +<div class="content"> +<pre class="highlight"><code class="language-verilog" data-lang="verilog">module neorv32_verilog_wrapper + (input clk_i, + input rstn_i, + input uart0_rxd_i, + output uart0_txd_o);</code></pre> +</div> +</div> +<div class="paragraph"> +<p>The generated Verilog netlist has been tested with +<a href="https://github.com/steveicarus/iverilog">Icarus Verilog</a> +(simulation) and AMD Vivado (simulation and synthesis).</p> +</div> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +For detailed information check out the <code>neorv32-verilog</code> repository at <a href="https://github.com/stnolting/neorv32-verilog" class="bare">https://github.com/stnolting/neorv32-verilog</a>. +</td> +</tr> +</table> +</div> +<div style="page-break-after: always;"></div> +</div> +</div> +<div class="sect1"> +<h2 id="_eclipse_ide">21. Eclipse IDE</h2> +<div class="sectionbody"> +<div class="paragraph"> +<p>Eclipse (<a href="https://www.eclipse.org/" class="bare">https://www.eclipse.org/</a>) is an interactive development environment that can be used to develop, debug and profile +application code for the NEORV32 RISC-V Processor. This chapter shows how to import the provided example setup +from the NEORV32 project repository. Additionally, all the required steps to create a compatible project from +scratch are illustrated in this chapter.</p> +</div> +<div class="admonitionblock important"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-important" title="Important"></i> +</td> +<td class="content"> +<div class="title">This is a Makefile-Based Project!</div> +Note that the provided Eclipse project as well as the setup tutorial in this section implement a <strong>makefile-based project</strong>. +Hence, the makefile in the example folder (that includes the main NEORV32 makefile) is used for building the application +instead of the Eclipse-managed build. Therefore, <strong>all compiler options, include folder, source files, etc. have to be +defined within the project&#8217;s makefile</strong>. +</td> +</tr> +</table> +</div> +<div class="imageblock text-center"> +<div class="content"> +<img src="../img/eclipse.png" alt="eclipse"> +</div> +<div class="title">Figure 5. Developing and debugging code for the NEORV32 using the Eclipse IDE</div> +</div> +<div class="sect2"> +<h3 id="_eclipse_prerequisites">21.1. Eclipse Prerequisites</h3> +<div class="paragraph"> +<p>The following tools are required:</p> +</div> +<div class="ulist"> +<ul> +<li> +<p>Eclipse IDE (<strong>Eclipse IDE for Embedded C/C++ Developers</strong>): <a href="https://www.eclipse.org/downloads/" class="bare">https://www.eclipse.org/downloads/</a></p> +</li> +<li> +<p>Precompiled RISC-V GCC toolchain: e.g. <a href="https://github.com/xpack-dev-tools/riscv-none-elf-gcc-xpack" class="bare">https://github.com/xpack-dev-tools/riscv-none-elf-gcc-xpack</a></p> +</li> +<li> +<p>Precompiled OpenOCD binaries: e.g. <a href="https://github.com/xpack-dev-tools/openocd-xpack" class="bare">https://github.com/xpack-dev-tools/openocd-xpack</a></p> +</li> +<li> +<p>Build tools like make: e.g. <a href="https://github.com/xpack-dev-tools/windows-build-tools-xpack" class="bare">https://github.com/xpack-dev-tools/windows-build-tools-xpack</a></p> +</li> +</ul> +</div> +<div class="admonitionblock important"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-important" title="Important"></i> +</td> +<td class="content"> +<div class="title">XPack Windows Build Tools</div> +The NEORV32 makefile relies on the <code>basename</code> command which is not part of the default XPack +Windows Build Tools. However, you can just open the <code>bin</code> folder, copy <code>busybox.exe</code> and rename +that copy to <code>basename.exe</code>. +</td> +</tr> +</table> +</div> +</div> +<div class="sect2"> +<h3 id="_import_the_provided_eclipse_example_project">21.2. Import The Provided Eclipse Example Project</h3> +<div class="paragraph"> +<p>A pre-configured Eclipse project is available in <code>neorv32/sw/example/eclipse</code>. +To import it:</p> +</div> +<div class="olist arabic"> +<ol class="arabic" start="1"> +<li> +<p>Open Eclipse.</p> +</li> +<li> +<p>Click on <strong>File &gt; Import</strong>, expand <strong>General</strong> and select <strong>Projects from Folder or Archive</strong>.</p> +</li> +<li> +<p>Click <strong>Next</strong>.</p> +</li> +<li> +<p>Click on <strong>Directory</strong> and select the provided example project folder (see directory above).</p> +</li> +<li> +<p>Click <strong>Finish</strong>.</p> +</li> +</ol> +</div> +<div class="admonitionblock important"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-important" title="Important"></i> +</td> +<td class="content"> +<div class="title">NEORV32 Folder and File Paths</div> +The provided example project uses <strong>relative paths</strong> for including all the NEORV32-specific files and folders +(in the Eclipse configuration files). Note that these paths need to be adjusted when moving this example setup +to a different location (makefile, NEORV32 sources, etc.). +</td> +</tr> +</table> +</div> +<div class="admonitionblock important"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-important" title="Important"></i> +</td> +<td class="content"> +<div class="title">Executables Configuration</div> +Make sure to adjust the binaries / installation folders of the RISC-V GCC toolchain +and OpenOCD according to your installation. See the following chapter for more information. +</td> +</tr> +</table> +</div> +</div> +<div class="sect2"> +<h3 id="_setup_a_new_eclipse_project_from_scratch">21.3. Setup a new Eclipse Project from Scratch</h3> +<div class="paragraph"> +<p>This chapter shows all the steps required to create an Eclipse project for the NEORV32 entirely from scratch.</p> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">This is an early version! ;)</div> +The provided Eclipse project as well as the tutorial from this chapter are in a very early stage. +This setup was build and tested on Windows. +Feel free to open a new issue or pull request to improve this setup. +</td> +</tr> +</table> +</div> +<div class="sect3"> +<h4 id="_create_a_new_project">21.3.1. Create a new Project</h4> +<div class="olist arabic"> +<ol class="arabic" start="1"> +<li> +<p>Select <strong>File &gt; New &gt; Project</strong>.</p> +</li> +<li> +<p>Expand <strong>C/C** and select **C project</strong>.</p> +</li> +<li> +<p>In the <strong>C++ Project</strong> wizard:</p> +<div class="ulist"> +<ul> +<li> +<p>Enter a <strong>Project name</strong>.</p> +</li> +<li> +<p>Uncheck the box next to <strong>Use default location</strong> and specify a location using <strong>Browse</strong> where you want to create the project.</p> +</li> +<li> +<p>From the <strong>Project type</strong> list expand <strong>Makefile project</strong> and select <strong>Empty Project</strong>.</p> +</li> +<li> +<p>Select <strong>RISC-V Cross GCC</strong> from the <strong>Toolchain</strong> list on the right side.</p> +</li> +<li> +<p>Click <strong>Next</strong>.</p> +</li> +<li> +<p>Skip the next page using the default configuration by clicking <strong>Next</strong>.</p> +</li> +</ul> +</div> +</li> +<li> +<p>In the <strong>GNU RISC-V Cross Toolchain</strong> wizard configure the <strong>Toolchain name</strong> and <strong>Toolchain path</strong> according to your RISC-V GCC installation.</p> +<div class="ulist"> +<ul> +<li> +<p>Example: <code>Toolchain name: xPack GNU RISC-V Embedded GCC (riscv-none-elf-gcc)</code></p> +</li> +<li> +<p>Example: <code>Toolchain path: C:\Program Files (x86)\xpack-riscv-none-elf-gcc-13.2.0-2\bin</code></p> +</li> +</ul> +</div> +</li> +<li> +<p>Click <strong>Finish</strong>.</p> +</li> +</ol> +</div> +<div class="paragraph"> +<p>If you need to reconfigure the RISC-V GCC binaries and/or paths:</p> +</div> +<div class="olist arabic"> +<ol class="arabic" start="1"> +<li> +<p>right-click on the projet in the left view, select <strong>Properties</strong></p> +</li> +<li> +<p>expand <strong>MCU</strong> and select <strong>RISC-V Toolchain Paths</strong></p> +</li> +<li> +<p>adjust the <strong>Toolchain folder</strong> and the <strong>Toolchain name</strong> if required</p> +</li> +<li> +<p>Click <strong>Apply</strong>.</p> +</li> +</ol> +</div> +</div> +<div class="sect3"> +<h4 id="_add_initial_files">21.3.2. Add Initial Files</h4> +<div class="paragraph"> +<p>Start a simple project by adding two initial files. Further files can be added later. Only the makefile is really +relevant here.</p> +</div> +<div class="olist arabic"> +<ol class="arabic" start="1"> +<li> +<p>Add a new file by right-clicking on the project and select <strong>New &gt; File</strong> and enter <code>main.c</code> in the filename box.</p> +</li> +<li> +<p>Add another new file by right-clicking on the project and select <strong>New &gt; File</strong> and enter <code>makefile</code> in the filename</p> +</li> +<li> +<p>Copy the makefile of an existing NEORV32 example program and paste it to the new (empty) makefile.</p> +</li> +</ol> +</div> +</div> +<div class="sect3"> +<h4 id="_add_build_targets_optional">21.3.3. Add Build Targets (optional)</h4> +<div class="paragraph"> +<p>This step adds some of the targets of the NEORV32 makefile for easy access. This step is optional.</p> +</div> +<div class="olist arabic"> +<ol class="arabic" start="1"> +<li> +<p>In the project explorer right-click on the project and select <strong>Build Target &gt; Create&#8230;&#8203;</strong>.</p> +</li> +<li> +<p>Add &#8220;all&#8221; as <strong>Target name</strong> (keep all the default checked boxes).</p> +</li> +<li> +<p>Repeat these steps for all further targets that you wish to add (e..g <code>clean_all</code>, <code>exe</code>, <code>elf</code>).</p> +</li> +</ol> +</div> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +<div class="title">Clean-All Target</div> +Adding the <code>clean_all</code> target is highly recommended. Executing this target once after importing the project ensures +that there are no (incompatible) artifacts left from previous builds. +</td> +</tr> +</table> +</div> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +<div class="title">Available Target</div> +See the NEORV32 data sheet for a list and description of all available makefile targets: +<a href="https://stnolting.github.io/neorv32/#_makefile_targets" class="bare">https://stnolting.github.io/neorv32/#_makefile_targets</a> +</td> +</tr> +</table> +</div> +</div> +</div> +<div class="sect2"> +<h3 id="_configure_build_tools">21.4. Configure Build Tools</h3> +<div class="paragraph"> +<p>This step is only required if your system does not provide any build tools (like <code>make</code>) by default.</p> +</div> +<div class="olist arabic"> +<ol class="arabic" start="1"> +<li> +<p>In the project explorer right-click on the project and select <strong>Properties</strong>.</p> +</li> +<li> +<p>Expand <strong>MCU</strong> and click on <strong>Build Tools Path</strong>.</p> +</li> +<li> +<p>Configure the <strong>Build tools folder</strong>.</p> +<div class="ulist"> +<ul> +<li> +<p>Example: <code>Build tools folder: C:/xpack/xpack-windows-build-tools-4.4.1-2/bin</code></p> +</li> +</ul> +</div> +</li> +<li> +<p>Click <strong>Apply and Close</strong>.</p> +</li> +</ol> +</div> +</div> +<div class="sect2"> +<h3 id="_adjust_default_build_configuration_optional">21.5. Adjust Default Build Configuration (optional)</h3> +<div class="paragraph"> +<p>This will simplify the auto-build by replacing the default <code>make all</code> command by <code>make elf</code>. Thus, only +the required <code>main.elf</code> file gets generated instead of <em>all</em> executable files (like HDL and memory image files).</p> +</div> +<div class="olist arabic"> +<ol class="arabic" start="1"> +<li> +<p>In the project explorer right-click on the project and select <strong>Properties</strong>.</p> +</li> +<li> +<p>Select <strong>C/C++ Build</strong> and click on the <strong>Behavior</strong> Tab.</p> +</li> +<li> +<p>Update the default targets in the <strong>Workbench Build Behavior</strong> box:</p> +<div class="ulist"> +<ul> +<li> +<p><strong>Build on resource save:</strong> <code>elf</code> (only build the ELF file)</p> +</li> +<li> +<p><strong>Build (Incremental build):</strong> <code>elf</code> (only build the ELF file)</p> +</li> +<li> +<p><strong>Clean:</strong> <code>clean</code> (only remove project-local build artifacts)</p> +</li> +</ul> +</div> +</li> +<li> +<p>Click <strong>Apply and Close</strong>.</p> +</li> +</ol> +</div> +<div class="sect3"> +<h4 id="_add_neorv32_software_framework">21.5.1. Add NEORV32 Software Framework</h4> +<div class="olist arabic"> +<ol class="arabic" start="1"> +<li> +<p>In the project explorer right-click on the project and select <strong>Properties</strong>.</p> +</li> +<li> +<p>Expand <strong>C/C++ General</strong>, click on <strong>Paths and Symbols</strong> and highlight <strong>Assembly</strong> under <strong>Languages</strong>.</p> +</li> +<li> +<p>In the <strong>Include</strong> tab click <strong>Add&#8230;&#8203;</strong></p> +<div class="ulist"> +<ul> +<li> +<p>Check the box in front of <strong>Add to all languages</strong> and click on <strong>File System&#8230;&#8203;</strong> and select the NEORV32 library include folder (<code>path/to/neorv32/sw/lib/include</code>).</p> +</li> +<li> +<p>Click <strong>OK</strong>.</p> +</li> +</ul> +</div> +</li> +<li> +<p>In the <strong>Include</strong> tab click <strong>Add&#8230;&#8203;</strong>.</p> +<div class="ulist"> +<ul> +<li> +<p>Check the box in front of <strong>Add to all languages</strong> and click on <strong>File System&#8230;&#8203;</strong> and select the NEORV32 commons folder (<code>path/to/neorv32/sw/common</code>).</p> +</li> +<li> +<p>Click <strong>OK</strong>.</p> +</li> +</ul> +</div> +</li> +<li> +<p>Click on the <strong>Source Location<strong> tab and click </strong>Link Folder&#8230;&#8203;</strong>*.</p> +<div class="ulist"> +<ul> +<li> +<p>Check the box in front of <strong>Link to folder in the system</strong> and click the <strong>Browse</strong> button.</p> +</li> +<li> +<p>Select the source folder of the NEORV32 software framework (<code>path/to/neorv32/sw/lib/source</code>).</p> +</li> +<li> +<p>Click <strong>OK</strong>.</p> +</li> +</ul> +</div> +</li> +<li> +<p>Click <strong>Apply and Close</strong>.</p> +</li> +</ol> +</div> +</div> +<div class="sect3"> +<h4 id="_setup_openocd">21.5.2. Setup OpenOCD</h4> +<div class="olist arabic"> +<ol class="arabic" start="1"> +<li> +<p>In the project explorer right-click on the project and select <strong>Properties</strong>.</p> +</li> +<li> +<p>Expand <strong>MCU</strong> and select <strong>OpenOCD Path</strong>.</p> +<div class="ulist"> +<ul> +<li> +<p>Configure the <strong>Executable</strong> and <strong>Folder</strong> according to your openOCD installation.</p> +</li> +<li> +<p>Example: <code>Executable: openocd.exe</code></p> +</li> +<li> +<p>Example: <code>Folder: C:\OpenOCD\bin</code></p> +</li> +<li> +<p>Click <strong>Apply and Close</strong>.</p> +</li> +</ul> +</div> +</li> +<li> +<p>In the top bar of Eclipse click on the tiny arrow right next to the <strong>Debug</strong> bug icon and select <strong>Debug Configurations</strong>.</p> +</li> +<li> +<p>Double-click on <strong>GDB OpenOCD Debugging</strong>; several menu tabs will open on the right.</p> +<div class="ulist"> +<ul> +<li> +<p>In the <strong>Main</strong> tab add <code>main.elf</code> to the <strong>C/C++ Application</strong> box.</p> +</li> +<li> +<p>In the <strong>Debugger</strong> tab add the NEORV32 OpenOCD script with a <code>-f</code> in front of it-</p> +</li> +<li> +<p>Example: <code>Config options: -f ../../openocd/openocd_neorv32.cfg</code></p> +</li> +<li> +<p>In the <strong>Startup</strong> tab uncheck he box in front of <strong>Initial Reset</strong> and add <code>monitor reset halt</code> to the box below.</p> +</li> +<li> +<p>In the "Common" tab mark <strong>Shared file</strong> to store the run-configuration right in the project folder instead of the workspace(optional).</p> +</li> +<li> +<p>In the <strong>SVD Path</strong> tab add the NEORV32 SVD file (<code>path/to/neorv32/sw/svd/neorv32.svd</code>).</p> +</li> +</ul> +</div> +</li> +<li> +<p>Click <strong>Apply</strong> and then <strong>Close</strong>.</p> +</li> +</ol> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">Default Debug Configuration</div> +When you start debugging the first time you might need to select the provided debug configuration: +<strong>GDB OpenOCD Debugging &gt; eclipse_example Default</strong> +</td> +</tr> +</table> +</div> +<div class="paragraph"> +<p>If you need to reconfigure OpenOCD binaries and/or paths:</p> +</div> +<div class="olist arabic"> +<ol class="arabic" start="1"> +<li> +<p>right-click on the projet in the left view, select <strong>Properties</strong></p> +</li> +<li> +<p>expand <strong>MCU</strong> and select <strong>OpenOCD Path</strong></p> +</li> +<li> +<p>adjust the <strong>Folder</strong> and the <strong>Executable</strong> name if required</p> +</li> +<li> +<p>Click <strong>Apply</strong>.</p> +</li> +</ol> +</div> +</div> +<div class="sect3"> +<h4 id="_setup_serial_terminal">21.5.3. Setup Serial Terminal</h4> +<div class="paragraph"> +<p>A serial terminal can be added to Eclipse by installing it as a plugin. +I recommend "TM Terminal" which is already installed in some Eclipse bundles.</p> +</div> +<div class="paragraph"> +<p>Open a TM Terminal serial console:</p> +</div> +<div class="olist arabic"> +<ol class="arabic" start="1"> +<li> +<p>Click on <strong>Window &gt; Show View &gt; Terminal</strong> to open the terminal.</p> +</li> +<li> +<p>A <strong>Terminal</strong> tab appears on the bottom. Click the tiny screen button on the right (or press Ctrl+Alt+Shift) +to open the terminal configuration.</p> +</li> +<li> +<p>Select <strong>Serial Terminal</strong> in <strong>Choose Terminal</strong> and configure the settings according to the processor&#8217;s +UART configuration.</p> +</li> +</ol> +</div> +<div class="paragraph"> +<p>Installing TM Terminal from the Eclipse market place:</p> +</div> +<div class="olist arabic"> +<ol class="arabic" start="1"> +<li> +<p>Click on <strong>Help &gt; Eclipse Marketplace&#8230;&#8203;</strong>.</p> +</li> +<li> +<p>Enter "TM Terminal" to the <strong>Find</strong> line and hit enter.</p> +</li> +<li> +<p>Select <strong>TM Terminal</strong> from the list and install it.</p> +</li> +<li> +<p>After installation restart Eclipse.</p> +</li> +</ol> +</div> +</div> +</div> +<div class="sect2"> +<h3 id="_eclipse_setup_references">21.6. Eclipse Setup References</h3> +<div class="ulist"> +<ul> +<li> +<p>Eclipse help: <a href="https://help.eclipse.org/latest/index.jsp" class="bare">https://help.eclipse.org/latest/index.jsp</a></p> +</li> +<li> +<p>Importing an existing project into Eclipse: <a href="https://help.eclipse.org/latest/index.jsp?topic=%2Forg.eclipse.cdt.doc.user%2Fgetting_started%2Fcdt_w_import.htm" class="bare">https://help.eclipse.org/latest/index.jsp?topic=%2Forg.eclipse.cdt.doc.user%2Fgetting_started%2Fcdt_w_import.htm</a></p> +</li> +<li> +<p>Eclipse OpenOCD Plug-In: <a href="https://eclipse-embed-cdt.github.io/debug/openocd/" class="bare">https://eclipse-embed-cdt.github.io/debug/openocd/</a></p> +</li> +</ul> +</div> +<div style="page-break-after: always;"></div> +</div> +</div> +</div> +<div class="sect1"> +<h2 id="_legal">22. Legal</h2> +<div class="sectionbody"> +<div class="sect2"> +<h3 id="_about">About</h3> +<div class="exampleblock"> +<div class="content"> +<div class="paragraph"> +<p><strong>The NEORV32 RISC-V Processor</strong><br> +<a href="https://github.com/stnolting/neorv32" class="bare">https://github.com/stnolting/neorv32</a><br> +Dipl.-Ing. Stephan Nolting (M.Sc.)<br> +🇪🇺 European Union, Germany<br> +<a href="mailto:stnolting@gmail.com">stnolting@gmail.com</a></p> +</div> +</div> +</div> +</div> +<div class="sect2"> +<h3 id="_license">License</h3> +<div class="paragraph"> +<p><strong>BSD 3-Clause License</strong></p> +</div> +<div class="paragraph"> +<p>Copyright (c) NEORV32 contributors. +Copyright (c) 2020 - 2024, Stephan Nolting. All rights reserved.</p> +</div> +<div class="paragraph"> +<p>Redistribution and use in source and binary forms, with or without modification, are permitted provided that +the following conditions are met:</p> +</div> +<div class="olist arabic"> +<ol class="arabic"> +<li> +<p>Redistributions of source code must retain the above copyright notice, this list of conditions and the +following disclaimer.</p> +</li> +<li> +<p>Redistributions in binary form must reproduce the above copyright notice, this list of conditions and +the following disclaimer in the documentation and/or other materials provided with the distribution.</p> +</li> +<li> +<p>Neither the name of the copyright holder nor the names of its contributors may be used to endorse or +promote products derived from this software without specific prior written permission.</p> +</li> +</ol> +</div> +<div class="paragraph"> +<p>THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" +AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE +IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE +ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE +LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR +CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF +SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS +INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN +CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) +ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED +OF THE POSSIBILITY OF SUCH DAMAGE.</p> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">SPDX Identifier</div> +<code>SPDX-License-Identifier: BSD-3-Clause</code> +</td> +</tr> +</table> +</div> +<div style="page-break-after: always;"></div> +</div> +<div class="sect2"> +<h3 id="_proprietary_notice">Proprietary Notice</h3> +<div class="ulist"> +<ul> +<li> +<p>"GitHub" is a Subsidiary of Microsoft Corporation.</p> +</li> +<li> +<p>"Vivado" and "Artix" are trademarks of AMD Inc.</p> +</li> +<li> +<p>"AXI", "AXI", "AXI4-Lite", "AXI4-Stream", "AHB", "AHB3" and "AHB3-Lite" are trademarks of Arm Holdings plc.</p> +</li> +<li> +<p>"ModelSim" is a trademark of Mentor Graphics – A Siemens Business.</p> +</li> +<li> +<p>"Quartus Prime" and "Cyclone" are trademarks of Intel Corporation.</p> +</li> +<li> +<p>"iCE40", "UltraPlus" and "Radiant" are trademarks of Lattice Semiconductor Corporation.</p> +</li> +<li> +<p>"Windows" is a trademark of Microsoft Corporation.</p> +</li> +<li> +<p>"Tera Term" copyright by T. Teranishi.</p> +</li> +<li> +<p>"NeoPixel" is a trademark of Adafruit Industries.</p> +</li> +<li> +<p>"Segger Embedded Studio" and "J-Link" are trademarks of Segger Microcontroller Systems GmbH.</p> +</li> +<li> +<p>Images/figures made with <em>Microsoft Power Point</em>.</p> +</li> +<li> +<p>Timing diagrams made with <em>WaveDrom Editor</em>.</p> +</li> +<li> +<p>Documentation made with <code>asciidoctor</code>.</p> +</li> +</ul> +</div> +<div class="paragraph"> +<p>All further/unreferenced projects/products/brands belong to their according copyright holders. +No copyright infringement intended.</p> +</div> +</div> +<div class="sect2"> +<h3 id="_disclaimer">Disclaimer</h3> +<div class="paragraph"> +<p>This project is released under the BSD 3-Clause license. No copyright infringement intended. +Other implied or used projects/sources might have different licensing – see their according +documentation for more information.</p> +</div> +</div> +<div class="sect2"> +<h3 id="_limitation_of_liability_for_external_links">Limitation of Liability for External Links</h3> +<div class="paragraph"> +<p>This document contains links to the websites of third parties ("external links"). As the content of these websites +is not under our control, we cannot assume any liability for such external content. In all cases, the provider of +information of the linked websites is liable for the content and accuracy of the information provided. At the +point in time when the links were placed, no infringements of the law were recognizable to us. As soon as an +infringement of the law becomes known to us, we will immediately remove the link in question.</p> +</div> +</div> +<div class="sect2"> +<h3 id="_citing">Citing</h3> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +This is an open-source project that is free of charge. Use this project in any way you like +(as long as it complies to the permissive license). Please cite it appropriately. 👍 +</td> +</tr> +</table> +</div> +<div class="admonitionblock note"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-note" title="Note"></i> +</td> +<td class="content"> +<div class="title">Contributors &amp; Community 🤝</div> +Please add as many <a href="https://github.com/stnolting/neorv32/graphs/contributors">contributors</a> as possible to the <code>author</code> field.<br> +This project would not be where it is without them. +</td> +</tr> +</table> +</div> +<div class="admonitionblock tip"> +<table> +<tr> +<td class="icon"> +<i class="fa icon-tip" title="Tip"></i> +</td> +<td class="content"> +<div class="title">DOI</div> +This project provides a <em>digital object identifier</em> provided by <a href="https://zenodo.org">zenodo</a>: +<a href="https://doi.org/10.5281/zenodo.5018888"><span class="image"><img src="https://zenodo.org/badge/DOI/10.5281/zenodo.5018888.svg" alt="zenodo.5018888" title="zenodo"></span></a> +</td> +</tr> +</table> +</div> +</div> +<div class="sect2"> +<h3 id="_acknowledgments">Acknowledgments</h3> +<div class="paragraph"> +<p><strong>A big shout-out to the community and all the <a href="https://github.com/stnolting/neorv32/graphs/contributors">contributors</a>, +who helped improving this project! This project would not be where it is without them. ❤️</strong></p> +</div> +<div class="paragraph"> +<p><a href="https://riscv.org">RISC-V</a> - instruction sets want to be free!</p> +</div> +<div class="paragraph"> +<p>Continuous integration provided by <a href="https://github.com/features/actions">GitHub Actions</a> and powered by <a href="https://github.com/ghdl/ghdl">GHDL</a>.</p> +</div> +</div> +</div> +</div> +</div> +<div id="footer"> +<div id="footer-text"> +Version v1.10.1-r126-g74b0d5cf<br> +</div> +</div> +<script type="text/x-mathjax-config"> +MathJax.Hub.Config({ + messageStyle: "none", + tex2jax: { + inlineMath: [["\\(", "\\)"]], + displayMath: [["\\[", "\\]"]], + ignoreClass: "nostem|nolatexmath" + }, + asciimath2jax: { + delimiters: [["\\$", "\\$"]], + ignoreClass: "nostem|noasciimath" + }, + TeX: { equationNumbers: { autoNumber: "none" } } +}) +MathJax.Hub.Register.StartupHook("AsciiMath Jax Ready", function () { + MathJax.InputJax.AsciiMath.postfilterHooks.Add(function (data, node) { + if ((node = data.script.parentNode) && (node = node.parentNode) && node.classList.contains("stemblock")) { + data.math.root.display = "block" + } + return data + }) +}) +</script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.9/MathJax.js?config=TeX-MML-AM_HTMLorMML"></script> +</body> +</html> \ No newline at end of file

P4((K}a-w({|$%xmw;`!&zJya}~ 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 JD3db{_&=k5k~shX literal 0 HcmV?d00001 diff --git a/img/neorv32_logo.png b/img/neorv32_logo.png new file mode 100644 index 0000000000000000000000000000000000000000..e90abe6afd2685b5a0212328d95dc43dd1d4c737 GIT binary patch literal 11461 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