|
@@ -146,6 +146,7 @@ static const char* get_bgp_state_name(u_int16_t state) {
|
|
static int mode=0;
|
|
static int mode=0;
|
|
static int timetype=0;
|
|
static int timetype=0;
|
|
static int show_packet_index = 0;
|
|
static int show_packet_index = 0;
|
|
|
|
+static int show_large_comms = 0;
|
|
static int packet_index = 0;
|
|
static int packet_index = 0;
|
|
|
|
|
|
static const char USAGE[] = "\
|
|
static const char USAGE[] = "\
|
|
@@ -162,11 +163,13 @@ Common options:\n\
|
|
-O <file> output to <file> instead of STDOUT\n\
|
|
-O <file> output to <file> instead of STDOUT\n\
|
|
-s log to syslog (the default)\n\
|
|
-s log to syslog (the default)\n\
|
|
-v log to STDERR\n\
|
|
-v log to STDERR\n\
|
|
|
|
+ -q quiet\n\
|
|
\n\
|
|
\n\
|
|
Options for -m and -M modes:\n\
|
|
Options for -m and -M modes:\n\
|
|
-t dump timestamps for RIB dumps reflect the time of the dump (the default)\n\
|
|
-t dump timestamps for RIB dumps reflect the time of the dump (the default)\n\
|
|
-t change timestamps for RIB dumps reflect the last route modification\n\
|
|
-t change timestamps for RIB dumps reflect the last route modification\n\
|
|
-p show packet index at second position\n\
|
|
-p show packet index at second position\n\
|
|
|
|
+ -l show large communities field after regular communities\n\
|
|
\n\
|
|
\n\
|
|
Special options:\n\
|
|
Special options:\n\
|
|
-T run unit tests and exit\n\
|
|
-T run unit tests and exit\n\
|
|
@@ -181,10 +184,11 @@ int main(int argc, char *argv[]) {
|
|
int fd;
|
|
int fd;
|
|
bool usage_error = false;
|
|
bool usage_error = false;
|
|
bool use_syslog = true;
|
|
bool use_syslog = true;
|
|
|
|
+ bool quiet = false;
|
|
|
|
|
|
log_to_stderr();
|
|
log_to_stderr();
|
|
|
|
|
|
- while ((c=getopt(argc,argv,"if:o:t:mMHO:svTp"))!=-1)
|
|
|
|
|
|
+ while ((c=getopt(argc,argv,"if:o:t:mMHO:svTplq"))!=-1)
|
|
switch(c)
|
|
switch(c)
|
|
{
|
|
{
|
|
case 'H':
|
|
case 'H':
|
|
@@ -232,6 +236,13 @@ int main(int argc, char *argv[]) {
|
|
case 'p':
|
|
case 'p':
|
|
show_packet_index = 1;
|
|
show_packet_index = 1;
|
|
break;
|
|
break;
|
|
|
|
+ case 'l':
|
|
|
|
+ show_large_comms = 1;
|
|
|
|
+ break;
|
|
|
|
+ case 'q':
|
|
|
|
+ quiet = true;
|
|
|
|
+ break;
|
|
|
|
+
|
|
case '?':
|
|
case '?':
|
|
default:
|
|
default:
|
|
usage_error = true;
|
|
usage_error = true;
|
|
@@ -240,7 +251,8 @@ int main(int argc, char *argv[]) {
|
|
argv += optind;
|
|
argv += optind;
|
|
|
|
|
|
if(use_syslog) {
|
|
if(use_syslog) {
|
|
- debug("logging to syslog");
|
|
|
|
|
|
+ if(!quiet)
|
|
|
|
+ debug("logging to syslog");
|
|
log_to_syslog();
|
|
log_to_syslog();
|
|
}
|
|
}
|
|
|
|
|
|
@@ -1372,6 +1384,10 @@ void show_attr(attributes_t *attr) {
|
|
}
|
|
}
|
|
if( (attr->flag & ATTR_FLAG_BIT(BGP_ATTR_COMMUNITIES) ) !=0)
|
|
if( (attr->flag & ATTR_FLAG_BIT(BGP_ATTR_COMMUNITIES) ) !=0)
|
|
printf("COMMUNITY:%s\n",attr->community->str);
|
|
printf("COMMUNITY:%s\n",attr->community->str);
|
|
|
|
+
|
|
|
|
+ if( (attr->flag & ATTR_FLAG_BIT(BGP_ATTR_LARGE_COMMUNITIES) ) !=0)
|
|
|
|
+ printf("LARGE_COMMUNITY:%s\n",attr->lcommunity->str);
|
|
|
|
+
|
|
}
|
|
}
|
|
|
|
|
|
}
|
|
}
|
|
@@ -1488,14 +1504,14 @@ static void table_line_announce(struct prefix *prefix,int count,BGPDUMP_ENTRY *e
|
|
{
|
|
{
|
|
int idx ;
|
|
int idx ;
|
|
char buf[128];
|
|
char buf[128];
|
|
- char tmp2[20];
|
|
|
|
|
|
+ char aggregate[20];
|
|
unsigned int npref;
|
|
unsigned int npref;
|
|
unsigned int nmed;
|
|
unsigned int nmed;
|
|
|
|
|
|
if (entry->attr->flag & ATTR_FLAG_BIT(BGP_ATTR_ATOMIC_AGGREGATE))
|
|
if (entry->attr->flag & ATTR_FLAG_BIT(BGP_ATTR_ATOMIC_AGGREGATE))
|
|
- sprintf(tmp2,"AG");
|
|
|
|
|
|
+ sprintf(aggregate,"AG");
|
|
else
|
|
else
|
|
- sprintf(tmp2,"NAG");
|
|
|
|
|
|
+ sprintf(aggregate,"NAG");
|
|
|
|
|
|
for (idx=0;idx<count;idx++)
|
|
for (idx=0;idx<count;idx++)
|
|
{
|
|
{
|
|
@@ -1533,10 +1549,19 @@ static void table_line_announce(struct prefix *prefix,int count,BGPDUMP_ENTRY *e
|
|
|
|
|
|
printf("%s|%u|%u|",inet_ntoa(entry->attr->nexthop),npref,nmed);
|
|
printf("%s|%u|%u|",inet_ntoa(entry->attr->nexthop),npref,nmed);
|
|
if( (entry->attr->flag & ATTR_FLAG_BIT(BGP_ATTR_COMMUNITIES) ) !=0)
|
|
if( (entry->attr->flag & ATTR_FLAG_BIT(BGP_ATTR_COMMUNITIES) ) !=0)
|
|
- printf("%s|%s|",entry->attr->community->str+1,tmp2);
|
|
|
|
- else
|
|
|
|
- printf("|%s|",tmp2);
|
|
|
|
-
|
|
|
|
|
|
+ printf("%s|",entry->attr->community->str+1);
|
|
|
|
+ else
|
|
|
|
+ printf("|");
|
|
|
|
+
|
|
|
|
+ if (show_large_comms) {
|
|
|
|
+ if( (entry->attr->flag & ATTR_FLAG_BIT(BGP_ATTR_LARGE_COMMUNITIES) ) !=0)
|
|
|
|
+ printf("%s|",entry->attr->lcommunity->str+1);
|
|
|
|
+ else
|
|
|
|
+ printf("|");
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ printf("%s|", aggregate); /* AG/NAG */
|
|
|
|
+
|
|
if (entry->attr->aggregator_addr.s_addr != -1)
|
|
if (entry->attr->aggregator_addr.s_addr != -1)
|
|
printf("%u %s|\n",entry->attr->aggregator_as,inet_ntoa(entry->attr->aggregator_addr));
|
|
printf("%u %s|\n",entry->attr->aggregator_as,inet_ntoa(entry->attr->aggregator_addr));
|
|
else
|
|
else
|
|
@@ -1573,14 +1598,14 @@ static void table_line_announce_1(struct mp_nlri *prefix,int count,BGPDUMP_ENTRY
|
|
{
|
|
{
|
|
int idx ;
|
|
int idx ;
|
|
char buf[128];
|
|
char buf[128];
|
|
- char tmp2[20];
|
|
|
|
|
|
+ char aggregate[20];
|
|
unsigned int npref;
|
|
unsigned int npref;
|
|
unsigned int nmed;
|
|
unsigned int nmed;
|
|
|
|
|
|
if (entry->attr->flag & ATTR_FLAG_BIT(BGP_ATTR_ATOMIC_AGGREGATE))
|
|
if (entry->attr->flag & ATTR_FLAG_BIT(BGP_ATTR_ATOMIC_AGGREGATE))
|
|
- sprintf(tmp2,"AG");
|
|
|
|
|
|
+ sprintf(aggregate,"AG");
|
|
else
|
|
else
|
|
- sprintf(tmp2,"NAG");
|
|
|
|
|
|
+ sprintf(aggregate,"NAG");
|
|
|
|
|
|
for (idx=0;idx<count;idx++)
|
|
for (idx=0;idx<count;idx++)
|
|
{
|
|
{
|
|
@@ -1625,9 +1650,18 @@ static void table_line_announce_1(struct mp_nlri *prefix,int count,BGPDUMP_ENTRY
|
|
|
|
|
|
//printf("%s|%d|%d|",inet_ntoa(prefix->nexthop.v4_addr),entry->attr->local_pref,entry->attr->med);
|
|
//printf("%s|%d|%d|",inet_ntoa(prefix->nexthop.v4_addr),entry->attr->local_pref,entry->attr->med);
|
|
if( (entry->attr->flag & ATTR_FLAG_BIT(BGP_ATTR_COMMUNITIES) ) !=0)
|
|
if( (entry->attr->flag & ATTR_FLAG_BIT(BGP_ATTR_COMMUNITIES) ) !=0)
|
|
- printf("%s|%s|",entry->attr->community->str+1,tmp2);
|
|
|
|
|
|
+ printf("%s|",entry->attr->community->str+1);
|
|
else
|
|
else
|
|
- printf("|%s|",tmp2);
|
|
|
|
|
|
+ printf("|");
|
|
|
|
+
|
|
|
|
+ if (show_large_comms) {
|
|
|
|
+ if( (entry->attr->flag & ATTR_FLAG_BIT(BGP_ATTR_LARGE_COMMUNITIES) ) !=0)
|
|
|
|
+ printf("%s|",entry->attr->lcommunity->str+1);
|
|
|
|
+ else
|
|
|
|
+ printf("|");
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ printf("%s|", aggregate); /* AG/NAG */
|
|
|
|
|
|
}
|
|
}
|
|
else
|
|
else
|
|
@@ -1668,10 +1702,18 @@ static void table_line_announce_1(struct mp_nlri *prefix,int count,BGPDUMP_ENTRY
|
|
printf("%s|%d|%d|",inet_ntoa(entry->attr->nexthop),npref,nmed);
|
|
printf("%s|%d|%d|",inet_ntoa(entry->attr->nexthop),npref,nmed);
|
|
//printf("%s|%d|%d|",inet_ntoa(entry->attr->nexthop),entry->attr->local_pref,entry->attr->med);
|
|
//printf("%s|%d|%d|",inet_ntoa(entry->attr->nexthop),entry->attr->local_pref,entry->attr->med);
|
|
if( (entry->attr->flag & ATTR_FLAG_BIT(BGP_ATTR_COMMUNITIES) ) !=0)
|
|
if( (entry->attr->flag & ATTR_FLAG_BIT(BGP_ATTR_COMMUNITIES) ) !=0)
|
|
- printf("%s|%s|",entry->attr->community->str+1,tmp2);
|
|
|
|
|
|
+ printf("%s|",entry->attr->community->str+1);
|
|
else
|
|
else
|
|
- printf("|%s|",tmp2);
|
|
|
|
|
|
+ printf("|");
|
|
|
|
|
|
|
|
+ if (show_large_comms) {
|
|
|
|
+ if( (entry->attr->flag & ATTR_FLAG_BIT(BGP_ATTR_LARGE_COMMUNITIES) ) !=0)
|
|
|
|
+ printf("%s|",entry->attr->lcommunity->str+1);
|
|
|
|
+ else
|
|
|
|
+ printf("|");
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ printf("%s|",aggregate); /* AG/NAG */
|
|
|
|
|
|
}
|
|
}
|
|
if (entry->attr->aggregator_addr.s_addr != -1)
|
|
if (entry->attr->aggregator_addr.s_addr != -1)
|
|
@@ -1713,14 +1755,14 @@ static void table_line_announce6(struct mp_nlri *prefix,int count,BGPDUMP_ENTRY
|
|
char buf[128];
|
|
char buf[128];
|
|
char buf1[128];
|
|
char buf1[128];
|
|
char buf2[128];
|
|
char buf2[128];
|
|
- char tmp2[20];
|
|
|
|
|
|
+ char aggregate[20];
|
|
unsigned int npref;
|
|
unsigned int npref;
|
|
unsigned int nmed;
|
|
unsigned int nmed;
|
|
|
|
|
|
if (entry->attr->flag & ATTR_FLAG_BIT(BGP_ATTR_ATOMIC_AGGREGATE))
|
|
if (entry->attr->flag & ATTR_FLAG_BIT(BGP_ATTR_ATOMIC_AGGREGATE))
|
|
- sprintf(tmp2,"AG");
|
|
|
|
|
|
+ sprintf(aggregate,"AG");
|
|
else
|
|
else
|
|
- sprintf(tmp2,"NAG");
|
|
|
|
|
|
+ sprintf(aggregate,"NAG");
|
|
|
|
|
|
for (idx=0;idx<count;idx++)
|
|
for (idx=0;idx<count;idx++)
|
|
{
|
|
{
|
|
@@ -1772,9 +1814,19 @@ static void table_line_announce6(struct mp_nlri *prefix,int count,BGPDUMP_ENTRY
|
|
printf("%s|%s|%s|%u|%u|", attr_aspath(entry->attr),describe_origin(entry->attr->origin),fmt_ipv6(prefix->nexthop,buf),npref,nmed);
|
|
printf("%s|%s|%s|%u|%u|", attr_aspath(entry->attr),describe_origin(entry->attr->origin),fmt_ipv6(prefix->nexthop,buf),npref,nmed);
|
|
|
|
|
|
if( (entry->attr->flag & ATTR_FLAG_BIT(BGP_ATTR_COMMUNITIES) ) !=0)
|
|
if( (entry->attr->flag & ATTR_FLAG_BIT(BGP_ATTR_COMMUNITIES) ) !=0)
|
|
- printf("%s|%s|",entry->attr->community->str+1,tmp2);
|
|
|
|
|
|
+ printf("%s|",entry->attr->community->str+1);
|
|
else
|
|
else
|
|
- printf("|%s|",tmp2);
|
|
|
|
|
|
+ printf("|");
|
|
|
|
+
|
|
|
|
+ if (show_large_comms) {
|
|
|
|
+ if( (entry->attr->flag & ATTR_FLAG_BIT(BGP_ATTR_LARGE_COMMUNITIES) ) !=0)
|
|
|
|
+ printf("%s|",entry->attr->lcommunity->str+1);
|
|
|
|
+ else
|
|
|
|
+ printf("|");
|
|
|
|
+
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ printf("%s|", aggregate); /* AG/NAG */
|
|
|
|
|
|
|
|
|
|
if (entry->attr->aggregator_addr.s_addr != -1)
|
|
if (entry->attr->aggregator_addr.s_addr != -1)
|
|
@@ -1816,16 +1868,16 @@ static void table_line_mrtd_route(BGPDUMP_MRTD_TABLE_DUMP *route,BGPDUMP_ENTRY *
|
|
{
|
|
{
|
|
|
|
|
|
struct tm *date = NULL;
|
|
struct tm *date = NULL;
|
|
- char tmp2[20];
|
|
|
|
|
|
+ char aggregate[20];
|
|
unsigned int npref;
|
|
unsigned int npref;
|
|
unsigned int nmed;
|
|
unsigned int nmed;
|
|
char time_str[20];
|
|
char time_str[20];
|
|
char peer[BGPDUMP_ADDRSTRLEN], prefix[BGPDUMP_ADDRSTRLEN], nexthop[BGPDUMP_ADDRSTRLEN];
|
|
char peer[BGPDUMP_ADDRSTRLEN], prefix[BGPDUMP_ADDRSTRLEN], nexthop[BGPDUMP_ADDRSTRLEN];
|
|
|
|
|
|
if (entry->attr->flag & ATTR_FLAG_BIT(BGP_ATTR_ATOMIC_AGGREGATE))
|
|
if (entry->attr->flag & ATTR_FLAG_BIT(BGP_ATTR_ATOMIC_AGGREGATE))
|
|
- sprintf(tmp2,"AG");
|
|
|
|
|
|
+ sprintf(aggregate,"AG");
|
|
else
|
|
else
|
|
- sprintf(tmp2,"NAG");
|
|
|
|
|
|
+ sprintf(aggregate,"NAG");
|
|
|
|
|
|
time_t *t;
|
|
time_t *t;
|
|
if (timetype==0) {
|
|
if (timetype==0) {
|
|
@@ -1880,9 +1932,19 @@ static void table_line_mrtd_route(BGPDUMP_MRTD_TABLE_DUMP *route,BGPDUMP_ENTRY *
|
|
printf("%s|%u|%u|",nexthop,npref,nmed);
|
|
printf("%s|%u|%u|",nexthop,npref,nmed);
|
|
|
|
|
|
if( (entry->attr->flag & ATTR_FLAG_BIT(BGP_ATTR_COMMUNITIES) ) !=0)
|
|
if( (entry->attr->flag & ATTR_FLAG_BIT(BGP_ATTR_COMMUNITIES) ) !=0)
|
|
- printf("%s|%s|",entry->attr->community->str+1,tmp2);
|
|
|
|
|
|
+ printf("%s|",entry->attr->community->str+1);
|
|
else
|
|
else
|
|
- printf("|%s|",tmp2);
|
|
|
|
|
|
+ printf("|");
|
|
|
|
+
|
|
|
|
+ if (show_large_comms) {
|
|
|
|
+ if( (entry->attr->flag & ATTR_FLAG_BIT(BGP_ATTR_LARGE_COMMUNITIES) ) !=0)
|
|
|
|
+ printf("%s|",entry->attr->lcommunity->str+1);
|
|
|
|
+ else
|
|
|
|
+ printf("|");
|
|
|
|
+
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ printf("%s|",aggregate); /* AG/NAG */
|
|
|
|
|
|
if (entry->attr->aggregator_addr.s_addr != -1)
|
|
if (entry->attr->aggregator_addr.s_addr != -1)
|
|
printf("%u %s|\n",entry->attr->aggregator_as,inet_ntoa(entry->attr->aggregator_addr));
|
|
printf("%u %s|\n",entry->attr->aggregator_as,inet_ntoa(entry->attr->aggregator_addr));
|
|
@@ -1997,10 +2059,19 @@ static void table_line_dump_v2_prefix(BGPDUMP_TABLE_DUMP_V2_PREFIX *e,BGPDUMP_EN
|
|
printf("%s|%u|%u|",nexthop,npref,nmed);
|
|
printf("%s|%u|%u|",nexthop,npref,nmed);
|
|
|
|
|
|
if( (attr->flag & ATTR_FLAG_BIT(BGP_ATTR_COMMUNITIES) ) !=0)
|
|
if( (attr->flag & ATTR_FLAG_BIT(BGP_ATTR_COMMUNITIES) ) !=0)
|
|
- printf("%s|%s|",attr->community->str+1,aggregate);
|
|
|
|
|
|
+ printf("%s|",attr->community->str+1);
|
|
else
|
|
else
|
|
- printf("|%s|",aggregate);
|
|
|
|
|
|
+ printf("|");
|
|
|
|
+
|
|
|
|
+ if (show_large_comms) {
|
|
|
|
+ if( (attr->flag & ATTR_FLAG_BIT(BGP_ATTR_LARGE_COMMUNITIES) ) !=0)
|
|
|
|
+ printf("%s|",attr->lcommunity->str+1);
|
|
|
|
+ else
|
|
|
|
+ printf("|");
|
|
|
|
+ }
|
|
|
|
|
|
|
|
+ printf("%s|",aggregate);
|
|
|
|
+
|
|
if (attr->aggregator_addr.s_addr != -1)
|
|
if (attr->aggregator_addr.s_addr != -1)
|
|
printf("%u %s|\n",attr->aggregator_as,inet_ntoa(attr->aggregator_addr));
|
|
printf("%u %s|\n",attr->aggregator_as,inet_ntoa(attr->aggregator_addr));
|
|
else
|
|
else
|