-
Notifications
You must be signed in to change notification settings - Fork 251
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
Missing Documentation Information Re: Adding Bare FPGAs as Options Under [Select] -> [Board] #646
Comments
hello Richard, If i understood well, about the Fpgaresources in the info.json files, they are not actually been used by icestudio (eg: for the colorligth boards they are not exact and it does cause any problem). Q1: ? Q3: the pinout.json file is use to make visible the fpga pins in icestudio ports dropbox:
Remark: for now, we should not rename a pin with a name include in another pin! Because one of the two pins will eg: the two following lines will be problematic. as you see the string "IOL_1" is also included in the string "IOL_16" @ Carlos/Charliva: i just saw that same problem on the workshop badge board created yesterday! {"name":"lcd_rst_n","value":"36","type":"output"}, You can change the "lcd_rs" to "lcd_rs_" Q9: No, the wiki indicates, correctly, thaht menu.json is in folder resources/boards/menu.json Some food and, will continue to reply to Q4..Q8 later ;-) .... |
hi! ireply you in the afternoon with calm. But important thing is that pinout.json could be generated from pcf with the python script utility located in the same directory that boards definition. You should complete the pcf file and then execute: python generator.py name_of_the_board name_of_the_board is the folder with the board definition. This scripts generate pinout.json In rules.json, for the moment, the only important thing is indicate as input the clk line and named it clk, if you put other name icestudio dont recognize it for this important function. about the IOL_1 and _16 is the same as the rs and rst and this is a bug! thanks i'll fix this afternoon and try to documented better this process. @jojo535275 try to help to @albatroxx and in this way we could take advantage of this issue to documented very well this process. Thanks a lot! |
Thank Carlos for the .pcf precisions, it is true that for the colorligth board, Benitos and myself went directly to a manual edition of the pinout.json file (without creating any pcf files!)! Let us continue with Richard questions, Q4: about rules.json, Cavear replied on his above post The think is that icestudio is made for drawing a design, build-it (synthesys+routing) and also loading it in our fpga! And for that last action, as you mentioned a programmer is needed (they are never included in any fpga chip). Q5: in theory, if you just want to compile (generate a bitstream file), i suppose, you can just let the programmer field empty! And you will just not be able to run the upload function! Q7: PCF = Physical Constraint File for lattice chips. Basically, it defines how your top-level signals attach to fpga pins, and has lines like this: set_io clk 78 a bit more info here: https://forum.mystorm.uk/t/syntax-of-pcf-file/383/5 Q8: No, the wiki indicates, correctly, thaht menu.json is in folder resources/boards/menu.json Have a nice evening |
Hi @albatroxx ! i'm focusing in your issue i think with your help is a good moment to put on the top of the todo list this task that is stopped for a long time and every day is more important. Thanks a lot! I dont have any bare fpga chip and i need your help to try and give us your feedback Give me a little to return the source that i've been starting to code few months ago and i stopped to prioritize other tasks. While i rescue it, i need some things for you:
|
It seems I can't select a bare FPGA chip as a target, only a dev board. In theory it seems like it would be super easy to add support for the bare chips because all of the variants of at least the LP/HX line have been supported for a while. I have found the wiki description for how to add new boards, which is somewhat lacking in terms of describing the file contents/rationale/etc.
I would like to address two related issues.
If I can get some questions answered about the documentation (first issue) and adding the bare chips is as easy as it seems to be in theory (second issue), then I am happy to put in the work to both improve the documentation and start adding files for the bare chips. And, if all goes well, people will be less intimidated about adding support for their own boards.
Documentation Questions
The following example was put together for the iCE40LP1K with the 49-pin ucBGA package. The
info.json
,pinout.json
,pinout.pcf
, andrules.json
appear to be in this folder. Please correct me if I am looking in the wrong place.info.json
[ Q1 ] I presume "plbs" refers to programmable logic blocks, but as this figure does not appear on the datasheet, is this always (at least for Lattice parts) just the number of LUTs divided by 8?
[ Q2 ] When calculating the "pios" field in the
info.json
file, should the null outputs be included in the count? Or does this refer only to the pins labelled as I, O, or I/O on the datasheet (ie. not power pins, not NULL pins).pinout.json
This file was basically just copied straight from the pinout excel sheets provided by Lattice.
[ Q3 ] Is this indeed how these files are generated?
rules.json
I believe what I have written here specifies the input clock coming in on pin G3, and nothing else.
[ Q4 ] Is there anything else that needs to be specified, such as clock speed, programming connections, something to do with interfaces, etc? Or will synthesizing, placing and routing, and timing analyses all work fine leaving it as is?
boards.json
To add support for the board to apio, my understand is that this file requires the following new entry
I am assuming here (please correct me if I am wrong) that a bare chip won't have a USB or FTDI capability, so those should be omitted, but every device lists a programmer so that appears to be required.
[ Q5 ] How do I know what to put in the programmer entry? The various entries in
boards.json
list 14 different programmers (iceprog, icesprog, iCEburn, iceprogduino, icoprog, litterbox, blackiceprog, icefunprog, tinyfpgab, tinyprog, dfu, fujprog, openfpgaloader_ft2232, and openfpgaloader_usb-blaster, if it matters), but as I am very new to FPGAs I don't really know the difference between the programmers, if it matters, what implications the choice of programmer has, or if anything else needs to be added (like USB or FTDI) based on the choice of programmers.[ Q6 ] If I am going to make a whole bunch of entries for bare chips so that people can build for chips rather than just dev boards, should I just specify "iceprog" since that appears to be Lattice's programmer and therefore the programmer than off-brand copies are likely to emulate? Or is there a specific dev board I should just copy the entire programmer-usb-ftdi block from?
pinout.pcf
[ Q7] Where can I find any information about this file format? My searches keep turning up unrelated content.
Other Questions
[ Q8 ] The wiki indicates that there is a
menu.json
file in the same directory asboards.json
that needs to be updated, but no such file appears to exist. Am I looking in the wrong spot? Is that no longer the case and it is now automatically assigned?[ Q9 ] As far as testing goes, I don't have any of these chips and can't physically test them, I imagine that once I have added support for the chips I should be able to successfully compile icestorm, select the chip, synthesize something, and route it, but is there anything else I should test?
The text was updated successfully, but these errors were encountered: