2018-01-25 08:51:41 +08:00
|
|
|
/*
|
|
|
|
|
* Copyright 2018 Google, Inc
|
|
|
|
|
*
|
|
|
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
|
* you may not use this file except in compliance with the License.
|
|
|
|
|
* You may obtain a copy of the License at
|
|
|
|
|
*
|
|
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
|
*
|
|
|
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
|
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
|
* See the License for the specific language governing permissions and
|
|
|
|
|
* limitations under the License.
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
#include <errno.h>
|
|
|
|
|
#include <fcntl.h>
|
|
|
|
|
#include <sys/cdefs.h>
|
|
|
|
|
#include <sys/stat.h>
|
|
|
|
|
#include <sys/types.h>
|
|
|
|
|
#include <stdio.h>
|
|
|
|
|
#include <unistd.h>
|
|
|
|
|
|
|
|
|
|
#include <cutils/sockets.h>
|
2022-03-22 01:47:24 +08:00
|
|
|
#include <liblmkd_utils.h>
|
|
|
|
|
#include <processgroup/processgroup.h>
|
2018-01-25 08:51:41 +08:00
|
|
|
|
|
|
|
|
int lmkd_connect() {
|
|
|
|
|
return socket_local_client("lmkd",
|
|
|
|
|
ANDROID_SOCKET_NAMESPACE_RESERVED,
|
2019-10-22 08:59:22 +08:00
|
|
|
SOCK_SEQPACKET | SOCK_CLOEXEC);
|
2018-01-25 08:51:41 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
int lmkd_register_proc(int sock, struct lmk_procprio *params) {
|
|
|
|
|
LMKD_CTRL_PACKET packet;
|
|
|
|
|
size_t size;
|
|
|
|
|
int ret;
|
|
|
|
|
|
|
|
|
|
size = lmkd_pack_set_procprio(packet, params);
|
2019-10-19 02:22:27 +08:00
|
|
|
ret = TEMP_FAILURE_RETRY(write(sock, packet, size));
|
|
|
|
|
|
|
|
|
|
return (ret < 0) ? -1 : 0;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
int lmkd_unregister_proc(int sock, struct lmk_procremove *params) {
|
|
|
|
|
LMKD_CTRL_PACKET packet;
|
|
|
|
|
size_t size;
|
|
|
|
|
int ret;
|
|
|
|
|
|
|
|
|
|
size = lmkd_pack_set_procremove(packet, params);
|
2018-01-25 08:51:41 +08:00
|
|
|
ret = TEMP_FAILURE_RETRY(write(sock, packet, size));
|
|
|
|
|
|
|
|
|
|
return (ret < 0) ? -1 : 0;
|
|
|
|
|
}
|
|
|
|
|
|
2020-04-29 06:52:29 +08:00
|
|
|
enum update_props_result lmkd_update_props(int sock) {
|
|
|
|
|
LMKD_CTRL_PACKET packet;
|
2020-05-12 07:31:57 +08:00
|
|
|
int size;
|
2020-04-29 06:52:29 +08:00
|
|
|
|
|
|
|
|
size = lmkd_pack_set_update_props(packet);
|
|
|
|
|
if (TEMP_FAILURE_RETRY(write(sock, packet, size)) < 0) {
|
|
|
|
|
return UPDATE_PROPS_SEND_ERR;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
size = TEMP_FAILURE_RETRY(read(sock, packet, CTRL_PACKET_MAX_SIZE));
|
|
|
|
|
if (size < 0) {
|
|
|
|
|
return UPDATE_PROPS_RECV_ERR;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (size != 2 * sizeof(int) || lmkd_pack_get_cmd(packet) != LMK_UPDATE_PROPS) {
|
|
|
|
|
return UPDATE_PROPS_FORMAT_ERR;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
struct lmk_update_props_reply params;
|
|
|
|
|
lmkd_pack_get_update_props_repl(packet, ¶ms);
|
|
|
|
|
|
|
|
|
|
return params.result == 0 ? UPDATE_PROPS_SUCCESS : UPDATE_PROPS_FAIL;
|
|
|
|
|
}
|
|
|
|
|
|
2024-03-28 06:27:40 +08:00
|
|
|
enum boot_completed_notification_result lmkd_notify_boot_completed(int sock) {
|
|
|
|
|
LMKD_CTRL_PACKET packet;
|
|
|
|
|
int size;
|
|
|
|
|
|
|
|
|
|
size = lmkd_pack_set_boot_completed_notif(packet);
|
|
|
|
|
if (TEMP_FAILURE_RETRY(write(sock, packet, size)) < 0) {
|
|
|
|
|
return BOOT_COMPLETED_NOTIF_SEND_ERR;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
size = TEMP_FAILURE_RETRY(read(sock, packet, CTRL_PACKET_MAX_SIZE));
|
|
|
|
|
if (size < 0) {
|
|
|
|
|
return BOOT_COMPLETED_NOTIF_RECV_ERR;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (size != 2 * sizeof(int) || lmkd_pack_get_cmd(packet) != LMK_BOOT_COMPLETED) {
|
|
|
|
|
return BOOT_COMPLETED_NOTIF_FORMAT_ERR;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
struct lmk_boot_completed_notif_reply params;
|
|
|
|
|
lmkd_pack_get_boot_completed_notif_repl(packet, ¶ms);
|
|
|
|
|
|
|
|
|
|
enum boot_completed_notification_result res;
|
|
|
|
|
switch (params.result) {
|
|
|
|
|
case -1:
|
|
|
|
|
res = BOOT_COMPLETED_NOTIF_FAILS;
|
|
|
|
|
break;
|
|
|
|
|
case 0:
|
|
|
|
|
res = BOOT_COMPLETED_NOTIF_SUCCESS;
|
|
|
|
|
break;
|
|
|
|
|
case 1:
|
|
|
|
|
res = BOOT_COMPLETED_NOTIF_ALREADY_HANDLED;
|
|
|
|
|
break;
|
|
|
|
|
default:
|
|
|
|
|
/* This should never be reached */
|
|
|
|
|
res = BOOT_COMPLETED_NOTIF_FAILS;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return res;
|
|
|
|
|
}
|
|
|
|
|
|
2024-05-15 05:21:11 +08:00
|
|
|
int lmkd_get_kill_count(int sock, struct lmk_getkillcnt* params) {
|
|
|
|
|
LMKD_CTRL_PACKET packet;
|
|
|
|
|
int size;
|
|
|
|
|
|
|
|
|
|
size = lmkd_pack_set_getkillcnt(packet, params);
|
|
|
|
|
if (TEMP_FAILURE_RETRY(write(sock, packet, size)) < 0) {
|
|
|
|
|
return (int)GET_KILL_COUNT_SEND_ERR;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
size = TEMP_FAILURE_RETRY(read(sock, packet, CTRL_PACKET_MAX_SIZE));
|
|
|
|
|
if (size < 0) {
|
|
|
|
|
return (int)GET_KILL_COUNT_RECV_ERR;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (size != 2 * sizeof(int) || lmkd_pack_get_cmd(packet) != LMK_GETKILLCNT) {
|
|
|
|
|
return (int)GET_KILL_COUNT_FORMAT_ERR;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return packet[1];
|
|
|
|
|
}
|
|
|
|
|
|
2018-01-25 08:51:41 +08:00
|
|
|
int create_memcg(uid_t uid, pid_t pid) {
|
2022-03-22 01:47:24 +08:00
|
|
|
return createProcessGroup(uid, pid, true) == 0 ? 0 : -1;
|
2018-01-25 08:51:41 +08:00
|
|
|
}
|
|
|
|
|
|