On Feb 20, 2013, at 9:31 AM, Sage Weil <sage@xxxxxxxxxxx> wrote: >> or something like this that replaces the current extent-to-sockaddr >> interface? The proposed interface about would do the host/ip mapping, as >> well as the topology mapping? > > Yeah. The ceph_offset_to_osds should probably also have an (optional?) > out argument that tells you how long the extent is starting from offset > that is on those devices. Then you can do another call at offset+len to > get the next segment. It'd be nice to hide the striping strategy so we don't have to reproduce it in the Hadoop shim as we currently do, and which is needed with an interface using only an offset (we have to know the stripe unit to jump to the next extent). So, something like this might work: struct extent { loff_t offset, length; vector<int> osds; } ceph_get_file_extents(file, offset, length, vector<extent>& extents); Then we could re-use the Striper or something? -Noah-- To unsubscribe from this list: send the line "unsubscribe ceph-devel" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html