1*4a64e381SAndroid Build Coastguard Worker /*
2*4a64e381SAndroid Build Coastguard Worker * Copyright (c) 2017-2018, The OpenThread Authors.
3*4a64e381SAndroid Build Coastguard Worker * All rights reserved.
4*4a64e381SAndroid Build Coastguard Worker *
5*4a64e381SAndroid Build Coastguard Worker * Redistribution and use in source and binary forms, with or without
6*4a64e381SAndroid Build Coastguard Worker * modification, are permitted provided that the following conditions are met:
7*4a64e381SAndroid Build Coastguard Worker * 1. Redistributions of source code must retain the above copyright
8*4a64e381SAndroid Build Coastguard Worker * notice, this list of conditions and the following disclaimer.
9*4a64e381SAndroid Build Coastguard Worker * 2. Redistributions in binary form must reproduce the above copyright
10*4a64e381SAndroid Build Coastguard Worker * notice, this list of conditions and the following disclaimer in the
11*4a64e381SAndroid Build Coastguard Worker * documentation and/or other materials provided with the distribution.
12*4a64e381SAndroid Build Coastguard Worker * 3. Neither the name of the copyright holder nor the
13*4a64e381SAndroid Build Coastguard Worker * names of its contributors may be used to endorse or promote products
14*4a64e381SAndroid Build Coastguard Worker * derived from this software without specific prior written permission.
15*4a64e381SAndroid Build Coastguard Worker *
16*4a64e381SAndroid Build Coastguard Worker * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
17*4a64e381SAndroid Build Coastguard Worker * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
18*4a64e381SAndroid Build Coastguard Worker * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
19*4a64e381SAndroid Build Coastguard Worker * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
20*4a64e381SAndroid Build Coastguard Worker * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
21*4a64e381SAndroid Build Coastguard Worker * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
22*4a64e381SAndroid Build Coastguard Worker * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
23*4a64e381SAndroid Build Coastguard Worker * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
24*4a64e381SAndroid Build Coastguard Worker * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
25*4a64e381SAndroid Build Coastguard Worker * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
26*4a64e381SAndroid Build Coastguard Worker * POSSIBILITY OF SUCH DAMAGE.
27*4a64e381SAndroid Build Coastguard Worker */
28*4a64e381SAndroid Build Coastguard Worker
29*4a64e381SAndroid Build Coastguard Worker #include "utils/steering_data.hpp"
30*4a64e381SAndroid Build Coastguard Worker
31*4a64e381SAndroid Build Coastguard Worker #include <assert.h>
32*4a64e381SAndroid Build Coastguard Worker #include <mbedtls/sha256.h>
33*4a64e381SAndroid Build Coastguard Worker
34*4a64e381SAndroid Build Coastguard Worker #include "utils/crc16.hpp"
35*4a64e381SAndroid Build Coastguard Worker
36*4a64e381SAndroid Build Coastguard Worker namespace otbr {
37*4a64e381SAndroid Build Coastguard Worker
Init(uint8_t aLength)38*4a64e381SAndroid Build Coastguard Worker void SteeringData::Init(uint8_t aLength)
39*4a64e381SAndroid Build Coastguard Worker {
40*4a64e381SAndroid Build Coastguard Worker assert(aLength <= kMaxSizeOfBloomFilter);
41*4a64e381SAndroid Build Coastguard Worker
42*4a64e381SAndroid Build Coastguard Worker mLength = aLength;
43*4a64e381SAndroid Build Coastguard Worker
44*4a64e381SAndroid Build Coastguard Worker Clear();
45*4a64e381SAndroid Build Coastguard Worker }
46*4a64e381SAndroid Build Coastguard Worker
ComputeJoinerId(const uint8_t * aEui64,uint8_t * aJoinerId)47*4a64e381SAndroid Build Coastguard Worker void SteeringData::ComputeJoinerId(const uint8_t *aEui64, uint8_t *aJoinerId)
48*4a64e381SAndroid Build Coastguard Worker {
49*4a64e381SAndroid Build Coastguard Worker const size_t kSizeHashSha256Output = 32;
50*4a64e381SAndroid Build Coastguard Worker const size_t kSizeEui64 = 8;
51*4a64e381SAndroid Build Coastguard Worker uint8_t hash[kSizeHashSha256Output];
52*4a64e381SAndroid Build Coastguard Worker mbedtls_sha256_context sha256;
53*4a64e381SAndroid Build Coastguard Worker
54*4a64e381SAndroid Build Coastguard Worker mbedtls_sha256_init(&sha256);
55*4a64e381SAndroid Build Coastguard Worker mbedtls_sha256_starts(&sha256, 0);
56*4a64e381SAndroid Build Coastguard Worker mbedtls_sha256_update(&sha256, aEui64, kSizeEui64);
57*4a64e381SAndroid Build Coastguard Worker mbedtls_sha256_finish(&sha256, hash);
58*4a64e381SAndroid Build Coastguard Worker
59*4a64e381SAndroid Build Coastguard Worker memcpy(aJoinerId, hash, kSizeJoinerId);
60*4a64e381SAndroid Build Coastguard Worker aJoinerId[0] |= 2;
61*4a64e381SAndroid Build Coastguard Worker }
62*4a64e381SAndroid Build Coastguard Worker
ComputeBloomFilter(const uint8_t * aJoinerId)63*4a64e381SAndroid Build Coastguard Worker void SteeringData::ComputeBloomFilter(const uint8_t *aJoinerId)
64*4a64e381SAndroid Build Coastguard Worker {
65*4a64e381SAndroid Build Coastguard Worker Crc16 ccitt(Crc16::kCcitt);
66*4a64e381SAndroid Build Coastguard Worker Crc16 ansi(Crc16::kAnsi);
67*4a64e381SAndroid Build Coastguard Worker const uint16_t numBits = mLength * 8;
68*4a64e381SAndroid Build Coastguard Worker
69*4a64e381SAndroid Build Coastguard Worker for (size_t i = 0; i < kSizeJoinerId; i++)
70*4a64e381SAndroid Build Coastguard Worker {
71*4a64e381SAndroid Build Coastguard Worker uint8_t byte = aJoinerId[i];
72*4a64e381SAndroid Build Coastguard Worker ccitt.Update(byte);
73*4a64e381SAndroid Build Coastguard Worker ansi.Update(byte);
74*4a64e381SAndroid Build Coastguard Worker }
75*4a64e381SAndroid Build Coastguard Worker
76*4a64e381SAndroid Build Coastguard Worker SetBit(static_cast<uint8_t>(ccitt.Get() % numBits));
77*4a64e381SAndroid Build Coastguard Worker SetBit(static_cast<uint8_t>(ansi.Get() % numBits));
78*4a64e381SAndroid Build Coastguard Worker }
79*4a64e381SAndroid Build Coastguard Worker
80*4a64e381SAndroid Build Coastguard Worker } // namespace otbr
81