From 149ac2fcefb14d6fd9f9da435dc86ff234fb7e52 Mon Sep 17 00:00:00 2001 From: Romain Dolbeau Date: Tue, 20 Dec 2022 08:19:41 +0100 Subject: [PATCH] preliminary support for the hdl-util/hdmi contorller as an alternative --- nubus-to-ztex-gateware/VintageBusFPGA_Common | 2 +- nubus-to-ztex-gateware/nubus_to_fpga_soc.py | 15 ++++++++++++--- 2 files changed, 13 insertions(+), 4 deletions(-) diff --git a/nubus-to-ztex-gateware/VintageBusFPGA_Common b/nubus-to-ztex-gateware/VintageBusFPGA_Common index c708a83..59e3973 160000 --- a/nubus-to-ztex-gateware/VintageBusFPGA_Common +++ b/nubus-to-ztex-gateware/VintageBusFPGA_Common @@ -1 +1 @@ -Subproject commit c708a834691efb34bbcc7d4c0022dd2f59aa7e4d +Subproject commit 59e39731defcad164ff30f395f7fa079e63a78af diff --git a/nubus-to-ztex-gateware/nubus_to_fpga_soc.py b/nubus-to-ztex-gateware/nubus_to_fpga_soc.py index d9059ed..35ebd21 100644 --- a/nubus-to-ztex-gateware/nubus_to_fpga_soc.py +++ b/nubus-to-ztex-gateware/nubus_to_fpga_soc.py @@ -30,7 +30,6 @@ from migen.genlib.resetsync import AsyncResetSynchronizer from litex.soc.cores.video import VideoS7HDMIPHY from litex.soc.cores.video import VideoVGAPHY from litex.soc.cores.video import video_timings -from VintageBusFPGA_Common.goblin_fb import * from VintageBusFPGA_Common.goblin_accel import * # Wishbone stuff @@ -164,6 +163,12 @@ class NuBusFPGA(SoCCore): self.platform = platform = ztex213_nubus.Platform(variant = variant, version = version) + use_goblin_alt = True + if ((not use_goblin_alt) or (not hdmi)): + from VintageBusFPGA_Common.goblin_fb import goblin_rounded_size, Goblin + else: + from VintageBusFPGA_Common.goblin_alt_fb import goblin_rounded_size, GoblinAlt + if (goblin): hres = int(goblin_res.split("@")[0].split("x")[0]) vres = int(goblin_res.split("@")[0].split("x")[1]) @@ -418,8 +423,12 @@ class NuBusFPGA(SoCCore): self.submodules.videophy = VideoVGAPHY(platform.request("vga"), clock_domain="vga") self.submodules.goblin = Goblin(soc=self, phy=self.videophy, timings=goblin_res, clock_domain="vga", irq_line=fb_irq, endian="little", hwcursor=False, truecolor=True) # clock_domain for the VGA side, goblin is running in cd_sys else: - self.submodules.videophy = VideoS7HDMIPHY(platform.request("hdmi"), clock_domain="hdmi") - self.submodules.goblin = Goblin(soc=self, phy=self.videophy, timings=goblin_res, clock_domain="hdmi", irq_line=fb_irq, endian="little", hwcursor=False, truecolor=True) # clock_domain for the HDMI side, goblin is running in cd_sys + if (not use_goblin_alt): + self.submodules.videophy = VideoS7HDMIPHY(platform.request("hdmi"), clock_domain="hdmi") + self.submodules.goblin = Goblin(soc=self, phy=self.videophy, timings=goblin_res, clock_domain="hdmi", irq_line=fb_irq, endian="little", hwcursor=False, truecolor=True) # clock_domain for the HDMI side, goblin is running in cd_sys + else: + # GoblinAlt contains its own PHY + self.submodules.goblin = GoblinAlt(soc=self, timings=goblin_res, clock_domain="hdmi", irq_line=fb_irq, endian="little", hwcursor=False, truecolor=True) self.bus.add_slave("goblin_bt", self.goblin.bus, SoCRegion(origin=self.mem_map.get("goblin_bt", None), size=0x1000, cached=False)) #pad_user_led_0 = platform.request("user_led", 0) #pad_user_led_1 = platform.request("user_led", 1)