Commit Graph

9367 Commits

Author SHA1 Message Date
enjoy-digital bf1349bd17
Merge pull request #1458 from antmicro/rowhammer-etherbone-retry
Added retransmission logic for EtherBone UDP reads.
2022-10-12 11:27:43 +02:00
Florent Kermarrec ac3699770c interconnect/stream/ClockDomainCrossing: Expose buffered parameter. 2022-10-06 18:30:02 +02:00
enjoy-digital 75bf668883
Merge pull request #1450 from tpwrules/improve-intel-pll-calculation
soc/cores/clock: improve Intel PLL calculation
2022-10-06 12:06:58 +02:00
enjoy-digital b47ebf2ce7
Merge pull request #1449 from tpwrules/fix-quartus-clock-constraints
build/altera: fix clock constraints
2022-10-06 11:59:31 +02:00
Gwenhael Goavec-Merou 536e24f715 soc/cores/cpu/neorv32: convert to VHDLWrapper 2022-10-05 14:10:45 +02:00
Gwenhael Goavec-Merou 8eef2cda0d build/VHDLWrapper: adding a class to factorize VHDL handling 2022-10-05 14:09:06 +02:00
Florent Kermarrec aa17c27eb9 interconnect/axi/axi_stream: Add clock_domain parameters.
Useful for wrapping IP and do checks or decide if CDC has to be inserted.
2022-10-05 11:07:34 +02:00
Thomas Watson fea73d932e soc/cores/clock/intel: speed up PLL config computation
Caching the list of clock divisors to test speeds up computation by
about a factor of three.
2022-10-01 13:08:16 -05:00
Thomas Watson b7ef989963 soc/cores/clock/intel_*: respect PFD input frequency
Only use input clock divisors which respect the device limitation for
the phase-frequency detector's input frequency. This avoids errors where
Quartus complains the PLL parameters are invalid and refuses to
implement it.

The supported PFD frequencies in integer mode have been verified against
each family's datasheet. The unsupported-by-LiteX fractional frequency
information is removed for clarity.

As a bonus, this speeds up PLL config computation by several times.
2022-10-01 13:00:24 -05:00
Thomas Watson d89d6dfd0a soc/cores/clock/intel_common: cleanup 2022-10-01 12:28:32 -05:00
Thomas Watson d531a07719 build/altera: fix clock constraints
This fixes two issues that prevented clock constraints (e.g.
"add_false_path_constraint") from working properly in Quartus.

The first fix passes the "keep" synthesis attribute through to the
generated Verilog in a way Quartus can understand.

The second fix tells Quartus to name PLL clocks according to their net
instead of the physical pin name by passing the "use_net_name" flag to
"derive_pll_clocks" in the .sdc file. Combined with the above, PLL
clocks will now be named according to the kept net.

This fix has been verified on Quartus Prime Lite 20.1.1.720.
2022-09-30 23:33:52 -05:00
Thomas Watson d27d6fca62 soc/cores/video: fix framebuffer color output
An earlier patch fixed the swapped red and blue channels on the HDMI
PHYs. This exposed the fact that the framebuffer readout was swapped
too.

The framebuffer readout is fixed by this patch to match the r5g6b5 and
a8b8g8r8 color format definitions documented in the Linux kernel's
simplefb driver and used by LiteX:
https://www.kernel.org/doc/Documentation/devicetree/bindings/display/simple-framebuffer.txt

This has been tested using 16 bit SDRAM in both supported color formats.

Additionally the green color used by the video terminal is swapped. It
now matches the color used by LiteX on Ubuntu's terminal, from which it
was probably originally sourced.
2022-09-30 19:15:56 -05:00
Dolu1990 3836e8a36c
Merge pull request #1447 from enjoy-digital/naxriscv-merge
cpu/naxriscv reduce memory latency on peripheral accesses
2022-09-30 16:21:23 +02:00
Florent Kermarrec 43699f2768 interconnect/axi/axi_common: Add missing param signals from connect_to_pads. 2022-09-30 14:36:46 +02:00
Dolu1990 c9f669d4ec Merge branch 'master' into naxriscv-merge
# Conflicts:
#	litex/soc/cores/cpu/naxriscv/core.py
2022-09-30 13:37:03 +02:00
Florent Kermarrec 79392e6eb8 soc/cores/jtag/Efinix: Cosmetic cleanups and rename EFINIX_JTAG to EfinixJTAG. 2022-09-30 13:34:00 +02:00
enjoy-digital b5b820b27f
Merge pull request #1446 from enjoy-digital/vexriscv-smp-merge
Add Efinix JTAG support, with vexriscv-smp binding function
2022-09-30 13:17:13 +02:00
Dolu1990 622a35fd4e Improve naxriscv peripheral latency 2022-09-30 11:52:14 +02:00
Dolu1990 cb0e9c23d3 Add Efinix JTAG support, with vexriscv-smp binding function 2022-09-30 11:48:07 +02:00
Florent Kermarrec af58237203 software/demo: Add comments for Nix specific changes (To ease future maintenance and avoid breaking it). 2022-09-29 17:30:09 +02:00
enjoy-digital 1fb1cf19e5
Merge pull request #1434 from tpwrules/fix-bare-metal-demo
demo: fix minor build issues
2022-09-29 17:20:12 +02:00
Florent Kermarrec c5eaac9c3e build/xilinx/vivado: Cosmetic cleanup. 2022-09-29 17:16:16 +02:00
enjoy-digital 28fb3962df
Merge pull request #1444 from cklarhorst/more_vivado_options
Vivado: Make directives configurable via argparser
2022-09-29 17:12:44 +02:00
enjoy-digital ad8b7da63d
Merge pull request #1442 from trabucayre/video_swap_blue_red
soc/cores/video: swap red and blue channel
2022-09-29 17:04:09 +02:00
Christian Klarhorst 8ffdc535d1 Vivado: Make directives configurable via argparser + add option to limit vivado threads 2022-09-29 15:42:15 +02:00
Gwenhael Goavec-Merou dc0a4ea40b soc/cores/video: swap red and blue channel 2022-09-27 08:07:31 +02:00
Dolu1990 c717e4c824
Merge pull request #1440 from cklarhorst/naxriscv
Naxriscv: Add two more argparser options for devs
2022-09-26 12:48:47 +02:00
Christian Klarhorst 9c43fe85c6 cpu/naxriscv: Add --no-netlist-cache
Ignores the netlist cache.
When you hack on naxriscv code, you always want fresh results.
2022-09-25 21:00:03 +02:00
Christian Klarhorst 7795fba3cf cpu/naxriscv: Add --update-repo option & check for update errors
Allows different update strategies which I find useful.
The git update process now checks the return code! So that problems in the update process can be noticed.
2022-09-25 20:51:37 +02:00
Gwenhael Goavec-Merou 759530f272 build/generic_platform, generic_toolchain, yosys_nextpnr_wrapper: introduce the information about ability to do synthesis with mixed languages 2022-09-23 19:02:48 +02:00
Florent Kermarrec b8e22fcd79 interconnect/axi: Simplify/Fix IOs generation. (Param signals were missing for AXIFull). 2022-09-22 09:54:58 +02:00
Gabriel Somlo 162a0a4c1e cpu/rocket: fix variant typos
The `fulld` and `fullq` variants point to the wrong (`LitexFullConfig`)
verilog. Fix by pointing to the correct code (`LitexFullDConfig` and
`LitexFullQConfig`, respectively).

