/* * Copyright 2012-15 Advanced Micro Devices, Inc. * * 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, sublicense, * 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 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 NONINFRINGEMENT. IN NO EVENT SHALL * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) 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. * * Authors: AMD * */ #ifndef __DAL_GRPH_OBJECT_DEFS_H__ #define __DAL_GRPH_OBJECT_DEFS_H__ #include "grph_object_id.h" /* ******************************************************************** * ******************************************************************** * * These defines shared between All Graphics Objects * * ******************************************************************** * ******************************************************************** */ #define MAX_CONNECTOR_NUMBER_PER_SLOT (16) #define MAX_BOARD_SLOTS (4) #define INVALID_CONNECTOR_INDEX ((unsigned int)(-1)) /* HPD unit id - HW direct translation */ enum hpd_source_id { HPD_SOURCEID1 = 0, HPD_SOURCEID2, HPD_SOURCEID3, HPD_SOURCEID4, HPD_SOURCEID5, HPD_SOURCEID6, HPD_SOURCEID_COUNT, HPD_SOURCEID_UNKNOWN }; /* DDC unit id - HW direct translation */ enum channel_id { CHANNEL_ID_UNKNOWN = 0, CHANNEL_ID_DDC1, CHANNEL_ID_DDC2, CHANNEL_ID_DDC3, CHANNEL_ID_DDC4, CHANNEL_ID_DDC5, CHANNEL_ID_DDC6, CHANNEL_ID_DDC_VGA, CHANNEL_ID_I2C_PAD, CHANNEL_ID_COUNT }; #define DECODE_CHANNEL_ID(ch_id) \ (ch_id) == CHANNEL_ID_DDC1 ? "CHANNEL_ID_DDC1" : \ (ch_id) == CHANNEL_ID_DDC2 ? "CHANNEL_ID_DDC2" : \ (ch_id) == CHANNEL_ID_DDC3 ? "CHANNEL_ID_DDC3" : \ (ch_id) == CHANNEL_ID_DDC4 ? "CHANNEL_ID_DDC4" : \ (ch_id) == CHANNEL_ID_DDC5 ? "CHANNEL_ID_DDC5" : \ (ch_id) == CHANNEL_ID_DDC6 ? "CHANNEL_ID_DDC6" : \ (ch_id) == CHANNEL_ID_DDC_VGA ? "CHANNEL_ID_DDC_VGA" : \ (ch_id) == CHANNEL_ID_I2C_PAD ? "CHANNEL_ID_I2C_PAD" : "Invalid" enum transmitter { TRANSMITTER_UNKNOWN = (-1L), TRANSMITTER_UNIPHY_A, TRANSMITTER_UNIPHY_B, TRANSMITTER_UNIPHY_C, TRANSMITTER_UNIPHY_D, TRANSMITTER_UNIPHY_E, TRANSMITTER_UNIPHY_F, TRANSMITTER_NUTMEG_CRT, TRANSMITTER_TRAVIS_CRT, TRANSMITTER_TRAVIS_LCD, TRANSMITTER_UNIPHY_G, TRANSMITTER_COUNT }; /* Generic source of the synchronisation input/output signal */ /* Can be used for flow control, stereo sync, timing sync, frame sync, etc */ enum sync_source { SYNC_SOURCE_NONE = 0, /* Source based on controllers */ SYNC_SOURCE_CONTROLLER0, SYNC_SOURCE_CONTROLLER1, SYNC_SOURCE_CONTROLLER2, SYNC_SOURCE_CONTROLLER3, SYNC_SOURCE_CONTROLLER4, SYNC_SOURCE_CONTROLLER5, /* Source based on GSL group */ SYNC_SOURCE_GSL_GROUP0, SYNC_SOURCE_GSL_GROUP1, SYNC_SOURCE_GSL_GROUP2, /* Source based on GSL IOs */ /* These IOs normally used as GSL input/output */ SYNC_SOURCE_GSL_IO_FIRST, SYNC_SOURCE_GSL_IO_GENLOCK_CLOCK = SYNC_SOURCE_GSL_IO_FIRST, SYNC_SOURCE_GSL_IO_GENLOCK_VSYNC, SYNC_SOURCE_GSL_IO_SWAPLOCK_A, SYNC_SOURCE_GSL_IO_SWAPLOCK_B, SYNC_SOURCE_GSL_IO_LAST = SYNC_SOURCE_GSL_IO_SWAPLOCK_B, /* Source based on regular IOs */ SYNC_SOURCE_IO_FIRST, SYNC_SOURCE_IO_GENERIC_A = SYNC_SOURCE_IO_FIRST, SYNC_SOURCE_IO_GENERIC_B, SYNC_SOURCE_IO_GENERIC_C, SYNC_SOURCE_IO_GENERIC_D, SYNC_SOURCE_IO_GENERIC_E, SYNC_SOURCE_IO_GENERIC_F, SYNC_SOURCE_IO_HPD1, SYNC_SOURCE_IO_HPD2, SYNC_SOURCE_IO_HSYNC_A, SYNC_SOURCE_IO_VSYNC_A, SYNC_SOURCE_IO_HSYNC_B, SYNC_SOURCE_IO_VSYNC_B, SYNC_SOURCE_IO_LAST = SYNC_SOURCE_IO_VSYNC_B, /* Misc. flow control sources */ SYNC_SOURCE_DUAL_GPU_PIN }; /* connector sizes in millimeters - from BiosParserTypes.hpp */ #define CONNECTOR_SIZE_DVI 40 #define CONNECTOR_SIZE_VGA 32 #define CONNECTOR_SIZE_HDMI 16 #define CONNECTOR_SIZE_DP 16 #define CONNECTOR_SIZE_MINI_DP 9 #define CONNECTOR_SIZE_UNKNOWN 30 enum connector_layout_type { CONNECTOR_LAYOUT_TYPE_UNKNOWN, CONNECTOR_LAYOUT_TYPE_DVI_D, CONNECTOR_LAYOUT_TYPE_DVI_I, CONNECTOR_LAYOUT_TYPE_VGA, CONNECTOR_LAYOUT_TYPE_HDMI, CONNECTOR_LAYOUT_TYPE_DP, CONNECTOR_LAYOUT_TYPE_MINI_DP, }; struct connector_layout_info { struct graphics_object_id connector_id; enum connector_layout_type connector_type; unsigned int length; unsigned int position; /* offset in mm from right side of the board */ }; /* length and width in mm */ struct slot_layout_info { unsigned int length; unsigned int width; unsigned int num_of_connectors; struct connector_layout_info connectors[MAX_CONNECTOR_NUMBER_PER_SLOT]; }; struct board_layout_info { unsigned int num_of_slots; /* indicates valid information in bracket layout structure. */ unsigned int is_number_of_slots_valid : 1; unsigned int is_slots_size_valid : 1; unsigned int is_connector_offsets_valid : 1; unsigned int is_connector_lengths_valid : 1; struct slot_layout_info slots[MAX_BOARD_SLOTS]; }; #endif