-
Notifications
You must be signed in to change notification settings - Fork 110
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
Add ULX3S. #90
Add ULX3S. #90
Conversation
Note: failing check is elsewhere ( |
That's indeed what we do. Also, right now no
We don't currently do this consistently, #89.
I would actually use a single connector with |
Something like this? connectors = [
Connector("gpio", 0, {
"0+": "B11", "0-": "C11", "1+": "A10", "1-": "A11",
"2+": "A9", "2-": "B10", "3+": "B9", "3-": "C10",
"4+": "A7", "4-": "A8", "5+": "C8", "5-": "B8",
"6+": "C6", "6-": "C7", "7+": "A6", "7-": "B6",
"8+": "A4", "8-": "A5", "9+": "A2", "9-": "B1",
"10-": "C4", "10-": "B4", "11-": "F4", "11-": "E3",
"12-": "G3", "12-": "F3", "13-": "H4", "13-": "G5",
"14-": "U18", "14-": "U17", "15-": "N17", "15-": "P16",
"16-": "N16", "16-": "M17", "17-": "L16", "17-": "L17",
"18-": "H18", "18-": "H17", "19-": "F17", "19-": "G18",
"20-": "D18", "20-": "E17", "21-": "C18", "21-": "D17",
"22-": "B15", "22-": "C15", "23-": "B17", "23-": "C17",
"24-": "C16", "24-": "D16", "25-": "D14", "25-": "E14",
"26-": "B13", "26-": "C13", "27-": "D13", "27-": "E13",
})
] I'm honestly not sure what's really convenient, here, so I'm entirely ambivalent. |
I considered ways to do this, and decided That said, if we had a nice pattern of saying "if this tool is here, do this" until one succeeds, that might be a good thing to establish.
Yep. Read through 89; and I don't think this is any of the patterns that have been used thus far, since I'm using a single file for four platforms. One downside of what I'm doing here is that the On the other hand, it seems like creating a file for each inherited subtype can easily create lots of namespace sprawl -- (imagine an ECP5 board that's sometimes populated with e.g. 12F, 25F, 45F, 85F, the SerDes variants, the 5G SerDes variants, etc). |
Something like this, yeah.
I was thinking that it would need explicit selection, since there could be confusing issues otherwise: maybe you have
Perhaps use |
Done; though we should probably think standardizing some of this and/or adding in some helper infrastructure, since I imagine that this boilerplate might be repeated several times in boards with different variants: if __name__ == "__main__":
from .test.blinky import *
variants = {
'12F': ULX3S_12F_Platform,
'25F': ULX3S_25F_Platform,
'45F': ULX3S_45F_Platform,
'85F': ULX3S_85F_Platform
}
# Figure out which FPGA variant we want to target...
parser = argparse.ArgumentParser()
parser.add_argument('variant', choices=variants.keys())
args = parser.parse_args()
# ... and run Blinky on it.
platform = variants[args.variant]
platform().build(Blinky(), do_program=True) Want me to summarize this commentary in #89, or open a new 'improvement'? |
I'm generally fine with the amount of boilerplate in nmigen-boards at the moment and I feel like there's no urgent need to factor out this sort of infrastructure, so I think for now a summary in #89 should be enough. |
Done. Is this ready to merge, or do we want to give a day or so in case any good feedback gathers in #89? |
(It was ready to merge.) |
Some interesting things about this platform that might be questionable here:
toolchain_program
that uses the tool that seems to be most widely in repos.0+
,0-
,1+
,1-
).