CCS C Software and Maintenance Offers
FAQFAQ   FAQForum Help   FAQOfficial CCS Support   SearchSearch  RegisterRegister 

ProfileProfile   Log in to check your private messagesLog in to check your private messages   Log inLog in 

CCS does not monitor this forum on a regular basis.

Please do not post bug reports on this forum. Send them to CCS Technical Support

Bootloader Problem 18F66K22

 
Post new topic   Reply to topic    CCS Forum Index -> General CCS C Discussion
View previous topic :: View next topic  
Author Message
Cogitum



Joined: 22 Mar 2012
Posts: 70
Location: France (Paris)

View user's profile Send private message

Bootloader Problem 18F66K22
PostPosted: Wed Jun 05, 2019 7:18 am     Reply with quote

Hello
My compiler 5.078
I am using a program that uses an ADXL365 and an MS5611 with I2C link
and PIC 18F66K22 at 20MHz.
The program compiles and works. MEMORY USE RAM 54% ROM 13%
I am trying to use the bootloader found in the CCS samples.
I tried the bootloader mode with different program (flashing LED + RS232 to TERMINAL)
All these programs made with and without bootloader.
The ADXL345 and MS5611 program does not compile if I add:
#include <bootloader.h>
It generates the errors below:

>>> Warning 228 "18F66K22_accel_alti.c" Line 58(9,15): Memory not available at requested location
--- Info 300 "18F66K22_accel_alti.c" Line 793(8,9): More info: Segment at 00000-004FE (0000 used) Priv
--- Info 300 "18F66K22_accel_alti.c" Line 793(8,9): More info: Segment at 00500-0FFFE (0000 used)
--- Info 300 "18F66K22_accel_alti.c" Line 793(8,9): More info: Segment at 10000-1FFFE (0000 used)
--- Info 300 "18F66K22_accel_alti.c" Line 793(8,9): More info: Attempted to create: 00002-00004 for reset
*** Error 126 "18F66K22_accel_alti.c" Line 793(8,9): Invalid ORG range
1 Errors, 1 Warnings.
Build Failed.

Thanks in advance for your help

Best regards

Cogitum
PCM programmer



Joined: 06 Sep 2003
Posts: 21708

View user's profile Send private message

PostPosted: Wed Jun 05, 2019 8:58 am     Reply with quote

Search for that phrase. Set it to search for all terms.
Here are two of the threads. There are a few others:

#import to combine bootloader with application code -
http://www.ccsinfo.com/forum/viewtopic.php?t=55241

Memory not available at requested location -
http://www.ccsinfo.com/forum/viewtopic.php?t=45650
Ttelmah



Joined: 11 Mar 2010
Posts: 19535

View user's profile Send private message

PostPosted: Wed Jun 05, 2019 9:36 am     Reply with quote

Also, post what is actually 'in' line 793 of 18F66K22_accel_alti.c.
Remember if the code itself contains #ORG statements (or anything else
that forces compilation 'at' a specific address), these will need to be changed
to match the new address when the bootloader is used.
Cogitum



Joined: 22 Mar 2012
Posts: 70
Location: France (Paris)

View user's profile Send private message

Bootloader Problem 18F66K22 next
PostPosted: Thu Jun 06, 2019 3:02 am     Reply with quote

Hello PCM programmer
Hello Ttelmah
Thank you both for your answers.
I did another test with ADXL365 alone.
The result is the same.
Line 783 is: "}."
The same line 793 "}" in the ACCEL + ALTIMETER program
=======================================
Here are the lines from the beginning of the ACCEL ALONE program
=======================================
Code:
#include <18F66K22_accel_alti.h>                             
 
 // #include <bootloader.h>

