From: Marek Vasut Date: Sun, 20 Apr 2014 18:40:00 +0000 (+0200) Subject: asix-sigma: Clearly separate the sample download X-Git-Tag: libsigrok-0.3.0~41 X-Git-Url: https://sigrok.org/gitaction?a=commitdiff_plain;h=00c8650877a169a04f309f5ecccf7b1b67c75987;p=libsigrok.git asix-sigma: Clearly separate the sample download Reorder the sigma_capture_mode() function so that the part which handles the download of samples from Sigma is clearly separated from the tests if the download should be started. Signed-off-by: Marek Vasut --- diff --git a/hardware/asix-sigma/asix-sigma.c b/hardware/asix-sigma/asix-sigma.c index e7fa7d3d..cdc0988b 100644 --- a/hardware/asix-sigma/asix-sigma.c +++ b/hardware/asix-sigma/asix-sigma.c @@ -1134,23 +1134,26 @@ static int sigma_capture_mode(struct sr_dev_inst *sdi) struct sr_datafeed_packet packet; uint64_t running_msec; struct timeval tv; - int numchunks; uint8_t modestatus; - /* Get the current position. */ - sigma_read_pos(&devc->state.stoppos, &devc->state.triggerpos, - devc); - - numchunks = (devc->state.stoppos + 511) / 512; + uint32_t stoppos, triggerpos; - /* Check if the timer has expired, or memory is full. */ + /* Check if the selected sampling duration passed. */ gettimeofday(&tv, 0); running_msec = (tv.tv_sec - devc->start_tv.tv_sec) * 1000 + - (tv.tv_usec - devc->start_tv.tv_usec) / 1000; + (tv.tv_usec - devc->start_tv.tv_usec) / 1000; + if (running_msec >= devc->limit_msec) + goto download; - if (running_msec < devc->limit_msec && numchunks < 32767) - /* Still capturing. */ - return TRUE; + /* Get the position in DRAM to which the FPGA is writing now. */ + sigma_read_pos(&stoppos, &triggerpos, devc); + /* Test if DRAM is full and if so, download the data. */ + if ((stoppos >> 9) == 32767) + goto download; + + return TRUE; + +download: /* Stop acquisition. */ sigma_set_register(WRITE_MODE, 0x11, devc);