When creating a file, you need a third parameter to open (the mode). If you don't do this, unpredictable things happen.
Also, if you want to create a file if it's not there, you will need O_CREAT or'd in, i.e.
fd = open(tmpname, O_WRONLY | O_APPEND | O_CREAT, 0644);
O_CREAT (roughly speaking) creates the file if it isn't present.
From the man page:
NAME
open, creat - open and possibly create a file or device
SYNOPSIS
#include
#include
#include
int open(const char *pathname, int flags);
int open(const char *pathname, int flags, mode_t mode);
int creat(const char *pathname, mode_t mode);
...
O_CREAT
If the file does not exist it will be created. The owner (user ID) of
the file is set to the effective user ID of the process. The group
ownership (group ID) is set either to the effective group ID of the
process or to the group ID of the parent directory (depending on
filesystem type and mount options, and the mode of the parent direc‐
tory, see the mount options bsdgroups and sysvgroups described in
mount(8)).
mode specifies the permissions to use in case a new file is created.
This argument must be supplied when O_CREAT is specified in flags; if
O_CREAT is not specified, then mode is ignored. The effective permis‐
sions are modified by the process's umask in the usual way: The per‐
missions of the created file are (mode & ~umask). Note that this mode
applies only to future accesses of the newly created file; the open()
call that creates a read-only file may well return a read/write file
descriptor.