* Copyright (c) 1990 Jan-Simon Pendry
* Copyright (c) 1990 Imperial College of Science, Technology & Medicine
* Copyright (c) 1990, 1993
* The Regents of the University of California. All rights reserved.
* This code is derived from software contributed to Berkeley by
* Jan-Simon Pendry at Imperial College, London.
* %sccs.include.redist.c%
* @(#)mtab_aix.c 8.1 (Berkeley) %G%
* $Id: mtab_aix.c,v 5.2.2.1 1992/02/09 15:10:07 jsp beta $
#ifdef READ_MTAB_AIX3_STYLE
static struct mntent
*mnt_dup(mp
)
struct mntent
*new_mp
= ALLOC(mntent
);
new_mp
->mnt_fsname
= strdup(vmt2dataptr(mp
, VMT_OBJECT
));
new_mp
->mnt_dir
= strdup(vmt2dataptr(mp
, VMT_STUB
));
new_mp
->mnt_opts
= strdup(vmt2dataptr(mp
, VMT_ARGS
));
switch (mp
->vmt_gfstype
) {
case MNT_JFS
: ty
= MTAB_TYPE_UFS
; break;
new_mp
->mnt_fsname
= str3cat(new_mp
->mnt_fsname
,
vmt2dataptr(mp
, VMT_HOSTNAME
),
":", new_mp
->mnt_fsname
);
default: ty
= "unknown"; break;
new_mp
->mnt_type
= strdup(ty
);
new_mp
->mnt_passno
= mp
->vmt_vfsnumber
;
* Read a mount table into memory
* First figure out size of mount table
* and allocate space for a copy...
* Then get mount table for real.
ret
= mntctl(MCTL_QUERY
, sizeof(i
), &i
);
ret
= mntctl(MCTL_QUERY
, i
, mntinfo
);
plog(XLOG_ERROR
, "mntctl: %m");
/*dlog("mntctl returns %d structures", ret);*/
for (i
= 0, cp
= mntinfo
; i
< ret
; i
++, cp
+= vp
->vmt_length
) {
vp
= (struct vmount
*) cp
;
* Copy the data returned by mntctl
(*mpp
)->mnt
= mnt_dup(vp
);
#endif /* READ_MTAB_AIX3_STYLE */