|
|
本帖最后由 yyj 于 2018-1-30 11:01 编辑 & r$ Q: `7 y' s6 [- p0 H J+ Q: K
- [code]EDMA sample test application
# F; ]! D4 B$ H3 E/ y! W$ Z2 i - /*
+ Y' t6 s, O6 @0 A. H7 v. I5 [/ z - * edma_test.c4 Y9 u) } W4 F1 b) Q
- *
: I9 E6 n" B, d2 [3 M - * brief EDMA3 Test Application
. H- E5 h' M: ^4 W - *8 Y7 b; I. ?+ C3 P' \& U! V! L# d
- * This file contains EDMA3 Test code.% G0 r: l3 V" `: n# t3 u/ u6 \
- * b9 v, Y* c+ i5 q7 F4 A
- * NOTE: THIS FILE IS PROVIDED ONLY FOR INITIAL DEMO RELEASE AND MAY BE
6 N7 ?. C, h" A8 y; z - * REMOVED AFTER THE DEMO OR THE CONTENTS OF THIS FILE ARE SUBJECT; p9 Y0 `: n: F# n5 \! l
- * TO CHANGE.
$ p& }, B/ T# d* {4 s$ J# q4 q - *6 u8 Q X% t* R6 l3 h
- * Copyright (C) 2011 Texas Instruments Incorporated - http://www.ti.com/' F9 o5 Y( @$ T8 O5 L( P
- *
# s% n* ]$ w% q; l: Q4 I - * This program is free software; you can redistribute it and/or" y( I! p) k( C7 Y" Q
- * modify it under the terms of the GNU General Public License as8 |6 H) p: c2 f# o4 ~# y/ m
- * published by the Free Software Foundation version 2.4 p* B9 g( v( w- o6 g( P6 q
- ** Z& m3 o. y- [
- * This program is distributed "as is" WITHOUT ANY WARRANTY of any$ a; _; z$ J3 P& U
- * kind, whether express or implied; without even the implied warranty, n: g( g1 G5 X0 R
- * of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
8 G, R. _$ i/ q' K, [* e8 N - * GNU General Public License for more details., q! ?0 x% v& M9 q$ }
- */* L: A9 q& V: M1 i* n% ^+ d1 ~
! `; ]( q O6 h% L2 N# M* k. I9 a- #include <linux/module.h>8 N5 J% Z8 i& ]0 L* A9 Q
- #include <linux/init.h>, x4 X" A8 Y+ n: [& _) h5 T
- #include <linux/errno.h>
5 X& z/ @4 V3 e0 ]4 n7 x" G" k - #include <linux/types.h>
% j2 j! Y* C6 _3 u0 ~ - #include <linux/interrupt.h>
4 e5 q' @6 M3 [" N/ F' M, ? - #include <asm/io.h>- P5 n0 o, f5 @7 E, K8 f
- #include <linux/moduleparam.h>5 |! r/ ~+ n3 c* H M
- #include <linux/sysctl.h>/ J/ s/ v' o! D' p+ F1 j
- #include <linux/mm.h>& S- D3 t1 _" T$ M" }- _' d
- #include <linux/dma-mapping.h>
/ p0 \' A3 e7 I% u$ T) l8 J - 9 t. |1 L, R) \1 @) y+ I, z ?, B. t
- #include <mach/memory.h>; |/ P7 z7 F9 A6 @
- #include <mach/hardware.h>* B% ?, o+ m+ M- b6 J/ U: t( X8 f
- #include <mach/irqs.h>: V9 Y6 E9 W, B9 f% |' E
- #include <asm/hardware/edma.h>/ f6 G3 s3 T% @4 J, J# _
- % z( P3 O& p, w8 v
- #undef EDMA3_DEBUG: y* O* D) p3 I6 s2 h, o
- /*#define EDMA3_DEBUG*/: `' I0 X0 b2 ?# C/ k [
8 G- |: g# v# W: m- #ifdef EDMA3_DEBUG
) w) f( C% f; L0 j - #define DMA_PRINTK(ARGS...) printk(KERN_INFO "<%s>: ",__FUNCTION__);printk(ARGS)
/ B0 l* i: P' I0 ] - #define DMA_FN_IN printk(KERN_INFO "[%s]: start\n", __FUNCTION__)8 F3 S& G2 A0 A* S# Z3 L* a$ F
- #define DMA_FN_OUT printk(KERN_INFO "[%s]: end\n",__FUNCTION__)) Q' N4 O, x; O3 p
- #else
7 k( E2 H7 H! ? - #define DMA_PRINTK( x... )( n5 T1 g/ K/ X2 s( ?
- #define DMA_FN_IN
! e) t* e* H* l; j - #define DMA_FN_OUT
3 l- J4 V0 }6 `( K- M+ [5 b1 I - #endif
8 l" b0 r5 V+ D& F" n/ p
" S# m# M; @2 m& b( E" O- #define MAX_DMA_TRANSFER_IN_BYTES (32768)
/ O1 Z1 Q2 ]/ W Q& Q4 [ - #define STATIC_SHIFT 3
( Y2 z1 n1 R9 Z" A: H - #define TCINTEN_SHIFT 20
) Z) Z$ [& p% F* m" m - #define ITCINTEN_SHIFT 210 ] z6 V# I0 k: U
- #define TCCHEN_SHIFT 223 ^6 Y% D; R1 w; T
- #define ITCCHEN_SHIFT 23
. f6 |. N: v+ k: F! ?! y: X1 V5 E
/ o* m! F; C5 J. {- static volatile int irqraised1 = 0;$ e) f+ H w3 `. e- `
- static volatile int irqraised2 = 0;' m: `; \) b7 d1 t
+ ?7 W" }7 z$ S$ U% L; Z0 E, h: b- int edma3_memtomemcpytest_dma(int acnt, int bcnt, int ccnt, int sync_mode, int event_queue);
* G) W1 u# n n; @9 Q - int edma3_memtomemcpytest_dma_link(int acnt, int bcnt, int ccnt, int sync_mode, int event_queue);
8 q. p( B1 U- J5 ]2 q/ j* j# @, @ - int edma3_memtomemcpytest_dma_chain(int acnt, int bcnt, int ccnt, int sync_mode, int event_queue);
. p# @+ ^9 ]8 S$ Y# N
" o1 [* O; s4 \2 l- dma_addr_t dmaphyssrc1 = 0;
7 ]1 d" ^; {0 \/ f( M6 e! { - dma_addr_t dmaphyssrc2 = 0;
- O: E; i' r9 p" O; R. x# b - dma_addr_t dmaphysdest1 = 0;
/ S `$ D C8 M! F" C3 h - dma_addr_t dmaphysdest2 = 0;/ X) q8 }, F, @" i
- * M7 y; N3 \. P" E! O' t* O$ |, ~, u
- char *dmabufsrc1 = NULL;1 t6 B0 V/ h$ z* M- Q
- char *dmabufsrc2 = NULL;
7 _6 I' i5 c5 S - char *dmabufdest1 = NULL;
: C! n. |/ |. M" G) F& u - char *dmabufdest2 = NULL;# o# c5 M- v( b# D( ]; M5 B; w* A
6 j4 K( X; \4 w m- static int acnt = 512;$ ~9 N# R7 V4 Z( H! s& p
- static int bcnt = 8;# [& \, ?6 {/ n* z9 V5 U
- static int ccnt = 8;
9 v; \ p O6 _( T+ U1 k5 ]" o4 W! r) x+ _ - 8 C7 g3 u! D) _9 V
- module_param(acnt, int, S_IRUGO);
; q* ], P1 d/ c4 o4 E - module_param(bcnt, int, S_IRUGO);
; E; x# C6 `+ ] L" w& T - module_param(ccnt, int, S_IRUGO);
复制代码 . C2 `! @8 z0 R) @
- Q* ^! J9 e- E2 o. J8 S3 H" r 这是在TI上找到的一个针对Davanci处理器简单的EDMA3驱动程序测试例程的一部分,我在编译的过程中是用
$ |0 z7 z8 \2 m% i$ l6 E, c7 o2 W7 qarm-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这个命令来链接库文件进行编译,但是报的错误特别多,我又试着一个函数一个函数往进加,仍然是很多错误。
6 a7 E3 w" p2 C" I5 m; Z7 o, ] 我想问一下如何用一个简单的程序来测试一下EDMA3的驱动。* l: Q8 v( k; F- Y) r6 ~
: Z7 U1 m3 ~: m. X
' t, T+ G" C& r3 X* d+ D |
|