gpu: host1x: Rework CPU syncpoint increment
authorArto Merilainen <amerilainen@nvidia.com>
Wed, 29 May 2013 10:26:08 +0000 (13:26 +0300)
committerThierry Reding <thierry.reding@gmail.com>
Sat, 22 Jun 2013 10:43:55 +0000 (12:43 +0200)
This patch merges host1x_syncpt_cpu_incr to host1x_syncpt_incr() as
they are in practise doing the same thing. host1x_syncpt_incr() is
also modified to return error codes. User space interface is modified
accordingly to pass return values.

Signed-off-by: Arto Merilainen <amerilainen@nvidia.com>
Acked-By: Terje Bergstrom <tbergstrom@nvidia.com>
Signed-off-by: Thierry Reding <thierry.reding@gmail.com>
drivers/gpu/host1x/dev.h
drivers/gpu/host1x/drm/drm.c
drivers/gpu/host1x/hw/cdma_hw.c
drivers/gpu/host1x/hw/syncpt_hw.c
drivers/gpu/host1x/syncpt.c
drivers/gpu/host1x/syncpt.h

index a1607d6e135b0de0b2ea7ab5db16d75595fdcfb6..790ddf114e58e46d33794a9bb5dc95ae07520e9f 100644 (file)
@@ -73,7 +73,7 @@ struct host1x_syncpt_ops {
        void (*restore_wait_base)(struct host1x_syncpt *syncpt);
        void (*load_wait_base)(struct host1x_syncpt *syncpt);
        u32 (*load)(struct host1x_syncpt *syncpt);
-       void (*cpu_incr)(struct host1x_syncpt *syncpt);
+       int (*cpu_incr)(struct host1x_syncpt *syncpt);
        int (*patch_wait)(struct host1x_syncpt *syncpt, void *patch_addr);
 };
 
@@ -157,10 +157,10 @@ static inline u32 host1x_hw_syncpt_load(struct host1x *host,
        return host->syncpt_op->load(sp);
 }
 
-static inline void host1x_hw_syncpt_cpu_incr(struct host1x *host,
-                                            struct host1x_syncpt *sp)
+static inline int host1x_hw_syncpt_cpu_incr(struct host1x *host,
+                                           struct host1x_syncpt *sp)
 {
-       host->syncpt_op->cpu_incr(sp);
+       return host->syncpt_op->cpu_incr(sp);
 }
 
 static inline int host1x_hw_syncpt_patch_wait(struct host1x *host,
index c171a07f47bf4a36fa4fd7575364256f6ecb09ac..e184b00faacdfe3688dd262a1bbac8f4346a6643 100644 (file)
@@ -387,8 +387,7 @@ static int tegra_syncpt_incr(struct drm_device *drm, void *data,
        if (!sp)
                return -EINVAL;
 
-       host1x_syncpt_incr(sp);
-       return 0;
+       return host1x_syncpt_incr(sp);
 }
 
 static int tegra_syncpt_wait(struct drm_device *drm, void *data,
index 590b69d91dabf2ce19d119f34642a59cd5e8b507..2ee4ad55c4dba344cbb28d72d8febecd7f0181ee 100644 (file)
@@ -44,7 +44,7 @@ static void cdma_timeout_cpu_incr(struct host1x_cdma *cdma, u32 getptr,
        u32 i;
 
        for (i = 0; i < syncpt_incrs; i++)
-               host1x_syncpt_cpu_incr(cdma->timeout.syncpt);
+               host1x_syncpt_incr(cdma->timeout.syncpt);
 
        /* after CPU incr, ensure shadow is up to date */
        host1x_syncpt_load(cdma->timeout.syncpt);
index 61174990102a0beff4d32b297ade6e543a51a042..0cf6095d33678f51da127f4feac313f9422bc9e8 100644 (file)
@@ -77,21 +77,19 @@ static u32 syncpt_load(struct host1x_syncpt *sp)
  * Write a cpu syncpoint increment to the hardware, without touching
  * the cache.
  */
-static void syncpt_cpu_incr(struct host1x_syncpt *sp)
+static int syncpt_cpu_incr(struct host1x_syncpt *sp)
 {
        struct host1x *host = sp->host;
        u32 reg_offset = sp->id / 32;
 
        if (!host1x_syncpt_client_managed(sp) &&
-           host1x_syncpt_idle(sp)) {
-               dev_err(host->dev, "Trying to increment syncpoint id %d beyond max\n",
-                       sp->id);
-               host1x_debug_dump(sp->host);
-               return;
-       }
+           host1x_syncpt_idle(sp))
+               return -EINVAL;
        host1x_sync_writel(host, BIT_MASK(sp->id),
                           HOST1X_SYNC_SYNCPT_CPU_INCR(reg_offset));
        wmb();
+
+       return 0;
 }
 
 /* remove a wait pointed to by patch_addr */
index 27201b51d8086b70a2bb05a97cc6864fe10d5514..409745b949dbfa7d9ecd897409147ae0225623e3 100644 (file)
@@ -128,23 +128,12 @@ u32 host1x_syncpt_load_wait_base(struct host1x_syncpt *sp)
        return val;
 }
 
-/*
- * Write a cpu syncpoint increment to the hardware, without touching
- * the cache. Caller is responsible for host being powered.
- */
-void host1x_syncpt_cpu_incr(struct host1x_syncpt *sp)
-{
-       host1x_hw_syncpt_cpu_incr(sp->host, sp);
-}
-
 /*
  * Increment syncpoint value from cpu, updating cache
  */
-void host1x_syncpt_incr(struct host1x_syncpt *sp)
+int host1x_syncpt_incr(struct host1x_syncpt *sp)
 {
-       if (host1x_syncpt_client_managed(sp))
-               host1x_syncpt_incr_max(sp, 1);
-       host1x_syncpt_cpu_incr(sp);
+       return host1x_hw_syncpt_cpu_incr(sp->host, sp);
 }
 
 /*
index d00e758352eba649fc644420dcab9671dea4a691..267c0b9d3647d24f2a3bf7dc81504eacaf957005 100644 (file)
@@ -115,9 +115,6 @@ static inline bool host1x_syncpt_idle(struct host1x_syncpt *sp)
 /* Return pointer to struct denoting sync point id. */
 struct host1x_syncpt *host1x_syncpt_get(struct host1x *host, u32 id);
 
-/* Request incrementing a sync point. */
-void host1x_syncpt_cpu_incr(struct host1x_syncpt *sp);
-
 /* Load current value from hardware to the shadow register. */
 u32 host1x_syncpt_load(struct host1x_syncpt *sp);
 
@@ -133,8 +130,8 @@ void host1x_syncpt_restore(struct host1x *host);
 /* Read current wait base value into shadow register and return it. */
 u32 host1x_syncpt_load_wait_base(struct host1x_syncpt *sp);
 
-/* Increment sync point and its max. */
-void host1x_syncpt_incr(struct host1x_syncpt *sp);
+/* Request incrementing a sync point. */
+int host1x_syncpt_incr(struct host1x_syncpt *sp);
 
 /* Indicate future operations by incrementing the sync point max. */
 u32 host1x_syncpt_incr_max(struct host1x_syncpt *sp, u32 incrs);