diff options
| author | Carl Hetherington <cth@carlh.net> | 2020-07-11 00:12:50 +0200 |
|---|---|---|
| committer | Carl Hetherington <cth@carlh.net> | 2020-07-11 21:14:02 +0200 |
| commit | aa646c58267a6bd2580f3cb30674f4ebd0ed6db7 (patch) | |
| tree | 2abc9a3123bf4f2470b093f0332ddeccb1390b0d /src/bitstream.cc | |
| parent | 1b6f847eddca54ed223b22858c19c987aa61c2df (diff) | |
Allow creation of ATMOS sync on channel 14.atmos
Diffstat (limited to 'src/bitstream.cc')
| -rw-r--r-- | src/bitstream.cc | 89 |
1 files changed, 89 insertions, 0 deletions
diff --git a/src/bitstream.cc b/src/bitstream.cc new file mode 100644 index 00000000..13d5ae4b --- /dev/null +++ b/src/bitstream.cc @@ -0,0 +1,89 @@ +/* + Copyright (C) 2020 Carl Hetherington <cth@carlh.net> + + This file is part of libdcp. + + libdcp 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. + + libdcp 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 libdcp. If not, see <http://www.gnu.org/licenses/>. + + In addition, as a special exception, the copyright holders give + permission to link the code of portions of this program with the + OpenSSL library under certain conditions as described in each + individual source file, and distribute linked combinations + including the two. + + You must obey the GNU General Public License in all respects + for all of the code used other than OpenSSL. If you modify + file(s) with this exception, you may extend this exception to your + version of the file(s), but you are not obligated to do so. If you + do not wish to do so, delete this exception statement from your + version. If you delete this exception statement from all source + files in the program, then also delete it here. +*/ + + +#include "bitstream.h" +#include "dcp_assert.h" +#include <iostream> +#include <stdint.h> +#include <string.h> + + +using namespace dcp; + + +void +Bitstream::write_bit (bool bit) +{ + if (_crc) { + _crc->process_bit (bit); + } + _data.push_back (bit); +} + + +void +Bitstream::write_from_byte (uint8_t byte, int bits) +{ + for (int i = bits - 1; i >= 0; --i) { + write_bit ((byte >> i) & 1); + } +} + + +void +Bitstream::write_from_word (uint32_t word, int bits) +{ + for (int i = bits - 1; i >= 0; --i) { + write_bit ((word >> i) & 1); + } +} + + +void +Bitstream::start_crc (uint16_t poly) +{ + DCP_ASSERT (!static_cast<bool>(_crc)); + _crc = boost::crc_basic<16> (poly); +} + + +void +Bitstream::write_crc () +{ + DCP_ASSERT (static_cast<bool>(_crc)); + uint16_t crc = _crc->checksum(); + write_from_word (crc, 16); + _crc = boost::none; +} + |
