-
-
Notifications
You must be signed in to change notification settings - Fork 336
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Disable vertical sync signal when composite sync is enabled #911
Comments
If I understand correctly, this line is what should be fixed: https://github.com/MiSTer-devel/Template_MiSTer/blob/master/sys/sys_top.v#L1476 I don't understand the logic here. Is "| csync_en" at the end really correct and intended? |
The result of the nested ternary is being OR'd with csync_en. If csync_en is high then VGA_VS is driven high. (I think) |
Do you have any thoughts why it would make sense to drive it high? Perhaps it's a bug and the intention was to drive it low to precisely avoid the issue I'm describing with devices that do their own HSYNC+VSYNC composition? (i.e. should be & ~csync_en). |
Maybe it's for RGsB output where Sync on Green and Composite Sync are both enabled? Not sure, sorg or someone else would have to answer this to be 100% sure. I was just translating what that code is doing for ya. To me it looks like treating csync as a clock enable signal for vsync. So synchronizing vsync to csync I guess. |
Vsync is driven high because it is used as a voltage source for SCART to switch the TV into RGB mode. Also Hsync/Vsync are usually active low so driving it high disables Vsync. |
Thanks for the quick reply, that makes sense. And now that I think about it for a XNOR gate, driving the VSYNC input high should be correct so that the XNOR gate becomes a no-op, duh. I need to look deeper into this. What is happening though is that with composite_sync=1, going into some sync combinators with VSYNC and HSYNC both connected messes up sync. Perhaps the only "fix" would be to leave HSYNC floating (is that something we can do?). I'll look deeper. |
Originally VSYNC=1 when composite sync is active. upd: it's really VSYNC=1 when csync_en=1, so i don't know why it doesn't work for you. |
Summary of the problem: When composite_sync=1 is set, the HSYNC line carries HSYNC+VSYNC as expected. However, the VSYNC line still carries the VSYNC signal. This creates a number of issues with devices that use a XOR/XNOR gate to combine VSYNC and HSYNC.
Suggested fix: Instead the VSYNC signal should not be sent when composite_sync=1 is set.
Many devices with HD-15 inputs XNOR the HSYNC and VSYNC line to get composite sync. This approach works great with many sources, including sources with separate HSYNC and VSYNC signals and sources with composite sync on the HSYNC line. However with MiSTer it doesn't work since mister doesn't disabled VSYNC on the VSYNC line.
This creates two potential issues:
The text was updated successfully, but these errors were encountered: