提交 e4eca2a1 编写于 作者: L Laurent FERT 提交者: Greg Kroah-Hartman

intel_th: msu: Fix offset for wrapped block

Fix offset for the second pass on the wrapped block when iterating over
memory in multi-block mode, otherwise wrong part of the block will get
copied.
Signed-off-by: NLaurent FERT <laurent.fert@intel.com>
Signed-off-by: NAlexander Shishkin <alexander.shishkin@linux.intel.com>
Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
上级 4d02ceff
...@@ -408,7 +408,7 @@ msc_buffer_iterate(struct msc_iter *iter, size_t size, void *data, ...@@ -408,7 +408,7 @@ msc_buffer_iterate(struct msc_iter *iter, size_t size, void *data,
* Second time (wrap_count==1), it's just like any other block, * Second time (wrap_count==1), it's just like any other block,
* containing data in the range of [MSC_BDESC..data_bytes]. * containing data in the range of [MSC_BDESC..data_bytes].
*/ */
if (iter->block == iter->start_block && iter->wrap_count) { if (iter->block == iter->start_block && iter->wrap_count == 2) {
tocopy = DATA_IN_PAGE - data_bytes; tocopy = DATA_IN_PAGE - data_bytes;
src += data_bytes; src += data_bytes;
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册