<html xmlns:v="urn:schemas-microsoft-com:vml" xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:w="urn:schemas-microsoft-com:office:word" xmlns:m="http://schemas.microsoft.com/office/2004/12/omml" xmlns="http://www.w3.org/TR/REC-html40"><head><META HTTP-EQUIV="Content-Type" CONTENT="text/html; charset=us-ascii"><meta name=Generator content="Microsoft Word 14 (filtered medium)"><style><!--
/* Font Definitions */
@font-face
        {font-family:Calibri;
        panose-1:2 15 5 2 2 2 4 3 2 4;}
/* Style Definitions */
p.MsoNormal, li.MsoNormal, div.MsoNormal
        {margin:0in;
        margin-bottom:.0001pt;
        font-size:11.0pt;
        font-family:"Calibri","sans-serif";}
a:link, span.MsoHyperlink
        {mso-style-priority:99;
        color:blue;
        text-decoration:underline;}
a:visited, span.MsoHyperlinkFollowed
        {mso-style-priority:99;
        color:purple;
        text-decoration:underline;}
span.EmailStyle17
        {mso-style-type:personal-compose;
        font-family:"Calibri","sans-serif";
        color:windowtext;}
.MsoChpDefault
        {mso-style-type:export-only;
        font-family:"Calibri","sans-serif";}
@page WordSection1
        {size:8.5in 11.0in;
        margin:1.0in 1.0in 1.0in 1.0in;}
div.WordSection1
        {page:WordSection1;}
--></style><!--[if gte mso 9]><xml>
<o:shapedefaults v:ext="edit" spidmax="1026" />
</xml><![endif]--><!--[if gte mso 9]><xml>
<o:shapelayout v:ext="edit">
<o:idmap v:ext="edit" data="1" />
</o:shapelayout></xml><![endif]--></head><body lang=EN-US link=blue vlink=purple><div class=WordSection1><p class=MsoNormal>All,<o:p></o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>I tried using the write-devices patch from rsync-patches.  Thanks for creating it.  I hope that and copy-devices become part of mainline.<o:p></o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>When I tried to copy from a regular file to a device, with a command like<o:p></o:p></p><p class=MsoNormal>   rsync –write-devices –inplace rsync://10.10.10.1/share/drive.img /dev/sdb3<o:p></o:p></p><p class=MsoNormal>I used to get a ‘rsync: ftruncate failed on “/dev/sdb3”: Invalid argument (22)’ error.<o:p></o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>The problem seems to be rooted in line 135 of write-devices.diff (from the rsync-patches repo).<o:p></o:p></p><p class=MsoNormal>Namely, I believe <o:p></o:p></p><p class=MsoNormal>   !IS_DEVICE(file->mode)<o:p></o:p></p><p class=MsoNormal>is checking the mode of the source file, not the destination, which is what it should check.  I wrote a hack to check if fd corresponds to a device instead (simple code changes below), which seemed to make things work although it should be coded more cleanly.  Thanks.<o:p></o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Ryan<o:p></o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Informal description of changes from receiver.c line 369:<o:p></o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Original code (after applying write-devices patch):<o:p></o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>#ifdef HAVE_TRUNCATE<o:p></o:p></p><p class=MsoNormal>                If((inplace<o:p></o:p></p><p class=MsoNormal>#ifdef PREALLOCATE_NEEDS_TRUNCATE<o:p></o:p></p><p class=MsoNormal style='text-indent:.5in'>|| preallocated_len > offset<o:p></o:p></p><p class=MsoNormal>#endif<o:p></o:p></p><p class=MsoNormal>                ) && fd != -1 && !IS_DEVICE(file->mode) && do_ftruncate(fd, offset) < 0) {<o:p></o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Code after change:<o:p></o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>#ifdef HAVE_TRUNCATE<o:p></o:p></p><p class=MsoNormal>{<o:p></o:p></p><p class=MsoNormal>                STRUCT_STAT st;<o:p></o:p></p><p class=MsoNormal>                Do_fstat(fd, &st);<o:p></o:p></p><p class=MsoNormal>                If((inplace<o:p></o:p></p><p class=MsoNormal>#ifdef PREALLOCATE_NEEDS_TRUNCATE<o:p></o:p></p><p class=MsoNormal style='text-indent:.5in'>|| preallocated_len > offset<o:p></o:p></p><p class=MsoNormal>#endif<o:p></o:p></p><p class=MsoNormal>                ) && fd != -1 && !IS_DEVICE(st.st_mode) && do_ftruncate(fd, offset) < 0) {<o:p></o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal><o:p> </o:p></p></div></body></html>