1
0
mirror of https://github.com/biergaizi/codecrypt synced 2024-06-20 13:58:17 +00:00
codecrypt/src/sc.h
Tom Li 7021f6c734
sc.h: correct access violation in load_key_vector(), close #2.
In load_key_vector(), the program passes a std::vector<byte> to
a C-style function, load_key (const byte*begin, const byte*end)
by creating references

    load_key (& (K[0]), & (K[K.size()]));

However, accessing the one-past-the-last element in a std::vector
via [] is not allowed in C++, it triggers an assertion failure.

    Assertion '__builtin_expect(__n < this->size(), true)' failed.

In this commit, we use K.data() and K.data() + K.size() to expose
the underlying pointers and pass them to the C function.

Signed-off-by: Tom Li <tomli@tomli.me>
2019-01-02 11:42:04 +08:00

61 lines
1.5 KiB
C++

/*
* This file is part of Codecrypt.
*
* Copyright (C) 2013-2016 Mirek Kratochvil <exa.exa@gmail.com>
*
* Codecrypt is free software: you can redistribute it and/or modify it
* under the terms of the GNU Lesser General Public License as published by
* the Free Software Foundation, either version 3 of the License, or (at
* your option) any later version.
*
* Codecrypt 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 Lesser General Public
* License for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with Codecrypt. If not, see <http://www.gnu.org/licenses/>.
*/
#ifndef _ccr_sc_h_
#define _ccr_sc_h_
#include "types.h"
#include "factoryof.h"
#include <sys/types.h>
#include <vector>
#include <map>
#include <string>
class streamcipher
{
public:
virtual void init() = 0;
virtual void clear() = 0;
virtual void load_key (const byte*begin, const byte*end) = 0;
virtual byte gen() = 0;
virtual void gen (size_t n, byte*out) = 0;
//advisory values for effective usage
virtual size_t key_size() = 0;
virtual size_t block_size() = 0;
virtual ~streamcipher() {}
void discard (size_t n) {
gen (n, 0);
}
void load_key_vector (const std::vector<byte>&K) {
load_key (K.data(), K.data() + K.size());
}
typedef std::map<std::string, factoryof<streamcipher>*> suite_t;
static suite_t& suite();
};
#endif