platform/core/system/libsyscommon.git
14 months agoresource-manager: Add convenient macro SYSCOMMON_RESOURCE_ID() 44/297044/2
Youngjae Cho [Wed, 9 Aug 2023 08:45:23 +0000 (17:45 +0900)]
resource-manager: Add convenient macro SYSCOMMON_RESOURCE_ID()

 The resource-manage APIs are working on top of the resource_id. Thus
an API user must get resource_id in advance to access resource instance.
Currently resource-manager provides syscommon_resman_get_resource_id()
for this purpose, however, it gets resource_id via parameter. Therefore,
it cannot pass resource_id directly to a function parameter.
 On the other hand, the convenient macro returns resource_id on success,
-1 on failure. As it returns reosurce_id, it can be used as an inline
parameter.

Change-Id: I45426096144c2a47de2554cbf2856b9f78d5b51d
Signed-off-by: Youngjae Cho <y0.cho@samsung.com>
14 months agoplugin-api: deviced: Include necessary header 43/297043/1
Youngjae Cho [Wed, 9 Aug 2023 07:39:33 +0000 (16:39 +0900)]
plugin-api: deviced: Include necessary header

Currently, the syscommon-plugin-deviced-display.h has nothing though,
those headers will be necessary for the display plugin-api. Therefore
added them in advance.

Change-Id: I5a0e20e627ca5845a52e1a47b9dc474f8759600d
Signed-off-by: Youngjae Cho <y0.cho@samsung.com>
14 months agoresource-manager: Fix checking attribute and control id validation 13/296613/8 accepted/tizen/unified/riscv/20230809.013303
Dongwoo Lee [Wed, 2 Aug 2023 05:53:23 +0000 (14:53 +0900)]
resource-manager: Fix checking attribute and control id validation

In order to prevent misbehavior during code genenration or
optimization for builtin function clzll of gcc due to undefined
operation, this fixes condition for checking attribute and control id
of resources properly.

Change-Id: Icef57b1ec27c54afdaf1ef93c94a069c4d8855be
Signed-off-by: Dongwoo Lee <dwoo08.lee@samsung.com>
14 months agoplugin-api: deviced: Add enum deviced_event 35/296935/2
Youngjae Cho [Mon, 7 Aug 2023 10:34:28 +0000 (19:34 +0900)]
plugin-api: deviced: Add enum deviced_event

 It replaces enum of the deviced, INTERNAL_LOCK_*, and it enumerates events
that the deviced can handle.
 The events are grouped by module name. And each group can have a single
'General' event and several 'Specific' events. General event is named with
module name. Specific event have suffix to the general event, describing
what the event exactly is. For example,
   - DEVICED_EVENT_BATTERY
     : Representative event of battery event. Represents overall events
       of battery and can be used by general battery event.

   - DEVICED_EVENT_BATTERY_CAPACITY_LOW
     : Specific event of battery event. Denotes battery capacity has
       entered into or escaped from low status.

Change-Id: I4bd752c2d5303ff25d7a070a621fe122f7d0f0dc
Signed-off-by: Youngjae Cho <y0.cho@samsung.com>
14 months agoplugin-api: deviced: Add display max brightness attributes 85/296885/1
Youngjae Cho [Fri, 4 Aug 2023 07:28:42 +0000 (16:28 +0900)]
plugin-api: deviced: Add display max brightness attributes

- DEVICED_DISPLAY_ATTR_INT_GET_MAX_BRIGHTNESS
  : Represent the max brightness. Only gettable.

Change-Id: I7b599eec0a1e6a5704b826478e3030f6cf9c2ad6
Signed-off-by: Youngjae Cho <y0.cho@samsung.com>
14 months agoplugin-api: deviced: Add DEVICED_RESOURCE_TYPE_DISPLAY 59/296759/4
Youngjae Cho [Fri, 4 Aug 2023 04:49:50 +0000 (13:49 +0900)]
plugin-api: deviced: Add DEVICED_RESOURCE_TYPE_DISPLAY

Deviced service controls the Display device.
When controlling the Display device of deviced
via resman (resource-manager), DEVICED_RESOURCE_TYPE_DISPLAY will be used
to control the Display attribute.

Change-Id: Iec69c2edf2ec18ef82641bc04ca31e9b2c5aaa47
Signed-off-by: Youngjae Cho <y0.cho@samsung.com>
14 months agoresource-manager: Cleanup uninitialized object correctly 58/296758/3
Youngjae Cho [Fri, 4 Aug 2023 03:08:11 +0000 (12:08 +0900)]
resource-manager: Cleanup uninitialized object correctly

 When create_resource() fails to set interest bit, a resource instance
fails to be initialized completely. At that point of failure, however,
the resource instance already has been registered to the hashtable,
g_resource_hash_table. Therefore, it is necessary to remove it from the
hashtable.

Change-Id: I26d392f6645ef9871a10de91117f69226f753638
Signed-off-by: Youngjae Cho <y0.cho@samsung.com>
15 months agoresource-manager: Add N-tuple setter to pass multiple parameter 28/296628/6 accepted/tizen/unified/20230803.174812 accepted/tizen/unified/20230809.071927
Chanwoo Choi [Wed, 2 Aug 2023 08:26:17 +0000 (17:26 +0900)]
resource-manager: Add N-tuple setter to pass multiple parameter

Add N-tuple setter function of resource manager to support the case
of when some attribute requires the multi paramters as setter.

[Newly added setter of resource-manager]
- int syscommon_resman_set_resource_attr_uint64_2(
int resource_id, u_int64_t attr_id,
u_int64_t data1, u_int64_t data2)
 : It pass the two parameter to the specific attribute which requires
   the two parameter as setter.

- int syscommon_resman_set_resource_attr_uint64_3(
int resource_id, u_int64_t attr_id,
u_int64_t data1, u_int64_t data2, u_int64_t data3)
 : It pass the three parameter to the specific attribute which requires
   the three parameter as setter.

- int syscommon_resman_set_resource_attr_uint64_4(
int resource_id, u_int64_t attr_id,
u_int64_t data1, u_int64_t data2, u_int64_t data3, u_int64_t data4)
 : It pass the four parameter to the specific attribute which requires
   the four parameter as setter.

[Newly added data type of resource manager]
- SYSCOMMON_RESMAN_DATA_TYPE_UINT64_UINT64
 : This data type include the two of u_int64 data type
- SYSCOMMON_RESMAN_DATA_TYPE_UINT64_UINT64_UINT64
 : This data type include the three of u_int64 data type
- SYSCOMMON_RESMAN_DATA_TYPE_UINT64_UINT64_UINT64_UINT64
 : This data type include the four of u_int64 data type

Change-Id: I8c659e5a9f5447e7aecb17c71005e5fa939960e8
Signed-off-by: Chanwoo Choi <cw00.choi@samsung.com>
Signed-off-by: Youngjae Cho <y0.cho@samsung.com>
15 months agoresource-manager: Fix bug of set_resource_attr_value_data() 21/296621/3
Youngjae Cho [Wed, 2 Aug 2023 07:57:51 +0000 (16:57 +0900)]
resource-manager: Fix bug of set_resource_attr_value_data()

It must check existence of setter instead of getter.

Change-Id: I1e34647390257ba1ac0c580b35bf1934eeb10d18
Signed-off-by: Youngjae Cho <y0.cho@samsung.com>
15 months agoresource-manager: Fix BIT() to SYSCOMMON_BIT() 00/296600/5
Youngjae Cho [Tue, 1 Aug 2023 08:56:28 +0000 (17:56 +0900)]
resource-manager: Fix BIT() to SYSCOMMON_BIT()

The BIT() is too general so that it is possible to collide with other
header when it is imported. Therefore, added prefix for the macro.

Change-Id: Idc999d6c09364bfc9fbc0dc93fb63c1d5eeea995
Signed-off-by: Youngjae Cho <y0.cho@samsung.com>
15 months agoresource-manager: Add syscommon_resman_get_resource_id() 99/296599/5
Youngjae Cho [Tue, 1 Aug 2023 05:00:08 +0000 (14:00 +0900)]
resource-manager: Add syscommon_resman_get_resource_id()

 It is necessary that a plugin know about resource_id so that the plugin
