|
|
本帖最后由 yyj 于 2018-1-30 11:01 编辑 # s# @' Z9 q& ~$ o
- [code]EDMA sample test application. Y6 i* L/ x0 ]4 A& b3 z! {# n
- /*
+ v9 M! r6 o( a$ Y" p- x - * edma_test.c
% K( ?3 U4 u! }5 Q - *$ m, a. A; Y4 S! C" Q- X& }
- * brief EDMA3 Test Application
% [# e. G7 H8 j+ a* q5 W Q - *
0 ^0 S; Q( z A" T: S - * This file contains EDMA3 Test code.
0 R" P& X0 H; ^3 O0 J. @9 X; j) @* l1 x - *
" j! K" k9 _- I) Y! x! F4 k - * NOTE: THIS FILE IS PROVIDED ONLY FOR INITIAL DEMO RELEASE AND MAY BE1 s9 w9 Y# R2 C) j. t( D( [/ [) R0 |
- * REMOVED AFTER THE DEMO OR THE CONTENTS OF THIS FILE ARE SUBJECT; b/ e# [, B5 e& @5 J, v4 A1 Z
- * TO CHANGE.
6 z7 p6 M1 I$ U - *, f$ w X- \+ }7 ~' @& H
- * Copyright (C) 2011 Texas Instruments Incorporated - http://www.ti.com/5 u1 W u* d* v2 ?) R X# ?
- *
: V( C& I: Y: _0 m, v/ ^ - * This program is free software; you can redistribute it and/or
! q; \5 R- x6 ~4 m - * modify it under the terms of the GNU General Public License as( Q6 u9 E/ u, X0 F
- * published by the Free Software Foundation version 2.
" S9 g% r5 K, h - *
8 ^. p! @. q6 f& M5 g - * This program is distributed "as is" WITHOUT ANY WARRANTY of any: O$ {# }) r8 A: K( t* M; p% d
- * kind, whether express or implied; without even the implied warranty
0 w1 [6 [( }+ ~- x, A j) e$ i - * of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the: u6 t$ `3 b* w, ^" m# N; [
- * GNU General Public License for more details.7 ]2 w7 r& C" s R: K6 h8 m! E! M
- */
4 O! b: G s9 x1 N* z6 t, h
! K0 _" M2 ?5 P) F3 x' T- #include <linux/module.h>3 W) v' [+ p# a
- #include <linux/init.h>
: l! M$ F+ G. ^, x% O9 e- ^5 T8 v - #include <linux/errno.h>
# P& l- |+ q) I* T' L# o - #include <linux/types.h>
1 N" `$ n+ X4 l1 H - #include <linux/interrupt.h># y: T, P8 w* l
- #include <asm/io.h>
8 V# ^) m" k6 b$ b2 p3 d - #include <linux/moduleparam.h>0 W3 a$ x* w/ @( r
- #include <linux/sysctl.h>
6 ]+ o2 p t. k - #include <linux/mm.h>
3 w! o8 i* v1 }- [0 Z - #include <linux/dma-mapping.h>
0 X! m; r' u9 O# ]7 M$ [ - - B7 e* @' R$ U
- #include <mach/memory.h>
: K5 A5 W8 n3 r# {8 N, z* A - #include <mach/hardware.h>$ Z) C" N2 W" L
- #include <mach/irqs.h>
# R+ V4 p$ @" Z - #include <asm/hardware/edma.h>% H9 o3 }' x! ]! g x6 w
6 T$ J" a- X- H' N( T- #undef EDMA3_DEBUG
0 { {0 k7 |9 i1 b - /*#define EDMA3_DEBUG*/, T/ \0 Z8 q. s5 ^# z2 _, u5 [
- ) l. C+ K& H: p+ G; T
- #ifdef EDMA3_DEBUG P5 c" L4 V3 t6 M6 I5 V
- #define DMA_PRINTK(ARGS...) printk(KERN_INFO "<%s>: ",__FUNCTION__);printk(ARGS)
5 S7 P L( k4 o+ S+ D - #define DMA_FN_IN printk(KERN_INFO "[%s]: start\n", __FUNCTION__)
/ N$ V7 D+ H2 ]- n+ H. Q! p* c+ l - #define DMA_FN_OUT printk(KERN_INFO "[%s]: end\n",__FUNCTION__)6 M4 S) b2 L( t( H' ?5 f4 A k2 }* I
- #else, Z$ }! ?. R7 ^7 y
- #define DMA_PRINTK( x... )
/ H/ x4 x4 u8 A4 F9 W) `8 G, b - #define DMA_FN_IN
9 ^9 U1 y- Y& ]0 ]* q4 Y3 v) | - #define DMA_FN_OUT. }. n, x/ m2 [; Y. @/ V
- #endif
2 ?% c- u! u( D - 9 r; V ]. w7 F J, x$ i5 C3 i
- #define MAX_DMA_TRANSFER_IN_BYTES (32768)0 i' k. {4 y" e- D% @4 z2 _
- #define STATIC_SHIFT 3. C. ?+ i n2 J1 m8 S) u' A
- #define TCINTEN_SHIFT 20, y1 J- s+ X/ J G% _$ T9 y' n
- #define ITCINTEN_SHIFT 212 H2 x& R: f0 q# l0 o: R0 H
- #define TCCHEN_SHIFT 22
' l7 {- Y S: S9 t- g - #define ITCCHEN_SHIFT 23' l2 v$ B; T: P( ^$ \/ H5 E; }
4 _$ X. N0 O0 g/ j T& V1 f- static volatile int irqraised1 = 0;, b6 g: j+ h6 _0 X- X; t f" Q
- static volatile int irqraised2 = 0;) j8 V3 F, S& R+ S! u. \$ u
- 0 M/ l( x; L; ^$ e% N
- int edma3_memtomemcpytest_dma(int acnt, int bcnt, int ccnt, int sync_mode, int event_queue);: Q& f% x! r& g
- int edma3_memtomemcpytest_dma_link(int acnt, int bcnt, int ccnt, int sync_mode, int event_queue);
% q+ N7 i2 n# m) V' p' f# `6 s! I. e - int edma3_memtomemcpytest_dma_chain(int acnt, int bcnt, int ccnt, int sync_mode, int event_queue);
+ C! `% ]0 E+ w6 w+ \ - 9 _3 ^) u! i+ Z: O. E4 x8 u8 l o
- dma_addr_t dmaphyssrc1 = 0;
* }3 g: U! t' D2 d2 p: ~ - dma_addr_t dmaphyssrc2 = 0;
; E" e& t& Q- ?1 Q4 t; o$ R - dma_addr_t dmaphysdest1 = 0;
4 i0 _# x- f# Q5 q L4 { z; e! I4 W - dma_addr_t dmaphysdest2 = 0;6 K: A6 k3 {2 ?- _4 Z* ?
- ( \/ N v. c$ W% ]+ A4 w- H
- char *dmabufsrc1 = NULL;
9 p- ~) M. W& q& R& D - char *dmabufsrc2 = NULL;4 T/ U6 I1 d% `% U
- char *dmabufdest1 = NULL;
, v" k, K. G2 o/ W - char *dmabufdest2 = NULL; s. V# D$ _# S. d: u
% p3 u4 J) I) d" k/ k3 D) K- static int acnt = 512;
% Q: h* X7 w7 {5 } - static int bcnt = 8;
, I# S: K3 ?# d+ Y - static int ccnt = 8;
1 I q* E+ n! g) D
. f9 p! [4 h& Z p- module_param(acnt, int, S_IRUGO);
" w* K. F( G3 d% k4 l; q9 u - module_param(bcnt, int, S_IRUGO);
$ X g; [2 g9 M5 T; ~ - module_param(ccnt, int, S_IRUGO);
复制代码
0 I- L) |- q% l
2 D3 L f% B1 ]! j" ` 这是在TI上找到的一个针对Davanci处理器简单的EDMA3驱动程序测试例程的一部分,我在编译的过程中是用
9 d. g+ ^, ?' U' U* c3 s7 [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这个命令来链接库文件进行编译,但是报的错误特别多,我又试着一个函数一个函数往进加,仍然是很多错误。
: B0 p( s: L7 I' u/ Z) [- y 我想问一下如何用一个简单的程序来测试一下EDMA3的驱动。
! V& ~; l) \/ R. h/ F
3 s6 W* Q- K4 C# i7 ~3 p# N4 b( W1 g
|
|