[LEDE-DEV] [PATCH ubus] cmake: Fix find_library for ubusd and examples/server
John Crispin
john at phrozen.org
Fri Jul 1 22:16:06 PDT 2016
Hi Florian,
i merged most of these, waiting for repo access for the remaining 3 patches
John
On 01/07/2016 23:57, Florian Fainelli wrote:
> Both ubusd and cli TARGET_LINK_LIBRARIES reference ${json} which is
> obtained via find_library(), but since the find_library() is searched
> after the TARGET_LINK_LIBRARIES for ubusd, ubusd always gets an empty
> ${json} variable.
>
> examples/server also links against libjson-c, but we were not setting
> TARGET_LINK_LIBRARIES accordingly, so do that too with ${json} appended.
>
> This was causing linking errors for ubusd and then examples/server using
> an external toolchain (stbgcc-4.8-1.x).
>
> Fixes: 9f52d1769b762 ("cli: use the new json-c library name")
> Signed-off-by: Florian Fainelli <f.fainelli at gmail.com>
> ---
> CMakeLists.txt | 3 ++-
> examples/CMakeLists.txt | 2 +-
> 2 files changed, 3 insertions(+), 2 deletions(-)
>
> diff --git a/CMakeLists.txt b/CMakeLists.txt
> index 70a0de6536d9..7123096a0f93 100644
> --- a/CMakeLists.txt
> +++ b/CMakeLists.txt
> @@ -32,10 +32,11 @@ INCLUDE_DIRECTORIES(${ubox_include_dir})
> ADD_LIBRARY(ubus SHARED libubus.c libubus-io.c libubus-obj.c libubus-sub.c libubus-req.c libubus-acl.c)
> TARGET_LINK_LIBRARIES(ubus ${ubox_library})
>
> +find_library(json NAMES json-c json)
> +
> ADD_EXECUTABLE(ubusd ubusd.c ubusd_id.c ubusd_obj.c ubusd_proto.c ubusd_event.c ubusd_acl.c ubusd_monitor.c)
> TARGET_LINK_LIBRARIES(ubusd ${ubox_library} ${blob_library} ${json})
>
> -find_library(json NAMES json-c json)
> ADD_EXECUTABLE(cli cli.c)
> SET_TARGET_PROPERTIES(cli PROPERTIES OUTPUT_NAME ubus)
> TARGET_LINK_LIBRARIES(cli ubus ${ubox_library} ${blob_library} ${json})
> diff --git a/examples/CMakeLists.txt b/examples/CMakeLists.txt
> index 006dac42a27c..81f999752950 100644
> --- a/examples/CMakeLists.txt
> +++ b/examples/CMakeLists.txt
> @@ -5,7 +5,7 @@ INCLUDE_DIRECTORIES(${CMAKE_CURRENT_SOURCE_DIR}/..)
>
> IF (BUILD_EXAMPLES)
> ADD_EXECUTABLE(server server.c count.c)
> - TARGET_LINK_LIBRARIES(server ubus ${ubox_library} ${blob_library})
> + TARGET_LINK_LIBRARIES(server ubus ${ubox_library} ${blob_library} ${json})
>
> ADD_EXECUTABLE(client client.c count.c)
> TARGET_LINK_LIBRARIES(client ubus ${ubox_library})
>
More information about the Lede-dev
mailing list