invoke resource-manager functions that works on top of resource_id. To
this end, added getter for resource_id.
 - syscommon_resman_get_resource_id()
     The function gets resource_id of the given type. The id is resource
     instance created first.
 - syscommon_resman_get_number_of_instance()
     The function gets how may resource instances have been created
     on a specific resource type.

 To support these operations, the resource-manager internally manages
hashtable dedicated to reosurce_id. The hashtable maps resource_type
into head of resource_id list.

Change-Id: I9d0df9a098444af506a94a81d14fae0f20bc1e04
Signed-off-by: Youngjae Cho <y0.cho@samsung.com>
15 months agoplugin-api: deviced: Add skeleton header for power module 28/296528/7
Youngjae Cho [Mon, 31 Jul 2023 07:17:45 +0000 (16:17 +0900)]
plugin-api: deviced: Add skeleton header for power module

syscommon-plugin-deviced-common-interface.h
 - Define common types and macros that can be commonly utilized over
   the whole modules, by both core and plugin.
 - Added enum deviced_resource_type so that all modules can share the
   enum. This is because the enum must be unique for each module.

syscommon-plugin-deviced-power.h
 - Contain plugin-api functions that invoking plugin functions
   from the deviced core.

syscommon-plugin-deviced-power-interface.h
 - Contain types and macros that can be utilized by both core and
   plugin.

Change-Id: Iab8bc083a3610b720222df284f880d961fb75188
Signed-off-by: Youngjae Cho <y0.cho@samsung.com>
15 months agoplugin-api: resourced: Pass oom level to LMK governor post for fg app 33/296333/7
Unsung Lee [Tue, 25 Jul 2023 11:21:34 +0000 (20:21 +0900)]
plugin-api: resourced: Pass oom level to LMK governor post for fg app

LMK governor post function reordering foreground app candidates
requires oom level, so pass oom level to this post function.

Change-Id: I77b24eb298506698fdef73d8136990734eb0ef24
Signed-off-by: Unsung Lee <unsung.lee@samsung.com>
15 months agoplugin-api: resourced: Add enum syscommon_resourced_memory_lmk_oom_level 32/296332/5
Unsung Lee [Tue, 25 Jul 2023 10:09:00 +0000 (19:09 +0900)]
plugin-api: resourced: Add enum syscommon_resourced_memory_lmk_oom_level

Add enumeration of oom level into libsyscommon to reference it
from both resourced and resourced plugin-backend

Oom level will be referenced by resourced and resourced backend
when LMK is triggered by low memory. Therefore, it should be located in
common library (i.e., libsyscommon)

Change-Id: I2dcc1c7e3768dccf5db256845614557b6d8dc60c
Signed-off-by: Unsung Lee <unsung.lee@samsung.com>
15 months agoplugin-api: resourced: Add a skeleton of get_kill_candidates_post funcs 95/294695/14
Unsung Lee [Thu, 22 Jun 2023 02:43:05 +0000 (11:43 +0900)]
plugin-api: resourced: Add a skeleton of get_kill_candidates_post funcs

Add a skeleton of three get_kill_candidates_post funcs. These functions
are directly mapped to get_kill_candidates_post funcs in resourced backend.

Support LMK governor post funcs which will be called after
LMK governor function to reorder a victim candidate list

resourced supports three type of get_kill_candidates_post ops newly
  - int syscommon_plugin_resourced_memory_lmk_get_kill_candidates_post(
  GArray *candidates)
    to consider user custom governor policy
  - int syscommon_plugin_resourced_memory_lmk_get_kill_candidates_post_with_wss(
  GArray *candidates)
    to consider working set size of app
  - int syscommon_plugin_resourced_memory_lmk_get_kill_candidates_post_with_foreground(
  GArray *candidates)
    to consider window information of app

Change-Id: I2a3c42635ce105f4400a68c8c382fb6548a11f8e
Signed-off-by: Unsung Lee <unsung.lee@samsung.com>
15 months agoplugin-api: resourced: Add window info into 'task_info' for LMK governor 94/294694/9
Unsung Lee [Thu, 22 Jun 2023 10:23:32 +0000 (19:23 +0900)]
plugin-api: resourced: Add window info into 'task_info' for LMK governor

Add window information list in 'task_info'.
Each window includes information such as visibility, focusing status,
and coordinate for LMK governor

resourced low memory killer (LMK) passes app information to LMK governor
during LMK process. Sometimes, LMK governor needs to know window information of
foreground app to prioritize which apps to be killed. This is because
foreground app(s) are visible status. If visible app(s) are killed by
LMK suddenly, then it embarrass the user.

Change-Id: I6b7b4ae00ca95534e7d99ec8b412909038d2fdc6
Signed-off-by: Unsung Lee <unsung.lee@samsung.com>
15 months agoplugin-api: deviced: Add syscommon_plugin_deviced_battery_is_possible_to_notify_batte... 08/296408/5 accepted/tizen/unified/20230731.175325
Yunhee Seo [Wed, 26 Jul 2023 11:00:04 +0000 (20:00 +0900)]
plugin-api: deviced: Add syscommon_plugin_deviced_battery_is_possible_to_notify_battery_full()

To use deviced plugin battery module, plugin backend battery module getter/setter are added.
And, new plugin module definition "SYSCOMMON_PLUGIN_MODULE_DEVICED_BATTERY" is added.
Also, to utilize plugin backend battery module function,
new battery interface header and source file was created.

To use plugin backend module, these are newly added.
- int syscommon_plugin_deviced_battery_get_backend(void);
- int syscommon_plugin_deviced_battery_put_backend(void);
- int syscommon_plugin_deviced_battery_is_possible_to_notify_battery_full(bool *possible_notify);
    -> This is used to determine whether to inform the fully charged or not.

* libsyscommon.spec typo was also corrected.

Change-Id: I30a76504cd27ab44000459080fb7cd0f72f42c92
Signed-off-by: Yunhee Seo <yuni.seo@samsung.com>
15 months agoplugin-api: common: Add SYSCOMMON_PLUGIN_ABI_VERSION_TIZEN_8_0 25/296425/2
Yunhee Seo [Thu, 27 Jul 2023 07:43:24 +0000 (16:43 +0900)]
plugin-api: common: Add SYSCOMMON_PLUGIN_ABI_VERSION_TIZEN_8_0

As tizen 7.5 is replaced with 8.0, this definition should be added.

Change-Id: Ifa6a0a2107ff700672f26f68839c3ef9c08314f9
Signed-off-by: Yunhee Seo <yuni.seo@samsung.com>
15 months agolibcommon: Add syscommon_mkdir() 70/296370/5
Youngjae Cho [Wed, 26 Jul 2023 07:34:36 +0000 (16:34 +0900)]
libcommon: Add syscommon_mkdir()

 It makes directory of the given path, including the whole intermediate
path if not exists. That is, it is equivalent to command 'mkdir -p'.
 It has come from the deviced as the function is eligible to being a
common function to be utilized by overall system libs/daemons.

Change-Id: Ifbf23c3fe721a149c54d6f650cce093dfb6f9e10
Signed-off-by: Youngjae Cho <y0.cho@samsung.com>
15 months agolibcommon: Add syscommon_file_copy() 55/296355/4
Youngjae Cho [Wed, 26 Jul 2023 05:34:11 +0000 (14:34 +0900)]
libcommon: Add syscommon_file_copy()

Change-Id: I00608e8a28b61026e19c1e73d4e0ed063c50379f
Signed-off-by: Youngjae Cho <y0.cho@samsung.com>
15 months agolibcommon: Introduce notifier 59/296359/2
Youngjae Cho [Tue, 25 Jul 2023 11:21:10 +0000 (20:21 +0900)]
libcommon: Introduce notifier

 The libsyscommon notifer provides mean that communicate between
different modules. And it works based on publish-subscribe pattern.

 If someone wants to listen to an event, it subscribes to notify id
that is defined by event publisher, using subscribe function such as
 - syscommon_notifier_subscribe_notify_priority()
 - syscommon_notifier_subscribe_notify()
 - syscommon_notifier_subscribe_notify_udata_priority()
 - syscommon_notifier_subscribe_notify_udata()
