|
|
本帖最后由 yyj 于 2018-1-30 11:01 编辑 ; M$ ?; P; y: A, E. D( {* N
- [code]EDMA sample test application* H5 o$ ^. V* C) H3 |4 N
- /*7 @& `* P/ N* I3 R7 _# y
- * edma_test.c3 _5 `* b7 n# Z4 U/ H6 T) J
- *
! L+ [% k+ N7 }# N( f6 m - * brief EDMA3 Test Application
& z( J5 A% |/ @* l - *% {( }; h) U; m1 a3 { {
- * This file contains EDMA3 Test code.6 m& z5 f! K( p- p
- *3 m$ G4 ~% S# |% G0 t
- * NOTE: THIS FILE IS PROVIDED ONLY FOR INITIAL DEMO RELEASE AND MAY BE6 C" W# o4 z$ B8 z
- * REMOVED AFTER THE DEMO OR THE CONTENTS OF THIS FILE ARE SUBJECT
2 p" t3 Q2 D4 L9 |, K - * TO CHANGE.
! X8 j8 N9 A( V5 {- A+ _ - *& K1 o* s9 p0 m' V6 F! i2 |% f& i
- * Copyright (C) 2011 Texas Instruments Incorporated - http://www.ti.com// g, J- V: ]; X a1 O
- *1 a% ~' c# `* N0 O0 H
- * This program is free software; you can redistribute it and/or1 a" a9 c6 x6 p3 W
- * modify it under the terms of the GNU General Public License as! k) i n/ k o4 z
- * published by the Free Software Foundation version 2.8 a q, y g/ A1 l9 G% o. Y
- *4 N* X3 ?/ I4 J2 u! E& W1 V1 G
- * This program is distributed "as is" WITHOUT ANY WARRANTY of any
$ J% l' p* T1 X0 i/ O - * kind, whether express or implied; without even the implied warranty1 a# Q6 O% o! a
- * of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the' o1 m( T/ J% `* Z$ l# D5 p
- * GNU General Public License for more details.. J+ I, ~" b/ X: X
- */& ^8 ^1 u2 |/ f( ?
# Q: `' F/ \' `4 @' v% ]3 t6 u7 ^- #include <linux/module.h>* M7 j3 c( Z& O/ E( D
- #include <linux/init.h>
" h2 t1 `9 ^% s- U' X3 K - #include <linux/errno.h>$ i- ^9 O: S& c" O
- #include <linux/types.h>
$ K4 D3 @# C8 {. j: t+ i - #include <linux/interrupt.h>
, X' R8 b) d4 b - #include <asm/io.h>0 q$ @, e- I6 D
- #include <linux/moduleparam.h>8 T6 ^: M' W2 {/ `# B' A( m6 E4 I, d
- #include <linux/sysctl.h>
5 v/ O) J8 l2 X! R" y/ `" E( N - #include <linux/mm.h>
+ S) ?+ `' s+ I- |, d; U$ b) N - #include <linux/dma-mapping.h>+ D6 x* z& u( x( d- y s3 K
- l& C, i# ]9 Z4 @4 ~4 f0 A# K: x
- #include <mach/memory.h>
) t G* k5 j }7 L3 Q - #include <mach/hardware.h>5 o3 j# E% Z! n' ~% t/ N
- #include <mach/irqs.h>/ @3 h% O r1 a, J: I/ z1 R+ f. H
- #include <asm/hardware/edma.h>
" {; _) l7 Y/ V& l. U) S0 C
* X1 }* m e$ G. K/ ^8 t- #undef EDMA3_DEBUG
) `/ R: W: j% S1 |) @. v2 Y( e - /*#define EDMA3_DEBUG*/9 K- M/ |1 @4 r5 q
- " h* X4 j) f6 z3 q
- #ifdef EDMA3_DEBUG! t$ e+ L) ], Q1 Q2 f
- #define DMA_PRINTK(ARGS...) printk(KERN_INFO "<%s>: ",__FUNCTION__);printk(ARGS)8 `9 S. f+ }9 `. {( |
- #define DMA_FN_IN printk(KERN_INFO "[%s]: start\n", __FUNCTION__)
[. Y, u" d5 ^ - #define DMA_FN_OUT printk(KERN_INFO "[%s]: end\n",__FUNCTION__)
/ H8 I5 e) `# p) @' i, x9 N" }" N - #else) k) b. `7 x3 [4 `5 y; i2 f
- #define DMA_PRINTK( x... )5 e& J" I1 Q) I! U: v
- #define DMA_FN_IN
1 J8 N9 O2 N6 T4 S { - #define DMA_FN_OUT
( G! O6 G8 F" n& }* k0 q - #endif% T# h* H% g. p8 x s
- 9 W6 p& c' K% k+ l4 ?
- #define MAX_DMA_TRANSFER_IN_BYTES (32768)% j3 K- H% M6 ]
- #define STATIC_SHIFT 3$ Q. u @8 z' \/ t" m" L
- #define TCINTEN_SHIFT 201 U( }0 T3 r# I; g9 [0 Q( b% m. W
- #define ITCINTEN_SHIFT 21/ ~3 s8 {! J7 v0 z; K
- #define TCCHEN_SHIFT 22
. h4 S4 i) A$ z) `4 Y6 X: o - #define ITCCHEN_SHIFT 23' F- ]6 o- }0 j6 j, ^1 G- [
2 ]2 z) i6 G7 b* ~1 P/ {& [2 E- static volatile int irqraised1 = 0;
# b1 j; l; \+ ~' D& Z6 v2 _ - static volatile int irqraised2 = 0;! Q( G# W4 A8 N/ ^0 q
- + _1 S% C# s& \( z" E6 b% |
- int edma3_memtomemcpytest_dma(int acnt, int bcnt, int ccnt, int sync_mode, int event_queue);
7 w; a2 _7 d3 z - int edma3_memtomemcpytest_dma_link(int acnt, int bcnt, int ccnt, int sync_mode, int event_queue);
4 ^/ ?) r' v! `: E4 c! |; |4 { - int edma3_memtomemcpytest_dma_chain(int acnt, int bcnt, int ccnt, int sync_mode, int event_queue);
: {% l7 m R4 t/ T7 H1 o
5 k9 W0 i. B7 T0 _+ j- dma_addr_t dmaphyssrc1 = 0;& w O/ K0 Z& D5 F9 m9 a
- dma_addr_t dmaphyssrc2 = 0;1 X4 j u* B7 ?/ ?; U6 F
- dma_addr_t dmaphysdest1 = 0;
# x7 e; k# P% K: F" j( h$ z5 d- \ - dma_addr_t dmaphysdest2 = 0;9 h5 l1 k- Y7 ]. L d5 Z, V" l
c# h6 C& e( g2 l; z- y9 `- char *dmabufsrc1 = NULL;, l" O4 |2 k& x5 {
- char *dmabufsrc2 = NULL;
+ L1 @8 y2 B5 K U - char *dmabufdest1 = NULL;- S, ~+ h7 X+ ~' U1 Y2 @& a: W
- char *dmabufdest2 = NULL;
+ l ]6 n6 @4 v& |2 O4 Z
: J( w$ s2 u& M; Z; z7 }! w, } `' D- static int acnt = 512;
: ?. m' x- W! r! q - static int bcnt = 8;
+ n4 ^" h5 V# a8 T - static int ccnt = 8;; n4 ?4 x# L7 A% W, ~
- $ ], F0 `5 r5 k8 {: K2 M
- module_param(acnt, int, S_IRUGO);
8 Z! z1 k; ]! V - module_param(bcnt, int, S_IRUGO);, [# x4 \3 Q! K- H* `1 [( a% C. T' b
- module_param(ccnt, int, S_IRUGO);
复制代码 ) V6 f: ?, y2 I! ~1 I" R
6 v J0 a9 ^$ b1 y
这是在TI上找到的一个针对Davanci处理器简单的EDMA3驱动程序测试例程的一部分,我在编译的过程中是用7 z0 ]- k4 G) N+ t j
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这个命令来链接库文件进行编译,但是报的错误特别多,我又试着一个函数一个函数往进加,仍然是很多错误。
# Y3 D) O) K D* S9 |4 t# { 我想问一下如何用一个简单的程序来测试一下EDMA3的驱动。
$ m1 I5 Q" p* u# Y6 H- t; r2 |; L! m: y, p4 l8 P) X2 M# [- I4 p: F
- F# ~6 h' r. D- j/ M( g |
|