/* SPDX-License-Identifier: GPL-2.0-only */

#ifndef __PINEVIEW_MCHBAR_REGS_H__
#define __PINEVIEW_MCHBAR_REGS_H__

/* Indexed register helper macros */
#define Gz(r, z)	((r) + ((z) * 0x100))
#define Ly(r, y)	((r) + ((y) * 4))
#define Cx(r, x)	((r) + ((x) * 0x400))
#define CxLy(r, x, y)	(((x) *	0x400) + (r) + ((y) * 4))

#define HTPACER			0x10
#define HPWRCTL1		0x14
#define HPWRCTL2		0x18
#define HPWRCTL3		0x1c
#define HTCLKGTCTL		0x20
#define SLIMCFGTMG		0x24
#define HTBONUS0		0x28
#define HTBONUS1		0x2c
#define HIT0			0x30
#define HIT1			0x34
#define HIT2			0x38
#define HIT3			0x3c
#define HIT4			0x40
#define HIT5			0x44
#define HICLKGTCTL		0x48
#define HIBONUS			0x4c
#define XTPR0			0x50
#define XTPR1			0x54
#define XTPR2			0x58
#define XTPR3			0x5c
#define XTPR4			0x60
#define XTPR5			0x64
#define XTPR6			0x68
#define XTPR7			0x6c
#define XTPR8			0x70
#define XTPR9			0x74
#define XTPR10			0x78
#define XTPR11			0x7c
#define XTPR12			0x80
#define XTPR13			0x84
#define XTPR14			0x88
#define XTPR15			0x8c
#define FCCREQ0SET		0x90
#define FCCREQ1SET		0x98
#define FCCREQ0MSK		0xa0
#define FCCREQ1MSK		0xa8
#define FCCDATASET		0xb0
#define FCCDATAMSK		0xb8
#define FCCCTL			0xc0
#define CFGPOCTL1		0xc8
#define CFGPOCTL2		0xcc
#define NOACFGBUSCTL		0xd0
#define POC			0xf4
#define POCRL			0xfa
#define CHDECMISC		0x111
#define ZQCALQT			0x114
#define SHC2REGI		0x115
#define SHC2REGII		0x117
#define WRWMCONFIG		0x120
#define SHC2REGIII		0x124
#define SHPENDREG		0x125
#define SHPAGECTRL		0x127
#define SHCMPLWRCMD		0x129
#define SHC2MINTM		0x12a
#define SHC2IDLETM		0x12c
#define BYPACTSF		0x12d
#define BYPKNRULE		0x12e
#define SHBONUSREG		0x12f
#define COMPCTRL1		0x130
#define COMPCTRL2		0x134
#define COMPCTRL3		0x138
#define XCOMP			0x13c
#define RCMEASBUFXOVR		0x140
#define ACTXCOMP		0x144
#define FINALXRCOMPRD		0x148
#define SCOMP			0x14c
#define SCMEASBUFOVR		0x150
#define ACTSCOMP		0x154
#define FINALXSCOMP		0x158
#define XSCSTART		0x15a
#define DCOMPRAW1		0x15c
#define DCOMPRAW2		0x160
#define DCMEASBUFOVR		0x164
#define FINALDELCOMP		0x168
#define OFREQDELSEL		0x16c
#define XCOMPDFCTRL		0x170
#define ZQCALCTRL		0x178
#define XCOMPCMNBNS		0x17a
#define PSMIOVR			0x17c
#define CSHRPDCTL		0x180
#define CSPDSLVWT		0x182
#define CSHRPDSHFTOUTLO		0x184
#define CSHRFIFOCTL		0x188
#define CSHWRIOBONUS		0x189
#define CSHRPDCTL2		0x18a
#define CSHRWRIOMLNS		0x18c
#define CSHRPDCTL3		0x18e
#define CSHRPDCTL4		0x190
#define CSHWRIOBONUS2		0x192
#define CSHRMSTDYNDLLENB	0x193
#define C0TXCCCMISC		0x194
#define CSHRMSTRCTL0		0x198
#define CSHRMSTRCTL1		0x19c
#define CSHRDQSTXPGM		0x1a0
#define CSHRDQSCMN		0x1a4
#define CSHRDDR3CTL		0x1a8
#define CSHRDIGANAOBSCTL	0x1b0
#define CSHRMISCCTL		0x1b4
#define CSHRMISCCTL1		0x1b6
#define CSHRDFTCTL		0x1b8
#define MPLLCTL			0x1c0
#define MPLLDBG			0x1c4
#define CREFPI			0x1c8
#define CSHRDQSDQTX		0x1e0
#define C0DRB0			0x200
#define C0DRB1			0x202
#define C0DRB2			0x204
#define C0DRB3			0x206
#define C0DRA01			0x208
#define C0DRA23			0x20a
#define CLOCKGATINGIII		0x210
#define SHC3C4REG1		0x212
#define SHC2REG4		0x216
#define C0COREBONUS2		0x218
#define C0GNT2LNCH3		0x21c
#define C0GNT2LNCH1		0x220
#define C0GNT2LNCH2		0x224
#define C0MISCTM		0x228
#define SHCYCTRKRDWRSFLV	0x22c
#define SHCYCTRKRFSHSFLV	0x232
#define SHCYCTRKCTLLVOV		0x234
#define C0WRDPYN		0x239
#define C0C2REG			0x23c
#define C0STATRDADJV		0x23e
#define C0LATCTRL		0x240
#define C0BYPCTRL		0x241
#define C0CWBCTRL		0x243
#define C0ARBCTRL		0x244
#define C0ADDCSCTRL		0x246
#define C0STATRDCTRL		0x248
#define C0RDFIFOCTRL		0x24c
#define C0WRDATACTRL		0x24d
#define C0CYCTRKPCHG		0x250
#define C0CYCTRKACT		0x252
#define C0CYCTRKWR		0x256
#define C0CYCTRKRD		0x258
#define C0CYCTRKREFR		0x25b
#define C0CYCTRKPCHG2		0x25d
#define C0RDQCTRL		0x25e
#define C0CKECTRL		0x260
#define C0CKEDELAY		0x264
#define C0PWLRCTRL		0x265
#define C0EPCONFIG		0x267
#define C0REFRCTRL2		0x268
#define C0REFRCTRL		0x269
#define C0PVCFG			0x26f
#define C0JEDEC			0x271
#define C0ARBSPL		0x272
#define C0DYNRDCTRL		0x274
#define C0WRWMFLSH		0x278
#define C0ECCERRLOG		0x280
#define C0DITCTRL		0x288
#define C0ODTRKCTRL		0x294
#define C0ODT			0x298
#define C0ODTCTRL		0x29c
#define C0GTEW			0x2a0
#define C0GTC			0x2a4
#define C0DTPEW			0x2a8
#define C0DTAEW			0x2ac
#define C0DTC			0x2b4
#define C0REFCTRL		0x2b8
#define C0NOASEL		0x2bf
#define C0COREBONUS		0x2c0
#define C0DARBTEST		0x2c8
#define CLOCKGATINGI		0x2d1
#define MEMTDPCTW		0x2d4
#define MTDPCTWHOTTH		0x2d8
#define MTDPCTWHOTTH2		0x2dc
#define MTDPCTWHOTTH3		0x2e0
#define MTDPCTWHOTTH4		0x2e4
#define MTDPCTWAUXTH		0x2e8
#define MTDPCTWIRTH		0x2ec
#define MTDPCCRWTWHOTTH		0x2f0
#define MTDPCCRWTWHOTTH2	0x2f4
#define MTDPCCRWTWHOTTH3	0x2f8
#define MTDPCCRWTWHOTTH4	0x2fc
#define MTDPCHOTTHINT		0x300
#define MTDPCHOTTHINT2		0x304
#define MTDPCTLAUXTNTINT	0x308
#define MTDPCMISC		0x30c

