mirror of
https://github.com/DreamSourceLab/DSView.git
synced 2025-01-13 13:32:53 +08:00
fix: Loading from a file sometimes crashes
This commit is contained in:
parent
7b479b4019
commit
452906de11
@ -81,6 +81,7 @@ void LogicSnapshot::init()
|
|||||||
{
|
{
|
||||||
std::lock_guard<std::mutex> lock(_mutex);
|
std::lock_guard<std::mutex> lock(_mutex);
|
||||||
init_all();
|
init_all();
|
||||||
|
_is_file = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
void LogicSnapshot::init_all()
|
void LogicSnapshot::init_all()
|
||||||
@ -104,6 +105,7 @@ void LogicSnapshot::clear()
|
|||||||
init_all();
|
init_all();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void LogicSnapshot::capture_ended()
|
void LogicSnapshot::capture_ended()
|
||||||
{
|
{
|
||||||
Snapshot::capture_ended();
|
Snapshot::capture_ended();
|
||||||
@ -117,12 +119,26 @@ void LogicSnapshot::capture_ended()
|
|||||||
int order = 0;
|
int order = 0;
|
||||||
|
|
||||||
for(auto& iter:_ch_data) {
|
for(auto& iter:_ch_data) {
|
||||||
|
|
||||||
|
// If load from file, process the last channel only
|
||||||
|
if (_is_file && order != _last_write_order){
|
||||||
|
order++;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (_is_file && (_last_index0 != index0 || _last_index1 != index1)){
|
||||||
|
// qDebug()<<"deleted index:"<<index0<<index1;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
if (iter[index0].lbp[index1] == NULL){
|
if (iter[index0].lbp[index1] == NULL){
|
||||||
|
// qDebug()<<"crash:"<<index0<<index1;
|
||||||
assert(false);
|
assert(false);
|
||||||
}
|
}
|
||||||
|
|
||||||
const uint64_t *end_ptr = (uint64_t *)iter[index0].lbp[index1] + (LeafBlockSamples / Scale);
|
const uint64_t *end_ptr = (uint64_t *)iter[index0].lbp[index1] + (LeafBlockSamples / Scale);
|
||||||
uint64_t *ptr = (uint64_t *)iter[index0].lbp[index1] + block_offset;
|
uint64_t *ptr = (uint64_t *)iter[index0].lbp[index1] + block_offset;
|
||||||
|
|
||||||
while (ptr < end_ptr)
|
while (ptr < end_ptr)
|
||||||
*ptr++ = 0;
|
*ptr++ = 0;
|
||||||
|
|
||||||
@ -199,13 +215,6 @@ void LogicSnapshot::first_payload(const sr_datafeed_logic &logic, uint64_t total
|
|||||||
for(auto& iter_rn : iter) {
|
for(auto& iter_rn : iter) {
|
||||||
iter_rn.tog = 0;
|
iter_rn.tog = 0;
|
||||||
iter_rn.value = 0;
|
iter_rn.value = 0;
|
||||||
|
|
||||||
for (int i=0; i<(int)Scale; i++){
|
|
||||||
if (iter_rn.lbp[i] != NULL){
|
|
||||||
free(iter_rn.lbp[i]);
|
|
||||||
iter_rn.lbp[i] = NULL;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -400,6 +409,9 @@ void LogicSnapshot::append_split_payload(const sr_datafeed_logic &logic)
|
|||||||
uint16_t order = logic.order;
|
uint16_t order = logic.order;
|
||||||
assert(order < _ch_data.size());
|
assert(order < _ch_data.size());
|
||||||
|
|
||||||
|
_last_write_order = order;
|
||||||
|
_is_file = true;
|
||||||
|
|
||||||
uint64_t sample_read_num = _sample_cnt[order];
|
uint64_t sample_read_num = _sample_cnt[order];
|
||||||
uint64_t write_block_num = _block_cnt[order];
|
uint64_t write_block_num = _block_cnt[order];
|
||||||
|
|
||||||
@ -431,10 +443,14 @@ void LogicSnapshot::append_split_payload(const sr_datafeed_logic &logic)
|
|||||||
}
|
}
|
||||||
|
|
||||||
_ch_data[order][index0].lbp[index1] = pbuf;
|
_ch_data[order][index0].lbp[index1] = pbuf;
|
||||||
|
// qDebug()<<"new:"<<index0<<index1;
|
||||||
}
|
}
|
||||||
|
|
||||||
memset(pbuf, 0, LeafBlockSpace);
|
memset(pbuf, 0, LeafBlockSpace);
|
||||||
write_block_num++;
|
write_block_num++;
|
||||||
|
|
||||||
|
_last_index0 = index0;
|
||||||
|
_last_index1 = index1;
|
||||||
}
|
}
|
||||||
|
|
||||||
_block_cnt[order] = write_block_num;
|
_block_cnt[order] = write_block_num;
|
||||||
@ -470,6 +486,13 @@ void LogicSnapshot::append_split_payload(const sr_datafeed_logic &logic)
|
|||||||
// trim leaf to free space
|
// trim leaf to free space
|
||||||
free(pbuf);
|
free(pbuf);
|
||||||
_ch_data[order][index0].lbp[index1] = NULL;
|
_ch_data[order][index0].lbp[index1] = NULL;
|
||||||
|
|
||||||
|
if (_last_index0 = index0 && _last_index1 == index1){
|
||||||
|
_last_index0 = -1;
|
||||||
|
_last_index1 = -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
// qDebug()<<"del:"<<index0<<index1;
|
||||||
}
|
}
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
|
@ -190,8 +190,12 @@ private:
|
|||||||
uint64_t _block_num;
|
uint64_t _block_num;
|
||||||
uint8_t _byte_fraction;
|
uint8_t _byte_fraction;
|
||||||
uint16_t _ch_fraction;
|
uint16_t _ch_fraction;
|
||||||
void *_src_ptr;
|
void *_src_ptr;
|
||||||
void *_dest_ptr;
|
void *_dest_ptr;
|
||||||
|
bool _is_file;
|
||||||
|
int _last_write_order;
|
||||||
|
uint64_t _last_index0;
|
||||||
|
uint64_t _last_index1;
|
||||||
|
|
||||||
std::vector<uint64_t> _sample_cnt;
|
std::vector<uint64_t> _sample_cnt;
|
||||||
std::vector<uint64_t> _block_cnt;
|
std::vector<uint64_t> _block_cnt;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user