From d1163e11af66f771c79d0e265c8303cf27146884 Mon Sep 17 00:00:00 2001 From: Daniel Bevenius Date: Thu, 5 May 2022 07:07:34 +0200 Subject: [PATCH 1/4] doc: add maintaining-libuv guide This commit adds a document to describe the steps needed for updating the libuv dependency. --- deps/uv/src/unix/hurd.c | 167 ++++++++++++++++++++++++++ doc/contributing/maintaining-libuv.md | 64 ++++++++++ 2 files changed, 231 insertions(+) create mode 100644 deps/uv/src/unix/hurd.c create mode 100644 doc/contributing/maintaining-libuv.md diff --git a/deps/uv/src/unix/hurd.c b/deps/uv/src/unix/hurd.c new file mode 100644 index 00000000000000..d19ea6347906e3 --- /dev/null +++ b/deps/uv/src/unix/hurd.c @@ -0,0 +1,167 @@ +/* Copyright libuv project contributors. All rights reserved. + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to + * deal in the Software without restriction, including without limitation the + * rights to use, copy, modify, merge, publish, distribute, sublicense, and/or + * sell copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING + * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS + * IN THE SOFTWARE. + */ + +#define _GNU_SOURCE 1 + +#include "uv.h" +#include "internal.h" + +#include +#include +#include +#include +#include + +#include +#include +#include +#include +#include + +int uv_exepath(char* buffer, size_t* size) { + kern_return_t err; + /* XXX in current Hurd, strings are char arrays of 1024 elements */ + string_t exepath; + ssize_t copied; + + if (buffer == NULL || size == NULL || *size == 0) + return UV_EINVAL; + + if (*size - 1 > 0) { + /* XXX limited length of buffer in current Hurd, this API will probably + * evolve in the future */ + err = proc_get_exe(getproc(), getpid(), exepath); + + if (err) + return UV__ERR(err); + } + + copied = uv__strscpy(buffer, exepath, *size); + + /* do not return error on UV_E2BIG failure */ + *size = copied < 0 ? strlen(buffer) : (size_t) copied; + + return 0; +} + +int uv_resident_set_memory(size_t* rss) { + kern_return_t err; + struct task_basic_info bi; + mach_msg_type_number_t count; + + count = TASK_BASIC_INFO_COUNT; + err = task_info(mach_task_self(), TASK_BASIC_INFO, + (task_info_t) &bi, &count); + + if (err) + return UV__ERR(err); + + *rss = bi.resident_size; + + return 0; +} + +uint64_t uv_get_free_memory(void) { + kern_return_t err; + struct vm_statistics vmstats; + + err = vm_statistics(mach_task_self(), &vmstats); + + if (err) + return 0; + + return vmstats.free_count * vm_page_size; +} + + +uint64_t uv_get_total_memory(void) { + kern_return_t err; + host_basic_info_data_t hbi; + mach_msg_type_number_t cnt; + + cnt = HOST_BASIC_INFO_COUNT; + err = host_info(mach_host_self(), HOST_BASIC_INFO, (host_info_t) &hbi, &cnt); + + if (err) + return 0; + + return hbi.memory_size; +} + + +int uv_uptime(double* uptime) { + char buf[128]; + + /* Try /proc/uptime first */ + if (0 == uv__slurp("/proc/uptime", buf, sizeof(buf))) + if (1 == sscanf(buf, "%lf", uptime)) + return 0; + + /* Reimplement here code from procfs to calculate uptime if not mounted? */ + + return UV__ERR(EIO); +} + +void uv_loadavg(double avg[3]) { + char buf[128]; /* Large enough to hold all of /proc/loadavg. */ + + if (0 == uv__slurp("/proc/loadavg", buf, sizeof(buf))) + if (3 == sscanf(buf, "%lf %lf %lf", &avg[0], &avg[1], &avg[2])) + return; + + /* Reimplement here code from procfs to calculate loadavg if not mounted? */ +} + + +int uv_cpu_info(uv_cpu_info_t** cpu_infos, int* count) { + kern_return_t err; + host_basic_info_data_t hbi; + mach_msg_type_number_t cnt; + + /* Get count of cpus */ + cnt = HOST_BASIC_INFO_COUNT; + err = host_info(mach_host_self(), HOST_BASIC_INFO, (host_info_t) &hbi, &cnt); + + if (err) { + err = UV__ERR(err); + goto abort; + } + + /* XXX not implemented on the Hurd */ + *cpu_infos = uv__calloc(hbi.avail_cpus, sizeof(**cpu_infos)); + if (*cpu_infos == NULL) { + err = UV_ENOMEM; + goto abort; + } + + *count = hbi.avail_cpus; + + return 0; + + abort: + *cpu_infos = NULL; + *count = 0; + return err; +} + +uint64_t uv_get_constrained_memory(void) { + return 0; /* Memory constraints are unknown. */ +} diff --git a/doc/contributing/maintaining-libuv.md b/doc/contributing/maintaining-libuv.md new file mode 100644 index 00000000000000..dc8eea2a795024 --- /dev/null +++ b/doc/contributing/maintaining-libuv.md @@ -0,0 +1,64 @@ +# Maintaining libuv + +This documents contains instructions about how to update libuv. + +## Updating libuv + +[Download](https://github.com/libuv/libuv/releases) the distribution and +signature file of the version to update to. + +### Verify the download + +Import the public key of the person who signed the distribution: + +```console +git tag -l | grep pubkey +pubkey-bnoordhuis +pubkey-cjihrig +pubkey-cjihrig-kb +pubkey-indutny +pubkey-iwuzhere +pubkey-richardlau +pubkey-saghul +pubkey-santigimeno +pubkey-vtjnash +pubkey2022-vtjnash + +git show | gpg --import +gpg --verify /path/to/download/libuv-v1.44.1-dist.tar.gz.sign libuv-v1.44.1-dist.tar.gz +gpg: Signature made Wed 09 Mar 2022 06:58:08 PM CET +gpg: using RSA key CFBB9CA9A5BEAFD70E2B3C5A79A67C55A3679C8B +gpg: Good signature from "Jameson Nash " [unknown] +gpg: WARNING: This key is not certified with a trusted signature! +gpg: There is no indication that the signature belongs to the owner. +Primary key fingerprint: CFBB 9CA9 A5BE AFD7 0E2B 3C5A 79A6 7C55 A367 9C8B +``` + +### Extract the distribution into deps/uv + +```bash +cd /path/to/nodejs/node +tar xvzf /path/to/download/libuv-v1.44.1-dist.tar.gz -C deps/uv --strip 1 +``` + +### Check that Node.js still builds and tests + +```console +./configure && make -j8 test +./node -p process.versions.uv +1.44.1 +``` + +### Committing zlib + +```console +git add --all deps/uv +``` + +Commit the changes with a message like: + +```text +deps: update libuv to upstream version + +Updated as described in doc/contributing/maintaining-libuv.md. +``` From 1ea9108d61e9622d8409fe356e23e449b9077358 Mon Sep 17 00:00:00 2001 From: Daniel Bevenius Date: Fri, 6 May 2022 05:49:21 +0200 Subject: [PATCH 2/4] fixup! doc: add maintaining-libuv guide --- doc/contributing/maintaining-libuv.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/doc/contributing/maintaining-libuv.md b/doc/contributing/maintaining-libuv.md index dc8eea2a795024..0d779c8e2918f0 100644 --- a/doc/contributing/maintaining-libuv.md +++ b/doc/contributing/maintaining-libuv.md @@ -49,7 +49,7 @@ tar xvzf /path/to/download/libuv-v1.44.1-dist.tar.gz -C deps/uv --strip 1 1.44.1 ``` -### Committing zlib +### Committing libuv ```console git add --all deps/uv From 93f0959c905ad53ba8e708146aee85f6778722cf Mon Sep 17 00:00:00 2001 From: Daniel Bevenius Date: Mon, 9 May 2022 06:00:41 +0200 Subject: [PATCH 3/4] fixup! doc: add maintaining-libuv guide --- doc/contributing/maintaining-libuv.md | 3 +++ 1 file changed, 3 insertions(+) diff --git a/doc/contributing/maintaining-libuv.md b/doc/contributing/maintaining-libuv.md index 0d779c8e2918f0..c25eaad606239d 100644 --- a/doc/contributing/maintaining-libuv.md +++ b/doc/contributing/maintaining-libuv.md @@ -38,8 +38,11 @@ Primary key fingerprint: CFBB 9CA9 A5BE AFD7 0E2B 3C5A 79A6 7C55 A367 9C8B ```bash cd /path/to/nodejs/node +find deps/uv -maxdepth 1 ! -name . ! -name .. ! -name common.gypi ! -name uv.gyp | xargs rm -rf {} tar xvzf /path/to/download/libuv-v1.44.1-dist.tar.gz -C deps/uv --strip 1 ``` +`common.gypi` and `uv.gyp` may require changes and it is recommended inspect to +these files even if the build and tests pass in the next stage. ### Check that Node.js still builds and tests From fec7a75cadcff3265bf0189d5e50398fa1540e01 Mon Sep 17 00:00:00 2001 From: Daniel Bevenius Date: Mon, 9 May 2022 06:08:41 +0200 Subject: [PATCH 4/4] fixup! doc: add maintaining-libuv guide --- doc/contributing/maintaining-libuv.md | 1 + 1 file changed, 1 insertion(+) diff --git a/doc/contributing/maintaining-libuv.md b/doc/contributing/maintaining-libuv.md index c25eaad606239d..c8064ddabbdd3a 100644 --- a/doc/contributing/maintaining-libuv.md +++ b/doc/contributing/maintaining-libuv.md @@ -41,6 +41,7 @@ cd /path/to/nodejs/node find deps/uv -maxdepth 1 ! -name . ! -name .. ! -name common.gypi ! -name uv.gyp | xargs rm -rf {} tar xvzf /path/to/download/libuv-v1.44.1-dist.tar.gz -C deps/uv --strip 1 ``` + `common.gypi` and `uv.gyp` may require changes and it is recommended inspect to these files even if the build and tests pass in the next stage.