diff options
author | Uwe Hermann <uwe@hermann-uwe.de> | 2013-02-02 12:18:29 +0100 |
---|---|---|
committer | Uwe Hermann <uwe@hermann-uwe.de> | 2013-02-02 12:18:29 +0100 |
commit | 38ff5046e8344940601f2b9eb5d8dbfbef975c30 (patch) | |
tree | 4092243cbd0b9b59ed2bac8acf6b00a0edf8d0a0 /type_logic.c | |
parent | de5a05f120d6d7f1e20265e9e264ac859c9c5020 (diff) | |
download | libsigrokdecode-38ff5046e8344940601f2b9eb5d8dbfbef975c30.tar.gz libsigrokdecode-38ff5046e8344940601f2b9eb5d8dbfbef975c30.zip |
Bring back temporarily reverted changes.
Diffstat (limited to 'type_logic.c')
-rw-r--r-- | type_logic.c | 17 |
1 files changed, 16 insertions, 1 deletions
diff --git a/type_logic.c b/type_logic.c index b284ebf..098e34d 100644 --- a/type_logic.c +++ b/type_logic.c @@ -45,11 +45,26 @@ static PyObject *srd_logic_iternext(PyObject *self) * Convert the bit-packed sample to an array of bytes, with only 0x01 * and 0x00 values, so the PD doesn't need to do any bitshifting. */ + + /* Get probe bits into the 'sample' variable. */ memcpy(&sample, logic->inbuf + logic->itercnt * logic->di->data_unitsize, logic->di->data_unitsize); - for (i = 0; i < logic->di->dec_num_probes; i++) + + /* All probe values (required + optional) are pre-set to 42. */ + memset(probe_samples, 42, logic->di->dec_num_probes); + /* TODO: None or -1 in Python would be better. */ + + /* + * Set probe values of specified/used probes to their resp. values. + * Unused probe values (those not specified by the user) remain at 42. + */ + for (i = 0; i < logic->di->dec_num_probes; i++) { + /* A probemap value of -1 means "unused optional probe". */ + if (logic->di->dec_probemap[i] == -1) + continue; probe_samples[i] = sample & (1 << logic->di->dec_probemap[i]) ? 1 : 0; + } /* Prepare the next samplenum/sample list in this iteration. */ py_samplenum = |