source: client/engine/Disk.lib @ 905ea9e

Last change on this file since 905ea9e was 20a91aa, checked in by ramon <ramongomez@…>, 13 years ago

Versión 1.0.2: función ogGetPartitionId detecta corretamente partición vacía (modifica #397).

git-svn-id: https://opengnsys.es/svn/trunk@2413 a21b9725-9963-47de-94b9-378ad31fedc9

  • Property mode set to 100755
File size: 29.0 KB
Line 
1#!/bin/bash
2#/**
3#@file    Disk.lib
4#@brief   Librería o clase Disk
5#@class   Disk
6#@brief   Funciones para gestión de discos y particiones.
7#@version 0.9
8#@warning License: GNU GPLv3+
9#*/
10
11
12#/**
13#         ogCreatePartitions int_ndisk str_parttype:int_partsize ...
14#@brief   Define el conjunto de particiones de un disco.
15#@param   int_ndisk      nº de orden del disco
16#@param   str_parttype   mnemónico del tipo de partición
17#@param   int_partsize   tamaño de la partición (en KB)
18#@return  (nada, por determinar)
19#@exception OG_ERR_FORMAT   formato incorrecto.
20#@exception OG_ERR_NOTFOUND disco o particion no detectado (no es un dispositivo).
21#@attention El nº de partición se indica por el orden de los párametros \c parttype:partsize
22#@attention Pueden definirse particiones vacías de tipo \c EMPTY
23#@attention No puede definirse partición de cache y no se modifica si existe.
24#@note    Requisitos: sfdisk, parted, partprobe, awk
25#@todo    Definir atributos (arranque, oculta) y tamaños en MB, GB, etc.
26#@version 0.9 - Primera versión para OpenGNSys
27#@author  Ramon Gomez, ETSII Universidad de Sevilla
28#@date    2009/09/09
29#@version 0.9.1 - Corrección del redondeo del tamaño del disco.
30#@author  Ramon Gomez, ETSII Universidad de Sevilla
31#@date    2010/03/09
32#*/ ##
33function ogCreatePartitions ()
34{
35# Variables locales.
36local ND DISK PART SECTORS CYLS START SIZE TYPE CACHEPART CACHESIZE EXTSTART EXTSIZE tmpsfdisk
37# Si se solicita, mostrar ayuda.
38if [ "$*" == "help" ]; then
39    ogHelp "$FUNCNAME" "$FUNCNAME int_ndisk str_parttype:int_partsize ..." \
40           "$FUNCNAME 1 NTFS:10000000 EXT3:5000000 LINUX-SWAP:1000000"
41    return
42fi
43# Error si no se reciben menos de 2 parámetros.
44[ $# -ge 2 ] || ogRaiseError $OG_ERR_FORMAT || return $?
45
46# Nº total de sectores, para evitar desbordamiento (evitar redondeo).
47ND="$1"
48DISK=$(ogDiskToDev "$ND") || return $?
49SECTORS=$(awk -v D=${DISK#/dev/} '{if ($4==D) {print $3*2}}' /proc/partitions)
50CYLS=$(sfdisk -g $DISK | cut -f2 -d" ")
51SECTORS=$[SECTORS/CYLS*CYLS-1]
52# Se recalcula el nº de sectores del disco 1, si existe partición de caché.
53CACHEPART=$(ogFindCache 2>/dev/null)
54[ "$ND" = "${CACHEPART% *}" ] && CACHESIZE=$(ogGetCacheSize 2>/dev/null | awk '{print $0*2}')
55[ -n "$CACHESIZE" ] && SECTORS=$[SECTORS-CACHESIZE]
56ENDPART3=$(sfdisk -uS -l $DISK | awk -v P="${DISK}3" '{if ($1==P) print $3}')
57# Sector de inicio (la partición 1 empieza en el sector 63).
58START=63
59PART=1
60
61# Fichero temporal de entrada para "sfdisk"
62tmpsfdisk=/tmp/sfdisk$$
63trap "rm -f $tmpsfdisk" 1 2 3 9 15
64
65echo "unit: sectors" >$tmpsfdisk
66echo                >>$tmpsfdisk
67
68# Generar fichero de entrada para "sfdisk" con las particiones.
69shift
70while [ $# -gt 0 ]; do
71    # Conservar los datos de la partición de caché.
72    if [ "$ND $PART" == "$CACHEPART" -a -n "$CACHESIZE" ]; then
73        echo "$DISK$PART : start=$[SECTORS+1], size=$CACHESIZE, Id=ca" >>$tmpsfdisk
74        PART=$[PART+1]
75    fi
76    # Leer formato de cada parámetro - Tipo:Tamaño
77    TYPE="${1%%:*}"
78    SIZE="${1#*:}"
79    # Obtener identificador de tipo de partición válido.
80    ID=$(ogFsToId "$TYPE")
81    [ "$TYPE" != "CACHE" -a -n "$ID" ] || ogRaiseError $OG_ERR_PARTITION "$TYPE" || return $?
82    # Comprobar tamaño numérico y convertir en sectores de 512 B.
83    [[ "$SIZE" == *([0-9]) ]] || ogRaiseError $OG_ERR_FORMAT "$SIZE" || return $?
84    SIZE=$[SIZE*2]
85    # Comprobar si la partición es extendida.
86    if [ $ID = 5 ]; then
87        [ $PART -gt 4 ] && ogRaiseError $OG_ERR_FORMAT && return $?
88        EXTSTART=$START
89        EXTSIZE=$SIZE
90    fi
91    # Incluir particiones lógicas dentro de la partición extendida.
92    if [ $PART = 5 ]; then
93        [ -z "$EXTSTART" ] && ogRaiseError $OG_ERR_FORMAT && return $?
94        START=$EXTSTART
95        SECTORS=$[EXTSTART+EXTSIZE]
96    fi
97    # Generar datos para la partición.
98    echo "$DISK$PART : start=$START, size=$SIZE, Id=$ID" >>$tmpsfdisk
99    # Error si se supera el nº total de sectores.
100    START=$[START+SIZE]
101    [ $START -le $SECTORS ] || ogRaiseError $OG_ERR_FORMAT "$[START/2] > $[SECTORS/2]" || return $?
102    PART=$[PART+1]
103    shift
104done
105# Si no se indican las 4 particiones primarias, definirlas como vacías, conservando la partición de caché.
106while [ $PART -le 4 ]; do
107    if [ "$ND $PART" == "$CACHEPART" -a -n "$CACHESIZE" ]; then
108        echo "$DISK$PART : start=$[SECTORS+1], size=$CACHESIZE, Id=ca" >>$tmpsfdisk
109    else
110        echo "$DISK$PART : start=0, size=0, Id=0" >>$tmpsfdisk
111    fi
112    PART=$[PART+1]
113done
114# Si se define partición extendida sin lógicas, crear particion 5 vacía.
115if [ $PART = 5 -a -n "$EXTSTART" ]; then
116    echo "${DISK}5 : start=$EXTSTART, size=$EXTSIZE, Id=0" >>$tmpsfdisk
117fi
118
119# Desmontar los sistemas de archivos del disco antes de realizar las operaciones.
120ogUnmountAll $ND 2>/dev/null
121[ -n "$CACHESIZE" ] && ogUnmountCache 2>/dev/null
122
123# Si la tabla de particiones no es valida, volver a generarla.
124[ $(parted -s $DISK print >/dev/null) ] || fdisk $DISK <<< "w"
125# Definir particiones y notificar al kernel.
126sfdisk -f $DISK < $tmpsfdisk 2>/dev/null && partprobe $DISK
127rm -f $tmpsfdisk
128[ -n "$CACHESIZE" ] && ogMountCache 2>/dev/null
129}
130
131
132#/**
133#         ogDevToDisk path_device
134#@brief   Devuelve el nº de orden de dicso (y partición) correspondiente al nombre de fichero de dispositivo.
135#@param   path_device Camino del fichero de dispositivo.
136#@return  int_ndisk (para dispositivo de disco)
137#@return  int_ndisk int_npartition (para dispositivo de partición).
138#@exception OG_ERR_FORMAT   Formato incorrecto.
139#@exception OG_ERR_NOTFOUND Dispositivo no detectado.
140#@note    Requisitos: awk
141#@version 0.1 -  Integracion para Opengnsys  -  EAC: DiskEAC() en ATA.lib
142#@author  Antonio J. Doblas Viso, Universidad de Malaga
143#@date    2008/10/27
144#@version 0.9 - Primera version para OpenGNSys
145#@author  Ramon Gomez, ETSII Universidad Sevilla
146#@date    2009/07/20
147#*/ ##
148function ogDevToDisk ()
149{
150# Variables locales.
151local d n
152# Si se solicita, mostrar ayuda.
153if [ "$*" == "help" ]; then
154    ogHelp "$FUNCNAME" "$FUNCNAME path_device" \
155           "$FUNCNAME /dev/sda  =>  1 1"
156    return
157fi
158
159# Error si no se recibe 1 parámetro.
160[ $# == 1 ] || ogRaiseError $OG_ERR_FORMAT || return $?
161# Error si no es fichero de bloques.
162[ -b "$1" ] || ogRaiseError $OG_ERR_NOTFOUND "$1" || return $?
163
164# Procesa todos los discos para devolver su nº de orden y de partición.
165n=1
166for d in $(ogDiskToDev); do
167    [ -n "$(echo $1 | grep $d)" ] && echo "$n ${1#$d}" && return
168    n=$[n+1]
169done
170ogRaiseError $OG_ERR_NOTFOUND "$1"
171return $OG_ERR_NOTFOUND
172}
173
174
175#/**
176#         ogDiskToDev [int_ndisk [int_npartition]]
177#@brief   Devuelve la equivalencia entre el nº de orden del dispositivo (dicso o partición) y el nombre de fichero de dispositivo correspondiente.
178#@param   int_ndisk      nº de orden del disco
179#@param   int_npartition nº de orden de la partición
180#@return  Para 0 parametros: Devuelve los nombres de ficheros  de los dispositivos sata/ata/usb linux encontrados.
181#@return  Para 1 parametros: Devuelve la ruta del disco duro indicado.
182#@return  Para 2 parametros: Devuelve la ruta de la particion indicada.
183#@exception OG_ERR_FORMAT   Formato incorrecto.
184#@exception OG_ERR_NOTFOUND Dispositivo no detectado.
185#@note    Requisitos: awk, lvm
186#@version 0.1 -  Integracion para Opengnsys  -  EAC: Disk() en ATA.lib;  HIDRA: DetectarDiscos.sh
187#@author Ramon Gomez, ETSII Universidad de Sevilla
188#@Date    2008/06/19
189#@author  Antonio J. Doblas Viso, Universidad de Malaga
190#@date    2008/10/27
191#@version 0.9 - Primera version para OpenGNSys
192#@author  Ramon Gomez, ETSII Universidad Sevilla
193#@date    2009-07-20
194#*/ ##
195function ogDiskToDev ()
196{
197# Variables locales
198local ALLDISKS VOLGROUPS DISK PART
199
200# Si se solicita, mostrar ayuda.
201if [ "$*" == "help" ]; then
202    ogHelp "$FUNCNAME" "$FUNCNAME int_ndisk [int_npartition]" \
203           "$FUNCNAME      =>  /dev/sda /dev/sdb" \
204           "$FUNCNAME 1    =>  /dev/sda" \
205           "$FUNCNAME 1 1  =>  /dev/sda1"
206    return
207fi
208
209# Listar dispositivo para los discos duros (tipos: 3=hd, 8=sd).
210ALLDISKS=$(awk '($1==3 || $1==8) && $4!~/[0-9]/ {printf "/dev/%s ",$4}' /proc/partitions)
211VOLGROUPS=$(vgs -a --noheadings 2>/dev/null | awk '{printf "/dev/%s ",$1}')
212ALLDISKS="$ALLDISKS $VOLGROUPS"
213
214# Mostrar salidas segun el número de parametros.
215case $# in
216    0)  # Muestra todos los discos, separados por espacios.
217        echo $ALLDISKS
218        ;;
219    1)  # Error si el parámetro no es un digito.
220        [ -z "${1/[1-9]/}" ] || ogRaiseError $OG_ERR_FORMAT || return $?
221        DISK=$(echo "$ALLDISKS" | awk -v n=$1 '{print $n}')
222        # Error si el fichero no existe.
223        [ -e "$DISK" ] || ogRaiseError $OG_ERR_NOTFOUND "$1" || return $?
224        echo "$DISK"
225        ;;
226    2)  # Error si los 2 parámetros no son digitos.
227        [ -z "${1/[1-9]/}" -a -z "${2/[1-9]/}" ] || ogRaiseError $OG_ERR_FORMAT|| return $?
228        DISK=$(echo "$ALLDISKS" | awk -v n=$1 '{print $n}')
229        [ -e "$DISK" ] || ogRaiseError $OG_ERR_NOTFOUND "$1" || return $?
230        PART="$DISK$2"
231        # Comprobar si es partición.
232        if [ -b "$PART" ]; then
233            echo "$PART"
234        elif [ -n "$VOLGROUPS" ]; then
235            # Comprobar si volumen lógico.      /* (comentario Doxygen)
236            PART=$(lvscan -a 2>/dev/null | grep "'$DISK/" | awk -v n=$2 -F\' '{if (NR==n) print $2}')
237            [ -e "$PART" ] || ogRaiseError $OG_ERR_NOTFOUND "$1 $2" || return $?
238            #                                   (comentario Doxygen) */
239            echo "$PART"
240        else
241            ogRaiseError $OG_ERR_NOTFOUND "$1 $2" || return $?
242        fi
243        ;;
244    *)  # Formato erroneo.
245        ogRaiseError $OG_ERR_FORMAT
246        return $OG_ERR_FORMAT
247        ;;
248esac
249}
250
251
252#/**
253#         ogFsToId str_fstype
254#@brief   Devuelve el identificador de partición correspondiente a un tipo de sistema de archivos.
255#@param   str_fstype  mnemónico de tipo de sistema de archivos
256#@return  int_idpart  nº identificador de tipo de partición.
257#@exception OG_ERR_FORMAT   Formato incorrecto.
258#@version 0.1 -  Integracion para Opengnsys  -  EAC: TypeFS () en ATA.lib
259#@author  Antonio J. Doblas Viso, Universidad de Malaga
260#@date    2008/10/27
261#@version 0.9 - Primera version para OpenGNSys
262#@author  Ramon Gomez, ETSII Universidad Sevilla
263#@date    2009-12-14
264#*/ ##
265function ogFsToId ()
266{
267# Variables locales
268local ID
269
270# Si se solicita, mostrar ayuda.
271if [ "$*" == "help" ]; then
272    ogHelp "$FUNCNAME" "$FUNCNAME str_fstype" "$FUNCNAME EXT3  =>  83"
273    return
274fi
275# Error si no se recibe 1 parámetro.
276[ $# == 1 ] || ogRaiseError $OG_ERR_FORMAT || return $?
277
278# Asociar id. de partición para su mnemónico de sistema de archivos.
279case "$1" in
280    EMPTY)      ID=0  ;;
281    FAT12)      ID=1  ;;
282    EXTENDED)   ID=5  ;;
283    FAT16)      ID=6  ;;
284    NTFS|EXFAT) ID=7  ;;
285    FAT32)      ID=b  ;;
286    HFAT12)     ID=11 ;;
287    HFAT16)     ID=16 ;;
288    HNTFS)      ID=17 ;;
289    HFAT32)     ID=1b ;;
290    LINUX-SWAP) ID=82 ;;
291    EXT[234]|REISERFS|REISER4|XFS|JFS)
292                ID=83 ;;
293    LINUX-LVM)  ID=8e ;;
294    SOLARIS)    ID=bf ;;
295    CACHE)      ID=ca ;;
296    LINUX-RAID) ID=fd ;;
297    *)          ID="" ;;
298esac
299echo $ID
300}
301
302
303#/**
304#         ogGetDiskSize int_ndisk
305#@brief   Muestra el tamaño en KB de un disco.
306#@param   int_ndisk   nº de orden del disco
307#@return  int_size  - Tamaño en KB del disco.
308#@exception OG_ERR_FORMAT   formato incorrecto.
309#@exception OG_ERR_NOTFOUND disco o particion no detectado (no es un dispositivo).
310#@note    Requisitos: sfdisk, awk
311#@version 0.9.2 - Primera version para OpenGnSys
312#@author  Ramon Gomez, ETSII Universidad de Sevilla
313#@date    2010/09/15
314#*/ ##
315function ogGetDiskSize ()
316{
317# Variables locales.
318local DISK
319
320# Si se solicita, mostrar ayuda.
321if [ "$*" == "help" ]; then
322    ogHelp "$FUNCNAME" "$FUNCNAME int_ndisk" "$FUNCNAME 1  => 244198584"
323    return
324fi
325# Error si no se recibe 1 parámetro.
326[ $# == 1 ] || ogRaiseError $OG_ERR_FORMAT || return $?
327
328# Obtener el tamaño de la partición.
329DISK="$(ogDiskToDev $1)" || return $?
330sfdisk -s $DISK
331}
332
333
334#/**
335#         ogGetDiskType path_device
336#@brief   Muestra el tipo de disco (real, RAID, meta-disco, etc.).
337#@warning Función en pruebas
338#*/ ##
339function ogGetDiskType ()
340{
341local DEV MAJOR TYPE
342
343# Obtener el driver del dispositivo de bloques.
344[ -b "$1" ] || ogRaiseError $OG_ERR_FORMAT || return $?
345DEV=${1#/dev/}
346MAJOR=$(awk -v D="$DEV" '{if ($4==D) print $1;}' /proc/partitions)
347TYPE=$(awk -v D=$MAJOR '/Block/ {bl=1} {if ($1==D&&bl) print toupper($2)}' /proc/devices)
348# Devolver mnemónico del driver de dispositivo.
349case "$TYPE" in
350    SD)            TYPE="DISK" ;;
351    SR|IDE*)       TYPE="CDROM" ;;         # FIXME Comprobar discos IDE.
352    MD|CCISS*)     TYPE="RAID" ;;
353    DEVICE-MAPPER) TYPE="MAPPER" ;;        # FIXME Comprobar LVM y RAID.
354esac
355echo $TYPE
356}
357
358
359#/**
360#         ogGetPartitionActive int_ndisk
361#@brief   Muestra que particion de un disco esta marcada como de activa.
362#@param   int_ndisk   nº de orden del disco
363#@return  int_npart   Nº de partición activa
364#@exception OG_ERR_FORMAT Formato incorrecto.
365#@exception OG_ERR_NOTFOUND Disco o particion no corresponden con un dispositivo.
366#@note    Requisitos: parted
367#@todo    Queda definir formato para atributos (arranque, oculta, ...).
368#@version 0.9 - Primera version compatible con OpenGNSys.
369#@author  Ramon Gomez, ETSII Universidad de Sevilla
370#@date    2009/09/17
371#*/ ##
372function ogGetPartitionActive ()
373{
374# Variables locales
375local DISK
376
377# Si se solicita, mostrar ayuda.
378if [ "$*" == "help" ]; then
379    ogHelp "$FUNCNAME" "$FUNCNAME int_ndisk" "$FUNCNAME 1  =>  1"
380    return
381fi
382# Error si no se recibe 1 parámetro.
383[ $# == 1 ] || ogRaiseError $OG_ERR_FORMAT || return $?
384
385# Comprobar que el disco existe y listar su partición activa.
386DISK="$(ogDiskToDev $1)" || return $?
387parted $DISK print 2>/dev/null | awk '/boot/ {print $1}'
388}
389
390
391#/**
392#         ogGetPartitionId int_ndisk int_npartition
393#@brief   Devuelve el mnemónico con el tipo de partición.
394#@param   int_ndisk      nº de orden del disco
395#@param   int_npartition nº de orden de la partición
396#@return  Identificador de tipo de partición.
397#@exception OG_ERR_FORMAT   Formato incorrecto.
398#@exception OG_ERR_NOTFOUND Disco o partición no corresponde con un dispositivo.
399#@note    Requisitos: sfdisk
400#@version 0.9 - Primera versión compatible con OpenGnSys.
401#@author  Ramon Gomez, ETSII Universidad de Sevilla
402#@date    25/03/2009
403#@version 1.0.2 - Detectar partición vacía.
404#@author  Ramon Gomez, ETSII Universidad de Sevilla
405#@date    23/12/2011
406#*/ ##
407function ogGetPartitionId ()
408{
409# Variables locales.
410local DISK ID
411
412# Si se solicita, mostrar ayuda.
413if [ "$*" == "help" ]; then
414    ogHelp "$FUNCNAME" "$FUNCNAME int_ndisk int_npartition" \
415           "$FUNCNAME 1 1  =>  7"
416    return
417fi
418# Error si no se reciben 2 parámetros.
419[ $# == 2 ] || ogRaiseError $OG_ERR_FORMAT || return $?
420
421# Detectar id. de tipo de partición y codificar al mnemónico.
422DISK=$(ogDiskToDev $1) || return $?
423ID=$(sfdisk --id $DISK $2 2>/dev/null) || ogRaiseError $OG_ERR_NOTFOUND "$1,$2" || return $?
424echo $ID
425}
426
427
428#/**
429#         ogGetPartitionSize int_ndisk int_npartition
430#@brief   Muestra el tamano en KB de una particion determinada.
431#@param   int_ndisk      nº de orden del disco
432#@param   int_npartition nº de orden de la partición
433#@return  int_partsize - Tamaño en KB de la partición.
434#@exception OG_ERR_FORMAT   formato incorrecto.
435#@exception OG_ERR_NOTFOUND disco o particion no detectado (no es un dispositivo).
436#@note    Requisitos: sfdisk, awk
437#@version 0.1 -  Integracion para Opengnsys  -  EAC: SizePartition () en ATA.lib
438#@author  Antonio J. Doblas Viso, Universidad de Malaga
439#@date    2008/10/27
440#@version 0.9 - Primera version para OpenGNSys
441#@author  Ramon Gomez, ETSII Universidad de Sevilla
442#@date    2009/07/24
443#*/ ##
444function ogGetPartitionSize ()
445{
446# Variables locales.
447local DISK PART
448
449# Si se solicita, mostrar ayuda.
450if [ "$*" == "help" ]; then
451    ogHelp "$FUNCNAME" "$FUNCNAME int_ndisk int_npartition" \
452           "$FUNCNAME 1 1  =>  10000000"
453    return
454fi
455# Error si no se reciben 2 parámetros.
456[ $# == 2 ] || ogRaiseError $OG_ERR_FORMAT || return $?
457
458# Obtener el tamaño de la partición.
459DISK="$(ogDiskToDev $1)" || return $?
460PART="$(ogDiskToDev $1 $2)" || return $?
461case "$(ogGetPartitionId $1 $2)" in
462    5|f)  # Procesar detección de tamaño de partición Extendida.
463          sfdisk -l $DISK 2>/dev/null | \
464                    awk -v p=$PART '{if ($1==p) {sub (/[^0-9]+/,"",$5); print $5} }'
465          ;;
466    *)    sfdisk -s $PART
467          ;;
468esac
469}
470
471
472#/**
473#         ogGetPartitionType int_ndisk int_npartition
474#@brief   Muestra el tipo de una particion determinada.
475#@see     ogGetFsType
476#*/ ##
477function ogGetPartitionType ()
478{
479ogGetFsType "$@"
480}
481
482
483#/**
484#         ogHidePartition int_ndisk int_npartition
485#@brief   Oculta un apartición visible.
486#@param   int_ndisk      nº de orden del disco
487#@param   int_npartition nº de orden de la partición
488#@return  (nada)
489#@exception OG_ERR_FORMAT    formato incorrecto.
490#@exception OG_ERR_NOTFOUND  disco o particion no detectado (no es un dispositivo).
491#@exception OG_ERR_PARTITION tipo de partición no reconocido.
492#@version 1.0 - Versión en pruebas.
493#@author  Ramon Gomez, ETSII Universidad de Sevilla
494#@date    2010/01/12
495#*/ ##
496function ogHidePartition ()
497{
498# Variables locales.
499local PART TYPE NEWTYPE
500# Si se solicita, mostrar ayuda.
501if [ "$*" == "help" ]; then
502    ogHelp "$FUNCNAME" "$FUNCNAME int_ndisk int_npartition" \
503           "$FUNCNAME 1 1"
504    return
505fi
506# Error si no se reciben 2 parámetros.
507[ $# == 2 ] || ogRaiseError $OG_ERR_FORMAT || return $?
508PART=$(ogDiskToDev "$1" "$2") || return $?
509
510# Obtener tipo de partición.
511TYPE=$(ogGetPartitionType "$1" "$2")
512case "$TYPE" in
513    NTFS)   NEWTYPE="HNTFS"  ;;
514    FAT32)  NEWTYPE="HFAT32" ;;
515    FAT16)  NEWTYPE="HFAT16" ;;
516    FAT12)  NEWTYPE="HFAT12" ;;
517    *)      ogRaiseError $OG_ERR_PARTITION "$TYPE"
518            return $? ;;
519esac
520# Cambiar tipo de partición.
521ogSetPartitionId $1 $2 $NEWTYPE
522}
523
524
525#/**
526#         ogListPartitions int_ndisk
527#@brief   Lista las particiones definidas en un disco.
528#@param   int_ndisk  nº de orden del disco
529#@return  str_parttype:int_partsize ...
530#@exception OG_ERR_FORMAT   formato incorrecto.
531#@exception OG_ERR_NOTFOUND disco o particion no detectado (no es un dispositivo).
532#@note    Requisitos: \c parted \c awk
533#@attention El nº de partición se indica por el orden de los párametros \c parttype:partsize
534#@attention Las tuplas de valores están separadas por espacios.
535#@version 0.9 - Primera versión para OpenGNSys
536#@author  Ramon Gomez, ETSII Universidad de Sevilla
537#@date    2009/07/24
538#*/ ##
539function ogListPartitions ()
540{
541# Variables locales.
542local DISK PART NPARTS TYPE SIZE
543
544# Si se solicita, mostrar ayuda.
545if [ "$*" == "help" ]; then
546    ogHelp "$FUNCNAME" "$FUNCNAME int_ndisk" \
547           "$FUNCNAME 1  =>  NTFS:10000000 EXT3:5000000 LINUX-SWAP:1000000"
548    return
549fi
550# Error si no se recibe 1 parámetro.
551[ $# == 1 ] || ogRaiseError $OG_ERR_FORMAT "$FORMAT" || return $?
552
553# Procesar la salida de \c parted .
554DISK="$(ogDiskToDev $1)" || return $?
555NPARTS=$(ogGetPartitionsNumber $1)
556for (( PART = 1; PART <= NPARTS; PART++ )); do
557    TYPE=$(ogGetFsType $1 $PART 2>/dev/null)
558    if [ $? -eq 0 ]; then
559        SIZE=$(ogGetPartitionSize $1 $PART 2>/dev/null)
560        echo -n "$TYPE:$SIZE "
561    else
562        echo -n "EMPTY:0 "
563    fi
564done
565echo
566}
567
568
569#/**
570#         ogListPrimaryPartitions int_ndisk
571#@brief   Metafunción que lista las particiones primarias no vacías definidas en un disco.
572#@param   int_ndisk  nº de orden del disco
573#@see     ogListPartitions
574#*/ ##
575function ogListPrimaryPartitions ()
576{
577# Variables locales.
578local PARTS
579
580PARTS=$(ogListPartitions "$@") || return $?
581echo $PARTS | cut -sf1-4 -d" " | sed 's/\( EMPTY:0\)*$//'
582}
583
584
585#/**
586#         ogListLogicalPartitions int_ndisk
587#@brief   Metafunción que lista las particiones lógicas definidas en un disco.
588#@param   int_ndisk  nº de orden del disco
589#@see     ogListPartitions
590#*/ ##
591function ogListLogicalPartitions ()
592{
593# Variables locales.
594local PARTS
595
596PARTS=$(ogListPartitions "$@") || return $?
597echo $PARTS | cut -sf5- -d" "
598}
599
600
601#/**
602#         ogSetPartitionActive int_ndisk int_npartition
603#@brief   Establece cual es la partición activa de un disco.
604#@param   int_ndisk      nº de orden del disco
605#@param   int_npartition nº de orden de la partición
606#@return  (nada).
607#@exception OG_ERR_FORMAT   Formato incorrecto.
608#@exception OG_ERR_NOTFOUND Disco o partición no corresponden con un dispositivo.
609#@note    Requisitos: parted
610#@version 0.1 -  Integracion para Opengnsys  -  EAC: SetPartitionActive() en ATA.lib
611#@author  Antonio J. Doblas Viso, Universidad de Malaga
612#@date    2008/10/27
613#@version 0.9 - Primera version compatible con OpenGNSys.
614#@author  Ramon Gomez, ETSII Universidad de Sevilla
615#@date    2009/09/17
616#*/ ##
617function ogSetPartitionActive ()
618{
619# Variables locales
620local DISK PART
621
622# Si se solicita, mostrar ayuda.
623if [ "$*" == "help" ]; then
624    ogHelp "$FUNCNAME" "$FUNCNAME int_ndisk int_npartition" \
625           "$FUNCNAME 1 1"
626    return
627fi
628# Error si no se reciben 2 parámetros.
629[ $# == 2 ] || ogRaiseError $OG_ERR_FORMAT || return $?
630
631# Comprobar que el disco existe y activar la partición indicada.
632DISK="$(ogDiskToDev $1)" || return $?
633PART="$(ogDiskToDev $1 $2)" || return $?
634parted -s $DISK set $2 boot on 2>/dev/null
635}
636
637
638#/**
639#         ogSetPartitionSize int_ndisk int_npartition int_size
640#@brief   Muestra el tamano en KB de una particion determinada.
641#@param  int_ndisk      nº de orden del disco
642#@param   int_npartition nº de orden de la partición
643#@param   int_size       tamaño de la partición (en KB)
644#@return  (nada)
645#@exception OG_ERR_FORMAT   formato incorrecto.
646#@exception OG_ERR_NOTFOUND disco o particion no detectado (no es un dispositivo).
647#@note    Requisitos: sfdisk, awk
648#@todo    Compruebar que el tamaño sea numérico positivo y evitar que pueda solaparse con la siguiente partición.
649#@version 0.9 - Primera versión para OpenGNSys
650#@author  Ramon Gomez, ETSII Universidad de Sevilla
651#@date    2009/07/24
652#*/ ##
653function ogSetPartitionSize ()
654{
655# Variables locales.
656local DISK PART SIZE
657
658# Si se solicita, mostrar ayuda.
659if [ "$*" == "help" ]; then
660    ogHelp "$FUNCNAME" "$FUNCNAME int_ndisk int_npartition int_size" \
661           "$FUNCNAME 1 1 10000000"
662    return
663fi
664# Error si no se reciben 3 parámetros.
665[ $# == 3 ] || ogRaiseError $OG_ERR_FORMAT || return $?
666
667# Obtener el tamaño de la partición.
668DISK="$(ogDiskToDev $1)" || return $?
669PART="$(ogDiskToDev $1 $2)" || return $?
670# Convertir tamaño en KB a sectores de 512 B.
671SIZE=$[$3*2] || ogRaiseError $OG_ERR_FORMAT || return $?
672# Redefinir el tamaño de la partición.
673sfdisk -f -uS -N$2 $DISK <<< ",$SIZE" &>/dev/null || ogRaiseError $OG_ERR_PARTITION "$1,$2" || return $?
674partprobe 2>/dev/null
675}
676
677#/**
678#         ogUnhidePartition int_ndisk int_npartition
679#@brief   Hace visible una partición oculta.
680#@param   int_ndisk      nº de orden del disco
681#@param   int_npartition nº de orden de la partición
682#@return  (nada)
683#@exception OG_ERR_FORMAT    formato incorrecto.
684#@exception OG_ERR_NOTFOUND  disco o particion no detectado (no es un dispositivo).
685#@exception OG_ERR_PARTITION tipo de partición no reconocido.
686#@version 1.0 - Versión en pruebas.
687#@author  Ramon Gomez, ETSII Universidad de Sevilla
688#@date    2010/01/12
689#*/ ##
690function ogUnhidePartition ()
691{
692# Variables locales.
693local PART TYPE NEWTYPE
694# Si se solicita, mostrar ayuda.
695if [ "$*" == "help" ]; then
696    ogHelp "$FUNCNAME" "$FUNCNAME int_ndisk int_npartition" \
697           "$FUNCNAME 1 1"
698    return
699fi
700# Error si no se reciben 2 parámetros.
701[ $# == 2 ] || ogRaiseError $OG_ERR_FORMAT || return $?
702PART=$(ogDiskToDev "$1" "$2") || return $?
703
704# Obtener tipo de partición.
705TYPE=$(ogGetPartitionType "$1" "$2")
706case "$TYPE" in
707    HNTFS)   NEWTYPE="NTFS"  ;;
708    HFAT32)  NEWTYPE="FAT32" ;;
709    HFAT16)  NEWTYPE="FAT16" ;;
710    HFAT12)  NEWTYPE="FAT12" ;;
711    *)      ogRaiseError $OG_ERR_PARTITION "$TYPE"
712            return $? ;;
713esac
714# Cambiar tipo de partición.
715ogSetPartitionId $1 $2 $NEWTYPE
716}
717
718
719#/**
720#         ogUpdatePartitionTable
721#@brief   Fuerza al kernel releer la tabla de particiones de los discos duros
722#@param   no requiere
723#@return  informacion propia de la herramienta
724#@note    Requisitos: \c partprobe
725#@warning pendiente estructurar la funcion a opengnsys
726#@version 0.1 -  Integracion para Opengnsys  -  EAC: UpdatePartitionTable() en ATA.lib
727#@author  Antonio J. Doblas Viso. Universidad de Malaga
728#@date    27/10/2008
729#*/ ##
730function ogUpdatePartitionTable ()
731{
732local i
733for i in `ogDiskToDev`
734do
735        partprobe $i
736done
737}
738
739
740
741#/**
742#         ogGetPartitionsNumber int_ndisk
743#@brief   Detecta el numero de particiones del disco duro indicado.
744#@param   int_ndisk      nº de orden del disco
745#@return  Devuelve el numero paritiones del disco duro indicado
746#@warning Salidas de errores no determinada
747#@attention Requisitos: parted
748#@note    Notas sin especificar
749#@version 0.1 -  Integracion para Opengnsys  -  EAC:  DetectNumberPartition () en ATA.lib
750#@author  Antonio J. Doblas Viso. Universidad de Malaga
751#@date    Date: 27/10/2008
752#@version 1.0 - Uso de sfdisk Primera version para OpenGnSys
753#@author  Ramon Gomez, ETSII Universidad de Sevilla
754#@date    2009/07/24
755#*/ ##
756function ogGetPartitionsNumber ()
757{
758           #local disco totalpart
759           #disco=`ogDiskToDev $1`
760           #totalpart=`parted $disco print | egrep ^" [0123456789] " -c`
761           #echo $totalpart
762local DISK
763# Contar el nº de veces que aparece el disco en su lista de particiones.
764DISK=$(ogDiskToDev $1) 2>/dev/null
765sfdisk -l $DISK 2>/dev/null | grep -c "^$DISK"
766}
767
768
769#/**  @function ogDiskToRelativeDev: @brief Traduce los ID de discos o particiones EAC a ID Linux relativos, es decir 1 1 => sda1
770#@param  Admite 1 parametro:   $1  int_numdisk
771#@param  Admite 2 parametro:   $1   int_numdisk                    $2  int_partition
772#@return  Para 1 parametros traduce Discos Duros: Devuelve la ruta relativa linux del disco duro indicado con nomenclatura EAC.........ejemplo: IdPartition 1 => sda
773#@return  Para 2 parametros traduce Particiones: Devuelve la ruta relativa linux de la particion indicado con nomenclatura EAC...........  ejemplo: IdPartition  2 1 => sdb1
774#@warning  No definidas
775#@attention
776#@note    Notas sin especificar
777#@version 0.1 -  Integracion para Opengnsys  -  EAC:  IdPartition en ATA.lib
778#@author  Antonio J. Doblas Viso. Universidad de Malaga
779#@date    27/10/2008
780#*/
781function ogDiskToRelativeDev () {
782if [ $# = 0 ]
783then
784        Msg "Info: Traduce el identificador del dispositivo EAC a dispositivo linux \n" info
785        Msg "Sintaxis1: IdPartition int_disk -----------------Ejemplo1: IdPartition 1 -> sda " example
786        Msg "Sintaxis2: IdPartition int_disk int_partition  --Ejemplo2: IdPartition 1 2 -> sda2 " example
787
788return
789fi
790#PART="$(Disk|cut -f$1 -d' ')$2"    # se comenta esta linea porque doxygen no reconoce la funcion disk y no crea los enlaces y referencias correctas.
791PART=$(ogDiskToDev|cut -f$1 -d' ')$2
792echo $PART | cut -f3 -d \/
793}
794
795#/**  @function ogDeletePartitionTable: @brief Borra la tabla de particiones del disco.
796#@param $1 opcion A (identificador LINUX)       str_ID_linux (/dev/sda)
797#@param $1 opcion B (Identifiador EAC)                  int_numdiskEAC(1)
798#@return   la informacion propia del fdisk
799#@warning    no definidos
800#@attention
801#@note
802#@version 0.1 -  Integracion para Opengnsys  -  EAC:  DeletePartitionTable () en ATA.lib
803#@author  Antonio J. Doblas Viso. Universidad de Malaga
804#@date    27/10/2008
805#*/
806function ogDeletePartitionTable () {
807if [ $# = 0 ]
808then
809        Msg "sintaxis1: ogDeletePartitionTable int_disk" red
810        Msg "sintaxis2: ogDeletePartitionTable str_/dev/sdX" red
811        return
812fi
813if [ -n "${1%/dev/*}" ]
814        then
815        dev=`DiskToDev $1`
816        else
817        dev=$1
818fi
819echo -ne "o\nw" | fdisk $dev
820}
821
822
823#/**  @function ogSetPartitionId: @brief Cambia el identificador de la particion, pero no su sistema de archivos.
824#@param  $1 int_numdiskEAC
825#@param  $2 int_numpartitionEAC
826#@param  $3 str_tipoPartition admite EXT2 EXT3 NTFS FAT32 SWAP CACHE
827#@return   la propia del fdisk
828#@warning    no controla los parametros, si se introducen mal o simplemente no se introducen no muestra mensaje
829#@warning    Identifica por nombre del sistema de archivos no por número
830#@attention Requisitos:  fdisk
831#@note
832#@version 0.1 -  Integracion para Opengnsys  - SetPartitionType() en ATA.lib
833#@author  Antonio J. Doblas Viso. Universidad de Malaga
834#@date    27/10/2008
835#*/
836function ogSetPartitionId() {
837# Variables locales
838local DISK PART ID
839
840# Si se solicita, mostrar ayuda.
841if [ "$*" == "help" ]; then
842    ogHelp "$FUNCNAME" "$FUNCNAME int_ndisk int_npartition str_type" \
843           "$FUNCNAME 1 1 NTFS"
844    return
845fi
846# Error si no se reciben 3 parámetros.
847[ $# == 3 ] || ogRaiseError $OG_ERR_FORMAT || return $?
848
849# Sustituye nº de disco por su dispositivo.
850DISK=`ogDiskToDev $1` || return $?
851PART=`ogDiskToDev $1 $2` || return $?
852
853# Elección del tipo de partición.
854ID=$(ogFsToId "$3")
855[ -n "$ID" ] || ogRaiseError $OG_ERR_PARTITION "$3" || return $?
856
857echo -ne "t\n$2\n${ID}\nw\n" | fdisk $DISK 1>/dev/null 2>&1
858}
859
860
861#/**  @function ogDeletePartitionsLabels: @brief Elimina la informacion que tiene el kernel del cliente og sobre los labels de los sistemas de archivos
862#@param  No requiere
863#@return   Nada
864#@warning
865#@attention Requisitos:  comando interno linux rm
866#@note
867#@version 0.1 -  Integracion para Opengnsys  -  EAC:   DeletePartitionTable()  en ATA.lib
868#@author  Antonio J. Doblas Viso. Universidad de Malaga
869#@date    27/10/2008
870#*/
871function ogDeletePartitionsLabels () {
872rm /dev/disk/by-label/*    # */ COMENTARIO OBLIGATORIO PARA DOXYGEN
873}
874
Note: See TracBrowser for help on using the repository browser.