Simple scripts to parse FreeBSD GEOM configuration and show information about disks, partitions, volumes and etc.
It doesn’t not require root privileges and runs without any additional dependencies. But, hah, it makes me feel like an old programmer because it actually consists of pure AWK code and a wrapper in Bourne shell 😉
- geom_show.awk is an awk-script which makes the job of parsing sysctl kern.geom.confxml variable
- geom_show.sh is a wrapper to make things more simple.
See geom_show on GitHub GitLab.
I hope, it can help someone to make things simpler, and, please, let me know if it doesn’t.
#!/bin/sh # Copyright (c) 2017 Mikhail Zakharov # All rights reserved. # # Redistribution and use in source and binary forms, with or without # modification, are permitted provided that the following conditions # are met: # 1. Redistributions of source code must retain the above copyright # notice, this list of conditions and the following disclaimer. # 2. Redistributions in binary form must reproduce the above copyright # notice, this list of conditions and the following disclaimer in the # documentation and/or other materials provided with the distribution. # # THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND # ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE # IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE # ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE # FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL # DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS # OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) # HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT # LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY # OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF # SUCH DAMAGE. # # Show GEOM configuration # # Typical usage: # geom_show.sh -l -c DISK # # 2017.07.25 1.0 # Defaults --------------------------------------------------------------------- ofs="," # Output Field Separator is "comma" show_headers=true # Show headers in output # ------------------------------------------------------------------------------ usage() { error_code=$1 # Error code on exit() to the caller error_text="$2" # Short error message to print usage_help="Usage: geom_show.sh -k [-s separator] List disk names known by the kernel. geom_show.sh -g [-s separator] geom_show.sh -g -c CLASS [-s separator] List GEOM provider names of all or any particular class. geom_show.sh -l -c CLASS | -p PROVIDER [-h] [-s separator] Show details of GEOM provider(s). Filter entries by CLASS or exact PROVIDER name. Suppress headers with -h key. geom_show.sh -d [-s separator] Dump raw GEOM configuration. Use [-s separator] to specify output field separator. Default is comma: (,)." [ "$error_text" ] && printf "Error: $error_text\n" printf "$usage_help\n" exit $error_code } # ----------------------------------------------------------------------------- awk="/usr/bin/awk" sed="/usr/bin/sed" sysctl="/sbin/sysctl" # Error messages -------------------------------------------------------------- err_kgld_flags="Options -k, -g, -l or -d cannot be combined together." err_no_flags="Specify -k, -g, -l or -d option to show disks configuration." err_cp_flags="Specify -c, -p flag or both." geom_show='#!/usr/bin/awk -f # Copyright (c) 2017 Mikhail Zakharov # All rights reserved. # # Redistribution and use in source and binary forms, with or without # modification, are permitted provided that the following conditions # are met: # 1. Redistributions of source code must retain the above copyright # notice, this list of conditions and the following disclaimer. # 2. Redistributions in binary form must reproduce the above copyright # notice, this list of conditions and the following disclaimer in the # documentation and/or other materials provided with the distribution. # # THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND # ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE # IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE # ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE # FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL # DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS # OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) # HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT # LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY # OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF # SUCH DAMAGE. # # Parse GEOM configuration # # Typical usage: # sysctl -n kern.geom.confxml | /path/to/geom_show.awk -v "class=DISK" # # Other options: # -v provider="ada0" Specify GEOM provider to show # -v noheader="yes" Omit header # -v short="yes" Short form prints only providers name(s) # 2017.07.25 v 1.0 BEGIN { FS = ">||<" if (!ofs) ofs = "," OFS = ofs gprov = provider gclass = class if (!gprov && !gclass) short = "yes" if (gclass && !gprov && !short && noheader != "yes") print_header(gclass) } function expanded_length(s) { gsub("\t", " ", s); return length(s) } function print_header(gclass) { common_header = "Class" ofs "Provider" ofs "Mediasize" ofs \ "Sectorsize" ofs "Stripesize" ofs "Stripeoffset" disk_header = common_header ofs "Heads" ofs "Sectors" ofs "RPM" ofs \ "Ident" ofs "Description" md_header = common_header ofs "Heads" ofs "Sectors" ofs "Compression" \ ofs "Access" ofs "Type" part_header = common_header ofs "Start" ofs "End" ofs "Index" ofs "Type" if (gclass == "DISK") print disk_header else if (gclass == "MD") print md_header else if (gclass == "PART") print part_header else print common_header } //,// { depth = expanded_length($1) if (depth == 4) if ($3 == gclass || !gclass) { # We have found requested GEOM Class in_class = 1 current_gclass = $3 } else in_class = 0 if (in_class && depth == 10) { if (gprov == $3) { # GEOM class for the given provider is detected gclass = current_gclass if (gclass && !short && noheader != "yes") print_header(gclass) } # This should be the GEOM Name gname = $3 } } // || // || // || // { if (!short && in_class && expanded_length($1) == 10) # These are common, default fields for all providers gdata = gdata ofs $3 next } // || // { if (!short && in_class && expanded_length($1) == 12) if (gclass == "DISK" || gclass == "MD") gdata = gdata ofs $3 next } // || // || // { if (!short && in_class && expanded_length($1) == 12 && gclass == "DISK") gdata = gdata ofs $3 next } // || // { if (!short && in_class && expanded_length($1) == 12 && gclass == "MD") gdata = gdata ofs $3 next } // { if (!short && in_class && expanded_length($1) == 12) if (gclass == "MD" || gclass == "PART") gdata = gdata ofs $3 next } // || // || // { if (!short && in_class && expanded_length($1) == 12 && gclass == "PART") gdata = gdata ofs $3 next } // { if (in_class && expanded_length($1) == 8) { if (!gprov || gprov == gname) if (current_gclass != "LABEL" && current_gclass != "DEV" || current_gclass == gclass) if (!short) print gclass ofs gname gdata else { if (!entry_1) printf gname else printf ofs gname entry_1 = 1 } gdata = "" } } END { if (short) printf "\n" }
UPD 2018/06/01. A small addendum to map /dev/daXX device names to SAS addresses: sas2da.sh