Since these articles came out, I've noticed two broken ports I saw prior seem to have vanished. One port has seen significant improvement in response to these articles, although still has significant concerns. And worst of all, more ports are popping up.
The official team has since reiterated some of these concerns, and I also wrote two articles regarding some concerns with random data.
Unfortunately, many of these ports are continuing to rely on arc4random() implementations on certain OSs or from certain portability libraries. These OSs or libraries may be copying some or all of the code from OpenBSD, but they are not copying the implementation.
To demonstrate this, let's see how different implementations of arc4random() work across fork() using the following test code:
/* Blogger is refusing to allow me to list the headers without trying to escape the signs. So they are: stdio.h, stdlib.h, stdint.h, unistd.h, sys/wait.h And on Linux: bsd/stdlib.h */ int main() { int children = 3; pid_t pid = getpid(); printf("parent process %08x: %08x %08x\n", (uint32_t)pid, arc4random(), arc4random()); fflush(stdout); while (children--) { pid_t pid = fork(); if (pid > 0) //Parent { waitpid(pid, 0, 0); } else if (pid == 0) //Child { pid = getpid(); printf(" child process %08x: %08x %08x\n", (uint32_t)pid, arc4random(), arc4random()); fflush(stdout); _exit(0); } else //Error { perror(0); break; } } printf("parent process %08x: %08x %08x\n", (uint32_t)pid, arc4random(), arc4random()); fflush(stdout); return(0); }
OpenBSD (the reference implementation):
parent process 0000660d: beb04672 aa183dd0Linux with libbsd 0.6:
child process 00001a2a: e52e0b25 764966bb
child process 00007eb7: 27619dd1 a7c0df81
child process 000039f5: 33daf1f1 4524c6c6
parent process 0000660d: 1eb05b45 d3956c43
parent process 000031cb: 2bcaaa9a 01532d3fNetBSD 6.1.2:
child process 000031cc: 3b43383f 4fbbb4d5
child process 000031cd: 3b43383f 4fbbb4d5
child process 000031ce: 3b43383f 4fbbb4d5
parent process 000031cb: 3b43383f 4fbbb4d5
parent process 0000021a: 4bc81424 958bf90fFreeBSD 9.2:
child process 0000021f: c0681a36 5a3f8bdb
child process 00000022: c0681a36 5a3f8bdb
child process 000001fc: c0681a36 5a3f8bdb
parent process 0000021a: c0681a36 5a3f8bdb
parent process 0000032e: 03d19ad2 543c5fa4DragonFlyBSD 3.4.3:
child process 0000032f: 6e3a1214 57b74381
child process 00000330: 6e3a1214 57b74381
child process 00000331: 6e3a1214 57b74381
parent process 0000032e: 6e3a1214 57b74381
parent process 0000030a: cb987922 8f94fb58
child process 0000030b: 65047965 1ebdc52b
child process 0000030c: 65047965 1ebdc52b
child process 0000030d: 65047965 1ebdc52b
parent process 0000030a: 65047965 1ebdc52b
So in looking at this data, one can see that on OpenBSD the random data is utterly different between the parent and all the various children. However, in all the ports of the function, the parent and children all share the exact same state after the fork() call. This situation is fine for single-process programs, but is a disaster in multi-process ones.
Since LibreSSL is having its random needs all being supplied by arc4random*(), and it can be used by multi-process servers, there is a serious porting problem here.
I covered this problem without elaboration in my previous article. See there for some solutions. The OpenBSD team is saying randomness is the responsibility of the OS, and for many of the issues involved, they are quite right. However, remember your ports cannot necessarily rely on the random functions provided by your OS. Even if the OSs fix them in future versions, one still has to be mindful of porting to older ones, so ensure your port doesn't rely too much on the OS.
Just an FYI - it appears to work correctly on OS X:
ReplyDeleteparent process 0000038b: e7ac9715 8eecdd17
child process 0000038c: e7ed4b63 77516582
child process 0000038d: 4bec9c8d 3e782fd9
child process 0000038e: e0910fc3 10a951b0
parent process 0000038b: 83ba6281 970b07d5
For FreeBSD (libbsd via FreeBSD) at least, the problem is that they ARE derived from the OpenBSD implementation. Unfortunately, they haven't pulled upstream changes since the fork fix went into OpenBSD in 2003.
ReplyDeleteIn the case of FreeBSD and NetBSD, this seems to be because of (unfounded) concerns with the performance of getpid() (Someone should probably poke them and get them to update.) In the case of libbsd, this seems to be something the authors don't know about, so I'll try to push it upstream.
Whether FreeBSD is using an implementation that was derived from OpenBSD's implementation or not is NOT the issue. It is whether the implementation they're using mimics the same behavior as the CURRENT implementation within OpenBSD, not an implementation from 11 years ago.
ReplyDeleteExcellent information, I like your blog.
ReplyDeleteBest Website Development Low Cost in Kolkata
Best Software Development Company in Kolkata
Best Web Development Company in kolkata
Thanks for sharing, nice post! Post really provice useful information!
ReplyDeleteHương Lâm chuyên cung cấp máy photocopy, chúng tôi cung cấp máy photocopy ricoh, toshiba, canon, sharp, đặc biệt chúng tôi có cung cấp máy photocopy màu uy tín, giá rẻ nhất.
Benificial for Ibps po, Clerk, SBI clerk, PO, RRB PO, Cler and Other Competitive Examination
ReplyDeleteEnglish Comprehension 2020
HOW TO SETUP HP ENVY 7155 TO WIFI, introduce and design simple strides to interface printers, wireless setup , driver introduce, streaming gadgets, information recuperation, email arrangement and pc rules.
ReplyDeleteDoubtlessly a Goliath and fulfilling thought, at any rate the thing is, it will cost a ton to the property holder to see the relationship of a kept up inside decorator. The Printer not Activated Error Code 30 because of wrong printer is set as the default printer and driver is missing. Contact our executive and we help you to fix Error Code -30.
ReplyDeleteNo missing, correspondingly as buts, your blog is epic. I'm going to bookmark it and plan to restore out of nowhere. The Hostinger Coupon Code India 2021. Best offers 80% off. Best Price available in this platform.
ReplyDelete
ReplyDeleteHere is always right information and i am very enjo
Odisha Resultes
Hi.....
ReplyDeleteReplace openssl with libressl. First, replace the port. # portmaster -o security/libressl security/openssl. Then update all dependencies.
You are also read more About Home Loan
Best gaming monitor under 15000 India 2022
ReplyDeleteTotosite has different subscription codes depending on the capabilities of the verification site. The Food Verification Expert security code and dash provide the most reliable environment for using Totosite games in private Toto. 토토사이트 메이저 안전놀이터 도메인 안전놀이터
ReplyDeleteVery nice post. I just stumbled upon your blog and wanted to say
ReplyDeletethat I’ve truly enjoyed surfing around your blog posts.
섯다
After all I will be subscribing to your feed and I hope you write again very soon!
ReplyDeleteA debt of gratitude is in order for sharing this helpful information..
스포츠토토
Incredible things you've generally imparted to us. Simply
ReplyDeletecontinue written work this sort of posts. The time which was
squandered in going for educational cost now it can be utilized for
studies. Thanks
한국야동
You have a decent point here! I absolutely concur with what you have
ReplyDeletesaid!!Thanks for sharing your views...hope more individuals will
read this article!!!
안전놀이터
Hi.....
ReplyDeleteThe other day I wrote an article discussing LibreSSL, and the common mistakes being made by those thinking they know how to port it to other ...
If any issue then contacts me The Syndicate Star Wars
Whatsapp plus is the best social networking app nowadays. Download now from here https://apkuno.com/descargar-whatsapp-plus/
ReplyDeleteHave you discovered such an area of business as live chats? You can easily create your own and earn decent amounts from it. With this task, you will be helped by specialists in the field of live chat outsource, who will work remotely on your project and bring you excellent results. Check out this opportunity today by clicking on the link.
ReplyDeleteYou covered some issues with LibreSSL and some common porting mistakes. I such an informative article for programming lovers. I will share this one with my friends. Now it's time to avail Hayatte Luxury Services for more information.
ReplyDeleteThank you for the great article I did enjoyed reading it, I will be sure to bookmark your blog. It is really very nice and you did a great job. Now its time to avail Sign and Blind Services in Eastbourne for more information.
ReplyDeleteThis comment has been removed by the author.
ReplyDeleteWow! What a great blog, I'm going to bookmark this article. Please share more blogs of this type. Now it's time to avail same day computer repair in Essex, MD for more information.
ReplyDeleteSuch an incredible post with great informative content. I am happy to see your blog after a long interval. Keep publish more articles like these. Now its time to avail Interior Painting Services in Fort Worth Tx for more information.
ReplyDeleteMust check this game
ReplyDeletefire kirin 777 download
fire kirin 777 apk