}
        }
 
-       /* Dump the IdleMask before we send hint to SMU */
-       amd_pmc_idlemask_read(pdev, pdev->dev, NULL);
        msg = amd_pmc_get_os_hint(pdev);
        rc = amd_pmc_send_cmd(pdev, arg, NULL, msg, 0);
        if (rc) {
        struct amd_pmc_dev *pdev = &pmc;
        int rc;
 
+       /* Dump the IdleMask before we add to the STB */
+       amd_pmc_idlemask_read(pdev, pdev->dev, NULL);
+
        rc = amd_pmc_write_stb(pdev, AMD_PMC_STB_S2IDLE_CHECK);
        if (rc)
                dev_err(pdev->dev, "error writing to STB: %d\n", rc);
        /* Let SMU know that we are looking for stats */
        amd_pmc_send_cmd(pdev, 0, NULL, SMU_MSG_LOG_DUMP_DATA, 0);
 
-       /* Dump the IdleMask to see the blockers */
-       amd_pmc_idlemask_read(pdev, pdev->dev, NULL);
-
        rc = amd_pmc_write_stb(pdev, AMD_PMC_STB_S2IDLE_RESTORE);
        if (rc)
                dev_err(pdev->dev, "error writing to STB: %d\n", rc);