17c478bd9Sstevel@tonic-gate /* 27c478bd9Sstevel@tonic-gate * CDDL HEADER START 37c478bd9Sstevel@tonic-gate * 47c478bd9Sstevel@tonic-gate * The contents of this file are subject to the terms of the 5a5f69788Scraigm * Common Development and Distribution License (the "License"). 6a5f69788Scraigm * You may not use this file except in compliance with the License. 77c478bd9Sstevel@tonic-gate * 87c478bd9Sstevel@tonic-gate * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE 97c478bd9Sstevel@tonic-gate * or http://www.opensolaris.org/os/licensing. 107c478bd9Sstevel@tonic-gate * See the License for the specific language governing permissions 117c478bd9Sstevel@tonic-gate * and limitations under the License. 127c478bd9Sstevel@tonic-gate * 137c478bd9Sstevel@tonic-gate * When distributing Covered Code, include this CDDL HEADER in each 147c478bd9Sstevel@tonic-gate * file and include the License file at usr/src/OPENSOLARIS.LICENSE. 157c478bd9Sstevel@tonic-gate * If applicable, add the following below this CDDL HEADER, with the 167c478bd9Sstevel@tonic-gate * fields enclosed by brackets "[]" replaced with your own identifying 177c478bd9Sstevel@tonic-gate * information: Portions Copyright [yyyy] [name of copyright owner] 187c478bd9Sstevel@tonic-gate * 197c478bd9Sstevel@tonic-gate * CDDL HEADER END 207c478bd9Sstevel@tonic-gate */ 21a5f69788Scraigm 227c478bd9Sstevel@tonic-gate /* 23*7257d1b4Sraf * Copyright 2008 Sun Microsystems, Inc. All rights reserved. 247c478bd9Sstevel@tonic-gate * Use is subject to license terms. 257c478bd9Sstevel@tonic-gate */ 267c478bd9Sstevel@tonic-gate 277c478bd9Sstevel@tonic-gate /* Copyright (c) 1988 AT&T */ 287c478bd9Sstevel@tonic-gate /* All Rights Reserved */ 297c478bd9Sstevel@tonic-gate 30a5f69788Scraigm #pragma ident "%Z%%M% %I% %E% SMI" 31a5f69788Scraigm 327c478bd9Sstevel@tonic-gate #ifndef _C89_INTMAX32 33*7257d1b4Sraf #pragma weak _vscanf = vscanf 34*7257d1b4Sraf #pragma weak _vfscanf = vfscanf 35*7257d1b4Sraf #pragma weak _vsscanf = vsscanf 367c478bd9Sstevel@tonic-gate #endif 377c478bd9Sstevel@tonic-gate 38*7257d1b4Sraf #include "lint.h" 397c478bd9Sstevel@tonic-gate #include "file64.h" 407c478bd9Sstevel@tonic-gate #include "mtlib.h" 417c478bd9Sstevel@tonic-gate #include <stdio.h> 427c478bd9Sstevel@tonic-gate #include <stdarg.h> 437c478bd9Sstevel@tonic-gate #include <string.h> 447c478bd9Sstevel@tonic-gate #include <thread.h> 457c478bd9Sstevel@tonic-gate #include <synch.h> 467c478bd9Sstevel@tonic-gate #include "libc.h" 477c478bd9Sstevel@tonic-gate #include "stdiom.h" 487c478bd9Sstevel@tonic-gate #include "mse.h" 497c478bd9Sstevel@tonic-gate #include <stdio_ext.h> 507c478bd9Sstevel@tonic-gate 517c478bd9Sstevel@tonic-gate 527c478bd9Sstevel@tonic-gate /* 537c478bd9Sstevel@tonic-gate * 32-bit shadow functions _vscanf_c89(), _vfscanf_c89(), _vsscanf_c89() 547c478bd9Sstevel@tonic-gate * are included here. 557c478bd9Sstevel@tonic-gate * When using the c89 compiler to build 32-bit applications, the size 567c478bd9Sstevel@tonic-gate * of intmax_t is 32-bits, otherwise the size of intmax_t is 64-bits. 577c478bd9Sstevel@tonic-gate * The shadow function uses 32-bit size of intmax_t for %j conversion. 587c478bd9Sstevel@tonic-gate * The #pragma redefine_extname in <stdio.h> selects the proper routine 597c478bd9Sstevel@tonic-gate * at compile time for the user application. 607c478bd9Sstevel@tonic-gate * NOTE: the shadow function only exists in the 32-bit library. 617c478bd9Sstevel@tonic-gate */ 627c478bd9Sstevel@tonic-gate 637c478bd9Sstevel@tonic-gate int 647c478bd9Sstevel@tonic-gate #ifdef _C89_INTMAX32 /* _C89_INTMAX32 version in 32-bit libc only */ 657c478bd9Sstevel@tonic-gate _vscanf_c89(const char *fmt, va_list ap) 667c478bd9Sstevel@tonic-gate #else 677c478bd9Sstevel@tonic-gate vscanf(const char *fmt, va_list ap) 687c478bd9Sstevel@tonic-gate #endif 697c478bd9Sstevel@tonic-gate { 707c478bd9Sstevel@tonic-gate rmutex_t *lk; 717c478bd9Sstevel@tonic-gate int ret; 727c478bd9Sstevel@tonic-gate 737c478bd9Sstevel@tonic-gate FLOCKFILE(lk, stdin); 747c478bd9Sstevel@tonic-gate 757c478bd9Sstevel@tonic-gate _SET_ORIENTATION_BYTE(stdin); 767c478bd9Sstevel@tonic-gate 777c478bd9Sstevel@tonic-gate #ifdef _C89_INTMAX32 787c478bd9Sstevel@tonic-gate ret = __doscan_u(stdin, fmt, ap, _F_INTMAX32); 797c478bd9Sstevel@tonic-gate #else 807c478bd9Sstevel@tonic-gate ret = __doscan_u(stdin, fmt, ap, 0); 817c478bd9Sstevel@tonic-gate #endif 827c478bd9Sstevel@tonic-gate 837c478bd9Sstevel@tonic-gate FUNLOCKFILE(lk); 847c478bd9Sstevel@tonic-gate return (ret); 857c478bd9Sstevel@tonic-gate } 867c478bd9Sstevel@tonic-gate 877c478bd9Sstevel@tonic-gate int 887c478bd9Sstevel@tonic-gate #ifdef _C89_INTMAX32 /* _C89_INTMAX32 version in 32-bit libc only */ 897c478bd9Sstevel@tonic-gate _vfscanf_c89(FILE *iop, const char *fmt, va_list ap) 907c478bd9Sstevel@tonic-gate #else 917c478bd9Sstevel@tonic-gate vfscanf(FILE *iop, const char *fmt, va_list ap) 927c478bd9Sstevel@tonic-gate #endif 937c478bd9Sstevel@tonic-gate { 947c478bd9Sstevel@tonic-gate rmutex_t *lk; 957c478bd9Sstevel@tonic-gate int ret; 967c478bd9Sstevel@tonic-gate 977c478bd9Sstevel@tonic-gate FLOCKFILE(lk, iop); 987c478bd9Sstevel@tonic-gate 997c478bd9Sstevel@tonic-gate _SET_ORIENTATION_BYTE(iop); 1007c478bd9Sstevel@tonic-gate 1017c478bd9Sstevel@tonic-gate #ifdef _C89_INTMAX32 1027c478bd9Sstevel@tonic-gate ret = __doscan_u(iop, fmt, ap, _F_INTMAX32); 1037c478bd9Sstevel@tonic-gate #else 1047c478bd9Sstevel@tonic-gate ret = __doscan_u(iop, fmt, ap, 0); 1057c478bd9Sstevel@tonic-gate #endif 1067c478bd9Sstevel@tonic-gate FUNLOCKFILE(lk); 1077c478bd9Sstevel@tonic-gate return (ret); 1087c478bd9Sstevel@tonic-gate } 1097c478bd9Sstevel@tonic-gate 1107c478bd9Sstevel@tonic-gate int 1117c478bd9Sstevel@tonic-gate #ifdef _C89_INTMAX32 /* _C89_INTMAX32 version in 32-bit libc only */ 1127c478bd9Sstevel@tonic-gate _vsscanf_c89(const char *str, const char *fmt, va_list ap) 1137c478bd9Sstevel@tonic-gate #else 1147c478bd9Sstevel@tonic-gate vsscanf(const char *str, const char *fmt, va_list ap) 1157c478bd9Sstevel@tonic-gate #endif 1167c478bd9Sstevel@tonic-gate { 1177c478bd9Sstevel@tonic-gate FILE strbuf; 1187c478bd9Sstevel@tonic-gate 1197c478bd9Sstevel@tonic-gate /* 1207c478bd9Sstevel@tonic-gate * The dummy FILE * created for sscanf has the _IOWRT 1217c478bd9Sstevel@tonic-gate * flag set to distinguish it from scanf and fscanf 1227c478bd9Sstevel@tonic-gate * invocations. 1237c478bd9Sstevel@tonic-gate */ 1247c478bd9Sstevel@tonic-gate strbuf._flag = _IOREAD | _IOWRT; 1257c478bd9Sstevel@tonic-gate strbuf._ptr = strbuf._base = (unsigned char *)str; 1267c478bd9Sstevel@tonic-gate strbuf._cnt = strlen(str); 127a5f69788Scraigm SET_FILE(&strbuf, _NFILE); 1287c478bd9Sstevel@tonic-gate 1297c478bd9Sstevel@tonic-gate /* 1307c478bd9Sstevel@tonic-gate * Mark the stream so that routines called by __doscan_u() 1317c478bd9Sstevel@tonic-gate * do not do any locking. In particular this avoids a NULL 1327c478bd9Sstevel@tonic-gate * lock pointer being used by getc() causing a core dump. 1337c478bd9Sstevel@tonic-gate * See bugid - 1210179 program SEGV's in sscanf if linked with 1347c478bd9Sstevel@tonic-gate * the libthread. 1357c478bd9Sstevel@tonic-gate * This also makes sscanf() quicker since it does not need 1367c478bd9Sstevel@tonic-gate * to do any locking. 1377c478bd9Sstevel@tonic-gate */ 1387c478bd9Sstevel@tonic-gate if (__fsetlocking(&strbuf, FSETLOCKING_BYCALLER) == -1) { 1397c478bd9Sstevel@tonic-gate return (-1); /* this should never happen */ 1407c478bd9Sstevel@tonic-gate } 1417c478bd9Sstevel@tonic-gate 1427c478bd9Sstevel@tonic-gate /* as this stream is local to this function, no locking is be done */ 1437c478bd9Sstevel@tonic-gate #ifdef _C89_INTMAX32 1447c478bd9Sstevel@tonic-gate return (__doscan_u(&strbuf, fmt, ap, _F_INTMAX32)); 1457c478bd9Sstevel@tonic-gate #else 1467c478bd9Sstevel@tonic-gate return (__doscan_u(&strbuf, fmt, ap, 0)); 1477c478bd9Sstevel@tonic-gate #endif 1487c478bd9Sstevel@tonic-gate } 149