|
|
本帖最后由 yyj 于 2018-1-30 11:01 编辑
7 u7 c" F7 m* e: r% }, w: h- [code]EDMA sample test application
0 v4 p8 v1 a4 `! K d1 G& ? - /*# _6 x; [" ~1 [! I9 N# {- W! b
- * edma_test.c
; r0 k* g, M+ {9 B2 u( b. ^ - *, p6 }& {6 N2 C
- * brief EDMA3 Test Application# K% N' t3 `+ Q( M: m1 F
- *
" C* _6 ~' u% f+ k - * This file contains EDMA3 Test code.
+ d% B2 ?0 {3 M, J5 P+ \0 _- {1 m - *
: y3 z5 g/ K9 |. `7 F - * NOTE: THIS FILE IS PROVIDED ONLY FOR INITIAL DEMO RELEASE AND MAY BE. ~. P& k( b1 s( M' q1 y, `
- * REMOVED AFTER THE DEMO OR THE CONTENTS OF THIS FILE ARE SUBJECT! x, x# X- n3 w
- * TO CHANGE.: I7 f2 U! H8 t! I, |$ N! n
- *
# t) I& m- s+ f& \& E - * Copyright (C) 2011 Texas Instruments Incorporated - http://www.ti.com/
, m# N, W {4 U1 C - *
4 T! T+ v/ y9 `; c" E6 G3 ^" M - * This program is free software; you can redistribute it and/or7 O |( B" O7 m2 r
- * modify it under the terms of the GNU General Public License as- _, a& T) A9 G+ i8 A! O
- * published by the Free Software Foundation version 2.. m3 {/ ^5 d+ c1 C
- *. ~; }: l# x4 y* E6 N1 O0 M9 I% E
- * This program is distributed "as is" WITHOUT ANY WARRANTY of any$ h, ]) z5 `, G/ [' a2 I! H
- * kind, whether express or implied; without even the implied warranty7 L" y: A0 {$ h8 J
- * of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
7 ~ C, G2 C+ q! G - * GNU General Public License for more details.
5 ]) e5 n0 `- c s* l - */
# H; {& l; b- ^
% Q. j% o$ D: v! O1 W) [4 b+ j- #include <linux/module.h>5 y! T/ r, d8 p/ H$ ~) y g4 R5 O. W
- #include <linux/init.h>
$ m T" v9 o" k' n- l' J - #include <linux/errno.h>
8 l# ?$ _8 q6 C' g7 c- I* W+ W - #include <linux/types.h>; j3 N0 T; _7 s( T3 y7 y2 ~' \
- #include <linux/interrupt.h>
) `+ C8 y9 C+ f7 n9 @ - #include <asm/io.h>2 m! f5 w: l. o u
- #include <linux/moduleparam.h>
5 c/ q) x( [3 x+ `& c$ t q - #include <linux/sysctl.h>
" _" X1 j/ S$ ~% ]* Q7 ] - #include <linux/mm.h>
, c$ m2 k* s& Z) i X - #include <linux/dma-mapping.h> V6 ?" i/ l2 F& d
- 5 j. d$ R6 [; x8 B/ X6 R
- #include <mach/memory.h>
6 D/ m8 Y4 }; s3 s) c - #include <mach/hardware.h>
) x: w- i4 y0 Y - #include <mach/irqs.h>
$ f8 v8 V- C: B( J% x8 {8 p - #include <asm/hardware/edma.h>- @; y. S, I- p$ z$ t: U
7 A7 p B/ T( m' x/ R6 O* I- #undef EDMA3_DEBUG# ]0 b$ u# J/ j& s1 ]
- /*#define EDMA3_DEBUG*/
1 b3 }0 ~* ~) a& a( K
% ~- [% c; W h: e- #ifdef EDMA3_DEBUG
, z/ F/ O" d" o6 @ - #define DMA_PRINTK(ARGS...) printk(KERN_INFO "<%s>: ",__FUNCTION__);printk(ARGS)
1 E( {% ?' J8 A6 | - #define DMA_FN_IN printk(KERN_INFO "[%s]: start\n", __FUNCTION__)
2 \! V7 H. j8 O' E3 r - #define DMA_FN_OUT printk(KERN_INFO "[%s]: end\n",__FUNCTION__)* i9 S" |6 h( E& M2 ?
- #else
( M& D4 y2 C2 ]% v - #define DMA_PRINTK( x... )
z$ }) M+ E. a4 t- B( g; u4 W5 R6 ~ - #define DMA_FN_IN
% K7 Z( ~8 x! J) G/ S - #define DMA_FN_OUT" ]( ]& G4 c3 }9 t0 w
- #endif6 f" `4 }/ D3 F7 j* Z# d# ^5 \
. M6 r, V7 V- \ J j# x- #define MAX_DMA_TRANSFER_IN_BYTES (32768)3 ]2 O! M. ` G7 B3 F* P: a
- #define STATIC_SHIFT 33 G6 y! J" r: y
- #define TCINTEN_SHIFT 20
* E% |5 o" A) m3 w* X S4 H% V - #define ITCINTEN_SHIFT 21* W( J4 B' d) Z+ c
- #define TCCHEN_SHIFT 228 N9 l7 h0 F" M E( y: L+ B
- #define ITCCHEN_SHIFT 234 B. \7 Z" g: \
- , u U6 }6 H4 A8 b1 M3 C9 Q' X/ I
- static volatile int irqraised1 = 0;
- b( H- z, L v2 h! A - static volatile int irqraised2 = 0;
0 Y: B5 y8 {8 Y+ ?
2 ^) Z7 z5 p9 }2 d; \- int edma3_memtomemcpytest_dma(int acnt, int bcnt, int ccnt, int sync_mode, int event_queue);
+ ]& f# {% \3 { {. _ - int edma3_memtomemcpytest_dma_link(int acnt, int bcnt, int ccnt, int sync_mode, int event_queue);9 J* g6 u+ w, v' l$ R- n$ A
- int edma3_memtomemcpytest_dma_chain(int acnt, int bcnt, int ccnt, int sync_mode, int event_queue);
# z k8 @! M% K2 P - ; ~ x8 |% Q8 P; \
- dma_addr_t dmaphyssrc1 = 0;
' g* L5 `" _, g! H - dma_addr_t dmaphyssrc2 = 0;/ Q) h0 [8 h( d) e) b# z/ C
- dma_addr_t dmaphysdest1 = 0;' Q! e9 B$ ]; w3 m6 D4 H
- dma_addr_t dmaphysdest2 = 0;+ u Q3 \: `+ [! ^% D- A2 R
- , T$ B9 R# X# E) m1 R( F# T8 C2 w
- char *dmabufsrc1 = NULL;- b7 \8 O; [6 }& s1 m0 t, U4 U
- char *dmabufsrc2 = NULL;( d8 O0 o) A% _# C' ~! |" _
- char *dmabufdest1 = NULL;- n; o: g7 O8 `' |' ]. D/ m7 ~* ]
- char *dmabufdest2 = NULL;, o B. X! p% X6 k$ o' }
+ A, Q. S' C2 e' p( B/ {- static int acnt = 512;9 S3 M' _! ], I% `
- static int bcnt = 8;8 X7 x/ J9 w: s' }, \! |
- static int ccnt = 8;9 U% ?1 V0 [# T1 T5 [6 ?; e
" k! G! r5 }0 f% b) T* {( Y- module_param(acnt, int, S_IRUGO);
$ ]$ Z" t2 \% }7 ~( u6 D7 t - module_param(bcnt, int, S_IRUGO);9 {$ {; U' D' L; F; _9 N0 _# F
- module_param(ccnt, int, S_IRUGO);
复制代码 - T9 ?. G+ b4 h. g
" Z$ Z7 o; u9 ~ 这是在TI上找到的一个针对Davanci处理器简单的EDMA3驱动程序测试例程的一部分,我在编译的过程中是用6 V% g& X( b4 ?5 F, `9 B
arm-none-linux-gnueabi-gcc -I /home/tl/omapl138/linux-3.3/arch/arm/include -I /home/tl/omapl138/linux-3.3/include EDMA3test.cpp -o EDMA3这个命令来链接库文件进行编译,但是报的错误特别多,我又试着一个函数一个函数往进加,仍然是很多错误。& I5 X" i ~4 A5 I5 t
我想问一下如何用一个简单的程序来测试一下EDMA3的驱动。- _+ T3 H5 F% P1 s$ N1 @
- J& G0 n' m: [: I5 ^5 K- r, ]0 f
- G3 y1 x. B4 x; ?" F4 [
|
|