/* * Copyright (c) 2022 Huawei Device Co., Ltd. * 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. */ #include "clienttransudpstreaminterface_fuzzer.h" #include #include "client_trans_udp_stream_interface.h" #include "softbus_adapter_mem.h" #include "softbus_def.h" namespace OHOS { void SendVtpStreamTest(const uint8_t* data, size_t size) { if (data == nullptr || size < sizeof(int64_t)) { return; } uint8_t *ptr = static_cast(SoftBusCalloc(size + 1)); if (ptr == nullptr) { return; } if (memcpy_s(ptr, size, data, size) != EOK) { SoftBusFree(ptr); return; } int32_t channelId = *(reinterpret_cast(ptr)); StreamData streamdata = { .buf = const_cast(reinterpret_cast(ptr)), .bufLen = size, }; StreamData ext = { .buf = const_cast(reinterpret_cast(ptr)), .bufLen = size, }; TV tv = { .type = *(reinterpret_cast(ptr)), .value = *(reinterpret_cast(ptr)), }; StreamFrameInfo param = { .frameType = *(reinterpret_cast(ptr)), .timeStamp = *(reinterpret_cast(ptr)), .seqNum = *(reinterpret_cast(ptr)), .seqSubNum = *(reinterpret_cast(ptr)), .level = *(reinterpret_cast(ptr)), .bitMap = *(reinterpret_cast(ptr)), .tvCount = 1, .tvList = &tv, }; SendVtpStream(channelId, &streamdata, &ext, ¶m); SoftBusFree(ptr); } void StartVtpStreamChannelServerTest(const uint8_t* data, size_t size) { if (data == nullptr || size < sizeof(int64_t)) { return; } uint8_t *ptr = static_cast(SoftBusCalloc(size + 1)); if (ptr == nullptr) { return; } if (memcpy_s(ptr, size, data, size) != EOK) { SoftBusFree(ptr); return; } int32_t channelId = *(reinterpret_cast(ptr)); VtpStreamOpenParam param = { .pkgName = reinterpret_cast(ptr), .myIp = const_cast(reinterpret_cast(ptr)), .peerIp = const_cast(reinterpret_cast(ptr)), .peerPort = *(reinterpret_cast(ptr)), .type = *(reinterpret_cast(ptr)), .sessionKey = const_cast(ptr), .keyLen = *(reinterpret_cast(ptr)), .isRawStreamEncrypt = size % 2, }; IStreamListener *callback = nullptr; StartVtpStreamChannelServer(channelId, ¶m, callback); SoftBusFree(ptr); } void StartVtpStreamChannelClientTest(const uint8_t* data, size_t size) { if (data == nullptr || size < sizeof(int64_t)) { return; } uint8_t *ptr = static_cast(SoftBusCalloc(size + 1)); if (ptr == nullptr) { return; } if (memcpy_s(ptr, size, data, size) != EOK) { SoftBusFree(ptr); return; } int32_t channelId = *(reinterpret_cast(ptr)); VtpStreamOpenParam param = { .pkgName = reinterpret_cast(ptr), .myIp = const_cast(reinterpret_cast(ptr)), .peerIp = const_cast(reinterpret_cast(ptr)), .peerPort = *(reinterpret_cast(ptr)), .type = *(reinterpret_cast(ptr)), .sessionKey = const_cast(ptr), .keyLen = *(reinterpret_cast(ptr)), .isRawStreamEncrypt = size % 2, }; IStreamListener *callback = nullptr; StartVtpStreamChannelClient(channelId, ¶m, callback); SoftBusFree(ptr); } void CloseVtpStreamChannelTest(const uint8_t* data, size_t size) { if (data == nullptr || size < PKG_NAME_SIZE_MAX) { return; } char tmp[PKG_NAME_SIZE_MAX + 1] = {0}; if (memcpy_s(tmp, PKG_NAME_SIZE_MAX, data, PKG_NAME_SIZE_MAX) != EOK) { return; }; CloseVtpStreamChannel(size, tmp); } } // namespace OHOS /* Fuzzer entry point */ extern "C" int32_t LLVMFuzzerTestOneInput(const uint8_t* data, size_t size) { /* Run your code on data */ OHOS::SendVtpStreamTest(data, size); OHOS::StartVtpStreamChannelServerTest(data, size); OHOS::StartVtpStreamChannelClientTest(data, size); return 0; }