e6061c
--- libsndfile-1.0.28/src/rf64.c	2017-04-02 09:43:22.000000000 +0200
e6061c
+++ libsndfile-1.0.27/src/rf64.c	2016-04-01 23:08:53.000000000 +0200
e6061c
@@ -735,25 +734,27 @@ rf64_write_header (SF_PRIVATE *psf, int
e6061c
 
e6061c
 #endif
e6061c
 
e6061c
-	pad_size = psf->dataoffset - 16 - psf->header.indx ;
e6061c
-	if (pad_size >= 0)
e6061c
-		psf_binheader_writef (psf, "m4z", PAD_MARKER, pad_size, make_size_t (pad_size)) ;
e6061c
+	if (psf->header.indx + 8 < psf->dataoffset)
e6061c
+	{	/* Add PAD data if necessary. */
e6061c
+		int k = psf->dataoffset - 16 - psf->header.indx ;
e6061c
+		psf_binheader_writef (psf, "m4z", PAD_MARKER, k, make_size_t (k)) ;
e6061c
+		} ;
e6061c
 
e6061c
 	if (wpriv->rf64_downgrade && (psf->filelength < RIFF_DOWNGRADE_BYTES))
e6061c
 		psf_binheader_writef (psf, "tm8", data_MARKER, psf->datalength) ;
e6061c
 	else
e6061c
 		psf_binheader_writef (psf, "m4", data_MARKER, 0xffffffff) ;
e6061c
 
e6061c
-	psf_fwrite (psf->header.ptr, psf->header.indx, 1, psf) ;
e6061c
+	psf_fwrite (psf->header.ptr, psf->header.indx, 1, psf) ;
e6061c
 	if (psf->error)
e6061c
 		return psf->error ;
e6061c
 
e6061c
-	if (has_data && psf->dataoffset != psf->header.indx)
e6061c
-	{	psf_log_printf (psf, "Oooops : has_data && psf->dataoffset != psf->header.indx\n") ;
e6061c
+	if (has_data && psf->dataoffset != psf->header.indx)
e6061c
+	{	psf_log_printf (psf, "Oooops : has_data && psf->dataoffset != psf->header.indx\n") ;
e6061c
 		return psf->error = SFE_INTERNAL ;
e6061c
 		} ;
e6061c
 
e6061c
-	psf->dataoffset = psf->header.indx ;
e6061c
+	psf->dataoffset = psf->header.indx ;
e6061c
 
e6061c
 	if (NOT (has_data))
e6061c
 		psf_fseek (psf, psf->dataoffset, SEEK_SET) ;