/* * Xilinx CFI interface * * Copyright (C) 2023, Advanced Micro Devices, Inc. * * Written by Francisco Iglesias * * SPDX-License-Identifier: GPL-2.0-or-later */ #ifndef XLNX_CFI_IF_H #define XLNX_CFI_IF_H 1 #include "qemu/help-texts.h" #include "qom/object.h" #define TYPE_XLNX_CFI_IF "xlnx-cfi-if" typedef struct XlnxCfiIfClass XlnxCfiIfClass; DECLARE_CLASS_CHECKERS(XlnxCfiIfClass, XLNX_CFI_IF, TYPE_XLNX_CFI_IF) #define XLNX_CFI_IF(obj) \ INTERFACE_CHECK(XlnxCfiIf, (obj), TYPE_XLNX_CFI_IF) typedef enum { PACKET_TYPE_CFU = 0x52, PACKET_TYPE_CFRAME = 0xA1, } xlnx_cfi_packet_type; typedef enum { CFRAME_FAR = 1, CFRAME_SFR = 2, CFRAME_FDRI = 4, CFRAME_CMD = 6, } xlnx_cfi_reg_addr; typedef struct XlnxCfiPacket { uint8_t reg_addr; uint32_t data[4]; } XlnxCfiPacket; typedef struct XlnxCfiIf { Object Parent; } XlnxCfiIf; typedef struct XlnxCfiIfClass { InterfaceClass parent; void (*cfi_transfer_packet)(XlnxCfiIf *cfi_if, XlnxCfiPacket *pkt); } XlnxCfiIfClass; /** * Transfer a XlnxCfiPacket. * * @cfi_if: the object implementing this interface * @XlnxCfiPacket: a pointer to the XlnxCfiPacket to transfer */ void xlnx_cfi_transfer_packet(XlnxCfiIf *cfi_if, XlnxCfiPacket *pkt); #endif /* XLNX_CFI_IF_H */