1*91e1e26aSAlexander Pyhalov /*
2*91e1e26aSAlexander Pyhalov * CDDL HEADER START
3*91e1e26aSAlexander Pyhalov *
4*91e1e26aSAlexander Pyhalov * The contents of this file are subject to the terms of the
5*91e1e26aSAlexander Pyhalov * Common Development and Distribution License (the "License").
6*91e1e26aSAlexander Pyhalov * You may not use this file except in compliance with the License.
7*91e1e26aSAlexander Pyhalov *
8*91e1e26aSAlexander Pyhalov * You can obtain a copy of the license at src/OPENSOLARIS.LICENSE
9*91e1e26aSAlexander Pyhalov * or http://www.opensolaris.org/os/licensing.
10*91e1e26aSAlexander Pyhalov * See the License for the specific language governing permissions
11*91e1e26aSAlexander Pyhalov * and limitations under the License.
12*91e1e26aSAlexander Pyhalov *
13*91e1e26aSAlexander Pyhalov * When distributing Covered Code, include this CDDL HEADER in each
14*91e1e26aSAlexander Pyhalov * file and include the License file at src/OPENSOLARIS.LICENSE.
15*91e1e26aSAlexander Pyhalov * If applicable, add the following below this CDDL HEADER, with the
16*91e1e26aSAlexander Pyhalov * fields enclosed by brackets "[]" replaced with your own identifying
17*91e1e26aSAlexander Pyhalov * information: Portions Copyright [yyyy] [name of copyright owner]
18*91e1e26aSAlexander Pyhalov *
19*91e1e26aSAlexander Pyhalov * CDDL HEADER END
20*91e1e26aSAlexander Pyhalov */
21*91e1e26aSAlexander Pyhalov /* $Id: c2p.c,v 1.12 1997/10/31 16:16:56 binz Exp $ SMI: ALE */
22*91e1e26aSAlexander Pyhalov
23*91e1e26aSAlexander Pyhalov /*
24*91e1e26aSAlexander Pyhalov * Copyright 2006 Sun Microsystems, Inc. All rights reserved.
25*91e1e26aSAlexander Pyhalov * Use is subject to license terms.
26*91e1e26aSAlexander Pyhalov */
27*91e1e26aSAlexander Pyhalov
28*91e1e26aSAlexander Pyhalov /*
29*91e1e26aSAlexander Pyhalov * Convert 2 byte completion code to
30*91e1e26aSAlexander Pyhalov * 2 byte combination code
31*91e1e26aSAlexander Pyhalov * 1) find the sequential No. of initial and middle sounds.
32*91e1e26aSAlexander Pyhalov * 2) decide the displacement of final sound from the starting point.
33*91e1e26aSAlexander Pyhalov * 3) combine each sounds into combination code.
34*91e1e26aSAlexander Pyhalov */
35*91e1e26aSAlexander Pyhalov
36*91e1e26aSAlexander Pyhalov #include <stdio.h>
37*91e1e26aSAlexander Pyhalov #include "kdefs.h"
38*91e1e26aSAlexander Pyhalov #include "ktable.h"
39*91e1e26aSAlexander Pyhalov
40*91e1e26aSAlexander Pyhalov #define SKIP 0xa1 + 0xff - 0xfe
41*91e1e26aSAlexander Pyhalov
42*91e1e26aSAlexander Pyhalov #define CI_CNT 19 - 1
43*91e1e26aSAlexander Pyhalov #define V_CNT 21 - 1
44*91e1e26aSAlexander Pyhalov
45*91e1e26aSAlexander Pyhalov /* KS C 5601-1986 */
c2p(comp2)46*91e1e26aSAlexander Pyhalov KCHAR c2p(comp2)
47*91e1e26aSAlexander Pyhalov KCHAR comp2;
48*91e1e26aSAlexander Pyhalov {
49*91e1e26aSAlexander Pyhalov
50*91e1e26aSAlexander Pyhalov KCHAR comb2;
51*91e1e26aSAlexander Pyhalov short Ci_val; /* initial sound */
52*91e1e26aSAlexander Pyhalov short V_val ; /* middle sound */
53*91e1e26aSAlexander Pyhalov short Cf_val; /* final sound */
54*91e1e26aSAlexander Pyhalov short mask ;
55*91e1e26aSAlexander Pyhalov short high = CI_CNT ;
56*91e1e26aSAlexander Pyhalov short low = 0 ;
57*91e1e26aSAlexander Pyhalov
58*91e1e26aSAlexander Pyhalov int disp,cnt;
59*91e1e26aSAlexander Pyhalov
60*91e1e26aSAlexander Pyhalov long Cfbit ;
61*91e1e26aSAlexander Pyhalov
62*91e1e26aSAlexander Pyhalov /*
63*91e1e26aSAlexander Pyhalov * Find initial sound (Ci_val) and
64*91e1e26aSAlexander Pyhalov * middle sound (V_val )
65*91e1e26aSAlexander Pyhalov * which make the starting point for 'comp2'.
66*91e1e26aSAlexander Pyhalov */
67*91e1e26aSAlexander Pyhalov
68*91e1e26aSAlexander Pyhalov for (;;) {
69*91e1e26aSAlexander Pyhalov Ci_val = (low + high) / 2 ;
70*91e1e26aSAlexander Pyhalov if (low >= high)
71*91e1e26aSAlexander Pyhalov break ;
72*91e1e26aSAlexander Pyhalov if (comp2 < cmp_srchtbl[Ci_val][0])
73*91e1e26aSAlexander Pyhalov high = Ci_val - 1 ;
74*91e1e26aSAlexander Pyhalov else if (comp2 < cmp_srchtbl[Ci_val+1][0])
75*91e1e26aSAlexander Pyhalov break ;
76*91e1e26aSAlexander Pyhalov else low = Ci_val + 1 ;
77*91e1e26aSAlexander Pyhalov }
78*91e1e26aSAlexander Pyhalov
79*91e1e26aSAlexander Pyhalov V_val = 1;
80*91e1e26aSAlexander Pyhalov while(1) {
81*91e1e26aSAlexander Pyhalov if (comp2 < cmp_srchtbl[Ci_val][V_val]) {
82*91e1e26aSAlexander Pyhalov while(cmp_srchtbl[Ci_val][--V_val] == 0)
83*91e1e26aSAlexander Pyhalov ;
84*91e1e26aSAlexander Pyhalov break;
85*91e1e26aSAlexander Pyhalov }else if (V_val == V_CNT)
86*91e1e26aSAlexander Pyhalov break ;
87*91e1e26aSAlexander Pyhalov V_val++;
88*91e1e26aSAlexander Pyhalov }
89*91e1e26aSAlexander Pyhalov
90*91e1e26aSAlexander Pyhalov /* Find displacement (temporary final sound value) */
91*91e1e26aSAlexander Pyhalov
92*91e1e26aSAlexander Pyhalov disp = comp2 - cmp_srchtbl[Ci_val][V_val] ;
93*91e1e26aSAlexander Pyhalov mask = cmp_srchtbl[Ci_val][V_val] & BYTE_MASK ;
94*91e1e26aSAlexander Pyhalov
95*91e1e26aSAlexander Pyhalov if ((mask + disp) > 0xfe)
96*91e1e26aSAlexander Pyhalov disp -= SKIP ;
97*91e1e26aSAlexander Pyhalov
98*91e1e26aSAlexander Pyhalov /* Find the value of final sound */
99*91e1e26aSAlexander Pyhalov
100*91e1e26aSAlexander Pyhalov Cfbit = cmp_bitmap[Ci_val][V_val] ;
101*91e1e26aSAlexander Pyhalov for (cnt = -1 , Cf_val = -1; cnt < disp; Cf_val++)
102*91e1e26aSAlexander Pyhalov {
103*91e1e26aSAlexander Pyhalov if (Cfbit & BIT_MASK)
104*91e1e26aSAlexander Pyhalov cnt++ ;
105*91e1e26aSAlexander Pyhalov Cfbit >>= 1 ;
106*91e1e26aSAlexander Pyhalov }
107*91e1e26aSAlexander Pyhalov
108*91e1e26aSAlexander Pyhalov /* make 2 byte combination code */
109*91e1e26aSAlexander Pyhalov
110*91e1e26aSAlexander Pyhalov comb2 = (unsigned int) (Ci_val + 0x0a) ;
111*91e1e26aSAlexander Pyhalov comb2 = (comb2 << 5) | (V_val + (V_val + 1)/3 + 2) ;
112*91e1e26aSAlexander Pyhalov comb2 = (comb2 << 5) | Cf_val ;
113*91e1e26aSAlexander Pyhalov
114*91e1e26aSAlexander Pyhalov return(comb2 | 0x8000) ;
115*91e1e26aSAlexander Pyhalov }
116*91e1e26aSAlexander Pyhalov
117*91e1e26aSAlexander Pyhalov /* KS C 5601-1992 */
c2j(comp2)118*91e1e26aSAlexander Pyhalov KCHAR c2j(comp2)
119*91e1e26aSAlexander Pyhalov KCHAR comp2;
120*91e1e26aSAlexander Pyhalov {
121*91e1e26aSAlexander Pyhalov
122*91e1e26aSAlexander Pyhalov KCHAR comb2;
123*91e1e26aSAlexander Pyhalov short Ci_val; /* initial sound */
124*91e1e26aSAlexander Pyhalov short V_val ; /* middle sound */
125*91e1e26aSAlexander Pyhalov short Cf_val; /* final sound */
126*91e1e26aSAlexander Pyhalov short mask ;
127*91e1e26aSAlexander Pyhalov short high = CI_CNT ;
128*91e1e26aSAlexander Pyhalov short low = 0 ;
129*91e1e26aSAlexander Pyhalov
130*91e1e26aSAlexander Pyhalov int disp,cnt;
131*91e1e26aSAlexander Pyhalov
132*91e1e26aSAlexander Pyhalov long Cfbit ;
133*91e1e26aSAlexander Pyhalov
134*91e1e26aSAlexander Pyhalov /*
135*91e1e26aSAlexander Pyhalov * Find initial sound (Ci_val) and
136*91e1e26aSAlexander Pyhalov * middle sound (V_val )
137*91e1e26aSAlexander Pyhalov * which make the starting point for 'comp2'.
138*91e1e26aSAlexander Pyhalov */
139*91e1e26aSAlexander Pyhalov
140*91e1e26aSAlexander Pyhalov for (;;) {
141*91e1e26aSAlexander Pyhalov Ci_val = (low + high) / 2 ;
142*91e1e26aSAlexander Pyhalov if (low >= high)
143*91e1e26aSAlexander Pyhalov break ;
144*91e1e26aSAlexander Pyhalov if (comp2 < cmp_srchtbl[Ci_val][0])
145*91e1e26aSAlexander Pyhalov high = Ci_val - 1 ;
146*91e1e26aSAlexander Pyhalov else if (comp2 < cmp_srchtbl[Ci_val+1][0])
147*91e1e26aSAlexander Pyhalov break ;
148*91e1e26aSAlexander Pyhalov else low = Ci_val + 1 ;
149*91e1e26aSAlexander Pyhalov }
150*91e1e26aSAlexander Pyhalov
151*91e1e26aSAlexander Pyhalov V_val = 1;
152*91e1e26aSAlexander Pyhalov while(1) {
153*91e1e26aSAlexander Pyhalov if (comp2 < cmp_srchtbl[Ci_val][V_val]) {
154*91e1e26aSAlexander Pyhalov while(cmp_srchtbl[Ci_val][--V_val] == 0)
155*91e1e26aSAlexander Pyhalov ;
156*91e1e26aSAlexander Pyhalov break;
157*91e1e26aSAlexander Pyhalov }else if (V_val == V_CNT)
158*91e1e26aSAlexander Pyhalov break ;
159*91e1e26aSAlexander Pyhalov V_val++;
160*91e1e26aSAlexander Pyhalov }
161*91e1e26aSAlexander Pyhalov
162*91e1e26aSAlexander Pyhalov /* Find displacement (temporary final sound value) */
163*91e1e26aSAlexander Pyhalov
164*91e1e26aSAlexander Pyhalov disp = comp2 - cmp_srchtbl[Ci_val][V_val] ;
165*91e1e26aSAlexander Pyhalov mask = cmp_srchtbl[Ci_val][V_val] & BYTE_MASK ;
166*91e1e26aSAlexander Pyhalov
167*91e1e26aSAlexander Pyhalov if ((mask + disp) > 0xfe)
168*91e1e26aSAlexander Pyhalov disp -= SKIP ;
169*91e1e26aSAlexander Pyhalov
170*91e1e26aSAlexander Pyhalov /* Find the value of final sound */
171*91e1e26aSAlexander Pyhalov
172*91e1e26aSAlexander Pyhalov Cfbit = cmp_bitmap[Ci_val][V_val] ;
173*91e1e26aSAlexander Pyhalov for (cnt = -1 , Cf_val = -1; cnt < disp; Cf_val++)
174*91e1e26aSAlexander Pyhalov {
175*91e1e26aSAlexander Pyhalov if (Cfbit & BIT_MASK)
176*91e1e26aSAlexander Pyhalov cnt++ ;
177*91e1e26aSAlexander Pyhalov Cfbit >>= 1 ;
178*91e1e26aSAlexander Pyhalov }
179*91e1e26aSAlexander Pyhalov
180*91e1e26aSAlexander Pyhalov /* make 2 byte combination code */
181*91e1e26aSAlexander Pyhalov
182*91e1e26aSAlexander Pyhalov comb2 = (unsigned int) (Ci_val + 2);
183*91e1e26aSAlexander Pyhalov comb2 = (comb2 << 5) | (V_val + (V_val + 1) / 6 * 2 + 3);
184*91e1e26aSAlexander Pyhalov comb2 = (comb2 << 5) | (Cf_val + (Cf_val) / 18);
185*91e1e26aSAlexander Pyhalov
186*91e1e26aSAlexander Pyhalov
187*91e1e26aSAlexander Pyhalov return(comb2 | 0x8000) ;
188*91e1e26aSAlexander Pyhalov }
189*91e1e26aSAlexander Pyhalov
190*91e1e26aSAlexander Pyhalov #ifdef TESTPRINT
main()191*91e1e26aSAlexander Pyhalov main()
192*91e1e26aSAlexander Pyhalov {
193*91e1e26aSAlexander Pyhalov unsigned short comp2, comb2;
194*91e1e26aSAlexander Pyhalov int i,j;
195*91e1e26aSAlexander Pyhalov
196*91e1e26aSAlexander Pyhalov printf("\ncompletion code combination code\n");
197*91e1e26aSAlexander Pyhalov for (i=0xb0;i<=0xc8;i++) {
198*91e1e26aSAlexander Pyhalov for (j=0xa1;j<=0xfe;j++) {
199*91e1e26aSAlexander Pyhalov comp2 = i<<8|j;
200*91e1e26aSAlexander Pyhalov comb2 = comptopack(comp2);
201*91e1e26aSAlexander Pyhalov printf(" %4x %4x\n", comp2,comb2);
202*91e1e26aSAlexander Pyhalov }
203*91e1e26aSAlexander Pyhalov }
204*91e1e26aSAlexander Pyhalov }
205*91e1e26aSAlexander Pyhalov #endif
206