projects
/
fw
/
sdcc
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Small change in valCastLiteral. I think this is a BUG in GCC convertion of
[fw/sdcc]
/
src
/
regression
/
b.c
diff --git
a/src/regression/b.c
b/src/regression/b.c
index 52b81e5cb404392edbae64e1d73da64de5553026..cf09e5c3fe92f2fbe0a942aa9414d550c0e84914 100644
(file)
--- a/
src/regression/b.c
+++ b/
src/regression/b.c
@@
-1,5
+1,6
@@
unsigned char success = 0;
unsigned char success = 0;
+unsigned char dummy = 0;
unsigned char uchar0=0;
unsigned char uchar1=0;
unsigned char uchar0=0;
unsigned char uchar1=0;
@@
-8,21
+9,37
@@
unsigned char uchar2=0;
void done(void)
{
void done(void)
{
-
success
++;
+
dummy
++;
}
}
-
+/*
void incptr(unsigned char *ucP)
{
*ucP = *ucP + 1;
}
void incptr(unsigned char *ucP)
{
*ucP = *ucP + 1;
}
+*/
void inc(unsigned char k)
{
uchar0 = uchar0 + k;
void inc(unsigned char k)
{
uchar0 = uchar0 + k;
- uchar1 = uchar1 + uchar0;
- uchar2 = uchar1 + k;
}
}
+void f1(void)
+{
+
+ uchar2++;
+}
+
+void nested_call(unsigned char u)
+{
+
+ f1();
+ uchar1 = uchar1 + u;
+ inc(uchar1);
+
+}
+ // uchar1 = uchar1 + uchar0;
+ // uchar2 = uchar1 + k;
+
void main(void)
{
void main(void)
{
@@
-31,5
+48,14
@@
void main(void)
inc(uchar0);
if(uchar0 !=2)
success++;
inc(uchar0);
if(uchar0 !=2)
success++;
+
+ uchar0 = 2;
+ uchar1 = 1;
+ uchar2 = 1;
+ nested_call(uchar2);
+
+ if(uchar0 !=4)
+ success++;
+
done();
}
done();
}