|
|
View previous topic :: View next topic |
Author |
Message |
neochrome32
Joined: 09 Jun 2013 Posts: 153
|
Virtual RAM Help |
Posted: Thu Dec 26, 2013 12:22 am |
|
|
CCS C 4:130
Ok, here is a pretty much out there idea... now please note:
* SSD1963 is 800x480 24bit colour LCD (i've set it to use 16bit colours only).
NOW this leaves about 400 KBytes to play with.
I've mapped the memory by a simple function, basically I'm drawing pixels OFF the screen (can't see it and it works!).
Since it is 16bit I'm losing 8bits per pixel (memory cell) which to be fair no worries for now.
Now what i want to do is figure out a way to make my MCU "POINT" to the "External ram"
Right as you know
Code: |
typedef struct {
int8 x,y,z;
} datainf;
datainf demo[2];
|
NOW as you know this allocates a location in the MCU rams, for 2 of demos
demo[0].x = 0; and so forth.. but make a few of these and you run out of ram..
I don't know how to approach this really as i do want to use the cpu's ram for registers only and allow to use 400 Kb for regular variables and lists...
I am considering an array of memory locations and sizes eg.
Code: |
typedef struct {
int32 alloc;
int16 size;
} memoryinf;
memoryinf variables[800];
|
and so there for would do something like
variables[0].size = sizeof(datainf) * 8; // expect 8 arrays
variables[0].alloc = ext_malloc(variables[0].size); // find a location in ram that will work with this.
as you can imagine though, variables[0..800]; it soaks up ram!??
any input at this point would be awesome!
Thank you guys in advance.
(the project WILL load files into the FAKE RAM and run and show and play back the data from these areas...) |
|
|
temtronic
Joined: 01 Jul 2010 Posts: 9290 Location: Greensville,Ontario
|
|
Posted: Thu Dec 26, 2013 6:36 am |
|
|
comment: It sounds like you want to use the LCD modules RAM for data storage for the progam. That isn't a big deal.The LCD datasheet should have a 'memory map' or table describing how to access it.Even the common 2x16 LCD units have that! Writing to non-display memory locations saves the data, it just doesn't get displayed and if enabled, you can read back the LCD ram data. I imagine the LCD memory may be setup as 'blocks' or 'pages' so that several 'screens' or data can be quickly accessed and displayed.PC video cards do this making for fast access even when using QBASIC4.5 so it should be doable. The 'trick' is to read the datasheet,figure out the locations of 'displayable RAM' vs 'hidden RAM', code the algorithms to access it,try with KNOWN data,recode as required,retest,etc.Speed might be an issue depending on how you want to use the 'vitrual RAM' within your program and only testing will tell.
hth
jay |
|
|
Ttelmah
Joined: 11 Mar 2010 Posts: 19614
|
|
Posted: Thu Dec 26, 2013 8:04 am |
|
|
What you seem to want is addressmod.
This allows the CPU to access variables stored in external memory.
Problem is that while it was working a few compilers ago, it has been broken for the last few - for few, read 'large number' - compilers.
It is one of those 'brilliant' features, that CCS need to get working....
Best Wishes |
|
|
neochrome32
Joined: 09 Jun 2013 Posts: 153
|
|
Posted: Thu Dec 26, 2013 5:56 pm |
|
|
@Ttelmah : Thanks for the info, i didn't know CCS had an external Variable stuff as that would have made things so very simply. Hope they fix it soon, but is there anyone that may have written some sort of algorithm.
@temtronic : I'm aware of the ram available, what I'm after is code to make USE of the ram in terms of CPU pointers, and variables.
Is the code still available for making use of External memory ? not just using ext_write(address,value); I'm talking about making it work using real declarations.
?? |
|
|
neochrome32
Joined: 09 Jun 2013 Posts: 153
|
|
Posted: Thu Dec 26, 2013 8:55 pm |
|
|
i run 4.130, was the addressmod function broken after this? or before? i can only go back to 4.114
ok seems to be ok ;
problem is, the addressmod doesn't work all that great with strcpy :( |
|
|
neochrome32
Joined: 09 Jun 2013 Posts: 153
|
|
Posted: Fri Dec 27, 2013 3:01 pm |
|
|
addressmod its precicly what i needed!!! THANK YOU !!!
only issue i have is how to use malloc with it too? it works but it didn't seem to work beyond the pics physical ram
sooo need a way around this too |
|
|
jeremiah
Joined: 20 Jul 2010 Posts: 1362
|
|
Posted: Fri Dec 27, 2013 3:25 pm |
|
|
You really really really should avoid using malloc or any dynamic memory. The PIC really isn't suited for that typically. There is almost never a need to use it. |
|
|
neochrome32
Joined: 09 Jun 2013 Posts: 153
|
|
Posted: Fri Dec 27, 2013 7:17 pm |
|
|
There is about 256Kb available to me (after altering the addressmod thing) - so messing about with static memory is ok, just seems extremely wasteful.
I'm thinking writing my own malloc system, be a bit slower, BUT why not |
|
|
jeremiah
Joined: 20 Jul 2010 Posts: 1362
|
|
Posted: Fri Dec 27, 2013 7:33 pm |
|
|
Dynamic memory is going to be both more wasteful (on average) and slower than static. With Dynamic Memory, a memory pool will need to be allocated as well resources to manage it. Both of those waste memory that could be used for other things.
I'll agree it is a fun thing to do if you are making your own memory management module (I use to play around making virtual functions for structures in CCS...virtual table and all, so I understand the fun factor), but it usually isn't a good idea for anything commercial grade. |
|
|
neochrome32
Joined: 09 Jun 2013 Posts: 153
|
|
Posted: Fri Dec 27, 2013 8:26 pm |
|
|
BOOO... oh well
ok I'm still having issues though
for some reason,
vram int16 test;
test=50;
sprintf (txt, "%lu", test);
this doesn't work, it says not a valid format! lol is the addressmod only able to use Signed stuff? as its screwed up alot of my code :(
scratched away the malloc stuff though, no need for it i guess then |
|
|
jeremiah
Joined: 20 Jul 2010 Posts: 1362
|
|
Posted: Sat Dec 28, 2013 10:47 am |
|
|
might be a compiler bug for your version. I just tried in 5.010 and it compiled fine. Try swapping the order VRAM and int16 around in front of test.
EDIT: however, in version 5.010 addressmod itself doesn't work properly. I emailed a bug report to CCS support the other day, but christmas season, so probably won't hear from them for a bit. |
|
|
neochrome32
Joined: 09 Jun 2013 Posts: 153
|
|
Posted: Sat Dec 28, 2013 11:24 am |
|
|
i dont have 5.010 to be honest, 4.130 is the best one that worked for me, and i DID find that addressmod appears to be really in favour of SIGNED values!
even structs, i found that
typedef struct {
int16 x,y,z;
int8 a,b,c;
} test;
this was all messed up, it didn't work until i made a,b,c all 16bit
looks like the struct is widened up to the largest number?
and pointers are messy but they do work now!
THANK YOU
EDIT:: i cant seem to use strcpy(txt, "HELLO WORLD")
eg,
FakeRAM char txt[32];
strcpy(txt, "hello");
doesnt seem to work either
i have to run a loop to insert them from a text from a real string! |
|
|
neochrome32
Joined: 09 Jun 2013 Posts: 153
|
|
Posted: Wed Jan 01, 2014 9:03 pm |
|
|
Sorry another question, i cant seem to find any infomation about addressmod limitations
i realise that the addressmod it self can only address up to 64kb or something like (seems to be able to for me right now) but i need more memory
can i use multiple addressmods?
Code: |
void write_ram(int32 addr, char data){
Address_set(addr, ram_y_offset, addr, ram_y_offset); // area to grab LCD_WR_DATA(data);
LCD_WR_DATA(data);
}
int8 read_ram(unsigned int32 addr){
Address_set(addr, ram_y_offset, addr, ram_y_offset); // area to grab
LCD_WR_REG(CMD_RD_MEMSTART);// Time to read from Screen area
return Read_Datafast();
}
void write_ram2(int32 addr, char data){
Address_set(addr, ram_y_offset + page2, addr, ram_y_offset); // area to grab LCD_WR_DATA(data);
LCD_WR_DATA(data);
}
int8 read_ram2(unsigned int32 addr){
Address_set(addr, ram_y_offset, addr, ram_y_offset); // area to grab
LCD_WR_REG(CMD_RD_MEMSTART);// Time to read from Screen area
return Read_Datafast();
}
void ram_read(unsigned int32 addr,int8 *ram, int8 nbytes){
int i;
//nbytes=2;
for(i=0;i<nbytes;i++,ram++,addr++)
*ram=read_ram(addr);
}
void ram_write(unsigned int32 addr,int8 *ram, int8 nbytes){
int i;
//nbytes=2;
for(i=0;i<nbytes;i++,ram++,addr++)
write_ram(addr,*ram);
}
void ram_read2(unsigned int32 addr,int8 *ram, int8 nbytes){
int i;
//nbytes=2;
for(i=0;i<nbytes;i++,ram++,addr++)
*ram=read_ram2(addr);
}
void ram_write2(unsigned int32 addr,int8 *ram, int8 nbytes){
int i;
//nbytes=2;
for(i=0;i<nbytes;i++,ram++,addr++)
write_ram2(addr,*ram);
}
addressmod( FRAM, ram_read, ram_write, 0, 0xFFFF ); // text infos
addressmod( BRAM, ram_read2, ram_write2, 0, 0xFFFF ); // buttons and lists
|
i realise the code is very crude here but i have 400KB available of use and i wanna try it all?
or does addressmod have the ability to address 0-<a huge size> |
|
|
|
|
You cannot post new topics in this forum You cannot reply to topics in this forum You cannot edit your posts in this forum You cannot delete your posts in this forum You cannot vote in polls in this forum
|
Powered by phpBB © 2001, 2005 phpBB Group
|