qemu/include/hw/pcmcia.h
<<
>>
Prefs
   1#ifndef HW_PCMCIA_H
   2#define HW_PCMCIA_H
   3
   4/* PCMCIA/Cardbus */
   5
   6#include "hw/qdev-core.h"
   7#include "qom/object.h"
   8
   9typedef struct PCMCIASocket {
  10    qemu_irq irq;
  11    bool attached;
  12} PCMCIASocket;
  13
  14#define TYPE_PCMCIA_CARD "pcmcia-card"
  15OBJECT_DECLARE_TYPE(PCMCIACardState, PCMCIACardClass, PCMCIA_CARD)
  16
  17struct PCMCIACardState {
  18    /*< private >*/
  19    DeviceState parent_obj;
  20    /*< public >*/
  21
  22    PCMCIASocket *slot;
  23};
  24
  25struct PCMCIACardClass {
  26    /*< private >*/
  27    DeviceClass parent_class;
  28    /*< public >*/
  29
  30    int (*attach)(PCMCIACardState *state);
  31    int (*detach)(PCMCIACardState *state);
  32
  33    const uint8_t *cis;
  34    int cis_len;
  35
  36    /* Only valid if attached */
  37    uint8_t (*attr_read)(PCMCIACardState *card, uint32_t address);
  38    void (*attr_write)(PCMCIACardState *card, uint32_t address, uint8_t value);
  39    uint16_t (*common_read)(PCMCIACardState *card, uint32_t address);
  40    void (*common_write)(PCMCIACardState *card,
  41                         uint32_t address, uint16_t value);
  42    uint16_t (*io_read)(PCMCIACardState *card, uint32_t address);
  43    void (*io_write)(PCMCIACardState *card, uint32_t address, uint16_t value);
  44};
  45
  46#define CISTPL_DEVICE           0x01    /* 5V Device Information Tuple */
  47#define CISTPL_NO_LINK          0x14    /* No Link Tuple */
  48#define CISTPL_VERS_1           0x15    /* Level 1 Version Tuple */
  49#define CISTPL_JEDEC_C          0x18    /* JEDEC ID Tuple */
  50#define CISTPL_JEDEC_A          0x19    /* JEDEC ID Tuple */
  51#define CISTPL_CONFIG           0x1a    /* Configuration Tuple */
  52#define CISTPL_CFTABLE_ENTRY    0x1b    /* 16-bit PCCard Configuration */
  53#define CISTPL_DEVICE_OC        0x1c    /* Additional Device Information */
  54#define CISTPL_DEVICE_OA        0x1d    /* Additional Device Information */
  55#define CISTPL_DEVICE_GEO       0x1e    /* Additional Device Information */
  56#define CISTPL_DEVICE_GEO_A     0x1f    /* Additional Device Information */
  57#define CISTPL_MANFID           0x20    /* Manufacture ID Tuple */
  58#define CISTPL_FUNCID           0x21    /* Function ID Tuple */
  59#define CISTPL_FUNCE            0x22    /* Function Extension Tuple */
  60#define CISTPL_END              0xff    /* Tuple End */
  61#define CISTPL_ENDMARK          0xff
  62
  63/* dscm1xxxx.c */
  64PCMCIACardState *dscm1xxxx_init(DriveInfo *bdrv);
  65
  66#endif
  67