Given the rich repertoire of tools for static source code scanning:
It is possible to use one of them to scan the C source code, generate the output as comment, and use it to differentiate between good and bad sources, and perhaps classifying into the different security bugs.
Then then using the [ C source => static code analysis output ] as sequence pair, we can feed it into an autoencoders engine and apply the Deep Learning algorithm to learn it. The output of this Deep Learning engine is the bug classes types assigned and its probability of correct classification. Using the following as example (motivated by Chatbot), the input for encoding will be C source, and output of decoding is the static analyzer output.
As mentioned in [8] autoencoder is for deterministics outuput, but whereas VAE is for stochastic output.
But as C source codes have a lot more richer information in it, a lot of it have to be learned to be ignored - and thus only the key sequence / ordering / combinations identified which can be successfully mapped to the bug class.
Through ensemble method, it is possible to use different vulnerability scanner and compute the overall result based on weighted average of individual classes.
Through the Bayesian reasoning - if 80% of the scanner indicated positive results with confidence of 0.8, then the probability overall should be a higher value than 0.8.
Comments as classification
Given that the dataset is from NIST SAMATE juliet source - it comes instrumented with comments on bugs classes - these comments can be used as reinforcement of whether classification is correct or not.
API as classification
As indicated in [4], use of certain API in certain manner can be indicative of bug vulnerability. For example, memcpy with oversized input into the smaller size heap or stack memory. But to do this analysis, additional information have to created as different cases, for the analysis to go ahead with classification.
Post Training vs Pre Training Architecture shift
After the learning/training is over, the input will just have C source code, and the comments perhaps to be ignored. And then then autoencoder engine will be in autopilot mode to classify the bug vulnerability.
A far - fetched goal is understanding algorithm and automatically picking up protocol implementations (eg, networking protocols) - and identifying vulnerable patterns in algorithm and protocols [6].
References:
Source code auditing:
No comments:
Post a Comment