diff options
| author | Wolfgang Denk <wd@denx.de> | 2012-04-16 23:01:12 +0200 | 
|---|---|---|
| committer | Wolfgang Denk <wd@denx.de> | 2012-04-16 23:01:12 +0200 | 
| commit | db39f24151627733d6166c5e9a875fe8b356fa72 (patch) | |
| tree | d091e23af47b9ae848c6f69144f941d9f072aae6 /drivers/dma/apbh_dma.c | |
| parent | b64c2420e02a7d068aae6e0d069f270feb3cdc9a (diff) | |
| parent | 2694bb9bcc8ca9636faf38c866dda7bf0529e35f (diff) | |
| download | olio-uboot-2014.01-db39f24151627733d6166c5e9a875fe8b356fa72.tar.xz olio-uboot-2014.01-db39f24151627733d6166c5e9a875fe8b356fa72.zip | |
Merge branch 'master' of git://git.denx.de/u-boot-arm
* 'master' of git://git.denx.de/u-boot-arm:
  ARM926EJS: Fix cache.c to comply with checkpatch.pl
  ARM926EJS: Make asm routines volatile in cache ops
  MX35: mx35pdk: wrong board revision
  ARM1136: MX35: Make asm routines volatile in cache ops
  ARM: add u-boot.imx as target for i.MX SOCs
  M28: Pull out CONFIG_APBH_DMA so it's always enabled
  DMA: Split the APBH DMA init into block and channel init
  imx: Return gpio_set_value in gpio_direction_output
  imx: Use GPIO_TO_PORT macro in the gpio driver instead of (gpio >> 5)
  imx: Add GPIO_TO_PORT macro in the mxc_gpio driver
  imx: Remove unneeded/repititive definitions from imx headers
  i.MX28: Allow coexistence of PIO and DMA mode for SD/MMC
  MX31: mx31pdk: drop enable_caches from board file
  i.MX28: Fix initial stack pointer position
  mx35: mx35pdk: fix when cache functions are linked
  mx35: flea3: fix when cache functions are linked
  ARM: 926ejs: use debug() for misaligned addresses
  ARM1136: add cache flush and invalidate operations
  mx6qsabrelite: Fix the serial console port
  mx6qsabrelite: Add boot switch setting information into the README
  i.MX6: mx6qsabrelite: add cache commands if cache is enabled
  i.MX6: implement enable_caches()
  i.MX6: define CACHELINE_SIZE
  MX53: DDR: Fix ZQHWCTRL field TZQ_CS
  mx28evk: Add a README file
  mx28: Split the README into a common part and a m28 specific part
  tricorder: Load kernel from ubifs
  tricorder: Add UBIFS
  cm-t35: fix Ethernet reset timing
  hawkboard: Add CONFIG_SPL_LIBGENERIC_SUPPORT
  BeagleBoard: Remove userbutton command and use gpio command instead
  OMAP: Move omap1510inn to Unmaintained / Orphaned
Diffstat (limited to 'drivers/dma/apbh_dma.c')
| -rw-r--r-- | drivers/dma/apbh_dma.c | 38 | 
1 files changed, 17 insertions, 21 deletions
| diff --git a/drivers/dma/apbh_dma.c b/drivers/dma/apbh_dma.c index c086629b0..cb2193ec5 100644 --- a/drivers/dma/apbh_dma.c +++ b/drivers/dma/apbh_dma.c @@ -316,7 +316,7 @@ static int mxs_dma_request(int channel)   * The channel will NOT be released if it's marked "busy" (see   * mxs_dma_enable()).   */ -static int mxs_dma_release(int channel) +int mxs_dma_release(int channel)  {  	struct mxs_dma_chan *pchan;  	int ret; @@ -552,12 +552,10 @@ int mxs_dma_go(int chan)  /*   * Initialize the DMA hardware   */ -int mxs_dma_init(void) +void mxs_dma_init(void)  {  	struct mx28_apbh_regs *apbh_regs =  		(struct mx28_apbh_regs *)MXS_APBH_BASE; -	struct mxs_dma_chan *pchan; -	int ret, channel;  	mx28_reset_block(&apbh_regs->hw_apbh_ctrl0_reg); @@ -576,28 +574,26 @@ int mxs_dma_init(void)  	writel(APBH_CTRL0_APB_BURST_EN,  		&apbh_regs->hw_apbh_ctrl0_clr);  #endif +} -	for (channel = 0; channel < MXS_MAX_DMA_CHANNELS; channel++) { -		pchan = mxs_dma_channels + channel; -		pchan->flags = MXS_DMA_FLAGS_VALID; - -		ret = mxs_dma_request(channel); +int mxs_dma_init_channel(int channel) +{ +	struct mxs_dma_chan *pchan; +	int ret; -		if (ret) { -			printf("MXS DMA: Can't acquire DMA channel %i\n", -				channel); +	pchan = mxs_dma_channels + channel; +	pchan->flags = MXS_DMA_FLAGS_VALID; -			goto err; -		} +	ret = mxs_dma_request(channel); -		mxs_dma_reset(channel); -		mxs_dma_ack_irq(channel); +	if (ret) { +		printf("MXS DMA: Can't acquire DMA channel %i\n", +			channel); +		return ret;  	} -	return 0; +	mxs_dma_reset(channel); +	mxs_dma_ack_irq(channel); -err: -	while (--channel >= 0) -		mxs_dma_release(channel); -	return ret; +	return 0;  } |