Собственно, возник один вопрос. Я создаю RAW-сокет (чтобы в Ethernet-фрейме была возможность указать MAC), привязываю его к интерфейсу и пытаюсь слать пакет, который я собрал. Проблема заключается в следующем: в логах моего приложения отправка выполняется, без ошибок, в tcpdump я также вижу отправку этого пакета, однако dhcping говорит "no answer". Если запустить этот dhcping через strace, то видно, что он слушает 0.0.0.0:68 UDP, а затем висит в select, который позже отваливается по таймауту. Если попытаться послушать этот же порт через nc -u -l 127.0.0.1 68, то при этих же обстоятельствах nc в терминал ничего не пишет. Может быть есть идеи, в чем может быть проблема, в какую сторону посмотреть?
ОС - Ubuntu 20.04, 5.13.0-44-generic
Код - https://pastebin.com/2SYKVgdV (2 закомменченные строки вверху - пробовал разные варианты открытия сокета, не помогло)
Вывод tcpdump (сверху пакет, отправленный программой dhcping, снизу мой) - https://pastebin.com/guHMU9TX
Вывод dhcping - https://pastebin.com/LBx7BdYC
dhcping через strace - https://pastebin.com/Xwy28kZE
AF_INET вместо AF_PACKET наверное...
Есть кто то с РБ? Не заходит на пастпбин по ссылке(
raw_socket = socket(AF_INET, SOCK_RAW, protocol); For SOCK_RAW you may specify a valid IANA IP protocol defined in RFC 1700 assigned numbers. не понятно зачем Вам нужен DST MAC в пакете - если определить broadcast это или нет - это можно сделать по DST IP.
Не уверен, но вроде мне надо в DHCPOFFER обязательно указывать MAC, потому что у клиента на данный момент еще нет IP-адреса в сети.
в сообщении есть мак клиента - для этого там есть отдельное поле длиной в 16 байт, а так-же длина данных в нем (должен быть 6) и тип (должен быть 1 для ethernet)
Эта логика у меня уже есть (хоть и MAC сейчас захардкожен для lo интерфейса), но разве MAC не должен также быть указан во фрейме на L2?
для broadcast фрейма dst mac будет обычно ff:ff:ff:ff:ff:ff - смысл его хардкодить? на lo у вас работать не будет dhcp - вы даже не сможете его нормально протестировать - на lo нету arp. отправить можно либо конкретному клиенту через arp injection (как это сделано например в dnsmasq) либо правильнее отправлять эти запросы броадкастом - если они пришли броадкастом.
Вот оно что, спасибо
Я это в образовательных целях, хотелось самому пройти и попытаться решить возникающие проблемы
Там и смотрите как сделано
Я уже оттуда потырил :D
Обсуждают сегодня