Günther Noack 878b30c0bc fspread: fix buffer overflow
Without this fix, fspread is trusting the server to return as much
data as requested, or less. If a server responds with more data
though, fspread writes beyond the bounds of the buffer to fill, which
is passed in by the caller. It depends on the caller of fspread()
where that buffer is, so there are various possible attack vectors.

In the Plan9 kernel, I found this implemented in devmnt.c, where
overly large responses are truncated to the size requested before
copying, so I assume that this strategy works here too.

This also affects fsread() and fsreadn(), which are based on
fspread().
2021-04-05 05:19:49 -04:00
2012-03-05 16:36:31 -05:00
2017-09-14 17:25:17 +02:00
2021-03-23 20:59:23 -04:00
2005-09-13 01:24:50 +00:00
2021-03-23 20:59:23 -04:00
2020-12-30 07:53:28 -05:00
2017-09-14 17:25:17 +02:00
2017-09-14 17:25:17 +02:00
2021-01-29 19:33:10 -05:00
2004-04-21 23:43:46 +00:00
2017-09-14 17:25:17 +02:00
2005-01-13 04:56:07 +00:00
2017-09-14 17:25:17 +02:00
2021-04-05 05:19:49 -04:00
2021-03-23 20:59:23 -04:00
2008-05-10 13:38:21 -04:00
2005-11-25 13:18:11 +00:00
2017-07-23 11:11:56 +00:00
2020-12-30 07:53:28 -05:00
2021-03-23 20:59:23 -04:00
2005-11-25 13:18:11 +00:00
2013-08-13 12:46:38 -04:00

This is a port of many Plan 9 libraries and programs to Unix.

Installation

To install, run ./INSTALL. It builds mk and then uses mk to run the rest of the installation.

For more details, see install(1), at install.txt in this directory and at https://9fans.github.io/plan9port/man/man1/install.html.

Documentation

See https://9fans.github.io/plan9port/man/ for more documentation. (Documentation is also in this tree, but you need to run a successful install first. After that, "9 man 1 intro".)

Intro(1) contains a list of man pages that describe new features or differences from Plan 9.

Helping out

If you'd like to help out, great!

If you port this code to other architectures, please share your changes so others can benefit.

Git

You can use Git to keep your local copy up-to-date as we make changes and fix bugs. See the git(1) man page here ("9 man git") for details on using Git.

Status

Build Status Coverity Scan Build Status

Contact

Languages
C 91.6%
Roff 1.4%
C++ 1.3%
Yacc 1.2%
Shell 1.2%
Other 3%