Logo Search packages:      
Sourcecode: xbox-cromwell version File versions  Download package

BootVgaInitialization.h

#ifndef BOOTVGAINITIALIZATION_H
#define BOOTVGAINITIALIZATION_H

/* Standard VGA registers */
#define VGA_ATTR_INDEX          0x3C0
#define VGA_ATTR_DATA_W         0x3C0
#define VGA_ATTR_DATA_R         0x3C1
#define VGA_IN_STAT_0           0x3C2           /* read */
#define VGA_MISC_OUT_W          0x3C2           /* write */
#define VGA_ENABLE              0x3C3
#define VGA_SEQ_INDEX           0x3C4
#define VGA_SEQ_DATA            0x3C5
#define VGA_DAC_MASK            0x3C6
#define VGA_DAC_READ_ADDR       0x3C7
#define VGA_DAC_WRITE_ADDR      0x3C8
#define VGA_DAC_DATA            0x3C9
#define VGA_FEATURE_R           0x3CA           /* read */
#define VGA_MISC_OUT_R          0x3CC           /* read */
#define VGA_GRAPH_INDEX         0x3CE
#define VGA_GRAPH_DATA          0x3CF

#define VGA_IOBASE_MONO         0x3B0
#define VGA_IOBASE_COLOR        0x3D0

#define VGA_CRTC_INDEX_OFFSET   0x04
#define VGA_CRTC_DATA_OFFSET    0x05
#define VGA_IN_STAT_1_OFFSET    0x0A            /* read */
#define VGA_FEATURE_W_OFFSET    0x0A            /* write */

/* Little macro to construct bitmask for contiguous ranges of bits */

#define BITMASK(t,b) (((unsigned)(1U << (((t)-(b)+1)))-1)  << (b))
#define MASKEXPAND(mask) BITMASK(1?mask,0?mask)

/* Macro to set specific bitfields (mask has to be a macro x:y) ! */

#define SetBF(mask,value) ((value) << (0?mask))
#define GetBF(var,mask) (((unsigned)((var) & MASKEXPAND(mask))) >> (0?mask) )

#define MaskAndSetBF(var,mask,value) (var)=(((var)&(~MASKEXPAND(mask)) \
                                             | SetBF(mask,value)))

/* SetBitField: Move bit-range in 'from' to bit-range in 'to' */

#define SetBitField(value,from,to) SetBF(to, GetBF(value,from))
#define SetBitFlag(value,mask,to) ((value & mask) ? (1 << to) : 0)
#define SetBit(n) (1<<(n))
#define GetBit(value,n) ((value)&(1<<(n)))
#define GetBitFlag(value,from,mask) (GetBit(value,from) ? mask : 0)
#define Set8Bits(value) ((value)&0xff)

#define HEAD 0x2000

#define CARD8 u8
#define CARD32 u32

#define MMIO_IN8(base, offset) \
        *(volatile CARD8 *)(((CARD8*)(base)) + (offset))
#define MMIO_IN16(base, offset) \
        *(volatile CARD16 *)(void *)(((CARD8*)(base)) + (offset))
#define MMIO_IN32(base, offset) \
        *(volatile CARD32 *)(void *)(((CARD8*)(base)) + (offset))
#define MMIO_OUT8(base, offset, val) \
        *(volatile CARD8 *)(((CARD8*)(base)) + (offset)) = (val)
#define MMIO_OUT16(base, offset, val) \
        *(volatile CARD16 *)(void *)(((CARD8*)(base)) + (offset)) = (val)
#define MMIO_OUT32(base, offset, val) \
        *(volatile CARD32 *)(void *)(((CARD8*)(base)) + (offset)) = (val)
#define MMIO_ONB8(base, offset, val) MMIO_OUT8(base, offset, val)
#define MMIO_ONB16(base, offset, val) MMIO_OUT16(base, offset, val)
#define MMIO_ONB32(base, offset, val) MMIO_OUT32(base, offset, val)

