OpenCores
URL https://opencores.org/ocsvn/or1k/or1k/trunk

Subversion Repositories or1k

[/] [or1k/] [tags/] [before_ORP/] [uclinux/] [uClinux-2.0.x/] [drivers/] [isdn/] [hisax/] [arcofi.c] - Blame information for rev 1765

Details | Compare with Previous | View Log

Line No. Rev Author Line
1 199 simons
/* $Id: arcofi.c,v 1.1.1.1 2001-09-10 07:44:18 simons Exp $
2
 
3
 * arcofi.c   Ansteuerung ARCOFI 2165
4
 *
5
 * Author     Karsten Keil (keil@temic-ech.spacenet.de)
6
 *
7
 *
8
 *
9
 * $Log: not supported by cvs2svn $
10
 * Revision 1.1.1.1  2001/07/02 17:58:32  simons
11
 * Initial revision
12
 *
13
 * Revision 1.1.2.5  1998/09/30 22:20:03  keil
14
 * Cosmetics
15
 *
16
 * Revision 1.1.2.4  1998/09/27 13:05:29  keil
17
 * Apply most changes from 2.1.X (HiSax 3.1)
18
 *
19
 * Revision 1.1.2.3  1998/05/27 18:04:48  keil
20
 * HiSax 3.0
21
 *
22
 * Revision 1.1.2.2  1998/04/11 18:45:13  keil
23
 * New interface
24
 *
25
 * Revision 1.1.2.1  1997/11/15 18:57:37  keil
26
 * ARCOFI 2165 support
27
 *
28
 *
29
 */
30
 
31
#define __NO_VERSION__
32
#include "hisax.h"
33
#include "isdnl1.h"
34
#include "isac.h"
35
 
36
int
37
send_arcofi(struct IsdnCardState *cs, const u_char *msg, int bc, int receive) {
38
        u_char val;
39
        long flags;
40
        int cnt=30;
41
 
42
        cs->mon_txp = 0;
43
        cs->mon_txc = msg[0];
44
        memcpy(cs->mon_tx, &msg[1], cs->mon_txc);
45
        switch(bc) {
46
                case 0: break;
47
                case 1: cs->mon_tx[1] |= 0x40;
48
                        break;
49
                default: break;
50
        }
51
        cs->mocr &= 0x0f;
52
        cs->mocr |= 0xa0;
53
        test_and_clear_bit(HW_MON1_TX_END, &cs->HW_Flags);
54
        if (receive)
55
                test_and_clear_bit(HW_MON1_RX_END, &cs->HW_Flags);
56
        cs->writeisac(cs, ISAC_MOCR, cs->mocr);
57
        val = cs->readisac(cs, ISAC_MOSR);
58
        cs->writeisac(cs, ISAC_MOX1, cs->mon_tx[cs->mon_txp++]);
59
        cs->mocr |= 0x10;
60
        cs->writeisac(cs, ISAC_MOCR, cs->mocr);
61
        save_flags(flags);
62
        sti();
63
        while (cnt && !test_bit(HW_MON1_TX_END, &cs->HW_Flags)) {
64
                cnt--;
65
                udelay(500);
66
        }
67
        if (receive) {
68
                while (cnt && !test_bit(HW_MON1_RX_END, &cs->HW_Flags)) {
69
                        cnt--;
70
                        udelay(500);
71
                }
72
        }
73
        restore_flags(flags);
74
        if (cnt <= 0) {
75
                printk(KERN_WARNING"HiSax arcofi monitor timed out\n");
76
                debugl1(cs, "HiSax arcofi monitor timed out");
77
        }
78
        return(cnt);
79
}

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.