diff mbox

implement librados aio_stat

Message ID 1355483921-15654-1-git-send-email-philipgian@grnet.gr (mailing list archive)
State New, archived
Headers show

Commit Message

Filippos Giannakos Dec. 14, 2012, 11:18 a.m. UTC
---
 src/include/rados/librados.h   |   14 ++++++++++++++
 src/include/rados/librados.hpp |   15 +++++++++++++-
 src/librados/IoCtxImpl.cc      |   42 ++++++++++++++++++++++++++++++++++++++++
 src/librados/IoCtxImpl.h       |    9 +++++++++
 src/librados/librados.cc       |   10 ++++++++++
 5 files changed, 89 insertions(+), 1 deletion(-)

--
1.7.10.4

--
To unsubscribe from this list: send the line "unsubscribe ceph-devel" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html

Comments

Filippos Giannakos Dec. 14, 2012, 12:19 p.m. UTC | #1
Hi team,

I forgot to include a description (also cc-ing correctly the 
synnefo-devel list).

I am a member of the Synnefo team, where we are experimenting with RADOS 
as a storage backend to host blocks for our volume block storage named 
"archipelago".

In this patch I implement aio stat and also export this functionality to 
the C API.

On 12/14/2012 01:18 PM, Filippos Giannakos wrote:
> ---
>   src/include/rados/librados.h   |   14 ++++++++++++++
>   src/include/rados/librados.hpp |   15 +++++++++++++-
>   src/librados/IoCtxImpl.cc      |   42 ++++++++++++++++++++++++++++++++++++++++
>   src/librados/IoCtxImpl.h       |    9 +++++++++
>   src/librados/librados.cc       |   10 ++++++++++
>   5 files changed, 89 insertions(+), 1 deletion(-)
>
> diff --git a/src/include/rados/librados.h b/src/include/rados/librados.h
> index 44d6f71..7f4b5c0 100644
> --- a/src/include/rados/librados.h
> +++ b/src/include/rados/librados.h
> @@ -1444,6 +1444,20 @@ int rados_aio_read(rados_ioctx_t io, const char *oid,
>    */
>   int rados_aio_flush(rados_ioctx_t io);
>
> +
> +/**
> + * Asynchronously get object stats (size/mtime)
> + *
> + * @param io ioctx
> + * @param o object name
> + * @param psize where to store object size
> + * @param pmtime where to store modification time
> + * @returns 0 on success, negative error code on failure
> + */
> +int rados_aio_stat(rados_ioctx_t io, const char *o,
> +		   rados_completion_t completion,
> +		   uint64_t *psize, time_t *pmtime);
> +
>   /** @} Asynchronous I/O */
>
>   /**
> diff --git a/src/include/rados/librados.hpp b/src/include/rados/librados.hpp
> index e50acdb..96bfc15 100644
> --- a/src/include/rados/librados.hpp
> +++ b/src/include/rados/librados.hpp
> @@ -473,9 +473,22 @@ namespace librados
>        * other than CEPH_NOSNAP
>        */
>       int aio_remove(const std::string&  oid, AioCompletion *c);
> -
> +
>       int aio_flush();
>
> +    /**
> +     * Asynchronously get object stats (size/mtime)
> +     *
> +     * @param io ioctx
> +     * @param o object name
> +     * @param psize where to store object size
> +     * @param pmtime where to store modification time
> +     * @returns 0 on success, negative error code on failure
> +     */
> +    int rados_aio_stat(rados_ioctx_t io, const char *o,
> +		       rados_completion_t completion,
> +		       uint64_t *psize, time_t *pmtime);
> +
>       int aio_exec(const std::string&  oid, AioCompletion *c, const char *cls, const char *method,
>   	         bufferlist&  inbl, bufferlist *outbl);
>
> diff --git a/src/librados/IoCtxImpl.cc b/src/librados/IoCtxImpl.cc
> index 01b4a94..50aab1e 100644
> --- a/src/librados/IoCtxImpl.cc
> +++ b/src/librados/IoCtxImpl.cc
> @@ -851,6 +851,21 @@ int librados::IoCtxImpl::aio_remove(const object_t&oid, AioCompletionImpl *c)
>     return 0;
>   }
>
> +
> +int librados::IoCtxImpl::aio_stat(const object_t&  oid, AioCompletionImpl *c,
> +		                  uint64_t *psize, time_t *pmtime)
> +{
> +  c->io = this;
> +  C_aio_stat_Ack *onack = new C_aio_stat_Ack(c, pmtime);
> +
> +  Mutex::Locker l(*lock);
> +  objecter->stat(oid, oloc,
> +		 snap_seq, psize,&onack->mtime, 0,
> +		 onack,&c->objver);
> +
> +  return 0;
> +}
> +
>   int librados::IoCtxImpl::remove(const object_t&  oid)
>   {
>     utime_t ut = ceph_clock_now(client->cct);
> @@ -1562,6 +1577,33 @@ void librados::IoCtxImpl::C_aio_Ack::finish(int r)
>     c->put_unlock();
>   }
>
> +///////////////////////////// C_aio_stat_Ack ////////////////////////////
> +
> +librados::IoCtxImpl::C_aio_stat_Ack::C_aio_stat_Ack(AioCompletionImpl *_c,
> +						    time_t *pm)
> +   : c(_c), pmtime(pm)
> +{
> +  c->get();
> +}
> +
> +void librados::IoCtxImpl::C_aio_stat_Ack::finish(int r)
> +{
> +  c->lock.Lock();
> +  c->rval = r;
> +  c->ack = true;
> +  c->cond.Signal();
> +
> +  if (r>= 0&&  pmtime) {
> +    *pmtime = mtime.sec();
> +  }
> +
> +  if (c->callback_complete) {
> +    c->io->client->finisher.queue(new C_AioComplete(c));
> +  }
> +
> +  c->put_unlock();
> +}
> +
>   /////////////////////// C_aio_sparse_read_Ack //////////////////////////
>
>   librados::IoCtxImpl::C_aio_sparse_read_Ack::C_aio_sparse_read_Ack(AioCompletionImpl *_c,
> diff --git a/src/librados/IoCtxImpl.h b/src/librados/IoCtxImpl.h
> index feea0e8..55b07ee 100644
> --- a/src/librados/IoCtxImpl.h
> +++ b/src/librados/IoCtxImpl.h
> @@ -144,6 +144,14 @@ struct librados::IoCtxImpl {
>       C_aio_Ack(AioCompletionImpl *_c);
>       void finish(int r);
>     };
> +
> +  struct C_aio_stat_Ack : public Context {
> +    librados::AioCompletionImpl *c;
> +    time_t *pmtime;
> +    utime_t mtime;
> +    C_aio_stat_Ack(AioCompletionImpl *_c, time_t *pm);
> +    void finish(int r);
> +  };
>
>     struct C_aio_sparse_read_Ack : public Context {
>       AioCompletionImpl *c;
> @@ -177,6 +185,7 @@ struct librados::IoCtxImpl {
>     int aio_remove(const object_t&oid, AioCompletionImpl *c);
>     int aio_exec(const object_t&  oid, AioCompletionImpl *c, const char *cls,
>   	       const char *method, bufferlist&  inbl, bufferlist *outbl);
> +  int aio_stat(const object_t&  oid, AioCompletionImpl *c, uint64_t *psize, time_t *pmtime);
>
>     int pool_change_auid(unsigned long long auid);
>     int pool_change_auid_async(unsigned long long auid, PoolAsyncCompletionImpl *c);
> diff --git a/src/librados/librados.cc b/src/librados/librados.cc
> index 274119c..af36b38 100644
> --- a/src/librados/librados.cc
> +++ b/src/librados/librados.cc
> @@ -2167,6 +2167,16 @@ extern "C" int rados_aio_flush(rados_ioctx_t io)
>     return 0;
>   }
>
> +extern "C" int rados_aio_stat(rados_ioctx_t io, const char *o,
> +			      rados_completion_t completion,
> +			      uint64_t *psize, time_t *pmtime)
> +{
> +  librados::IoCtxImpl *ctx = (librados::IoCtxImpl *)io;
> +  object_t oid(o);
> +  return ctx->aio_stat(oid, (librados::AioCompletionImpl*)completion,
> +		       psize, pmtime);
> +}
> +
>   struct C_WatchCB : public librados::WatchCtx {
>     rados_watchcb_t wcb;
>     void *arg;
> --
> 1.7.10.4
>

--
To unsubscribe from this list: send the line "unsubscribe ceph-devel" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Yehuda Sadeh Dec. 15, 2012, 7:49 a.m. UTC | #2
Went through it briefly, looks fine, though I'd like to go over it
some more before picking this up. Note that LIBRADOS_VER_MINOR needs
to be bumped up too.

Thanks,
Yehuda

On Fri, Dec 14, 2012 at 3:18 AM, Filippos Giannakos <philipgian@grnet.gr> wrote:
> ---
>  src/include/rados/librados.h   |   14 ++++++++++++++
>  src/include/rados/librados.hpp |   15 +++++++++++++-
>  src/librados/IoCtxImpl.cc      |   42 ++++++++++++++++++++++++++++++++++++++++
>  src/librados/IoCtxImpl.h       |    9 +++++++++
>  src/librados/librados.cc       |   10 ++++++++++
>  5 files changed, 89 insertions(+), 1 deletion(-)
>
> diff --git a/src/include/rados/librados.h b/src/include/rados/librados.h
> index 44d6f71..7f4b5c0 100644
> --- a/src/include/rados/librados.h
> +++ b/src/include/rados/librados.h
> @@ -1444,6 +1444,20 @@ int rados_aio_read(rados_ioctx_t io, const char *oid,
>   */
>  int rados_aio_flush(rados_ioctx_t io);
>
> +
> +/**
> + * Asynchronously get object stats (size/mtime)
> + *
> + * @param io ioctx
> + * @param o object name
> + * @param psize where to store object size
> + * @param pmtime where to store modification time
> + * @returns 0 on success, negative error code on failure
> + */
> +int rados_aio_stat(rados_ioctx_t io, const char *o,
> +                  rados_completion_t completion,
> +                  uint64_t *psize, time_t *pmtime);
> +
>  /** @} Asynchronous I/O */
>
>  /**
> diff --git a/src/include/rados/librados.hpp b/src/include/rados/librados.hpp
> index e50acdb..96bfc15 100644
> --- a/src/include/rados/librados.hpp
> +++ b/src/include/rados/librados.hpp
> @@ -473,9 +473,22 @@ namespace librados
>       * other than CEPH_NOSNAP
>       */
>      int aio_remove(const std::string& oid, AioCompletion *c);
> -
> +
>      int aio_flush();
>
> +    /**
> +     * Asynchronously get object stats (size/mtime)
> +     *
> +     * @param io ioctx
> +     * @param o object name
> +     * @param psize where to store object size
> +     * @param pmtime where to store modification time
> +     * @returns 0 on success, negative error code on failure
> +     */
> +    int rados_aio_stat(rados_ioctx_t io, const char *o,
> +                      rados_completion_t completion,
> +                      uint64_t *psize, time_t *pmtime);
> +
>      int aio_exec(const std::string& oid, AioCompletion *c, const char *cls, const char *method,
>                  bufferlist& inbl, bufferlist *outbl);
>
> diff --git a/src/librados/IoCtxImpl.cc b/src/librados/IoCtxImpl.cc
> index 01b4a94..50aab1e 100644
> --- a/src/librados/IoCtxImpl.cc
> +++ b/src/librados/IoCtxImpl.cc
> @@ -851,6 +851,21 @@ int librados::IoCtxImpl::aio_remove(const object_t &oid, AioCompletionImpl *c)
>    return 0;
>  }
>
> +
> +int librados::IoCtxImpl::aio_stat(const object_t& oid, AioCompletionImpl *c,
> +                                 uint64_t *psize, time_t *pmtime)
> +{
> +  c->io = this;
> +  C_aio_stat_Ack *onack = new C_aio_stat_Ack(c, pmtime);
> +
> +  Mutex::Locker l(*lock);
> +  objecter->stat(oid, oloc,
> +                snap_seq, psize, &onack->mtime, 0,
> +                onack, &c->objver);
> +
> +  return 0;
> +}
> +
>  int librados::IoCtxImpl::remove(const object_t& oid)
>  {
>    utime_t ut = ceph_clock_now(client->cct);
> @@ -1562,6 +1577,33 @@ void librados::IoCtxImpl::C_aio_Ack::finish(int r)
>    c->put_unlock();
>  }
>
> +///////////////////////////// C_aio_stat_Ack ////////////////////////////
> +
> +librados::IoCtxImpl::C_aio_stat_Ack::C_aio_stat_Ack(AioCompletionImpl *_c,
> +                                                   time_t *pm)
> +   : c(_c), pmtime(pm)
> +{
> +  c->get();
> +}
> +
> +void librados::IoCtxImpl::C_aio_stat_Ack::finish(int r)
> +{
> +  c->lock.Lock();
> +  c->rval = r;
> +  c->ack = true;
> +  c->cond.Signal();
> +
> +  if (r >= 0 && pmtime) {
> +    *pmtime = mtime.sec();
> +  }
> +
> +  if (c->callback_complete) {
> +    c->io->client->finisher.queue(new C_AioComplete(c));
> +  }
> +
> +  c->put_unlock();
> +}
> +
>  /////////////////////// C_aio_sparse_read_Ack //////////////////////////
>
>  librados::IoCtxImpl::C_aio_sparse_read_Ack::C_aio_sparse_read_Ack(AioCompletionImpl *_c,
> diff --git a/src/librados/IoCtxImpl.h b/src/librados/IoCtxImpl.h
> index feea0e8..55b07ee 100644
> --- a/src/librados/IoCtxImpl.h
> +++ b/src/librados/IoCtxImpl.h
> @@ -144,6 +144,14 @@ struct librados::IoCtxImpl {
>      C_aio_Ack(AioCompletionImpl *_c);
>      void finish(int r);
>    };
> +
> +  struct C_aio_stat_Ack : public Context {
> +    librados::AioCompletionImpl *c;
> +    time_t *pmtime;
> +    utime_t mtime;
> +    C_aio_stat_Ack(AioCompletionImpl *_c, time_t *pm);
> +    void finish(int r);
> +  };
>
>    struct C_aio_sparse_read_Ack : public Context {
>      AioCompletionImpl *c;
> @@ -177,6 +185,7 @@ struct librados::IoCtxImpl {
>    int aio_remove(const object_t &oid, AioCompletionImpl *c);
>    int aio_exec(const object_t& oid, AioCompletionImpl *c, const char *cls,
>                const char *method, bufferlist& inbl, bufferlist *outbl);
> +  int aio_stat(const object_t& oid, AioCompletionImpl *c, uint64_t *psize, time_t *pmtime);
>
>    int pool_change_auid(unsigned long long auid);
>    int pool_change_auid_async(unsigned long long auid, PoolAsyncCompletionImpl *c);
> diff --git a/src/librados/librados.cc b/src/librados/librados.cc
> index 274119c..af36b38 100644
> --- a/src/librados/librados.cc
> +++ b/src/librados/librados.cc
> @@ -2167,6 +2167,16 @@ extern "C" int rados_aio_flush(rados_ioctx_t io)
>    return 0;
>  }
>
> +extern "C" int rados_aio_stat(rados_ioctx_t io, const char *o,
> +                             rados_completion_t completion,
> +                             uint64_t *psize, time_t *pmtime)
> +{
> +  librados::IoCtxImpl *ctx = (librados::IoCtxImpl *)io;
> +  object_t oid(o);
> +  return ctx->aio_stat(oid, (librados::AioCompletionImpl*)completion,
> +                      psize, pmtime);
> +}
> +
>  struct C_WatchCB : public librados::WatchCtx {
>    rados_watchcb_t wcb;
>    void *arg;
> --
> 1.7.10.4
>
> --
> To unsubscribe from this list: send the line "unsubscribe ceph-devel" in
> the body of a message to majordomo@vger.kernel.org
> More majordomo info at  http://vger.kernel.org/majordomo-info.html
--
To unsubscribe from this list: send the line "unsubscribe ceph-devel" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Filippos Giannakos Dec. 19, 2012, 9:13 a.m. UTC | #3
OK. About the LIBRADOS_VER_MINOR, do you want me to bump it and submit a
new patch?

Best regards,
Filippos

On 12/15/2012 09:49 AM, Yehuda Sadeh wrote:
> Went through it briefly, looks fine, though I'd like to go over it
> some more before picking this up. Note that LIBRADOS_VER_MINOR needs
> to be bumped up too.
>
> Thanks,
> Yehuda
>
> On Fri, Dec 14, 2012 at 3:18 AM, Filippos Giannakos<philipgian@grnet.gr>  wrote:
>> ---
>>   src/include/rados/librados.h   |   14 ++++++++++++++
>>   src/include/rados/librados.hpp |   15 +++++++++++++-
>>   src/librados/IoCtxImpl.cc      |   42 ++++++++++++++++++++++++++++++++++++++++
>>   src/librados/IoCtxImpl.h       |    9 +++++++++
>>   src/librados/librados.cc       |   10 ++++++++++
>>   5 files changed, 89 insertions(+), 1 deletion(-)
>>
>> diff --git a/src/include/rados/librados.h b/src/include/rados/librados.h
>> index 44d6f71..7f4b5c0 100644
>> --- a/src/include/rados/librados.h
>> +++ b/src/include/rados/librados.h
>> @@ -1444,6 +1444,20 @@ int rados_aio_read(rados_ioctx_t io, const char *oid,
>>    */
>>   int rados_aio_flush(rados_ioctx_t io);
>>
>> +
>> +/**
>> + * Asynchronously get object stats (size/mtime)
>> + *
>> + * @param io ioctx
>> + * @param o object name
>> + * @param psize where to store object size
>> + * @param pmtime where to store modification time
>> + * @returns 0 on success, negative error code on failure
>> + */
>> +int rados_aio_stat(rados_ioctx_t io, const char *o,
>> +                  rados_completion_t completion,
>> +                  uint64_t *psize, time_t *pmtime);
>> +
>>   /** @} Asynchronous I/O */
>>
>>   /**
>> diff --git a/src/include/rados/librados.hpp b/src/include/rados/librados.hpp
>> index e50acdb..96bfc15 100644
>> --- a/src/include/rados/librados.hpp
>> +++ b/src/include/rados/librados.hpp
>> @@ -473,9 +473,22 @@ namespace librados
>>        * other than CEPH_NOSNAP
>>        */
>>       int aio_remove(const std::string&  oid, AioCompletion *c);
>> -
>> +
>>       int aio_flush();
>>
>> +    /**
>> +     * Asynchronously get object stats (size/mtime)
>> +     *
>> +     * @param io ioctx
>> +     * @param o object name
>> +     * @param psize where to store object size
>> +     * @param pmtime where to store modification time
>> +     * @returns 0 on success, negative error code on failure
>> +     */
>> +    int rados_aio_stat(rados_ioctx_t io, const char *o,
>> +                      rados_completion_t completion,
>> +                      uint64_t *psize, time_t *pmtime);
>> +
>>       int aio_exec(const std::string&  oid, AioCompletion *c, const char *cls, const char *method,
>>                   bufferlist&  inbl, bufferlist *outbl);
>>
>> diff --git a/src/librados/IoCtxImpl.cc b/src/librados/IoCtxImpl.cc
>> index 01b4a94..50aab1e 100644
>> --- a/src/librados/IoCtxImpl.cc
>> +++ b/src/librados/IoCtxImpl.cc
>> @@ -851,6 +851,21 @@ int librados::IoCtxImpl::aio_remove(const object_t&oid, AioCompletionImpl *c)
>>     return 0;
>>   }
>>
>> +
>> +int librados::IoCtxImpl::aio_stat(const object_t&  oid, AioCompletionImpl *c,
>> +                                 uint64_t *psize, time_t *pmtime)
>> +{
>> +  c->io = this;
>> +  C_aio_stat_Ack *onack = new C_aio_stat_Ack(c, pmtime);
>> +
>> +  Mutex::Locker l(*lock);
>> +  objecter->stat(oid, oloc,
>> +                snap_seq, psize,&onack->mtime, 0,
>> +                onack,&c->objver);
>> +
>> +  return 0;
>> +}
>> +
>>   int librados::IoCtxImpl::remove(const object_t&  oid)
>>   {
>>     utime_t ut = ceph_clock_now(client->cct);
>> @@ -1562,6 +1577,33 @@ void librados::IoCtxImpl::C_aio_Ack::finish(int r)
>>     c->put_unlock();
>>   }
>>
>> +///////////////////////////// C_aio_stat_Ack ////////////////////////////
>> +
>> +librados::IoCtxImpl::C_aio_stat_Ack::C_aio_stat_Ack(AioCompletionImpl *_c,
>> +                                                   time_t *pm)
>> +   : c(_c), pmtime(pm)
>> +{
>> +  c->get();
>> +}
>> +
>> +void librados::IoCtxImpl::C_aio_stat_Ack::finish(int r)
>> +{
>> +  c->lock.Lock();
>> +  c->rval = r;
>> +  c->ack = true;
>> +  c->cond.Signal();
>> +
>> +  if (r>= 0&&  pmtime) {
>> +    *pmtime = mtime.sec();
>> +  }
>> +
>> +  if (c->callback_complete) {
>> +    c->io->client->finisher.queue(new C_AioComplete(c));
>> +  }
>> +
>> +  c->put_unlock();
>> +}
>> +
>>   /////////////////////// C_aio_sparse_read_Ack //////////////////////////
>>
>>   librados::IoCtxImpl::C_aio_sparse_read_Ack::C_aio_sparse_read_Ack(AioCompletionImpl *_c,
>> diff --git a/src/librados/IoCtxImpl.h b/src/librados/IoCtxImpl.h
>> index feea0e8..55b07ee 100644
>> --- a/src/librados/IoCtxImpl.h
>> +++ b/src/librados/IoCtxImpl.h
>> @@ -144,6 +144,14 @@ struct librados::IoCtxImpl {
>>       C_aio_Ack(AioCompletionImpl *_c);
>>       void finish(int r);
>>     };
>> +
>> +  struct C_aio_stat_Ack : public Context {
>> +    librados::AioCompletionImpl *c;
>> +    time_t *pmtime;
>> +    utime_t mtime;
>> +    C_aio_stat_Ack(AioCompletionImpl *_c, time_t *pm);
>> +    void finish(int r);
>> +  };
>>
>>     struct C_aio_sparse_read_Ack : public Context {
>>       AioCompletionImpl *c;
>> @@ -177,6 +185,7 @@ struct librados::IoCtxImpl {
>>     int aio_remove(const object_t&oid, AioCompletionImpl *c);
>>     int aio_exec(const object_t&  oid, AioCompletionImpl *c, const char *cls,
>>                 const char *method, bufferlist&  inbl, bufferlist *outbl);
>> +  int aio_stat(const object_t&  oid, AioCompletionImpl *c, uint64_t *psize, time_t *pmtime);
>>
>>     int pool_change_auid(unsigned long long auid);
>>     int pool_change_auid_async(unsigned long long auid, PoolAsyncCompletionImpl *c);
>> diff --git a/src/librados/librados.cc b/src/librados/librados.cc
>> index 274119c..af36b38 100644
>> --- a/src/librados/librados.cc
>> +++ b/src/librados/librados.cc
>> @@ -2167,6 +2167,16 @@ extern "C" int rados_aio_flush(rados_ioctx_t io)
>>     return 0;
>>   }
>>
>> +extern "C" int rados_aio_stat(rados_ioctx_t io, const char *o,
>> +                             rados_completion_t completion,
>> +                             uint64_t *psize, time_t *pmtime)
>> +{
>> +  librados::IoCtxImpl *ctx = (librados::IoCtxImpl *)io;
>> +  object_t oid(o);
>> +  return ctx->aio_stat(oid, (librados::AioCompletionImpl*)completion,
>> +                      psize, pmtime);
>> +}
>> +
>>   struct C_WatchCB : public librados::WatchCtx {
>>     rados_watchcb_t wcb;
>>     void *arg;
>> --
>> 1.7.10.4
>>
>> --
>> To unsubscribe from this list: send the line "unsubscribe ceph-devel" in
>> the body of a message to majordomo@vger.kernel.org
>> More majordomo info at  http://vger.kernel.org/majordomo-info.html

--
To unsubscribe from this list: send the line "unsubscribe ceph-devel" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Sage Weil Dec. 19, 2012, 3:43 p.m. UTC | #4
On Wed, 19 Dec 2012, Filippos Giannakos wrote:
> OK. About the LIBRADOS_VER_MINOR, do you want me to bump it and submit a
> new patch?

Yes, please.  Also, one other thing: can you add a functional test to 
ceph.git/src/test/librados/aio.cc so that all of the the regular testing 
and test suites will exercise the new code?

Thanks!
sage


> 
> Best regards,
> Filippos
> 
> On 12/15/2012 09:49 AM, Yehuda Sadeh wrote:
> > Went through it briefly, looks fine, though I'd like to go over it
> > some more before picking this up. Note that LIBRADOS_VER_MINOR needs
> > to be bumped up too.
> > 
> > Thanks,
> > Yehuda
> > 
> > On Fri, Dec 14, 2012 at 3:18 AM, Filippos Giannakos<philipgian@grnet.gr>
> > wrote:
> > > ---
> > >   src/include/rados/librados.h   |   14 ++++++++++++++
> > >   src/include/rados/librados.hpp |   15 +++++++++++++-
> > >   src/librados/IoCtxImpl.cc      |   42
> > > ++++++++++++++++++++++++++++++++++++++++
> > >   src/librados/IoCtxImpl.h       |    9 +++++++++
> > >   src/librados/librados.cc       |   10 ++++++++++
> > >   5 files changed, 89 insertions(+), 1 deletion(-)
> > > 
> > > diff --git a/src/include/rados/librados.h b/src/include/rados/librados.h
> > > index 44d6f71..7f4b5c0 100644
> > > --- a/src/include/rados/librados.h
> > > +++ b/src/include/rados/librados.h
> > > @@ -1444,6 +1444,20 @@ int rados_aio_read(rados_ioctx_t io, const char
> > > *oid,
> > >    */
> > >   int rados_aio_flush(rados_ioctx_t io);
> > > 
> > > +
> > > +/**
> > > + * Asynchronously get object stats (size/mtime)
> > > + *
> > > + * @param io ioctx
> > > + * @param o object name
> > > + * @param psize where to store object size
> > > + * @param pmtime where to store modification time
> > > + * @returns 0 on success, negative error code on failure
> > > + */
> > > +int rados_aio_stat(rados_ioctx_t io, const char *o,
> > > +                  rados_completion_t completion,
> > > +                  uint64_t *psize, time_t *pmtime);
> > > +
> > >   /** @} Asynchronous I/O */
> > > 
> > >   /**
> > > diff --git a/src/include/rados/librados.hpp
> > > b/src/include/rados/librados.hpp
> > > index e50acdb..96bfc15 100644
> > > --- a/src/include/rados/librados.hpp
> > > +++ b/src/include/rados/librados.hpp
> > > @@ -473,9 +473,22 @@ namespace librados
> > >        * other than CEPH_NOSNAP
> > >        */
> > >       int aio_remove(const std::string&  oid, AioCompletion *c);
> > > -
> > > +
> > >       int aio_flush();
> > > 
> > > +    /**
> > > +     * Asynchronously get object stats (size/mtime)
> > > +     *
> > > +     * @param io ioctx
> > > +     * @param o object name
> > > +     * @param psize where to store object size
> > > +     * @param pmtime where to store modification time
> > > +     * @returns 0 on success, negative error code on failure
> > > +     */
> > > +    int rados_aio_stat(rados_ioctx_t io, const char *o,
> > > +                      rados_completion_t completion,
> > > +                      uint64_t *psize, time_t *pmtime);
> > > +
> > >       int aio_exec(const std::string&  oid, AioCompletion *c, const char
> > > *cls, const char *method,
> > >                   bufferlist&  inbl, bufferlist *outbl);
> > > 
> > > diff --git a/src/librados/IoCtxImpl.cc b/src/librados/IoCtxImpl.cc
> > > index 01b4a94..50aab1e 100644
> > > --- a/src/librados/IoCtxImpl.cc
> > > +++ b/src/librados/IoCtxImpl.cc
> > > @@ -851,6 +851,21 @@ int librados::IoCtxImpl::aio_remove(const
> > > object_t&oid, AioCompletionImpl *c)
> > >     return 0;
> > >   }
> > > 
> > > +
> > > +int librados::IoCtxImpl::aio_stat(const object_t&  oid, AioCompletionImpl
> > > *c,
> > > +                                 uint64_t *psize, time_t *pmtime)
> > > +{
> > > +  c->io = this;
> > > +  C_aio_stat_Ack *onack = new C_aio_stat_Ack(c, pmtime);
> > > +
> > > +  Mutex::Locker l(*lock);
> > > +  objecter->stat(oid, oloc,
> > > +                snap_seq, psize,&onack->mtime, 0,
> > > +                onack,&c->objver);
> > > +
> > > +  return 0;
> > > +}
> > > +
> > >   int librados::IoCtxImpl::remove(const object_t&  oid)
> > >   {
> > >     utime_t ut = ceph_clock_now(client->cct);
> > > @@ -1562,6 +1577,33 @@ void librados::IoCtxImpl::C_aio_Ack::finish(int r)
> > >     c->put_unlock();
> > >   }
> > > 
> > > +///////////////////////////// C_aio_stat_Ack ////////////////////////////
> > > +
> > > +librados::IoCtxImpl::C_aio_stat_Ack::C_aio_stat_Ack(AioCompletionImpl
> > > *_c,
> > > +                                                   time_t *pm)
> > > +   : c(_c), pmtime(pm)
> > > +{
> > > +  c->get();
> > > +}
> > > +
> > > +void librados::IoCtxImpl::C_aio_stat_Ack::finish(int r)
> > > +{
> > > +  c->lock.Lock();
> > > +  c->rval = r;
> > > +  c->ack = true;
> > > +  c->cond.Signal();
> > > +
> > > +  if (r>= 0&&  pmtime) {
> > > +    *pmtime = mtime.sec();
> > > +  }
> > > +
> > > +  if (c->callback_complete) {
> > > +    c->io->client->finisher.queue(new C_AioComplete(c));
> > > +  }
> > > +
> > > +  c->put_unlock();
> > > +}
> > > +
> > >   /////////////////////// C_aio_sparse_read_Ack //////////////////////////
> > > 
> > >   librados::IoCtxImpl::C_aio_sparse_read_Ack::C_aio_sparse_read_Ack(AioCompletionImpl
> > > *_c,
> > > diff --git a/src/librados/IoCtxImpl.h b/src/librados/IoCtxImpl.h
> > > index feea0e8..55b07ee 100644
> > > --- a/src/librados/IoCtxImpl.h
> > > +++ b/src/librados/IoCtxImpl.h
> > > @@ -144,6 +144,14 @@ struct librados::IoCtxImpl {
> > >       C_aio_Ack(AioCompletionImpl *_c);
> > >       void finish(int r);
> > >     };
> > > +
> > > +  struct C_aio_stat_Ack : public Context {
> > > +    librados::AioCompletionImpl *c;
> > > +    time_t *pmtime;
> > > +    utime_t mtime;
> > > +    C_aio_stat_Ack(AioCompletionImpl *_c, time_t *pm);
> > > +    void finish(int r);
> > > +  };
> > > 
> > >     struct C_aio_sparse_read_Ack : public Context {
> > >       AioCompletionImpl *c;
> > > @@ -177,6 +185,7 @@ struct librados::IoCtxImpl {
> > >     int aio_remove(const object_t&oid, AioCompletionImpl *c);
> > >     int aio_exec(const object_t&  oid, AioCompletionImpl *c, const char
> > > *cls,
> > >                 const char *method, bufferlist&  inbl, bufferlist *outbl);
> > > +  int aio_stat(const object_t&  oid, AioCompletionImpl *c, uint64_t
> > > *psize, time_t *pmtime);
> > > 
> > >     int pool_change_auid(unsigned long long auid);
> > >     int pool_change_auid_async(unsigned long long auid,
> > > PoolAsyncCompletionImpl *c);
> > > diff --git a/src/librados/librados.cc b/src/librados/librados.cc
> > > index 274119c..af36b38 100644
> > > --- a/src/librados/librados.cc
> > > +++ b/src/librados/librados.cc
> > > @@ -2167,6 +2167,16 @@ extern "C" int rados_aio_flush(rados_ioctx_t io)
> > >     return 0;
> > >   }
> > > 
> > > +extern "C" int rados_aio_stat(rados_ioctx_t io, const char *o,
> > > +                             rados_completion_t completion,
> > > +                             uint64_t *psize, time_t *pmtime)
> > > +{
> > > +  librados::IoCtxImpl *ctx = (librados::IoCtxImpl *)io;
> > > +  object_t oid(o);
> > > +  return ctx->aio_stat(oid, (librados::AioCompletionImpl*)completion,
> > > +                      psize, pmtime);
> > > +}
> > > +
> > >   struct C_WatchCB : public librados::WatchCtx {
> > >     rados_watchcb_t wcb;
> > >     void *arg;
> > > --
> > > 1.7.10.4
> > > 
> > > --
> > > To unsubscribe from this list: send the line "unsubscribe ceph-devel" in
> > > the body of a message to majordomo@vger.kernel.org
> > > More majordomo info at  http://vger.kernel.org/majordomo-info.html
> 
> --
> To unsubscribe from this list: send the line "unsubscribe ceph-devel" in
> the body of a message to majordomo@vger.kernel.org
> More majordomo info at  http://vger.kernel.org/majordomo-info.html
> 
> 
--
To unsubscribe from this list: send the line "unsubscribe ceph-devel" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Josh Durgin Dec. 19, 2012, 3:53 p.m. UTC | #5
On 12/19/2012 07:43 AM, Sage Weil wrote:
> On Wed, 19 Dec 2012, Filippos Giannakos wrote:
>> OK. About the LIBRADOS_VER_MINOR, do you want me to bump it and submit a
>> new patch?
>
> Yes, please.  Also, one other thing: can you add a functional test to
> ceph.git/src/test/librados/aio.cc so that all of the the regular testing
> and test suites will exercise the new code?

Also the C++ version can just be aio_stat rather than rados_aio_stat.
It's already in the librados namespace.

Josh

> Thanks!
> sage
>
>
>>
>> Best regards,
>> Filippos
>>
>> On 12/15/2012 09:49 AM, Yehuda Sadeh wrote:
>>> Went through it briefly, looks fine, though I'd like to go over it
>>> some more before picking this up. Note that LIBRADOS_VER_MINOR needs
>>> to be bumped up too.
>>>
>>> Thanks,
>>> Yehuda
>>>
>>> On Fri, Dec 14, 2012 at 3:18 AM, Filippos Giannakos<philipgian@grnet.gr>
>>> wrote:
>>>> ---
>>>>    src/include/rados/librados.h   |   14 ++++++++++++++
>>>>    src/include/rados/librados.hpp |   15 +++++++++++++-
>>>>    src/librados/IoCtxImpl.cc      |   42
>>>> ++++++++++++++++++++++++++++++++++++++++
>>>>    src/librados/IoCtxImpl.h       |    9 +++++++++
>>>>    src/librados/librados.cc       |   10 ++++++++++
>>>>    5 files changed, 89 insertions(+), 1 deletion(-)
>>>>
>>>> diff --git a/src/include/rados/librados.h b/src/include/rados/librados.h
>>>> index 44d6f71..7f4b5c0 100644
>>>> --- a/src/include/rados/librados.h
>>>> +++ b/src/include/rados/librados.h
>>>> @@ -1444,6 +1444,20 @@ int rados_aio_read(rados_ioctx_t io, const char
>>>> *oid,
>>>>     */
>>>>    int rados_aio_flush(rados_ioctx_t io);
>>>>
>>>> +
>>>> +/**
>>>> + * Asynchronously get object stats (size/mtime)
>>>> + *
>>>> + * @param io ioctx
>>>> + * @param o object name
>>>> + * @param psize where to store object size
>>>> + * @param pmtime where to store modification time
>>>> + * @returns 0 on success, negative error code on failure
>>>> + */
>>>> +int rados_aio_stat(rados_ioctx_t io, const char *o,
>>>> +                  rados_completion_t completion,
>>>> +                  uint64_t *psize, time_t *pmtime);
>>>> +
>>>>    /** @} Asynchronous I/O */
>>>>
>>>>    /**
>>>> diff --git a/src/include/rados/librados.hpp
>>>> b/src/include/rados/librados.hpp
>>>> index e50acdb..96bfc15 100644
>>>> --- a/src/include/rados/librados.hpp
>>>> +++ b/src/include/rados/librados.hpp
>>>> @@ -473,9 +473,22 @@ namespace librados
>>>>         * other than CEPH_NOSNAP
>>>>         */
>>>>        int aio_remove(const std::string&  oid, AioCompletion *c);
>>>> -
>>>> +
>>>>        int aio_flush();
>>>>
>>>> +    /**
>>>> +     * Asynchronously get object stats (size/mtime)
>>>> +     *
>>>> +     * @param io ioctx
>>>> +     * @param o object name
>>>> +     * @param psize where to store object size
>>>> +     * @param pmtime where to store modification time
>>>> +     * @returns 0 on success, negative error code on failure
>>>> +     */
>>>> +    int rados_aio_stat(rados_ioctx_t io, const char *o,
>>>> +                      rados_completion_t completion,
>>>> +                      uint64_t *psize, time_t *pmtime);
>>>> +
>>>>        int aio_exec(const std::string&  oid, AioCompletion *c, const char
>>>> *cls, const char *method,
>>>>                    bufferlist&  inbl, bufferlist *outbl);
>>>>
>>>> diff --git a/src/librados/IoCtxImpl.cc b/src/librados/IoCtxImpl.cc
>>>> index 01b4a94..50aab1e 100644
>>>> --- a/src/librados/IoCtxImpl.cc
>>>> +++ b/src/librados/IoCtxImpl.cc
>>>> @@ -851,6 +851,21 @@ int librados::IoCtxImpl::aio_remove(const
>>>> object_t&oid, AioCompletionImpl *c)
>>>>      return 0;
>>>>    }
>>>>
>>>> +
>>>> +int librados::IoCtxImpl::aio_stat(const object_t&  oid, AioCompletionImpl
>>>> *c,
>>>> +                                 uint64_t *psize, time_t *pmtime)
>>>> +{
>>>> +  c->io = this;
>>>> +  C_aio_stat_Ack *onack = new C_aio_stat_Ack(c, pmtime);
>>>> +
>>>> +  Mutex::Locker l(*lock);
>>>> +  objecter->stat(oid, oloc,
>>>> +                snap_seq, psize,&onack->mtime, 0,
>>>> +                onack,&c->objver);
>>>> +
>>>> +  return 0;
>>>> +}
>>>> +
>>>>    int librados::IoCtxImpl::remove(const object_t&  oid)
>>>>    {
>>>>      utime_t ut = ceph_clock_now(client->cct);
>>>> @@ -1562,6 +1577,33 @@ void librados::IoCtxImpl::C_aio_Ack::finish(int r)
>>>>      c->put_unlock();
>>>>    }
>>>>
>>>> +///////////////////////////// C_aio_stat_Ack ////////////////////////////
>>>> +
>>>> +librados::IoCtxImpl::C_aio_stat_Ack::C_aio_stat_Ack(AioCompletionImpl
>>>> *_c,
>>>> +                                                   time_t *pm)
>>>> +   : c(_c), pmtime(pm)
>>>> +{
>>>> +  c->get();
>>>> +}
>>>> +
>>>> +void librados::IoCtxImpl::C_aio_stat_Ack::finish(int r)
>>>> +{
>>>> +  c->lock.Lock();
>>>> +  c->rval = r;
>>>> +  c->ack = true;
>>>> +  c->cond.Signal();
>>>> +
>>>> +  if (r>= 0&&  pmtime) {
>>>> +    *pmtime = mtime.sec();
>>>> +  }
>>>> +
>>>> +  if (c->callback_complete) {
>>>> +    c->io->client->finisher.queue(new C_AioComplete(c));
>>>> +  }
>>>> +
>>>> +  c->put_unlock();
>>>> +}
>>>> +
>>>>    /////////////////////// C_aio_sparse_read_Ack //////////////////////////
>>>>
>>>>    librados::IoCtxImpl::C_aio_sparse_read_Ack::C_aio_sparse_read_Ack(AioCompletionImpl
>>>> *_c,
>>>> diff --git a/src/librados/IoCtxImpl.h b/src/librados/IoCtxImpl.h
>>>> index feea0e8..55b07ee 100644
>>>> --- a/src/librados/IoCtxImpl.h
>>>> +++ b/src/librados/IoCtxImpl.h
>>>> @@ -144,6 +144,14 @@ struct librados::IoCtxImpl {
>>>>        C_aio_Ack(AioCompletionImpl *_c);
>>>>        void finish(int r);
>>>>      };
>>>> +
>>>> +  struct C_aio_stat_Ack : public Context {
>>>> +    librados::AioCompletionImpl *c;
>>>> +    time_t *pmtime;
>>>> +    utime_t mtime;
>>>> +    C_aio_stat_Ack(AioCompletionImpl *_c, time_t *pm);
>>>> +    void finish(int r);
>>>> +  };
>>>>
>>>>      struct C_aio_sparse_read_Ack : public Context {
>>>>        AioCompletionImpl *c;
>>>> @@ -177,6 +185,7 @@ struct librados::IoCtxImpl {
>>>>      int aio_remove(const object_t&oid, AioCompletionImpl *c);
>>>>      int aio_exec(const object_t&  oid, AioCompletionImpl *c, const char
>>>> *cls,
>>>>                  const char *method, bufferlist&  inbl, bufferlist *outbl);
>>>> +  int aio_stat(const object_t&  oid, AioCompletionImpl *c, uint64_t
>>>> *psize, time_t *pmtime);
>>>>
>>>>      int pool_change_auid(unsigned long long auid);
>>>>      int pool_change_auid_async(unsigned long long auid,
>>>> PoolAsyncCompletionImpl *c);
>>>> diff --git a/src/librados/librados.cc b/src/librados/librados.cc
>>>> index 274119c..af36b38 100644
>>>> --- a/src/librados/librados.cc
>>>> +++ b/src/librados/librados.cc
>>>> @@ -2167,6 +2167,16 @@ extern "C" int rados_aio_flush(rados_ioctx_t io)
>>>>      return 0;
>>>>    }
>>>>
>>>> +extern "C" int rados_aio_stat(rados_ioctx_t io, const char *o,
>>>> +                             rados_completion_t completion,
>>>> +                             uint64_t *psize, time_t *pmtime)
>>>> +{
>>>> +  librados::IoCtxImpl *ctx = (librados::IoCtxImpl *)io;
>>>> +  object_t oid(o);
>>>> +  return ctx->aio_stat(oid, (librados::AioCompletionImpl*)completion,
>>>> +                      psize, pmtime);
>>>> +}
>>>> +
>>>>    struct C_WatchCB : public librados::WatchCtx {
>>>>      rados_watchcb_t wcb;
>>>>      void *arg;
>>>> --
>>>> 1.7.10.4

--
To unsubscribe from this list: send the line "unsubscribe ceph-devel" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Filippos Giannakos Dec. 20, 2012, 8:05 p.m. UTC | #6
Hi Team,

Here is the patch with the changes, plus the tests you requested.

Best regards,
Filippos


--
To unsubscribe from this list: send the line "unsubscribe ceph-devel" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Filippos Giannakos Jan. 4, 2013, 1:01 p.m. UTC | #7
Hi Team,

Is there any progress or any comments regarding the librados aio stat
patch ?

Best regards

On 12/20/2012 10:05 PM, Filippos Giannakos wrote:
> Hi Team,
>
> Here is the patch with the changes, plus the tests you requested.
>
> Best regards,
> Filippos
Sage Weil Jan. 4, 2013, 6 p.m. UTC | #8
Sorry, I missed this second set of patches when they came through over the 
break.  We'll try to get them merged into master shortly.

Thanks!
sage


On Fri, 4 Jan 2013, Filippos Giannakos wrote:

> Hi Team,
> 
> Is there any progress or any comments regarding the librados aio stat
> patch ?
> 
> Best regards
> 
> On 12/20/2012 10:05 PM, Filippos Giannakos wrote:
> > Hi Team,
> > 
> > Here is the patch with the changes, plus the tests you requested.
> > 
> > Best regards,
> > Filippos
> 
> 
> -- 
> Filippos.
> --
> To unsubscribe from this list: send the line "unsubscribe ceph-devel" in
> the body of a message to majordomo@vger.kernel.org
> More majordomo info at  http://vger.kernel.org/majordomo-info.html
> 
> 
--
To unsubscribe from this list: send the line "unsubscribe ceph-devel" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Josh Durgin Jan. 5, 2013, 12:08 a.m. UTC | #9
On 01/04/2013 05:01 AM, Filippos Giannakos wrote:
> Hi Team,
>
> Is there any progress or any comments regarding the librados aio stat
> patch ?

They look good to me. I put them in the wip-librados-aio-stat branch.
Can we add your signed-off-by to them?

Thanks,
Josh

> Best regards
>
> On 12/20/2012 10:05 PM, Filippos Giannakos wrote:
>> Hi Team,
>>
>> Here is the patch with the changes, plus the tests you requested.
>>
>> Best regards,
>> Filippos
>
>

--
To unsubscribe from this list: send the line "unsubscribe ceph-devel" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Filippos Giannakos Jan. 7, 2013, 2:40 p.m. UTC | #10
Hi Josh,

On 01/05/2013 02:08 AM, Josh Durgin wrote:
> On 01/04/2013 05:01 AM, Filippos Giannakos wrote:
>> Hi Team,
>>
>> Is there any progress or any comments regarding the librados aio stat
>> patch ?
>
> They look good to me. I put them in the wip-librados-aio-stat branch.
> Can we add your signed-off-by to them?
>
> Thanks,
> Josh

Sorry for my late response. You can go ahead with the signed-off.

Best Regards
Sage Weil Jan. 9, 2013, 3:40 a.m. UTC | #11
On Mon, 7 Jan 2013, Filippos Giannakos wrote:
> Hi Josh,
> 
> On 01/05/2013 02:08 AM, Josh Durgin wrote:
> > On 01/04/2013 05:01 AM, Filippos Giannakos wrote:
> > > Hi Team,
> > > 
> > > Is there any progress or any comments regarding the librados aio stat
> > > patch ?
> > 
> > They look good to me. I put them in the wip-librados-aio-stat branch.
> > Can we add your signed-off-by to them?
> > 
> > Thanks,
> > Josh
> 
> Sorry for my late response. You can go ahead with the signed-off.

I merged these into master (Josh is out this week).

Thanks!
sage
--
To unsubscribe from this list: send the line "unsubscribe ceph-devel" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
diff mbox

Patch

diff --git a/src/include/rados/librados.h b/src/include/rados/librados.h
index 44d6f71..7f4b5c0 100644
--- a/src/include/rados/librados.h
+++ b/src/include/rados/librados.h
@@ -1444,6 +1444,20 @@  int rados_aio_read(rados_ioctx_t io, const char *oid,
  */
 int rados_aio_flush(rados_ioctx_t io);
 
+
+/**
+ * Asynchronously get object stats (size/mtime)
+ *
+ * @param io ioctx
+ * @param o object name
+ * @param psize where to store object size
+ * @param pmtime where to store modification time
+ * @returns 0 on success, negative error code on failure
+ */
+int rados_aio_stat(rados_ioctx_t io, const char *o,
+		   rados_completion_t completion,
+		   uint64_t *psize, time_t *pmtime);
+
 /** @} Asynchronous I/O */
 
 /**
diff --git a/src/include/rados/librados.hpp b/src/include/rados/librados.hpp
index e50acdb..96bfc15 100644
--- a/src/include/rados/librados.hpp
+++ b/src/include/rados/librados.hpp
@@ -473,9 +473,22 @@  namespace librados
      * other than CEPH_NOSNAP
      */
     int aio_remove(const std::string& oid, AioCompletion *c);
-    
+
     int aio_flush();
 
+    /**
+     * Asynchronously get object stats (size/mtime)
+     *
+     * @param io ioctx
+     * @param o object name
+     * @param psize where to store object size
+     * @param pmtime where to store modification time
+     * @returns 0 on success, negative error code on failure
+     */
+    int rados_aio_stat(rados_ioctx_t io, const char *o,
+		       rados_completion_t completion,
+		       uint64_t *psize, time_t *pmtime);
+
     int aio_exec(const std::string& oid, AioCompletion *c, const char *cls, const char *method,
 	         bufferlist& inbl, bufferlist *outbl);
 
diff --git a/src/librados/IoCtxImpl.cc b/src/librados/IoCtxImpl.cc
index 01b4a94..50aab1e 100644
--- a/src/librados/IoCtxImpl.cc
+++ b/src/librados/IoCtxImpl.cc
@@ -851,6 +851,21 @@  int librados::IoCtxImpl::aio_remove(const object_t &oid, AioCompletionImpl *c)
   return 0;
 }
 
+
+int librados::IoCtxImpl::aio_stat(const object_t& oid, AioCompletionImpl *c,
+		                  uint64_t *psize, time_t *pmtime)
+{
+  c->io = this;
+  C_aio_stat_Ack *onack = new C_aio_stat_Ack(c, pmtime);
+
+  Mutex::Locker l(*lock);
+  objecter->stat(oid, oloc,
+		 snap_seq, psize, &onack->mtime, 0,
+		 onack, &c->objver);
+
+  return 0;
+}
+
 int librados::IoCtxImpl::remove(const object_t& oid)
 {
   utime_t ut = ceph_clock_now(client->cct);
@@ -1562,6 +1577,33 @@  void librados::IoCtxImpl::C_aio_Ack::finish(int r)
   c->put_unlock();
 }
 
+///////////////////////////// C_aio_stat_Ack ////////////////////////////
+
+librados::IoCtxImpl::C_aio_stat_Ack::C_aio_stat_Ack(AioCompletionImpl *_c,
+						    time_t *pm)
+   : c(_c), pmtime(pm)
+{
+  c->get();
+}
+
+void librados::IoCtxImpl::C_aio_stat_Ack::finish(int r)
+{
+  c->lock.Lock();
+  c->rval = r;
+  c->ack = true;
+  c->cond.Signal();
+
+  if (r >= 0 && pmtime) {
+    *pmtime = mtime.sec();
+  }
+
+  if (c->callback_complete) {
+    c->io->client->finisher.queue(new C_AioComplete(c));
+  }
+
+  c->put_unlock();
+}
+
 /////////////////////// C_aio_sparse_read_Ack //////////////////////////

 librados::IoCtxImpl::C_aio_sparse_read_Ack::C_aio_sparse_read_Ack(AioCompletionImpl *_c,
diff --git a/src/librados/IoCtxImpl.h b/src/librados/IoCtxImpl.h
index feea0e8..55b07ee 100644
--- a/src/librados/IoCtxImpl.h
+++ b/src/librados/IoCtxImpl.h
@@ -144,6 +144,14 @@  struct librados::IoCtxImpl {
     C_aio_Ack(AioCompletionImpl *_c);
     void finish(int r);
   };
+
+  struct C_aio_stat_Ack : public Context {
+    librados::AioCompletionImpl *c;
+    time_t *pmtime;
+    utime_t mtime;
+    C_aio_stat_Ack(AioCompletionImpl *_c, time_t *pm);
+    void finish(int r);
+  };

   struct C_aio_sparse_read_Ack : public Context {
     AioCompletionImpl *c;
@@ -177,6 +185,7 @@  struct librados::IoCtxImpl {
   int aio_remove(const object_t &oid, AioCompletionImpl *c);
   int aio_exec(const object_t& oid, AioCompletionImpl *c, const char *cls,
 	       const char *method, bufferlist& inbl, bufferlist *outbl);
+  int aio_stat(const object_t& oid, AioCompletionImpl *c, uint64_t *psize, time_t *pmtime);

   int pool_change_auid(unsigned long long auid);
   int pool_change_auid_async(unsigned long long auid, PoolAsyncCompletionImpl *c);
diff --git a/src/librados/librados.cc b/src/librados/librados.cc
index 274119c..af36b38 100644
--- a/src/librados/librados.cc
+++ b/src/librados/librados.cc
@@ -2167,6 +2167,16 @@  extern "C" int rados_aio_flush(rados_ioctx_t io)
   return 0;
 }

+extern "C" int rados_aio_stat(rados_ioctx_t io, const char *o,
+			      rados_completion_t completion,
+			      uint64_t *psize, time_t *pmtime)
+{
+  librados::IoCtxImpl *ctx = (librados::IoCtxImpl *)io;
+  object_t oid(o);
+  return ctx->aio_stat(oid, (librados::AioCompletionImpl*)completion,
+		       psize, pmtime);
+}
+
 struct C_WatchCB : public librados::WatchCtx {
   rados_watchcb_t wcb;
   void *arg;