aboutsummaryrefslogtreecommitdiff
path: root/sys/kern/kern_uuid.c
diff options
context:
space:
mode:
authorRalf S. Engelschall <rse@FreeBSD.org>2004-01-22 13:34:11 +0000
committerRalf S. Engelschall <rse@FreeBSD.org>2004-01-22 13:34:11 +0000
commit446655ac4f558a2f9070a95ec0ed4f88347d1ffb (patch)
treeb3e8ba1994cc946907196cc329af0d953c838bef /sys/kern/kern_uuid.c
parent95d9bfd8d60057fa7a321124d39e58cb1a8ab02c (diff)
downloadsrc-446655ac4f558a2f9070a95ec0ed4f88347d1ffb.tar.gz
src-446655ac4f558a2f9070a95ec0ed4f88347d1ffb.zip
Fix generation of random multicast MAC address.
In case no real/physical IEEE 802 address is available, both the expired "draft-leach-uuids-guids-01" (section "4. Node IDs when no IEEE 802 network card is available") and RFC 2518 (section "6.4.1 Node Field Generation Without the IEEE 802 Address") recommend (quoted from RFC 2518): "The ideal solution is to obtain a 47 bit cryptographic quality random number, and use it as the low 47 bits of the node ID, with the _most_ significant bit of the first octet of the node ID set to 1. This bit is the unicast/multicast bit, which will never be set in IEEE 802 addresses obtained from network cards; hence, there can never be a conflict between UUIDs generated by machines with and without network cards." Unfortunately, this incorrectly explains how to implement this and the FreeBSD UUID generator code inherited this generation bug from the broken reference code in the standards draft. They should instead specify the "_least_ significant bit of the first octet of the node ID" as the multicast bit in a memory and hexadecimal string representation of a 48-bit IEEE 802 MAC address. This standards bug arised from a false interpretation, as the multicast bit is actually the _most_ significant bit in IEEE 802.3 (Ethernet) _transmission order_ of an IEEE 802 MAC address. The standards authors forgot that the bitwise order of an _octet_ from a MAC address _memory_ and hexadecimal string representation is still always from left (MSB, bit 7) to right (LSB, bit 0). Fortunately, this UUID generation bug could have occurred on systems without any Ethernet NICs only.
Notes
Notes: svn path=/head/; revision=124835
Diffstat (limited to 'sys/kern/kern_uuid.c')
-rw-r--r--sys/kern/kern_uuid.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/sys/kern/kern_uuid.c b/sys/kern/kern_uuid.c
index 0ff5bd5e310f..92f80c7ca4bc 100644
--- a/sys/kern/kern_uuid.c
+++ b/sys/kern/kern_uuid.c
@@ -110,7 +110,7 @@ uuid_node(uint16_t *node)
for (i = 0; i < (UUID_NODE_LEN>>1); i++)
node[i] = (uint16_t)arc4random();
- *((uint8_t*)node) |= 0x80;
+ *((uint8_t*)node) |= 0x01;
}
/*