1d9f0492fSopenharmony_ci/* 2d9f0492fSopenharmony_ci * Copyright (c) 2024 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#include "getdevicenodepermissions_fuzzer.h" 17d9f0492fSopenharmony_ci#include <string> 18d9f0492fSopenharmony_ci#include "ueventd_read_cfg.h" 19d9f0492fSopenharmony_ci 20d9f0492fSopenharmony_cinamespace OHOS { 21d9f0492fSopenharmony_ci bool FuzzGetDeviceNodePermissions(const uint8_t* data, size_t size) 22d9f0492fSopenharmony_ci { 23d9f0492fSopenharmony_ci if ((data == nullptr) || (size < sizeof(char) + sizeof(uid_t) + sizeof(gid_t) + sizeof(mode_t))) { 24d9f0492fSopenharmony_ci return false; 25d9f0492fSopenharmony_ci } 26d9f0492fSopenharmony_ci bool result = false; 27d9f0492fSopenharmony_ci unsigned int offset = 0; 28d9f0492fSopenharmony_ci const char *devNode = reinterpret_cast<const char*>(data + offset); 29d9f0492fSopenharmony_ci offset += sizeof(char); 30d9f0492fSopenharmony_ci uid_t *uid = reinterpret_cast<uid_t*>(const_cast<uint8_t *>(data + offset)); 31d9f0492fSopenharmony_ci offset += sizeof(uid_t); 32d9f0492fSopenharmony_ci gid_t *gid = reinterpret_cast<gid_t*>(const_cast<uint8_t *>(data + offset)); 33d9f0492fSopenharmony_ci offset += sizeof(gid_t); 34d9f0492fSopenharmony_ci mode_t *mode = reinterpret_cast<mode_t*>(const_cast<uint8_t *>(data + offset)); 35d9f0492fSopenharmony_ci if (GetDeviceNodePermissions(devNode, uid, gid, mode) != 0) { 36d9f0492fSopenharmony_ci result = true; 37d9f0492fSopenharmony_ci }; 38d9f0492fSopenharmony_ci return result; 39d9f0492fSopenharmony_ci } 40d9f0492fSopenharmony_ci} 41d9f0492fSopenharmony_ci 42d9f0492fSopenharmony_ci/* Fuzzer entry point */ 43d9f0492fSopenharmony_ciextern "C" int LLVMFuzzerTestOneInput(const uint8_t* data, size_t size) 44d9f0492fSopenharmony_ci{ 45d9f0492fSopenharmony_ci /* Run your code on data */ 46d9f0492fSopenharmony_ci OHOS::FuzzGetDeviceNodePermissions(data, size); 47d9f0492fSopenharmony_ci return 0; 48d9f0492fSopenharmony_ci}