123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143 |
- /* vim: set expandtab ts=4 sw=4: */
- /*
- * You may redistribute this program and/or modify it under the terms of
- * the GNU General Public License as published by the Free Software Foundation,
- * either version 3 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/>.
- */
- #include "crypto/random/Random.h"
- #include "crypto/CryptoAuth.h"
- #include "io/FileWriter.h"
- #include "benc/Object.h"
- #include "memory/MallocAllocator.h"
- #include "util/Bits.h"
- #include "util/Hex.h"
- #include "util/Endian.h"
- #include "util/events/Time.h"
- #include "util/events/EventBase.h"
- #include "wire/Error.h"
- #include "util/Assert.h"
- #include <stdio.h>
- static const uint8_t* privateKey = (uint8_t*)
- "\x20\xca\x45\xd9\x5b\xbf\xca\xe7\x35\x3c\xd2\xdf\xfa\x12\x84\x4b"
- "\x4e\xff\xbe\x7d\x39\xd8\x4d\x8e\x14\x2b\x9d\x21\x89\x5b\x38\x09";
- static const uint8_t* publicKey = (uint8_t*)
- "\x51\xaf\x8d\xd9\x35\xe8\x61\x86\x3e\x94\x2b\x1b\x6d\x21\x22\xe0"
- "\x2f\xb2\xd0\x88\x20\xbb\xf3\xf0\x6f\xcd\xe5\x85\x30\xe0\x08\x34";
- struct Context
- {
- uint8_t padding[256];
- uint8_t buffer[2048];
- struct Message message;
- struct CryptoAuth* ca1;
- struct CryptoAuth* ca2;
- struct Interface if1;
- struct Interface* cif1;
- struct Message* if1Incoming;
- struct Interface if2;
- struct Interface* cif2;
- struct Message* if2Incoming;
- struct EventBase* base;
- };
- static inline uint8_t transferMessage(struct Message* message, struct Interface* iface)
- {
- struct Interface* otherIface = iface->senderContext;
- return otherIface->receiveMessage(message, otherIface);
- }
- static inline void setupMessage(struct Context* ctx, uint16_t length)
- {
- ctx->message.bytes = ctx->buffer;
- ctx->message.padding = 256;
- ctx->message.length = length;
- }
- static const char* KEY = "key";
- static const char* HELLO = "hello";
- static const char* TRAFFIC = "data";
- static inline void sendMessages(struct Context* ctx,
- int count,
- int size,
- const char* type)
- {
- printf("Test sending %d %d byte\t%s packets\n", count, size, type);
- ctx->cif2 = CryptoAuth_wrapInterface(&ctx->if2, NULL, NULL, false, "cif2", ctx->ca2);
- ctx->cif1 = CryptoAuth_wrapInterface(&ctx->if1, publicKey, NULL, false, "cif1", ctx->ca1);
- uint64_t startTime = Time_hrtime();
- if (type != HELLO) {
- setupMessage(ctx, size);
- ctx->cif1->sendMessage(&ctx->message, ctx->cif1);
- if (type == TRAFFIC) {
- setupMessage(ctx, size);
- ctx->cif2->sendMessage(&ctx->message, ctx->cif2);
- }
- }
- for (int i = 0; i < count; i++) {
- setupMessage(ctx, size);
- if (type == KEY) {
- ctx->cif2->sendMessage(&ctx->message, ctx->cif2);
- } else {
- ctx->cif1->sendMessage(&ctx->message, ctx->cif1);
- }
- }
- uint64_t endTimes = Time_hrtime();
- uint64_t time = (endTimes - startTime) / 1000000;
- uint64_t kbSent = (size * count * 8) / 1024;
- // same as kbSent / (time / 1024) (converting time to seconds)
- uint64_t kbps = (kbSent * 1024) / time;
- printf("\tFinished in %dms. %d Kb/s\n\n", (int)time, (int)kbps);
- }
- void CryptoAuth_benchmark(struct EventBase* base,
- struct Log* logger,
- struct Allocator* alloc)
- {
- struct Random* rand = Random_new(alloc, logger, NULL);
- struct Context ctx = {
- .ca1 = CryptoAuth_new(alloc, NULL, base, NULL, rand),
- .ca2 = CryptoAuth_new(alloc, privateKey, base, NULL, rand),
- .if1 = {
- .sendMessage = transferMessage,
- .senderContext = &ctx.if2,
- .allocator = alloc
- },
- .if2 = {
- .sendMessage = transferMessage,
- .senderContext = &ctx.if1,
- .allocator = alloc
- },
- .base = base
- };
- printf("These metrics are speed of encryption and decryption similar to the usage pattern\n"
- "when decrypting a packet, switching it, and re-encrypting it with another key.\n");
- sendMessages(&ctx, 1000, 64, HELLO);
- sendMessages(&ctx, 1000, 1500, HELLO);
- sendMessages(&ctx, 1000, 64, KEY);
- sendMessages(&ctx, 1000, 1500, KEY);
- sendMessages(&ctx, 100000, 64, TRAFFIC);
- printf("This is the switch configuration so this indicates expected switch throughput:\n");
- sendMessages(&ctx, 100000, 1500, TRAFFIC);
- }
|