xref: /freebsd/sys/contrib/openzfs/module/unicode/u8_textprep.c (revision 6132212808e8dccedc9e5d85fea4390c2f38059a)
1 /*
2  * CDDL HEADER START
3  *
4  * The contents of this file are subject to the terms of the
5  * Common Development and Distribution License (the "License").
6  * You may not use this file except in compliance with the License.
7  *
8  * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
9  * or http://www.opensolaris.org/os/licensing.
10  * See the License for the specific language governing permissions
11  * and limitations under the License.
12  *
13  * When distributing Covered Code, include this CDDL HEADER in each
14  * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
15  * If applicable, add the following below this CDDL HEADER, with the
16  * fields enclosed by brackets "[]" replaced with your own identifying
17  * information: Portions Copyright [yyyy] [name of copyright owner]
18  *
19  * CDDL HEADER END
20  */
21 /*
22  * Copyright 2008 Sun Microsystems, Inc.  All rights reserved.
23  * Use is subject to license terms.
24  */
25 
26 
27 
28 
29 /*
30  * UTF-8 text preparation functions (PSARC/2007/149, PSARC/2007/458).
31  *
32  * Man pages: u8_textprep_open(9F), u8_textprep_buf(9F), u8_textprep_close(9F),
33  * u8_textprep_str(9F), u8_strcmp(9F), and u8_validate(9F). See also
34  * the section 3C man pages.
35  * Interface stability: Committed.
36  */
37 
38 #include <sys/types.h>
39 #include <sys/strings.h>
40 #include <sys/param.h>
41 #include <sys/sysmacros.h>
42 #include <sys/debug.h>
43 #include <sys/kmem.h>
44 #include <sys/sunddi.h>
45 #include <sys/u8_textprep.h>
46 #include <sys/byteorder.h>
47 #include <sys/errno.h>
48 #include <sys/u8_textprep_data.h>
49 #include <sys/mod.h>
50 
51 /* The maximum possible number of bytes in a UTF-8 character. */
52 #define	U8_MB_CUR_MAX			(4)
53 
54 /*
55  * The maximum number of bytes needed for a UTF-8 character to cover
56  * U+0000 - U+FFFF, i.e., the coding space of now deprecated UCS-2.
57  */
58 #define	U8_MAX_BYTES_UCS2		(3)
59 
60 /* The maximum possible number of bytes in a Stream-Safe Text. */
61 #define	U8_STREAM_SAFE_TEXT_MAX		(128)
62 
63 /*
64  * The maximum number of characters in a combining/conjoining sequence and
65  * the actual upperbound limit of a combining/conjoining sequence.
66  */
67 #define	U8_MAX_CHARS_A_SEQ		(32)
68 #define	U8_UPPER_LIMIT_IN_A_SEQ		(31)
69 
70 /* The combining class value for Starter. */
71 #define	U8_COMBINING_CLASS_STARTER	(0)
72 
73 /*
74  * Some Hangul related macros at below.
75  *
76  * The first and the last of Hangul syllables, Hangul Jamo Leading consonants,
77  * Vowels, and optional Trailing consonants in Unicode scalar values.
78  *
79  * Please be noted that the U8_HANGUL_JAMO_T_FIRST is 0x11A7 at below not
80  * the actual U+11A8. This is due to that the trailing consonant is optional
81  * and thus we are doing a pre-calculation of subtracting one.
82  *
83  * Each of 19 modern leading consonants has total 588 possible syllables since
84  * Hangul has 21 modern vowels and 27 modern trailing consonants plus 1 for
85  * no trailing consonant case, i.e., 21 x 28 = 588.
86  *
87  * We also have bunch of Hangul related macros at below. Please bear in mind
88  * that the U8_HANGUL_JAMO_1ST_BYTE can be used to check whether it is
89  * a Hangul Jamo or not but the value does not guarantee that it is a Hangul
90  * Jamo; it just guarantee that it will be most likely.
91  */
92 #define	U8_HANGUL_SYL_FIRST		(0xAC00U)
93 #define	U8_HANGUL_SYL_LAST		(0xD7A3U)
94 
95 #define	U8_HANGUL_JAMO_L_FIRST		(0x1100U)
96 #define	U8_HANGUL_JAMO_L_LAST		(0x1112U)
97 #define	U8_HANGUL_JAMO_V_FIRST		(0x1161U)
98 #define	U8_HANGUL_JAMO_V_LAST		(0x1175U)
99 #define	U8_HANGUL_JAMO_T_FIRST		(0x11A7U)
100 #define	U8_HANGUL_JAMO_T_LAST		(0x11C2U)
101 
102 #define	U8_HANGUL_V_COUNT		(21)
103 #define	U8_HANGUL_VT_COUNT		(588)
104 #define	U8_HANGUL_T_COUNT		(28)
105 
106 #define	U8_HANGUL_JAMO_1ST_BYTE		(0xE1U)
107 
108 #define	U8_SAVE_HANGUL_AS_UTF8(s, i, j, k, b) \
109 	(s)[(i)] = (uchar_t)(0xE0U | ((uint32_t)(b) & 0xF000U) >> 12); \
110 	(s)[(j)] = (uchar_t)(0x80U | ((uint32_t)(b) & 0x0FC0U) >> 6); \
111 	(s)[(k)] = (uchar_t)(0x80U | ((uint32_t)(b) & 0x003FU));
112 
113 #define	U8_HANGUL_JAMO_L(u) \
114 	((u) >= U8_HANGUL_JAMO_L_FIRST && (u) <= U8_HANGUL_JAMO_L_LAST)
115 
116 #define	U8_HANGUL_JAMO_V(u) \
117 	((u) >= U8_HANGUL_JAMO_V_FIRST && (u) <= U8_HANGUL_JAMO_V_LAST)
118 
119 #define	U8_HANGUL_JAMO_T(u) \
120 	((u) > U8_HANGUL_JAMO_T_FIRST && (u) <= U8_HANGUL_JAMO_T_LAST)
121 
122 #define	U8_HANGUL_JAMO(u) \
123 	((u) >= U8_HANGUL_JAMO_L_FIRST && (u) <= U8_HANGUL_JAMO_T_LAST)
124 
125 #define	U8_HANGUL_SYLLABLE(u) \
126 	((u) >= U8_HANGUL_SYL_FIRST && (u) <= U8_HANGUL_SYL_LAST)
127 
128 #define	U8_HANGUL_COMPOSABLE_L_V(s, u) \
129 	((s) == U8_STATE_HANGUL_L && U8_HANGUL_JAMO_V((u)))
130 
131 #define	U8_HANGUL_COMPOSABLE_LV_T(s, u) \
132 	((s) == U8_STATE_HANGUL_LV && U8_HANGUL_JAMO_T((u)))
133 
134 /* The types of decomposition mappings. */
135 #define	U8_DECOMP_BOTH			(0xF5U)
136 #define	U8_DECOMP_CANONICAL		(0xF6U)
137 
138 /* The indicator for 16-bit table. */
139 #define	U8_16BIT_TABLE_INDICATOR	(0x8000U)
140 
141 /* The following are some convenience macros. */
142 #define	U8_PUT_3BYTES_INTO_UTF32(u, b1, b2, b3)  \
143 	(u) = ((((uint32_t)(b1) & 0x0F) << 12) | \
144 		(((uint32_t)(b2) & 0x3F) << 6)  | \
145 		((uint32_t)(b3) & 0x3F));
146 
147 #define	U8_SIMPLE_SWAP(a, b, t) \
148 	(t) = (a); \
149 	(a) = (b); \
150 	(b) = (t);
151 
152 #define	U8_ASCII_TOUPPER(c) \
153 	(((c) >= 'a' && (c) <= 'z') ? (c) - 'a' + 'A' : (c))
154 
155 #define	U8_ASCII_TOLOWER(c) \
156 	(((c) >= 'A' && (c) <= 'Z') ? (c) - 'A' + 'a' : (c))
157 
158 #define	U8_ISASCII(c)			(((uchar_t)(c)) < 0x80U)
159 /*
160  * The following macro assumes that the two characters that are to be
161  * swapped are adjacent to each other and 'a' comes before 'b'.
162  *
163  * If the assumptions are not met, then, the macro will fail.
164  */
165 #define	U8_SWAP_COMB_MARKS(a, b) \
166 	for (k = 0; k < disp[(a)]; k++) \
167 		u8t[k] = u8s[start[(a)] + k]; \
168 	for (k = 0; k < disp[(b)]; k++) \
169 		u8s[start[(a)] + k] = u8s[start[(b)] + k]; \
170 	start[(b)] = start[(a)] + disp[(b)]; \
171 	for (k = 0; k < disp[(a)]; k++) \
172 		u8s[start[(b)] + k] = u8t[k]; \
173 	U8_SIMPLE_SWAP(comb_class[(a)], comb_class[(b)], tc); \
174 	U8_SIMPLE_SWAP(disp[(a)], disp[(b)], tc);
175 
176 /* The possible states during normalization. */
177 typedef enum {
178 	U8_STATE_START = 0,
179 	U8_STATE_HANGUL_L = 1,
180 	U8_STATE_HANGUL_LV = 2,
181 	U8_STATE_HANGUL_LVT = 3,
182 	U8_STATE_HANGUL_V = 4,
183 	U8_STATE_HANGUL_T = 5,
184 	U8_STATE_COMBINING_MARK = 6
185 } u8_normalization_states_t;
186 
187 /*
188  * The three vectors at below are used to check bytes of a given UTF-8
189  * character are valid and not containing any malformed byte values.
190  *
191  * We used to have a quite relaxed UTF-8 binary representation but then there
192  * was some security related issues and so the Unicode Consortium defined
193  * and announced the UTF-8 Corrigendum at Unicode 3.1 and then refined it
194  * one more time at the Unicode 3.2. The following three tables are based on
195  * that.
196  */
197 
198 #define	U8_ILLEGAL_NEXT_BYTE_COMMON(c)	((c) < 0x80 || (c) > 0xBF)
199 
200 #define	I_				U8_ILLEGAL_CHAR
201 #define	O_				U8_OUT_OF_RANGE_CHAR
202 
203 const int8_t u8_number_of_bytes[0x100] = {
204 	1,  1,  1,  1,  1,  1,  1,  1,  1,  1,  1,  1,  1,  1,  1,  1,
205 	1,  1,  1,  1,  1,  1,  1,  1,  1,  1,  1,  1,  1,  1,  1,  1,
206 	1,  1,  1,  1,  1,  1,  1,  1,  1,  1,  1,  1,  1,  1,  1,  1,
207 	1,  1,  1,  1,  1,  1,  1,  1,  1,  1,  1,  1,  1,  1,  1,  1,
208 	1,  1,  1,  1,  1,  1,  1,  1,  1,  1,  1,  1,  1,  1,  1,  1,
209 	1,  1,  1,  1,  1,  1,  1,  1,  1,  1,  1,  1,  1,  1,  1,  1,
210 	1,  1,  1,  1,  1,  1,  1,  1,  1,  1,  1,  1,  1,  1,  1,  1,
211 	1,  1,  1,  1,  1,  1,  1,  1,  1,  1,  1,  1,  1,  1,  1,  1,
212 
213 /*	80  81  82  83  84  85  86  87  88  89  8A  8B  8C  8D  8E  8F  */
214 	I_, I_, I_, I_, I_, I_, I_, I_, I_, I_, I_, I_, I_, I_, I_, I_,
215 
216 /*  	90  91  92  93  94  95  96  97  98  99  9A  9B  9C  9D  9E  9F  */
217 	I_, I_, I_, I_, I_, I_, I_, I_, I_, I_, I_, I_, I_, I_, I_, I_,
218 
219 /*  	A0  A1  A2  A3  A4  A5  A6  A7  A8  A9  AA  AB  AC  AD  AE  AF  */
220 	I_, I_, I_, I_, I_, I_, I_, I_, I_, I_, I_, I_, I_, I_, I_, I_,
221 
222 /*	B0  B1  B2  B3  B4  B5  B6  B7  B8  B9  BA  BB  BC  BD  BE  BF  */
223 	I_, I_, I_, I_, I_, I_, I_, I_, I_, I_, I_, I_, I_, I_, I_, I_,
224 
225 /*	C0  C1  C2  C3  C4  C5  C6  C7  C8  C9  CA  CB  CC  CD  CE  CF  */
226 	I_, I_, 2,  2,  2,  2,  2,  2,  2,  2,  2,  2,  2,  2,  2,  2,
227 
228 /*	D0  D1  D2  D3  D4  D5  D6  D7  D8  D9  DA  DB  DC  DD  DE  DF  */
229 	2,  2,  2,  2,  2,  2,  2,  2,  2,  2,  2,  2,  2,  2,  2,  2,
230 
231 /*	E0  E1  E2  E3  E4  E5  E6  E7  E8  E9  EA  EB  EC  ED  EE  EF  */
232 	3,  3,  3,  3,  3,  3,  3,  3,  3,  3,  3,  3,  3,  3,  3,  3,
233 
234 /*	F0  F1  F2  F3  F4  F5  F6  F7  F8  F9  FA  FB  FC  FD  FE  FF  */
235 	4,  4,  4,  4,  4,  O_, O_, O_, O_, O_, O_, O_, O_, O_, O_, O_,
236 };
237 
238 #undef	I_
239 #undef	O_
240 
241 const uint8_t u8_valid_min_2nd_byte[0x100] = {
242 	0,    0,    0,    0,    0,    0,    0,    0,
243 	0,    0,    0,    0,    0,    0,    0,    0,
244 	0,    0,    0,    0,    0,    0,    0,    0,
245 	0,    0,    0,    0,    0,    0,    0,    0,
246 	0,    0,    0,    0,    0,    0,    0,    0,
247 	0,    0,    0,    0,    0,    0,    0,    0,
248 	0,    0,    0,    0,    0,    0,    0,    0,
249 	0,    0,    0,    0,    0,    0,    0,    0,
250 	0,    0,    0,    0,    0,    0,    0,    0,
251 	0,    0,    0,    0,    0,    0,    0,    0,
252 	0,    0,    0,    0,    0,    0,    0,    0,
253 	0,    0,    0,    0,    0,    0,    0,    0,
254 	0,    0,    0,    0,    0,    0,    0,    0,
255 	0,    0,    0,    0,    0,    0,    0,    0,
256 	0,    0,    0,    0,    0,    0,    0,    0,
257 	0,    0,    0,    0,    0,    0,    0,    0,
258 	0,    0,    0,    0,    0,    0,    0,    0,
259 	0,    0,    0,    0,    0,    0,    0,    0,
260 	0,    0,    0,    0,    0,    0,    0,    0,
261 	0,    0,    0,    0,    0,    0,    0,    0,
262 	0,    0,    0,    0,    0,    0,    0,    0,
263 	0,    0,    0,    0,    0,    0,    0,    0,
264 	0,    0,    0,    0,    0,    0,    0,    0,
265 	0,    0,    0,    0,    0,    0,    0,    0,
266 /*	C0    C1    C2    C3    C4    C5    C6    C7    */
267 	0,    0,    0x80, 0x80, 0x80, 0x80, 0x80, 0x80,
268 /*	C8    C9    CA    CB    CC    CD    CE    CF    */
269 	0x80, 0x80, 0x80, 0x80, 0x80, 0x80, 0x80, 0x80,
270 /*	D0    D1    D2    D3    D4    D5    D6    D7    */
271 	0x80, 0x80, 0x80, 0x80, 0x80, 0x80, 0x80, 0x80,
272 /*	D8    D9    DA    DB    DC    DD    DE    DF    */
273 	0x80, 0x80, 0x80, 0x80, 0x80, 0x80, 0x80, 0x80,
274 /*	E0    E1    E2    E3    E4    E5    E6    E7    */
275 	0xa0, 0x80, 0x80, 0x80, 0x80, 0x80, 0x80, 0x80,
276 /*	E8    E9    EA    EB    EC    ED    EE    EF    */
277 	0x80, 0x80, 0x80, 0x80, 0x80, 0x80, 0x80, 0x80,
278 /*	F0    F1    F2    F3    F4    F5    F6    F7    */
279 	0x90, 0x80, 0x80, 0x80, 0x80, 0,    0,    0,
280 	0,    0,    0,    0,    0,    0,    0,    0,
281 };
282 
283 const uint8_t u8_valid_max_2nd_byte[0x100] = {
284 	0,    0,    0,    0,    0,    0,    0,    0,
285 	0,    0,    0,    0,    0,    0,    0,    0,
286 	0,    0,    0,    0,    0,    0,    0,    0,
287 	0,    0,    0,    0,    0,    0,    0,    0,
288 	0,    0,    0,    0,    0,    0,    0,    0,
289 	0,    0,    0,    0,    0,    0,    0,    0,
290 	0,    0,    0,    0,    0,    0,    0,    0,
291 	0,    0,    0,    0,    0,    0,    0,    0,
292 	0,    0,    0,    0,    0,    0,    0,    0,
293 	0,    0,    0,    0,    0,    0,    0,    0,
294 	0,    0,    0,    0,    0,    0,    0,    0,
295 	0,    0,    0,    0,    0,    0,    0,    0,
296 	0,    0,    0,    0,    0,    0,    0,    0,
297 	0,    0,    0,    0,    0,    0,    0,    0,
298 	0,    0,    0,    0,    0,    0,    0,    0,
299 	0,    0,    0,    0,    0,    0,    0,    0,
300 	0,    0,    0,    0,    0,    0,    0,    0,
301 	0,    0,    0,    0,    0,    0,    0,    0,
302 	0,    0,    0,    0,    0,    0,    0,    0,
303 	0,    0,    0,    0,    0,    0,    0,    0,
304 	0,    0,    0,    0,    0,    0,    0,    0,
305 	0,    0,    0,    0,    0,    0,    0,    0,
306 	0,    0,    0,    0,    0,    0,    0,    0,
307 	0,    0,    0,    0,    0,    0,    0,    0,
308 /*	C0    C1    C2    C3    C4    C5    C6    C7    */
309 	0,    0,    0xbf, 0xbf, 0xbf, 0xbf, 0xbf, 0xbf,
310 /*	C8    C9    CA    CB    CC    CD    CE    CF    */
311 	0xbf, 0xbf, 0xbf, 0xbf, 0xbf, 0xbf, 0xbf, 0xbf,
312 /*	D0    D1    D2    D3    D4    D5    D6    D7    */
313 	0xbf, 0xbf, 0xbf, 0xbf, 0xbf, 0xbf, 0xbf, 0xbf,
314 /*	D8    D9    DA    DB    DC    DD    DE    DF    */
315 	0xbf, 0xbf, 0xbf, 0xbf, 0xbf, 0xbf, 0xbf, 0xbf,
316 /*	E0    E1    E2    E3    E4    E5    E6    E7    */
317 	0xbf, 0xbf, 0xbf, 0xbf, 0xbf, 0xbf, 0xbf, 0xbf,
318 /*	E8    E9    EA    EB    EC    ED    EE    EF    */
319 	0xbf, 0xbf, 0xbf, 0xbf, 0xbf, 0x9f, 0xbf, 0xbf,
320 /*	F0    F1    F2    F3    F4    F5    F6    F7    */
321 	0xbf, 0xbf, 0xbf, 0xbf, 0x8f, 0,    0,    0,
322 	0,    0,    0,    0,    0,    0,    0,    0,
323 };
324 
325 
326 /*
327  * The u8_validate() validates on the given UTF-8 character string and
328  * calculate the byte length. It is quite similar to mblen(3C) except that
329  * this will validate against the list of characters if required and
330  * specific to UTF-8 and Unicode.
331  */
332 int
333 u8_validate(char *u8str, size_t n, char **list, int flag, int *errnum)
334 {
335 	uchar_t *ib;
336 	uchar_t *ibtail;
337 	uchar_t **p;
338 	uchar_t *s1;
339 	uchar_t *s2;
340 	uchar_t f;
341 	int sz;
342 	size_t i;
343 	int ret_val;
344 	boolean_t second;
345 	boolean_t no_need_to_validate_entire;
346 	boolean_t check_additional;
347 	boolean_t validate_ucs2_range_only;
348 
349 	if (! u8str)
350 		return (0);
351 
352 	ib = (uchar_t *)u8str;
353 	ibtail = ib + n;
354 
355 	ret_val = 0;
356 
357 	no_need_to_validate_entire = ! (flag & U8_VALIDATE_ENTIRE);
358 	check_additional = flag & U8_VALIDATE_CHECK_ADDITIONAL;
359 	validate_ucs2_range_only = flag & U8_VALIDATE_UCS2_RANGE;
360 
361 	while (ib < ibtail) {
362 		/*
363 		 * The first byte of a UTF-8 character tells how many
364 		 * bytes will follow for the character. If the first byte
365 		 * is an illegal byte value or out of range value, we just
366 		 * return -1 with an appropriate error number.
367 		 */
368 		sz = u8_number_of_bytes[*ib];
369 		if (sz == U8_ILLEGAL_CHAR) {
370 			*errnum = EILSEQ;
371 			return (-1);
372 		}
373 
374 		if (sz == U8_OUT_OF_RANGE_CHAR ||
375 		    (validate_ucs2_range_only && sz > U8_MAX_BYTES_UCS2)) {
376 			*errnum = ERANGE;
377 			return (-1);
378 		}
379 
380 		/*
381 		 * If we don't have enough bytes to check on, that's also
382 		 * an error. As you can see, we give illegal byte sequence
383 		 * checking higher priority then EINVAL cases.
384 		 */
385 		if ((ibtail - ib) < sz) {
386 			*errnum = EINVAL;
387 			return (-1);
388 		}
389 
390 		if (sz == 1) {
391 			ib++;
392 			ret_val++;
393 		} else {
394 			/*
395 			 * Check on the multi-byte UTF-8 character. For more
396 			 * details on this, see comment added for the used
397 			 * data structures at the beginning of the file.
398 			 */
399 			f = *ib++;
400 			ret_val++;
401 			second = B_TRUE;
402 			for (i = 1; i < sz; i++) {
403 				if (second) {
404 					if (*ib < u8_valid_min_2nd_byte[f] ||
405 					    *ib > u8_valid_max_2nd_byte[f]) {
406 						*errnum = EILSEQ;
407 						return (-1);
408 					}
409 					second = B_FALSE;
410 				} else if (U8_ILLEGAL_NEXT_BYTE_COMMON(*ib)) {
411 					*errnum = EILSEQ;
412 					return (-1);
413 				}
414 				ib++;
415 				ret_val++;
416 			}
417 		}
418 
419 		if (check_additional) {
420 			for (p = (uchar_t **)list, i = 0; p[i]; i++) {
421 				s1 = ib - sz;
422 				s2 = p[i];
423 				while (s1 < ib) {
424 					if (*s1 != *s2 || *s2 == '\0')
425 						break;
426 					s1++;
427 					s2++;
428 				}
429 
430 				if (s1 >= ib && *s2 == '\0') {
431 					*errnum = EBADF;
432 					return (-1);
433 				}
434 			}
435 		}
436 
437 		if (no_need_to_validate_entire)
438 			break;
439 	}
440 
441 	return (ret_val);
442 }
443 
444 /*
445  * The do_case_conv() looks at the mapping tables and returns found
446  * bytes if any. If not found, the input bytes are returned. The function
447  * always terminate the return bytes with a null character assuming that
448  * there are plenty of room to do so.
449  *
450  * The case conversions are simple case conversions mapping a character to
451  * another character as specified in the Unicode data. The byte size of
452  * the mapped character could be different from that of the input character.
453  *
454  * The return value is the byte length of the returned character excluding
455  * the terminating null byte.
456  */
457 static size_t
458 do_case_conv(int uv, uchar_t *u8s, uchar_t *s, int sz, boolean_t is_it_toupper)
459 {
460 	size_t i;
461 	uint16_t b1 = 0;
462 	uint16_t b2 = 0;
463 	uint16_t b3 = 0;
464 	uint16_t b3_tbl;
465 	uint16_t b3_base;
466 	uint16_t b4 = 0;
467 	size_t start_id;
468 	size_t end_id;
469 
470 	/*
471 	 * At this point, the only possible values for sz are 2, 3, and 4.
472 	 * The u8s should point to a vector that is well beyond the size of
473 	 * 5 bytes.
474 	 */
475 	if (sz == 2) {
476 		b3 = u8s[0] = s[0];
477 		b4 = u8s[1] = s[1];
478 	} else if (sz == 3) {
479 		b2 = u8s[0] = s[0];
480 		b3 = u8s[1] = s[1];
481 		b4 = u8s[2] = s[2];
482 	} else if (sz == 4) {
483 		b1 = u8s[0] = s[0];
484 		b2 = u8s[1] = s[1];
485 		b3 = u8s[2] = s[2];
486 		b4 = u8s[3] = s[3];
487 	} else {
488 		/* This is not possible but just in case as a fallback. */
489 		if (is_it_toupper)
490 			*u8s = U8_ASCII_TOUPPER(*s);
491 		else
492 			*u8s = U8_ASCII_TOLOWER(*s);
493 		u8s[1] = '\0';
494 
495 		return (1);
496 	}
497 	u8s[sz] = '\0';
498 
499 	/*
500 	 * Let's find out if we have a corresponding character.
501 	 */
502 	b1 = u8_common_b1_tbl[uv][b1];
503 	if (b1 == U8_TBL_ELEMENT_NOT_DEF)
504 		return ((size_t)sz);
505 
506 	b2 = u8_case_common_b2_tbl[uv][b1][b2];
507 	if (b2 == U8_TBL_ELEMENT_NOT_DEF)
508 		return ((size_t)sz);
509 
510 	if (is_it_toupper) {
511 		b3_tbl = u8_toupper_b3_tbl[uv][b2][b3].tbl_id;
512 		if (b3_tbl == U8_TBL_ELEMENT_NOT_DEF)
513 			return ((size_t)sz);
514 
515 		start_id = u8_toupper_b4_tbl[uv][b3_tbl][b4];
516 		end_id = u8_toupper_b4_tbl[uv][b3_tbl][b4 + 1];
517 
518 		/* Either there is no match or an error at the table. */
519 		if (start_id >= end_id || (end_id - start_id) > U8_MB_CUR_MAX)
520 			return ((size_t)sz);
521 
522 		b3_base = u8_toupper_b3_tbl[uv][b2][b3].base;
523 
524 		for (i = 0; start_id < end_id; start_id++)
525 			u8s[i++] = u8_toupper_final_tbl[uv][b3_base + start_id];
526 	} else {
527 		b3_tbl = u8_tolower_b3_tbl[uv][b2][b3].tbl_id;
528 		if (b3_tbl == U8_TBL_ELEMENT_NOT_DEF)
529 			return ((size_t)sz);
530 
531 		start_id = u8_tolower_b4_tbl[uv][b3_tbl][b4];
532 		end_id = u8_tolower_b4_tbl[uv][b3_tbl][b4 + 1];
533 
534 		if (start_id >= end_id || (end_id - start_id) > U8_MB_CUR_MAX)
535 			return ((size_t)sz);
536 
537 		b3_base = u8_tolower_b3_tbl[uv][b2][b3].base;
538 
539 		for (i = 0; start_id < end_id; start_id++)
540 			u8s[i++] = u8_tolower_final_tbl[uv][b3_base + start_id];
541 	}
542 
543 	/*
544 	 * If i is still zero, that means there is no corresponding character.
545 	 */
546 	if (i == 0)
547 		return ((size_t)sz);
548 
549 	u8s[i] = '\0';
550 
551 	return (i);
552 }
553 
554 /*
555  * The do_case_compare() function compares the two input strings, s1 and s2,
556  * one character at a time doing case conversions if applicable and return
557  * the comparison result as like strcmp().
558  *
559  * Since, in empirical sense, most of text data are 7-bit ASCII characters,
560  * we treat the 7-bit ASCII characters as a special case trying to yield
561  * faster processing time.
562  */
563 static int
564 do_case_compare(size_t uv, uchar_t *s1, uchar_t *s2, size_t n1,
565     size_t n2, boolean_t is_it_toupper, int *errnum)
566 {
567 	int f;
568 	int sz1;
569 	int sz2;
570 	size_t j;
571 	size_t i1;
572 	size_t i2;
573 	uchar_t u8s1[U8_MB_CUR_MAX + 1];
574 	uchar_t u8s2[U8_MB_CUR_MAX + 1];
575 
576 	i1 = i2 = 0;
577 	while (i1 < n1 && i2 < n2) {
578 		/*
579 		 * Find out what would be the byte length for this UTF-8
580 		 * character at string s1 and also find out if this is
581 		 * an illegal start byte or not and if so, issue a proper
582 		 * error number and yet treat this byte as a character.
583 		 */
584 		sz1 = u8_number_of_bytes[*s1];
585 		if (sz1 < 0) {
586 			*errnum = EILSEQ;
587 			sz1 = 1;
588 		}
589 
590 		/*
591 		 * For 7-bit ASCII characters mainly, we do a quick case
592 		 * conversion right at here.
593 		 *
594 		 * If we don't have enough bytes for this character, issue
595 		 * an EINVAL error and use what are available.
596 		 *
597 		 * If we have enough bytes, find out if there is
598 		 * a corresponding uppercase character and if so, copy over
599 		 * the bytes for a comparison later. If there is no
600 		 * corresponding uppercase character, then, use what we have
601 		 * for the comparison.
602 		 */
603 		if (sz1 == 1) {
604 			if (is_it_toupper)
605 				u8s1[0] = U8_ASCII_TOUPPER(*s1);
606 			else
607 				u8s1[0] = U8_ASCII_TOLOWER(*s1);
608 			s1++;
609 			u8s1[1] = '\0';
610 		} else if ((i1 + sz1) > n1) {
611 			*errnum = EINVAL;
612 			for (j = 0; (i1 + j) < n1; )
613 				u8s1[j++] = *s1++;
614 			u8s1[j] = '\0';
615 		} else {
616 			(void) do_case_conv(uv, u8s1, s1, sz1, is_it_toupper);
617 			s1 += sz1;
618 		}
619 
620 		/* Do the same for the string s2. */
621 		sz2 = u8_number_of_bytes[*s2];
622 		if (sz2 < 0) {
623 			*errnum = EILSEQ;
624 			sz2 = 1;
625 		}
626 
627 		if (sz2 == 1) {
628 			if (is_it_toupper)
629 				u8s2[0] = U8_ASCII_TOUPPER(*s2);
630 			else
631 				u8s2[0] = U8_ASCII_TOLOWER(*s2);
632 			s2++;
633 			u8s2[1] = '\0';
634 		} else if ((i2 + sz2) > n2) {
635 			*errnum = EINVAL;
636 			for (j = 0; (i2 + j) < n2; )
637 				u8s2[j++] = *s2++;
638 			u8s2[j] = '\0';
639 		} else {
640 			(void) do_case_conv(uv, u8s2, s2, sz2, is_it_toupper);
641 			s2 += sz2;
642 		}
643 
644 		/* Now compare the two characters. */
645 		if (sz1 == 1 && sz2 == 1) {
646 			if (*u8s1 > *u8s2)
647 				return (1);
648 			if (*u8s1 < *u8s2)
649 				return (-1);
650 		} else {
651 			f = strcmp((const char *)u8s1, (const char *)u8s2);
652 			if (f != 0)
653 				return (f);
654 		}
655 
656 		/*
657 		 * They were the same. Let's move on to the next
658 		 * characters then.
659 		 */
660 		i1 += sz1;
661 		i2 += sz2;
662 	}
663 
664 	/*
665 	 * We compared until the end of either or both strings.
666 	 *
667 	 * If we reached to or went over the ends for the both, that means
668 	 * they are the same.
669 	 *
670 	 * If we reached only one of the two ends, that means the other string
671 	 * has something which then the fact can be used to determine
672 	 * the return value.
673 	 */
674 	if (i1 >= n1) {
675 		if (i2 >= n2)
676 			return (0);
677 		return (-1);
678 	}
679 	return (1);
680 }
681 
682 /*
683  * The combining_class() function checks on the given bytes and find out
684  * the corresponding Unicode combining class value. The return value 0 means
685  * it is a Starter. Any illegal UTF-8 character will also be treated as
686  * a Starter.
687  */
688 static uchar_t
689 combining_class(size_t uv, uchar_t *s, size_t sz)
690 {
691 	uint16_t b1 = 0;
692 	uint16_t b2 = 0;
693 	uint16_t b3 = 0;
694 	uint16_t b4 = 0;
695 
696 	if (sz == 1 || sz > 4)
697 		return (0);
698 
699 	if (sz == 2) {
700 		b3 = s[0];
701 		b4 = s[1];
702 	} else if (sz == 3) {
703 		b2 = s[0];
704 		b3 = s[1];
705 		b4 = s[2];
706 	} else if (sz == 4) {
707 		b1 = s[0];
708 		b2 = s[1];
709 		b3 = s[2];
710 		b4 = s[3];
711 	}
712 
713 	b1 = u8_common_b1_tbl[uv][b1];
714 	if (b1 == U8_TBL_ELEMENT_NOT_DEF)
715 		return (0);
716 
717 	b2 = u8_combining_class_b2_tbl[uv][b1][b2];
718 	if (b2 == U8_TBL_ELEMENT_NOT_DEF)
719 		return (0);
720 
721 	b3 = u8_combining_class_b3_tbl[uv][b2][b3];
722 	if (b3 == U8_TBL_ELEMENT_NOT_DEF)
723 		return (0);
724 
725 	return (u8_combining_class_b4_tbl[uv][b3][b4]);
726 }
727 
728 /*
729  * The do_decomp() function finds out a matching decomposition if any
730  * and return. If there is no match, the input bytes are copied and returned.
731  * The function also checks if there is a Hangul, decomposes it if necessary
732  * and returns.
733  *
734  * To save time, a single byte 7-bit ASCII character should be handled by
735  * the caller.
736  *
737  * The function returns the number of bytes returned sans always terminating
738  * the null byte. It will also return a state that will tell if there was
739  * a Hangul character decomposed which then will be used by the caller.
740  */
741 static size_t
742 do_decomp(size_t uv, uchar_t *u8s, uchar_t *s, int sz,
743     boolean_t canonical_decomposition, u8_normalization_states_t *state)
744 {
745 	uint16_t b1 = 0;
746 	uint16_t b2 = 0;
747 	uint16_t b3 = 0;
748 	uint16_t b3_tbl;
749 	uint16_t b3_base;
750 	uint16_t b4 = 0;
751 	size_t start_id;
752 	size_t end_id;
753 	size_t i;
754 	uint32_t u1;
755 
756 	if (sz == 2) {
757 		b3 = u8s[0] = s[0];
758 		b4 = u8s[1] = s[1];
759 		u8s[2] = '\0';
760 	} else if (sz == 3) {
761 		/* Convert it to a Unicode scalar value. */
762 		U8_PUT_3BYTES_INTO_UTF32(u1, s[0], s[1], s[2]);
763 
764 		/*
765 		 * If this is a Hangul syllable, we decompose it into
766 		 * a leading consonant, a vowel, and an optional trailing
767 		 * consonant and then return.
768 		 */
769 		if (U8_HANGUL_SYLLABLE(u1)) {
770 			u1 -= U8_HANGUL_SYL_FIRST;
771 
772 			b1 = U8_HANGUL_JAMO_L_FIRST + u1 / U8_HANGUL_VT_COUNT;
773 			b2 = U8_HANGUL_JAMO_V_FIRST + (u1 % U8_HANGUL_VT_COUNT)
774 			    / U8_HANGUL_T_COUNT;
775 			b3 = u1 % U8_HANGUL_T_COUNT;
776 
777 			U8_SAVE_HANGUL_AS_UTF8(u8s, 0, 1, 2, b1);
778 			U8_SAVE_HANGUL_AS_UTF8(u8s, 3, 4, 5, b2);
779 			if (b3) {
780 				b3 += U8_HANGUL_JAMO_T_FIRST;
781 				U8_SAVE_HANGUL_AS_UTF8(u8s, 6, 7, 8, b3);
782 
783 				u8s[9] = '\0';
784 				*state = U8_STATE_HANGUL_LVT;
785 				return (9);
786 			}
787 
788 			u8s[6] = '\0';
789 			*state = U8_STATE_HANGUL_LV;
790 			return (6);
791 		}
792 
793 		b2 = u8s[0] = s[0];
794 		b3 = u8s[1] = s[1];
795 		b4 = u8s[2] = s[2];
796 		u8s[3] = '\0';
797 
798 		/*
799 		 * If this is a Hangul Jamo, we know there is nothing
800 		 * further that we can decompose.
801 		 */
802 		if (U8_HANGUL_JAMO_L(u1)) {
803 			*state = U8_STATE_HANGUL_L;
804 			return (3);
805 		}
806 
807 		if (U8_HANGUL_JAMO_V(u1)) {
808 			if (*state == U8_STATE_HANGUL_L)
809 				*state = U8_STATE_HANGUL_LV;
810 			else
811 				*state = U8_STATE_HANGUL_V;
812 			return (3);
813 		}
814 
815 		if (U8_HANGUL_JAMO_T(u1)) {
816 			if (*state == U8_STATE_HANGUL_LV)
817 				*state = U8_STATE_HANGUL_LVT;
818 			else
819 				*state = U8_STATE_HANGUL_T;
820 			return (3);
821 		}
822 	} else if (sz == 4) {
823 		b1 = u8s[0] = s[0];
824 		b2 = u8s[1] = s[1];
825 		b3 = u8s[2] = s[2];
826 		b4 = u8s[3] = s[3];
827 		u8s[4] = '\0';
828 	} else {
829 		/*
830 		 * This is a fallback and should not happen if the function
831 		 * was called properly.
832 		 */
833 		u8s[0] = s[0];
834 		u8s[1] = '\0';
835 		*state = U8_STATE_START;
836 		return (1);
837 	}
838 
839 	/*
840 	 * At this point, this routine does not know what it would get.
841 	 * The caller should sort it out if the state isn't a Hangul one.
842 	 */
843 	*state = U8_STATE_START;
844 
845 	/* Try to find matching decomposition mapping byte sequence. */
846 	b1 = u8_common_b1_tbl[uv][b1];
847 	if (b1 == U8_TBL_ELEMENT_NOT_DEF)
848 		return ((size_t)sz);
849 
850 	b2 = u8_decomp_b2_tbl[uv][b1][b2];
851 	if (b2 == U8_TBL_ELEMENT_NOT_DEF)
852 		return ((size_t)sz);
853 
854 	b3_tbl = u8_decomp_b3_tbl[uv][b2][b3].tbl_id;
855 	if (b3_tbl == U8_TBL_ELEMENT_NOT_DEF)
856 		return ((size_t)sz);
857 
858 	/*
859 	 * If b3_tbl is bigger than or equal to U8_16BIT_TABLE_INDICATOR
860 	 * which is 0x8000, this means we couldn't fit the mappings into
861 	 * the cardinality of a unsigned byte.
862 	 */
863 	if (b3_tbl >= U8_16BIT_TABLE_INDICATOR) {
864 		b3_tbl -= U8_16BIT_TABLE_INDICATOR;
865 		start_id = u8_decomp_b4_16bit_tbl[uv][b3_tbl][b4];
866 		end_id = u8_decomp_b4_16bit_tbl[uv][b3_tbl][b4 + 1];
867 	} else {
868 		start_id = u8_decomp_b4_tbl[uv][b3_tbl][b4];
869 		end_id = u8_decomp_b4_tbl[uv][b3_tbl][b4 + 1];
870 	}
871 
872 	/* This also means there wasn't any matching decomposition. */
873 	if (start_id >= end_id)
874 		return ((size_t)sz);
875 
876 	/*
877 	 * The final table for decomposition mappings has three types of
878 	 * byte sequences depending on whether a mapping is for compatibility
879 	 * decomposition, canonical decomposition, or both like the following:
880 	 *
881 	 * (1) Compatibility decomposition mappings:
882 	 *
883 	 *	+---+---+-...-+---+
884 	 *	| B0| B1| ... | Bm|
885 	 *	+---+---+-...-+---+
886 	 *
887 	 *	The first byte, B0, is always less then 0xF5 (U8_DECOMP_BOTH).
888 	 *
889 	 * (2) Canonical decomposition mappings:
890 	 *
891 	 *	+---+---+---+-...-+---+
892 	 *	| T | b0| b1| ... | bn|
893 	 *	+---+---+---+-...-+---+
894 	 *
895 	 *	where the first byte, T, is 0xF6 (U8_DECOMP_CANONICAL).
896 	 *
897 	 * (3) Both mappings:
898 	 *
899 	 *	+---+---+---+---+-...-+---+---+---+-...-+---+
900 	 *	| T | D | b0| b1| ... | bn| B0| B1| ... | Bm|
901 	 *	+---+---+---+---+-...-+---+---+---+-...-+---+
902 	 *
903 	 *	where T is 0xF5 (U8_DECOMP_BOTH) and D is a displacement
904 	 *	byte, b0 to bn are canonical mapping bytes and B0 to Bm are
905 	 *	compatibility mapping bytes.
906 	 *
907 	 * Note that compatibility decomposition means doing recursive
908 	 * decompositions using both compatibility decomposition mappings and
909 	 * canonical decomposition mappings. On the other hand, canonical
910 	 * decomposition means doing recursive decompositions using only
911 	 * canonical decomposition mappings. Since the table we have has gone
912 	 * through the recursions already, we do not need to do so during
913 	 * runtime, i.e., the table has been completely flattened out
914 	 * already.
915 	 */
916 
917 	b3_base = u8_decomp_b3_tbl[uv][b2][b3].base;
918 
919 	/* Get the type, T, of the byte sequence. */
920 	b1 = u8_decomp_final_tbl[uv][b3_base + start_id];
921 
922 	/*
923 	 * If necessary, adjust start_id, end_id, or both. Note that if
924 	 * this is compatibility decomposition mapping, there is no
925 	 * adjustment.
926 	 */
927 	if (canonical_decomposition) {
928 		/* Is the mapping only for compatibility decomposition? */
929 		if (b1 < U8_DECOMP_BOTH)
930 			return ((size_t)sz);
931 
932 		start_id++;
933 
934 		if (b1 == U8_DECOMP_BOTH) {
935 			end_id = start_id +
936 			    u8_decomp_final_tbl[uv][b3_base + start_id];
937 			start_id++;
938 		}
939 	} else {
940 		/*
941 		 * Unless this is a compatibility decomposition mapping,
942 		 * we adjust the start_id.
943 		 */
944 		if (b1 == U8_DECOMP_BOTH) {
945 			start_id++;
946 			start_id += u8_decomp_final_tbl[uv][b3_base + start_id];
947 		} else if (b1 == U8_DECOMP_CANONICAL) {
948 			start_id++;
949 		}
950 	}
951 
952 	for (i = 0; start_id < end_id; start_id++)
953 		u8s[i++] = u8_decomp_final_tbl[uv][b3_base + start_id];
954 	u8s[i] = '\0';
955 
956 	return (i);
957 }
958 
959 /*
960  * The find_composition_start() function uses the character bytes given and
961  * find out the matching composition mappings if any and return the address
962  * to the composition mappings as explained in the do_composition().
963  */
964 static uchar_t *
965 find_composition_start(size_t uv, uchar_t *s, size_t sz)
966 {
967 	uint16_t b1 = 0;
968 	uint16_t b2 = 0;
969 	uint16_t b3 = 0;
970 	uint16_t b3_tbl;
971 	uint16_t b3_base;
972 	uint16_t b4 = 0;
973 	size_t start_id;
974 	size_t end_id;
975 
976 	if (sz == 1) {
977 		b4 = s[0];
978 	} else if (sz == 2) {
979 		b3 = s[0];
980 		b4 = s[1];
981 	} else if (sz == 3) {
982 		b2 = s[0];
983 		b3 = s[1];
984 		b4 = s[2];
985 	} else if (sz == 4) {
986 		b1 = s[0];
987 		b2 = s[1];
988 		b3 = s[2];
989 		b4 = s[3];
990 	} else {
991 		/*
992 		 * This is a fallback and should not happen if the function
993 		 * was called properly.
994 		 */
995 		return (NULL);
996 	}
997 
998 	b1 = u8_composition_b1_tbl[uv][b1];
999 	if (b1 == U8_TBL_ELEMENT_NOT_DEF)
1000 		return (NULL);
1001 
1002 	b2 = u8_composition_b2_tbl[uv][b1][b2];
1003 	if (b2 == U8_TBL_ELEMENT_NOT_DEF)
1004 		return (NULL);
1005 
1006 	b3_tbl = u8_composition_b3_tbl[uv][b2][b3].tbl_id;
1007 	if (b3_tbl == U8_TBL_ELEMENT_NOT_DEF)
1008 		return (NULL);
1009 
1010 	if (b3_tbl >= U8_16BIT_TABLE_INDICATOR) {
1011 		b3_tbl -= U8_16BIT_TABLE_INDICATOR;
1012 		start_id = u8_composition_b4_16bit_tbl[uv][b3_tbl][b4];
1013 		end_id = u8_composition_b4_16bit_tbl[uv][b3_tbl][b4 + 1];
1014 	} else {
1015 		start_id = u8_composition_b4_tbl[uv][b3_tbl][b4];
1016 		end_id = u8_composition_b4_tbl[uv][b3_tbl][b4 + 1];
1017 	}
1018 
1019 	if (start_id >= end_id)
1020 		return (NULL);
1021 
1022 	b3_base = u8_composition_b3_tbl[uv][b2][b3].base;
1023 
1024 	return ((uchar_t *)&(u8_composition_final_tbl[uv][b3_base + start_id]));
1025 }
1026 
1027 /*
1028  * The blocked() function checks on the combining class values of previous
1029  * characters in this sequence and return whether it is blocked or not.
1030  */
1031 static boolean_t
1032 blocked(uchar_t *comb_class, size_t last)
1033 {
1034 	uchar_t my_comb_class;
1035 	size_t i;
1036 
1037 	my_comb_class = comb_class[last];
1038 	for (i = 1; i < last; i++)
1039 		if (comb_class[i] >= my_comb_class ||
1040 		    comb_class[i] == U8_COMBINING_CLASS_STARTER)
1041 			return (B_TRUE);
1042 
1043 	return (B_FALSE);
1044 }
1045 
1046 /*
1047  * The do_composition() reads the character string pointed by 's' and
1048  * do necessary canonical composition and then copy over the result back to
1049  * the 's'.
1050  *
1051  * The input argument 's' cannot contain more than 32 characters.
1052  */
1053 static size_t
1054 do_composition(size_t uv, uchar_t *s, uchar_t *comb_class, uchar_t *start,
1055     uchar_t *disp, size_t last, uchar_t **os, uchar_t *oslast)
1056 {
1057 	uchar_t t[U8_STREAM_SAFE_TEXT_MAX + 1];
1058 	uchar_t tc[U8_MB_CUR_MAX] = { '\0' };
1059 	uint8_t saved_marks[U8_MAX_CHARS_A_SEQ];
1060 	size_t saved_marks_count;
1061 	uchar_t *p;
1062 	uchar_t *saved_p;
1063 	uchar_t *q;
1064 	size_t i;
1065 	size_t saved_i;
1066 	size_t j;
1067 	size_t k;
1068 	size_t l;
1069 	size_t C;
1070 	size_t saved_l;
1071 	size_t size;
1072 	uint32_t u1;
1073 	uint32_t u2;
1074 	boolean_t match_not_found = B_TRUE;
1075 
1076 	/*
1077 	 * This should never happen unless the callers are doing some strange
1078 	 * and unexpected things.
1079 	 *
1080 	 * The "last" is the index pointing to the last character not last + 1.
1081 	 */
1082 	if (last >= U8_MAX_CHARS_A_SEQ)
1083 		last = U8_UPPER_LIMIT_IN_A_SEQ;
1084 
1085 	for (i = l = 0; i <= last; i++) {
1086 		/*
1087 		 * The last or any non-Starters at the beginning, we don't
1088 		 * have any chance to do composition and so we just copy them
1089 		 * to the temporary buffer.
1090 		 */
1091 		if (i >= last || comb_class[i] != U8_COMBINING_CLASS_STARTER) {
1092 SAVE_THE_CHAR:
1093 			p = s + start[i];
1094 			size = disp[i];
1095 			for (k = 0; k < size; k++)
1096 				t[l++] = *p++;
1097 			continue;
1098 		}
1099 
1100 		/*
1101 		 * If this could be a start of Hangul Jamos, then, we try to
1102 		 * conjoin them.
1103 		 */
1104 		if (s[start[i]] == U8_HANGUL_JAMO_1ST_BYTE) {
1105 			U8_PUT_3BYTES_INTO_UTF32(u1, s[start[i]],
1106 			    s[start[i] + 1], s[start[i] + 2]);
1107 			U8_PUT_3BYTES_INTO_UTF32(u2, s[start[i] + 3],
1108 			    s[start[i] + 4], s[start[i] + 5]);
1109 
1110 			if (U8_HANGUL_JAMO_L(u1) && U8_HANGUL_JAMO_V(u2)) {
1111 				u1 -= U8_HANGUL_JAMO_L_FIRST;
1112 				u2 -= U8_HANGUL_JAMO_V_FIRST;
1113 				u1 = U8_HANGUL_SYL_FIRST +
1114 				    (u1 * U8_HANGUL_V_COUNT + u2) *
1115 				    U8_HANGUL_T_COUNT;
1116 
1117 				i += 2;
1118 				if (i <= last) {
1119 					U8_PUT_3BYTES_INTO_UTF32(u2,
1120 					    s[start[i]], s[start[i] + 1],
1121 					    s[start[i] + 2]);
1122 
1123 					if (U8_HANGUL_JAMO_T(u2)) {
1124 						u1 += u2 -
1125 						    U8_HANGUL_JAMO_T_FIRST;
1126 						i++;
1127 					}
1128 				}
1129 
1130 				U8_SAVE_HANGUL_AS_UTF8(t + l, 0, 1, 2, u1);
1131 				i--;
1132 				l += 3;
1133 				continue;
1134 			}
1135 		}
1136 
1137 		/*
1138 		 * Let's then find out if this Starter has composition
1139 		 * mapping.
1140 		 */
1141 		p = find_composition_start(uv, s + start[i], disp[i]);
1142 		if (p == NULL)
1143 			goto SAVE_THE_CHAR;
1144 
1145 		/*
1146 		 * We have a Starter with composition mapping and the next
1147 		 * character is a non-Starter. Let's try to find out if
1148 		 * we can do composition.
1149 		 */
1150 
1151 		saved_p = p;
1152 		saved_i = i;
1153 		saved_l = l;
1154 		saved_marks_count = 0;
1155 
1156 TRY_THE_NEXT_MARK:
1157 		q = s + start[++i];
1158 		size = disp[i];
1159 
1160 		/*
1161 		 * The next for() loop compares the non-Starter pointed by
1162 		 * 'q' with the possible (joinable) characters pointed by 'p'.
1163 		 *
1164 		 * The composition final table entry pointed by the 'p'
1165 		 * looks like the following:
1166 		 *
1167 		 * +---+---+---+-...-+---+---+---+---+-...-+---+---+
1168 		 * | C | b0| b2| ... | bn| F | B0| B1| ... | Bm| F |
1169 		 * +---+---+---+-...-+---+---+---+---+-...-+---+---+
1170 		 *
1171 		 * where C is the count byte indicating the number of
1172 		 * mapping pairs where each pair would be look like
1173 		 * (b0-bn F, B0-Bm F). The b0-bn are the bytes of the second
1174 		 * character of a canonical decomposition and the B0-Bm are
1175 		 * the bytes of a matching composite character. The F is
1176 		 * a filler byte after each character as the separator.
1177 		 */
1178 
1179 		match_not_found = B_TRUE;
1180 
1181 		for (C = *p++; C > 0; C--) {
1182 			for (k = 0; k < size; p++, k++)
1183 				if (*p != q[k])
1184 					break;
1185 
1186 			/* Have we found it? */
1187 			if (k >= size && *p == U8_TBL_ELEMENT_FILLER) {
1188 				match_not_found = B_FALSE;
1189 
1190 				l = saved_l;
1191 
1192 				while (*++p != U8_TBL_ELEMENT_FILLER)
1193 					t[l++] = *p;
1194 
1195 				break;
1196 			}
1197 
1198 			/* We didn't find; skip to the next pair. */
1199 			if (*p != U8_TBL_ELEMENT_FILLER)
1200 				while (*++p != U8_TBL_ELEMENT_FILLER)
1201 					;
1202 			while (*++p != U8_TBL_ELEMENT_FILLER)
1203 				;
1204 			p++;
1205 		}
1206 
1207 		/*
1208 		 * If there was no match, we will need to save the combining
1209 		 * mark for later appending. After that, if the next one
1210 		 * is a non-Starter and not blocked, then, we try once
1211 		 * again to do composition with the next non-Starter.
1212 		 *
1213 		 * If there was no match and this was a Starter, then,
1214 		 * this is a new start.
1215 		 *
1216 		 * If there was a match and a composition done and we have
1217 		 * more to check on, then, we retrieve a new composition final
1218 		 * table entry for the composite and then try to do the
1219 		 * composition again.
1220 		 */
1221 
1222 		if (match_not_found) {
1223 			if (comb_class[i] == U8_COMBINING_CLASS_STARTER) {
1224 				i--;
1225 				goto SAVE_THE_CHAR;
1226 			}
1227 
1228 			saved_marks[saved_marks_count++] = i;
1229 		}
1230 
1231 		if (saved_l == l) {
1232 			while (i < last) {
1233 				if (blocked(comb_class, i + 1))
1234 					saved_marks[saved_marks_count++] = ++i;
1235 				else
1236 					break;
1237 			}
1238 			if (i < last) {
1239 				p = saved_p;
1240 				goto TRY_THE_NEXT_MARK;
1241 			}
1242 		} else if (i < last) {
1243 			p = find_composition_start(uv, t + saved_l,
1244 			    l - saved_l);
1245 			if (p != NULL) {
1246 				saved_p = p;
1247 				goto TRY_THE_NEXT_MARK;
1248 			}
1249 		}
1250 
1251 		/*
1252 		 * There is no more composition possible.
1253 		 *
1254 		 * If there was no composition what so ever then we copy
1255 		 * over the original Starter and then append any non-Starters
1256 		 * remaining at the target string sequentially after that.
1257 		 */
1258 
1259 		if (saved_l == l) {
1260 			p = s + start[saved_i];
1261 			size = disp[saved_i];
1262 			for (j = 0; j < size; j++)
1263 				t[l++] = *p++;
1264 		}
1265 
1266 		for (k = 0; k < saved_marks_count; k++) {
1267 			p = s + start[saved_marks[k]];
1268 			size = disp[saved_marks[k]];
1269 			for (j = 0; j < size; j++)
1270 				t[l++] = *p++;
1271 		}
1272 	}
1273 
1274 	/*
1275 	 * If the last character is a Starter and if we have a character
1276 	 * (possibly another Starter) that can be turned into a composite,
1277 	 * we do so and we do so until there is no more of composition
1278 	 * possible.
1279 	 */
1280 	if (comb_class[last] == U8_COMBINING_CLASS_STARTER) {
1281 		p = *os;
1282 		saved_l = l - disp[last];
1283 
1284 		while (p < oslast) {
1285 			size = u8_number_of_bytes[*p];
1286 			if (size <= 1 || (p + size) > oslast)
1287 				break;
1288 
1289 			saved_p = p;
1290 
1291 			for (i = 0; i < size; i++)
1292 				tc[i] = *p++;
1293 
1294 			q = find_composition_start(uv, t + saved_l,
1295 			    l - saved_l);
1296 			if (q == NULL) {
1297 				p = saved_p;
1298 				break;
1299 			}
1300 
1301 			match_not_found = B_TRUE;
1302 
1303 			for (C = *q++; C > 0; C--) {
1304 				for (k = 0; k < size; q++, k++)
1305 					if (*q != tc[k])
1306 						break;
1307 
1308 				if (k >= size && *q == U8_TBL_ELEMENT_FILLER) {
1309 					match_not_found = B_FALSE;
1310 
1311 					l = saved_l;
1312 
1313 					while (*++q != U8_TBL_ELEMENT_FILLER) {
1314 						/*
1315 						 * This is practically
1316 						 * impossible but we don't
1317 						 * want to take any chances.
1318 						 */
1319 						if (l >=
1320 						    U8_STREAM_SAFE_TEXT_MAX) {
1321 							p = saved_p;
1322 							goto SAFE_RETURN;
1323 						}
1324 						t[l++] = *q;
1325 					}
1326 
1327 					break;
1328 				}
1329 
1330 				if (*q != U8_TBL_ELEMENT_FILLER)
1331 					while (*++q != U8_TBL_ELEMENT_FILLER)
1332 						;
1333 				while (*++q != U8_TBL_ELEMENT_FILLER)
1334 					;
1335 				q++;
1336 			}
1337 
1338 			if (match_not_found) {
1339 				p = saved_p;
1340 				break;
1341 			}
1342 		}
1343 SAFE_RETURN:
1344 		*os = p;
1345 	}
1346 
1347 	/*
1348 	 * Now we copy over the temporary string to the target string.
1349 	 * Since composition always reduces the number of characters or
1350 	 * the number of characters stay, we don't need to worry about
1351 	 * the buffer overflow here.
1352 	 */
1353 	for (i = 0; i < l; i++)
1354 		s[i] = t[i];
1355 	s[l] = '\0';
1356 
1357 	return (l);
1358 }
1359 
1360 /*
1361  * The collect_a_seq() function checks on the given string s, collect
1362  * a sequence of characters at u8s, and return the sequence. While it collects
1363  * a sequence, it also applies case conversion, canonical or compatibility
1364  * decomposition, canonical decomposition, or some or all of them and
1365  * in that order.
1366  *
1367  * The collected sequence cannot be bigger than 32 characters since if
1368  * it is having more than 31 characters, the sequence will be terminated
1369  * with a U+034F COMBINING GRAPHEME JOINER (CGJ) character and turned into
1370  * a Stream-Safe Text. The collected sequence is always terminated with
1371  * a null byte and the return value is the byte length of the sequence
1372  * including 0. The return value does not include the terminating
1373  * null byte.
1374  */
1375 static size_t
1376 collect_a_seq(size_t uv, uchar_t *u8s, uchar_t **source, uchar_t *slast,
1377     boolean_t is_it_toupper, boolean_t is_it_tolower,
1378     boolean_t canonical_decomposition, boolean_t compatibility_decomposition,
1379     boolean_t canonical_composition,
1380     int *errnum, u8_normalization_states_t *state)
1381 {
1382 	uchar_t *s;
1383 	int sz;
1384 	int saved_sz;
1385 	size_t i;
1386 	size_t j;
1387 	size_t k;
1388 	size_t l;
1389 	uchar_t comb_class[U8_MAX_CHARS_A_SEQ];
1390 	uchar_t disp[U8_MAX_CHARS_A_SEQ];
1391 	uchar_t start[U8_MAX_CHARS_A_SEQ];
1392 	uchar_t u8t[U8_MB_CUR_MAX] = { '\0' };
1393 	uchar_t uts[U8_STREAM_SAFE_TEXT_MAX + 1];
1394 	uchar_t tc;
1395 	size_t last;
1396 	size_t saved_last;
1397 	uint32_t u1;
1398 
1399 	/*
1400 	 * Save the source string pointer which we will return a changed
1401 	 * pointer if we do processing.
1402 	 */
1403 	s = *source;
1404 
1405 	/*
1406 	 * The following is a fallback for just in case callers are not
1407 	 * checking the string boundaries before the calling.
1408 	 */
1409 	if (s >= slast) {
1410 		u8s[0] = '\0';
1411 
1412 		return (0);
1413 	}
1414 
1415 	/*
1416 	 * As the first thing, let's collect a character and do case
1417 	 * conversion if necessary.
1418 	 */
1419 
1420 	sz = u8_number_of_bytes[*s];
1421 
1422 	if (sz < 0) {
1423 		*errnum = EILSEQ;
1424 
1425 		u8s[0] = *s++;
1426 		u8s[1] = '\0';
1427 
1428 		*source = s;
1429 
1430 		return (1);
1431 	}
1432 
1433 	if (sz == 1) {
1434 		if (is_it_toupper)
1435 			u8s[0] = U8_ASCII_TOUPPER(*s);
1436 		else if (is_it_tolower)
1437 			u8s[0] = U8_ASCII_TOLOWER(*s);
1438 		else
1439 			u8s[0] = *s;
1440 		s++;
1441 		u8s[1] = '\0';
1442 	} else if ((s + sz) > slast) {
1443 		*errnum = EINVAL;
1444 
1445 		for (i = 0; s < slast; )
1446 			u8s[i++] = *s++;
1447 		u8s[i] = '\0';
1448 
1449 		*source = s;
1450 
1451 		return (i);
1452 	} else {
1453 		if (is_it_toupper || is_it_tolower) {
1454 			i = do_case_conv(uv, u8s, s, sz, is_it_toupper);
1455 			s += sz;
1456 			sz = i;
1457 		} else {
1458 			for (i = 0; i < sz; )
1459 				u8s[i++] = *s++;
1460 			u8s[i] = '\0';
1461 		}
1462 	}
1463 
1464 	/*
1465 	 * And then canonical/compatibility decomposition followed by
1466 	 * an optional canonical composition. Please be noted that
1467 	 * canonical composition is done only when a decomposition is
1468 	 * done.
1469 	 */
1470 	if (canonical_decomposition || compatibility_decomposition) {
1471 		if (sz == 1) {
1472 			*state = U8_STATE_START;
1473 
1474 			saved_sz = 1;
1475 
1476 			comb_class[0] = 0;
1477 			start[0] = 0;
1478 			disp[0] = 1;
1479 
1480 			last = 1;
1481 		} else {
1482 			saved_sz = do_decomp(uv, u8s, u8s, sz,
1483 			    canonical_decomposition, state);
1484 
1485 			last = 0;
1486 
1487 			for (i = 0; i < saved_sz; ) {
1488 				sz = u8_number_of_bytes[u8s[i]];
1489 
1490 				comb_class[last] = combining_class(uv,
1491 				    u8s + i, sz);
1492 				start[last] = i;
1493 				disp[last] = sz;
1494 
1495 				last++;
1496 				i += sz;
1497 			}
1498 
1499 			/*
1500 			 * Decomposition yields various Hangul related
1501 			 * states but not on combining marks. We need to
1502 			 * find out at here by checking on the last
1503 			 * character.
1504 			 */
1505 			if (*state == U8_STATE_START) {
1506 				if (comb_class[last - 1])
1507 					*state = U8_STATE_COMBINING_MARK;
1508 			}
1509 		}
1510 
1511 		saved_last = last;
1512 
1513 		while (s < slast) {
1514 			sz = u8_number_of_bytes[*s];
1515 
1516 			/*
1517 			 * If this is an illegal character, an incomplete
1518 			 * character, or an 7-bit ASCII Starter character,
1519 			 * then we have collected a sequence; break and let
1520 			 * the next call deal with the two cases.
1521 			 *
1522 			 * Note that this is okay only if you are using this
1523 			 * function with a fixed length string, not on
1524 			 * a buffer with multiple calls of one chunk at a time.
1525 			 */
1526 			if (sz <= 1) {
1527 				break;
1528 			} else if ((s + sz) > slast) {
1529 				break;
1530 			} else {
1531 				/*
1532 				 * If the previous character was a Hangul Jamo
1533 				 * and this character is a Hangul Jamo that
1534 				 * can be conjoined, we collect the Jamo.
1535 				 */
1536 				if (*s == U8_HANGUL_JAMO_1ST_BYTE) {
1537 					U8_PUT_3BYTES_INTO_UTF32(u1,
1538 					    *s, *(s + 1), *(s + 2));
1539 
1540 					if (U8_HANGUL_COMPOSABLE_L_V(*state,
1541 					    u1)) {
1542 						i = 0;
1543 						*state = U8_STATE_HANGUL_LV;
1544 						goto COLLECT_A_HANGUL;
1545 					}
1546 
1547 					if (U8_HANGUL_COMPOSABLE_LV_T(*state,
1548 					    u1)) {
1549 						i = 0;
1550 						*state = U8_STATE_HANGUL_LVT;
1551 						goto COLLECT_A_HANGUL;
1552 					}
1553 				}
1554 
1555 				/*
1556 				 * Regardless of whatever it was, if this is
1557 				 * a Starter, we don't collect the character
1558 				 * since that's a new start and we will deal
1559 				 * with it at the next time.
1560 				 */
1561 				i = combining_class(uv, s, sz);
1562 				if (i == U8_COMBINING_CLASS_STARTER)
1563 					break;
1564 
1565 				/*
1566 				 * We know the current character is a combining
1567 				 * mark. If the previous character wasn't
1568 				 * a Starter (not Hangul) or a combining mark,
1569 				 * then, we don't collect this combining mark.
1570 				 */
1571 				if (*state != U8_STATE_START &&
1572 				    *state != U8_STATE_COMBINING_MARK)
1573 					break;
1574 
1575 				*state = U8_STATE_COMBINING_MARK;
1576 COLLECT_A_HANGUL:
1577 				/*
1578 				 * If we collected a Starter and combining
1579 				 * marks up to 30, i.e., total 31 characters,
1580 				 * then, we terminate this degenerately long
1581 				 * combining sequence with a U+034F COMBINING
1582 				 * GRAPHEME JOINER (CGJ) which is 0xCD 0x8F in
1583 				 * UTF-8 and turn this into a Stream-Safe
1584 				 * Text. This will be extremely rare but
1585 				 * possible.
1586 				 *
1587 				 * The following will also guarantee that
1588 				 * we are not writing more than 32 characters
1589 				 * plus a NULL at u8s[].
1590 				 */
1591 				if (last >= U8_UPPER_LIMIT_IN_A_SEQ) {
1592 TURN_STREAM_SAFE:
1593 					*state = U8_STATE_START;
1594 					comb_class[last] = 0;
1595 					start[last] = saved_sz;
1596 					disp[last] = 2;
1597 					last++;
1598 
1599 					u8s[saved_sz++] = 0xCD;
1600 					u8s[saved_sz++] = 0x8F;
1601 
1602 					break;
1603 				}
1604 
1605 				/*
1606 				 * Some combining marks also do decompose into
1607 				 * another combining mark or marks.
1608 				 */
1609 				if (*state == U8_STATE_COMBINING_MARK) {
1610 					k = last;
1611 					l = sz;
1612 					i = do_decomp(uv, uts, s, sz,
1613 					    canonical_decomposition, state);
1614 					for (j = 0; j < i; ) {
1615 						sz = u8_number_of_bytes[uts[j]];
1616 
1617 						comb_class[last] =
1618 						    combining_class(uv,
1619 						    uts + j, sz);
1620 						start[last] = saved_sz + j;
1621 						disp[last] = sz;
1622 
1623 						last++;
1624 						if (last >=
1625 						    U8_UPPER_LIMIT_IN_A_SEQ) {
1626 							last = k;
1627 							goto TURN_STREAM_SAFE;
1628 						}
1629 						j += sz;
1630 					}
1631 
1632 					*state = U8_STATE_COMBINING_MARK;
1633 					sz = i;
1634 					s += l;
1635 
1636 					for (i = 0; i < sz; i++)
1637 						u8s[saved_sz++] = uts[i];
1638 				} else {
1639 					comb_class[last] = i;
1640 					start[last] = saved_sz;
1641 					disp[last] = sz;
1642 					last++;
1643 
1644 					for (i = 0; i < sz; i++)
1645 						u8s[saved_sz++] = *s++;
1646 				}
1647 
1648 				/*
1649 				 * If this is U+0345 COMBINING GREEK
1650 				 * YPOGEGRAMMENI (0xCD 0x85 in UTF-8), a.k.a.,
1651 				 * iota subscript, and need to be converted to
1652 				 * uppercase letter, convert it to U+0399 GREEK
1653 				 * CAPITAL LETTER IOTA (0xCE 0x99 in UTF-8),
1654 				 * i.e., convert to capital adscript form as
1655 				 * specified in the Unicode standard.
1656 				 *
1657 				 * This is the only special case of (ambiguous)
1658 				 * case conversion at combining marks and
1659 				 * probably the standard will never have
1660 				 * anything similar like this in future.
1661 				 */
1662 				if (is_it_toupper && sz >= 2 &&
1663 				    u8s[saved_sz - 2] == 0xCD &&
1664 				    u8s[saved_sz - 1] == 0x85) {
1665 					u8s[saved_sz - 2] = 0xCE;
1666 					u8s[saved_sz - 1] = 0x99;
1667 				}
1668 			}
1669 		}
1670 
1671 		/*
1672 		 * Let's try to ensure a canonical ordering for the collected
1673 		 * combining marks. We do this only if we have collected
1674 		 * at least one more non-Starter. (The decomposition mapping
1675 		 * data tables have fully (and recursively) expanded and
1676 		 * canonically ordered decompositions.)
1677 		 *
1678 		 * The U8_SWAP_COMB_MARKS() convenience macro has some
1679 		 * assumptions and we are meeting the assumptions.
1680 		 */
1681 		last--;
1682 		if (last >= saved_last) {
1683 			for (i = 0; i < last; i++)
1684 				for (j = last; j > i; j--)
1685 					if (comb_class[j] &&
1686 					    comb_class[j - 1] > comb_class[j]) {
1687 						U8_SWAP_COMB_MARKS(j - 1, j);
1688 					}
1689 		}
1690 
1691 		*source = s;
1692 
1693 		if (! canonical_composition) {
1694 			u8s[saved_sz] = '\0';
1695 			return (saved_sz);
1696 		}
1697 
1698 		/*
1699 		 * Now do the canonical composition. Note that we do this
1700 		 * only after a canonical or compatibility decomposition to
1701 		 * finish up NFC or NFKC.
1702 		 */
1703 		sz = do_composition(uv, u8s, comb_class, start, disp, last,
1704 		    &s, slast);
1705 	}
1706 
1707 	*source = s;
1708 
1709 	return ((size_t)sz);
1710 }
1711 
1712 /*
1713  * The do_norm_compare() function does string comparison based on Unicode
1714  * simple case mappings and Unicode Normalization definitions.
1715  *
1716  * It does so by collecting a sequence of character at a time and comparing
1717  * the collected sequences from the strings.
1718  *
1719  * The meanings on the return values are the same as the usual strcmp().
1720  */
1721 static int
1722 do_norm_compare(size_t uv, uchar_t *s1, uchar_t *s2, size_t n1, size_t n2,
1723     int flag, int *errnum)
1724 {
1725 	int result;
1726 	size_t sz1;
1727 	size_t sz2;
1728 	uchar_t u8s1[U8_STREAM_SAFE_TEXT_MAX + 1];
1729 	uchar_t u8s2[U8_STREAM_SAFE_TEXT_MAX + 1];
1730 	uchar_t *s1last;
1731 	uchar_t *s2last;
1732 	boolean_t is_it_toupper;
1733 	boolean_t is_it_tolower;
1734 	boolean_t canonical_decomposition;
1735 	boolean_t compatibility_decomposition;
1736 	boolean_t canonical_composition;
1737 	u8_normalization_states_t state;
1738 
1739 	s1last = s1 + n1;
1740 	s2last = s2 + n2;
1741 
1742 	is_it_toupper = flag & U8_TEXTPREP_TOUPPER;
1743 	is_it_tolower = flag & U8_TEXTPREP_TOLOWER;
1744 	canonical_decomposition = flag & U8_CANON_DECOMP;
1745 	compatibility_decomposition = flag & U8_COMPAT_DECOMP;
1746 	canonical_composition = flag & U8_CANON_COMP;
1747 
1748 	while (s1 < s1last && s2 < s2last) {
1749 		/*
1750 		 * If the current character is a 7-bit ASCII and the last
1751 		 * character, or, if the current character and the next
1752 		 * character are both some 7-bit ASCII characters then
1753 		 * we treat the current character as a sequence.
1754 		 *
1755 		 * In any other cases, we need to call collect_a_seq().
1756 		 */
1757 
1758 		if (U8_ISASCII(*s1) && ((s1 + 1) >= s1last ||
1759 		    ((s1 + 1) < s1last && U8_ISASCII(*(s1 + 1))))) {
1760 			if (is_it_toupper)
1761 				u8s1[0] = U8_ASCII_TOUPPER(*s1);
1762 			else if (is_it_tolower)
1763 				u8s1[0] = U8_ASCII_TOLOWER(*s1);
1764 			else
1765 				u8s1[0] = *s1;
1766 			u8s1[1] = '\0';
1767 			sz1 = 1;
1768 			s1++;
1769 		} else {
1770 			state = U8_STATE_START;
1771 			sz1 = collect_a_seq(uv, u8s1, &s1, s1last,
1772 			    is_it_toupper, is_it_tolower,
1773 			    canonical_decomposition,
1774 			    compatibility_decomposition,
1775 			    canonical_composition, errnum, &state);
1776 		}
1777 
1778 		if (U8_ISASCII(*s2) && ((s2 + 1) >= s2last ||
1779 		    ((s2 + 1) < s2last && U8_ISASCII(*(s2 + 1))))) {
1780 			if (is_it_toupper)
1781 				u8s2[0] = U8_ASCII_TOUPPER(*s2);
1782 			else if (is_it_tolower)
1783 				u8s2[0] = U8_ASCII_TOLOWER(*s2);
1784 			else
1785 				u8s2[0] = *s2;
1786 			u8s2[1] = '\0';
1787 			sz2 = 1;
1788 			s2++;
1789 		} else {
1790 			state = U8_STATE_START;
1791 			sz2 = collect_a_seq(uv, u8s2, &s2, s2last,
1792 			    is_it_toupper, is_it_tolower,
1793 			    canonical_decomposition,
1794 			    compatibility_decomposition,
1795 			    canonical_composition, errnum, &state);
1796 		}
1797 
1798 		/*
1799 		 * Now compare the two characters. If they are the same,
1800 		 * we move on to the next character sequences.
1801 		 */
1802 		if (sz1 == 1 && sz2 == 1) {
1803 			if (*u8s1 > *u8s2)
1804 				return (1);
1805 			if (*u8s1 < *u8s2)
1806 				return (-1);
1807 		} else {
1808 			result = strcmp((const char *)u8s1, (const char *)u8s2);
1809 			if (result != 0)
1810 				return (result);
1811 		}
1812 	}
1813 
1814 	/*
1815 	 * We compared until the end of either or both strings.
1816 	 *
1817 	 * If we reached to or went over the ends for the both, that means
1818 	 * they are the same.
1819 	 *
1820 	 * If we reached only one end, that means the other string has
1821 	 * something which then can be used to determine the return value.
1822 	 */
1823 	if (s1 >= s1last) {
1824 		if (s2 >= s2last)
1825 			return (0);
1826 		return (-1);
1827 	}
1828 	return (1);
1829 }
1830 
1831 /*
1832  * The u8_strcmp() function compares two UTF-8 strings quite similar to
1833  * the strcmp(). For the comparison, however, Unicode Normalization specific
1834  * equivalency and Unicode simple case conversion mappings based equivalency
1835  * can be requested and checked against.
1836  */
1837 int
1838 u8_strcmp(const char *s1, const char *s2, size_t n, int flag, size_t uv,
1839     int *errnum)
1840 {
1841 	int f;
1842 	size_t n1;
1843 	size_t n2;
1844 
1845 	*errnum = 0;
1846 
1847 	/*
1848 	 * Check on the requested Unicode version, case conversion, and
1849 	 * normalization flag values.
1850 	 */
1851 
1852 	if (uv > U8_UNICODE_LATEST) {
1853 		*errnum = ERANGE;
1854 		uv = U8_UNICODE_LATEST;
1855 	}
1856 
1857 	if (flag == 0) {
1858 		flag = U8_STRCMP_CS;
1859 	} else {
1860 		f = flag & (U8_STRCMP_CS | U8_STRCMP_CI_UPPER |
1861 		    U8_STRCMP_CI_LOWER);
1862 		if (f == 0) {
1863 			flag |= U8_STRCMP_CS;
1864 		} else if (f != U8_STRCMP_CS && f != U8_STRCMP_CI_UPPER &&
1865 		    f != U8_STRCMP_CI_LOWER) {
1866 			*errnum = EBADF;
1867 			flag = U8_STRCMP_CS;
1868 		}
1869 
1870 		f = flag & (U8_CANON_DECOMP | U8_COMPAT_DECOMP | U8_CANON_COMP);
1871 		if (f && f != U8_STRCMP_NFD && f != U8_STRCMP_NFC &&
1872 		    f != U8_STRCMP_NFKD && f != U8_STRCMP_NFKC) {
1873 			*errnum = EBADF;
1874 			flag = U8_STRCMP_CS;
1875 		}
1876 	}
1877 
1878 	if (flag == U8_STRCMP_CS) {
1879 		return (n == 0 ? strcmp(s1, s2) : strncmp(s1, s2, n));
1880 	}
1881 
1882 	n1 = strlen(s1);
1883 	n2 = strlen(s2);
1884 	if (n != 0) {
1885 		if (n < n1)
1886 			n1 = n;
1887 		if (n < n2)
1888 			n2 = n;
1889 	}
1890 
1891 	/*
1892 	 * Simple case conversion can be done much faster and so we do
1893 	 * them separately here.
1894 	 */
1895 	if (flag == U8_STRCMP_CI_UPPER) {
1896 		return (do_case_compare(uv, (uchar_t *)s1, (uchar_t *)s2,
1897 		    n1, n2, B_TRUE, errnum));
1898 	} else if (flag == U8_STRCMP_CI_LOWER) {
1899 		return (do_case_compare(uv, (uchar_t *)s1, (uchar_t *)s2,
1900 		    n1, n2, B_FALSE, errnum));
1901 	}
1902 
1903 	return (do_norm_compare(uv, (uchar_t *)s1, (uchar_t *)s2, n1, n2,
1904 	    flag, errnum));
1905 }
1906 
1907 size_t
1908 u8_textprep_str(char *inarray, size_t *inlen, char *outarray, size_t *outlen,
1909     int flag, size_t unicode_version, int *errnum)
1910 {
1911 	int f;
1912 	int sz;
1913 	uchar_t *ib;
1914 	uchar_t *ibtail;
1915 	uchar_t *ob;
1916 	uchar_t *obtail;
1917 	boolean_t do_not_ignore_null;
1918 	boolean_t do_not_ignore_invalid;
1919 	boolean_t is_it_toupper;
1920 	boolean_t is_it_tolower;
1921 	boolean_t canonical_decomposition;
1922 	boolean_t compatibility_decomposition;
1923 	boolean_t canonical_composition;
1924 	size_t ret_val;
1925 	size_t i;
1926 	size_t j;
1927 	uchar_t u8s[U8_STREAM_SAFE_TEXT_MAX + 1];
1928 	u8_normalization_states_t state;
1929 
1930 	if (unicode_version > U8_UNICODE_LATEST) {
1931 		*errnum = ERANGE;
1932 		return ((size_t)-1);
1933 	}
1934 
1935 	f = flag & (U8_TEXTPREP_TOUPPER | U8_TEXTPREP_TOLOWER);
1936 	if (f == (U8_TEXTPREP_TOUPPER | U8_TEXTPREP_TOLOWER)) {
1937 		*errnum = EBADF;
1938 		return ((size_t)-1);
1939 	}
1940 
1941 	f = flag & (U8_CANON_DECOMP | U8_COMPAT_DECOMP | U8_CANON_COMP);
1942 	if (f && f != U8_TEXTPREP_NFD && f != U8_TEXTPREP_NFC &&
1943 	    f != U8_TEXTPREP_NFKD && f != U8_TEXTPREP_NFKC) {
1944 		*errnum = EBADF;
1945 		return ((size_t)-1);
1946 	}
1947 
1948 	if (inarray == NULL || *inlen == 0)
1949 		return (0);
1950 
1951 	if (outarray == NULL) {
1952 		*errnum = E2BIG;
1953 		return ((size_t)-1);
1954 	}
1955 
1956 	ib = (uchar_t *)inarray;
1957 	ob = (uchar_t *)outarray;
1958 	ibtail = ib + *inlen;
1959 	obtail = ob + *outlen;
1960 
1961 	do_not_ignore_null = !(flag & U8_TEXTPREP_IGNORE_NULL);
1962 	do_not_ignore_invalid = !(flag & U8_TEXTPREP_IGNORE_INVALID);
1963 	is_it_toupper = flag & U8_TEXTPREP_TOUPPER;
1964 	is_it_tolower = flag & U8_TEXTPREP_TOLOWER;
1965 
1966 	ret_val = 0;
1967 
1968 	/*
1969 	 * If we don't have a normalization flag set, we do the simple case
1970 	 * conversion based text preparation separately below. Text
1971 	 * preparation involving Normalization will be done in the false task
1972 	 * block, again, separately since it will take much more time and
1973 	 * resource than doing simple case conversions.
1974 	 */
1975 	if (f == 0) {
1976 		while (ib < ibtail) {
1977 			if (*ib == '\0' && do_not_ignore_null)
1978 				break;
1979 
1980 			sz = u8_number_of_bytes[*ib];
1981 
1982 			if (sz < 0) {
1983 				if (do_not_ignore_invalid) {
1984 					*errnum = EILSEQ;
1985 					ret_val = (size_t)-1;
1986 					break;
1987 				}
1988 
1989 				sz = 1;
1990 				ret_val++;
1991 			}
1992 
1993 			if (sz == 1) {
1994 				if (ob >= obtail) {
1995 					*errnum = E2BIG;
1996 					ret_val = (size_t)-1;
1997 					break;
1998 				}
1999 
2000 				if (is_it_toupper)
2001 					*ob = U8_ASCII_TOUPPER(*ib);
2002 				else if (is_it_tolower)
2003 					*ob = U8_ASCII_TOLOWER(*ib);
2004 				else
2005 					*ob = *ib;
2006 				ib++;
2007 				ob++;
2008 			} else if ((ib + sz) > ibtail) {
2009 				if (do_not_ignore_invalid) {
2010 					*errnum = EINVAL;
2011 					ret_val = (size_t)-1;
2012 					break;
2013 				}
2014 
2015 				if ((obtail - ob) < (ibtail - ib)) {
2016 					*errnum = E2BIG;
2017 					ret_val = (size_t)-1;
2018 					break;
2019 				}
2020 
2021 				/*
2022 				 * We treat the remaining incomplete character
2023 				 * bytes as a character.
2024 				 */
2025 				ret_val++;
2026 
2027 				while (ib < ibtail)
2028 					*ob++ = *ib++;
2029 			} else {
2030 				if (is_it_toupper || is_it_tolower) {
2031 					i = do_case_conv(unicode_version, u8s,
2032 					    ib, sz, is_it_toupper);
2033 
2034 					if ((obtail - ob) < i) {
2035 						*errnum = E2BIG;
2036 						ret_val = (size_t)-1;
2037 						break;
2038 					}
2039 
2040 					ib += sz;
2041 
2042 					for (sz = 0; sz < i; sz++)
2043 						*ob++ = u8s[sz];
2044 				} else {
2045 					if ((obtail - ob) < sz) {
2046 						*errnum = E2BIG;
2047 						ret_val = (size_t)-1;
2048 						break;
2049 					}
2050 
2051 					for (i = 0; i < sz; i++)
2052 						*ob++ = *ib++;
2053 				}
2054 			}
2055 		}
2056 	} else {
2057 		canonical_decomposition = flag & U8_CANON_DECOMP;
2058 		compatibility_decomposition = flag & U8_COMPAT_DECOMP;
2059 		canonical_composition = flag & U8_CANON_COMP;
2060 
2061 		while (ib < ibtail) {
2062 			if (*ib == '\0' && do_not_ignore_null)
2063 				break;
2064 
2065 			/*
2066 			 * If the current character is a 7-bit ASCII
2067 			 * character and it is the last character, or,
2068 			 * if the current character is a 7-bit ASCII
2069 			 * character and the next character is also a 7-bit
2070 			 * ASCII character, then, we copy over this
2071 			 * character without going through collect_a_seq().
2072 			 *
2073 			 * In any other cases, we need to look further with
2074 			 * the collect_a_seq() function.
2075 			 */
2076 			if (U8_ISASCII(*ib) && ((ib + 1) >= ibtail ||
2077 			    ((ib + 1) < ibtail && U8_ISASCII(*(ib + 1))))) {
2078 				if (ob >= obtail) {
2079 					*errnum = E2BIG;
2080 					ret_val = (size_t)-1;
2081 					break;
2082 				}
2083 
2084 				if (is_it_toupper)
2085 					*ob = U8_ASCII_TOUPPER(*ib);
2086 				else if (is_it_tolower)
2087 					*ob = U8_ASCII_TOLOWER(*ib);
2088 				else
2089 					*ob = *ib;
2090 				ib++;
2091 				ob++;
2092 			} else {
2093 				*errnum = 0;
2094 				state = U8_STATE_START;
2095 
2096 				j = collect_a_seq(unicode_version, u8s,
2097 				    &ib, ibtail,
2098 				    is_it_toupper,
2099 				    is_it_tolower,
2100 				    canonical_decomposition,
2101 				    compatibility_decomposition,
2102 				    canonical_composition,
2103 				    errnum, &state);
2104 
2105 				if (*errnum && do_not_ignore_invalid) {
2106 					ret_val = (size_t)-1;
2107 					break;
2108 				}
2109 
2110 				if ((obtail - ob) < j) {
2111 					*errnum = E2BIG;
2112 					ret_val = (size_t)-1;
2113 					break;
2114 				}
2115 
2116 				for (i = 0; i < j; i++)
2117 					*ob++ = u8s[i];
2118 			}
2119 		}
2120 	}
2121 
2122 	*inlen = ibtail - ib;
2123 	*outlen = obtail - ob;
2124 
2125 	return (ret_val);
2126 }
2127 
2128 #if defined(_KERNEL)
2129 static int __init
2130 unicode_init(void)
2131 {
2132 	return (0);
2133 }
2134 
2135 static void __exit
2136 unicode_fini(void)
2137 {
2138 }
2139 
2140 module_init(unicode_init);
2141 module_exit(unicode_fini);
2142 #endif
2143 
2144 ZFS_MODULE_DESCRIPTION("Unicode implementation");
2145 ZFS_MODULE_AUTHOR(ZFS_META_AUTHOR);
2146 ZFS_MODULE_LICENSE(ZFS_META_LICENSE);
2147 ZFS_MODULE_VERSION(ZFS_META_VERSION "-" ZFS_META_RELEASE);
2148 
2149 EXPORT_SYMBOL(u8_validate);
2150 EXPORT_SYMBOL(u8_strcmp);
2151 EXPORT_SYMBOL(u8_textprep_str);
2152