drm/amdgpu: move atom scratch setup into amdgpu_atombios.c
authorAlex Deucher <alexander.deucher@amd.com>
Fri, 23 Sep 2016 17:10:49 +0000 (13:10 -0400)
committerAlex Deucher <alexander.deucher@amd.com>
Thu, 30 Mar 2017 03:54:17 +0000 (23:54 -0400)
There will be a slightly different version for atomfirmware.

Acked-by: Christian König <christian.koenig@amd.com>
Reviewed-by: Ken Wang <Qingqing.Wang@amd.com>
Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
drivers/gpu/drm/amd/amdgpu/amdgpu_atombios.c
drivers/gpu/drm/amd/amdgpu/amdgpu_atombios.h
drivers/gpu/drm/amd/amdgpu/amdgpu_device.c
drivers/gpu/drm/amd/amdgpu/atom.c
drivers/gpu/drm/amd/amdgpu/atom.h

index 56a86dd5789e967abb9f13a0a7f78fb3f519b2ea..f52b1bf3d3d9a75bb406f3c62cf892b5ee76fe63 100644 (file)
@@ -1748,3 +1748,31 @@ void amdgpu_atombios_copy_swap(u8 *dst, u8 *src, u8 num_bytes, bool to_le)
        memcpy(dst, src, num_bytes);
 #endif
 }
+
+int amdgpu_atombios_allocate_fb_scratch(struct amdgpu_device *adev)
+{
+       struct atom_context *ctx = adev->mode_info.atom_context;
+       int index = GetIndexIntoMasterTable(DATA, VRAM_UsageByFirmware);
+       uint16_t data_offset;
+       int usage_bytes = 0;
+       struct _ATOM_VRAM_USAGE_BY_FIRMWARE *firmware_usage;
+
+       if (amdgpu_atom_parse_data_header(ctx, index, NULL, NULL, NULL, &data_offset)) {
+               firmware_usage = (struct _ATOM_VRAM_USAGE_BY_FIRMWARE *)(ctx->bios + data_offset);
+
+               DRM_DEBUG("atom firmware requested %08x %dkb\n",
+                         le32_to_cpu(firmware_usage->asFirmwareVramReserveInfo[0].ulStartAddrUsedByFirmware),
+                         le16_to_cpu(firmware_usage->asFirmwareVramReserveInfo[0].usFirmwareUseInKb));
+
+               usage_bytes = le16_to_cpu(firmware_usage->asFirmwareVramReserveInfo[0].usFirmwareUseInKb) * 1024;
+       }
+       ctx->scratch_size_bytes = 0;
+       if (usage_bytes == 0)
+               usage_bytes = 20 * 1024;
+       /* allocate some scratch memory */
+       ctx->scratch = kzalloc(usage_bytes, GFP_KERNEL);
+       if (!ctx->scratch)
+               return -ENOMEM;
+       ctx->scratch_size_bytes = usage_bytes;
+       return 0;
+}
index 70e9acef5d9c67ac228e173cd1beece437b5e82d..4e0f488487f31812f51a23b6dd39d73417ffcf2c 100644 (file)
@@ -215,4 +215,7 @@ int amdgpu_atombios_get_clock_dividers(struct amdgpu_device *adev,
 int amdgpu_atombios_get_svi2_info(struct amdgpu_device *adev,
                              u8 voltage_type,
                              u8 *svd_gpio_id, u8 *svc_gpio_id);
+
+int amdgpu_atombios_allocate_fb_scratch(struct amdgpu_device *adev);
+
 #endif
index 7f996ac089b4ad352480c2ff77eeba25d312e95c..dfbfd56bcc25c193d9cb7b0bb8b85df0814a729c 100644 (file)
@@ -994,7 +994,7 @@ static int amdgpu_atombios_init(struct amdgpu_device *adev)
 
        mutex_init(&adev->mode_info.atom_context->mutex);
        amdgpu_atombios_scratch_regs_init(adev);
-       amdgpu_atom_allocate_fb_scratch(adev->mode_info.atom_context);
+       amdgpu_atombios_allocate_fb_scratch(adev);
        return 0;
 }
 
index 81c60a277eebd5e1d7d6dceb686b93304c11fd2e..d69aa2e179bbedbcc955a9848fc80d0f03eada85 100644 (file)
@@ -1417,29 +1417,3 @@ bool amdgpu_atom_parse_cmd_header(struct atom_context *ctx, int index, uint8_t *
        return true;
 }
 
-int amdgpu_atom_allocate_fb_scratch(struct atom_context *ctx)
-{
-       int index = GetIndexIntoMasterTable(DATA, VRAM_UsageByFirmware);
-       uint16_t data_offset;
-       int usage_bytes = 0;
-       struct _ATOM_VRAM_USAGE_BY_FIRMWARE *firmware_usage;
-
-       if (amdgpu_atom_parse_data_header(ctx, index, NULL, NULL, NULL, &data_offset)) {
-               firmware_usage = (struct _ATOM_VRAM_USAGE_BY_FIRMWARE *)(ctx->bios + data_offset);
-
-               DRM_DEBUG("atom firmware requested %08x %dkb\n",
-                         le32_to_cpu(firmware_usage->asFirmwareVramReserveInfo[0].ulStartAddrUsedByFirmware),
-                         le16_to_cpu(firmware_usage->asFirmwareVramReserveInfo[0].usFirmwareUseInKb));
-
-               usage_bytes = le16_to_cpu(firmware_usage->asFirmwareVramReserveInfo[0].usFirmwareUseInKb) * 1024;
-       }
-       ctx->scratch_size_bytes = 0;
-       if (usage_bytes == 0)
-               usage_bytes = 20 * 1024;
-       /* allocate some scratch memory */
-       ctx->scratch = kzalloc(usage_bytes, GFP_KERNEL);
-       if (!ctx->scratch)
-               return -ENOMEM;
-       ctx->scratch_size_bytes = usage_bytes;
-       return 0;
-}
index baa2438d7883c2712e15aee006d97539129a683f..ddd8045accf3e764d47498bfbc0c0bd8cbb71433 100644 (file)
@@ -152,7 +152,6 @@ bool amdgpu_atom_parse_data_header(struct atom_context *ctx, int index, uint16_t
                            uint8_t *frev, uint8_t *crev, uint16_t *data_start);
 bool amdgpu_atom_parse_cmd_header(struct atom_context *ctx, int index,
                           uint8_t *frev, uint8_t *crev);
-int amdgpu_atom_allocate_fb_scratch(struct atom_context *ctx);
 #include "atom-types.h"
 #include "atombios.h"
 #include "ObjectID.h"