summaryrefslogtreecommitdiff
path: root/libnetfs
diff options
context:
space:
mode:
Diffstat (limited to 'libnetfs')
-rw-r--r--libnetfs/ChangeLog7
-rw-r--r--libnetfs/io-read.c9
2 files changed, 14 insertions, 2 deletions
diff --git a/libnetfs/ChangeLog b/libnetfs/ChangeLog
index c1dbb120..20f60e53 100644
--- a/libnetfs/ChangeLog
+++ b/libnetfs/ChangeLog
@@ -1,3 +1,10 @@
+2002-05-23 Marcus Brinkmann <marcus@gnu.org>
+
+ * io-read.c (netfs_S_io_read): If desired amount is larger than
+ symlink length, truncate amount. Actually use WHOLE_LINK to store
+ link target temporarily. When reading the link target directly,
+ update *DATALEN.
+
2002-05-13 Roland McGrath <roland@frob.com>
* netfs.h (struct node): New member `nn_translated'.
diff --git a/libnetfs/io-read.c b/libnetfs/io-read.c
index a4b1b2e2..ff8fbcff 100644
--- a/libnetfs/io-read.c
+++ b/libnetfs/io-read.c
@@ -65,6 +65,8 @@ netfs_S_io_read (struct protid *user,
if (start + amount > size)
amount = size - start;
+ if (amount > size)
+ amount = size;
if (start >= size)
{
@@ -74,7 +76,7 @@ netfs_S_io_read (struct protid *user,
else if (amount < size || start > 0)
{
char *whole_link = alloca (size);
- err = netfs_attempt_readlink (user->user, node, *data);
+ err = netfs_attempt_readlink (user->user, node, whole_link);
if (! err)
{
memcpy (*data, whole_link + start, amount);
@@ -82,7 +84,10 @@ netfs_S_io_read (struct protid *user,
}
}
else
- err = netfs_attempt_readlink (user->user, node, *data);
+ {
+ err = netfs_attempt_readlink (user->user, node, *data);
+ *datalen = amount;
+ }
}
else
/* Read from a normal file. */