Florian, it seems you missed a comment on that topic I wrote a while ago.

There is also the need to have a tuple that matches controllertype to controllerunit to get rid of a big peace of duplicated code from cpuinfo.pas in lazarus.

Lazarus needs to know which unit to include so that codetools can do their magic. In current implementation parts of controllertypes are duplicated in lazarus code.


To get rid of this lazarus will not only need to know the available controllertypes, it will also need to have the mapping from controllertype tu unitname like this:

<controllertype name="NUCLEOF103RB" unit="STM32F103RB" />*
*

in the xml.

Example:

~/fpcupdeluxe-test/fpc/bin/aarch64-darwin/fpc -Tembedded -Parm -ix

<?xml version="1.0" encoding="utf-8"?>
<fpcoutput>
  <info>
    <ostargets>
...

   </ostargets>
    <cpuinstructionsets>
...

   </cpuinstructionsets>
    <fpuinstructionsets>
...

   </fpuinstructionsets>
    <abis>
...

   </abis>
...

   <optimizations>

    </optimizations>
    <wpoptimizations>
...

   </wpoptimizations>
    <modeswitches>
...

   </modeswitches>
    <asmmodes>
...

   </asmmodes>
    <controllertypes>

*...*

*     <controllertype name="NUCLEOF103RB" unit="STM32F103RB" />**
*...

    </controllertypes>
    <features>
...

   </features>
    <codegeneratorbackend>FPC</codegeneratorbackend>
  </info>
</fpcoutput>


Am 02.04.21 um 15:07 schrieb Michael Van Canneyt via fpc-devel:


On Fri, 2 Apr 2021, Florian Klämpfl via fpc-devel wrote:



Am 07.03.2021 um 15:12 schrieb Florian Klämpfl via fpc-devel <fpc-devel@lists.freepascal.org>:

Am 07.03.21 um 12:05 schrieb Alfred via fpc-devel:
Hello,
As a follow-up on a Lazarus feature request.
Among other applications, Lazarus uses some hard-coded list that represent FPC features. Like supported MCU and boards. It would be (much) more convenient to parse the FPC output itself to supply this info. And that could be made easy by using XML as FPC output. Besides the above, I would welcome more features to be available through FPC itself. FPC uses system files, located in "compiler/systems". With all kinds of settings. Like alignment and calling convention and linker to use. FPC uses search-paths. Some user defined through fpc.cfg, some build-in. See all -F... compiler settings. It would be nice to be able to get info through FPC itself about these settings and paths. As maintainer of fpcupdeluxe, often I need to parse fpc.cfg by hand. Or look into a file like fpmkunit.pp to find the valid FPC targets. Or parse the Makefile to find all available subarchs when building a cross-compiler. For a start, I would favor a XML/JSON output of fpc -i. Would be very nice to use its output.

I added a first experimental implementation in r48897. It does not cover full -i, so far only to show how it could look like. Any comments?

Meanwhile I completed it.

So if somebody thinks it’s useful, the json output can be added as well.

Will do, thanks!

Michael.

_______________________________________________
fpc-devel maillist  -  fpc-devel@lists.freepascal.org
https://lists.freepascal.org/cgi-bin/mailman/listinfo/fpc-devel
_______________________________________________
fpc-devel maillist  -  fpc-devel@lists.freepascal.org
https://lists.freepascal.org/cgi-bin/mailman/listinfo/fpc-devel

Reply via email to