source: drsdaq/VME/struck/sis1100/V2.02/dev/pci/sis1100_synch_handler.c@ 23

Last change on this file since 23 was 22, checked in by ogrimm, 16 years ago
First commit of drsdaq program
File size: 2.7 KB
Line 
1/* $ZEL: sis1100_synch_handler.c,v 1.4 2004/05/27 23:10:35 wuestner Exp $ */
2
3/*
4 * Copyright (c) 2003-2004
5 * Peter Wuestner. All rights reserved.
6 *
7 * Redistribution and use in source and binary forms, with or without
8 * modification, are permitted provided that the following conditions
9 * are met:
10 * 1. Redistributions of source code must retain the above copyright
11 * notice, this list of conditions, and the following disclaimer.
12 * 2. Redistributions in binary form must reproduce the above copyright
13 * notice, this list of conditions and the following disclaimer in the
14 * documentation and/or other materials provided with the distribution.
15 *
16 * THIS SOFTWARE IS PROVIDED BY THE AUTHORS AND CONTRIBUTORS ``AS IS'' AND
17 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
18 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
19 * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
20 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
21 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
22 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
23 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
24 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
25 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
26 * SUCH DAMAGE.
27 */
28
29#include "sis1100_sc.h"
30
31/*
32 * This function ist started by a timer (sc->link_up_timer) 1 second after
33 * the optical link state has changed.
34 * It is executed in irq context!
35 * The awakened kernel thread (sis1100_irq_thread) calls
36 * sis1100_synch_handler below
37 */
38void
39#ifdef __NetBSD__
40sis1100_link_up_handler(void* data)
41#elif __linux__
42sis1100_link_up_handler(unsigned long data)
43#endif
44{
45 struct sis1100_softc* sc=(struct sis1100_softc*)data;
46 DECLARE_SPINLOCKFLAGS(flags)
47
48 SPIN_LOCK_IRQSAVE(sc->handlercommand.lock, flags);
49 sc->handlercommand.command|=handlercomm_synch;
50 SPIN_UNLOCK_IRQRESTORE(sc->handlercommand.lock, flags);
51#ifdef __NetBSD__
52 wakeup(&sc->handler_wait);
53#elif __linux__
54 wake_up(&sc->handler_wait);
55#endif
56}
57
58/*
59 * this is called from _sis1100_irq_thread
60 */
61void
62sis1100_synch_handler(struct sis1100_softc* sc)
63{
64 u_int32_t status;
65
66 /* pINFO(sc, "synch_handler called"); */
67 sis1100_enable_irq(sc, 0, irq_synch_chg|irq_reset_req|irq_prot_l_err);
68 status=sis1100readreg(sc, sr);
69
70 if ((status&sr_synch)==sr_synch) {
71 if (sc->remote_hw==sis1100_hw_invalid) {
72 sis1100_init_remote(sc);
73 } else {
74 pINFO(sc, "synch_handler: remote_hw=%d (not hw_invalid)",
75 sc->remote_hw);
76 sis1100_init_remote(sc);
77 }
78 }
79}
Note: See TracBrowser for help on using the repository browser.