Line data Source code
1 : /****************************************************************************** 2 : * 3 : * Project: GDAL 4 : * Purpose: Fuzzer 5 : * Author: Even Rouault, even.rouault at spatialys.com 6 : * 7 : ****************************************************************************** 8 : * Copyright (c) 2017, Even Rouault <even.rouault at spatialys.com> 9 : * 10 : * Permission is hereby granted, free of charge, to any person obtaining a 11 : * copy of this software and associated documentation files (the "Software"), 12 : * to deal in the Software without restriction, including without limitation 13 : * the rights to use, copy, modify, merge, publish, distribute, sublicense, 14 : * and/or sell copies of the Software, and to permit persons to whom the 15 : * Software is furnished to do so, subject to the following conditions: 16 : * 17 : * The above copyright notice and this permission notice shall be included 18 : * in all copies or substantial portions of the Software. 19 : * 20 : * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS 21 : * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 22 : * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL 23 : * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 24 : * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING 25 : * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER 26 : * DEALINGS IN THE SOFTWARE. 27 : ****************************************************************************/ 28 : 29 : #include <stddef.h> 30 : #include <stdint.h> 31 : 32 : #include "ogr_api.h" 33 : #include "cpl_conv.h" 34 : #include "cpl_error.h" 35 : 36 : extern "C" int LLVMFuzzerInitialize(int *argc, char ***argv); 37 : 38 0 : int LLVMFuzzerInitialize(int * /*argc*/, char *** /*argv*/) 39 : { 40 0 : return 0; 41 : } 42 : 43 : extern "C" int LLVMFuzzerTestOneInput(const uint8_t *buf, size_t len); 44 : 45 1 : int LLVMFuzzerTestOneInput(const uint8_t *buf, size_t len) 46 : { 47 1 : OGRGeometryH hGeom = nullptr; 48 1 : char *pszWKT = static_cast<char *>(CPLMalloc(len + 1)); 49 1 : memcpy(pszWKT, buf, len); 50 1 : pszWKT[len] = '\0'; 51 1 : char *pszWKTParam = pszWKT; 52 1 : CPLPushErrorHandler(CPLQuietErrorHandler); 53 1 : OGR_G_CreateFromWkt(&pszWKTParam, nullptr, &hGeom); 54 1 : CPLPopErrorHandler(); 55 1 : CPLFree(pszWKT); 56 1 : OGR_G_DestroyGeometry(hGeom); 57 1 : return 0; 58 : }