#define GPU_PAS_ID 13
 
-static int zap_shader_load_mdt(struct device *dev, const char *fwname)
+static int zap_shader_load_mdt(struct msm_gpu *gpu, const char *fwname)
 {
+       struct device *dev = &gpu->pdev->dev;
        const struct firmware *fw;
        struct device_node *np;
        struct resource r;
        mem_size = resource_size(&r);
 
        /* Request the MDT file for the firmware */
-       ret = request_firmware(&fw, fwname, dev);
-       if (ret) {
+       fw = adreno_request_fw(to_adreno_gpu(gpu), fwname);
+       if (IS_ERR(fw)) {
                DRM_DEV_ERROR(dev, "Unable to load %s\n", fwname);
-               return ret;
+               return PTR_ERR(fw);
        }
 
        /* Figure out how much memory we need */
                return -ENODEV;
        }
 
-       ret = zap_shader_load_mdt(&pdev->dev, adreno_gpu->info->zapfw);
+       ret = zap_shader_load_mdt(gpu, adreno_gpu->info->zapfw);
 
        loaded = !ret;
 
 
                return;
 
        /* Get the firmware */
-       if (request_firmware(&fw, adreno_gpu->info->gpmufw, drm->dev)) {
+       fw = adreno_request_fw(adreno_gpu, adreno_gpu->info->gpmufw);
+       if (IS_ERR(fw)) {
                DRM_ERROR("%s: Could not get GPMU firmware. GPMU will not be active\n",
                        gpu->name);
                return;
 
        }
 }
 
-static int adreno_load_fw(struct adreno_gpu *adreno_gpu)
+const struct firmware *
+adreno_request_fw(struct adreno_gpu *adreno_gpu, const char *fwname)
 {
        struct drm_device *drm = adreno_gpu->base.dev;
+       const struct firmware *fw = NULL;
        int ret;
 
+       ret = request_firmware(&fw, fwname, drm->dev);
+       if (ret) {
+               dev_err(drm->dev, "failed to load %s: %d\n", fwname, ret);
+               return ERR_PTR(ret);
+       }
+
+       return fw;
+}
+
+static int adreno_load_fw(struct adreno_gpu *adreno_gpu)
+{
+       const struct firmware *fw;
+
        if (adreno_gpu->pm4)
                return 0;
 
-       ret = request_firmware(&adreno_gpu->pm4, adreno_gpu->info->pm4fw, drm->dev);
-       if (ret) {
-               dev_err(drm->dev, "failed to load %s PM4 firmware: %d\n",
-                               adreno_gpu->info->pm4fw, ret);
-               return ret;
-       }
+       fw = adreno_request_fw(adreno_gpu, adreno_gpu->info->pm4fw);
+       if (IS_ERR(fw))
+               return PTR_ERR(fw);
+       adreno_gpu->pm4 = fw;
 
-       ret = request_firmware(&adreno_gpu->pfp, adreno_gpu->info->pfpfw, drm->dev);
-       if (ret) {
-               dev_err(drm->dev, "failed to load %s PFP firmware: %d\n",
-                               adreno_gpu->info->pfpfw, ret);
+       fw = adreno_request_fw(adreno_gpu, adreno_gpu->info->pfpfw);
+       if (IS_ERR(fw)) {
                release_firmware(adreno_gpu->pm4);
                adreno_gpu->pm4 = NULL;
-               return ret;
+               return PTR_ERR(fw);
        }
+       adreno_gpu->pfp = fw;
 
        return 0;
 }
 
 }
 
 int adreno_get_param(struct msm_gpu *gpu, uint32_t param, uint64_t *value);
+const struct firmware *adreno_request_fw(struct adreno_gpu *adreno_gpu,
+               const char *fwname);
 int adreno_hw_init(struct msm_gpu *gpu);
 uint32_t adreno_last_fence(struct msm_gpu *gpu);
 void adreno_recover(struct msm_gpu *gpu);