|  | 
| Strange behaviour with memory pointer calculation (*solved*) - Printable Version +- Boriel Basic Forum (https://forum.boriel.com) +-- Forum: Compilers and Computer Languages (https://forum.boriel.com/forumdisplay.php?fid=12) +--- Forum: ZX Basic Compiler (https://forum.boriel.com/forumdisplay.php?fid=11) +---- Forum: Bug Reports (https://forum.boriel.com/forumdisplay.php?fid=15) +---- Thread: Strange behaviour with memory pointer calculation (*solved*) (/showthread.php?tid=809) | 
| Strange behaviour with memory pointer calculation (*solved*) - LTee - 2017-06-25 Splitting this out from the other thread, sorry.  In 1.6.2 there seems to be something weird going on when I perform calculations on memory pointers. My program switches between various banks of UDGs by POKEing 23675/23676 to point to different addresses. When I compiled with the 1.6.2 I noticed that none of my UDGs were working properly. After some experimentation I discovered that the maths I was using to calculate the high and low byte values was giving the wrong values for some reason. Take a look at this program, which I adapted from my main program (hence it looking a bit weird, sorry): Code: dim n, b as ubyteWhen I run this the address of the UDGS bank is 32793. The first two calculations that I print directly (without assigning to a variable) work as I would expect - the value is 128. But when I do the same calculation and assign it to ubyte 'b', the value suddenly becomes 254. This same program produces '128' in all PRINT statements using version 1.5.3 of ZX Basic. I've no idea what's going on there, unfortunately. Sorry!   Re: Strange behaviour with memory pointer calculation - boriel - 2017-06-27 Thanks for reporting! this is a bug in the compiler. Will fix it ASAP :roll: Re: Strange behaviour with memory pointer calculation - boriel - 2017-06-28 Can you download version 1.6.4 and test it again, please? :roll: Re: Strange behaviour with memory pointer calculation - LTee - 2017-06-29 Thanks, boriel - it's much appreciated as always. This one behaves better than 1.6.2, but I'm still having trouble with the other part of my calculation - I revised the test program to show this by adding a few extra lines: Code: dim n, b, c as ubyteThe (slightly dodgy, please forgive me - I was trying to do the whole thing in one line) code to calculate the high and low byte values for the UDG pointer is now getting one of the two values right but the other one is still wrong unless I assign the memory pointer to a variable first. When I run the new test the value of @UDGS is 24601, so I would expect the values of b and c to be 96 and 25 respectively. Looking at the second set of results (where I assign @UDGS to the variable 'x' first) you can see this is what I get. But on the first set of results where I do the calculations with @UDGS directly the 'c' calculation results in '24576' rather than '25', so the byte value becomes '0'. Sorry if this is a bit of a pain - I realise I could just adjust the code and avoid the issue entirely but I'm not sure how likely it is that the problem will appear elsewhere...   Re: Strange behaviour with memory pointer calculation - boriel - 2017-06-30 LTee Wrote:Sorry if this is a bit of a pain - I realise I could just adjust the code and avoid the issue entirely but I'm not sure how likely it is that the problem will appear elsewhere...On the contrary, it's me who must thank you! :roll: This is what the compiler needs (more testing) and it's a way to contribute to it. I'll check it ASAP. Thx. Re: Strange behaviour with memory pointer calculation - boriel - 2017-07-01 OK, I think It's fixed now. Can you download version 1.6.6 and test it, please? :roll: Re: Strange behaviour with memory pointer calculation - LTee - 2017-07-01 Looking good, boriel - all my UDGs are back to normal and all of my other test programs are passing perfectly! I think you can mark this one as solved, thanks so much for the help! Re: Strange behaviour with memory pointer calculation - boriel - 2017-07-02 You're welcome   |