Author: Marian Buschsieweke Date: 2024-05-07T13:58:13-07:00 New Revision: bc8a42762057d7036f6871211e62b1c3efb2738a
URL: https://github.com/llvm/llvm-project/commit/bc8a42762057d7036f6871211e62b1c3efb2738a DIFF: https://github.com/llvm/llvm-project/commit/bc8a42762057d7036f6871211e62b1c3efb2738a.diff LOG: [MSP430][Clang] Update list of MCUs (#91258) This updates the list of MSP430 MCUs from TI's devices.csv obtained from [1] under the "Header and Support Files" link. A simple python script has been used to generate this list and is included as well. [1]: https://www.ti.com/tool/MSP430-GCC-OPENSOURCE#downloads Added: clang/include/clang/Basic/Target/MSP430/gen-msp430-def.py Modified: clang/include/clang/Basic/MSP430Target.def Removed: ################################################################################ diff --git a/clang/include/clang/Basic/MSP430Target.def b/clang/include/clang/Basic/MSP430Target.def index 7a10be1d54c8d..8fd44e3ba8e71 100644 --- a/clang/include/clang/Basic/MSP430Target.def +++ b/clang/include/clang/Basic/MSP430Target.def @@ -8,6 +8,10 @@ // // This file defines the MSP430 devices and their features. // +// Generated from TI's devices.csv in version 1.212 using the script in +// Target/MSP430/gen-msp430-def.py - use this tool rather than adding +// new MCUs by hand. +// //===----------------------------------------------------------------------===// #ifndef MSP430_MCU_FEAT @@ -24,7 +28,19 @@ MSP430_MCU("msp430c112") MSP430_MCU("msp430c1121") MSP430_MCU("msp430c1331") MSP430_MCU("msp430c1351") +MSP430_MCU("msp430c311s") +MSP430_MCU("msp430c312") +MSP430_MCU("msp430c313") +MSP430_MCU("msp430c314") +MSP430_MCU("msp430c315") +MSP430_MCU("msp430c323") +MSP430_MCU("msp430c325") +MSP430_MCU("msp430c412") +MSP430_MCU("msp430c413") MSP430_MCU("msp430e112") +MSP430_MCU("msp430e313") +MSP430_MCU("msp430e315") +MSP430_MCU("msp430e325") MSP430_MCU("msp430f110") MSP430_MCU("msp430f1101") MSP430_MCU("msp430f1101a") @@ -44,7 +60,6 @@ MSP430_MCU("msp430f135") MSP430_MCU("msp430f155") MSP430_MCU("msp430f156") MSP430_MCU("msp430f157") -MSP430_MCU("msp430p112") MSP430_MCU("msp430f2001") MSP430_MCU("msp430f2011") MSP430_MCU("msp430f2002") @@ -64,6 +79,58 @@ MSP430_MCU("msp430f2272") MSP430_MCU("msp430f2234") MSP430_MCU("msp430f2254") MSP430_MCU("msp430f2274") +MSP430_MCU("msp430f412") +MSP430_MCU("msp430f413") +MSP430_MCU("msp430f415") +MSP430_MCU("msp430f417") +MSP430_MCU("msp430f4132") +MSP430_MCU("msp430f4152") +MSP430_MCU("msp430f435") +MSP430_MCU("msp430f436") +MSP430_MCU("msp430f437") +MSP430_MCU("msp430f4351") +MSP430_MCU("msp430f4361") +MSP430_MCU("msp430f4371") +MSP430_MCU("msp430fe423") +MSP430_MCU("msp430fe425") +MSP430_MCU("msp430fe427") +MSP430_MCU("msp430fe423a") +MSP430_MCU("msp430fe425a") +MSP430_MCU("msp430fe427a") +MSP430_MCU("msp430fe4232") +MSP430_MCU("msp430fe4242") +MSP430_MCU("msp430fe4252") +MSP430_MCU("msp430fe4272") +MSP430_MCU("msp430f4250") +MSP430_MCU("msp430f4260") +MSP430_MCU("msp430f4270") +MSP430_MCU("msp430fg4250") +MSP430_MCU("msp430fg4260") +MSP430_MCU("msp430fg4270") +MSP430_MCU("msp430fw423") +MSP430_MCU("msp430fw425") +MSP430_MCU("msp430fw427") +MSP430_MCU("msp430fw428") +MSP430_MCU("msp430fw429") +MSP430_MCU("msp430fg437") +MSP430_MCU("msp430fg438") +MSP430_MCU("msp430fg439") +MSP430_MCU("msp430f438") +MSP430_MCU("msp430f439") +MSP430_MCU("msp430f477") +MSP430_MCU("msp430f478") +MSP430_MCU("msp430f479") +MSP430_MCU("msp430fg477") +MSP430_MCU("msp430fg478") +MSP430_MCU("msp430fg479") +MSP430_MCU("msp430p112") +MSP430_MCU("msp430p313") +MSP430_MCU("msp430p315") +MSP430_MCU("msp430p315s") +MSP430_MCU("msp430p325") +MSP430_MCU("msp430l092") +MSP430_MCU("msp430c091") +MSP430_MCU("msp430c092") MSP430_MCU("msp430g2211") MSP430_MCU("msp430g2201") MSP430_MCU("msp430g2111") @@ -115,68 +182,32 @@ MSP430_MCU("msp430g2855") MSP430_MCU("msp430g2955") MSP430_MCU("msp430g2230") MSP430_MCU("msp430g2210") -MSP430_MCU("msp430c311s") -MSP430_MCU("msp430c312") -MSP430_MCU("msp430c313") -MSP430_MCU("msp430c314") -MSP430_MCU("msp430c315") -MSP430_MCU("msp430c323") -MSP430_MCU("msp430c325") -MSP430_MCU("msp430c412") -MSP430_MCU("msp430c413") -MSP430_MCU("msp430e313") -MSP430_MCU("msp430e315") -MSP430_MCU("msp430e325") -MSP430_MCU("msp430p313") -MSP430_MCU("msp430p315") -MSP430_MCU("msp430p315s") -MSP430_MCU("msp430p325") -MSP430_MCU("msp430f412") -MSP430_MCU("msp430f413") -MSP430_MCU("msp430f415") -MSP430_MCU("msp430f417") -MSP430_MCU("msp430f4132") -MSP430_MCU("msp430f4152") -MSP430_MCU("msp430f435") -MSP430_MCU("msp430f436") -MSP430_MCU("msp430f437") -MSP430_MCU("msp430f4351") -MSP430_MCU("msp430f4361") -MSP430_MCU("msp430f4371") -MSP430_MCU("msp430fe423") -MSP430_MCU("msp430fe425") -MSP430_MCU("msp430fe427") -MSP430_MCU("msp430fe423a") -MSP430_MCU("msp430fe425a") -MSP430_MCU("msp430fe427a") -MSP430_MCU("msp430fe4232") -MSP430_MCU("msp430fe4242") -MSP430_MCU("msp430fe4252") -MSP430_MCU("msp430fe4272") -MSP430_MCU("msp430f4250") -MSP430_MCU("msp430f4260") -MSP430_MCU("msp430f4270") -MSP430_MCU("msp430fg4250") -MSP430_MCU("msp430fg4260") -MSP430_MCU("msp430fg4270") -MSP430_MCU("msp430fw423") -MSP430_MCU("msp430fw425") -MSP430_MCU("msp430fw427") -MSP430_MCU("msp430fw428") -MSP430_MCU("msp430fw429") -MSP430_MCU("msp430fg437") -MSP430_MCU("msp430fg438") -MSP430_MCU("msp430fg439") -MSP430_MCU("msp430f438") -MSP430_MCU("msp430f439") -MSP430_MCU("msp430f477") -MSP430_MCU("msp430f478") -MSP430_MCU("msp430f479") -MSP430_MCU("msp430fg477") -MSP430_MCU("msp430fg478") -MSP430_MCU("msp430fg479") +MSP430_MCU("rf430frl152h") +MSP430_MCU("rf430frl153h") +MSP430_MCU("rf430frl154h") +MSP430_MCU("rf430frl152h_rom") +MSP430_MCU("rf430frl153h_rom") +MSP430_MCU("rf430frl154h_rom") +MSP430_MCU("msp430fr4131") +MSP430_MCU("msp430fr4132") +MSP430_MCU("msp430fr4133") +MSP430_MCU("msp430fr2032") +MSP430_MCU("msp430fr2033") +MSP430_MCU("msp430fr2110") +MSP430_MCU("msp430fr2111") +MSP430_MCU("msp430fr2310") +MSP430_MCU("msp430fr2311") +MSP430_MCU("msp430fr2100") +MSP430_MCU("msp430fr2000") // With 16-bit hardware multiplier +MSP430_MCU_FEAT("msp430c336", "16bit") +MSP430_MCU_FEAT("msp430c337", "16bit") +MSP430_MCU_FEAT("msp430cg4616", "16bit") +MSP430_MCU_FEAT("msp430cg4617", "16bit") +MSP430_MCU_FEAT("msp430cg4618", "16bit") +MSP430_MCU_FEAT("msp430cg4619", "16bit") +MSP430_MCU_FEAT("msp430e337", "16bit") MSP430_MCU_FEAT("msp430f147", "16bit") MSP430_MCU_FEAT("msp430f148", "16bit") MSP430_MCU_FEAT("msp430f149", "16bit") @@ -189,21 +220,6 @@ MSP430_MCU_FEAT("msp430f169", "16bit") MSP430_MCU_FEAT("msp430f1610", "16bit") MSP430_MCU_FEAT("msp430f1611", "16bit") MSP430_MCU_FEAT("msp430f1612", "16bit") -MSP430_MCU_FEAT("msp430c336", "16bit") -MSP430_MCU_FEAT("msp430c337", "16bit") -MSP430_MCU_FEAT("msp430e337", "16bit") -MSP430_MCU_FEAT("msp430p337", "16bit") -MSP430_MCU_FEAT("msp430f423", "16bit") -MSP430_MCU_FEAT("msp430f425", "16bit") -MSP430_MCU_FEAT("msp430f427", "16bit") -MSP430_MCU_FEAT("msp430f423a", "16bit") -MSP430_MCU_FEAT("msp430f425a", "16bit") -MSP430_MCU_FEAT("msp430f427a", "16bit") -MSP430_MCU_FEAT("msp430f4481", "16bit") -MSP430_MCU_FEAT("msp430f4491", "16bit") -MSP430_MCU_FEAT("msp430f447", "16bit") -MSP430_MCU_FEAT("msp430f448", "16bit") -MSP430_MCU_FEAT("msp430f449", "16bit") MSP430_MCU_FEAT("msp430f2330", "16bit") MSP430_MCU_FEAT("msp430f2350", "16bit") MSP430_MCU_FEAT("msp430f2370", "16bit") @@ -216,12 +232,38 @@ MSP430_MCU_FEAT("msp430f2410", "16bit") MSP430_MCU_FEAT("msp430f2471", "16bit") MSP430_MCU_FEAT("msp430f2481", "16bit") MSP430_MCU_FEAT("msp430f2491", "16bit") -MSP430_MCU_FEAT("msp430i2020", "16bit") -MSP430_MCU_FEAT("msp430i2021", "16bit") -MSP430_MCU_FEAT("msp430i2030", "16bit") -MSP430_MCU_FEAT("msp430i2031", "16bit") -MSP430_MCU_FEAT("msp430i2040", "16bit") -MSP430_MCU_FEAT("msp430i2041", "16bit") +MSP430_MCU_FEAT("msp430f2416", "16bit") +MSP430_MCU_FEAT("msp430f2417", "16bit") +MSP430_MCU_FEAT("msp430f2418", "16bit") +MSP430_MCU_FEAT("msp430f2419", "16bit") +MSP430_MCU_FEAT("msp430f2616", "16bit") +MSP430_MCU_FEAT("msp430f2617", "16bit") +MSP430_MCU_FEAT("msp430f2618", "16bit") +MSP430_MCU_FEAT("msp430f2619", "16bit") +MSP430_MCU_FEAT("msp430f423", "16bit") +MSP430_MCU_FEAT("msp430f425", "16bit") +MSP430_MCU_FEAT("msp430f427", "16bit") +MSP430_MCU_FEAT("msp430f423a", "16bit") +MSP430_MCU_FEAT("msp430f425a", "16bit") +MSP430_MCU_FEAT("msp430f427a", "16bit") +MSP430_MCU_FEAT("msp430f4481", "16bit") +MSP430_MCU_FEAT("msp430f4491", "16bit") +MSP430_MCU_FEAT("msp430f447", "16bit") +MSP430_MCU_FEAT("msp430f448", "16bit") +MSP430_MCU_FEAT("msp430f449", "16bit") +MSP430_MCU_FEAT("msp430f46161", "16bit") +MSP430_MCU_FEAT("msp430f46171", "16bit") +MSP430_MCU_FEAT("msp430f46181", "16bit") +MSP430_MCU_FEAT("msp430f46191", "16bit") +MSP430_MCU_FEAT("msp430f4616", "16bit") +MSP430_MCU_FEAT("msp430f4617", "16bit") +MSP430_MCU_FEAT("msp430f4618", "16bit") +MSP430_MCU_FEAT("msp430f4619", "16bit") +MSP430_MCU_FEAT("msp430fg4616", "16bit") +MSP430_MCU_FEAT("msp430fg4617", "16bit") +MSP430_MCU_FEAT("msp430fg4618", "16bit") +MSP430_MCU_FEAT("msp430fg4619", "16bit") +MSP430_MCU_FEAT("msp430p337", "16bit") MSP430_MCU_FEAT("msp430afe221", "16bit") MSP430_MCU_FEAT("msp430afe231", "16bit") MSP430_MCU_FEAT("msp430afe251", "16bit") @@ -231,12 +273,387 @@ MSP430_MCU_FEAT("msp430afe252", "16bit") MSP430_MCU_FEAT("msp430afe223", "16bit") MSP430_MCU_FEAT("msp430afe233", "16bit") MSP430_MCU_FEAT("msp430afe253", "16bit") +MSP430_MCU_FEAT("msp430i2020", "16bit") +MSP430_MCU_FEAT("msp430i2021", "16bit") +MSP430_MCU_FEAT("msp430i2030", "16bit") +MSP430_MCU_FEAT("msp430i2031", "16bit") +MSP430_MCU_FEAT("msp430i2040", "16bit") +MSP430_MCU_FEAT("msp430i2041", "16bit") -// With 32 Bit Hardware Multiplier +// With 32-bit hardware multiplier MSP430_MCU_FEAT("msp430f4783", "32bit") MSP430_MCU_FEAT("msp430f4793", "32bit") MSP430_MCU_FEAT("msp430f4784", "32bit") MSP430_MCU_FEAT("msp430f4794", "32bit") +MSP430_MCU_FEAT("msp430f47126", "32bit") +MSP430_MCU_FEAT("msp430f47127", "32bit") +MSP430_MCU_FEAT("msp430f47163", "32bit") +MSP430_MCU_FEAT("msp430f47173", "32bit") +MSP430_MCU_FEAT("msp430f47183", "32bit") +MSP430_MCU_FEAT("msp430f47193", "32bit") +MSP430_MCU_FEAT("msp430f47166", "32bit") +MSP430_MCU_FEAT("msp430f47176", "32bit") +MSP430_MCU_FEAT("msp430f47186", "32bit") +MSP430_MCU_FEAT("msp430f47196", "32bit") +MSP430_MCU_FEAT("msp430f47167", "32bit") +MSP430_MCU_FEAT("msp430f47177", "32bit") +MSP430_MCU_FEAT("msp430f47187", "32bit") +MSP430_MCU_FEAT("msp430f47197", "32bit") +MSP430_MCU_FEAT("msp430f5418", "32bit") +MSP430_MCU_FEAT("msp430f5419", "32bit") +MSP430_MCU_FEAT("msp430f5435", "32bit") +MSP430_MCU_FEAT("msp430f5436", "32bit") +MSP430_MCU_FEAT("msp430f5437", "32bit") +MSP430_MCU_FEAT("msp430f5438", "32bit") +MSP430_MCU_FEAT("msp430f5418a", "32bit") +MSP430_MCU_FEAT("msp430f5419a", "32bit") +MSP430_MCU_FEAT("msp430f5435a", "32bit") +MSP430_MCU_FEAT("msp430f5436a", "32bit") +MSP430_MCU_FEAT("msp430f5437a", "32bit") +MSP430_MCU_FEAT("msp430f5438a", "32bit") +MSP430_MCU_FEAT("msp430f5212", "32bit") +MSP430_MCU_FEAT("msp430f5213", "32bit") +MSP430_MCU_FEAT("msp430f5214", "32bit") +MSP430_MCU_FEAT("msp430f5217", "32bit") +MSP430_MCU_FEAT("msp430f5218", "32bit") +MSP430_MCU_FEAT("msp430f5219", "32bit") +MSP430_MCU_FEAT("msp430f5222", "32bit") +MSP430_MCU_FEAT("msp430f5223", "32bit") +MSP430_MCU_FEAT("msp430f5224", "32bit") +MSP430_MCU_FEAT("msp430f5227", "32bit") +MSP430_MCU_FEAT("msp430f5228", "32bit") +MSP430_MCU_FEAT("msp430f5229", "32bit") +MSP430_MCU_FEAT("msp430f5232", "32bit") +MSP430_MCU_FEAT("msp430f5234", "32bit") +MSP430_MCU_FEAT("msp430f5237", "32bit") +MSP430_MCU_FEAT("msp430f5239", "32bit") +MSP430_MCU_FEAT("msp430f5242", "32bit") +MSP430_MCU_FEAT("msp430f5244", "32bit") +MSP430_MCU_FEAT("msp430f5247", "32bit") +MSP430_MCU_FEAT("msp430f5249", "32bit") +MSP430_MCU_FEAT("msp430f5304", "32bit") +MSP430_MCU_FEAT("msp430f5308", "32bit") +MSP430_MCU_FEAT("msp430f5309", "32bit") +MSP430_MCU_FEAT("msp430f5310", "32bit") +MSP430_MCU_FEAT("msp430f5340", "32bit") +MSP430_MCU_FEAT("msp430f5341", "32bit") +MSP430_MCU_FEAT("msp430f5342", "32bit") +MSP430_MCU_FEAT("msp430f5324", "32bit") +MSP430_MCU_FEAT("msp430f5325", "32bit") +MSP430_MCU_FEAT("msp430f5326", "32bit") +MSP430_MCU_FEAT("msp430f5327", "32bit") +MSP430_MCU_FEAT("msp430f5328", "32bit") +MSP430_MCU_FEAT("msp430f5329", "32bit") +MSP430_MCU_FEAT("msp430f5500", "32bit") +MSP430_MCU_FEAT("msp430f5501", "32bit") +MSP430_MCU_FEAT("msp430f5502", "32bit") +MSP430_MCU_FEAT("msp430f5503", "32bit") +MSP430_MCU_FEAT("msp430f5504", "32bit") +MSP430_MCU_FEAT("msp430f5505", "32bit") +MSP430_MCU_FEAT("msp430f5506", "32bit") +MSP430_MCU_FEAT("msp430f5507", "32bit") +MSP430_MCU_FEAT("msp430f5508", "32bit") +MSP430_MCU_FEAT("msp430f5509", "32bit") +MSP430_MCU_FEAT("msp430f5510", "32bit") +MSP430_MCU_FEAT("msp430f5513", "32bit") +MSP430_MCU_FEAT("msp430f5514", "32bit") +MSP430_MCU_FEAT("msp430f5515", "32bit") +MSP430_MCU_FEAT("msp430f5517", "32bit") +MSP430_MCU_FEAT("msp430f5519", "32bit") +MSP430_MCU_FEAT("msp430f5521", "32bit") +MSP430_MCU_FEAT("msp430f5522", "32bit") +MSP430_MCU_FEAT("msp430f5524", "32bit") +MSP430_MCU_FEAT("msp430f5525", "32bit") +MSP430_MCU_FEAT("msp430f5526", "32bit") +MSP430_MCU_FEAT("msp430f5527", "32bit") +MSP430_MCU_FEAT("msp430f5528", "32bit") +MSP430_MCU_FEAT("msp430f5529", "32bit") +MSP430_MCU_FEAT("cc430f5133", "32bit") +MSP430_MCU_FEAT("cc430f5135", "32bit") +MSP430_MCU_FEAT("cc430f5137", "32bit") +MSP430_MCU_FEAT("cc430f6125", "32bit") +MSP430_MCU_FEAT("cc430f6126", "32bit") +MSP430_MCU_FEAT("cc430f6127", "32bit") +MSP430_MCU_FEAT("cc430f6135", "32bit") +MSP430_MCU_FEAT("cc430f6137", "32bit") +MSP430_MCU_FEAT("cc430f5123", "32bit") +MSP430_MCU_FEAT("cc430f5125", "32bit") +MSP430_MCU_FEAT("cc430f5143", "32bit") +MSP430_MCU_FEAT("cc430f5145", "32bit") +MSP430_MCU_FEAT("cc430f5147", "32bit") +MSP430_MCU_FEAT("cc430f6143", "32bit") +MSP430_MCU_FEAT("cc430f6145", "32bit") +MSP430_MCU_FEAT("cc430f6147", "32bit") +MSP430_MCU_FEAT("msp430f5333", "32bit") +MSP430_MCU_FEAT("msp430f5335", "32bit") +MSP430_MCU_FEAT("msp430f5336", "32bit") +MSP430_MCU_FEAT("msp430f5338", "32bit") +MSP430_MCU_FEAT("msp430f5630", "32bit") +MSP430_MCU_FEAT("msp430f5631", "32bit") +MSP430_MCU_FEAT("msp430f5632", "32bit") +MSP430_MCU_FEAT("msp430f5633", "32bit") +MSP430_MCU_FEAT("msp430f5634", "32bit") +MSP430_MCU_FEAT("msp430f5635", "32bit") +MSP430_MCU_FEAT("msp430f5636", "32bit") +MSP430_MCU_FEAT("msp430f5637", "32bit") +MSP430_MCU_FEAT("msp430f5638", "32bit") +MSP430_MCU_FEAT("msp430f6433", "32bit") +MSP430_MCU_FEAT("msp430f6435", "32bit") +MSP430_MCU_FEAT("msp430f6436", "32bit") +MSP430_MCU_FEAT("msp430f6438", "32bit") +MSP430_MCU_FEAT("msp430f6630", "32bit") +MSP430_MCU_FEAT("msp430f6631", "32bit") +MSP430_MCU_FEAT("msp430f6632", "32bit") +MSP430_MCU_FEAT("msp430f6633", "32bit") +MSP430_MCU_FEAT("msp430f6634", "32bit") +MSP430_MCU_FEAT("msp430f6635", "32bit") +MSP430_MCU_FEAT("msp430f6636", "32bit") +MSP430_MCU_FEAT("msp430f6637", "32bit") +MSP430_MCU_FEAT("msp430f6638", "32bit") +MSP430_MCU_FEAT("msp430f5358", "32bit") +MSP430_MCU_FEAT("msp430f5359", "32bit") +MSP430_MCU_FEAT("msp430f5658", "32bit") +MSP430_MCU_FEAT("msp430f5659", "32bit") +MSP430_MCU_FEAT("msp430f6458", "32bit") +MSP430_MCU_FEAT("msp430f6459", "32bit") +MSP430_MCU_FEAT("msp430f6658", "32bit") +MSP430_MCU_FEAT("msp430f6659", "32bit") +MSP430_MCU_FEAT("msp430fg6425", "32bit") +MSP430_MCU_FEAT("msp430fg6426", "32bit") +MSP430_MCU_FEAT("msp430fg6625", "32bit") +MSP430_MCU_FEAT("msp430fg6626", "32bit") +MSP430_MCU_FEAT("msp430f5131", "32bit") +MSP430_MCU_FEAT("msp430f5151", "32bit") +MSP430_MCU_FEAT("msp430f5171", "32bit") +MSP430_MCU_FEAT("msp430f5132", "32bit") +MSP430_MCU_FEAT("msp430f5152", "32bit") +MSP430_MCU_FEAT("msp430f5172", "32bit") +MSP430_MCU_FEAT("msp430f6720", "32bit") +MSP430_MCU_FEAT("msp430f6721", "32bit") +MSP430_MCU_FEAT("msp430f6723", "32bit") +MSP430_MCU_FEAT("msp430f6724", "32bit") +MSP430_MCU_FEAT("msp430f6725", "32bit") +MSP430_MCU_FEAT("msp430f6726", "32bit") +MSP430_MCU_FEAT("msp430f6730", "32bit") +MSP430_MCU_FEAT("msp430f6731", "32bit") +MSP430_MCU_FEAT("msp430f6733", "32bit") +MSP430_MCU_FEAT("msp430f6734", "32bit") +MSP430_MCU_FEAT("msp430f6735", "32bit") +MSP430_MCU_FEAT("msp430f6736", "32bit") +MSP430_MCU_FEAT("msp430f67621", "32bit") +MSP430_MCU_FEAT("msp430f67641", "32bit") +MSP430_MCU_FEAT("msp430f6720a", "32bit") +MSP430_MCU_FEAT("msp430f6721a", "32bit") +MSP430_MCU_FEAT("msp430f6723a", "32bit") +MSP430_MCU_FEAT("msp430f6724a", "32bit") +MSP430_MCU_FEAT("msp430f6725a", "32bit") +MSP430_MCU_FEAT("msp430f6726a", "32bit") +MSP430_MCU_FEAT("msp430f6730a", "32bit") +MSP430_MCU_FEAT("msp430f6731a", "32bit") +MSP430_MCU_FEAT("msp430f6733a", "32bit") +MSP430_MCU_FEAT("msp430f6734a", "32bit") +MSP430_MCU_FEAT("msp430f6735a", "32bit") +MSP430_MCU_FEAT("msp430f6736a", "32bit") +MSP430_MCU_FEAT("msp430f67621a", "32bit") +MSP430_MCU_FEAT("msp430f67641a", "32bit") +MSP430_MCU_FEAT("msp430f67451", "32bit") +MSP430_MCU_FEAT("msp430f67651", "32bit") +MSP430_MCU_FEAT("msp430f67751", "32bit") +MSP430_MCU_FEAT("msp430f67461", "32bit") +MSP430_MCU_FEAT("msp430f67661", "32bit") +MSP430_MCU_FEAT("msp430f67761", "32bit") +MSP430_MCU_FEAT("msp430f67471", "32bit") +MSP430_MCU_FEAT("msp430f67671", "32bit") +MSP430_MCU_FEAT("msp430f67771", "32bit") +MSP430_MCU_FEAT("msp430f67481", "32bit") +MSP430_MCU_FEAT("msp430f67681", "32bit") +MSP430_MCU_FEAT("msp430f67781", "32bit") +MSP430_MCU_FEAT("msp430f67491", "32bit") +MSP430_MCU_FEAT("msp430f67691", "32bit") +MSP430_MCU_FEAT("msp430f67791", "32bit") +MSP430_MCU_FEAT("msp430f6745", "32bit") +MSP430_MCU_FEAT("msp430f6765", "32bit") +MSP430_MCU_FEAT("msp430f6775", "32bit") +MSP430_MCU_FEAT("msp430f6746", "32bit") +MSP430_MCU_FEAT("msp430f6766", "32bit") +MSP430_MCU_FEAT("msp430f6776", "32bit") +MSP430_MCU_FEAT("msp430f6747", "32bit") +MSP430_MCU_FEAT("msp430f6767", "32bit") +MSP430_MCU_FEAT("msp430f6777", "32bit") +MSP430_MCU_FEAT("msp430f6748", "32bit") +MSP430_MCU_FEAT("msp430f6768", "32bit") +MSP430_MCU_FEAT("msp430f6778", "32bit") +MSP430_MCU_FEAT("msp430f6749", "32bit") +MSP430_MCU_FEAT("msp430f6769", "32bit") +MSP430_MCU_FEAT("msp430f6779", "32bit") +MSP430_MCU_FEAT("msp430f67451a", "32bit") +MSP430_MCU_FEAT("msp430f67651a", "32bit") +MSP430_MCU_FEAT("msp430f67751a", "32bit") +MSP430_MCU_FEAT("msp430f67461a", "32bit") +MSP430_MCU_FEAT("msp430f67661a", "32bit") +MSP430_MCU_FEAT("msp430f67761a", "32bit") +MSP430_MCU_FEAT("msp430f67471a", "32bit") +MSP430_MCU_FEAT("msp430f67671a", "32bit") +MSP430_MCU_FEAT("msp430f67771a", "32bit") +MSP430_MCU_FEAT("msp430f67481a", "32bit") +MSP430_MCU_FEAT("msp430f67681a", "32bit") +MSP430_MCU_FEAT("msp430f67781a", "32bit") +MSP430_MCU_FEAT("msp430f67491a", "32bit") +MSP430_MCU_FEAT("msp430f67691a", "32bit") +MSP430_MCU_FEAT("msp430f67791a", "32bit") +MSP430_MCU_FEAT("msp430f6745a", "32bit") +MSP430_MCU_FEAT("msp430f6765a", "32bit") +MSP430_MCU_FEAT("msp430f6775a", "32bit") +MSP430_MCU_FEAT("msp430f6746a", "32bit") +MSP430_MCU_FEAT("msp430f6766a", "32bit") +MSP430_MCU_FEAT("msp430f6776a", "32bit") +MSP430_MCU_FEAT("msp430f6747a", "32bit") +MSP430_MCU_FEAT("msp430f6767a", "32bit") +MSP430_MCU_FEAT("msp430f6777a", "32bit") +MSP430_MCU_FEAT("msp430f6748a", "32bit") +MSP430_MCU_FEAT("msp430f6768a", "32bit") +MSP430_MCU_FEAT("msp430f6778a", "32bit") +MSP430_MCU_FEAT("msp430f6749a", "32bit") +MSP430_MCU_FEAT("msp430f6769a", "32bit") +MSP430_MCU_FEAT("msp430f6779a", "32bit") +MSP430_MCU_FEAT("msp430fr5720", "32bit") +MSP430_MCU_FEAT("msp430fr5721", "32bit") +MSP430_MCU_FEAT("msp430fr5722", "32bit") +MSP430_MCU_FEAT("msp430fr5723", "32bit") +MSP430_MCU_FEAT("msp430fr5724", "32bit") +MSP430_MCU_FEAT("msp430fr5725", "32bit") +MSP430_MCU_FEAT("msp430fr5726", "32bit") +MSP430_MCU_FEAT("msp430fr5727", "32bit") +MSP430_MCU_FEAT("msp430fr5728", "32bit") +MSP430_MCU_FEAT("msp430fr5729", "32bit") +MSP430_MCU_FEAT("msp430fr5730", "32bit") +MSP430_MCU_FEAT("msp430fr5731", "32bit") +MSP430_MCU_FEAT("msp430fr5732", "32bit") +MSP430_MCU_FEAT("msp430fr5733", "32bit") +MSP430_MCU_FEAT("msp430fr5734", "32bit") +MSP430_MCU_FEAT("msp430fr5735", "32bit") +MSP430_MCU_FEAT("msp430fr5736", "32bit") +MSP430_MCU_FEAT("msp430fr5737", "32bit") +MSP430_MCU_FEAT("msp430fr5738", "32bit") +MSP430_MCU_FEAT("msp430fr5739", "32bit") +MSP430_MCU_FEAT("msp430bt5190", "32bit") +MSP430_MCU_FEAT("msp430fr5857", "32bit") +MSP430_MCU_FEAT("msp430fr5858", "32bit") +MSP430_MCU_FEAT("msp430fr5859", "32bit") +MSP430_MCU_FEAT("msp430fr5847", "32bit") +MSP430_MCU_FEAT("msp430fr58471", "32bit") +MSP430_MCU_FEAT("msp430fr5848", "32bit") +MSP430_MCU_FEAT("msp430fr5849", "32bit") +MSP430_MCU_FEAT("msp430fr5867", "32bit") +MSP430_MCU_FEAT("msp430fr58671", "32bit") +MSP430_MCU_FEAT("msp430fr5868", "32bit") +MSP430_MCU_FEAT("msp430fr5869", "32bit") +MSP430_MCU_FEAT("msp430fr5957", "32bit") +MSP430_MCU_FEAT("msp430fr5958", "32bit") +MSP430_MCU_FEAT("msp430fr5959", "32bit") +MSP430_MCU_FEAT("msp430fr5947", "32bit") +MSP430_MCU_FEAT("msp430fr59471", "32bit") +MSP430_MCU_FEAT("msp430fr5948", "32bit") +MSP430_MCU_FEAT("msp430fr5949", "32bit") +MSP430_MCU_FEAT("msp430fr5967", "32bit") +MSP430_MCU_FEAT("msp430fr5968", "32bit") +MSP430_MCU_FEAT("msp430fr5969", "32bit") +MSP430_MCU_FEAT("msp430fr59691", "32bit") +MSP430_MCU_FEAT("rf430f5175", "32bit") +MSP430_MCU_FEAT("rf430f5155", "32bit") +MSP430_MCU_FEAT("rf430f5144", "32bit") +MSP430_MCU_FEAT("msp430fr69271", "32bit") +MSP430_MCU_FEAT("msp430fr68791", "32bit") +MSP430_MCU_FEAT("msp430fr69791", "32bit") +MSP430_MCU_FEAT("msp430fr6927", "32bit") +MSP430_MCU_FEAT("msp430fr6928", "32bit") +MSP430_MCU_FEAT("msp430fr6877", "32bit") +MSP430_MCU_FEAT("msp430fr6977", "32bit") +MSP430_MCU_FEAT("msp430fr6879", "32bit") +MSP430_MCU_FEAT("msp430fr6979", "32bit") +MSP430_MCU_FEAT("msp430fr58891", "32bit") +MSP430_MCU_FEAT("msp430fr68891", "32bit") +MSP430_MCU_FEAT("msp430fr59891", "32bit") +MSP430_MCU_FEAT("msp430fr69891", "32bit") +MSP430_MCU_FEAT("msp430fr5887", "32bit") +MSP430_MCU_FEAT("msp430fr5888", "32bit") +MSP430_MCU_FEAT("msp430fr5889", "32bit") +MSP430_MCU_FEAT("msp430fr6887", "32bit") +MSP430_MCU_FEAT("msp430fr6888", "32bit") +MSP430_MCU_FEAT("msp430fr6889", "32bit") +MSP430_MCU_FEAT("msp430fr5986", "32bit") +MSP430_MCU_FEAT("msp430fr5987", "32bit") +MSP430_MCU_FEAT("msp430fr5988", "32bit") +MSP430_MCU_FEAT("msp430fr5989", "32bit") +MSP430_MCU_FEAT("msp430fr6987", "32bit") +MSP430_MCU_FEAT("msp430fr6988", "32bit") +MSP430_MCU_FEAT("msp430fr6989", "32bit") +MSP430_MCU_FEAT("msp430fr5922", "32bit") +MSP430_MCU_FEAT("msp430fr5870", "32bit") +MSP430_MCU_FEAT("msp430fr5970", "32bit") +MSP430_MCU_FEAT("msp430fr5872", "32bit") +MSP430_MCU_FEAT("msp430fr5972", "32bit") +MSP430_MCU_FEAT("msp430fr6820", "32bit") +MSP430_MCU_FEAT("msp430fr6920", "32bit") +MSP430_MCU_FEAT("msp430fr6822", "32bit") +MSP430_MCU_FEAT("msp430fr6922", "32bit") +MSP430_MCU_FEAT("msp430fr6870", "32bit") +MSP430_MCU_FEAT("msp430fr6970", "32bit") +MSP430_MCU_FEAT("msp430fr6872", "32bit") +MSP430_MCU_FEAT("msp430fr6972", "32bit") +MSP430_MCU_FEAT("msp430fr59221", "32bit") +MSP430_MCU_FEAT("msp430fr58721", "32bit") +MSP430_MCU_FEAT("msp430fr59721", "32bit") +MSP430_MCU_FEAT("msp430fr68221", "32bit") +MSP430_MCU_FEAT("msp430fr69221", "32bit") +MSP430_MCU_FEAT("msp430fr68721", "32bit") +MSP430_MCU_FEAT("msp430fr69721", "32bit") +MSP430_MCU_FEAT("msp430sl5438a", "32bit") +MSP430_MCU_FEAT("msp430fr2433", "32bit") +MSP430_MCU_FEAT("msp430fr2532", "32bit") +MSP430_MCU_FEAT("msp430fr2533", "32bit") +MSP430_MCU_FEAT("msp430fr2632", "32bit") +MSP430_MCU_FEAT("msp430fr2633", "32bit") +MSP430_MCU_FEAT("msp430f5252", "32bit") +MSP430_MCU_FEAT("msp430f5253", "32bit") +MSP430_MCU_FEAT("msp430f5254", "32bit") +MSP430_MCU_FEAT("msp430f5255", "32bit") +MSP430_MCU_FEAT("msp430f5256", "32bit") +MSP430_MCU_FEAT("msp430f5257", "32bit") +MSP430_MCU_FEAT("msp430f5258", "32bit") +MSP430_MCU_FEAT("msp430f5259", "32bit") +MSP430_MCU_FEAT("msp430fr5962", "32bit") +MSP430_MCU_FEAT("msp430fr5964", "32bit") +MSP430_MCU_FEAT("msp430fr5992", "32bit") +MSP430_MCU_FEAT("msp430fr5994", "32bit") +MSP430_MCU_FEAT("msp430fr59941", "32bit") +MSP430_MCU_FEAT("msp430fr2355", "32bit") +MSP430_MCU_FEAT("msp430fr2155", "32bit") +MSP430_MCU_FEAT("msp430fr2353", "32bit") +MSP430_MCU_FEAT("msp430fr2153", "32bit") +MSP430_MCU_FEAT("msp430fr2522", "32bit") +MSP430_MCU_FEAT("msp430fr2512", "32bit") +MSP430_MCU_FEAT("msp430fr2422", "32bit") +MSP430_MCU_FEAT("msp430fr2676", "32bit") +MSP430_MCU_FEAT("msp430fr2476", "32bit") +MSP430_MCU_FEAT("msp430fr2675", "32bit") +MSP430_MCU_FEAT("msp430fr2673", "32bit") +MSP430_MCU_FEAT("msp430fr2475", "32bit") +MSP430_MCU_FEAT("msp430fr2672", "32bit") +MSP430_MCU_FEAT("msp430fr6043", "32bit") +MSP430_MCU_FEAT("msp430fr5043", "32bit") +MSP430_MCU_FEAT("msp430fr6041", "32bit") +MSP430_MCU_FEAT("msp430fr60431", "32bit") +MSP430_MCU_FEAT("msp430fr5041", "32bit") +MSP430_MCU_FEAT("msp430fr50431", "32bit") +MSP430_MCU_FEAT("msp430fr6005", "32bit") +MSP430_MCU_FEAT("msp430fr6047", "32bit") +MSP430_MCU_FEAT("msp430fr6037", "32bit") +MSP430_MCU_FEAT("msp430fr6045", "32bit") +MSP430_MCU_FEAT("msp430fr60471", "32bit") +MSP430_MCU_FEAT("msp430fr6035", "32bit") +MSP430_MCU_FEAT("msp430fr6007", "32bit") +MSP430_MCU_FEAT("msp430fr60371", "32bit") // Generic MCUs MSP430_MCU("msp430i2xxgeneric") diff --git a/clang/include/clang/Basic/Target/MSP430/gen-msp430-def.py b/clang/include/clang/Basic/Target/MSP430/gen-msp430-def.py new file mode 100755 index 0000000000000..3ae6fdd9d5c65 --- /dev/null +++ b/clang/include/clang/Basic/Target/MSP430/gen-msp430-def.py @@ -0,0 +1,126 @@ +#!/usr/bin/env python3 +# ===----------------------------------------------------------------------===## +# +# Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. +# See https://llvm.org/LICENSE.txt for license information. +# SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception +# +# ===----------------------------------------------------------------------===## +""" +Script to generate MSP430 definitions from TI's devices.csv + +Download the devices.csv from [1] using the link "Header and Support Files". + +[1]: https://www.ti.com/tool/MSP430-GCC-OPENSOURCE#downloads +""" +import csv +import sys + +DEVICE_COLUMN = 0 +MULTIPLIER_COLUMN = 3 + +MULTIPLIER_SW = "0" +MULTIPLIER_HW_16 = ("1", "2") +MULTIPLIER_HW_32 = ("4", "8") + +PREFIX = """//===--- MSP430Target.def - MSP430 Feature/Processor Database----*- C++ -*-===// +// +// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. +// See https://llvm.org/LICENSE.txt for license information. +// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception +// +//===----------------------------------------------------------------------===// +// +// This file defines the MSP430 devices and their features. +// +// Generated from TI's devices.csv in version {} using the script in +// Target/MSP430/gen-msp430-def.py - use this tool rather than adding +// new MCUs by hand. +// +//===----------------------------------------------------------------------===// + +#ifndef MSP430_MCU_FEAT +#define MSP430_MCU_FEAT(NAME, HWMULT) MSP430_MCU(NAME) +#endif + +#ifndef MSP430_MCU +#define MSP430_MCU(NAME) +#endif + +""" + +SUFFIX = """ +// Generic MCUs +MSP430_MCU("msp430i2xxgeneric") + +#undef MSP430_MCU +#undef MSP430_MCU_FEAT +""" + + +def csv2def(csv_path, def_path): + """ + Parse the devices.csv file at the given path, generate the definitions and + write them to the given path. + + :param csv_path: Path to the devices.csv to parse + :type csv_path: str + :param def_path: Path to the output file to write the definitions to + "type def_path: str + """ + + mcus_multiplier_sw = [] + mcus_multiplier_hw_16 = [] + mcus_multiplier_hw_32 = [] + version = "unknown" + + with open(csv_path) as csv_file: + csv_reader = csv.reader(csv_file) + while True: + row = next(csv_reader) + if len(row) < MULTIPLIER_COLUMN: + continue + + if row[DEVICE_COLUMN] == "# Device Name": + assert row[MULTIPLIER_COLUMN] == "MPY_TYPE", "File format changed" + break + + if row[0] == "Version:": + version = row[1] + + for row in csv_reader: + if row[DEVICE_COLUMN].endswith("generic"): + continue + if row[MULTIPLIER_COLUMN] == MULTIPLIER_SW: + mcus_multiplier_sw.append(row[DEVICE_COLUMN]) + elif row[MULTIPLIER_COLUMN] in MULTIPLIER_HW_16: + mcus_multiplier_hw_16.append(row[DEVICE_COLUMN]) + elif row[MULTIPLIER_COLUMN] in MULTIPLIER_HW_32: + mcus_multiplier_hw_32.append(row[DEVICE_COLUMN]) + else: + assert 0, "Unknown multiplier type" + + with open(def_path, "w") as def_file: + def_file.write(PREFIX.format(version)) + + for mcu in mcus_multiplier_sw: + def_file.write(f'MSP430_MCU("{mcu}")\n') + + def_file.write("\n// With 16-bit hardware multiplier\n") + + for mcu in mcus_multiplier_hw_16: + def_file.write(f'MSP430_MCU_FEAT("{mcu}", "16bit")\n') + + def_file.write("\n// With 32-bit hardware multiplier\n") + + for mcu in mcus_multiplier_hw_32: + def_file.write(f'MSP430_MCU_FEAT("{mcu}", "32bit")\n') + + def_file.write(SUFFIX) + + +if __name__ == "__main__": + if len(sys.argv) != 3: + sys.exit(f"Usage: {sys.argv[0]} <CSV_FILE> <DEF_FILE>") + + csv2def(sys.argv[1], sys.argv[2]) _______________________________________________ cfe-commits mailing list cfe-commits@lists.llvm.org https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits