<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
</head>
<body style="overflow-wrap: break-word; -webkit-nbsp-mode: space; line-break: after-white-space;">
Here’s a PR that more concretely expresses this approach:
<div><br>
</div>
<div>  <a href="https://github.com/openjdk/babylon/pull/263/">https://github.com/openjdk/babylon/pull/263/</a></div>
<div><br>
</div>
<div>Paul.<br>
<div>
<div><br>
<blockquote type="cite">
<div>On Oct 23, 2024, at 11:15 AM, Paul Sandoz <paul.sandoz@oracle.com> wrote:</div>
<br class="Apple-interchange-newline">
<div>
<div>Currently we model an uninitialized variable as if it were initialized with the default value. So we loose the distinction between the following assignment statements:<br>
<br>
 int x = 0;<br>
 int x;<br>
<br>
It becomes problematic when generating and lifting bytecode. It will be problematic for value types that have no default. And, I think is generally problematic when reasoning about variables and definite assignment rules.<br>
<br>
Consider the Java code and the models at the end of this email. Notice that for the lowered pure SSA model the initialization value is no longer used, which makes sense due to the Java language’s rules about definite assignment.<br>
<br>
I think we can solve this by introducing an undefined operation whose result would be used instead of the constant default value:<br>
<br>
   %0 : undefined<int> = undefined;<br>
   %1 : Var<int> = var %0 @"x";<br>
<br>
The above models an uninitialized variable. It states the var is initialized with an undefined value whose type is of int. Allowing var to uniformly accept an operand should allow for more uniform processing and better analysis e.g., when an undefined value
 shows up in places it should not.<br>
<br>
There is probably some other, possibly better, name/concept for this in academic literature.<br>
<br>
Paul.<br>
<br>
   @CodeReflection<br>
   public static int f() {<br>
       int x;<br>
       // x is definitely unassigned<br>
       if (true) {<br>
           x = 1;<br>
       } else {<br>
           x = 0;<br>
       }<br>
       // x is definitely assigned<br>
       return x;<br>
   }<br>
<br>
<br>
Model produced by the compiler:<br>
<br>
func @"f" ()int -> {<br>
   %0 : int = constant @"0";<br>
   %1 : Var<int> = var %0 @"x";<br>
   java.if<br>
       ()boolean -> {<br>
           %2 : boolean = constant @"true";<br>
           yield %2;<br>
       }<br>
       ()void -> {<br>
           %3 : int = constant @"1";<br>
           var.store %1 %3;<br>
           yield;<br>
       }<br>
       ()void -> {<br>
           %4 : int = constant @"0";<br>
           var.store %1 %4;<br>
           yield;<br>
       };<br>
   %5 : int = var.load %1;<br>
   return %5;<br>
};<br>
<br>
<br>
Lowered model:<br>
<br>
func @"f" ()int -> {<br>
   %0 : int = constant @"0";<br>
   %1 : Var<int> = var %0 @"x";<br>
   %2 : boolean = constant @"true";<br>
   cbranch %2 ^block_1 ^block_2;<br>
<br>
 ^block_1:<br>
   %3 : int = constant @"1";<br>
   var.store %1 %3;<br>
   branch ^block_3;<br>
<br>
 ^block_2:<br>
   %4 : int = constant @"0";<br>
   var.store %1 %4;<br>
   branch ^block_3;<br>
<br>
 ^block_3:<br>
   %5 : int = var.load %1;<br>
   return %5;<br>
};<br>
<br>
<br>
Lowered and pure SSA model:<br>
<br>
func @"f" ()int -> {<br>
   %0 : int = constant @"0";<br>
   %1 : boolean = constant @"true";<br>
   cbranch %1 ^block_1 ^block_2;<br>
<br>
 ^block_1:<br>
   %2 : int = constant @"1";<br>
   branch ^block_3(%2);<br>
<br>
 ^block_2:<br>
   %3 : int = constant @"0";<br>
   branch ^block_3(%3);<br>
<br>
 ^block_3(%4 : int):<br>
   return %4;<br>
};<br>
<br>
<br>
<br>
</div>
</div>
</blockquote>
</div>
<br>
</div>
</div>
</body>
</html>