The patches for 3.0.9.
[rsync-patches.git] / slow-down.diff
1 This patch adds a --slow-down=USECs option that causes the sender to scan
2 the filelist more slowly, and the generator to scan for deletions more
3 slowly.  It doesn't do anything to make anyone slow down during the normal
4 transfer processing, though.
5
6 The idea is to lessen rsync's impact on disk I/O.  Unfortunately, there
7 should really be a way to affect more of rsync's processing, perhaps by
8 specifying a maximum disk I/O rate (and have that affect a maximum stat()
9 rate or something like that).
10
11 To use this patch, run these commands for a successful build:
12
13     patch -p1 <patches/slow-down.diff
14     ./configure                           (optional if already run)
15     make
16
17 based-on: 40afd365cc8ca968fd16e161d24df5b8a8a520cc
18 diff --git a/flist.c b/flist.c
19 --- a/flist.c
20 +++ b/flist.c
21 @@ -68,6 +68,7 @@ extern int need_unsorted_flist;
22  extern int sender_symlink_iconv;
23  extern int unsort_ndx;
24  extern uid_t our_uid;
25 +extern unsigned long sleep_asec;
26  extern struct stats stats;
27  extern char *filesfrom_host;
28  
29 @@ -1671,6 +1672,9 @@ static void send_directory(int f, struct file_list *flist, char *fbuf, int len,
30                 }
31  
32                 send_file_name(f, flist, fbuf, NULL, flags, filter_level);
33 +               /* Sleep for a bit, to avoid hammering the disk. */
34 +               if (sleep_asec)
35 +                       usleep(sleep_asec);
36         }
37  
38         fbuf[len] = '\0';
39 diff --git a/options.c b/options.c
40 --- a/options.c
41 +++ b/options.c
42 @@ -107,6 +107,7 @@ int size_only = 0;
43  int daemon_bwlimit = 0;
44  int bwlimit = 0;
45  int fuzzy_basis = 0;
46 +unsigned long sleep_asec = 0;
47  size_t bwlimit_writemax = 0;
48  int ignore_existing = 0;
49  int ignore_non_existing = 0;
50 @@ -423,6 +424,7 @@ void usage(enum logcode F)
51    rprintf(F,"     --password-file=FILE    read daemon-access password from FILE\n");
52    rprintf(F,"     --list-only             list the files instead of copying them\n");
53    rprintf(F,"     --bwlimit=KBPS          limit I/O bandwidth; KBytes per second\n");
54 +  rprintf(F,"     --slow-down=USECs       sleep N usec while creating the filelist\n");
55    rprintf(F,"     --write-batch=FILE      write a batched update to FILE\n");
56    rprintf(F,"     --only-write-batch=FILE like --write-batch but w/o updating destination\n");
57    rprintf(F,"     --read-batch=FILE       read a batched update from FILE\n");
58 @@ -603,6 +605,7 @@ static struct poptOption long_options[] = {
59    {"itemize-changes", 'i', POPT_ARG_NONE,   0, 'i', 0, 0 },
60    {"no-itemize-changes",0, POPT_ARG_VAL,    &itemize_changes, 0, 0, 0 },
61    {"no-i",             0,  POPT_ARG_VAL,    &itemize_changes, 0, 0, 0 },
62 +  {"slow-down",        0,  POPT_ARG_LONG,   &sleep_asec, 0, 0, 0 },
63    {"bwlimit",          0,  POPT_ARG_INT,    &bwlimit, 0, 0, 0 },
64    {"no-bwlimit",       0,  POPT_ARG_VAL,    &bwlimit, 0, 0, 0 },
65    {"backup",          'b', POPT_ARG_VAL,    &make_backups, 1, 0, 0 },