Reported-by: Ioannis Ioannou <roryt@roryt.gr>
Signed-off-by: Gabriel Somlo <gsomlo@gmail.com>
2022-09-20 09:29:46 -04:00
Maciej Kurc cb8e0193fc Added retransmission logic for EtherBone UDP reads.
Signed-off-by: Maciej Kurc <mkurc@antmicro.com>
2022-09-20 09:26:24 +02:00
Florent Kermarrec e12af4f050 interconnect/axi/axi_stream: Fix get_ios and base it on length of created Endpoint's signals. 2022-09-20 09:08:22 +02:00
enjoy-digital 23db2e65f4
Merge pull request #1437 from trabucayre/yosys_nextpnr_refactor_args
build/yosys,nextpnr, lattice: refactor args
2022-09-19 19:29:34 +02:00
Gwenhael Goavec-Merou e9f6642d8f build/yosys,nextpnr, lattice: refactor args 2022-09-19 19:08:25 +02:00
Florent Kermarrec 32272ba855 axi/axi_stream: Set default keep_width to None and automatically set it to data_width//8 when not specified. 2022-09-19 13:28:42 +02:00
enjoy-digital 860c757f33
Merge pull request #1435 from gsomlo/gls-yosys-flow3
yosys_nextpnr_toolchain: add flow3 option to abc9 mode
2022-09-19 09:18:00 +02:00
Gabriel Somlo 441042bef4 yosys_nextpnr_toolchain: add flow3 option to abc9 mode
Add "flow3" option to abc9 mode. This runs FPGA mapping several times,
producing a generally better mapping at the cost of increased runtime
(see https://github.com/Ravenslofty/yosys-cookbook/blob/master/ecp5.md).

Also, add a "--yosys-flow3" build option to both "trellis" and "oxide".

Signed-off-by: Gabriel Somlo <gsomlo@gmail.com>
2022-09-18 08:28:40 -04:00
Thomas Watson d7837f8751 demo: fix minor build issues 2022-09-17 19:05:45 -05:00
Thomas Watson 5b524485e8 increase jtaguart speed using large transfers in openocd 2022-09-17 17:57:18 -05:00
Florent Kermarrec c24bbedb68 interconnect/axi/axi_full: Fix AXIUpConverter compilation. 2022-09-16 14:06:22 +02:00
Florent Kermarrec 1e1e75dba7 software/bios/boot: Fix missing CONFIG_BIOS_NO_DELAYS update. 2022-09-16 14:05:45 +02:00
Florent Kermarrec fa902281aa integration/common/get_mem_data: Allow filemane_or_regions to be None and add endianness assertion. 2022-09-16 14:05:20 +02:00
Florent Kermarrec d36f98bf45 axi/axi_full: Simplify by switching AXI channels to AXIStreamInterface. 2022-09-15 15:52:03 +02:00
Florent Kermarrec bc385c7358 interconnect/axi/axi_stream: Simplify by always adding id/dest/user to endpoints and add layout/name parameters for more flexibility. 2022-09-15 15:25:59 +02:00
Florent Kermarrec 3cd4a3830c cores/dma/WishboneDMAWriter: Add ready_on_idle parameter and set it to 1 by default.
This allows controlling ready behavior on idle state.
2022-09-14 10:02:07 +02:00
enjoy-digital 0adb604c97
Merge pull request #1423 from zyp/improve_dma
Improve DMA
2022-09-14 09:57:43 +02:00
Dolu1990 89bb688500
Merge pull request #1426 from enjoy-digital/naxriscv-merge
cpu/NaxRiscv fix peripheral bus width to 32 bits and CLINT is now protected from overflow glitches
2022-09-12 23:25:47 +02:00
Dolu1990 0a380b9c3b cpu/NaxRiscv improve peripheral read/write speed by staying 32 bits 2022-09-12 19:19:35 +02:00