Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/sys/external/bsd/drm2/dist/drm/amd/amdgpu Tired of fine-grai...



details:   https://anonhg.NetBSD.org/src/rev/d2bcca3494e3
branches:  trunk
changeset: 366232:d2bcca3494e3
user:      riastradh <riastradh%NetBSD.org@localhost>
date:      Mon Aug 27 14:04:50 2018 +0000

description:
Tired of fine-grained commits.  Have an amdgpu(4).

diffstat:

 sys/external/bsd/drm2/dist/drm/amd/amdgpu/amdgpu.h               |   61 ++-
 sys/external/bsd/drm2/dist/drm/amd/amdgpu/amdgpu_acpi.c          |    7 +-
 sys/external/bsd/drm2/dist/drm/amd/amdgpu/amdgpu_amdkfd.c        |    8 +-
 sys/external/bsd/drm2/dist/drm/amd/amdgpu/amdgpu_amdkfd_gfx_v8.c |    8 +-
 sys/external/bsd/drm2/dist/drm/amd/amdgpu/amdgpu_atombios.c      |   59 +-
 sys/external/bsd/drm2/dist/drm/amd/amdgpu/amdgpu_benchmark.c     |    6 +-
 sys/external/bsd/drm2/dist/drm/amd/amdgpu/amdgpu_bios.c          |   50 +-
 sys/external/bsd/drm2/dist/drm/amd/amdgpu/amdgpu_bo_list.c       |   14 +-
 sys/external/bsd/drm2/dist/drm/amd/amdgpu/amdgpu_cgs.c           |   21 +-
 sys/external/bsd/drm2/dist/drm/amd/amdgpu/amdgpu_cs.c            |   17 +-
 sys/external/bsd/drm2/dist/drm/amd/amdgpu/amdgpu_ctx.c           |   12 +-
 sys/external/bsd/drm2/dist/drm/amd/amdgpu/amdgpu_device.c        |  251 +++++++++-
 sys/external/bsd/drm2/dist/drm/amd/amdgpu/amdgpu_display.c       |   10 +-
 sys/external/bsd/drm2/dist/drm/amd/amdgpu/amdgpu_dpm.c           |   53 +-
 sys/external/bsd/drm2/dist/drm/amd/amdgpu/amdgpu_drv.c           |   33 +-
 sys/external/bsd/drm2/dist/drm/amd/amdgpu/amdgpu_fb.c            |   68 ++-
 sys/external/bsd/drm2/dist/drm/amd/amdgpu/amdgpu_fence.c         |  103 +++-
 sys/external/bsd/drm2/dist/drm/amd/amdgpu/amdgpu_gart.c          |  169 ++++++-
 sys/external/bsd/drm2/dist/drm/amd/amdgpu/amdgpu_gem.c           |   28 +-
 sys/external/bsd/drm2/dist/drm/amd/amdgpu/amdgpu_gfx.c           |    5 +-
 sys/external/bsd/drm2/dist/drm/amd/amdgpu/amdgpu_i2c.c           |   21 +-
 sys/external/bsd/drm2/dist/drm/amd/amdgpu/amdgpu_ih.c            |   66 ++-
 sys/external/bsd/drm2/dist/drm/amd/amdgpu/amdgpu_ih.h            |    6 +-
 sys/external/bsd/drm2/dist/drm/amd/amdgpu/amdgpu_irq.c           |    6 +-
 sys/external/bsd/drm2/dist/drm/amd/amdgpu/amdgpu_irq.h           |    4 +-
 sys/external/bsd/drm2/dist/drm/amd/amdgpu/amdgpu_kms.c           |   20 +-
 sys/external/bsd/drm2/dist/drm/amd/amdgpu/amdgpu_object.c        |   16 +-
 sys/external/bsd/drm2/dist/drm/amd/amdgpu/amdgpu_object.h        |    7 +-
 sys/external/bsd/drm2/dist/drm/amd/amdgpu/amdgpu_pll.c           |    6 +-
 sys/external/bsd/drm2/dist/drm/amd/amdgpu/amdgpu_pm.c            |   18 +-
 sys/external/bsd/drm2/dist/drm/amd/amdgpu/amdgpu_pm.h            |    8 +-
 sys/external/bsd/drm2/dist/drm/amd/amdgpu/amdgpu_ring.c          |    8 +-
 sys/external/bsd/drm2/dist/drm/amd/amdgpu/amdgpu_sa.c            |   48 +-
 sys/external/bsd/drm2/dist/drm/amd/amdgpu/amdgpu_test.c          |   24 +-
 sys/external/bsd/drm2/dist/drm/amd/amdgpu/amdgpu_ttm.c           |   99 +++-
 sys/external/bsd/drm2/dist/drm/amd/amdgpu/amdgpu_ucode.c         |   25 +-
 sys/external/bsd/drm2/dist/drm/amd/amdgpu/amdgpu_uvd.c           |   36 +-
 sys/external/bsd/drm2/dist/drm/amd/amdgpu/amdgpu_vce.c           |    9 +-
 sys/external/bsd/drm2/dist/drm/amd/amdgpu/amdgpu_vm.c            |   22 +-
 sys/external/bsd/drm2/dist/drm/amd/amdgpu/atom.c                 |   11 +-
 sys/external/bsd/drm2/dist/drm/amd/amdgpu/atombios_crtc.c        |    6 +-
 sys/external/bsd/drm2/dist/drm/amd/amdgpu/atombios_dp.c          |   13 +-
 sys/external/bsd/drm2/dist/drm/amd/amdgpu/atombios_encoders.c    |   16 +-
 sys/external/bsd/drm2/dist/drm/amd/amdgpu/atombios_i2c.c         |   13 +-
 sys/external/bsd/drm2/dist/drm/amd/amdgpu/ci_dpm.c               |    8 +-
 sys/external/bsd/drm2/dist/drm/amd/amdgpu/cz_dpm.c               |   19 +-
 sys/external/bsd/drm2/dist/drm/amd/amdgpu/cz_ih.c                |    6 +-
 sys/external/bsd/drm2/dist/drm/amd/amdgpu/cz_smc.c               |   24 +-
 sys/external/bsd/drm2/dist/drm/amd/amdgpu/dce_v10_0.c            |    6 +-
 sys/external/bsd/drm2/dist/drm/amd/amdgpu/dce_v11_0.c            |    6 +-
 sys/external/bsd/drm2/dist/drm/amd/amdgpu/fiji_dpm.c             |    5 +-
 sys/external/bsd/drm2/dist/drm/amd/amdgpu/fiji_smc.c             |    9 +-
 sys/external/bsd/drm2/dist/drm/amd/amdgpu/gfx_v8_0.c             |   41 +-
 sys/external/bsd/drm2/dist/drm/amd/amdgpu/gmc_v7_0.c             |   34 +-
 sys/external/bsd/drm2/dist/drm/amd/amdgpu/gmc_v8_0.c             |   34 +-
 sys/external/bsd/drm2/dist/drm/amd/amdgpu/iceland_dpm.c          |    5 +-
 sys/external/bsd/drm2/dist/drm/amd/amdgpu/iceland_ih.c           |    7 +-
 sys/external/bsd/drm2/dist/drm/amd/amdgpu/iceland_smc.c          |   13 +-
 sys/external/bsd/drm2/dist/drm/amd/amdgpu/sdma_v2_4.c            |   13 +-
 sys/external/bsd/drm2/dist/drm/amd/amdgpu/sdma_v3_0.c            |   13 +-
 sys/external/bsd/drm2/dist/drm/amd/amdgpu/tonga_dpm.c            |    5 +-
 sys/external/bsd/drm2/dist/drm/amd/amdgpu/tonga_ih.c             |    6 +-
 sys/external/bsd/drm2/dist/drm/amd/amdgpu/tonga_smc.c            |    9 +-
 sys/external/bsd/drm2/dist/drm/amd/amdgpu/uvd_v5_0.c             |    7 +-
 sys/external/bsd/drm2/dist/drm/amd/amdgpu/uvd_v6_0.c             |    7 +-
 sys/external/bsd/drm2/dist/drm/amd/amdgpu/vce_v3_0.c             |    9 +-
 sys/external/bsd/drm2/dist/drm/amd/amdgpu/vi.c                   |    8 +-
 67 files changed, 1473 insertions(+), 312 deletions(-)

diffs (truncated from 5366 to 300 lines):

diff -r faa8f8b34fc8 -r d2bcca3494e3 sys/external/bsd/drm2/dist/drm/amd/amdgpu/amdgpu.h
--- a/sys/external/bsd/drm2/dist/drm/amd/amdgpu/amdgpu.h        Mon Aug 27 14:03:38 2018 +0000
+++ b/sys/external/bsd/drm2/dist/drm/amd/amdgpu/amdgpu.h        Mon Aug 27 14:04:50 2018 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: amdgpu.h,v 1.2 2018/08/27 04:58:19 riastradh Exp $     */
+/*     $NetBSD: amdgpu.h,v 1.3 2018/08/27 14:04:50 riastradh Exp $     */
 
 /*
  * Copyright 2008 Advanced Micro Devices, Inc.
@@ -361,7 +361,12 @@
  * Dummy page
  */
 struct amdgpu_dummy_page {
+#ifdef __NetBSD__
+       bus_dma_segment_t       adp_seg;
+       bus_dmamap_t            adp_map;
+#else
        struct page     *page;
+#endif
        dma_addr_t      addr;
 };
 int amdgpu_dummy_page_init(struct amdgpu_device *adev);
@@ -400,7 +405,13 @@
        struct amdgpu_irq_src           *irq_src;
        unsigned                        irq_type;
        struct timer_list               fallback_timer;