/* RCOMP 0 */
#define C0RCOMPCTRL0		0x31c
#define C0RCOMPMULT0		0x320
#define C0RCOMPOVR0		0x322
#define C0RCOMPOSV0		0x326
#define C0SCOMPVREF0		0x32a
#define C0SCOMPOVR0		0x32c
#define C0SCOMPOFF0		0x32e
#define C0DCOMP0		0x330
#define C0SLEWBASE0		0x332
#define C0SLEWPULUT0		0x334
#define C0SLEWPDLUT0		0x338
#define C0DCOMPOVR0		0x33c
#define C0DCOMPOFF0		0x340

/* RCOMP 2 */
#define C0RCOMPCTRL2		0x374
#define C0RCOMPMULT2		0x378
#define C0RCOMPOVR2		0x37a
#define C0RCOMPOSV2		0x37e
#define C0SCOMPVREF2		0x382
#define C0SCOMPOVR2		0x384
#define C0SCOMPOFF2		0x386
#define C0DCOMP2		0x388
#define C0SLEWBASE2		0x38a
#define C0SLEWPULUT2		0x38c
#define C0SLEWPDLUT2		0x390
#define C0DCOMPOVR2		0x394
#define C0DCOMPOFF2		0x398

/* RCOMP 3 */
#define C0RCOMPCTRL3		0x3a2
#define C0RCOMPMULT3		0x3a6
#define C0RCOMPOVR3		0x3a8
#define C0RCOMPOSV3		0x3ac
#define C0SCOMPVREF3		0x3b0
#define C0SCOMPOVR3		0x3b2
#define C0SCOMPOFF3		0x3b4
#define C0DCOMP3		0x3b6
#define C0SLEWBASE3		0x3b8
#define C0SLEWPULUT3		0x3ba
#define C0SLEWPDLUT3		0x3be
#define C0DCOMPOVR3		0x3c2
#define C0DCOMPOFF3		0x3c6

