1*b2441318SGreg Kroah-Hartman /* SPDX-License-Identifier: GPL-2.0 */ 2f7018c21STomi Valkeinen #ifndef __RIVAFB_H 3f7018c21STomi Valkeinen #define __RIVAFB_H 4f7018c21STomi Valkeinen 5f7018c21STomi Valkeinen #include <linux/fb.h> 6f7018c21STomi Valkeinen #include <video/vga.h> 7f7018c21STomi Valkeinen #include <linux/i2c.h> 8f7018c21STomi Valkeinen #include <linux/i2c-algo-bit.h> 9f7018c21STomi Valkeinen 10f7018c21STomi Valkeinen #include "riva_hw.h" 11f7018c21STomi Valkeinen 12f7018c21STomi Valkeinen /* GGI compatibility macros */ 13f7018c21STomi Valkeinen #define NUM_SEQ_REGS 0x05 14f7018c21STomi Valkeinen #define NUM_CRT_REGS 0x41 15f7018c21STomi Valkeinen #define NUM_GRC_REGS 0x09 16f7018c21STomi Valkeinen #define NUM_ATC_REGS 0x15 17f7018c21STomi Valkeinen 18f7018c21STomi Valkeinen /* I2C */ 19f7018c21STomi Valkeinen #define DDC_SCL_READ_MASK (1 << 2) 20f7018c21STomi Valkeinen #define DDC_SCL_WRITE_MASK (1 << 5) 21f7018c21STomi Valkeinen #define DDC_SDA_READ_MASK (1 << 3) 22f7018c21STomi Valkeinen #define DDC_SDA_WRITE_MASK (1 << 4) 23f7018c21STomi Valkeinen 24f7018c21STomi Valkeinen /* holds the state of the VGA core and extended Riva hw state from riva_hw.c. 25f7018c21STomi Valkeinen * From KGI originally. */ 26f7018c21STomi Valkeinen struct riva_regs { 27f7018c21STomi Valkeinen u8 attr[NUM_ATC_REGS]; 28f7018c21STomi Valkeinen u8 crtc[NUM_CRT_REGS]; 29f7018c21STomi Valkeinen u8 gra[NUM_GRC_REGS]; 30f7018c21STomi Valkeinen u8 seq[NUM_SEQ_REGS]; 31f7018c21STomi Valkeinen u8 misc_output; 32f7018c21STomi Valkeinen RIVA_HW_STATE ext; 33f7018c21STomi Valkeinen }; 34f7018c21STomi Valkeinen 35f7018c21STomi Valkeinen struct riva_par; 36f7018c21STomi Valkeinen 37f7018c21STomi Valkeinen struct riva_i2c_chan { 38f7018c21STomi Valkeinen struct riva_par *par; 39f7018c21STomi Valkeinen unsigned long ddc_base; 40f7018c21STomi Valkeinen struct i2c_adapter adapter; 41f7018c21STomi Valkeinen struct i2c_algo_bit_data algo; 42f7018c21STomi Valkeinen }; 43f7018c21STomi Valkeinen 44f7018c21STomi Valkeinen struct riva_par { 45f7018c21STomi Valkeinen RIVA_HW_INST riva; /* interface to riva_hw.c */ 46f7018c21STomi Valkeinen u32 pseudo_palette[16]; /* default palette */ 47f7018c21STomi Valkeinen u32 palette[16]; /* for Riva128 */ 48f7018c21STomi Valkeinen u8 __iomem *ctrl_base; /* virtual control register base addr */ 49f7018c21STomi Valkeinen unsigned dclk_max; /* max DCLK */ 50f7018c21STomi Valkeinen 51f7018c21STomi Valkeinen struct riva_regs initial_state; /* initial startup video mode */ 52f7018c21STomi Valkeinen struct riva_regs current_state; 53f7018c21STomi Valkeinen #ifdef CONFIG_X86 54f7018c21STomi Valkeinen struct vgastate state; 55f7018c21STomi Valkeinen #endif 56f7018c21STomi Valkeinen struct mutex open_lock; 57f7018c21STomi Valkeinen unsigned int ref_count; 58f7018c21STomi Valkeinen unsigned char *EDID; 59f7018c21STomi Valkeinen unsigned int Chipset; 60f7018c21STomi Valkeinen int forceCRTC; 61f7018c21STomi Valkeinen Bool SecondCRTC; 62f7018c21STomi Valkeinen int FlatPanel; 63f7018c21STomi Valkeinen struct pci_dev *pdev; 64f7018c21STomi Valkeinen int cursor_reset; 6504dc78b4SLuis R. Rodriguez int wc_cookie; 66f7018c21STomi Valkeinen struct riva_i2c_chan chan[3]; 67f7018c21STomi Valkeinen }; 68f7018c21STomi Valkeinen 69f7018c21STomi Valkeinen void riva_common_setup(struct riva_par *); 70f7018c21STomi Valkeinen unsigned long riva_get_memlen(struct riva_par *); 71f7018c21STomi Valkeinen unsigned long riva_get_maxdclk(struct riva_par *); 72f7018c21STomi Valkeinen void riva_delete_i2c_busses(struct riva_par *par); 73f7018c21STomi Valkeinen void riva_create_i2c_busses(struct riva_par *par); 74f7018c21STomi Valkeinen int riva_probe_i2c_connector(struct riva_par *par, int conn, u8 **out_edid); 75f7018c21STomi Valkeinen 76f7018c21STomi Valkeinen #endif /* __RIVAFB_H */ 77