1. 06 9月, 2012 14 次提交
    • H
      staging: comedi: comedi_fops: remove subdevice pointer math · b077f2cd
      H Hartley Sweeten 提交于
      Convert the comedi_subdevice access from pointer math to array
      access.
      Signed-off-by: NH Hartley Sweeten <hsweeten@visionengravers.com>
      Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      b077f2cd
    • D
      staging: ramster: place ramster codebase on top of new zcache2 codebase · 14c9fda5
      Dan Magenheimer 提交于
      [V2: rebased to apply to 20120905 staging-next, no other changes]
      
      This slightly modified ramster codebase is now built entirely on zcache2
      and all ramster-specific code is fully contained in a subdirectory.
      
      Ramster extends zcache2 to allow pages compressed via zcache2 to be
      "load-balanced" across machines in a cluster.  Control and data communication
      is done via kernel sockets, and cluster configuration and management is
      heavily leveraged from the ocfs2 cluster filesystem.
      
      There are no new features since the codebase introduced into staging at 3.4.
      Some cleanup was performed though:
       1) Interfaces directly with new zbud
       2) Debugfs now used instead of sysfs where possible.  Sysfs still
          used where necessary for userland cluster configuration.
      
      Ramster is very much a work-in-progress but also does really work!
      
      RAMSTER HIGH LEVEL OVERVIEW (from original V5 posting in Feb 2012)
      
      RAMster implements peer-to-peer transcendent memory, allowing a "cluster" of
      kernels to dynamically pool their RAM so that a RAM-hungry workload on one
      machine can temporarily and transparently utilize RAM on another machine which
      is presumably idle or running a non-RAM-hungry workload.  Other than the
      already-merged cleancache patchset and frontswap patchset, no core kernel
      changes are currently required.
      
      (Note that, unlike previous public descriptions of RAMster, this implementation
      does NOT require synchronous "gets" or core networking changes. As of V5,
      it also co-exists with ocfs2.)
      
      RAMster combines a clustering and messaging foundation based on the ocfs2
      cluster layer with the in-kernel compression implementation of zcache2, and
      adds code to glue them together.  When a page is "put" to RAMster, it is
      compressed and stored locally.  Periodically, a thread will "remotify" these
      pages by sending them via messages to a remote machine.  When the page is
      later needed as indicated by a page fault, a "get" is issued.  If the data
      is local, it is uncompressed and the fault is resolved.  If the data is
      remote, a message is sent to fetch the data and the faulting thread sleeps;
      when the data arrives, the thread awakens, the data is decompressed and
      the fault is resolved.
      
      As of V5, clusters up to eight nodes are supported; each node can remotify
      pages to one specified node, so clusters can be configured as clients to
      a "memory server".  Some simple policy is in place that will need to be
      refined over time.  Larger clusters and fault-resistant protocols can also
      be added over time.
      
      A HOW-TO is available at:
      http://oss.oracle.com/projects/tmem/dist/files/RAMster/HOWTO-120817Acked-by: NKonrad Rzeszutek Wilk <konrad.wilk@oracle.com>
      Signed-off-by: NDan Magenheimer <dan.magenheimer@oracle.com>
      Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      14c9fda5
    • D
      staging: ramster: move to new zcache2 codebase · faca2ef7
      Dan Magenheimer 提交于
      [V2: rebased to apply to 20120905 staging-next, no other changes]
      
      The original zcache in staging is a "demo" version, and this is a massive
      rewrite.  This was intended to result in a merged zcache and ramster, but
      that option has been blocked so, to continue forward progress on ramster
      and future related projects, only ramster moves to the new codebase.
      To differentiate between the old demo zcache and the rewrite, we refer
      to the latter as zcache2, config'd as CONFIG_ZCACHE2.  Zcache and zcache2
      cannot be built in the same kernel, so CONFIG_ZCACHE2 implies !CONFIG_ZCACHE.
      
      This developer still has hope that zcache and zcache2 will be merged
      into one codebase.  Until then, zcache2 can be considered a one-node
      version of ramster.
      
      No history of changes was recorded during the zcache2 rewrite and recreating
      a sane one would be a Sisyphean task but, since ramster is still in
      staging and has been unchanged since it was merged, presumably this
      is acceptable.
      
      This commit also provides the hooks in zcache2 for ramster, but all
      ramster-specific code is provided in a separate commit.
      
      Some of the highlights of this rewritten codebase for zcache2:
      (Note: If you are not familiar with the tmem terminology, you can review
      it here: http://lwn.net/Articles/454795/ )
       1. Merge of "demo" zcache and the v1.1 version of zcache in ramster.  Zcache
          and ramster had a great deal of duplicate code which is now merged.
          In essence, zcache2 *is* ramster but with no remote machine available,
          but !CONFIG_RAMSTER will avoid compiling lots of ramster-specific code.
       2. Allocator.  Previously, persistent pools used zsmalloc and ephemeral pools
          used zbud.  Now a completely rewritten zbud is used for both.  Notably
          this zbud maintains all persistent (frontswap) and ephemeral (cleancache)
          pageframes in separate queues in LRU order.
       3. Interaction with page allocator.  Zbud does no page allocation/freeing,
          it is done entirely in zcache2 where it can be tracked more effectively.
       4. Better pre-allocation.  Previously, on put, if a new pageframe could not be
          pre-allocated, the put would fail, even if the allocator had plenty of
          partial pages where the data could be stored; this is now fixed.
       5. Ouroboros ("eating its own tail") allocation.  If no pageframe can be
          allocated AND no partial pages are available, the least-recently-used
          ephemeral pageframe is reclaimed immediately (including flushing tmem
          pointers to it) and re-used.  This ensures that most-recently-used
          cleancache pages are more likely to be retained than LRU pages and also
          that, as in the core mm subsystem, anonymous pages have a higher priority
          than clean page cache pages.
       6. Zcache and zbud now use debugfs instead of sysfs.  Ramster uses debugfs
          where possible and sysfs where necessary.  (Some ramster configuration
          is done from userspace so some sysfs is necessary.)
       7. Modularization.  As some have observed, the monolithic zcache-main.c code
          included zbud code, which has now been separated into its own code module.
          Much ramster-specific code in the old ramster zcache-main.c has also been
          moved into ramster.c so that it does not get compiled with !CONFIG_RAMSTER.
       8. Rebased to 3.5.
      
      This new codebase also provides hooks for several future new features:
       A. WasActive patch, requires some mm/frontswap changes previously posted.
          A new version of this patch will be provided separately.
          See ifdef __PG_WAS_ACTIVE
       B. Exclusive gets.  It seems tmem _can_ support exclusive gets with a
          minor change to both zcache2 and a small backwards-compatible change
          to frontswap.c.  Explanation and frontswap patch will be provided
          separately.  See ifdef FRONTSWAP_HAS_EXCLUSIVE_GETS
       C. Ouroboros writeback.  Since persistent (frontswap) pages may now also be
          reclaimed in LRU order, the foundation is in place to properly writeback
          these pages back into the swap cache and then the swap disk.  This is still
          under development and requires some other mm changes which are prototyped.
          See ifdef FRONTSWAP_HAS_UNUSE.
      
      A new feature that desperately needs attention (if someone is looking for
      a way to contribute) is kernel module support.  A preliminary version of
      a patch was posted by Erlangen University and needs to be integrated and
      tested for zcache2 and brought up to kernel standards.
      
      If anybody is interested on helping out with any of these, let me know!
      Acked-by: NKonrad Rzeszutek Wilk <konrad.wilk@oracle.com>
      Signed-off-by: NDan Magenheimer <dan.magenheimer@oracle.com>
      Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      faca2ef7
    • D
      staging: ramster: remove old driver to prep for new base · c857ce16
      Dan Magenheimer 提交于
      [V2: rebased to apply to 20120905 staging-next, no other changes]
      
      To prep for moving the ramster codebase on top of the new
      redesigned zcache2 codebase, we remove ramster (as well
      as its contained diverged v1.1 version of zcache) entirely.
      Acked-by: NKonrad Rzeszutek Wilk <konrad.wilk@oracle.com>
      Signed-off-by: NDan Magenheimer <dan.magenheimer@oracle.com>
      Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      c857ce16
    • M
      staging: zcache: fix spelling of comment · 3ddd31fa
      Marcus Karlsson 提交于
      Fix spelling in tmem.c:
      Transcedent -> Transcendent
      Signed-off-by: NMarcus Karlsson <mk@acc.umu.se>
      Acked-by: NKonrad Rzeszutek Wilk <konrad.wilk@oracle.com>
      Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      3ddd31fa
    • D
      staging: slicoss: fix a null deref when pci_alloc_consistent fail · b8131fc0
      Devendra Naga 提交于
      we are dereferencing the pshmem , and the pci_alloc_consistent can fail
      returning null,
      
      do a memcpy if we have a valid pshmem
      Signed-off-by: NDevendra Naga <devendra.aaru@gmail.com>
      Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      b8131fc0
    • D
      staging: slicoss: remove return statement at the end of slic_mcast_set_list · 8f6f4c17
      Devendra Naga 提交于
      this function return void, means return at the end of this function
      is not needed
      Signed-off-by: NDevendra Naga <devendra.aaru@gmail.com>
      Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      8f6f4c17
    • D
      staging: slicoss: clean the spinlock code in slic_entry_open · 71329965
      Devendra Naga 提交于
      the locked variable is used for checking whether the function
      acquired lock, then unlock. actually with out this we
      can achieve the same lock and unlock senario, remove the locked
      variable and also cleanup the code around.
      Signed-off-by: NDevendra Naga <devendra.aaru@gmail.com>
      Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      71329965
    • D
      staging: slicoss: remove default case after we done with request_firmware · 92adcc80
      Devendra Naga 提交于
      we are returning -ENOENT when there is no firmware file for a matching
      device id. then we start calling request_firmware,
      after this we do checks on the firmware length of corresponding
      device id, since the default case is handled in the begining itself
      there is no need of a default case at the firmware length checks
      Signed-off-by: NDevendra Naga <devendra.aaru@gmail.com>
      Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      92adcc80
    • W
      staging: gdm72xx: use list_move_tail instead of list_del/list_add_tail · e5d2cb4a
      Wei Yongjun 提交于
      Using list_move_tail() instead of list_del() + list_add_tail().
      
      spatch with a semantic match is used to found this problem.
      (http://coccinelle.lip6.fr/)
      Signed-off-by: NWei Yongjun <yongjun_wei@trendmicro.com.cn>
      Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      e5d2cb4a
    • W
      staging: ozwpan: use list_move_tail instead of list_del/list_add_tail · 094e74c2
      Wei Yongjun 提交于
      Using list_move_tail() instead of list_del() + list_add_tail().
      
      spatch with a semantic match is used to found this problem.
      (http://coccinelle.lip6.fr/)
      Signed-off-by: NWei Yongjun <yongjun_wei@trendmicro.com.cn>
      Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      094e74c2
    • S
      Staging: ipack: fix build failure in powerpc allyesconfig · b9f789fb
      Samuel Iglesias Gonsálvez 提交于
      Caused by commit 187e4782 ("Staging: ipack: Read the ID space during
      device registration").
      
      drivers/staging/ipack/ipack.c: In function 'ipack_device_read_id':
      drivers/staging/ipack/ipack.c:291:2: error: implicit declaration of function
      	'ioread8' [-Werror=implicit-function-declaration]
      drivers/staging/ipack/ipack.c:309:3: error: implicit declaration of function
      	'ioread16be' [-Werror=implicit-function-declaration]
      Reported-by: NStephen Rothwell <sfr@canb.auug.org.au>
      Signed-off-by: NSamuel Iglesias Gonsálvez <siglesias@igalia.com>
      Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      b9f789fb
    • I
      staging: comedi: das08: Use struct comedi_device hw_dev for PCI · 40a3ee02
      Ian Abbott 提交于
      Remove the pointer to the PCI device from the private data `struct
      das08_private_struct`.  Use `comedi_set_hw_dev()` to save a pointer to
      the PCI device (actually, its embedded `struct device`) and
      `comedi_to_pci_dev()` to retrieve it.
      Signed-off-by: NIan Abbott <abbotti@mev.co.uk>
      Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      40a3ee02
    • I
      staging: comedi: das08: No need to manipulate PCI ref count · c3961470
      Ian Abbott 提交于
      Now that this driver no longer supports "manual" attachment of PCI
      devices in its `attach` hook (`das08_attach()`), it no longer has code
      that searches for a suitable PCI device and increments its reference
      count.  Since the driver no longer has any reason for incrementing and
      decrementing the PCI device's reference count, the calls to
      `pci_dev_get()` and `pci_dev_put()` can be removed.
      Signed-off-by: NIan Abbott <abbotti@mev.co.uk>
      Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      c3961470
  2. 05 9月, 2012 26 次提交