Obviously, it is possible to unsubscribe notify via
 - syscommon_notifier_unsubscribe_notify()
 - syscommon_notifier_unsubscribe_notify_udata()

 If someone want publish a notify, it can be done by the functions
such as
 - syscommon_notifier_emit_notify()
 - syscommon_notifier_emit_notify_once()
See below for a detailed description about libsyscommon notifier.

 int syscommon_notifier_subscribe_notify_priority()
  - Subscribe notify without user_data callback.
  - Higher number of priority will be notified first.

 int syscommon_notifier_subscribe_notify()
  - Subscribe notify without user_data callback
  - Automatically assign default priority of 0.

 int syscommon_notifier_unsubscribe_notify()
  - Unsubscribe notify callback without user_data.

 int syscommon_notifier_subscribe_notify_udata_priority()
  - Subscribe notify with user_data callback.
  - Provide destroy callback to free user_data on unsubscribing.
  - Higher number of priority will be notified first.
  - Return notify id and can be used for unsubscribing.

 int syscommon_notifier_unsubscribe_notify_udata()
  - Subscribe notify with user_data callback
  - Provide destroy callback to free user_data on unsubscribing
  - Automatically assign default priority of 0.
  - Return notify id and can be used for unsubscribing.

 int syscommon_notifier_subscribe_notify_udata()
  - Unsubscribe notify callback with user_data.
  - Invoke destroy function with user_data.

 void syscommon_notifier_emit_notify()
  - Emit notify.

 void syscommon_notifier_emit_notify_once()
  - Emit notify only once.
  - Notification after the first one is ignored.

Change-Id: I1853f5a51e999c1f20b34c9281becb9cfbdb8a8b
Signed-off-by: Youngjae Cho <y0.cho@samsung.com>
Change-Id: Iff113c8869e27a90f11156181b500d25893387a8

15 months agolibcommon: Add syscommon_is_mounted() 64/296264/2 accepted/tizen/unified/20230726.163532
Youngjae Cho [Mon, 24 Jul 2023 11:46:52 +0000 (20:46 +0900)]
libcommon: Add syscommon_is_mounted()

syscmmon_is_mounted() checks whether the given path exists in /etc/mtab.

Change-Id: I994c4190a069330403e5eb516eb6fef7f5d5404f
Signed-off-by: Youngjae Cho <y0.cho@samsung.com>
15 months agoReplace prefix 'libsys' with 'syscommon' 63/296263/1
Youngjae Cho [Mon, 24 Jul 2023 11:25:11 +0000 (20:25 +0900)]
Replace prefix 'libsys' with 'syscommon'

Change-Id: Ibe92ea978eb95b6a2f470dae7195b2840dd7c2d5
Signed-off-by: Youngjae Cho <y0.cho@samsung.com>
15 months agoproc: Add proc operation 90/295990/4
Youngjae Cho [Mon, 17 Jul 2023 06:18:40 +0000 (15:18 +0900)]
proc: Add proc operation

These have come from the deviced.
 - int syscommon_proc_get_comm(pid_t pid, char *buf, int len);
 - int syscommon_proc_get_cmdline(pid_t pid, char *buf, int len);
 - int syscommon_proc_get_attr_current(pid_t pid, char *buf, int len);
 - int syscommon_proc_is_app(pid_t pid);

Change-Id: I89b668ed045db9c666e1921bceaf8a70c112af78
Signed-off-by: Youngjae Cho <y0.cho@samsung.com>
15 months agoAdd include directory to collect header file 90/295890/1 accepted/tizen/unified/20230718.162146 accepted/tizen/unified/dev/20230726.120020 accepted/tizen/unified/riscv/20230718.003634
Youngjae Cho [Mon, 17 Jul 2023 02:13:49 +0000 (11:13 +0900)]
Add include directory to collect header file

It is collected and installed automatically just by creating header
file in include directory.

Change-Id: Ia411edd7101afbb49097229986965eff5b175519
Signed-off-by: Youngjae Cho <y0.cho@samsung.com>
15 months agolibcommon: Add missing source/header for CMake 87/295887/1
Youngjae Cho [Mon, 17 Jul 2023 01:22:12 +0000 (10:22 +0900)]
libcommon: Add missing source/header for CMake

Change-Id: Ifc3d782a610cd6dfddcdc66037ea680ca9aca8da
Signed-off-by: Youngjae Cho <y0.cho@samsung.com>
15 months agoAdd functions that use a private connection. 11/295611/2
Mateusz Moscicki [Mon, 10 Jul 2023 14:34:25 +0000 (16:34 +0200)]
Add functions that use a private connection.

At the moment only the functions that libstorage uses are prepared.
Currently only functoins are added that are called by libstorage during
the dotnet-launcher preparation.

Change-Id: Idd7f145d1fef057cb5ba42039d006b491f5d7166

15 months agolibcommon: Introduce bitmap 94/295694/2
Youngjae Cho [Wed, 12 Jul 2023 10:05:44 +0000 (19:05 +0900)]
libcommon: Introduce bitmap

These have come from the deviced.

Change-Id: I8d5eb95703d32d8fd17054c4446378adb4db97b2
Signed-off-by: Youngjae Cho <y0.cho@samsung.com>
16 months agoRevert "Allow to change the default connection type to private" 11/294911/1 accepted/tizen/unified/20230703.093326
Mateusz Moscicki [Wed, 28 Jun 2023 13:59:03 +0000 (15:59 +0200)]
Revert "Allow to change the default connection type to private"

This reverts commit 81ca03541a0b4c72570b65875ce03c6be86e753b.

Change-Id: I871cf09f17724070d7e4c437d4638e87c33a5eae

16 months agoAllow to change the default connection type to private 17/294517/5 accepted/tizen/unified/20230626.043754
Mateusz Moscicki [Tue, 20 Jun 2023 11:15:22 +0000 (13:15 +0200)]
Allow to change the default connection type to private

This is used to ensure that applications launched by launchpad get their
own connection with the appropriate label, rather than using the
connection that was established before the label change.

Change-Id: Id1a6c80638c762f3de8856410b562df653dd70b5

16 months agoRemove the unnecessary dependencies and fix pc file 41/292341/5 accepted/tizen/unified/20230613.170800
wchang kim [Thu, 4 May 2023 08:35:13 +0000 (17:35 +0900)]
Remove the unnecessary dependencies and fix pc file

If it have to make the dependency with specific packages
at install time of rpm package , 'Requires' keyword should be used.

But, development packages are only used when building the packages
and they are not needed to be included in the image like rootfs.img.

In result, remove the unnecessary dependencies and fix pc file
from platform image.

Change-Id: Ic14f2ab2bbe5134bedd948618c1aeee1e6d2d0fb
Signed-off-by: wchang kim <wchang.kim@samsung.com>
[cw00.choi: Update patch title and add description]
Signed-off-by: Chanwoo Choi <cw00.choi@samsung.com>
16 months agoplugin-api: Fix the name of backend .so files 08/293908/1 accepted/tizen/unified/20230608.164354
SangYoun Kwak [Thu, 8 Jun 2023 02:10:22 +0000 (11:10 +0900)]
plugin-api: Fix the name of backend .so files

The name for plugin backend .so files changed:
    libplugin-resourced-memory-lmk.so
    -> libplugin-backend-resourced-memory-lmk.so
Since there are other packages start with "system-plugin", it is
necessary to show that it is a backend for system-plugin.

Change-Id: I5b11cfc6c1cdf39a3b60758d8bc2c075ac348ce9
Signed-off-by: SangYoun Kwak <sy.kwak@samsung.com>
18 months agoplugin-api: Add manifest to plugin-api packages 56/292156/1 accepted/tizen/unified/20230607.160247
SangYoun Kwak [Fri, 28 Apr 2023 04:55:10 +0000 (13:55 +0900)]
plugin-api: Add manifest to plugin-api packages

Previously, the smack label("_") was added by 'chsmack' command.
By adding '%manifest' in the '%file' section, smack label can be applied
to files without using chsmack in the '%post' section.

