Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
L
linux
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
linux
Commits
5bdbe23a
Commit
5bdbe23a
authored
Nov 23, 2007
by
Linus Torvalds
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Import 2.3.25pre3
parent
a3b4d222
Changes
31
Expand all
Hide whitespace changes
Inline
Side-by-side
Showing
31 changed files
with
736 additions
and
863 deletions
+736
-863
MAINTAINERS
MAINTAINERS
+2
-0
drivers/net/wan/cycx_drv.c
drivers/net/wan/cycx_drv.c
+100
-181
drivers/net/wan/cycx_main.c
drivers/net/wan/cycx_main.c
+4
-9
drivers/net/wan/cycx_x25.c
drivers/net/wan/cycx_x25.c
+119
-51
drivers/sound/es1370.c
drivers/sound/es1370.c
+2
-2
drivers/sound/es1371.c
drivers/sound/es1371.c
+2
-2
drivers/sound/esssolo1.c
drivers/sound/esssolo1.c
+1
-1
drivers/sound/sonicvibes.c
drivers/sound/sonicvibes.c
+1
-1
fs/file.c
fs/file.c
+2
-2
fs/ncpfs/dir.c
fs/ncpfs/dir.c
+58
-32
fs/ncpfs/ncplib_kernel.h
fs/ncpfs/ncplib_kernel.h
+6
-5
fs/nfs/dir.c
fs/nfs/dir.c
+22
-40
fs/open.c
fs/open.c
+1
-1
fs/super.c
fs/super.c
+3
-3
fs/udf/balloc.c
fs/udf/balloc.c
+1
-11
fs/udf/dir.c
fs/udf/dir.c
+4
-3
fs/udf/directory.c
fs/udf/directory.c
+2
-2
fs/udf/file.c
fs/udf/file.c
+31
-11
fs/udf/inode.c
fs/udf/inode.c
+93
-22
fs/udf/lowlevel.c
fs/udf/lowlevel.c
+7
-6
fs/udf/misc.c
fs/udf/misc.c
+0
-22
fs/udf/namei.c
fs/udf/namei.c
+88
-121
fs/udf/super.c
fs/udf/super.c
+9
-6
fs/udf/udfdecl.h
fs/udf/udfdecl.h
+2
-2
fs/udf/udfend.h
fs/udf/udfend.h
+4
-4
fs/udf/udftime.c
fs/udf/udftime.c
+76
-263
include/linux/cycx_drv.h
include/linux/cycx_drv.h
+6
-8
include/linux/if_arp.h
include/linux/if_arp.h
+2
-0
include/linux/udf_167.h
include/linux/udf_167.h
+8
-0
include/linux/udf_fs.h
include/linux/udf_fs.h
+2
-2
net/sunrpc/clnt.c
net/sunrpc/clnt.c
+78
-50
No files found.
MAINTAINERS
View file @
5bdbe23a
...
@@ -903,6 +903,8 @@ S: Maintained
...
@@ -903,6 +903,8 @@ S: Maintained
UDF FILESYSTEM
UDF FILESYSTEM
P: Ben Fennema
P: Ben Fennema
M: bfennema@falcon.csc.calpoly.edu
M: bfennema@falcon.csc.calpoly.edu
P: Dave Boynton
M: dave@trylinux.com
L: linux_udf@hootie.lvld.hp.com
L: linux_udf@hootie.lvld.hp.com
W: http://www.trylinux.com/projects/udf/index.html
W: http://www.trylinux.com/projects/udf/index.html
S: Maintained
S: Maintained
...
...
drivers/net/wan/cycx_drv.c
View file @
5bdbe23a
This diff is collapsed.
Click to expand it.
drivers/net/wan/cycx_main.c
View file @
5bdbe23a
/*
/*
* cycx_main.c Cyclades Cyclom
X Multiprotocol
WAN Link Driver. Main module.
* cycx_main.c Cyclades Cyclom
2X
WAN Link Driver. Main module.
*
*
* Author: Arnaldo Carvalho de Melo <acme@conectiva.com.br>
* Author: Arnaldo Carvalho de Melo <acme@conectiva.com.br>
*
*
...
@@ -40,7 +40,7 @@
...
@@ -40,7 +40,7 @@
#ifdef MODULE
#ifdef MODULE
MODULE_AUTHOR
(
"Arnaldo Carvalho de Melo"
);
MODULE_AUTHOR
(
"Arnaldo Carvalho de Melo"
);
MODULE_DESCRIPTION
(
"Cycl
ades Sync Cards
Driver."
);
MODULE_DESCRIPTION
(
"Cycl
om 2X Sync Card
Driver."
);
#endif
#endif
/* Defines & Macros */
/* Defines & Macros */
...
@@ -73,7 +73,7 @@ static void cycx_isr (int irq, void *dev_id, struct pt_regs *regs);
...
@@ -73,7 +73,7 @@ static void cycx_isr (int irq, void *dev_id, struct pt_regs *regs);
/* private data */
/* private data */
static
char
drvname
[]
=
"cyclomx"
;
static
char
drvname
[]
=
"cyclomx"
;
static
char
fullname
[]
=
"CYCLOM
X(tm) Multiprotocol
Driver"
;
static
char
fullname
[]
=
"CYCLOM
2X(tm) Sync Card
Driver"
;
static
char
copyright
[]
=
"(c) 1998, 1999 Arnaldo Carvalho de Melo"
;
static
char
copyright
[]
=
"(c) 1998, 1999 Arnaldo Carvalho de Melo"
;
static
int
ncards
=
CONFIG_CYCLOMX_CARDS
;
static
int
ncards
=
CONFIG_CYCLOMX_CARDS
;
static
cycx_t
*
card_array
=
NULL
;
/* adapter data space */
static
cycx_t
*
card_array
=
NULL
;
/* adapter data space */
...
@@ -214,7 +214,6 @@ static int setup (wan_device_t *wandev, wandev_conf_t *conf)
...
@@ -214,7 +214,6 @@ static int setup (wan_device_t *wandev, wandev_conf_t *conf)
card
->
hw
.
irq
=
(
conf
->
irq
==
9
)
?
2
:
conf
->
irq
;
card
->
hw
.
irq
=
(
conf
->
irq
==
9
)
?
2
:
conf
->
irq
;
card
->
hw
.
dpmbase
=
conf
->
maddr
;
card
->
hw
.
dpmbase
=
conf
->
maddr
;
card
->
hw
.
dpmsize
=
CYCX_WINDOWSIZE
;
card
->
hw
.
dpmsize
=
CYCX_WINDOWSIZE
;
card
->
hw
.
type
=
conf
->
hw_opt
[
0
];
card
->
hw
.
fwid
=
CFID_X25_2X
;
card
->
hw
.
fwid
=
CFID_X25_2X
;
card
->
lock
=
SPIN_LOCK_UNLOCKED
;
card
->
lock
=
SPIN_LOCK_UNLOCKED
;
#if LINUX_VERSION_CODE >= 0x020300
#if LINUX_VERSION_CODE >= 0x020300
...
@@ -234,9 +233,7 @@ static int setup (wan_device_t *wandev, wandev_conf_t *conf)
...
@@ -234,9 +233,7 @@ static int setup (wan_device_t *wandev, wandev_conf_t *conf)
wandev
->
dma
=
wandev
->
ioport
=
0
;
wandev
->
dma
=
wandev
->
ioport
=
0
;
wandev
->
maddr
=
(
unsigned
long
*
)
card
->
hw
.
dpmbase
;
wandev
->
maddr
=
(
unsigned
long
*
)
card
->
hw
.
dpmbase
;
wandev
->
msize
=
card
->
hw
.
dpmsize
;
wandev
->
msize
=
card
->
hw
.
dpmsize
;
wandev
->
hw_opt
[
0
]
=
card
->
hw
.
type
;
wandev
->
hw_opt
[
2
]
=
0
;
wandev
->
hw_opt
[
1
]
=
card
->
hw
.
pclk
;
wandev
->
hw_opt
[
2
]
=
card
->
hw
.
memory
;
wandev
->
hw_opt
[
3
]
=
card
->
hw
.
fwid
;
wandev
->
hw_opt
[
3
]
=
card
->
hw
.
fwid
;
/* Protocol-specific initialization */
/* Protocol-specific initialization */
...
@@ -251,7 +248,6 @@ static int setup (wan_device_t *wandev, wandev_conf_t *conf)
...
@@ -251,7 +248,6 @@ static int setup (wan_device_t *wandev, wandev_conf_t *conf)
}
}
if
(
err
)
{
if
(
err
)
{
cycx_down
(
&
card
->
hw
);
free_irq
(
irq
,
card
);
free_irq
(
irq
,
card
);
return
err
;
return
err
;
}
}
...
@@ -278,7 +274,6 @@ static int shutdown (wan_device_t *wandev)
...
@@ -278,7 +274,6 @@ static int shutdown (wan_device_t *wandev)
card
=
wandev
->
private
;
card
=
wandev
->
private
;
wandev
->
state
=
WAN_UNCONFIGURED
;
wandev
->
state
=
WAN_UNCONFIGURED
;
cycx_down
(
&
card
->
hw
);
printk
(
KERN_INFO
"%s: irq %d being freed!
\n
"
,
wandev
->
name
,
wandev
->
irq
);
printk
(
KERN_INFO
"%s: irq %d being freed!
\n
"
,
wandev
->
name
,
wandev
->
irq
);
free_irq
(
wandev
->
irq
,
card
);
free_irq
(
wandev
->
irq
,
card
);
return
0
;
return
0
;
...
...
drivers/net/wan/cycx_x25.c
View file @
5bdbe23a
This diff is collapsed.
Click to expand it.
drivers/sound/es1370.c
View file @
5bdbe23a
...
@@ -1316,7 +1316,7 @@ static int es1370_mmap(struct file *file, struct vm_area_struct *vma)
...
@@ -1316,7 +1316,7 @@ static int es1370_mmap(struct file *file, struct vm_area_struct *vma)
db
=
&
s
->
dma_adc
;
db
=
&
s
->
dma_adc
;
}
else
}
else
return
-
EINVAL
;
return
-
EINVAL
;
if
(
vma
->
vm_
offset
!=
0
)
if
(
vma
->
vm_
pgoff
!=
0
)
return
-
EINVAL
;
return
-
EINVAL
;
size
=
vma
->
vm_end
-
vma
->
vm_start
;
size
=
vma
->
vm_end
-
vma
->
vm_start
;
if
(
size
>
(
PAGE_SIZE
<<
db
->
buforder
))
if
(
size
>
(
PAGE_SIZE
<<
db
->
buforder
))
...
@@ -1840,7 +1840,7 @@ static int es1370_mmap_dac(struct file *file, struct vm_area_struct *vma)
...
@@ -1840,7 +1840,7 @@ static int es1370_mmap_dac(struct file *file, struct vm_area_struct *vma)
return
-
EINVAL
;
return
-
EINVAL
;
if
((
ret
=
prog_dmabuf_dac1
(
s
))
!=
0
)
if
((
ret
=
prog_dmabuf_dac1
(
s
))
!=
0
)
return
ret
;
return
ret
;
if
(
vma
->
vm_
offset
!=
0
)
if
(
vma
->
vm_
pgoff
!=
0
)
return
-
EINVAL
;
return
-
EINVAL
;
size
=
vma
->
vm_end
-
vma
->
vm_start
;
size
=
vma
->
vm_end
-
vma
->
vm_start
;
if
(
size
>
(
PAGE_SIZE
<<
s
->
dma_dac1
.
buforder
))
if
(
size
>
(
PAGE_SIZE
<<
s
->
dma_dac1
.
buforder
))
...
...
drivers/sound/es1371.c
View file @
5bdbe23a
...
@@ -1894,7 +1894,7 @@ static int es1371_mmap(struct file *file, struct vm_area_struct *vma)
...
@@ -1894,7 +1894,7 @@ static int es1371_mmap(struct file *file, struct vm_area_struct *vma)
db
=
&
s
->
dma_adc
;
db
=
&
s
->
dma_adc
;
}
else
}
else
return
-
EINVAL
;
return
-
EINVAL
;
if
(
vma
->
vm_
offset
!=
0
)
if
(
vma
->
vm_
pgoff
!=
0
)
return
-
EINVAL
;
return
-
EINVAL
;
size
=
vma
->
vm_end
-
vma
->
vm_start
;
size
=
vma
->
vm_end
-
vma
->
vm_start
;
if
(
size
>
(
PAGE_SIZE
<<
db
->
buforder
))
if
(
size
>
(
PAGE_SIZE
<<
db
->
buforder
))
...
@@ -2415,7 +2415,7 @@ static int es1371_mmap_dac(struct file *file, struct vm_area_struct *vma)
...
@@ -2415,7 +2415,7 @@ static int es1371_mmap_dac(struct file *file, struct vm_area_struct *vma)
return
-
EINVAL
;
return
-
EINVAL
;
if
((
ret
=
prog_dmabuf_dac1
(
s
))
!=
0
)
if
((
ret
=
prog_dmabuf_dac1
(
s
))
!=
0
)
return
ret
;
return
ret
;
if
(
vma
->
vm_
offset
!=
0
)
if
(
vma
->
vm_
pgoff
!=
0
)
return
-
EINVAL
;
return
-
EINVAL
;
size
=
vma
->
vm_end
-
vma
->
vm_start
;
size
=
vma
->
vm_end
-
vma
->
vm_start
;
if
(
size
>
(
PAGE_SIZE
<<
s
->
dma_dac1
.
buforder
))
if
(
size
>
(
PAGE_SIZE
<<
s
->
dma_dac1
.
buforder
))
...
...
drivers/sound/esssolo1.c
View file @
5bdbe23a
...
@@ -1199,7 +1199,7 @@ static int solo1_mmap(struct file *file, struct vm_area_struct *vma)
...
@@ -1199,7 +1199,7 @@ static int solo1_mmap(struct file *file, struct vm_area_struct *vma)
db
=
&
s
->
dma_adc
;
db
=
&
s
->
dma_adc
;
}
else
}
else
return
-
EINVAL
;
return
-
EINVAL
;
if
(
vma
->
vm_
offset
!=
0
)
if
(
vma
->
vm_
pgoff
!=
0
)
return
-
EINVAL
;
return
-
EINVAL
;
size
=
vma
->
vm_end
-
vma
->
vm_start
;
size
=
vma
->
vm_end
-
vma
->
vm_start
;
if
(
size
>
(
PAGE_SIZE
<<
db
->
buforder
))
if
(
size
>
(
PAGE_SIZE
<<
db
->
buforder
))
...
...
drivers/sound/sonicvibes.c
View file @
5bdbe23a
...
@@ -1516,7 +1516,7 @@ static int sv_mmap(struct file *file, struct vm_area_struct *vma)
...
@@ -1516,7 +1516,7 @@ static int sv_mmap(struct file *file, struct vm_area_struct *vma)
db
=
&
s
->
dma_adc
;
db
=
&
s
->
dma_adc
;
}
else
}
else
return
-
EINVAL
;
return
-
EINVAL
;
if
(
vma
->
vm_
offset
!=
0
)
if
(
vma
->
vm_
pgoff
!=
0
)
return
-
EINVAL
;
return
-
EINVAL
;
size
=
vma
->
vm_end
-
vma
->
vm_start
;
size
=
vma
->
vm_end
-
vma
->
vm_start
;
if
(
size
>
(
PAGE_SIZE
<<
db
->
buforder
))
if
(
size
>
(
PAGE_SIZE
<<
db
->
buforder
))
...
...
fs/file.c
View file @
5bdbe23a
...
@@ -64,7 +64,7 @@ int expand_fd_array(struct files_struct *files, int nr)
...
@@ -64,7 +64,7 @@ int expand_fd_array(struct files_struct *files, int nr)
error
=
-
EMFILE
;
error
=
-
EMFILE
;
if
(
files
->
max_fds
>=
NR_OPEN
||
nr
>
NR_OPEN
)
if
(
files
->
max_fds
>=
NR_OPEN
||
nr
>
=
NR_OPEN
)
goto
out
;
goto
out
;
nfds
=
files
->
max_fds
;
nfds
=
files
->
max_fds
;
...
@@ -88,7 +88,7 @@ int expand_fd_array(struct files_struct *files, int nr)
...
@@ -88,7 +88,7 @@ int expand_fd_array(struct files_struct *files, int nr)
if
(
nfds
>
NR_OPEN
)
if
(
nfds
>
NR_OPEN
)
nfds
=
NR_OPEN
;
nfds
=
NR_OPEN
;
}
}
}
while
(
nfds
<
nr
);
}
while
(
nfds
<
=
nr
);
error
=
-
ENOMEM
;
error
=
-
ENOMEM
;
new_fds
=
alloc_fd_array
(
nfds
);
new_fds
=
alloc_fd_array
(
nfds
);
...
...
fs/ncpfs/dir.c
View file @
5bdbe23a
...
@@ -371,24 +371,31 @@ ncp_lookup_validate(struct dentry * dentry, int flags)
...
@@ -371,24 +371,31 @@ ncp_lookup_validate(struct dentry * dentry, int flags)
static
struct
page
*
static
struct
page
*
ncp_get_cache_page
(
struct
inode
*
inode
,
unsigned
long
offset
,
int
used
)
ncp_get_cache_page
(
struct
inode
*
inode
,
unsigned
long
offset
,
int
used
)
{
{
struct
page
*
page
,
**
hash
;
struct
address_space
*
i_data
=
&
inode
->
i_data
;
struct
page
*
page_cache
;
struct
page
*
new_page
,
*
page
,
**
hash
;
hash
=
page_hash
(
&
inode
->
i_data
,
offset
);
hash
=
page_hash
(
i_data
,
offset
);
page
=
__find_lock_page
(
&
inode
->
i_data
,
offset
,
hash
);
page
=
__find_lock_page
(
i_data
,
offset
,
hash
);
if
(
used
||
page
)
if
(
used
||
page
)
return
page
;
return
page
;
page_cache
=
page_cache_alloc
();
new_page
=
page_cache_alloc
();
if
(
page_cache
)
{
if
(
!
new_page
)
page
=
page_cache
;
return
NULL
;
if
(
add_to_page_cache_unique
(
page
,
&
inode
->
i_data
,
offset
,
hash
))
{
page_cache_release
(
page
);
for
(;;)
{
page
=
NULL
;
page
=
new_page
;
page_cache_free
(
page_cache
);
if
(
!
add_to_page_cache_unique
(
page
,
i_data
,
offset
,
hash
))
break
;
page_cache_release
(
page
);
page
=
__find_lock_page
(
i_data
,
offset
,
hash
);
if
(
page
)
{
page_cache_free
(
new_page
);
break
;
}
}
}
}
return
page
;
return
page
;
}
}
...
@@ -460,6 +467,29 @@ ncp_dget_fpos(struct dentry *dentry, struct dentry *parent, unsigned long fpos)
...
@@ -460,6 +467,29 @@ ncp_dget_fpos(struct dentry *dentry, struct dentry *parent, unsigned long fpos)
return
NULL
;
return
NULL
;
}
}
static
time_t
ncp_obtain_mtime
(
struct
dentry
*
dentry
)
{
struct
inode
*
inode
=
dentry
->
d_inode
;
struct
inode
*
parent
=
dentry
->
d_parent
->
d_inode
;
struct
ncp_server
*
server
=
NCP_SERVER
(
inode
);
struct
nw_info_struct
i
;
int
len
=
dentry
->
d_name
.
len
;
__u8
__name
[
len
+
1
];
if
(
!
ncp_conn_valid
(
server
)
||
(
inode
==
inode
->
i_sb
->
s_root
->
d_inode
)
||
ncp_is_server_root
(
parent
))
return
0
;
memcpy
(
__name
,
dentry
->
d_name
.
name
,
len
);
io2vol
(
server
,
__name
,
!
ncp_preserve_case
(
parent
));
if
(
ncp_obtain_info
(
server
,
parent
,
__name
,
&
i
))
return
0
;
return
ncp_date_dos2unix
(
le16_to_cpu
(
i
.
modifyTime
),
le16_to_cpu
(
i
.
modifyDate
));
}
static
int
ncp_readdir
(
struct
file
*
filp
,
void
*
dirent
,
filldir_t
filldir
)
static
int
ncp_readdir
(
struct
file
*
filp
,
void
*
dirent
,
filldir_t
filldir
)
{
{
struct
dentry
*
dentry
=
filp
->
f_dentry
;
struct
dentry
*
dentry
=
filp
->
f_dentry
;
...
@@ -497,36 +527,31 @@ static int ncp_readdir(struct file *filp, void *dirent, filldir_t filldir)
...
@@ -497,36 +527,31 @@ static int ncp_readdir(struct file *filp, void *dirent, filldir_t filldir)
page
=
ncp_get_cache_page
(
inode
,
0
,
0
);
page
=
ncp_get_cache_page
(
inode
,
0
,
0
);
if
(
!
page
)
if
(
!
page
)
goto
read_really
;
goto
read_really
;
ctl
.
cache
=
cache
=
(
union
ncp_dir_cache
*
)
page_address
(
page
);
ctl
.
cache
=
cache
=
(
union
ncp_dir_cache
*
)
page_address
(
page
);
ctl
.
head
=
cache
->
head
;
ctl
.
head
=
cache
->
head
;
if
(
!
Page_Uptodate
(
page
)
||
!
ctl
.
head
.
eof
)
if
(
!
Page_Uptodate
(
page
)
||
!
ctl
.
head
.
eof
)
goto
init_cache
;
goto
init_cache
;
if
((
filp
->
f_pos
==
2
)
&&
if
(
filp
->
f_pos
==
2
)
{
(
jiffies
-
ctl
.
head
.
time
>=
NCP_MAX_AGE
(
server
)))
time_t
mtime
;
/* Test, whether inode is changed. */
/* if (...) */
if
(
jiffies
-
ctl
.
head
.
time
>=
NCP_MAX_AGE
(
server
))
goto
init_cache
;
mtime
=
ncp_obtain_mtime
(
dentry
);
if
((
!
mtime
)
||
(
mtime
!=
ctl
.
head
.
mtime
))
goto
init_cache
;
goto
init_cache
;
/* Todo, if inode is unchanged? */
}
/* else {
ncp_renew_dentries(dentry);
ctl.head.time = jiffies;
} */
if
(
filp
->
f_pos
>
ctl
.
head
.
end
)
if
(
filp
->
f_pos
>
ctl
.
head
.
end
)
goto
finished
;
goto
finished
;
/*
* Should we check the complete cache before using?
* If we have big dirs, it can take a long time.
*/
ctl
.
fpos
=
filp
->
f_pos
+
(
NCP_DIRCACHE_START
-
2
);
ctl
.
fpos
=
filp
->
f_pos
+
(
NCP_DIRCACHE_START
-
2
);
ctl
.
ofs
=
ctl
.
fpos
/
NCP_DIRCACHE_SIZE
;
ctl
.
ofs
=
ctl
.
fpos
/
NCP_DIRCACHE_SIZE
;
ctl
.
idx
=
ctl
.
fpos
%
NCP_DIRCACHE_SIZE
;
ctl
.
idx
=
ctl
.
fpos
%
NCP_DIRCACHE_SIZE
;
for
(;;)
{
for
(;;)
{
if
(
ctl
.
ofs
!=
0
)
{
if
(
ctl
.
ofs
!=
0
)
{
ctl
.
page
=
ncp_get_cache_page
(
inode
,
ctl
.
ofs
,
1
);
ctl
.
page
=
ncp_get_cache_page
(
inode
,
ctl
.
ofs
,
1
);
...
@@ -540,7 +565,7 @@ static int ncp_readdir(struct file *filp, void *dirent, filldir_t filldir)
...
@@ -540,7 +565,7 @@ static int ncp_readdir(struct file *filp, void *dirent, filldir_t filldir)
while
(
ctl
.
idx
<
NCP_DIRCACHE_SIZE
)
{
while
(
ctl
.
idx
<
NCP_DIRCACHE_SIZE
)
{
struct
dentry
*
dent
;
struct
dentry
*
dent
;
int
res
;
int
res
;
dent
=
ncp_dget_fpos
(
ctl
.
cache
->
dentry
[
ctl
.
idx
],
dent
=
ncp_dget_fpos
(
ctl
.
cache
->
dentry
[
ctl
.
idx
],
dentry
,
filp
->
f_pos
);
dentry
,
filp
->
f_pos
);
if
(
!
dent
)
if
(
!
dent
)
...
@@ -574,6 +599,7 @@ static int ncp_readdir(struct file *filp, void *dirent, filldir_t filldir)
...
@@ -574,6 +599,7 @@ static int ncp_readdir(struct file *filp, void *dirent, filldir_t filldir)
ctl
.
cache
=
cache
;
ctl
.
cache
=
cache
;
init_cache:
init_cache:
ncp_invalidate_dircache_entries
(
dentry
);
ncp_invalidate_dircache_entries
(
dentry
);
ctl
.
head
.
mtime
=
ncp_obtain_mtime
(
dentry
);
ctl
.
head
.
time
=
jiffies
;
ctl
.
head
.
time
=
jiffies
;
ctl
.
head
.
eof
=
0
;
ctl
.
head
.
eof
=
0
;
ctl
.
fpos
=
2
;
ctl
.
fpos
=
2
;
...
...
fs/ncpfs/ncplib_kernel.h
View file @
5bdbe23a
...
@@ -223,15 +223,16 @@ ncp_invalidate_dircache_entries(struct dentry *parent)
...
@@ -223,15 +223,16 @@ ncp_invalidate_dircache_entries(struct dentry *parent)
}
}
struct
ncp_cache_head
{
struct
ncp_cache_head
{
unsigned
long
time
;
/* cache age */
time_t
mtime
;
unsigned
long
end
;
/* last valid fpos in cache */
unsigned
long
time
;
/* cache age */
int
eof
;
unsigned
long
end
;
/* last valid fpos in cache */
int
eof
;
};
};
#define NCP_DIRCACHE_SIZE ((int)(PAGE_CACHE_SIZE/sizeof(struct dentry *)))
#define NCP_DIRCACHE_SIZE ((int)(PAGE_CACHE_SIZE/sizeof(struct dentry *)))
union
ncp_dir_cache
{
union
ncp_dir_cache
{
struct
ncp_cache_head
head
;
struct
ncp_cache_head
head
;
struct
dentry
*
dentry
[
NCP_DIRCACHE_SIZE
];
struct
dentry
*
dentry
[
NCP_DIRCACHE_SIZE
];
};
};
#define NCP_FIRSTCACHE_SIZE ((int)((NCP_DIRCACHE_SIZE * \
#define NCP_FIRSTCACHE_SIZE ((int)((NCP_DIRCACHE_SIZE * \
...
...
fs/nfs/dir.c
View file @
5bdbe23a
...
@@ -1200,12 +1200,12 @@ static int nfs_rename(struct inode *old_dir, struct dentry *old_dentry,
...
@@ -1200,12 +1200,12 @@ static int nfs_rename(struct inode *old_dir, struct dentry *old_dentry,
struct
inode
*
old_inode
=
old_dentry
->
d_inode
;
struct
inode
*
old_inode
=
old_dentry
->
d_inode
;
struct
inode
*
new_inode
=
new_dentry
->
d_inode
;
struct
inode
*
new_inode
=
new_dentry
->
d_inode
;
struct
dentry
*
dentry
=
NULL
;
struct
dentry
*
dentry
=
NULL
;
int
error
,
rehash
=
0
,
update
=
1
;
int
error
,
rehash
=
0
;
dfprintk
(
VFS
,
"NFS: rename(%s/%s -> %s/%s, ct=%d)
\n
"
,
dfprintk
(
VFS
,
"NFS: rename(%s/%s -> %s/%s, ct=%d)
\n
"
,
old_dentry
->
d_parent
->
d_name
.
name
,
old_dentry
->
d_name
.
name
,
old_dentry
->
d_parent
->
d_name
.
name
,
old_dentry
->
d_name
.
name
,
new_dentry
->
d_parent
->
d_name
.
name
,
new_dentry
->
d_name
.
name
,
new_dentry
->
d_parent
->
d_name
.
name
,
new_dentry
->
d_name
.
name
,
new_dentry
->
d_count
);
new_dentry
->
d_count
);
/*
/*
* First check whether the target is busy ... we can't
* First check whether the target is busy ... we can't
...
@@ -1238,21 +1238,16 @@ static int nfs_rename(struct inode *old_dir, struct dentry *old_dentry,
...
@@ -1238,21 +1238,16 @@ static int nfs_rename(struct inode *old_dir, struct dentry *old_dentry,
/* dentry still busy? */
/* dentry still busy? */
if
(
new_dentry
->
d_count
>
1
)
{
if
(
new_dentry
->
d_count
>
1
)
{
#ifdef NFS_PARANOIA
#ifdef NFS_PARANOIA
printk
(
"nfs_rename: target %s/%s busy, d_count=%d
\n
"
,
printk
(
"nfs_rename: target %s/%s busy, d_count=%d
\n
"
,
new_dentry
->
d_parent
->
d_name
.
name
,
new_dentry
->
d_name
.
name
,
new_dentry
->
d_count
);
new_dentry
->
d_parent
->
d_name
.
name
,
new_dentry
->
d_name
.
name
,
new_dentry
->
d_count
);
#endif
#endif
goto
out
;
goto
out
;
}
}
}
}
/*
/*
* Check for within-directory rename ... no complications.
*/
if
(
new_dir
==
old_dir
)
goto
do_rename
;
/*
* Cross-directory move ...
*
* ... prune child dentries and writebacks if needed.
* ... prune child dentries and writebacks if needed.
*/
*/
if
(
old_dentry
->
d_count
>
1
)
{
if
(
old_dentry
->
d_count
>
1
)
{
...
@@ -1260,40 +1255,26 @@ new_dentry->d_parent->d_name.name,new_dentry->d_name.name,new_dentry->d_count);
...
@@ -1260,40 +1255,26 @@ new_dentry->d_parent->d_name.name,new_dentry->d_name.name,new_dentry->d_count);
shrink_dcache_parent
(
old_dentry
);
shrink_dcache_parent
(
old_dentry
);
}
}
/*
* Now check the use counts ... we can't safely do the
* rename unless we can drop the dentries first.
*/
if
(
old_dentry
->
d_count
>
1
)
{
#ifdef NFS_PARANOIA
printk
(
"nfs_rename: old dentry %s/%s busy, d_count=%d
\n
"
,
old_dentry
->
d_parent
->
d_name
.
name
,
old_dentry
->
d_name
.
name
,
old_dentry
->
d_count
);
#endif
goto
out
;
}
if
(
new_dentry
->
d_count
>
1
&&
new_inode
)
{
if
(
new_dentry
->
d_count
>
1
&&
new_inode
)
{
#ifdef NFS_PARANOIA
#ifdef NFS_PARANOIA
printk
(
"nfs_rename: new dentry %s/%s busy, d_count=%d
\n
"
,
printk
(
"nfs_rename: new dentry %s/%s busy, d_count=%d
\n
"
,
new_dentry
->
d_parent
->
d_name
.
name
,
new_dentry
->
d_name
.
name
,
new_dentry
->
d_count
);
new_dentry
->
d_parent
->
d_name
.
name
,
new_dentry
->
d_name
.
name
,
new_dentry
->
d_count
);
#endif
#endif
goto
out
;
goto
out
;
}
}
d_drop
(
old_dentry
);
update
=
0
;
do_rename:
/*
/*
* To prevent any new references to the target during the rename,
* To prevent any new references to the target during the rename,
* we unhash the dentry and free the inode in advance.
* we unhash the dentry and free the inode in advance.
*/
*/
if
(
!
list_empty
(
&
new_dentry
->
d_hash
))
{
if
(
!
list_empty
(
&
new_dentry
->
d_hash
))
{
d_drop
(
new_dentry
);
d_drop
(
new_dentry
);
rehash
=
update
;
rehash
=
1
;
}
}
if
(
new_inode
)
{
if
(
new_inode
)
d_delete
(
new_dentry
);
d_delete
(
new_dentry
);
}
invalidate_inode_pages
(
new_dir
);
invalidate_inode_pages
(
new_dir
);
nfs_flush_dircache
(
new_dir
);
nfs_flush_dircache
(
new_dir
);
...
@@ -1302,13 +1283,14 @@ new_dentry->d_parent->d_name.name,new_dentry->d_name.name,new_dentry->d_count);
...
@@ -1302,13 +1283,14 @@ new_dentry->d_parent->d_name.name,new_dentry->d_name.name,new_dentry->d_count);
error
=
nfs_proc_rename
(
NFS_DSERVER
(
old_dentry
),
error
=
nfs_proc_rename
(
NFS_DSERVER
(
old_dentry
),
NFS_FH
(
old_dentry
->
d_parent
),
old_dentry
->
d_name
.
name
,
NFS_FH
(
old_dentry
->
d_parent
),
old_dentry
->
d_name
.
name
,
NFS_FH
(
new_dentry
->
d_parent
),
new_dentry
->
d_name
.
name
);
NFS_FH
(
new_dentry
->
d_parent
),
new_dentry
->
d_name
.
name
);
if
(
!
error
&&
!
S_ISDIR
(
old_inode
->
i_mode
))
{
/* Update the dcache if needed */
NFS_CACHEINV
(
old_dir
);
if
(
rehash
)
NFS_CACHEINV
(
new_dir
);
d_add
(
new_dentry
,
NULL
);
/* Update the dcache if needed */
if
(
update
)
if
(
rehash
)
d_move
(
old_dentry
,
new_dentry
);
d_add
(
new_dentry
,
NULL
);
}
if
(
!
error
&&
!
S_ISDIR
(
old_inode
->
i_mode
))
d_move
(
old_dentry
,
new_dentry
);
out:
out:
/* new dentry created? */
/* new dentry created? */
...
...
fs/open.c
View file @
5bdbe23a
...
@@ -719,7 +719,7 @@ int get_unused_fd(void)
...
@@ -719,7 +719,7 @@ int get_unused_fd(void)
* Check whether we need to expand the fd array.
* Check whether we need to expand the fd array.
*/
*/
if
(
fd
>=
files
->
max_fds
)
{
if
(
fd
>=
files
->
max_fds
)
{
error
=
expand_fd_array
(
files
,
0
);
error
=
expand_fd_array
(
files
,
fd
);
if
(
!
error
)
{
if
(
!
error
)
{
error
=
-
EMFILE
;
error
=
-
EMFILE
;
goto
repeat
;
goto
repeat
;
...
...
fs/super.c
View file @
5bdbe23a
...
@@ -1025,14 +1025,14 @@ asmlinkage long sys_mount(char * dev_name, char * dir_name, char * type,
...
@@ -1025,14 +1025,14 @@ asmlinkage long sys_mount(char * dev_name, char * dir_name, char * type,
struct
dentry
*
dentry
=
NULL
;
struct
dentry
*
dentry
=
NULL
;
struct
inode
*
inode
=
NULL
;
struct
inode
*
inode
=
NULL
;
kdev_t
dev
;
kdev_t
dev
;
int
retval
=
-
EPERM
;
int
retval
;
unsigned
long
flags
=
0
;
unsigned
long
flags
=
0
;
unsigned
long
page
=
0
;
unsigned
long
page
=
0
;
struct
file
dummy
;
/* allows read-write or read-only flag */
struct
file
dummy
;
/* allows read-write or read-only flag */
lock_kernel
();
if
(
!
capable
(
CAP_SYS_ADMIN
))
if
(
!
capable
(
CAP_SYS_ADMIN
))
goto
out
;
return
-
EPERM
;
lock_kernel
();
if
((
new_flags
&
if
((
new_flags
&
(
MS_MGC_MSK
|
MS_REMOUNT
))
==
(
MS_MGC_VAL
|
MS_REMOUNT
))
{
(
MS_MGC_MSK
|
MS_REMOUNT
))
==
(
MS_MGC_VAL
|
MS_REMOUNT
))
{
retval
=
copy_mount_options
(
data
,
&
page
);
retval
=
copy_mount_options
(
data
,
&
page
);
...
...
fs/udf/balloc.c
View file @
5bdbe23a
...
@@ -402,7 +402,7 @@ int udf_new_block(const struct inode * inode, Uint16 partition, Uint32 goal, int
...
@@ -402,7 +402,7 @@ int udf_new_block(const struct inode * inode, Uint16 partition, Uint32 goal, int
got_block:
got_block:
newblock
=
bit
+
(
block_group
<<
(
sb
->
s_blocksize_bits
+
3
))
-
newblock
=
bit
+
(
block_group
<<
(
sb
->
s_blocksize_bits
+
3
))
-
(
group_start
<<
3
);
(
sizeof
(
struct
SpaceBitmapDesc
)
<<
3
);
tmp
=
udf_get_pblock
(
sb
,
newblock
,
partition
,
0
);
tmp
=
udf_get_pblock
(
sb
,
newblock
,
partition
,
0
);
if
(
!
udf_clear_bit
(
bit
,
bh
->
b_data
))
if
(
!
udf_clear_bit
(
bit
,
bh
->
b_data
))
...
@@ -412,16 +412,6 @@ int udf_new_block(const struct inode * inode, Uint16 partition, Uint32 goal, int
...
@@ -412,16 +412,6 @@ int udf_new_block(const struct inode * inode, Uint16 partition, Uint32 goal, int
}
}
mark_buffer_dirty
(
bh
,
1
);
mark_buffer_dirty
(
bh
,
1
);
if
(
!
(
bh
=
getblk
(
sb
->
s_dev
,
tmp
,
sb
->
s_blocksize
)))
{
udf_debug
(
"cannot get block %d
\n
"
,
tmp
);
unlock_super
(
sb
);
return
0
;
}
memset
(
bh
->
b_data
,
0
,
sb
->
s_blocksize
);
mark_buffer_uptodate
(
bh
,
1
);
mark_buffer_dirty
(
bh
,
1
);
udf_release_data
(
bh
);
if
(
UDF_SB_LVIDBH
(
sb
))
if
(
UDF_SB_LVIDBH
(
sb
))
{
{
...
...
fs/udf/dir.c
View file @
5bdbe23a
...
@@ -180,7 +180,7 @@ do_udf_readdir(struct inode * dir, struct file *filp, filldir_t filldir, void *d
...
@@ -180,7 +180,7 @@ do_udf_readdir(struct inode * dir, struct file *filp, filldir_t filldir, void *d
&
bloc
,
&
extoffset
,
&
eloc
,
&
elen
,
&
offset
,
&
bh
)
==
EXTENT_RECORDED_ALLOCATED
)
&
bloc
,
&
extoffset
,
&
eloc
,
&
elen
,
&
offset
,
&
bh
)
==
EXTENT_RECORDED_ALLOCATED
)
{
{
block
=
udf_get_lb_pblock
(
dir
->
i_sb
,
eloc
,
offset
);
block
=
udf_get_lb_pblock
(
dir
->
i_sb
,
eloc
,
offset
);
if
(
++
offset
<
(
elen
>>
dir
->
i_sb
->
s_blocksize_bits
)
)
if
(
(
++
offset
<<
dir
->
i_sb
->
s_blocksize_bits
)
<
elen
)
{
{
if
(
UDF_I_ALLOCTYPE
(
dir
)
==
ICB_FLAG_AD_SHORT
)
if
(
UDF_I_ALLOCTYPE
(
dir
)
==
ICB_FLAG_AD_SHORT
)
extoffset
-=
sizeof
(
short_ad
);
extoffset
-=
sizeof
(
short_ad
);
...
@@ -207,8 +207,6 @@ do_udf_readdir(struct inode * dir, struct file *filp, filldir_t filldir, void *d
...
@@ -207,8 +207,6 @@ do_udf_readdir(struct inode * dir, struct file *filp, filldir_t filldir, void *d
filp
->
f_pos
=
nf_pos
;
filp
->
f_pos
=
nf_pos
;
fi
=
udf_fileident_read
(
dir
,
&
nf_pos
,
&
fibh
,
&
cfi
,
&
bloc
,
&
extoffset
,
&
offset
,
&
bh
);
fi
=
udf_fileident_read
(
dir
,
&
nf_pos
,
&
fibh
,
&
cfi
,
&
bloc
,
&
extoffset
,
&
offset
,
&
bh
);
liu
=
le16_to_cpu
(
cfi
.
lengthOfImpUse
);
lfi
=
cfi
.
lengthFileIdent
;
if
(
!
fi
)
if
(
!
fi
)
{
{
...
@@ -219,6 +217,9 @@ do_udf_readdir(struct inode * dir, struct file *filp, filldir_t filldir, void *d
...
@@ -219,6 +217,9 @@ do_udf_readdir(struct inode * dir, struct file *filp, filldir_t filldir, void *d
return
1
;
return
1
;
}
}
liu
=
le16_to_cpu
(
cfi
.
lengthOfImpUse
);
lfi
=
cfi
.
lengthFileIdent
;
if
(
fibh
.
sbh
==
fibh
.
ebh
)
if
(
fibh
.
sbh
==
fibh
.
ebh
)
nameptr
=
fi
->
fileIdent
+
liu
;
nameptr
=
fi
->
fileIdent
+
liu
;
else
else
...
...
fs/udf/directory.c
View file @
5bdbe23a
...
@@ -112,7 +112,7 @@ udf_fileident_read(struct inode *dir, int *nf_pos,
...
@@ -112,7 +112,7 @@ udf_fileident_read(struct inode *dir, int *nf_pos,
(
*
offset
)
++
;
(
*
offset
)
++
;
if
(
*
offset
>=
(
elen
>>
dir
->
i_sb
->
s_blocksize_bits
)
)
if
(
(
*
offset
<<
dir
->
i_sb
->
s_blocksize_bits
)
>=
elen
)
*
offset
=
0
;
*
offset
=
0
;
else
else
*
extoffset
=
lextoffset
;
*
extoffset
=
lextoffset
;
...
@@ -154,7 +154,7 @@ udf_fileident_read(struct inode *dir, int *nf_pos,
...
@@ -154,7 +154,7 @@ udf_fileident_read(struct inode *dir, int *nf_pos,
(
*
offset
)
++
;
(
*
offset
)
++
;
if
(
*
offset
>=
(
elen
>>
dir
->
i_sb
->
s_blocksize_bits
)
)
if
(
(
*
offset
<<
dir
->
i_sb
->
s_blocksize_bits
)
>=
elen
)
*
offset
=
0
;
*
offset
=
0
;
else
else
*
extoffset
=
lextoffset
;
*
extoffset
=
lextoffset
;
...
...
fs/udf/file.c
View file @
5bdbe23a
...
@@ -213,6 +213,8 @@ static ssize_t udf_file_write(struct file * file, const char * buf,
...
@@ -213,6 +213,8 @@ static ssize_t udf_file_write(struct file * file, const char * buf,
if
((
bh
=
udf_expand_adinicb
(
inode
,
&
i
,
0
,
&
err
)))
if
((
bh
=
udf_expand_adinicb
(
inode
,
&
i
,
0
,
&
err
)))
udf_release_data
(
bh
);
udf_release_data
(
bh
);
else
if
(
UDF_I_ALLOCTYPE
(
inode
)
==
ICB_FLAG_AD_IN_ICB
)
return
err
;
}
}
retval
=
generic_file_write
(
file
,
buf
,
count
,
ppos
,
block_write_partial_page
);
retval
=
generic_file_write
(
file
,
buf
,
count
,
ppos
,
block_write_partial_page
);
...
@@ -294,7 +296,9 @@ static ssize_t udf_file_read_adinicb(struct file * filp, char * buf,
...
@@ -294,7 +296,9 @@ static ssize_t udf_file_read_adinicb(struct file * filp, char * buf,
if
(
!
copy_to_user
(
buf
,
bh
->
b_data
+
pos
,
left
))
if
(
!
copy_to_user
(
buf
,
bh
->
b_data
+
pos
,
left
))
*
loff
+=
left
;
*
loff
+=
left
;
else
else
return
-
EFAULT
;
left
=
-
EFAULT
;
udf_release_data
(
bh
);
return
left
;
return
left
;
}
}
...
@@ -336,11 +340,11 @@ static ssize_t udf_file_read_adinicb(struct file * filp, char * buf,
...
@@ -336,11 +340,11 @@ static ssize_t udf_file_read_adinicb(struct file * filp, char * buf,
int
udf_ioctl
(
struct
inode
*
inode
,
struct
file
*
filp
,
unsigned
int
cmd
,
int
udf_ioctl
(
struct
inode
*
inode
,
struct
file
*
filp
,
unsigned
int
cmd
,
unsigned
long
arg
)
unsigned
long
arg
)
{
{
int
result
=-
1
;
int
result
=
-
1
;
int
size
;
struct
buffer_head
*
bh
=
NULL
;
struct
buffer_head
*
bh
=
NULL
;
struct
FileEntry
*
fe
;
Uint16
ident
;
Uint16
ident
;
long_ad
eaicb
;
Uint8
*
ea
=
NULL
;
if
(
permission
(
inode
,
MAY_READ
)
!=
0
)
if
(
permission
(
inode
,
MAY_READ
)
!=
0
)
{
{
...
@@ -368,26 +372,42 @@ int udf_ioctl(struct inode *inode, struct file *filp, unsigned int cmd,
...
@@ -368,26 +372,42 @@ int udf_ioctl(struct inode *inode, struct file *filp, unsigned int cmd,
/* ok, we need to read the inode */
/* ok, we need to read the inode */
bh
=
udf_read_ptagged
(
inode
->
i_sb
,
UDF_I_LOCATION
(
inode
),
0
,
&
ident
);
bh
=
udf_read_ptagged
(
inode
->
i_sb
,
UDF_I_LOCATION
(
inode
),
0
,
&
ident
);
if
(
!
bh
||
ident
!=
TID_FILE_ENTRY
)
if
(
!
bh
||
(
ident
!=
TID_FILE_ENTRY
&&
ident
!=
TID_EXTENDED_FILE_ENTRY
)
)
{
{
udf_debug
(
"bread failed (ino=%ld) or ident (%d) != TID_FILE_ENTRY"
,
udf_debug
(
"bread failed (ino=%ld) or ident (%d) != TID_
(EXTENDED_)
FILE_ENTRY"
,
inode
->
i_ino
,
ident
);
inode
->
i_ino
,
ident
);
return
-
EFAULT
;
return
-
EFAULT
;
}
}
fe
=
(
struct
FileEntry
*
)
bh
->
b_data
;
if
(
UDF_I_EXTENDED_FE
(
inode
)
==
0
)
size
=
le32_to_cpu
(
fe
->
lengthExtendedAttr
);
{
struct
FileEntry
*
fe
;
fe
=
(
struct
FileEntry
*
)
bh
->
b_data
;
eaicb
=
fe
->
extendedAttrICB
;
if
(
UDF_I_LENEATTR
(
inode
))
ea
=
fe
->
extendedAttr
;
}
else
{
struct
ExtendedFileEntry
*
efe
;
efe
=
(
struct
ExtendedFileEntry
*
)
bh
->
b_data
;
eaicb
=
efe
->
extendedAttrICB
;
if
(
UDF_I_LENEATTR
(
inode
))
ea
=
efe
->
extendedAttr
;
}
switch
(
cmd
)
switch
(
cmd
)
{
{
case
UDF_GETEASIZE
:
case
UDF_GETEASIZE
:
if
(
(
result
=
verify_area
(
VERIFY_WRITE
,
(
char
*
)
arg
,
4
))
==
0
)
if
(
(
result
=
verify_area
(
VERIFY_WRITE
,
(
char
*
)
arg
,
4
))
==
0
)
result
=
put_user
(
size
,
(
int
*
)
arg
);
result
=
put_user
(
UDF_I_LENEATTR
(
inode
)
,
(
int
*
)
arg
);
break
;
break
;
case
UDF_GETEABLOCK
:
case
UDF_GETEABLOCK
:
if
(
(
result
=
verify_area
(
VERIFY_WRITE
,
(
char
*
)
arg
,
size
))
==
0
)
if
(
(
result
=
verify_area
(
VERIFY_WRITE
,
(
char
*
)
arg
,
UDF_I_LENEATTR
(
inode
)
))
==
0
)
result
=
copy_to_user
((
char
*
)
arg
,
fe
->
extendedAttr
,
size
);
result
=
copy_to_user
((
char
*
)
arg
,
ea
,
UDF_I_LENEATTR
(
inode
)
);
break
;
break
;
default:
default:
...
...
fs/udf/inode.c
View file @
5bdbe23a
...
@@ -106,18 +106,48 @@ void udf_delete_inode(struct inode * inode)
...
@@ -106,18 +106,48 @@ void udf_delete_inode(struct inode * inode)
void
udf_discard_prealloc
(
struct
inode
*
inode
)
void
udf_discard_prealloc
(
struct
inode
*
inode
)
{
{
#ifdef UDF_PREALLOCATE
#ifdef UDF_PREALLOCATE
#if 0
lb_addr
bloc
,
eloc
;
unsigned short total
;
Uint32
extoffset
,
elen
,
nelen
,
offset
,
adsize
=
0
;
lb_addr loc = UDF_I_LOCATION(inode)
;
struct
buffer_head
*
bh
=
NULL
;
if (UDF_I_PREALLOC_COUNT(inode))
if
((
inode
->
i_size
>
0
)
&&
(
inode_bmap
(
inode
,
(
inode
->
i_size
-
1
)
>>
inode
->
i_sb
->
s_blocksize_bits
,
&
bloc
,
&
extoffset
,
&
eloc
,
&
elen
,
&
offset
,
&
bh
)
==
EXTENT_RECORDED_ALLOCATED
))
{
{
total = UDF_I_PREALLOC_COUNT(inode);
if
(
UDF_I_ALLOCTYPE
(
inode
)
==
ICB_FLAG_AD_SHORT
)
UDF_I_PREALLOC_COUNT(inode) = 0;
adsize
=
sizeof
(
short_ad
);
loc.logicalBlockNum = UDF_I_PREALLOC_BLOCK(inode);
else
if
(
UDF_I_ALLOCTYPE
(
inode
)
==
ICB_FLAG_AD_LONG
)
udf_free_blocks(inode, loc, 0, total);
adsize
=
sizeof
(
long_ad
);
else
{
udf_release_data
(
bh
);
return
;
}
nelen
=
(
EXTENT_RECORDED_ALLOCATED
<<
30
)
|
((((
elen
-
1
)
&
~
(
inode
->
i_sb
->
s_blocksize
-
1
))
|
((
inode
->
i_size
-
1
)
&
(
inode
->
i_sb
->
s_blocksize
-
1
)))
+
1
);
if
(
nelen
!=
((
EXTENT_RECORDED_ALLOCATED
<<
30
)
|
elen
))
{
extoffset
-=
adsize
;
udf_write_aext
(
inode
,
bloc
,
&
extoffset
,
eloc
,
nelen
,
&
bh
,
1
);
}
if
(
udf_next_aext
(
inode
,
&
bloc
,
&
extoffset
,
&
eloc
,
&
elen
,
&
bh
,
0
)
==
EXTENT_NOT_RECORDED_ALLOCATED
)
{
udf_free_blocks
(
inode
,
eloc
,
0
,
elen
>>
inode
->
i_sb
->
s_blocksize_bits
);
memset
(
&
eloc
,
0x00
,
sizeof
(
lb_addr
));
udf_write_aext
(
inode
,
bloc
,
&
extoffset
,
eloc
,
0
,
&
bh
,
1
);
UDF_I_LENALLOC
(
inode
)
-=
adsize
;
udf_write_inode
(
inode
);
}
udf_release_data
(
bh
);
}
}
#endif
else
if
(
bh
)
udf_release_data
(
bh
);
#endif
#endif
}
}
...
@@ -144,6 +174,9 @@ struct buffer_head * udf_expand_adinicb(struct inode *inode, int *block, int isd
...
@@ -144,6 +174,9 @@ struct buffer_head * udf_expand_adinicb(struct inode *inode, int *block, int isd
{
{
UDF_I_EXT0OFFS
(
inode
)
=
0
;
UDF_I_EXT0OFFS
(
inode
)
=
0
;
UDF_I_ALLOCTYPE
(
inode
)
=
ICB_FLAG_AD_LONG
;
UDF_I_ALLOCTYPE
(
inode
)
=
ICB_FLAG_AD_LONG
;
mark_inode_dirty
(
inode
);
if
(
inode
->
i_op
==
&
udf_file_inode_operations_adinicb
)
inode
->
i_op
=
&
udf_file_inode_operations
;
return
NULL
;
return
NULL
;
}
}
...
@@ -208,6 +241,7 @@ struct buffer_head * udf_expand_adinicb(struct inode *inode, int *block, int isd
...
@@ -208,6 +241,7 @@ struct buffer_head * udf_expand_adinicb(struct inode *inode, int *block, int isd
memset
(
sbh
->
b_data
+
udf_file_entry_alloc_offset
(
inode
),
memset
(
sbh
->
b_data
+
udf_file_entry_alloc_offset
(
inode
),
0
,
UDF_I_LENALLOC
(
inode
));
0
,
UDF_I_LENALLOC
(
inode
));
memset
(
&
newad
,
0x00
,
sizeof
(
long_ad
));
newad
.
extLength
=
UDF_I_EXT0LEN
(
inode
)
=
inode
->
i_size
;
newad
.
extLength
=
UDF_I_EXT0LEN
(
inode
)
=
inode
->
i_size
;
newad
.
extLocation
.
logicalBlockNum
=
*
block
;
newad
.
extLocation
.
logicalBlockNum
=
*
block
;
newad
.
extLocation
.
partitionReferenceNum
=
UDF_I_LOCATION
(
inode
).
partitionReferenceNum
;
newad
.
extLocation
.
partitionReferenceNum
=
UDF_I_LOCATION
(
inode
).
partitionReferenceNum
;
...
@@ -248,7 +282,7 @@ struct buffer_head * udf_getblk(struct inode * inode, long block,
...
@@ -248,7 +282,7 @@ struct buffer_head * udf_getblk(struct inode * inode, long block,
bh
=
getblk
(
dummy
.
b_dev
,
dummy
.
b_blocknr
,
inode
->
i_sb
->
s_blocksize
);
bh
=
getblk
(
dummy
.
b_dev
,
dummy
.
b_blocknr
,
inode
->
i_sb
->
s_blocksize
);
if
(
buffer_new
(
&
dummy
))
if
(
buffer_new
(
&
dummy
))
{
{
memset
(
bh
->
b_data
,
0
,
inode
->
i_sb
->
s_blocksize
);
memset
(
bh
->
b_data
,
0
x00
,
inode
->
i_sb
->
s_blocksize
);
mark_buffer_uptodate
(
bh
,
1
);
mark_buffer_uptodate
(
bh
,
1
);
mark_buffer_dirty
(
bh
,
1
);
mark_buffer_dirty
(
bh
,
1
);
}
}
...
@@ -340,6 +374,7 @@ static struct buffer_head * inode_getblk(struct inode * inode, long block,
...
@@ -340,6 +374,7 @@ static struct buffer_head * inode_getblk(struct inode * inode, long block,
if
(
pbh
!=
cbh
)
if
(
pbh
!=
cbh
)
{
{
udf_release_data
(
pbh
);
udf_release_data
(
pbh
);
pbh
=
cbh
;
atomic_inc
(
&
cbh
->
b_count
);
atomic_inc
(
&
cbh
->
b_count
);
pbloc
=
cbloc
;
pbloc
=
cbloc
;
}
}
...
@@ -462,7 +497,6 @@ static struct buffer_head * inode_getblk(struct inode * inode, long block,
...
@@ -462,7 +497,6 @@ static struct buffer_head * inode_getblk(struct inode * inode, long block,
UDF_I_LOCATION
(
inode
).
partitionReferenceNum
,
goal
,
err
)))
UDF_I_LOCATION
(
inode
).
partitionReferenceNum
,
goal
,
err
)))
{
{
udf_release_data
(
pbh
);
udf_release_data
(
pbh
);
udf_release_data
(
cbh
);
*
err
=
-
ENOSPC
;
*
err
=
-
ENOSPC
;
return
NULL
;
return
NULL
;
}
}
...
@@ -488,7 +522,7 @@ static struct buffer_head * inode_getblk(struct inode * inode, long block,
...
@@ -488,7 +522,7 @@ static struct buffer_head * inode_getblk(struct inode * inode, long block,
udf_release_data
(
pbh
);
udf_release_data
(
pbh
);
if
(
c
==
0
||
c
==
1
)
if
(
pextoffset
==
udf_file_entry_alloc_offset
(
inode
)
)
{
{
UDF_I_EXT0LEN
(
inode
)
=
laarr
[
0
].
extLength
;
UDF_I_EXT0LEN
(
inode
)
=
laarr
[
0
].
extLength
;
UDF_I_EXT0LOC
(
inode
)
=
laarr
[
0
].
extLocation
;
UDF_I_EXT0LOC
(
inode
)
=
laarr
[
0
].
extLocation
;
...
@@ -889,7 +923,8 @@ static void udf_fill_inode(struct inode *inode, struct buffer_head *bh)
...
@@ -889,7 +923,8 @@ static void udf_fill_inode(struct inode *inode, struct buffer_head *bh)
{
{
struct
FileEntry
*
fe
;
struct
FileEntry
*
fe
;
struct
ExtendedFileEntry
*
efe
;
struct
ExtendedFileEntry
*
efe
;
time_t
convtime
;
time_t
convtime
;
long
convtime_usec
;
int
offset
,
alen
;
int
offset
,
alen
;
fe
=
(
struct
FileEntry
*
)
bh
->
b_data
;
fe
=
(
struct
FileEntry
*
)
bh
->
b_data
;
...
@@ -940,21 +975,33 @@ static void udf_fill_inode(struct inode *inode, struct buffer_head *bh)
...
@@ -940,21 +975,33 @@ static void udf_fill_inode(struct inode *inode, struct buffer_head *bh)
inode
->
i_blocks
=
le64_to_cpu
(
fe
->
logicalBlocksRecorded
)
<<
inode
->
i_blocks
=
le64_to_cpu
(
fe
->
logicalBlocksRecorded
)
<<
(
inode
->
i_sb
->
s_blocksize_bits
-
9
);
(
inode
->
i_sb
->
s_blocksize_bits
-
9
);
if
(
udf_stamp_to_time
(
&
convtime
,
lets_to_cpu
(
fe
->
modificationTime
))
)
if
(
udf_stamp_to_time
(
&
convtime
,
&
convtime_usec
,
lets_to_cpu
(
fe
->
modificationTime
))
)
{
{
inode
->
i_mtime
=
convtime
;
inode
->
i_mtime
=
convtime
;
UDF_I_UMTIME
(
inode
)
=
convtime_usec
;
inode
->
i_ctime
=
convtime
;
inode
->
i_ctime
=
convtime
;
UDF_I_UCTIME
(
inode
)
=
convtime_usec
;
}
}
else
else
{
{
inode
->
i_mtime
=
UDF_SB_RECORDTIME
(
inode
->
i_sb
);
inode
->
i_mtime
=
UDF_SB_RECORDTIME
(
inode
->
i_sb
);
UDF_I_UMTIME
(
inode
)
=
0
;
inode
->
i_ctime
=
UDF_SB_RECORDTIME
(
inode
->
i_sb
);
inode
->
i_ctime
=
UDF_SB_RECORDTIME
(
inode
->
i_sb
);
UDF_I_UCTIME
(
inode
)
=
0
;
}
}
if
(
udf_stamp_to_time
(
&
convtime
,
lets_to_cpu
(
fe
->
accessTime
))
)
if
(
udf_stamp_to_time
(
&
convtime
,
&
convtime_usec
,
lets_to_cpu
(
fe
->
accessTime
))
)
{
inode
->
i_atime
=
convtime
;
inode
->
i_atime
=
convtime
;
UDF_I_UATIME
(
inode
)
=
convtime_usec
;
}
else
else
{
inode
->
i_atime
=
UDF_SB_RECORDTIME
(
inode
->
i_sb
);
inode
->
i_atime
=
UDF_SB_RECORDTIME
(
inode
->
i_sb
);
UDF_I_UATIME
(
inode
)
=
convtime_usec
;
}
UDF_I_UNIQUE
(
inode
)
=
le64_to_cpu
(
fe
->
uniqueID
);
UDF_I_UNIQUE
(
inode
)
=
le64_to_cpu
(
fe
->
uniqueID
);
UDF_I_LENEATTR
(
inode
)
=
le32_to_cpu
(
fe
->
lengthExtendedAttr
);
UDF_I_LENEATTR
(
inode
)
=
le32_to_cpu
(
fe
->
lengthExtendedAttr
);
...
@@ -967,20 +1014,41 @@ static void udf_fill_inode(struct inode *inode, struct buffer_head *bh)
...
@@ -967,20 +1014,41 @@ static void udf_fill_inode(struct inode *inode, struct buffer_head *bh)
inode
->
i_blocks
=
le64_to_cpu
(
efe
->
logicalBlocksRecorded
)
<<
inode
->
i_blocks
=
le64_to_cpu
(
efe
->
logicalBlocksRecorded
)
<<
(
inode
->
i_sb
->
s_blocksize_bits
-
9
);
(
inode
->
i_sb
->
s_blocksize_bits
-
9
);
if
(
udf_stamp_to_time
(
&
convtime
,
lets_to_cpu
(
efe
->
modificationTime
))
)
if
(
udf_stamp_to_time
(
&
convtime
,
&
convtime_usec
,
lets_to_cpu
(
efe
->
modificationTime
))
)
{
inode
->
i_mtime
=
convtime
;
inode
->
i_mtime
=
convtime
;
UDF_I_UMTIME
(
inode
)
=
convtime_usec
;
}
else
else
{
inode
->
i_mtime
=
UDF_SB_RECORDTIME
(
inode
->
i_sb
);
inode
->
i_mtime
=
UDF_SB_RECORDTIME
(
inode
->
i_sb
);
UDF_I_UMTIME
(
inode
)
=
0
;
}
if
(
udf_stamp_to_time
(
&
convtime
,
lets_to_cpu
(
efe
->
accessTime
))
)
if
(
udf_stamp_to_time
(
&
convtime
,
&
convtime_usec
,
lets_to_cpu
(
efe
->
accessTime
))
)
{
inode
->
i_atime
=
convtime
;
inode
->
i_atime
=
convtime
;
UDF_I_UATIME
(
inode
)
=
convtime_usec
;
}
else
else
{
inode
->
i_atime
=
UDF_SB_RECORDTIME
(
inode
->
i_sb
);
inode
->
i_atime
=
UDF_SB_RECORDTIME
(
inode
->
i_sb
);
UDF_I_UATIME
(
inode
)
=
0
;
}
if
(
udf_stamp_to_time
(
&
convtime
,
lets_to_cpu
(
efe
->
createTime
))
)
if
(
udf_stamp_to_time
(
&
convtime
,
&
convtime_usec
,
lets_to_cpu
(
efe
->
createTime
))
)
{
inode
->
i_ctime
=
convtime
;
inode
->
i_ctime
=
convtime
;
UDF_I_UCTIME
(
inode
)
=
convtime_usec
;
}
else
else
{
inode
->
i_ctime
=
UDF_SB_RECORDTIME
(
inode
->
i_sb
);
inode
->
i_ctime
=
UDF_SB_RECORDTIME
(
inode
->
i_sb
);
UDF_I_UCTIME
(
inode
)
=
0
;
}
UDF_I_UNIQUE
(
inode
)
=
le64_to_cpu
(
efe
->
uniqueID
);
UDF_I_UNIQUE
(
inode
)
=
le64_to_cpu
(
efe
->
uniqueID
);
UDF_I_LENEATTR
(
inode
)
=
le32_to_cpu
(
efe
->
lengthExtendedAttr
);
UDF_I_LENEATTR
(
inode
)
=
le32_to_cpu
(
efe
->
lengthExtendedAttr
);
...
@@ -1274,8 +1342,8 @@ udf_update_inode(struct inode *inode, int do_sync)
...
@@ -1274,8 +1342,8 @@ udf_update_inode(struct inode *inode, int do_sync)
efe
->
impIdent
.
identSuffix
[
0
]
=
UDF_OS_CLASS_UNIX
;
efe
->
impIdent
.
identSuffix
[
0
]
=
UDF_OS_CLASS_UNIX
;
efe
->
impIdent
.
identSuffix
[
1
]
=
UDF_OS_ID_LINUX
;
efe
->
impIdent
.
identSuffix
[
1
]
=
UDF_OS_ID_LINUX
;
efe
->
uniqueID
=
cpu_to_le64
(
UDF_I_UNIQUE
(
inode
));
efe
->
uniqueID
=
cpu_to_le64
(
UDF_I_UNIQUE
(
inode
));
efe
->
lengthExtendedAttr
=
cpu_to_le32
(
UDF_I_LENEATTR
(
inode
));
efe
->
lengthExtendedAttr
=
cpu_to_le32
(
UDF_I_LENEATTR
(
inode
));
efe
->
lengthAllocDescs
=
cpu_to_le32
(
UDF_I_LENALLOC
(
inode
));
efe
->
lengthAllocDescs
=
cpu_to_le32
(
UDF_I_LENALLOC
(
inode
));
efe
->
descTag
.
tagIdent
=
le16_to_cpu
(
TID_EXTENDED_FILE_ENTRY
);
efe
->
descTag
.
tagIdent
=
le16_to_cpu
(
TID_EXTENDED_FILE_ENTRY
);
crclen
=
sizeof
(
struct
ExtendedFileEntry
);
crclen
=
sizeof
(
struct
ExtendedFileEntry
);
}
}
...
@@ -1764,6 +1832,8 @@ int udf_insert_aext(struct inode *inode, lb_addr bloc, int extoffset,
...
@@ -1764,6 +1832,8 @@ int udf_insert_aext(struct inode *inode, lb_addr bloc, int extoffset,
return
-
1
;
return
-
1
;
}
}
}
}
else
atomic_inc
(
&
bh
->
b_count
);
while
((
type
=
udf_next_aext
(
inode
,
&
bloc
,
&
extoffset
,
&
oeloc
,
&
oelen
,
&
bh
,
0
))
!=
-
1
)
while
((
type
=
udf_next_aext
(
inode
,
&
bloc
,
&
extoffset
,
&
oeloc
,
&
oelen
,
&
bh
,
0
))
!=
-
1
)
{
{
...
@@ -1773,6 +1843,7 @@ int udf_insert_aext(struct inode *inode, lb_addr bloc, int extoffset,
...
@@ -1773,6 +1843,7 @@ int udf_insert_aext(struct inode *inode, lb_addr bloc, int extoffset,
nelen
=
(
type
<<
30
)
|
oelen
;
nelen
=
(
type
<<
30
)
|
oelen
;
}
}
udf_add_aext
(
inode
,
&
bloc
,
&
extoffset
,
neloc
,
nelen
,
&
bh
,
1
);
udf_add_aext
(
inode
,
&
bloc
,
&
extoffset
,
neloc
,
nelen
,
&
bh
,
1
);
udf_release_data
(
bh
);
return
(
nelen
>>
30
);
return
(
nelen
>>
30
);
}
}
...
@@ -1879,12 +1950,12 @@ int inode_bmap(struct inode *inode, int block, lb_addr *bloc, Uint32 *extoffset,
...
@@ -1879,12 +1950,12 @@ int inode_bmap(struct inode *inode, int block, lb_addr *bloc, Uint32 *extoffset,
if
(
block
<
0
)
if
(
block
<
0
)
{
{
printk
(
KERN_ERR
"udf: inode_bmap: block < 0
\n
"
);
printk
(
KERN_ERR
"udf: inode_bmap: block < 0
\n
"
);
return
0
;
return
-
1
;
}
}
if
(
!
inode
)
if
(
!
inode
)
{
{
printk
(
KERN_ERR
"udf: inode_bmap: NULL inode
\n
"
);
printk
(
KERN_ERR
"udf: inode_bmap: NULL inode
\n
"
);
return
0
;
return
-
1
;
}
}
b_off
=
block
<<
inode
->
i_sb
->
s_blocksize_bits
;
b_off
=
block
<<
inode
->
i_sb
->
s_blocksize_bits
;
...
...
fs/udf/lowlevel.c
View file @
5bdbe23a
...
@@ -95,16 +95,17 @@ udf_get_last_block(kdev_t dev, int *flags)
...
@@ -95,16 +95,17 @@ udf_get_last_block(kdev_t dev, int *flags)
int
ret
;
int
ret
;
unsigned
long
lblock
;
unsigned
long
lblock
;
unsigned
int
hbsize
=
get_hardblocksize
(
dev
);
unsigned
int
hbsize
=
get_hardblocksize
(
dev
);
unsigned
int
secsize
=
512
;
unsigned
int
mult
=
0
;
unsigned
int
mult
=
0
;
unsigned
int
div
=
0
;
unsigned
int
div
=
0
;
if
(
!
hbsize
)
if
(
!
hbsize
)
hbsize
=
512
;
hbsize
=
blksize_size
[
MAJOR
(
dev
)][
MINOR
(
dev
)]
;
if
(
hbsize
>
blksize_size
[
MAJOR
(
dev
)][
MINOR
(
dev
)]
)
if
(
secsize
>
hbsize
)
mult
=
hbsize
/
blksize_size
[
MAJOR
(
dev
)][
MINOR
(
dev
)]
;
mult
=
secsize
/
hbsize
;
else
if
(
blksize_size
[
MAJOR
(
dev
)][
MINOR
(
dev
)]
>
hb
size
)
else
if
(
hbsize
>
sec
size
)
div
=
blksize_size
[
MAJOR
(
dev
)][
MINOR
(
dev
)]
/
hb
size
;
div
=
hbsize
/
sec
size
;
if
(
get_blkfops
(
MAJOR
(
dev
))
->
ioctl
!=
NULL
)
if
(
get_blkfops
(
MAJOR
(
dev
))
->
ioctl
!=
NULL
)
{
{
...
@@ -138,7 +139,7 @@ udf_get_last_block(kdev_t dev, int *flags)
...
@@ -138,7 +139,7 @@ udf_get_last_block(kdev_t dev, int *flags)
}
}
set_fs
(
old_fs
);
set_fs
(
old_fs
);
if
(
!
ret
)
if
(
!
ret
&&
lblock
)
return
lblock
-
1
;
return
lblock
-
1
;
}
}
else
else
...
...
fs/udf/misc.c
View file @
5bdbe23a
...
@@ -66,28 +66,6 @@ udf64_high32(Uint64 indat)
...
@@ -66,28 +66,6 @@ udf64_high32(Uint64 indat)
return
indat
>>
32
;
return
indat
>>
32
;
}
}
/*
* udf_stamp_to_time
*/
time_t
*
udf_stamp_to_time
(
time_t
*
dest
,
timestamp
src
)
{
struct
ktm
tm
;
if
((
!
dest
))
return
NULL
;
/* this is very rough. need to find source to mktime() */
tm
.
tm_year
=
(
src
.
year
)
-
1900
;
tm
.
tm_mon
=
(
src
.
month
);
tm
.
tm_mday
=
(
src
.
day
);
tm
.
tm_hour
=
src
.
hour
;
tm
.
tm_min
=
src
.
minute
;
tm
.
tm_sec
=
src
.
second
;
*
dest
=
udf_converttime
(
&
tm
);
return
dest
;
}
uid_t
udf_convert_uid
(
int
uidin
)
uid_t
udf_convert_uid
(
int
uidin
)
{
{
if
(
uidin
==
-
1
)
if
(
uidin
==
-
1
)
...
...
fs/udf/namei.c
View file @
5bdbe23a
This diff is collapsed.
Click to expand it.
fs/udf/super.c
View file @
5bdbe23a
...
@@ -768,18 +768,20 @@ udf_load_pvoldesc(struct super_block *sb, struct buffer_head *bh)
...
@@ -768,18 +768,20 @@ udf_load_pvoldesc(struct super_block *sb, struct buffer_head *bh)
{
{
struct
PrimaryVolDesc
*
pvoldesc
;
struct
PrimaryVolDesc
*
pvoldesc
;
time_t
recording
;
time_t
recording
;
long
recording_usec
;
struct
ustr
instr
;
struct
ustr
instr
;
struct
ustr
outstr
;
struct
ustr
outstr
;
pvoldesc
=
(
struct
PrimaryVolDesc
*
)
bh
->
b_data
;
pvoldesc
=
(
struct
PrimaryVolDesc
*
)
bh
->
b_data
;
if
(
udf_stamp_to_time
(
&
recording
,
lets_to_cpu
(
pvoldesc
->
recordingDateAndTime
))
)
if
(
udf_stamp_to_time
(
&
recording
,
&
recording_usec
,
lets_to_cpu
(
pvoldesc
->
recordingDateAndTime
))
)
{
{
timestamp
ts
;
timestamp
ts
;
ts
=
lets_to_cpu
(
pvoldesc
->
recordingDateAndTime
);
ts
=
lets_to_cpu
(
pvoldesc
->
recordingDateAndTime
);
udf_debug
(
"recording time %ld
, %u/%u/%u %u:%
u (%x)
\n
"
,
udf_debug
(
"recording time %ld
/%ld, %04u/%02u/%02u %02u:%02
u (%x)
\n
"
,
recording
,
ts
.
year
,
ts
.
month
,
ts
.
day
,
ts
.
hour
,
ts
.
minute
,
recording
,
recording_usec
,
ts
.
typeAndTimezone
);
ts
.
year
,
ts
.
month
,
ts
.
day
,
ts
.
hour
,
ts
.
minute
,
ts
.
typeAndTimezone
);
UDF_SB_RECORDTIME
(
sb
)
=
recording
;
UDF_SB_RECORDTIME
(
sb
)
=
recording
;
}
}
...
@@ -1397,8 +1399,9 @@ udf_read_super(struct super_block *sb, void *options, int silent)
...
@@ -1397,8 +1399,9 @@ udf_read_super(struct super_block *sb, void *options, int silent)
{
{
timestamp
ts
;
timestamp
ts
;
udf_time_to_stamp
(
&
ts
,
UDF_SB_RECORDTIME
(
sb
),
0
);
udf_time_to_stamp
(
&
ts
,
UDF_SB_RECORDTIME
(
sb
),
0
);
udf_info
(
"Mounting volume '%s', timestamp %u/%02u/%u %02u:%02u
\n
"
,
udf_info
(
"Mounting volume '%s', timestamp %04u/%02u/%02u %02u:%02u (%x)
\n
"
,
UDF_SB_VOLIDENT
(
sb
),
ts
.
year
,
ts
.
month
,
ts
.
day
,
ts
.
hour
,
ts
.
minute
);
UDF_SB_VOLIDENT
(
sb
),
ts
.
year
,
ts
.
month
,
ts
.
day
,
ts
.
hour
,
ts
.
minute
,
ts
.
typeAndTimezone
);
}
}
if
(
!
(
sb
->
s_flags
&
MS_RDONLY
))
if
(
!
(
sb
->
s_flags
&
MS_RDONLY
))
udf_open_lvid
(
sb
);
udf_open_lvid
(
sb
);
...
...
fs/udf/udfdecl.h
View file @
5bdbe23a
#ifndef __UDF_DECL_H
#ifndef __UDF_DECL_H
#define __UDF_DECL_H
#define __UDF_DECL_H
#define UDF_VERSION_NOTICE "v0.8.9"
#define UDF_VERSION_NOTICE "v0.8.9
.3
"
#ifdef __KERNEL__
#ifdef __KERNEL__
...
@@ -249,7 +249,7 @@ extern Uint32 udf64_low32(Uint64);
...
@@ -249,7 +249,7 @@ extern Uint32 udf64_low32(Uint64);
extern
Uint32
udf64_high32
(
Uint64
);
extern
Uint32
udf64_high32
(
Uint64
);
extern
time_t
*
udf_stamp_to_time
(
time_t
*
,
timestamp
);
extern
time_t
*
udf_stamp_to_time
(
time_t
*
,
long
*
,
timestamp
);
extern
timestamp
*
udf_time_to_stamp
(
timestamp
*
,
time_t
,
long
);
extern
timestamp
*
udf_time_to_stamp
(
timestamp
*
,
time_t
,
long
);
extern
time_t
udf_converttime
(
struct
ktm
*
);
extern
time_t
udf_converttime
(
struct
ktm
*
);
...
...
fs/udf/udfend.h
View file @
5bdbe23a
...
@@ -42,13 +42,13 @@
...
@@ -42,13 +42,13 @@
#define cpu_to_le32(x) (x)
#define cpu_to_le32(x) (x)
#define cpu_to_le64(x) (x)
#define cpu_to_le64(x) (x)
#endif
#endif
/* __BYTE_ORDER == 0 */
#e
ndif
#e
lse
/* __KERNEL__ */
#ifdef __KERNEL__
#include <linux/string.h>
#include <linux/string.h>
#endif
#endif
/* ! __KERNEL__ */
static
inline
lb_addr
lelb_to_cpu
(
lb_addr
in
)
static
inline
lb_addr
lelb_to_cpu
(
lb_addr
in
)
{
{
...
...
fs/udf/udftime.c
View file @
5bdbe23a
This diff is collapsed.
Click to expand it.
include/linux/cycx_drv.h
View file @
5bdbe23a
...
@@ -11,13 +11,14 @@
...
@@ -11,13 +11,14 @@
* as published by the Free Software Foundation; either version
* as published by the Free Software Foundation; either version
* 2 of the License, or (at your option) any later version.
* 2 of the License, or (at your option) any later version.
* ============================================================================
* ============================================================================
* 1999/10/23 acme cycxhw_t cleanup
* 1999/01/03 acme more judicious use of data types...
* 1999/01/03 acme more judicious use of data types...
* uclong, ucchar, etc deleted, the u8, u16, u32
* uclong, ucchar, etc deleted, the u8, u16, u32
* types are the portable way to go.
* types are the portable way to go.
* 1999/01/03 acme judicious use of data types... u16, u32, etc
* 1999/01/03 acme judicious use of data types... u16, u32, etc
*
Dec 26, 1998 Arnaldo
FIXED_BUFFERS, CONF_OFFSET,
*
1998/12/26 acme
FIXED_BUFFERS, CONF_OFFSET,
* removal of cy_read{bwl}
* removal of cy_read{bwl}
*
Aug 08, 1998 Arnaldo
Initial version.
*
1998/08/08 acme
Initial version.
*/
*/
#ifndef _CYCX_DRV_H
#ifndef _CYCX_DRV_H
#define _CYCX_DRV_H
#define _CYCX_DRV_H
...
@@ -43,22 +44,19 @@
...
@@ -43,22 +44,19 @@
/* Adapter hardware configuration. Pointer to this structure is passed to all
/* Adapter hardware configuration. Pointer to this structure is passed to all
* APIs. */
* APIs. */
typedef
struct
cycxhw
{
typedef
struct
cycxhw
{
u32
type
;
/* adapter type */
u32
fwid
;
/* firmware ID */
u32
fwid
;
/* firmware ID */
int
irq
;
/* interrupt request level */
int
irq
;
/* interrupt request level */
u32
dpmbase
;
/* dual-port memory base */
u32
dpmbase
;
/* dual-port memory base */
u32
dpmsize
;
/* dual-port memory size */
u32
dpmsize
;
/* dual-port memory size */
u32
pclk
;
/* CPU clock rate, kHz */
u32
memory
;
/* memory size */
u32
reserved
[
5
];
u32
reserved
[
5
];
}
cycxhw_t
;
}
cycxhw_t
;
/* Function Prototypes */
/* Function Prototypes */
extern
int
cycx_setup
(
cycxhw_t
*
hw
,
void
*
sfm
,
u32
len
);
extern
int
cycx_setup
(
cycxhw_t
*
hw
,
void
*
sfm
,
u32
len
);
extern
int
cycx_down
(
cycxhw_t
*
hw
);
extern
int
cycx_inten
(
cycxhw_t
*
hw
);
extern
int
cycx_intr
(
cycxhw_t
*
hw
);
extern
int
cycx_peek
(
cycxhw_t
*
hw
,
u32
addr
,
void
*
buf
,
u32
len
);
extern
int
cycx_peek
(
cycxhw_t
*
hw
,
u32
addr
,
void
*
buf
,
u32
len
);
extern
int
cycx_poke
(
cycxhw_t
*
hw
,
u32
addr
,
void
*
buf
,
u32
len
);
extern
int
cycx_poke
(
cycxhw_t
*
hw
,
u32
addr
,
void
*
buf
,
u32
len
);
extern
int
cycx_exec
(
u32
addr
);
extern
int
cycx_exec
(
u32
addr
);
extern
void
cycx_inten
(
cycxhw_t
*
hw
);
extern
void
cycx_intr
(
cycxhw_t
*
hw
);
#endif
/* _CYCX_DRV_H */
#endif
/* _CYCX_DRV_H */
include/linux/if_arp.h
View file @
5bdbe23a
...
@@ -13,6 +13,7 @@
...
@@ -13,6 +13,7 @@
* Fred N. van Kempen, <waltje@uWalt.NL.Mugnet.ORG>
* Fred N. van Kempen, <waltje@uWalt.NL.Mugnet.ORG>
* Florian La Roche,
* Florian La Roche,
* Jonathan Layes <layes@loran.com>
* Jonathan Layes <layes@loran.com>
* Arnaldo Carvalho de Melo <acme@conectiva.com.br> ARPHRD_HWX25
*
*
* This program is free software; you can redistribute it and/or
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License
* modify it under the terms of the GNU General Public License
...
@@ -47,6 +48,7 @@
...
@@ -47,6 +48,7 @@
#define ARPHRD_ADAPT 264
#define ARPHRD_ADAPT 264
#define ARPHRD_ROSE 270
#define ARPHRD_ROSE 270
#define ARPHRD_X25 271
/* CCITT X.25 */
#define ARPHRD_X25 271
/* CCITT X.25 */
#define ARPHRD_HWX25 272
/* Boards with X.25 in firmware */
#define ARPHRD_PPP 512
#define ARPHRD_PPP 512
#define ARPHRD_HDLC 513
/* (Cisco) HDLC */
#define ARPHRD_HDLC 513
/* (Cisco) HDLC */
#define ARPHRD_LAPB 516
/* LAPB */
#define ARPHRD_LAPB 516
/* LAPB */
...
...
include/linux/udf_167.h
View file @
5bdbe23a
...
@@ -54,15 +54,23 @@
...
@@ -54,15 +54,23 @@
#ifdef __KERNEL__
#ifdef __KERNEL__
#include <linux/types.h>
#include <linux/types.h>
#define Uint8 __u8
#define Uint8 __u8
#define Sint8 __s8
#define Uint16 __u16
#define Uint16 __u16
#define Sint16 __s16
#define Uint32 __u32
#define Uint32 __u32
#define Sint32 __s32
#define Uint64 __u64
#define Uint64 __u64
#define Sint64 __s64
typedef
Uint8
dstring
;
typedef
Uint8
dstring
;
#else
#else
#define Uint8 unsigned char
#define Uint8 unsigned char
#define Sint8 char
#define Uint16 unsigned short
#define Uint16 unsigned short
#define Sint16 short
#define Uint32 unsigned int
#define Uint32 unsigned int
#define Sint32 int
#define Uint64 unsigned long long
#define Uint64 unsigned long long
#define Sint64 long long
typedef
Uint8
dstring
;
typedef
Uint8
dstring
;
#endif
#endif
...
...
include/linux/udf_fs.h
View file @
5bdbe23a
...
@@ -30,8 +30,8 @@
...
@@ -30,8 +30,8 @@
#define UDF_DEFAULT_PREALLOC_BLOCKS 8
#define UDF_DEFAULT_PREALLOC_BLOCKS 8
#define UDF_DEFAULT_PREALLOC_DIR_BLOCKS 0
#define UDF_DEFAULT_PREALLOC_DIR_BLOCKS 0
#define UDFFS_DATE "99/
09/02
"
#define UDFFS_DATE "99/
10/29
"
#define UDFFS_VERSION "0.8.9"
#define UDFFS_VERSION "0.8.9
.3
"
#define UDFFS_DEBUG
#define UDFFS_DEBUG
#ifdef UDFFS_DEBUG
#ifdef UDFFS_DEBUG
...
...
net/sunrpc/clnt.c
View file @
5bdbe23a
...
@@ -294,7 +294,8 @@ rpc_call_setup(struct rpc_task *task, u32 proc,
...
@@ -294,7 +294,8 @@ rpc_call_setup(struct rpc_task *task, u32 proc,
task
->
tk_flags
|=
flags
;
task
->
tk_flags
|=
flags
;
/* Increment call count */
/* Increment call count */
rpcproc_count
(
task
->
tk_client
,
proc
)
++
;
if
(
task
->
tk_proc
<
task
->
tk_client
->
cl_maxproc
)
rpcproc_count
(
task
->
tk_client
,
proc
)
++
;
}
}
/*
/*
...
@@ -319,9 +320,14 @@ static void
...
@@ -319,9 +320,14 @@ static void
call_bind
(
struct
rpc_task
*
task
)
call_bind
(
struct
rpc_task
*
task
)
{
{
struct
rpc_clnt
*
clnt
=
task
->
tk_client
;
struct
rpc_clnt
*
clnt
=
task
->
tk_client
;
struct
rpc_xprt
*
xprt
=
clnt
->
cl_xprt
;
task
->
tk_action
=
call_reserve
;
if
(
xprt
->
stream
&&
!
xprt
->
connected
)
task
->
tk_action
=
call_reconnect
;
else
task
->
tk_action
=
call_reserve
;
task
->
tk_status
=
0
;
task
->
tk_status
=
0
;
if
(
!
clnt
->
cl_port
)
if
(
!
clnt
->
cl_port
)
rpc_getport
(
task
,
clnt
);
rpc_getport
(
task
,
clnt
);
}
}
...
@@ -340,6 +346,7 @@ call_reserve(struct rpc_task *task)
...
@@ -340,6 +346,7 @@ call_reserve(struct rpc_task *task)
clnt
->
cl_protname
,
clnt
->
cl_server
,
clnt
->
cl_protname
,
clnt
->
cl_server
,
clnt
->
cl_softrtry
?
"giving up"
:
"retrying"
);
clnt
->
cl_softrtry
?
"giving up"
:
"retrying"
);
if
(
!
clnt
->
cl_softrtry
)
{
if
(
!
clnt
->
cl_softrtry
)
{
task
->
tk_action
=
call_bind
;
rpc_delay
(
task
,
5
*
HZ
);
rpc_delay
(
task
,
5
*
HZ
);
return
;
return
;
}
}
...
@@ -376,25 +383,27 @@ call_reserveresult(struct rpc_task *task)
...
@@ -376,25 +383,27 @@ call_reserveresult(struct rpc_task *task)
if
(
task
->
tk_status
>=
0
)
{
if
(
task
->
tk_status
>=
0
)
{
task
->
tk_action
=
call_allocate
;
task
->
tk_action
=
call_allocate
;
goto
out
;
return
;
}
else
if
(
task
->
tk_status
==
-
EAGAIN
)
{
}
switch
(
task
->
tk_status
)
{
case
-
EAGAIN
:
case
-
ENOBUFS
:
task
->
tk_timeout
=
task
->
tk_client
->
cl_timeout
.
to_resrvval
;
task
->
tk_timeout
=
task
->
tk_client
->
cl_timeout
.
to_resrvval
;
task
->
tk_status
=
0
;
task
->
tk_status
=
0
;
xprt_reserve
(
task
)
;
task
->
tk_action
=
call_reserve
;
goto
out
;
break
;
}
else
if
(
task
->
tk_status
==
-
ETIMEDOUT
)
{
case
-
ETIMEDOUT
:
dprintk
(
"RPC: task timed out
\n
"
);
dprintk
(
"RPC: task timed out
\n
"
);
task
->
tk_action
=
call_timeout
;
task
->
tk_action
=
call_timeout
;
goto
out
;
break
;
}
else
{
default:
task
->
tk_action
=
NULL
;
task
->
tk_action
=
NULL
;
if
(
!
task
->
tk_rqstp
)
{
printk
(
"RPC: task has no request, exit EIO
\n
"
);
rpc_exit
(
task
,
-
EIO
);
}
}
}
if
(
!
task
->
tk_rqstp
)
{
printk
(
"RPC: task has no request, exit EIO
\n
"
);
rpc_exit
(
task
,
-
EIO
);
}
out:
return
;
}
}
/*
/*
...
@@ -424,7 +433,7 @@ call_allocate(struct rpc_task *task)
...
@@ -424,7 +433,7 @@ call_allocate(struct rpc_task *task)
if
(
!
signalled
())
{
if
(
!
signalled
())
{
xprt_release
(
task
);
xprt_release
(
task
);
task
->
tk_action
=
call_reserve
;
task
->
tk_action
=
call_reserve
;
rpc_delay
(
task
,
HZ
);
rpc_delay
(
task
,
HZ
>>
4
);
return
;
return
;
}
}
...
@@ -477,7 +486,7 @@ call_encode(struct rpc_task *task)
...
@@ -477,7 +486,7 @@ call_encode(struct rpc_task *task)
printk
(
"RPC: call_header failed, exit EIO
\n
"
);
printk
(
"RPC: call_header failed, exit EIO
\n
"
);
rpc_exit
(
task
,
-
EIO
);
rpc_exit
(
task
,
-
EIO
);
}
else
}
else
if
((
status
=
encode
(
req
,
p
,
task
->
tk_argp
))
<
0
)
{
if
(
encode
&&
(
status
=
encode
(
req
,
p
,
task
->
tk_argp
))
<
0
)
{
printk
(
KERN_WARNING
"%s: can't encode arguments: %d
\n
"
,
printk
(
KERN_WARNING
"%s: can't encode arguments: %d
\n
"
,
clnt
->
cl_protname
,
-
status
);
clnt
->
cl_protname
,
-
status
);
rpc_exit
(
task
,
status
);
rpc_exit
(
task
,
status
);
...
@@ -508,19 +517,16 @@ call_receive(struct rpc_task *task)
...
@@ -508,19 +517,16 @@ call_receive(struct rpc_task *task)
task
->
tk_pid
,
task
->
tk_status
);
task
->
tk_pid
,
task
->
tk_status
);
task
->
tk_action
=
call_status
;
task
->
tk_action
=
call_status
;
/* In case of error, evaluate status */
if
(
task
->
tk_status
<
0
)
/* Need to ensure cleanups are performed by xprt_receive_status() */
return
;
xprt_receive
(
task
)
;
/* If we have no decode function, this means we're performing
/* If we have no decode function, this means we're performing
* a void call (a la lockd message passing). */
* a void call (a la lockd message passing). */
if
(
!
rpcproc_decode
(
task
->
tk_client
,
task
->
tk_proc
))
{
if
(
!
rpcproc_decode
(
task
->
tk_client
,
task
->
tk_proc
))
{
rpc_remove_wait_queue
(
task
);
/* remove from xprt_pending */
task
->
tk_action
=
NULL
;
task
->
tk_action
=
NULL
;
return
;
return
;
}
}
xprt_receive
(
task
);
}
}
/*
/*
...
@@ -530,6 +536,7 @@ static void
...
@@ -530,6 +536,7 @@ static void
call_status
(
struct
rpc_task
*
task
)
call_status
(
struct
rpc_task
*
task
)
{
{
struct
rpc_clnt
*
clnt
=
task
->
tk_client
;
struct
rpc_clnt
*
clnt
=
task
->
tk_client
;
struct
rpc_xprt
*
xprt
=
clnt
->
cl_xprt
;
struct
rpc_rqst
*
req
;
struct
rpc_rqst
*
req
;
int
status
=
task
->
tk_status
;
int
status
=
task
->
tk_status
;
...
@@ -538,28 +545,48 @@ call_status(struct rpc_task *task)
...
@@ -538,28 +545,48 @@ call_status(struct rpc_task *task)
if
(
status
>=
0
)
{
if
(
status
>=
0
)
{
task
->
tk_action
=
call_decode
;
task
->
tk_action
=
call_decode
;
}
else
if
(
status
==
-
ETIMEDOUT
)
{
}
task
->
tk_status
=
0
;
req
=
task
->
tk_rqstp
;
switch
(
status
)
{
case
-
ETIMEDOUT
:
task
->
tk_action
=
call_timeout
;
task
->
tk_action
=
call_timeout
;
}
else
if
(
status
==
-
EAGAIN
)
{
break
;
if
(
!
(
req
=
task
->
tk_rqstp
))
case
-
EAGAIN
:
if
(
!
req
)
task
->
tk_action
=
call_reserve
;
task
->
tk_action
=
call_reserve
;
else
if
(
!
task
->
tk_buffer
)
else
if
(
!
task
->
tk_buffer
)
task
->
tk_action
=
call_allocate
;
task
->
tk_action
=
call_allocate
;
else
if
(
req
->
rq_damaged
)
else
if
(
req
->
rq_damaged
)
{
task
->
tk_action
=
call_encode
;
task
->
tk_action
=
call_encode
;
else
clnt
->
cl_stats
->
rpcretrans
++
;
}
else
{
task
->
tk_action
=
call_transmit
;
task
->
tk_action
=
call_transmit
;
}
else
if
(
status
==
-
ENOTCONN
)
{
clnt
->
cl_stats
->
rpcretrans
++
;
task
->
tk_action
=
call_reconnect
;
}
}
else
if
(
status
==
-
ECONNREFUSED
&&
clnt
->
cl_autobind
)
{
break
;
task
->
tk_action
=
call_bind
;
case
-
ECONNREFUSED
:
clnt
->
cl_port
=
0
;
case
-
ENOTCONN
:
}
else
{
if
(
clnt
->
cl_autobind
||
!
clnt
->
cl_port
)
{
clnt
->
cl_port
=
0
;
task
->
tk_action
=
call_bind
;
}
else
if
(
xprt
->
stream
)
task
->
tk_action
=
call_reconnect
;
else
{
rpc_delay
(
task
,
5
*
HZ
);
/* Hope it all wears off */
if
(
req
->
rq_damaged
)
task
->
tk_action
=
call_encode
;
else
task
->
tk_action
=
call_transmit
;
clnt
->
cl_stats
->
rpcretrans
++
;
}
break
;
default:
if
(
clnt
->
cl_chatty
)
if
(
clnt
->
cl_chatty
)
printk
(
"%s: RPC call returned error %d
\n
"
,
printk
(
"%s: RPC call returned error %d
\n
"
,
clnt
->
cl_protname
,
-
status
);
clnt
->
cl_protname
,
-
status
);
task
->
tk_action
=
NULL
;
rpc_exit
(
task
,
status
);
return
;
}
}
}
}
...
@@ -600,7 +627,7 @@ call_timeout(struct rpc_task *task)
...
@@ -600,7 +627,7 @@ call_timeout(struct rpc_task *task)
if
(
req
)
if
(
req
)
printk
(
"%s: server %s not responding, still trying
\n
"
,
printk
(
"%s: server %s not responding, still trying
\n
"
,
clnt
->
cl_protname
,
clnt
->
cl_server
);
clnt
->
cl_protname
,
clnt
->
cl_server
);
else
else
printk
(
"%s: task %d can't get a request slot
\n
"
,
printk
(
"%s: task %d can't get a request slot
\n
"
,
clnt
->
cl_protname
,
task
->
tk_pid
);
clnt
->
cl_protname
,
task
->
tk_pid
);
}
}
...
@@ -610,6 +637,8 @@ call_timeout(struct rpc_task *task)
...
@@ -610,6 +637,8 @@ call_timeout(struct rpc_task *task)
minor_timeout:
minor_timeout:
if
(
!
clnt
->
cl_port
)
{
if
(
!
clnt
->
cl_port
)
{
task
->
tk_action
=
call_bind
;
task
->
tk_action
=
call_bind
;
}
else
if
(
clnt
->
cl_xprt
->
stream
&&
!
clnt
->
cl_xprt
->
connected
)
{
task
->
tk_action
=
call_reconnect
;
}
else
if
(
!
req
)
{
}
else
if
(
!
req
)
{
task
->
tk_action
=
call_reserve
;
task
->
tk_action
=
call_reserve
;
}
else
if
(
req
->
rq_damaged
)
{
}
else
if
(
req
->
rq_damaged
)
{
...
@@ -628,14 +657,12 @@ call_timeout(struct rpc_task *task)
...
@@ -628,14 +657,12 @@ call_timeout(struct rpc_task *task)
static
void
static
void
call_reconnect
(
struct
rpc_task
*
task
)
call_reconnect
(
struct
rpc_task
*
task
)
{
{
struct
rpc_clnt
*
clnt
=
task
->
tk_client
;
dprintk
(
"RPC: %4d call_reconnect status %d
\n
"
,
dprintk
(
"RPC: %4d call_reconnect status %d
\n
"
,
task
->
tk_pid
,
task
->
tk_status
);
task
->
tk_pid
,
task
->
tk_status
);
if
(
task
->
tk_status
==
0
)
{
task
->
tk_action
=
call_reserve
;
task
->
tk_action
=
call_status
;
task
->
tk_status
=
0
;
task
->
tk_status
=
-
EAGAIN
;
clnt
->
cl_stats
->
netreconn
++
;
return
;
}
task
->
tk_client
->
cl_stats
->
netreconn
++
;
xprt_reconnect
(
task
);
xprt_reconnect
(
task
);
}
}
...
@@ -685,7 +712,9 @@ call_decode(struct rpc_task *task)
...
@@ -685,7 +712,9 @@ call_decode(struct rpc_task *task)
}
}
task
->
tk_action
=
NULL
;
task
->
tk_action
=
NULL
;
task
->
tk_status
=
decode
(
req
,
p
,
task
->
tk_resp
);
if
(
decode
)
task
->
tk_status
=
decode
(
req
,
p
,
task
->
tk_resp
);
dprintk
(
"RPC: %4d call_decode result %d
\n
"
,
task
->
tk_pid
,
dprintk
(
"RPC: %4d call_decode result %d
\n
"
,
task
->
tk_pid
,
task
->
tk_status
);
task
->
tk_status
);
}
}
...
@@ -714,11 +743,10 @@ call_refreshresult(struct rpc_task *task)
...
@@ -714,11 +743,10 @@ call_refreshresult(struct rpc_task *task)
dprintk
(
"RPC: %4d call_refreshresult (status %d)
\n
"
,
dprintk
(
"RPC: %4d call_refreshresult (status %d)
\n
"
,
task
->
tk_pid
,
task
->
tk_status
);
task
->
tk_pid
,
task
->
tk_status
);
if
(
task
->
tk_status
<
0
)
{
if
(
task
->
tk_status
<
0
)
task
->
tk_status
=
-
EACCES
;
rpc_exit
(
task
,
-
EACCES
);
task
->
tk_action
=
NULL
;
else
}
else
task
->
tk_action
=
call_bind
;
task
->
tk_action
=
call_reserve
;
}
}
/*
/*
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment