diff options
| author | Soumya Koduri <skoduri@redhat.com> | 2015-07-10 11:23:07 +0530 | 
|---|---|---|
| committer | Kaleb KEITHLEY <kkeithle@redhat.com> | 2015-07-15 08:08:30 -0700 | 
| commit | 09da0f0870dbb79d6e6dfddbfa452152c510d467 (patch) | |
| tree | 392d6db51ca10f9ba3c254f77a977fe6356bc323 | |
| parent | 94b0109a8ed55d5aebe0604ffb19cbb583797cf5 (diff) | |
syncop: Include iatt to 'syncop_link' args
Include iatt to 'syncop_link' args to fetch proper attributes of
the newly linked inode.
This is backport of the below fix -
http://review.gluster.org/11611
Change-Id: If6b92961bd7a89add3791ed3a9b494087348b492
BUG: 1243408
Reviewed-on: http://review.gluster.org/11611
Reviewed-by: Shyamsundar Ranganathan <srangana@redhat.com>
Reviewed-by: Kaleb KEITHLEY <kkeithle@redhat.com>
Signed-off-by: Soumya Koduri <skoduri@redhat.com>
Reviewed-on: http://review.gluster.org/11677
Tested-by: Gluster Build System <jenkins@build.gluster.com>
| -rw-r--r-- | api/src/glfs-fops.c | 4 | ||||
| -rw-r--r-- | api/src/glfs-handleops.c | 6 | ||||
| -rw-r--r-- | libglusterfs/src/syncop.c | 10 | ||||
| -rw-r--r-- | libglusterfs/src/syncop.h | 2 | ||||
| -rw-r--r-- | xlators/cluster/afr/src/afr-self-heal-entry.c | 2 | ||||
| -rw-r--r-- | xlators/cluster/dht/src/dht-rebalance.c | 2 | 
6 files changed, 16 insertions, 10 deletions
diff --git a/api/src/glfs-fops.c b/api/src/glfs-fops.c index 2997452e5c3..eaf18051f9c 100644 --- a/api/src/glfs-fops.c +++ b/api/src/glfs-fops.c @@ -1996,7 +1996,7 @@ retrynew:  	}          newloc.inode = inode_ref (oldloc.inode); -	ret = syncop_link (subvol, &oldloc, &newloc, NULL, NULL); +	ret = syncop_link (subvol, &oldloc, &newloc, &newiatt, NULL, NULL);          DECODE_SYNCOP_ERR (ret);  	if (ret == -1 && errno == ESTALE) { @@ -2007,7 +2007,7 @@ retrynew:  	}  	if (ret == 0) -		ret = glfs_loc_link (&newloc, &oldiatt); +		ret = glfs_loc_link (&newloc, &newiatt);  out:  	loc_wipe (&oldloc);  	loc_wipe (&newloc); diff --git a/api/src/glfs-handleops.c b/api/src/glfs-handleops.c index 9a85f194451..2e552b763dc 100644 --- a/api/src/glfs-handleops.c +++ b/api/src/glfs-handleops.c @@ -1572,6 +1572,7 @@ pub_glfs_h_link (struct glfs *fs, struct glfs_object *linksrc,          inode_t            *pinode = NULL;          loc_t               oldloc = {0, };          loc_t               newloc = {0, }; +        struct iatt         iatt = {0, };          DECLARE_OLD_THIS; @@ -1629,12 +1630,11 @@ pub_glfs_h_link (struct glfs *fs, struct glfs_object *linksrc,          newloc.inode = inode_ref (inode);          /* fop/op */ -        ret = syncop_link (subvol, &oldloc, &newloc, NULL, NULL); +        ret = syncop_link (subvol, &oldloc, &newloc, &iatt, NULL, NULL);          DECODE_SYNCOP_ERR (ret);          if (ret == 0) -                /* TODO: No iatt to pass as there has been no lookup */ -                ret = glfs_loc_link (&newloc, NULL); +                ret = glfs_loc_link (&newloc, &iatt);  out:          loc_wipe (&oldloc);          loc_wipe (&newloc); diff --git a/libglusterfs/src/syncop.c b/libglusterfs/src/syncop.c index 9e563a8b044..019e8962598 100644 --- a/libglusterfs/src/syncop.c +++ b/libglusterfs/src/syncop.c @@ -2163,6 +2163,9 @@ syncop_link_cbk (call_frame_t *frame, void *cookie, xlator_t *this,          if (xdata)                  args->xdata  = dict_ref (xdata); +        if (buf) +                args->iatt1 = *buf; +          __wake (args);          return 0; @@ -2170,14 +2173,17 @@ syncop_link_cbk (call_frame_t *frame, void *cookie, xlator_t *this,  int -syncop_link (xlator_t *subvol, loc_t *oldloc, loc_t *newloc, dict_t *xdata_in, -             dict_t **xdata_out) +syncop_link (xlator_t *subvol, loc_t *oldloc, loc_t *newloc, struct iatt *iatt, +             dict_t *xdata_in, dict_t **xdata_out)  {          struct syncargs args = {0, };          SYNCOP (subvol, (&args), syncop_link_cbk, subvol->fops->link,                  oldloc, newloc, xdata_in); +        if (iatt) +                *iatt = args.iatt1; +          if (xdata_out)                  *xdata_out = args.xdata;          else if (args.xdata) diff --git a/libglusterfs/src/syncop.h b/libglusterfs/src/syncop.h index ca25d98ea38..ee6e07f47ff 100644 --- a/libglusterfs/src/syncop.h +++ b/libglusterfs/src/syncop.h @@ -480,7 +480,7 @@ int syncop_mkdir (xlator_t *subvol, loc_t *loc, mode_t mode, struct iatt *iatt,                    dict_t *xdata_in, dict_t **xdata_out);  int syncop_link (xlator_t *subvol, loc_t *oldloc, loc_t *newloc, -                 dict_t *xdata_in, dict_t **xdata_out); +                 struct iatt *iatt, dict_t *xdata_in, dict_t **xdata_out);  int syncop_fsyncdir (xlator_t *subvol, fd_t *fd, int datasync,                       dict_t *xdata_in, dict_t **xdata_out); diff --git a/xlators/cluster/afr/src/afr-self-heal-entry.c b/xlators/cluster/afr/src/afr-self-heal-entry.c index 13a280fa66c..146c743c67d 100644 --- a/xlators/cluster/afr/src/afr-self-heal-entry.c +++ b/xlators/cluster/afr/src/afr-self-heal-entry.c @@ -131,7 +131,7 @@ afr_selfheal_recreate_entry (xlator_t *this, int dst, int source, inode_t *dir,  		ret = syncop_lookup (priv->children[dst], &srcloc, 0, 0, 0, 0);  		if (ret == 0) {  			ret = syncop_link (priv->children[dst], &srcloc, &loc, -					   NULL, NULL); +					   &newent, NULL, NULL);  		} else {  			ret = syncop_readlink (priv->children[source], &srcloc,  					       &linkname, 4096, NULL, NULL); diff --git a/xlators/cluster/dht/src/dht-rebalance.c b/xlators/cluster/dht/src/dht-rebalance.c index 39c1647d364..4db6134b8f9 100644 --- a/xlators/cluster/dht/src/dht-rebalance.c +++ b/xlators/cluster/dht/src/dht-rebalance.c @@ -319,7 +319,7 @@ gf_defrag_handle_hardlink (xlator_t *this, loc_t *loc, dict_t  *xattrs,                          hashed_subvol = linkto_subvol;                  } -                ret = syncop_link (hashed_subvol, loc, loc, NULL, NULL); +                ret = syncop_link (hashed_subvol, loc, loc, &iatt, NULL, NULL);                  if  (ret) {                          op_errno = -ret;                          ret = -1;  | 
