diff options
author | Xin Li <delphij@google.com> | 2024-03-06 09:30:13 -0800 |
---|---|---|
committer | Xin Li <delphij@google.com> | 2024-03-06 18:58:27 -0800 |
commit | 172864a11a2defd2431f69ca684fab4b05704275 (patch) | |
tree | b12481ea41843f462f476d0d9d9dfeb4b87742c2 /10/include/packages/modules/Connectivity | |
parent | 1044a72f45dc752b4f1bef3cbd9cdcf1acfc01a0 (diff) | |
parent | f21dbb1b5dd99b7e2de952e6cdd57861eb067a44 (diff) | |
download | Connectivity-172864a11a2defd2431f69ca684fab4b05704275.tar.gz |
Merge Android 14 QPR2 to AOSP main
Bug: 319669529
Merged-In: I239c5227a4e33e6afc47ead8568e22ae7873f021
Change-Id: I32c24ae4aa5fdfb26019c50a5f17d9bec02b53df
Diffstat (limited to '10/include/packages/modules/Connectivity')
-rw-r--r-- | 10/include/packages/modules/Connectivity/netd/include/NetdUpdatablePublic.h | 61 |
1 files changed, 61 insertions, 0 deletions
diff --git a/10/include/packages/modules/Connectivity/netd/include/NetdUpdatablePublic.h b/10/include/packages/modules/Connectivity/netd/include/NetdUpdatablePublic.h new file mode 100644 index 0000000..1ca5ea2 --- /dev/null +++ b/10/include/packages/modules/Connectivity/netd/include/NetdUpdatablePublic.h @@ -0,0 +1,61 @@ +/* + * Copyright (C) 2022 The Android Open Source Project + * + * 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. + */ + +#pragma once + +#include <stdint.h> +#include <sys/cdefs.h> +#include <sys/types.h> + +__BEGIN_DECLS + +/* + * Initial function for libnetd_updatable library. + * + * The function uses |cg2_path| as cgroup v2 mount location to attach BPF programs so that the + * kernel can record packet number, size, etc. in BPF maps when packets pass through, and let user + * space retrieve statistics. + * + * Returns 0 on success, or a negative POSIX error code (see errno.h) on + * failure. + */ +int libnetd_updatable_init(const char* cg2_path); + +/* + * Set the socket tag and owning UID for traffic statistics on the specified socket. Permission + * check is performed based on the |realUid| before socket tagging. + * + * The |sockFd| is a file descriptor of the socket that needs to tag. The |tag| is the mark to tag. + * It can be an arbitrary value in uint32_t range. The |chargeUid| is owning uid which will be + * tagged along with the |tag|. The |realUid| is an effective uid of the calling process, which is + * used for permission check before socket tagging. + * + * Returns 0 on success, or a negative POSIX error code (see errno.h) on failure. + */ +int libnetd_updatable_tagSocket(int sockFd, uint32_t tag, uid_t chargeUid, + uid_t realUid); + +/* + * Untag a network socket. Future traffic on this socket will no longer be associated with any + * previously configured tag and uid. + * + * The |sockFd| is a file descriptor of the socket that wants to untag. + * + * Returns 0 on success, or a negative POSIX error code (see errno.h) on failure. + */ +int libnetd_updatable_untagSocket(int sockFd); + +__END_DECLS
\ No newline at end of file |