Skip site navigation (1)Skip section navigation (2)
Date:      Tue, 24 Dec 2019 20:13:30 +0000 (UTC)
From:      Brandon Bergren <bdragon@FreeBSD.org>
To:        src-committers@freebsd.org, svn-src-all@freebsd.org, svn-src-head@freebsd.org
Subject:   svn commit: r356061 - head/sys/powerpc/include
Message-ID:  <201912242013.xBOKDU4b073278@repo.freebsd.org>

next in thread | raw e-mail | index | archive | help
Author: bdragon
Date: Tue Dec 24 20:13:29 2019
New Revision: 356061
URL: https://svnweb.freebsd.org/changeset/base/356061

Log:
  [PowerPC] Define powerpc IFUNC kernel/userspace ABI.
  
  This is a prerequisite for anything IFUNC in the ELFv2 / clang switch.
  
  Since probing cpu info on powerpc is a privileged operation, define that we
  pass AT_HWCAP / AT_HWCAP2 through as cpu_features and cpu_features2 to ifunc
  resolvers.
  
  This is particularly important when dealing with non-PLT GNU IFUNC, which is
  not allowed to PLT call from resolvers and therefore can't access global
  variables.
  
  The naming convention "cpu_features"/"cpu_features2" is an existing FreeBSD
  PowerPC convention and matches the way we treat these variables in
  machine/cpu.h.
  
  The underlying variables are u_long, however, as per the commit message for
  r332868, only the low 32 bits are ever used, so the underlying flags are
  compatible across all of PowerPC.
  
  The resolver prototype is defined to reserve the maximum number of
  register-passed parameters the various PowerPC ABIs allow. This leaves
  plenty of room for growth without needing to resort to passing via the
  stack in the future.
  
  Reviewed by:	jhibbits
  Differential Revision:	https://reviews.freebsd.org/D22787

Added:
  head/sys/powerpc/include/ifunc.h   (contents, props changed)

Added: head/sys/powerpc/include/ifunc.h
==============================================================================
--- /dev/null	00:00:00 1970	(empty, because file is newly added)
+++ head/sys/powerpc/include/ifunc.h	Tue Dec 24 20:13:29 2019	(r356061)
@@ -0,0 +1,60 @@
+/*-
+ * SPDX-License-Identifier: BSD-2-Clause-FreeBSD
+ *
+ * Copyright (c) 2019 Brandon Bergren <bdragon@FreeBSD.org>
+ * Copyright (c) 2015-2018 The FreeBSD Foundation. All rights reserved.
+ *
+ * Part of this software was developed by
+ * Konstantin Belousov <kib@FreeBSD.org>
+ * under sponsorship from the FreeBSD Foundation.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ * 1. Redistributions of source code must retain the above copyright
+ *    notice, this list of conditions and the following disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright
+ *    notice, this list of conditions and the following disclaimer in the
+ *    documentation and/or other materials provided with the distribution.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
+ * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
+ * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
+ * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
+ * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
+ * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
+ * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
+ * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
+ * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
+ * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
+ * SUCH DAMAGE.
+ *
+ * $FreeBSD$
+ */
+
+#ifndef __POWERPC_IFUNC_H
+#define	__POWERPC_IFUNC_H
+
+#include <sys/types.h>
+
+#define	DEFINE_IFUNC(qual, ret_type, name, args)			\
+    static ret_type (*name##_resolver(void))args __used;		\
+    qual ret_type name args __attribute__((ifunc(#name "_resolver")));	\
+    static ret_type (*name##_resolver(void))args
+
+#define	DEFINE_UIFUNC(qual, ret_type, name, args)			\
+    static ret_type (*name##_resolver(register_t, register_t,		\
+	register_t, register_t, register_t, register_t, register_t,	\
+	register_t))args __used;					\
+    qual ret_type name args __attribute__((ifunc(#name "_resolver")));	\
+    static ret_type (*name##_resolver(					\
+	register_t cpu_features,					\
+	register_t cpu_features2,					\
+	register_t arg3 __unused,					\
+	register_t arg4 __unused,					\
+	register_t arg5 __unused,					\
+	register_t arg6 __unused,					\
+	register_t arg7 __unused,					\
+	register_t arg8 __unused))args
+
+#endif



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?201912242013.xBOKDU4b073278>