// Copyright 2021-2023 Nick Brassel (@tzarc) // SPDX-License-Identifier: GPL-2.0-or-later #pragma once #include "qp_internal.h" //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// // Driver callbacks typedef bool (*painter_driver_init_func)(painter_device_t device, painter_rotation_t rotation); typedef bool (*painter_driver_power_func)(painter_device_t device, bool power_on); typedef bool (*painter_driver_clear_func)(painter_device_t device); typedef bool (*painter_driver_flush_func)(painter_device_t device); typedef bool (*painter_driver_viewport_func)(painter_device_t device, uint16_t left, uint16_t top, uint16_t right, uint16_t bottom); typedef bool (*painter_driver_pixdata_func)(painter_device_t device, const void *pixel_data, uint32_t native_pixel_count); typedef bool (*painter_driver_convert_palette_func)(painter_device_t device, int16_t palette_size, qp_pixel_t *palette); typedef bool (*painter_driver_append_pixels)(painter_device_t device, uint8_t *target_buffer, qp_pixel_t *palette, uint32_t pixel_offset, uint32_t pixel_count, uint8_t *palette_indices); typedef bool (*painter_driver_append_pixdata)(painter_device_t device, uint8_t *target_buffer, uint32_t pixdata_offset, uint8_t pixdata_byte); // Driver vtable definition typedef struct painter_driver_vtable_t { painter_driver_init_func init; painter_driver_power_func power; painter_driver_clear_func clear; painter_driver_flush_func flush; painter_driver_viewport_func viewport; painter_driver_pixdata_func pixdata; painter_driver_convert_palette_func palette_convert; painter_driver_append_pixels append_pixels; painter_driver_append_pixdata append_pixdata; } painter_driver_vtable_t; //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// // Comms callbacks typedef bool (*painter_driver_comms_init_func)(painter_device_t device); typedef bool (*painter_driver_comms_start_func)(painter_device_t device); typedef void (*painter_driver_comms_stop_func)(painter_device_t device); typedef uint32_t (*painter_driver_comms_send_func)(painter_device_t device, const void *data, uint32_t byte_count); typedef struct painter_comms_vtable_t { painter_driver_comms_init_func comms_init; painter_driver_comms_start_func comms_start; painter_driver_comms_stop_func comms_stop; painter_driver_comms_send_func comms_send; } painter_comms_vtable_t; typedef void (*painter_driver_comms_send_command_func)(painter_device_t device, uint8_t cmd); typedef void (*painter_driver_comms_bulk_command_sequence)(painter_device_t device, const uint8_t *sequence, size_t sequence_len); typedef struct painter_comms_with_command_vtable_t { painter_comms_vtable_t base; // must be first, so this object can be cast from the painter_comms_vtable_t* type painter_driver_comms_send_command_func send_command; painter_driver_comms_bulk_command_sequence bulk_command_sequence; } painter_comms_with_command_vtable_t; //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// // Driver base definition typedef struct painter_driver_t { const painter_driver_vtable_t *driver_vtable; const painter_comms_vtable_t * comms_vtable; // Flag signifying if validation was successful bool validate_ok; // Panel geometry uint16_t panel_width; uint16_t panel_height; // Target drawing rotation painter_rotation_t rotation; // Automated offsets for setting viewport uint16_t offset_x; uint16_t offset_y; // Number of bits per pixel, used for determining how many pixels can be sent during a transmission of the pixdata buffer uint8_t native_bits_per_pixel; // Comms config pointer -- needs to point to an appropriate comms config if the comms driver requires it. void *comms_config; } painter_driver_t; //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// // Device internals bool qp_internal_register_device(painter_device_t driver);