Hello, If we create 2 Banks for our project, for using more than 64K program. 1.We wanted to common SRAM for both the banks. Please describe how we can control the SRAM with 2 banks program; 2.When we create 2 banks for program; after compile; our SRAM getting dubbeld Details: >> We are using 89C51X2BN, with External EP-Rom Winbond 27C010-70, SRAM: 62-256 >> earlier we are using Franklin 3.2; (Dos Based Compiler) and we created 2 different Hex Files(1 Main Program and 2 Print Program) with this our product working perfectly,) the same we did in Keil PK51) The system start working but when we use 2 part program; and same time used 1 Part program > system goes hang) After seen the Code banking on keil site, we did required correction; result our SRAM dubbeld. Please guide us.
"I have to admit I'm not entirely clear on exactly what the OP's problem is." I think we're all pretty baffled! "Perversely we will compile both the files (line20 & print20) separately..." Perverse is certainly the right word! I think Hans-Bernhard has probably managed to penetrate the fog the best so far. Like he says, it sounds like your original concept is not code banking at all - it's two entirely independant programs that just happen to be in the same ROM. "at that time we are getting same XDATA address for both the files." How do you know that? the Compiler does not assign addresses; this is only done by the Linker - unless you've defined every single variable using _at_... "Now we tried to use code banking with linking the both the files, so we declaring both the variables as external" No, that can't work - they can't both be external! You must have one of them define the data, and the other reference it via external declarations - as Hans-Bernhard said. You really need to stand back and get the principle right before trying it on this monster system (2x 60K in a single 8051!!): Write two very simple programs that share just a couple of variables, and get that working - something so simple that you can easily post the whole code here. Once you've got this working, you can go back to applying it to the big system
"I have to admit I'm not entirely clear on exactly what the OP's problem is." Me too! Perhaps it'd help if Sandeep explained what it is that he's actually trying to do? Why does he have two independent (apparently), very large programs that he's trying to load onto the same processor? Never mind implementation details (code banking, etc) what is the system actually supposed to do?
Perverse is certainly the right word! Well, I prefer to think he actually meant to say "previously", though ;-> How do you know that? the Compiler does not assign addresses; this is only done by the Linker - unless you've defined every single variable using _at_... He said "at that time" --- by which he means eons ago, using C51 version 3.20. And he thinks he knows because the system appeared to work, back then. Now, if one really wanted to, I think one could still achieve that for separately compiled programs, even with the latest C51. You could do one of the following: * turn on the "keep variables in order" option in C51, and run an appropriately tuned 'diff' on the two map files, to check that it actually worked out * use LX51 options "PUBLICSONLY" and "MERGEPUBLICS" (currently only in the preliminary online manual, but not in any release notes???) to bound one program's definitions to the other program's declarations * Extract one program's public symbols from its map file, and transform them into _at_ declarations to be used by the other(s). But in the end of the day, I'm pretty sure that creating a properly banked application is a better overall plan.
Thanks, you understand me ;) We create 2 programs, and than compile it, map it, again compile it. :) and able to run the program. Any way we are working on PK51, and doing correction as required. support needed: Due to above 2 program is belong for one systems, now we wanted to correct the code and program as one hex into the ep-rom. if you have some tips, please let us know so we can fix the error fast.
Hello, We are able to compile our current code using code banking. after compiling PK51 generate 2 hex files for programming into the ep-rom. Now we stuck up in one more problem. 1. We are using P89C51 with 4 K internal Flash. We wanted to keep very little code into the micro controller for security only. rest all code we wanted to keep in external Rom, and we don't wanted to modify the micro controller code, wanted to fix the code. When ever we upgrade the program we just reprogram the ep-rom; As per my programmer told that after using code banking; we are unable to create the separate file for micro controllers, we have to program microcontroller each time. We seen the bootloader example, but it is to complex, we wanted to keep very few of function in microcontroller. As seen to other products in our same line, they are also keeping Little code in microcontroller and rest all code in ep-rom. please suggest the solution.