Change-Id: Icd91b04e46d0eeb4182454aada7705ff0952c8fb
Signed-off-by: SangYoun Kwak <sy.kwak@samsung.com>
18 months agoplugin-api: Rename 'plugin' to 'syscommon-plugin' 81/292081/3
SangYoun Kwak [Thu, 27 Apr 2023 05:13:39 +0000 (14:13 +0900)]
plugin-api: Rename 'plugin' to 'syscommon-plugin'

Since the plugin-api is the plugin feature which is only used in system
scope and it is located in libsyscommon, plugin was changed to
syscommon-plugin to indicate its usage and location.

Change rule:
 * Basically, plugin becomes syscommon-plugin to indicate it is from
   the libsyscommon repository
 * Symbols which are used internally can omit the prefix 'syscommon'.

Changed:
 * Package name: plugin-api... -> libsyscommon-plugin-api...
 * Package config file name:
      plugin-api-....pc -> libsyscommon-plugin-api....pc
 * .so name: libplugin-api-....so -> libsyscommon-plugin-api....so

Change-Id: Ia56c935ebf97a93cad7efd0235508c540ee0348d
Signed-off-by: SangYoun Kwak <sy.kwak@samsung.com>
19 months agoplugin-api: Fix the prefix for pkg_check_modules of CMakeLists.txt 95/289995/3
SangYoun Kwak [Thu, 16 Mar 2023 11:45:18 +0000 (20:45 +0900)]
plugin-api: Fix the prefix for pkg_check_modules of CMakeLists.txt

The command pkg_check_modules in CMakeLists.txt checks modules and sets
variables about these modules.
The names of these variables have their prefix designated by the command
pkg_check_modules like below:
pkg_check_modules(<prefix> REQUIRED <modules>)

Previously, in plugin-api-common, prefix was "pkgs", which is not a
unique name.
In plugin-api-resourced, prefix was ${PROJECT_NAME} but when calling
variables, "pkgs" was used for prefix, which is not correct usage.
This fault was fixed by replacing their prefix as their ${PROJECT_NAME}.

Change-Id: Ide1db4b707f2c6e9f632c0cc36ab4ec654383887
Signed-off-by: SangYoun Kwak <sy.kwak@samsung.com>
19 months agoplugin-api: deviced: Add plugin-api-deviced 94/289994/3 accepted/tizen/unified/20230320.164216 accepted/tizen/unified/20230321.035424
Youngjae Cho [Fri, 17 Mar 2023 00:57:59 +0000 (09:57 +0900)]
plugin-api: deviced: Add plugin-api-deviced

Initialize plugin-api for deviced. It creates package plugin-api-deviced
and the package contains empty library.

Change-Id: I2a91b9185e4b9f0ffbe61c4d71801d20a15b0df2
Signed-off-by: Youngjae Cho <y0.cho@samsung.com>
19 months agopackaging: Rearrange %package directive 90/289990/3
Youngjae Cho [Fri, 17 Mar 2023 00:40:27 +0000 (09:40 +0900)]
packaging: Rearrange %package directive

As those relocated %packages overwrite the %{version} of libsyscommon,
define %{libsyscommon_version} to maintain its value.

Change-Id: I0049a45fdd343515e09c97a4abf0f8aa6ea9704a
Signed-off-by: Youngjae Cho <y0.cho@samsung.com>
19 months agoresource-manager: cleanup resource instance correctly 47/289947/2 accepted/tizen/unified/20230317.081018
Youngjae Cho [Thu, 16 Mar 2023 04:07:42 +0000 (13:07 +0900)]
resource-manager: cleanup resource instance correctly

On failure during create_resource(), remove resource instance from
hashtable if it has been registered hashtable via add_resource().

Change-Id: I124add4633b06be0e3a2bc2786f1eee8b69acce0
Signed-off-by: Youngjae Cho <y0.cho@samsung.com>
19 months agoRevert "resource-manager: Relocate add_resource() in create_resource()" 46/289946/1
Youngjae Cho [Thu, 16 Mar 2023 03:54:51 +0000 (12:54 +0900)]
Revert "resource-manager: Relocate add_resource() in create_resource()"

This reverts commit 5880b22f3e55b60c7b9326c51012b95f05416145.

The resource instance must be added to hashtable prior to the operation
driver->ops.create(resource->id). As this operation passes resource id,
it is possible that the operation work based on that resource id, which
denotes resource instance and must have been registered to hashtable.
Therefore, add_resource() must be followed by driver->ops.create().

Change-Id: I05b8a9f85741313c14201501fe6bbc4a5b8c7233
Signed-off-by: Youngjae Cho <y0.cho@samsung.com>
19 months agoini-parser: Fix size_t to ssize_t 97/288797/7
TaeminYeom [Thu, 23 Feb 2023 07:51:13 +0000 (16:51 +0900)]
ini-parser: Fix size_t to ssize_t

Variable "n_read" brings the return of getline,
but return type of getline is ssize_t.
Also, fseek's second parameter is long type,
so it is proper to use signed data type.

Change-Id: I87f01a986a9b7fa68d7a675a1e31a0afe0c1f4bf
Signed-off-by: TaeminYeom <taemin.yeom@samsung.com>
19 months agoplugin-api: resourced: Add plugin-api-resourced 78/287978/23 accepted/tizen/unified/20230310.062652
SangYoun Kwak [Wed, 8 Feb 2023 10:59:30 +0000 (19:59 +0900)]
plugin-api: resourced: Add plugin-api-resourced

This plugin api provides functions for resourced.
Provided functions:
 * plugin_resourced_low_memory_killer_get_backend: get backend library
 * plugin_resourced_low_memory_killer_put_backend: put backend library
 * plugin_resourced_low_memory_killer_get_kill_candidates: choose kill
   candidates from procs/apps list.

The files newly created during build due to this patch are as follows:
(arch=armv7l)

plugin-api-resourced-0.1.0-0.armv7l.rpm
 * /usr/lib: libplugin-api-resourced.so.0 -> libplugin-api-resourced.so.0.1.0
 * /usr/lib: libplugin-api-resourced.so.0.1.0
 * /usr/share/licenses/plugin-api/resourced: LICENSE.MIT

plugin-api-resourced-debuginfo-0.1.0-0.armv7l.rpm
 * /usr/lib/debug/usr/lib/libplugin-api-resourced.so.0.1.0.debug

libsyscommon-debugsource-5.0.0-0.armv7l.rpm
 * /usr/src/debug/libsyscommon-5.0.0-0.arm/src/plugin-api/resourced/include: plugin-resourced-memory-lmk-interface.h
 * /usr/src/debug/libsyscommon-5.0.0-0.arm/src/plugin-api/resourced/src: plugin-resourced-memory-lmk.c

plugin-api-resourced-devel-0.1.0-0.armv7l.rpm
 * /usr/include/plugin: plugin-resourced-memory-lmk.h
 * /usr/include/plugin: plugin-resourced-memory-lmk-interface.h
 * /usr/lib: libplugin-api-resourced.so -> libplugin-api-resourced.so.0
 * /usr/lib/pkgconfig: plugin-api-resourced.pc
 * /usr/share/licenses/plugin-api/resourced: LICENSE.MIT

Change-Id: I3f9c2deac1220131df5bb8a3db502b40dc1bdd72
Signed-off-by: SangYoun Kwak <sy.kwak@samsung.com>
19 months agoplugin-api: common: Add plugin-api-common 56/287856/26
SangYoun Kwak [Tue, 7 Feb 2023 06:53:24 +0000 (15:53 +0900)]
plugin-api: common: Add plugin-api-common

plugin-api was added to provide plugin feature.
Plugin separates target-specific code to plugin-backend
from common Tizen codes such as deviced or resourced.
The structure of plugin-api is based on the hal-api.

The files newly created during build due to this patch are as follows:
(arch=armv7l)

plugin-api-common-0.1.0-0.armv7l.rpm
 * /usr/lib/: libplugin-api-common.so.0 -> libplugin-api-common.so.0.1.0
 * /usr/lib/: libplugin-api-common.so.0.1.0
 * /usr/share/licenses/plugin-api-common: LICENSE.MIT

plugin-api-common-debuginfo-0.1.0-0.armv7l
 * /usr/lib/debug/usr/lib: libplugin-api-common.so.0.1.0.debug