/* RCOMP 4 */
#define C0RCOMPCTRL4		0x3d0
#define C0RCOMPMULT4		0x3d4
#define C0RCOMPOVR4		0x3d6
#define C0RCOMPOSV4		0x3da
#define C0SCOMPVREF4		0x3de
#define C0SCOMPOVR4		0x3e0
#define C0SCOMPOFF4		0x3e2
#define C0DCOMP4		0x3e4
#define C0SLEWBASE4		0x3e6
#define C0SLEWPULUT4		0x3e8
#define C0SLEWPDLUT4		0x3ec
#define C0DCOMPOVR4		0x3f0
#define C0DCOMPOFF4		0x3f4

/* RCOMP 5 */
#define C0RCOMPCTRL5		0x3fe
#define C0RCOMPMULT5		0x402
#define C0RCOMPOVR5		0x404
#define C0RCOMPOSV5		0x408
#define C0SCOMPVREF5		0x40c
#define C0SCOMPOVR5		0x40e
#define C0SCOMPOFF5		0x410
#define C0DCOMP5		0x412
#define C0SLEWBASE5		0x414
#define C0SLEWPULUT5		0x416
#define C0SLEWPDLUT5		0x41a
#define C0DCOMPOVR5		0x41e
#define C0DCOMPOFF5		0x422

/* RCOMP 6 */
#define C0RCOMPCTRL6		0x42c
#define C0RCOMPMULT6		0x430
#define C0RCOMPOVR6		0x432
#define C0RCOMPOSV6		0x436
#define C0SCOMPVREF6		0x43a
#define C0SCOMPOVR6		0x43c
#define C0SCOMPOFF6		0x43e
#define C0DCOMP6		0x440
#define C0SLEWBASE6		0x442
#define C0SLEWPULUT6		0x444
#define C0SLEWPDLUT6		0x448
#define C0DCOMPOVR6		0x44c
#define C0DCOMPOFF6		0x450

