1. 27 Jan, 2009 2 commits
    • David Brownell's avatar
      MMC/SD dma fault handling fixes · 4f8ee6ae
      David Brownell authored
      Clean up MMC/SD fault handling for transfers with data stages:
      
       - After DMA errors, always issue any STOP needed; aborting DMA
         on the host is not sufficient to reset the card's state.
      
       - It does that already after data or command errors; but also:
           * Always reset the data and command state machines, instead
             of just the command machine (and just for data "CRC" errors)
           * Report how many blocks were transferred (resolving FIXMEs)
      
      There are probably still a few holes in fault handling, but these
      updates resolved some problems I was (briefly) able to reproduce
      by running a DM6446 quite a bit faster than it's supposed to be
      able to handle.
      Signed-off-by: default avatarDavid Brownell <dbrownell@users.sourceforge.net>
      Signed-off-by: default avatarKevin Hilman <khilman@deeprootsystems.com>
      4f8ee6ae
    • David Brownell's avatar
      MMC/SD allocates extra EDMA slots · bd417539
      David Brownell authored
      Allocate and free (NR_SG - 1) parameter RAM slots, and make max_hw_segs
      reflect that.  This is a NOP until NR_SG is changed, at which point
      those slots *need* to be used.
      
      Unmapping scatterlists must use the original scatterlist length, not
      the length after mapping.  (But they won't currently differ.)
      Signed-off-by: default avatarDavid Brownell <dbrownell@users.sourceforge.net>
      Signed-off-by: default avatarKevin Hilman <khilman@deeprootsystems.com>
      bd417539
  2. 19 Jan, 2009 8 commits
    • David Brownell's avatar
      EDMA TC selection updates · 3c8fcf77
      David Brownell authored
      Minor tweaks:
      
        - Bugfix handling of EVENTQ_DEFAULT ... recognize it, and
          implement as EVENTQ_1 instead of reserved/illegal value
      
        - Use the defined enum type internally
      
        - Have MMC use TC1, as appropriate for "longer, nonreal-time
          sensitive transfers" (per docs) ... instead of using TC0,
          as for "urgent, small, real-time sensitive transfers".
      
      Arguably, TC0 priority should be increased (to 0) to be
      higher priority than the ARM ... matching "urgent" etc.
      
      The added TCs on DM646x chips are still not recognized.
      Signed-off-by: default avatarDavid Brownell <dbrownell@users.sourceforge.net>
      Signed-off-by: default avatarKevin Hilman <khilman@deeprootsystems.com>
      3c8fcf77
    • David Brownell's avatar
      EDMA renames: all remaining operations · 9df2a6b8
      David Brownell authored
      This patch primarily renames functions to use an edma_ prefix and remove
      a needless infix "_dma_" token.  Again, parameters which identify parameter
      RAM slots were renamed as "slot" from "lch".
      
      Also, edma_get_position() was moved to be adjacent to the other operations
      that rely on just a few fields of a parameter RAM slot.
      Signed-off-by: default avatarDavid Brownell <dbrownell@users.sourceforge.net>
      Signed-off-by: default avatarKevin Hilman <khilman@deeprootsystems.com>
      9df2a6b8
    • David Brownell's avatar
      EDMA renames: remaining parameter RAM ops · 18478af5
      David Brownell authored
      This patch primarily renames functions to use an edma_ prefix and remove
      a needless infix "_dma_" token ... except that "src_params" became "src",
      and "dest_params" became "dest".  Parameters which identify parameter RAM
      slots were renamed as "slot" from "lch".
      
      Also, the slot numbers become unsigned (supporting a minor code shrink),
      and a handful of needless temporary variables were removed.
      Signed-off-by: default avatarDavid Brownell <dbrownell@users.sourceforge.net>
      Signed-off-by: default avatarKevin Hilman <khilman@deeprootsystems.com>
      18478af5
    • David Brownell's avatar
      EDMA renames: edma_start(), edma_stop() · b69e435d
      David Brownell authored
      These functions now only accept channels, since reload slots can
      never be independently active.  Change parameter to unsinged, to
      allow a minor code shrink.  Remove pointless foof in edma_stop():
      the channel's parameter RAM slot must be reinitialized, so there
      is no reason to modify it unless chaining is being misused; and
      just updating the link register can't protect aginst chain bugs.
      Signed-off-by: default avatarDavid Brownell <dbrownell@users.sourceforge.net>
      Signed-off-by: default avatarKevin Hilman <khilman@deeprootsystems.com>
      b69e435d
    • David Brownell's avatar
      EDMA: split channel/slot resource management · 62ef2b07
      David Brownell authored
      EDMA interface update for channel and parameter RAM slot alloc/free.
      This is the biggest of these changes, since it's non-cosmetic.
      
       - Stop talking about "master" and "slave"!  Instead, use the notions
         exposed by the hardware:  a DMA "channel", and a PaRAM slot.  This
         is a general doc/comment update, and affects calling conventions.
      
       - Split davinci_request_dma() into two simpler routines:
           * edma_alloc_channel() with three fewer parameters
           * edma_alloc_slot() with just one parameter (may be a wildcard)
         The test for successful returns is "value < 0", not "value != 0";
         non-negative values are the returned channel or slot number.
      
       - Split davinci_free_dma() into two routines, both of which update
         the now-free parameter RAM slot to hold a dummy transfer.
           * void edma_free_channel(unsigned channel)
           * void edma_free_slot(unsigned slot);
      
       - Fill all PaRAM slots with dummy transfers when they're not in use.
      
       - Change the channel and slot numbers to "unsigned" in some cases so
         we can avoid some tests for invalid parameters.
      
      A key notion here is to *stop* fuzzing distinctions between DMA channels
      and parameter RAM slots.  This makes it easier to match these calls to
      hardware docs, and harder to get confused by differences; channels are
      (potentially) active, while slots are always passive.
      
      Transfer Completion Code (TCC) values are no longer supported except
      through the calls which manipulate entire parameter RAM sets.  This
      means that completion IRQ setup (for audio) is a bit different.
      Signed-off-by: default avatarDavid Brownell <dbrownell@users.sourceforge.net>
      Signed-off-by: default avatarKevin Hilman <khilman@deeprootsystems.com>
      62ef2b07
    • David Brownell's avatar
      EDMA interface renames: edma_link(), edma_unlink() · ff2f60e6
      David Brownell authored
      Another EDMA interface update.  Fixes documentation for the linking
      calls to be kerneldoc style.  Rename parameters so they're meaningful
      (from/to vs lch/lch_que) and unsigned (eliminates some error checks).
      Remove unused edma_unlink() parameter.  Move this code so it's grouped
      with the other calls which only modify parameter RAM.
      Signed-off-by: default avatarDavid Brownell <dbrownell@users.sourceforge.net>
      Signed-off-by: default avatarKevin Hilman <khilman@deeprootsystems.com>
      ff2f60e6
    • David Brownell's avatar
      EDMA renames: edma_read_slot(), edma_write_slot() · ce31af1d
      David Brownell authored
      This renames two parameter RAM calls that read and write entire param
      sets, and re-focusses their descriptions on the fact that they update
      parameter RAM.  That has nothing *directly* to do with any hardware DMA
      channel.  Switch to unsigned params, letting some error checks be removed.
      
      It also starts updating the dma.c comments to reflect the different
      structural blocks of the programming interface, calling out the two
      groups of parameter RAM operations and channel control operations.
      Signed-off-by: default avatarDavid Brownell <dbrownell@users.sourceforge.net>
      Signed-off-by: default avatarKevin Hilman <khilman@deeprootsystems.com>
      ce31af1d
    • Chaithrika U S's avatar
      ARM DaVinci: Low level debug macros for DaVinci Platforms · e890af73
      Chaithrika U S authored
      This patch defines debug macros for low-level debugging for Davinci based
      platforms
      
      Tested on :
              - DM644x DaVinci EVM
              - DM646X DaVinciHD EVM
      	- DM355 EVM
      
      This patch attempts to solve the low-level debug issue in DM646x. The UART
      on DM646x SoC allows only 32-bit access. The existing debug-macro.S uses the
      macros from debug-8250.S file. This led to garbage serial out in the case of
      DM646x.
      
      The inclusion of debug-8250.S does not allow for run time fix for this issue.
      There are compile time errors due to multiple definitions of the macros.
      Also when building a single image for multiple DaVinci Platforms, the ifdefs
      cannot be relied upon.
      
      The solution below does not include the debug-8250.S file and defines the
      necessary macros. This solution was arrived at after observing that word
      access does not affect the low-level debug messages on DM644x/DM355.
      
      The other approach to this issue is to use the UART module information
      available in the peripheral registers to decide the access mechanism. But this
      will have to be done for every access of UART specifically for DM646x. Also
      this calls for a modification of the debug-8250.S file.
      Signed-off-by: default avatarChaithrika U S <chaithrika@ti.com>
      Signed-off-by: default avatarKevin Hilman <khilman@deeprootsystems.com>
      e890af73
  3. 16 Jan, 2009 5 commits
  4. 12 Jan, 2009 2 commits
  5. 09 Jan, 2009 1 commit
  6. 08 Jan, 2009 22 commits