ASUS DSL-AC3100 Router Firmware sendpackets Bug
This is a tiny bug, but it's still a bug nevertheless. strncpy is not guaranteed to NUL terminate if the max buf size is reached. The code below doesn't explicity NUL terminate the strncpy to iface. It's probably not been triggered because the stack is likely to be clean when the program reaches the strncpy. However, it's not guaranteed.
void
main (int argc, char **argv)
{
pcap_t *fp;
char errbuf[PCAP_ERRBUF_SIZE];
int i;
int j;
int nstreams;
int cnt;
int tdelay;
char iface[32];
int patternlen;
int opt;
struct timeval tstart;
struct timeval t;
struct timeval tint;
int pdone;
int pbusy;
iface[0] = 0;
patternlen = 0;
nstreams = 0;
tdelay = 0;
while ((opt = getopt (argc, argv, "i:t:c:p:")) != -1)
{
switch (opt)
{
case 'i':
strncpy (iface, optarg, 32);
break;
void
main (int argc, char **argv)
{
pcap_t *fp;
char errbuf[PCAP_ERRBUF_SIZE];
int i;
int j;
int nstreams;
int cnt;
int tdelay;
char iface[32];
int patternlen;
int opt;
struct timeval tstart;
struct timeval t;
struct timeval tint;
int pdone;
int pbusy;
iface[0] = 0;
patternlen = 0;
nstreams = 0;
tdelay = 0;
while ((opt = getopt (argc, argv, "i:t:c:p:")) != -1)
{
switch (opt)
{
case 'i':
strncpy (iface, optarg, 32);
break;