sendto(msg) points to uninitialised byte(s)

B

BlueJ

My program is to send data using socket.. but I got the error message:
"sendto(msg) points to uninitialised byte(s) " This is my source code

1. key_list = emalloc(BUFSIZE - sizeof(Key) - sizeof(byte) -
sizeof(int));
bzero(key_list, sizeof(*key_list));

bp = key_list;

memmove(bp, key, ID_LEN);
bp += ID_LEN;

memmove(bp, &ip_num, sizeof(int));
bp += sizeof(int);

pack_addr = htonl(addr);
memmove(bp, &pack_addr, sizeof(ulong));
bp +=sizeof(ulong);

Ivn_send_key(srv, ttl, succ->addr, succ->port, bp, (bp -
key_list), addr, port);

2.
void Ivn_send_key(Vnode *srv, byte ttl, ulong to_addr, ushort
to_port, uchar *key_list, int list_len, ulong addr, ushort port)
{
byte buf[BUFSIZE];

Ivn_send_raw(srv, to_addr, to_port, Ivn_pack_key(buf, ttl, key_list,
list_len, addr, port), buf);
}

3.
int Ivn_pack_key(uchar *buf, byte ttl, uchar *key_list, int list_len,
ulong addr, ushort port)
{
//return Ivn_pack(buf, "ccxls", CHORD_KEY, ttl, key_list , port);
uchar *bp;
ushort sport;

bp = buf;

*bp++ = CHORD_KEY;

*bp++ = ttl;

sport = htons(port); //port number
memmove(bp, (char *)&sport, sizeof(ushort));
bp += sizeof(ushort);

memmove(bp, key_list, list_len);
bp += list_len;
free(key_list);

return bp -buf;
}

4.
void Ivn_send_raw(Vnode *srv, in_addr_t addr, in_port_t port, int n,
uchar *buf)
{
struct sockaddr_in dest;

memset(&dest, 0, sizeof(dest));
dest.sin_family = AF_INET;
dest.sin_port = htons(port);
dest.sin_addr.s_addr = htonl(addr);

//fprintf(stderr, " dst addr is %s\n", inet_ntoa(dest.sin_addr));

if (sendto(srv->out_sock, buf, n, 0, (struct sockaddr *) &dest,
sizeof(dest)) < 0)
warnm("sendto failed:"); /* ignore errors for now */
}


please help to correct the error?
 
C

CBFalconer

BlueJ said:
My program is to send data using socket.. but I got the error message:
"sendto(msg) points to uninitialised byte(s) " This is my source code

1. key_list = emalloc(BUFSIZE - sizeof(Key) - sizeof(byte) -
sizeof(int));
bzero(key_list, sizeof(*key_list));

So far the entities 'key_list', 'emalloc', 'Key', 'byte', 'bzero'
are all undefined. Not to mention 'socket' and 'sendto()'.
 
P

Peter Pichler

BlueJ said:
My program is to send data using socket.. but I got the error message:
"sendto(msg) points to uninitialised byte(s) " This is my source code

BlueJ,
I wanted to help you, but could not find a single instance of msg in
your code snippet, let alone sendto(msg).
1. key_list = emalloc(BUFSIZE - sizeof(Key) - sizeof(byte) -
sizeof(int));
bzero(key_list, sizeof(*key_list));
<snip>

What's emalloc and bzero? What's key_list, Key, byte? Your code snippet
is incomplete at best. If you want help, copy and paste a reduced source
that exhibits your problem but is still compilable, or at least contains
enough information for a human reader to understand.

Peter
 
J

Jack Klein

My program is to send data using socket.. but I got the error message:
"sendto(msg) points to uninitialised byte(s) " This is my source code

1. key_list = emalloc(BUFSIZE - sizeof(Key) - sizeof(byte) -

There is no emalloc() function in C.
sizeof(int));
bzero(key_list, sizeof(*key_list));

There is no bzero() function in C, and IIRC it's been deprecated in
*nix for a long time.

In any case, your question seems to be about non-standard, platform
specific network APIs, and they are off-topic here. I suggest you
post to a group for your platform.

--
Jack Klein
Home: http://JK-Technology.Com
FAQs for
comp.lang.c http://c-faq.com/
comp.lang.c++ http://www.parashift.com/c++-faq-lite/
alt.comp.lang.learn.c-c++
http://www.club.cc.cmu.edu/~ajo/docs/FAQ-acllc.html
 
J

jaysome

My program is to send data using socket.. but I got the error message:
"sendto(msg) points to uninitialised byte(s) " This is my source code

1. key_list = emalloc(BUFSIZE - sizeof(Key) - sizeof(byte) -
sizeof(int));
bzero(key_list, sizeof(*key_list));

bp = key_list;

memmove(bp, key, ID_LEN);
bp += ID_LEN;

memmove(bp, &ip_num, sizeof(int));
bp += sizeof(int);

pack_addr = htonl(addr);
memmove(bp, &pack_addr, sizeof(ulong));
bp +=sizeof(ulong);

Ivn_send_key(srv, ttl, succ->addr, succ->port, bp, (bp -
key_list), addr, port);

2.
void Ivn_send_key(Vnode *srv, byte ttl, ulong to_addr, ushort
to_port, uchar *key_list, int list_len, ulong addr, ushort port)
{
byte buf[BUFSIZE];

Ivn_send_raw(srv, to_addr, to_port, Ivn_pack_key(buf, ttl, key_list,
list_len, addr, port), buf);
}

3.
int Ivn_pack_key(uchar *buf, byte ttl, uchar *key_list, int list_len,
ulong addr, ushort port)
{
//return Ivn_pack(buf, "ccxls", CHORD_KEY, ttl, key_list , port);
uchar *bp;
ushort sport;

bp = buf;

*bp++ = CHORD_KEY;

*bp++ = ttl;

sport = htons(port); //port number
memmove(bp, (char *)&sport, sizeof(ushort));
bp += sizeof(ushort);

memmove(bp, key_list, list_len);
bp += list_len;
free(key_list);

return bp -buf;
}

4.
void Ivn_send_raw(Vnode *srv, in_addr_t addr, in_port_t port, int n,
uchar *buf)
{
struct sockaddr_in dest;

memset(&dest, 0, sizeof(dest));
dest.sin_family = AF_INET;
dest.sin_port = htons(port);
dest.sin_addr.s_addr = htonl(addr);

//fprintf(stderr, " dst addr is %s\n", inet_ntoa(dest.sin_addr));

if (sendto(srv->out_sock, buf, n, 0, (struct sockaddr *) &dest,
sizeof(dest)) < 0)
warnm("sendto failed:"); /* ignore errors for now */
}


please help to correct the error?

Hi BlueJ,

Others have replied to you with what I feel and most likely you feel
are of little to no help to you at all. Within the context of what
they feel this newsgroup is about (discussing Standard C-related
issues), they are right (e.g., there are no Standard C functions such
as emalloc or bzero, and therefore the short-circuit rules apply and
you post is off-topic).

However, in a broader sense, which is programming in C (and the trials
and tribulations you will inevitable encounter, regardless of whether
you are programming in Standard C or not), those same people who
replied to your post are cheating you, and every reasonable person
like you who have committed such a serious error in C, of a more
reasonable response.

I'd bet each and every one of those posters who replied to your post
are aware of the non-standard function sendto() and its prototype, yet
they failed to use their knowledge of this to be of any real help to
you, even though the type of error you committed could as just as
easily be committed in Standard C code.

Based on my knowledge of the non-standard function sendto(), it's
prototype is (for one of my compilers):

int sendto(
SOCKET s,
const char FAR *buf,
int len,
int flags,
const struct sockaddr FAR *to,
int tolen
);

What is not important is what SOCKET or FAR are defined as. What is
important is the definition of what the buf parameter is. Whether you
are using Linux or Windows or MAC OS X or any other OS, if your
compiler provides the sendto() function, its definition of the buf
parameter will invariably be something like this:

buf
[in] Buffer containing the data to be transmitted.

Given this definition (which effectively translates into buf being
something whose contents are transmitted and therefore needs to be
initialized/set to something BY YOU), it's obvious that what you pass
as the buf parameter to sendto() as a result of the uninitialized
local variable buf in Ivn_send_key() is your problem, and therefore
deserves the compiler warning you received.

Best regards
 
C

CBFalconer

jaysome said:
.... snip ...

Based on my knowledge of the non-standard function sendto(), it's
prototype is (for one of my compilers):

int sendto(
SOCKET s,
const char FAR *buf,
int len,
int flags,
const struct sockaddr FAR *to,
int tolen
);

No, around here it is:

int sendto(const char *s) {
return remove(s);
}

which may indicate the foolishness of making assumptions in order
to answer an off-topic post. Indications of where the poster
should go are useful, as are indications of why the post is
off-topic. The poster then has reasonable choices, and faulty
answers are likely to get properly detected and flagged.
 
B

Ben Bacarisse

jaysome said:
My program is to send data using socket.. but I got the error message:
"sendto(msg) points to uninitialised byte(s) " This is my source code
void Ivn_send_key(Vnode *srv, byte ttl, ulong to_addr, ushort
to_port, uchar *key_list, int list_len, ulong addr, ushort port)
{
byte buf[BUFSIZE];

Ivn_send_raw(srv, to_addr, to_port, Ivn_pack_key(buf, ttl, key_list,
list_len, addr, port), buf);
}
int Ivn_pack_key(uchar *buf, byte ttl, uchar *key_list, int list_len,
ulong addr, ushort port)
{
void Ivn_send_raw(Vnode *srv, in_addr_t addr, in_port_t port, int n,
uchar *buf)
{
it's obvious that what you pass
as the buf parameter to sendto() as a result of the uninitialized
local variable buf in Ivn_send_key() is your problem, and therefore
deserves the compiler warning you received.

Not obvious to me. I did not reply because I could not find the
error, and not because a non-standard function was used.. The buffer
seems to be filled by the call to Ivn_pack_key in the argument list of
the call to Ivn_send_raw.

Also, it seem unlikely to be a compiler warning, since the call to
sendto is a long way from the definition of the buffer (and if it is a
compiler warning it look bogus to me).

Unless I am missing something, we need more information. As usual, the
small compilable program that exhibits the problem would help (and,
equally usually, might help the OP find the problem on their own).
 

Ask a Question

Want to reply to this thread or ask your own question?

You'll need to choose a username for the site, which only take a couple of moments. After that, you can post your question and our members will help you out.

Ask a Question

Members online

No members online now.

Forum statistics

Threads
473,962
Messages
2,570,134
Members
46,692
Latest member
JenniferTi

Latest Threads

Top