#define C0ODTRECORDX		0x45a
#define C0DQSODTRECORDX		0x462
#define XCOMPSDR0BNS		0x4b0
#define C0TXDQ0R0DLL		0x500
#define C0TXDQ0R1DLL		0x501
#define C0TXDQ0R2DLL		0x502
#define C0TXDQ0R3DLL		0x503
#define C0TXDQ1R0DLL		0x504
#define C0TXDQ1R1DLL		0x505
#define C0TXDQ1R2DLL		0x506
#define C0TXDQ1R3DLL		0x507
#define C0TXDQ2R0DLL		0x508
#define C0TXDQ2R1DLL		0x509
#define C0TXDQ2R2DLL		0x50a
#define C0TXDQ2R3DLL		0x50b
#define C0TXDQ3R0DLL		0x50c
#define C0TXDQ3R1DLL		0x50d
#define C0TXDQ3R2DLL		0x50e
#define C0TXDQ3R3DLL		0x50f
#define C0TXDQ4R0DLL		0x510
#define C0TXDQ4R1DLL		0x511
#define C0TXDQ4R2DLL		0x512
#define C0TXDQ4R3DLL		0x513
#define C0TXDQ5R0DLL		0x514
#define C0TXDQ5R1DLL		0x515
#define C0TXDQ5R2DLL		0x516
#define C0TXDQ5R3DLL		0x517
#define C0TXDQ6R0DLL		0x518
#define C0TXDQ6R1DLL		0x519
#define C0TXDQ6R2DLL		0x51a
#define C0TXDQ6R3DLL		0x51b
#define C0TXDQ7R0DLL		0x51c
#define C0TXDQ7R1DLL		0x51d
#define C0TXDQ7R2DLL		0x51e
#define C0TXDQ7R3DLL		0x51f
#define C0TXDQS0R0DLL		0x520
#define C0TXDQS0R1DLL		0x521
#define C0TXDQS0R2DLL		0x522
#define C0TXDQS0R3DLL		0x523
#define C0TXDQS1R0DLL		0x524
#define C0TXDQS1R1DLL		0x525
#define C0TXDQS1R2DLL		0x526
#define C0TXDQS1R3DLL		0x527
#define C0TXDQS2R0DLL		0x528
#define C0TXDQS2R1DLL		0x529
#define C0TXDQS2R2DLL		0x52a
#define C0TXDQS2R3DLL		0x52b
#define C0TXDQS3R0DLL		0x52c
#define C0TXDQS3R1DLL		0x52d
#define C0TXDQS3R2DLL		0x52e
#define C0TXDQS3R3DLL		0x52f
#define C0TXDQS4R0DLL		0x530
#define C0TXDQS4R1DLL		0x531
#define C0TXDQS4R2DLL		0x532
#define C0TXDQS4R3DLL		0x533
#define C0TXDQS5R0DLL		0x534
#define C0TXDQS5R1DLL		0x535
#define C0TXDQS5R2DLL		0x536
#define C0TXDQS5R3DLL		0x537
#define C0TXDQS6R0DLL		0x538
#define C0TXDQS6R1DLL		0x539
#define C0TXDQS6R2DLL		0x53a
#define C0TXDQS6R3DLL		0x53b
#define C0TXDQS7R0DLL		0x53c
#define C0TXDQS7R1DLL		0x53d
#define C0TXDQS7R2DLL		0x53e
#define C0TXDQS7R3DLL		0x53f

#define C0DLLRCVCTLy(y)		Ly(0x540, y)
#define C0RXRCVyDLL(y)		Ly(0x560, y)
#define C0MISCCTLy(y)		Ly(0x561, y)

#define C0TXCMD0DLL		0x580
#define C0TXCK0DLL		0x581
#define C0TXCK1DLL		0x582
#define C0TXCMD1DLL		0x583
#define C0TXCTL0DLL		0x584
#define C0TXCTL1DLL		0x585
#define C0TXCTL2DLL		0x586
#define C0TXCTL3DLL		0x587
#define C0RCVMISCCTL1		0x588
#define C0RCVMISCCTL2		0x58c
#define C0MCHODTMISCCTL1	0x590
#define C0DYNSLVDLLEN		0x592
#define C0CMDTX1		0x594
#define C0CMDTX2		0x598
#define C0CTLTX2		0x59c
#define C0CKTX			0x5a0

