RECENT BLOG NEWS
wolfSSL 1.6.0 is now available
Release 1.6.0 for the wolfSSL embedded ssl library adds bug fixes, support for RIPEMD-160 and SHA-512 algorithms and RSA key generation. For general build instructions see doc/Building_wolfSSL.pdf. For build options to enable RIPEMD-160 and SHA-512, please see the README included in the download.
Please contact support@yassl.com with any questions.
DTLS and wolfSSL embedded ssl
Did you know that the wolfSSL embedded ssl solution includes DTLS support? wolfSSL has supported DTLS functionality for over a year now. Frankly, we have not had much user feedback on the feature, which means that either people are not using it or that those using it are perfectly satisfied. If you care to comment, we’d love your feedback at info@yassl.com.
DTLS was initially designed to serve the needs of secure VoIP designers, SIP users, internet game builders, and others that have an unreliable connection. Further background on the genesis and purposing of DTLS can be found here: http://crypto.stanford.edu/~nagendra/papers/dtls.pdf. The RFC can be found here: http://tools.ietf.org/html/rfc4347, and the Wikipedia page is here: http://en.wikipedia.org/wiki/Datagram_Transport_Layer_Security.
wolfSSL Embedded SSL for iPhone
Did you know that wolfSSL is available for iPhone/iOS? We’ve been building and testing wolfSSL on iOS now for the last couple of years. As wolfSSL users know, the code is extremely portable. When iPhone originally launched, we decided to build for the device as yet another test for portability. Everything moved over smoothly and we’ve been building and testing each incremental release ever since. Let us know if you’re building cross platform applications and need support for iPhone by contacting us at info@yassl.com.
The Benefit of Stream Ciphers
Ever wondered what the difference between a block cipher and a stream cipher was? A block cipher has to be encrypted in chunks that are the block size for the cipher. For example, AES has block size of 16 bytes. So if you`re encrypting a bunch of small, 2 or 3 byte, chucks back and forth, over 80% of the data is useless padding, decreasing the speed of the encryption/decryption process and needlessly wasting network bandwidth to boot. So basically block ciphers are designed for large chucks of data, have block sizes requiring padding, and use a fixed, unvarying transformation.
Stream ciphers work well for large or small chucks of data. They`re suitable for smaller data sizes because no block size is required. And if speed is a concern, stream ciphers are your answer, because they use a simpler transformation that typically involves an xor`d keystream. So if you need to stream media, encrypt various data sizes including small ones, or have a need for a fast cipher then stream ciphers are your best bet.
SSL uses RC4 as the default stream cipher. It`s a pretty good one, though it`s getting a little older. There are some interesting advancements being made in the field and nearly two years ago wolfSSL added two ciphers from the eStream project into the code base, RABBIT and HC-128. RABBIT is nearly twice as fast as RC4 and HC-128 is about 5 times as fast! So if you`ve ever decided not to use SSL because of speed concerns, using wolfSSL`s stream ciphers should lessen or eliminate that performance doubt.
Both RABBIT and HC-128 are built by default into wolfSSL. Please see the examples or the docs for usage.
The Next wolfSSL Embedded SSL release
Hi! The next wolfSSL release should be ready this week, barring unforeseen testing issues. Our big feature addition for this release is key generation. The addition of key generation to wolfSSL clears the way for us to add certificate generation, with planned availability in September. We’ve had a number of our commercial customers as well as open source users asking us for these features for various reasons, and we’re happy to add them for the enjoyment of all.
One use case that we are particularly excited about is enabling digital signing for embedded systems and devices. Essentially, we’ll be providing the key components in our next release for our users to set up digital signing for their various embedded systems. Watch this space for our white paper on the topic. The white paper will go through the process of setting up your own private certificate authority, as you would do if you were setting up your own private app store or secure firmware download site. Many users like to do this sort of thing if they have closed systems, and don’t need certificates from a standard certificate authority. Who knows, perhaps one of our users will use wolfSSL certificate generation to break the monopolies currently enjoyed by the current batch of certificate authorities.
If you are a device vendor, you might ask the broader question of why to use SSL secure firmware download to your devices? First, you will know where the firmware updated and installed on your device is coming from. It won’t be random, it will be coming from a server you control. Second, you will know that the software updated to the device has not been tampered with during delivery.
As we saw from the recent Security B-Sides presentation “Fun with VxWorks” (The presentation can be found here: https://speakerdeck.com/hdm/fun-with-vxworks), the attack vector of current interest is embedded systems and devices. As such, vendors of connected devices such as printers, cameras, etc, will need to be setting up their own private secure delivery mechanisms for applying firmware updates, etc.
As always, we’re here to help. Contact us at info@yassl.com if you need help with this stuff, either on the server side or the device side.
wolfSSL embedded ssl and IPv6
If you are an adopter of IPv6 and want to use an embedded ssl implementation, then you may have been wondering if wolfSSL supports IPv6. The answer is yes, we do support wolfSSL running on top of IPv6. Note that our current test applications default to IPv4, so as to apply to a broader number of systems. Please see https://www.wolfssl.com/docs/wolfssl-manual/ch2/ –enable-ipv6 to change the test applications to IPv6. You can contact us at facts@wolfssl.com if you need assistance with IP version issues.
Further information on IPv6 can be found here: http://en.wikipedia.org/wiki/IPv6.
Top Five Reasons to choose wolfSSL as your Embedded SSL solution
1. Size: wolfSSL can be built as small as 30k.
2. Supports the newest standards: TLS 1.1 and 1.2, DTLS, and Stream Ciphers
3. Multi-platform
4. Royalty Free
5. OpenSSL compatibility API to ease porting into older applications
More on VxWorks vulnerabilities from DarkReading.com
Here’s another informative blog post from John Sawyer of DarkReading: http://www.darkreading.com/blog/archives/2010/08/gaining_a_footh.html.
Embedded Systems Can Mean Embedded Vulnerabilities
Here’s another warning from the media with regard to adding proper security to embedded systems: https://www.darkreading.com/risk/embedded-systems-can-mean-embedded-vulnerabilities/d/d-id/1134205. It’s a good article that reminds us how many vulnerable embedded systems are out there that need to be retrofitted with embedded ssl.
Announcing the yaSSL Embedded Web Server
As stated in previous blog posts, we have ported wolfSSL into a number of embedded web servers on behalf of our customers and community users. wolfSSL can be included in Mongoose , Lighttpd (aka Lighty), Nginx, GoAhead, and others. As a part of the work of enabling these embedded web servers to use SSL, we have learned a lot about all of these excellent products, including how they are used in embedded environments, what their code is like, and their feature support.
As a result of our evaluation, we put a lot of energy into determining which open source embedded web server should receive the bulk of our attention. We want to focus on the one that maps most closely to the needs of our customer base. The wolfSSL customer generally wants the following in their open source embedded web server, in order of priority:
1. Support for real time and embedded operating systems.
2. Commercially available support
3. Size: Small, tight code.
4. Well enabled security features
5. Speed
As a result of our evaluation, we determined that the Mongoose embedded web server should receive the bulk of our attention. Mongoose is the winner because it fits our customer’s needs, via the following metrics:
1. Default size, with wolfSSL enabled, of less than 200k.
2. Excellent code base and community.
3. Portability to real time and embedded operating systems.
Based on all of the above, and more, we have decided to sell and market a version of Mongoose we’re calling the yaSSL Embedded Web Server. We have agreed with the leader of the Mongoose community, Sergey Lyubka, to collaborate on feature development and bug fixes. Bug fixes, feature additions, and general improvements that we generate to the code base will be rolled back into the main source tree subject to Sergey’s approval. We will endeavor to be a good citizen and quality partner to the Mongoose community!
Versions of the yaSSL Embedded Web Server for RTOS and embedded environments are available immediately, upon request, on a subscription basis. Annual subscriptions are available at the price of $5,000 USD per year. Subscriptions include the following, per product line within which you embed:
1. Commercial support for wolfSSL and the yaSSL Embedded Web server
2. Updates and upgrades
3. Porting of both the SSL and Web Server to your embedded environment and chipset.
4. Commercial licenses
5. Size and speed optimization support
Supported environments include ThreadX, VxWorks, QNX, OpenWRT, Tron, iTron, Microitron, Android, OpenCL, and MontaVista. Other supported environments are available on a per request basis. We’ll also support *nix and the gaggle of *bsd’s, which we’ll port to as requested.
As always, we’d like your feedback and questions! Please contact us at info@yassl.com.
Weekly updates
Archives
- April 2025 (4)
- March 2025 (22)
- February 2025 (21)
- January 2025 (23)
- December 2024 (22)
- November 2024 (29)
- October 2024 (18)
- September 2024 (21)
- August 2024 (24)
- July 2024 (27)
- June 2024 (22)
- May 2024 (28)
- April 2024 (29)
- March 2024 (21)
- February 2024 (18)
- January 2024 (21)
- December 2023 (20)
- November 2023 (20)
- October 2023 (23)
- September 2023 (17)
- August 2023 (25)
- July 2023 (39)
- June 2023 (13)
- May 2023 (11)
- April 2023 (6)
- March 2023 (23)
- February 2023 (7)
- January 2023 (7)
- December 2022 (15)
- November 2022 (11)
- October 2022 (8)
- September 2022 (7)
- August 2022 (12)
- July 2022 (7)
- June 2022 (14)
- May 2022 (10)
- April 2022 (11)
- March 2022 (12)
- February 2022 (22)
- January 2022 (12)
- December 2021 (13)
- November 2021 (27)
- October 2021 (11)
- September 2021 (14)
- August 2021 (10)
- July 2021 (16)
- June 2021 (13)
- May 2021 (9)
- April 2021 (13)
- March 2021 (24)
- February 2021 (22)
- January 2021 (18)
- December 2020 (19)
- November 2020 (11)
- October 2020 (3)
- September 2020 (20)
- August 2020 (11)
- July 2020 (7)
- June 2020 (14)
- May 2020 (13)
- April 2020 (14)
- March 2020 (4)
- February 2020 (21)
- January 2020 (18)
- December 2019 (7)
- November 2019 (16)
- October 2019 (14)
- September 2019 (18)
- August 2019 (16)
- July 2019 (8)
- June 2019 (9)
- May 2019 (28)
- April 2019 (27)
- March 2019 (15)
- February 2019 (10)
- January 2019 (16)
- December 2018 (24)
- November 2018 (9)
- October 2018 (15)
- September 2018 (15)
- August 2018 (5)
- July 2018 (15)
- June 2018 (29)
- May 2018 (12)
- April 2018 (6)
- March 2018 (18)
- February 2018 (6)
- January 2018 (11)
- December 2017 (5)
- November 2017 (12)
- October 2017 (5)
- September 2017 (7)
- August 2017 (6)
- July 2017 (11)
- June 2017 (7)
- May 2017 (9)
- April 2017 (5)
- March 2017 (6)
- January 2017 (8)
- December 2016 (2)
- November 2016 (1)
- October 2016 (15)
- September 2016 (6)
- August 2016 (5)
- July 2016 (4)
- June 2016 (9)
- May 2016 (4)
- April 2016 (4)
- March 2016 (4)
- February 2016 (9)
- January 2016 (6)
- December 2015 (4)
- November 2015 (6)
- October 2015 (5)
- September 2015 (5)
- August 2015 (8)
- July 2015 (7)
- June 2015 (9)
- May 2015 (1)
- April 2015 (4)
- March 2015 (12)
- January 2015 (4)
- December 2014 (6)
- November 2014 (3)
- October 2014 (1)
- September 2014 (11)
- August 2014 (5)
- July 2014 (9)
- June 2014 (10)
- May 2014 (5)
- April 2014 (9)
- February 2014 (3)
- January 2014 (5)
- December 2013 (7)
- November 2013 (4)
- October 2013 (7)
- September 2013 (3)
- August 2013 (9)
- July 2013 (7)
- June 2013 (4)
- May 2013 (7)
- April 2013 (4)
- March 2013 (2)
- February 2013 (3)
- January 2013 (8)
- December 2012 (12)
- November 2012 (5)
- October 2012 (7)
- September 2012 (3)
- August 2012 (6)
- July 2012 (4)
- June 2012 (3)
- May 2012 (4)
- April 2012 (6)
- March 2012 (2)
- February 2012 (5)
- January 2012 (7)
- December 2011 (5)
- November 2011 (7)
- October 2011 (5)
- September 2011 (6)
- August 2011 (5)
- July 2011 (2)
- June 2011 (7)
- May 2011 (11)
- April 2011 (4)
- March 2011 (12)
- February 2011 (7)
- January 2011 (11)
- December 2010 (17)
- November 2010 (12)
- October 2010 (11)
- September 2010 (9)
- August 2010 (20)
- July 2010 (12)
- June 2010 (7)
- May 2010 (1)
- January 2010 (2)
- November 2009 (2)
- October 2009 (1)
- September 2009 (1)
- May 2009 (1)
- February 2009 (1)
- January 2009 (1)
- December 2008 (1)