blob: dd9e745ad95e2bbc3d4a261c2e3703dd632e73e1 [file] [log] [blame]
Wayne Davison0f78b812006-04-25 20:23:34 +00001/*
2 * Support the max connections option.
3 *
4 * Copyright (C) 1998 Andrew Tridgell
5 *
6 * This program is free software; you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License as published by
8 * the Free Software Foundation; either version 2 of the License, or
9 * (at your option) any later version.
10 *
11 * This program is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU General Public License for more details.
15 *
16 * You should have received a copy of the GNU General Public License
17 * along with this program; if not, write to the Free Software
18 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
19 */
Andrew Tridgell0c515f11998-05-13 08:52:12 +000020
Andrew Tridgell0c515f11998-05-13 08:52:12 +000021#include "rsync.h"
22
Andrew Tridgell0c515f11998-05-13 08:52:12 +000023/****************************************************************************
24simple routine to do connection counting
25****************************************************************************/
26int claim_connection(char *fname,int max_connections)
27{
28 int fd, i;
Andrew Tridgell0c515f11998-05-13 08:52:12 +000029
30 if (max_connections <= 0)
31 return 1;
Andrew Tridgell8d72ef61998-07-17 05:37:18 +000032
Andrew Tridgell0c515f11998-05-13 08:52:12 +000033 fd = open(fname,O_RDWR|O_CREAT, 0600);
34
35 if (fd == -1) {
36 return 0;
37 }
38
Andrew Tridgell0c515f11998-05-13 08:52:12 +000039 /* find a free spot */
40 for (i=0;i<max_connections;i++) {
Andrew Tridgell31593dd1998-05-13 09:38:54 +000041 if (lock_range(fd, i*4, 4)) return 1;
Wayne Davison0f78b812006-04-25 20:23:34 +000042 }
Andrew Tridgell0c515f11998-05-13 08:52:12 +000043
Andrew Tridgell8d72ef61998-07-17 05:37:18 +000044 /* only interested in open failures */
45 errno = 0;
46
Andrew Tridgell0c515f11998-05-13 08:52:12 +000047 close(fd);
Andrew Tridgell31593dd1998-05-13 09:38:54 +000048 return 0;
Andrew Tridgell0c515f11998-05-13 08:52:12 +000049}