Re: opening things without the O_LARGEFILE flag




xhoster@xxxxxxxxx wrote:
"Athanasios" <aduitsis@xxxxxxxxx> wrote:
Hi everyone,

I am trying to open the /dev/net/tun character device with perl.

In C, I would issue:

open("/dev/net/tun", O_RDWR)

and continue as usual.

However, when I try to use sysopen in perl like

sysopen(TUNNELDEV, "/dev/net/tun", O_RDWR);

from the strace (truss) output I can see that instead it tries to do:

open("/dev/net/tun", O_RDWR|O_LARGEFILE)

which for some VERY strange reason succeeds but the file descriptor is
left in a bad state, so it is really unusable. For anything I try to do
afterwards, I get a

EBADFD (File descriptor in bad state).

As I have come down to the systel call level, there is no other reason
for this problem that I can think of except the O_LARGEFILE flag.
Indeed, a simple C program works quite fine without that flag.

Just to make sure it is absolutely nailed down, does the simple C program
stop working fine if you add the O_LARGEFILE in?

I 'll confirm that shortly, I haven't tried it yet. But judging from
the system calls I see in truss, it almost surely won't work.



I also have tried to use POSIX::open but it still adds the flag.

The documentation clearly states that from perl 5.6 and forth, the
O_LARGEFILE will be used whenever possible. But I really need to bypass
this and generate an open system call without it.

Maybe you could compile perl without large file support?

Or write a small C server that will accept socket connections and
proxy /dev/net/tun over the socket.

Yes, these are valid options, as is the Inline::C idea which the
previous poster suggested. But the general idea is that there *should*
be a way to omit the O_LARGEFILE flag if needed.

Kind Regards,
Athanasios


Xho

--
-------------------- http://NewsReader.Com/ --------------------
Usenet Newsgroup Service $9.95/Month 30GB

.



Relevant Pages

  • Re: Output of Concise
    ... that op, and, unless the op has the OPf_STACKED flag, it is used to ... Instead, the TARG ... Perl source - the only kind of documentation found therein is the ... It's not anything like reading prose: ...
    (comp.lang.perl.misc)
  • Re: Output of Concise
    ... that op, and, unless the op has the OPf_STACKED flag, it is used to ... Perl source - the only kind of documentation found therein is the ... get this information - there are no books about this kind of Perl ...
    (comp.lang.perl.misc)
  • RE: Issue with perl, DBD::Oracle, Solaris 10
    ... So when I edit the Makefile and remove the "extra" cc from the command ... Against the stock perl in Solaris 10, I get an error that looks ... Do you have a Sun C compiler on the machine? ... the OTHERLDFLAGS, ...
    (perl.dbi.users)
  • Re: Embedding perl in shared libs
    ... perl functions from within a C program. ... flag, a segfault occurs during the parsing of the script. ... When statically linking library B to program A (instead of dlopening it), ... | bol resolution of subsequently loaded libraries. ...
    (comp.lang.perl.misc)
  • Re: opening things without the O_LARGEFILE flag
    ... I am trying to open the /dev/net/tun character device with perl. ... EBADFD (File descriptor in bad state). ... a simple C program works quite fine without that flag. ... Or write a small C server that will accept socket connections and ...
    (comp.lang.perl.misc)