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
5*92402265SMarek Pospisil * Common Development and Distribution License (the "License").
6*92402265SMarek Pospisil * 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 */
217c478bd9Sstevel@tonic-gate /*
22*92402265SMarek Pospisil * Copyright (c) 1992, 2010, Oracle and/or its affiliates. All rights reserved.
237c478bd9Sstevel@tonic-gate */
247c478bd9Sstevel@tonic-gate
257c478bd9Sstevel@tonic-gate /*
267c478bd9Sstevel@tonic-gate * Adr memory based encoding
277c478bd9Sstevel@tonic-gate */
287c478bd9Sstevel@tonic-gate
297c478bd9Sstevel@tonic-gate #include <sys/feature_tests.h>
307c478bd9Sstevel@tonic-gate
317c478bd9Sstevel@tonic-gate #pragma weak adr_ushort = adr_short
327c478bd9Sstevel@tonic-gate #pragma weak adr_uint32 = adr_int32
337c478bd9Sstevel@tonic-gate #pragma weak adr_uint64 = adr_int64
347c478bd9Sstevel@tonic-gate #pragma weak adr_getushort = adr_getshort
357c478bd9Sstevel@tonic-gate #pragma weak adr_getuint32 = adr_getint32
367c478bd9Sstevel@tonic-gate #pragma weak adr_getuint64 = adr_getint64
377c478bd9Sstevel@tonic-gate
387c478bd9Sstevel@tonic-gate #include <sys/types.h>
397c478bd9Sstevel@tonic-gate #include <sys/t_lock.h>
407c478bd9Sstevel@tonic-gate #include <sys/systm.h>
417c478bd9Sstevel@tonic-gate #include <sys/mutex.h>
427c478bd9Sstevel@tonic-gate #include <sys/thread.h>
437c478bd9Sstevel@tonic-gate #include <c2/audit.h>
447c478bd9Sstevel@tonic-gate #include <c2/audit_kernel.h>
457c478bd9Sstevel@tonic-gate #include <c2/audit_record.h>
467c478bd9Sstevel@tonic-gate
477c478bd9Sstevel@tonic-gate void
adr_start(adr_t * adr,char * p)487c478bd9Sstevel@tonic-gate adr_start(adr_t *adr, char *p)
497c478bd9Sstevel@tonic-gate {
507c478bd9Sstevel@tonic-gate adr->adr_stream = p;
517c478bd9Sstevel@tonic-gate adr->adr_now = p;
527c478bd9Sstevel@tonic-gate }
537c478bd9Sstevel@tonic-gate
547c478bd9Sstevel@tonic-gate int
adr_count(adr_t * adr)557c478bd9Sstevel@tonic-gate adr_count(adr_t *adr)
567c478bd9Sstevel@tonic-gate {
577c478bd9Sstevel@tonic-gate return ((int)((uintptr_t)adr->adr_now - (uintptr_t)adr->adr_stream));
587c478bd9Sstevel@tonic-gate }
597c478bd9Sstevel@tonic-gate
607c478bd9Sstevel@tonic-gate
617c478bd9Sstevel@tonic-gate /*
627c478bd9Sstevel@tonic-gate * adr_char - pull out characters
637c478bd9Sstevel@tonic-gate */
647c478bd9Sstevel@tonic-gate void
adr_char(adr_t * adr,char * cp,int count)657c478bd9Sstevel@tonic-gate adr_char(adr_t *adr, char *cp, int count)
667c478bd9Sstevel@tonic-gate {
677c478bd9Sstevel@tonic-gate while (count-- > 0)
687c478bd9Sstevel@tonic-gate *adr->adr_now++ = *cp++;
697c478bd9Sstevel@tonic-gate }
707c478bd9Sstevel@tonic-gate
717c478bd9Sstevel@tonic-gate /*
727c478bd9Sstevel@tonic-gate * adr_short - pull out shorts
737c478bd9Sstevel@tonic-gate */
747c478bd9Sstevel@tonic-gate void
adr_short(adr_t * adr,short * sp,int count)757c478bd9Sstevel@tonic-gate adr_short(adr_t *adr, short *sp, int count)
767c478bd9Sstevel@tonic-gate {
777c478bd9Sstevel@tonic-gate
787c478bd9Sstevel@tonic-gate for (; count-- > 0; sp++) {
797c478bd9Sstevel@tonic-gate *adr->adr_now++ = (char)((*sp >> (int)8) & 0x00ff);
807c478bd9Sstevel@tonic-gate *adr->adr_now++ = (char)(*sp & 0x00ff);
817c478bd9Sstevel@tonic-gate }
827c478bd9Sstevel@tonic-gate }
837c478bd9Sstevel@tonic-gate
847c478bd9Sstevel@tonic-gate /*
857c478bd9Sstevel@tonic-gate * adr_int32 - pull out int32
867c478bd9Sstevel@tonic-gate */
877c478bd9Sstevel@tonic-gate void
adr_int32(adr_t * adr,int32_t * lp,int count)887c478bd9Sstevel@tonic-gate adr_int32(adr_t *adr, int32_t *lp, int count)
897c478bd9Sstevel@tonic-gate {
907c478bd9Sstevel@tonic-gate int i; /* index for counting */
917c478bd9Sstevel@tonic-gate int32_t l; /* value for shifting */
927c478bd9Sstevel@tonic-gate
937c478bd9Sstevel@tonic-gate for (; count-- > 0; lp++) {
947c478bd9Sstevel@tonic-gate for (i = 0, l = *lp; i < 4; i++) {
957c478bd9Sstevel@tonic-gate *adr->adr_now++ = (char)((l & (int32_t)0xff000000) >>
967c478bd9Sstevel@tonic-gate (int)24);
977c478bd9Sstevel@tonic-gate l <<= (int)8;
987c478bd9Sstevel@tonic-gate }
997c478bd9Sstevel@tonic-gate }
1007c478bd9Sstevel@tonic-gate }
1017c478bd9Sstevel@tonic-gate
1027c478bd9Sstevel@tonic-gate /*
1037c478bd9Sstevel@tonic-gate * adr_int64 - pull out int64
1047c478bd9Sstevel@tonic-gate */
1057c478bd9Sstevel@tonic-gate void
adr_int64(adr_t * adr,int64_t * lp,int count)1067c478bd9Sstevel@tonic-gate adr_int64(adr_t *adr, int64_t *lp, int count)
1077c478bd9Sstevel@tonic-gate {
1087c478bd9Sstevel@tonic-gate int i; /* index for counting */
1097c478bd9Sstevel@tonic-gate int64_t l; /* value for shifting */
1107c478bd9Sstevel@tonic-gate
1117c478bd9Sstevel@tonic-gate for (; count-- > 0; lp++) {
1127c478bd9Sstevel@tonic-gate for (i = 0, l = *lp; i < 8; i++) {
1137c478bd9Sstevel@tonic-gate *adr->adr_now++ =
114*92402265SMarek Pospisil (char)((l & (int64_t)0xff00000000000000) >>
115*92402265SMarek Pospisil (int)56);
1167c478bd9Sstevel@tonic-gate l <<= (int)8;
1177c478bd9Sstevel@tonic-gate }
1187c478bd9Sstevel@tonic-gate }
1197c478bd9Sstevel@tonic-gate }
1207c478bd9Sstevel@tonic-gate
1217c478bd9Sstevel@tonic-gate
1227c478bd9Sstevel@tonic-gate char *
adr_getchar(adr_t * adr,char * cp)1237c478bd9Sstevel@tonic-gate adr_getchar(adr_t *adr, char *cp)
1247c478bd9Sstevel@tonic-gate {
1257c478bd9Sstevel@tonic-gate char *old;
1267c478bd9Sstevel@tonic-gate
1277c478bd9Sstevel@tonic-gate old = adr->adr_now;
1287c478bd9Sstevel@tonic-gate *cp = *adr->adr_now++;
1297c478bd9Sstevel@tonic-gate return (old);
1307c478bd9Sstevel@tonic-gate }
1317c478bd9Sstevel@tonic-gate
1327c478bd9Sstevel@tonic-gate char *
adr_getshort(adr_t * adr,short * sp)1337c478bd9Sstevel@tonic-gate adr_getshort(adr_t *adr, short *sp)
1347c478bd9Sstevel@tonic-gate {
1357c478bd9Sstevel@tonic-gate char *old;
1367c478bd9Sstevel@tonic-gate
1377c478bd9Sstevel@tonic-gate old = adr->adr_now;
1387c478bd9Sstevel@tonic-gate *sp = *adr->adr_now++;
1397c478bd9Sstevel@tonic-gate *sp >>= (int)8;
1407c478bd9Sstevel@tonic-gate *sp = *adr->adr_now++;
1417c478bd9Sstevel@tonic-gate *sp >>= (int)8;
1427c478bd9Sstevel@tonic-gate return (old);
1437c478bd9Sstevel@tonic-gate }
1447c478bd9Sstevel@tonic-gate
1457c478bd9Sstevel@tonic-gate char *
adr_getint32(adr_t * adr,int32_t * lp)1467c478bd9Sstevel@tonic-gate adr_getint32(adr_t *adr, int32_t *lp)
1477c478bd9Sstevel@tonic-gate {
1487c478bd9Sstevel@tonic-gate char *old;
1497c478bd9Sstevel@tonic-gate int i;
1507c478bd9Sstevel@tonic-gate
1517c478bd9Sstevel@tonic-gate old = adr->adr_now;
1527c478bd9Sstevel@tonic-gate for (i = 0; i < 4; i++) {
1537c478bd9Sstevel@tonic-gate *lp <<= 8;
1547c478bd9Sstevel@tonic-gate *lp += ((int32_t)*adr->adr_now++) & 0x000000ff;
1557c478bd9Sstevel@tonic-gate
1567c478bd9Sstevel@tonic-gate }
1577c478bd9Sstevel@tonic-gate return (old);
1587c478bd9Sstevel@tonic-gate }
1597c478bd9Sstevel@tonic-gate
1607c478bd9Sstevel@tonic-gate char *
adr_getint64(adr_t * adr,int64_t * lp)1617c478bd9Sstevel@tonic-gate adr_getint64(adr_t *adr, int64_t *lp)
1627c478bd9Sstevel@tonic-gate {
1637c478bd9Sstevel@tonic-gate char *old;
1647c478bd9Sstevel@tonic-gate int i;
1657c478bd9Sstevel@tonic-gate
1667c478bd9Sstevel@tonic-gate old = adr->adr_now;
1677c478bd9Sstevel@tonic-gate for (i = 0; i < 8; i++) {
1687c478bd9Sstevel@tonic-gate *lp <<= 8;
1697c478bd9Sstevel@tonic-gate *lp += ((int64_t)*adr->adr_now++) & 0x00000000000000ff;
1707c478bd9Sstevel@tonic-gate }
1717c478bd9Sstevel@tonic-gate return (old);
1727c478bd9Sstevel@tonic-gate }
173