2011-11-06 14:37:06 +08:00
|
|
|
/**
|
|
|
|
* @file util.c
|
|
|
|
* @note Copyright (C) 2011 Richard Cochran <richardcochran@gmail.com>
|
|
|
|
*
|
|
|
|
* This program 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.
|
|
|
|
*
|
|
|
|
* 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, write to the Free Software Foundation, Inc.,
|
|
|
|
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
|
|
|
*/
|
|
|
|
#include <stdio.h>
|
2013-02-04 06:01:50 +08:00
|
|
|
#include <string.h>
|
2011-11-06 14:37:06 +08:00
|
|
|
|
2012-08-05 20:11:18 +08:00
|
|
|
#include "sk.h"
|
2011-11-06 14:37:06 +08:00
|
|
|
#include "util.h"
|
|
|
|
|
|
|
|
char *ps_str[] = {
|
|
|
|
"NONE",
|
|
|
|
"INITIALIZING",
|
|
|
|
"FAULTY",
|
|
|
|
"DISABLED",
|
|
|
|
"LISTENING",
|
|
|
|
"PRE_MASTER",
|
|
|
|
"MASTER",
|
|
|
|
"PASSIVE",
|
|
|
|
"UNCALIBRATED",
|
|
|
|
"SLAVE",
|
2013-02-08 03:03:10 +08:00
|
|
|
"GRAND_MASTER",
|
2011-11-06 14:37:06 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
char *ev_str[] = {
|
|
|
|
"NONE",
|
|
|
|
"POWERUP",
|
|
|
|
"INITIALIZE",
|
|
|
|
"DESIGNATED_ENABLED",
|
|
|
|
"DESIGNATED_DISABLED",
|
|
|
|
"FAULT_CLEARED",
|
|
|
|
"FAULT_DETECTED",
|
|
|
|
"STATE_DECISION_EVENT",
|
|
|
|
"QUALIFICATION_TIMEOUT_EXPIRES",
|
|
|
|
"ANNOUNCE_RECEIPT_TIMEOUT_EXPIRES",
|
|
|
|
"SYNCHRONIZATION_FAULT",
|
|
|
|
"MASTER_CLOCK_SELECTED",
|
|
|
|
"RS_MASTER",
|
2011-12-27 18:04:50 +08:00
|
|
|
"RS_GRAND_MASTER",
|
2011-11-06 14:37:06 +08:00
|
|
|
"RS_SLAVE",
|
|
|
|
"RS_PASSIVE",
|
|
|
|
};
|
|
|
|
|
|
|
|
char *cid2str(struct ClockIdentity *id)
|
|
|
|
{
|
|
|
|
static char buf[64];
|
|
|
|
unsigned char *ptr = id->id;
|
|
|
|
snprintf(buf, sizeof(buf), "%02x%02x%02x.%02x%02x.%02x%02x%02x",
|
|
|
|
ptr[0], ptr[1], ptr[2], ptr[3],
|
|
|
|
ptr[4], ptr[5], ptr[6], ptr[7]);
|
|
|
|
return buf;
|
|
|
|
}
|
|
|
|
|
|
|
|
char *pid2str(struct PortIdentity *id)
|
|
|
|
{
|
|
|
|
static char buf[64];
|
|
|
|
unsigned char *ptr = id->clockIdentity.id;
|
|
|
|
snprintf(buf, sizeof(buf), "%02x%02x%02x.%02x%02x.%02x%02x%02x-%hu",
|
|
|
|
ptr[0], ptr[1], ptr[2], ptr[3],
|
|
|
|
ptr[4], ptr[5], ptr[6], ptr[7],
|
|
|
|
id->portNumber);
|
|
|
|
return buf;
|
|
|
|
}
|
2012-08-05 20:11:18 +08:00
|
|
|
|
|
|
|
int generate_clock_identity(struct ClockIdentity *ci, char *name)
|
|
|
|
{
|
|
|
|
unsigned char mac[6];
|
|
|
|
if (sk_interface_macaddr(name, mac, sizeof(mac)))
|
|
|
|
return -1;
|
|
|
|
ci->id[0] = mac[0];
|
|
|
|
ci->id[1] = mac[1];
|
|
|
|
ci->id[2] = mac[2];
|
|
|
|
ci->id[3] = 0xFF;
|
|
|
|
ci->id[4] = 0xFE;
|
|
|
|
ci->id[5] = mac[3];
|
|
|
|
ci->id[6] = mac[4];
|
|
|
|
ci->id[7] = mac[5];
|
|
|
|
return 0;
|
|
|
|
}
|
2013-02-04 06:01:50 +08:00
|
|
|
|
|
|
|
/* Naive count of utf8 symbols. Doesn't detect invalid UTF-8 and
|
|
|
|
* probably doesn't count combining characters correctly. */
|
|
|
|
static size_t strlen_utf8(const Octet *s)
|
|
|
|
{
|
|
|
|
size_t len = 0;
|
|
|
|
char c;
|
|
|
|
while ((c = *(s++))) {
|
|
|
|
if ((c & 0xC0) != 0x80)
|
|
|
|
len++;
|
|
|
|
}
|
|
|
|
return len;
|
|
|
|
}
|
|
|
|
|
|
|
|
int static_ptp_text_copy(struct static_ptp_text *dst, const struct PTPText *src)
|
|
|
|
{
|
|
|
|
int len = src->length;
|
|
|
|
if (dst->max_symbols > 0 && strlen_utf8(src->text) > dst->max_symbols)
|
|
|
|
return -1;
|
|
|
|
dst->length = len;
|
|
|
|
memcpy(dst->text, src->text, len);
|
|
|
|
dst->text[len] = '\0';
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
void ptp_text_copy(struct PTPText *dst, const struct static_ptp_text *src)
|
|
|
|
{
|
|
|
|
dst->length = src->length;
|
|
|
|
dst->text = (Octet *)src->text;
|
|
|
|
}
|
|
|
|
|
|
|
|
int ptp_text_set(struct PTPText *dst, const char *src)
|
|
|
|
{
|
|
|
|
size_t len;
|
|
|
|
if (src) {
|
|
|
|
len = strlen(src);
|
|
|
|
if (len > MAX_PTP_OCTETS)
|
|
|
|
return -1;
|
|
|
|
dst->length = len;
|
|
|
|
dst->text = (Octet *)src;
|
|
|
|
} else {
|
|
|
|
dst->length = 0;
|
|
|
|
dst->text = NULL;
|
|
|
|
}
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
int static_ptp_text_set(struct static_ptp_text *dst, const char *src)
|
|
|
|
{
|
|
|
|
struct PTPText t;
|
|
|
|
size_t len = strlen(src);
|
|
|
|
if (len > MAX_PTP_OCTETS)
|
|
|
|
return -1;
|
|
|
|
t.length = len;
|
|
|
|
t.text = (Octet *)src;
|
|
|
|
return static_ptp_text_copy(dst, &t);
|
|
|
|
}
|