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