libsyscommon-debugsource-5.0.0-0.armv7l.rpm
 * /usr/src/debug/libsyscommon-5.0.0-0.arm/src/plugin-api/common/include: plugin-common.h
 * /usr/src/debug/libsyscommon-5.0.0-0.arm/src/plugin-api/common/include: plugin-common-interface.h
 * /usr/src/debug/libsyscommon-5.0.0-0.arm/src/plugin-api/common/src: plugin-api-list.h
 * /usr/src/debug/libsyscommon-5.0.0-0.arm/src/plugin-api/common/src: plugin-api-conf.c
 * /usr/src/debug/libsyscommon-5.0.0-0.arm/src/plugin-api/common/src: plugin-api-conf.h
 * /usr/src/debug/libsyscommon-5.0.0-0.arm/src/plugin-api/common/src: common.h
 * /usr/src/debug/libsyscommon-5.0.0-0.arm/src/plugin-api/common/src: plugin-api-common.c

plugin-api-common-devel-0.1.0-0.armv7l
 * /usr/include/plugin: plugin-common.h
 * /usr/include/plugin: plugin-common-interface.h
 * /usr/lib/: libplugin-api-common.so -> libplugin-api-common.so.0
 * /usr/lib/pkgconfig/plugin-api-common.pc
 * /usr/share/licenses/plugin-api-common: LICENSE.MIT

Change-Id: I3c0b385d7bd76b82db8db73beb189b78009b8774
Signed-off-by: SangYoun Kwak <sy.kwak@samsung.com>
19 months agoresource-manager: Relocate add_resource() in create_resource() 94/289494/3
Youngjae Cho [Thu, 9 Mar 2023 00:23:06 +0000 (09:23 +0900)]
resource-manager: Relocate add_resource() in create_resource()

If operations following the add_resource() fail, then it is necessary
to cleanup resource instance from hashtable that has been added by
add_resource(). Instead of impelementing cleanup, move add_resource()
to the end of create_resource() so that nothing follow add_resource().

Change-Id: I705a3dc3487c8ebf9e80cff51b7e89069a6a4f1a
Signed-off-by: Youngjae Cho <y0.cho@samsung.com>
19 months agoresource-manager: Introduce attribute setter 82/288382/6
Youngjae Cho [Thu, 16 Feb 2023 04:44:03 +0000 (13:44 +0900)]
resource-manager: Introduce attribute setter

The setter is only allowed for resource type of INSTANCE_TYPE_NORMAL.
- syscommon_resman_set_resource_attr_int()
- syscommon_resman_set_resource_attr_int64()
- syscommon_resman_set_resource_attr_uint()
- syscommon_resman_set_resource_attr_uint64()
- syscommon_resman_set_resource_attr_double()
- syscommon_resman_set_resource_attr_string()
- syscommon_resman_set_resource_attr_array()
- syscommon_resman_set_resource_attr_ptr()

Change-Id: I0e30425c35ec6df9660ef3c57a5ecd6a5769e1dd
Signed-off-by: Youngjae Cho <y0.cho@samsung.com>
19 months agoresource-manager: Add get API for INSTANCE_TYPE_NORMAL 33/288333/15
Youngjae Cho [Wed, 15 Feb 2023 08:37:17 +0000 (17:37 +0900)]
resource-manager: Add get API for INSTANCE_TYPE_NORMAL

Resource instance type of INSTANCE_TYPE_NORMAL fetches its attribute
value by calling attribute_ops.get().
 - syscommon_resman_get_resource_attr_int()
 - syscommon_resman_get_resource_attr_int64()
 - syscommon_resman_get_resource_attr_uint()
 - syscommon_resman_get_resource_attr_uint64()
 - syscommon_resman_get_resource_attr_double()
 - syscommon_resman_get_resource_attr_string()
 - syscommon_resman_get_resource_attr_array()
 - syscommon_resman_get_resource_attr_ptr()

Change-Id: Ib3482ff685b0c3e4783cd8a3ce7dc5e6ab1e9699
Signed-off-by: Youngjae Cho <y0.cho@samsung.com>
19 months agoresource-manager: Make monitor API be exclusive for INSTANCE_TYPE_MONITOR 66/288666/10
Youngjae Cho [Tue, 21 Feb 2023 08:06:22 +0000 (17:06 +0900)]
resource-manager: Make monitor API be exclusive for INSTANCE_TYPE_MONITOR

The APIs for monitor instance has changed to return error when it is
used on instance type other than INSTANCE_TYPE_MONITOR.

Change-Id: Ifa1ce8924e60cb3a08ab467bf6f112421bd0abb7
Signed-off-by: Youngjae Cho <y0.cho@samsung.com>
19 months agoresource-manager: Reimplement attribute_ops 64/288664/11
Youngjae Cho [Tue, 21 Feb 2023 03:10:00 +0000 (12:10 +0900)]
resource-manager: Reimplement attribute_ops

attribute_ops is in charge of operations for resource instance type
of INSTANCE_TYPE_NORMAL. As the is_resource_attr_supported() works
based on instance type, API for NORMAL instance has been added.
 - syscommon_resman_is_resource_attr_supported()

Change-Id: Ia9078f9d4639f6ce3812a4749aaf0ada87af22f2
Signed-off-by: Youngjae Cho <y0.cho@samsung.com>
19 months agoresource-manager: Introduce resource instance type 46/288646/10
Youngjae Cho [Tue, 21 Feb 2023 01:41:58 +0000 (10:41 +0900)]
resource-manager: Introduce resource instance type

 To clearly partition the way how resource works, added instance_type
to resource, INSTANCE_TYPE_NORMAL and INSTANCE_TYPE_MONITOR. Resource
instance of each type can be created by the below functions:
  - INSTANCE_TYPE_NORMAL: syscommon_resman_create_resource()
  - INSTANCE_TYPE_MONITOR: syscommon_resman_monitor_create_resource()

 Instance type of NORMAL sets all interest bits by default. Therefore,
it doesn't need to set interest bit additionally. On the other hand,
instance type of MONITOR clears all interest bits by default. Therefore,
it should set bit manually in which a monitor interest before it starts
monitoring.
 In addition, instance type of NORMAL always invoke its attribute
getter for every access to attribute value. That is, it always fetches
the latest value. On the other hand, instance type of MONITOR fetches
attribute value on a specific time that must have been synchronized by
syscommon_resman_monitor_update_resource_attrs().

Change-Id: I39b2089a21d5b5d7b59704a7835e2646939a20c2
Signed-off-by: Youngjae Cho <y0.cho@samsung.com>
20 months agoresource-manager: Change variable name 45/288645/2
Youngjae Cho [Tue, 21 Feb 2023 01:25:29 +0000 (10:25 +0900)]
resource-manager: Change variable name

There will be another type, instance_type, which denotes how an resource
instance operates. To clearly distinguish role of those variables, change
variable name type to resource_type.

Change-Id: I2b5dd012d86cc7869da7206feea4ffad7f1dd8c3
Signed-off-by: Youngjae Cho <y0.cho@samsung.com>
20 months agoresource-manager: Fix license Apache to MIT 85/288785/1 accepted/tizen/unified/20230306.172221
TaeminYeom [Thu, 23 Feb 2023 04:48:29 +0000 (13:48 +0900)]
resource-manager: Fix license Apache to MIT

libsyscommon project is under the MIT license,
but newly added files were marked with Apache licenses.

[Changed file]
src/resource-manager/resource-device.c
src/resource-manager/resource-device.h
src/resource-manager/resource-listener-epoll.c
src/resource-manager/resource-listener.h
src/resource-manager/resource-manager.c
src/resource-manager/resource-manager.h
src/resource-manager/resource-type.h

Change-Id: I922df053003b2d1924543fd26690f7dd58069c42
Signed-off-by: TaeminYeom <taemin.yeom@samsung.com>
20 months agoresource-manager: Rename existing ops to monitor_ops 96/288496/2
Dongwoo Lee [Fri, 17 Feb 2023 05:43:08 +0000 (14:43 +0900)]
resource-manager: Rename existing ops to monitor_ops

Change-Id: I2d5e1228052a24c52831a1ac64b6e8c9a6394617
Signed-off-by: Dongwoo Lee <dwoo08.lee@samsung.com>
20 months agoRevert "resource-manager: introduce sync getter" 95/288495/2
Dongwoo Lee [Fri, 17 Feb 2023 02:59:48 +0000 (11:59 +0900)]
Revert "resource-manager: introduce sync getter"

Since non-sync getter for monitoring is moved into monitor_ops, sync
suffix for normal getter/setter is no more needed. Thus, this reverts
commit ad9493c0b5ae ("resource-manager: introduce sync getter").

Change-Id: I667899fc5254fa3777ffa5d784f062a3fa9e28c5
Signed-off-by: Dongwoo Lee <dwoo08.lee@samsung.com>
20 months agoresource-manager: reduce repetitive code 01/288301/2
Youngjae Cho [Wed, 15 Feb 2023 02:03:12 +0000 (11:03 +0900)]
resource-manager: reduce repetitive code

Change-Id: I374f930323e3f85550251d015e4f9c320b554d1f
Signed-off-by: Youngjae Cho <y0.cho@samsung.com>
20 months agoresource-manager: Add epoll type listener support 79/287479/6 accepted/tizen/unified/20230221.031433
Dongwoo Lee [Thu, 12 Jan 2023 01:01:22 +0000 (10:01 +0900)]
resource-manager: Add epoll type listener support

To support ease of use for epoll type listener, this introduces
following APIs:
 - syscommon_resman_register_epoll_listener: register fd to epoll
   listener worker thread and returns listener handle id.
 - syscommon_resman_unregister_epoll_listener: unregister fd from
   worker for the correspongding handle id. (fd is not closed by this
   function, so caller resource driver should be close fd by its own
   responsibility.

Change-Id: Ide38a3816742939c9101e5a92944f8dc2480ff8f
Signed-off-by: Dongwoo Lee <dwoo08.lee@samsung.com>
20 months agoresource-manager: Introduce attribute listener operations 78/287478/4
Dongwoo Lee [Thu, 12 Jan 2023 01:01:22 +0000 (10:01 +0900)]
resource-manager: Introduce attribute listener operations

Now each attribute can have 'listener_ops' which consists 'init',
'exit', and 'action', to watch changes for underlying state. Each
operation has a role as below:

 - init: allocate resources and register listeners
 - exit: deallocate resources and unregister listeners
 - action: change attribute values as following listener parameters

'init'/'exit' is called automatically when each attribute interest is
set/unset each, on the other hand, 'action' should be called by each
listener.

Change-Id: I076f41f751b18f4c39d7548e4d78ddc02e8e26a2
Signed-off-by: Dongwoo Lee <dwoo08.lee@samsung.com>
20 months agoresource-manager: revamp init/exit of resource driver 10/288010/1
Youngjae Cho [Thu, 9 Feb 2023 04:39:57 +0000 (13:39 +0900)]
resource-manager: revamp init/exit of resource driver

Change-Id: I24bf3bd1b93bbe53c170522bc039b082191989de
Signed-off-by: Youngjae Cho <y0.cho@samsung.com>
20 months agolibgdbus: add dbus signal for power lock state change 81/287781/2 accepted/tizen/unified/20230209.111304
Yunhee Seo [Mon, 6 Feb 2023 05:42:42 +0000 (14:42 +0900)]
libgdbus: add dbus signal for power lock state change

In this context, power lock state is meaning of "locked or unlocked".
Thus, If the power lock state of specific pmlock is changed,
this signal will be used.

Change-Id: I9db5527bf9668fe54ee9c0c19a2be23b42f91517
Signed-off-by: Yunhee Seo <yuni.seo@samsung.com>
20 months agoresource-manager: allocate resource id correctly 95/287795/2
Youngjae Cho [Mon, 6 Feb 2023 10:05:08 +0000 (19:05 +0900)]
resource-manager: allocate resource id correctly

It hasn't cleared sign bit on allocating resource id. Fix it to clear
sign bit correctly.

Change-Id: Ic429dd26bcd6082ed434aecf98b8a48eb0b52b47
Signed-off-by: Youngjae Cho <y0.cho@samsung.com>
21 months agoresource-manager: fix wrong indentation in unset_resource_attr_interest 71/286771/2
Chanwoo Choi [Thu, 12 Jan 2023 13:48:30 +0000 (22:48 +0900)]
resource-manager: fix wrong indentation in unset_resource_attr_interest

Fix the wrong indentation in unset_resource_attr_interest internal
function in order to improve the readability.

Change-Id: I07f3d84060d14c0d5cc141d74949900dd9fe11f0
Signed-off-by: Chanwoo Choi <cw00.choi@samsung.com>
21 months agoresource-manager: fix free_resource() 49/286649/3
Youngjae Cho [Wed, 11 Jan 2023 01:56:27 +0000 (10:56 +0900)]
resource-manager: fix free_resource()

Change-Id: I15855cc6ce7eef4859a94fbc0d959d91abdd0c06
Signed-off-by: Youngjae Cho <y0.cho@samsung.com>
21 months agoresource-manager: introduce sync getter 35/286435/1
Youngjae Cho [Fri, 6 Jan 2023 03:04:34 +0000 (12:04 +0900)]
resource-manager: introduce sync getter

Sync getter fetches data after update.

Change-Id: I4610f99f1b4039b985890f77abb827a1174bf5dd
Signed-off-by: Youngjae Cho <y0.cho@samsung.com>
22 months agolibgdbus: add dbus signal for power state change 84/285084/2 accepted/tizen/unified/20221220.180317
Youngjae Cho [Tue, 6 Dec 2022 02:15:52 +0000 (11:15 +0900)]
libgdbus: add dbus signal for power state change

Change-Id: I8b4b22f7bfb5e4d662ee531d5b170ada2f09acdf
Signed-off-by: Youngjae Cho <y0.cho@samsung.com>
22 months agoresource-manager: add missing header 77/285077/1
Youngjae Cho [Tue, 6 Dec 2022 02:33:07 +0000 (11:33 +0900)]
resource-manager: add missing header

Change-Id: I3c1d4fb91d0ebbf784075c5b7bb5f6e49a0cc51a
Signed-off-by: Youngjae Cho <y0.cho@samsung.com>
23 months agopackaging: couple .spec version with .pc version 52/284852/1 accepted/tizen/unified/20221206.170548
Youngjae Cho [Tue, 29 Nov 2022 02:30:19 +0000 (11:30 +0900)]
packaging: couple .spec version with .pc version

Change-Id: I2ccfce3f0afbfe66b2807858e7b081d7cbf022e5
Signed-off-by: Youngjae Cho <y0.cho@samsung.com>
23 months agolibsyscommon v5.0.0 21/283221/3
Dongwoo Lee [Thu, 20 Oct 2022 10:14:12 +0000 (19:14 +0900)]
libsyscommon v5.0.0

Changes from v4.1
- Add libsyscommon-resource-manager feature to handle the resource and
  resource attribute based on ID.
- Newly added header files for resource-manager
  1. usr/include/libsyscommon/resource-type.h
  : Contain the supported resource data type and resource flag to
    indicate the specific characteristic.
  2. usr/include/libsyscommon/resource-manager.h
  : Contain the resource handelr functions such as create/delete
    resource, update the resource attributes and get value of resource attributes.
  : Contain the structures for resource driver and attribute
  3. usr/include/libsyscommon/resource-device.h
  : Contain the resource_device structure and function to handle the
    resource device data.

Change-Id: Id43eb66dc1797cf8838497ff0aaa37625ca6fe30
Signed-off-by: Dongwoo Lee <dwoo08.lee@samsung.com>
Signed-off-by: Chanwoo Choi <cw00.choi@samsung.com>
23 months agoresource-manager: operate based on resource id 56/283856/4
Youngjae Cho [Fri, 4 Nov 2022 05:45:16 +0000 (14:45 +0900)]
resource-manager: operate based on resource id

All operations provided by resource-manager now work based on resource
"id" instead of resource "instance" itself. All resource "instances" are
managed within libsyscommon and it only exposes their id.

The resource-manager source code has been implemented based on the
coding rule below.
 - An actual operating function has no prefix syscommon_resman_. It has
   internal linkage and takes actual resource instance as a parameter.
   e.g., get_resource_attr(struct syscommon_resman_resource *resource, ...)

 - A function exposed through header is prefixed with syscommon_resman_
   and it takes resource id as a parameter. It locates resource instance
   using resource id and invokes matching function.
   e.g., syscommon_resman_get_resource_attr(int resource_id, ...)

Change-Id: If82c58593b363433188bf01809dc57a242ede24f
Signed-off-by: Youngjae Cho <y0.cho@samsung.com>
23 months agoresource-manager: add system resource manager library 06/283206/3
Dongwoo Lee [Thu, 20 Oct 2022 07:27:30 +0000 (16:27 +0900)]
resource-manager: add system resource manager library

To provide system-wide unified resource framework, resource utilities in
resource monitor is extracted into this library.

Change-Id: I7ba90e3b1fda1b525a015bb46addd4d860045d6d
Signed-off-by: Dongwoo Lee <dwoo08.lee@samsung.com>
Signed-off-by: Youngjae Cho <y0.cho@samsung.com>
2 years agoAdd extern "C" keyword in header files 47/280147/1 accepted/tizen_7.0_unified_hotfix tizen_7.0_hotfix accepted/tizen/7.0/unified/20221110.060712 accepted/tizen/7.0/unified/hotfix/20221116.105738 accepted/tizen/unified/20220919.021606 tizen_7.0_m2_release
TaeminYeom [Wed, 24 Aug 2022 09:15:03 +0000 (18:15 +0900)]
Add extern "C" keyword in header files

Change-Id: Ie16f5ec1d1c18f5e20cd94d46ad63a3ad7ac58fc
Signed-off-by: TaeminYeom <taemin.yeom@samsung.com>
2 years agoRelicense libsyscommon package as MIT to prevent license conflict issues 33/279833/1 accepted/tizen/unified/20220824.135652 submit/tizen/20220822.111221
Hyotaek Shim [Thu, 18 Aug 2022 07:40:18 +0000 (16:40 +0900)]
Relicense libsyscommon package as MIT to prevent license conflict issues

For example, Apache-2.0 is in conflict with GPL-2.0.

Change-Id: I52aff6d3d7083fa20939f1fd356c299ddc69e0cf
Signed-off-by: Hyotaek Shim <hyotaek.shim@samsung.com>
2 years agoini-parser: check closing bracket when parsing section name 79/276079/1
Youngjae Cho [Thu, 9 Jun 2022 08:12:42 +0000 (17:12 +0900)]
ini-parser: check closing bracket when parsing section name

Change-Id: Ic939bfd6f57c9ee20e41fe7adf34f0debe3539e6
Signed-off-by: Youngjae Cho <y0.cho@samsung.com>
2 years agoFix build errors - different header path 58/275658/1 accepted/tizen/unified/20220530.140622 submit/tizen/20220528.014654
Hyotaek Shim [Sat, 28 May 2022 01:43:38 +0000 (10:43 +0900)]
Fix build errors - different header path

Public) /include/system/system_info.h
VD TV)  /include/capi-system-info/system_info.h

Change-Id: Ibae5b76527051ecda6b7e24d546846886e8cb213
Signed-off-by: Hyotaek Shim <hyotaek.shim@samsung.com>
2 years agoAdd missing Requires to pkgconfig(capi-system-info) 49/274349/2 accepted/tizen/unified/20220526.144244 submit/tizen/20220525.001052
Hyotaek Shim [Wed, 27 Apr 2022 02:44:15 +0000 (11:44 +0900)]
Add missing Requires to pkgconfig(capi-system-info)

Change-Id: I677a0b3995caaf937e54a318ea655b8822539cd6
Signed-off-by: Hyotaek Shim <hyotaek.shim@samsung.com>
2 years agoFix build warnings 96/269496/2
Youngjae Cho [Mon, 17 Jan 2022 05:17:58 +0000 (14:17 +0900)]
Fix build warnings

Change-Id: Ib5784f64fb176d2916f376ca4c0ca05d6e363c36
Signed-off-by: Youngjae Cho <y0.cho@samsung.com>
2 years agoAdd libsys_is_emulator() and refactor libsys_is_container() 29/273729/2
Hyotaek Shim [Wed, 13 Apr 2022 02:26:17 +0000 (11:26 +0900)]
Add libsys_is_emulator() and refactor libsys_is_container()

Change-Id: Ic2cce60d76704803cd1c54aa70a9c795b92c9906
Signed-off-by: Hyotaek Shim <hyotaek.shim@samsung.com>
Signed-off-by: Youngjae Cho <y0.cho@samsung.com>
2 years agoAdd description for the declaration of the file utils 77/273477/2
SangYoun Kwak [Wed, 6 Apr 2022 06:58:55 +0000 (15:58 +0900)]
Add description for the declaration of the file utils

Change-Id: Ia8367863a59fd3f31738fa62db1d0618c4e8ba5a
Signed-off-by: SangYoun Kwak <sy.kwak@samsung.com>
2 years agoCheck tmp buffer overflow 06/269706/5
SangYoun Kwak [Thu, 20 Jan 2022 05:14:21 +0000 (14:14 +0900)]
Check tmp buffer overflow

Change-Id: I5de5195293f72444d91d7b8f89f72bfe3ac5301e
Signed-off-by: SangYoun Kwak <sy.kwak@samsung.com>
2 years agoini-parser: add libsys_config_parse_by_section() 72/268472/4 accepted/tizen/unified/20220117.135033 submit/tizen/20220112.015321 submit/tizen/20220113.004629
Youngjae Cho [Thu, 23 Dec 2021 07:33:30 +0000 (16:33 +0900)]
ini-parser: add libsys_config_parse_by_section()

The original function, config_parse(), parses configuration file line by
line. Due to this, a parser, which is registered by the config_parse(),
can hardly handle out-of-ordered section/property or multiple sections
with same name.

The libsys_config_parse_by_section() now parses configuration file
by section. Therefore a parser can now find whole properties of a
section when the section is conveyed to the parser.

Change-Id: I08f09e2f6aefabea497393edb3c1f88dbe2d8850
Signed-off-by: Youngjae Cho <y0.cho@samsung.com>
2 years agofile: add libsys_parse_cmdline_scanf() 14/268314/3
Youngjae Cho [Mon, 20 Dec 2021 07:46:29 +0000 (16:46 +0900)]
file: add libsys_parse_cmdline_scanf()

libsys_parse_cmdline_scanf() scans tokens of file /proc/cmdline.
The parameters and return value have same semantics to those of
scanf() family.

Change-Id: Iac5838fe36b0ed2de36eb0412a13691ba0a50c3b
Signed-off-by: Youngjae Cho <y0.cho@samsung.com>
2 years agoChange interface DEVICED_INTERFACE_POWER 28/267728/1 accepted/tizen/unified/20211213.133502 submit/tizen/20211210.062426
Youngjae Cho [Thu, 9 Dec 2021 08:14:37 +0000 (17:14 +0900)]
Change interface DEVICED_INTERFACE_POWER

Change-Id: I3c605793fb70e4948c8a95dbb2d4c1bf4b75b39f
Signed-off-by: Youngjae Cho <y0.cho@samsung.com>
2 years agoModify dbus object path 33/265433/4 submit/tizen/20211111.113430
Unsung Lee [Tue, 19 Oct 2021 05:26:02 +0000 (14:26 +0900)]
Modify dbus object path

Change-Id: I6377613b93197d45e7873004767a22ddbedb68a1
Signed-off-by: Unsung Lee <unsung.lee@samsung.com>
2 years agoFix svace issue 72/266172/1
Youngjae Cho [Tue, 9 Nov 2021 01:18:17 +0000 (17:18 -0800)]
Fix svace issue

Change-Id: I920fbb2f16b8af7cf164c58a18a1eb6ff2f1db9a
Signed-off-by: Youngjae Cho <y0.cho@samsung.com>
3 years agotests: add test running automatically on building 63/264863/6 accepted/tizen/unified/20211105.130505 submit/tizen/20211103.072537 submit/tizen/20211104.031932 submit/tizen/20211104.080231
Youngjae Cho [Fri, 1 Oct 2021 09:10:18 +0000 (18:10 +0900)]
tests: add test running automatically on building

