This repository has been archived by the owner on Jun 3, 2019. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 33
/
Copy pathid.c
96 lines (87 loc) · 2.93 KB
/
id.c
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
#include "freertps/id.h"
#include <stdio.h>
#include <string.h>
#include "freertps/bswap.h"
static unsigned g_frudp_next_user_eid = 1;
const frudp_guid_t g_frudp_guid_unknown = { .prefix = { .prefix = {0} },
.eid = { .u = 0 } };
const char *frudp_vendor(const frudp_vid_t vid)
{
switch (vid)
{
case 0x0101: return "RTI Connext";
case 0x0102: return "PrismTech OpenSplice";
case 0x0103: return "OCI OpenDDS";
case 0x0104: return "MilSoft";
case 0x0105: return "Gallium InterCOM";
case 0x0106: return "TwinOaks CoreDX";
case 0x0107: return "Lakota Technical Systems";
case 0x0108: return "ICOUP Consulting";
case 0x0109: return "ETRI";
case 0x010a: return "RTI Connext Micro";
case 0x010b: return "PrismTech Vortex Cafe";
case 0x010c: return "PrismTech Vortex Gateway";
case 0x010d: return "PrismTech Vortex Lite";
case 0x010e: return "Technicolor Qeo";
case 0x010f: return "eProsima";
case 0x0120: return "PrismTech Vortex Cloud";
case FREERTPS_VENDOR_ID: return "freertps";
default: return "unknown";
}
}
bool frudp_guid_prefix_identical(frudp_guid_prefix_t * const a,
frudp_guid_prefix_t * const b)
{
for (int i = 0; i < FRUDP_GUID_PREFIX_LEN; i++)
if (a->prefix[i] != b->prefix[i])
return false;
return true;
}
bool frudp_guid_identical(const frudp_guid_t * const a,
const frudp_guid_t * const b)
{
if (a->eid.u != b->eid.u)
return false;
for (int i = 0; i < FRUDP_GUID_PREFIX_LEN; i++)
if (a->prefix.prefix[i] != b->prefix.prefix[i])
return false;
return true;
}
void frudp_print_guid_prefix(const frudp_guid_prefix_t *p)
{
printf("%02x%02x%02x%02x:%02x%02x%02x%02x:%02x%02x%02x%02x",
(unsigned)p->prefix[0],
(unsigned)p->prefix[1],
(unsigned)p->prefix[2],
(unsigned)p->prefix[3],
(unsigned)p->prefix[4],
(unsigned)p->prefix[5],
(unsigned)p->prefix[6],
(unsigned)p->prefix[7],
(unsigned)p->prefix[8],
(unsigned)p->prefix[9],
(unsigned)p->prefix[10],
(unsigned)p->prefix[11]);
}
void frudp_stuff_guid(frudp_guid_t *guid,
const frudp_guid_prefix_t *prefix,
const frudp_eid_t *id)
{
memcpy(&guid->prefix, prefix, sizeof(frudp_guid_prefix_t));
guid->eid = *id;
}
void frudp_print_guid(const frudp_guid_t *guid)
{
frudp_print_guid_prefix(&guid->prefix);
printf(":%08x", (unsigned)freertps_htonl(guid->eid.u));
}
frudp_eid_t frudp_create_user_id(const uint8_t entity_kind)
{
printf("frudp_create_user_id()\r\n");
frudp_eid_t eid;
eid.s.kind = entity_kind; // entity kind must be set by caller of this functionmust be overwritten by FRUDP_ENTITY_KIND_USER_READER_NO_KEY; // has key? dunno
eid.s.key[0] = 0;
eid.s.key[1] = 0; // todo: >8 bit ID's
eid.s.key[2] = g_frudp_next_user_eid++;
return eid;
}