+#ifdef __NetBSD__
+       spinlock_t                      fence_lock;
+       drm_waitqueue_t                 fence_queue;
+       TAILQ_HEAD(, amdgpu_fence)      fence_check;
+#else
        wait_queue_head_t               fence_queue;
+#endif
 };
 
 /* some special values for the owner field */
@@ -420,7 +431,11 @@
        /* filp or special value for fence creator */
        void                            *owner;
 
+#ifdef __NetBSD__
+       TAILQ_ENTRY(amdgpu_fence)       fence_check;
+#else
        wait_queue_t                    fence_wake;
+#endif
 };
 
 struct amdgpu_user_fence {
@@ -478,7 +493,12 @@
                       uint32_t byte_count,
                       struct reservation_object *resv,
                       struct fence **fence);
+#ifdef __NetBSD__
+int amdgpu_mmap_object(struct drm_device *, off_t, size_t, vm_prot_t,
+    struct uvm_object **, voff_t *, struct file *);
+#else
 int amdgpu_mmap(struct file *filp, struct vm_area_struct *vma);
+#endif
 
 struct amdgpu_bo_list_entry {
        struct amdgpu_bo                *robj;
@@ -595,7 +615,12 @@
  * alignment).
  */
 struct amdgpu_sa_manager {
+#ifdef __NetBSD__
+       spinlock_t              wq_lock;
+       drm_waitqueue_t         wq;
+#else
        wait_queue_head_t       wq;
+#endif
        struct amdgpu_bo        *bo;
        struct list_head        *hole;
        struct list_head        flist[AMDGPU_MAX_RINGS];
@@ -693,6 +718,10 @@
 #define AMDGPU_GPU_PAGE_ALIGN(a) (((a) + AMDGPU_GPU_PAGE_MASK) & ~AMDGPU_GPU_PAGE_MASK)
 
 struct amdgpu_gart {
+#ifdef __NetBSD__
+       bus_dma_segment_t               ag_table_seg;
+       bus_dmamap_t                    ag_table_map;
+#endif
        dma_addr_t                      table_addr;
        struct amdgpu_bo                *robj;
        void                            *ptr;
@@ -713,11 +742,19 @@
 void amdgpu_gart_table_vram_unpin(struct amdgpu_device *adev);
 int amdgpu_gart_init(struct amdgpu_device *adev);
 void amdgpu_gart_fini(struct amdgpu_device *adev);
+#ifdef __NetBSD__
+void amdgpu_gart_unbind(struct amdgpu_device *adev, uint64_t gpu_start,
+    unsigned npages);
+int amdgpu_gart_bind(struct amdgpu_device *adev, uint64_t gpu_start,
+    unsigned npages, struct page **pagelist, bus_dmamap_t dmamap,
+    uint32_t flags);
+#else
 void amdgpu_gart_unbind(struct amdgpu_device *adev, uint64_t offset,
                        int pages);
 int amdgpu_gart_bind(struct amdgpu_device *adev, uint64_t offset,
                     int pages, struct page **pagelist,
                     dma_addr_t *dma_addr, uint32_t flags);
+#endif
 
 /*
  * GPU MC structures, functions & helpers
@@ -774,7 +811,12 @@
        /* doorbell mmio */
        resource_size_t         base;
        resource_size_t         size;
+#ifdef __NetBSD__
+       bus_space_tag_t         bst;
+       bus_space_handle_t      bsh;
+#else
        u32 __iomem             *ptr;
+#endif
        u32                     num_doorbells;  /* Number of doorbells actually reserved for amdgpu. */
 };
 
@@ -1296,7 +1338,7 @@
        volatile uint32_t       *wb;
        uint64_t                gpu_addr;
        u32                     num_wb; /* Number of wb slots actually reserved for amdgpu. */
-       unsigned long           used[DIV_ROUND_UP(AMDGPU_MAX_WB, BITS_PER_LONG)];
+       unsigned long           used[DIV_ROUND_UP(AMDGPU_MAX_WB, NBBY*sizeof(unsigned long))];
 };
 
 int amdgpu_wb_get(struct amdgpu_device *adev, u32 *wb);
