<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE ArticleSet PUBLIC "-//NLM//DTD PubMed 2.7//EN" "https://dtd.nlm.nih.gov/ncbi/pubmed/in/PubMed.dtd">
<ArticleSet>
<Article>
<Journal>
				<PublisherName>Iranian Society of Cryptology</PublisherName>
				<JournalTitle>The ISC International Journal of Information Security</JournalTitle>
				<Issn>2008-2045</Issn>
				<Volume></Volume>
				<Issue></Issue>
				<PubDate PubStatus="epublish">
					<Year>2026</Year>
					<Month>03</Month>
					<Day>14</Day>
				</PubDate>
			</Journal>
<ArticleTitle>Learning to Locate: GNN-Powered Vulnerability Path Discovery in Open Source Code</ArticleTitle>
<VernacularTitle></VernacularTitle>
			<FirstPage></FirstPage>
			<LastPage></LastPage>
			<ELocationID EIdType="pii">242017</ELocationID>
			
<ELocationID EIdType="doi">10.22042/isecure.2026.242017</ELocationID>
			
			<Language>EN</Language>
<AuthorList>
<Author>
					<FirstName>Nima</FirstName>
					<LastName>Atashin</LastName>
<Affiliation>Faculty of Computer Engineering, University of Isfahan, Isfahan, Iran</Affiliation>

</Author>
<Author>
					<FirstName>Behrouz</FirstName>
					<LastName>Tork Ladani</LastName>
<Affiliation>Faculty of Computer Engineering, University of Isfahan, Isfahan, Iran.</Affiliation>

</Author>
<Author>
					<FirstName>Mohammadreza</FirstName>
					<LastName>Sharbaf</LastName>
<Affiliation>Faculty of Computer Engineering, University of Isfahan, Isfahan, Iran.</Affiliation>

</Author>
</AuthorList>
				<PublicationType>Journal Article</PublicationType>
		<Abstract>Detecting security vulnerabilities in open-source software is a critical task that is highly regarded in the related research communities. Several approaches have been proposed in the literature for detecting vulnerable code and identifying classes of vulnerabilities. However, there is still room to improve the explanation of the root causes of detected vulnerabilities by locating vulnerable statements and discovering the paths that lead to the activation of the vulnerability. While frameworks like SliceLocator offer explanations by identifying vulnerable paths, they rely on rule-based sink identification that limits their generalisation. In this paper, we introduce VulPathFinder, an explainable vulnerability path discovery framework that enhances SliceLocator’s methodology by utilising a novel Graph Neural Network (GNN) model for detecting sink statements, rather than relying on predefined rules. The proposed GNN captures semantic and syntactic dependencies to find potential sink points (PSPs), which are candidate statements where vulnerable paths end. After detecting PSPs, program slicing can be used to extract potentially vulnerable paths, which are then ranked by feeding them back into the target graph-based detector. Ultimately, the most probable path is returned, explaining the root cause of the detected vulnerability. We demonstrate the effectiveness of the proposed approach by performing evaluations on a benchmark of the buffer overflow CWEs from the SARD dataset, providing explanations for the corresponding detected vulnerabilities. The results show that VulPathFinder outperforms both the original SliceLocator and GNNExplainer (as a general GNN explainability tool) in discovering vulnerability paths to identified PSPs. </Abstract>
		<ObjectList>
			<Object Type="keyword">
			<Param Name="value">Explainable AI</Param>
			</Object>
			<Object Type="keyword">
			<Param Name="value">graph neural networks</Param>
			</Object>
			<Object Type="keyword">
			<Param Name="value">Program Slicing</Param>
			</Object>
			<Object Type="keyword">
			<Param Name="value">Vulnerability Detection</Param>
			</Object>
			<Object Type="keyword">
			<Param Name="value">Vulnerability Path Discovery</Param>
			</Object>
		</ObjectList>
<ArchiveCopySource DocType="pdf">https://www.isecure-journal.com/article_242017_d09621a9e736b5da1e34e4efb59402dc.pdf</ArchiveCopySource>
</Article>
</ArticleSet>
