Oops, r335053 had an old version of the comment about 16-bit linux dev_t

translation.
This commit is contained in:
Bruce Evans 2018-06-13 12:44:45 +00:00
parent 5add83935a
commit 407a812657

View File

@ -130,18 +130,20 @@ translate_fd_major_minor(struct thread *td, int fd, struct stat *buf)
/* /*
* l_dev_t has the same encoding as dev_t in the latter's low 16 bits, so * l_dev_t has the same encoding as dev_t in the latter's low 16 bits, so
* don't bother going through major() and minor(). Keep doing blind * truncation of a dev_t to 16 bits gives the same result as unpacking
* truncation, as for other fields. The previous version didn't even do * using major() and minor() and repacking in the l_dev_t format. This
* blind truncation after dev_t was expanded to 64 bits. It failed to * detail is hidden in dev_to_ldev(). Overflow in conversions of dev_t's
* mask out bits 8-15 in minor(). These bits can only be nonzero in th * are not checked for, as for other fields.
* 64-bit version.
* *
* This is only used for st_dev. st_dev is for the mounted-on device so * dev_to_ldev() is only used for translating st_dev. When we convert
* it can't be a device that needs very special translation. The translation * st_rdev for copying it out, it isn't really a dev_t, but has already
* of blind truncation is done here. st_rdev is supposed to be specially * been translated to an l_dev_t in a nontrivial way. Translating it
* translated in callers, with the blind truncation done there too and * again would be illogical but would have no effect since the low 16
* st_rdev in the native struct state abused to hold the linux st_rdev. * bits have the same encoding.
* Callers do the last step using an open-coded Linux makedev(). *
* The nontrivial translation for st_rdev renumbers some devices, but not
* ones that can be mounted on, so it is consistent with the translation
* for st_dev except when the renumbering or truncation causes conflicts.
*/ */
#define dev_to_ldev(d) ((uint16_t)(d)) #define dev_to_ldev(d) ((uint16_t)(d))