+2010-10-07 Hans-Peter Nilsson <hp@axis.com>
+
+ * sim/cris/c/seek3.c, sim/cris/c/seek4.c: New tests.
+
2010-08-24 Hans-Peter Nilsson <hp@axis.com>
* sim/cris/asm/nonvcv32.ms: Neutralize changed &&-in-macro gas syntax.
--- /dev/null
+/* Check for a sim bug, whereby the position was always unsigned
+ (truncation instead of sign-extension for 64-bit hosts). */
+#include <stdio.h>
+#include <stdlib.h>
+#include <string.h>
+#include <sys/types.h>
+#include <sys/stat.h>
+#include <fcntl.h>
+#include <unistd.h>
+
+int
+main (void)
+{
+ FILE *f;
+ const char fname[] = "sk1test.dat";
+ const char tsttxt[]
+ = "A random line of text, used to test correct read, write and seek.\n";
+ char buf[sizeof tsttxt] = "";
+ const char correct[] = "correct";
+ char buf2[sizeof correct] = {0};
+ int fd;
+
+ f = fopen (fname, "wb");
+ if (f == NULL
+ || fwrite (tsttxt, 1, strlen (tsttxt), f) != strlen (tsttxt)
+ || fclose (f) != 0)
+ {
+ printf ("fail\n");
+ exit (1);
+ }
+
+ /* We have to use file-descriptor calls instead of stream calls to
+ provoke the bug (for stream calls, the lseek call is canonicalized
+ to use SEEK_SET). */
+ fd = open (fname, O_RDONLY);
+ if (fd < 0
+ || read (fd, buf, strlen (tsttxt)) != strlen (tsttxt)
+ || strcmp (buf, tsttxt) != 0
+ || lseek (fd, -30L, SEEK_CUR) != 36
+ || read (fd, buf2, strlen (correct)) != strlen (correct)
+ || strcmp (buf2, correct) != 0)
+ {
+ printf ("fail\n");
+ exit (1);
+ }
+
+ printf ("pass\n");
+ exit (0);
+}
--- /dev/null
+/* Check for a sim bug, whereby an invalid seek (to a negative offset)
+ did not return an error. */
+#include <stdio.h>
+#include <stdlib.h>
+#include <string.h>
+#include <errno.h>
+#include <sys/types.h>
+#include <sys/stat.h>
+#include <fcntl.h>
+#include <unistd.h>
+
+int
+main (void)
+{
+ FILE *f;
+ const char fname[] = "sk1test.dat";
+ const char tsttxt[]
+ = "A random line of text, used to test correct read, write and seek.\n";
+ char buf[sizeof tsttxt] = "";
+ int fd;
+
+ f = fopen (fname, "wb");
+ if (f == NULL
+ || fwrite (tsttxt, 1, strlen (tsttxt), f) != strlen (tsttxt)
+ || fclose (f) != 0)
+ {
+ printf ("fail\n");
+ exit (1);
+ }
+
+ fd = open (fname, O_RDONLY);
+ if (fd < 0
+ || lseek (fd, -1L, SEEK_CUR) != -1
+ || errno != EINVAL
+ || read (fd, buf, strlen (tsttxt)) != strlen (tsttxt)
+ || strcmp (buf, tsttxt) != 0)
+ {
+ printf ("fail\n");
+ exit (1);
+ }
+
+ printf ("pass\n");
+ exit (0);
+}