<div dir="ltr"><div style>Hi,</div><div><br></div>While working on adding newlib to my backend I hit the following assert :<br><br>Assertion failed: BestRC && "Couldn't find the register class", file TargetRegisterInfo.cpp, line 112<br>
<br>The following llvm causes this :<br><br><div>define void @specialBreak(i8* %out) nounwind {</div><div>entry:</div><div> %out.addr = alloca i8*, align 4</div><div> store i8* %out, i8** %out.addr, align 4</div><div> %0 = load i8** %out.addr, align 4</div>
<div> %call = call signext i8 @cnv(i8* %0)</div><div> %1 = load i8** %out.addr, align 4</div><div> %arrayidx = getelementptr inbounds i8* %1, i32 0</div><div> store i8 %call, i8* %arrayidx, align 1</div><div> ret void</div>
<div>}</div><div><br></div><div>declare signext i8 @cnv(i8*)<br><br>Now originally (at the time I hadn't added 8/16 bit register support) I had made the calling convention return values promote i8 & i16 to i32 :<br>
<br><div>def RetCC_test : CallingConv<[</div><div> // Promote i8 returns to i32.</div><div> CCIfType<[i8], CCPromoteToType<i32>>,</div><div> // Promote i16 returns to i32.</div><div> CCIfType<[i16], CCPromoteToType<i32>>,</div>
<div><br></div><div> // i32 are returned in register R0</div><div> CCIfType<[i32], CCAssignToReg<[R0L]>></div><div>]>;</div></div><div style><br>I've now changed this to :<br><br><div>def RetCC_test : CallingConv<[</div>
<div> // i8 are returned in register R0</div><div> CCIfType<[i8], CCAssignToReg<[R0B]>>,</div><div> // i16 are returned in register R0</div><div> CCIfType<[i16], CCAssignToReg<[R0W]>>,</div><div>
// i32 are returned in register R0</div><div> CCIfType<[i32], CCAssignToReg<[R0L]>></div><div>]>;</div><div><br></div><div style>Which has stopped the assert and produced valid code. <br><br>I`m happy to leave the return value definitions as they are now, but was wondering if it perhaps points to something I've missed elsewhere as to why the original promoted convention would fail.</div>
<div style><br></div><div style> </div><div style> Lee</div></div></div>