cachepc-qemu

Fork of AMDESE/qemu with changes for cachepc side-channel attack
git clone https://git.sinitax.com/sinitax/cachepc-qemu
Log | Files | Refs | Submodules | LICENSE | sfeed.txt

sdhci.h (1949B)


      1/*
      2 * libqos driver framework
      3 *
      4 * Copyright (c) 2018 Emanuele Giuseppe Esposito <e.emanuelegiuseppe@gmail.com>
      5 *
      6 * This library is free software; you can redistribute it and/or
      7 * modify it under the terms of the GNU Lesser General Public
      8 * License version 2.1 as published by the Free Software Foundation.
      9 *
     10 * This library is distributed in the hope that it will be useful,
     11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
     12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
     13 * Lesser General Public License for more details.
     14 *
     15 * You should have received a copy of the GNU Lesser General Public
     16 * License along with this library; if not, see <http://www.gnu.org/licenses/>
     17 */
     18
     19#ifndef QGRAPH_QSDHCI_H
     20#define QGRAPH_QSDHCI_H
     21
     22#include "qgraph.h"
     23#include "pci.h"
     24
     25typedef struct QSDHCI QSDHCI;
     26typedef struct QSDHCI_MemoryMapped QSDHCI_MemoryMapped;
     27typedef struct QSDHCI_PCI  QSDHCI_PCI;
     28typedef struct QSDHCIProperties QSDHCIProperties;
     29
     30/* Properties common to all QSDHCI devices */
     31struct QSDHCIProperties {
     32    uint8_t version;
     33    uint8_t baseclock;
     34    struct {
     35        bool sdma;
     36        uint64_t reg;
     37    } capab;
     38};
     39
     40struct QSDHCI {
     41    uint16_t (*readw)(QSDHCI *s, uint32_t reg);
     42    uint64_t (*readq)(QSDHCI *s, uint32_t reg);
     43    void (*writeq)(QSDHCI *s, uint32_t reg, uint64_t val);
     44    QSDHCIProperties props;
     45};
     46
     47/* Memory Mapped implementation of QSDHCI */
     48struct QSDHCI_MemoryMapped {
     49    QOSGraphObject obj;
     50    QTestState *qts;
     51    QSDHCI sdhci;
     52    uint64_t addr;
     53};
     54
     55/* PCI implementation of QSDHCI */
     56struct QSDHCI_PCI {
     57    QOSGraphObject obj;
     58    QPCIDevice dev;
     59    QSDHCI sdhci;
     60    QPCIBar mem_bar;
     61};
     62
     63/**
     64 * qos_init_sdhci_mm(): external constructor used by all drivers/machines
     65 * that "contain" a #QSDHCI_MemoryMapped driver
     66 */
     67void qos_init_sdhci_mm(QSDHCI_MemoryMapped *sdhci, QTestState *qts,
     68                       uint32_t addr, QSDHCIProperties *common);
     69
     70#endif