LCOV - code coverage report
Current view: top level - drivers/gpu/drm/amd/pm/powerplay/hwmgr - common_baco.c (source / functions) Hit Total Coverage
Test: coverage.info Lines: 0 38 0.0 %
Date: 2022-12-09 01:23:36 Functions: 0 4 0.0 %

          Line data    Source code
       1             : /*
       2             :  * Copyright 2018 Advanced Micro Devices, Inc.
       3             :  *
       4             :  * Permission is hereby granted, free of charge, to any person obtaining a
       5             :  * copy of this software and associated documentation files (the "Software"),
       6             :  * to deal in the Software without restriction, including without limitation
       7             :  * the rights to use, copy, modify, merge, publish, distribute, sublicense,
       8             :  * and/or sell copies of the Software, and to permit persons to whom the
       9             :  * Software is furnished to do so, subject to the following conditions:
      10             :  *
      11             :  * The above copyright notice and this permission notice shall be included in
      12             :  * all copies or substantial portions of the Software.
      13             :  *
      14             :  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
      15             :  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
      16             :  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
      17             :  * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
      18             :  * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
      19             :  * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
      20             :  * OTHER DEALINGS IN THE SOFTWARE.
      21             :  *
      22             :  */
      23             : 
      24             : #include "common_baco.h"
      25             : 
      26             : 
      27           0 : static bool baco_wait_register(struct pp_hwmgr *hwmgr, u32 reg, u32 mask, u32 value)
      28             : {
      29           0 :         struct amdgpu_device *adev = (struct amdgpu_device *)(hwmgr->adev);
      30           0 :         u32 timeout = 5000, data;
      31             : 
      32             :         do {
      33           0 :                 msleep(1);
      34           0 :                 data = RREG32(reg);
      35           0 :                 timeout--;
      36           0 :         } while (value != (data & mask) && (timeout != 0));
      37             : 
      38           0 :         if (timeout == 0)
      39             :                 return false;
      40             : 
      41             :         return true;
      42             : }
      43             : 
      44           0 : static bool baco_cmd_handler(struct pp_hwmgr *hwmgr, u32 command, u32 reg, u32 mask,
      45             :                                 u32 shift, u32 value, u32 timeout)
      46             : {
      47           0 :         struct amdgpu_device *adev = (struct amdgpu_device *)(hwmgr->adev);
      48             :         u32 data;
      49           0 :         bool ret = true;
      50             : 
      51           0 :         switch (command) {
      52             :         case CMD_WRITE:
      53           0 :                 WREG32(reg, value << shift);
      54             :                 break;
      55             :         case CMD_READMODIFYWRITE:
      56           0 :                 data = RREG32(reg);
      57           0 :                 data = (data & (~mask)) | (value << shift);
      58           0 :                 WREG32(reg, data);
      59             :                 break;
      60             :         case CMD_WAITFOR:
      61           0 :                 ret = baco_wait_register(hwmgr, reg, mask, value);
      62             :                 break;
      63             :         case CMD_DELAY_MS:
      64           0 :                 if (timeout)
      65             :                         /* Delay in milli Seconds */
      66           0 :                         msleep(timeout);
      67             :                 break;
      68             :         case CMD_DELAY_US:
      69           0 :                 if (timeout)
      70             :                         /* Delay in micro Seconds */
      71           0 :                         udelay(timeout);
      72             :                 break;
      73             : 
      74             :         default:
      75           0 :                 dev_warn(adev->dev, "Invalid BACO command.\n");
      76           0 :                 ret = false;
      77             :         }
      78             : 
      79           0 :         return ret;
      80             : }
      81             : 
      82           0 : bool baco_program_registers(struct pp_hwmgr *hwmgr,
      83             :                             const struct baco_cmd_entry *entry,
      84             :                             const u32 array_size)
      85             : {
      86           0 :         u32 i, reg = 0;
      87             : 
      88           0 :         for (i = 0; i < array_size; i++) {
      89           0 :                 if ((entry[i].cmd == CMD_WRITE) ||
      90             :                     (entry[i].cmd == CMD_READMODIFYWRITE) ||
      91             :                     (entry[i].cmd == CMD_WAITFOR))
      92           0 :                         reg = entry[i].reg_offset;
      93           0 :                 if (!baco_cmd_handler(hwmgr, entry[i].cmd, reg, entry[i].mask,
      94             :                                      entry[i].shift, entry[i].val, entry[i].timeout))
      95             :                         return false;
      96             :         }
      97             : 
      98             :         return true;
      99             : }
     100             : 
     101           0 : bool soc15_baco_program_registers(struct pp_hwmgr *hwmgr,
     102             :                                  const struct soc15_baco_cmd_entry *entry,
     103             :                                  const u32 array_size)
     104             : {
     105           0 :         struct amdgpu_device *adev = (struct amdgpu_device *)(hwmgr->adev);
     106           0 :         u32 i, reg = 0;
     107             : 
     108           0 :         for (i = 0; i < array_size; i++) {
     109           0 :                 if ((entry[i].cmd == CMD_WRITE) ||
     110             :                     (entry[i].cmd == CMD_READMODIFYWRITE) ||
     111             :                     (entry[i].cmd == CMD_WAITFOR))
     112           0 :                         reg = adev->reg_offset[entry[i].hwip][entry[i].inst][entry[i].seg]
     113           0 :                                 + entry[i].reg_offset;
     114           0 :                 if (!baco_cmd_handler(hwmgr, entry[i].cmd, reg, entry[i].mask,
     115             :                                      entry[i].shift, entry[i].val, entry[i].timeout))
     116             :                         return false;
     117             :         }
     118             : 
     119             :         return true;
     120             : }

Generated by: LCOV version 1.14