node/deps/openssl
Anna Henningsen 203398dd18 build: fix C string encoding for `PRODUCT_DIR_ABS`
Since the `PRODUCT_DIR_ABS` gyp variable is meant to be used
in a C string in the OpenSSL config, provide a version of it
that actually provides it in a way that is always usable as a
C string. Otherwise, unescaped characters in the path can mess
with the string definitions; for example, building in paths
on Windows whose directories start with valid or invalid escape
sequences (e.g.: `C:\...\x61foobar\...` or `C:\...\456789\...`)
can result in failing builds or incorrect paths provided to
OpenSSL.

PR-URL: https://github.com/nodejs/node/pull/56111
Reviewed-By: Yagiz Nizipli <yagiz@nizipli.com>
Reviewed-By: James M Snell <jasnell@gmail.com>
2024-12-12 18:34:18 +00:00
..
config deps: update archs files for openssl-3.0.15+quic1 2024-10-02 17:29:15 +00:00
openssl deps: update archs files for openssl-3.0.15+quic1 2024-10-02 17:29:15 +00:00
.gitignore deps,test,src,doc,tools: update to OpenSSL 3.0 2021-10-11 06:28:08 +02:00
BUILD.gn build: add GN build files 2023-11-11 09:51:05 +00:00
README.md doc: fix broken link to new folder doc/contributing/maintaining 2023-05-28 21:28:19 +02:00
nodejs-openssl.cnf src,deps,build,test: add OpenSSL config appname 2022-05-31 13:41:30 +02:00
openssl-cl_asm.gypi build: fix IBM i build with Python 3.9 2023-09-29 18:26:28 +00:00
openssl-cl_asm_avx2.gypi build: fix IBM i build with Python 3.9 2023-09-29 18:26:28 +00:00
openssl-cl_no_asm.gypi build: fix IBM i build with Python 3.9 2023-09-29 18:26:28 +00:00
openssl-cli.gypi build, deps, tools: avoid excessive LTO 2023-04-06 00:24:58 +00:00
openssl-fips_asm.gypi build: fix IBM i build with Python 3.9 2023-09-29 18:26:28 +00:00
openssl-fips_asm_avx2.gypi build: fix IBM i build with Python 3.9 2023-09-29 18:26:28 +00:00
openssl-fips_no_asm.gypi build: fix IBM i build with Python 3.9 2023-09-29 18:26:28 +00:00
openssl.gyp build: fix C string encoding for `PRODUCT_DIR_ABS` 2024-12-12 18:34:18 +00:00
openssl.gypi deps: attempt to suppress macro-redefined warning 2021-10-21 04:17:12 +02:00
openssl_asm.gypi build: fix IBM i build with Python 3.9 2023-09-29 18:26:28 +00:00
openssl_asm_avx2.gypi build: fix IBM i build with Python 3.9 2023-09-29 18:26:28 +00:00
openssl_common.gypi build: harmonize Clang checks 2024-05-09 12:10:59 +00:00
openssl_no_asm.gypi build: fix IBM i build with Python 3.9 2023-09-29 18:26:28 +00:00
unofficial.gni build: fix arm64 host cross-compilation in GN 2024-03-06 11:11:52 +09:00

README.md

This has a new binding scheme in building OpenSSL-3.0.0 library with Node.js. OpenSSL-3.0.0 uses a new build system with Perl for various supported platforms. See openssl/Configurations/README and openssl/Configurations/README-design.md in the OpenSSL source for details.

In order to build OpenSSL library without Perl in the build of Node.js for various supported platforms, platform dependent files (e.g. asm and header files ) are pre-generated and stored into the config/archs directory.

  • config/Makefile and config/generate_gypi.pl

    Makefile has supported platform list and generates and copies platform dependent files (e.g. asm files) into arch directory with generate_gypi.pl. Platform dependent gypi files are also created obtaining build information from configdata.pm that is generated with Configure in the OpenSSL build system.

    For Windows, Configure generates makefile that is only available to nmake command. config/Makefile_VC-WIN32 and config/Makefile_VC-WIN64A are made by hand for the use of GNU make. If makefile rules or targets are changed in the version up of OpenSSL, they should be also updated.

  • gyp and gypi files (openssl*.{gyp,gypi})

    openssl.gyp has two targets of openssl and openssl-cli referred from node.gyp. They include asm and no_asm gypi files with arch dependent gypi according to its build options and platforms. The gyp data which is common with asm and no_asm are stored in openssl_common.gypi.

  • header files (config/*.{h,h.tmpl})

    bn_conf.h, dso_conf.h and opensslconf.h are platform dependent in the OpenSSL sources. They are replaced with config/*.h.tmpl files to include the file in the ../../../config/ and referred to each arch file that depends on asm and no-asm option. These headers are generated by the make target generate_headers.

Supported architectures for use of ASM

Here is a list of supported architectures for use of ASM in OpenSSL.

--dest-os --dest-cpu OpenSSL target arch CI
aix ppc64 aix64-gcc o
linux ia32 linux-elf o
linux x32 linux-x32 -
linux x64 linux-x86_64 o
linux arm linux-armv4 o
linux arm64 linux-aarch64 o
linux ppc64(*1) linux-ppc64le o
linux s390 linux32-s390x o
linux s390x linux64-s390x o
mac ia32 darwin-i386-cc -
mac x64 darwin64-x86-cc o
win ia32 VC-WIN32 -
win x64 VC-WIN64A o
solaris ia32 solaris-x86-gcc o
solaris x64 solaris64-x86_64-gcc o
freebsd ia32 BSD-x86 -
freebsd x64 BSD-x86_64 o
openbsd ia32 BSD-x86 -
openbsd x64 BSD-x86_64 -
others others linux-elf -

(*1: This needs to be configured with the variable of node_byteorder: little)

These are listed in config/Makefile. Please refer config/opensslconf_asm.h for details.

To remove or add an architecture the templates need to be updated for which there are two:

  • include_asm.h.tmpl
  • include_no-asm.h.tmpl

Remove the architecture in question from these files and then run:

$ make generate-headers

Also remove the architecture from the list of supported ASM architectures in README.md

Upgrading OpenSSL

Please refer to maintaining-openssl.