#define MMIO_H_IN8(base,h,offset) MMIO_IN8(base,(offset)+(h)*HEAD)
#define MMIO_H_IN32(base,h,offset) MMIO_IN32(base,(offset)+(h)*HEAD)
#define MMIO_H_OUT8(base,h,offset,val) MMIO_OUT8(base,(offset)+(h)*HEAD,val)
#define MMIO_H_OUT32(base,h,offset,val) MMIO_OUT32(base,(offset)+(h)*HEAD,val)

#define MMIO_H_AND32(base,h,offset,val) MMIO_AND32(base,(offset)+(h)*HEAD,val)
#define MMIO_H_OR32(base,h,offset,val) MMIO_OR32(base,(offset)+(h)*HEAD,val)

#define MMIO_AND32(base, offset, val) \
        *(volatile CARD32 *)(void *)(((CARD8*)(base)) + (offset)) &= (val)
#define MMIO_OR32(base, offset, val) \
        *(volatile CARD32 *)(void *)(((CARD8*)(base)) + (offset)) |= (val)


/* these assume memory-mapped I/O, and not normal I/O space */
#define NV_WR08(p,i,d)  MMIO_OUT8((volatile void *)(p), (i), (d))
#define NV_RD08(p,i)    MMIO_IN8((volatile void *)(p), (i))
#define NV_WR16(p,i,d)  MMIO_OUT16((volatile void *)(p), (i), (d))
#define NV_RD16(p,i)    MMIO_IN16((volatile void *)(p), (i))
#define NV_WR32(p,i,d)  MMIO_OUT32((volatile void *)(p), (i), (d))
#define NV_RD32(p,i)    MMIO_IN32((volatile void *)(p), (i))

#define VGA_WR08(p,i,d) NV_WR08(p,i,d)
#define VGA_RD08(p,i)   NV_RD08(p,i)

#define CRT_INDEX(h) (0x3d4 + (h) * HEAD)
#define CRT_DATA(h)  (0x3d5 + (h) * HEAD)

#define NV_FLAG_DOUBLE_PIX    (1 << 1)
#define NV_FLAG_DOUBLE_SCAN   (1 << 0)

#define DEV_TELEVISION        (1 << 1)
#define DEV_FLATPANEL         (1 << 2)

#define NVCRTC 0x6013D4

typedef struct _riva_hw_inst
{
      /*
      * Non-FIFO registers.
      */
      volatile u8 *PCRTC;
      volatile u8 *PRAMDAC;
      volatile u8 *PFB;
      volatile u8 *PFIFO;
      volatile u8 *PGRAPH;
      volatile u8 *PEXTDEV;
      volatile u8 *PTIMER;
      volatile u8 *PMC;
      volatile u8 *PRAMIN;
      volatile u8 *FIFO;
      volatile u8 *CURSOR;
      volatile u8 *CURSORPOS;
      volatile u8 *VBLANKENABLE;
      volatile u8 *VBLANK;

      volatile u8 *PCIO;
      volatile u8 *PVIO;
      volatile u8 *PDIO;
      volatile u8 *PVIDEO;
} RIVA_HW_INST;

// function prototypes, not to be called from outside BootVgaInitialization
static void mapNvMem (RIVA_HW_INST *riva, u8 *IOAddress);
static void NVDisablePalette (RIVA_HW_INST *riva, int head);
static void NVWriteSeq(RIVA_HW_INST *riva, CARD8 index, CARD8 value);
static void NVWriteGr(RIVA_HW_INST *riva, CARD8 index, CARD8 value);
static void NVInitGrSeq (RIVA_HW_INST *riva);
static void NVInitAttr (RIVA_HW_INST *riva, int head);
static inline void unlockCrtNv (RIVA_HW_INST *riva, int head);
static inline void lockCrtNv (RIVA_HW_INST *riva, int head);
static void writeCrtNv (RIVA_HW_INST *riva, int head, int reg, u8 val);
static void NVVertIntrEnabled (RIVA_HW_INST *riva, int head);
static void NVSetFBStart (RIVA_HW_INST *riva, int head, u32 dwFBStart);

#endif

Generated by  Doxygen 1.6.0   Back to index