1
0
mirror of https://git.libssh.org/projects/libssh.git synced 2025-12-06 13:20:57 +03:00
Files
libssh/tests/fuzz/ssh_bind_config_fuzzer.c
Jakub Jelen a3c5d3b256 tests: Rewrite all fuzzers to LLVMFuzzerInitialize and nalloc
Signed-off-by: Jakub Jelen <jjelen@redhat.com>
Reviewed-by: Andreas Schneider <asn@cryptomilk.org>
2025-09-25 15:03:07 +02:00

76 lines
1.5 KiB
C

/*
* Copyright 2021 Jakub Jelen <jjelen@redhat.com>
*
* 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 <assert.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#define LIBSSH_STATIC 1
#include "libssh/libssh.h"
#include "libssh/server.h"
#include "libssh/bind_config.h"
#include "nallocinc.c"
static void _fuzz_finalize(void)
{
ssh_finalize();
}
int LLVMFuzzerInitialize(int *argc, char ***argv)
{
(void)argc;
nalloc_init(*argv[0]);
ssh_init();
atexit(_fuzz_finalize);
return 0;
}
int LLVMFuzzerTestOneInput(const uint8_t *data, size_t size)
{
ssh_bind bind = NULL;
char *input = NULL;
input = (char *)malloc(size + 1);
if (!input) {
return 1;
}
strncpy(input, (const char *)data, size);
input[size] = '\0';
assert(nalloc_start(data, size) > 0);
bind = ssh_bind_new();
if (bind == NULL) {
goto out;
}
ssh_bind_config_parse_string(bind, input);
ssh_bind_free(bind);
out:
free(input);
nalloc_end();
return 0;
}