What is Secure Software Engineering?
A popular saying is that "Reliable software does what it is supposed to do. Secure software does that and nothing else" (Ivan Arce). However, how do we get there, and can we claim that we have achieved the practice of an engineering science? The plethora of vulnerabilities found every year (thousands, and that's just in software that matters or is publicly known) suggests not. Does that mean that we don't know how, or that it is just not put into practice for reasons of ignorance, education, costs, market pressures, or something else?
The distinction between artisanal work and engineering work is well expressed in the SEI (Software Engineering Institute) work on capability maturity models. Levels of maturity range from 1 to 5:
- Ad-hoc, individual efforts and heroics
- Repeatable
- Defined
- Managed
- Optimizing (Science)


