Это неважно, как я себе представляю.
Так вот с этого надо и начинать.
Не знаю зачем, но раз надо, то давайте начнем.
Как побайтово передавать Сид через родное приложение мне примерно понятно.
А вот чтобы передавать тоже самое через стороннее приложение, которым в нашем случае является Электрум, прийдется каким то образом впихивать в туже транзакцию вместе с полезной информацией еще и идентификаторы:Леджера, клиета, порядковый номер байтов и еще и сделать это так, чтобы все это не выглядело подозрительным для других. Лично я себе это плохо представляю.
Я не программист, представляю себе это так. Если кто-то обоснованно раскритикует, буду только рад.
Проще описать алгоритм передачи через eth-транзакцию, там обычно используется только один адрес, и есть порядковый номер транзакции, который будет очень кстати как счетчик отправленных байтов.
Значение r (r - это, если упрощенно, результат ecdsa функции, примененной к произвольному числу - нонсу) в подписи первой транзакции с адреса подбирается перебором нонса таким образом, чтобы какой-то байт (допустим, десятый) этого r соответствовал первому байту сида. Во второй транзакции с данного адреса передается второй байт и так далее. Для маскировки следует передавать не непосредственно байт сида, а, к примеру, xor-ить его с хешем переменной - никто тогда не сможет уличить в бэкдоре.
Учитывая что у кошелька Леджер нано Х всего 2048Кб (у других моделей еще меньше), то запихнуть туда такой сложный алгоритм, чтобы он не сильно выделялся на фоне самой прошивки и приложений думаю врядли получится, даже если писать его на ассемблере.
В 90-х, помню, на ассемблере писались шикарные демки по 4 кБ и меньше. Не думаю, что это проблема, алгоритм тут совсем несложный.