/* SPDX-License-Identifier: GPL-2.0+ */ /* * Copyright (c) 2022 Google, Inc. * Written by Andrew Scull <ascull@google.com> */ #ifndef __FUZZING_ENGINE_H #define __FUZZING_ENGINE_H struct udevice; /** * dm_fuzzing_engine_get_input() - get an input from the fuzzing engine device * * The function will return a pointer to the input data and the size of the * data pointed to. The pointer will remain valid until the next invocation of * this function. * * @dev: fuzzing engine device * @data: output pointer to input data * @size output size of input data * Return: 0 if OK, -ve on error */ int dm_fuzzing_engine_get_input(struct udevice *dev, const uint8_t **data, size_t *size); /** * struct dm_fuzzing_engine_ops - operations for the fuzzing engine uclass * * This contains the functions implemented by a fuzzing engine device. */ struct dm_fuzzing_engine_ops { /** * @get_input() - get an input * * The function will return a pointer to the input data and the size of * the data pointed to. The pointer will remain valid until the next * invocation of this function. * * @get_input.dev: fuzzing engine device * @get_input.data: output pointer to input data * @get_input.size output size of input data * @get_input.Return: 0 if OK, -ve on error */ int (*get_input)(struct udevice *dev, const uint8_t **data, size_t *size); }; #endif /* __FUZZING_ENGINE_H */