mirror of
https://github.com/topjohnwu/Magisk.git
synced 2024-11-24 02:25:28 +00:00
448384af06
Previously `read_string()` calls `std::string.resize()` with a int read from remote process. When I/O error occurs, -1 will be used for resizing the string, `std::bad_alloc` is thrown and since magisk is compiled with `-fno-exceptions`, it will crash the whole daemon process. May fix topjohnwu#5681
26 lines
680 B
C++
26 lines
680 B
C++
#pragma once
|
|
|
|
#include <sys/un.h>
|
|
#include <sys/socket.h>
|
|
#include <string_view>
|
|
#include <string>
|
|
#include <vector>
|
|
|
|
struct sock_cred : public ucred {
|
|
std::string context;
|
|
};
|
|
|
|
socklen_t setup_sockaddr(sockaddr_un *sun, const char *name);
|
|
bool get_client_cred(int fd, sock_cred *cred);
|
|
std::vector<int> recv_fds(int sockfd);
|
|
int recv_fd(int sockfd);
|
|
int send_fds(int sockfd, const int *fds, int cnt);
|
|
int send_fd(int sockfd, int fd);
|
|
int read_int(int fd);
|
|
int read_int_be(int fd);
|
|
void write_int(int fd, int val);
|
|
void write_int_be(int fd, int val);
|
|
std::string read_string(int fd);
|
|
bool read_string(int fd, std::string &str);
|
|
void write_string(int fd, std::string_view str);
|