1c19800e8SDoug Rabson /*
2*ae771770SStanislav Sedov * Copyright (c) 2005 Kungliga Tekniska Högskolan
3c19800e8SDoug Rabson * (Royal Institute of Technology, Stockholm, Sweden).
4c19800e8SDoug Rabson * All rights reserved.
5c19800e8SDoug Rabson *
6c19800e8SDoug Rabson * Redistribution and use in source and binary forms, with or without
7c19800e8SDoug Rabson * modification, are permitted provided that the following conditions
8c19800e8SDoug Rabson * are met:
9c19800e8SDoug Rabson *
10c19800e8SDoug Rabson * 1. Redistributions of source code must retain the above copyright
11c19800e8SDoug Rabson * notice, this list of conditions and the following disclaimer.
12c19800e8SDoug Rabson *
13c19800e8SDoug Rabson * 2. Redistributions in binary form must reproduce the above copyright
14c19800e8SDoug Rabson * notice, this list of conditions and the following disclaimer in the
15c19800e8SDoug Rabson * documentation and/or other materials provided with the distribution.
16c19800e8SDoug Rabson *
17c19800e8SDoug Rabson * 3. Neither the name of the Institute nor the names of its contributors
18c19800e8SDoug Rabson * may be used to endorse or promote products derived from this software
19c19800e8SDoug Rabson * without specific prior written permission.
20c19800e8SDoug Rabson *
21c19800e8SDoug Rabson * THIS SOFTWARE IS PROVIDED BY THE INSTITUTE AND CONTRIBUTORS ``AS IS'' AND
22c19800e8SDoug Rabson * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
23c19800e8SDoug Rabson * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
24c19800e8SDoug Rabson * ARE DISCLAIMED. IN NO EVENT SHALL THE INSTITUTE OR CONTRIBUTORS BE LIABLE
25c19800e8SDoug Rabson * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
26c19800e8SDoug Rabson * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
27c19800e8SDoug Rabson * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
28c19800e8SDoug Rabson * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
29c19800e8SDoug Rabson * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
30c19800e8SDoug Rabson * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
31c19800e8SDoug Rabson * SUCH DAMAGE.
32c19800e8SDoug Rabson */
33c19800e8SDoug Rabson
34c19800e8SDoug Rabson #include <config.h>
35c19800e8SDoug Rabson
36c19800e8SDoug Rabson #include "roken.h"
37c19800e8SDoug Rabson
38c19800e8SDoug Rabson /*
39c19800e8SDoug Rabson * Write datablob to a filename, don't care about errors.
40c19800e8SDoug Rabson */
41c19800e8SDoug Rabson
42*ae771770SStanislav Sedov ROKEN_LIB_FUNCTION void ROKEN_LIB_CALL
rk_dumpdata(const char * filename,const void * buf,size_t size)43c19800e8SDoug Rabson rk_dumpdata (const char *filename, const void *buf, size_t size)
44c19800e8SDoug Rabson {
45c19800e8SDoug Rabson int fd;
46c19800e8SDoug Rabson
47c19800e8SDoug Rabson fd = open(filename, O_WRONLY|O_TRUNC|O_CREAT, 0640);
48c19800e8SDoug Rabson if (fd < 0)
49c19800e8SDoug Rabson return;
50c19800e8SDoug Rabson net_write(fd, buf, size);
51c19800e8SDoug Rabson close(fd);
52c19800e8SDoug Rabson }
53*ae771770SStanislav Sedov
54*ae771770SStanislav Sedov /*
55*ae771770SStanislav Sedov * Read all data from a filename, care about errors.
56*ae771770SStanislav Sedov */
57*ae771770SStanislav Sedov
58*ae771770SStanislav Sedov ROKEN_LIB_FUNCTION int ROKEN_LIB_CALL
rk_undumpdata(const char * filename,void ** buf,size_t * size)59*ae771770SStanislav Sedov rk_undumpdata(const char *filename, void **buf, size_t *size)
60*ae771770SStanislav Sedov {
61*ae771770SStanislav Sedov struct stat sb;
62*ae771770SStanislav Sedov int fd, ret;
63*ae771770SStanislav Sedov ssize_t sret;
64*ae771770SStanislav Sedov
65*ae771770SStanislav Sedov *buf = NULL;
66*ae771770SStanislav Sedov
67*ae771770SStanislav Sedov fd = open(filename, O_RDONLY, 0);
68*ae771770SStanislav Sedov if (fd < 0)
69*ae771770SStanislav Sedov return errno;
70*ae771770SStanislav Sedov if (fstat(fd, &sb) != 0){
71*ae771770SStanislav Sedov ret = errno;
72*ae771770SStanislav Sedov goto out;
73*ae771770SStanislav Sedov }
74*ae771770SStanislav Sedov *buf = malloc(sb.st_size);
75*ae771770SStanislav Sedov if (*buf == NULL) {
76*ae771770SStanislav Sedov ret = ENOMEM;
77*ae771770SStanislav Sedov goto out;
78*ae771770SStanislav Sedov }
79*ae771770SStanislav Sedov *size = sb.st_size;
80*ae771770SStanislav Sedov
81*ae771770SStanislav Sedov sret = net_read(fd, *buf, *size);
82*ae771770SStanislav Sedov if (sret < 0)
83*ae771770SStanislav Sedov ret = errno;
84*ae771770SStanislav Sedov else if (sret != (ssize_t)*size) {
85*ae771770SStanislav Sedov ret = EINVAL;
86*ae771770SStanislav Sedov free(*buf);
87*ae771770SStanislav Sedov *buf = NULL;
88*ae771770SStanislav Sedov } else
89*ae771770SStanislav Sedov ret = 0;
90*ae771770SStanislav Sedov
91*ae771770SStanislav Sedov out:
92*ae771770SStanislav Sedov close(fd);
93*ae771770SStanislav Sedov return ret;
94*ae771770SStanislav Sedov }
95