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