16596afd4SAlex Deucher /* 26596afd4SAlex Deucher * Copyright 2011 Advanced Micro Devices, Inc. 36596afd4SAlex Deucher * 46596afd4SAlex Deucher * Permission is hereby granted, free of charge, to any person obtaining a 56596afd4SAlex Deucher * copy of this software and associated documentation files (the "Software"), 66596afd4SAlex Deucher * to deal in the Software without restriction, including without limitation 76596afd4SAlex Deucher * the rights to use, copy, modify, merge, publish, distribute, sublicense, 86596afd4SAlex Deucher * and/or sell copies of the Software, and to permit persons to whom the 96596afd4SAlex Deucher * Software is furnished to do so, subject to the following conditions: 106596afd4SAlex Deucher * 116596afd4SAlex Deucher * The above copyright notice and this permission notice shall be included in 126596afd4SAlex Deucher * all copies or substantial portions of the Software. 136596afd4SAlex Deucher * 146596afd4SAlex Deucher * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 156596afd4SAlex Deucher * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 166596afd4SAlex Deucher * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL 176596afd4SAlex Deucher * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR 186596afd4SAlex Deucher * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, 196596afd4SAlex Deucher * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR 206596afd4SAlex Deucher * OTHER DEALINGS IN THE SOFTWARE. 216596afd4SAlex Deucher * 226596afd4SAlex Deucher * Authors: Alex Deucher 236596afd4SAlex Deucher */ 246596afd4SAlex Deucher 256596afd4SAlex Deucher #include "drmP.h" 266596afd4SAlex Deucher #include "radeon.h" 276596afd4SAlex Deucher #include "btcd.h" 286596afd4SAlex Deucher #include "r600_dpm.h" 296596afd4SAlex Deucher #include "cypress_dpm.h" 306596afd4SAlex Deucher #include "btc_dpm.h" 316596afd4SAlex Deucher #include "atom.h" 326596afd4SAlex Deucher 336596afd4SAlex Deucher #define MC_CG_ARB_FREQ_F0 0x0a 346596afd4SAlex Deucher #define MC_CG_ARB_FREQ_F1 0x0b 356596afd4SAlex Deucher #define MC_CG_ARB_FREQ_F2 0x0c 366596afd4SAlex Deucher #define MC_CG_ARB_FREQ_F3 0x0d 376596afd4SAlex Deucher 386596afd4SAlex Deucher #define MC_CG_SEQ_DRAMCONF_S0 0x05 396596afd4SAlex Deucher #define MC_CG_SEQ_DRAMCONF_S1 0x06 406596afd4SAlex Deucher #define MC_CG_SEQ_YCLK_SUSPEND 0x04 416596afd4SAlex Deucher #define MC_CG_SEQ_YCLK_RESUME 0x0a 426596afd4SAlex Deucher 436596afd4SAlex Deucher #define SMC_RAM_END 0x8000 446596afd4SAlex Deucher 456596afd4SAlex Deucher #ifndef BTC_MGCG_SEQUENCE 466596afd4SAlex Deucher #define BTC_MGCG_SEQUENCE 300 476596afd4SAlex Deucher 486596afd4SAlex Deucher struct rv7xx_ps *rv770_get_ps(struct radeon_ps *rps); 496596afd4SAlex Deucher struct rv7xx_power_info *rv770_get_pi(struct radeon_device *rdev); 506596afd4SAlex Deucher struct evergreen_power_info *evergreen_get_pi(struct radeon_device *rdev); 516596afd4SAlex Deucher 52*6c7bcceaSAlex Deucher extern int ni_mc_load_microcode(struct radeon_device *rdev); 536596afd4SAlex Deucher 546596afd4SAlex Deucher //********* BARTS **************// 556596afd4SAlex Deucher static const u32 barts_cgcg_cgls_default[] = 566596afd4SAlex Deucher { 576596afd4SAlex Deucher /* Register, Value, Mask bits */ 586596afd4SAlex Deucher 0x000008f8, 0x00000010, 0xffffffff, 596596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 606596afd4SAlex Deucher 0x000008f8, 0x00000011, 0xffffffff, 616596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 626596afd4SAlex Deucher 0x000008f8, 0x00000012, 0xffffffff, 636596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 646596afd4SAlex Deucher 0x000008f8, 0x00000013, 0xffffffff, 656596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 666596afd4SAlex Deucher 0x000008f8, 0x00000014, 0xffffffff, 676596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 686596afd4SAlex Deucher 0x000008f8, 0x00000015, 0xffffffff, 696596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 706596afd4SAlex Deucher 0x000008f8, 0x00000016, 0xffffffff, 716596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 726596afd4SAlex Deucher 0x000008f8, 0x00000017, 0xffffffff, 736596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 746596afd4SAlex Deucher 0x000008f8, 0x00000018, 0xffffffff, 756596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 766596afd4SAlex Deucher 0x000008f8, 0x00000019, 0xffffffff, 776596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 786596afd4SAlex Deucher 0x000008f8, 0x0000001a, 0xffffffff, 796596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 806596afd4SAlex Deucher 0x000008f8, 0x0000001b, 0xffffffff, 816596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 826596afd4SAlex Deucher 0x000008f8, 0x00000020, 0xffffffff, 836596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 846596afd4SAlex Deucher 0x000008f8, 0x00000021, 0xffffffff, 856596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 866596afd4SAlex Deucher 0x000008f8, 0x00000022, 0xffffffff, 876596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 886596afd4SAlex Deucher 0x000008f8, 0x00000023, 0xffffffff, 896596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 906596afd4SAlex Deucher 0x000008f8, 0x00000024, 0xffffffff, 916596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 926596afd4SAlex Deucher 0x000008f8, 0x00000025, 0xffffffff, 936596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 946596afd4SAlex Deucher 0x000008f8, 0x00000026, 0xffffffff, 956596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 966596afd4SAlex Deucher 0x000008f8, 0x00000027, 0xffffffff, 976596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 986596afd4SAlex Deucher 0x000008f8, 0x00000028, 0xffffffff, 996596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 1006596afd4SAlex Deucher 0x000008f8, 0x00000029, 0xffffffff, 1016596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 1026596afd4SAlex Deucher 0x000008f8, 0x0000002a, 0xffffffff, 1036596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 1046596afd4SAlex Deucher 0x000008f8, 0x0000002b, 0xffffffff, 1056596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff 1066596afd4SAlex Deucher }; 1076596afd4SAlex Deucher #define BARTS_CGCG_CGLS_DEFAULT_LENGTH sizeof(barts_cgcg_cgls_default) / (3 * sizeof(u32)) 1086596afd4SAlex Deucher 1096596afd4SAlex Deucher static const u32 barts_cgcg_cgls_disable[] = 1106596afd4SAlex Deucher { 1116596afd4SAlex Deucher 0x000008f8, 0x00000010, 0xffffffff, 1126596afd4SAlex Deucher 0x000008fc, 0xffffffff, 0xffffffff, 1136596afd4SAlex Deucher 0x000008f8, 0x00000011, 0xffffffff, 1146596afd4SAlex Deucher 0x000008fc, 0xffffffff, 0xffffffff, 1156596afd4SAlex Deucher 0x000008f8, 0x00000012, 0xffffffff, 1166596afd4SAlex Deucher 0x000008fc, 0xffffffff, 0xffffffff, 1176596afd4SAlex Deucher 0x000008f8, 0x00000013, 0xffffffff, 1186596afd4SAlex Deucher 0x000008fc, 0xffffffff, 0xffffffff, 1196596afd4SAlex Deucher 0x000008f8, 0x00000014, 0xffffffff, 1206596afd4SAlex Deucher 0x000008fc, 0xffffffff, 0xffffffff, 1216596afd4SAlex Deucher 0x000008f8, 0x00000015, 0xffffffff, 1226596afd4SAlex Deucher 0x000008fc, 0xffffffff, 0xffffffff, 1236596afd4SAlex Deucher 0x000008f8, 0x00000016, 0xffffffff, 1246596afd4SAlex Deucher 0x000008fc, 0xffffffff, 0xffffffff, 1256596afd4SAlex Deucher 0x000008f8, 0x00000017, 0xffffffff, 1266596afd4SAlex Deucher 0x000008fc, 0xffffffff, 0xffffffff, 1276596afd4SAlex Deucher 0x000008f8, 0x00000018, 0xffffffff, 1286596afd4SAlex Deucher 0x000008fc, 0xffffffff, 0xffffffff, 1296596afd4SAlex Deucher 0x000008f8, 0x00000019, 0xffffffff, 1306596afd4SAlex Deucher 0x000008fc, 0xffffffff, 0xffffffff, 1316596afd4SAlex Deucher 0x000008f8, 0x0000001a, 0xffffffff, 1326596afd4SAlex Deucher 0x000008fc, 0xffffffff, 0xffffffff, 1336596afd4SAlex Deucher 0x000008f8, 0x0000001b, 0xffffffff, 1346596afd4SAlex Deucher 0x000008fc, 0xffffffff, 0xffffffff, 1356596afd4SAlex Deucher 0x000008f8, 0x00000020, 0xffffffff, 1366596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 1376596afd4SAlex Deucher 0x000008f8, 0x00000021, 0xffffffff, 1386596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 1396596afd4SAlex Deucher 0x000008f8, 0x00000022, 0xffffffff, 1406596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 1416596afd4SAlex Deucher 0x000008f8, 0x00000023, 0xffffffff, 1426596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 1436596afd4SAlex Deucher 0x000008f8, 0x00000024, 0xffffffff, 1446596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 1456596afd4SAlex Deucher 0x000008f8, 0x00000025, 0xffffffff, 1466596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 1476596afd4SAlex Deucher 0x000008f8, 0x00000026, 0xffffffff, 1486596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 1496596afd4SAlex Deucher 0x000008f8, 0x00000027, 0xffffffff, 1506596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 1516596afd4SAlex Deucher 0x000008f8, 0x00000028, 0xffffffff, 1526596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 1536596afd4SAlex Deucher 0x000008f8, 0x00000029, 0xffffffff, 1546596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 1556596afd4SAlex Deucher 0x000008f8, 0x0000002a, 0xffffffff, 1566596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 1576596afd4SAlex Deucher 0x000008f8, 0x0000002b, 0xffffffff, 1586596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 1596596afd4SAlex Deucher 0x00000644, 0x000f7912, 0x001f4180, 1606596afd4SAlex Deucher 0x00000644, 0x000f3812, 0x001f4180 1616596afd4SAlex Deucher }; 1626596afd4SAlex Deucher #define BARTS_CGCG_CGLS_DISABLE_LENGTH sizeof(barts_cgcg_cgls_disable) / (3 * sizeof(u32)) 1636596afd4SAlex Deucher 1646596afd4SAlex Deucher static const u32 barts_cgcg_cgls_enable[] = 1656596afd4SAlex Deucher { 1666596afd4SAlex Deucher /* 0x0000c124, 0x84180000, 0x00180000, */ 1676596afd4SAlex Deucher 0x00000644, 0x000f7892, 0x001f4080, 1686596afd4SAlex Deucher 0x000008f8, 0x00000010, 0xffffffff, 1696596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 1706596afd4SAlex Deucher 0x000008f8, 0x00000011, 0xffffffff, 1716596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 1726596afd4SAlex Deucher 0x000008f8, 0x00000012, 0xffffffff, 1736596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 1746596afd4SAlex Deucher 0x000008f8, 0x00000013, 0xffffffff, 1756596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 1766596afd4SAlex Deucher 0x000008f8, 0x00000014, 0xffffffff, 1776596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 1786596afd4SAlex Deucher 0x000008f8, 0x00000015, 0xffffffff, 1796596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 1806596afd4SAlex Deucher 0x000008f8, 0x00000016, 0xffffffff, 1816596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 1826596afd4SAlex Deucher 0x000008f8, 0x00000017, 0xffffffff, 1836596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 1846596afd4SAlex Deucher 0x000008f8, 0x00000018, 0xffffffff, 1856596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 1866596afd4SAlex Deucher 0x000008f8, 0x00000019, 0xffffffff, 1876596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 1886596afd4SAlex Deucher 0x000008f8, 0x0000001a, 0xffffffff, 1896596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 1906596afd4SAlex Deucher 0x000008f8, 0x0000001b, 0xffffffff, 1916596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 1926596afd4SAlex Deucher 0x000008f8, 0x00000020, 0xffffffff, 1936596afd4SAlex Deucher 0x000008fc, 0xffffffff, 0xffffffff, 1946596afd4SAlex Deucher 0x000008f8, 0x00000021, 0xffffffff, 1956596afd4SAlex Deucher 0x000008fc, 0xffffffff, 0xffffffff, 1966596afd4SAlex Deucher 0x000008f8, 0x00000022, 0xffffffff, 1976596afd4SAlex Deucher 0x000008fc, 0xffffffff, 0xffffffff, 1986596afd4SAlex Deucher 0x000008f8, 0x00000023, 0xffffffff, 1996596afd4SAlex Deucher 0x000008fc, 0xffffffff, 0xffffffff, 2006596afd4SAlex Deucher 0x000008f8, 0x00000024, 0xffffffff, 2016596afd4SAlex Deucher 0x000008fc, 0xffffffff, 0xffffffff, 2026596afd4SAlex Deucher 0x000008f8, 0x00000025, 0xffffffff, 2036596afd4SAlex Deucher 0x000008fc, 0xffffffff, 0xffffffff, 2046596afd4SAlex Deucher 0x000008f8, 0x00000026, 0xffffffff, 2056596afd4SAlex Deucher 0x000008fc, 0xffffffff, 0xffffffff, 2066596afd4SAlex Deucher 0x000008f8, 0x00000027, 0xffffffff, 2076596afd4SAlex Deucher 0x000008fc, 0xffffffff, 0xffffffff, 2086596afd4SAlex Deucher 0x000008f8, 0x00000028, 0xffffffff, 2096596afd4SAlex Deucher 0x000008fc, 0xffffffff, 0xffffffff, 2106596afd4SAlex Deucher 0x000008f8, 0x00000029, 0xffffffff, 2116596afd4SAlex Deucher 0x000008fc, 0xffffffff, 0xffffffff, 2126596afd4SAlex Deucher 0x000008f8, 0x0000002a, 0xffffffff, 2136596afd4SAlex Deucher 0x000008fc, 0xffffffff, 0xffffffff, 2146596afd4SAlex Deucher 0x000008f8, 0x0000002b, 0xffffffff, 2156596afd4SAlex Deucher 0x000008fc, 0xffffffff, 0xffffffff 2166596afd4SAlex Deucher }; 2176596afd4SAlex Deucher #define BARTS_CGCG_CGLS_ENABLE_LENGTH sizeof(barts_cgcg_cgls_enable) / (3 * sizeof(u32)) 2186596afd4SAlex Deucher 2196596afd4SAlex Deucher static const u32 barts_mgcg_default[] = 2206596afd4SAlex Deucher { 2216596afd4SAlex Deucher 0x0000802c, 0xc0000000, 0xffffffff, 2226596afd4SAlex Deucher 0x00005448, 0x00000100, 0xffffffff, 2236596afd4SAlex Deucher 0x000055e4, 0x00600100, 0xffffffff, 2246596afd4SAlex Deucher 0x0000160c, 0x00000100, 0xffffffff, 2256596afd4SAlex Deucher 0x0000c164, 0x00000100, 0xffffffff, 2266596afd4SAlex Deucher 0x00008a18, 0x00000100, 0xffffffff, 2276596afd4SAlex Deucher 0x0000897c, 0x06000100, 0xffffffff, 2286596afd4SAlex Deucher 0x00008b28, 0x00000100, 0xffffffff, 2296596afd4SAlex Deucher 0x00009144, 0x00000100, 0xffffffff, 2306596afd4SAlex Deucher 0x00009a60, 0x00000100, 0xffffffff, 2316596afd4SAlex Deucher 0x00009868, 0x00000100, 0xffffffff, 2326596afd4SAlex Deucher 0x00008d58, 0x00000100, 0xffffffff, 2336596afd4SAlex Deucher 0x00009510, 0x00000100, 0xffffffff, 2346596afd4SAlex Deucher 0x0000949c, 0x00000100, 0xffffffff, 2356596afd4SAlex Deucher 0x00009654, 0x00000100, 0xffffffff, 2366596afd4SAlex Deucher 0x00009030, 0x00000100, 0xffffffff, 2376596afd4SAlex Deucher 0x00009034, 0x00000100, 0xffffffff, 2386596afd4SAlex Deucher 0x00009038, 0x00000100, 0xffffffff, 2396596afd4SAlex Deucher 0x0000903c, 0x00000100, 0xffffffff, 2406596afd4SAlex Deucher 0x00009040, 0x00000100, 0xffffffff, 2416596afd4SAlex Deucher 0x0000a200, 0x00000100, 0xffffffff, 2426596afd4SAlex Deucher 0x0000a204, 0x00000100, 0xffffffff, 2436596afd4SAlex Deucher 0x0000a208, 0x00000100, 0xffffffff, 2446596afd4SAlex Deucher 0x0000a20c, 0x00000100, 0xffffffff, 2456596afd4SAlex Deucher 0x0000977c, 0x00000100, 0xffffffff, 2466596afd4SAlex Deucher 0x00003f80, 0x00000100, 0xffffffff, 2476596afd4SAlex Deucher 0x0000a210, 0x00000100, 0xffffffff, 2486596afd4SAlex Deucher 0x0000a214, 0x00000100, 0xffffffff, 2496596afd4SAlex Deucher 0x000004d8, 0x00000100, 0xffffffff, 2506596afd4SAlex Deucher 0x00009784, 0x00000100, 0xffffffff, 2516596afd4SAlex Deucher 0x00009698, 0x00000100, 0xffffffff, 2526596afd4SAlex Deucher 0x000004d4, 0x00000200, 0xffffffff, 2536596afd4SAlex Deucher 0x000004d0, 0x00000000, 0xffffffff, 2546596afd4SAlex Deucher 0x000030cc, 0x00000100, 0xffffffff, 2556596afd4SAlex Deucher 0x0000d0c0, 0xff000100, 0xffffffff, 2566596afd4SAlex Deucher 0x0000802c, 0x40000000, 0xffffffff, 2576596afd4SAlex Deucher 0x0000915c, 0x00010000, 0xffffffff, 2586596afd4SAlex Deucher 0x00009160, 0x00030002, 0xffffffff, 2596596afd4SAlex Deucher 0x00009164, 0x00050004, 0xffffffff, 2606596afd4SAlex Deucher 0x00009168, 0x00070006, 0xffffffff, 2616596afd4SAlex Deucher 0x00009178, 0x00070000, 0xffffffff, 2626596afd4SAlex Deucher 0x0000917c, 0x00030002, 0xffffffff, 2636596afd4SAlex Deucher 0x00009180, 0x00050004, 0xffffffff, 2646596afd4SAlex Deucher 0x0000918c, 0x00010006, 0xffffffff, 2656596afd4SAlex Deucher 0x00009190, 0x00090008, 0xffffffff, 2666596afd4SAlex Deucher 0x00009194, 0x00070000, 0xffffffff, 2676596afd4SAlex Deucher 0x00009198, 0x00030002, 0xffffffff, 2686596afd4SAlex Deucher 0x0000919c, 0x00050004, 0xffffffff, 2696596afd4SAlex Deucher 0x000091a8, 0x00010006, 0xffffffff, 2706596afd4SAlex Deucher 0x000091ac, 0x00090008, 0xffffffff, 2716596afd4SAlex Deucher 0x000091b0, 0x00070000, 0xffffffff, 2726596afd4SAlex Deucher 0x000091b4, 0x00030002, 0xffffffff, 2736596afd4SAlex Deucher 0x000091b8, 0x00050004, 0xffffffff, 2746596afd4SAlex Deucher 0x000091c4, 0x00010006, 0xffffffff, 2756596afd4SAlex Deucher 0x000091c8, 0x00090008, 0xffffffff, 2766596afd4SAlex Deucher 0x000091cc, 0x00070000, 0xffffffff, 2776596afd4SAlex Deucher 0x000091d0, 0x00030002, 0xffffffff, 2786596afd4SAlex Deucher 0x000091d4, 0x00050004, 0xffffffff, 2796596afd4SAlex Deucher 0x000091e0, 0x00010006, 0xffffffff, 2806596afd4SAlex Deucher 0x000091e4, 0x00090008, 0xffffffff, 2816596afd4SAlex Deucher 0x000091e8, 0x00000000, 0xffffffff, 2826596afd4SAlex Deucher 0x000091ec, 0x00070000, 0xffffffff, 2836596afd4SAlex Deucher 0x000091f0, 0x00030002, 0xffffffff, 2846596afd4SAlex Deucher 0x000091f4, 0x00050004, 0xffffffff, 2856596afd4SAlex Deucher 0x00009200, 0x00010006, 0xffffffff, 2866596afd4SAlex Deucher 0x00009204, 0x00090008, 0xffffffff, 2876596afd4SAlex Deucher 0x00009208, 0x00070000, 0xffffffff, 2886596afd4SAlex Deucher 0x0000920c, 0x00030002, 0xffffffff, 2896596afd4SAlex Deucher 0x00009210, 0x00050004, 0xffffffff, 2906596afd4SAlex Deucher 0x0000921c, 0x00010006, 0xffffffff, 2916596afd4SAlex Deucher 0x00009220, 0x00090008, 0xffffffff, 2926596afd4SAlex Deucher 0x00009224, 0x00070000, 0xffffffff, 2936596afd4SAlex Deucher 0x00009228, 0x00030002, 0xffffffff, 2946596afd4SAlex Deucher 0x0000922c, 0x00050004, 0xffffffff, 2956596afd4SAlex Deucher 0x00009238, 0x00010006, 0xffffffff, 2966596afd4SAlex Deucher 0x0000923c, 0x00090008, 0xffffffff, 2976596afd4SAlex Deucher 0x00009294, 0x00000000, 0xffffffff, 2986596afd4SAlex Deucher 0x0000802c, 0x40010000, 0xffffffff, 2996596afd4SAlex Deucher 0x0000915c, 0x00010000, 0xffffffff, 3006596afd4SAlex Deucher 0x00009160, 0x00030002, 0xffffffff, 3016596afd4SAlex Deucher 0x00009164, 0x00050004, 0xffffffff, 3026596afd4SAlex Deucher 0x00009168, 0x00070006, 0xffffffff, 3036596afd4SAlex Deucher 0x00009178, 0x00070000, 0xffffffff, 3046596afd4SAlex Deucher 0x0000917c, 0x00030002, 0xffffffff, 3056596afd4SAlex Deucher 0x00009180, 0x00050004, 0xffffffff, 3066596afd4SAlex Deucher 0x0000918c, 0x00010006, 0xffffffff, 3076596afd4SAlex Deucher 0x00009190, 0x00090008, 0xffffffff, 3086596afd4SAlex Deucher 0x00009194, 0x00070000, 0xffffffff, 3096596afd4SAlex Deucher 0x00009198, 0x00030002, 0xffffffff, 3106596afd4SAlex Deucher 0x0000919c, 0x00050004, 0xffffffff, 3116596afd4SAlex Deucher 0x000091a8, 0x00010006, 0xffffffff, 3126596afd4SAlex Deucher 0x000091ac, 0x00090008, 0xffffffff, 3136596afd4SAlex Deucher 0x000091b0, 0x00070000, 0xffffffff, 3146596afd4SAlex Deucher 0x000091b4, 0x00030002, 0xffffffff, 3156596afd4SAlex Deucher 0x000091b8, 0x00050004, 0xffffffff, 3166596afd4SAlex Deucher 0x000091c4, 0x00010006, 0xffffffff, 3176596afd4SAlex Deucher 0x000091c8, 0x00090008, 0xffffffff, 3186596afd4SAlex Deucher 0x000091cc, 0x00070000, 0xffffffff, 3196596afd4SAlex Deucher 0x000091d0, 0x00030002, 0xffffffff, 3206596afd4SAlex Deucher 0x000091d4, 0x00050004, 0xffffffff, 3216596afd4SAlex Deucher 0x000091e0, 0x00010006, 0xffffffff, 3226596afd4SAlex Deucher 0x000091e4, 0x00090008, 0xffffffff, 3236596afd4SAlex Deucher 0x000091e8, 0x00000000, 0xffffffff, 3246596afd4SAlex Deucher 0x000091ec, 0x00070000, 0xffffffff, 3256596afd4SAlex Deucher 0x000091f0, 0x00030002, 0xffffffff, 3266596afd4SAlex Deucher 0x000091f4, 0x00050004, 0xffffffff, 3276596afd4SAlex Deucher 0x00009200, 0x00010006, 0xffffffff, 3286596afd4SAlex Deucher 0x00009204, 0x00090008, 0xffffffff, 3296596afd4SAlex Deucher 0x00009208, 0x00070000, 0xffffffff, 3306596afd4SAlex Deucher 0x0000920c, 0x00030002, 0xffffffff, 3316596afd4SAlex Deucher 0x00009210, 0x00050004, 0xffffffff, 3326596afd4SAlex Deucher 0x0000921c, 0x00010006, 0xffffffff, 3336596afd4SAlex Deucher 0x00009220, 0x00090008, 0xffffffff, 3346596afd4SAlex Deucher 0x00009224, 0x00070000, 0xffffffff, 3356596afd4SAlex Deucher 0x00009228, 0x00030002, 0xffffffff, 3366596afd4SAlex Deucher 0x0000922c, 0x00050004, 0xffffffff, 3376596afd4SAlex Deucher 0x00009238, 0x00010006, 0xffffffff, 3386596afd4SAlex Deucher 0x0000923c, 0x00090008, 0xffffffff, 3396596afd4SAlex Deucher 0x00009294, 0x00000000, 0xffffffff, 3406596afd4SAlex Deucher 0x0000802c, 0xc0000000, 0xffffffff, 3416596afd4SAlex Deucher 0x000008f8, 0x00000010, 0xffffffff, 3426596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 3436596afd4SAlex Deucher 0x000008f8, 0x00000011, 0xffffffff, 3446596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 3456596afd4SAlex Deucher 0x000008f8, 0x00000012, 0xffffffff, 3466596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 3476596afd4SAlex Deucher 0x000008f8, 0x00000013, 0xffffffff, 3486596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 3496596afd4SAlex Deucher 0x000008f8, 0x00000014, 0xffffffff, 3506596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 3516596afd4SAlex Deucher 0x000008f8, 0x00000015, 0xffffffff, 3526596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 3536596afd4SAlex Deucher 0x000008f8, 0x00000016, 0xffffffff, 3546596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 3556596afd4SAlex Deucher 0x000008f8, 0x00000017, 0xffffffff, 3566596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 3576596afd4SAlex Deucher 0x000008f8, 0x00000018, 0xffffffff, 3586596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 3596596afd4SAlex Deucher 0x000008f8, 0x00000019, 0xffffffff, 3606596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 3616596afd4SAlex Deucher 0x000008f8, 0x0000001a, 0xffffffff, 3626596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 3636596afd4SAlex Deucher 0x000008f8, 0x0000001b, 0xffffffff, 3646596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff 3656596afd4SAlex Deucher }; 3666596afd4SAlex Deucher #define BARTS_MGCG_DEFAULT_LENGTH sizeof(barts_mgcg_default) / (3 * sizeof(u32)) 3676596afd4SAlex Deucher 3686596afd4SAlex Deucher static const u32 barts_mgcg_disable[] = 3696596afd4SAlex Deucher { 3706596afd4SAlex Deucher 0x0000802c, 0xc0000000, 0xffffffff, 3716596afd4SAlex Deucher 0x000008f8, 0x00000000, 0xffffffff, 3726596afd4SAlex Deucher 0x000008fc, 0xffffffff, 0xffffffff, 3736596afd4SAlex Deucher 0x000008f8, 0x00000001, 0xffffffff, 3746596afd4SAlex Deucher 0x000008fc, 0xffffffff, 0xffffffff, 3756596afd4SAlex Deucher 0x000008f8, 0x00000002, 0xffffffff, 3766596afd4SAlex Deucher 0x000008fc, 0xffffffff, 0xffffffff, 3776596afd4SAlex Deucher 0x000008f8, 0x00000003, 0xffffffff, 3786596afd4SAlex Deucher 0x000008fc, 0xffffffff, 0xffffffff, 3796596afd4SAlex Deucher 0x00009150, 0x00600000, 0xffffffff 3806596afd4SAlex Deucher }; 3816596afd4SAlex Deucher #define BARTS_MGCG_DISABLE_LENGTH sizeof(barts_mgcg_disable) / (3 * sizeof(u32)) 3826596afd4SAlex Deucher 3836596afd4SAlex Deucher static const u32 barts_mgcg_enable[] = 3846596afd4SAlex Deucher { 3856596afd4SAlex Deucher 0x0000802c, 0xc0000000, 0xffffffff, 3866596afd4SAlex Deucher 0x000008f8, 0x00000000, 0xffffffff, 3876596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 3886596afd4SAlex Deucher 0x000008f8, 0x00000001, 0xffffffff, 3896596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 3906596afd4SAlex Deucher 0x000008f8, 0x00000002, 0xffffffff, 3916596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 3926596afd4SAlex Deucher 0x000008f8, 0x00000003, 0xffffffff, 3936596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 3946596afd4SAlex Deucher 0x00009150, 0x81944000, 0xffffffff 3956596afd4SAlex Deucher }; 3966596afd4SAlex Deucher #define BARTS_MGCG_ENABLE_LENGTH sizeof(barts_mgcg_enable) / (3 * sizeof(u32)) 3976596afd4SAlex Deucher 3986596afd4SAlex Deucher //********* CAICOS **************// 3996596afd4SAlex Deucher static const u32 caicos_cgcg_cgls_default[] = 4006596afd4SAlex Deucher { 4016596afd4SAlex Deucher 0x000008f8, 0x00000010, 0xffffffff, 4026596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 4036596afd4SAlex Deucher 0x000008f8, 0x00000011, 0xffffffff, 4046596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 4056596afd4SAlex Deucher 0x000008f8, 0x00000012, 0xffffffff, 4066596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 4076596afd4SAlex Deucher 0x000008f8, 0x00000013, 0xffffffff, 4086596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 4096596afd4SAlex Deucher 0x000008f8, 0x00000014, 0xffffffff, 4106596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 4116596afd4SAlex Deucher 0x000008f8, 0x00000015, 0xffffffff, 4126596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 4136596afd4SAlex Deucher 0x000008f8, 0x00000016, 0xffffffff, 4146596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 4156596afd4SAlex Deucher 0x000008f8, 0x00000017, 0xffffffff, 4166596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 4176596afd4SAlex Deucher 0x000008f8, 0x00000018, 0xffffffff, 4186596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 4196596afd4SAlex Deucher 0x000008f8, 0x00000019, 0xffffffff, 4206596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 4216596afd4SAlex Deucher 0x000008f8, 0x0000001a, 0xffffffff, 4226596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 4236596afd4SAlex Deucher 0x000008f8, 0x0000001b, 0xffffffff, 4246596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 4256596afd4SAlex Deucher 0x000008f8, 0x00000020, 0xffffffff, 4266596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 4276596afd4SAlex Deucher 0x000008f8, 0x00000021, 0xffffffff, 4286596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 4296596afd4SAlex Deucher 0x000008f8, 0x00000022, 0xffffffff, 4306596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 4316596afd4SAlex Deucher 0x000008f8, 0x00000023, 0xffffffff, 4326596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 4336596afd4SAlex Deucher 0x000008f8, 0x00000024, 0xffffffff, 4346596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 4356596afd4SAlex Deucher 0x000008f8, 0x00000025, 0xffffffff, 4366596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 4376596afd4SAlex Deucher 0x000008f8, 0x00000026, 0xffffffff, 4386596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 4396596afd4SAlex Deucher 0x000008f8, 0x00000027, 0xffffffff, 4406596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 4416596afd4SAlex Deucher 0x000008f8, 0x00000028, 0xffffffff, 4426596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 4436596afd4SAlex Deucher 0x000008f8, 0x00000029, 0xffffffff, 4446596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 4456596afd4SAlex Deucher 0x000008f8, 0x0000002a, 0xffffffff, 4466596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 4476596afd4SAlex Deucher 0x000008f8, 0x0000002b, 0xffffffff, 4486596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff 4496596afd4SAlex Deucher }; 4506596afd4SAlex Deucher #define CAICOS_CGCG_CGLS_DEFAULT_LENGTH sizeof(caicos_cgcg_cgls_default) / (3 * sizeof(u32)) 4516596afd4SAlex Deucher 4526596afd4SAlex Deucher static const u32 caicos_cgcg_cgls_disable[] = 4536596afd4SAlex Deucher { 4546596afd4SAlex Deucher 0x000008f8, 0x00000010, 0xffffffff, 4556596afd4SAlex Deucher 0x000008fc, 0xffffffff, 0xffffffff, 4566596afd4SAlex Deucher 0x000008f8, 0x00000011, 0xffffffff, 4576596afd4SAlex Deucher 0x000008fc, 0xffffffff, 0xffffffff, 4586596afd4SAlex Deucher 0x000008f8, 0x00000012, 0xffffffff, 4596596afd4SAlex Deucher 0x000008fc, 0xffffffff, 0xffffffff, 4606596afd4SAlex Deucher 0x000008f8, 0x00000013, 0xffffffff, 4616596afd4SAlex Deucher 0x000008fc, 0xffffffff, 0xffffffff, 4626596afd4SAlex Deucher 0x000008f8, 0x00000014, 0xffffffff, 4636596afd4SAlex Deucher 0x000008fc, 0xffffffff, 0xffffffff, 4646596afd4SAlex Deucher 0x000008f8, 0x00000015, 0xffffffff, 4656596afd4SAlex Deucher 0x000008fc, 0xffffffff, 0xffffffff, 4666596afd4SAlex Deucher 0x000008f8, 0x00000016, 0xffffffff, 4676596afd4SAlex Deucher 0x000008fc, 0xffffffff, 0xffffffff, 4686596afd4SAlex Deucher 0x000008f8, 0x00000017, 0xffffffff, 4696596afd4SAlex Deucher 0x000008fc, 0xffffffff, 0xffffffff, 4706596afd4SAlex Deucher 0x000008f8, 0x00000018, 0xffffffff, 4716596afd4SAlex Deucher 0x000008fc, 0xffffffff, 0xffffffff, 4726596afd4SAlex Deucher 0x000008f8, 0x00000019, 0xffffffff, 4736596afd4SAlex Deucher 0x000008fc, 0xffffffff, 0xffffffff, 4746596afd4SAlex Deucher 0x000008f8, 0x0000001a, 0xffffffff, 4756596afd4SAlex Deucher 0x000008fc, 0xffffffff, 0xffffffff, 4766596afd4SAlex Deucher 0x000008f8, 0x0000001b, 0xffffffff, 4776596afd4SAlex Deucher 0x000008fc, 0xffffffff, 0xffffffff, 4786596afd4SAlex Deucher 0x000008f8, 0x00000020, 0xffffffff, 4796596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 4806596afd4SAlex Deucher 0x000008f8, 0x00000021, 0xffffffff, 4816596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 4826596afd4SAlex Deucher 0x000008f8, 0x00000022, 0xffffffff, 4836596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 4846596afd4SAlex Deucher 0x000008f8, 0x00000023, 0xffffffff, 4856596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 4866596afd4SAlex Deucher 0x000008f8, 0x00000024, 0xffffffff, 4876596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 4886596afd4SAlex Deucher 0x000008f8, 0x00000025, 0xffffffff, 4896596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 4906596afd4SAlex Deucher 0x000008f8, 0x00000026, 0xffffffff, 4916596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 4926596afd4SAlex Deucher 0x000008f8, 0x00000027, 0xffffffff, 4936596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 4946596afd4SAlex Deucher 0x000008f8, 0x00000028, 0xffffffff, 4956596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 4966596afd4SAlex Deucher 0x000008f8, 0x00000029, 0xffffffff, 4976596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 4986596afd4SAlex Deucher 0x000008f8, 0x0000002a, 0xffffffff, 4996596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 5006596afd4SAlex Deucher 0x000008f8, 0x0000002b, 0xffffffff, 5016596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 5026596afd4SAlex Deucher 0x00000644, 0x000f7912, 0x001f4180, 5036596afd4SAlex Deucher 0x00000644, 0x000f3812, 0x001f4180 5046596afd4SAlex Deucher }; 5056596afd4SAlex Deucher #define CAICOS_CGCG_CGLS_DISABLE_LENGTH sizeof(caicos_cgcg_cgls_disable) / (3 * sizeof(u32)) 5066596afd4SAlex Deucher 5076596afd4SAlex Deucher static const u32 caicos_cgcg_cgls_enable[] = 5086596afd4SAlex Deucher { 5096596afd4SAlex Deucher /* 0x0000c124, 0x84180000, 0x00180000, */ 5106596afd4SAlex Deucher 0x00000644, 0x000f7892, 0x001f4080, 5116596afd4SAlex Deucher 0x000008f8, 0x00000010, 0xffffffff, 5126596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 5136596afd4SAlex Deucher 0x000008f8, 0x00000011, 0xffffffff, 5146596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 5156596afd4SAlex Deucher 0x000008f8, 0x00000012, 0xffffffff, 5166596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 5176596afd4SAlex Deucher 0x000008f8, 0x00000013, 0xffffffff, 5186596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 5196596afd4SAlex Deucher 0x000008f8, 0x00000014, 0xffffffff, 5206596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 5216596afd4SAlex Deucher 0x000008f8, 0x00000015, 0xffffffff, 5226596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 5236596afd4SAlex Deucher 0x000008f8, 0x00000016, 0xffffffff, 5246596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 5256596afd4SAlex Deucher 0x000008f8, 0x00000017, 0xffffffff, 5266596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 5276596afd4SAlex Deucher 0x000008f8, 0x00000018, 0xffffffff, 5286596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 5296596afd4SAlex Deucher 0x000008f8, 0x00000019, 0xffffffff, 5306596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 5316596afd4SAlex Deucher 0x000008f8, 0x0000001a, 0xffffffff, 5326596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 5336596afd4SAlex Deucher 0x000008f8, 0x0000001b, 0xffffffff, 5346596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 5356596afd4SAlex Deucher 0x000008f8, 0x00000020, 0xffffffff, 5366596afd4SAlex Deucher 0x000008fc, 0xffffffff, 0xffffffff, 5376596afd4SAlex Deucher 0x000008f8, 0x00000021, 0xffffffff, 5386596afd4SAlex Deucher 0x000008fc, 0xffffffff, 0xffffffff, 5396596afd4SAlex Deucher 0x000008f8, 0x00000022, 0xffffffff, 5406596afd4SAlex Deucher 0x000008fc, 0xffffffff, 0xffffffff, 5416596afd4SAlex Deucher 0x000008f8, 0x00000023, 0xffffffff, 5426596afd4SAlex Deucher 0x000008fc, 0xffffffff, 0xffffffff, 5436596afd4SAlex Deucher 0x000008f8, 0x00000024, 0xffffffff, 5446596afd4SAlex Deucher 0x000008fc, 0xffffffff, 0xffffffff, 5456596afd4SAlex Deucher 0x000008f8, 0x00000025, 0xffffffff, 5466596afd4SAlex Deucher 0x000008fc, 0xffffffff, 0xffffffff, 5476596afd4SAlex Deucher 0x000008f8, 0x00000026, 0xffffffff, 5486596afd4SAlex Deucher 0x000008fc, 0xffffffff, 0xffffffff, 5496596afd4SAlex Deucher 0x000008f8, 0x00000027, 0xffffffff, 5506596afd4SAlex Deucher 0x000008fc, 0xffffffff, 0xffffffff, 5516596afd4SAlex Deucher 0x000008f8, 0x00000028, 0xffffffff, 5526596afd4SAlex Deucher 0x000008fc, 0xffffffff, 0xffffffff, 5536596afd4SAlex Deucher 0x000008f8, 0x00000029, 0xffffffff, 5546596afd4SAlex Deucher 0x000008fc, 0xffffffff, 0xffffffff, 5556596afd4SAlex Deucher 0x000008f8, 0x0000002a, 0xffffffff, 5566596afd4SAlex Deucher 0x000008fc, 0xffffffff, 0xffffffff, 5576596afd4SAlex Deucher 0x000008f8, 0x0000002b, 0xffffffff, 5586596afd4SAlex Deucher 0x000008fc, 0xffffffff, 0xffffffff 5596596afd4SAlex Deucher }; 5606596afd4SAlex Deucher #define CAICOS_CGCG_CGLS_ENABLE_LENGTH sizeof(caicos_cgcg_cgls_enable) / (3 * sizeof(u32)) 5616596afd4SAlex Deucher 5626596afd4SAlex Deucher static const u32 caicos_mgcg_default[] = 5636596afd4SAlex Deucher { 5646596afd4SAlex Deucher 0x0000802c, 0xc0000000, 0xffffffff, 5656596afd4SAlex Deucher 0x00005448, 0x00000100, 0xffffffff, 5666596afd4SAlex Deucher 0x000055e4, 0x00600100, 0xffffffff, 5676596afd4SAlex Deucher 0x0000160c, 0x00000100, 0xffffffff, 5686596afd4SAlex Deucher 0x0000c164, 0x00000100, 0xffffffff, 5696596afd4SAlex Deucher 0x00008a18, 0x00000100, 0xffffffff, 5706596afd4SAlex Deucher 0x0000897c, 0x06000100, 0xffffffff, 5716596afd4SAlex Deucher 0x00008b28, 0x00000100, 0xffffffff, 5726596afd4SAlex Deucher 0x00009144, 0x00000100, 0xffffffff, 5736596afd4SAlex Deucher 0x00009a60, 0x00000100, 0xffffffff, 5746596afd4SAlex Deucher 0x00009868, 0x00000100, 0xffffffff, 5756596afd4SAlex Deucher 0x00008d58, 0x00000100, 0xffffffff, 5766596afd4SAlex Deucher 0x00009510, 0x00000100, 0xffffffff, 5776596afd4SAlex Deucher 0x0000949c, 0x00000100, 0xffffffff, 5786596afd4SAlex Deucher 0x00009654, 0x00000100, 0xffffffff, 5796596afd4SAlex Deucher 0x00009030, 0x00000100, 0xffffffff, 5806596afd4SAlex Deucher 0x00009034, 0x00000100, 0xffffffff, 5816596afd4SAlex Deucher 0x00009038, 0x00000100, 0xffffffff, 5826596afd4SAlex Deucher 0x0000903c, 0x00000100, 0xffffffff, 5836596afd4SAlex Deucher 0x00009040, 0x00000100, 0xffffffff, 5846596afd4SAlex Deucher 0x0000a200, 0x00000100, 0xffffffff, 5856596afd4SAlex Deucher 0x0000a204, 0x00000100, 0xffffffff, 5866596afd4SAlex Deucher 0x0000a208, 0x00000100, 0xffffffff, 5876596afd4SAlex Deucher 0x0000a20c, 0x00000100, 0xffffffff, 5886596afd4SAlex Deucher 0x0000977c, 0x00000100, 0xffffffff, 5896596afd4SAlex Deucher 0x00003f80, 0x00000100, 0xffffffff, 5906596afd4SAlex Deucher 0x0000a210, 0x00000100, 0xffffffff, 5916596afd4SAlex Deucher 0x0000a214, 0x00000100, 0xffffffff, 5926596afd4SAlex Deucher 0x000004d8, 0x00000100, 0xffffffff, 5936596afd4SAlex Deucher 0x00009784, 0x00000100, 0xffffffff, 5946596afd4SAlex Deucher 0x00009698, 0x00000100, 0xffffffff, 5956596afd4SAlex Deucher 0x000004d4, 0x00000200, 0xffffffff, 5966596afd4SAlex Deucher 0x000004d0, 0x00000000, 0xffffffff, 5976596afd4SAlex Deucher 0x000030cc, 0x00000100, 0xffffffff, 5986596afd4SAlex Deucher 0x0000d0c0, 0xff000100, 0xffffffff, 5996596afd4SAlex Deucher 0x0000915c, 0x00010000, 0xffffffff, 6006596afd4SAlex Deucher 0x00009160, 0x00030002, 0xffffffff, 6016596afd4SAlex Deucher 0x00009164, 0x00050004, 0xffffffff, 6026596afd4SAlex Deucher 0x00009168, 0x00070006, 0xffffffff, 6036596afd4SAlex Deucher 0x00009178, 0x00070000, 0xffffffff, 6046596afd4SAlex Deucher 0x0000917c, 0x00030002, 0xffffffff, 6056596afd4SAlex Deucher 0x00009180, 0x00050004, 0xffffffff, 6066596afd4SAlex Deucher 0x0000918c, 0x00010006, 0xffffffff, 6076596afd4SAlex Deucher 0x00009190, 0x00090008, 0xffffffff, 6086596afd4SAlex Deucher 0x00009194, 0x00070000, 0xffffffff, 6096596afd4SAlex Deucher 0x00009198, 0x00030002, 0xffffffff, 6106596afd4SAlex Deucher 0x0000919c, 0x00050004, 0xffffffff, 6116596afd4SAlex Deucher 0x000091a8, 0x00010006, 0xffffffff, 6126596afd4SAlex Deucher 0x000091ac, 0x00090008, 0xffffffff, 6136596afd4SAlex Deucher 0x000091e8, 0x00000000, 0xffffffff, 6146596afd4SAlex Deucher 0x00009294, 0x00000000, 0xffffffff, 6156596afd4SAlex Deucher 0x000008f8, 0x00000010, 0xffffffff, 6166596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 6176596afd4SAlex Deucher 0x000008f8, 0x00000011, 0xffffffff, 6186596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 6196596afd4SAlex Deucher 0x000008f8, 0x00000012, 0xffffffff, 6206596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 6216596afd4SAlex Deucher 0x000008f8, 0x00000013, 0xffffffff, 6226596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 6236596afd4SAlex Deucher 0x000008f8, 0x00000014, 0xffffffff, 6246596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 6256596afd4SAlex Deucher 0x000008f8, 0x00000015, 0xffffffff, 6266596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 6276596afd4SAlex Deucher 0x000008f8, 0x00000016, 0xffffffff, 6286596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 6296596afd4SAlex Deucher 0x000008f8, 0x00000017, 0xffffffff, 6306596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 6316596afd4SAlex Deucher 0x000008f8, 0x00000018, 0xffffffff, 6326596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 6336596afd4SAlex Deucher 0x000008f8, 0x00000019, 0xffffffff, 6346596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 6356596afd4SAlex Deucher 0x000008f8, 0x0000001a, 0xffffffff, 6366596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 6376596afd4SAlex Deucher 0x000008f8, 0x0000001b, 0xffffffff, 6386596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff 6396596afd4SAlex Deucher }; 6406596afd4SAlex Deucher #define CAICOS_MGCG_DEFAULT_LENGTH sizeof(caicos_mgcg_default) / (3 * sizeof(u32)) 6416596afd4SAlex Deucher 6426596afd4SAlex Deucher static const u32 caicos_mgcg_disable[] = 6436596afd4SAlex Deucher { 6446596afd4SAlex Deucher 0x0000802c, 0xc0000000, 0xffffffff, 6456596afd4SAlex Deucher 0x000008f8, 0x00000000, 0xffffffff, 6466596afd4SAlex Deucher 0x000008fc, 0xffffffff, 0xffffffff, 6476596afd4SAlex Deucher 0x000008f8, 0x00000001, 0xffffffff, 6486596afd4SAlex Deucher 0x000008fc, 0xffffffff, 0xffffffff, 6496596afd4SAlex Deucher 0x000008f8, 0x00000002, 0xffffffff, 6506596afd4SAlex Deucher 0x000008fc, 0xffffffff, 0xffffffff, 6516596afd4SAlex Deucher 0x000008f8, 0x00000003, 0xffffffff, 6526596afd4SAlex Deucher 0x000008fc, 0xffffffff, 0xffffffff, 6536596afd4SAlex Deucher 0x00009150, 0x00600000, 0xffffffff 6546596afd4SAlex Deucher }; 6556596afd4SAlex Deucher #define CAICOS_MGCG_DISABLE_LENGTH sizeof(caicos_mgcg_disable) / (3 * sizeof(u32)) 6566596afd4SAlex Deucher 6576596afd4SAlex Deucher static const u32 caicos_mgcg_enable[] = 6586596afd4SAlex Deucher { 6596596afd4SAlex Deucher 0x0000802c, 0xc0000000, 0xffffffff, 6606596afd4SAlex Deucher 0x000008f8, 0x00000000, 0xffffffff, 6616596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 6626596afd4SAlex Deucher 0x000008f8, 0x00000001, 0xffffffff, 6636596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 6646596afd4SAlex Deucher 0x000008f8, 0x00000002, 0xffffffff, 6656596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 6666596afd4SAlex Deucher 0x000008f8, 0x00000003, 0xffffffff, 6676596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 6686596afd4SAlex Deucher 0x00009150, 0x46944040, 0xffffffff 6696596afd4SAlex Deucher }; 6706596afd4SAlex Deucher #define CAICOS_MGCG_ENABLE_LENGTH sizeof(caicos_mgcg_enable) / (3 * sizeof(u32)) 6716596afd4SAlex Deucher 6726596afd4SAlex Deucher //********* TURKS **************// 6736596afd4SAlex Deucher static const u32 turks_cgcg_cgls_default[] = 6746596afd4SAlex Deucher { 6756596afd4SAlex Deucher 0x000008f8, 0x00000010, 0xffffffff, 6766596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 6776596afd4SAlex Deucher 0x000008f8, 0x00000011, 0xffffffff, 6786596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 6796596afd4SAlex Deucher 0x000008f8, 0x00000012, 0xffffffff, 6806596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 6816596afd4SAlex Deucher 0x000008f8, 0x00000013, 0xffffffff, 6826596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 6836596afd4SAlex Deucher 0x000008f8, 0x00000014, 0xffffffff, 6846596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 6856596afd4SAlex Deucher 0x000008f8, 0x00000015, 0xffffffff, 6866596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 6876596afd4SAlex Deucher 0x000008f8, 0x00000016, 0xffffffff, 6886596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 6896596afd4SAlex Deucher 0x000008f8, 0x00000017, 0xffffffff, 6906596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 6916596afd4SAlex Deucher 0x000008f8, 0x00000018, 0xffffffff, 6926596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 6936596afd4SAlex Deucher 0x000008f8, 0x00000019, 0xffffffff, 6946596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 6956596afd4SAlex Deucher 0x000008f8, 0x0000001a, 0xffffffff, 6966596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 6976596afd4SAlex Deucher 0x000008f8, 0x0000001b, 0xffffffff, 6986596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 6996596afd4SAlex Deucher 0x000008f8, 0x00000020, 0xffffffff, 7006596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 7016596afd4SAlex Deucher 0x000008f8, 0x00000021, 0xffffffff, 7026596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 7036596afd4SAlex Deucher 0x000008f8, 0x00000022, 0xffffffff, 7046596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 7056596afd4SAlex Deucher 0x000008f8, 0x00000023, 0xffffffff, 7066596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 7076596afd4SAlex Deucher 0x000008f8, 0x00000024, 0xffffffff, 7086596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 7096596afd4SAlex Deucher 0x000008f8, 0x00000025, 0xffffffff, 7106596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 7116596afd4SAlex Deucher 0x000008f8, 0x00000026, 0xffffffff, 7126596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 7136596afd4SAlex Deucher 0x000008f8, 0x00000027, 0xffffffff, 7146596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 7156596afd4SAlex Deucher 0x000008f8, 0x00000028, 0xffffffff, 7166596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 7176596afd4SAlex Deucher 0x000008f8, 0x00000029, 0xffffffff, 7186596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 7196596afd4SAlex Deucher 0x000008f8, 0x0000002a, 0xffffffff, 7206596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 7216596afd4SAlex Deucher 0x000008f8, 0x0000002b, 0xffffffff, 7226596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff 7236596afd4SAlex Deucher }; 7246596afd4SAlex Deucher #define TURKS_CGCG_CGLS_DEFAULT_LENGTH sizeof(turks_cgcg_cgls_default) / (3 * sizeof(u32)) 7256596afd4SAlex Deucher 7266596afd4SAlex Deucher static const u32 turks_cgcg_cgls_disable[] = 7276596afd4SAlex Deucher { 7286596afd4SAlex Deucher 0x000008f8, 0x00000010, 0xffffffff, 7296596afd4SAlex Deucher 0x000008fc, 0xffffffff, 0xffffffff, 7306596afd4SAlex Deucher 0x000008f8, 0x00000011, 0xffffffff, 7316596afd4SAlex Deucher 0x000008fc, 0xffffffff, 0xffffffff, 7326596afd4SAlex Deucher 0x000008f8, 0x00000012, 0xffffffff, 7336596afd4SAlex Deucher 0x000008fc, 0xffffffff, 0xffffffff, 7346596afd4SAlex Deucher 0x000008f8, 0x00000013, 0xffffffff, 7356596afd4SAlex Deucher 0x000008fc, 0xffffffff, 0xffffffff, 7366596afd4SAlex Deucher 0x000008f8, 0x00000014, 0xffffffff, 7376596afd4SAlex Deucher 0x000008fc, 0xffffffff, 0xffffffff, 7386596afd4SAlex Deucher 0x000008f8, 0x00000015, 0xffffffff, 7396596afd4SAlex Deucher 0x000008fc, 0xffffffff, 0xffffffff, 7406596afd4SAlex Deucher 0x000008f8, 0x00000016, 0xffffffff, 7416596afd4SAlex Deucher 0x000008fc, 0xffffffff, 0xffffffff, 7426596afd4SAlex Deucher 0x000008f8, 0x00000017, 0xffffffff, 7436596afd4SAlex Deucher 0x000008fc, 0xffffffff, 0xffffffff, 7446596afd4SAlex Deucher 0x000008f8, 0x00000018, 0xffffffff, 7456596afd4SAlex Deucher 0x000008fc, 0xffffffff, 0xffffffff, 7466596afd4SAlex Deucher 0x000008f8, 0x00000019, 0xffffffff, 7476596afd4SAlex Deucher 0x000008fc, 0xffffffff, 0xffffffff, 7486596afd4SAlex Deucher 0x000008f8, 0x0000001a, 0xffffffff, 7496596afd4SAlex Deucher 0x000008fc, 0xffffffff, 0xffffffff, 7506596afd4SAlex Deucher 0x000008f8, 0x0000001b, 0xffffffff, 7516596afd4SAlex Deucher 0x000008fc, 0xffffffff, 0xffffffff, 7526596afd4SAlex Deucher 0x000008f8, 0x00000020, 0xffffffff, 7536596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 7546596afd4SAlex Deucher 0x000008f8, 0x00000021, 0xffffffff, 7556596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 7566596afd4SAlex Deucher 0x000008f8, 0x00000022, 0xffffffff, 7576596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 7586596afd4SAlex Deucher 0x000008f8, 0x00000023, 0xffffffff, 7596596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 7606596afd4SAlex Deucher 0x000008f8, 0x00000024, 0xffffffff, 7616596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 7626596afd4SAlex Deucher 0x000008f8, 0x00000025, 0xffffffff, 7636596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 7646596afd4SAlex Deucher 0x000008f8, 0x00000026, 0xffffffff, 7656596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 7666596afd4SAlex Deucher 0x000008f8, 0x00000027, 0xffffffff, 7676596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 7686596afd4SAlex Deucher 0x000008f8, 0x00000028, 0xffffffff, 7696596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 7706596afd4SAlex Deucher 0x000008f8, 0x00000029, 0xffffffff, 7716596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 7726596afd4SAlex Deucher 0x000008f8, 0x0000002a, 0xffffffff, 7736596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 7746596afd4SAlex Deucher 0x000008f8, 0x0000002b, 0xffffffff, 7756596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 7766596afd4SAlex Deucher 0x00000644, 0x000f7912, 0x001f4180, 7776596afd4SAlex Deucher 0x00000644, 0x000f3812, 0x001f4180 7786596afd4SAlex Deucher }; 7796596afd4SAlex Deucher #define TURKS_CGCG_CGLS_DISABLE_LENGTH sizeof(turks_cgcg_cgls_disable) / (3 * sizeof(u32)) 7806596afd4SAlex Deucher 7816596afd4SAlex Deucher static const u32 turks_cgcg_cgls_enable[] = 7826596afd4SAlex Deucher { 7836596afd4SAlex Deucher /* 0x0000c124, 0x84180000, 0x00180000, */ 7846596afd4SAlex Deucher 0x00000644, 0x000f7892, 0x001f4080, 7856596afd4SAlex Deucher 0x000008f8, 0x00000010, 0xffffffff, 7866596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 7876596afd4SAlex Deucher 0x000008f8, 0x00000011, 0xffffffff, 7886596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 7896596afd4SAlex Deucher 0x000008f8, 0x00000012, 0xffffffff, 7906596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 7916596afd4SAlex Deucher 0x000008f8, 0x00000013, 0xffffffff, 7926596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 7936596afd4SAlex Deucher 0x000008f8, 0x00000014, 0xffffffff, 7946596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 7956596afd4SAlex Deucher 0x000008f8, 0x00000015, 0xffffffff, 7966596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 7976596afd4SAlex Deucher 0x000008f8, 0x00000016, 0xffffffff, 7986596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 7996596afd4SAlex Deucher 0x000008f8, 0x00000017, 0xffffffff, 8006596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 8016596afd4SAlex Deucher 0x000008f8, 0x00000018, 0xffffffff, 8026596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 8036596afd4SAlex Deucher 0x000008f8, 0x00000019, 0xffffffff, 8046596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 8056596afd4SAlex Deucher 0x000008f8, 0x0000001a, 0xffffffff, 8066596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 8076596afd4SAlex Deucher 0x000008f8, 0x0000001b, 0xffffffff, 8086596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 8096596afd4SAlex Deucher 0x000008f8, 0x00000020, 0xffffffff, 8106596afd4SAlex Deucher 0x000008fc, 0xffffffff, 0xffffffff, 8116596afd4SAlex Deucher 0x000008f8, 0x00000021, 0xffffffff, 8126596afd4SAlex Deucher 0x000008fc, 0xffffffff, 0xffffffff, 8136596afd4SAlex Deucher 0x000008f8, 0x00000022, 0xffffffff, 8146596afd4SAlex Deucher 0x000008fc, 0xffffffff, 0xffffffff, 8156596afd4SAlex Deucher 0x000008f8, 0x00000023, 0xffffffff, 8166596afd4SAlex Deucher 0x000008fc, 0xffffffff, 0xffffffff, 8176596afd4SAlex Deucher 0x000008f8, 0x00000024, 0xffffffff, 8186596afd4SAlex Deucher 0x000008fc, 0xffffffff, 0xffffffff, 8196596afd4SAlex Deucher 0x000008f8, 0x00000025, 0xffffffff, 8206596afd4SAlex Deucher 0x000008fc, 0xffffffff, 0xffffffff, 8216596afd4SAlex Deucher 0x000008f8, 0x00000026, 0xffffffff, 8226596afd4SAlex Deucher 0x000008fc, 0xffffffff, 0xffffffff, 8236596afd4SAlex Deucher 0x000008f8, 0x00000027, 0xffffffff, 8246596afd4SAlex Deucher 0x000008fc, 0xffffffff, 0xffffffff, 8256596afd4SAlex Deucher 0x000008f8, 0x00000028, 0xffffffff, 8266596afd4SAlex Deucher 0x000008fc, 0xffffffff, 0xffffffff, 8276596afd4SAlex Deucher 0x000008f8, 0x00000029, 0xffffffff, 8286596afd4SAlex Deucher 0x000008fc, 0xffffffff, 0xffffffff, 8296596afd4SAlex Deucher 0x000008f8, 0x0000002a, 0xffffffff, 8306596afd4SAlex Deucher 0x000008fc, 0xffffffff, 0xffffffff, 8316596afd4SAlex Deucher 0x000008f8, 0x0000002b, 0xffffffff, 8326596afd4SAlex Deucher 0x000008fc, 0xffffffff, 0xffffffff 8336596afd4SAlex Deucher }; 8346596afd4SAlex Deucher #define TURKS_CGCG_CGLS_ENABLE_LENGTH sizeof(turks_cgcg_cgls_enable) / (3 * sizeof(u32)) 8356596afd4SAlex Deucher 8366596afd4SAlex Deucher // These are the sequences for turks_mgcg_shls 8376596afd4SAlex Deucher static const u32 turks_mgcg_default[] = 8386596afd4SAlex Deucher { 8396596afd4SAlex Deucher 0x0000802c, 0xc0000000, 0xffffffff, 8406596afd4SAlex Deucher 0x00005448, 0x00000100, 0xffffffff, 8416596afd4SAlex Deucher 0x000055e4, 0x00600100, 0xffffffff, 8426596afd4SAlex Deucher 0x0000160c, 0x00000100, 0xffffffff, 8436596afd4SAlex Deucher 0x0000c164, 0x00000100, 0xffffffff, 8446596afd4SAlex Deucher 0x00008a18, 0x00000100, 0xffffffff, 8456596afd4SAlex Deucher 0x0000897c, 0x06000100, 0xffffffff, 8466596afd4SAlex Deucher 0x00008b28, 0x00000100, 0xffffffff, 8476596afd4SAlex Deucher 0x00009144, 0x00000100, 0xffffffff, 8486596afd4SAlex Deucher 0x00009a60, 0x00000100, 0xffffffff, 8496596afd4SAlex Deucher 0x00009868, 0x00000100, 0xffffffff, 8506596afd4SAlex Deucher 0x00008d58, 0x00000100, 0xffffffff, 8516596afd4SAlex Deucher 0x00009510, 0x00000100, 0xffffffff, 8526596afd4SAlex Deucher 0x0000949c, 0x00000100, 0xffffffff, 8536596afd4SAlex Deucher 0x00009654, 0x00000100, 0xffffffff, 8546596afd4SAlex Deucher 0x00009030, 0x00000100, 0xffffffff, 8556596afd4SAlex Deucher 0x00009034, 0x00000100, 0xffffffff, 8566596afd4SAlex Deucher 0x00009038, 0x00000100, 0xffffffff, 8576596afd4SAlex Deucher 0x0000903c, 0x00000100, 0xffffffff, 8586596afd4SAlex Deucher 0x00009040, 0x00000100, 0xffffffff, 8596596afd4SAlex Deucher 0x0000a200, 0x00000100, 0xffffffff, 8606596afd4SAlex Deucher 0x0000a204, 0x00000100, 0xffffffff, 8616596afd4SAlex Deucher 0x0000a208, 0x00000100, 0xffffffff, 8626596afd4SAlex Deucher 0x0000a20c, 0x00000100, 0xffffffff, 8636596afd4SAlex Deucher 0x0000977c, 0x00000100, 0xffffffff, 8646596afd4SAlex Deucher 0x00003f80, 0x00000100, 0xffffffff, 8656596afd4SAlex Deucher 0x0000a210, 0x00000100, 0xffffffff, 8666596afd4SAlex Deucher 0x0000a214, 0x00000100, 0xffffffff, 8676596afd4SAlex Deucher 0x000004d8, 0x00000100, 0xffffffff, 8686596afd4SAlex Deucher 0x00009784, 0x00000100, 0xffffffff, 8696596afd4SAlex Deucher 0x00009698, 0x00000100, 0xffffffff, 8706596afd4SAlex Deucher 0x000004d4, 0x00000200, 0xffffffff, 8716596afd4SAlex Deucher 0x000004d0, 0x00000000, 0xffffffff, 8726596afd4SAlex Deucher 0x000030cc, 0x00000100, 0xffffffff, 8736596afd4SAlex Deucher 0x0000d0c0, 0x00000100, 0xffffffff, 8746596afd4SAlex Deucher 0x0000915c, 0x00010000, 0xffffffff, 8756596afd4SAlex Deucher 0x00009160, 0x00030002, 0xffffffff, 8766596afd4SAlex Deucher 0x00009164, 0x00050004, 0xffffffff, 8776596afd4SAlex Deucher 0x00009168, 0x00070006, 0xffffffff, 8786596afd4SAlex Deucher 0x00009178, 0x00070000, 0xffffffff, 8796596afd4SAlex Deucher 0x0000917c, 0x00030002, 0xffffffff, 8806596afd4SAlex Deucher 0x00009180, 0x00050004, 0xffffffff, 8816596afd4SAlex Deucher 0x0000918c, 0x00010006, 0xffffffff, 8826596afd4SAlex Deucher 0x00009190, 0x00090008, 0xffffffff, 8836596afd4SAlex Deucher 0x00009194, 0x00070000, 0xffffffff, 8846596afd4SAlex Deucher 0x00009198, 0x00030002, 0xffffffff, 8856596afd4SAlex Deucher 0x0000919c, 0x00050004, 0xffffffff, 8866596afd4SAlex Deucher 0x000091a8, 0x00010006, 0xffffffff, 8876596afd4SAlex Deucher 0x000091ac, 0x00090008, 0xffffffff, 8886596afd4SAlex Deucher 0x000091b0, 0x00070000, 0xffffffff, 8896596afd4SAlex Deucher 0x000091b4, 0x00030002, 0xffffffff, 8906596afd4SAlex Deucher 0x000091b8, 0x00050004, 0xffffffff, 8916596afd4SAlex Deucher 0x000091c4, 0x00010006, 0xffffffff, 8926596afd4SAlex Deucher 0x000091c8, 0x00090008, 0xffffffff, 8936596afd4SAlex Deucher 0x000091cc, 0x00070000, 0xffffffff, 8946596afd4SAlex Deucher 0x000091d0, 0x00030002, 0xffffffff, 8956596afd4SAlex Deucher 0x000091d4, 0x00050004, 0xffffffff, 8966596afd4SAlex Deucher 0x000091e0, 0x00010006, 0xffffffff, 8976596afd4SAlex Deucher 0x000091e4, 0x00090008, 0xffffffff, 8986596afd4SAlex Deucher 0x000091e8, 0x00000000, 0xffffffff, 8996596afd4SAlex Deucher 0x000091ec, 0x00070000, 0xffffffff, 9006596afd4SAlex Deucher 0x000091f0, 0x00030002, 0xffffffff, 9016596afd4SAlex Deucher 0x000091f4, 0x00050004, 0xffffffff, 9026596afd4SAlex Deucher 0x00009200, 0x00010006, 0xffffffff, 9036596afd4SAlex Deucher 0x00009204, 0x00090008, 0xffffffff, 9046596afd4SAlex Deucher 0x00009208, 0x00070000, 0xffffffff, 9056596afd4SAlex Deucher 0x0000920c, 0x00030002, 0xffffffff, 9066596afd4SAlex Deucher 0x00009210, 0x00050004, 0xffffffff, 9076596afd4SAlex Deucher 0x0000921c, 0x00010006, 0xffffffff, 9086596afd4SAlex Deucher 0x00009220, 0x00090008, 0xffffffff, 9096596afd4SAlex Deucher 0x00009294, 0x00000000, 0xffffffff, 9106596afd4SAlex Deucher 0x000008f8, 0x00000010, 0xffffffff, 9116596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 9126596afd4SAlex Deucher 0x000008f8, 0x00000011, 0xffffffff, 9136596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 9146596afd4SAlex Deucher 0x000008f8, 0x00000012, 0xffffffff, 9156596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 9166596afd4SAlex Deucher 0x000008f8, 0x00000013, 0xffffffff, 9176596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 9186596afd4SAlex Deucher 0x000008f8, 0x00000014, 0xffffffff, 9196596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 9206596afd4SAlex Deucher 0x000008f8, 0x00000015, 0xffffffff, 9216596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 9226596afd4SAlex Deucher 0x000008f8, 0x00000016, 0xffffffff, 9236596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 9246596afd4SAlex Deucher 0x000008f8, 0x00000017, 0xffffffff, 9256596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 9266596afd4SAlex Deucher 0x000008f8, 0x00000018, 0xffffffff, 9276596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 9286596afd4SAlex Deucher 0x000008f8, 0x00000019, 0xffffffff, 9296596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 9306596afd4SAlex Deucher 0x000008f8, 0x0000001a, 0xffffffff, 9316596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 9326596afd4SAlex Deucher 0x000008f8, 0x0000001b, 0xffffffff, 9336596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff 9346596afd4SAlex Deucher }; 9356596afd4SAlex Deucher #define TURKS_MGCG_DEFAULT_LENGTH sizeof(turks_mgcg_default) / (3 * sizeof(u32)) 9366596afd4SAlex Deucher 9376596afd4SAlex Deucher static const u32 turks_mgcg_disable[] = 9386596afd4SAlex Deucher { 9396596afd4SAlex Deucher 0x0000802c, 0xc0000000, 0xffffffff, 9406596afd4SAlex Deucher 0x000008f8, 0x00000000, 0xffffffff, 9416596afd4SAlex Deucher 0x000008fc, 0xffffffff, 0xffffffff, 9426596afd4SAlex Deucher 0x000008f8, 0x00000001, 0xffffffff, 9436596afd4SAlex Deucher 0x000008fc, 0xffffffff, 0xffffffff, 9446596afd4SAlex Deucher 0x000008f8, 0x00000002, 0xffffffff, 9456596afd4SAlex Deucher 0x000008fc, 0xffffffff, 0xffffffff, 9466596afd4SAlex Deucher 0x000008f8, 0x00000003, 0xffffffff, 9476596afd4SAlex Deucher 0x000008fc, 0xffffffff, 0xffffffff, 9486596afd4SAlex Deucher 0x00009150, 0x00600000, 0xffffffff 9496596afd4SAlex Deucher }; 9506596afd4SAlex Deucher #define TURKS_MGCG_DISABLE_LENGTH sizeof(turks_mgcg_disable) / (3 * sizeof(u32)) 9516596afd4SAlex Deucher 9526596afd4SAlex Deucher static const u32 turks_mgcg_enable[] = 9536596afd4SAlex Deucher { 9546596afd4SAlex Deucher 0x0000802c, 0xc0000000, 0xffffffff, 9556596afd4SAlex Deucher 0x000008f8, 0x00000000, 0xffffffff, 9566596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 9576596afd4SAlex Deucher 0x000008f8, 0x00000001, 0xffffffff, 9586596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 9596596afd4SAlex Deucher 0x000008f8, 0x00000002, 0xffffffff, 9606596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 9616596afd4SAlex Deucher 0x000008f8, 0x00000003, 0xffffffff, 9626596afd4SAlex Deucher 0x000008fc, 0x00000000, 0xffffffff, 9636596afd4SAlex Deucher 0x00009150, 0x6e944000, 0xffffffff 9646596afd4SAlex Deucher }; 9656596afd4SAlex Deucher #define TURKS_MGCG_ENABLE_LENGTH sizeof(turks_mgcg_enable) / (3 * sizeof(u32)) 9666596afd4SAlex Deucher 9676596afd4SAlex Deucher #endif 9686596afd4SAlex Deucher 9696596afd4SAlex Deucher #ifndef BTC_SYSLS_SEQUENCE 9706596afd4SAlex Deucher #define BTC_SYSLS_SEQUENCE 100 9716596afd4SAlex Deucher 9726596afd4SAlex Deucher 9736596afd4SAlex Deucher //********* BARTS **************// 9746596afd4SAlex Deucher static const u32 barts_sysls_default[] = 9756596afd4SAlex Deucher { 9766596afd4SAlex Deucher /* Register, Value, Mask bits */ 9776596afd4SAlex Deucher 0x000055e8, 0x00000000, 0xffffffff, 9786596afd4SAlex Deucher 0x0000d0bc, 0x00000000, 0xffffffff, 9796596afd4SAlex Deucher 0x000015c0, 0x000c1401, 0xffffffff, 9806596afd4SAlex Deucher 0x0000264c, 0x000c0400, 0xffffffff, 9816596afd4SAlex Deucher 0x00002648, 0x000c0400, 0xffffffff, 9826596afd4SAlex Deucher 0x00002650, 0x000c0400, 0xffffffff, 9836596afd4SAlex Deucher 0x000020b8, 0x000c0400, 0xffffffff, 9846596afd4SAlex Deucher 0x000020bc, 0x000c0400, 0xffffffff, 9856596afd4SAlex Deucher 0x000020c0, 0x000c0c80, 0xffffffff, 9866596afd4SAlex Deucher 0x0000f4a0, 0x000000c0, 0xffffffff, 9876596afd4SAlex Deucher 0x0000f4a4, 0x00680fff, 0xffffffff, 9886596afd4SAlex Deucher 0x000004c8, 0x00000001, 0xffffffff, 9896596afd4SAlex Deucher 0x000064ec, 0x00000000, 0xffffffff, 9906596afd4SAlex Deucher 0x00000c7c, 0x00000000, 0xffffffff, 9916596afd4SAlex Deucher 0x00006dfc, 0x00000000, 0xffffffff 9926596afd4SAlex Deucher }; 9936596afd4SAlex Deucher #define BARTS_SYSLS_DEFAULT_LENGTH sizeof(barts_sysls_default) / (3 * sizeof(u32)) 9946596afd4SAlex Deucher 9956596afd4SAlex Deucher static const u32 barts_sysls_disable[] = 9966596afd4SAlex Deucher { 9976596afd4SAlex Deucher 0x000055e8, 0x00000000, 0xffffffff, 9986596afd4SAlex Deucher 0x0000d0bc, 0x00000000, 0xffffffff, 9996596afd4SAlex Deucher 0x000015c0, 0x00041401, 0xffffffff, 10006596afd4SAlex Deucher 0x0000264c, 0x00040400, 0xffffffff, 10016596afd4SAlex Deucher 0x00002648, 0x00040400, 0xffffffff, 10026596afd4SAlex Deucher 0x00002650, 0x00040400, 0xffffffff, 10036596afd4SAlex Deucher 0x000020b8, 0x00040400, 0xffffffff, 10046596afd4SAlex Deucher 0x000020bc, 0x00040400, 0xffffffff, 10056596afd4SAlex Deucher 0x000020c0, 0x00040c80, 0xffffffff, 10066596afd4SAlex Deucher 0x0000f4a0, 0x000000c0, 0xffffffff, 10076596afd4SAlex Deucher 0x0000f4a4, 0x00680000, 0xffffffff, 10086596afd4SAlex Deucher 0x000004c8, 0x00000001, 0xffffffff, 10096596afd4SAlex Deucher 0x000064ec, 0x00007ffd, 0xffffffff, 10106596afd4SAlex Deucher 0x00000c7c, 0x0000ff00, 0xffffffff, 10116596afd4SAlex Deucher 0x00006dfc, 0x0000007f, 0xffffffff 10126596afd4SAlex Deucher }; 10136596afd4SAlex Deucher #define BARTS_SYSLS_DISABLE_LENGTH sizeof(barts_sysls_disable) / (3 * sizeof(u32)) 10146596afd4SAlex Deucher 10156596afd4SAlex Deucher static const u32 barts_sysls_enable[] = 10166596afd4SAlex Deucher { 10176596afd4SAlex Deucher 0x000055e8, 0x00000001, 0xffffffff, 10186596afd4SAlex Deucher 0x0000d0bc, 0x00000100, 0xffffffff, 10196596afd4SAlex Deucher 0x000015c0, 0x000c1401, 0xffffffff, 10206596afd4SAlex Deucher 0x0000264c, 0x000c0400, 0xffffffff, 10216596afd4SAlex Deucher 0x00002648, 0x000c0400, 0xffffffff, 10226596afd4SAlex Deucher 0x00002650, 0x000c0400, 0xffffffff, 10236596afd4SAlex Deucher 0x000020b8, 0x000c0400, 0xffffffff, 10246596afd4SAlex Deucher 0x000020bc, 0x000c0400, 0xffffffff, 10256596afd4SAlex Deucher 0x000020c0, 0x000c0c80, 0xffffffff, 10266596afd4SAlex Deucher 0x0000f4a0, 0x000000c0, 0xffffffff, 10276596afd4SAlex Deucher 0x0000f4a4, 0x00680fff, 0xffffffff, 10286596afd4SAlex Deucher 0x000004c8, 0x00000000, 0xffffffff, 10296596afd4SAlex Deucher 0x000064ec, 0x00000000, 0xffffffff, 10306596afd4SAlex Deucher 0x00000c7c, 0x00000000, 0xffffffff, 10316596afd4SAlex Deucher 0x00006dfc, 0x00000000, 0xffffffff 10326596afd4SAlex Deucher }; 10336596afd4SAlex Deucher #define BARTS_SYSLS_ENABLE_LENGTH sizeof(barts_sysls_enable) / (3 * sizeof(u32)) 10346596afd4SAlex Deucher 10356596afd4SAlex Deucher //********* CAICOS **************// 10366596afd4SAlex Deucher static const u32 caicos_sysls_default[] = 10376596afd4SAlex Deucher { 10386596afd4SAlex Deucher 0x000055e8, 0x00000000, 0xffffffff, 10396596afd4SAlex Deucher 0x0000d0bc, 0x00000000, 0xffffffff, 10406596afd4SAlex Deucher 0x000015c0, 0x000c1401, 0xffffffff, 10416596afd4SAlex Deucher 0x0000264c, 0x000c0400, 0xffffffff, 10426596afd4SAlex Deucher 0x00002648, 0x000c0400, 0xffffffff, 10436596afd4SAlex Deucher 0x00002650, 0x000c0400, 0xffffffff, 10446596afd4SAlex Deucher 0x000020b8, 0x000c0400, 0xffffffff, 10456596afd4SAlex Deucher 0x000020bc, 0x000c0400, 0xffffffff, 10466596afd4SAlex Deucher 0x0000f4a0, 0x000000c0, 0xffffffff, 10476596afd4SAlex Deucher 0x0000f4a4, 0x00680fff, 0xffffffff, 10486596afd4SAlex Deucher 0x000004c8, 0x00000001, 0xffffffff, 10496596afd4SAlex Deucher 0x000064ec, 0x00000000, 0xffffffff, 10506596afd4SAlex Deucher 0x00000c7c, 0x00000000, 0xffffffff, 10516596afd4SAlex Deucher 0x00006dfc, 0x00000000, 0xffffffff 10526596afd4SAlex Deucher }; 10536596afd4SAlex Deucher #define CAICOS_SYSLS_DEFAULT_LENGTH sizeof(caicos_sysls_default) / (3 * sizeof(u32)) 10546596afd4SAlex Deucher 10556596afd4SAlex Deucher static const u32 caicos_sysls_disable[] = 10566596afd4SAlex Deucher { 10576596afd4SAlex Deucher 0x000055e8, 0x00000000, 0xffffffff, 10586596afd4SAlex Deucher 0x0000d0bc, 0x00000000, 0xffffffff, 10596596afd4SAlex Deucher 0x000015c0, 0x00041401, 0xffffffff, 10606596afd4SAlex Deucher 0x0000264c, 0x00040400, 0xffffffff, 10616596afd4SAlex Deucher 0x00002648, 0x00040400, 0xffffffff, 10626596afd4SAlex Deucher 0x00002650, 0x00040400, 0xffffffff, 10636596afd4SAlex Deucher 0x000020b8, 0x00040400, 0xffffffff, 10646596afd4SAlex Deucher 0x000020bc, 0x00040400, 0xffffffff, 10656596afd4SAlex Deucher 0x0000f4a0, 0x000000c0, 0xffffffff, 10666596afd4SAlex Deucher 0x0000f4a4, 0x00680000, 0xffffffff, 10676596afd4SAlex Deucher 0x000004c8, 0x00000001, 0xffffffff, 10686596afd4SAlex Deucher 0x000064ec, 0x00007ffd, 0xffffffff, 10696596afd4SAlex Deucher 0x00000c7c, 0x0000ff00, 0xffffffff, 10706596afd4SAlex Deucher 0x00006dfc, 0x0000007f, 0xffffffff 10716596afd4SAlex Deucher }; 10726596afd4SAlex Deucher #define CAICOS_SYSLS_DISABLE_LENGTH sizeof(caicos_sysls_disable) / (3 * sizeof(u32)) 10736596afd4SAlex Deucher 10746596afd4SAlex Deucher static const u32 caicos_sysls_enable[] = 10756596afd4SAlex Deucher { 10766596afd4SAlex Deucher 0x000055e8, 0x00000001, 0xffffffff, 10776596afd4SAlex Deucher 0x0000d0bc, 0x00000100, 0xffffffff, 10786596afd4SAlex Deucher 0x000015c0, 0x000c1401, 0xffffffff, 10796596afd4SAlex Deucher 0x0000264c, 0x000c0400, 0xffffffff, 10806596afd4SAlex Deucher 0x00002648, 0x000c0400, 0xffffffff, 10816596afd4SAlex Deucher 0x00002650, 0x000c0400, 0xffffffff, 10826596afd4SAlex Deucher 0x000020b8, 0x000c0400, 0xffffffff, 10836596afd4SAlex Deucher 0x000020bc, 0x000c0400, 0xffffffff, 10846596afd4SAlex Deucher 0x0000f4a0, 0x000000c0, 0xffffffff, 10856596afd4SAlex Deucher 0x0000f4a4, 0x00680fff, 0xffffffff, 10866596afd4SAlex Deucher 0x000064ec, 0x00000000, 0xffffffff, 10876596afd4SAlex Deucher 0x00000c7c, 0x00000000, 0xffffffff, 10886596afd4SAlex Deucher 0x00006dfc, 0x00000000, 0xffffffff, 10896596afd4SAlex Deucher 0x000004c8, 0x00000000, 0xffffffff 10906596afd4SAlex Deucher }; 10916596afd4SAlex Deucher #define CAICOS_SYSLS_ENABLE_LENGTH sizeof(caicos_sysls_enable) / (3 * sizeof(u32)) 10926596afd4SAlex Deucher 10936596afd4SAlex Deucher //********* TURKS **************// 10946596afd4SAlex Deucher static const u32 turks_sysls_default[] = 10956596afd4SAlex Deucher { 10966596afd4SAlex Deucher 0x000055e8, 0x00000000, 0xffffffff, 10976596afd4SAlex Deucher 0x0000d0bc, 0x00000000, 0xffffffff, 10986596afd4SAlex Deucher 0x000015c0, 0x000c1401, 0xffffffff, 10996596afd4SAlex Deucher 0x0000264c, 0x000c0400, 0xffffffff, 11006596afd4SAlex Deucher 0x00002648, 0x000c0400, 0xffffffff, 11016596afd4SAlex Deucher 0x00002650, 0x000c0400, 0xffffffff, 11026596afd4SAlex Deucher 0x000020b8, 0x000c0400, 0xffffffff, 11036596afd4SAlex Deucher 0x000020bc, 0x000c0400, 0xffffffff, 11046596afd4SAlex Deucher 0x000020c0, 0x000c0c80, 0xffffffff, 11056596afd4SAlex Deucher 0x0000f4a0, 0x000000c0, 0xffffffff, 11066596afd4SAlex Deucher 0x0000f4a4, 0x00680fff, 0xffffffff, 11076596afd4SAlex Deucher 0x000004c8, 0x00000001, 0xffffffff, 11086596afd4SAlex Deucher 0x000064ec, 0x00000000, 0xffffffff, 11096596afd4SAlex Deucher 0x00000c7c, 0x00000000, 0xffffffff, 11106596afd4SAlex Deucher 0x00006dfc, 0x00000000, 0xffffffff 11116596afd4SAlex Deucher }; 11126596afd4SAlex Deucher #define TURKS_SYSLS_DEFAULT_LENGTH sizeof(turks_sysls_default) / (3 * sizeof(u32)) 11136596afd4SAlex Deucher 11146596afd4SAlex Deucher static const u32 turks_sysls_disable[] = 11156596afd4SAlex Deucher { 11166596afd4SAlex Deucher 0x000055e8, 0x00000000, 0xffffffff, 11176596afd4SAlex Deucher 0x0000d0bc, 0x00000000, 0xffffffff, 11186596afd4SAlex Deucher 0x000015c0, 0x00041401, 0xffffffff, 11196596afd4SAlex Deucher 0x0000264c, 0x00040400, 0xffffffff, 11206596afd4SAlex Deucher 0x00002648, 0x00040400, 0xffffffff, 11216596afd4SAlex Deucher 0x00002650, 0x00040400, 0xffffffff, 11226596afd4SAlex Deucher 0x000020b8, 0x00040400, 0xffffffff, 11236596afd4SAlex Deucher 0x000020bc, 0x00040400, 0xffffffff, 11246596afd4SAlex Deucher 0x000020c0, 0x00040c80, 0xffffffff, 11256596afd4SAlex Deucher 0x0000f4a0, 0x000000c0, 0xffffffff, 11266596afd4SAlex Deucher 0x0000f4a4, 0x00680000, 0xffffffff, 11276596afd4SAlex Deucher 0x000004c8, 0x00000001, 0xffffffff, 11286596afd4SAlex Deucher 0x000064ec, 0x00007ffd, 0xffffffff, 11296596afd4SAlex Deucher 0x00000c7c, 0x0000ff00, 0xffffffff, 11306596afd4SAlex Deucher 0x00006dfc, 0x0000007f, 0xffffffff 11316596afd4SAlex Deucher }; 11326596afd4SAlex Deucher #define TURKS_SYSLS_DISABLE_LENGTH sizeof(turks_sysls_disable) / (3 * sizeof(u32)) 11336596afd4SAlex Deucher 11346596afd4SAlex Deucher static const u32 turks_sysls_enable[] = 11356596afd4SAlex Deucher { 11366596afd4SAlex Deucher 0x000055e8, 0x00000001, 0xffffffff, 11376596afd4SAlex Deucher 0x0000d0bc, 0x00000100, 0xffffffff, 11386596afd4SAlex Deucher 0x000015c0, 0x000c1401, 0xffffffff, 11396596afd4SAlex Deucher 0x0000264c, 0x000c0400, 0xffffffff, 11406596afd4SAlex Deucher 0x00002648, 0x000c0400, 0xffffffff, 11416596afd4SAlex Deucher 0x00002650, 0x000c0400, 0xffffffff, 11426596afd4SAlex Deucher 0x000020b8, 0x000c0400, 0xffffffff, 11436596afd4SAlex Deucher 0x000020bc, 0x000c0400, 0xffffffff, 11446596afd4SAlex Deucher 0x000020c0, 0x000c0c80, 0xffffffff, 11456596afd4SAlex Deucher 0x0000f4a0, 0x000000c0, 0xffffffff, 11466596afd4SAlex Deucher 0x0000f4a4, 0x00680fff, 0xffffffff, 11476596afd4SAlex Deucher 0x000004c8, 0x00000000, 0xffffffff, 11486596afd4SAlex Deucher 0x000064ec, 0x00000000, 0xffffffff, 11496596afd4SAlex Deucher 0x00000c7c, 0x00000000, 0xffffffff, 11506596afd4SAlex Deucher 0x00006dfc, 0x00000000, 0xffffffff 11516596afd4SAlex Deucher }; 11526596afd4SAlex Deucher #define TURKS_SYSLS_ENABLE_LENGTH sizeof(turks_sysls_enable) / (3 * sizeof(u32)) 11536596afd4SAlex Deucher 11546596afd4SAlex Deucher #endif 11556596afd4SAlex Deucher 115669e0b57aSAlex Deucher u32 btc_valid_sclk[40] = 1157d22b7e40SAlex Deucher { 1158d22b7e40SAlex Deucher 5000, 10000, 15000, 20000, 25000, 30000, 35000, 40000, 45000, 50000, 1159d22b7e40SAlex Deucher 55000, 60000, 65000, 70000, 75000, 80000, 85000, 90000, 95000, 100000, 1160d22b7e40SAlex Deucher 105000, 110000, 11500, 120000, 125000, 130000, 135000, 140000, 145000, 150000, 1161d22b7e40SAlex Deucher 155000, 160000, 165000, 170000, 175000, 180000, 185000, 190000, 195000, 200000 1162d22b7e40SAlex Deucher }; 1163d22b7e40SAlex Deucher 1164d22b7e40SAlex Deucher static const struct radeon_blacklist_clocks btc_blacklist_clocks[] = 1165d22b7e40SAlex Deucher { 1166d22b7e40SAlex Deucher { 10000, 30000, RADEON_SCLK_UP }, 1167d22b7e40SAlex Deucher { 15000, 30000, RADEON_SCLK_UP }, 1168d22b7e40SAlex Deucher { 20000, 30000, RADEON_SCLK_UP }, 1169d22b7e40SAlex Deucher { 25000, 30000, RADEON_SCLK_UP } 1170d22b7e40SAlex Deucher }; 1171d22b7e40SAlex Deucher 11727102e232SAlex Deucher void btc_get_max_clock_from_voltage_dependency_table(struct radeon_clock_voltage_dependency_table *table, 11737102e232SAlex Deucher u32 *max_clock) 11747102e232SAlex Deucher { 11757102e232SAlex Deucher u32 i, clock = 0; 11767102e232SAlex Deucher 11777102e232SAlex Deucher if ((table == NULL) || (table->count == 0)) { 11787102e232SAlex Deucher *max_clock = clock; 11797102e232SAlex Deucher return; 11807102e232SAlex Deucher } 11817102e232SAlex Deucher 11827102e232SAlex Deucher for (i = 0; i < table->count; i++) { 11837102e232SAlex Deucher if (clock < table->entries[i].clk) 11847102e232SAlex Deucher clock = table->entries[i].clk; 11857102e232SAlex Deucher } 11867102e232SAlex Deucher *max_clock = clock; 11877102e232SAlex Deucher } 11887102e232SAlex Deucher 118969e0b57aSAlex Deucher void btc_apply_voltage_dependency_rules(struct radeon_clock_voltage_dependency_table *table, 1190d22b7e40SAlex Deucher u32 clock, u16 max_voltage, u16 *voltage) 1191d22b7e40SAlex Deucher { 1192d22b7e40SAlex Deucher u32 i; 1193d22b7e40SAlex Deucher 1194d22b7e40SAlex Deucher if ((table == NULL) || (table->count == 0)) 1195d22b7e40SAlex Deucher return; 1196d22b7e40SAlex Deucher 1197d22b7e40SAlex Deucher for (i= 0; i < table->count; i++) { 1198d22b7e40SAlex Deucher if (clock <= table->entries[i].clk) { 1199d22b7e40SAlex Deucher if (*voltage < table->entries[i].v) 1200d22b7e40SAlex Deucher *voltage = (u16)((table->entries[i].v < max_voltage) ? 1201d22b7e40SAlex Deucher table->entries[i].v : max_voltage); 1202d22b7e40SAlex Deucher return; 1203d22b7e40SAlex Deucher } 1204d22b7e40SAlex Deucher } 1205d22b7e40SAlex Deucher 1206d22b7e40SAlex Deucher *voltage = (*voltage > max_voltage) ? *voltage : max_voltage; 1207d22b7e40SAlex Deucher } 1208d22b7e40SAlex Deucher 1209d22b7e40SAlex Deucher static u32 btc_find_valid_clock(struct radeon_clock_array *clocks, 1210d22b7e40SAlex Deucher u32 max_clock, u32 requested_clock) 1211d22b7e40SAlex Deucher { 1212d22b7e40SAlex Deucher unsigned int i; 1213d22b7e40SAlex Deucher 1214d22b7e40SAlex Deucher if ((clocks == NULL) || (clocks->count == 0)) 1215d22b7e40SAlex Deucher return (requested_clock < max_clock) ? requested_clock : max_clock; 1216d22b7e40SAlex Deucher 1217d22b7e40SAlex Deucher for (i = 0; i < clocks->count; i++) { 1218d22b7e40SAlex Deucher if (clocks->values[i] >= requested_clock) 1219d22b7e40SAlex Deucher return (clocks->values[i] < max_clock) ? clocks->values[i] : max_clock; 1220d22b7e40SAlex Deucher } 1221d22b7e40SAlex Deucher 1222d22b7e40SAlex Deucher return (clocks->values[clocks->count - 1] < max_clock) ? 1223d22b7e40SAlex Deucher clocks->values[clocks->count - 1] : max_clock; 1224d22b7e40SAlex Deucher } 1225d22b7e40SAlex Deucher 1226d22b7e40SAlex Deucher static u32 btc_get_valid_mclk(struct radeon_device *rdev, 1227d22b7e40SAlex Deucher u32 max_mclk, u32 requested_mclk) 1228d22b7e40SAlex Deucher { 1229d22b7e40SAlex Deucher return btc_find_valid_clock(&rdev->pm.dpm.dyn_state.valid_mclk_values, 1230d22b7e40SAlex Deucher max_mclk, requested_mclk); 1231d22b7e40SAlex Deucher } 1232d22b7e40SAlex Deucher 1233d22b7e40SAlex Deucher static u32 btc_get_valid_sclk(struct radeon_device *rdev, 1234d22b7e40SAlex Deucher u32 max_sclk, u32 requested_sclk) 1235d22b7e40SAlex Deucher { 1236d22b7e40SAlex Deucher return btc_find_valid_clock(&rdev->pm.dpm.dyn_state.valid_sclk_values, 1237d22b7e40SAlex Deucher max_sclk, requested_sclk); 1238d22b7e40SAlex Deucher } 1239d22b7e40SAlex Deucher 124069e0b57aSAlex Deucher void btc_skip_blacklist_clocks(struct radeon_device *rdev, 1241d22b7e40SAlex Deucher const u32 max_sclk, const u32 max_mclk, 1242d22b7e40SAlex Deucher u32 *sclk, u32 *mclk) 1243d22b7e40SAlex Deucher { 1244d22b7e40SAlex Deucher int i, num_blacklist_clocks; 1245d22b7e40SAlex Deucher 1246d22b7e40SAlex Deucher if ((sclk == NULL) || (mclk == NULL)) 1247d22b7e40SAlex Deucher return; 1248d22b7e40SAlex Deucher 1249d22b7e40SAlex Deucher num_blacklist_clocks = ARRAY_SIZE(btc_blacklist_clocks); 1250d22b7e40SAlex Deucher 1251d22b7e40SAlex Deucher for (i = 0; i < num_blacklist_clocks; i++) { 1252d22b7e40SAlex Deucher if ((btc_blacklist_clocks[i].sclk == *sclk) && 1253d22b7e40SAlex Deucher (btc_blacklist_clocks[i].mclk == *mclk)) 1254d22b7e40SAlex Deucher break; 1255d22b7e40SAlex Deucher } 1256d22b7e40SAlex Deucher 1257d22b7e40SAlex Deucher if (i < num_blacklist_clocks) { 1258d22b7e40SAlex Deucher if (btc_blacklist_clocks[i].action == RADEON_SCLK_UP) { 1259d22b7e40SAlex Deucher *sclk = btc_get_valid_sclk(rdev, max_sclk, *sclk + 1); 1260d22b7e40SAlex Deucher 1261d22b7e40SAlex Deucher if (*sclk < max_sclk) 1262d22b7e40SAlex Deucher btc_skip_blacklist_clocks(rdev, max_sclk, max_mclk, sclk, mclk); 1263d22b7e40SAlex Deucher } 1264d22b7e40SAlex Deucher } 1265d22b7e40SAlex Deucher } 1266d22b7e40SAlex Deucher 126769e0b57aSAlex Deucher void btc_adjust_clock_combinations(struct radeon_device *rdev, 1268d22b7e40SAlex Deucher const struct radeon_clock_and_voltage_limits *max_limits, 1269d22b7e40SAlex Deucher struct rv7xx_pl *pl) 1270d22b7e40SAlex Deucher { 1271d22b7e40SAlex Deucher 1272d22b7e40SAlex Deucher if ((pl->mclk == 0) || (pl->sclk == 0)) 1273d22b7e40SAlex Deucher return; 1274d22b7e40SAlex Deucher 1275d22b7e40SAlex Deucher if (pl->mclk == pl->sclk) 1276d22b7e40SAlex Deucher return; 1277d22b7e40SAlex Deucher 1278d22b7e40SAlex Deucher if (pl->mclk > pl->sclk) { 1279d22b7e40SAlex Deucher if (((pl->mclk + (pl->sclk - 1)) / pl->sclk) > rdev->pm.dpm.dyn_state.mclk_sclk_ratio) 1280d22b7e40SAlex Deucher pl->sclk = btc_get_valid_sclk(rdev, 1281d22b7e40SAlex Deucher max_limits->sclk, 1282d22b7e40SAlex Deucher (pl->mclk + 1283d22b7e40SAlex Deucher (rdev->pm.dpm.dyn_state.mclk_sclk_ratio - 1)) / 1284d22b7e40SAlex Deucher rdev->pm.dpm.dyn_state.mclk_sclk_ratio); 1285d22b7e40SAlex Deucher } else { 1286d22b7e40SAlex Deucher if ((pl->sclk - pl->mclk) > rdev->pm.dpm.dyn_state.sclk_mclk_delta) 1287d22b7e40SAlex Deucher pl->mclk = btc_get_valid_mclk(rdev, 1288d22b7e40SAlex Deucher max_limits->mclk, 1289d22b7e40SAlex Deucher pl->sclk - 1290d22b7e40SAlex Deucher rdev->pm.dpm.dyn_state.sclk_mclk_delta); 1291d22b7e40SAlex Deucher } 1292d22b7e40SAlex Deucher } 1293d22b7e40SAlex Deucher 1294d22b7e40SAlex Deucher static u16 btc_find_voltage(struct atom_voltage_table *table, u16 voltage) 1295d22b7e40SAlex Deucher { 1296d22b7e40SAlex Deucher unsigned int i; 1297d22b7e40SAlex Deucher 1298d22b7e40SAlex Deucher for (i = 0; i < table->count; i++) { 1299d22b7e40SAlex Deucher if (voltage <= table->entries[i].value) 1300d22b7e40SAlex Deucher return table->entries[i].value; 1301d22b7e40SAlex Deucher } 1302d22b7e40SAlex Deucher 1303d22b7e40SAlex Deucher return table->entries[table->count - 1].value; 1304d22b7e40SAlex Deucher } 1305d22b7e40SAlex Deucher 130669e0b57aSAlex Deucher void btc_apply_voltage_delta_rules(struct radeon_device *rdev, 1307d22b7e40SAlex Deucher u16 max_vddc, u16 max_vddci, 1308d22b7e40SAlex Deucher u16 *vddc, u16 *vddci) 1309d22b7e40SAlex Deucher { 1310d22b7e40SAlex Deucher struct evergreen_power_info *eg_pi = evergreen_get_pi(rdev); 1311d22b7e40SAlex Deucher u16 new_voltage; 1312d22b7e40SAlex Deucher 1313d22b7e40SAlex Deucher if ((0 == *vddc) || (0 == *vddci)) 1314d22b7e40SAlex Deucher return; 1315d22b7e40SAlex Deucher 1316d22b7e40SAlex Deucher if (*vddc > *vddci) { 1317d22b7e40SAlex Deucher if ((*vddc - *vddci) > rdev->pm.dpm.dyn_state.vddc_vddci_delta) { 1318d22b7e40SAlex Deucher new_voltage = btc_find_voltage(&eg_pi->vddci_voltage_table, 1319d22b7e40SAlex Deucher (*vddc - rdev->pm.dpm.dyn_state.vddc_vddci_delta)); 1320d22b7e40SAlex Deucher *vddci = (new_voltage < max_vddci) ? new_voltage : max_vddci; 1321d22b7e40SAlex Deucher } 1322d22b7e40SAlex Deucher } else { 1323d22b7e40SAlex Deucher if ((*vddci - *vddc) > rdev->pm.dpm.dyn_state.vddc_vddci_delta) { 1324d22b7e40SAlex Deucher new_voltage = btc_find_voltage(&eg_pi->vddc_voltage_table, 1325d22b7e40SAlex Deucher (*vddci - rdev->pm.dpm.dyn_state.vddc_vddci_delta)); 1326d22b7e40SAlex Deucher *vddc = (new_voltage < max_vddc) ? new_voltage : max_vddc; 1327d22b7e40SAlex Deucher } 1328d22b7e40SAlex Deucher } 1329d22b7e40SAlex Deucher } 1330d22b7e40SAlex Deucher 13316596afd4SAlex Deucher static void btc_enable_bif_dynamic_pcie_gen2(struct radeon_device *rdev, 13326596afd4SAlex Deucher bool enable) 13336596afd4SAlex Deucher { 13346596afd4SAlex Deucher struct rv7xx_power_info *pi = rv770_get_pi(rdev); 13356596afd4SAlex Deucher u32 tmp, bif; 13366596afd4SAlex Deucher 13376596afd4SAlex Deucher tmp = RREG32_PCIE_PORT(PCIE_LC_SPEED_CNTL); 13386596afd4SAlex Deucher if (enable) { 13396596afd4SAlex Deucher if ((tmp & LC_OTHER_SIDE_EVER_SENT_GEN2) && 13406596afd4SAlex Deucher (tmp & LC_OTHER_SIDE_SUPPORTS_GEN2)) { 13416596afd4SAlex Deucher if (!pi->boot_in_gen2) { 13426596afd4SAlex Deucher bif = RREG32(CG_BIF_REQ_AND_RSP) & ~CG_CLIENT_REQ_MASK; 13436596afd4SAlex Deucher bif |= CG_CLIENT_REQ(0xd); 13446596afd4SAlex Deucher WREG32(CG_BIF_REQ_AND_RSP, bif); 13456596afd4SAlex Deucher 13466596afd4SAlex Deucher tmp &= ~LC_HW_VOLTAGE_IF_CONTROL_MASK; 13476596afd4SAlex Deucher tmp |= LC_HW_VOLTAGE_IF_CONTROL(1); 13486596afd4SAlex Deucher tmp |= LC_GEN2_EN_STRAP; 13496596afd4SAlex Deucher 13506596afd4SAlex Deucher tmp |= LC_CLR_FAILED_SPD_CHANGE_CNT; 13516596afd4SAlex Deucher WREG32_PCIE_PORT(PCIE_LC_SPEED_CNTL, tmp); 13526596afd4SAlex Deucher udelay(10); 13536596afd4SAlex Deucher tmp &= ~LC_CLR_FAILED_SPD_CHANGE_CNT; 13546596afd4SAlex Deucher WREG32_PCIE_PORT(PCIE_LC_SPEED_CNTL, tmp); 13556596afd4SAlex Deucher } 13566596afd4SAlex Deucher } 13576596afd4SAlex Deucher } else { 13586596afd4SAlex Deucher if ((tmp & LC_OTHER_SIDE_EVER_SENT_GEN2) || 13596596afd4SAlex Deucher (tmp & LC_OTHER_SIDE_SUPPORTS_GEN2)) { 13606596afd4SAlex Deucher if (!pi->boot_in_gen2) { 13616596afd4SAlex Deucher bif = RREG32(CG_BIF_REQ_AND_RSP) & ~CG_CLIENT_REQ_MASK; 13626596afd4SAlex Deucher bif |= CG_CLIENT_REQ(0xd); 13636596afd4SAlex Deucher WREG32(CG_BIF_REQ_AND_RSP, bif); 13646596afd4SAlex Deucher 13656596afd4SAlex Deucher tmp &= ~LC_HW_VOLTAGE_IF_CONTROL_MASK; 13666596afd4SAlex Deucher tmp &= ~LC_GEN2_EN_STRAP; 13676596afd4SAlex Deucher } 13686596afd4SAlex Deucher WREG32_PCIE_PORT(PCIE_LC_SPEED_CNTL, tmp); 13696596afd4SAlex Deucher } 13706596afd4SAlex Deucher } 13716596afd4SAlex Deucher } 13726596afd4SAlex Deucher 13736596afd4SAlex Deucher static void btc_enable_dynamic_pcie_gen2(struct radeon_device *rdev, 13746596afd4SAlex Deucher bool enable) 13756596afd4SAlex Deucher { 13766596afd4SAlex Deucher btc_enable_bif_dynamic_pcie_gen2(rdev, enable); 13776596afd4SAlex Deucher 13786596afd4SAlex Deucher if (enable) 13796596afd4SAlex Deucher WREG32_P(GENERAL_PWRMGT, ENABLE_GEN2PCIE, ~ENABLE_GEN2PCIE); 13806596afd4SAlex Deucher else 13816596afd4SAlex Deucher WREG32_P(GENERAL_PWRMGT, 0, ~ENABLE_GEN2PCIE); 13826596afd4SAlex Deucher } 13836596afd4SAlex Deucher 13846596afd4SAlex Deucher static int btc_disable_ulv(struct radeon_device *rdev) 13856596afd4SAlex Deucher { 13866596afd4SAlex Deucher struct evergreen_power_info *eg_pi = evergreen_get_pi(rdev); 13876596afd4SAlex Deucher 13886596afd4SAlex Deucher if (eg_pi->ulv.supported) { 13896596afd4SAlex Deucher if (rv770_send_msg_to_smc(rdev, PPSMC_MSG_DisableULV) != PPSMC_Result_OK) 13906596afd4SAlex Deucher return -EINVAL; 13916596afd4SAlex Deucher } 13926596afd4SAlex Deucher return 0; 13936596afd4SAlex Deucher } 13946596afd4SAlex Deucher 13956596afd4SAlex Deucher static int btc_populate_ulv_state(struct radeon_device *rdev, 13966596afd4SAlex Deucher RV770_SMC_STATETABLE *table) 13976596afd4SAlex Deucher { 13986596afd4SAlex Deucher int ret = -EINVAL; 13996596afd4SAlex Deucher struct evergreen_power_info *eg_pi = evergreen_get_pi(rdev); 14006596afd4SAlex Deucher struct rv7xx_pl *ulv_pl = eg_pi->ulv.pl; 14016596afd4SAlex Deucher 14026596afd4SAlex Deucher if (ulv_pl->vddc) { 14036596afd4SAlex Deucher ret = cypress_convert_power_level_to_smc(rdev, 14046596afd4SAlex Deucher ulv_pl, 14056596afd4SAlex Deucher &table->ULVState.levels[0], 14066596afd4SAlex Deucher PPSMC_DISPLAY_WATERMARK_LOW); 14076596afd4SAlex Deucher if (ret == 0) { 14086596afd4SAlex Deucher table->ULVState.levels[0].arbValue = MC_CG_ARB_FREQ_F0; 14096596afd4SAlex Deucher table->ULVState.levels[0].ACIndex = 1; 14106596afd4SAlex Deucher 14116596afd4SAlex Deucher table->ULVState.levels[1] = table->ULVState.levels[0]; 14126596afd4SAlex Deucher table->ULVState.levels[2] = table->ULVState.levels[0]; 14136596afd4SAlex Deucher 14146596afd4SAlex Deucher table->ULVState.flags |= PPSMC_SWSTATE_FLAG_DC; 14156596afd4SAlex Deucher 14166596afd4SAlex Deucher WREG32(CG_ULV_CONTROL, BTC_CGULVCONTROL_DFLT); 14176596afd4SAlex Deucher WREG32(CG_ULV_PARAMETER, BTC_CGULVPARAMETER_DFLT); 14186596afd4SAlex Deucher } 14196596afd4SAlex Deucher } 14206596afd4SAlex Deucher 14216596afd4SAlex Deucher return ret; 14226596afd4SAlex Deucher } 14236596afd4SAlex Deucher 14246596afd4SAlex Deucher static int btc_populate_smc_acpi_state(struct radeon_device *rdev, 14256596afd4SAlex Deucher RV770_SMC_STATETABLE *table) 14266596afd4SAlex Deucher { 14276596afd4SAlex Deucher int ret = cypress_populate_smc_acpi_state(rdev, table); 14286596afd4SAlex Deucher 14296596afd4SAlex Deucher if (ret == 0) { 14306596afd4SAlex Deucher table->ACPIState.levels[0].ACIndex = 0; 14316596afd4SAlex Deucher table->ACPIState.levels[1].ACIndex = 0; 14326596afd4SAlex Deucher table->ACPIState.levels[2].ACIndex = 0; 14336596afd4SAlex Deucher } 14346596afd4SAlex Deucher 14356596afd4SAlex Deucher return ret; 14366596afd4SAlex Deucher } 14376596afd4SAlex Deucher 143869e0b57aSAlex Deucher void btc_program_mgcg_hw_sequence(struct radeon_device *rdev, 14396596afd4SAlex Deucher const u32 *sequence, u32 count) 14406596afd4SAlex Deucher { 14416596afd4SAlex Deucher u32 i, length = count * 3; 14426596afd4SAlex Deucher u32 tmp; 14436596afd4SAlex Deucher 14446596afd4SAlex Deucher for (i = 0; i < length; i+=3) { 14456596afd4SAlex Deucher tmp = RREG32(sequence[i]); 14466596afd4SAlex Deucher tmp &= ~sequence[i+2]; 14476596afd4SAlex Deucher tmp |= sequence[i+1] & sequence[i+2]; 14486596afd4SAlex Deucher WREG32(sequence[i], tmp); 14496596afd4SAlex Deucher } 14506596afd4SAlex Deucher } 14516596afd4SAlex Deucher 14526596afd4SAlex Deucher static void btc_cg_clock_gating_default(struct radeon_device *rdev) 14536596afd4SAlex Deucher { 14546596afd4SAlex Deucher u32 count; 14556596afd4SAlex Deucher const u32 *p = NULL; 14566596afd4SAlex Deucher 14576596afd4SAlex Deucher if (rdev->family == CHIP_BARTS) { 14586596afd4SAlex Deucher p = (const u32 *)&barts_cgcg_cgls_default; 14596596afd4SAlex Deucher count = BARTS_CGCG_CGLS_DEFAULT_LENGTH; 14606596afd4SAlex Deucher } else if (rdev->family == CHIP_TURKS) { 14616596afd4SAlex Deucher p = (const u32 *)&turks_cgcg_cgls_default; 14626596afd4SAlex Deucher count = TURKS_CGCG_CGLS_DEFAULT_LENGTH; 14636596afd4SAlex Deucher } else if (rdev->family == CHIP_CAICOS) { 14646596afd4SAlex Deucher p = (const u32 *)&caicos_cgcg_cgls_default; 14656596afd4SAlex Deucher count = CAICOS_CGCG_CGLS_DEFAULT_LENGTH; 14666596afd4SAlex Deucher } else 14676596afd4SAlex Deucher return; 14686596afd4SAlex Deucher 14696596afd4SAlex Deucher btc_program_mgcg_hw_sequence(rdev, p, count); 14706596afd4SAlex Deucher } 14716596afd4SAlex Deucher 14726596afd4SAlex Deucher static void btc_cg_clock_gating_enable(struct radeon_device *rdev, 14736596afd4SAlex Deucher bool enable) 14746596afd4SAlex Deucher { 14756596afd4SAlex Deucher u32 count; 14766596afd4SAlex Deucher const u32 *p = NULL; 14776596afd4SAlex Deucher 14786596afd4SAlex Deucher if (enable) { 14796596afd4SAlex Deucher if (rdev->family == CHIP_BARTS) { 14806596afd4SAlex Deucher p = (const u32 *)&barts_cgcg_cgls_enable; 14816596afd4SAlex Deucher count = BARTS_CGCG_CGLS_ENABLE_LENGTH; 14826596afd4SAlex Deucher } else if (rdev->family == CHIP_TURKS) { 14836596afd4SAlex Deucher p = (const u32 *)&turks_cgcg_cgls_enable; 14846596afd4SAlex Deucher count = TURKS_CGCG_CGLS_ENABLE_LENGTH; 14856596afd4SAlex Deucher } else if (rdev->family == CHIP_CAICOS) { 14866596afd4SAlex Deucher p = (const u32 *)&caicos_cgcg_cgls_enable; 14876596afd4SAlex Deucher count = CAICOS_CGCG_CGLS_ENABLE_LENGTH; 14886596afd4SAlex Deucher } else 14896596afd4SAlex Deucher return; 14906596afd4SAlex Deucher } else { 14916596afd4SAlex Deucher if (rdev->family == CHIP_BARTS) { 14926596afd4SAlex Deucher p = (const u32 *)&barts_cgcg_cgls_disable; 14936596afd4SAlex Deucher count = BARTS_CGCG_CGLS_DISABLE_LENGTH; 14946596afd4SAlex Deucher } else if (rdev->family == CHIP_TURKS) { 14956596afd4SAlex Deucher p = (const u32 *)&turks_cgcg_cgls_disable; 14966596afd4SAlex Deucher count = TURKS_CGCG_CGLS_DISABLE_LENGTH; 14976596afd4SAlex Deucher } else if (rdev->family == CHIP_CAICOS) { 14986596afd4SAlex Deucher p = (const u32 *)&caicos_cgcg_cgls_disable; 14996596afd4SAlex Deucher count = CAICOS_CGCG_CGLS_DISABLE_LENGTH; 15006596afd4SAlex Deucher } else 15016596afd4SAlex Deucher return; 15026596afd4SAlex Deucher } 15036596afd4SAlex Deucher 15046596afd4SAlex Deucher btc_program_mgcg_hw_sequence(rdev, p, count); 15056596afd4SAlex Deucher } 15066596afd4SAlex Deucher 15076596afd4SAlex Deucher static void btc_mg_clock_gating_default(struct radeon_device *rdev) 15086596afd4SAlex Deucher { 15096596afd4SAlex Deucher u32 count; 15106596afd4SAlex Deucher const u32 *p = NULL; 15116596afd4SAlex Deucher 15126596afd4SAlex Deucher if (rdev->family == CHIP_BARTS) { 15136596afd4SAlex Deucher p = (const u32 *)&barts_mgcg_default; 15146596afd4SAlex Deucher count = BARTS_MGCG_DEFAULT_LENGTH; 15156596afd4SAlex Deucher } else if (rdev->family == CHIP_TURKS) { 15166596afd4SAlex Deucher p = (const u32 *)&turks_mgcg_default; 15176596afd4SAlex Deucher count = TURKS_MGCG_DEFAULT_LENGTH; 15186596afd4SAlex Deucher } else if (rdev->family == CHIP_CAICOS) { 15196596afd4SAlex Deucher p = (const u32 *)&caicos_mgcg_default; 15206596afd4SAlex Deucher count = CAICOS_MGCG_DEFAULT_LENGTH; 15216596afd4SAlex Deucher } else 15226596afd4SAlex Deucher return; 15236596afd4SAlex Deucher 15246596afd4SAlex Deucher btc_program_mgcg_hw_sequence(rdev, p, count); 15256596afd4SAlex Deucher } 15266596afd4SAlex Deucher 15276596afd4SAlex Deucher static void btc_mg_clock_gating_enable(struct radeon_device *rdev, 15286596afd4SAlex Deucher bool enable) 15296596afd4SAlex Deucher { 15306596afd4SAlex Deucher u32 count; 15316596afd4SAlex Deucher const u32 *p = NULL; 15326596afd4SAlex Deucher 15336596afd4SAlex Deucher if (enable) { 15346596afd4SAlex Deucher if (rdev->family == CHIP_BARTS) { 15356596afd4SAlex Deucher p = (const u32 *)&barts_mgcg_enable; 15366596afd4SAlex Deucher count = BARTS_MGCG_ENABLE_LENGTH; 15376596afd4SAlex Deucher } else if (rdev->family == CHIP_TURKS) { 15386596afd4SAlex Deucher p = (const u32 *)&turks_mgcg_enable; 15396596afd4SAlex Deucher count = TURKS_MGCG_ENABLE_LENGTH; 15406596afd4SAlex Deucher } else if (rdev->family == CHIP_CAICOS) { 15416596afd4SAlex Deucher p = (const u32 *)&caicos_mgcg_enable; 15426596afd4SAlex Deucher count = CAICOS_MGCG_ENABLE_LENGTH; 15436596afd4SAlex Deucher } else 15446596afd4SAlex Deucher return; 15456596afd4SAlex Deucher } else { 15466596afd4SAlex Deucher if (rdev->family == CHIP_BARTS) { 15476596afd4SAlex Deucher p = (const u32 *)&barts_mgcg_disable[0]; 15486596afd4SAlex Deucher count = BARTS_MGCG_DISABLE_LENGTH; 15496596afd4SAlex Deucher } else if (rdev->family == CHIP_TURKS) { 15506596afd4SAlex Deucher p = (const u32 *)&turks_mgcg_disable[0]; 15516596afd4SAlex Deucher count = TURKS_MGCG_DISABLE_LENGTH; 15526596afd4SAlex Deucher } else if (rdev->family == CHIP_CAICOS) { 15536596afd4SAlex Deucher p = (const u32 *)&caicos_mgcg_disable[0]; 15546596afd4SAlex Deucher count = CAICOS_MGCG_DISABLE_LENGTH; 15556596afd4SAlex Deucher } else 15566596afd4SAlex Deucher return; 15576596afd4SAlex Deucher } 15586596afd4SAlex Deucher 15596596afd4SAlex Deucher btc_program_mgcg_hw_sequence(rdev, p, count); 15606596afd4SAlex Deucher } 15616596afd4SAlex Deucher 15626596afd4SAlex Deucher static void btc_ls_clock_gating_default(struct radeon_device *rdev) 15636596afd4SAlex Deucher { 15646596afd4SAlex Deucher u32 count; 15656596afd4SAlex Deucher const u32 *p = NULL; 15666596afd4SAlex Deucher 15676596afd4SAlex Deucher if (rdev->family == CHIP_BARTS) { 15686596afd4SAlex Deucher p = (const u32 *)&barts_sysls_default; 15696596afd4SAlex Deucher count = BARTS_SYSLS_DEFAULT_LENGTH; 15706596afd4SAlex Deucher } else if (rdev->family == CHIP_TURKS) { 15716596afd4SAlex Deucher p = (const u32 *)&turks_sysls_default; 15726596afd4SAlex Deucher count = TURKS_SYSLS_DEFAULT_LENGTH; 15736596afd4SAlex Deucher } else if (rdev->family == CHIP_CAICOS) { 15746596afd4SAlex Deucher p = (const u32 *)&caicos_sysls_default; 15756596afd4SAlex Deucher count = CAICOS_SYSLS_DEFAULT_LENGTH; 15766596afd4SAlex Deucher } else 15776596afd4SAlex Deucher return; 15786596afd4SAlex Deucher 15796596afd4SAlex Deucher btc_program_mgcg_hw_sequence(rdev, p, count); 15806596afd4SAlex Deucher } 15816596afd4SAlex Deucher 15826596afd4SAlex Deucher static void btc_ls_clock_gating_enable(struct radeon_device *rdev, 15836596afd4SAlex Deucher bool enable) 15846596afd4SAlex Deucher { 15856596afd4SAlex Deucher u32 count; 15866596afd4SAlex Deucher const u32 *p = NULL; 15876596afd4SAlex Deucher 15886596afd4SAlex Deucher if (enable) { 15896596afd4SAlex Deucher if (rdev->family == CHIP_BARTS) { 15906596afd4SAlex Deucher p = (const u32 *)&barts_sysls_enable; 15916596afd4SAlex Deucher count = BARTS_SYSLS_ENABLE_LENGTH; 15926596afd4SAlex Deucher } else if (rdev->family == CHIP_TURKS) { 15936596afd4SAlex Deucher p = (const u32 *)&turks_sysls_enable; 15946596afd4SAlex Deucher count = TURKS_SYSLS_ENABLE_LENGTH; 15956596afd4SAlex Deucher } else if (rdev->family == CHIP_CAICOS) { 15966596afd4SAlex Deucher p = (const u32 *)&caicos_sysls_enable; 15976596afd4SAlex Deucher count = CAICOS_SYSLS_ENABLE_LENGTH; 15986596afd4SAlex Deucher } else 15996596afd4SAlex Deucher return; 16006596afd4SAlex Deucher } else { 16016596afd4SAlex Deucher if (rdev->family == CHIP_BARTS) { 16026596afd4SAlex Deucher p = (const u32 *)&barts_sysls_disable; 16036596afd4SAlex Deucher count = BARTS_SYSLS_DISABLE_LENGTH; 16046596afd4SAlex Deucher } else if (rdev->family == CHIP_TURKS) { 16056596afd4SAlex Deucher p = (const u32 *)&turks_sysls_disable; 16066596afd4SAlex Deucher count = TURKS_SYSLS_DISABLE_LENGTH; 16076596afd4SAlex Deucher } else if (rdev->family == CHIP_CAICOS) { 16086596afd4SAlex Deucher p = (const u32 *)&caicos_sysls_disable; 16096596afd4SAlex Deucher count = CAICOS_SYSLS_DISABLE_LENGTH; 16106596afd4SAlex Deucher } else 16116596afd4SAlex Deucher return; 16126596afd4SAlex Deucher } 16136596afd4SAlex Deucher 16146596afd4SAlex Deucher btc_program_mgcg_hw_sequence(rdev, p, count); 16156596afd4SAlex Deucher } 16166596afd4SAlex Deucher 161769e0b57aSAlex Deucher bool btc_dpm_enabled(struct radeon_device *rdev) 16186596afd4SAlex Deucher { 16196596afd4SAlex Deucher if (rv770_is_smc_running(rdev)) 16206596afd4SAlex Deucher return true; 16216596afd4SAlex Deucher else 16226596afd4SAlex Deucher return false; 16236596afd4SAlex Deucher } 16246596afd4SAlex Deucher 16254cb3a02fSAlex Deucher static int btc_init_smc_table(struct radeon_device *rdev, 16264cb3a02fSAlex Deucher struct radeon_ps *radeon_boot_state) 16276596afd4SAlex Deucher { 16286596afd4SAlex Deucher struct rv7xx_power_info *pi = rv770_get_pi(rdev); 16296596afd4SAlex Deucher struct evergreen_power_info *eg_pi = evergreen_get_pi(rdev); 16306596afd4SAlex Deucher RV770_SMC_STATETABLE *table = &pi->smc_statetable; 16316596afd4SAlex Deucher int ret; 16326596afd4SAlex Deucher 16336596afd4SAlex Deucher memset(table, 0, sizeof(RV770_SMC_STATETABLE)); 16346596afd4SAlex Deucher 16356596afd4SAlex Deucher cypress_populate_smc_voltage_tables(rdev, table); 16366596afd4SAlex Deucher 16376596afd4SAlex Deucher switch (rdev->pm.int_thermal_type) { 16386596afd4SAlex Deucher case THERMAL_TYPE_EVERGREEN: 16396596afd4SAlex Deucher case THERMAL_TYPE_EMC2103_WITH_INTERNAL: 16406596afd4SAlex Deucher table->thermalProtectType = PPSMC_THERMAL_PROTECT_TYPE_INTERNAL; 16416596afd4SAlex Deucher break; 16426596afd4SAlex Deucher case THERMAL_TYPE_NONE: 16436596afd4SAlex Deucher table->thermalProtectType = PPSMC_THERMAL_PROTECT_TYPE_NONE; 16446596afd4SAlex Deucher break; 16456596afd4SAlex Deucher default: 16466596afd4SAlex Deucher table->thermalProtectType = PPSMC_THERMAL_PROTECT_TYPE_EXTERNAL; 16476596afd4SAlex Deucher break; 16486596afd4SAlex Deucher } 16496596afd4SAlex Deucher 16506596afd4SAlex Deucher if (rdev->pm.dpm.platform_caps & ATOM_PP_PLATFORM_CAP_HARDWAREDC) 16516596afd4SAlex Deucher table->systemFlags |= PPSMC_SYSTEMFLAG_GPIO_DC; 16526596afd4SAlex Deucher 16536596afd4SAlex Deucher if (rdev->pm.dpm.platform_caps & ATOM_PP_PLATFORM_CAP_REGULATOR_HOT) 16546596afd4SAlex Deucher table->systemFlags |= PPSMC_SYSTEMFLAG_REGULATOR_HOT; 16556596afd4SAlex Deucher 16566596afd4SAlex Deucher if (rdev->pm.dpm.platform_caps & ATOM_PP_PLATFORM_CAP_STEPVDDC) 16576596afd4SAlex Deucher table->systemFlags |= PPSMC_SYSTEMFLAG_STEPVDDC; 16586596afd4SAlex Deucher 16596596afd4SAlex Deucher if (pi->mem_gddr5) 16606596afd4SAlex Deucher table->systemFlags |= PPSMC_SYSTEMFLAG_GDDR5; 16616596afd4SAlex Deucher 16626596afd4SAlex Deucher ret = cypress_populate_smc_initial_state(rdev, radeon_boot_state, table); 16636596afd4SAlex Deucher if (ret) 16646596afd4SAlex Deucher return ret; 16656596afd4SAlex Deucher 16666596afd4SAlex Deucher if (eg_pi->sclk_deep_sleep) 16676596afd4SAlex Deucher WREG32_P(SCLK_PSKIP_CNTL, PSKIP_ON_ALLOW_STOP_HI(32), 16686596afd4SAlex Deucher ~PSKIP_ON_ALLOW_STOP_HI_MASK); 16696596afd4SAlex Deucher 16706596afd4SAlex Deucher ret = btc_populate_smc_acpi_state(rdev, table); 16716596afd4SAlex Deucher if (ret) 16726596afd4SAlex Deucher return ret; 16736596afd4SAlex Deucher 16746596afd4SAlex Deucher if (eg_pi->ulv.supported) { 16756596afd4SAlex Deucher ret = btc_populate_ulv_state(rdev, table); 16766596afd4SAlex Deucher if (ret) 16776596afd4SAlex Deucher eg_pi->ulv.supported = false; 16786596afd4SAlex Deucher } 16796596afd4SAlex Deucher 16806596afd4SAlex Deucher table->driverState = table->initialState; 16816596afd4SAlex Deucher 16826596afd4SAlex Deucher return rv770_copy_bytes_to_smc(rdev, 16836596afd4SAlex Deucher pi->state_table_start, 16846596afd4SAlex Deucher (u8 *)table, 16856596afd4SAlex Deucher sizeof(RV770_SMC_STATETABLE), 16866596afd4SAlex Deucher pi->sram_end); 16876596afd4SAlex Deucher } 16886596afd4SAlex Deucher 16894cb3a02fSAlex Deucher static void btc_set_at_for_uvd(struct radeon_device *rdev, 16904cb3a02fSAlex Deucher struct radeon_ps *radeon_new_state) 1691f85392bcSAlex Deucher { 1692f85392bcSAlex Deucher struct rv7xx_power_info *pi = rv770_get_pi(rdev); 1693f85392bcSAlex Deucher struct evergreen_power_info *eg_pi = evergreen_get_pi(rdev); 1694f85392bcSAlex Deucher int idx = 0; 1695f85392bcSAlex Deucher 1696f85392bcSAlex Deucher if (r600_is_uvd_state(radeon_new_state->class, radeon_new_state->class2)) 1697f85392bcSAlex Deucher idx = 1; 1698f85392bcSAlex Deucher 1699f85392bcSAlex Deucher if ((idx == 1) && !eg_pi->smu_uvd_hs) { 1700f85392bcSAlex Deucher pi->rlp = 10; 1701f85392bcSAlex Deucher pi->rmp = 100; 1702f85392bcSAlex Deucher pi->lhp = 100; 1703f85392bcSAlex Deucher pi->lmp = 10; 1704f85392bcSAlex Deucher } else { 1705f85392bcSAlex Deucher pi->rlp = eg_pi->ats[idx].rlp; 1706f85392bcSAlex Deucher pi->rmp = eg_pi->ats[idx].rmp; 1707f85392bcSAlex Deucher pi->lhp = eg_pi->ats[idx].lhp; 1708f85392bcSAlex Deucher pi->lmp = eg_pi->ats[idx].lmp; 1709f85392bcSAlex Deucher } 1710f85392bcSAlex Deucher 1711f85392bcSAlex Deucher } 1712f85392bcSAlex Deucher 17134cb3a02fSAlex Deucher void btc_notify_uvd_to_smc(struct radeon_device *rdev, 17144cb3a02fSAlex Deucher struct radeon_ps *radeon_new_state) 1715f85392bcSAlex Deucher { 1716f85392bcSAlex Deucher struct evergreen_power_info *eg_pi = evergreen_get_pi(rdev); 1717f85392bcSAlex Deucher 1718f85392bcSAlex Deucher if (r600_is_uvd_state(radeon_new_state->class, radeon_new_state->class2)) { 1719f85392bcSAlex Deucher rv770_write_smc_soft_register(rdev, 1720f85392bcSAlex Deucher RV770_SMC_SOFT_REGISTER_uvd_enabled, 1); 1721f85392bcSAlex Deucher eg_pi->uvd_enabled = true; 1722f85392bcSAlex Deucher } else { 1723f85392bcSAlex Deucher rv770_write_smc_soft_register(rdev, 1724f85392bcSAlex Deucher RV770_SMC_SOFT_REGISTER_uvd_enabled, 0); 1725f85392bcSAlex Deucher eg_pi->uvd_enabled = false; 1726f85392bcSAlex Deucher } 1727f85392bcSAlex Deucher } 1728f85392bcSAlex Deucher 172969e0b57aSAlex Deucher int btc_reset_to_default(struct radeon_device *rdev) 17306596afd4SAlex Deucher { 17316596afd4SAlex Deucher if (rv770_send_msg_to_smc(rdev, PPSMC_MSG_ResetToDefaults) != PPSMC_Result_OK) 17326596afd4SAlex Deucher return -EINVAL; 17336596afd4SAlex Deucher 17346596afd4SAlex Deucher return 0; 17356596afd4SAlex Deucher } 17366596afd4SAlex Deucher 17376596afd4SAlex Deucher static void btc_stop_smc(struct radeon_device *rdev) 17386596afd4SAlex Deucher { 17396596afd4SAlex Deucher int i; 17406596afd4SAlex Deucher 17416596afd4SAlex Deucher for (i = 0; i < rdev->usec_timeout; i++) { 17426596afd4SAlex Deucher if (((RREG32(LB_SYNC_RESET_SEL) & LB_SYNC_RESET_SEL_MASK) >> LB_SYNC_RESET_SEL_SHIFT) != 1) 17436596afd4SAlex Deucher break; 17446596afd4SAlex Deucher udelay(1); 17456596afd4SAlex Deucher } 17466596afd4SAlex Deucher udelay(100); 17476596afd4SAlex Deucher 17486596afd4SAlex Deucher r7xx_stop_smc(rdev); 17496596afd4SAlex Deucher } 17506596afd4SAlex Deucher 175169e0b57aSAlex Deucher void btc_read_arb_registers(struct radeon_device *rdev) 17526596afd4SAlex Deucher { 17536596afd4SAlex Deucher struct evergreen_power_info *eg_pi = evergreen_get_pi(rdev); 17546596afd4SAlex Deucher struct evergreen_arb_registers *arb_registers = 17556596afd4SAlex Deucher &eg_pi->bootup_arb_registers; 17566596afd4SAlex Deucher 17576596afd4SAlex Deucher arb_registers->mc_arb_dram_timing = RREG32(MC_ARB_DRAM_TIMING); 17586596afd4SAlex Deucher arb_registers->mc_arb_dram_timing2 = RREG32(MC_ARB_DRAM_TIMING2); 17596596afd4SAlex Deucher arb_registers->mc_arb_rfsh_rate = RREG32(MC_ARB_RFSH_RATE); 17606596afd4SAlex Deucher arb_registers->mc_arb_burst_time = RREG32(MC_ARB_BURST_TIME); 17616596afd4SAlex Deucher } 17626596afd4SAlex Deucher 17636596afd4SAlex Deucher 17646596afd4SAlex Deucher static void btc_set_arb0_registers(struct radeon_device *rdev, 17656596afd4SAlex Deucher struct evergreen_arb_registers *arb_registers) 17666596afd4SAlex Deucher { 17676596afd4SAlex Deucher u32 val; 17686596afd4SAlex Deucher 17696596afd4SAlex Deucher WREG32(MC_ARB_DRAM_TIMING, arb_registers->mc_arb_dram_timing); 17706596afd4SAlex Deucher WREG32(MC_ARB_DRAM_TIMING2, arb_registers->mc_arb_dram_timing2); 17716596afd4SAlex Deucher 17726596afd4SAlex Deucher val = (arb_registers->mc_arb_rfsh_rate & POWERMODE0_MASK) >> 17736596afd4SAlex Deucher POWERMODE0_SHIFT; 17746596afd4SAlex Deucher WREG32_P(MC_ARB_RFSH_RATE, POWERMODE0(val), ~POWERMODE0_MASK); 17756596afd4SAlex Deucher 17766596afd4SAlex Deucher val = (arb_registers->mc_arb_burst_time & STATE0_MASK) >> 17776596afd4SAlex Deucher STATE0_SHIFT; 17786596afd4SAlex Deucher WREG32_P(MC_ARB_BURST_TIME, STATE0(val), ~STATE0_MASK); 17796596afd4SAlex Deucher } 17806596afd4SAlex Deucher 17816596afd4SAlex Deucher static void btc_set_boot_state_timing(struct radeon_device *rdev) 17826596afd4SAlex Deucher { 17836596afd4SAlex Deucher struct evergreen_power_info *eg_pi = evergreen_get_pi(rdev); 17846596afd4SAlex Deucher 17856596afd4SAlex Deucher if (eg_pi->ulv.supported) 17866596afd4SAlex Deucher btc_set_arb0_registers(rdev, &eg_pi->bootup_arb_registers); 17876596afd4SAlex Deucher } 17886596afd4SAlex Deucher 17896596afd4SAlex Deucher static bool btc_is_state_ulv_compatible(struct radeon_device *rdev, 17906596afd4SAlex Deucher struct radeon_ps *radeon_state) 17916596afd4SAlex Deucher { 17926596afd4SAlex Deucher struct rv7xx_ps *state = rv770_get_ps(radeon_state); 17936596afd4SAlex Deucher struct evergreen_power_info *eg_pi = evergreen_get_pi(rdev); 17946596afd4SAlex Deucher struct rv7xx_pl *ulv_pl = eg_pi->ulv.pl; 17956596afd4SAlex Deucher 17966596afd4SAlex Deucher if (state->low.mclk != ulv_pl->mclk) 17976596afd4SAlex Deucher return false; 17986596afd4SAlex Deucher 17996596afd4SAlex Deucher if (state->low.vddci != ulv_pl->vddci) 18006596afd4SAlex Deucher return false; 18016596afd4SAlex Deucher 18026596afd4SAlex Deucher /* XXX check minclocks, etc. */ 18036596afd4SAlex Deucher 18046596afd4SAlex Deucher return true; 18056596afd4SAlex Deucher } 18066596afd4SAlex Deucher 18076596afd4SAlex Deucher 18086596afd4SAlex Deucher static int btc_set_ulv_dram_timing(struct radeon_device *rdev) 18096596afd4SAlex Deucher { 18106596afd4SAlex Deucher u32 val; 18116596afd4SAlex Deucher struct evergreen_power_info *eg_pi = evergreen_get_pi(rdev); 18126596afd4SAlex Deucher struct rv7xx_pl *ulv_pl = eg_pi->ulv.pl; 18136596afd4SAlex Deucher 18146596afd4SAlex Deucher radeon_atom_set_engine_dram_timings(rdev, 18156596afd4SAlex Deucher ulv_pl->sclk, 18166596afd4SAlex Deucher ulv_pl->mclk); 18176596afd4SAlex Deucher 18186596afd4SAlex Deucher val = rv770_calculate_memory_refresh_rate(rdev, ulv_pl->sclk); 18196596afd4SAlex Deucher WREG32_P(MC_ARB_RFSH_RATE, POWERMODE0(val), ~POWERMODE0_MASK); 18206596afd4SAlex Deucher 18216596afd4SAlex Deucher val = cypress_calculate_burst_time(rdev, ulv_pl->sclk, ulv_pl->mclk); 18226596afd4SAlex Deucher WREG32_P(MC_ARB_BURST_TIME, STATE0(val), ~STATE0_MASK); 18236596afd4SAlex Deucher 18246596afd4SAlex Deucher return 0; 18256596afd4SAlex Deucher } 18266596afd4SAlex Deucher 18276596afd4SAlex Deucher static int btc_enable_ulv(struct radeon_device *rdev) 18286596afd4SAlex Deucher { 18296596afd4SAlex Deucher if (rv770_send_msg_to_smc(rdev, PPSMC_MSG_EnableULV) != PPSMC_Result_OK) 18306596afd4SAlex Deucher return -EINVAL; 18316596afd4SAlex Deucher 18326596afd4SAlex Deucher return 0; 18336596afd4SAlex Deucher } 18346596afd4SAlex Deucher 18354cb3a02fSAlex Deucher static int btc_set_power_state_conditionally_enable_ulv(struct radeon_device *rdev, 18364cb3a02fSAlex Deucher struct radeon_ps *radeon_new_state) 18376596afd4SAlex Deucher { 18386596afd4SAlex Deucher int ret = 0; 18396596afd4SAlex Deucher struct evergreen_power_info *eg_pi = evergreen_get_pi(rdev); 18406596afd4SAlex Deucher 18416596afd4SAlex Deucher if (eg_pi->ulv.supported) { 18426596afd4SAlex Deucher if (btc_is_state_ulv_compatible(rdev, radeon_new_state)) { 18436596afd4SAlex Deucher // Set ARB[0] to reflect the DRAM timing needed for ULV. 18446596afd4SAlex Deucher ret = btc_set_ulv_dram_timing(rdev); 18456596afd4SAlex Deucher if (ret == 0) 18466596afd4SAlex Deucher ret = btc_enable_ulv(rdev); 18476596afd4SAlex Deucher } 18486596afd4SAlex Deucher } 18496596afd4SAlex Deucher 18506596afd4SAlex Deucher return ret; 18516596afd4SAlex Deucher } 18526596afd4SAlex Deucher 18536596afd4SAlex Deucher static bool btc_check_s0_mc_reg_index(u16 in_reg, u16 *out_reg) 18546596afd4SAlex Deucher { 18556596afd4SAlex Deucher bool result = true; 18566596afd4SAlex Deucher 18576596afd4SAlex Deucher switch (in_reg) { 18586596afd4SAlex Deucher case MC_SEQ_RAS_TIMING >> 2: 18596596afd4SAlex Deucher *out_reg = MC_SEQ_RAS_TIMING_LP >> 2; 18606596afd4SAlex Deucher break; 18616596afd4SAlex Deucher case MC_SEQ_CAS_TIMING >> 2: 18626596afd4SAlex Deucher *out_reg = MC_SEQ_CAS_TIMING_LP >> 2; 18636596afd4SAlex Deucher break; 18646596afd4SAlex Deucher case MC_SEQ_MISC_TIMING >> 2: 18656596afd4SAlex Deucher *out_reg = MC_SEQ_MISC_TIMING_LP >> 2; 18666596afd4SAlex Deucher break; 18676596afd4SAlex Deucher case MC_SEQ_MISC_TIMING2 >> 2: 18686596afd4SAlex Deucher *out_reg = MC_SEQ_MISC_TIMING2_LP >> 2; 18696596afd4SAlex Deucher break; 18706596afd4SAlex Deucher case MC_SEQ_RD_CTL_D0 >> 2: 18716596afd4SAlex Deucher *out_reg = MC_SEQ_RD_CTL_D0_LP >> 2; 18726596afd4SAlex Deucher break; 18736596afd4SAlex Deucher case MC_SEQ_RD_CTL_D1 >> 2: 18746596afd4SAlex Deucher *out_reg = MC_SEQ_RD_CTL_D1_LP >> 2; 18756596afd4SAlex Deucher break; 18766596afd4SAlex Deucher case MC_SEQ_WR_CTL_D0 >> 2: 18776596afd4SAlex Deucher *out_reg = MC_SEQ_WR_CTL_D0_LP >> 2; 18786596afd4SAlex Deucher break; 18796596afd4SAlex Deucher case MC_SEQ_WR_CTL_D1 >> 2: 18806596afd4SAlex Deucher *out_reg = MC_SEQ_WR_CTL_D1_LP >> 2; 18816596afd4SAlex Deucher break; 18826596afd4SAlex Deucher case MC_PMG_CMD_EMRS >> 2: 18836596afd4SAlex Deucher *out_reg = MC_SEQ_PMG_CMD_EMRS_LP >> 2; 18846596afd4SAlex Deucher break; 18856596afd4SAlex Deucher case MC_PMG_CMD_MRS >> 2: 18866596afd4SAlex Deucher *out_reg = MC_SEQ_PMG_CMD_MRS_LP >> 2; 18876596afd4SAlex Deucher break; 18886596afd4SAlex Deucher case MC_PMG_CMD_MRS1 >> 2: 18896596afd4SAlex Deucher *out_reg = MC_SEQ_PMG_CMD_MRS1_LP >> 2; 18906596afd4SAlex Deucher break; 18916596afd4SAlex Deucher default: 18926596afd4SAlex Deucher result = false; 18936596afd4SAlex Deucher break; 18946596afd4SAlex Deucher } 18956596afd4SAlex Deucher 18966596afd4SAlex Deucher return result; 18976596afd4SAlex Deucher } 18986596afd4SAlex Deucher 18996596afd4SAlex Deucher static void btc_set_valid_flag(struct evergreen_mc_reg_table *table) 19006596afd4SAlex Deucher { 19016596afd4SAlex Deucher u8 i, j; 19026596afd4SAlex Deucher 19036596afd4SAlex Deucher for (i = 0; i < table->last; i++) { 19046596afd4SAlex Deucher for (j = 1; j < table->num_entries; j++) { 19056596afd4SAlex Deucher if (table->mc_reg_table_entry[j-1].mc_data[i] != 19066596afd4SAlex Deucher table->mc_reg_table_entry[j].mc_data[i]) { 19076596afd4SAlex Deucher table->valid_flag |= (1 << i); 19086596afd4SAlex Deucher break; 19096596afd4SAlex Deucher } 19106596afd4SAlex Deucher } 19116596afd4SAlex Deucher } 19126596afd4SAlex Deucher } 19136596afd4SAlex Deucher 19146596afd4SAlex Deucher static int btc_set_mc_special_registers(struct radeon_device *rdev, 19156596afd4SAlex Deucher struct evergreen_mc_reg_table *table) 19166596afd4SAlex Deucher { 19176596afd4SAlex Deucher struct rv7xx_power_info *pi = rv770_get_pi(rdev); 19186596afd4SAlex Deucher u8 i, j, k; 19196596afd4SAlex Deucher u32 tmp; 19206596afd4SAlex Deucher 19216596afd4SAlex Deucher for (i = 0, j = table->last; i < table->last; i++) { 19226596afd4SAlex Deucher switch (table->mc_reg_address[i].s1) { 19236596afd4SAlex Deucher case MC_SEQ_MISC1 >> 2: 19246596afd4SAlex Deucher tmp = RREG32(MC_PMG_CMD_EMRS); 19256596afd4SAlex Deucher table->mc_reg_address[j].s1 = MC_PMG_CMD_EMRS >> 2; 19266596afd4SAlex Deucher table->mc_reg_address[j].s0 = MC_SEQ_PMG_CMD_EMRS_LP >> 2; 19276596afd4SAlex Deucher for (k = 0; k < table->num_entries; k++) { 19286596afd4SAlex Deucher table->mc_reg_table_entry[k].mc_data[j] = 19296596afd4SAlex Deucher ((tmp & 0xffff0000)) | 19306596afd4SAlex Deucher ((table->mc_reg_table_entry[k].mc_data[i] & 0xffff0000) >> 16); 19316596afd4SAlex Deucher } 19326596afd4SAlex Deucher j++; 19336596afd4SAlex Deucher 193496d8df84SDan Carpenter if (j >= SMC_EVERGREEN_MC_REGISTER_ARRAY_SIZE) 19356596afd4SAlex Deucher return -EINVAL; 19366596afd4SAlex Deucher 19376596afd4SAlex Deucher tmp = RREG32(MC_PMG_CMD_MRS); 19386596afd4SAlex Deucher table->mc_reg_address[j].s1 = MC_PMG_CMD_MRS >> 2; 19396596afd4SAlex Deucher table->mc_reg_address[j].s0 = MC_SEQ_PMG_CMD_MRS_LP >> 2; 19406596afd4SAlex Deucher for (k = 0; k < table->num_entries; k++) { 19416596afd4SAlex Deucher table->mc_reg_table_entry[k].mc_data[j] = 19426596afd4SAlex Deucher (tmp & 0xffff0000) | 19436596afd4SAlex Deucher (table->mc_reg_table_entry[k].mc_data[i] & 0x0000ffff); 19446596afd4SAlex Deucher if (!pi->mem_gddr5) 19456596afd4SAlex Deucher table->mc_reg_table_entry[k].mc_data[j] |= 0x100; 19466596afd4SAlex Deucher } 19476596afd4SAlex Deucher j++; 19486596afd4SAlex Deucher 194996d8df84SDan Carpenter if (j >= SMC_EVERGREEN_MC_REGISTER_ARRAY_SIZE) 19506596afd4SAlex Deucher return -EINVAL; 19516596afd4SAlex Deucher break; 19526596afd4SAlex Deucher case MC_SEQ_RESERVE_M >> 2: 19536596afd4SAlex Deucher tmp = RREG32(MC_PMG_CMD_MRS1); 19546596afd4SAlex Deucher table->mc_reg_address[j].s1 = MC_PMG_CMD_MRS1 >> 2; 19556596afd4SAlex Deucher table->mc_reg_address[j].s0 = MC_SEQ_PMG_CMD_MRS1_LP >> 2; 19566596afd4SAlex Deucher for (k = 0; k < table->num_entries; k++) { 19576596afd4SAlex Deucher table->mc_reg_table_entry[k].mc_data[j] = 19586596afd4SAlex Deucher (tmp & 0xffff0000) | 19596596afd4SAlex Deucher (table->mc_reg_table_entry[k].mc_data[i] & 0x0000ffff); 19606596afd4SAlex Deucher } 19616596afd4SAlex Deucher j++; 19626596afd4SAlex Deucher 196396d8df84SDan Carpenter if (j >= SMC_EVERGREEN_MC_REGISTER_ARRAY_SIZE) 19646596afd4SAlex Deucher return -EINVAL; 19656596afd4SAlex Deucher break; 19666596afd4SAlex Deucher default: 19676596afd4SAlex Deucher break; 19686596afd4SAlex Deucher } 19696596afd4SAlex Deucher } 19706596afd4SAlex Deucher 19716596afd4SAlex Deucher table->last = j; 19726596afd4SAlex Deucher 19736596afd4SAlex Deucher return 0; 19746596afd4SAlex Deucher } 19756596afd4SAlex Deucher 19766596afd4SAlex Deucher static void btc_set_s0_mc_reg_index(struct evergreen_mc_reg_table *table) 19776596afd4SAlex Deucher { 19786596afd4SAlex Deucher u32 i; 19796596afd4SAlex Deucher u16 address; 19806596afd4SAlex Deucher 19816596afd4SAlex Deucher for (i = 0; i < table->last; i++) { 19826596afd4SAlex Deucher table->mc_reg_address[i].s0 = 19836596afd4SAlex Deucher btc_check_s0_mc_reg_index(table->mc_reg_address[i].s1, &address) ? 19846596afd4SAlex Deucher address : table->mc_reg_address[i].s1; 19856596afd4SAlex Deucher } 19866596afd4SAlex Deucher } 19876596afd4SAlex Deucher 19886596afd4SAlex Deucher static int btc_copy_vbios_mc_reg_table(struct atom_mc_reg_table *table, 19896596afd4SAlex Deucher struct evergreen_mc_reg_table *eg_table) 19906596afd4SAlex Deucher { 19916596afd4SAlex Deucher u8 i, j; 19926596afd4SAlex Deucher 19936596afd4SAlex Deucher if (table->last > SMC_EVERGREEN_MC_REGISTER_ARRAY_SIZE) 19946596afd4SAlex Deucher return -EINVAL; 19956596afd4SAlex Deucher 19966596afd4SAlex Deucher if (table->num_entries > MAX_AC_TIMING_ENTRIES) 19976596afd4SAlex Deucher return -EINVAL; 19986596afd4SAlex Deucher 19996596afd4SAlex Deucher for (i = 0; i < table->last; i++) 20006596afd4SAlex Deucher eg_table->mc_reg_address[i].s1 = table->mc_reg_address[i].s1; 20016596afd4SAlex Deucher eg_table->last = table->last; 20026596afd4SAlex Deucher 20036596afd4SAlex Deucher for (i = 0; i < table->num_entries; i++) { 20046596afd4SAlex Deucher eg_table->mc_reg_table_entry[i].mclk_max = 20056596afd4SAlex Deucher table->mc_reg_table_entry[i].mclk_max; 20066596afd4SAlex Deucher for(j = 0; j < table->last; j++) 20076596afd4SAlex Deucher eg_table->mc_reg_table_entry[i].mc_data[j] = 20086596afd4SAlex Deucher table->mc_reg_table_entry[i].mc_data[j]; 20096596afd4SAlex Deucher } 20106596afd4SAlex Deucher eg_table->num_entries = table->num_entries; 20116596afd4SAlex Deucher 20126596afd4SAlex Deucher return 0; 20136596afd4SAlex Deucher } 20146596afd4SAlex Deucher 20156596afd4SAlex Deucher static int btc_initialize_mc_reg_table(struct radeon_device *rdev) 20166596afd4SAlex Deucher { 20176596afd4SAlex Deucher int ret; 20186596afd4SAlex Deucher struct atom_mc_reg_table *table; 20196596afd4SAlex Deucher struct evergreen_power_info *eg_pi = evergreen_get_pi(rdev); 20206596afd4SAlex Deucher struct evergreen_mc_reg_table *eg_table = &eg_pi->mc_reg_table; 20216596afd4SAlex Deucher u8 module_index = rv770_get_memory_module_index(rdev); 20226596afd4SAlex Deucher 20236596afd4SAlex Deucher table = kzalloc(sizeof(struct atom_mc_reg_table), GFP_KERNEL); 20246596afd4SAlex Deucher if (!table) 20256596afd4SAlex Deucher return -ENOMEM; 20266596afd4SAlex Deucher 20276596afd4SAlex Deucher /* Program additional LP registers that are no longer programmed by VBIOS */ 20286596afd4SAlex Deucher WREG32(MC_SEQ_RAS_TIMING_LP, RREG32(MC_SEQ_RAS_TIMING)); 20296596afd4SAlex Deucher WREG32(MC_SEQ_CAS_TIMING_LP, RREG32(MC_SEQ_CAS_TIMING)); 20306596afd4SAlex Deucher WREG32(MC_SEQ_MISC_TIMING_LP, RREG32(MC_SEQ_MISC_TIMING)); 20316596afd4SAlex Deucher WREG32(MC_SEQ_MISC_TIMING2_LP, RREG32(MC_SEQ_MISC_TIMING2)); 20326596afd4SAlex Deucher WREG32(MC_SEQ_RD_CTL_D0_LP, RREG32(MC_SEQ_RD_CTL_D0)); 20336596afd4SAlex Deucher WREG32(MC_SEQ_RD_CTL_D1_LP, RREG32(MC_SEQ_RD_CTL_D1)); 20346596afd4SAlex Deucher WREG32(MC_SEQ_WR_CTL_D0_LP, RREG32(MC_SEQ_WR_CTL_D0)); 20356596afd4SAlex Deucher WREG32(MC_SEQ_WR_CTL_D1_LP, RREG32(MC_SEQ_WR_CTL_D1)); 20366596afd4SAlex Deucher WREG32(MC_SEQ_PMG_CMD_EMRS_LP, RREG32(MC_PMG_CMD_EMRS)); 20376596afd4SAlex Deucher WREG32(MC_SEQ_PMG_CMD_MRS_LP, RREG32(MC_PMG_CMD_MRS)); 20386596afd4SAlex Deucher WREG32(MC_SEQ_PMG_CMD_MRS1_LP, RREG32(MC_PMG_CMD_MRS1)); 20396596afd4SAlex Deucher 20406596afd4SAlex Deucher ret = radeon_atom_init_mc_reg_table(rdev, module_index, table); 20416596afd4SAlex Deucher 20426596afd4SAlex Deucher if (ret) 20436596afd4SAlex Deucher goto init_mc_done; 20446596afd4SAlex Deucher 20456596afd4SAlex Deucher ret = btc_copy_vbios_mc_reg_table(table, eg_table); 20466596afd4SAlex Deucher 20476596afd4SAlex Deucher if (ret) 20486596afd4SAlex Deucher goto init_mc_done; 20496596afd4SAlex Deucher 20506596afd4SAlex Deucher btc_set_s0_mc_reg_index(eg_table); 20516596afd4SAlex Deucher ret = btc_set_mc_special_registers(rdev, eg_table); 20526596afd4SAlex Deucher 20536596afd4SAlex Deucher if (ret) 20546596afd4SAlex Deucher goto init_mc_done; 20556596afd4SAlex Deucher 20566596afd4SAlex Deucher btc_set_valid_flag(eg_table); 20576596afd4SAlex Deucher 20586596afd4SAlex Deucher init_mc_done: 20596596afd4SAlex Deucher kfree(table); 20606596afd4SAlex Deucher 20616596afd4SAlex Deucher return ret; 20626596afd4SAlex Deucher } 20636596afd4SAlex Deucher 20646596afd4SAlex Deucher static void btc_init_stutter_mode(struct radeon_device *rdev) 20656596afd4SAlex Deucher { 20666596afd4SAlex Deucher struct rv7xx_power_info *pi = rv770_get_pi(rdev); 20676596afd4SAlex Deucher u32 tmp; 20686596afd4SAlex Deucher 20696596afd4SAlex Deucher if (pi->mclk_stutter_mode_threshold) { 20706596afd4SAlex Deucher if (pi->mem_gddr5) { 20716596afd4SAlex Deucher tmp = RREG32(MC_PMG_AUTO_CFG); 20726596afd4SAlex Deucher if ((0x200 & tmp) == 0) { 20736596afd4SAlex Deucher tmp = (tmp & 0xfffffc0b) | 0x204; 20746596afd4SAlex Deucher WREG32(MC_PMG_AUTO_CFG, tmp); 20756596afd4SAlex Deucher } 20766596afd4SAlex Deucher } 20776596afd4SAlex Deucher } 20786596afd4SAlex Deucher } 20796596afd4SAlex Deucher 2080a84301c6SAlex Deucher bool btc_dpm_vblank_too_short(struct radeon_device *rdev) 2081a84301c6SAlex Deucher { 2082a84301c6SAlex Deucher struct rv7xx_power_info *pi = rv770_get_pi(rdev); 2083a84301c6SAlex Deucher u32 vblank_time = r600_dpm_get_vblank_time(rdev); 2084a84301c6SAlex Deucher u32 switch_limit = pi->mem_gddr5 ? 450 : 100; 2085a84301c6SAlex Deucher 2086a84301c6SAlex Deucher if (vblank_time < switch_limit) 2087a84301c6SAlex Deucher return true; 2088a84301c6SAlex Deucher else 2089a84301c6SAlex Deucher return false; 2090a84301c6SAlex Deucher 2091a84301c6SAlex Deucher } 2092a84301c6SAlex Deucher 20934cb3a02fSAlex Deucher static void btc_apply_state_adjust_rules(struct radeon_device *rdev, 20944cb3a02fSAlex Deucher struct radeon_ps *rps) 2095d22b7e40SAlex Deucher { 2096d22b7e40SAlex Deucher struct rv7xx_ps *ps = rv770_get_ps(rps); 2097d22b7e40SAlex Deucher struct radeon_clock_and_voltage_limits *max_limits; 2098d22b7e40SAlex Deucher bool disable_mclk_switching; 2099d22b7e40SAlex Deucher u32 mclk, sclk; 2100d22b7e40SAlex Deucher u16 vddc, vddci; 21011f28fb92SAlex Deucher u32 max_sclk_vddc, max_mclk_vddci, max_mclk_vddc; 2102d22b7e40SAlex Deucher 2103a84301c6SAlex Deucher if ((rdev->pm.dpm.new_active_crtc_count > 1) || 2104a84301c6SAlex Deucher btc_dpm_vblank_too_short(rdev)) 2105d22b7e40SAlex Deucher disable_mclk_switching = true; 2106d22b7e40SAlex Deucher else 2107d22b7e40SAlex Deucher disable_mclk_switching = false; 2108d22b7e40SAlex Deucher 2109d22b7e40SAlex Deucher if (rdev->pm.dpm.ac_power) 2110d22b7e40SAlex Deucher max_limits = &rdev->pm.dpm.dyn_state.max_clock_voltage_on_ac; 2111d22b7e40SAlex Deucher else 2112d22b7e40SAlex Deucher max_limits = &rdev->pm.dpm.dyn_state.max_clock_voltage_on_dc; 2113d22b7e40SAlex Deucher 2114d22b7e40SAlex Deucher if (rdev->pm.dpm.ac_power == false) { 2115d22b7e40SAlex Deucher if (ps->high.mclk > max_limits->mclk) 2116d22b7e40SAlex Deucher ps->high.mclk = max_limits->mclk; 2117d22b7e40SAlex Deucher if (ps->high.sclk > max_limits->sclk) 2118d22b7e40SAlex Deucher ps->high.sclk = max_limits->sclk; 2119d22b7e40SAlex Deucher if (ps->high.vddc > max_limits->vddc) 2120d22b7e40SAlex Deucher ps->high.vddc = max_limits->vddc; 2121d22b7e40SAlex Deucher if (ps->high.vddci > max_limits->vddci) 2122d22b7e40SAlex Deucher ps->high.vddci = max_limits->vddci; 2123d22b7e40SAlex Deucher 2124d22b7e40SAlex Deucher if (ps->medium.mclk > max_limits->mclk) 2125d22b7e40SAlex Deucher ps->medium.mclk = max_limits->mclk; 2126d22b7e40SAlex Deucher if (ps->medium.sclk > max_limits->sclk) 2127d22b7e40SAlex Deucher ps->medium.sclk = max_limits->sclk; 2128d22b7e40SAlex Deucher if (ps->medium.vddc > max_limits->vddc) 2129d22b7e40SAlex Deucher ps->medium.vddc = max_limits->vddc; 2130d22b7e40SAlex Deucher if (ps->medium.vddci > max_limits->vddci) 2131d22b7e40SAlex Deucher ps->medium.vddci = max_limits->vddci; 2132d22b7e40SAlex Deucher 2133d22b7e40SAlex Deucher if (ps->low.mclk > max_limits->mclk) 2134d22b7e40SAlex Deucher ps->low.mclk = max_limits->mclk; 2135d22b7e40SAlex Deucher if (ps->low.sclk > max_limits->sclk) 2136d22b7e40SAlex Deucher ps->low.sclk = max_limits->sclk; 2137d22b7e40SAlex Deucher if (ps->low.vddc > max_limits->vddc) 2138d22b7e40SAlex Deucher ps->low.vddc = max_limits->vddc; 2139d22b7e40SAlex Deucher if (ps->low.vddci > max_limits->vddci) 2140d22b7e40SAlex Deucher ps->low.vddci = max_limits->vddci; 2141d22b7e40SAlex Deucher } 2142d22b7e40SAlex Deucher 21431f28fb92SAlex Deucher /* limit clocks to max supported clocks based on voltage dependency tables */ 21441f28fb92SAlex Deucher btc_get_max_clock_from_voltage_dependency_table(&rdev->pm.dpm.dyn_state.vddc_dependency_on_sclk, 21451f28fb92SAlex Deucher &max_sclk_vddc); 21461f28fb92SAlex Deucher btc_get_max_clock_from_voltage_dependency_table(&rdev->pm.dpm.dyn_state.vddci_dependency_on_mclk, 21471f28fb92SAlex Deucher &max_mclk_vddci); 21481f28fb92SAlex Deucher btc_get_max_clock_from_voltage_dependency_table(&rdev->pm.dpm.dyn_state.vddc_dependency_on_mclk, 21491f28fb92SAlex Deucher &max_mclk_vddc); 21501f28fb92SAlex Deucher 21511f28fb92SAlex Deucher if (max_sclk_vddc) { 21521f28fb92SAlex Deucher if (ps->low.sclk > max_sclk_vddc) 21531f28fb92SAlex Deucher ps->low.sclk = max_sclk_vddc; 21541f28fb92SAlex Deucher if (ps->medium.sclk > max_sclk_vddc) 21551f28fb92SAlex Deucher ps->medium.sclk = max_sclk_vddc; 21561f28fb92SAlex Deucher if (ps->high.sclk > max_sclk_vddc) 21571f28fb92SAlex Deucher ps->high.sclk = max_sclk_vddc; 21581f28fb92SAlex Deucher } 21591f28fb92SAlex Deucher if (max_mclk_vddci) { 21601f28fb92SAlex Deucher if (ps->low.mclk > max_mclk_vddci) 21611f28fb92SAlex Deucher ps->low.mclk = max_mclk_vddci; 21621f28fb92SAlex Deucher if (ps->medium.mclk > max_mclk_vddci) 21631f28fb92SAlex Deucher ps->medium.mclk = max_mclk_vddci; 21641f28fb92SAlex Deucher if (ps->high.mclk > max_mclk_vddci) 21651f28fb92SAlex Deucher ps->high.mclk = max_mclk_vddci; 21661f28fb92SAlex Deucher } 21671f28fb92SAlex Deucher if (max_mclk_vddc) { 21681f28fb92SAlex Deucher if (ps->low.mclk > max_mclk_vddc) 21691f28fb92SAlex Deucher ps->low.mclk = max_mclk_vddc; 21701f28fb92SAlex Deucher if (ps->medium.mclk > max_mclk_vddc) 21711f28fb92SAlex Deucher ps->medium.mclk = max_mclk_vddc; 21721f28fb92SAlex Deucher if (ps->high.mclk > max_mclk_vddc) 21731f28fb92SAlex Deucher ps->high.mclk = max_mclk_vddc; 21741f28fb92SAlex Deucher } 21751f28fb92SAlex Deucher 2176d22b7e40SAlex Deucher /* XXX validate the min clocks required for display */ 2177d22b7e40SAlex Deucher 2178d22b7e40SAlex Deucher if (disable_mclk_switching) { 2179d22b7e40SAlex Deucher sclk = ps->low.sclk; 2180d22b7e40SAlex Deucher mclk = ps->high.mclk; 2181d22b7e40SAlex Deucher vddc = ps->low.vddc; 2182d22b7e40SAlex Deucher vddci = ps->high.vddci; 2183d22b7e40SAlex Deucher } else { 2184d22b7e40SAlex Deucher sclk = ps->low.sclk; 2185d22b7e40SAlex Deucher mclk = ps->low.mclk; 2186d22b7e40SAlex Deucher vddc = ps->low.vddc; 2187d22b7e40SAlex Deucher vddci = ps->low.vddci; 2188d22b7e40SAlex Deucher } 2189d22b7e40SAlex Deucher 2190d22b7e40SAlex Deucher /* adjusted low state */ 2191d22b7e40SAlex Deucher ps->low.sclk = sclk; 2192d22b7e40SAlex Deucher ps->low.mclk = mclk; 2193d22b7e40SAlex Deucher ps->low.vddc = vddc; 2194d22b7e40SAlex Deucher ps->low.vddci = vddci; 2195d22b7e40SAlex Deucher 2196d22b7e40SAlex Deucher btc_skip_blacklist_clocks(rdev, max_limits->sclk, max_limits->mclk, 2197d22b7e40SAlex Deucher &ps->low.sclk, &ps->low.mclk); 2198d22b7e40SAlex Deucher 2199d22b7e40SAlex Deucher /* adjusted medium, high states */ 2200d22b7e40SAlex Deucher if (ps->medium.sclk < ps->low.sclk) 2201d22b7e40SAlex Deucher ps->medium.sclk = ps->low.sclk; 2202d22b7e40SAlex Deucher if (ps->medium.vddc < ps->low.vddc) 2203d22b7e40SAlex Deucher ps->medium.vddc = ps->low.vddc; 2204d22b7e40SAlex Deucher if (ps->high.sclk < ps->medium.sclk) 2205d22b7e40SAlex Deucher ps->high.sclk = ps->medium.sclk; 2206d22b7e40SAlex Deucher if (ps->high.vddc < ps->medium.vddc) 2207d22b7e40SAlex Deucher ps->high.vddc = ps->medium.vddc; 2208d22b7e40SAlex Deucher 2209d22b7e40SAlex Deucher if (disable_mclk_switching) { 2210d22b7e40SAlex Deucher mclk = ps->low.mclk; 2211d22b7e40SAlex Deucher if (mclk < ps->medium.mclk) 2212d22b7e40SAlex Deucher mclk = ps->medium.mclk; 2213d22b7e40SAlex Deucher if (mclk < ps->high.mclk) 2214d22b7e40SAlex Deucher mclk = ps->high.mclk; 2215d22b7e40SAlex Deucher ps->low.mclk = mclk; 2216d22b7e40SAlex Deucher ps->low.vddci = vddci; 2217d22b7e40SAlex Deucher ps->medium.mclk = mclk; 2218d22b7e40SAlex Deucher ps->medium.vddci = vddci; 2219d22b7e40SAlex Deucher ps->high.mclk = mclk; 2220d22b7e40SAlex Deucher ps->high.vddci = vddci; 2221d22b7e40SAlex Deucher } else { 2222d22b7e40SAlex Deucher if (ps->medium.mclk < ps->low.mclk) 2223d22b7e40SAlex Deucher ps->medium.mclk = ps->low.mclk; 2224d22b7e40SAlex Deucher if (ps->medium.vddci < ps->low.vddci) 2225d22b7e40SAlex Deucher ps->medium.vddci = ps->low.vddci; 2226d22b7e40SAlex Deucher if (ps->high.mclk < ps->medium.mclk) 2227d22b7e40SAlex Deucher ps->high.mclk = ps->medium.mclk; 2228d22b7e40SAlex Deucher if (ps->high.vddci < ps->medium.vddci) 2229d22b7e40SAlex Deucher ps->high.vddci = ps->medium.vddci; 2230d22b7e40SAlex Deucher } 2231d22b7e40SAlex Deucher 2232d22b7e40SAlex Deucher btc_skip_blacklist_clocks(rdev, max_limits->sclk, max_limits->mclk, 2233d22b7e40SAlex Deucher &ps->medium.sclk, &ps->medium.mclk); 2234d22b7e40SAlex Deucher btc_skip_blacklist_clocks(rdev, max_limits->sclk, max_limits->mclk, 2235d22b7e40SAlex Deucher &ps->high.sclk, &ps->high.mclk); 2236d22b7e40SAlex Deucher 2237d22b7e40SAlex Deucher btc_adjust_clock_combinations(rdev, max_limits, &ps->low); 2238d22b7e40SAlex Deucher btc_adjust_clock_combinations(rdev, max_limits, &ps->medium); 2239d22b7e40SAlex Deucher btc_adjust_clock_combinations(rdev, max_limits, &ps->high); 2240d22b7e40SAlex Deucher 2241d22b7e40SAlex Deucher btc_apply_voltage_dependency_rules(&rdev->pm.dpm.dyn_state.vddc_dependency_on_sclk, 2242d22b7e40SAlex Deucher ps->low.sclk, max_limits->vddc, &ps->low.vddc); 2243d22b7e40SAlex Deucher btc_apply_voltage_dependency_rules(&rdev->pm.dpm.dyn_state.vddci_dependency_on_mclk, 2244d22b7e40SAlex Deucher ps->low.mclk, max_limits->vddci, &ps->low.vddci); 2245d22b7e40SAlex Deucher btc_apply_voltage_dependency_rules(&rdev->pm.dpm.dyn_state.vddc_dependency_on_mclk, 2246d22b7e40SAlex Deucher ps->low.mclk, max_limits->vddc, &ps->low.vddc); 22474489cd62SAlex Deucher btc_apply_voltage_dependency_rules(&rdev->pm.dpm.dyn_state.vddc_dependency_on_dispclk, 22484489cd62SAlex Deucher rdev->clock.current_dispclk, max_limits->vddc, &ps->low.vddc); 22494489cd62SAlex Deucher 2250d22b7e40SAlex Deucher btc_apply_voltage_dependency_rules(&rdev->pm.dpm.dyn_state.vddc_dependency_on_sclk, 2251d22b7e40SAlex Deucher ps->medium.sclk, max_limits->vddc, &ps->medium.vddc); 2252d22b7e40SAlex Deucher btc_apply_voltage_dependency_rules(&rdev->pm.dpm.dyn_state.vddci_dependency_on_mclk, 2253d22b7e40SAlex Deucher ps->medium.mclk, max_limits->vddci, &ps->medium.vddci); 2254d22b7e40SAlex Deucher btc_apply_voltage_dependency_rules(&rdev->pm.dpm.dyn_state.vddc_dependency_on_mclk, 2255d22b7e40SAlex Deucher ps->medium.mclk, max_limits->vddc, &ps->medium.vddc); 22564489cd62SAlex Deucher btc_apply_voltage_dependency_rules(&rdev->pm.dpm.dyn_state.vddc_dependency_on_dispclk, 22574489cd62SAlex Deucher rdev->clock.current_dispclk, max_limits->vddc, &ps->medium.vddc); 22584489cd62SAlex Deucher 2259d22b7e40SAlex Deucher btc_apply_voltage_dependency_rules(&rdev->pm.dpm.dyn_state.vddc_dependency_on_sclk, 2260d22b7e40SAlex Deucher ps->high.sclk, max_limits->vddc, &ps->high.vddc); 2261d22b7e40SAlex Deucher btc_apply_voltage_dependency_rules(&rdev->pm.dpm.dyn_state.vddci_dependency_on_mclk, 2262d22b7e40SAlex Deucher ps->high.mclk, max_limits->vddci, &ps->high.vddci); 2263d22b7e40SAlex Deucher btc_apply_voltage_dependency_rules(&rdev->pm.dpm.dyn_state.vddc_dependency_on_mclk, 2264d22b7e40SAlex Deucher ps->high.mclk, max_limits->vddc, &ps->high.vddc); 22654489cd62SAlex Deucher btc_apply_voltage_dependency_rules(&rdev->pm.dpm.dyn_state.vddc_dependency_on_dispclk, 22664489cd62SAlex Deucher rdev->clock.current_dispclk, max_limits->vddc, &ps->high.vddc); 2267d22b7e40SAlex Deucher 2268d22b7e40SAlex Deucher btc_apply_voltage_delta_rules(rdev, max_limits->vddc, max_limits->vddci, 2269d22b7e40SAlex Deucher &ps->low.vddc, &ps->low.vddci); 2270d22b7e40SAlex Deucher btc_apply_voltage_delta_rules(rdev, max_limits->vddc, max_limits->vddci, 2271d22b7e40SAlex Deucher &ps->medium.vddc, &ps->medium.vddci); 2272d22b7e40SAlex Deucher btc_apply_voltage_delta_rules(rdev, max_limits->vddc, max_limits->vddci, 2273d22b7e40SAlex Deucher &ps->high.vddc, &ps->high.vddci); 2274d22b7e40SAlex Deucher 2275d22b7e40SAlex Deucher if ((ps->high.vddc <= rdev->pm.dpm.dyn_state.max_clock_voltage_on_dc.vddc) && 2276d22b7e40SAlex Deucher (ps->medium.vddc <= rdev->pm.dpm.dyn_state.max_clock_voltage_on_dc.vddc) && 2277d22b7e40SAlex Deucher (ps->low.vddc <= rdev->pm.dpm.dyn_state.max_clock_voltage_on_dc.vddc)) 2278d22b7e40SAlex Deucher ps->dc_compatible = true; 2279d22b7e40SAlex Deucher else 2280d22b7e40SAlex Deucher ps->dc_compatible = false; 2281d22b7e40SAlex Deucher 2282d22b7e40SAlex Deucher if (ps->low.vddc < rdev->pm.dpm.dyn_state.min_vddc_for_pcie_gen2) 2283d22b7e40SAlex Deucher ps->low.flags &= ~ATOM_PPLIB_R600_FLAGS_PCIEGEN2; 2284d22b7e40SAlex Deucher if (ps->medium.vddc < rdev->pm.dpm.dyn_state.min_vddc_for_pcie_gen2) 2285d22b7e40SAlex Deucher ps->medium.flags &= ~ATOM_PPLIB_R600_FLAGS_PCIEGEN2; 2286d22b7e40SAlex Deucher if (ps->high.vddc < rdev->pm.dpm.dyn_state.min_vddc_for_pcie_gen2) 2287d22b7e40SAlex Deucher ps->high.flags &= ~ATOM_PPLIB_R600_FLAGS_PCIEGEN2; 2288d22b7e40SAlex Deucher } 2289d22b7e40SAlex Deucher 2290e8a9539fSAlex Deucher static void btc_update_current_ps(struct radeon_device *rdev, 2291e8a9539fSAlex Deucher struct radeon_ps *rps) 2292e8a9539fSAlex Deucher { 2293e8a9539fSAlex Deucher struct rv7xx_ps *new_ps = rv770_get_ps(rps); 2294e8a9539fSAlex Deucher struct evergreen_power_info *eg_pi = evergreen_get_pi(rdev); 2295e8a9539fSAlex Deucher 2296e8a9539fSAlex Deucher eg_pi->current_rps = *rps; 2297e8a9539fSAlex Deucher eg_pi->current_ps = *new_ps; 2298e8a9539fSAlex Deucher eg_pi->current_rps.ps_priv = &eg_pi->current_ps; 2299e8a9539fSAlex Deucher } 2300e8a9539fSAlex Deucher 2301e8a9539fSAlex Deucher static void btc_update_requested_ps(struct radeon_device *rdev, 2302e8a9539fSAlex Deucher struct radeon_ps *rps) 2303e8a9539fSAlex Deucher { 2304e8a9539fSAlex Deucher struct rv7xx_ps *new_ps = rv770_get_ps(rps); 2305e8a9539fSAlex Deucher struct evergreen_power_info *eg_pi = evergreen_get_pi(rdev); 2306e8a9539fSAlex Deucher 2307e8a9539fSAlex Deucher eg_pi->requested_rps = *rps; 2308e8a9539fSAlex Deucher eg_pi->requested_ps = *new_ps; 2309e8a9539fSAlex Deucher eg_pi->requested_rps.ps_priv = &eg_pi->requested_ps; 2310e8a9539fSAlex Deucher } 2311e8a9539fSAlex Deucher 23126596afd4SAlex Deucher void btc_dpm_reset_asic(struct radeon_device *rdev) 23136596afd4SAlex Deucher { 23146596afd4SAlex Deucher rv770_restrict_performance_levels_before_switch(rdev); 23156596afd4SAlex Deucher btc_disable_ulv(rdev); 23166596afd4SAlex Deucher btc_set_boot_state_timing(rdev); 23176596afd4SAlex Deucher rv770_set_boot_state(rdev); 23186596afd4SAlex Deucher } 23196596afd4SAlex Deucher 2320e8a9539fSAlex Deucher int btc_dpm_pre_set_power_state(struct radeon_device *rdev) 2321e8a9539fSAlex Deucher { 2322e8a9539fSAlex Deucher struct evergreen_power_info *eg_pi = evergreen_get_pi(rdev); 2323e8a9539fSAlex Deucher struct radeon_ps requested_ps = *rdev->pm.dpm.requested_ps; 2324e8a9539fSAlex Deucher struct radeon_ps *new_ps = &requested_ps; 2325e8a9539fSAlex Deucher 2326e8a9539fSAlex Deucher btc_update_requested_ps(rdev, new_ps); 2327e8a9539fSAlex Deucher 2328e8a9539fSAlex Deucher btc_apply_state_adjust_rules(rdev, &eg_pi->requested_rps); 2329e8a9539fSAlex Deucher 2330e8a9539fSAlex Deucher return 0; 2331e8a9539fSAlex Deucher } 2332e8a9539fSAlex Deucher 23336596afd4SAlex Deucher int btc_dpm_set_power_state(struct radeon_device *rdev) 23346596afd4SAlex Deucher { 23356596afd4SAlex Deucher struct evergreen_power_info *eg_pi = evergreen_get_pi(rdev); 2336e8a9539fSAlex Deucher struct radeon_ps *new_ps = &eg_pi->requested_rps; 2337e8a9539fSAlex Deucher struct radeon_ps *old_ps = &eg_pi->current_rps; 2338aafb3afaSAlex Deucher int ret; 2339d22b7e40SAlex Deucher 2340aafb3afaSAlex Deucher ret = btc_disable_ulv(rdev); 23416596afd4SAlex Deucher btc_set_boot_state_timing(rdev); 2342aafb3afaSAlex Deucher ret = rv770_restrict_performance_levels_before_switch(rdev); 234372dd2c54SAlex Deucher if (ret) { 234472dd2c54SAlex Deucher DRM_ERROR("rv770_restrict_performance_levels_before_switch failed\n"); 2345aafb3afaSAlex Deucher return ret; 234672dd2c54SAlex Deucher } 23476596afd4SAlex Deucher if (eg_pi->pcie_performance_request) 2348dbc34160SAlex Deucher cypress_notify_link_speed_change_before_state_change(rdev, new_ps, old_ps); 23496596afd4SAlex Deucher 23505d77d776SAlex Deucher rv770_set_uvd_clock_before_set_eng_clock(rdev, new_ps, old_ps); 2351aafb3afaSAlex Deucher ret = rv770_halt_smc(rdev); 235272dd2c54SAlex Deucher if (ret) { 235372dd2c54SAlex Deucher DRM_ERROR("rv770_halt_smc failed\n"); 2354aafb3afaSAlex Deucher return ret; 235572dd2c54SAlex Deucher } 23564cb3a02fSAlex Deucher btc_set_at_for_uvd(rdev, new_ps); 2357f85392bcSAlex Deucher if (eg_pi->smu_uvd_hs) 23584cb3a02fSAlex Deucher btc_notify_uvd_to_smc(rdev, new_ps); 2359aafb3afaSAlex Deucher ret = cypress_upload_sw_state(rdev, new_ps); 236072dd2c54SAlex Deucher if (ret) { 236172dd2c54SAlex Deucher DRM_ERROR("cypress_upload_sw_state failed\n"); 2362aafb3afaSAlex Deucher return ret; 236372dd2c54SAlex Deucher } 2364aafb3afaSAlex Deucher if (eg_pi->dynamic_ac_timing) { 2365aafb3afaSAlex Deucher ret = cypress_upload_mc_reg_table(rdev, new_ps); 236672dd2c54SAlex Deucher if (ret) { 236772dd2c54SAlex Deucher DRM_ERROR("cypress_upload_mc_reg_table failed\n"); 2368aafb3afaSAlex Deucher return ret; 2369aafb3afaSAlex Deucher } 237072dd2c54SAlex Deucher } 23716596afd4SAlex Deucher 2372dbc34160SAlex Deucher cypress_program_memory_timing_parameters(rdev, new_ps); 23736596afd4SAlex Deucher 2374aafb3afaSAlex Deucher ret = rv770_resume_smc(rdev); 237572dd2c54SAlex Deucher if (ret) { 237672dd2c54SAlex Deucher DRM_ERROR("rv770_resume_smc failed\n"); 2377aafb3afaSAlex Deucher return ret; 237872dd2c54SAlex Deucher } 2379aafb3afaSAlex Deucher ret = rv770_set_sw_state(rdev); 238072dd2c54SAlex Deucher if (ret) { 238172dd2c54SAlex Deucher DRM_ERROR("rv770_set_sw_state failed\n"); 2382aafb3afaSAlex Deucher return ret; 238372dd2c54SAlex Deucher } 23845d77d776SAlex Deucher rv770_set_uvd_clock_after_set_eng_clock(rdev, new_ps, old_ps); 23856596afd4SAlex Deucher 23866596afd4SAlex Deucher if (eg_pi->pcie_performance_request) 2387dbc34160SAlex Deucher cypress_notify_link_speed_change_after_state_change(rdev, new_ps, old_ps); 23886596afd4SAlex Deucher 2389aafb3afaSAlex Deucher ret = btc_set_power_state_conditionally_enable_ulv(rdev, new_ps); 239072dd2c54SAlex Deucher if (ret) { 239172dd2c54SAlex Deucher DRM_ERROR("btc_set_power_state_conditionally_enable_ulv failed\n"); 2392aafb3afaSAlex Deucher return ret; 239372dd2c54SAlex Deucher } 23946596afd4SAlex Deucher 23956596afd4SAlex Deucher return 0; 23966596afd4SAlex Deucher } 23976596afd4SAlex Deucher 2398e8a9539fSAlex Deucher void btc_dpm_post_set_power_state(struct radeon_device *rdev) 2399e8a9539fSAlex Deucher { 2400e8a9539fSAlex Deucher struct evergreen_power_info *eg_pi = evergreen_get_pi(rdev); 2401e8a9539fSAlex Deucher struct radeon_ps *new_ps = &eg_pi->requested_rps; 2402e8a9539fSAlex Deucher 2403e8a9539fSAlex Deucher btc_update_current_ps(rdev, new_ps); 2404e8a9539fSAlex Deucher } 2405e8a9539fSAlex Deucher 24066596afd4SAlex Deucher int btc_dpm_enable(struct radeon_device *rdev) 24076596afd4SAlex Deucher { 24086596afd4SAlex Deucher struct rv7xx_power_info *pi = rv770_get_pi(rdev); 24096596afd4SAlex Deucher struct evergreen_power_info *eg_pi = evergreen_get_pi(rdev); 2410dbc34160SAlex Deucher struct radeon_ps *boot_ps = rdev->pm.dpm.boot_ps; 2411aafb3afaSAlex Deucher int ret; 24126596afd4SAlex Deucher 24136596afd4SAlex Deucher if (pi->gfx_clock_gating) 24146596afd4SAlex Deucher btc_cg_clock_gating_default(rdev); 24156596afd4SAlex Deucher 24166596afd4SAlex Deucher if (btc_dpm_enabled(rdev)) 24176596afd4SAlex Deucher return -EINVAL; 24186596afd4SAlex Deucher 24196596afd4SAlex Deucher if (pi->mg_clock_gating) 24206596afd4SAlex Deucher btc_mg_clock_gating_default(rdev); 24216596afd4SAlex Deucher 24226596afd4SAlex Deucher if (eg_pi->ls_clock_gating) 24236596afd4SAlex Deucher btc_ls_clock_gating_default(rdev); 24246596afd4SAlex Deucher 24256596afd4SAlex Deucher if (pi->voltage_control) { 24266596afd4SAlex Deucher rv770_enable_voltage_control(rdev, true); 2427aafb3afaSAlex Deucher ret = cypress_construct_voltage_tables(rdev); 2428fa4b5471SAlex Deucher if (ret) { 2429fa4b5471SAlex Deucher DRM_ERROR("cypress_construct_voltage_tables failed\n"); 2430aafb3afaSAlex Deucher return ret; 24316596afd4SAlex Deucher } 2432fa4b5471SAlex Deucher } 24336596afd4SAlex Deucher 2434aafb3afaSAlex Deucher if (pi->mvdd_control) { 2435aafb3afaSAlex Deucher ret = cypress_get_mvdd_configuration(rdev); 2436fa4b5471SAlex Deucher if (ret) { 2437fa4b5471SAlex Deucher DRM_ERROR("cypress_get_mvdd_configuration failed\n"); 2438aafb3afaSAlex Deucher return ret; 2439aafb3afaSAlex Deucher } 2440fa4b5471SAlex Deucher } 24416596afd4SAlex Deucher 2442aafb3afaSAlex Deucher if (eg_pi->dynamic_ac_timing) { 2443aafb3afaSAlex Deucher ret = btc_initialize_mc_reg_table(rdev); 2444aafb3afaSAlex Deucher if (ret) 2445aafb3afaSAlex Deucher eg_pi->dynamic_ac_timing = false; 2446aafb3afaSAlex Deucher } 24476596afd4SAlex Deucher 24486596afd4SAlex Deucher if (rdev->pm.dpm.platform_caps & ATOM_PP_PLATFORM_CAP_BACKBIAS) 24496596afd4SAlex Deucher rv770_enable_backbias(rdev, true); 24506596afd4SAlex Deucher 24516596afd4SAlex Deucher if (pi->dynamic_ss) 24526596afd4SAlex Deucher cypress_enable_spread_spectrum(rdev, true); 24536596afd4SAlex Deucher 24546596afd4SAlex Deucher if (pi->thermal_protection) 24556596afd4SAlex Deucher rv770_enable_thermal_protection(rdev, true); 24566596afd4SAlex Deucher 24576596afd4SAlex Deucher rv770_setup_bsp(rdev); 24586596afd4SAlex Deucher rv770_program_git(rdev); 24596596afd4SAlex Deucher rv770_program_tp(rdev); 24606596afd4SAlex Deucher rv770_program_tpp(rdev); 24616596afd4SAlex Deucher rv770_program_sstp(rdev); 24626596afd4SAlex Deucher rv770_program_engine_speed_parameters(rdev); 24636596afd4SAlex Deucher cypress_enable_display_gap(rdev); 24646596afd4SAlex Deucher rv770_program_vc(rdev); 24656596afd4SAlex Deucher 24666596afd4SAlex Deucher if (pi->dynamic_pcie_gen2) 24676596afd4SAlex Deucher btc_enable_dynamic_pcie_gen2(rdev, true); 24686596afd4SAlex Deucher 2469aafb3afaSAlex Deucher ret = rv770_upload_firmware(rdev); 2470fa4b5471SAlex Deucher if (ret) { 2471fa4b5471SAlex Deucher DRM_ERROR("rv770_upload_firmware failed\n"); 2472aafb3afaSAlex Deucher return ret; 2473fa4b5471SAlex Deucher } 2474aafb3afaSAlex Deucher ret = cypress_get_table_locations(rdev); 2475fa4b5471SAlex Deucher if (ret) { 2476fa4b5471SAlex Deucher DRM_ERROR("cypress_get_table_locations failed\n"); 2477aafb3afaSAlex Deucher return ret; 2478fa4b5471SAlex Deucher } 2479aafb3afaSAlex Deucher ret = btc_init_smc_table(rdev, boot_ps); 2480aafb3afaSAlex Deucher if (ret) 2481aafb3afaSAlex Deucher return ret; 24826596afd4SAlex Deucher 2483aafb3afaSAlex Deucher if (eg_pi->dynamic_ac_timing) { 2484aafb3afaSAlex Deucher ret = cypress_populate_mc_reg_table(rdev, boot_ps); 2485fa4b5471SAlex Deucher if (ret) { 2486fa4b5471SAlex Deucher DRM_ERROR("cypress_populate_mc_reg_table failed\n"); 2487aafb3afaSAlex Deucher return ret; 2488aafb3afaSAlex Deucher } 2489fa4b5471SAlex Deucher } 24906596afd4SAlex Deucher 24916596afd4SAlex Deucher cypress_program_response_times(rdev); 24926596afd4SAlex Deucher r7xx_start_smc(rdev); 2493aafb3afaSAlex Deucher ret = cypress_notify_smc_display_change(rdev, false); 2494fa4b5471SAlex Deucher if (ret) { 2495fa4b5471SAlex Deucher DRM_ERROR("cypress_notify_smc_display_change failed\n"); 2496aafb3afaSAlex Deucher return ret; 2497fa4b5471SAlex Deucher } 24986596afd4SAlex Deucher cypress_enable_sclk_control(rdev, true); 24996596afd4SAlex Deucher 25006596afd4SAlex Deucher if (eg_pi->memory_transition) 25016596afd4SAlex Deucher cypress_enable_mclk_control(rdev, true); 25026596afd4SAlex Deucher 25036596afd4SAlex Deucher cypress_start_dpm(rdev); 25046596afd4SAlex Deucher 25056596afd4SAlex Deucher if (pi->gfx_clock_gating) 25066596afd4SAlex Deucher btc_cg_clock_gating_enable(rdev, true); 25076596afd4SAlex Deucher 25086596afd4SAlex Deucher if (pi->mg_clock_gating) 25096596afd4SAlex Deucher btc_mg_clock_gating_enable(rdev, true); 25106596afd4SAlex Deucher 25116596afd4SAlex Deucher if (eg_pi->ls_clock_gating) 25126596afd4SAlex Deucher btc_ls_clock_gating_enable(rdev, true); 25136596afd4SAlex Deucher 25146596afd4SAlex Deucher rv770_enable_auto_throttle_source(rdev, RADEON_DPM_AUTO_THROTTLE_SRC_THERMAL, true); 25156596afd4SAlex Deucher 25166596afd4SAlex Deucher btc_init_stutter_mode(rdev); 25176596afd4SAlex Deucher 2518e8a9539fSAlex Deucher btc_update_current_ps(rdev, rdev->pm.dpm.boot_ps); 2519e8a9539fSAlex Deucher 25206596afd4SAlex Deucher return 0; 25216596afd4SAlex Deucher }; 25226596afd4SAlex Deucher 25236596afd4SAlex Deucher void btc_dpm_disable(struct radeon_device *rdev) 25246596afd4SAlex Deucher { 25256596afd4SAlex Deucher struct rv7xx_power_info *pi = rv770_get_pi(rdev); 25266596afd4SAlex Deucher struct evergreen_power_info *eg_pi = evergreen_get_pi(rdev); 25276596afd4SAlex Deucher 25286596afd4SAlex Deucher if (!btc_dpm_enabled(rdev)) 25296596afd4SAlex Deucher return; 25306596afd4SAlex Deucher 25316596afd4SAlex Deucher rv770_clear_vc(rdev); 25326596afd4SAlex Deucher 25336596afd4SAlex Deucher if (pi->thermal_protection) 25346596afd4SAlex Deucher rv770_enable_thermal_protection(rdev, false); 25356596afd4SAlex Deucher 25366596afd4SAlex Deucher if (pi->dynamic_pcie_gen2) 25376596afd4SAlex Deucher btc_enable_dynamic_pcie_gen2(rdev, false); 25386596afd4SAlex Deucher 25396596afd4SAlex Deucher if (rdev->irq.installed && 25406596afd4SAlex Deucher r600_is_internal_thermal_sensor(rdev->pm.int_thermal_type)) { 25416596afd4SAlex Deucher rdev->irq.dpm_thermal = false; 25426596afd4SAlex Deucher radeon_irq_set(rdev); 25436596afd4SAlex Deucher } 25446596afd4SAlex Deucher 25456596afd4SAlex Deucher if (pi->gfx_clock_gating) 25466596afd4SAlex Deucher btc_cg_clock_gating_enable(rdev, false); 25476596afd4SAlex Deucher 25486596afd4SAlex Deucher if (pi->mg_clock_gating) 25496596afd4SAlex Deucher btc_mg_clock_gating_enable(rdev, false); 25506596afd4SAlex Deucher 25516596afd4SAlex Deucher if (eg_pi->ls_clock_gating) 25526596afd4SAlex Deucher btc_ls_clock_gating_enable(rdev, false); 25536596afd4SAlex Deucher 25546596afd4SAlex Deucher rv770_stop_dpm(rdev); 25556596afd4SAlex Deucher btc_reset_to_default(rdev); 25566596afd4SAlex Deucher btc_stop_smc(rdev); 25576596afd4SAlex Deucher cypress_enable_spread_spectrum(rdev, false); 2558e8a9539fSAlex Deucher 2559e8a9539fSAlex Deucher btc_update_current_ps(rdev, rdev->pm.dpm.boot_ps); 25606596afd4SAlex Deucher } 25616596afd4SAlex Deucher 25626596afd4SAlex Deucher void btc_dpm_setup_asic(struct radeon_device *rdev) 25636596afd4SAlex Deucher { 25646596afd4SAlex Deucher struct evergreen_power_info *eg_pi = evergreen_get_pi(rdev); 2565*6c7bcceaSAlex Deucher int r; 25666596afd4SAlex Deucher 2567*6c7bcceaSAlex Deucher r = ni_mc_load_microcode(rdev); 2568*6c7bcceaSAlex Deucher if (r) 2569*6c7bcceaSAlex Deucher DRM_ERROR("Failed to load MC firmware!\n"); 25706596afd4SAlex Deucher rv770_get_memory_type(rdev); 25716596afd4SAlex Deucher rv740_read_clock_registers(rdev); 25726596afd4SAlex Deucher btc_read_arb_registers(rdev); 25736596afd4SAlex Deucher rv770_read_voltage_smio_registers(rdev); 25746596afd4SAlex Deucher 25756596afd4SAlex Deucher if (eg_pi->pcie_performance_request) 25766596afd4SAlex Deucher cypress_advertise_gen2_capability(rdev); 25776596afd4SAlex Deucher 25786596afd4SAlex Deucher rv770_get_pcie_gen2_status(rdev); 25796596afd4SAlex Deucher rv770_enable_acpi_pm(rdev); 25806596afd4SAlex Deucher } 25816596afd4SAlex Deucher 25826596afd4SAlex Deucher int btc_dpm_init(struct radeon_device *rdev) 25836596afd4SAlex Deucher { 25846596afd4SAlex Deucher struct rv7xx_power_info *pi; 25856596afd4SAlex Deucher struct evergreen_power_info *eg_pi; 25866596afd4SAlex Deucher struct atom_clock_dividers dividers; 25876596afd4SAlex Deucher int ret; 25886596afd4SAlex Deucher 25896596afd4SAlex Deucher eg_pi = kzalloc(sizeof(struct evergreen_power_info), GFP_KERNEL); 25906596afd4SAlex Deucher if (eg_pi == NULL) 25916596afd4SAlex Deucher return -ENOMEM; 25926596afd4SAlex Deucher rdev->pm.dpm.priv = eg_pi; 25936596afd4SAlex Deucher pi = &eg_pi->rv7xx; 25946596afd4SAlex Deucher 25956596afd4SAlex Deucher rv770_get_max_vddc(rdev); 25966596afd4SAlex Deucher 25976596afd4SAlex Deucher eg_pi->ulv.supported = false; 25986596afd4SAlex Deucher pi->acpi_vddc = 0; 25996596afd4SAlex Deucher eg_pi->acpi_vddci = 0; 26006596afd4SAlex Deucher pi->min_vddc_in_table = 0; 26016596afd4SAlex Deucher pi->max_vddc_in_table = 0; 26026596afd4SAlex Deucher 26036596afd4SAlex Deucher ret = rv7xx_parse_power_table(rdev); 26046596afd4SAlex Deucher if (ret) 26056596afd4SAlex Deucher return ret; 2606d22b7e40SAlex Deucher ret = r600_parse_extended_power_table(rdev); 2607d22b7e40SAlex Deucher if (ret) 2608d22b7e40SAlex Deucher return ret; 26096596afd4SAlex Deucher 26104489cd62SAlex Deucher rdev->pm.dpm.dyn_state.vddc_dependency_on_dispclk.entries = 26114489cd62SAlex Deucher kzalloc(4 * sizeof(struct radeon_clock_voltage_dependency_entry), GFP_KERNEL); 26124489cd62SAlex Deucher if (!rdev->pm.dpm.dyn_state.vddc_dependency_on_dispclk.entries) { 26134489cd62SAlex Deucher r600_free_extended_power_table(rdev); 26144489cd62SAlex Deucher return -ENOMEM; 26154489cd62SAlex Deucher } 26164489cd62SAlex Deucher rdev->pm.dpm.dyn_state.vddc_dependency_on_dispclk.count = 4; 26174489cd62SAlex Deucher rdev->pm.dpm.dyn_state.vddc_dependency_on_dispclk.entries[0].clk = 0; 26184489cd62SAlex Deucher rdev->pm.dpm.dyn_state.vddc_dependency_on_dispclk.entries[0].v = 0; 26194489cd62SAlex Deucher rdev->pm.dpm.dyn_state.vddc_dependency_on_dispclk.entries[1].clk = 36000; 26204489cd62SAlex Deucher rdev->pm.dpm.dyn_state.vddc_dependency_on_dispclk.entries[1].v = 800; 26214489cd62SAlex Deucher rdev->pm.dpm.dyn_state.vddc_dependency_on_dispclk.entries[2].clk = 54000; 26224489cd62SAlex Deucher rdev->pm.dpm.dyn_state.vddc_dependency_on_dispclk.entries[2].v = 800; 26234489cd62SAlex Deucher rdev->pm.dpm.dyn_state.vddc_dependency_on_dispclk.entries[3].clk = 72000; 26244489cd62SAlex Deucher rdev->pm.dpm.dyn_state.vddc_dependency_on_dispclk.entries[3].v = 800; 26254489cd62SAlex Deucher 26266596afd4SAlex Deucher if (rdev->pm.dpm.voltage_response_time == 0) 26276596afd4SAlex Deucher rdev->pm.dpm.voltage_response_time = R600_VOLTAGERESPONSETIME_DFLT; 26286596afd4SAlex Deucher if (rdev->pm.dpm.backbias_response_time == 0) 26296596afd4SAlex Deucher rdev->pm.dpm.backbias_response_time = R600_BACKBIASRESPONSETIME_DFLT; 26306596afd4SAlex Deucher 26316596afd4SAlex Deucher ret = radeon_atom_get_clock_dividers(rdev, COMPUTE_ENGINE_PLL_PARAM, 26326596afd4SAlex Deucher 0, false, ÷rs); 26336596afd4SAlex Deucher if (ret) 26346596afd4SAlex Deucher pi->ref_div = dividers.ref_div + 1; 26356596afd4SAlex Deucher else 26366596afd4SAlex Deucher pi->ref_div = R600_REFERENCEDIVIDER_DFLT; 26376596afd4SAlex Deucher 26386596afd4SAlex Deucher pi->mclk_strobe_mode_threshold = 40000; 26396596afd4SAlex Deucher pi->mclk_edc_enable_threshold = 40000; 26406596afd4SAlex Deucher eg_pi->mclk_edc_wr_enable_threshold = 40000; 26416596afd4SAlex Deucher 2642f85392bcSAlex Deucher pi->rlp = RV770_RLP_DFLT; 2643f85392bcSAlex Deucher pi->rmp = RV770_RMP_DFLT; 2644f85392bcSAlex Deucher pi->lhp = RV770_LHP_DFLT; 2645f85392bcSAlex Deucher pi->lmp = RV770_LMP_DFLT; 2646f85392bcSAlex Deucher 2647f85392bcSAlex Deucher eg_pi->ats[0].rlp = RV770_RLP_DFLT; 2648f85392bcSAlex Deucher eg_pi->ats[0].rmp = RV770_RMP_DFLT; 2649f85392bcSAlex Deucher eg_pi->ats[0].lhp = RV770_LHP_DFLT; 2650f85392bcSAlex Deucher eg_pi->ats[0].lmp = RV770_LMP_DFLT; 2651f85392bcSAlex Deucher 2652f85392bcSAlex Deucher eg_pi->ats[1].rlp = BTC_RLP_UVD_DFLT; 2653f85392bcSAlex Deucher eg_pi->ats[1].rmp = BTC_RMP_UVD_DFLT; 2654f85392bcSAlex Deucher eg_pi->ats[1].lhp = BTC_LHP_UVD_DFLT; 2655f85392bcSAlex Deucher eg_pi->ats[1].lmp = BTC_LMP_UVD_DFLT; 2656f85392bcSAlex Deucher 2657f85392bcSAlex Deucher eg_pi->smu_uvd_hs = true; 2658f85392bcSAlex Deucher 26596596afd4SAlex Deucher pi->voltage_control = 266058653abdSAlex Deucher radeon_atom_is_voltage_gpio(rdev, SET_VOLTAGE_TYPE_ASIC_VDDC, 0); 26616596afd4SAlex Deucher 26626596afd4SAlex Deucher pi->mvdd_control = 266358653abdSAlex Deucher radeon_atom_is_voltage_gpio(rdev, SET_VOLTAGE_TYPE_ASIC_MVDDC, 0); 26646596afd4SAlex Deucher 26656596afd4SAlex Deucher eg_pi->vddci_control = 266658653abdSAlex Deucher radeon_atom_is_voltage_gpio(rdev, SET_VOLTAGE_TYPE_ASIC_VDDCI, 0); 26676596afd4SAlex Deucher 2668b841ce7bSAlex Deucher rv770_get_engine_memory_ss(rdev); 26696596afd4SAlex Deucher 26706596afd4SAlex Deucher pi->asi = RV770_ASI_DFLT; 26716596afd4SAlex Deucher pi->pasi = CYPRESS_HASI_DFLT; 26726596afd4SAlex Deucher pi->vrc = CYPRESS_VRC_DFLT; 26736596afd4SAlex Deucher 26746596afd4SAlex Deucher pi->power_gating = false; 26756596afd4SAlex Deucher 26766596afd4SAlex Deucher pi->gfx_clock_gating = true; 26776596afd4SAlex Deucher 26786596afd4SAlex Deucher pi->mg_clock_gating = true; 26796596afd4SAlex Deucher pi->mgcgtssm = true; 26806596afd4SAlex Deucher eg_pi->ls_clock_gating = false; 26816596afd4SAlex Deucher eg_pi->sclk_deep_sleep = false; 26826596afd4SAlex Deucher 26836596afd4SAlex Deucher pi->dynamic_pcie_gen2 = true; 26846596afd4SAlex Deucher 2685fda83724SAlex Deucher if (rdev->pm.int_thermal_type != THERMAL_TYPE_NONE) 26866596afd4SAlex Deucher pi->thermal_protection = true; 26876596afd4SAlex Deucher else 26886596afd4SAlex Deucher pi->thermal_protection = false; 26896596afd4SAlex Deucher 26906596afd4SAlex Deucher pi->display_gap = true; 26916596afd4SAlex Deucher 26926596afd4SAlex Deucher if (rdev->flags & RADEON_IS_MOBILITY) 26936596afd4SAlex Deucher pi->dcodt = true; 26946596afd4SAlex Deucher else 26956596afd4SAlex Deucher pi->dcodt = false; 26966596afd4SAlex Deucher 26976596afd4SAlex Deucher pi->ulps = true; 26986596afd4SAlex Deucher 26996596afd4SAlex Deucher eg_pi->dynamic_ac_timing = true; 27006596afd4SAlex Deucher eg_pi->abm = true; 27016596afd4SAlex Deucher eg_pi->mcls = true; 27026596afd4SAlex Deucher eg_pi->light_sleep = true; 27036596afd4SAlex Deucher eg_pi->memory_transition = true; 27046596afd4SAlex Deucher #if defined(CONFIG_ACPI) 27056596afd4SAlex Deucher eg_pi->pcie_performance_request = 27066596afd4SAlex Deucher radeon_acpi_is_pcie_performance_request_supported(rdev); 27076596afd4SAlex Deucher #else 27086596afd4SAlex Deucher eg_pi->pcie_performance_request = false; 27096596afd4SAlex Deucher #endif 27106596afd4SAlex Deucher 27116596afd4SAlex Deucher if (rdev->family == CHIP_BARTS) 27126596afd4SAlex Deucher eg_pi->dll_default_on = true; 27136596afd4SAlex Deucher else 27146596afd4SAlex Deucher eg_pi->dll_default_on = false; 27156596afd4SAlex Deucher 27166596afd4SAlex Deucher eg_pi->sclk_deep_sleep = false; 27176596afd4SAlex Deucher if (ASIC_IS_LOMBOK(rdev)) 27186596afd4SAlex Deucher pi->mclk_stutter_mode_threshold = 30000; 27196596afd4SAlex Deucher else 27206596afd4SAlex Deucher pi->mclk_stutter_mode_threshold = 0; 27216596afd4SAlex Deucher 27226596afd4SAlex Deucher pi->sram_end = SMC_RAM_END; 27236596afd4SAlex Deucher 2724d22b7e40SAlex Deucher rdev->pm.dpm.dyn_state.mclk_sclk_ratio = 4; 2725d22b7e40SAlex Deucher rdev->pm.dpm.dyn_state.vddc_vddci_delta = 200; 2726d22b7e40SAlex Deucher rdev->pm.dpm.dyn_state.min_vddc_for_pcie_gen2 = 900; 2727d22b7e40SAlex Deucher rdev->pm.dpm.dyn_state.valid_sclk_values.count = ARRAY_SIZE(btc_valid_sclk); 2728d22b7e40SAlex Deucher rdev->pm.dpm.dyn_state.valid_sclk_values.values = btc_valid_sclk; 2729d22b7e40SAlex Deucher rdev->pm.dpm.dyn_state.valid_mclk_values.count = 0; 2730d22b7e40SAlex Deucher rdev->pm.dpm.dyn_state.valid_mclk_values.values = NULL; 2731d22b7e40SAlex Deucher 2732d22b7e40SAlex Deucher if (rdev->family == CHIP_TURKS) 2733d22b7e40SAlex Deucher rdev->pm.dpm.dyn_state.sclk_mclk_delta = 15000; 2734d22b7e40SAlex Deucher else 2735d22b7e40SAlex Deucher rdev->pm.dpm.dyn_state.sclk_mclk_delta = 10000; 2736d22b7e40SAlex Deucher 27371ff60ddbSAlex Deucher /* make sure dc limits are valid */ 27381ff60ddbSAlex Deucher if ((rdev->pm.dpm.dyn_state.max_clock_voltage_on_dc.sclk == 0) || 27391ff60ddbSAlex Deucher (rdev->pm.dpm.dyn_state.max_clock_voltage_on_dc.mclk == 0)) 27401ff60ddbSAlex Deucher rdev->pm.dpm.dyn_state.max_clock_voltage_on_dc = 27411ff60ddbSAlex Deucher rdev->pm.dpm.dyn_state.max_clock_voltage_on_ac; 27421ff60ddbSAlex Deucher 27436596afd4SAlex Deucher return 0; 27446596afd4SAlex Deucher } 27456596afd4SAlex Deucher 27466596afd4SAlex Deucher void btc_dpm_fini(struct radeon_device *rdev) 27476596afd4SAlex Deucher { 27486596afd4SAlex Deucher int i; 27496596afd4SAlex Deucher 27506596afd4SAlex Deucher for (i = 0; i < rdev->pm.dpm.num_ps; i++) { 27516596afd4SAlex Deucher kfree(rdev->pm.dpm.ps[i].ps_priv); 27526596afd4SAlex Deucher } 27536596afd4SAlex Deucher kfree(rdev->pm.dpm.ps); 27546596afd4SAlex Deucher kfree(rdev->pm.dpm.priv); 27554489cd62SAlex Deucher kfree(rdev->pm.dpm.dyn_state.vddc_dependency_on_dispclk.entries); 2756d22b7e40SAlex Deucher r600_free_extended_power_table(rdev); 27576596afd4SAlex Deucher } 2758e8a9539fSAlex Deucher 2759e8a9539fSAlex Deucher u32 btc_dpm_get_sclk(struct radeon_device *rdev, bool low) 2760e8a9539fSAlex Deucher { 2761e8a9539fSAlex Deucher struct evergreen_power_info *eg_pi = evergreen_get_pi(rdev); 2762e8a9539fSAlex Deucher struct rv7xx_ps *requested_state = rv770_get_ps(&eg_pi->requested_rps); 2763e8a9539fSAlex Deucher 2764e8a9539fSAlex Deucher if (low) 2765e8a9539fSAlex Deucher return requested_state->low.sclk; 2766e8a9539fSAlex Deucher else 2767e8a9539fSAlex Deucher return requested_state->high.sclk; 2768e8a9539fSAlex Deucher } 2769e8a9539fSAlex Deucher 2770e8a9539fSAlex Deucher u32 btc_dpm_get_mclk(struct radeon_device *rdev, bool low) 2771e8a9539fSAlex Deucher { 2772e8a9539fSAlex Deucher struct evergreen_power_info *eg_pi = evergreen_get_pi(rdev); 2773e8a9539fSAlex Deucher struct rv7xx_ps *requested_state = rv770_get_ps(&eg_pi->requested_rps); 2774e8a9539fSAlex Deucher 2775e8a9539fSAlex Deucher if (low) 2776e8a9539fSAlex Deucher return requested_state->low.mclk; 2777e8a9539fSAlex Deucher else 2778e8a9539fSAlex Deucher return requested_state->high.mclk; 2779e8a9539fSAlex Deucher } 2780