mirror of
https://github.com/corundum/corundum.git
synced 2025-01-16 08:12:53 +08:00
56df4cb677
Signed-off-by: Alex Forencich <alex@alexforencich.com>
335 lines
12 KiB
C
335 lines
12 KiB
C
/*
|
|
|
|
Copyright 2020-2022, The Regents of the University of California.
|
|
All rights reserved.
|
|
|
|
Redistribution and use in source and binary forms, with or without
|
|
modification, are permitted provided that the following conditions are met:
|
|
|
|
1. Redistributions of source code must retain the above copyright notice,
|
|
this list of conditions and the following disclaimer.
|
|
|
|
2. Redistributions in binary form must reproduce the above copyright notice,
|
|
this list of conditions and the following disclaimer in the documentation
|
|
and/or other materials provided with the distribution.
|
|
|
|
THIS SOFTWARE IS PROVIDED BY THE REGENTS OF THE UNIVERSITY OF CALIFORNIA ''AS
|
|
IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
|
DISCLAIMED. IN NO EVENT SHALL THE REGENTS OF THE UNIVERSITY OF CALIFORNIA OR
|
|
CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
|
|
EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT
|
|
OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
|
INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
|
CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING
|
|
IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY
|
|
OF SUCH DAMAGE.
|
|
|
|
The views and conclusions contained in the software and documentation are those
|
|
of the authors and should not be interpreted as representing official policies,
|
|
either expressed or implied, of The Regents of the University of California.
|
|
|
|
*/
|
|
|
|
#ifndef FPGA_ID_H
|
|
#define FPGA_ID_H
|
|
|
|
#define FPGA_ID_MASK_FULL 0xFFFFFFFF
|
|
#define FPGA_ID_MASK_VER 0xF0000000
|
|
#define FPGA_ID_MASK_PART 0x0FFFF000
|
|
#define FPGA_ID_MASK_MFR 0x00000FFE
|
|
#define FPGA_ID_MASK_NOVER 0x0FFFFFFF
|
|
|
|
// Xilinx
|
|
// Spartan 7
|
|
#define FPGA_ID_XC7S6 0x3622093
|
|
#define FPGA_ID_XC7S15 0x3620093
|
|
#define FPGA_ID_XC7S25 0x37C4093
|
|
#define FPGA_ID_XC7S50 0x362F093
|
|
#define FPGA_ID_XC7S75 0x37C8093
|
|
#define FPGA_ID_XC7S100 0x37C7093
|
|
// Artix 7
|
|
#define FPGA_ID_XC7A15T 0x362D093
|
|
#define FPGA_ID_XC7A35T 0x362D093
|
|
#define FPGA_ID_XC7A50T 0x362C093
|
|
#define FPGA_ID_XC7A75T 0x3632093
|
|
#define FPGA_ID_XC7A100T 0x3631093
|
|
#define FPGA_ID_XC7A200T 0x3636093
|
|
// Kintex 7
|
|
#define FPGA_ID_XC7K70T 0x3647093
|
|
#define FPGA_ID_XC7K160T 0x364C093
|
|
#define FPGA_ID_XC7K325T 0x3651093
|
|
#define FPGA_ID_XC7K355T 0x3747093
|
|
#define FPGA_ID_XC7K410T 0x3656093
|
|
#define FPGA_ID_XC7K420T 0x3752093
|
|
#define FPGA_ID_XC7K480T 0x3751093
|
|
// Virtex 7
|
|
#define FPGA_ID_XC7V585T 0x3671093
|
|
#define FPGA_ID_XC7V2000T 0x36B3093
|
|
#define FPGA_ID_XC7VX330T 0x3667093
|
|
#define FPGA_ID_XC7VX415T 0x3682093
|
|
#define FPGA_ID_XC7VX485T 0x3687093
|
|
#define FPGA_ID_XC7VX550T 0x3692093
|
|
#define FPGA_ID_XC7VX690T 0x3691093
|
|
#define FPGA_ID_XC7VX980T 0x3696093
|
|
#define FPGA_ID_XC7VX1140T 0x36D5093
|
|
#define FPGA_ID_XC7VH580T 0x36D9093
|
|
#define FPGA_ID_XC7VH870T 0x36DB093
|
|
// Zynq 7000
|
|
#define FPGA_ID_XC7Z007 0x3723093
|
|
#define FPGA_ID_XC7Z010 0x3722093
|
|
#define FPGA_ID_XC7Z012 0x373C093
|
|
#define FPGA_ID_XC7Z014 0x3728093
|
|
#define FPGA_ID_XC7Z015 0x373B093
|
|
#define FPGA_ID_XC7Z020 0x3727093
|
|
#define FPGA_ID_XC7Z030 0x372C093
|
|
#define FPGA_ID_XC7Z035 0x3732093
|
|
#define FPGA_ID_XC7Z045 0x3731093
|
|
#define FPGA_ID_XC7Z100 0x3736093
|
|
// Kintex UltraScale
|
|
#define FPGA_ID_XCKU025 0x3824093
|
|
#define FPGA_ID_XCKU035 0x3823093
|
|
#define FPGA_ID_XCKU040 0x3822093
|
|
#define FPGA_ID_XCKU060 0x3919093
|
|
#define FPGA_ID_XCKU085 0x380F093
|
|
#define FPGA_ID_XCKU095 0x3844093
|
|
#define FPGA_ID_XCKU115 0x390D093
|
|
// Virtex UltraScale
|
|
#define FPGA_ID_XCVU065 0x3939093
|
|
#define FPGA_ID_XCVU080 0x3843093
|
|
#define FPGA_ID_XCVU095 0x3842093
|
|
#define FPGA_ID_XCVU125 0x392D093
|
|
#define FPGA_ID_XCVU160 0x3933093
|
|
#define FPGA_ID_XCVU190 0x3931093
|
|
#define FPGA_ID_XCVU440 0x396D093
|
|
// Artix UltraScale+
|
|
#define FPGA_ID_XCAU10P 0x4AC5093
|
|
#define FPGA_ID_XCAU15P 0x4AC4093
|
|
#define FPGA_ID_XCAU20P 0x4A65093
|
|
#define FPGA_ID_XCAU25P 0x4A64093
|
|
// Kintex UltraScale+
|
|
#define FPGA_ID_XCKU3P 0x4A63093
|
|
#define FPGA_ID_XCKU5P 0x4A62093
|
|
#define FPGA_ID_XCKU9P 0x484A093
|
|
#define FPGA_ID_XCKU11P 0x4A4E093
|
|
#define FPGA_ID_XCKU13P 0x4A52093
|
|
#define FPGA_ID_XCKU15P 0x4A56093
|
|
#define FPGA_ID_XCKU19P 0x4ACF093
|
|
// Virtex UltraScale+
|
|
#define FPGA_ID_XCVU3P 0x4B39093
|
|
#define FPGA_ID_XCVU5P 0x4B2B093
|
|
#define FPGA_ID_XCVU7P 0x4B29093
|
|
#define FPGA_ID_XCVU9P 0x4B31093
|
|
#define FPGA_ID_XCVU11P 0x4B49093
|
|
#define FPGA_ID_XCVU13P 0x4B51093
|
|
#define FPGA_ID_XCVU19P 0x4BA1093
|
|
#define FPGA_ID_XCVU23P 0x4ACE093
|
|
#define FPGA_ID_XCVU27P 0x4B43093
|
|
#define FPGA_ID_XCVU29P 0x4B41093
|
|
#define FPGA_ID_XCVU31P 0x4B6B093
|
|
#define FPGA_ID_XCVU33P 0x4B69093
|
|
#define FPGA_ID_XCVU35P 0x4B71093
|
|
#define FPGA_ID_XCVU37P 0x4B79093
|
|
#define FPGA_ID_XCVU45P 0x4B73093
|
|
#define FPGA_ID_XCVU47P 0x4B7B093
|
|
#define FPGA_ID_XCVU57P 0x4B61093
|
|
// Zynq UltraScale+
|
|
#define FPGA_ID_XCZU1 0x4688093
|
|
#define FPGA_ID_XCZU2 0x4711093
|
|
#define FPGA_ID_XCZU3 0x4710093
|
|
#define FPGA_ID_XCZU4 0x4721093
|
|
#define FPGA_ID_XCZU5 0x4720093
|
|
#define FPGA_ID_XCZU6 0x4739093
|
|
#define FPGA_ID_XCZU7 0x4730093
|
|
#define FPGA_ID_XCZU9 0x4738093
|
|
#define FPGA_ID_XCZU11 0x4740093
|
|
#define FPGA_ID_XCZU15 0x4750093
|
|
#define FPGA_ID_XCZU17 0x4759093
|
|
#define FPGA_ID_XCZU19 0x4758093
|
|
#define FPGA_ID_XCZU21 0x47E1093
|
|
#define FPGA_ID_XCZU25 0x47E5093
|
|
#define FPGA_ID_XCZU27 0x47E4093
|
|
#define FPGA_ID_XCZU28 0x47E0093
|
|
#define FPGA_ID_XCZU29 0x47E2093
|
|
#define FPGA_ID_XCZU39 0x47E6093
|
|
#define FPGA_ID_XCZU43 0x47FD093
|
|
#define FPGA_ID_XCZU46 0x47F8093
|
|
#define FPGA_ID_XCZU47 0x47FF093
|
|
#define FPGA_ID_XCZU48 0x47FB093
|
|
#define FPGA_ID_XCZU49 0x47FE093
|
|
#define FPGA_ID_XCZU65 0x46D1093
|
|
#define FPGA_ID_XCZU67 0x46D0093
|
|
// Kria SoM (Zynq UltraScale+)
|
|
#define FPGA_ID_XCK26 0x4A49093
|
|
// Alveo (Virtex UltraScale+)
|
|
#define FPGA_ID_XCU50 0x4B77093
|
|
#define FPGA_ID_XCU200 0x4B37093
|
|
#define FPGA_ID_XCU250 0x4B57093
|
|
#define FPGA_ID_XCU280 0x4B7D093
|
|
// Versal AI Edge
|
|
#define FPGA_ID_XCVE1752 0x4C9A093
|
|
#define FPGA_ID_XCVE2002 0x4CC1093
|
|
#define FPGA_ID_XCVE2102 0x4CC0093
|
|
#define FPGA_ID_XCVE2202 0x4CC9093
|
|
#define FPGA_ID_XCVE2302 0x4CC8093
|
|
#define FPGA_ID_XCVE2602 0x4CD3093
|
|
#define FPGA_ID_XCVE2802 0x4CD1093
|
|
// Versal AI Core
|
|
#define FPGA_ID_XCVC1352 0x4C93093
|
|
#define FPGA_ID_XCVC1502 0x4C9B093
|
|
#define FPGA_ID_XCVC1702 0x4C98093
|
|
#define FPGA_ID_XCVC1802 0x4CA9093
|
|
#define FPGA_ID_XCVC1902 0x4CA8093
|
|
#define FPGA_ID_XCVC2602 0x4CD2093
|
|
#define FPGA_ID_XCVC2802 0x4CD0093
|
|
// Versal Prime
|
|
#define FPGA_ID_XCVM1102 0x4CCA093
|
|
#define FPGA_ID_XCVM1302 0x4C09093
|
|
#define FPGA_ID_XCVM1402 0x4C08093
|
|
#define FPGA_ID_XCVM1502 0x4C99093
|
|
#define FPGA_ID_XCVM1802 0x4CAA093
|
|
#define FPGA_ID_XCVM2202 0x4CD4093
|
|
#define FPGA_ID_XCVM2302 0x4C24093
|
|
#define FPGA_ID_XCVM2502 0x4D01093
|
|
#define FPGA_ID_XCVM2902 0x4C23093
|
|
// Versal Premium
|
|
#define FPGA_ID_XCVP1002 0x4C1B093
|
|
#define FPGA_ID_XCVP1052 0x4C18093
|
|
#define FPGA_ID_XCVP1102 0x4C22093
|
|
#define FPGA_ID_XCVP1202 0x4D00093
|
|
#define FPGA_ID_XCVP1402 0x4C20093
|
|
#define FPGA_ID_XCVP1502 0x4D08093
|
|
#define FPGA_ID_XCVP1552 0x4D34093
|
|
#define FPGA_ID_XCVP1702 0x4D10093
|
|
#define FPGA_ID_XCVP1802 0x4D14093
|
|
#define FPGA_ID_XCVP2502 0x4D1C093
|
|
#define FPGA_ID_XCVP2802 0x4D20093
|
|
|
|
// Intel
|
|
// Stratix 10
|
|
#define FPGA_ID_1SG10MH_U1 0x032270DD
|
|
#define FPGA_ID_1SG10MH_U2 0x0322F0DD
|
|
#define FPGA_ID_1SG040H 0x032200DD
|
|
#define FPGA_ID_1SG040H_NL 0x032A00DD
|
|
#define FPGA_ID_1SG065H 0x032210DD
|
|
#define FPGA_ID_1SG065H_NL 0x032A10DD
|
|
#define FPGA_ID_1SG085H 0x132220DD
|
|
#define FPGA_ID_1SG110H 0x032220DD
|
|
#define FPGA_ID_1SG110H_NL 0x032A20DD
|
|
#define FPGA_ID_1SG165H 0xF32250DD
|
|
#define FPGA_ID_1SG166H 0x532240DD
|
|
#define FPGA_ID_1SG166H_NL 0x5322C0DD
|
|
#define FPGA_ID_1SG210H 0xE32250DD
|
|
#define FPGA_ID_1SG210H_ES1 0x232250DD
|
|
#define FPGA_ID_1SG211H 0x432240DD
|
|
#define FPGA_ID_1SG250L 0xD32150DD
|
|
#define FPGA_ID_1SG250H 0xD32250DD
|
|
#define FPGA_ID_1SG280L 0xC32150DD
|
|
#define FPGA_ID_1SG280L_NL 0xC32950DD
|
|
#define FPGA_ID_1SG280L_ES1 0x032150DD
|
|
#define FPGA_ID_1SG280L_ES2 0x032250DD
|
|
#define FPGA_ID_1SG280L_ES3 0xC32150DD
|
|
#define FPGA_ID_1SG280H 0xC32250DD
|
|
#define FPGA_ID_1SG280H_NL 0xC32A50DD
|
|
#define FPGA_ID_1SG280H_ES1 0x032250DD
|
|
#define FPGA_ID_1SG280H_ES2 0xC32150DD
|
|
#define FPGA_ID_1SG280H_ES3 0xC32250DD
|
|
#define FPGA_ID_1SX040H 0x032280DD
|
|
#define FPGA_ID_1SX065H 0x032290DD
|
|
#define FPGA_ID_1SX085H 0x1322A0DD
|
|
#define FPGA_ID_1SX110H 0x0322A0DD
|
|
#define FPGA_ID_1SX165H 0xF322D0DD
|
|
#define FPGA_ID_1SX210H 0xE322D0DD
|
|
#define FPGA_ID_1SX250L 0xD321D0DD
|
|
#define FPGA_ID_1SX250H 0xD322D0DD
|
|
#define FPGA_ID_1SX280L 0xC321D0DD
|
|
#define FPGA_ID_1SX280L_ES1 0x4321D0DD
|
|
#define FPGA_ID_1SX280L_ES2 0x4321D0DD
|
|
#define FPGA_ID_1SX280H 0xC322D0DD
|
|
#define FPGA_ID_1SX280H_ES1 0x4322D0DD
|
|
#define FPGA_ID_1SX280H_ES2 0xC322D0DD
|
|
#define FPGA_ID_1ST040E 0x032380DD
|
|
#define FPGA_ID_1ST040E_NL 0x032B00DD
|
|
#define FPGA_ID_1ST085E 0x1323A0DD
|
|
#define FPGA_ID_1ST110E 0x0323A0DD
|
|
#define FPGA_ID_1ST110E_NL 0x032B20DD
|
|
#define FPGA_ID_1ST165E 0x532340DD
|
|
#define FPGA_ID_1ST210E 0x432340DD
|
|
#define FPGA_ID_1ST210E_ES1 0x032340DD
|
|
#define FPGA_ID_1ST250E 0xD323D0DD
|
|
#define FPGA_ID_1ST280E 0xC323D0DD
|
|
#define FPGA_ID_1ST280E_ES1 0xC323D0DD
|
|
#define FPGA_ID_1SM16BE 0x732BC0DD
|
|
#define FPGA_ID_1SM16BE_ES1 0x732BC0DD
|
|
#define FPGA_ID_1SM16BH 0x732AC0DD
|
|
#define FPGA_ID_1SM16BH_ES1 0x332AC0DD
|
|
#define FPGA_ID_1SM16CH 0x532AC0DD
|
|
#define FPGA_ID_1SM16CH_ES1 0x132AC0DD
|
|
#define FPGA_ID_1SM21BE 0x632BC0DD
|
|
#define FPGA_ID_1SM21BE_ES1 0x632BC0DD
|
|
#define FPGA_ID_1SM21BH 0x632AC0DD
|
|
#define FPGA_ID_1SM21BH_ES1 0x232AC0DD
|
|
#define FPGA_ID_1SM21CH 0x432AC0DD
|
|
#define FPGA_ID_1SM21CH_ES1 0x032AC0DD
|
|
#define FPGA_ID_1SD110P 0x0324A0DD
|
|
#define FPGA_ID_1SD110P_NL 0x032C20DD
|
|
#define FPGA_ID_1SD21BP 0x632CC0DD
|
|
#define FPGA_ID_1SD280P 0xC32450DD
|
|
// Agilex
|
|
#define FPGA_ID_AGFA006R16A 0x134310DD
|
|
#define FPGA_ID_AGFA008R16A 0x034310DD
|
|
#define FPGA_ID_AGFA012R24A 0x534120DD
|
|
#define FPGA_ID_AGFA012R24B 0xD34120DD
|
|
#define FPGA_ID_AGFA014R24AR0 0x034120DD
|
|
#define FPGA_ID_AGFA014R24A 0x434120DD
|
|
#define FPGA_ID_AGFA014R24B 0xC34120DD
|
|
#define FPGA_ID_AGFA019R25A 0x134150DD
|
|
#define FPGA_ID_AGFA022R24C 0x134330DD
|
|
#define FPGA_ID_AGFA022R25A 0x134130DD
|
|
#define FPGA_ID_AGFA022R31C 0x134330DD
|
|
#define FPGA_ID_AGFA023R25AR0 0x034150DD
|
|
#define FPGA_ID_AGFA023R25A 0x034150DD
|
|
#define FPGA_ID_AGFA027R24CR0 0x034330DD
|
|
#define FPGA_ID_AGFA027R24CR2 0x034330DD
|
|
#define FPGA_ID_AGFA027R24C 0x034330DD
|
|
#define FPGA_ID_AGFA027R25AR0 0x034130DD
|
|
#define FPGA_ID_AGFA027R25A 0x034130DD
|
|
#define FPGA_ID_AGFA027R31C 0x034330DD
|
|
#define FPGA_ID_AGFB006R16A 0x134390DD
|
|
#define FPGA_ID_AGFB008R16A 0x034390DD
|
|
#define FPGA_ID_AGFB012R24A 0x5341A0DD
|
|
#define FPGA_ID_AGFB012R24B 0xD341A0DD
|
|
#define FPGA_ID_AGFB014R24AR0 0x0341A0DD
|
|
#define FPGA_ID_AGFB014R24A 0x4341A0DD
|
|
#define FPGA_ID_AGFB014R24B 0xC341A0DD
|
|
#define FPGA_ID_AGFB019R25A 0x1341D0DD
|
|
#define FPGA_ID_AGFB022R24C 0x1343B0DD
|
|
#define FPGA_ID_AGFB022R25A 0x1341B0DD
|
|
#define FPGA_ID_AGFB022R31C 0x1343B0DD
|
|
#define FPGA_ID_AGFB023R25AR0 0x0341D0DD
|
|
#define FPGA_ID_AGFB023R25A 0x0341D0DD
|
|
#define FPGA_ID_AGFB027R24CR0 0x0343B0DD
|
|
#define FPGA_ID_AGFB027R24CR2 0x0343B0DD
|
|
#define FPGA_ID_AGFB027R24C 0x0343B0DD
|
|
#define FPGA_ID_AGFB027R25AR0 0x0341B0DD
|
|
#define FPGA_ID_AGFB027R25A 0x0341B0DD
|
|
#define FPGA_ID_AGFB027R31C 0x0343B0DD
|
|
#define FPGA_ID_AGFC019R25A 0x334150DD
|
|
#define FPGA_ID_AGFC023R25AR0 0x234150DD
|
|
#define FPGA_ID_AGFC023R25A 0x234150DD
|
|
#define FPGA_ID_AGFD019R25A 0x3341D0DD
|
|
#define FPGA_ID_AGFD023R25AR0 0x2341D0DD
|
|
#define FPGA_ID_AGFD023R25A 0x2341D0DD
|
|
#define FPGA_ID_AGIB022R29A 0x134BB0DD
|
|
#define FPGA_ID_AGIB022R31B 0x1343B0DD
|
|
#define FPGA_ID_AGIB027R29AR0 0x034BB0DD
|
|
#define FPGA_ID_AGIB027R29AR1 0x034BB0DD
|
|
#define FPGA_ID_AGIB027R29AR3 0x034BB0DD
|
|
#define FPGA_ID_AGIB027R29A 0x034BB0DD
|
|
#define FPGA_ID_AGIB027R31BR0 0x0343B0DD
|
|
#define FPGA_ID_AGIB027R31B 0x0343B0DD
|
|
|
|
const char *get_fpga_part(int id);
|
|
|
|
#endif /* FPGA_ID_H */
|