1
0
mirror of https://review.coreboot.org/flashrom.git synced 2025-04-26 22:52:34 +02:00
flashrom/tests/libusb_wraps.c
Alexander Goncharov 224ce81687 tests: add mocks for libusb's asynchronous API
This patch adds mocks for several libusb functions are introduced
in one of the previous commits.

Signed-off-by: Alexander Goncharov <chat@joursoir.net>
Change-Id: I5a316687ab39a112d968eeaedb71f7b4b659d8d5
Reviewed-on: https://review.coreboot.org/c/flashrom/+/69873
Tested-by: build bot (Jenkins) <no-reply@coreboot.org>
Reviewed-by: Anastasia Klimchuk <aklm@chromium.org>
2022-11-29 21:02:49 +00:00

223 lines
5.1 KiB
C

/*
* This file is part of the flashrom project.
*
* Copyright 2021 Google LLC
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; version 2 of the License.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*/
#include <stdlib.h>
#include <include/test.h>
#include "io_mock.h"
#include "libusb_wraps.h"
void *__wrap_usb_dev_get_by_vid_pid_number(
libusb_context *usb_ctx, uint16_t vid, uint16_t pid, unsigned int num)
{
LOG_ME;
return not_null();
}
int __wrap_libusb_init(libusb_context **ctx)
{
LOG_ME;
if (get_io() && get_io()->libusb_init)
return get_io()->libusb_init(get_io()->state, ctx);
return 0;
}
void __wrap_libusb_set_debug(libusb_context *ctx, int level)
{
LOG_ME;
}
int __wrap_libusb_set_option(libusb_context *ctx, int option, ...)
{
LOG_ME;
return 0;
}
int __wrap_libusb_open(libusb_device *dev, libusb_device_handle **devh)
{
LOG_ME;
return 0;
}
int __wrap_libusb_set_auto_detach_kernel_driver(libusb_device_handle *devh, int enable)
{
LOG_ME;
return 0;
}
int __wrap_libusb_detach_kernel_driver(libusb_device_handle *dev_handle, int interface_number)
{
LOG_ME;
return 0;
}
int __wrap_libusb_attach_kernel_driver(libusb_device_handle *dev_handle, int interface_number)
{
LOG_ME;
return 0;
}
struct libusb_device_handle *__wrap_libusb_open_device_with_vid_pid(
libusb_context *ctx, uint16_t vendor_id, uint16_t product_id)
{
LOG_ME;
return not_null();
}
libusb_device *__wrap_libusb_get_device(libusb_device_handle *dev_handle)
{
LOG_ME;
return not_null();
}
ssize_t __wrap_libusb_get_device_list(libusb_context *ctx, libusb_device ***list)
{
LOG_ME;
if (get_io() && get_io()->libusb_get_device_list)
return get_io()->libusb_get_device_list(get_io()->state, ctx, list);
return 0;
}
void __wrap_libusb_free_device_list(libusb_device **list, int unref_devices)
{
LOG_ME;
if (get_io() && get_io()->libusb_free_device_list)
get_io()->libusb_free_device_list(get_io()->state, list, unref_devices);
}
uint8_t __wrap_libusb_get_bus_number(libusb_device *dev)
{
LOG_ME;
return 0;
}
uint8_t __wrap_libusb_get_device_address(libusb_device *dev)
{
LOG_ME;
return USB_DEVICE_ADDRESS;
}
int __wrap_libusb_get_device_descriptor(libusb_device *dev, struct libusb_device_descriptor *desc)
{
LOG_ME;
if (get_io() && get_io()->libusb_get_device_descriptor)
return get_io()->libusb_get_device_descriptor(get_io()->state, dev, desc);
return 0;
}
int __wrap_libusb_get_config_descriptor(
libusb_device *dev, uint8_t config_index, struct libusb_config_descriptor **config)
{
LOG_ME;
if (get_io() && get_io()->libusb_get_config_descriptor)
return get_io()->libusb_get_config_descriptor(get_io()->state, dev, config_index, config);
return 0;
}
void __wrap_libusb_free_config_descriptor(struct libusb_config_descriptor *config)
{
LOG_ME;
if (get_io() && get_io()->libusb_free_config_descriptor)
return get_io()->libusb_free_config_descriptor(get_io()->state, config);
return;
}
int __wrap_libusb_get_configuration(libusb_device_handle *devh, int *config)
{
LOG_ME;
return 0;
}
int __wrap_libusb_set_configuration(libusb_device_handle *devh, int config)
{
LOG_ME;
return 0;
}
int __wrap_libusb_claim_interface(libusb_device_handle *devh, int interface_number)
{
LOG_ME;
return 0;
}
int __wrap_libusb_control_transfer(libusb_device_handle *devh, uint8_t bmRequestType,
uint8_t bRequest, uint16_t wValue, uint16_t wIndex, unsigned char *data,
uint16_t wLength, unsigned int timeout)
{
LOG_ME;
if (get_io() && get_io()->libusb_control_transfer)
return get_io()->libusb_control_transfer(get_io()->state,
devh, bmRequestType, bRequest, wValue, wIndex, data, wLength, timeout);
return 0;
}
int __wrap_libusb_release_interface(libusb_device_handle *devh, int interface_number)
{
LOG_ME;
return 0;
}
void __wrap_libusb_close(libusb_device_handle *devh)
{
LOG_ME;
}
libusb_device *__wrap_libusb_ref_device(libusb_device *dev)
{
LOG_ME;
return NULL;
}
void __wrap_libusb_unref_device(libusb_device *dev)
{
LOG_ME;
}
struct libusb_transfer *__wrap_libusb_alloc_transfer(int iso_packets)
{
LOG_ME;
if (get_io() && get_io()->libusb_alloc_transfer)
return get_io()->libusb_alloc_transfer(get_io()->state, iso_packets);
return not_null();
}
int __wrap_libusb_submit_transfer(struct libusb_transfer *transfer)
{
LOG_ME;
if (get_io() && get_io()->libusb_submit_transfer)
return get_io()->libusb_submit_transfer(get_io()->state, transfer);
return 0;
}
void __wrap_libusb_free_transfer(struct libusb_transfer *transfer)
{
LOG_ME;
if (get_io() && get_io()->libusb_free_transfer)
get_io()->libusb_free_transfer(get_io()->state, transfer);
}
int __wrap_libusb_handle_events_timeout(libusb_context *ctx, struct timeval *tv)
{
LOG_ME;
if (get_io() && get_io()->libusb_handle_events_timeout)
get_io()->libusb_handle_events_timeout(get_io()->state, ctx, tv);
return 0;
}
void __wrap_libusb_exit(libusb_context *ctx)
{
LOG_ME;
}