@@ -1995,9 +2037,16 @@
        uint32_t                        bios_scratch[AMDGPU_BIOS_NUM_SCRATCH];
 
        /* Register/doorbell mmio */
+#ifdef __NetBSD__
+       bus_space_tag_t                 rmmiot;
+       bus_space_handle_t              rmmioh;
+       bus_addr_t                      rmmio_base;
+       bus_size_t                      rmmio_size;
+#else
        resource_size_t                 rmmio_base;
        resource_size_t                 rmmio_size;
        void __iomem                    *rmmio;
+#endif
        /* protects concurrent MM_INDEX/DATA based register access */
        spinlock_t mmio_idx_lock;
        /* protects concurrent SMC based register access */
@@ -2020,8 +2069,14 @@
        spinlock_t audio_endpt_idx_lock;
        amdgpu_block_rreg_t             audio_endpt_rreg;
        amdgpu_block_wreg_t             audio_endpt_wreg;
+#ifdef __NetBSD__
+       bus_space_tag_t                 rio_memt;
+       bus_space_handle_t              rio_memh;
+       bus_size_t                      rio_mem_size;
+#else
        void __iomem                    *rio_mem;
        resource_size_t                 rio_mem_size;
+#endif
        struct amdgpu_doorbell          doorbell;
 
        /* clock/pll info */
@@ -2327,6 +2382,8 @@
 void amdgpu_program_register_sequence(struct amdgpu_device *adev,
                                             const u32 *registers,
                                             const u32 array_size);
+int amdgpu_ttm_init(struct amdgpu_device *adev);
+void amdgpu_ttm_fini(struct amdgpu_device *adev);
 
 bool amdgpu_device_is_px(struct drm_device *dev);
 /* atpx handler */
diff -r faa8f8b34fc8 -r d2bcca3494e3 sys/external/bsd/drm2/dist/drm/amd/amdgpu/amdgpu_acpi.c
--- a/sys/external/bsd/drm2/dist/drm/amd/amdgpu/amdgpu_acpi.c   Mon Aug 27 14:03:38 2018 +0000
+++ b/sys/external/bsd/drm2/dist/drm/amd/amdgpu/amdgpu_acpi.c   Mon Aug 27 14:04:50 2018 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: amdgpu_acpi.c,v 1.2 2018/08/27 04:58:19 riastradh Exp $        */
+/*     $NetBSD: amdgpu_acpi.c,v 1.3 2018/08/27 14:04:50 riastradh Exp $        */
 
 /*
  * Copyright 2012 Advanced Micro Devices, Inc.
@@ -24,7 +24,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: amdgpu_acpi.c,v 1.2 2018/08/27 04:58:19 riastradh Exp $");
+__KERNEL_RCSID(0, "$NetBSD: amdgpu_acpi.c,v 1.3 2018/08/27 14:04:50 riastradh Exp $");
 
 #include <linux/pci.h>
 #include <linux/acpi.h>
@@ -35,12 +35,11 @@
 #include <drm/drm_crtc_helper.h>
 #include "amdgpu.h"
 #include "amdgpu_acpi.h"
+#include "amdgpu_pm.h"
 #include "atom.h"
 
 #define ACPI_AC_CLASS           "ac_adapter"
 
-extern void amdgpu_pm_acpi_event_handler(struct amdgpu_device *adev);
-
 struct atif_verify_interface {
        u16 size;               /* structure size in bytes (includes size field) */
        u16 version;            /* version */
diff -r faa8f8b34fc8 -r d2bcca3494e3 sys/external/bsd/drm2/dist/drm/amd/amdgpu/amdgpu_amdkfd.c
--- a/sys/external/bsd/drm2/dist/drm/amd/amdgpu/amdgpu_amdkfd.c Mon Aug 27 14:03:38 2018 +0000
+++ b/sys/external/bsd/drm2/dist/drm/amd/amdgpu/amdgpu_amdkfd.c Mon Aug 27 14:04:50 2018 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: amdgpu_amdkfd.c,v 1.2 2018/08/27 04:58:19 riastradh Exp $      */
+/*     $NetBSD: amdgpu_amdkfd.c,v 1.3 2018/08/27 14:04:50 riastradh Exp $      */
 
 /*
  * Copyright 2014 Advanced Micro Devices, Inc.
@@ -23,7 +23,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: amdgpu_amdkfd.c,v 1.2 2018/08/27 04:58:19 riastradh Exp $");
+__KERNEL_RCSID(0, "$NetBSD: amdgpu_amdkfd.c,v 1.3 2018/08/27 14:04:50 riastradh Exp $");
 
 #include "amdgpu_amdkfd.h"
 #include "amd_shared.h"
@@ -102,7 +102,9 @@
 {
        if (kgd2kfd) {
                kgd2kfd->exit();
+#ifndef __NetBSD__
                symbol_put(kgd2kfd_init);
+#endif
        }
 }
 
@@ -163,6 +165,7 @@
        return r;
 }
 
+#ifndef __NetBSD__             /* XXX unused? */
 u32 pool_to_domain(enum kgd_memory_pool p)
 {
        switch (p) {
@@ -170,6 +173,7 @@
        default: return AMDGPU_GEM_DOMAIN_GTT;
        }
 }
