1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123
|
.\" Hey Emacs! This file is -*- nroff -*- source.
.\"
.\" Copyright 1993 Rickard E. Faith (faith@cs.unc.edu)
.\"
.\" Permission is granted to make and distribute verbatim copies of this
.\" manual provided the copyright notice and this permission notice are
.\" preserved on all copies.
.\"
.\" Permission is granted to copy and distribute modified versions of this
.\" manual under the conditions for verbatim copying, provided that the
.\" entire resulting derived work is distributed under the terms of a
.\" permission notice identical to this one
.\"
.\" Since the Linux kernel and libraries are constantly changing, this
.\" manual page may be incorrect or out-of-date. The author(s) assume no
.\" responsibility for errors or omissions, or for damages resulting from
.\" the use of the information contained herein. The author(s) may not
.\" have taken the same level of care in the production of this manual,
.\" which is licensed free of charge, as they might when working
.\" professionally.
.\"
.\" Formatted or processed versions of this manual, if unaccompanied by
.\" the source, must acknowledge the copyright and authors of this
.\" work.
.\" Modified Fri Jan 31 16:26:07 1997 by Eric S. Raymond <esr@thyrsus.com>
.\"
.\" Translated 25 December Miguel A. Sepulveda (miguel@typhoon.harvard.edu)
.\" Modified 1 Jul 1996 Miguel A. Sepulveda (angel@vivaldi.princeton.edu)
.\" Translation fixed on Tue Apr 28 16:34:06 CEST 1998 by Gerardo
.\" Aburruzaga Garca <gerardo.aburruzaga@uca.es>
.\" Modified Fri Dec 11 17:57:27 1998 by Jamie Lokier <jamie@imbolc.ucc.ie>
.\" Translation revised on Sun Apr 4 1999 by Juan Piernas <piernas@ditec.um.es>
.\"
.TH FLOCK 2 "11 Diciembre 1998" "Linux" "Manual del Programador de Linux"
.SH NOMBRE
flock \- impone o elimina un candado de recomendacin en un fichero abierto.
.SH SINOPSIS
.B #include <sys/file.h>
.sp
.BR "int flock(int " fd ", int " operation )
.SH DESCRIPCIN
Impone o elimina un candado de recomendacin (advisory lock) en un
fichero abierto.
El fichero est especificado por
.IR fd .
Las operaciones vlidas son:
.RS
.sp
.TP 1.0i
LOCK_SH
Candado compartido. Ms de un proceso puede tener un
candado compartido para un fichero en un momento dado.
.TP
LOCK_EX
Candado exclusivo. Solamente un proceso puede tener un
candado exclusivo para un fichero en un momento dado.
.TP
LOCK_UN
Desbloqueo.
.TP
LOCK_NB
No bloquear cuando se cierre el candado. Puede especificarse (mediante
la operacin
.IR OR )
junto con otra de las operaciones.
.sp
.RE
Un fichero no puede tener simultaneamente candados compartido y exclusivo.
Es un fichero el que est encadenado (i.e., el nodo-i),
.I no
el descriptor de fichero. Por tanto,
.BR dup (2)
y
.BR fork (2)
no crean mltiples casos de un candado.
.SH "VALOR DEVUELTO"
En caso de xito, cero, En caso de error, \-1 , y
se pone en
.I errno
un cdigo apropiado.
.SH ERRORES
.TP
.B EWOULDBLOCK
El fichero est encadenado y la bandera
.B LOCK_NB
ha sido elegida.
.\".SH NOTAS
.\"En linux,
.\".B flock
.\"est implementado como una llamada a
.\".BR fcntl .
.\"Por favor vease
.\".BR fcntl (2)
.\"para ms detalles sobre errores.
.SH CONFORME A
4.4BSD (la llamada al sistema
.BR flock (2)
apareci por primera vez en 4.2BSD).
.SH NOTAS
.BR flock (2)
no impone candados en ficheros sobre NFS. Use
.BR fcntl (2)
en su lugar: funcionar sobre NFS, dada una versin suficientemente reciente
de Linux y un servidor que soporte candados.
.PP
Los candados de
.BR flock (2)
y
.BR fcntl (2)
tienen semnticas diferentes con respecto a los procesos creados con fork y
con respecto a
.BR dup (2).
.SH "VASE TAMBIN"
.BR open "(2), " close "(2), " dup "(2), " execve "(2), " fcntl "(2), "
.BR fork "(2)."
Tambin estn
.I locks.txt
y
.I mandatory.txt
en
.IR /usr/src/linux/Documentation .
|