1 /* SPDX-License-Identifier: GPL-2.0-or-later */ 2 /* Hisilicon Hibmc SoC drm driver 3 * 4 * Based on the bochs drm driver. 5 * 6 * Copyright (c) 2016 Huawei Limited. 7 * 8 * Author: 9 * Rongrong Zou <zourongrong@huawei.com> 10 * Rongrong Zou <zourongrong@gmail.com> 11 * Jianhua Li <lijianhua@huawei.com> 12 */ 13 14 #ifndef HIBMC_DRM_HW_H 15 #define HIBMC_DRM_HW_H 16 17 /* register definition */ 18 #define HIBMC_MISC_CTRL 0x4 19 20 #define HIBMC_MSCCTL_LOCALMEM_RESET(x) ((x) << 6) 21 #define HIBMC_MSCCTL_LOCALMEM_RESET_MASK 0x40 22 23 #define HIBMC_CURRENT_GATE 0x000040 24 #define HIBMC_CURR_GATE_DISPLAY(x) ((x) << 2) 25 #define HIBMC_CURR_GATE_DISPLAY_MASK 0x4 26 27 #define HIBMC_CURR_GATE_LOCALMEM(x) ((x) << 1) 28 #define HIBMC_CURR_GATE_LOCALMEM_MASK 0x2 29 30 #define HIBMC_MODE0_GATE 0x000044 31 #define HIBMC_MODE1_GATE 0x000048 32 #define HIBMC_POWER_MODE_CTRL 0x00004C 33 34 #define HIBMC_PW_MODE_CTL_OSC_INPUT(x) ((x) << 3) 35 #define HIBMC_PW_MODE_CTL_OSC_INPUT_MASK 0x8 36 37 #define HIBMC_PW_MODE_CTL_MODE(x) ((x) << 0) 38 #define HIBMC_PW_MODE_CTL_MODE_MASK 0x03 39 #define HIBMC_PW_MODE_CTL_MODE_SHIFT 0 40 41 #define HIBMC_PW_MODE_CTL_MODE_MODE0 0 42 #define HIBMC_PW_MODE_CTL_MODE_MODE1 1 43 #define HIBMC_PW_MODE_CTL_MODE_SLEEP 2 44 45 #define HIBMC_PANEL_PLL_CTRL 0x00005C 46 #define HIBMC_CRT_PLL_CTRL 0x000060 47 48 #define HIBMC_PLL_CTRL_BYPASS(x) ((x) << 18) 49 #define HIBMC_PLL_CTRL_BYPASS_MASK 0x40000 50 51 #define HIBMC_PLL_CTRL_POWER(x) ((x) << 17) 52 #define HIBMC_PLL_CTRL_POWER_MASK 0x20000 53 54 #define HIBMC_PLL_CTRL_INPUT(x) ((x) << 16) 55 #define HIBMC_PLL_CTRL_INPUT_MASK 0x10000 56 57 #define HIBMC_PLL_CTRL_POD(x) ((x) << 14) 58 #define HIBMC_PLL_CTRL_POD_MASK 0xC000 59 60 #define HIBMC_PLL_CTRL_OD(x) ((x) << 12) 61 #define HIBMC_PLL_CTRL_OD_MASK 0x3000 62 63 #define HIBMC_PLL_CTRL_N(x) ((x) << 8) 64 #define HIBMC_PLL_CTRL_N_MASK 0xF00 65 66 #define HIBMC_PLL_CTRL_M(x) ((x) << 0) 67 #define HIBMC_PLL_CTRL_M_MASK 0xFF 68 69 #define HIBMC_CRT_DISP_CTL 0x80200 70 71 #define HIBMC_CRT_DISP_CTL_DPMS(x) ((x) << 30) 72 #define HIBMC_CRT_DISP_CTL_DPMS_MASK 0xc0000000 73 74 #define HIBMC_CRT_DPMS_ON 0 75 #define HIBMC_CRT_DPMS_OFF 3 76 77 #define HIBMC_CRT_DISP_CTL_CRTSELECT(x) ((x) << 25) 78 #define HIBMC_CRT_DISP_CTL_CRTSELECT_MASK 0x2000000 79 80 #define HIBMC_CRTSELECT_CRT 1 81 82 #define HIBMC_CRT_DISP_CTL_CLOCK_PHASE(x) ((x) << 14) 83 #define HIBMC_CRT_DISP_CTL_CLOCK_PHASE_MASK 0x4000 84 85 #define HIBMC_CRT_DISP_CTL_VSYNC_PHASE(x) ((x) << 13) 86 #define HIBMC_CRT_DISP_CTL_VSYNC_PHASE_MASK 0x2000 87 88 #define HIBMC_CRT_DISP_CTL_HSYNC_PHASE(x) ((x) << 12) 89 #define HIBMC_CRT_DISP_CTL_HSYNC_PHASE_MASK 0x1000 90 91 #define HIBMC_CRT_DISP_CTL_TIMING(x) ((x) << 8) 92 #define HIBMC_CRT_DISP_CTL_TIMING_MASK 0x100 93 94 #define HIBMC_CRT_DISP_CTL_PLANE(x) ((x) << 2) 95 #define HIBMC_CRT_DISP_CTL_PLANE_MASK 4 96 97 #define HIBMC_CRT_DISP_CTL_FORMAT(x) ((x) << 0) 98 #define HIBMC_CRT_DISP_CTL_FORMAT_MASK 0x03 99 100 #define HIBMC_CRT_FB_ADDRESS 0x080204 101 102 #define HIBMC_CRT_FB_WIDTH 0x080208 103 #define HIBMC_CRT_FB_WIDTH_WIDTH(x) ((x) << 16) 104 #define HIBMC_CRT_FB_WIDTH_WIDTH_MASK 0x3FFF0000 105 #define HIBMC_CRT_FB_WIDTH_OFFS(x) ((x) << 0) 106 #define HIBMC_CRT_FB_WIDTH_OFFS_MASK 0x3FFF 107 108 #define HIBMC_CRT_HORZ_TOTAL 0x08020C 109 #define HIBMC_CRT_HORZ_TOTAL_TOTAL(x) ((x) << 16) 110 #define HIBMC_CRT_HORZ_TOTAL_TOTAL_MASK 0xFFF0000 111 112 #define HIBMC_CRT_HORZ_TOTAL_DISP_END(x) ((x) << 0) 113 #define HIBMC_CRT_HORZ_TOTAL_DISP_END_MASK 0xFFF 114 115 #define HIBMC_CRT_HORZ_SYNC 0x080210 116 #define HIBMC_CRT_HORZ_SYNC_WIDTH(x) ((x) << 16) 117 #define HIBMC_CRT_HORZ_SYNC_WIDTH_MASK 0xFF0000 118 119 #define HIBMC_CRT_HORZ_SYNC_START(x) ((x) << 0) 120 #define HIBMC_CRT_HORZ_SYNC_START_MASK 0xFFF 121 122 #define HIBMC_CRT_VERT_TOTAL 0x080214 123 #define HIBMC_CRT_VERT_TOTAL_TOTAL(x) ((x) << 16) 124 #define HIBMC_CRT_VERT_TOTAL_TOTAL_MASK 0x7FFF0000 125 126 #define HIBMC_CRT_VERT_TOTAL_DISP_END(x) ((x) << 0) 127 #define HIBMC_CRT_VERT_TOTAL_DISP_END_MASK 0x7FF 128 129 #define HIBMC_CRT_VERT_SYNC 0x080218 130 #define HIBMC_CRT_VERT_SYNC_HEIGHT(x) ((x) << 16) 131 #define HIBMC_CRT_VERT_SYNC_HEIGHT_MASK 0x3F0000 132 133 #define HIBMC_CRT_VERT_SYNC_START(x) ((x) << 0) 134 #define HIBMC_CRT_VERT_SYNC_START_MASK 0x7FF 135 136 /* Auto Centering */ 137 #define HIBMC_CRT_AUTO_CENTERING_TL 0x080280 138 #define HIBMC_CRT_AUTO_CENTERING_TL_TOP(x) ((x) << 16) 139 #define HIBMC_CRT_AUTO_CENTERING_TL_TOP_MASK 0x7FF0000 140 141 #define HIBMC_CRT_AUTO_CENTERING_TL_LEFT(x) ((x) << 0) 142 #define HIBMC_CRT_AUTO_CENTERING_TL_LEFT_MASK 0x7FF 143 144 #define HIBMC_CRT_AUTO_CENTERING_BR 0x080284 145 #define HIBMC_CRT_AUTO_CENTERING_BR_BOTTOM(x) ((x) << 16) 146 #define HIBMC_CRT_AUTO_CENTERING_BR_BOTTOM_MASK 0x7FF0000 147 148 #define HIBMC_CRT_AUTO_CENTERING_BR_RIGHT(x) ((x) << 0) 149 #define HIBMC_CRT_AUTO_CENTERING_BR_RIGHT_MASK 0x7FF 150 151 /* register to control panel output */ 152 #define HIBMC_DISPLAY_CONTROL_HISILE 0x80288 153 #define HIBMC_DISPLAY_CONTROL_FPVDDEN(x) ((x) << 0) 154 #define HIBMC_DISPLAY_CONTROL_PANELDATE(x) ((x) << 1) 155 #define HIBMC_DISPLAY_CONTROL_FPEN(x) ((x) << 2) 156 #define HIBMC_DISPLAY_CONTROL_VBIASEN(x) ((x) << 3) 157 158 #define HIBMC_RAW_INTERRUPT 0x80290 159 #define HIBMC_RAW_INTERRUPT_VBLANK(x) ((x) << 2) 160 #define HIBMC_RAW_INTERRUPT_VBLANK_MASK 0x4 161 162 #define HIBMC_RAW_INTERRUPT_EN 0x80298 163 #define HIBMC_RAW_INTERRUPT_EN_VBLANK(x) ((x) << 2) 164 #define HIBMC_RAW_INTERRUPT_EN_VBLANK_MASK 0x4 165 166 /* register and values for PLL control */ 167 #define CRT_PLL1_HS 0x802a8 168 #define CRT_PLL1_HS_OUTER_BYPASS(x) ((x) << 30) 169 #define CRT_PLL1_HS_INTER_BYPASS(x) ((x) << 29) 170 #define CRT_PLL1_HS_POWERON(x) ((x) << 24) 171 172 #define CRT_PLL1_HS_25MHZ 0x23d40f02 173 #define CRT_PLL1_HS_40MHZ 0x23940801 174 #define CRT_PLL1_HS_65MHZ 0x23940d01 175 #define CRT_PLL1_HS_78MHZ 0x23540F82 176 #define CRT_PLL1_HS_74MHZ 0x23941dc2 177 #define CRT_PLL1_HS_80MHZ 0x23941001 178 #define CRT_PLL1_HS_80MHZ_1152 0x23540fc2 179 #define CRT_PLL1_HS_108MHZ 0x23b41b01 180 #define CRT_PLL1_HS_162MHZ 0x23480681 181 #define CRT_PLL1_HS_148MHZ 0x23541dc2 182 #define CRT_PLL1_HS_193MHZ 0x234807c1 183 184 #define CRT_PLL2_HS 0x802ac 185 #define CRT_PLL2_HS_25MHZ 0x206B851E 186 #define CRT_PLL2_HS_40MHZ 0x30000000 187 #define CRT_PLL2_HS_65MHZ 0x40000000 188 #define CRT_PLL2_HS_78MHZ 0x50E147AE 189 #define CRT_PLL2_HS_74MHZ 0x602B6AE7 190 #define CRT_PLL2_HS_80MHZ 0x70000000 191 #define CRT_PLL2_HS_108MHZ 0x80000000 192 #define CRT_PLL2_HS_162MHZ 0xA0000000 193 #define CRT_PLL2_HS_148MHZ 0xB0CCCCCD 194 #define CRT_PLL2_HS_193MHZ 0xC0872B02 195 196 #define HIBMC_FIELD(field, value) (field(value) & field##_MASK) 197 #endif 198