1*4882a593Smuzhiyun /* SPDX-License-Identifier: GPL-2.0-only */ 2*4882a593Smuzhiyun /* 3*4882a593Smuzhiyun * PS3 AV backend support. 4*4882a593Smuzhiyun * 5*4882a593Smuzhiyun * Copyright (C) 2007 Sony Computer Entertainment Inc. 6*4882a593Smuzhiyun * Copyright 2007 Sony Corp. 7*4882a593Smuzhiyun */ 8*4882a593Smuzhiyun 9*4882a593Smuzhiyun #ifndef _ASM_POWERPC_PS3AV_H_ 10*4882a593Smuzhiyun #define _ASM_POWERPC_PS3AV_H_ 11*4882a593Smuzhiyun 12*4882a593Smuzhiyun /** command for ioctl() **/ 13*4882a593Smuzhiyun #define PS3AV_VERSION 0x205 /* version of ps3av command */ 14*4882a593Smuzhiyun 15*4882a593Smuzhiyun #define PS3AV_CID_AV_INIT 0x00000001 16*4882a593Smuzhiyun #define PS3AV_CID_AV_FIN 0x00000002 17*4882a593Smuzhiyun #define PS3AV_CID_AV_GET_HW_CONF 0x00000003 18*4882a593Smuzhiyun #define PS3AV_CID_AV_GET_MONITOR_INFO 0x00000004 19*4882a593Smuzhiyun #define PS3AV_CID_AV_ENABLE_EVENT 0x00000006 20*4882a593Smuzhiyun #define PS3AV_CID_AV_DISABLE_EVENT 0x00000007 21*4882a593Smuzhiyun #define PS3AV_CID_AV_TV_MUTE 0x0000000a 22*4882a593Smuzhiyun 23*4882a593Smuzhiyun #define PS3AV_CID_AV_VIDEO_CS 0x00010001 24*4882a593Smuzhiyun #define PS3AV_CID_AV_VIDEO_MUTE 0x00010002 25*4882a593Smuzhiyun #define PS3AV_CID_AV_VIDEO_DISABLE_SIG 0x00010003 26*4882a593Smuzhiyun #define PS3AV_CID_AV_AUDIO_PARAM 0x00020001 27*4882a593Smuzhiyun #define PS3AV_CID_AV_AUDIO_MUTE 0x00020002 28*4882a593Smuzhiyun #define PS3AV_CID_AV_HDMI_MODE 0x00040001 29*4882a593Smuzhiyun 30*4882a593Smuzhiyun #define PS3AV_CID_VIDEO_INIT 0x01000001 31*4882a593Smuzhiyun #define PS3AV_CID_VIDEO_MODE 0x01000002 32*4882a593Smuzhiyun #define PS3AV_CID_VIDEO_FORMAT 0x01000004 33*4882a593Smuzhiyun #define PS3AV_CID_VIDEO_PITCH 0x01000005 34*4882a593Smuzhiyun 35*4882a593Smuzhiyun #define PS3AV_CID_AUDIO_INIT 0x02000001 36*4882a593Smuzhiyun #define PS3AV_CID_AUDIO_MODE 0x02000002 37*4882a593Smuzhiyun #define PS3AV_CID_AUDIO_MUTE 0x02000003 38*4882a593Smuzhiyun #define PS3AV_CID_AUDIO_ACTIVE 0x02000004 39*4882a593Smuzhiyun #define PS3AV_CID_AUDIO_INACTIVE 0x02000005 40*4882a593Smuzhiyun #define PS3AV_CID_AUDIO_SPDIF_BIT 0x02000006 41*4882a593Smuzhiyun #define PS3AV_CID_AUDIO_CTRL 0x02000007 42*4882a593Smuzhiyun 43*4882a593Smuzhiyun #define PS3AV_CID_EVENT_UNPLUGGED 0x10000001 44*4882a593Smuzhiyun #define PS3AV_CID_EVENT_PLUGGED 0x10000002 45*4882a593Smuzhiyun #define PS3AV_CID_EVENT_HDCP_DONE 0x10000003 46*4882a593Smuzhiyun #define PS3AV_CID_EVENT_HDCP_FAIL 0x10000004 47*4882a593Smuzhiyun #define PS3AV_CID_EVENT_HDCP_AUTH 0x10000005 48*4882a593Smuzhiyun #define PS3AV_CID_EVENT_HDCP_ERROR 0x10000006 49*4882a593Smuzhiyun 50*4882a593Smuzhiyun #define PS3AV_CID_AVB_PARAM 0x04000001 51*4882a593Smuzhiyun 52*4882a593Smuzhiyun /* max backend ports */ 53*4882a593Smuzhiyun #define PS3AV_HDMI_MAX 2 /* HDMI_0 HDMI_1 */ 54*4882a593Smuzhiyun #define PS3AV_AVMULTI_MAX 1 /* AVMULTI_0 */ 55*4882a593Smuzhiyun #define PS3AV_AV_PORT_MAX (PS3AV_HDMI_MAX + PS3AV_AVMULTI_MAX) 56*4882a593Smuzhiyun #define PS3AV_OPT_PORT_MAX 1 /* SPDIF0 */ 57*4882a593Smuzhiyun #define PS3AV_HEAD_MAX 2 /* HEAD_A HEAD_B */ 58*4882a593Smuzhiyun 59*4882a593Smuzhiyun /* num of pkt for PS3AV_CID_AVB_PARAM */ 60*4882a593Smuzhiyun #define PS3AV_AVB_NUM_VIDEO PS3AV_HEAD_MAX 61*4882a593Smuzhiyun #define PS3AV_AVB_NUM_AUDIO 0 /* not supported */ 62*4882a593Smuzhiyun #define PS3AV_AVB_NUM_AV_VIDEO PS3AV_AV_PORT_MAX 63*4882a593Smuzhiyun #define PS3AV_AVB_NUM_AV_AUDIO PS3AV_HDMI_MAX 64*4882a593Smuzhiyun 65*4882a593Smuzhiyun #define PS3AV_MUTE_PORT_MAX 1 /* num of ports in mute pkt */ 66*4882a593Smuzhiyun 67*4882a593Smuzhiyun /* event_bit */ 68*4882a593Smuzhiyun #define PS3AV_CMD_EVENT_BIT_UNPLUGGED (1 << 0) 69*4882a593Smuzhiyun #define PS3AV_CMD_EVENT_BIT_PLUGGED (1 << 1) 70*4882a593Smuzhiyun #define PS3AV_CMD_EVENT_BIT_HDCP_DONE (1 << 2) 71*4882a593Smuzhiyun #define PS3AV_CMD_EVENT_BIT_HDCP_FAIL (1 << 3) 72*4882a593Smuzhiyun #define PS3AV_CMD_EVENT_BIT_HDCP_REAUTH (1 << 4) 73*4882a593Smuzhiyun #define PS3AV_CMD_EVENT_BIT_HDCP_TOPOLOGY (1 << 5) 74*4882a593Smuzhiyun 75*4882a593Smuzhiyun /* common params */ 76*4882a593Smuzhiyun /* mute */ 77*4882a593Smuzhiyun #define PS3AV_CMD_MUTE_OFF 0x0000 78*4882a593Smuzhiyun #define PS3AV_CMD_MUTE_ON 0x0001 79*4882a593Smuzhiyun /* avport */ 80*4882a593Smuzhiyun #define PS3AV_CMD_AVPORT_HDMI_0 0x0000 81*4882a593Smuzhiyun #define PS3AV_CMD_AVPORT_HDMI_1 0x0001 82*4882a593Smuzhiyun #define PS3AV_CMD_AVPORT_AVMULTI_0 0x0010 83*4882a593Smuzhiyun #define PS3AV_CMD_AVPORT_SPDIF_0 0x0020 84*4882a593Smuzhiyun #define PS3AV_CMD_AVPORT_SPDIF_1 0x0021 85*4882a593Smuzhiyun 86*4882a593Smuzhiyun /* for av backend */ 87*4882a593Smuzhiyun /* av_mclk */ 88*4882a593Smuzhiyun #define PS3AV_CMD_AV_MCLK_128 0x0000 89*4882a593Smuzhiyun #define PS3AV_CMD_AV_MCLK_256 0x0001 90*4882a593Smuzhiyun #define PS3AV_CMD_AV_MCLK_512 0x0003 91*4882a593Smuzhiyun /* av_inputlen */ 92*4882a593Smuzhiyun #define PS3AV_CMD_AV_INPUTLEN_16 0x02 93*4882a593Smuzhiyun #define PS3AV_CMD_AV_INPUTLEN_20 0x0a 94*4882a593Smuzhiyun #define PS3AV_CMD_AV_INPUTLEN_24 0x0b 95*4882a593Smuzhiyun /* av_layout */ 96*4882a593Smuzhiyun #define PS3AV_CMD_AV_LAYOUT_32 (1 << 0) 97*4882a593Smuzhiyun #define PS3AV_CMD_AV_LAYOUT_44 (1 << 1) 98*4882a593Smuzhiyun #define PS3AV_CMD_AV_LAYOUT_48 (1 << 2) 99*4882a593Smuzhiyun #define PS3AV_CMD_AV_LAYOUT_88 (1 << 3) 100*4882a593Smuzhiyun #define PS3AV_CMD_AV_LAYOUT_96 (1 << 4) 101*4882a593Smuzhiyun #define PS3AV_CMD_AV_LAYOUT_176 (1 << 5) 102*4882a593Smuzhiyun #define PS3AV_CMD_AV_LAYOUT_192 (1 << 6) 103*4882a593Smuzhiyun /* hdmi_mode */ 104*4882a593Smuzhiyun #define PS3AV_CMD_AV_HDMI_MODE_NORMAL 0xff 105*4882a593Smuzhiyun #define PS3AV_CMD_AV_HDMI_HDCP_OFF 0x01 106*4882a593Smuzhiyun #define PS3AV_CMD_AV_HDMI_EDID_PASS 0x80 107*4882a593Smuzhiyun #define PS3AV_CMD_AV_HDMI_DVI 0x40 108*4882a593Smuzhiyun 109*4882a593Smuzhiyun /* for video module */ 110*4882a593Smuzhiyun /* video_head */ 111*4882a593Smuzhiyun #define PS3AV_CMD_VIDEO_HEAD_A 0x0000 112*4882a593Smuzhiyun #define PS3AV_CMD_VIDEO_HEAD_B 0x0001 113*4882a593Smuzhiyun /* video_cs_out video_cs_in */ 114*4882a593Smuzhiyun #define PS3AV_CMD_VIDEO_CS_NONE 0x0000 115*4882a593Smuzhiyun #define PS3AV_CMD_VIDEO_CS_RGB_8 0x0001 116*4882a593Smuzhiyun #define PS3AV_CMD_VIDEO_CS_YUV444_8 0x0002 117*4882a593Smuzhiyun #define PS3AV_CMD_VIDEO_CS_YUV422_8 0x0003 118*4882a593Smuzhiyun #define PS3AV_CMD_VIDEO_CS_XVYCC_8 0x0004 119*4882a593Smuzhiyun #define PS3AV_CMD_VIDEO_CS_RGB_10 0x0005 120*4882a593Smuzhiyun #define PS3AV_CMD_VIDEO_CS_YUV444_10 0x0006 121*4882a593Smuzhiyun #define PS3AV_CMD_VIDEO_CS_YUV422_10 0x0007 122*4882a593Smuzhiyun #define PS3AV_CMD_VIDEO_CS_XVYCC_10 0x0008 123*4882a593Smuzhiyun #define PS3AV_CMD_VIDEO_CS_RGB_12 0x0009 124*4882a593Smuzhiyun #define PS3AV_CMD_VIDEO_CS_YUV444_12 0x000a 125*4882a593Smuzhiyun #define PS3AV_CMD_VIDEO_CS_YUV422_12 0x000b 126*4882a593Smuzhiyun #define PS3AV_CMD_VIDEO_CS_XVYCC_12 0x000c 127*4882a593Smuzhiyun /* video_vid */ 128*4882a593Smuzhiyun #define PS3AV_CMD_VIDEO_VID_NONE 0x0000 129*4882a593Smuzhiyun #define PS3AV_CMD_VIDEO_VID_480I 0x0001 130*4882a593Smuzhiyun #define PS3AV_CMD_VIDEO_VID_576I 0x0003 131*4882a593Smuzhiyun #define PS3AV_CMD_VIDEO_VID_480P 0x0005 132*4882a593Smuzhiyun #define PS3AV_CMD_VIDEO_VID_576P 0x0006 133*4882a593Smuzhiyun #define PS3AV_CMD_VIDEO_VID_1080I_60HZ 0x0007 134*4882a593Smuzhiyun #define PS3AV_CMD_VIDEO_VID_1080I_50HZ 0x0008 135*4882a593Smuzhiyun #define PS3AV_CMD_VIDEO_VID_720P_60HZ 0x0009 136*4882a593Smuzhiyun #define PS3AV_CMD_VIDEO_VID_720P_50HZ 0x000a 137*4882a593Smuzhiyun #define PS3AV_CMD_VIDEO_VID_1080P_60HZ 0x000b 138*4882a593Smuzhiyun #define PS3AV_CMD_VIDEO_VID_1080P_50HZ 0x000c 139*4882a593Smuzhiyun #define PS3AV_CMD_VIDEO_VID_WXGA 0x000d 140*4882a593Smuzhiyun #define PS3AV_CMD_VIDEO_VID_SXGA 0x000e 141*4882a593Smuzhiyun #define PS3AV_CMD_VIDEO_VID_WUXGA 0x000f 142*4882a593Smuzhiyun #define PS3AV_CMD_VIDEO_VID_480I_A 0x0010 143*4882a593Smuzhiyun /* video_format */ 144*4882a593Smuzhiyun #define PS3AV_CMD_VIDEO_FORMAT_BLACK 0x0000 145*4882a593Smuzhiyun #define PS3AV_CMD_VIDEO_FORMAT_ARGB_8BIT 0x0007 146*4882a593Smuzhiyun /* video_order */ 147*4882a593Smuzhiyun #define PS3AV_CMD_VIDEO_ORDER_RGB 0x0000 148*4882a593Smuzhiyun #define PS3AV_CMD_VIDEO_ORDER_BGR 0x0001 149*4882a593Smuzhiyun /* video_fmt */ 150*4882a593Smuzhiyun #define PS3AV_CMD_VIDEO_FMT_X8R8G8B8 0x0000 151*4882a593Smuzhiyun /* video_out_format */ 152*4882a593Smuzhiyun #define PS3AV_CMD_VIDEO_OUT_FORMAT_RGB_12BIT 0x0000 153*4882a593Smuzhiyun /* video_cl_cnv */ 154*4882a593Smuzhiyun #define PS3AV_CMD_VIDEO_CL_CNV_ENABLE_LUT 0x0000 155*4882a593Smuzhiyun #define PS3AV_CMD_VIDEO_CL_CNV_DISABLE_LUT 0x0010 156*4882a593Smuzhiyun /* video_sync */ 157*4882a593Smuzhiyun #define PS3AV_CMD_VIDEO_SYNC_VSYNC 0x0001 158*4882a593Smuzhiyun #define PS3AV_CMD_VIDEO_SYNC_CSYNC 0x0004 159*4882a593Smuzhiyun #define PS3AV_CMD_VIDEO_SYNC_HSYNC 0x0010 160*4882a593Smuzhiyun 161*4882a593Smuzhiyun /* for audio module */ 162*4882a593Smuzhiyun /* num_of_ch */ 163*4882a593Smuzhiyun #define PS3AV_CMD_AUDIO_NUM_OF_CH_2 0x0000 164*4882a593Smuzhiyun #define PS3AV_CMD_AUDIO_NUM_OF_CH_3 0x0001 165*4882a593Smuzhiyun #define PS3AV_CMD_AUDIO_NUM_OF_CH_4 0x0002 166*4882a593Smuzhiyun #define PS3AV_CMD_AUDIO_NUM_OF_CH_5 0x0003 167*4882a593Smuzhiyun #define PS3AV_CMD_AUDIO_NUM_OF_CH_6 0x0004 168*4882a593Smuzhiyun #define PS3AV_CMD_AUDIO_NUM_OF_CH_7 0x0005 169*4882a593Smuzhiyun #define PS3AV_CMD_AUDIO_NUM_OF_CH_8 0x0006 170*4882a593Smuzhiyun /* audio_fs */ 171*4882a593Smuzhiyun #define PS3AV_CMD_AUDIO_FS_32K 0x0001 172*4882a593Smuzhiyun #define PS3AV_CMD_AUDIO_FS_44K 0x0002 173*4882a593Smuzhiyun #define PS3AV_CMD_AUDIO_FS_48K 0x0003 174*4882a593Smuzhiyun #define PS3AV_CMD_AUDIO_FS_88K 0x0004 175*4882a593Smuzhiyun #define PS3AV_CMD_AUDIO_FS_96K 0x0005 176*4882a593Smuzhiyun #define PS3AV_CMD_AUDIO_FS_176K 0x0006 177*4882a593Smuzhiyun #define PS3AV_CMD_AUDIO_FS_192K 0x0007 178*4882a593Smuzhiyun /* audio_word_bits */ 179*4882a593Smuzhiyun #define PS3AV_CMD_AUDIO_WORD_BITS_16 0x0001 180*4882a593Smuzhiyun #define PS3AV_CMD_AUDIO_WORD_BITS_20 0x0002 181*4882a593Smuzhiyun #define PS3AV_CMD_AUDIO_WORD_BITS_24 0x0003 182*4882a593Smuzhiyun /* audio_format */ 183*4882a593Smuzhiyun #define PS3AV_CMD_AUDIO_FORMAT_PCM 0x0001 184*4882a593Smuzhiyun #define PS3AV_CMD_AUDIO_FORMAT_BITSTREAM 0x00ff 185*4882a593Smuzhiyun /* audio_source */ 186*4882a593Smuzhiyun #define PS3AV_CMD_AUDIO_SOURCE_SERIAL 0x0000 187*4882a593Smuzhiyun #define PS3AV_CMD_AUDIO_SOURCE_SPDIF 0x0001 188*4882a593Smuzhiyun /* audio_swap */ 189*4882a593Smuzhiyun #define PS3AV_CMD_AUDIO_SWAP_0 0x0000 190*4882a593Smuzhiyun #define PS3AV_CMD_AUDIO_SWAP_1 0x0000 191*4882a593Smuzhiyun /* audio_map */ 192*4882a593Smuzhiyun #define PS3AV_CMD_AUDIO_MAP_OUTPUT_0 0x0000 193*4882a593Smuzhiyun #define PS3AV_CMD_AUDIO_MAP_OUTPUT_1 0x0001 194*4882a593Smuzhiyun #define PS3AV_CMD_AUDIO_MAP_OUTPUT_2 0x0002 195*4882a593Smuzhiyun #define PS3AV_CMD_AUDIO_MAP_OUTPUT_3 0x0003 196*4882a593Smuzhiyun /* audio_layout */ 197*4882a593Smuzhiyun #define PS3AV_CMD_AUDIO_LAYOUT_2CH 0x0000 198*4882a593Smuzhiyun #define PS3AV_CMD_AUDIO_LAYOUT_6CH 0x000b /* LREClr */ 199*4882a593Smuzhiyun #define PS3AV_CMD_AUDIO_LAYOUT_8CH 0x001f /* LREClrXY */ 200*4882a593Smuzhiyun /* audio_downmix */ 201*4882a593Smuzhiyun #define PS3AV_CMD_AUDIO_DOWNMIX_PERMITTED 0x0000 202*4882a593Smuzhiyun #define PS3AV_CMD_AUDIO_DOWNMIX_PROHIBITED 0x0001 203*4882a593Smuzhiyun 204*4882a593Smuzhiyun /* audio_port */ 205*4882a593Smuzhiyun #define PS3AV_CMD_AUDIO_PORT_HDMI_0 ( 1 << 0 ) 206*4882a593Smuzhiyun #define PS3AV_CMD_AUDIO_PORT_HDMI_1 ( 1 << 1 ) 207*4882a593Smuzhiyun #define PS3AV_CMD_AUDIO_PORT_AVMULTI_0 ( 1 << 10 ) 208*4882a593Smuzhiyun #define PS3AV_CMD_AUDIO_PORT_SPDIF_0 ( 1 << 20 ) 209*4882a593Smuzhiyun #define PS3AV_CMD_AUDIO_PORT_SPDIF_1 ( 1 << 21 ) 210*4882a593Smuzhiyun 211*4882a593Smuzhiyun /* audio_ctrl_id */ 212*4882a593Smuzhiyun #define PS3AV_CMD_AUDIO_CTRL_ID_DAC_RESET 0x0000 213*4882a593Smuzhiyun #define PS3AV_CMD_AUDIO_CTRL_ID_DAC_DE_EMPHASIS 0x0001 214*4882a593Smuzhiyun #define PS3AV_CMD_AUDIO_CTRL_ID_AVCLK 0x0002 215*4882a593Smuzhiyun /* audio_ctrl_data[0] reset */ 216*4882a593Smuzhiyun #define PS3AV_CMD_AUDIO_CTRL_RESET_NEGATE 0x0000 217*4882a593Smuzhiyun #define PS3AV_CMD_AUDIO_CTRL_RESET_ASSERT 0x0001 218*4882a593Smuzhiyun /* audio_ctrl_data[0] de-emphasis */ 219*4882a593Smuzhiyun #define PS3AV_CMD_AUDIO_CTRL_DE_EMPHASIS_OFF 0x0000 220*4882a593Smuzhiyun #define PS3AV_CMD_AUDIO_CTRL_DE_EMPHASIS_ON 0x0001 221*4882a593Smuzhiyun /* audio_ctrl_data[0] avclk */ 222*4882a593Smuzhiyun #define PS3AV_CMD_AUDIO_CTRL_AVCLK_22 0x0000 223*4882a593Smuzhiyun #define PS3AV_CMD_AUDIO_CTRL_AVCLK_18 0x0001 224*4882a593Smuzhiyun 225*4882a593Smuzhiyun /* av_vid */ 226*4882a593Smuzhiyun /* do not use these params directly, use vid_video2av */ 227*4882a593Smuzhiyun #define PS3AV_CMD_AV_VID_480I 0x0000 228*4882a593Smuzhiyun #define PS3AV_CMD_AV_VID_480P 0x0001 229*4882a593Smuzhiyun #define PS3AV_CMD_AV_VID_720P_60HZ 0x0002 230*4882a593Smuzhiyun #define PS3AV_CMD_AV_VID_1080I_60HZ 0x0003 231*4882a593Smuzhiyun #define PS3AV_CMD_AV_VID_1080P_60HZ 0x0004 232*4882a593Smuzhiyun #define PS3AV_CMD_AV_VID_576I 0x0005 233*4882a593Smuzhiyun #define PS3AV_CMD_AV_VID_576P 0x0006 234*4882a593Smuzhiyun #define PS3AV_CMD_AV_VID_720P_50HZ 0x0007 235*4882a593Smuzhiyun #define PS3AV_CMD_AV_VID_1080I_50HZ 0x0008 236*4882a593Smuzhiyun #define PS3AV_CMD_AV_VID_1080P_50HZ 0x0009 237*4882a593Smuzhiyun #define PS3AV_CMD_AV_VID_WXGA 0x000a 238*4882a593Smuzhiyun #define PS3AV_CMD_AV_VID_SXGA 0x000b 239*4882a593Smuzhiyun #define PS3AV_CMD_AV_VID_WUXGA 0x000c 240*4882a593Smuzhiyun /* av_cs_out av_cs_in */ 241*4882a593Smuzhiyun /* use cs_video2av() */ 242*4882a593Smuzhiyun #define PS3AV_CMD_AV_CS_RGB_8 0x0000 243*4882a593Smuzhiyun #define PS3AV_CMD_AV_CS_YUV444_8 0x0001 244*4882a593Smuzhiyun #define PS3AV_CMD_AV_CS_YUV422_8 0x0002 245*4882a593Smuzhiyun #define PS3AV_CMD_AV_CS_XVYCC_8 0x0003 246*4882a593Smuzhiyun #define PS3AV_CMD_AV_CS_RGB_10 0x0004 247*4882a593Smuzhiyun #define PS3AV_CMD_AV_CS_YUV444_10 0x0005 248*4882a593Smuzhiyun #define PS3AV_CMD_AV_CS_YUV422_10 0x0006 249*4882a593Smuzhiyun #define PS3AV_CMD_AV_CS_XVYCC_10 0x0007 250*4882a593Smuzhiyun #define PS3AV_CMD_AV_CS_RGB_12 0x0008 251*4882a593Smuzhiyun #define PS3AV_CMD_AV_CS_YUV444_12 0x0009 252*4882a593Smuzhiyun #define PS3AV_CMD_AV_CS_YUV422_12 0x000a 253*4882a593Smuzhiyun #define PS3AV_CMD_AV_CS_XVYCC_12 0x000b 254*4882a593Smuzhiyun #define PS3AV_CMD_AV_CS_8 0x0000 255*4882a593Smuzhiyun #define PS3AV_CMD_AV_CS_10 0x0001 256*4882a593Smuzhiyun #define PS3AV_CMD_AV_CS_12 0x0002 257*4882a593Smuzhiyun /* dither */ 258*4882a593Smuzhiyun #define PS3AV_CMD_AV_DITHER_OFF 0x0000 259*4882a593Smuzhiyun #define PS3AV_CMD_AV_DITHER_ON 0x0001 260*4882a593Smuzhiyun #define PS3AV_CMD_AV_DITHER_8BIT 0x0000 261*4882a593Smuzhiyun #define PS3AV_CMD_AV_DITHER_10BIT 0x0002 262*4882a593Smuzhiyun #define PS3AV_CMD_AV_DITHER_12BIT 0x0004 263*4882a593Smuzhiyun /* super_white */ 264*4882a593Smuzhiyun #define PS3AV_CMD_AV_SUPER_WHITE_OFF 0x0000 265*4882a593Smuzhiyun #define PS3AV_CMD_AV_SUPER_WHITE_ON 0x0001 266*4882a593Smuzhiyun /* aspect */ 267*4882a593Smuzhiyun #define PS3AV_CMD_AV_ASPECT_16_9 0x0000 268*4882a593Smuzhiyun #define PS3AV_CMD_AV_ASPECT_4_3 0x0001 269*4882a593Smuzhiyun /* video_cs_cnv() */ 270*4882a593Smuzhiyun #define PS3AV_CMD_VIDEO_CS_RGB 0x0001 271*4882a593Smuzhiyun #define PS3AV_CMD_VIDEO_CS_YUV422 0x0002 272*4882a593Smuzhiyun #define PS3AV_CMD_VIDEO_CS_YUV444 0x0003 273*4882a593Smuzhiyun 274*4882a593Smuzhiyun /* for broadcast automode */ 275*4882a593Smuzhiyun #define PS3AV_RESBIT_720x480P 0x0003 /* 0x0001 | 0x0002 */ 276*4882a593Smuzhiyun #define PS3AV_RESBIT_720x576P 0x0003 /* 0x0001 | 0x0002 */ 277*4882a593Smuzhiyun #define PS3AV_RESBIT_1280x720P 0x0004 278*4882a593Smuzhiyun #define PS3AV_RESBIT_1920x1080I 0x0008 279*4882a593Smuzhiyun #define PS3AV_RESBIT_1920x1080P 0x4000 280*4882a593Smuzhiyun #define PS3AV_RES_MASK_60 (PS3AV_RESBIT_720x480P \ 281*4882a593Smuzhiyun | PS3AV_RESBIT_1280x720P \ 282*4882a593Smuzhiyun | PS3AV_RESBIT_1920x1080I \ 283*4882a593Smuzhiyun | PS3AV_RESBIT_1920x1080P) 284*4882a593Smuzhiyun #define PS3AV_RES_MASK_50 (PS3AV_RESBIT_720x576P \ 285*4882a593Smuzhiyun | PS3AV_RESBIT_1280x720P \ 286*4882a593Smuzhiyun | PS3AV_RESBIT_1920x1080I \ 287*4882a593Smuzhiyun | PS3AV_RESBIT_1920x1080P) 288*4882a593Smuzhiyun 289*4882a593Smuzhiyun /* for VESA automode */ 290*4882a593Smuzhiyun #define PS3AV_RESBIT_VGA 0x0001 291*4882a593Smuzhiyun #define PS3AV_RESBIT_WXGA 0x0002 292*4882a593Smuzhiyun #define PS3AV_RESBIT_SXGA 0x0004 293*4882a593Smuzhiyun #define PS3AV_RESBIT_WUXGA 0x0008 294*4882a593Smuzhiyun #define PS3AV_RES_MASK_VESA (PS3AV_RESBIT_WXGA |\ 295*4882a593Smuzhiyun PS3AV_RESBIT_SXGA |\ 296*4882a593Smuzhiyun PS3AV_RESBIT_WUXGA) 297*4882a593Smuzhiyun 298*4882a593Smuzhiyun #define PS3AV_MONITOR_TYPE_HDMI 1 /* HDMI */ 299*4882a593Smuzhiyun #define PS3AV_MONITOR_TYPE_DVI 2 /* DVI */ 300*4882a593Smuzhiyun 301*4882a593Smuzhiyun 302*4882a593Smuzhiyun /* for video mode */ 303*4882a593Smuzhiyun enum ps3av_mode_num { 304*4882a593Smuzhiyun PS3AV_MODE_AUTO = 0, 305*4882a593Smuzhiyun PS3AV_MODE_480I = 1, 306*4882a593Smuzhiyun PS3AV_MODE_480P = 2, 307*4882a593Smuzhiyun PS3AV_MODE_720P60 = 3, 308*4882a593Smuzhiyun PS3AV_MODE_1080I60 = 4, 309*4882a593Smuzhiyun PS3AV_MODE_1080P60 = 5, 310*4882a593Smuzhiyun PS3AV_MODE_576I = 6, 311*4882a593Smuzhiyun PS3AV_MODE_576P = 7, 312*4882a593Smuzhiyun PS3AV_MODE_720P50 = 8, 313*4882a593Smuzhiyun PS3AV_MODE_1080I50 = 9, 314*4882a593Smuzhiyun PS3AV_MODE_1080P50 = 10, 315*4882a593Smuzhiyun PS3AV_MODE_WXGA = 11, 316*4882a593Smuzhiyun PS3AV_MODE_SXGA = 12, 317*4882a593Smuzhiyun PS3AV_MODE_WUXGA = 13, 318*4882a593Smuzhiyun }; 319*4882a593Smuzhiyun 320*4882a593Smuzhiyun #define PS3AV_MODE_MASK 0x000F 321*4882a593Smuzhiyun #define PS3AV_MODE_HDCP_OFF 0x1000 /* Retail PS3 product doesn't support this */ 322*4882a593Smuzhiyun #define PS3AV_MODE_DITHER 0x0800 323*4882a593Smuzhiyun #define PS3AV_MODE_COLOR 0x0400 324*4882a593Smuzhiyun #define PS3AV_MODE_WHITE 0x0200 325*4882a593Smuzhiyun #define PS3AV_MODE_FULL 0x0080 326*4882a593Smuzhiyun #define PS3AV_MODE_DVI 0x0040 327*4882a593Smuzhiyun #define PS3AV_MODE_RGB 0x0020 328*4882a593Smuzhiyun 329*4882a593Smuzhiyun 330*4882a593Smuzhiyun #define PS3AV_DEFAULT_HDMI_MODE_ID_REG_60 PS3AV_MODE_480P 331*4882a593Smuzhiyun #define PS3AV_DEFAULT_AVMULTI_MODE_ID_REG_60 PS3AV_MODE_480I 332*4882a593Smuzhiyun #define PS3AV_DEFAULT_HDMI_MODE_ID_REG_50 PS3AV_MODE_576P 333*4882a593Smuzhiyun #define PS3AV_DEFAULT_AVMULTI_MODE_ID_REG_50 PS3AV_MODE_576I 334*4882a593Smuzhiyun 335*4882a593Smuzhiyun #define PS3AV_REGION_60 0x01 336*4882a593Smuzhiyun #define PS3AV_REGION_50 0x02 337*4882a593Smuzhiyun #define PS3AV_REGION_RGB 0x10 338*4882a593Smuzhiyun 339*4882a593Smuzhiyun #define get_status(buf) (((__u32 *)buf)[2]) 340*4882a593Smuzhiyun #define PS3AV_HDR_SIZE 4 /* version + size */ 341*4882a593Smuzhiyun 342*4882a593Smuzhiyun 343*4882a593Smuzhiyun /** command packet structure **/ 344*4882a593Smuzhiyun struct ps3av_send_hdr { 345*4882a593Smuzhiyun u16 version; 346*4882a593Smuzhiyun u16 size; /* size of command packet */ 347*4882a593Smuzhiyun u32 cid; /* command id */ 348*4882a593Smuzhiyun }; 349*4882a593Smuzhiyun 350*4882a593Smuzhiyun struct ps3av_reply_hdr { 351*4882a593Smuzhiyun u16 version; 352*4882a593Smuzhiyun u16 size; 353*4882a593Smuzhiyun u32 cid; 354*4882a593Smuzhiyun u32 status; 355*4882a593Smuzhiyun }; 356*4882a593Smuzhiyun 357*4882a593Smuzhiyun /* backend: initialization */ 358*4882a593Smuzhiyun struct ps3av_pkt_av_init { 359*4882a593Smuzhiyun struct ps3av_send_hdr send_hdr; 360*4882a593Smuzhiyun u32 event_bit; 361*4882a593Smuzhiyun }; 362*4882a593Smuzhiyun 363*4882a593Smuzhiyun /* backend: finalize */ 364*4882a593Smuzhiyun struct ps3av_pkt_av_fin { 365*4882a593Smuzhiyun struct ps3av_send_hdr send_hdr; 366*4882a593Smuzhiyun /* recv */ 367*4882a593Smuzhiyun u32 reserved; 368*4882a593Smuzhiyun }; 369*4882a593Smuzhiyun 370*4882a593Smuzhiyun /* backend: get port */ 371*4882a593Smuzhiyun struct ps3av_pkt_av_get_hw_conf { 372*4882a593Smuzhiyun struct ps3av_send_hdr send_hdr; 373*4882a593Smuzhiyun /* recv */ 374*4882a593Smuzhiyun u32 status; 375*4882a593Smuzhiyun u16 num_of_hdmi; /* out: number of hdmi */ 376*4882a593Smuzhiyun u16 num_of_avmulti; /* out: number of avmulti */ 377*4882a593Smuzhiyun u16 num_of_spdif; /* out: number of hdmi */ 378*4882a593Smuzhiyun u16 reserved; 379*4882a593Smuzhiyun }; 380*4882a593Smuzhiyun 381*4882a593Smuzhiyun /* backend: get monitor info */ 382*4882a593Smuzhiyun struct ps3av_info_resolution { 383*4882a593Smuzhiyun u32 res_bits; 384*4882a593Smuzhiyun u32 native; 385*4882a593Smuzhiyun }; 386*4882a593Smuzhiyun 387*4882a593Smuzhiyun struct ps3av_info_cs { 388*4882a593Smuzhiyun u8 rgb; 389*4882a593Smuzhiyun u8 yuv444; 390*4882a593Smuzhiyun u8 yuv422; 391*4882a593Smuzhiyun u8 reserved; 392*4882a593Smuzhiyun }; 393*4882a593Smuzhiyun 394*4882a593Smuzhiyun struct ps3av_info_color { 395*4882a593Smuzhiyun u16 red_x; 396*4882a593Smuzhiyun u16 red_y; 397*4882a593Smuzhiyun u16 green_x; 398*4882a593Smuzhiyun u16 green_y; 399*4882a593Smuzhiyun u16 blue_x; 400*4882a593Smuzhiyun u16 blue_y; 401*4882a593Smuzhiyun u16 white_x; 402*4882a593Smuzhiyun u16 white_y; 403*4882a593Smuzhiyun u32 gamma; 404*4882a593Smuzhiyun }; 405*4882a593Smuzhiyun 406*4882a593Smuzhiyun struct ps3av_info_audio { 407*4882a593Smuzhiyun u8 type; 408*4882a593Smuzhiyun u8 max_num_of_ch; 409*4882a593Smuzhiyun u8 fs; 410*4882a593Smuzhiyun u8 sbit; 411*4882a593Smuzhiyun }; 412*4882a593Smuzhiyun 413*4882a593Smuzhiyun struct ps3av_info_monitor { 414*4882a593Smuzhiyun u8 avport; 415*4882a593Smuzhiyun u8 monitor_id[10]; 416*4882a593Smuzhiyun u8 monitor_type; 417*4882a593Smuzhiyun u8 monitor_name[16]; 418*4882a593Smuzhiyun struct ps3av_info_resolution res_60; 419*4882a593Smuzhiyun struct ps3av_info_resolution res_50; 420*4882a593Smuzhiyun struct ps3av_info_resolution res_other; 421*4882a593Smuzhiyun struct ps3av_info_resolution res_vesa; 422*4882a593Smuzhiyun struct ps3av_info_cs cs; 423*4882a593Smuzhiyun struct ps3av_info_color color; 424*4882a593Smuzhiyun u8 supported_ai; 425*4882a593Smuzhiyun u8 speaker_info; 426*4882a593Smuzhiyun u8 num_of_audio_block; 427*4882a593Smuzhiyun struct ps3av_info_audio audio[0]; /* 0 or more audio blocks */ 428*4882a593Smuzhiyun u8 reserved[169]; 429*4882a593Smuzhiyun } __attribute__ ((packed)); 430*4882a593Smuzhiyun 431*4882a593Smuzhiyun struct ps3av_pkt_av_get_monitor_info { 432*4882a593Smuzhiyun struct ps3av_send_hdr send_hdr; 433*4882a593Smuzhiyun u16 avport; /* in: avport */ 434*4882a593Smuzhiyun u16 reserved; 435*4882a593Smuzhiyun /* recv */ 436*4882a593Smuzhiyun struct ps3av_info_monitor info; /* out: monitor info */ 437*4882a593Smuzhiyun }; 438*4882a593Smuzhiyun 439*4882a593Smuzhiyun /* backend: enable/disable event */ 440*4882a593Smuzhiyun struct ps3av_pkt_av_event { 441*4882a593Smuzhiyun struct ps3av_send_hdr send_hdr; 442*4882a593Smuzhiyun u32 event_bit; /* in */ 443*4882a593Smuzhiyun }; 444*4882a593Smuzhiyun 445*4882a593Smuzhiyun /* backend: video cs param */ 446*4882a593Smuzhiyun struct ps3av_pkt_av_video_cs { 447*4882a593Smuzhiyun struct ps3av_send_hdr send_hdr; 448*4882a593Smuzhiyun u16 avport; /* in: avport */ 449*4882a593Smuzhiyun u16 av_vid; /* in: video resolution */ 450*4882a593Smuzhiyun u16 av_cs_out; /* in: output color space */ 451*4882a593Smuzhiyun u16 av_cs_in; /* in: input color space */ 452*4882a593Smuzhiyun u8 dither; /* in: dither bit length */ 453*4882a593Smuzhiyun u8 bitlen_out; /* in: bit length */ 454*4882a593Smuzhiyun u8 super_white; /* in: super white */ 455*4882a593Smuzhiyun u8 aspect; /* in: aspect ratio */ 456*4882a593Smuzhiyun }; 457*4882a593Smuzhiyun 458*4882a593Smuzhiyun /* backend: video mute */ 459*4882a593Smuzhiyun struct ps3av_av_mute { 460*4882a593Smuzhiyun u16 avport; /* in: avport */ 461*4882a593Smuzhiyun u16 mute; /* in: mute on/off */ 462*4882a593Smuzhiyun }; 463*4882a593Smuzhiyun 464*4882a593Smuzhiyun struct ps3av_pkt_av_video_mute { 465*4882a593Smuzhiyun struct ps3av_send_hdr send_hdr; 466*4882a593Smuzhiyun struct ps3av_av_mute mute[PS3AV_MUTE_PORT_MAX]; 467*4882a593Smuzhiyun }; 468*4882a593Smuzhiyun 469*4882a593Smuzhiyun /* backend: video disable signal */ 470*4882a593Smuzhiyun struct ps3av_pkt_av_video_disable_sig { 471*4882a593Smuzhiyun struct ps3av_send_hdr send_hdr; 472*4882a593Smuzhiyun u16 avport; /* in: avport */ 473*4882a593Smuzhiyun u16 reserved; 474*4882a593Smuzhiyun }; 475*4882a593Smuzhiyun 476*4882a593Smuzhiyun /* backend: audio param */ 477*4882a593Smuzhiyun struct ps3av_audio_info_frame { 478*4882a593Smuzhiyun struct pb1_bit { 479*4882a593Smuzhiyun u8 ct:4; 480*4882a593Smuzhiyun u8 rsv:1; 481*4882a593Smuzhiyun u8 cc:3; 482*4882a593Smuzhiyun } pb1; 483*4882a593Smuzhiyun struct pb2_bit { 484*4882a593Smuzhiyun u8 rsv:3; 485*4882a593Smuzhiyun u8 sf:3; 486*4882a593Smuzhiyun u8 ss:2; 487*4882a593Smuzhiyun } pb2; 488*4882a593Smuzhiyun u8 pb3; 489*4882a593Smuzhiyun u8 pb4; 490*4882a593Smuzhiyun struct pb5_bit { 491*4882a593Smuzhiyun u8 dm:1; 492*4882a593Smuzhiyun u8 lsv:4; 493*4882a593Smuzhiyun u8 rsv:3; 494*4882a593Smuzhiyun } pb5; 495*4882a593Smuzhiyun }; 496*4882a593Smuzhiyun 497*4882a593Smuzhiyun struct ps3av_pkt_av_audio_param { 498*4882a593Smuzhiyun struct ps3av_send_hdr send_hdr; 499*4882a593Smuzhiyun u16 avport; /* in: avport */ 500*4882a593Smuzhiyun u16 reserved; 501*4882a593Smuzhiyun u8 mclk; /* in: audio mclk */ 502*4882a593Smuzhiyun u8 ns[3]; /* in: audio ns val */ 503*4882a593Smuzhiyun u8 enable; /* in: audio enable */ 504*4882a593Smuzhiyun u8 swaplr; /* in: audio swap */ 505*4882a593Smuzhiyun u8 fifomap; /* in: audio fifomap */ 506*4882a593Smuzhiyun u8 inputctrl; /* in: audio input ctrl */ 507*4882a593Smuzhiyun u8 inputlen; /* in: sample bit size */ 508*4882a593Smuzhiyun u8 layout; /* in: speaker layout param */ 509*4882a593Smuzhiyun struct ps3av_audio_info_frame info; /* in: info */ 510*4882a593Smuzhiyun u8 chstat[5]; /* in: ch stat */ 511*4882a593Smuzhiyun }; 512*4882a593Smuzhiyun 513*4882a593Smuzhiyun /* backend: audio_mute */ 514*4882a593Smuzhiyun struct ps3av_pkt_av_audio_mute { 515*4882a593Smuzhiyun struct ps3av_send_hdr send_hdr; 516*4882a593Smuzhiyun struct ps3av_av_mute mute[PS3AV_MUTE_PORT_MAX]; 517*4882a593Smuzhiyun }; 518*4882a593Smuzhiyun 519*4882a593Smuzhiyun /* backend: hdmi_mode */ 520*4882a593Smuzhiyun struct ps3av_pkt_av_hdmi_mode { 521*4882a593Smuzhiyun struct ps3av_send_hdr send_hdr; 522*4882a593Smuzhiyun u8 mode; /* in: hdmi_mode */ 523*4882a593Smuzhiyun u8 reserved0; 524*4882a593Smuzhiyun u8 reserved1; 525*4882a593Smuzhiyun u8 reserved2; 526*4882a593Smuzhiyun }; 527*4882a593Smuzhiyun 528*4882a593Smuzhiyun /* backend: tv_mute */ 529*4882a593Smuzhiyun struct ps3av_pkt_av_tv_mute { 530*4882a593Smuzhiyun struct ps3av_send_hdr send_hdr; 531*4882a593Smuzhiyun u16 avport; /* in: avport HDMI only */ 532*4882a593Smuzhiyun u16 mute; /* in: mute */ 533*4882a593Smuzhiyun }; 534*4882a593Smuzhiyun 535*4882a593Smuzhiyun /* video: initialize */ 536*4882a593Smuzhiyun struct ps3av_pkt_video_init { 537*4882a593Smuzhiyun struct ps3av_send_hdr send_hdr; 538*4882a593Smuzhiyun /* recv */ 539*4882a593Smuzhiyun u32 reserved; 540*4882a593Smuzhiyun }; 541*4882a593Smuzhiyun 542*4882a593Smuzhiyun /* video: mode setting */ 543*4882a593Smuzhiyun struct ps3av_pkt_video_mode { 544*4882a593Smuzhiyun struct ps3av_send_hdr send_hdr; 545*4882a593Smuzhiyun u32 video_head; /* in: head */ 546*4882a593Smuzhiyun u32 reserved; 547*4882a593Smuzhiyun u32 video_vid; /* in: video resolution */ 548*4882a593Smuzhiyun u16 reserved1; 549*4882a593Smuzhiyun u16 width; /* in: width in pixel */ 550*4882a593Smuzhiyun u16 reserved2; 551*4882a593Smuzhiyun u16 height; /* in: height in pixel */ 552*4882a593Smuzhiyun u32 pitch; /* in: line size in byte */ 553*4882a593Smuzhiyun u32 video_out_format; /* in: out format */ 554*4882a593Smuzhiyun u32 video_format; /* in: input frame buffer format */ 555*4882a593Smuzhiyun u8 reserved3; 556*4882a593Smuzhiyun u8 video_cl_cnv; /* in: color conversion */ 557*4882a593Smuzhiyun u16 video_order; /* in: input RGB order */ 558*4882a593Smuzhiyun u32 reserved4; 559*4882a593Smuzhiyun }; 560*4882a593Smuzhiyun 561*4882a593Smuzhiyun /* video: format */ 562*4882a593Smuzhiyun struct ps3av_pkt_video_format { 563*4882a593Smuzhiyun struct ps3av_send_hdr send_hdr; 564*4882a593Smuzhiyun u32 video_head; /* in: head */ 565*4882a593Smuzhiyun u32 video_format; /* in: frame buffer format */ 566*4882a593Smuzhiyun u8 reserved; 567*4882a593Smuzhiyun u8 video_cl_cnv; /* in: color conversion */ 568*4882a593Smuzhiyun u16 video_order; /* in: input RGB order */ 569*4882a593Smuzhiyun }; 570*4882a593Smuzhiyun 571*4882a593Smuzhiyun /* video: pitch */ 572*4882a593Smuzhiyun struct ps3av_pkt_video_pitch { 573*4882a593Smuzhiyun u16 version; 574*4882a593Smuzhiyun u16 size; /* size of command packet */ 575*4882a593Smuzhiyun u32 cid; /* command id */ 576*4882a593Smuzhiyun u32 video_head; /* in: head */ 577*4882a593Smuzhiyun u32 pitch; /* in: line size in byte */ 578*4882a593Smuzhiyun }; 579*4882a593Smuzhiyun 580*4882a593Smuzhiyun /* audio: initialize */ 581*4882a593Smuzhiyun struct ps3av_pkt_audio_init { 582*4882a593Smuzhiyun struct ps3av_send_hdr send_hdr; 583*4882a593Smuzhiyun /* recv */ 584*4882a593Smuzhiyun u32 reserved; 585*4882a593Smuzhiyun }; 586*4882a593Smuzhiyun 587*4882a593Smuzhiyun /* audio: mode setting */ 588*4882a593Smuzhiyun struct ps3av_pkt_audio_mode { 589*4882a593Smuzhiyun struct ps3av_send_hdr send_hdr; 590*4882a593Smuzhiyun u8 avport; /* in: avport */ 591*4882a593Smuzhiyun u8 reserved0[3]; 592*4882a593Smuzhiyun u32 mask; /* in: mask */ 593*4882a593Smuzhiyun u32 audio_num_of_ch; /* in: number of ch */ 594*4882a593Smuzhiyun u32 audio_fs; /* in: sampling freq */ 595*4882a593Smuzhiyun u32 audio_word_bits; /* in: sample bit size */ 596*4882a593Smuzhiyun u32 audio_format; /* in: audio output format */ 597*4882a593Smuzhiyun u32 audio_source; /* in: audio source */ 598*4882a593Smuzhiyun u8 audio_enable[4]; /* in: audio enable */ 599*4882a593Smuzhiyun u8 audio_swap[4]; /* in: audio swap */ 600*4882a593Smuzhiyun u8 audio_map[4]; /* in: audio map */ 601*4882a593Smuzhiyun u32 audio_layout; /* in: speaker layout */ 602*4882a593Smuzhiyun u32 audio_downmix; /* in: audio downmix permission */ 603*4882a593Smuzhiyun u32 audio_downmix_level; 604*4882a593Smuzhiyun u8 audio_cs_info[8]; /* in: IEC channel status */ 605*4882a593Smuzhiyun }; 606*4882a593Smuzhiyun 607*4882a593Smuzhiyun /* audio: mute */ 608*4882a593Smuzhiyun struct ps3av_audio_mute { 609*4882a593Smuzhiyun u8 avport; /* in: opt_port optical */ 610*4882a593Smuzhiyun u8 reserved[3]; 611*4882a593Smuzhiyun u32 mute; /* in: mute */ 612*4882a593Smuzhiyun }; 613*4882a593Smuzhiyun 614*4882a593Smuzhiyun struct ps3av_pkt_audio_mute { 615*4882a593Smuzhiyun struct ps3av_send_hdr send_hdr; 616*4882a593Smuzhiyun struct ps3av_audio_mute mute[PS3AV_OPT_PORT_MAX]; 617*4882a593Smuzhiyun }; 618*4882a593Smuzhiyun 619*4882a593Smuzhiyun /* audio: active/inactive */ 620*4882a593Smuzhiyun struct ps3av_pkt_audio_active { 621*4882a593Smuzhiyun struct ps3av_send_hdr send_hdr; 622*4882a593Smuzhiyun u32 audio_port; /* in: audio active/inactive port */ 623*4882a593Smuzhiyun }; 624*4882a593Smuzhiyun 625*4882a593Smuzhiyun /* audio: SPDIF user bit */ 626*4882a593Smuzhiyun struct ps3av_pkt_audio_spdif_bit { 627*4882a593Smuzhiyun u16 version; 628*4882a593Smuzhiyun u16 size; /* size of command packet */ 629*4882a593Smuzhiyun u32 cid; /* command id */ 630*4882a593Smuzhiyun u8 avport; /* in: avport SPDIF only */ 631*4882a593Smuzhiyun u8 reserved[3]; 632*4882a593Smuzhiyun u32 audio_port; /* in: SPDIF only */ 633*4882a593Smuzhiyun u32 spdif_bit_data[12]; /* in: user bit data */ 634*4882a593Smuzhiyun }; 635*4882a593Smuzhiyun 636*4882a593Smuzhiyun /* audio: audio control */ 637*4882a593Smuzhiyun struct ps3av_pkt_audio_ctrl { 638*4882a593Smuzhiyun u16 version; 639*4882a593Smuzhiyun u16 size; /* size of command packet */ 640*4882a593Smuzhiyun u32 cid; /* command id */ 641*4882a593Smuzhiyun u32 audio_ctrl_id; /* in: control id */ 642*4882a593Smuzhiyun u32 audio_ctrl_data[4]; /* in: control data */ 643*4882a593Smuzhiyun }; 644*4882a593Smuzhiyun 645*4882a593Smuzhiyun /* avb:param */ 646*4882a593Smuzhiyun #define PS3AV_PKT_AVB_PARAM_MAX_BUF_SIZE \ 647*4882a593Smuzhiyun (PS3AV_AVB_NUM_VIDEO*sizeof(struct ps3av_pkt_video_mode) + \ 648*4882a593Smuzhiyun PS3AV_AVB_NUM_AUDIO*sizeof(struct ps3av_pkt_audio_mode) + \ 649*4882a593Smuzhiyun PS3AV_AVB_NUM_AV_VIDEO*sizeof(struct ps3av_pkt_av_video_cs) + \ 650*4882a593Smuzhiyun PS3AV_AVB_NUM_AV_AUDIO*sizeof(struct ps3av_pkt_av_audio_param)) 651*4882a593Smuzhiyun 652*4882a593Smuzhiyun struct ps3av_pkt_avb_param { 653*4882a593Smuzhiyun struct ps3av_send_hdr send_hdr; 654*4882a593Smuzhiyun u16 num_of_video_pkt; 655*4882a593Smuzhiyun u16 num_of_audio_pkt; 656*4882a593Smuzhiyun u16 num_of_av_video_pkt; 657*4882a593Smuzhiyun u16 num_of_av_audio_pkt; 658*4882a593Smuzhiyun /* 659*4882a593Smuzhiyun * The actual buffer layout depends on the fields above: 660*4882a593Smuzhiyun * 661*4882a593Smuzhiyun * struct ps3av_pkt_video_mode video[num_of_video_pkt]; 662*4882a593Smuzhiyun * struct ps3av_pkt_audio_mode audio[num_of_audio_pkt]; 663*4882a593Smuzhiyun * struct ps3av_pkt_av_video_cs av_video[num_of_av_video_pkt]; 664*4882a593Smuzhiyun * struct ps3av_pkt_av_audio_param av_audio[num_of_av_audio_pkt]; 665*4882a593Smuzhiyun */ 666*4882a593Smuzhiyun u8 buf[PS3AV_PKT_AVB_PARAM_MAX_BUF_SIZE]; 667*4882a593Smuzhiyun }; 668*4882a593Smuzhiyun 669*4882a593Smuzhiyun /* channel status */ 670*4882a593Smuzhiyun extern u8 ps3av_mode_cs_info[]; 671*4882a593Smuzhiyun 672*4882a593Smuzhiyun /** command status **/ 673*4882a593Smuzhiyun #define PS3AV_STATUS_SUCCESS 0x0000 /* success */ 674*4882a593Smuzhiyun #define PS3AV_STATUS_RECEIVE_VUART_ERROR 0x0001 /* receive vuart error */ 675*4882a593Smuzhiyun #define PS3AV_STATUS_SYSCON_COMMUNICATE_FAIL 0x0002 /* syscon communication error */ 676*4882a593Smuzhiyun #define PS3AV_STATUS_INVALID_COMMAND 0x0003 /* obsolete invalid CID */ 677*4882a593Smuzhiyun #define PS3AV_STATUS_INVALID_PORT 0x0004 /* invalid port number */ 678*4882a593Smuzhiyun #define PS3AV_STATUS_INVALID_VID 0x0005 /* invalid video format */ 679*4882a593Smuzhiyun #define PS3AV_STATUS_INVALID_COLOR_SPACE 0x0006 /* invalid video colose space */ 680*4882a593Smuzhiyun #define PS3AV_STATUS_INVALID_FS 0x0007 /* invalid audio sampling freq */ 681*4882a593Smuzhiyun #define PS3AV_STATUS_INVALID_AUDIO_CH 0x0008 /* invalid audio channel number */ 682*4882a593Smuzhiyun #define PS3AV_STATUS_UNSUPPORTED_VERSION 0x0009 /* version mismatch */ 683*4882a593Smuzhiyun #define PS3AV_STATUS_INVALID_SAMPLE_SIZE 0x000a /* invalid audio sample bit size */ 684*4882a593Smuzhiyun #define PS3AV_STATUS_FAILURE 0x000b /* other failures */ 685*4882a593Smuzhiyun #define PS3AV_STATUS_UNSUPPORTED_COMMAND 0x000c /* unsupported cid */ 686*4882a593Smuzhiyun #define PS3AV_STATUS_BUFFER_OVERFLOW 0x000d /* write buffer overflow */ 687*4882a593Smuzhiyun #define PS3AV_STATUS_INVALID_VIDEO_PARAM 0x000e /* invalid video param */ 688*4882a593Smuzhiyun #define PS3AV_STATUS_NO_SEL 0x000f /* not exist selector */ 689*4882a593Smuzhiyun #define PS3AV_STATUS_INVALID_AV_PARAM 0x0010 /* invalid backend param */ 690*4882a593Smuzhiyun #define PS3AV_STATUS_INVALID_AUDIO_PARAM 0x0011 /* invalid audio param */ 691*4882a593Smuzhiyun #define PS3AV_STATUS_UNSUPPORTED_HDMI_MODE 0x0012 /* unsupported hdmi mode */ 692*4882a593Smuzhiyun #define PS3AV_STATUS_NO_SYNC_HEAD 0x0013 /* sync head failed */ 693*4882a593Smuzhiyun 694*4882a593Smuzhiyun extern void ps3av_set_hdr(u32, u16, struct ps3av_send_hdr *); 695*4882a593Smuzhiyun extern int ps3av_do_pkt(u32, u16, size_t, struct ps3av_send_hdr *); 696*4882a593Smuzhiyun 697*4882a593Smuzhiyun extern int ps3av_cmd_init(void); 698*4882a593Smuzhiyun extern int ps3av_cmd_fin(void); 699*4882a593Smuzhiyun extern int ps3av_cmd_av_video_mute(int, u32 *, u32); 700*4882a593Smuzhiyun extern int ps3av_cmd_av_video_disable_sig(u32); 701*4882a593Smuzhiyun extern int ps3av_cmd_av_tv_mute(u32, u32); 702*4882a593Smuzhiyun extern int ps3av_cmd_enable_event(void); 703*4882a593Smuzhiyun extern int ps3av_cmd_av_hdmi_mode(u8); 704*4882a593Smuzhiyun extern u32 ps3av_cmd_set_av_video_cs(void *, u32, int, int, int, u32); 705*4882a593Smuzhiyun extern u32 ps3av_cmd_set_video_mode(void *, u32, int, int, u32); 706*4882a593Smuzhiyun extern int ps3av_cmd_video_format_black(u32, u32, u32); 707*4882a593Smuzhiyun extern int ps3av_cmd_av_audio_mute(int, u32 *, u32); 708*4882a593Smuzhiyun extern u32 ps3av_cmd_set_av_audio_param(void *, u32, 709*4882a593Smuzhiyun const struct ps3av_pkt_audio_mode *, 710*4882a593Smuzhiyun u32); 711*4882a593Smuzhiyun extern void ps3av_cmd_set_audio_mode(struct ps3av_pkt_audio_mode *, u32, u32, 712*4882a593Smuzhiyun u32, u32, u32, u32); 713*4882a593Smuzhiyun extern int ps3av_cmd_audio_mode(struct ps3av_pkt_audio_mode *); 714*4882a593Smuzhiyun extern int ps3av_cmd_audio_mute(int, u32 *, u32); 715*4882a593Smuzhiyun extern int ps3av_cmd_audio_active(int, u32); 716*4882a593Smuzhiyun extern int ps3av_cmd_avb_param(struct ps3av_pkt_avb_param *, u32); 717*4882a593Smuzhiyun extern int ps3av_cmd_av_get_hw_conf(struct ps3av_pkt_av_get_hw_conf *); 718*4882a593Smuzhiyun extern int ps3av_cmd_video_get_monitor_info(struct ps3av_pkt_av_get_monitor_info *, 719*4882a593Smuzhiyun u32); 720*4882a593Smuzhiyun 721*4882a593Smuzhiyun extern int ps3av_set_video_mode(int); 722*4882a593Smuzhiyun extern int ps3av_set_audio_mode(u32, u32, u32, u32, u32); 723*4882a593Smuzhiyun extern int ps3av_get_auto_mode(void); 724*4882a593Smuzhiyun extern int ps3av_get_mode(void); 725*4882a593Smuzhiyun extern int ps3av_video_mode2res(u32, u32 *, u32 *); 726*4882a593Smuzhiyun extern int ps3av_video_mute(int); 727*4882a593Smuzhiyun extern int ps3av_audio_mute(int); 728*4882a593Smuzhiyun extern int ps3av_audio_mute_analog(int); 729*4882a593Smuzhiyun extern int ps3av_dev_open(void); 730*4882a593Smuzhiyun extern int ps3av_dev_close(void); 731*4882a593Smuzhiyun #endif /* _ASM_POWERPC_PS3AV_H_ */ 732