#define C0DQRyTX1(y)		Ly(0x5a4, y)
#define C0DQSRyTX1(y)		Ly(0x5b4, y)

#define C0DQSDQTX2		0x5c4

#define C0DQSDQRyTX3(y)		Ly(0x5c8, y)

#define C0RSTCTL		0x5d8
#define C0MISCCTL		0x5d9
#define C0MISC2			0x5da
#define C0BONUS			0x5db
#define CMNDQFIFORST		0x5dc
#define C0IOBUFACTCTL		0x5dd
#define C0BONUS2		0x5de
#define C0DLLPIEN		0x5f0
#define C0COARSEDLY0		0x5fa
#define C0COARSEDLY1		0x5fc
#define SHC3C4REG2		0x610
#define SHC3C4REG3		0x612
#define SHC3C4REG4		0x614
#define SHCYCTRKCKEL		0x62c
#define SHCYCTRKACTSFLV		0x630
#define SHCYCTRKPCHGSFLV	0x634
#define C1COREBONUS		0x6c0
#define CLOCKGATINGII		0x6d1
#define CLKXSSH2MCBYPPHAS	0x6d4
#define CLKXSSH2MCBYP		0x6d8
#define CLKXSSH2MCRDQ		0x6e0
#define CLKXSSH2MCRDCST		0x6e8
#define CLKXSSMC2H		0x6f0
#define CLKXSSMC2HALT		0x6f8
#define CLKXSSH2MD		0x700
#define CLKXSSH2X2MD		0x708
#define XSBFTCTL		0xb00
#define XSBFTDRR		0xb04
#define DACGIOCTRL1		0xb08
#define CLKCFG			0xc00
#define HMCCMP			0xc04
#define HMCCMC			0xc08
#define HMPLLO			0xc10
#define CPCTL			0xc1c
#define SSKPD			0xc20
#define HMCCPEXT		0xc28
#define HMDCPEXT		0xc2c
#define CPBUP			0xc30
#define HMBYPEXT		0xc34
#define HPLLVCO			0xc38
#define HPLLMONCTLA		0xc3c
#define HPLLMONCTLB		0xc40
#define HPLLMONCTLC		0xc44
#define DPLLMONCTLA		0xc48
#define DPLLMONCTLB		0xc4c
#define HMDCMP			0xc50
#define HMBYPCP			0xc54
#define FLRCSSEL		0xc58
#define DPLLMONCTLC		0xc5c
#define MPLLMONCTLA		0xc60
#define MPLLMONCTLB		0xc64
#define MPLLMONCTLC		0xc68
#define PLLFUSEOVR1		0xc70
#define PLLFUSEOVR2		0xc74
#define GCRCSCP			0xc80
#define GCRCSCMP		0xc84
#define GCRCSBYPCP		0xc86
#define GCPLLO			0xc88
#define MCH_GCFGC		0xc8c	/* Note: 'GCFGC' is also defined in 'i915_reg.h' */
#define GTDPCTSHOTTH		0xd00
#define GTDPCTSHOTTH2		0xd04
#define MTDPCTSHOTTH		0xd08
#define MTDPCTSHOTTH2		0xd0c
#define TSROTDPC		0xd10
#define TSMISC			0xd14
#define TEST_MC			0xe00
#define APSMCTL			0xe04
#define DFT_STRAP1		0xe08
#define DFT_STRAP2		0xe0c
#define CFGFUSE1		0xe10
#define FUSEOVR1		0xe1c
#define FUSEOVR2		0xe20
#define FUSEOVR3		0xe24
#define FUSEOVR4		0xe28
#define NOA_RCOMP		0xe2c
#define NOAR1			0xe30
#define NOAR2			0xe34
#define NOAR3			0xe38
#define NOAR4			0xe3c
#define NOAR5			0xe40
#define NOAR6			0xe44
#define NOAR7			0xe48
#define NOAR8			0xe4c
#define NOAR9			0xe50
#define NOAR10			0xe54
#define ODOC1			0xe58
#define ODOC2			0xe5c
#define ODOSTAT			0xe60
#define ODOSTAT2		0xe64
#define ODOSTAT3		0xe68
#define DPLLMMC			0xe6c
#define CFGFUSE2		0xe70
#define FUSEOVR5		0xe78
#define NOA_LVDSCTRL		0xe7c
#define NOABUFMSK		0xe80
#define PMCFG			0xf10
#define PMSTS			0xf14
#define PMMISC			0xf18
#define GTDPCNME		0xf20
#define GTDPCTW			0xf24
#define GTDPCTW2		0xf28
#define GTDPTWHOTTH		0xf2c
#define GTDPTWHOTTH2		0xf30
#define GTDPTWHOTTH3		0xf34
#define GTDPTWHOTTH4		0xf38
#define GTDPTWAUXTH		0xf3c
#define GTDPCTWIRTH		0xf40
#define GTDPCTWIRTH2NMISC	0xf44
#define GTDPHTM			0xf48
#define GTDPHTM2		0xf4c
#define GTDPHTM3		0xf50
#define GTDPHTM4		0xf54
#define GTDPAHTMOV		0xf58
#define GTDPAHTMOV2		0xf5c
#define GTDPAHTMOV3		0xf60
#define GTDPAHTMOV4		0xf64
#define GTDPATM			0xf68
#define GTDPCGC			0xf6c
#define PCWBFC			0xf90
#define SCWBFC			0xf98
#define SBCTL			0xfa0
#define SBCTL2			0xfa4
#define PCWBPFC			0xfa8
#define SBCTL3			0xfac
#define SBCLKGATECTRL		0xfb0
#define SBBONUS0		0xfb4
#define SBBONUS1		0xfb6
#define PSMICTL			0xfc0
#define PSMIMBASE		0xfc4
#define PSMIMLIMIT		0xfc8
#define PSMIDEBUG		0xfcc
#define PSMICTL2		0xfd0
#define PSMIRPLYNOAMAP		0xfd4
#define CICGDIS			0xff0
#define CICTRL			0xff4
#define CISDCTRL		0xff8
#define CIMBSR			0xffc
#define GFXC3C4			0x1104
#define PMDSLFRC		0x1108
#define PMMSPMRES		0x110c
#define PMCLKRC			0x1110
#define PMPXPRC			0x1114
#define PMC6CTL			0x111c
#define PMICHTST		0x1120
#define PMBAK			0x1124
#define C0TXDQDQS0MISC		0x2800
#define C0TXDQDQS1MISC		0x2804
#define C0TXDQDQS2MISC		0x2808
#define C0TXDQDQS3MISC		0x280c
#define C0TXDQDQS4MISC		0x2810
#define C0TXDQDQS5MISC		0x2814
#define C0TXDQDQS6MISC		0x2818
#define C0TXDQDQS7MISC		0x281c
#define CSHRPDCTL5		0x2c00
#define CSHWRIOBONUSX		0x2c02
#define C0CALRESULT1		0x2c04
#define C0CALRESULT2		0x2c08
#define C0MODREFOFFSET1		0x2c0c
#define C0MODREFOFFSET2		0x2c10
#define C0SLVDLLOUTEN		0x2c14
#define C0DYNSLVDLLEN2		0x2c15
#define LVDSICR1		0x3000
#define LVDSICR2		0x3004
#define IOCKTRR1		0x3008
#define IOCKTRR2		0x300c
#define IOCKTRR3		0x3010
#define IOCKTSTTR		0x3014
#define IUB			0x3800
#define BIR			0x3804
#define TSC1			0x3808
#define TSC2			0x3809
#define TSS			0x380a
#define TR			0x380b
#define TSTTP			0x380c
#define TCO			0x3812
#define TST			0x3813
#define THERM1			0x3814
#define THERM3			0x3816
#define TIS			0x381a
#define TERRCMD			0x3820
#define TSMICMD			0x3821
#define TSCICMD			0x3822
#define TSC3			0x3824
#define EXTTSCS			0x3825
#define C0THRMSTS		0x3830

#endif	/* __PINEVIEW_MCHBAR_REGS_H__ */