]> git.ipfire.org Git - thirdparty/u-boot.git/commitdiff
fpga: zynq: Use helper function zynq_validate_bitstream
authorSiva Durga Prasad Paladugu <siva.durga.paladugu@xilinx.com>
Thu, 13 Mar 2014 06:27:34 +0000 (11:57 +0530)
committerMichal Simek <michal.simek@xilinx.com>
Mon, 17 Mar 2014 13:34:11 +0000 (14:34 +0100)
Use helper function zynq_validate_bitstream so that the
code can be reused easily for different cases of dma transfer.

Signed-off-by: Siva Durga Prasad Paladugu <sivadur@xilinx.com>
Signed-off-by: Michal Simek <michal.simek@xilinx.com>
drivers/fpga/zynqpl.c

index 813c89abe25718690f813c59686d85ca756c23b4..e53ab7641c00be1e773c2786b85ad709d6dd2b63 100644 (file)
@@ -321,20 +321,20 @@ static u32 *zynq_align_dma_buffer(u32 *buf, u32 len, u32 swap)
        return buf;
 }
 
-int zynq_load(Xilinx_desc *desc, const void *buf, size_t bsize)
+static int zynq_validate_bitstream(Xilinx_desc *desc, const void *buf,
+                                  size_t bsize, u32 blocksize, u32 *swap,
+                                  u32 *partialbit)
 {
-       unsigned long ts; /* Timestamp */
-       u32 partialbit = 0;
-       u32 isr_status, swap, diff;
        u32 *buf_start;
+       u32 diff;
 
        /* Detect if we are going working with partial or full bitstream */
        if (bsize != desc->size) {
                printf("%s: Working with partial bitstream\n", __func__);
-               partialbit = 1;
+               *partialbit = 1;
        }
+       buf_start = check_data((u8 *)buf, blocksize, swap);
 
-       buf_start = check_data((u8 *)buf, bsize, &swap);
        if (!buf_start)
                return FPGA_FAIL;
 
@@ -352,7 +352,24 @@ int zynq_load(Xilinx_desc *desc, const void *buf, size_t bsize)
                return FPGA_FAIL;
        }
 
-       if (zynq_dma_xfer_init(partialbit))
+       if (zynq_dma_xfer_init(*partialbit))
+               return FPGA_FAIL;
+
+       return 0;
+}
+
+int zynq_load(Xilinx_desc *desc, const void *buf, size_t bsize)
+{
+       unsigned long ts; /* Timestamp */
+       u32 partialbit = 0;
+       u32 isr_status, swap;
+
+       /*
+        * send bsize inplace of blocksize as it was not a bitstream
+        * in chunks
+        */
+       if (zynq_validate_bitstream(desc, buf, bsize, bsize, &swap,
+                                   &partialbit))
                return FPGA_FAIL;
 
        buf = zynq_align_dma_buffer((u32 *)buf, bsize, swap);