Skip to content
GitLab
Explore
Sign in
Primary navigation
Search or go to…
Project
R
RIOT
Manage
Activity
Members
Labels
Plan
Issues
Issue boards
Milestones
Wiki
Code
Merge requests
Repository
Branches
Commits
Tags
Repository graph
Compare revisions
Snippets
Build
Pipelines
Jobs
Pipeline schedules
Artifacts
Deploy
Releases
Container Registry
Model registry
Operate
Environments
Monitor
Incidents
Service Desk
Analyze
Value stream analytics
Contributor analytics
CI/CD analytics
Repository analytics
Model experiments
Help
Help
Support
GitLab documentation
Compare GitLab plans
Community forum
Contribute to GitLab
Provide feedback
Keyboard shortcuts
?
Snippets
Groups
Projects
Show more breadcrumbs
cm-projects
RIOT
Commits
6b36a076
Commit
6b36a076
authored
9 years ago
by
Cenk Gündoğan
Browse files
Options
Downloads
Patches
Plain Diff
sys/shell/commands/sc_fib.c: make dev param optional
parent
b256b9c2
No related branches found
Branches containing commit
No related tags found
No related merge requests found
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
sys/shell/commands/sc_fib.c
+77
-74
77 additions, 74 deletions
sys/shell/commands/sc_fib.c
with
77 additions
and
74 deletions
sys/shell/commands/sc_fib.c
+
77
−
74
View file @
6b36a076
...
@@ -25,12 +25,16 @@
...
@@ -25,12 +25,16 @@
#include
"thread.h"
#include
"thread.h"
#include
"inet_pton.h"
#include
"inet_pton.h"
#include
"ng_fib.h"
#include
"ng_fib.h"
#ifdef MODULE_NG_NETIF
#include
"ng_netif.h"
#endif
#define INFO1_TXT "fibroute add <destination> via <next hop> dev <device>"
#define INFO1_TXT "fibroute add <destination> via <next hop>
[
dev <device>
]
"
#define INFO2_TXT " [lifetime <lifetime>]"
#define INFO2_TXT " [lifetime <lifetime>]"
#define INFO3_TXT " <destination> - the destination address\n" \
#define INFO3_TXT " <destination> - the destination address\n" \
" <next hop> - the address of the next-hop towards the <destination>\n" \
" <next hop> - the address of the next-hop towards the <destination>\n" \
" <device> - the device id of the Interface to use\n"
" <device> - the device id of the Interface to use." \
" Optional if only one interface is available.\n"
#define INFO4_TXT " <lifetime> - optional lifetime in ms when the entry automatically invalidates\n"
#define INFO4_TXT " <lifetime> - optional lifetime in ms when the entry automatically invalidates\n"
#define INFO5_TXT "fibroute del <destination>\n" \
#define INFO5_TXT "fibroute del <destination>\n" \
" <destination> - the destination address of the entry to be deleted\n"
" <destination> - the destination address of the entry to be deleted\n"
...
@@ -66,6 +70,42 @@ static void _fib_usage(int info)
...
@@ -66,6 +70,42 @@ static void _fib_usage(int info)
};
};
}
}
static
void
_fib_add
(
const
char
*
dest
,
const
char
*
next
,
kernel_pid_t
pid
,
uint32_t
lifetime
)
{
unsigned
char
*
dst
=
(
unsigned
char
*
)
dest
;
size_t
dst_size
=
(
strlen
(
dest
));
uint32_t
dst_flags
=
0xffff
;
unsigned
char
*
nxt
=
(
unsigned
char
*
)
next
;
size_t
nxt_size
=
(
strlen
(
next
));
uint32_t
nxt_flags
=
0xffff
;
/* determine destination address */
if
(
inet_pton
(
AF_INET6
,
dest
,
tmp_ipv6_dst
))
{
dst
=
tmp_ipv6_dst
;
dst_size
=
IN6ADDRSZ
;
dst_flags
=
AF_INET6
;
}
else
if
(
inet_pton
(
AF_INET
,
dest
,
tmp_ipv4_dst
))
{
dst
=
tmp_ipv4_dst
;
dst_size
=
INADDRSZ
;
dst_flags
=
AF_INET
;
}
/* determine next-hop address */
if
(
inet_pton
(
AF_INET6
,
next
,
tmp_ipv6_nxt
))
{
nxt
=
tmp_ipv6_nxt
;
nxt_size
=
IN6ADDRSZ
;
nxt_flags
=
AF_INET6
;
}
else
if
(
inet_pton
(
AF_INET
,
next
,
tmp_ipv4_nxt
))
{
nxt
=
tmp_ipv4_nxt
;
nxt_size
=
INADDRSZ
;
nxt_flags
=
AF_INET
;
}
fib_add_entry
(
pid
,
dst
,
dst_size
,
dst_flags
,
nxt
,
nxt_size
,
nxt_flags
,
lifetime
);
}
int
_fib_route_handler
(
int
argc
,
char
**
argv
)
int
_fib_route_handler
(
int
argc
,
char
**
argv
)
{
{
/* e.g. fibroute right now dont care about the adress/protocol family */
/* e.g. fibroute right now dont care about the adress/protocol family */
...
@@ -109,46 +149,44 @@ int _fib_route_handler(int argc, char **argv)
...
@@ -109,46 +149,44 @@ int _fib_route_handler(int argc, char **argv)
return
0
;
return
0
;
}
}
#ifdef MODULE_NG_NETIF
/* e.g. fibroute add <destination> via <next hop> */
if
((
argc
==
5
)
&&
(
strcmp
(
"add"
,
argv
[
1
])
==
0
)
&&
(
strcmp
(
"via"
,
argv
[
3
])
==
0
))
{
kernel_pid_t
ifs
[
NG_NETIF_NUMOF
];
size_t
ifnum
=
ng_netif_get
(
ifs
);
if
(
ifnum
==
1
)
{
_fib_add
(
argv
[
2
],
argv
[
4
],
ifs
[
0
],
FIB_LIFETIME_NO_EXPIRE
);
}
else
{
_fib_usage
(
1
);
return
1
;
}
return
0
;
}
/* e.g. fibroute add <destination> via <next hop> lifetime <lifetime> */
if
((
argc
==
7
)
&&
(
strcmp
(
"add"
,
argv
[
1
])
==
0
)
&&
(
strcmp
(
"via"
,
argv
[
3
])
==
0
)
&&
(
strcmp
(
"lifetime"
,
argv
[
5
])
==
0
))
{
kernel_pid_t
ifs
[
NG_NETIF_NUMOF
];
size_t
ifnum
=
ng_netif_get
(
ifs
);
if
(
ifnum
==
1
)
{
_fib_add
(
argv
[
2
],
argv
[
4
],
ifs
[
0
],
(
uint32_t
)
atoi
(
argv
[
6
]));
}
else
{
_fib_usage
(
1
);
return
1
;
}
return
0
;
}
#endif
/* e.g. fibroute add <destination> via <next hop> dev <device> */
/* e.g. fibroute add <destination> via <next hop> dev <device> */
if
(
argc
==
7
)
{
if
(
argc
==
7
)
{
if
((
strcmp
(
"add"
,
argv
[
1
])
==
0
)
&&
(
strcmp
(
"via"
,
argv
[
3
])
==
0
)
if
((
strcmp
(
"add"
,
argv
[
1
])
==
0
)
&&
(
strcmp
(
"via"
,
argv
[
3
])
==
0
)
&&
(
strcmp
(
"dev"
,
argv
[
5
])
==
0
))
{
&&
(
strcmp
(
"dev"
,
argv
[
5
])
==
0
))
{
_fib_add
(
argv
[
2
],
argv
[
4
],
(
kernel_pid_t
)
atoi
(
argv
[
6
]),
FIB_LIFETIME_NO_EXPIRE
);
unsigned
char
*
dst
=
(
unsigned
char
*
)
argv
[
2
];
size_t
dst_size
=
(
strlen
(
argv
[
2
]));
uint32_t
dst_flags
=
0xffff
;
unsigned
char
*
nxt
=
(
unsigned
char
*
)
argv
[
4
];
size_t
nxt_size
=
(
strlen
(
argv
[
4
]));
uint32_t
nxt_flags
=
0xffff
;
/* determine destination address */
if
(
inet_pton
(
AF_INET6
,
argv
[
2
],
tmp_ipv6_dst
))
{
dst
=
tmp_ipv6_dst
;
dst_size
=
IN6ADDRSZ
;
dst_flags
=
AF_INET6
;
}
else
if
(
inet_pton
(
AF_INET
,
argv
[
2
],
tmp_ipv4_dst
))
{
dst
=
tmp_ipv4_dst
;
dst_size
=
INADDRSZ
;
dst_flags
=
AF_INET
;
}
/* determine next-hop address */
if
(
inet_pton
(
AF_INET6
,
argv
[
4
],
tmp_ipv6_nxt
))
{
nxt
=
tmp_ipv6_nxt
;
nxt_size
=
IN6ADDRSZ
;
nxt_flags
=
AF_INET6
;
}
else
if
(
inet_pton
(
AF_INET
,
argv
[
4
],
tmp_ipv4_nxt
))
{
nxt
=
tmp_ipv4_nxt
;
nxt_size
=
INADDRSZ
;
nxt_flags
=
AF_INET
;
}
fib_add_entry
((
kernel_pid_t
)
atoi
(
argv
[
6
]),
dst
,
dst_size
,
dst_flags
,
nxt
,
nxt_size
,
nxt_flags
,
FIB_LIFETIME_NO_EXPIRE
);
}
}
else
{
else
{
_fib_usage
(
1
);
_fib_usage
(
1
);
...
@@ -163,42 +201,7 @@ int _fib_route_handler(int argc, char **argv)
...
@@ -163,42 +201,7 @@ int _fib_route_handler(int argc, char **argv)
if
((
strcmp
(
"add"
,
argv
[
1
])
==
0
)
&&
(
strcmp
(
"via"
,
argv
[
3
])
==
0
)
if
((
strcmp
(
"add"
,
argv
[
1
])
==
0
)
&&
(
strcmp
(
"via"
,
argv
[
3
])
==
0
)
&&
(
strcmp
(
"dev"
,
argv
[
5
])
==
0
)
&&
(
strcmp
(
"dev"
,
argv
[
5
])
==
0
)
&&
(
strcmp
(
"lifetime"
,
argv
[
7
])
==
0
))
{
&&
(
strcmp
(
"lifetime"
,
argv
[
7
])
==
0
))
{
_fib_add
(
argv
[
2
],
argv
[
4
],
(
kernel_pid_t
)
atoi
(
argv
[
6
]),
(
uint32_t
)
atoi
(
argv
[
8
]));
unsigned
char
*
dst
=
(
unsigned
char
*
)
argv
[
2
];
size_t
dst_size
=
(
strlen
(
argv
[
2
]));
uint32_t
dst_flags
=
0xffff
;
unsigned
char
*
nxt
=
(
unsigned
char
*
)
argv
[
4
];
size_t
nxt_size
=
(
strlen
(
argv
[
4
]));
uint32_t
nxt_flags
=
0xffff
;
/* determine destination address */
if
(
inet_pton
(
AF_INET6
,
argv
[
2
],
tmp_ipv6_dst
))
{
dst
=
tmp_ipv6_dst
;
dst_size
=
IN6ADDRSZ
;
dst_flags
=
AF_INET6
;
}
else
if
(
inet_pton
(
AF_INET
,
argv
[
2
],
tmp_ipv4_dst
))
{
dst
=
tmp_ipv4_dst
;
dst_size
=
INADDRSZ
;
dst_flags
=
AF_INET
;
}
/* determine next-hop address */
if
(
inet_pton
(
AF_INET6
,
argv
[
4
],
tmp_ipv6_nxt
))
{
nxt
=
tmp_ipv6_nxt
;
nxt_size
=
IN6ADDRSZ
;
nxt_flags
=
AF_INET6
;
}
else
if
(
inet_pton
(
AF_INET
,
argv
[
4
],
tmp_ipv4_nxt
))
{
nxt
=
tmp_ipv4_nxt
;
nxt_size
=
INADDRSZ
;
nxt_flags
=
AF_INET
;
}
fib_add_entry
((
kernel_pid_t
)
atoi
(
argv
[
6
]),
dst
,
dst_size
,
dst_flags
,
nxt
,
nxt_size
,
nxt_flags
,
(
uint32_t
)
atoi
(
argv
[
8
]));
}
}
else
{
else
{
_fib_usage
(
2
);
_fib_usage
(
2
);
...
...
This diff is collapsed.
Click to expand it.
Preview
0%
Loading
Try again
or
attach a new file
.
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Save comment
Cancel
Please
register
or
sign in
to comment