Wireshark-dev: Re: [Wireshark-dev] Problems with the newly modified and compiled wpcap.dll
Hello,
> > And when I press the start button, the program, Hangs up.
> Perhaps your xxx_read routine is blocked waiting for a 3968-byte
buffer > full of data to arrive, even though some
> data has arrived? See
my mail to tcpdump-workers on that.
I have not implemented it yet, before doing it I tried to enter some raw data to an u_char array
and point to that just to make sure pointers and other stuff works together.
my xxx_read() file looks like this below
___________________________________________________________________
int muwis_read(pcap_t *p, int cnt, pcap_handler callback, u_char *user)
{
int processed = 0;
u_char dispbuff[250] = {'\x20','\x41','\x56','\x25','\x30','\x23','\x34'};
/* --------These are to get the time stamp--------*/
__int64 freq, tStart, tStop;
unsigned long Timeinus;
// Get the frequency of the hi-res timer
QueryPerformanceFrequency((LARGE_INTEGER*)&freq);
QueryPerformanceCounter((LARGE_INTEGER*)&tStart);
/*_________________________________________________*/
/*repeat until a packet is read
*a NULL message means :
* when no packet is in queue or all packets in queue already read
*/
do{
unsigned short packet_len = 0;
int caplen = 0;
struct pcap_pkthdr pcap_header; /* Appears in pcap.h */
u_char *dp ; /*pointer to the pcap data*/
/* Creation of the pcap header packet header */
caplen = p->snapshot; /*portion of the packet inside */
packet_len = 4;/*should be set*/
if (caplen > packet_len) {
caplen = packet_len;
}
QueryPerformanceCounter((LARGE_INTEGER*)&tStop);
Timeinus = (unsigned long)((tStop * 1000000) / freq);
/* Fill in our own header data */
pcap_header.caplen = caplen;
pcap_header.len = packet_len;
pcap_header.ts.tv_sec= Timeinus/1000000;
pcap_header.ts.tv_usec = Timeinus%1000000;
/* Count the packet. */
p->md.stat.ps_recv++
;
dp = &dispbuff[0]; /*pointer to the data*/
/* Call the user supplied callback function */
callback(user, &pcap_header, dp);
processed++;
}while(processed<cnt);
return processed;
}
________________________________________________________________________
In capture->interfaces list displays my device along with the others,
but in the "packets" and "packets/s" column, for all the interfaces
listed
it shows some very high "unrealistic " values such as 277314 for
packets
and extremely high value for packets/s.
> Have you implemented an xxx_stats routine that returns the correct
packet counts?
I had not implemented it before, but now I have implemented in a similar way to septel_stat()
static int muwis_stats(pcap_t *p, struct pcap_stat *ps) {
*ps = p->md.stat;
return 0;
}
But then The problem has now got Worsen
Now when I select capture-> interfaces. The Program CRASHES :(
Next I did something like below though it cant really be like this,
static int muwis_stats(pcap_t *p, struct pcap_stat *ps) {
return 0;
}
Now as similar to the previous occasion, I get a high value for
packets and packets/s, just for one time and then I get this
error message appearing
" Couldnt set capture buffer size
Size 1MB seems to be too high for your machine
default is 1MB
Any way capture started. "
But now the packets could be seen. Is this comes with the
memory of my machine(256MB) being low?
But surely there is a problem with my muwis_stats() function
Isnt it? Kindly correct me! and possibly with
*ps = p->md.stat;
I just passed the same message(Useless) but that is just to understand
the process.
Further I have not done anything regarding these two functions and
they appear as is in the pcap-septel.c, any specific additions I need
to do ?
________________________________________________________________
static int muwis_setfilter(pcap_t *p, struct bpf_program *fp) {
return (0);
}
static void muwis_platform_close(pcap_t *p) {
}
int muwis_setnonblock_fd(pcap_t *p, int nonblock, char *errbuf){
return (0);
}
int muwis_getnonblock_fd(pcap_t *p, char *errbuf){
return (0);
}
_________________________________________________________________
kindly let me know of any comments you have
Thanks
Xavier