1d9f0492fSopenharmony_ci/*
2d9f0492fSopenharmony_ci * Copyright (c) 2022 Huawei Device Co., Ltd.
3d9f0492fSopenharmony_ci * Licensed under the Apache License, Version 2.0 (the "License");
4d9f0492fSopenharmony_ci * you may not use this file except in compliance with the License.
5d9f0492fSopenharmony_ci * You may obtain a copy of the License at
6d9f0492fSopenharmony_ci *
7d9f0492fSopenharmony_ci * http://www.apache.org/licenses/LICENSE-2.0
8d9f0492fSopenharmony_ci *
9d9f0492fSopenharmony_ci * Unless required by applicable law or agreed to in writing, software
10d9f0492fSopenharmony_ci * distributed under the License is distributed on an "AS IS" BASIS,
11d9f0492fSopenharmony_ci * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12d9f0492fSopenharmony_ci * See the License for the specific language governing permissions and
13d9f0492fSopenharmony_ci * limitations under the License.
14d9f0492fSopenharmony_ci */
15d9f0492fSopenharmony_ci
16d9f0492fSopenharmony_ci#ifndef SECCOMP_POLICY_H
17d9f0492fSopenharmony_ci#define SECCOMP_POLICY_H
18d9f0492fSopenharmony_ci
19d9f0492fSopenharmony_ci#include <stdint.h>
20d9f0492fSopenharmony_ci#include <stdbool.h>
21d9f0492fSopenharmony_ci
22d9f0492fSopenharmony_ci#ifdef __cplusplus
23d9f0492fSopenharmony_ci#if __cplusplus
24d9f0492fSopenharmony_ciextern "C" {
25d9f0492fSopenharmony_ci#endif
26d9f0492fSopenharmony_ci#endif
27d9f0492fSopenharmony_ci
28d9f0492fSopenharmony_ci#define SYSTEM_NAME "system"
29d9f0492fSopenharmony_ci#define APPSPAWN_NAME "appspawn"
30d9f0492fSopenharmony_ci#define NWEBSPAWN_NAME "nwebspawn"
31d9f0492fSopenharmony_ci#define APP_NAME "app"
32d9f0492fSopenharmony_ci#define IMF_EXTENTOIN_NAME "imf_secure_mode"
33d9f0492fSopenharmony_ci#define APP_PRIVILEGE "app_privilege"
34d9f0492fSopenharmony_ci
35d9f0492fSopenharmony_citypedef enum {
36d9f0492fSopenharmony_ci    SYSTEM_SA,       // system service process
37d9f0492fSopenharmony_ci    SYSTEM_OTHERS,   // HDF process and daemon process
38d9f0492fSopenharmony_ci    APP,
39d9f0492fSopenharmony_ci    INDIVIDUAL       // process which need enable individual policy
40d9f0492fSopenharmony_ci} SeccompFilterType;
41d9f0492fSopenharmony_ci
42d9f0492fSopenharmony_cibool SetSeccompPolicyWithName(SeccompFilterType type, const char *filterName);
43d9f0492fSopenharmony_ci
44d9f0492fSopenharmony_cibool IsEnableSeccomp(void);
45d9f0492fSopenharmony_ci
46d9f0492fSopenharmony_ci#ifdef __cplusplus
47d9f0492fSopenharmony_ci#if __cplusplus
48d9f0492fSopenharmony_ci}
49d9f0492fSopenharmony_ci#endif
50d9f0492fSopenharmony_ci#endif
51d9f0492fSopenharmony_ci
52d9f0492fSopenharmony_ci#endif // SECCOMP_POLICY_H
53