From nobody Thu Mar 28 18:09:50 2024 X-Original-To: dev-commits-src-all@mlmmj.nyi.freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2610:1c1:1:606c::19:1]) by mlmmj.nyi.freebsd.org (Postfix) with ESMTP id 4V5BQQ39x3z5GQlH; Thu, 28 Mar 2024 18:09:50 +0000 (UTC) (envelope-from git@FreeBSD.org) Received: from mxrelay.nyi.freebsd.org (mxrelay.nyi.freebsd.org [IPv6:2610:1c1:1:606c::19:3]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange X25519 server-signature RSA-PSS (4096 bits) server-digest SHA256 client-signature RSA-PSS (4096 bits) client-digest SHA256) (Client CN "mxrelay.nyi.freebsd.org", Issuer "R3" (verified OK)) by mx1.freebsd.org (Postfix) with ESMTPS id 4V5BQQ1g6nz4D96; Thu, 28 Mar 2024 18:09:50 +0000 (UTC) (envelope-from git@FreeBSD.org) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=freebsd.org; s=dkim; t=1711649390; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding; bh=gmcSdJV4/eTEsnFnm7D9A/AIwXEbEXdr9YErPqrKph4=; b=D7dfE5UTzipONBfcTrAHiJn0GP5n58j81NbrfFyjw23b9DQXVjRguCMPly5kNvbIlGb5ft sOLAz/x7+EOiSDcRnfNqpWgSLZ/4V3caeiZeAdww2c2dfp9i3o6z4ftRIX3yL8OLSUV+5F QUMERHM32xcx5dIbNOp6s8tzvDg8QOetmRtd1WX7RRQWyXLzekbfu17JRzyReEs16qr88c /Kq11a3Hzv8Mdgw23iuWkr5LvXzq6G70y2BwPTa9N8whuGygyWtVaTZuO7XunV6QWa5c3Z EarOI0S77jPsyFc7IMRNHlfHsPFW8rnwBT99ROZJouMoRqKvknqRpp2Gf+JRKA== ARC-Seal: i=1; s=dkim; d=freebsd.org; t=1711649390; a=rsa-sha256; cv=none; b=d/DeycCET9wH8GdoUU1OPBBLD+BOnyz2m9pyPuKzg8SUfF5oFLsTZmQ771CM9jjcbcyKI2 q3qHFO1SjMpsQ2kBMYcgsSNdQ/SSzwoUZ1V9tAQrPx7FMW8a6kAv9g8NfEskjlSxjL6YcQ slLQYNFQrY6NySdZAJxj3Hy/GXjl6/jvHKO9eurHX3vl894czcuZpGzDFZuJeXLruUjIdJ s9BUuloP78Yc3JixoobomR1w4HKYru95KnCpgwp63TTOwYuI2DKt/b7sOQsbIIR4PHZK8P FEpPOOR0LYdZPrQM0qvS4aqWQ0jFhq6cbLaL76apXxufHnPjAVDxezdcPo9MVw== ARC-Authentication-Results: i=1; mx1.freebsd.org; none ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=freebsd.org; s=dkim; t=1711649390; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding; bh=gmcSdJV4/eTEsnFnm7D9A/AIwXEbEXdr9YErPqrKph4=; b=kd3e4tfzbdj2sbw0RK1HKGFP39dEya15AUBd7q2MBa2zi/vhITE7jvy3o4c1TFkfaK50XS fu3frT9ASF36qird66bHu5gOvOplXjvD2Jm8swgKzEkSJ3vU8SY2o3bYAqrNk/YRV38fTA /232T1XapUPdOvsda1JdSU2XAJpjY1QdeA6T+rEQbRWUPM/qslsVaSNVOtp0gr9PUiAZ2p VYlx1aFn3iLSucIYZ2sMFGairVqlJQcYkXqn84NdwVlyDvhE7WKS4lubugH4edsyvhOEob XokUD0vMSkatTvFXJOla9fjt7qahU28Lgfc3zMwUlaa3mLAzGo9A7e8HGn2OYA== Received: from gitrepo.freebsd.org (gitrepo.freebsd.org [IPv6:2610:1c1:1:6068::e6a:5]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange X25519 server-signature RSA-PSS (4096 bits) server-digest SHA256) (Client did not present a certificate) by mxrelay.nyi.freebsd.org (Postfix) with ESMTPS id 4V5BQQ18NyzdnW; Thu, 28 Mar 2024 18:09:50 +0000 (UTC) (envelope-from git@FreeBSD.org) Received: from gitrepo.freebsd.org ([127.0.1.44]) by gitrepo.freebsd.org (8.17.1/8.17.1) with ESMTP id 42SI9oHo021347; Thu, 28 Mar 2024 18:09:50 GMT (envelope-from git@gitrepo.freebsd.org) Received: (from git@localhost) by gitrepo.freebsd.org (8.17.1/8.17.1/Submit) id 42SI9ovv021344; Thu, 28 Mar 2024 18:09:50 GMT (envelope-from git) Date: Thu, 28 Mar 2024 18:09:50 GMT Message-Id: <202403281809.42SI9ovv021344@gitrepo.freebsd.org> To: src-committers@FreeBSD.org, dev-commits-src-all@FreeBSD.org, dev-commits-src-main@FreeBSD.org From: "Stephen J. Kiernan" Subject: git: fe429e6794d3 - main - stand/efi: Changes to efichar to allow it to be used in the kernel List-Id: Commit messages for all branches of the src repository List-Archive: https://lists.freebsd.org/archives/dev-commits-src-all List-Help: List-Post: List-Subscribe: List-Unsubscribe: Sender: owner-dev-commits-src-all@freebsd.org X-BeenThere: dev-commits-src-all@freebsd.org MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Transfer-Encoding: 8bit X-Git-Committer: stevek X-Git-Repository: src X-Git-Refname: refs/heads/main X-Git-Reftype: branch X-Git-Commit: fe429e6794d322636e7c1e520d50ec0cb711dd14 Auto-Submitted: auto-generated The branch main has been updated by stevek: URL: https://cgit.FreeBSD.org/src/commit/?id=fe429e6794d322636e7c1e520d50ec0cb711dd14 commit fe429e6794d322636e7c1e520d50ec0cb711dd14 Author: Stephen J. Kiernan AuthorDate: 2024-03-27 22:37:48 +0000 Commit: Stephen J. Kiernan CommitDate: 2024-03-28 18:09:37 +0000 stand/efi: Changes to efichar to allow it to be used in the kernel Replace malloc/free with EFICHAR_MALLOC and EFICHAR_FREEE macros. Obtained from: Juniper Networks, Inc. Reviewed by: imp Differential Revision: https://reviews.freebsd.org/D44541 --- stand/efi/include/efichar.h | 8 ++++++++ stand/efi/libefi/efichar.c | 17 ++++++++++++----- 2 files changed, 20 insertions(+), 5 deletions(-) diff --git a/stand/efi/include/efichar.h b/stand/efi/include/efichar.h index 4460f5efdcef..0a40906aeedf 100644 --- a/stand/efi/include/efichar.h +++ b/stand/efi/include/efichar.h @@ -37,4 +37,12 @@ int ucs2_to_utf8(const efi_char *, char **); int utf8_to_ucs2(const char *, efi_char **, size_t *); int ucs2len(const efi_char *); +#ifdef _KERNEL +#define EFICHAR_MALLOC(sz) malloc((sz), M_TEMP, M_WAITOK | M_ZERO) +#define EFICHAR_FREE(sz) free((sz), M_TEMP) +#else +#define EFICHAR_MALLOC(sz) malloc(sz) +#define EFICHAR_FREE(sz) free(sz) +#endif + #endif /* _BOOT_EFI_EFICHAR_H_ */ diff --git a/stand/efi/libefi/efichar.c b/stand/efi/libefi/efichar.c index 86642d325754..659212799b6a 100644 --- a/stand/efi/libefi/efichar.c +++ b/stand/efi/libefi/efichar.c @@ -25,14 +25,21 @@ */ #include +#ifndef _KERNEL #include +#endif #ifdef _STANDALONE #include #else +#ifdef _KERNEL +#include +#include +#else #include #include #include #include +#endif #include #include #endif @@ -87,7 +94,7 @@ ucs2_to_utf8(const efi_char *nm, char **name) if (*name != NULL) cp = *name; else - cp = *name = malloc(sz); + cp = *name = EFICHAR_MALLOC(sz); if (*name == NULL) return (ENOMEM); @@ -114,7 +121,7 @@ ucs2_to_utf8(const efi_char *nm, char **name) if (len >= sz) { /* Absent bugs, we'll never return EOVERFLOW */ if (freeit) { - free(*name); + EFICHAR_FREE(*name); *name = NULL; } return (EOVERFLOW); @@ -135,7 +142,7 @@ utf8_to_ucs2(const char *name, efi_char **nmp, size_t *len) sz = strlen(name) * 2 + 2; if (*nmp == NULL) - *nmp = malloc(sz); + *nmp = EFICHAR_MALLOC(sz); if (*nmp == NULL) return (ENOMEM); nm = *nmp; @@ -183,7 +190,7 @@ utf8_to_ucs2(const char *name, efi_char **nmp, size_t *len) } if (sz < 2) { if (freeit) { - free(nm); + EFICHAR_FREE(nm); *nmp = NULL; } return (EDOOFUS); @@ -194,7 +201,7 @@ utf8_to_ucs2(const char *name, efi_char **nmp, size_t *len) return (0); ilseq: if (freeit) { - free(nm); + EFICHAR_FREE(nm); *nmp = NULL; } return (EILSEQ);