1. 03 11月, 2011 3 次提交
    • B
      pnfs-obj: Get rid of objlayout_{alloc,free}_io_state · 96218556
      Boaz Harrosh 提交于
      This is part of moving objio_osd to use the ORE.
      
      objlayout_io_state had two functions:
      1. It was used in the error reporting mechanism at layout_return.
         This function is kept intact.
         (Later patch will rename objlayout_io_state => objlayout_io_res)
      2. Carrier of rw io members into the objio_read/write_paglist API.
         This is removed in this patch.
      
      The {r,w}data received from NFS are passed directly to the
      objio_{read,write}_paglist API. The io_engine is now allocating
      it's own IO state as part of the read/write. The minimal
      functionality that was part of the generic allocation is passed
      to the io_engine.
      
      So part of this patch is rename of:
      	ios->ol_state.foo => ios->foo
      
      At objlayout_{read,write}_done an objlayout_io_state is passed that
      denotes the result of the IO. (Hence the later name change).
      If the IO is successful objlayout calls an objio_free_result() API
      immediately (Which for objio_osd causes the release of the io_state).
      If the IO ended in an error it is hanged onto until reported in
      layout_return and is released later through the objio_free_result()
      API. (All this is not new just renamed and cleaned)
      Signed-off-by: NBoaz Harrosh <bharrosh@panasas.com>
      Signed-off-by: NTrond Myklebust <Trond.Myklebust@netapp.com>
      96218556
    • B
      pnfs-obj: Return PNFS_NOT_ATTEMPTED in case of read/write_pagelist · e6c40fe3
      Boaz Harrosh 提交于
      objlayout driver was always returning PNFS_ATTEMPTED from it's
      read/write_pagelist operations. Even on error. Fix that.
      
      Start by establishing an error return API from io-engine, by
      not returning ssize_t (length-or-error) but returning "int"
      0=OK, 0>Error. And clean up all return types in io-engine.
      
      Then if io-engine returned error return PNFS_NOT_ATTEMPTED
      to generic layer. (With a dprint)
      Signed-off-by: NBoaz Harrosh <bharrosh@panasas.com>
      Signed-off-by: NTrond Myklebust <Trond.Myklebust@netapp.com>
      e6c40fe3
    • B
      pnfs-obj: Remove redundant EOF from objlayout_io_state · 4cdc685c
      Boaz Harrosh 提交于
      The EOF calculation was done on .read_pagelist(), cached
      in objlayout_io_state->eof, and set in objlayout_read_done()
      into nfs_read_data->res.eof.
      
      So set it directly into nfs_read_data->res.eof and avoid
      the extra member.
      Signed-off-by: NBoaz Harrosh <bharrosh@panasas.com>
      Signed-off-by: NTrond Myklebust <Trond.Myklebust@netapp.com>
      4cdc685c
  2. 30 5月, 2011 7 次提交
    • B
      pnfs-obj: objlayout_encode_layoutcommit implementation · a0fe8bf4
      Boaz Harrosh 提交于
      * Define API for io-engines to report delta_space_used in IOs
      * Encode the osd-layout specific information of the layoutcommit
        XDR buffer.
      Signed-off-by: NBoaz Harrosh <bharrosh@panasas.com>
      Signed-off-by: NBenny Halevy <bhalevy@panasas.com>
      a0fe8bf4
    • B
      pnfs-obj: report errors and .encode_layoutreturn Implementation. · adb58535
      Boaz Harrosh 提交于
      An io_state pre-allocates an error information structure for each
      possible osd-device that might error during IO. When IO is done if all
      was well the io_state is freed. (as today). If the I/O has ended with an
      error, the io_state is queued on a per-layout err_list. When eventually
      encode_layoutreturn() is called, each error is properly encoded on the
      XDR buffer and only then the io_state is removed from err_list and
      de-allocated.
      
      It is up to the io_engine to fill in the segment that fault and the type
      of osd_error that occurred. By calling objlayout_io_set_result() for
      each failing device.
      
      In objio_osd:
      * Allocate io-error descriptors space as part of io_state
      * Use generic objlayout error reporting at end of io.
      Signed-off-by: NBoaz Harrosh <bharrosh@panasas.com>
      Signed-off-by: NBenny Halevy <bhalevy@panasas.com>
      adb58535
    • B
      pnfs-obj: osd raid engine read/write implementation · 04f83450
      Boaz Harrosh 提交于
      With the use of the in-kernel osd library. Implement read/write
      of data from/to osd-objects according to information specified
      in the objects-layout.
      
      Support for stripping over mirrors with a received stripe_unit.
      There are however a few constrains which are not supported:
       1. Stripe Unit must be a multiple of PAGE_SIZE
       2. stripe length (stripe_unit * number_of_stripes) can not be
          bigger then 32bit.
      
      Also support raid-groups and partial-layout. Partial-layout is
      when not all the groups are received on the line, addressing
      only a partial range of the file.
      
      TODO:
        Only raid0! raid 4/5/6 support will come at later stage
      
      A none supported layout will send IO through the MDS
      
      [Important fallout from the last rebase]
      Signed-off-by: NBoaz Harrosh <bharrosh@panasas.com>
      [gfp_flags]
      Signed-off-by: NBenny Halevy <bhalevy@panasas.com>
      04f83450
    • B
      pnfs-obj: define per-inode private structure · e51b841d
      Benny Halevy 提交于
      allocate and deallocate per-inode private pnfs_layout_hdr
      in preparation for I/O implementation.
      Signed-off-by: NBoaz Harrosh <bharrosh@panasas.com>
      Signed-off-by: NBenny Halevy <bhalevy@panasas.com>
      e51b841d
    • B
      pnfs-obj: objio_osd device information retrieval and caching · b6c05f16
      Boaz Harrosh 提交于
      When a new layout is received in objio_alloc_lseg all device_ids
      referenced are retrieved. The device information is queried for from MDS
      and then the osd_device is looked-up from the osd-initiator library. The
      devices are cached in a per-mount-point list, for later use. At unmount
      all devices are "put" back to the library.
      
      objlayout_get_deviceinfo(), objlayout_put_deviceinfo() middleware
      API for retrieving device information given a device_id.
      
      TODO: The device cache can get big. Cap its size. Keep an LRU and start
            to return devices which were not used, when list gets to big, or
            when new entries allocation fail.
      
      [pnfs-obj: Bugs in new global-device-cache code]
      Signed-off-by: NBoaz Harrosh <bharrosh@panasas.com>
      [gfp_flags]
      [use global device cache]
      [use layout driver in global device cache]
      Signed-off-by: NBenny Halevy <bhalevy@panasas.com>
      b6c05f16
    • B
      pnfs-obj: decode layout, alloc/free lseg · 09f5bf4e
      Boaz Harrosh 提交于
      objlayout_alloc_lseg prepares an xdr_stream and calls the
      raid engins objio_alloc_lseg() to allocate a private
      pnfs_layout_segment.
      
      objio_osd.c::objio_alloc_lseg() uses passed xdr_stream to
      decode and store the layout_segment information in an
      objio_segment struct, using the pnfs_osd_xdr.h API for
      the actual parsing the layout xdr.
      
      objlayout_free_lseg calls objio_free_lseg() to free the
      allocated space.
      Signed-off-by: NBoaz Harrosh <bharrosh@panasas.com>
      [gfp_flags]
      [removed "extern" from function definitions]
      Signed-off-by: NBenny Halevy <bhalevy@panasas.com>
      09f5bf4e
    • B
      pnfs-obj: objlayoutdriver module skeleton · c93407d0
      Benny Halevy 提交于
      * Define the PNFS_OBJLAYOUT Kconfig option in the nfs
        master Kconfig file.
      * Add the objlayout driver to the Kernel's Kbuild system.
      * Add the fs/nfs/objlayout/Kbuild file for building the
        objlayoutdriver.ko driver
      * Define fs/nfs/objlayout/objio_osd.c, register the driver on module
        initialization and unregister on exit.
      
      [pnfs-obj: remove of CONFIG_PNFS fallout]
      Signed-off-by: NBoaz Harrosh <bharrosh@panasas.com>
      [added "unsure" clause]
      [depend on NFS_V4_1]
      Signed-off-by: NBenny Halevy <bhalevy@panasas.com>
      c93407d0
  3. 05 1月, 2011 2 次提交
  4. 10 5月, 2007 1 次提交
  5. 17 2月, 2007 1 次提交
  6. 17 4月, 2005 1 次提交
    • L
      Linux-2.6.12-rc2 · 1da177e4
      Linus Torvalds 提交于
      Initial git repository build. I'm not bothering with the full history,
      even though we have it. We can create a separate "historical" git
      archive of that later if we want to, and in the meantime it's about
      3.2GB when imported into git - space that would just make the early
      git days unnecessarily complicated, when we don't have a lot of good
      infrastructure for it.
      
      Let it rip!
      1da177e4