Expand PMF_FN_* macros.
[netbsd-mini2440.git] / sys / dev / microcode / siop / oosiop.ss
blobeb60bd755215ecf5a8f12df6802ecb7064ba8d87
1 ;       $NetBSD$
4 ; Copyright (c) 2001 Shuichiro URATA.  All rights reserved.
6 ; Redistribution and use in source and binary forms, with or without
7 ; modification, are permitted provided that the following conditions
8 ; are met:
9 ; 1. Redistributions of source code must retain the above copyright
10 ;    notice, this list of conditions and the following disclaimer.
11 ; 2. Redistributions in binary form must reproduce the above copyright
12 ;    notice, this list of conditions and the following disclaimer in the
13 ;    documentation and/or other materials provided with the distribution.
14 ; 3. The name of the author may not be used to endorse or promote products
15 ;    derived from this software without specific prior written permission.
17 ; THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
18 ; IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
19 ; OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
20 ; IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
21 ; INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
22 ; NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
23 ; DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
24 ; THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
25 ; (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
26 ; THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
29 ; NCR 53c700 script
32 ARCH 700
34 ; interrupt codes
35 ABSOLUTE int_done       = 0xbeef0000
36 ABSOLUTE int_msgin      = 0xbeef0001
37 ABSOLUTE int_extmsg     = 0xbeef0002
38 ABSOLUTE int_resel      = 0xbeef0003
39 ABSOLUTE int_res_id     = 0xbeef0004
40 ABSOLUTE int_resfail    = 0xbeef0005
41 ABSOLUTE int_disc       = 0xbeef0006
42 ABSOLUTE int_err        = 0xdeadbeef
44 ; patch entries
45 ENTRY p_resel_msgin_move
46 ENTRY p_select
47 ENTRY p_datain_jump
48 ENTRY p_dataout_jump
49 ENTRY p_msgin_move
50 ENTRY p_msgout_move
51 ENTRY p_cmdout_move
52 ENTRY p_status_move
53 ENTRY p_extmsglen_move
54 ENTRY p_extmsgin_move
57 PROC  oosiop_script:
59 ENTRY wait_reselect
60 wait_reselect:
61         WAIT RESELECT REL(reselect_fail)
62         INT int_resel
63 reselect_fail:
64         INT int_resfail
66 ENTRY wait_resel_identify
67 wait_resel_identify:
68         INT int_err, WHEN NOT MSG_IN
69 p_resel_msgin_move:
70         MOVE 0, 0, WHEN MSG_IN
71         INT int_res_id
73 ENTRY start_select
74 start_select:
75 p_select:
76         SELECT ATN 0, REL(wait_reselect)
78 ENTRY phasedispatch
79 phasedispatch:
80         JUMP REL(msgin), WHEN MSG_IN
81         JUMP REL(msgout), WHEN MSG_OUT
82         JUMP REL(status), WHEN STATUS
83         JUMP REL(cmdout), WHEN CMD
84 p_datain_jump:
85         JUMP 0, WHEN DATA_IN
86 p_dataout_jump:
87         JUMP 0, WHEN DATA_OUT
88         INT int_err
90 msgin:
91         CLEAR ATN
92 p_msgin_move:
93         MOVE 0, 0, WHEN MSG_IN
94         JUMP REL(complete), IF 0x00
95         JUMP REL(extmsgsetup), IF 0x01
96         JUMP REL(disconnect), IF 0x04
97         INT int_msgin
99 ENTRY ack_msgin
100 ack_msgin:
101         CLEAR ACK
102         JUMP REL(phasedispatch)
104 ENTRY sendmsg
105 sendmsg:
106         SET ATN
107         CLEAR ACK
108 msgout:
109 p_msgout_move:
110         MOVE 0, 0, WHEN MSG_OUT
111         CLEAR ATN
112         JUMP REL(phasedispatch)
114 cmdout:
115         CLEAR ATN
116 p_cmdout_move:
117         MOVE 0, 0, WHEN CMD
118         JUMP REL(phasedispatch)
120 status:
121 p_status_move:
122         MOVE 0, 0, WHEN STATUS
123         JUMP REL(phasedispatch)
125 disconnect:
126         CLEAR ACK
127         WAIT DISCONNECT
128         INT int_disc
130 complete:
131         CLEAR ACK
132         WAIT DISCONNECT
133         INT int_done
135 ; receive extended message length
136 extmsgsetup:
137         CLEAR ACK
138         INT int_err, IF NOT MSG_IN
139 p_extmsglen_move:
140         MOVE 0, 0, WHEN MSG_IN
141         INT int_extmsg
143 ; receive extended message
144 ENTRY rcv_extmsg
145 rcv_extmsg:
146         CLEAR ACK
147         INT int_err, IF NOT MSG_IN
148 p_extmsgin_move:
149         MOVE 0, 0, WHEN MSG_IN
150         INT int_msgin