summaryrefslogtreecommitdiff
path: root/decoders/pjdl/__init__.py
diff options
context:
space:
mode:
authorGerhard Sittig <gerhard.sittig@gmx.net>2020-06-15 13:37:18 +0200
committerGerhard Sittig <gerhard.sittig@gmx.net>2020-06-24 19:09:54 +0200
commitdb18ba49bcbe38a9a67297207d821bf0e1e9dc4c (patch)
tree59179cf166cbd0d727d9afd46ae867a3c75f6f5a /decoders/pjdl/__init__.py
parent36d499e09aaf4e6145a32b732632a99fec1b3d57 (diff)
downloadlibsigrokdecode-db18ba49bcbe38a9a67297207d821bf0e1e9dc4c.tar.gz
libsigrokdecode-db18ba49bcbe38a9a67297207d821bf0e1e9dc4c.zip
pjdl: introduce decoder for PJON single wire serial link layer
Introduce a protocol decoder which generates 'pjon-link' output from 'logic' input by interpreting the PJDL single wire serial communication link layer of the PJON protocol stack. This decoder extracts frame markers, data bytes, as well as their pad/sync decoration. Inspection of data values, or checks for frame validity remain the responsibility of a stacked decoder which is shared among several link layer types. This implementation "violates" the PJDL spec in those places where the spec is incomplete or vague, and real world traffic would not decode at all when the strict letter of the spec is applied instead of its spirit. When in doubt, the decoder implementation errs to the usability side. Carrier sense detection is incomplete in this version. Data extraction works for all currently available captures. Recovery from synchronization loss after glitches is acceptable. Glitch filtering is missing (the spec is silent on this subject).
Diffstat (limited to 'decoders/pjdl/__init__.py')
-rw-r--r--decoders/pjdl/__init__.py27
1 files changed, 27 insertions, 0 deletions
diff --git a/decoders/pjdl/__init__.py b/decoders/pjdl/__init__.py
new file mode 100644
index 0000000..c3cc855
--- /dev/null
+++ b/decoders/pjdl/__init__.py
@@ -0,0 +1,27 @@
+##
+## This file is part of the libsigrokdecode project.
+##
+## Copyright (C) 2020 Gerhard Sittig <gerhard.sittig@gmx.net>
+##
+## This program is free software; you can redistribute it and/or modify
+## it under the terms of the GNU General Public License as published by
+## the Free Software Foundation; either version 2 of the License, or
+## (at your option) any later version.
+##
+## This program is distributed in the hope that it will be useful,
+## but WITHOUT ANY WARRANTY; without even the implied warranty of
+## MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+## GNU General Public License for more details.
+##
+## You should have received a copy of the GNU General Public License
+## along with this program; if not, see <http://www.gnu.org/licenses/>.
+##
+
+'''
+This protocol decoder interprets the PJDL data link of the PJON protocol.
+Bytes and frames get extracted from single wire serial communication
+(which often is referred to as "software bitbang" because that's what
+the Arduino reference implementation happens to do).
+'''
+
+from .pd import Decoder