[llvm] [llvm] annotate interfaces in llvm-c for DLL export (PR #141701)

Saleem Abdulrasool via llvm-commits llvm-commits at lists.llvm.org
Mon Jun 9 15:19:23 PDT 2025


================
@@ -0,0 +1,42 @@
+/*===-- llvm-c/Visibility.h - Visibility macros for llvm-c ------*- C++ -*-===*\
+|*                                                                            *|
+|* Part of the LLVM Project, under the Apache License v2.0 with LLVM          *|
+|* Exceptions.                                                                *|
+|* See https://llvm.org/LICENSE.txt for license information.                  *|
+|* SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception                    *|
+|*                                                                            *|
+|*===----------------------------------------------------------------------===*|
+|*                                                                            *|
+|* This header defines visibility macros used for the LLVM C interface. These *|
+|* macros are used to annotate C functions that should be exported as part of *|
+|*                                                                            *|
+\*===----------------------------------------------------------------------===*/
+
+#ifndef LLVM_C_VISIBILITY_H
+#define LLVM_C_VISIBILITY_H
+
+#include "llvm/Config/llvm-config.h"
+
+/// LLVM_C_ABI is the export/visibility macro used to mark symbols declared in
+/// llvm-c as exported when llvm is built as a shared library.
+
+#if defined(LLVM_BUILD_LLVM_DYLIB) || defined(LLVM_BUILD_SHARED_LIBS) ||       \
----------------
compnerd wrote:

I don't think that we need to bind this to the LLVM's build style. That is, it should be safe to use a shared llvmc and a static LLVM.

https://github.com/llvm/llvm-project/pull/141701


More information about the llvm-commits mailing list