#include <stdio.h>                                 
#include <string.h>                                                 
#include <stdlib.h>                                                     
#include <math.h>                                                                                                                 
//! #zero_ram                                                             
#define ACCEL_WRITE_ADDR   0XA6  // suivant cablage !
#define ACCEL_READ_ADDR    0XA7                       
#define ACCEL_DATA_ADDR    0x32                                     
#define ACCEL_PWRCTRL_ADDR 0x2d                                   
#define ACCEL_MEASURE_MODE 0x08                                                                   
#define BP PIN_B0     
//_____ M A C R O S
#define ADDR_W       0xEE // Module address write mode     suivant cablage             
#define ADDR_R       0xEF // Module address read mode
#define CMD_RESET    0x1E // ADC reset command                                     
#define CMD_ADC_READ 0x00 // ADC read command
#define CMD_ADC_CONV 0x40 // ADC conversion command                   
#define CMD_ADC_D1   0x00 // ADC D1 conversion Pression
#define CMD_ADC_D2   0x10 // ADC D2 conversion TEMPERATURE
#define CMD_ADC_256  0x00 // ADC OSR=256
#define CMD_ADC_512  0x02 // ADC OSR=512
#define CMD_ADC_1024 0x04 // ADC OSR=1024
#define CMD_ADC_2048 0x06 // ADC OSR=2048                       
#define CMD_ADC_4096 0x08 // ADC OSR=4096
#define CMD_PROM_RD  0xA0 // Prom read command 
//#define LED_TEST     PIN_B5

//
#define EEPROM_ADRESS 10    // Location in EEPROM 10

#build(reset=0x0002) 
#ROM 0 = {0xFFFF}     // Insert NOP at address 0

#define max_buffer_size 150    // Taille maxi     
#define TempsGeoOn        300  //  60 // Temps attente geo ON en secondes, soit 10 Minutes
#define TempsGeoOffCourt  900  // 120 // Temps attente geo Off COURT (si PinB3 à 0)en secondes  soit une journée
#define TempsGeoOffLong  1800 // 180 // Temps attente geo Off LONG (si PinB3 à 1) en secondes, soit 7 jours

Best regards

Cogitum
temtronic



Joined: 01 Jul 2010
Posts: 9241
Location: Greensville,Ontario

View user's profile Send private message

PostPosted: Thu Jun 06, 2019 5:13 am     Reply with quote

this...
Quote:
Line 783 is: "}."

makes no sense to me...

Please post the lines above that line.

The original error sounds like the 18F66K22_accel_alti.c code wants to be located at a specific memory location.

You should post that code as well, at least the first few lines of code.

Jay
Cogitum



Joined: 22 Mar 2012
Posts: 70
Location: France (Paris)

View user's profile Send private message

Bootloader Problem 18F66K22 next_02
PostPosted: Thu Jun 06, 2019 5:55 am     Reply with quote

Hello Temtronic,

Thanks for your help

I agree with you "no sense" but however ...have a look ;

(it' not the same line number after some change) now number is 605

Maybe I solve the problem ...

Line 37 #define EEPROM_ADRESS 10 // Location in EEPROM
Line 38 #build(reset=0x0002)
Line 39 #ROM 0 = {0xFFFF} // Insert NOP at address 0

IF I put this 3 lines in "REM" i can compile the program.

After another test ONLY with LINE 38 in REM I can compile too.

Best regards


Laughing
temtronic



Joined: 01 Jul 2010
Posts: 9241
Location: Greensville,Ontario

View user's profile Send private message

PostPosted: Thu Jun 06, 2019 7:21 am     Reply with quote

Put those 3 line back in, and compile, when it fails, remark ONE line, recompile. If it does compile then the 'remarked' line is the problem.
Cogitum



Joined: 22 Mar 2012
Posts: 70
Location: France (Paris)

View user's profile Send private message

Bootloader Problem 18F66K22 SOLVED
PostPosted: Thu Jun 06, 2019 8:13 am     Reply with quote

Very Happy

Hello Temtronic

I have already done this test. Indeed this line generates the error and the compiler does a little anything.

#build(reset=0x0002)

PREVIOUS MSG :
After another test ONLY with LINE 38 in REM I can compile too

Thanks for your help

Best regards
Ttelmah



Joined: 11 Mar 2010
Posts: 19535

View user's profile Send private message

PostPosted: Thu Jun 06, 2019 11:40 am     Reply with quote

This is not going to work:

Line 37 #define EEPROM_ADRESS 10 // Location in EEPROM
Line 38 #build(reset=0x0002)
Line 39 #ROM 0 = {0xFFFF} // Insert NOP at address 0

The _bootloader_ is at address 0.

You need to move this to be above 'loader end'.

Why have you got this?. What is the point of putting a NOP at address 0?.
Display posts from previous:   
Post new topic   Reply to topic    CCS Forum Index -> General CCS C Discussion All times are GMT - 6 Hours
Page 1 of 1

 
Jump to:  
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