cachepc-linux

Fork of AMDESE/linux with modifications for CachePC side-channel attack
git clone https://git.sinitax.com/sinitax/cachepc-linux
Log | Files | Refs | README | LICENSE | sfeed.txt

nwl-dsi.h (4728B)


      1/* SPDX-License-Identifier: GPL-2.0+ */
      2/*
      3 * NWL MIPI DSI host driver
      4 *
      5 * Copyright (C) 2017 NXP
      6 * Copyright (C) 2019 Purism SPC
      7 */
      8#ifndef __NWL_DSI_H__
      9#define __NWL_DSI_H__
     10
     11/* DSI HOST registers */
     12#define NWL_DSI_CFG_NUM_LANES			0x0
     13#define NWL_DSI_CFG_NONCONTINUOUS_CLK		0x4
     14#define NWL_DSI_CFG_T_PRE			0x8
     15#define NWL_DSI_CFG_T_POST			0xc
     16#define NWL_DSI_CFG_TX_GAP			0x10
     17#define NWL_DSI_CFG_AUTOINSERT_EOTP		0x14
     18#define NWL_DSI_CFG_EXTRA_CMDS_AFTER_EOTP	0x18
     19#define NWL_DSI_CFG_HTX_TO_COUNT		0x1c
     20#define NWL_DSI_CFG_LRX_H_TO_COUNT		0x20
     21#define NWL_DSI_CFG_BTA_H_TO_COUNT		0x24
     22#define NWL_DSI_CFG_TWAKEUP			0x28
     23#define NWL_DSI_CFG_STATUS_OUT			0x2c
     24#define NWL_DSI_RX_ERROR_STATUS			0x30
     25
     26/* DSI DPI registers */
     27#define NWL_DSI_PIXEL_PAYLOAD_SIZE		0x200
     28#define NWL_DSI_PIXEL_FIFO_SEND_LEVEL		0x204
     29#define NWL_DSI_INTERFACE_COLOR_CODING		0x208
     30#define NWL_DSI_PIXEL_FORMAT			0x20c
     31#define NWL_DSI_VSYNC_POLARITY			0x210
     32#define NWL_DSI_VSYNC_POLARITY_ACTIVE_LOW	0
     33#define NWL_DSI_VSYNC_POLARITY_ACTIVE_HIGH	BIT(1)
     34
     35#define NWL_DSI_HSYNC_POLARITY			0x214
     36#define NWL_DSI_HSYNC_POLARITY_ACTIVE_LOW	0
     37#define NWL_DSI_HSYNC_POLARITY_ACTIVE_HIGH	BIT(1)
     38
     39#define NWL_DSI_VIDEO_MODE			0x218
     40#define NWL_DSI_HFP				0x21c
     41#define NWL_DSI_HBP				0x220
     42#define NWL_DSI_HSA				0x224
     43#define NWL_DSI_ENABLE_MULT_PKTS		0x228
     44#define NWL_DSI_VBP				0x22c
     45#define NWL_DSI_VFP				0x230
     46#define NWL_DSI_BLLP_MODE			0x234
     47#define NWL_DSI_USE_NULL_PKT_BLLP		0x238
     48#define NWL_DSI_VACTIVE				0x23c
     49#define NWL_DSI_VC				0x240
     50
     51/* DSI APB PKT control */
     52#define NWL_DSI_TX_PAYLOAD			0x280
     53#define NWL_DSI_PKT_CONTROL			0x284
     54#define NWL_DSI_SEND_PACKET			0x288
     55#define NWL_DSI_PKT_STATUS			0x28c
     56#define NWL_DSI_PKT_FIFO_WR_LEVEL		0x290
     57#define NWL_DSI_PKT_FIFO_RD_LEVEL		0x294
     58#define NWL_DSI_RX_PAYLOAD			0x298
     59#define NWL_DSI_RX_PKT_HEADER			0x29c
     60
     61/* DSI IRQ handling */
     62#define NWL_DSI_IRQ_STATUS			0x2a0
     63#define NWL_DSI_SM_NOT_IDLE			BIT(0)
     64#define NWL_DSI_TX_PKT_DONE			BIT(1)
     65#define NWL_DSI_DPHY_DIRECTION			BIT(2)
     66#define NWL_DSI_TX_FIFO_OVFLW			BIT(3)
     67#define NWL_DSI_TX_FIFO_UDFLW			BIT(4)
     68#define NWL_DSI_RX_FIFO_OVFLW			BIT(5)
     69#define NWL_DSI_RX_FIFO_UDFLW			BIT(6)
     70#define NWL_DSI_RX_PKT_HDR_RCVD			BIT(7)
     71#define NWL_DSI_RX_PKT_PAYLOAD_DATA_RCVD	BIT(8)
     72#define NWL_DSI_BTA_TIMEOUT			BIT(29)
     73#define NWL_DSI_LP_RX_TIMEOUT			BIT(30)
     74#define NWL_DSI_HS_TX_TIMEOUT			BIT(31)
     75
     76#define NWL_DSI_IRQ_STATUS2			0x2a4
     77#define NWL_DSI_SINGLE_BIT_ECC_ERR		BIT(0)
     78#define NWL_DSI_MULTI_BIT_ECC_ERR		BIT(1)
     79#define NWL_DSI_CRC_ERR				BIT(2)
     80
     81#define NWL_DSI_IRQ_MASK			0x2a8
     82#define NWL_DSI_SM_NOT_IDLE_MASK		BIT(0)
     83#define NWL_DSI_TX_PKT_DONE_MASK		BIT(1)
     84#define NWL_DSI_DPHY_DIRECTION_MASK		BIT(2)
     85#define NWL_DSI_TX_FIFO_OVFLW_MASK		BIT(3)
     86#define NWL_DSI_TX_FIFO_UDFLW_MASK		BIT(4)
     87#define NWL_DSI_RX_FIFO_OVFLW_MASK		BIT(5)
     88#define NWL_DSI_RX_FIFO_UDFLW_MASK		BIT(6)
     89#define NWL_DSI_RX_PKT_HDR_RCVD_MASK		BIT(7)
     90#define NWL_DSI_RX_PKT_PAYLOAD_DATA_RCVD_MASK	BIT(8)
     91#define NWL_DSI_BTA_TIMEOUT_MASK		BIT(29)
     92#define NWL_DSI_LP_RX_TIMEOUT_MASK		BIT(30)
     93#define NWL_DSI_HS_TX_TIMEOUT_MASK		BIT(31)
     94
     95#define NWL_DSI_IRQ_MASK2			0x2ac
     96#define NWL_DSI_SINGLE_BIT_ECC_ERR_MASK		BIT(0)
     97#define NWL_DSI_MULTI_BIT_ECC_ERR_MASK		BIT(1)
     98#define NWL_DSI_CRC_ERR_MASK			BIT(2)
     99
    100/*
    101 * PKT_CONTROL format:
    102 * [15: 0] - word count
    103 * [17:16] - virtual channel
    104 * [23:18] - data type
    105 * [24]	   - LP or HS select (0 - LP, 1 - HS)
    106 * [25]	   - perform BTA after packet is sent
    107 * [26]	   - perform BTA only, no packet tx
    108 */
    109#define NWL_DSI_WC(x)		FIELD_PREP(GENMASK(15, 0), (x))
    110#define NWL_DSI_TX_VC(x)	FIELD_PREP(GENMASK(17, 16), (x))
    111#define NWL_DSI_TX_DT(x)	FIELD_PREP(GENMASK(23, 18), (x))
    112#define NWL_DSI_HS_SEL(x)	FIELD_PREP(GENMASK(24, 24), (x))
    113#define NWL_DSI_BTA_TX(x)	FIELD_PREP(GENMASK(25, 25), (x))
    114#define NWL_DSI_BTA_NO_TX(x)	FIELD_PREP(GENMASK(26, 26), (x))
    115
    116/*
    117 * RX_PKT_HEADER format:
    118 * [15: 0] - word count
    119 * [21:16] - data type
    120 * [23:22] - virtual channel
    121 */
    122#define NWL_DSI_RX_DT(x)	FIELD_GET(GENMASK(21, 16), (x))
    123#define NWL_DSI_RX_VC(x)	FIELD_GET(GENMASK(23, 22), (x))
    124
    125/* DSI Video mode */
    126#define NWL_DSI_VM_BURST_MODE_WITH_SYNC_PULSES		0
    127#define NWL_DSI_VM_NON_BURST_MODE_WITH_SYNC_EVENTS	BIT(0)
    128#define NWL_DSI_VM_BURST_MODE				BIT(1)
    129
    130/* * DPI color coding */
    131#define NWL_DSI_DPI_16_BIT_565_PACKED	0
    132#define NWL_DSI_DPI_16_BIT_565_ALIGNED	1
    133#define NWL_DSI_DPI_16_BIT_565_SHIFTED	2
    134#define NWL_DSI_DPI_18_BIT_PACKED	3
    135#define NWL_DSI_DPI_18_BIT_ALIGNED	4
    136#define NWL_DSI_DPI_24_BIT		5
    137
    138/* * DPI Pixel format */
    139#define NWL_DSI_PIXEL_FORMAT_16  0
    140#define NWL_DSI_PIXEL_FORMAT_18  BIT(0)
    141#define NWL_DSI_PIXEL_FORMAT_18L BIT(1)
    142#define NWL_DSI_PIXEL_FORMAT_24  (BIT(0) | BIT(1))
    143
    144#endif /* __NWL_DSI_H__ */