• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /*
2  * Copyright (c) 2022-2023 Huawei Device Co., Ltd.
3  * Licensed under the Apache License, Version 2.0 (the "License");
4  * you may not use this file except in compliance with the License.
5  * You may obtain a copy of the License at
6  *
7  *     http://www.apache.org/licenses/LICENSE-2.0
8  *
9  * Unless required by applicable law or agreed to in writing, software
10  * distributed under the License is distributed on an "AS IS" BASIS,
11  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12  * See the License for the specific language governing permissions and
13  * limitations under the License.
14  */
15 
16 #include "setgetcbconfig_fuzzer.h"
17 
18 #define private public
19 
20 #include "addsmstoken_fuzzer.h"
21 #include "gsm_cb_gsm_codec.h"
22 #include "gsm_cb_umts_codec.h"
23 #include "sms_service.h"
24 #include "string_utils.h"
25 
26 using namespace OHOS::Telephony;
27 namespace OHOS {
28 static bool g_isInited = false;
29 static int32_t SIM_COUNT = 2;
30 static int32_t CB_CHANNEL_DIVISOR = 2;
31 static int32_t NET_COUNT = 3;
32 
IsServiceInited()33 bool IsServiceInited()
34 {
35     if (!g_isInited) {
36         DelayedSingleton<SmsService>::GetInstance()->OnStart();
37         if (DelayedSingleton<SmsService>::GetInstance()->GetServiceRunningState() ==
38             static_cast<int32_t>(Telephony::ServiceRunningState::STATE_RUNNING)) {
39             g_isInited = true;
40         }
41     }
42     return g_isInited;
43 }
44 
SetCBConfigFuzz(const uint8_t * data,size_t size)45 void SetCBConfigFuzz(const uint8_t *data, size_t size)
46 {
47     if (!IsServiceInited()) {
48         return;
49     }
50 
51     MessageParcel dataParcel;
52     MessageParcel replyParcel;
53     MessageOption option(MessageOption::TF_SYNC);
54 
55     int32_t slotId = static_cast<int32_t>(size % SIM_COUNT);
56     bool enable = slotId == 1 ? true : false;
57     uint32_t fromMsgId = static_cast<uint32_t>(size / CB_CHANNEL_DIVISOR);
58     uint32_t toMsgId = static_cast<uint32_t>(size);
59     int32_t netType = static_cast<int32_t>(size % NET_COUNT);
60 
61     dataParcel.WriteInt32(slotId);
62     dataParcel.WriteBool(enable);
63     dataParcel.WriteUint32(fromMsgId);
64     dataParcel.WriteUint32(toMsgId);
65     dataParcel.WriteUint8(netType);
66 
67     dataParcel.WriteBuffer(data, size);
68     dataParcel.RewindRead(0);
69     DelayedSingleton<SmsService>::GetInstance()->OnSetCBConfig(dataParcel, replyParcel, option);
70 
71     std::shared_ptr<SmsInterfaceManager> interfaceManager = std::make_shared<SmsInterfaceManager>(slotId);
72     if (interfaceManager == nullptr) {
73         TELEPHONY_LOGE("interfaceManager nullptr error");
74         return;
75     }
76     interfaceManager->SetCBConfig(enable, fromMsgId, toMsgId, netType);
77 
78     std::shared_ptr<SmsMiscManager> smsMiscManager = std::make_shared<SmsMiscManager>(slotId);
79     if (smsMiscManager == nullptr) {
80         TELEPHONY_LOGE("smsMiscManager nullptr error");
81         return;
82     }
83     smsMiscManager->SetCBConfig(enable, fromMsgId, toMsgId, netType);
84 }
85 
SetImsSmsConfigFuzz(const uint8_t * data,size_t size)86 void SetImsSmsConfigFuzz(const uint8_t *data, size_t size)
87 {
88     if (!IsServiceInited()) {
89         return;
90     }
91 
92     MessageParcel dataParcel;
93     MessageParcel replyParcel;
94     MessageOption option(MessageOption::TF_SYNC);
95 
96     int32_t slotId = static_cast<int32_t>(size % SIM_COUNT);
97     int32_t enable = slotId == 1 ? true : false;
98     dataParcel.WriteInt32(slotId);
99     dataParcel.WriteInt32(enable);
100     dataParcel.WriteBuffer(data, size);
101     dataParcel.RewindRead(0);
102     DelayedSingleton<SmsService>::GetInstance()->OnSetImsSmsConfig(dataParcel, replyParcel, option);
103 
104     std::shared_ptr<SmsInterfaceManager> interfaceManager = std::make_shared<SmsInterfaceManager>(slotId);
105     if (interfaceManager == nullptr) {
106         TELEPHONY_LOGE("interfaceManager nullptr error");
107         return;
108     }
109     interfaceManager->SetImsSmsConfig(slotId, enable);
110 
111     auto smsSendManager = std::make_shared<SmsSendManager>(slotId);
112     if (smsSendManager == nullptr) {
113         return;
114     }
115     smsSendManager->SetImsSmsConfig(slotId, enable);
116 }
117 
UpdataCBMessage(const uint8_t * data,size_t size)118 void UpdataCBMessage(const uint8_t *data, size_t size)
119 {
120     std::string pdu(reinterpret_cast<const char *>(data), size);
121     auto cbMessage = GsmCbCodec::CreateCbMessage(pdu);
122     if (cbMessage == nullptr) {
123         return;
124     }
125     cbMessage->GetCbHeader();
126     auto cbMessageByVectorInit = GsmCbCodec::CreateCbMessage(StringUtils::HexToByteVector(pdu));
127     if (cbMessageByVectorInit == nullptr) {
128         return;
129     }
130     cbMessageByVectorInit->GetCbMessageRaw();
131     cbMessageByVectorInit->IsSinglePageMsg();
132 
133     cbMessage->PduAnalysis(StringUtils::HexToByteVector(pdu));
134 
135     auto gsmCodec = std::make_shared<GsmCbGsmCodec>(cbMessage->cbHeader_, cbMessage->cbPduBuffer_, cbMessage);
136     auto umtsCodec = std::make_shared<GsmCbUmtsCodec>(cbMessage->cbHeader_, cbMessage->cbPduBuffer_, cbMessage);
137     if (gsmCodec == nullptr || umtsCodec == nullptr) {
138         return;
139     }
140     gsmCodec->Decode2gHeader();
141     umtsCodec->Decode3gHeader();
142 
143     gsmCodec->Decode2gCbMsg();
144     umtsCodec->Decode3gCbMsg();
145     umtsCodec->Decode3g7Bit();
146     umtsCodec->Decode3gUCS2();
147     gsmCodec->DecodeEtwsMsg();
148 
149     std::string raw(reinterpret_cast<const char *>(data), size);
150     std::string message(reinterpret_cast<const char *>(data), size);
151     cbMessage->ConvertToUTF8(raw, message);
152 }
153 
DoCBConfigWithMyAPI(const uint8_t * data,size_t size)154 void DoCBConfigWithMyAPI(const uint8_t *data, size_t size)
155 {
156     if (data == nullptr || size == 0) {
157         return;
158     }
159     SetCBConfigFuzz(data, size);
160     SetImsSmsConfigFuzz(data, size);
161     UpdataCBMessage(data, size);
162 }
163 } // namespace OHOS
164 
165 /* Fuzzer entry point */
LLVMFuzzerTestOneInput(const uint8_t * data,size_t size)166 extern "C" int LLVMFuzzerTestOneInput(const uint8_t *data, size_t size)
167 {
168     /* Run your code on data */
169     OHOS::AddSmsTokenFuzzer token;
170     OHOS::DoCBConfigWithMyAPI(data, size);
171     return 0;
172 }
173