+#endif
 
 int alloc_gtt_mem(struct kgd_dev *kgd, size_t size,
                        void **mem_obj, uint64_t *gpu_addr,
diff -r faa8f8b34fc8 -r d2bcca3494e3 sys/external/bsd/drm2/dist/drm/amd/amdgpu/amdgpu_amdkfd_gfx_v8.c
--- a/sys/external/bsd/drm2/dist/drm/amd/amdgpu/amdgpu_amdkfd_gfx_v8.c  Mon Aug 27 14:03:38 2018 +0000
+++ b/sys/external/bsd/drm2/dist/drm/amd/amdgpu/amdgpu_amdkfd_gfx_v8.c  Mon Aug 27 14:04:50 2018 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: amdgpu_amdkfd_gfx_v8.c,v 1.2 2018/08/27 04:58:19 riastradh Exp $       */
+/*     $NetBSD: amdgpu_amdkfd_gfx_v8.c,v 1.3 2018/08/27 14:04:50 riastradh Exp $       */
 
 /*
  * Copyright 2014 Advanced Micro Devices, Inc.
@@ -23,7 +23,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: amdgpu_amdkfd_gfx_v8.c,v 1.2 2018/08/27 04:58:19 riastradh Exp $");
+__KERNEL_RCSID(0, "$NetBSD: amdgpu_amdkfd_gfx_v8.c,v 1.3 2018/08/27 14:04:50 riastradh Exp $");
 
 #include <linux/module.h>
 #include <linux/fdtable.h>
@@ -120,9 +120,9 @@
        .get_fw_version = get_fw_version
 };
 
-struct kfd2kgd_calls *amdgpu_amdkfd_gfx_8_0_get_functions()
+struct kfd2kgd_calls *amdgpu_amdkfd_gfx_8_0_get_functions(void)
 {
-       return (struct kfd2kgd_calls *)&kfd2kgd;
+       return (struct kfd2kgd_calls *)__UNCONST(&kfd2kgd); /* XXX */
 }
 
 static inline struct amdgpu_device *get_amdgpu_device(struct kgd_dev *kgd)
diff -r faa8f8b34fc8 -r d2bcca3494e3 sys/external/bsd/drm2/dist/drm/amd/amdgpu/amdgpu_atombios.c
--- a/sys/external/bsd/drm2/dist/drm/amd/amdgpu/amdgpu_atombios.c       Mon Aug 27 14:03:38 2018 +0000
+++ b/sys/external/bsd/drm2/dist/drm/amd/amdgpu/amdgpu_atombios.c       Mon Aug 27 14:04:50 2018 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: amdgpu_atombios.c,v 1.2 2018/08/27 04:58:19 riastradh Exp $    */
+/*     $NetBSD: amdgpu_atombios.c,v 1.3 2018/08/27 14:04:50 riastradh Exp $    */
 
 /*
  * Copyright 2007-8 Advanced Micro Devices, Inc.
@@ -26,8 +26,9 @@
  *          Alex Deucher
  */
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: amdgpu_atombios.c,v 1.2 2018/08/27 04:58:19 riastradh Exp $");
+__KERNEL_RCSID(0, "$NetBSD: amdgpu_atombios.c,v 1.3 2018/08/27 14:04:50 riastradh Exp $");
 
+#include <asm/byteorder.h>
 #include <drm/drmP.h>
 #include <drm/amdgpu_drm.h>
 #include "amdgpu.h"
@@ -104,7 +105,7 @@
        i2c.valid = false;
 
        if (amdgpu_atom_parse_data_header(ctx, index, &size, NULL, NULL, &data_offset)) {
-               i2c_info = (struct _ATOM_GPIO_I2C_INFO *)(ctx->bios + data_offset);
+               i2c_info = (struct _ATOM_GPIO_I2C_INFO *)((char *)ctx->bios + data_offset);



Home | Main Index | Thread Index | Old Index