struct dma_fence *fence;
        int ret;
 
-       if (fence_id > queue->last_fence) {
+       if (fence_after(fence_id, queue->last_fence)) {
                DRM_ERROR_RATELIMITED("waiting on invalid fence: %u (of %u)\n",
                                      fence_id, queue->last_fence);
                return -EINVAL;
 
 
 struct dma_fence * msm_fence_alloc(struct msm_fence_context *fctx);
 
+static inline bool
+fence_before(uint32_t a, uint32_t b)
+{
+   return (int32_t)(a - b) < 0;
+}
+
+static inline bool
+fence_after(uint32_t a, uint32_t b)
+{
+   return (int32_t)(a - b) > 0;
+}
+
 #endif
 
 
        spin_lock_irqsave(&ring->submit_lock, flags);
        list_for_each_entry(submit, &ring->submits, node) {
-               if (submit->seqno > fence)
+               if (fence_after(submit->seqno, fence))
                        break;
 
                msm_update_fence(submit->ring->fctx,
        if (fence != ring->hangcheck_fence) {
                /* some progress has been made.. ya! */
                ring->hangcheck_fence = fence;
-       } else if (fence < ring->seqno) {
+       } else if (fence_before(fence, ring->seqno)) {
                /* no progress and not done.. hung! */
                ring->hangcheck_fence = fence;
                DRM_DEV_ERROR(dev->dev, "%s: hangcheck detected gpu lockup rb %d!\n",
        }
 
        /* if still more pending work, reset the hangcheck timer: */
-       if (ring->seqno > ring->hangcheck_fence)
+       if (fence_after(ring->seqno, ring->hangcheck_fence))
                hangcheck_timer_reset(gpu);
 
        /* workaround for missing irq: */
 
        for (i = 0; i < gpu->nr_rings; i++) {
                struct msm_ringbuffer *ring = gpu->rb[i];
 
-               if (ring->seqno > ring->memptrs->fence)
+               if (fence_after(ring->seqno, ring->memptrs->fence))
                        return true;
        }