|
@@ -143,10 +143,27 @@ static const char* get_bgp_state_name(u_int16_t state) {
|
|
|
}
|
|
|
}
|
|
|
|
|
|
+/* Check if -u (compact attributes) is enabled and append a field
|
|
|
+ * to the output to show any unknown attributes. */
|
|
|
+static void append_compact_unknown_attributes(attributes_t *attr) {
|
|
|
+ for(int i = 0; i < attr->unknown_num; i++) {
|
|
|
+ struct unknown_attr *ua = &(attr->unknown[i]);
|
|
|
+ printf("%02x:%02x:", ua->type, ua->flag);
|
|
|
+ for(size_t s = 0; s < ua->len; s++) {
|
|
|
+ printf("%02x", (uint8_t)(ua->raw[s]));
|
|
|
+ }
|
|
|
+ if(i < attr->unknown_num - 1) {
|
|
|
+ printf(" ");
|
|
|
+ }
|
|
|
+ }
|
|
|
+ printf("|");
|
|
|
+}
|
|
|
+
|
|
|
static int mode=0;
|
|
|
static int timetype=0;
|
|
|
static int show_packet_index = 0;
|
|
|
static int show_large_comms = 0;
|
|
|
+static int show_unknown_attributes = 0;
|
|
|
static int packet_index = 0;
|
|
|
|
|
|
static const char USAGE[] = "\
|
|
@@ -170,6 +187,7 @@ Options for -m and -M modes:\n\
|
|
|
-t change timestamps for RIB dumps reflect the last route modification\n\
|
|
|
-p show packet index at second position\n\
|
|
|
-l show large communities field after regular communities\n\
|
|
|
+ -u show unassigned attributes in one-line mode\n\
|
|
|
\n\
|
|
|
Special options:\n\
|
|
|
-T run unit tests and exit\n\
|
|
@@ -188,7 +206,7 @@ int main(int argc, char *argv[]) {
|
|
|
|
|
|
log_to_stderr();
|
|
|
|
|
|
- while ((c=getopt(argc,argv,"if:o:t:mMHO:svTplq"))!=-1)
|
|
|
+ while ((c=getopt(argc,argv,"if:o:t:mMHO:svTplqu"))!=-1)
|
|
|
switch(c)
|
|
|
{
|
|
|
case 'H':
|
|
@@ -239,6 +257,9 @@ int main(int argc, char *argv[]) {
|
|
|
case 'l':
|
|
|
show_large_comms = 1;
|
|
|
break;
|
|
|
+ case 'u':
|
|
|
+ show_unknown_attributes = 1;
|
|
|
+ break;
|
|
|
case 'q':
|
|
|
quiet = true;
|
|
|
break;
|
|
@@ -1562,10 +1583,15 @@ static void table_line_announce(struct prefix *prefix,int count,BGPDUMP_ENTRY *e
|
|
|
|
|
|
printf("%s|", aggregate); /* AG/NAG */
|
|
|
|
|
|
- if (entry->attr->aggregator_addr.s_addr != -1)
|
|
|
- printf("%u %s|\n",entry->attr->aggregator_as,inet_ntoa(entry->attr->aggregator_addr));
|
|
|
- else
|
|
|
- printf("|\n");
|
|
|
+ if (entry->attr->aggregator_addr.s_addr != -1) {
|
|
|
+ printf("%u %s",entry->attr->aggregator_as,inet_ntoa(entry->attr->aggregator_addr));
|
|
|
+ }
|
|
|
+ printf("|");
|
|
|
+
|
|
|
+ if (show_unknown_attributes) {
|
|
|
+ append_compact_unknown_attributes(entry->attr);
|
|
|
+ }
|
|
|
+ printf("\n");
|
|
|
}
|
|
|
else
|
|
|
{
|
|
@@ -1716,10 +1742,16 @@ static void table_line_announce_1(struct mp_nlri *prefix,int count,BGPDUMP_ENTRY
|
|
|
printf("%s|",aggregate); /* AG/NAG */
|
|
|
|
|
|
}
|
|
|
- if (entry->attr->aggregator_addr.s_addr != -1)
|
|
|
- printf("%u %s|\n",entry->attr->aggregator_as,inet_ntoa(entry->attr->aggregator_addr));
|
|
|
- else
|
|
|
- printf("|\n");
|
|
|
+ if (entry->attr->aggregator_addr.s_addr != -1) {
|
|
|
+ printf("%u %s",entry->attr->aggregator_as,inet_ntoa(entry->attr->aggregator_addr));
|
|
|
+ }
|
|
|
+ printf("|");
|
|
|
+
|
|
|
+ if (show_unknown_attributes) {
|
|
|
+ append_compact_unknown_attributes(entry->attr);
|
|
|
+ }
|
|
|
+
|
|
|
+ printf("\n");
|
|
|
}
|
|
|
else
|
|
|
{
|
|
@@ -1829,11 +1861,16 @@ static void table_line_announce6(struct mp_nlri *prefix,int count,BGPDUMP_ENTRY
|
|
|
printf("%s|", aggregate); /* AG/NAG */
|
|
|
|
|
|
|
|
|
- if (entry->attr->aggregator_addr.s_addr != -1)
|
|
|
- printf("%u %s|\n",entry->attr->aggregator_as,inet_ntoa(entry->attr->aggregator_addr));
|
|
|
- else
|
|
|
- printf("|\n");
|
|
|
+ if (entry->attr->aggregator_addr.s_addr != -1) {
|
|
|
+ printf("%u %s",entry->attr->aggregator_as,inet_ntoa(entry->attr->aggregator_addr));
|
|
|
+ }
|
|
|
+ printf("|");
|
|
|
+
|
|
|
+ if (show_unknown_attributes) {
|
|
|
+ append_compact_unknown_attributes(entry->attr);
|
|
|
+ }
|
|
|
|
|
|
+ printf("\n");
|
|
|
}
|
|
|
else
|
|
|
{
|
|
@@ -1946,17 +1983,25 @@ static void table_line_mrtd_route(BGPDUMP_MRTD_TABLE_DUMP *route,BGPDUMP_ENTRY *
|
|
|
|
|
|
printf("%s|",aggregate); /* AG/NAG */
|
|
|
|
|
|
- if (entry->attr->aggregator_addr.s_addr != -1)
|
|
|
- printf("%u %s|\n",entry->attr->aggregator_as,inet_ntoa(entry->attr->aggregator_addr));
|
|
|
- else
|
|
|
- printf("|\n");
|
|
|
+ if (entry->attr->aggregator_addr.s_addr != -1) {
|
|
|
+ printf("%u %s",entry->attr->aggregator_as,inet_ntoa(entry->attr->aggregator_addr));
|
|
|
+ }
|
|
|
+ printf("|");
|
|
|
+
|
|
|
+ if (show_unknown_attributes) {
|
|
|
+ append_compact_unknown_attributes(entry->attr);
|
|
|
+ }
|
|
|
+ printf("\n");
|
|
|
+
|
|
|
}
|
|
|
+
|
|
|
else
|
|
|
{
|
|
|
printf("%s|%u|",peer,route->peer_as);
|
|
|
printf("%s/%d|%s|%s\n",prefix,route->mask,attr_aspath(entry->attr),describe_origin(entry->attr->origin));
|
|
|
}
|
|
|
|
|
|
+
|
|
|
}
|
|
|
|
|
|
static char *describe_origin(int origin) {
|
|
@@ -2072,10 +2117,15 @@ static void table_line_dump_v2_prefix(BGPDUMP_TABLE_DUMP_V2_PREFIX *e,BGPDUMP_EN
|
|
|
|
|
|
printf("%s|",aggregate);
|
|
|
|
|
|
- if (attr->aggregator_addr.s_addr != -1)
|
|
|
- printf("%u %s|\n",attr->aggregator_as,inet_ntoa(attr->aggregator_addr));
|
|
|
- else
|
|
|
- printf("|\n");
|
|
|
+ if (attr->aggregator_addr.s_addr != -1) {
|
|
|
+ printf("%u %s",attr->aggregator_as,inet_ntoa(attr->aggregator_addr));
|
|
|
+ }
|
|
|
+ printf("|");
|
|
|
+
|
|
|
+ if (show_unknown_attributes) {
|
|
|
+ append_compact_unknown_attributes(attr);
|
|
|
+ }
|
|
|
+ printf("\n");
|
|
|
}
|
|
|
else
|
|
|
{
|