return 0;
 }
 
-static int scatter_list_length(struct scatterlist *sg)
+static u64 scatter_list_length(struct scatterlist *sg)
 {
-       int len = 0;
+       u64 len = 0;
 
        while (sg && sg_dma_len(sg)) {
                len += sg_dma_len(sg);
        return len;
 }
 
-static void
+static int
 calculate_chunk_sz(struct drm_i915_private *i915, bool src_is_lmem,
-                  int *src_sz, u32 bytes_to_cpy, u32 ccs_bytes_to_cpy)
+                  u64 bytes_to_cpy, u64 ccs_bytes_to_cpy)
 {
-       if (ccs_bytes_to_cpy) {
-               if (!src_is_lmem)
-                       /*
-                        * When CHUNK_SZ is passed all the pages upto CHUNK_SZ
-                        * will be taken for the blt. in Flat-ccs supported
-                        * platform Smem obj will have more pages than required
-                        * for main meory hence limit it to the required size
-                        * for main memory
-                        */
-                       *src_sz = min_t(int, bytes_to_cpy, CHUNK_SZ);
-       } else { /* ccs handling is not required */
-               *src_sz = CHUNK_SZ;
-       }
+       if (ccs_bytes_to_cpy && !src_is_lmem)
+               /*
+                * When CHUNK_SZ is passed all the pages upto CHUNK_SZ
+                * will be taken for the blt. in Flat-ccs supported
+                * platform Smem obj will have more pages than required
+                * for main meory hence limit it to the required size
+                * for main memory
+                */
+               return min_t(u64, bytes_to_cpy, CHUNK_SZ);
+       else
+               return CHUNK_SZ;
 }
 
-static void get_ccs_sg_sgt(struct sgt_dma *it, u32 bytes_to_cpy)
+static void get_ccs_sg_sgt(struct sgt_dma *it, u64 bytes_to_cpy)
 {
-       u32 len;
+       u64 len;
 
        do {
                GEM_BUG_ON(!it->sg || !sg_dma_len(it->sg));
 {
        struct sgt_dma it_src = sg_sgt(src), it_dst = sg_sgt(dst), it_ccs;
        struct drm_i915_private *i915 = ce->engine->i915;
-       u32 ccs_bytes_to_cpy = 0, bytes_to_cpy;
+       u64 ccs_bytes_to_cpy = 0, bytes_to_cpy;
        enum i915_cache_level ccs_cache_level;
        u32 src_offset, dst_offset;
        u8 src_access, dst_access;
        struct i915_request *rq;
-       int src_sz, dst_sz;
+       u64 src_sz, dst_sz;
        bool ccs_is_src, overwrite_ccs;
        int err;
 
                if (err)
                        goto out_rq;
 
-               calculate_chunk_sz(i915, src_is_lmem, &src_sz,
-                                  bytes_to_cpy, ccs_bytes_to_cpy);
+               src_sz = calculate_chunk_sz(i915, src_is_lmem,
+                                           bytes_to_cpy, ccs_bytes_to_cpy);
 
                len = emit_pte(rq, &it_src, src_cache_level, src_is_lmem,
                               src_offset, src_sz);