svn commit: r297690 - head/sys/boot/forth

Bruce Evans brde at optusnet.com.au
Fri Apr 8 09:59:42 UTC 2016


On Thu, 7 Apr 2016, Maxim Sobolev wrote:

> Hi Bruce, thanks for the input! I will see if I can move that piece into
> loader.8 and extend it a bit from the source "documentation".

Thanks.

I checked what happens for space and newline as field separators.  They
both to work in -current.  The newline form is less backwards compatible
and has other problems, so it should never be used.

Quoting for the spaces and newlines is painful, and also unclearly
documented.  I noticed these problems:
- in the static env source file, IIRC spaces don't work despite the
   strings being quoted, so I use hex escapes.  Octal escapes might
   work.  I doubt that the format is documented.  It is either not
   just C string format, or there is a problem with outer quotes being
   removed.
- in the default loader.conf and device.hints, everything is quoted with
   literal double quotes, even though most of the strings don't have
   whitespace.  I don't know if this is needed.  Quoting has a lot of
   documentation in loader.8
- the 'show' command in at least old versions of loader strips quotes,
   even in strings with whitespace.  Setting setting foo=123 and
   foo="123" both give 123.  Hex escapes are documented to work in the
   parser, but don't work from the command line (\x20 becomes x20), so
   so my use of them in kernel.env wouldn't work in loader.  Octal
   escapes are docmented to work in the parser, and work from the command
   line.
- when I got the octal escape sequence for newline wrong in loader, it
   did no OPOST processing like it does for newline, so it displayed a
   strange glyph (whatever is in the BIOS font).  Kernel error messages
   did the same.  For syscons, boot messages use the BIOS font.  I think
   vt would not display anything for control characters.
- when mountroot tries a device that doesn't exist, it prints the
   confusing errno 19.  19 is ENODEV.  ENODEV means ENOENT for the device.
   Documentation of this was broken by nmount in mount.2.  It still refers
   to the ufs_args struct which is not used by nmount and is no longer
   documented (except via this broken pointer) in mount.2.
- quoting is needed for strings with spaces or escape sequences: setting
   either foo=1 2 3 or foo=1\0402\0403 are syntax errors.
- loader.8, when viewed using man, has a few instances of excessive
   quoting too.  I not see that this a markup error.  Double quotes for
   string literals are rendered on a text terminal as 2 single quote
   characters each.  The string literals should be marked up as literals,
   especially the quotes in them, so that the quotes are rendered literally.
- loader.conf.5 barely documents quoting.  It just says that settings have
   the form variable="value".  The double quotes are correctly rendered for
   this but are misrendered in all examples.

Bruce


More information about the svn-src-head mailing list