Deleted Added
full compact
atomicio.c (57429) atomicio.c (58582)
1/*
2 * Copyright (c) 1999 Theo de Raadt
3 * All rights reserved.
4 *
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions
7 * are met:
8 * 1. Redistributions of source code must retain the above copyright

--- 10 unchanged lines hidden (view full) ---

19 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
20 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
21 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
22 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
23 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
24 */
25
26#include "includes.h"
1/*
2 * Copyright (c) 1999 Theo de Raadt
3 * All rights reserved.
4 *
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions
7 * are met:
8 * 1. Redistributions of source code must retain the above copyright

--- 10 unchanged lines hidden (view full) ---

19 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
20 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
21 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
22 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
23 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
24 */
25
26#include "includes.h"
27RCSID("$Id: atomicio.c,v 1.2 2000/02/01 22:32:53 d Exp $");
27RCSID("$Id: atomicio.c,v 1.3 2000/03/16 20:56:13 markus Exp $");
28
29#include "xmalloc.h"
30#include "ssh.h"
31
32/*
33 * ensure all of data on socket comes through. f==read || f==write
34 */
35ssize_t
28
29#include "xmalloc.h"
30#include "ssh.h"
31
32/*
33 * ensure all of data on socket comes through. f==read || f==write
34 */
35ssize_t
36atomicio(f, fd, s, n)
36atomicio(f, fd, _s, n)
37 ssize_t (*f) ();
38 int fd;
37 ssize_t (*f) ();
38 int fd;
39 void *s;
39 void *_s;
40 size_t n;
41{
40 size_t n;
41{
42 char *s = _s;
42 ssize_t res, pos = 0;
43
44 while (n > pos) {
45 res = (f) (fd, s + pos, n - pos);
46 switch (res) {
47 case -1:
48 if (errno == EINTR || errno == EAGAIN)
49 continue;
50 case 0:
51 return (res);
52 default:
53 pos += res;
54 }
55 }
56 return (pos);
57}
43 ssize_t res, pos = 0;
44
45 while (n > pos) {
46 res = (f) (fd, s + pos, n - pos);
47 switch (res) {
48 case -1:
49 if (errno == EINTR || errno == EAGAIN)
50 continue;
51 case 0:
52 return (res);
53 default:
54 pos += res;
55 }
56 }
57 return (pos);
58}