CMAKE_MINIMUM_REQUIRED(VERSION 2.6)
-PROJECT(pass C)
+PROJECT(pass)
########################################################
-# Build options:
+# PASS CMakeLists.txt
########################################################
-IF("${ARCH}" STREQUAL "emulator")
- OPTION(USE_EMULATOR "Use Emulator" ON)
-ELSEIF("${ARCH}" STREQUAL "arm")
- OPTION(USE_ARM "Use Arm" ON)
-ENDIF()
-
-IF("${ARCH_BIT}" STREQUAL "32")
- OPTION(USE_32BIT "Use 32bit architecture" ON)
-ELSEIF("${ARCH_BIT}" STREQUAL "64")
- OPTION(USE_64BIT "Use 64bit architecture" ON)
-ENDIF()
-
-########################################################
-# Deviced Macros
-########################################################
-
-MACRO(ADD_SOURCE DIR OUT)
- FILE(GLOB ALL_SRCS "${DIR}/*.c")
- FOREACH(SRC ${ALL_SRCS})
- IF(NOT ${SRC} MATCHES "ivi|mobile|wearable|tv|none")
- SET(D_SRCS ${D_SRCS} ${SRC})
- ENDIF()
- ENDFOREACH()
- FILE(GLOB S_SRCS "${DIR}/*-${PROFILE}.c")
- IF(DEFINED S_SRCS)
- SET(D_SRCS ${D_SRCS} ${S_SRCS})
- ENDIF()
- SET(${OUT} ${D_SRCS})
-ENDMACRO()
-
-MACRO(INSTALL_CONF DIR CONF)
- SET(T_CONF ${DIR}/${CONF}-${PROFILE}.conf)
- SET(E_CONF ${DIR}/${CONF}-emul-${PROFILE}.conf)
- IF(USE_EMULATOR AND EXISTS ${E_CONF})
- SET(T_CONF ${E_CONF})
- ENDIF()
- IF(NOT EXISTS ${T_CONF})
- SET(T_CONF ${DIR}/${CONF}.conf)
- ENDIF()
- IF(DEFINED T_CONF)
- INSTALL(FILES ${CMAKE_CURRENT_SOURCE_DIR}/${T_CONF}
- DESTINATION /etc/deviced
- RENAME ${CONF}.conf)
- ENDIF()
-ENDMACRO()
-
-########################################################
-# Deviced CMakeLists.txt
-########################################################
-SET(PREFIX ${CMAKE_INSTALL_PREFIX})
-SET(EXEC_PREFIX "${PREFIX}/bin")
-SET(INCLUDEDIR "${PREFIX}/include/${PROJECT_NAME}")
-SET(DATADIR "${PREFIX}/share/${PROJECT_NAME}")
-SET(CONFDIR "/etc/${PROJECT_NAME}")
+SET(EXEC_PREFIX "${CMAKE_INSTALL_PREFIX}/bin")
+SET(INCLUDEDIR "${CMAKE_INSTALL_PREFIX}/include/${PROJECT_NAME}")
SET(VERSION 0.1.0)
SET(SRCS
- src/apps/apps.c
- src/control/control.c
- src/core/common.c
- src/core/config-parser.c
- src/core/device-idler.c
- src/core/device-notifier.c
- src/core/devices.c
- src/core/edbus-handler.c
- src/core/execute.c
- src/core/launch.c
- src/core/log.c
- src/core/main.c
- src/core/sig-handler.c
- src/core/udev.c
- src/proc/cpu-info.c
- src/proc/proc-handler.c
- src/time/time-handler.c
+ src/pass/pass.c
+ src/pass/pass-cpuhp.c
+ src/pass/pass-cpuhp-radiation.c
+ src/pass/pass-cpuhp-step.c
+ src/pass/pass-parser.c
+ src/pass/pass-hal.c
+ src/pass/pass-rescon.c
+ src/pass/pass-resmon.c
+ src/pass/pass-resmon-source.c
+ src/pass/pass-pmqos.c
+ src/pass/pass-thermal.c
+ src/pmqos/pmqos.c
+ src/pmqos/pmqos-parser.c
+ src/thermal/thermal.c
+ src/thermal/thermal-parser.c
+ src/util/common.c
+ src/util/device-notifier.c
+ src/util/devices.c
+ src/util/resource.c
+ src/util/gdbus-util.c
+ src/util/timer.c
+ src/util/thread.c
+ src/util/queue.c
+ src/util/kernel.c
+ src/main.c
+ #Generated by a custom command 'gdbus-codegen' below
+ src/pass/pass-dbus-stub.c
+ #Generated by a custom command 'gdbus-codegen' below
+ src/pmqos/pmqos-dbus-stub.c
+ #Generated by a custom command 'gdbus-codegen' below
+ src/thermal/thermal-dbus-stub.c
+ src/resource/resource-cpu.c
+ src/resource/resource-bus.c
+ src/resource/resource-gpu.c
+ src/resource/resource-memory.c
+ src/resource/resource-display.c
+ src/resource/resource-system.c
+ src/resource/resource-battery.c
+ src/resource/resource-process.c
+ src/resource/resource-process-group.c
+ src/resource/resource-disk.c
+ src/resource/resource-network.c
+ src/monitor/monitor.c
+ src/monitor/monitor-thread.c
+ src/monitor/monitor-command.c
+ src/monitor/request-handler.c
+ #Generated by a custom command 'gdbus-codegen' below
+ src/monitor/monitor-dbus-stub.c
)
-IF(BATTERY_MODULE STREQUAL on)
- ADD_SOURCE(src/battery BATTERY_SRCS)
- SET(SRCS ${SRCS} ${BATTERY_SRCS})
-ENDIF()
-
-IF(BLOCK_MODULE STREQUAL on)
- ADD_SOURCE(src/block BLOCK_SRCS)
- SET(SRCS ${SRCS} ${BLOCK_SRCS})
- IF(BLOCK_TMPFS STREQUAL on)
- ADD_DEFINITIONS("-DBLOCK_TMPFS")
- ENDIF(BLOCK_TMPFS STREQUAL on)
-ENDIF()
-
-IF(EXTCON_MODULE STREQUAL on)
- ADD_SOURCE(src/extcon EXTCON_SRCS)
- SET(SRCS ${SRCS} ${EXTCON_SRCS})
-ENDIF()
-
-IF(LED_MODULE STREQUAL on)
- ADD_SOURCE(src/led LED_SRCS)
- SET(SRCS ${SRCS} ${LED_SRCS})
-ENDIF()
-
-IF(TOUCHSCREEN_MODULE STREQUAL on)
- ADD_SOURCE(src/touchscreen TOUCHSCREEN_SRCS)
- SET(SRCS ${SRCS} ${TOUCHSCREEN_SRCS})
-ENDIF()
-
-IF(TZIP_MODULE STREQUAL on)
- ADD_SOURCE(src/tzip TZIP_SRCS)
- SET(SRCS ${SRCS} ${TZIP_SRCS})
-ENDIF()
-
-IF(POWER_MODULE STREQUAL on)
- ADD_SOURCE(src/power POWER_SRCS)
- SET(SRCS ${SRCS} ${POWER_SRCS})
-ENDIF()
-
-IF(DISPLAY_MODULE STREQUAL on)
- ADD_SOURCE(src/display DISPLAY_SRCS)
- SET(SRCS ${SRCS} ${DISPLAY_SRCS})
-
- IF("${DPMS}" STREQUAL "x")
- SET(SRCS ${SRCS} src/display/dpms-x-none.c)
- ELSEIF("${DPMS}" STREQUAL "wayland")
- SET(SRCS ${SRCS} src/display/dpms-wayland-none.c)
- ENDIF()
-ENDIF()
-
-# usb client
-IF(${USB_MODULE} STREQUAL on)
- ADD_SOURCE(src/usb USB_SRCS)
- SET(SRCS ${SRCS} ${USB_SRCS})
-ENDIF()
-
-# usb host
-IF(${USBHOST_MODULE} STREQUAL on)
- ADD_SOURCE(src/usbhost USBHOST_SRCS)
- SET(SRCS ${SRCS} ${USBHOST_SRCS})
-ENDIF()
-
-IF(IR_MODULE STREQUAL on)
- ADD_SOURCE(src/ir IR_SRCS)
- SET(SRCS ${SRCS} ${IR_SRCS})
-ENDIF()
-
-IF(TIZEN_FEATURE_USBHOST_TEST STREQUAL on)
- ADD_SOURCE(src/usb-host-test USB_HOST_TEST_SRCS)
- SET(SRCS ${SRCS} ${USB_HOST_TEST_SRCS})
- INSTALL(FILES ${CMAKE_CURRENT_SOURCE_DIR}/src/usb-host-test/test_gadget.gs
- DESTINATION /etc/deviced/usb-host-test/)
-ENDIF()
-
INCLUDE_DIRECTORIES(${CMAKE_CURRENT_SOURCE_DIR})
INCLUDE_DIRECTORIES(${CMAKE_CURRENT_SOURCE_DIR}/src)
-INCLUDE_DIRECTORIES(${CMAKE_CURRENT_SOURCE_DIR}/src/deviced)
+INCLUDE_DIRECTORIES(${CMAKE_CURRENT_SOURCE_DIR}/include)
+INCLUDE_DIRECTORIES(${CMAKE_CURRENT_SOURCE_DIR}/lib)
SET(PKG_MODULES
- ecore
- edbus
- vconf
dlog
- libudev
- device-node
- capi-base-common
glib-2.0
dbus-1
gio-2.0
- eventsystem
- libtzplatform-config
- hwcommon
- mount
+ gio-unix-2.0
+ libudev
+ libsystemd
+ libnl-3.0
+ libnl-genl-3.0
+ json-c
+ hal-api-power
)
-IF(DISPLAY_MODULE STREQUAL on)
- IF("${DPMS}" STREQUAL "x")
- SET(PKG_MODULES ${PKG_MODULES} x11 xext)
- ENDIF()
- SET(PKG_MODULES ${PKG_MODULES} libinput capi-system-sensor)
-ENDIF()
-IF(BLOCK_MODULE STREQUAL on)
- SET(PKG_MODULES ${PKG_MODULES} storage app2sd capi-system-info)
-ENDIF()
-IF(TZIP_MODULE STREQUAL on)
- SET(PKG_MODULES ${PKG_MODULES} minizip fuse)
-ENDIF()
-IF(TIZEN_FEATURE_USBHOST_TEST STREQUAL on)
- SET(PKG_MODULES ${PKG_MODULES} libkmod libusbg)
-ENDIF()
-
INCLUDE(FindPkgConfig)
pkg_check_modules(pkgs REQUIRED ${PKG_MODULES})
SET(EXTRA_CFLAGS "${EXTRA_CFLAGS} -g -fno-omit-frame-pointer -finstrument-functions")
SET(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} ${EXTRA_CFLAGS} -lrt")
SET(CMAKE_EXE_LINKER_FLAGS "-pie")
+SET(LIBDIR ${CMAKE_LIBDIR_PREFIX})
+ADD_DEFINITIONS("-DLOG_TAG=\"PASS\"")
ADD_DEFINITIONS("-DPREFIX=\"${CMAKE_INSTALL_PREFIX}\"")
ADD_DEFINITIONS("-DFACTORYFS=\"$ENV{FACTORYFS}\"")
-ADD_DEFINITIONS("-DLIBPATH=\"${LIB_INSTALL_DIR}\"")
-ADD_DEFINITIONS("-DENABLE_DEVICED_DLOG")
-ADD_DEFINITIONS("-DENABLE_LIBDEVICED_DLOG")
-ADD_DEFINITIONS("-DENABLE_PM_LOG")
-IF(ENGINEER_MODE STREQUAL on)
-ADD_DEFINITIONS("-DENGINEER_MODE")
-ENDIF(ENGINEER_MODE STREQUAL on)
-IF(PROFILE STREQUAL tv)
- ADD_DEFINITIONS("-DPROFILE_TV")
-ENDIF()
-IF(USE_ARM)
- ADD_DEFINITIONS("-DTARGET")
-ELSEIF(USE_EMULATOR)
- ADD_DEFINITIONS("-DEMULATOR")
-ENDIF()
-IF(USE_32BIT)
- ADD_DEFINITIONS("-DARCH_32BIT")
-ELSEIF(USE_64BIT)
- ADD_DEFINITIONS("-DARCH_64BIT")
-ENDIF()
-ADD_DEFINITIONS("-DDEBUG")
-IF(TIZEN_FEATURE_BLOCK_SET_PERMISSION STREQUAL on)
- ADD_DEFINITIONS("-DTIZEN_FEATURE_BLOCK_SET_PERMISSION")
-ENDIF(TIZEN_FEATURE_BLOCK_SET_PERMISSION STREQUAL on)
+ADD_DEFINITIONS("-DLIBPATH=\"${LIBDIR}\"")
+
+ADD_CUSTOM_COMMAND(
+ OUTPUT src/pass/pass-dbus-stub.c
+ COMMAND gdbus-codegen --interface-prefix org.tizen.
+ --generate-c-code pass-dbus-stub
+ --output-directory src/pass/
+ scripts/pass-dbus.xml
+ COMMENT "Generating GDBus stub for core interface")
+ADD_CUSTOM_COMMAND(
+ OUTPUT src/pmqos/pmqos-dbus-stub.c
+ COMMAND gdbus-codegen --interface-prefix org.tizen.
+ --generate-c-code pmqos-dbus-stub
+ --output-directory src/pmqos/
+ scripts/pmqos-dbus.xml
+ COMMENT "Generating GDBus stub for pmqos interface")
+ADD_CUSTOM_COMMAND(
+ OUTPUT src/thermal/thermal-dbus-stub.c
+ COMMAND gdbus-codegen --interface-prefix org.tizen.
+ --generate-c-code thermal-dbus-stub
+ --output-directory src/thermal/
+ scripts/thermal-dbus.xml
+ COMMENT "Generating GDBus stub for thermal interface")
+ADD_CUSTOM_COMMAND(
+ OUTPUT src/monitor/monitor-dbus-stub.c
+ COMMAND gdbus-codegen --interface-prefix org.tizen.
+ --generate-c-code monitor-dbus-stub
+ --output-directory src/monitor/
+ scripts/monitor-dbus.xml
+ COMMENT "Generating GDBus stub for monitor interface")
ADD_EXECUTABLE(${PROJECT_NAME} ${SRCS})
-TARGET_LINK_LIBRARIES(${PROJECT_NAME} ${pkgs_LDFLAGS} "-ldl" "-lm" shared)
+TARGET_LINK_LIBRARIES(${PROJECT_NAME} ${pkgs_LDFLAGS} -ldl -lm)
INSTALL(TARGETS ${PROJECT_NAME} DESTINATION bin)
-
-INSTALL(DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR}/src/deviced/ DESTINATION include/${PROJECT_NAME}
- FILES_MATCHING
- PATTERN "*_doc.h" EXCLUDE
- PATTERN "*.h")
-
-IF(BATTERY_MODULE STREQUAL on)
- INSTALL_CONF(src/battery battery)
-ENDIF()
-IF(BLOCK_MODULE STREQUAL on)
- INSTALL_CONF(src/block block)
- INSTALL_CONF(src/block storage)
- IF(TIZEN_FEATURE_BLOCK_SET_PERMISSION STREQUAL on)
- INSTALL(PROGRAMS ${CMAKE_CURRENT_SOURCE_DIR}/scripts/mmc-smack-label DESTINATION bin)
- ENDIF(TIZEN_FEATURE_BLOCK_SET_PERMISSION STREQUAL on)
-ENDIF()
-
-IF(DISPLAY_MODULE STREQUAL on)
- INSTALL_CONF(src/display display)
-ENDIF()
-
-# USB connection
-IF(${USB_MODULE} STREQUAL on)
- INSTALL_CONF(src/usb usb-operation)
-
- # USB (Manual setting)
- INSTALL(PROGRAMS ${CMAKE_CURRENT_SOURCE_DIR}/scripts/direct_set_debug.sh DESTINATION bin)
- IF(${SDB_PRESTART} STREQUAL on)
- INSTALL(FILES ${CMAKE_CURRENT_SOURCE_DIR}/systemd/sdb-prestart.service DESTINATION lib/systemd/system)
- ENDIF(${SDB_PRESTART} STREQUAL on)
-ENDIF()
-
INSTALL(FILES ${CMAKE_CURRENT_SOURCE_DIR}/scripts/${PROJECT_NAME}.conf DESTINATION /etc/dbus-1/system.d)
+INSTALL(FILES ${CMAKE_CURRENT_SOURCE_DIR}/scripts/pass-pmqos.json DESTINATION /etc/pass)
+INSTALL(FILES ${CMAKE_CURRENT_SOURCE_DIR}/scripts/pass-thermal.json DESTINATION /etc/pass)
+CONFIGURE_FILE(${CMAKE_SOURCE_DIR}/systemd/${PROJECT_NAME}.service.in ${CMAKE_SOURCE_DIR}/systemd/${PROJECT_NAME}.service @ONLY)
+CONFIGURE_FILE(${CMAKE_SOURCE_DIR}/systemd/${PROJECT_NAME}-resource-monitor.socket.in ${CMAKE_SOURCE_DIR}/systemd/${PROJECT_NAME}-resource-monitor.socket @ONLY)
+INSTALL(FILES ${CMAKE_SOURCE_DIR}/systemd/org.tizen.system.pass.service DESTINATION /usr/share/dbus-1/system-services)
+INSTALL(FILES ${CMAKE_SOURCE_DIR}/systemd/org.tizen.system.thermal.service DESTINATION /usr/share/dbus-1/system-services)
-CONFIGURE_FILE(${PROJECT_NAME}.pc.in ${PROJECT_NAME}.pc @ONLY)
-INSTALL(FILES ${CMAKE_CURRENT_BINARY_DIR}/${PROJECT_NAME}.pc DESTINATION ${LIB_INSTALL_DIR}/pkgconfig)
+INSTALL(DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR}/systemd/ DESTINATION lib/systemd/system
+ FILES_MATCHING
+ PATTERN "${PROJECT_NAME}.service"
+ )
INSTALL(DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR}/systemd/ DESTINATION lib/systemd/system
FILES_MATCHING
- PATTERN "*.service"
- PATTERN "*.socket"
- PATTERN "sdb-prestart.service" EXCLUDE
- PATTERN "deviced-vibrator.service" EXCLUDE
- PATTERN "usb-host*" EXCLUDE)
+ PATTERN "${PROJECT_NAME}-resource-monitor.socket"
+ )
+
+ADD_SUBDIRECTORY(tests/integration-test)
+ADD_SUBDIRECTORY(tests/haltest)
+ADD_SUBDIRECTORY(tests/unittest)
-IF(TIZEN_FEATURE_USBHOST_TEST STREQUAL on)
- INSTALL(FILES ${CMAKE_CURRENT_SOURCE_DIR}/systemd/usb-host-ffs-test-daemon.service
- DESTINATION lib/systemd/system)
- INSTALL(FILES ${CMAKE_CURRENT_SOURCE_DIR}/systemd/usb-host-test.socket
- DESTINATION lib/systemd/system)
-ENDIF()
+ADD_SUBDIRECTORY(lib)
-ADD_SUBDIRECTORY(src/shared)
-ADD_SUBDIRECTORY(src/libdeviced)
-ADD_SUBDIRECTORY(src/devicectl)
-IF(HAPTIC_MODULE STREQUAL on)
- ADD_SUBDIRECTORY(src/haptic)
-ENDIF()
-IF(TIZEN_FEATURE_USBHOST_TEST STREQUAL on)
- ADD_SUBDIRECTORY(src/usb-host-ffs-test-daemon)
-ENDIF()
+ADD_SUBDIRECTORY(tools/resource-monitor)