2013-03-24, 21:45
Hi everyone
So I called this Google+ Hangout meeting to discuss how we could participate in GSoC 2013. Some people had some technical issues to work out before they could attend, some had other problems with Google+, but eventually some people were able to attend.
The people attending were:
Robin Smidsrød (myself)
Matthew Helton (aka MultiMediaMan)
Andrew Bobulsky (aka RulerOf)
Marin Hannache (aka Mareo)
Brijesh Kumar (potential GSoC student that found us randomly)
I was asking around of what kind of skills people had and in what capacity they might consider to help out. None of the people present had any deep C skills, but we are all interested in automation, so we know some scripting language. Perl and PHP was mentioned.
Both myself, Andrew and Matthew mentioned positively that we might be able to mentor _something_ we are good at. Together with Michael Brown (mcb30) and Thomas Miletich (thomil) that are quite good at C I think we have enough people to apply. Shao Miller and John Hawley (warthog9) has also mentioned (earlier) that they'd be willing to backup the others a bit if needed, but not take on any primary responsibilites.
We discussed what potential ideas could be added to the http://ipxe.org/gsoc page, and this is what we came up with (slightly more organized then the discussion was):
1. IPv6 support
2. USB driver framework
3. Intel wireless driver
4. A revival of boot.kernel.org (or another similar service)
5. An iPXE-based file browser for FTP/NFS
6. Syntax highlighter for iPXE scripts
7. One-time LAN boot instrumentation from running OS
I'll try to summarize what was said about each topic in turn so we know what questions to address on the ideas page.
== IPv6 support ==
The current patch made by mouse is apparently not using proper async methodology, so it is not possible to merge in its current state. It is obvious for long-term usage that IPv6 support of some kind is high on the wish list for a lot of users. It is still unclear what kind of IPv6 features would have to be provided, and it is probably not realistic to do as a GSoC project because the effort is just too big and too hard to mentor. I still think it's worthwhile to put it on the page to give students something to think/dream about.
== USB driver framework ==
More and more machines these days come only with wireless and no Ethernet jack. For these machines, the only way to network boot is to use a USB-based Ethernet adapter. None of these devices are currently supported because we don't have a USB driver stack. If it is possible to implement, we'd be able to bridge access to all of our current drivers over USB, which would make a lot of things easier. This is also a big project, and probably outside the scope of GSoC, but also highly sought after. I've answered questions more times than I can recall where it came down to the fact that the hardware was not supported because it used USB.
== Intel wireless driver ==
So many machines these days comes with built-in Intel wireless (centrino) and wireless network boot is a very cool feature. For most people it is unfortunately unavailable because iPXE doesn't support the intel adapters. Getting a working Intel wifi driver that works with the current Core/Core2 architectures would open a lot of eyes everywhere.
== boot.kernel.org revival ==
We already have several sophisticated examples of menus at http://ipxe.org/examples, but what we don't have, is a service like boot.kernel.org was. Instead of using PXELinux, we now have an option to use iPXE and script a sophisticated solution that would allow recovery environments and installers to be booted straight over the internet, even with full security. The current examples are not very well structured, and to make it into a public service we need more generalization and better security. It was also mentioned that the service should be possible to clone into your own local system and modified without too much effort. It was also mentioned that we could try to generate virtual machine images already set up to provide a boot menu for your local network.
== iPXE-based file browser for FTP/NFS ==
This is a continuation of Marin's work from last year's GSoC, but really a separate project. It is basically a file browser that would allow you to pick the name of the kernel+initrd to boot, potentially specify arguments to them and then boot them. This should all happen interactively. Any file service that supports directory browsing should be usable.
== Syntax highlighter for iPXE scripts ==
As our iPXE scripts are getting bigger and bigger, it is getting harder and harder to maintain them. A syntax highlighter, or more generally a lexer/parser that can convert the ipxe script into an abstract syntax tree and enable features like syntax highlighting, code completion, context-sensitive help and such for various editors like vim, emacs, Notepad++, Eclipse or such would be very useful. Code folding and block jumping are also useful side-effects. Actually being able to verify if the script is valid _before_ you run it is also a useful thing to be able to do.
== One-time LAN boot instrumentation from running OS ==
Some BIOSes has the ability to be told to perform their next boot from the network using operating system tools. But a lot of BIOSes can't really do that. Create a solution that make it possible to instrument a running Linux and/or Windows machine to add an item to their boot menu that will boot the machine from the network the next time it starts. Andrew had some prior experience doing this thing, and it was a crude hack. Making this into something robust could be very useful.
============
It was also mentioned that the documentation on http://ipxe.org/ is good, but its more of a reference than a good tutorial on how to get a beginner started with network booting. I think we all agreed on the fact that getting started with network booting is REALLY, REALLY HARD! There are so many moving parts, DHCP, TFTP, PXE, HTTP, iSCSI, routing, BIOS/kernel handover and more that is very hard to get a good overview on. It is even harder to get it all configured to do what you want in your environment. I think we need more tutorial information, better introduction material that contains a visual overview (i.e. we need help from someone that knows how to draw or make good diagrams).
I also mentioned that I had been thinking about doing Google+ Hangouts On Air with the title "Q/A - How to get started with network booting and iPXE" were beginners could come in and ask questions on how to do things and we could answer those questions, possibly with examples and live demos. Since these sessions would be recorded and published on YouTube it would get us more publicity. My main challenge with this is basically how to get the word out. I was thinking about posting in the appropriate Reddit forums and Google+ communities, but to get more people to come I think we need to use our joint force in getting the word out.
Overall it was a great experience, and everyone involved was very into trying to do it again. My plan is to invite again in about a week, but then have a more general topic than GSoC (or possibly no topic). I hope more of you'll be able to attend. My plan is to start somewhere around 16:00 or 17:00 UTC, as that should enable most people in both Europe and America to attend during daytime. If you'd very much like to attend, please tell me what day of the week and time would work best for you.
Let's do it again!
-- Robin
So I called this Google+ Hangout meeting to discuss how we could participate in GSoC 2013. Some people had some technical issues to work out before they could attend, some had other problems with Google+, but eventually some people were able to attend.
The people attending were:
Robin Smidsrød (myself)
Matthew Helton (aka MultiMediaMan)
Andrew Bobulsky (aka RulerOf)
Marin Hannache (aka Mareo)
Brijesh Kumar (potential GSoC student that found us randomly)
I was asking around of what kind of skills people had and in what capacity they might consider to help out. None of the people present had any deep C skills, but we are all interested in automation, so we know some scripting language. Perl and PHP was mentioned.
Both myself, Andrew and Matthew mentioned positively that we might be able to mentor _something_ we are good at. Together with Michael Brown (mcb30) and Thomas Miletich (thomil) that are quite good at C I think we have enough people to apply. Shao Miller and John Hawley (warthog9) has also mentioned (earlier) that they'd be willing to backup the others a bit if needed, but not take on any primary responsibilites.
We discussed what potential ideas could be added to the http://ipxe.org/gsoc page, and this is what we came up with (slightly more organized then the discussion was):
1. IPv6 support
2. USB driver framework
3. Intel wireless driver
4. A revival of boot.kernel.org (or another similar service)
5. An iPXE-based file browser for FTP/NFS
6. Syntax highlighter for iPXE scripts
7. One-time LAN boot instrumentation from running OS
I'll try to summarize what was said about each topic in turn so we know what questions to address on the ideas page.
== IPv6 support ==
The current patch made by mouse is apparently not using proper async methodology, so it is not possible to merge in its current state. It is obvious for long-term usage that IPv6 support of some kind is high on the wish list for a lot of users. It is still unclear what kind of IPv6 features would have to be provided, and it is probably not realistic to do as a GSoC project because the effort is just too big and too hard to mentor. I still think it's worthwhile to put it on the page to give students something to think/dream about.
== USB driver framework ==
More and more machines these days come only with wireless and no Ethernet jack. For these machines, the only way to network boot is to use a USB-based Ethernet adapter. None of these devices are currently supported because we don't have a USB driver stack. If it is possible to implement, we'd be able to bridge access to all of our current drivers over USB, which would make a lot of things easier. This is also a big project, and probably outside the scope of GSoC, but also highly sought after. I've answered questions more times than I can recall where it came down to the fact that the hardware was not supported because it used USB.
== Intel wireless driver ==
So many machines these days comes with built-in Intel wireless (centrino) and wireless network boot is a very cool feature. For most people it is unfortunately unavailable because iPXE doesn't support the intel adapters. Getting a working Intel wifi driver that works with the current Core/Core2 architectures would open a lot of eyes everywhere.
== boot.kernel.org revival ==
We already have several sophisticated examples of menus at http://ipxe.org/examples, but what we don't have, is a service like boot.kernel.org was. Instead of using PXELinux, we now have an option to use iPXE and script a sophisticated solution that would allow recovery environments and installers to be booted straight over the internet, even with full security. The current examples are not very well structured, and to make it into a public service we need more generalization and better security. It was also mentioned that the service should be possible to clone into your own local system and modified without too much effort. It was also mentioned that we could try to generate virtual machine images already set up to provide a boot menu for your local network.
== iPXE-based file browser for FTP/NFS ==
This is a continuation of Marin's work from last year's GSoC, but really a separate project. It is basically a file browser that would allow you to pick the name of the kernel+initrd to boot, potentially specify arguments to them and then boot them. This should all happen interactively. Any file service that supports directory browsing should be usable.
== Syntax highlighter for iPXE scripts ==
As our iPXE scripts are getting bigger and bigger, it is getting harder and harder to maintain them. A syntax highlighter, or more generally a lexer/parser that can convert the ipxe script into an abstract syntax tree and enable features like syntax highlighting, code completion, context-sensitive help and such for various editors like vim, emacs, Notepad++, Eclipse or such would be very useful. Code folding and block jumping are also useful side-effects. Actually being able to verify if the script is valid _before_ you run it is also a useful thing to be able to do.
== One-time LAN boot instrumentation from running OS ==
Some BIOSes has the ability to be told to perform their next boot from the network using operating system tools. But a lot of BIOSes can't really do that. Create a solution that make it possible to instrument a running Linux and/or Windows machine to add an item to their boot menu that will boot the machine from the network the next time it starts. Andrew had some prior experience doing this thing, and it was a crude hack. Making this into something robust could be very useful.
============
It was also mentioned that the documentation on http://ipxe.org/ is good, but its more of a reference than a good tutorial on how to get a beginner started with network booting. I think we all agreed on the fact that getting started with network booting is REALLY, REALLY HARD! There are so many moving parts, DHCP, TFTP, PXE, HTTP, iSCSI, routing, BIOS/kernel handover and more that is very hard to get a good overview on. It is even harder to get it all configured to do what you want in your environment. I think we need more tutorial information, better introduction material that contains a visual overview (i.e. we need help from someone that knows how to draw or make good diagrams).
I also mentioned that I had been thinking about doing Google+ Hangouts On Air with the title "Q/A - How to get started with network booting and iPXE" were beginners could come in and ask questions on how to do things and we could answer those questions, possibly with examples and live demos. Since these sessions would be recorded and published on YouTube it would get us more publicity. My main challenge with this is basically how to get the word out. I was thinking about posting in the appropriate Reddit forums and Google+ communities, but to get more people to come I think we need to use our joint force in getting the word out.
Overall it was a great experience, and everyone involved was very into trying to do it again. My plan is to invite again in about a week, but then have a more general topic than GSoC (or possibly no topic). I hope more of you'll be able to attend. My plan is to start somewhere around 16:00 or 17:00 UTC, as that should enable most people in both Europe and America to attend during daytime. If you'd very much like to attend, please tell me what day of the week and time would work best for you.
Let's do it again!
-- Robin