Commit ac185bdc authored by Greg Kroah-Hartman's avatar Greg Kroah-Hartman

Merge gregkh@master.kernel.org:/home/rmk/linux-2.6-arm

parents ae298c98 ba9b5d76
...@@ -179,17 +179,19 @@ alloc_safe_buffer(struct dmabounce_device_info *device_info, void *ptr, ...@@ -179,17 +179,19 @@ alloc_safe_buffer(struct dmabounce_device_info *device_info, void *ptr,
static inline struct safe_buffer * static inline struct safe_buffer *
find_safe_buffer(struct dmabounce_device_info *device_info, dma_addr_t safe_dma_addr) find_safe_buffer(struct dmabounce_device_info *device_info, dma_addr_t safe_dma_addr)
{ {
struct safe_buffer *b = NULL; struct safe_buffer *b, *rb = NULL;
unsigned long flags; unsigned long flags;
read_lock_irqsave(&device_info->lock, flags); read_lock_irqsave(&device_info->lock, flags);
list_for_each_entry(b, &device_info->safe_buffers, node) list_for_each_entry(b, &device_info->safe_buffers, node)
if (b->safe_dma_addr == safe_dma_addr) if (b->safe_dma_addr == safe_dma_addr) {
rb = b;
break; break;
}
read_unlock_irqrestore(&device_info->lock, flags); read_unlock_irqrestore(&device_info->lock, flags);
return b; return rb;
} }
static inline void static inline void
......
...@@ -634,6 +634,14 @@ ENTRY(__switch_to) ...@@ -634,6 +634,14 @@ ENTRY(__switch_to)
* purpose. * purpose.
*/ */
.macro usr_ret, reg
#ifdef CONFIG_ARM_THUMB
bx \reg
#else
mov pc, \reg
#endif
.endm
.align 5 .align 5
.globl __kuser_helper_start .globl __kuser_helper_start
__kuser_helper_start: __kuser_helper_start:
...@@ -675,7 +683,7 @@ __kuser_memory_barrier: @ 0xffff0fa0 ...@@ -675,7 +683,7 @@ __kuser_memory_barrier: @ 0xffff0fa0
#if __LINUX_ARM_ARCH__ >= 6 && defined(CONFIG_SMP) #if __LINUX_ARM_ARCH__ >= 6 && defined(CONFIG_SMP)
mcr p15, 0, r0, c7, c10, 5 @ dmb mcr p15, 0, r0, c7, c10, 5 @ dmb
#endif #endif
mov pc, lr usr_ret lr
.align 5 .align 5
...@@ -778,7 +786,7 @@ __kuser_cmpxchg: @ 0xffff0fc0 ...@@ -778,7 +786,7 @@ __kuser_cmpxchg: @ 0xffff0fc0
mov r0, #-1 mov r0, #-1
adds r0, r0, #0 adds r0, r0, #0
#endif #endif
mov pc, lr usr_ret lr
#else #else
...@@ -792,7 +800,7 @@ __kuser_cmpxchg: @ 0xffff0fc0 ...@@ -792,7 +800,7 @@ __kuser_cmpxchg: @ 0xffff0fc0
#ifdef CONFIG_SMP #ifdef CONFIG_SMP
mcr p15, 0, r0, c7, c10, 5 @ dmb mcr p15, 0, r0, c7, c10, 5 @ dmb
#endif #endif
mov pc, lr usr_ret lr
#endif #endif
...@@ -834,16 +842,11 @@ __kuser_cmpxchg: @ 0xffff0fc0 ...@@ -834,16 +842,11 @@ __kuser_cmpxchg: @ 0xffff0fc0
__kuser_get_tls: @ 0xffff0fe0 __kuser_get_tls: @ 0xffff0fe0
#if !defined(CONFIG_HAS_TLS_REG) && !defined(CONFIG_TLS_REG_EMUL) #if !defined(CONFIG_HAS_TLS_REG) && !defined(CONFIG_TLS_REG_EMUL)
ldr r0, [pc, #(16 - 8)] @ TLS stored at 0xffff0ff0 ldr r0, [pc, #(16 - 8)] @ TLS stored at 0xffff0ff0
mov pc, lr
#else #else
mrc p15, 0, r0, c13, c0, 3 @ read TLS register mrc p15, 0, r0, c13, c0, 3 @ read TLS register
mov pc, lr
#endif #endif
usr_ret lr
.rep 5 .rep 5
.word 0 @ pad up to __kuser_helper_version .word 0 @ pad up to __kuser_helper_version
......
...@@ -118,7 +118,7 @@ ENTRY(secondary_startup) ...@@ -118,7 +118,7 @@ ENTRY(secondary_startup)
sub r4, r4, r5 @ mmu has been enabled sub r4, r4, r5 @ mmu has been enabled
ldr r4, [r7, r4] @ get secondary_data.pgdir ldr r4, [r7, r4] @ get secondary_data.pgdir
adr lr, __enable_mmu @ return address adr lr, __enable_mmu @ return address
add pc, r10, #12 @ initialise processor add pc, r10, #PROCINFO_INITFUNC @ initialise processor
@ (return control reg) @ (return control reg)
/* /*
......
...@@ -10,45 +10,47 @@ obj-m := ...@@ -10,45 +10,47 @@ obj-m :=
obj-n := obj-n :=
obj- := obj- :=
# DMA
obj-$(CONFIG_S3C2410_DMA) += dma.o
# S3C2400 support files # S3C2400 support files
obj-$(CONFIG_CPU_S3C2400) += s3c2400-gpio.o obj-$(CONFIG_CPU_S3C2400) += s3c2400-gpio.o
# S3C2410 support files # S3C2410 support files
obj-$(CONFIG_CPU_S3C2410) += s3c2410.o obj-$(CONFIG_CPU_S3C2410) += s3c2410.o
obj-$(CONFIG_CPU_S3C2410) += s3c2410-gpio.o obj-$(CONFIG_CPU_S3C2410) += s3c2410-gpio.o
obj-$(CONFIG_S3C2410_DMA) += dma.o
# Power Management support # Power Management support
obj-$(CONFIG_PM) += pm.o sleep.o obj-$(CONFIG_PM) += pm.o sleep.o
obj-$(CONFIG_PM_SIMTEC) += pm-simtec.o obj-$(CONFIG_PM_SIMTEC) += pm-simtec.o
# S3C2412 support # S3C2412 support
obj-$(CONFIG_CPU_S3C2412) += s3c2412.o obj-$(CONFIG_CPU_S3C2412) += s3c2412.o
obj-$(CONFIG_CPU_S3C2412) += s3c2412-clock.o obj-$(CONFIG_CPU_S3C2412) += s3c2412-clock.o
# #
# S3C244X support # S3C244X support
obj-$(CONFIG_CPU_S3C244X) += s3c244x.o obj-$(CONFIG_CPU_S3C244X) += s3c244x.o
obj-$(CONFIG_CPU_S3C244X) += s3c244x-irq.o obj-$(CONFIG_CPU_S3C244X) += s3c244x-irq.o
# Clock control # Clock control
obj-$(CONFIG_S3C2410_CLOCK) += s3c2410-clock.o obj-$(CONFIG_S3C2410_CLOCK) += s3c2410-clock.o
# S3C2440 support # S3C2440 support
obj-$(CONFIG_CPU_S3C2440) += s3c2440.o s3c2440-dsc.o obj-$(CONFIG_CPU_S3C2440) += s3c2440.o s3c2440-dsc.o
obj-$(CONFIG_CPU_S3C2440) += s3c2440-irq.o obj-$(CONFIG_CPU_S3C2440) += s3c2440-irq.o
obj-$(CONFIG_CPU_S3C2440) += s3c2440-clock.o obj-$(CONFIG_CPU_S3C2440) += s3c2440-clock.o
obj-$(CONFIG_CPU_S3C2440) += s3c2410-gpio.o obj-$(CONFIG_CPU_S3C2440) += s3c2410-gpio.o
# S3C2442 support # S3C2442 support
obj-$(CONFIG_CPU_S3C2442) += s3c2442.o obj-$(CONFIG_CPU_S3C2442) += s3c2442.o
obj-$(CONFIG_CPU_S3C2442) += s3c2442-clock.o obj-$(CONFIG_CPU_S3C2442) += s3c2442-clock.o
# bast extras # bast extras
......
...@@ -112,7 +112,7 @@ dmadbg_capture(s3c2410_dma_chan_t *chan, struct s3c2410_dma_regstate *regs) ...@@ -112,7 +112,7 @@ dmadbg_capture(s3c2410_dma_chan_t *chan, struct s3c2410_dma_regstate *regs)
} }
static void static void
dmadbg_showregs(const char *fname, int line, s3c2410_dma_chan_t *chan, dmadbg_dumpregs(const char *fname, int line, s3c2410_dma_chan_t *chan,
struct s3c2410_dma_regstate *regs) struct s3c2410_dma_regstate *regs)
{ {
printk(KERN_DEBUG "dma%d: %s:%d: DCSRC=%08lx, DISRC=%08lx, DSTAT=%08lx DMT=%02lx, DCON=%08lx\n", printk(KERN_DEBUG "dma%d: %s:%d: DCSRC=%08lx, DISRC=%08lx, DSTAT=%08lx DMT=%02lx, DCON=%08lx\n",
...@@ -132,7 +132,16 @@ dmadbg_showchan(const char *fname, int line, s3c2410_dma_chan_t *chan) ...@@ -132,7 +132,16 @@ dmadbg_showchan(const char *fname, int line, s3c2410_dma_chan_t *chan)
chan->number, fname, line, chan->load_state, chan->number, fname, line, chan->load_state,
chan->curr, chan->next, chan->end); chan->curr, chan->next, chan->end);
dmadbg_showregs(fname, line, chan, &state); dmadbg_dumpregs(fname, line, chan, &state);
}
static void
dmadbg_showregs(const char *fname, int line, s3c2410_dma_chan_t *chan)
{
struct s3c2410_dma_regstate state;
dmadbg_capture(chan, &state);
dmadbg_dumpregs(fname, line, chan, &state);
} }
#define dbg_showregs(chan) dmadbg_showregs(__FUNCTION__, __LINE__, (chan)) #define dbg_showregs(chan) dmadbg_showregs(__FUNCTION__, __LINE__, (chan))
...@@ -253,10 +262,14 @@ s3c2410_dma_loadbuffer(s3c2410_dma_chan_t *chan, ...@@ -253,10 +262,14 @@ s3c2410_dma_loadbuffer(s3c2410_dma_chan_t *chan,
buf->next); buf->next);
reload = (buf->next == NULL) ? S3C2410_DCON_NORELOAD : 0; reload = (buf->next == NULL) ? S3C2410_DCON_NORELOAD : 0;
} else { } else {
pr_debug("load_state is %d => autoreload\n", chan->load_state); //pr_debug("load_state is %d => autoreload\n", chan->load_state);
reload = S3C2410_DCON_AUTORELOAD; reload = S3C2410_DCON_AUTORELOAD;
} }
if ((buf->data & 0xf0000000) != 0x30000000) {
dmawarn("dmaload: buffer is %p\n", (void *)buf->data);
}
writel(buf->data, chan->addr_reg); writel(buf->data, chan->addr_reg);
dma_wrreg(chan, S3C2410_DMA_DCON, dma_wrreg(chan, S3C2410_DMA_DCON,
...@@ -370,7 +383,7 @@ static int s3c2410_dma_start(s3c2410_dma_chan_t *chan) ...@@ -370,7 +383,7 @@ static int s3c2410_dma_start(s3c2410_dma_chan_t *chan)
tmp |= S3C2410_DMASKTRIG_ON; tmp |= S3C2410_DMASKTRIG_ON;
dma_wrreg(chan, S3C2410_DMA_DMASKTRIG, tmp); dma_wrreg(chan, S3C2410_DMA_DMASKTRIG, tmp);
pr_debug("wrote %08lx to DMASKTRIG\n", tmp); pr_debug("dma%d: %08lx to DMASKTRIG\n", chan->number, tmp);
#if 0 #if 0
/* the dma buffer loads should take care of clearing the AUTO /* the dma buffer loads should take care of clearing the AUTO
...@@ -384,7 +397,30 @@ static int s3c2410_dma_start(s3c2410_dma_chan_t *chan) ...@@ -384,7 +397,30 @@ static int s3c2410_dma_start(s3c2410_dma_chan_t *chan)
dbg_showchan(chan); dbg_showchan(chan);
/* if we've only loaded one buffer onto the channel, then chec
* to see if we have another, and if so, try and load it so when
* the first buffer is finished, the new one will be loaded onto
* the channel */
if (chan->next != NULL) {
if (chan->load_state == S3C2410_DMALOAD_1LOADED) {
if (s3c2410_dma_waitforload(chan, __LINE__) == 0) {
pr_debug("%s: buff not yet loaded, no more todo\n",
__FUNCTION__);
} else {
chan->load_state = S3C2410_DMALOAD_1RUNNING;
s3c2410_dma_loadbuffer(chan, chan->next);
}
} else if (chan->load_state == S3C2410_DMALOAD_1RUNNING) {
s3c2410_dma_loadbuffer(chan, chan->next);
}
}
local_irq_restore(flags); local_irq_restore(flags);
return 0; return 0;
} }
...@@ -436,12 +472,11 @@ int s3c2410_dma_enqueue(unsigned int channel, void *id, ...@@ -436,12 +472,11 @@ int s3c2410_dma_enqueue(unsigned int channel, void *id,
buf = kmem_cache_alloc(dma_kmem, GFP_ATOMIC); buf = kmem_cache_alloc(dma_kmem, GFP_ATOMIC);
if (buf == NULL) { if (buf == NULL) {
pr_debug("%s: out of memory (%ld alloc)\n", pr_debug("%s: out of memory (%ld alloc)\n",
__FUNCTION__, sizeof(*buf)); __FUNCTION__, (long)sizeof(*buf));
return -ENOMEM; return -ENOMEM;
} }
pr_debug("%s: new buffer %p\n", __FUNCTION__, buf); //pr_debug("%s: new buffer %p\n", __FUNCTION__, buf);
//dbg_showchan(chan); //dbg_showchan(chan);
buf->next = NULL; buf->next = NULL;
...@@ -537,14 +572,20 @@ s3c2410_dma_lastxfer(s3c2410_dma_chan_t *chan) ...@@ -537,14 +572,20 @@ s3c2410_dma_lastxfer(s3c2410_dma_chan_t *chan)
case S3C2410_DMALOAD_1LOADED: case S3C2410_DMALOAD_1LOADED:
if (s3c2410_dma_waitforload(chan, __LINE__) == 0) { if (s3c2410_dma_waitforload(chan, __LINE__) == 0) {
/* flag error? */ /* flag error? */
printk(KERN_ERR "dma%d: timeout waiting for load\n", printk(KERN_ERR "dma%d: timeout waiting for load (%s)\n",
chan->number); chan->number, __FUNCTION__);
return; return;
} }
break; break;
case S3C2410_DMALOAD_1LOADED_1RUNNING:
/* I belive in this case we do not have anything to do
* until the next buffer comes along, and we turn off the
* reload */
return;
default: default:
pr_debug("dma%d: lastxfer: unhandled load_state %d with no next", pr_debug("dma%d: lastxfer: unhandled load_state %d with no next\n",
chan->number, chan->load_state); chan->number, chan->load_state);
return; return;
...@@ -629,7 +670,14 @@ s3c2410_dma_irq(int irq, void *devpw, struct pt_regs *regs) ...@@ -629,7 +670,14 @@ s3c2410_dma_irq(int irq, void *devpw, struct pt_regs *regs)
} else { } else {
} }
if (chan->next != NULL) { /* only reload if the channel is still running... our buffer done
* routine may have altered the state by requesting the dma channel
* to stop or shutdown... */
/* todo: check that when the channel is shut-down from inside this
* function, we cope with unsetting reload, etc */
if (chan->next != NULL && chan->state != S3C2410_DMA_IDLE) {
unsigned long flags; unsigned long flags;
switch (chan->load_state) { switch (chan->load_state) {
...@@ -644,8 +692,8 @@ s3c2410_dma_irq(int irq, void *devpw, struct pt_regs *regs) ...@@ -644,8 +692,8 @@ s3c2410_dma_irq(int irq, void *devpw, struct pt_regs *regs)
case S3C2410_DMALOAD_1LOADED: case S3C2410_DMALOAD_1LOADED:
if (s3c2410_dma_waitforload(chan, __LINE__) == 0) { if (s3c2410_dma_waitforload(chan, __LINE__) == 0) {
/* flag error? */ /* flag error? */
printk(KERN_ERR "dma%d: timeout waiting for load\n", printk(KERN_ERR "dma%d: timeout waiting for load (%s)\n",
chan->number); chan->number, __FUNCTION__);
return IRQ_HANDLED; return IRQ_HANDLED;
} }
...@@ -678,8 +726,6 @@ s3c2410_dma_irq(int irq, void *devpw, struct pt_regs *regs) ...@@ -678,8 +726,6 @@ s3c2410_dma_irq(int irq, void *devpw, struct pt_regs *regs)
return IRQ_HANDLED; return IRQ_HANDLED;
} }
/* s3c2410_request_dma /* s3c2410_request_dma
* *
* get control of an dma channel * get control of an dma channel
...@@ -718,11 +764,17 @@ int s3c2410_dma_request(unsigned int channel, s3c2410_dma_client_t *client, ...@@ -718,11 +764,17 @@ int s3c2410_dma_request(unsigned int channel, s3c2410_dma_client_t *client,
pr_debug("dma%d: %s : requesting irq %d\n", pr_debug("dma%d: %s : requesting irq %d\n",
channel, __FUNCTION__, chan->irq); channel, __FUNCTION__, chan->irq);
chan->irq_claimed = 1;
local_irq_restore(flags);
err = request_irq(chan->irq, s3c2410_dma_irq, IRQF_DISABLED, err = request_irq(chan->irq, s3c2410_dma_irq, IRQF_DISABLED,
client->name, (void *)chan); client->name, (void *)chan);
local_irq_save(flags);
if (err) { if (err) {
chan->in_use = 0; chan->in_use = 0;
chan->irq_claimed = 0;
local_irq_restore(flags); local_irq_restore(flags);
printk(KERN_ERR "%s: cannot get IRQ %d for DMA %d\n", printk(KERN_ERR "%s: cannot get IRQ %d for DMA %d\n",
...@@ -730,7 +782,6 @@ int s3c2410_dma_request(unsigned int channel, s3c2410_dma_client_t *client, ...@@ -730,7 +782,6 @@ int s3c2410_dma_request(unsigned int channel, s3c2410_dma_client_t *client,
return err; return err;
} }
chan->irq_claimed = 1;
chan->irq_enabled = 1; chan->irq_enabled = 1;
} }
...@@ -810,6 +861,7 @@ static int s3c2410_dma_dostop(s3c2410_dma_chan_t *chan) ...@@ -810,6 +861,7 @@ static int s3c2410_dma_dostop(s3c2410_dma_chan_t *chan)
tmp = dma_rdreg(chan, S3C2410_DMA_DMASKTRIG); tmp = dma_rdreg(chan, S3C2410_DMA_DMASKTRIG);
tmp |= S3C2410_DMASKTRIG_STOP; tmp |= S3C2410_DMASKTRIG_STOP;
//tmp &= ~S3C2410_DMASKTRIG_ON;
dma_wrreg(chan, S3C2410_DMA_DMASKTRIG, tmp); dma_wrreg(chan, S3C2410_DMA_DMASKTRIG, tmp);
#if 0 #if 0
...@@ -819,6 +871,7 @@ static int s3c2410_dma_dostop(s3c2410_dma_chan_t *chan) ...@@ -819,6 +871,7 @@ static int s3c2410_dma_dostop(s3c2410_dma_chan_t *chan)
dma_wrreg(chan, S3C2410_DMA_DCON, tmp); dma_wrreg(chan, S3C2410_DMA_DCON, tmp);
#endif #endif
/* should stop do this, or should we wait for flush? */
chan->state = S3C2410_DMA_IDLE; chan->state = S3C2410_DMA_IDLE;
chan->load_state = S3C2410_DMALOAD_NONE; chan->load_state = S3C2410_DMALOAD_NONE;
...@@ -827,6 +880,22 @@ static int s3c2410_dma_dostop(s3c2410_dma_chan_t *chan) ...@@ -827,6 +880,22 @@ static int s3c2410_dma_dostop(s3c2410_dma_chan_t *chan)
return 0; return 0;
} }
void s3c2410_dma_waitforstop(s3c2410_dma_chan_t *chan)
{
unsigned long tmp;
unsigned int timeout = 0x10000;
while (timeout-- > 0) {
tmp = dma_rdreg(chan, S3C2410_DMA_DMASKTRIG);
if (!(tmp & S3C2410_DMASKTRIG_ON))
return;
}
pr_debug("dma%d: failed to stop?\n", chan->number);
}
/* s3c2410_dma_flush /* s3c2410_dma_flush
* *
* stop the channel, and remove all current and pending transfers * stop the channel, and remove all current and pending transfers
...@@ -837,7 +906,9 @@ static int s3c2410_dma_flush(s3c2410_dma_chan_t *chan) ...@@ -837,7 +906,9 @@ static int s3c2410_dma_flush(s3c2410_dma_chan_t *chan)
s3c2410_dma_buf_t *buf, *next; s3c2410_dma_buf_t *buf, *next;
unsigned long flags; unsigned long flags;
pr_debug("%s:\n", __FUNCTION__); pr_debug("%s: chan %p (%d)\n", __FUNCTION__, chan, chan->number);
dbg_showchan(chan);
local_irq_save(flags); local_irq_save(flags);
...@@ -864,11 +935,64 @@ static int s3c2410_dma_flush(s3c2410_dma_chan_t *chan) ...@@ -864,11 +935,64 @@ static int s3c2410_dma_flush(s3c2410_dma_chan_t *chan)
} }
} }
dbg_showregs(chan);
s3c2410_dma_waitforstop(chan);
#if 0
/* should also clear interrupts, according to WinCE BSP */
{
unsigned long tmp;
tmp = dma_rdreg(chan, S3C2410_DMA_DCON);
tmp |= S3C2410_DCON_NORELOAD;
dma_wrreg(chan, S3C2410_DMA_DCON, tmp);
}
#endif
dbg_showregs(chan);
local_irq_restore(flags); local_irq_restore(flags);
return 0; return 0;
} }
int
s3c2410_dma_started(s3c2410_dma_chan_t *chan)
{
unsigned long flags;
local_irq_save(flags);
dbg_showchan(chan);
/* if we've only loaded one buffer onto the channel, then chec
* to see if we have another, and if so, try and load it so when
* the first buffer is finished, the new one will be loaded onto
* the channel */
if (chan->next != NULL) {
if (chan->load_state == S3C2410_DMALOAD_1LOADED) {
if (s3c2410_dma_waitforload(chan, __LINE__) == 0) {
pr_debug("%s: buff not yet loaded, no more todo\n",
__FUNCTION__);
} else {
chan->load_state = S3C2410_DMALOAD_1RUNNING;
s3c2410_dma_loadbuffer(chan, chan->next);
}
} else if (chan->load_state == S3C2410_DMALOAD_1RUNNING) {
s3c2410_dma_loadbuffer(chan, chan->next);
}
}
local_irq_restore(flags);
return 0;
}
int int
s3c2410_dma_ctrl(dmach_t channel, s3c2410_chan_op_t op) s3c2410_dma_ctrl(dmach_t channel, s3c2410_chan_op_t op)
...@@ -885,14 +1009,15 @@ s3c2410_dma_ctrl(dmach_t channel, s3c2410_chan_op_t op) ...@@ -885,14 +1009,15 @@ s3c2410_dma_ctrl(dmach_t channel, s3c2410_chan_op_t op)
return s3c2410_dma_dostop(chan); return s3c2410_dma_dostop(chan);
case S3C2410_DMAOP_PAUSE: case S3C2410_DMAOP_PAUSE:
return -ENOENT;
case S3C2410_DMAOP_RESUME: case S3C2410_DMAOP_RESUME:
return -ENOENT; return -ENOENT;
case S3C2410_DMAOP_FLUSH: case S3C2410_DMAOP_FLUSH:
return s3c2410_dma_flush(chan); return s3c2410_dma_flush(chan);
case S3C2410_DMAOP_STARTED:
return s3c2410_dma_started(chan);
case S3C2410_DMAOP_TIMEOUT: case S3C2410_DMAOP_TIMEOUT:
return 0; return 0;
......
...@@ -285,7 +285,7 @@ static struct flash_platform_data versatile_flash_data = { ...@@ -285,7 +285,7 @@ static struct flash_platform_data versatile_flash_data = {
static struct resource versatile_flash_resource = { static struct resource versatile_flash_resource = {
.start = VERSATILE_FLASH_BASE, .start = VERSATILE_FLASH_BASE,
.end = VERSATILE_FLASH_BASE + VERSATILE_FLASH_SIZE, .end = VERSATILE_FLASH_BASE + VERSATILE_FLASH_SIZE - 1,
.flags = IORESOURCE_MEM, .flags = IORESOURCE_MEM,
}; };
......
...@@ -104,6 +104,7 @@ enum s3c2410_chan_op_e { ...@@ -104,6 +104,7 @@ enum s3c2410_chan_op_e {
S3C2410_DMAOP_RESUME, S3C2410_DMAOP_RESUME,
S3C2410_DMAOP_FLUSH, S3C2410_DMAOP_FLUSH,
S3C2410_DMAOP_TIMEOUT, /* internal signal to handler */ S3C2410_DMAOP_TIMEOUT, /* internal signal to handler */
S3C2410_DMAOP_STARTED, /* indicate channel started */
}; };
typedef enum s3c2410_chan_op_e s3c2410_chan_op_t; typedef enum s3c2410_chan_op_e s3c2410_chan_op_t;
......
...@@ -55,5 +55,6 @@ extern unsigned int elf_hwcap; ...@@ -55,5 +55,6 @@ extern unsigned int elf_hwcap;
#define HWCAP_VFP 64 #define HWCAP_VFP 64
#define HWCAP_EDSP 128 #define HWCAP_EDSP 128
#define HWCAP_JAVA 256 #define HWCAP_JAVA 256
#define HWCAP_IWMMXT 512
#endif #endif
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment