Commit 0402f75e authored by Mathieu Poirier's avatar Mathieu Poirier Committed by Greg Kroah-Hartman

coresight: tmc-etf: Properly set AUX buffer head in snapshot mode

Unify amongst sink drivers how the AUX ring buffer head is communicated
to user space.  That way the same algorithm in user space can be used to
determine where the latest data is and how much of it to access.
Signed-off-by: default avatarMathieu Poirier <mathieu.poirier@linaro.org>
Reviewed-by: default avatarSuzuki K Poulose <suzuki.poulose@arm.com>
Tested-by: default avatarLeo Yan <leo.yan@linaro.org>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 3ecb0302
...@@ -542,11 +542,15 @@ static unsigned long tmc_update_etf_buffer(struct coresight_device *csdev, ...@@ -542,11 +542,15 @@ static unsigned long tmc_update_etf_buffer(struct coresight_device *csdev,
} }
} }
/* In snapshot mode we have to update the head */ /*
if (buf->snapshot) { * In snapshot mode we simply increment the head by the number of byte
handle->head = (cur * PAGE_SIZE) + offset; * that were written. User space function cs_etm_find_snapshot() will
to_read = buf->nr_pages << PAGE_SHIFT; * figure out how many bytes to get from the AUX buffer based on the
} * position of the head.
*/
if (buf->snapshot)
handle->head += to_read;
CS_LOCK(drvdata->base); CS_LOCK(drvdata->base);
out: out:
spin_unlock_irqrestore(&drvdata->spinlock, flags); spin_unlock_irqrestore(&drvdata->spinlock, flags);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment