|
|
本帖最后由 yyj 于 2018-1-30 11:01 编辑
" X4 m3 M5 H# }- {9 j- [code]EDMA sample test application
/ h3 b. F: x9 {2 S. X5 N! Y - /** z* V" t, m7 i2 u. J0 A
- * edma_test.c
. t! G2 k* Y6 g# C% ^6 v; g# N - *
x1 J, G# ?: \) ~6 Q - * brief EDMA3 Test Application7 q r4 q1 `2 ]2 e
- *5 m1 X1 E8 A! v( _
- * This file contains EDMA3 Test code.' B* L. ~5 K! P! v0 `) M
- *
* z. Q, I( a5 b# n s - * NOTE: THIS FILE IS PROVIDED ONLY FOR INITIAL DEMO RELEASE AND MAY BE M7 {, s0 r+ x. u% r ^+ B# v* m
- * REMOVED AFTER THE DEMO OR THE CONTENTS OF THIS FILE ARE SUBJECT D- g; }7 M. _* M+ v% p! q- D
- * TO CHANGE.$ p$ Y8 q k. c6 l: j4 X
- *- o# U$ ~7 Z4 d) ?+ |8 V+ z& g4 r
- * Copyright (C) 2011 Texas Instruments Incorporated - http://www.ti.com/
0 i: Q) W4 f- K0 X, h7 b - *
4 Z9 `1 \, G i3 [6 p8 T( a - * This program is free software; you can redistribute it and/or
5 I- w' k( K5 d - * modify it under the terms of the GNU General Public License as9 X: Q' c* F! ]* A( D
- * published by the Free Software Foundation version 2.
/ [6 @0 A; O% u. Z+ Z - *% e |1 G4 b8 p G3 V1 L, _
- * This program is distributed "as is" WITHOUT ANY WARRANTY of any8 d9 Y2 E/ I+ i3 z* i! J
- * kind, whether express or implied; without even the implied warranty
7 A7 H( B+ i( Z* ?/ e! h - * of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the C3 P* ~: o7 @. T; G8 R+ `
- * GNU General Public License for more details.+ l8 I1 S# G- a! v
- */& ~& @, R8 X( d( ?! B4 }
- 3 q# P v! K4 Z+ l% D$ n$ S0 `! W- R
- #include <linux/module.h>
& i6 p0 M r: ]" A5 E, b - #include <linux/init.h>
) B7 N) b0 _' I1 Q7 F2 h - #include <linux/errno.h>
6 s% j% K) U5 z - #include <linux/types.h>; ^' ^" k+ v m
- #include <linux/interrupt.h>
) f% |6 r/ y$ J5 Q K C - #include <asm/io.h>
- `: V4 G* O) n$ e3 b" W - #include <linux/moduleparam.h>5 v' {8 G* m. t' J
- #include <linux/sysctl.h>
& z) q3 I4 o8 C4 H( `4 d - #include <linux/mm.h> {8 l o4 D& r$ q7 n
- #include <linux/dma-mapping.h>/ N' ?/ N) d- a( y
7 I1 H" T+ [3 n2 g" l$ S- #include <mach/memory.h>" y* r2 W6 P2 v# k
- #include <mach/hardware.h>
& v- a8 z5 g$ V6 ~* J - #include <mach/irqs.h>
4 q* W1 g, \! O) e3 `/ Z* j# C - #include <asm/hardware/edma.h>. a5 W$ v3 h/ q9 }4 ^% t8 o4 q4 e
- $ J( A- j$ Q0 L+ ^& K' f6 X3 k
- #undef EDMA3_DEBUG# p) X: M. U) b* H# \
- /*#define EDMA3_DEBUG*/& h$ t) W6 z: J: Z0 G
- 9 z. u9 Q) ^- C$ ^. D7 U! X: m& z
- #ifdef EDMA3_DEBUG
* `2 T1 ~* |, ?4 ~ - #define DMA_PRINTK(ARGS...) printk(KERN_INFO "<%s>: ",__FUNCTION__);printk(ARGS)
5 B# Q3 U5 B" X4 b - #define DMA_FN_IN printk(KERN_INFO "[%s]: start\n", __FUNCTION__)7 B4 j% c/ w, u! i( X% u) i
- #define DMA_FN_OUT printk(KERN_INFO "[%s]: end\n",__FUNCTION__)
" r. u' P# U, |# O1 v- l: g4 Z; X0 g - #else9 q w' A& F; j$ W& M3 f# Z" d
- #define DMA_PRINTK( x... )
$ x2 q$ _7 d& U7 L - #define DMA_FN_IN6 c: c- z: _5 Q$ W' R
- #define DMA_FN_OUT+ W% r" K2 j; A% M% ]. B
- #endif
& r: A `# R. U& R9 `8 e( T - : y$ b4 ~1 ^1 z& P W" ]
- #define MAX_DMA_TRANSFER_IN_BYTES (32768)9 a) S2 J0 ]& Z# p! Z) W+ x. M
- #define STATIC_SHIFT 3
: [2 q# C" h8 Y7 {. w: T - #define TCINTEN_SHIFT 20
' O5 x( p0 o' z) v* q+ S9 O0 k/ N - #define ITCINTEN_SHIFT 21
( J- Z. w7 d4 E% z - #define TCCHEN_SHIFT 22
" {6 A/ e* F% h( ] - #define ITCCHEN_SHIFT 23
# q( j% N9 H* N7 m
: {6 g, j0 N9 ?0 Y, S% h2 Q- static volatile int irqraised1 = 0;* i8 _) D3 D# z
- static volatile int irqraised2 = 0;
3 Q1 ]7 I! ?: `" a
$ d( S- |: Z L& ]$ m0 }* y- int edma3_memtomemcpytest_dma(int acnt, int bcnt, int ccnt, int sync_mode, int event_queue);, y1 [: N! `7 a* q+ s3 k
- int edma3_memtomemcpytest_dma_link(int acnt, int bcnt, int ccnt, int sync_mode, int event_queue);. \0 ]4 w* |9 F# z3 C
- int edma3_memtomemcpytest_dma_chain(int acnt, int bcnt, int ccnt, int sync_mode, int event_queue);" ]) U$ q& q9 V. n3 N: `0 k& o
- * S, b4 c% V) I6 e
- dma_addr_t dmaphyssrc1 = 0;1 J, B% L+ f) Z2 k+ f# b# W# Z3 [, b
- dma_addr_t dmaphyssrc2 = 0;
+ ^/ u X" o; J - dma_addr_t dmaphysdest1 = 0;
# }3 s. R/ u& _% E/ D - dma_addr_t dmaphysdest2 = 0;
- O, {- t7 q( @5 t6 ~7 C4 h - 5 y9 V* K; t! l: b
- char *dmabufsrc1 = NULL;
7 X. n, G' K6 b4 u5 S9 A - char *dmabufsrc2 = NULL; v- ^ I$ o/ Q7 [/ o
- char *dmabufdest1 = NULL;) S5 ?6 q0 d& _. [
- char *dmabufdest2 = NULL;
* e6 \" ?9 v" o& _# ]1 V- q3 W
* ^/ s0 \$ K* e& A! Z+ i- static int acnt = 512;3 T8 J) P. {1 t* ~/ B! Z6 d
- static int bcnt = 8;" H `4 n+ K) V( {* b
- static int ccnt = 8;9 T+ C7 U; ]9 |) o
% k3 I$ a" o: k% ^0 u- module_param(acnt, int, S_IRUGO);! C! ~# i3 l* a6 A1 ], K
- module_param(bcnt, int, S_IRUGO);; }3 D$ j) Y+ Y) z' k
- module_param(ccnt, int, S_IRUGO);
复制代码 0 N0 S& d3 |0 A7 p4 N" x
. h1 w) P( r4 S; T& I 这是在TI上找到的一个针对Davanci处理器简单的EDMA3驱动程序测试例程的一部分,我在编译的过程中是用
; H% e* X4 E) Q. uarm-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这个命令来链接库文件进行编译,但是报的错误特别多,我又试着一个函数一个函数往进加,仍然是很多错误。+ [7 Z/ j5 ^, h0 w$ n, ~
我想问一下如何用一个简单的程序来测试一下EDMA3的驱动。' ^# U& k/ Q. ]+ K& ]' [
Y1 d+ F9 y* L7 \) i. o6 R* B4 ~0 M; _; t( R2 O9 M. s
|
|