summaryrefslogtreecommitdiff
path: root/10/include/packages/modules/Connectivity/netd/include/NetdUpdatablePublic.h
blob: 1ca5ea2aeb6525131428d8d8846de8cf671d6104 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
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