Skip to content

Support more targets #7

Open
Open
@agagniere

Description

@agagniere

Current state

For now only recent linux on amd64 and macos on intel and apple silicon are supported.
It is done by dirty hacks: configuration is half hard-coded and a few generated headers are provided pre-generated.

Benefit of change

Not hard-coding configuration and generated headers would allow finally allow cross-compiling libpq on many more targets, and also make building the server code much easier.

Note that each PostgreSQL version has a different list of variable to provide for its configuration, so not hard-coding it would allow building more versions with less effort.

What should be done to get there

1. Generate configuration from the target

ALIGNOF_ TYPE

For now i've used @alignOf.

For cross-compiling we need to switch to std.Target.cTypeAlignment. Problem: it was called c_type_alignment up to zig 0.13.

I'll wait for 0.14 to release before doing that change.

SIZEOF_ TYPE

Same thing: i'll change from @sizeOf to std.Target.cTypeByteSize upon 0.14 release

HAVE_ FUNCTION

A mix of options for optional dependencies and writing a big switch.

There is also a need to know which GLIBC version is targeted.
In the case of a version explicitely queried, it will appear in std.Build.ResolvedTarget's query, but in the other case, I don't know how to proceed yet, help would be welcomed

HAVE_ HEADER

Idem

DLSUFFIX

Not needed to set correctly as it it not used when building statically I guess

BLCKSZ ENABLE_THREAD_SAFETY ...

I haven't spent time understanding that, leaving it hard-coded until it breaks something

2. Generate headers at build-time

Certain headers are generated by perl scripts.
They are not a function of the target OS and arch, but may change for each PostgreSQL version, so it is more about supporting different PostgreSQL versions and building the server code than about cross-compilation.

include/catalog/pg_tablespace_d.h

Generated by src/backend/catalog/genbki.pl, see src/include/catalog/Makefile.
Not sure exactly what it does and what it depends on.

include/kwlist_d.h

Generated by src/tools/gen_keywordlist.pl, using module src/tools/PerfectHash.pm (see src/common/Makefile).

include/utils/errcodes.h

Generated by src/backend/utils/generate-errcodes.pl using src/backend/utils/errcodes.txt

TODO list

  • ALIGNOF_ TYPE
  • SIZEOF_ TYPE
  • include/catalog/pg_tablespace_d.h
  • include/kwlist_d.h
  • include/utils/errcodes.h

Metadata

Metadata

Assignees

No one assigned

    Labels

    enhancementNew feature or request

    Type

    No type

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions