aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJami Kettunen <jami.kettunen@protonmail.com>2020-10-16 23:54:54 +0300
committerMike Gabriel <mike.gabriel@das-netzwerkteam.de>2021-08-28 10:17:14 +0200
commit333a4273eb26ffc47b29f3ea8ce3213d36803894 (patch)
tree0600bf19950287ed5ce1f66978fdfcf265ceadc7
parent948a5107c479a72a2940316674fae6a3b55534ff (diff)
downloadayatana-indicator-power-333a4273eb26ffc47b29f3ea8ce3213d36803894.tar.gz
ayatana-indicator-power-333a4273eb26ffc47b29f3ea8ce3213d36803894.tar.bz2
ayatana-indicator-power-333a4273eb26ffc47b29f3ea8ce3213d36803894.zip
flashlight: Add support for simpler sysfs toggles (#34)
Unlike the overcomplicated Qualcomm mess, there are also simpler sysfs toggles which you can just write 1/0 to when enabling/disabling the flash. This is used by the MediaTek flashlight_core driver on the Volla Phone (Helio P23 / MT6763) for example, which this also adds support for. Pinephone also uses a simple sysfs toggle for flashlight.
-rw-r--r--src/flashlight.c70
-rw-r--r--src/flashlight.h9
2 files changed, 65 insertions, 14 deletions
diff --git a/src/flashlight.c b/src/flashlight.c
index 55a108a..8aba2b5 100644
--- a/src/flashlight.c
+++ b/src/flashlight.c
@@ -26,6 +26,8 @@
#define QCOM_ENABLE "255"
#define QCOM_DISABLE "0"
+#define SIMPLE_ENABLE "1"
+#define SIMPLE_DISABLE "0"
const size_t qcom_sysfs_size = 5;
const char* const qcom_sysfs[] = {"/sys/class/leds/torch-light/brightness",
@@ -33,10 +35,14 @@ const char* const qcom_sysfs[] = {"/sys/class/leds/torch-light/brightness",
"/sys/class/leds/flashlight/brightness",
"/sys/class/leds/torch-light0/brightness",
"/sys/class/leds/torch-light1/brightness"};
-
const char* qcom_torch_enable = "/sys/class/leds/led:switch/brightness";
+const size_t simple_sysfs_size = 2;
+const char* const simple_sysfs[] = {"/sys/class/flashlight_core/flashlight/flashlight_torch",
+ "/sys/class/leds/white:flash/brightness"};
+
char* flash_sysfs_path = NULL;
+enum TorchType torch_type = SIMPLE;
gboolean activated = 0;
int
@@ -45,6 +51,13 @@ set_sysfs_path()
for (size_t i = 0; i < qcom_sysfs_size; i++) {
if (access(qcom_sysfs[i], F_OK ) != -1){
flash_sysfs_path = (char*)qcom_sysfs[i];
+ torch_type = QCOM;
+ return 1;
+ }
+ }
+ for (size_t i = 0; i < simple_sysfs_size; i++) {
+ if (access(simple_sysfs[i], F_OK ) != -1){
+ flash_sysfs_path = (char*)simple_sysfs[i];
return 1;
}
}
@@ -57,22 +70,12 @@ flashlight_activated()
return activated;
}
-void
-toggle_flashlight_action(GAction *action,
- GVariant *parameter G_GNUC_UNUSED,
- gpointer data G_GNUC_UNUSED)
+int
+toggle_flashlight_action_qcom()
{
- GVariant *state;
FILE *fd1 = NULL, *fd2 = NULL;
-
int needs_enable;
- if (!set_sysfs_path())
- return;
-
- state = g_action_get_state(action);
- activated = g_variant_get_boolean(state);
- g_variant_unref(state);
fd1 = fopen(flash_sysfs_path, "w");
if (fd1 != NULL) {
needs_enable = access(qcom_torch_enable, F_OK ) != -1;
@@ -91,8 +94,47 @@ toggle_flashlight_action(GAction *action,
fclose(fd1);
if (fd2 !=NULL)
fclose(fd2);
- g_action_change_state(action, g_variant_new_boolean(!activated));
+ return 1;
}
+ return 0;
+}
+
+int
+toggle_flashlight_action_simple()
+{
+ FILE *fd = NULL;
+
+ fd = fopen(flash_sysfs_path, "w");
+ if (fd != NULL) {
+ fprintf(fd, activated ? SIMPLE_DISABLE : SIMPLE_ENABLE);
+ fclose(fd);
+ return 1;
+ }
+ return 0;
+}
+
+void
+toggle_flashlight_action(GAction *action,
+ GVariant *parameter G_GNUC_UNUSED,
+ gpointer data G_GNUC_UNUSED)
+{
+ GVariant *state;
+ int toggled;
+
+ if (!set_sysfs_path())
+ return;
+
+ state = g_action_get_state(action);
+ activated = g_variant_get_boolean(state);
+ g_variant_unref(state);
+
+ if (torch_type == QCOM)
+ toggled = toggle_flashlight_action_qcom();
+ else
+ toggled = toggle_flashlight_action_simple();
+
+ if (toggled)
+ g_action_change_state(action, g_variant_new_boolean(!activated));
}
int
diff --git a/src/flashlight.h b/src/flashlight.h
index 51ed5e7..19f738e 100644
--- a/src/flashlight.h
+++ b/src/flashlight.h
@@ -24,6 +24,12 @@
G_BEGIN_DECLS
+int
+toggle_flashlight_action_qcom();
+
+int
+toggle_flashlight_action_simple();
+
void
toggle_flashlight_action(GAction *action,
GVariant *parameter G_GNUC_UNUSED,
@@ -35,6 +41,9 @@ flashlight_supported();
gboolean
flashlight_activated();
+enum
+TorchType { SIMPLE = 1, QCOM };
+
G_END_DECLS
#endif /* INDICATOR_POWER_FLASHLIGHT__H */