summaryrefslogblamecommitdiffstats
path: root/include/hw/misc/imx7_ccm.h
blob: dcaebfb4efdd6712c3d5fa9df8936290ef0692cb (plain) (tree)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16















                                                                            
                       

























































































                                              
                                                  
 
                     






                           
  


                                      
                                                        
 
                        












                                
  

                       
/*
 * Copyright (c) 2017, Impinj, Inc.
 *
 * i.MX7 CCM, PMU and ANALOG IP blocks emulation code
 *
 * Author: Andrey Smirnov <andrew.smirnov@gmail.com>
 *
 * This work is licensed under the terms of the GNU GPL, version 2 or later.
 * See the COPYING file in the top-level directory.
 */

#ifndef IMX7_CCM_H
#define IMX7_CCM_H

#include "hw/misc/imx_ccm.h"
#include "qemu/bitops.h"
#include "qom/object.h"

enum IMX7AnalogRegisters {
    ANALOG_PLL_ARM,
    ANALOG_PLL_ARM_SET,
    ANALOG_PLL_ARM_CLR,
    ANALOG_PLL_ARM_TOG,
    ANALOG_PLL_DDR,
    ANALOG_PLL_DDR_SET,
    ANALOG_PLL_DDR_CLR,
    ANALOG_PLL_DDR_TOG,
    ANALOG_PLL_DDR_SS,
    ANALOG_PLL_DDR_SS_SET,
    ANALOG_PLL_DDR_SS_CLR,
    ANALOG_PLL_DDR_SS_TOG,
    ANALOG_PLL_DDR_NUM,
    ANALOG_PLL_DDR_NUM_SET,
    ANALOG_PLL_DDR_NUM_CLR,
    ANALOG_PLL_DDR_NUM_TOG,
    ANALOG_PLL_DDR_DENOM,
    ANALOG_PLL_DDR_DENOM_SET,
    ANALOG_PLL_DDR_DENOM_CLR,
    ANALOG_PLL_DDR_DENOM_TOG,
    ANALOG_PLL_480,
    ANALOG_PLL_480_SET,
    ANALOG_PLL_480_CLR,
    ANALOG_PLL_480_TOG,
    ANALOG_PLL_480A,
    ANALOG_PLL_480A_SET,
    ANALOG_PLL_480A_CLR,
    ANALOG_PLL_480A_TOG,
    ANALOG_PLL_480B,
    ANALOG_PLL_480B_SET,
    ANALOG_PLL_480B_CLR,
    ANALOG_PLL_480B_TOG,
    ANALOG_PLL_ENET,
    ANALOG_PLL_ENET_SET,
    ANALOG_PLL_ENET_CLR,
    ANALOG_PLL_ENET_TOG,
    ANALOG_PLL_AUDIO,
    ANALOG_PLL_AUDIO_SET,
    ANALOG_PLL_AUDIO_CLR,
    ANALOG_PLL_AUDIO_TOG,
    ANALOG_PLL_AUDIO_SS,
    ANALOG_PLL_AUDIO_SS_SET,
    ANALOG_PLL_AUDIO_SS_CLR,
    ANALOG_PLL_AUDIO_SS_TOG,
    ANALOG_PLL_AUDIO_NUM,
    ANALOG_PLL_AUDIO_NUM_SET,
    ANALOG_PLL_AUDIO_NUM_CLR,
    ANALOG_PLL_AUDIO_NUM_TOG,
    ANALOG_PLL_AUDIO_DENOM,
    ANALOG_PLL_AUDIO_DENOM_SET,
    ANALOG_PLL_AUDIO_DENOM_CLR,
    ANALOG_PLL_AUDIO_DENOM_TOG,
    ANALOG_PLL_VIDEO,
    ANALOG_PLL_VIDEO_SET,
    ANALOG_PLL_VIDEO_CLR,
    ANALOG_PLL_VIDEO_TOG,
    ANALOG_PLL_VIDEO_SS,
    ANALOG_PLL_VIDEO_SS_SET,
    ANALOG_PLL_VIDEO_SS_CLR,
    ANALOG_PLL_VIDEO_SS_TOG,
    ANALOG_PLL_VIDEO_NUM,
    ANALOG_PLL_VIDEO_NUM_SET,
    ANALOG_PLL_VIDEO_NUM_CLR,
    ANALOG_PLL_VIDEO_NUM_TOG,
    ANALOG_PLL_VIDEO_DENOM,
    ANALOG_PLL_VIDEO_DENOM_SET,
    ANALOG_PLL_VIDEO_DENOM_CLR,
    ANALOG_PLL_VIDEO_DENOM_TOG,
    ANALOG_PLL_MISC0,
    ANALOG_PLL_MISC0_SET,
    ANALOG_PLL_MISC0_CLR,
    ANALOG_PLL_MISC0_TOG,

    ANALOG_DIGPROG = 0x800 / sizeof(uint32_t),
    ANALOG_MAX,

    ANALOG_PLL_LOCK = BIT(31)
};

enum IMX7CCMRegisters {
    CCM_MAX = 0xBE00 / sizeof(uint32_t) + 1,
};

enum IMX7PMURegisters {
    PMU_MAX = 0x140 / sizeof(uint32_t),
};

#define TYPE_IMX7_CCM "imx7.ccm"
OBJECT_DECLARE_SIMPLE_TYPE(IMX7CCMState, IMX7_CCM)

struct IMX7CCMState {
    /* <private> */
    IMXCCMState parent_obj;

    /* <public> */
    MemoryRegion iomem;

    uint32_t ccm[CCM_MAX];
};


#define TYPE_IMX7_ANALOG "imx7.analog"
OBJECT_DECLARE_SIMPLE_TYPE(IMX7AnalogState, IMX7_ANALOG)

struct IMX7AnalogState {
    /* <private> */
    IMXCCMState parent_obj;

    /* <public> */
    struct {
        MemoryRegion container;
        MemoryRegion analog;
        MemoryRegion digprog;
        MemoryRegion pmu;
    } mmio;

    uint32_t analog[ANALOG_MAX];
    uint32_t pmu[PMU_MAX];
};

#endif /* IMX7_CCM_H */