radeon_video.h revision b7e1c893
1209ff23fSmrg#ifndef __RADEON_VIDEO_H__ 2209ff23fSmrg#define __RADEON_VIDEO_H__ 3209ff23fSmrg 4209ff23fSmrg#include "xf86i2c.h" 5209ff23fSmrg#include "fi1236.h" 6209ff23fSmrg#include "msp3430.h" 7209ff23fSmrg#include "tda9885.h" 8209ff23fSmrg#include "uda1380.h" 9209ff23fSmrg#include "i2c_def.h" 10209ff23fSmrg 11209ff23fSmrg#include "generic_bus.h" 12209ff23fSmrg#include "theatre.h" 13209ff23fSmrg 14209ff23fSmrg#include "xf86Crtc.h" 15209ff23fSmrg 16b7e1c893Smrg#include "bicubic_table.h" 17b7e1c893Smrg 18b7e1c893Smrg#define ClipValue(v,min,max) ((v) < (min) ? (min) : (v) > (max) ? (max) : (v)) 19b7e1c893Smrg 20209ff23fSmrg/* Xvideo port struct */ 21209ff23fSmrgtypedef struct { 22209ff23fSmrg uint32_t transform_index; 23209ff23fSmrg uint32_t gamma; /* gamma value x 1000 */ 24209ff23fSmrg int brightness; 25209ff23fSmrg int saturation; 26209ff23fSmrg int hue; 27209ff23fSmrg int contrast; 28209ff23fSmrg int red_intensity; 29209ff23fSmrg int green_intensity; 30209ff23fSmrg int blue_intensity; 31209ff23fSmrg 32209ff23fSmrg /* overlay composition mode */ 33209ff23fSmrg int alpha_mode; /* 0 = key mode, 1 = global mode */ 34209ff23fSmrg int ov_alpha; 35209ff23fSmrg int gr_alpha; 36209ff23fSmrg 37209ff23fSmrg /* i2c bus and devices */ 38209ff23fSmrg I2CBusPtr i2c; 39209ff23fSmrg uint32_t radeon_i2c_timing; 40209ff23fSmrg uint32_t radeon_M; 41209ff23fSmrg uint32_t radeon_N; 42209ff23fSmrg uint32_t i2c_status; 43209ff23fSmrg uint32_t i2c_cntl; 44b7e1c893Smrg 45209ff23fSmrg FI1236Ptr fi1236; 46209ff23fSmrg uint8_t tuner_type; 47209ff23fSmrg MSP3430Ptr msp3430; 48209ff23fSmrg TDA9885Ptr tda9885; 49209ff23fSmrg UDA1380Ptr uda1380; 50209ff23fSmrg 51209ff23fSmrg /* VIP bus and devices */ 52209ff23fSmrg GENERIC_BUS_Ptr VIP; 53b7e1c893Smrg TheatrePtr theatre; 54209ff23fSmrg 55209ff23fSmrg Bool video_stream_active; 56209ff23fSmrg int encoding; 57209ff23fSmrg uint32_t frequency; 58209ff23fSmrg int volume; 59209ff23fSmrg Bool mute; 60209ff23fSmrg int sap_channel; 61209ff23fSmrg int v; 62209ff23fSmrg uint32_t adjustment; /* general purpose variable */ 63b7e1c893Smrg 64209ff23fSmrg#define METHOD_BOB 0 65209ff23fSmrg#define METHOD_SINGLE 1 66209ff23fSmrg#define METHOD_WEAVE 2 67209ff23fSmrg#define METHOD_ADAPTIVE 3 68209ff23fSmrg 69209ff23fSmrg int overlay_deinterlacing_method; 70209ff23fSmrg 71209ff23fSmrg int capture_vbi_data; 72209ff23fSmrg 73209ff23fSmrg int dec_brightness; 74209ff23fSmrg int dec_saturation; 75209ff23fSmrg int dec_hue; 76209ff23fSmrg int dec_contrast; 77209ff23fSmrg 78209ff23fSmrg Bool doubleBuffer; 79209ff23fSmrg unsigned char currentBuffer; 80209ff23fSmrg RegionRec clip; 81209ff23fSmrg uint32_t colorKey; 82209ff23fSmrg uint32_t videoStatus; 83209ff23fSmrg Time offTime; 84209ff23fSmrg Time freeTime; 85209ff23fSmrg Bool autopaint_colorkey; 86209ff23fSmrg xf86CrtcPtr desired_crtc; 87209ff23fSmrg 88209ff23fSmrg int size; 89209ff23fSmrg 90209ff23fSmrg void *video_memory; 91209ff23fSmrg int video_offset; 92209ff23fSmrg 93b7e1c893Smrg Bool planar_hw; 94b7e1c893Smrg Bool planar_state; 95b7e1c893Smrg int planeu_offset; 96b7e1c893Smrg int planev_offset; 97b7e1c893Smrg 98b7e1c893Smrg /* bicubic filtering */ 99b7e1c893Smrg void *bicubic_memory; 100b7e1c893Smrg int bicubic_offset; 101b7e1c893Smrg Bool bicubic_enabled; 102b7e1c893Smrg uint32_t bicubic_src_offset; 103b7e1c893Smrg int bicubic_state; 104b7e1c893Smrg#define BICUBIC_OFF 0 105b7e1c893Smrg#define BICUBIC_ON 1 106b7e1c893Smrg#define BICUBIC_AUTO 2 107b7e1c893Smrg 108209ff23fSmrg Atom device_id, location_id, instance_id; 109209ff23fSmrg 110209ff23fSmrg /* textured video */ 111209ff23fSmrg Bool textured; 112209ff23fSmrg DrawablePtr pDraw; 113209ff23fSmrg PixmapPtr pPixmap; 114209ff23fSmrg 115209ff23fSmrg uint32_t src_offset; 116209ff23fSmrg uint32_t src_pitch; 117209ff23fSmrg uint8_t *src_addr; 118209ff23fSmrg 119209ff23fSmrg int id; 120209ff23fSmrg int src_w, src_h, dst_w, dst_h; 121209ff23fSmrg int w, h; 122209ff23fSmrg int drw_x, drw_y; 123b7e1c893Smrg int vsync; 124209ff23fSmrg} RADEONPortPrivRec, *RADEONPortPrivPtr; 125209ff23fSmrg 126b7e1c893Smrgxf86CrtcPtr 127b7e1c893Smrgradeon_xv_pick_best_crtc(ScrnInfoPtr pScrn, 128b7e1c893Smrg int x1, int x2, int y1, int y2); 129209ff23fSmrg 130209ff23fSmrgvoid RADEONInitI2C(ScrnInfoPtr pScrn, RADEONPortPrivPtr pPriv); 131209ff23fSmrgvoid RADEONResetI2C(ScrnInfoPtr pScrn, RADEONPortPrivPtr pPriv); 132209ff23fSmrg 133209ff23fSmrgvoid RADEONVIP_init(ScrnInfoPtr pScrn, RADEONPortPrivPtr pPriv); 134209ff23fSmrgvoid RADEONVIP_reset(ScrnInfoPtr pScrn, RADEONPortPrivPtr pPriv); 135209ff23fSmrg 136209ff23fSmrgint RADEONSetPortAttribute(ScrnInfoPtr, Atom, INT32, pointer); 137209ff23fSmrgint RADEONGetPortAttribute(ScrnInfoPtr, Atom ,INT32 *, pointer); 138209ff23fSmrgvoid RADEONStopVideo(ScrnInfoPtr, pointer, Bool); 139209ff23fSmrgvoid RADEONQueryBestSize(ScrnInfoPtr, Bool, short, short, short, short, 140209ff23fSmrg unsigned int *, unsigned int *, pointer); 141209ff23fSmrgint RADEONQueryImageAttributes(ScrnInfoPtr, int, unsigned short *, 142209ff23fSmrg unsigned short *, int *, int *); 143209ff23fSmrg 144209ff23fSmrgXF86VideoAdaptorPtr 145209ff23fSmrgRADEONSetupImageTexturedVideo(ScreenPtr pScreen); 146209ff23fSmrg 147209ff23fSmrgvoid 148209ff23fSmrgRADEONCopyData(ScrnInfoPtr pScrn, 149209ff23fSmrg unsigned char *src, unsigned char *dst, 150209ff23fSmrg unsigned int srcPitch, unsigned int dstPitch, 151209ff23fSmrg unsigned int h, unsigned int w, unsigned int bpp); 152209ff23fSmrg 153209ff23fSmrgvoid 154209ff23fSmrgRADEONCopyMungedData(ScrnInfoPtr pScrn, 155209ff23fSmrg unsigned char *src1, unsigned char *src2, 156209ff23fSmrg unsigned char *src3, unsigned char *dst1, 157209ff23fSmrg unsigned int srcPitch, unsigned int srcPitch2, 158209ff23fSmrg unsigned int dstPitch, unsigned int h, unsigned int w); 159209ff23fSmrg 160209ff23fSmrg#endif 161