ifconfig - кто решил, что MAC-адрес должен быть в нижнем регистре?

ifconfig - кто решил, что MAC-адрес должен быть в нижнем регистре?

На некоторых компьютерах Linux ifconfigотображает шестнадцатеричные цифры MAC-адреса ("HWaddr") в верхнем регистре. На других компьютерах Linux цифры [af] в нижнем регистре.

Почему разница? Есть ли две конкурирующие версии программы? Есть ли где-то возможность управлять этим?

решение1

Причин может быть несколько.

 Различные типы интерфейсов

Одна из возможностей: ifconfigделегировать печать аппаратного адреса реализации интерфейса. Фактическая печать выполняется функцией в interfaceструктуре для конкретного интерфейса в net-tools-1.60(изздесь), вызванный lib/interface.c, строка 678:

printf(_("HWaddr %s  "), hw->print(ptr->hwaddr));

Список поддерживаемых типов интерфейсов см. nettools-1.60в исходном коде : существуют отдельные реализации для Ethernet, оптоволокна, Token Ring и т. д.lib/hw.c

Теперь перейдем к самой функции печати: Пример: lib/ether.c:

/* Display an Ethernet address in readable format. */
static char *pr_ether(unsigned char *ptr)
{
    static char buff[64];

    snprintf(buff, sizeof(buff), "%02X:%02X:%02X:%02X:%02X:%02X",
         (ptr[0] & 0377), (ptr[1] & 0377), (ptr[2] & 0377),
         (ptr[3] & 0377), (ptr[4] & 0377), (ptr[5] & 0377)
    );
    return (buff);
}

Различные типы сетевых интерфейсов могут быть реализованы для отображения одного и того же типа информации по-разному, используя строчные буквы xs в строке форматирования вместо (т.е. %02xвместо %02X). Например, интерфейс IrDA использует строчные шестнадцатеричные цифры ( lib/irda.c):

/*
 * Function irda_print (ptr)
 *
 *    Print hardware address of interface
 *
 */
static char *irda_print(unsigned char *ptr)
{
    static char buff[8];

    sprintf(&buff[strlen(buff)], "%02x:%02x:%02x:%02x", ptr[3], ptr[2], 
        ptr[1], ptr[0]);

    return (buff);
}

Патчи дляifconfig

Другая возможность, и, вероятно, причина здесь: дистрибутивы часто меняют пакеты программного обеспечения. Приведенный выше фрагмент кода взят из оригинала net-tools-1.60, давайте рассмотрим Debian, или, скорее, его патч net-tools-1.60-23.diff(изздесь):

+--- net-tools.orig/lib/ether.c
++++ net-tools/lib/ether.c
[...]
+@@ -39,7 +39,7 @@ static char *pr_ether(unsigned char *ptr
+ {
+     static char buff[64];
+ 
+-    snprintf(buff, sizeof(buff), "%02X:%02X:%02X:%02X:%02X:%02X",
++    snprintf(buff, sizeof(buff), "%02x:%02x:%02x:%02x:%02x:%02x",
+        (ptr[0] & 0377), (ptr[1] & 0377), (ptr[2] & 0377),
+        (ptr[3] & 0377), (ptr[4] & 0377), (ptr[5] & 0377)
+   );

Поэтому Debian исправил исходный код ifconfigдля своего дистрибутива, который также может быть использован Ubuntu (Википедия: "Пакеты Ubuntu основаны на пакетах из нестабильной ветки Debian.").

Связанный контент