unichrome_regs.h

来自「君正早期ucos系统(只有早期的才不没有打包成库),MPLAYER,文件系统,图」· C头文件 代码 · 共 636 行 · 第 1/2 页

H
636
字号
/* $XFree86: xc/programs/Xserver/hw/xfree86/drivers/via/via.h,v 1.5 2004/01/05 00:34:17 dawes Exp $ *//* * Copyright 1998-2003 VIA Technologies, Inc. All Rights Reserved. * Copyright 2001-2003 S3 Graphics, Inc. All Rights Reserved. * * Permission is hereby granted, free of charge, to any person obtaining a * copy of this software and associated documentation files (the "Software"), * to deal in the Software without restriction, including without limitation * the rights to use, copy, modify, merge, publish, distribute, sub license, * and/or sell copies of the Software, and to permit persons to whom the * Software is furnished to do so, subject to the following conditions: * * The above copyright notice and this permission notice (including the * next paragraph) shall be included in all copies or substantial portions * of the Software. * * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, * FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT. IN NO EVENT SHALL * VIA, S3 GRAPHICS, AND/OR ITS SUPPLIERS BE LIABLE FOR ANY CLAIM, DAMAGES OR * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER * DEALINGS IN THE SOFTWARE. */#ifndef UNICHROME_REGS_H#define UNICHROME_REGS_H/* Video status flag */#define VIDEO_SHOW              0x80000000  /*Video on*/#define VIDEO_HIDE              0x00000000  /*Video off*/#define VIDEO_MPEG_INUSE        0x08000000  /*Video is used with MPEG */#define VIDEO_HQV_INUSE         0x04000000  /*Video is used with HQV*/#define VIDEO_CAPTURE0_INUSE    0x02000000  /*Video is used with CAPTURE 0*/#define VIDEO_CAPTURE1_INUSE    0x00000000  /*Video is used with CAPTURE 1*/#define VIDEO_1_INUSE           0x01000000  /*Video 1 is used with software flip*/#define VIDEO_3_INUSE           0x00000000  /*Video 3 is used with software flip*/#define MPEG_USE_V1             0x00010000  /*[16] : 1:MPEG use V1, 0:MPEG use V3*/#define MPEG_USE_V3             0x00000000  /*[16] : 1:MPEG use V1, 0:MPEG use V3*/#define MPEG_USE_HQV            0x00020000  /*[17] : 1:MPEG use HQV,0:MPEG not use HQV*/#define MPEG_USE_HW_FLIP        0x00040000  /*[18] : 1:MPEG use H/W flip,0:MPEG use S/W flip*/#define MPEG_USE_SW_FLIP        0x00000000  /*[18] : 1:MPEG use H/W flip,0:MPEG use S/W flip*/#define CAP0_USE_V1             0x00001000  /*[12] : 1:Capture 0 use V1, 0:Capture 0 use V3*/#define CAP0_USE_V3             0x00000000  /*[12] : 1:Capture 0 use V1, 0:Capture 0 use V3*/#define CAP0_USE_HQV            0x00002000  /*[13] : 1:Capture 0 use HQV,0:Capture 0 not use HQV*/#define CAP0_USE_HW_FLIP        0x00004000  /*[14] : 1:Capture 0 use H/W flip,0:Capture 0 use S/W flip*/#define CAP0_USE_CCIR656        0x00008000  /*[15] : 1:Capture 0 use CCIR656,0:Capture 0 CCIR601*/#define CAP1_USE_V1             0x00000100  /*[ 8] : 1:Capture 1 use V1, 0:Capture 1 use V3*/#define CAP1_USE_V3             0x00000000  /*[ 8] : 1:Capture 1 use V1, 0:Capture 1 use V3*/#define CAP1_USE_HQV            0x00000200  /*[ 9] : 1:Capture 1 use HQV,0:Capture 1 not use HQV*/#define CAP1_USE_HW_FLIP        0x00000400  /*[10] : 1:Capture 1 use H/W flip,0:Capture 1 use S/W flip  */#define SW_USE_V1               0x00000010  /*[ 4] : 1:Capture 1 use V1, 0:Capture 1 use V3             */#define SW_USE_V3               0x00000000  /*[ 4] : 1:Capture 1 use V1, 0:Capture 1 use V3             */#define SW_USE_HQV              0x00000020  /*[ 5] : 1:Capture 1 use HQV,0:Capture 1 not use HQV        */     /*#define VIDEO1_INUSE            0x00000010  //[ 4] : 1:Video 1 is used with S/W flip#define VIDEO1_USE_HQV          0x00000020  //[ 5] : 1:Video 1 use HQV with S/W flip#define VIDEO3_INUSE            0x00000001  //[ 0] : 1:Video 3 is used with S/W flip#define VIDEO3_USE_HQV          0x00000002  //[ 1] : 1:Video 3 use HQV with S/W flip*//* H/W registers for Video Engine *//* *      bus master */#define PCI_MASTER_ENABLE       0x01#define PCI_MASTER_SCATTER      0x00#define PCI_MASTER_SINGLE       0x02#define PCI_MASTER_GUI          0x00#define PCI_MASTER_VIDEO        0x04#define PCI_MASTER_INPUT        0x00#define PCI_MASTER_OUTPUT       0x08/* *      video registers */#define V_FLAGS				    0x00#define V_CAP_STATUS            0x04#define V_FLIP_STATUS           0x04#define V_ALPHA_WIN_START       0x08#define V_ALPHA_WIN_END         0x0C#define V_ALPHA_CONTROL         0x10#define V_CRT_STARTADDR         0x14#define V_CRT_STARTADDR_2       0x18#define V_ALPHA_STRIDE          0x1C#define V_COLOR_KEY             0x20#define V_ALPHA_STARTADDR       0x24#define V_CHROMAKEY_LOW         0x28#define V_CHROMAKEY_HIGH        0x2C#define V1_CONTROL              0x30#define V12_QWORD_PER_LINE      0x34#define V1_STARTADDR_1          0x38#define V1_STARTADDR_Y1         V1_STARTADDR_1#define V1_STRIDE               0x3C#define V1_WIN_START_Y          0x40#define V1_WIN_START_X          0x42#define V1_WIN_END_Y            0x44#define V1_WIN_END_X            0x46#define V1_STARTADDR_2          0x48#define V1_STARTADDR_Y2         V1_STARTADDR_2#define V1_ZOOM_CONTROL         0x4C#define V1_MINI_CONTROL         0x50#define V1_STARTADDR_0          0x54#define V1_STARTADDR_Y0         V1_STARTADDR_0#define V_FIFO_CONTROL          0x58#define V1_STARTADDR_3          0x5C#define V1_STARTADDR_Y3         V1_STARTADDR_3#define HI_CONTROL              0x60#define SND_COLOR_KEY           0x64#define ALPHA_V3_PREFIFO_CONTROL   0x68#define V1_SOURCE_HEIGHT        0x6C#define HI_TRANSPARENT_COLOR    0x70#define V_DISPLAY_TEMP          0x74  /* No use */#define ALPHA_V3_FIFO_CONTROL   0x78#define V3_SOURCE_WIDTH         0x7C#define V3_COLOR_KEY            0x80#define V1_ColorSpaceReg_1      0x84#define V1_ColorSpaceReg_2      0x88#define V1_STARTADDR_CB0        0x8C#define V1_OPAQUE_CONTROL       0x90  /* To be deleted */#define V3_OPAQUE_CONTROL       0x94  /* To be deleted */#define V_COMPOSE_MODE          0x98#define V3_STARTADDR_2          0x9C#define V3_CONTROL              0xA0#define V3_STARTADDR_0          0xA4#define V3_STARTADDR_1          0xA8#define V3_STRIDE               0xAC#define V3_WIN_START_Y          0xB0#define V3_WIN_START_X          0xB2#define V3_WIN_END_Y            0xB4#define V3_WIN_END_X            0xB6#define V3_ALPHA_QWORD_PER_LINE 0xB8#define V3_ZOOM_CONTROL         0xBC#define V3_MINI_CONTROL         0xC0#define V3_ColorSpaceReg_1      0xC4#define V3_ColorSpaceReg_2      0xC8#define V3_DISPLAY_TEMP         0xCC  /* No use */#define V1_STARTADDR_CB1        0xE4#define V1_STARTADDR_CB2        0xE8#define V1_STARTADDR_CB3        0xEC#define V1_STARTADDR_CR0        0xF0#define V1_STARTADDR_CR1        0xF4#define V1_STARTADDR_CR2        0xF8#define V1_STARTADDR_CR3        0xFC/* Video Capture Engine Registers  * Capture Port 1 */#define CAP0_MASKS          0x100#define CAP1_MASKS          0x104#define CAP0_CONTROL        0x110#define CAP0_H_RANGE        0x114#define CAP0_V_RANGE        0x118#define CAP0_SCAL_CONTROL   0x11C #define CAP0_VBI_H_RANGE    0x120#define CAP0_VBI_V_RANGE    0x124#define CAP0_VBI_STARTADDR  0x128#define CAP0_VBI_STRIDE     0x12C #define CAP0_ANCIL_COUNT    0x130#define CAP0_MAXCOUNT       0x134#define CAP0_VBIMAX_COUNT   0x138#define CAP0_DATA_COUNT     0x13C #define CAP0_FB_STARTADDR0  0x140#define CAP0_FB_STARTADDR1  0x144#define CAP0_FB_STARTADDR2  0x148#define CAP0_STRIDE         0x150/* Capture Port 2 */#define CAP1_CONTROL        0x154#define CAP1_SCAL_CONTROL   0x160#define CAP1_VBI_H_RANGE    0x164 /*To be deleted*/#define CAP1_VBI_V_RANGE    0x168 /*To be deleted*/#define CAP1_VBI_STARTADDR  0x16C /*To be deleted*/#define CAP1_VBI_STRIDE     0x170 /*To be deleted*/#define CAP1_ANCIL_COUNT    0x174 /*To be deleted*/#define CAP1_MAXCOUNT       0x178#define CAP1_VBIMAX_COUNT   0x17C /*To be deleted*/#define CAP1_DATA_COUNT     0x180 #define CAP1_FB_STARTADDR0  0x184#define CAP1_FB_STARTADDR1  0x188#define CAP1_STRIDE         0x18C /* SUBPICTURE Registers */#define SUBP_CONTROL_STRIDE     0x1C0#define SUBP_STARTADDR          0x1C4#define RAM_TABLE_CONTROL       0x1C8#define RAM_TABLE_READ          0x1CC/* HQV Registers */#define HQV_CONTROL             0x1D0#define HQV_SRC_STARTADDR_Y     0x1D4#define HQV_SRC_STARTADDR_U     0x1D8#define HQV_SRC_STARTADDR_V     0x1DC#define HQV_SRC_FETCH_LINE      0x1E0#define HQV_FILTER_CONTROL      0x1E4#define HQV_MINIFY_CONTROL      0x1E8#define HQV_DST_STARTADDR0      0x1EC#define HQV_DST_STARTADDR1      0x1F0#define HQV_DST_STARTADDR2      0x1FC#define HQV_DST_STRIDE          0x1F4#define HQV_SRC_STRIDE          0x1F8/* *  Video command definition *//* #define V_ALPHA_CONTROL         0x210 */#define ALPHA_WIN_EXPIRENUMBER_4        0x00040000#define ALPHA_WIN_CONSTANT_FACTOR_4     0x00004000#define ALPHA_WIN_CONSTANT_FACTOR_12    0x0000c000#define ALPHA_WIN_BLENDING_CONSTANT     0x00000000#define ALPHA_WIN_BLENDING_ALPHA        0x00000001#define ALPHA_WIN_BLENDING_GRAPHIC      0x00000002#define ALPHA_WIN_PREFIFO_THRESHOLD_12  0x000c0000#define ALPHA_WIN_FIFO_THRESHOLD_8      0x000c0000#define ALPHA_WIN_FIFO_DEPTH_16         0x00100000/* V_CHROMAKEY_LOW         0x228 */#define V_CHROMAKEY_V3          0x80000000/* V1_CONTROL                   0x230 */#define V1_ENABLE               0x00000001#define V1_FULL_SCREEN          0x00000002#define V1_YUV422               0x00000000#define V1_RGB32                0x00000004#define V1_RGB15                0x00000008#define V1_RGB16                0x0000000C#define V1_YCbCr420             0x00000010#define V1_COLORSPACE_SIGN      0x00000080#define V1_SRC_IS_FIELD_PIC     0x00000200#define V1_SRC_IS_FRAME_PIC     0x00000000#define V1_BOB_ENABLE           0x00400000#define V1_FIELD_BASE           0x00000000#define V1_FRAME_BASE           0x01000000#define V1_SWAP_SW              0x00000000#define V1_SWAP_HW_HQV          0x02000000#define V1_SWAP_HW_CAPTURE      0x04000000#define V1_SWAP_HW_MC           0x06000000/* #define V1_DOUBLE_BUFFERS       0x00000000 *//* #define V1_QUADRUPLE_BUFFERS    0x18000000 */#define V1_EXPIRE_NUM           0x00050000#define V1_EXPIRE_NUM_A         0x000a0000#define V1_EXPIRE_NUM_F         0x000f0000 /* jason */#define V1_FIFO_EXTENDED        0x00200000#define V1_ON_CRT               0x00000000#define V1_ON_SND_DISPLAY       0x80000000#define V1_FIFO_32V1_32V2       0x00000000#define V1_FIFO_48V1_32V2       0x00200000/* V12_QWORD_PER_LINE           0x234 */#define V1_FETCH_COUNT          0x3ff00000#define V1_FETCHCOUNT_ALIGNMENT 0x0000000f#define V1_FETCHCOUNT_UNIT      0x00000004   /* Doubld QWORD *//* V1_STRIDE */#define V1_STRIDE_YMASK         0x00001fff#define V1_STRIDE_UVMASK        0x1ff00000/* V1_ZOOM_CONTROL              0x24C */#define V1_X_ZOOM_ENABLE        0x80000000#define V1_Y_ZOOM_ENABLE        0x00008000/* V1_MINI_CONTROL              0x250 */#define V1_X_INTERPOLY          0x00000002  /* X interpolation */#define V1_Y_INTERPOLY          0x00000001  /* Y interpolation */#define V1_YCBCR_INTERPOLY      0x00000004  /* Y, Cb, Cr all interpolation */#define V1_X_DIV_2              0x01000000#define V1_X_DIV_4              0x03000000#define V1_X_DIV_8              0x05000000#define V1_X_DIV_16             0x07000000#define V1_Y_DIV_2              0x00010000#define V1_Y_DIV_4              0x00030000#define V1_Y_DIV_8              0x00050000#define V1_Y_DIV_16             0x00070000/* V1_STARTADDR0               0x254 */#define SW_FLIP_ODD             0x08000000/* V_FIFO_CONTROL               0x258 * IA2 has 32 level FIFO for packet mode video format *         32 level FIFO for planar mode video YV12. with extension reg 230 bit 21 enable *         16 level FIFO for planar mode video YV12. with extension reg 230 bit 21 disable * BCos of 128 bits. 1 level in IA2 = 2 level in VT3122 */#define V1_FIFO_DEPTH12         0x0000000B#define V1_FIFO_DEPTH16         0x0000000F#define V1_FIFO_DEPTH32         0x0000001F#define V1_FIFO_DEPTH48         0x0000002F#define V1_FIFO_DEPTH64         0x0000003F   #define V1_FIFO_THRESHOLD6      0x00000600#define V1_FIFO_THRESHOLD8      0x00000800#define V1_FIFO_THRESHOLD12     0x00000C00#define V1_FIFO_THRESHOLD16     0x00001000#define V1_FIFO_THRESHOLD24     0x00001800#define V1_FIFO_THRESHOLD32     0x00002000#define V1_FIFO_THRESHOLD40     0x00002800  #define V1_FIFO_THRESHOLD48     0x00003000   #define V1_FIFO_THRESHOLD56     0x00003800  #define V1_FIFO_THRESHOLD61     0x00003D00  #define V1_FIFO_PRETHRESHOLD10  0x0A000000#define V1_FIFO_PRETHRESHOLD12  0x0C000000#define V1_FIFO_PRETHRESHOLD29  0x1d000000#define V1_FIFO_PRETHRESHOLD40  0x28000000  #define V1_FIFO_PRETHRESHOLD44  0x2c000000#define V1_FIFO_PRETHRESHOLD56  0x38000000   #define V1_FIFO_PRETHRESHOLD61  0x3D000000   /* ALPHA_V3_FIFO_CONTROL        0x278 * IA2 has 32 level FIFO for packet mode video format *         32 level FIFO for planar mode video YV12. with extension reg 230 bit 21 enable *         16 level FIFO for planar mode video YV12. with extension reg 230 bit 21 disable *          8 level FIFO for ALPHA * BCos of 128 bits. 1 level in IA2 = 2 level in VT3122 */#define V3_FIFO_DEPTH16         0x0000000F#define V3_FIFO_DEPTH24         0x00000017

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?