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 58dc347dbStz204579 * Common Development and Distribution License (the "License"). 68dc347dbStz204579 * 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 /* 228dc347dbStz204579 * Copyright 2007 Sun Microsystems, Inc. All rights reserved. 237c478bd9Sstevel@tonic-gate * Use is subject to license terms. 247c478bd9Sstevel@tonic-gate */ 257c478bd9Sstevel@tonic-gate 267c478bd9Sstevel@tonic-gate #pragma ident "%Z%%M% %I% %E% SMI" 277c478bd9Sstevel@tonic-gate 287c478bd9Sstevel@tonic-gate /* 297c478bd9Sstevel@tonic-gate * Adr memory based translations 307c478bd9Sstevel@tonic-gate */ 317c478bd9Sstevel@tonic-gate 327c478bd9Sstevel@tonic-gate #include <stdio.h> 337c478bd9Sstevel@tonic-gate #include <sys/types.h> 347c478bd9Sstevel@tonic-gate #include <bsm/audit.h> 357c478bd9Sstevel@tonic-gate #include <bsm/audit_record.h> 367c478bd9Sstevel@tonic-gate 377c478bd9Sstevel@tonic-gate void 387c478bd9Sstevel@tonic-gate adrm_start(adr_t *adr, char *p) 397c478bd9Sstevel@tonic-gate { 407c478bd9Sstevel@tonic-gate adr->adr_stream = p; 417c478bd9Sstevel@tonic-gate adr->adr_now = p; 427c478bd9Sstevel@tonic-gate } 437c478bd9Sstevel@tonic-gate 447c478bd9Sstevel@tonic-gate /* 457c478bd9Sstevel@tonic-gate * adrm_char - pull out characters 467c478bd9Sstevel@tonic-gate */ 477c478bd9Sstevel@tonic-gate void 487c478bd9Sstevel@tonic-gate adrm_char(adr_t *adr, char *cp, int count) 497c478bd9Sstevel@tonic-gate { 508dc347dbStz204579 while (count-- > 0) 517c478bd9Sstevel@tonic-gate *cp++ = *adr->adr_now++; 527c478bd9Sstevel@tonic-gate } 537c478bd9Sstevel@tonic-gate 547c478bd9Sstevel@tonic-gate /* 557c478bd9Sstevel@tonic-gate * adrm_short - pull out shorts 567c478bd9Sstevel@tonic-gate */ 577c478bd9Sstevel@tonic-gate void 587c478bd9Sstevel@tonic-gate adrm_short(adr_t *adr, short *sp, int count) 597c478bd9Sstevel@tonic-gate { 608dc347dbStz204579 while (count-- > 0) { 617c478bd9Sstevel@tonic-gate *sp = *adr->adr_now++ << 8; 627c478bd9Sstevel@tonic-gate *sp++ += ((short)*adr->adr_now++) & 0x00ff; 637c478bd9Sstevel@tonic-gate } 647c478bd9Sstevel@tonic-gate } 657c478bd9Sstevel@tonic-gate 667c478bd9Sstevel@tonic-gate /* 677c478bd9Sstevel@tonic-gate * adrm_int32 - pull out int 687c478bd9Sstevel@tonic-gate */ 697c478bd9Sstevel@tonic-gate void adrm_int(adr_t *adr, int32_t *lp, int count); 707c478bd9Sstevel@tonic-gate void adrm_long(adr_t *adr, int32_t *lp, int count); 717c478bd9Sstevel@tonic-gate #pragma weak adrm_int = adrm_int32 727c478bd9Sstevel@tonic-gate #pragma weak adrm_long = adrm_int32 737c478bd9Sstevel@tonic-gate 747c478bd9Sstevel@tonic-gate void 757c478bd9Sstevel@tonic-gate adrm_int32(adr_t *adr, int32_t *lp, int count) 767c478bd9Sstevel@tonic-gate { 777c478bd9Sstevel@tonic-gate int i; 787c478bd9Sstevel@tonic-gate 798dc347dbStz204579 for (; count-- > 0; lp++) { 807c478bd9Sstevel@tonic-gate *lp = 0; 817c478bd9Sstevel@tonic-gate for (i = 0; i < 4; i++) { 827c478bd9Sstevel@tonic-gate *lp <<= 8; 837c478bd9Sstevel@tonic-gate *lp += ((int32_t)*adr->adr_now++) & 0x000000ff; 847c478bd9Sstevel@tonic-gate } 857c478bd9Sstevel@tonic-gate } 867c478bd9Sstevel@tonic-gate } 877c478bd9Sstevel@tonic-gate 887c478bd9Sstevel@tonic-gate void 89*a7746f66Stz204579 adrm_uid(adr_t *adr, uid_t *up, int count) 90*a7746f66Stz204579 { 91*a7746f66Stz204579 int i; 92*a7746f66Stz204579 93*a7746f66Stz204579 for (; count-- > 0; up++) { 94*a7746f66Stz204579 *up = 0; 95*a7746f66Stz204579 for (i = 0; i < 4; i++) { 96*a7746f66Stz204579 *up <<= 8; 97*a7746f66Stz204579 *up += ((uid_t)*adr->adr_now++) & 0x000000ff; 98*a7746f66Stz204579 } 99*a7746f66Stz204579 } 100*a7746f66Stz204579 } 101*a7746f66Stz204579 102*a7746f66Stz204579 void 1037c478bd9Sstevel@tonic-gate adrm_int64(adr_t *adr, int64_t *lp, int count) 1047c478bd9Sstevel@tonic-gate { 1057c478bd9Sstevel@tonic-gate int i; 1067c478bd9Sstevel@tonic-gate 1078dc347dbStz204579 for (; count-- > 0; lp++) { 1087c478bd9Sstevel@tonic-gate *lp = 0; 1097c478bd9Sstevel@tonic-gate for (i = 0; i < 8; i++) { 1107c478bd9Sstevel@tonic-gate *lp <<= 8; 1117c478bd9Sstevel@tonic-gate *lp += ((int64_t)*adr->adr_now++) & 0x00000000000000ff; 1127c478bd9Sstevel@tonic-gate } 1137c478bd9Sstevel@tonic-gate } 1147c478bd9Sstevel@tonic-gate } 1157c478bd9Sstevel@tonic-gate 1167c478bd9Sstevel@tonic-gate void adrm_u_int(adr_t *adr, uint32_t *cp, int count); 1177c478bd9Sstevel@tonic-gate void adrm_u_long(adr_t *adr, uint32_t *cp, int count); 1187c478bd9Sstevel@tonic-gate #pragma weak adrm_u_int = adrm_u_int32 1197c478bd9Sstevel@tonic-gate #pragma weak adrm_u_long = adrm_u_int32 1207c478bd9Sstevel@tonic-gate 1217c478bd9Sstevel@tonic-gate void 1227c478bd9Sstevel@tonic-gate adrm_u_int32(adr_t *adr, uint32_t *cp, int count) 1237c478bd9Sstevel@tonic-gate { 1247c478bd9Sstevel@tonic-gate adrm_int32(adr, (int32_t *)cp, count); 1257c478bd9Sstevel@tonic-gate } 1267c478bd9Sstevel@tonic-gate 1277c478bd9Sstevel@tonic-gate void 1287c478bd9Sstevel@tonic-gate adrm_u_char(adr_t *adr, uchar_t *cp, int count) 1297c478bd9Sstevel@tonic-gate { 1307c478bd9Sstevel@tonic-gate adrm_char(adr, (char *)cp, count); 1317c478bd9Sstevel@tonic-gate } 1327c478bd9Sstevel@tonic-gate 1337c478bd9Sstevel@tonic-gate void 1347c478bd9Sstevel@tonic-gate adrm_u_int64(adr_t *adr, uint64_t *lp, int count) 1357c478bd9Sstevel@tonic-gate { 1367c478bd9Sstevel@tonic-gate adrm_int64(adr, (int64_t *)lp, count); 1377c478bd9Sstevel@tonic-gate } 1387c478bd9Sstevel@tonic-gate 1397c478bd9Sstevel@tonic-gate void 1407c478bd9Sstevel@tonic-gate adrm_u_short(adr_t *adr, ushort_t *sp, int count) 1417c478bd9Sstevel@tonic-gate { 1427c478bd9Sstevel@tonic-gate adrm_short(adr, (short *)sp, count); 1437c478bd9Sstevel@tonic-gate } 1447c478bd9Sstevel@tonic-gate 1457c478bd9Sstevel@tonic-gate /* 1467c478bd9Sstevel@tonic-gate * adrm_putint32 - pack in int32 1477c478bd9Sstevel@tonic-gate */ 1487c478bd9Sstevel@tonic-gate #pragma weak adrm_putint = adrm_putint32 1497c478bd9Sstevel@tonic-gate #pragma weak adrm_putlong = adrm_putint32 1507c478bd9Sstevel@tonic-gate void 1517c478bd9Sstevel@tonic-gate adrm_putint32(adr_t *adr, int32_t *lp, int count) 1527c478bd9Sstevel@tonic-gate { 1537c478bd9Sstevel@tonic-gate int i; /* index for counting */ 1547c478bd9Sstevel@tonic-gate int32_t l; /* value for shifting */ 1557c478bd9Sstevel@tonic-gate 1567c478bd9Sstevel@tonic-gate for (; count-- > 0; lp++) { 1577c478bd9Sstevel@tonic-gate for (i = 0, l = *lp; i < 4; i++) { 1587c478bd9Sstevel@tonic-gate *adr->adr_now++ = (char)((l & (int32_t)0xff000000) >> 1597c478bd9Sstevel@tonic-gate (int)24); 1607c478bd9Sstevel@tonic-gate l <<= (int)8; 1617c478bd9Sstevel@tonic-gate } 1627c478bd9Sstevel@tonic-gate } 1637c478bd9Sstevel@tonic-gate } 164