If the test fails, the whole build will fail.

Change-Id: Ibb88e60d13bcec09567630d051372fbcfbbb79da
Signed-off-by: Youngjae Cho <y0.cho@samsung.com>
3 years agolibcommon: add is_container function 42/260842/2 accepted/tizen/6.5/unified/20211028.115050 accepted/tizen/unified/20210707.070905 submit/tizen/20210706.074949 submit/tizen_6.5/20211028.162501 tizen_6.5.m2_release
Yunmi Ha [Mon, 5 Jul 2021 11:47:06 +0000 (20:47 +0900)]
libcommon: add is_container function

Change-Id: I5ba0109e996b3f4e8ff939859499a3de8b623c90
Signed-off-by: Yunmi Ha <yunmi.ha@samsung.com>
3 years agolibcommon: bring file IO from deviced 91/259691/2 accepted/tizen/unified/20210615.120427 submit/tizen/20210611.122922 submit/tizen/20210614.021455
Youngjae Cho [Fri, 11 Jun 2021 06:12:50 +0000 (15:12 +0900)]
libcommon: bring file IO from deviced

Change-Id: I0068a42487b31881ff2c8f91de785ae8362984d4
Signed-off-by: Youngjae Cho <y0.cho@samsung.com>
3 years agolibcommon: fix indentation 89/259689/1
Youngjae Cho [Fri, 11 Jun 2021 06:09:02 +0000 (15:09 +0900)]
libcommon: fix indentation

Change-Id: Ib0af8672bfa8843050db917540c3ddfe91efbcff
Signed-off-by: Youngjae Cho <y0.cho@samsung.com>
3 years agoRemove with_tizen build macro 56/257256/1
Hyotaek Shim [Thu, 22 Apr 2021 01:01:48 +0000 (10:01 +0900)]
Remove with_tizen build macro

Change-Id: I565075d4b1dbc99f73fd3bcc7afe5eb944bce854
Signed-off-by: Hyotaek Shim <hyotaek.shim@samsung.com>
3 years agoFix including libgdbus header libsystemd 74/255574/1 accepted/tizen/unified/20210321.225805 submit/tizen/20210319.090004
Hyotaek Shim [Fri, 19 Mar 2021 08:40:06 +0000 (17:40 +0900)]
Fix including libgdbus header libsystemd

Change-Id: I427757673726c8829a777d8667dcd096eb481a49
Signed-off-by: Hyotaek Shim <hyotaek.shim@samsung.com>
3 years agoChange dbus function name 31/255531/2
taemin.yeom [Fri, 19 Mar 2021 05:14:10 +0000 (14:14 +0900)]
Change dbus function name

Change-Id: I67b2b5d555db01ecbd32078380662e90f1dc3b6f
Signed-off-by: taemin.yeom <taemin.yeom@samsung.com>
3 years agoImprove variable naming style 31/255031/5
taemin.yeom [Thu, 11 Mar 2021 09:17:04 +0000 (18:17 +0900)]
Improve variable naming style

Change-Id: I5236467f2efbc7768f49028b09e0a758967fd979
Signed-off-by: taemin.yeom <taemin.yeom@samsung.com>
3 years agoAdd GVariant NULL check 78/255078/3
taemin.yeom [Fri, 12 Mar 2021 02:02:08 +0000 (11:02 +0900)]
Add GVariant NULL check

Change-Id: I7278251402d76f4785b15b8fdc6724d80e59f642
Signed-off-by: taemin.yeom <taemin.yeom@samsung.com>
3 years agoRearrange header and source files 28/254728/1
Hyotaek Shim [Tue, 9 Mar 2021 04:24:11 +0000 (13:24 +0900)]
Rearrange header and source files

Change-Id: I7cb9725a5be1ac4ead7cac73d50203f413f669cf
Signed-off-by: Hyotaek Shim <hyotaek.shim@samsung.com>
3 years agoRestore gdbus APIs based on va_list 82/254682/1 accepted/tizen/unified/20210310.145057 submit/tizen/20210309.090957 submit/tizen/20210310.040440
taemin.yeom [Mon, 8 Mar 2021 08:23:27 +0000 (17:23 +0900)]
Restore gdbus APIs based on va_list

Change-Id: I9c275d6c652ac4253d3058fa3c022340ca55c6cd
Signed-off-by: taemin.yeom <taemin.yeom@samsung.com>
3 years agoImprove error handling 01/254601/3
taemin.yeom [Fri, 5 Mar 2021 05:38:18 +0000 (14:38 +0900)]
Improve error handling

Change-Id: I2db312e210c37a457eb874d41f1adcfb5700885a
Signed-off-by: taemin.yeom <taemin.yeom@samsung.com>
3 years agoChange dbus handle method functions 21/254521/5
taemin.yeom [Thu, 4 Mar 2021 06:20:57 +0000 (15:20 +0900)]
Change dbus handle method functions

change "dbus_handle_method_sync_var" and
"dbus_handle_method_with_unix_fd_list_sync_with_reply_var"
to add a return value indicating error results

Change-Id: Ib9063dc6811bb28e885f71e85b0253dfd6d303bc
Signed-off-by: taemin.yeom <taemin.yeom@samsung.com>
3 years agoChange dbus_handle_method_sync_with_reply_var 58/254458/14
taemin.yeom [Wed, 3 Mar 2021 07:54:50 +0000 (16:54 +0900)]
Change dbus_handle_method_sync_with_reply_var

to add a return value indicating error results.

Change-Id: I557c3fe79168076aaa9516f0c36eafd471e19c56
Signed-off-by: taemin.yeom <taemin.yeom@samsung.com>
3 years agoRemove unused gdbus APIs based on char string 06/254506/1
Hyotaek Shim [Thu, 4 Mar 2021 02:17:58 +0000 (11:17 +0900)]
Remove unused gdbus APIs based on char string

Change-Id: I6ddb7dd5948c5268f7da0b3977d25059b7898110
Signed-off-by: Hyotaek Shim <hyotaek.shim@samsung.com>
3 years agoRemove unused gdbus APIs based on va_list 05/254505/1
Hyotaek Shim [Thu, 4 Mar 2021 02:08:12 +0000 (11:08 +0900)]
Remove unused gdbus APIs based on va_list

Change-Id: I0d858522fda0f49e0bda8f4b4b7178b9ca770429
Signed-off-by: Hyotaek Shim <hyotaek.shim@samsung.com>
3 years agoFix svace 87/253187/3 accepted/tizen/unified/20210223.065526 submit/tizen/20210222.042310
lokilee73 [Fri, 5 Feb 2021 08:35:15 +0000 (17:35 +0900)]
Fix svace

Change-Id: I5397a386b95ed5fbaccda82a02a2b70026766044
Signed-off-by: lokilee73 <changjoo.lee@samsung.com>
3 years agoChange dbus method name for pass SetScenario 43/253143/4 accepted/tizen/unified/20210208.061715 submit/tizen/20210205.011235
lokilee73 [Fri, 5 Feb 2021 00:50:02 +0000 (09:50 +0900)]
Change dbus method name for pass SetScenario

Change-Id: I963a064da7d8f7a4cef14c2b4df30139d742c963
Signed-off-by: lokilee73 <changjoo.lee@samsung.com>
3 years agolibgdbus: Return null when dbus connection fails 12/252212/2 accepted/tizen/unified/20210129.002321 submit/tizen/20210127.032903
Karol Lewandowski [Mon, 25 Jan 2021 16:57:49 +0000 (17:57 +0100)]
libgdbus: Return null when dbus connection fails

When libgdbus fails to get bus for one of global busses (system, session)
it still returns vaild pointer.  It's because global busses are cached in
g_dh[2] which always exist.

This commit changes the get_connection function to return null for all the
checks like following to detect and fail in the case where getting bus was
unsuccessfull (ie. dbus-daemon isn't running in early boot/special targets)

    dh = _dbus_handle_get_default_connection();
    if (!dh) {
        _E("failed to get default connection, bustype:%d", (int)dbus_handle_get_default_bus_type());
        ...

Change-Id: If85fe8e6cb7a5f95618df8f7f3fefa923e3e271a